This page provides more technical information about my experiences and past projects, interview screening tests, sample codes with removed company logic for simplicity, including both ReactJS, .NET Core, Golang, and system design.
Build a simple FE and BE application to demonstrate the use of popular React libraries.
- This project was bootstrapped with Create React App, using the Redux and Redux Toolkit template.
- Integrated with Tailwind CSS.
- Provides basic unit tests for reducers.
- Provides an example of a simple RESTful API Node.js application.
- Technical stack:
- Node.js, TypeScript
- RESTful API hapi, swagger
- MongoDB, Mongoose
- Each service follows a 3-layer architecture.
An application that submits a simple form to the server.
- FrontEnd: Angular application with 2 components to display users and create new ones.
- BackEnd: .NET Core Web API to deliver RESTful API.
Apply Design Thinking, OKR in the process of implementing a new application, integrate with SOAP-based APIs, and standards in healthcare.
FrontEnd stack:
- React, Redux, Next.js
- State management: Redux, Valtio
- Styled-components
- Integrate with block-based Lexical editor (similar to Notion) to provide interactive command-like actions, customize a select node
- Code samples for a React component with hooks, TypeScript type definition, Valtio store, styled-components
- Code samples: a shared component from the design system, customize ReactSelect lib to provide a simpler version and adapt to the current theme
- Implement WebWorkers to prove fuzzy search capacity in the browser for a fixed set of text data
Systems Design using microservices (from modulo-monolith, ready to split into microservices by topics or serverless), event-based programming with nat.io.
BackEnd stack:
- Golang APIs, Dockerize, MongoDB
- Multi-tenant, microservices using nat.io as a service bus
- BFF architecture (ensure simplicity on the FE side, shifting rules and complexity to the BE side for easy testing)
- Switch between Restful APIs and Websocket to retrieve event notification for FE
- CI/CD from GitLab running ShellScript
- End-to-end testing using PlayWright for happy cases
- Custom proto code generation for both API Golang server and API Typescript server for both RESTful API and websocket connection
Here is the portfolio of Readirace game from the Lead designer of 3PL, presenting the idea and implementation.
FrontEnd:
- Using Lottie and animation library to control objects and do animation as per event
- Viewport detection for iOS and Android devices to change the layout when the keyboard shows up (challenging with older iOS versions in Safari)
- Micro-frontend using iframe, sharing authentication tokens, each module hosted in different repositories
Systems Design using Onion Architecture, microservices:
BackEnd:
- Websocket and long-polling connection to ensure data is updated across multiple players in the same room
- Show the number of online users
- Join room
- Technical design 1 Technical design 2 for the game
- Cypress end-to-end testing
- Postman/NewMan to automate API testing
- System design for the report and background request
TripBff is a traveling mobile app that provides a convenient way to import your images and export infographics to Facebook and other social networks.
React Native application repository: TripBffMobile
- React Native, Redux, Redux Thunk
Backend repository: TripBff
- Node.js, Express, MongoDB
- Terraform to deploy to AWS