-
Notifications
You must be signed in to change notification settings - Fork 18
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Build Journal / Log #1
Comments
[Saturday, 8 January, 2022] A few new updates. I have made some major changes in how I plan on building the project. I decided to move from MySQL to MongoDB. With multiple Spaces, Folders, Lists and Tasks nested inside each other, it gets really complicated to represent hierarchical data in a relational database. A NoSQL database seems better suited. In the last 2 days, this is what I have implemented so far. Server
Front End
With this, I think I can no start with the dashboard. I plan on creating a simple and minimal dashboard for now, followed by session management. After I setup a store and create a better way to interact with the backend, I will get started with core features and dashboard. |
[Wednesday, 12 January, 2022] I have completed the authentication part for this app. I have also setup a Higher Order Component called ProtectedRoute that will prevent authorized users for accessing the signup or login page and prevent unauthorized users from accessing the private pages. I also decided to move from my usual Component-Container Architecture to a feature based one. I figured with all the code classified into only 2 categories, it might get messy. It would also become a little harder to navigate through the code and maintain it. Still haven't figured all of the new architecture, but that's ok for now. I have started with the dashboard, specifically with the Navigation Menu. I created a new folder in the features folder and will put all the nav related stuff here. For now, I am dividing the navigation menu into 3 parts- a search bar (to be developed later), a space container (contains spaces, folders, lists, tasks, etc.) and a profile manager (for creating workspaces, settings, logging out, etc) Also, I decided to install Material UI. They have a lot of useful components, and icons that will make my life easy. EDIT |
[Friday, 14 January, 2022] I have created a Model for storing workspace data and modified the User model. Now, when we fetch the user (after authentication step), we will also get an array of id's of workspaces the user owns. On opening the dashboard, we then make another request to fetch other data related to workspaces. This will return an array of objects containing the id and names of all workspaces. At this point, I am not going to fetch the spaces or other details. Only when the user switches to another workspace do we fetch its data recursively. On the front end, I have created a settings menu that appears in the bottom right corner of the page. It has 3 sections- Workspace Selector, Workspace Manager and User Settings. The workspace selector will be used for switching from one workspace to another. It will also allow user to create a new workspace. Before proceeding any further, I am really feeling the need to write unittests. They would certainly make my life easier as I might break some feature while working on another. This way, I won't have to manually test everything. |
[Sunday, 16 January, 2022] I have almost completed the Space Management controllers. Based on what I have done till now, it should be fairly easy to create the rest of the controllers as most of the code is repeated. I also found a logical bug in the code. In the database, we are preventing Workspaces and Spaces from having duplicate names. But this should be avoided as two different users can create workspace with same name. Can't believe I missed this. Today, I will get started on fetching the workspace data recursively for all levels so that we can display it on the UI. |
[Tuesday, 1 February, 2022] Done with recursively fetching workspace data. After all the data is fetched, it gets converted to a form that we can render using components easily. |
[Monday, 28 February 2022] After a long break for exams, I am back again. The navigation menu and corresponding backend is done, which means you can create Workspaces, Spaces, Folders, Nested Folders, Lists and Tasks from the dashboard. You can also switch between workspaces and the contents of this workspace will be shown to you. The only part left in the navbar is editing and deleting all the items. It is a backend task and I plan on doing this at the end. During this time, I realised how important testing (unit and integration) is. So I will start writing tests for all the work I have done till now. P.S. I found this advice on FreeCodeCamp blog about designing react components. Basically it says I should create isolated components that can work on their own and then create a container for them that allows them to interact with outside works (requests and redux). This will also make it easier to test. |
[Thursday, 3 March 2022] I modified a lot of the existing classes. The code looks a lot cleaner and organised now. I also started writing tests. |
[Tuesday, 8 March 2022] I have created some additional dialogs as follows-
I have also started developing the Views. I managed to create the List View, but I think I will scrape that. The view needs to have a lot of capabilities (drag and drop, sorting, grouping, etc.). The List View is probably the most important view and it contains the most features. I am planning on using a library called react-kanban for this. It seems to be easy to use and has a lot of features I might need. So all I have to do is put most of my focus on the styling and the library will handle the rest. I also seem to have stopped writing tests. It is soo hard! Today, I will create some additional widgets required for the Task Dialog. I am also adding some meaningful data on the UI like 'Marketing' and 'Development' spaces, etc. instead of using 'Space 1', 'Folder 1'. Probably backup this data and use it as default when I deploy the project. |
[Friday, 6 May 2022] Well I have been gone for a while. But I am back again. There is a bug in GridView where it become really hard to add new items to a lane that already has no items within. Will fix it soon. I think this is it for Views, I will start writing unittests and integration tests now. I also need to fix the Header Bar as the UI and icons are uber ugly! |
This project will involve a lot of planning and design decisions. Which is why, I am creating this issue.
In this issue, I will be writing my thought process so that I can reflect and take better decisions in the future.
I am also keeping this as a reference for all those who might wish to create a similar project.
First things first, the reason I chose ClickUp for making this clone is because it has a lot of features that should be challenging to implement. Also, I haven't heard of anyone else who has made such a project. If you take a look at the website, you will notice that the UI is amazing. Thus, making the front end will be as hard as implementing the backend.
A major problem I faced here was that ClickUp's policies prevent people from copying anything from their website. This includes their UI as well. So, I will be creating my own design using Adobe XD. This design will be very heavily inspired by ClickUp, but I will make a few tweaks that suite me. In the end, both these websites should be distinct.
I am going to be honest here. This is my first major backend project. I have no idea how to organize the code, what architecture to use or how to design the API. I will do those as I move along. Right now, I will start with creating the Sign Up and Register pages.
I plan on using MySQL as the database. I will post the schema and some description here as soon as I finish it.
Today, I am installing all dependencies.
The text was updated successfully, but these errors were encountered: