-
Notifications
You must be signed in to change notification settings - Fork 735
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
Device > Channels > Import > The "Task finished" snackbar is never shown #12965
Comments
Thanks @pcenov |
Yes - ensuring that the task finished snackbar properly displays when a task finishes would be what is needed! |
@rtibbles Could you please assign the issue to me? I would like to give it a try. |
Thank you both for your willingness to help with this! We only need one person to handle it at a time, and since @shruti862 asked first, I'll assign it to them. |
Hi @LianaHarris360 , I noticed that this issue is still open, and it seems @shruti862 is not actively working on it. Could you please assign this issue to me? I'd like to take it up |
Hi @karankoder, we'll wait another week since the holidays are coming to an end. If there's no update by then, I'll hand it over to @ananyakaligal if they are still interested, if not I'll assign to you. @shruti862, can you let me know if you will be working on this? |
@LianaHarris360 Yes, I am working on it; I have already inspected the cause of issue but due to the holidays I thought to share afterwards ,By tonight I will share my work. |
Thanks for the update and your thoughtfulness in waiting until after the holidays to share @shruti862! It's great that you're making progress, there's no rush to share it by tonight :) |
@rtibbles @pcenov ,After inspecting the issue I noticed that watcher on computed property (watchedTaskHasFinished ) is not being triggered in taskNotificationMixin.js file due to which createTaskFinishedSnackbar() method is not called leading to no display of finished Snackbar. But I was unable to inspect the cause of watcher not being triggered because both watchedTaskId and watchedTaskHasFinished values are changing on task starting and on ending..Could you please suggest me something which can help me figure out the problem
|
Hrm, that is tricky - and this watcher is never called at all?
Or is it called only with a falsy value so it doesn't get past the |
@rtibbles, According to my finding watchers is never called, But when I tried to call it on initial render by using immediate:true , it does triggered because at that time it is not dependent on change in a computed property. |
Hey @shruti862! Are we sure that this taskNotificationMixin is being used in that page? I just added a console.log on mounted, but didnt see any outputs in the console. Can you double check if that mixin is used in the manage tasks page? |
Hey @AlexVelezLl After inspecting using vue devtool I found that in manageChannelContentPage, on clicking delete button handleDeleteSubmit method evoke which has this.onTaskSuccess method which displays 'Task started' Snackbar through notifyAndWatchTask(task)
and it also have this onWatchedTaskFinished() method which is supposed to be used by taskNotificationMixin to display 'Task Finished' Snackbar
|
@AlexVelezLl I found nothing revelant in ManageTaskPage which is responsible for displaying Snackbar |
It seems reasonable that there may be an issue in the reactivity of I would look and see if watching either the task itself, or the task's status triggers a watcher? Then we can just check the status in the watcher to see if it has finished and trigger the snackbar based on that? |
Hey @rtibbles ,When I tried to have tasks computed property, it is not updating with finished tasks, it remains a empty array is it due to reactivity issues? In Vuex store taskList is being updated but not reflecting changes in tasks computed property
|
Hey @rtibbles , any suggestions on resolving this reactivity issue would be appreciated so I can start working on it. If there are no updates or if someone else is better suited to take it up, feel free to unassign me so others can contribute. Thanks! |
So, it seems the way that the taskList vuex state is being updated is not triggering reactivity. What is the vuex mutation that is updating it? Where is it being updated? |
Hey @rtibbles , in
|
Hrm, that does look like it shouldn't be falling foul of any of the usual reactive gotchas. Can you try using the See here for guidance: https://vuex.vuejs.org/guide/state.html#the-mapstate-helper (looking at how it is used elsewhere in Kolibri will also help!) |
Hey @rtibbles, Thank you for your suggestion. I will try this approach as well and provide you with updates soon. |
Hey @rtibbles, I tried your suggestion
Before deleting resources computed properties were: After deleting resources, only watchedTaskId is getting updated ( as seen under vuex binding in vue-devtools ),taskList still remains empty array: |
Hi @shruti862, would you be able to debug a bit deeper around what's the reactivity issue around |
If this doesn't help then I'd recommend you track step by step places executed in code that (1) set and (2) retrieve the task list and see at what point exactly the mismatch begins |
@MisRob Thank you for your suggestions I will try to debug it deeper and will provide updates soon. |
Observed behavior
This is a follow-up to #12946 - The "Task finished" snackbar is never shown after successfully importing/exporting or deleting a channel. This is valid for both Kolibri 0.17 and 0.18.
Expected behavior
Should be investigated why is this snackbar not being displayed and if possible it should be restored.
Steps to reproduce the issue
Usage Details
Windows 11, Ubuntu 22 - Chrome
The text was updated successfully, but these errors were encountered: