In the last chapter, we learned how to build an app using Vue. There are always two aspects to take care about when we start writing apps. The first one is the logic of the app or the architecture and another one is how to accomodate that architecture using the syntax which our stdlib or framework provides. It is the same in our case as well, we learned how to write an app using Vue in the earlier chapter and we built the core architecture too, which included creating the necessary variables to display content on our web page. The only thing and perhaps the most important thing which we missed was the interaction with the server.
We need to design a few things before we can start hooking our front end with the backend. There are two aspects of interaction with the server
- Fetch everything when the web page is loaded.
- Fetch as per user interaction.
Both methods are fine, but the catch is that when our data is huge, the app becomes slow due to the large data fetch. That is why we end up choosing the second option to fetch data incrementally.
We have the following data flow:
- Load all pending tasks
- If the user interacts with the tasks, do the changes to the Vue data store after sending the changes back to the server.
- If the user clicks on category
- Go back to the server and fetch todos related to the category
- If the user adds/deletes tasks, add them to the Vue data store after sending it back to the server.
- If user clicks on category name/pending => fetch them again (the webserver is our single source of truth)
- Go back to the server and fetch todos related to the category
- If the user clicks on pending/deleted/completed
- Go back to the server and fetch related tasks
This means that in our architecture, we only go back to the server when we need to fetch data, modifying data is done in place after sending the modified data back to the server and if the server responds back with a 200 status code which means everything went fine on the server.
"/task/", Methods("GET") Fetches a new task
"/task/", Methods("PUT") Inserts a new task
"/task/", Methods("POST") Updates a task
"/task/{id}", Methods("DELETE") deletes the task with id
"/deleted/", Methods("GET") Fetches all deleted tasks
"/completed/", Methods("GET") Fetches all completed tasks
"/categories/", Methods("GET") Fetches all categories of the logged in user
"/category/{category}", Methods("GET") Fetches tasks of category 'category'
"/category/{category}", Methods("DELETE") Deletes task 'category'
"/category/{category}", Methods("POST") Updates category name 'category'
"/category/", Methods("PUT") Adds a new category
"/complete-task/{id}", Methods("GET") Marks task #id as complete
"/incomplete-task/{id}", Methods("GET") Marks task #id as incomplete
"/restore-task/{id}", Methods("GET") Restores task #id as pending
"/comment/", Methods("PUT") Adds a comment
"/comment/{id}", Methods("DELETE") Deletes comment #id
"/login/", Methods("POST", "GET") Login; GET sends status 200 if user is logged in, POST will read the form value and update status accordingly
"/logout/", Methods("GET") Logs the user out.
"/signup/", Methods("PUT") Signup page
This is the server backend, you can see it in chapter5/final/Tasks-vue/main.go
.