-
Notifications
You must be signed in to change notification settings - Fork 736
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 polling on the home page to more accurately and quickly display information related to sync statuses #11883
Comments
@marcellamaki Can i give it a shot |
Hi @Technmad! Sure, I'll assign this issue to you :). Thanks for your interest in contributing to Kolibri 👐 |
@AlexVelezLl Thanks for opportunity, I'll start right away |
can I work on this issue, as a GSOC 24' applicant? @AlexVelezLl |
Hi @Technmad! are you still working on this? If @Technmad is no longer working on this, we can assign it to you @Janarthana2992. 👐 |
Hello, since @Technmad did not respond, I will assign this issue to you, @Janarthana2992. Thank you very much for volunteering. Let us know if you have any questions. |
Unassigning as no updates in over 6 months. |
This issue is still open? |
Hi @Jeevansm25! Yes, this issue is still open. I just assigned you another issue so lets wait for now before I assign you this. Once you have a PR for the other issue you can ping us to assign you this one 🤗. |
Thank you for assigning me the other issue 😊. I'll work on it and submit a PR soon. Once it's done, I'll reach out to you for this issue. Thanks again for your guidance and support! 🙌 |
@AlexVelezLl Can you assign this issue to me as @Jeevansm25 is already on other issue. |
Hi @yashhash2! For sure! I will assign this to you. Please let us know if you have any question :) |
Hi @yashhash2, I wanted to mention that Learning Equality will be closed from December 23 to January 5. |
To address the issue of missing resources on lesson and quiz cards, the following approach is proposed: showMissingResource Function: This function will check whether an individual lesson or quiz has a missing_resource flag. If the flag is present, the function will return true, indicating that the warning icon should be displayed for that specific card. Polling for Missing Resources: A polling mechanism will be implemented to check for missing resources every 5 seconds. This polling behavior will update the missing_resource flag for each lesson and quiz, ensuring that the status of resources is regularly refreshed. Conditional Rendering on Cards: A yellow warning icon ( Disabling Card Interaction: If a resource is missing for a particular card, that card will be visually disabled by applying the pointer-events: none CSS style. This will prevent user interaction with the card until the resources are available. This approach will ensure that users receive clear and timely feedback regarding missing or syncing resources on lesson and quiz cards. It will also provide a more intuitive user experience by disabling interaction with cards that lack resources. Let me know if you have any suggestions or feedback on this approach before proceeding with implementation. |
Hi @yashhash2 - overall this sounds like a good summary of the approach needed. Before you get started, I'd like to request that you investigate a little bit more the previous polling implementation on the home page and do some troubleshooting. Then, share a little bit about what you find here and we can decide together a bit more on the specifics of implementation. You can use git history of the files that compose the home page to see if polling is still happening, if it's happening sometimes, or if it's not happening at all. There may be some commits after we implemented it the first time that broke it, or it may just be not polling frequently enough. Building this skill of investigating the underlying causes of bugs in a codebase is a very useful one, and this is a great opportunity to do so. Taking a little bit of extra time early will help you uncover the root cause of the issue and make the best decision about the approach moving forward. After that, we can discuss further what decisions would need to be made for the frontend components, although it seems like you're on the right track. :) Let me know if you have any questions! |
Hi @marcellamaki, I was reviewing the history of components related to the homepage and noticed a change made about a year ago under the commit titled "Rehydrate the home page when syncing has completed to refresh missing resources." This change may be contributing to the issue where the "Resources are missing or not supported" banner persists for too long without disappearing automatically. Potential CauseThe change involved using Reactivity Problems with
|
Hi @yashhash2, thanks for looking into it.
Is this something you've observed yourself or is there some source describing it as a general Vue issue? From your comment, it's not clear to me whether you think that using
Regarding using
Hm yes syncing issues can generally be a bit tricky to reproduce, sorry for the trouble. I wonder if finding the relevant places on frontend and tweaking them to mock backend behaviors that are needed would help. |
Hi @MisRob, Thank you for your thoughtful response and questions. Observations and ContextRegarding the potential impact of using get() on reactivity, my initial hypothesis was based on how @vueuse/core abstracts reactive values. While get() provides consistency and readability, it introduces an abstraction layer over direct .value access. This indirection could theoretically contribute to delayed reactivity updates. However, after manually testing by removing get(), I observed that this is not the root cause of the issue. I apologize for the delay, as I spent time reviewing the timeline of related commits. Updated FindingsThrough further exploration, I discovered that a manual page refresh is required even to reflect assigned resources, even when new resources are available. This behavior suggests that the homepage currently lacks automatic polling to regularly fetch updated data. The absence of polling prevents the "Resources are missing or not supported" banner from disappearing without user intervention. Proposed ApproachTo address this, I propose implementing a manual polling mechanism using setInterval() to fetch data at regular intervals, ensuring the homepage reflects up-to-date resource availability dynamically. Before proceeding, I would appreciate your input on this approach or any alternative strategies you recommend. Additionally, if there are any relevant resources or examples that demonstrate how polling is implemented within Kolibri, I would be grateful for the guidance. Looking forward to your feedback. Best regards, |
Hi @yashhash2, yes, fixing the polling is what we wish to do. As per the issue description
the next step for you would be to search through the code and find out whether there's some polling already implemented but it's broken, or if we lost it completely and it needs to be re-implemented. Please search code carefully. |
Hi @MisRob, I noticed that polling is actively occurring on the page via useUserSyncStatus. However, the issue with the banner not disappearing seems to stem from the ResourceSyncingUiAlert component. Specifically, the @syncComplete="hydrateHomePage" event is not being emitted, which prevents hydrateHomePage from being triggered. In my case, I logged the status value and found that it is consistently "NOT_RECENTLY_SYNCED". As a result, the isSyncing value in the watch function remains false at all times, and the syncComplete event is never emitted. For reference, please find attached the screenshot of the logs: To resolve this, we may need to address the syncing issue or adjust the conditions for emitting the syncComplete event to ensure that hydrateHomePage is triggered successfully. Let me know your thoughts. Best regards, |
Observed in connection with several different issues during the 0.16 sync session on Feb 14 2024
Observed behavior
Desired behavior/Acceptance Criteria
Steps to reproduce
Context
0.16.x
The text was updated successfully, but these errors were encountered: