-
Notifications
You must be signed in to change notification settings - Fork 733
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
Improve router handlers architecture in Coach #11219
Comments
This is a major blocker for any further improvements of loading states on Coach pages --> adding P1 priority |
This might be good for contribution, but probably only if you have a bit of experience with Kolibri already. I would recommend gradual approach - refactoring one page handler at a time, especially for the first few page handlers.
|
@MisRob i would like to work on this issue can you assign it to me. |
Hi @GarvitSinghal47, we'd be happy to have you work on this. Is everything clear in regards to the proposed solution? Feel free to ask any questions before you start working on it, or even jot down briefly the steps you're planning to do here and we will have a look. Please only choose one handler to work on now, for example |
@GarvitSinghal47 I also updated the issue description with some more references |
Most likely related #11238 (comment) |
Hi @GarvitSinghal47, are you working on this or should we unassign you? |
Unassigning due to no activity |
I would like to work on this issue. |
Hey @ShivangRawat30 I've assigned you to the issue please let me know if you have any questions |
@MisRob Could you please provide information about the referenced pull request |
I am having a little trouble understanding the proposal. |
@MisRob this is a pretty complex proposal and I'm wondering if, perhaps, we might be better able to handle the data initialization by way of some kind of I may be misreading a bit -- but if the issue can be reworded as "some pages need some data boostrapped and others don't" then I think moving that logic entirely out of the router would be ideal. For example, a Anyway just some thoughts happy to chat through 1:1 or in a larger discussion as well. |
I agree, @nucleogenesis. This issue is a first step towards us being able to use composables or any other solution. We can't really do much though until we get the promises out of the global hook (unless we want to do everything at once in a big refactor). So the idea is - get rid of the global promises by moving them to current handlers. Then, we can do whatever we want with those separate handlers (e.g. continue refactoring them to composables gradually in the scope of upcoming issues). I think this is aligned with what you suggest? |
@MisRob yeah that makes sense and is probably a good way to do this. So then the major change here (or like the acceptance criteria?), then, is to just extract the logic from the global I think perhaps updating the acceptance criteria to reflect that (ie, that the logic needs to be rehomed) might make things a little bit clearer for @ShivangRawat30 -- in addition to this discussion I hope! Thanks Misha! |
Yes, I will think about a way how to make this more straightforward. Now I can see I mentioned two possible approaches, which doesn't help either. |
@ShivangRawat30 I will follow-up tomorrow |
Also, @ShivangRawat30, meanwhile please ask any clarifying questions, or you could also try to see those problems on you local dev server, preview code I referenced, and perhaps formulate your understanding of the problem in a few bullet points. This will help me to think about ways to reformulate this in a beneficial way. It's a bit more complex issue connected to the way we work with router handlers in the whole Kolibri, but I think if as soon as we are on the same page in regards to what's the core problem, it will be much easier. Thanks both. |
By that, I was trying to suggest that you prepare a pull request for |
@ShivangRawat30 In my attempts to be organized, I added a tasklist to the issue description which references files with routes to be examined and possibly refactored as part of this work. |
@MisRob for the routes in |
Hi @ShivangRawat30, for handlers that do not fetch data, please add promises to their respective components |
@MisRob there are also some routes that doesn't contain any name |
@ShivangRawat30 Ah I see, I think you can just name them somehow :) |
Hi @ShivangRawat30, are you planning to return to this or would it be better to unassign? |
May I work on Task - 3 of refactoring routes in kolibri/plugins/coach/assets/src/routes/index.js? |
Hi @shubh1007, that'd be great! This issue has a pretty high priority since we're planning some features that will need to have this cleaned up. Please have a look at the previous pull requests and conversations as that will help you to understand the strategy since you will continue it in your work. I'd ask if your PR description can have a format like here #11900 - containing the table of refactored places for reference and also ways you navigated to test them as this well help review process and QA. But first, let's see if it's all clear in regard to how to approach the work. |
Thank you for assigning me the issue related to refactoring the routes. I have reviewed the previous pull requests and conversations, but I would appreciate a brief explanation to ensure I understand the task correctly. |
Thanks for looking into it @shubh1007. To sum it up The ultimate goal is to prepare all coach pages so that one day, we can completely remove this part from the global route handler kolibri/kolibri/plugins/coach/assets/src/app.js Lines 93 to 106 in 7ba25fd
This means that at first, we need to prepare all pages that rely implicitly on data fetched by I will use #11900 as example to elaborate on the strategy you would continue. In that PR, the author
After all pages are refactored, we will remove the temporary ignore list together with Is the approach clear overall? Note that some handlers can be used in more than one page, and there can be differences in how we fetch data in pages - sometimes it's via route handler functions, and sometimes in a component. It will be up to you to do code search and understand what's happening page by page. It should be pretty straightforward as it's just a few repeating patterns. In case of doubt, we can discuss in pull requests. It'd be always best to open a PR with just a few places refactored, especially in the beginning. Feel free to use a draft pull request with just one or two routes and ask any questions there. I'd also ask you to note down instructions for testing, similarly to the table in the example PR. Nothing elaborate needed, if you could just note what you did when you were manually previewing refactored pages by yourself. The routes that haven't been refactored yet are listed in the PR tasklist. |
Hey @shubh1007, we need to prioritize this for the upcoming release so the core team is going to finish this issue. Thanks a lot for your contribution! |
Thank you for providing me the opportunity to contribute. |
Happy to! We'd be still glad to have you work on any issues currently marked 'help wanted' any time you're interested. |
Blocks
#11422
Observed behavior
For majority of Coach pages, in addition to fetching data in their individual route handlers (e.g.
showExamsPage
handler), we fetch some of their data in the globalbeforeRoute
handler, which is run before individual route handlers:kolibri/kolibri/plugins/coach/assets/src/app.js
Lines 38 to 57 in 0f7b06c
This approach has the following problems:
1. Slows down navigation (user-facing)
Particularly observable on slower networks when after clicking a coach page, until all global
beforeRoute
promises are finished, user is not even redirected to a new page.2. Limits individual pages ability to control when and how to display loading states (user-facing)
Many pages have their individual handlers that are sometimes connected to local loading states, however there is no way to factor in waiting time for this global
beforeRoute
which often seem to take even more time than promises in individual handlers, causing inaccuracy and discrepancy of loading states.3. It's difficult to build a mental picture of what requests are performed when a page is visited (developer-facing)
Promises in the global
beforeRoute
are run for majority of pages except of few pages listed herekolibri/kolibri/plugins/coach/assets/src/app.js
Line 40 in 0f7b06c
Then, many pages have their separate handlers that have no information or control over the common logic, and are placed in different files.
Expected behavior
Steps to reproduce
Navigate Coach main pages and tabs on slower network
Guidance
To be able to achieve the expected behavior, we need to move promises from the global
beforeRoute
handlerkolibri/kolibri/plugins/coach/assets/src/app.js
Line 26 in 0f7b06c
to individual page handlers.
For example, for
showExamsPage
page handler the steps could be:showExamsPage
:PageNames.EXAMS
kolibri/kolibri/plugins/coach/assets/src/routes/planExamRoutes.js
Lines 27 to 37 in b88a804
Add a condition to the global
beforeRoute
handler instructing it to not run code containing promises fetching data if user is navigating to a page with namePageNames.EXAMS
And instead, copy all those promises to
showExamsPage
This needs to be done for all individual page handlers in Coach. In this manner, it can be done gradually. I would recommend opening one pull request for one handler so we can review and QA loading states easily.
After all individual handlers are updated to have the promises, we can finally remove the promises completely from the global
beforeRoute
handlers.Acceptance criteria
beforeRoute
handler doesn't contain any promises fetching dataTasks
The text was updated successfully, but these errors were encountered: