Skip to content

Latest commit

 

History

History
65 lines (47 loc) · 2.54 KB

File metadata and controls

65 lines (47 loc) · 2.54 KB

Chat

Project Description

Chat for real-time communication in the form of a Single Page Application, or SPA without the use of ready-made frameworks. Independent practical work performed as part of training on the professional program "Middle Frontend Developer".

Sprint 1

  • Designed app layout based on template in Figma.
  • Implemented the main pages of the application using the template engine Handlebars.
  • Customized build using Parcel.
  • Created a dev environment and NodeJS + Express for distributing static files on the local computer.
  • Used preprocessor Less when writing page styles.
  • App is automatically deployed from the deploy branch to Netlify.

Sprint 2

  • Files are structured according to architectural advice. Added component approach.
  • The project is written in TypeScript, taking into account the new components.
  • Configured static code analysis [ESLint] and [Stylelint]. The principles of SOLID, DRY, KISS are used.
  • Added client validation for all forms.
  • Implemented event bus (EventBus.ts).
  • Implemented a component (Block.ts) with its own props, lifecycle and reactive renderer. When changing props (using Proxy).
  • Implemented analog fetch for requests to the server (HTTPTransport.ts).

Sprint 3

  • Implementation of the client router (Route.ts, Router.ts).
  • Client-server interaction and work with requests.
  • Implemented HTTP API for chats, authorization and users.
  • Added api layer.
  • Added controllers layer.
  • Implementation of the central store (Store.ts).
  • Used WebSocket to work with real-time chat messages.
  • The following features are implemented in the application:
    • Registration
    • Authorization
    • Sign Out
    • Change user data
    • Create and add users in chat
    • List of user's chats
    • Sending text messages
  • The project is protected from XSS and DOS.

Sprint 4

  • Added Unit tests for template engine, router, component and request module.
  • Configured build using Webpack.
  • Configured precommit for the project.
  • Used Docker to build a static application.

Installation

  • npm install - install dependencies.
  • npm run dev - run the project in development mode.
  • npm run build - start building the project.
  • npm run start - start the project on the server.
  • npm run test - run tests.