Skip to content

Latest commit

 

History

History
69 lines (47 loc) · 2.2 KB

README.md

File metadata and controls

69 lines (47 loc) · 2.2 KB

Smaply Test Task

Dev setup -

Prerequisites

  • NodeJS
  • NPM or Yarn

Check the version compatibility in the Dev Environment section

Dev Environment

  • NodeJS - v20.15.1
  • NPM - v10.7.0
  • yarn - v1.22.19
  • Ubuntu 20.04

Clone the Repo

git clone [email protected]:shubham43MP/smaply-persona-test.git

Navigate to root directory

cd smaply-persona-test

Install Dependencies

npm install or yarn install

Start the dev environment

yarn run dev or npm run dev

The dev server will come up at localhost:5173

Developed App Screenshots

  • Main page with Modal Main Page with Modal

  • Persona Page Persona page Editor

Dev Comments

  • Used index.ts in various files just to have a kind of modular formatting.
  • Tried to declutter logic and JSX on some files whic were becoming very big all at once
  • Components are of two types - atoms and compounds. Atoms are single elements very small ones while compounds are complex components that can be fairly reused as well
  • Used react quill rich text editor
  • utilised some debouncing hooks and optimised how the events and rendering happens
  • utilised a dynamic data structre to handle both the cards differently in different columns. This has more scope for optimisation based on use case
  • A substantial time elapsed in tailwind config and removing a bottleneck of the inline styles removal as tailwind config was ot very clear on docs and mismatch of opinions about it like an example here This problem was finally solved by exploring tailwind library

What can be improved if more time is provided

  • yjs collaboration havent added due to time considerations as this has a substantial learning curve
  • Designs can be further inch tweaked and made closer including responsiveness.
  • Not implemented Left menubar as found no reference of it in the task description.
  • The RTE can be more customised
  • I have tried to keep the code structure as best as possible but still, there can be minor scope of improvement