-
-
Notifications
You must be signed in to change notification settings - Fork 651
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
fix: show overlay again after cancel #2436
Conversation
@mutschler the only issue I'd have with the proposed solution is the assumption that the use case is to always start a tour where you left off. For me, I'd assume |
@chuckcarpenter makes sense! I've hacked together a quick example of what i ment with the proposal, see: 2862cf9 But even if the tour was Here's how i do the "logic" part of it:
This is absolutely fine and i don't think the library should keep track of that BUT this has currently an issue with the modal:
This is the part i think the library should handle i hope this makes it a little bit clearer what i was talking about and what i propose ;) EDIT: so tl;dr: not gonna channge how |
Hey there. We found the same issue in developing our product and I'd like to know if this fix can be merged soon. Thanks! |
src/js/step.js
Outdated
@@ -403,6 +406,10 @@ export class Step extends Evented { | |||
this.tour._setupModal(); | |||
} | |||
|
|||
if (Shepherd.activeTour != this.tour) { | |||
this.tour._setupActiveTour() |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Do we need all the setup or can we just this.tour.modal.show()
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
im not 100% sure since it's been a while since i've wrote this but i the main reason to use _setupActiveTour
here instead of just show
was to make sure the correct tour is flagged as active and the 'activation' events are triggered.
src/js/tour.js
Outdated
@@ -315,6 +315,7 @@ export class Tour extends Evented { | |||
|
|||
if (modalContainer) { | |||
modalContainer.remove(); | |||
this.modal = null |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm wondering if we need to set this to null
or if we can just show/hide the modal?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
again not 100% sure but i think i did this to make sure we re-attach the modal element to dom since modalContainer.remove();
removes the modal completely from the dom show()
will do nothing (since the element is already deleted)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hmm, should we maybe just hide/show it instead of fully removing? It's odd that the overlay behavior is different than the behavior of the tour itself. If the tour works without calling start
again, then we should probably make the modal do the same.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I get your point. I didn't want to temper to much with how the whole tour works. Also after some thinking I actually came to the conclusion that keeping it the way it is/was is probably the best. If you end/cancel a tour it the modal should be removed since it's not needed anymore. If you restart (or choose to continue) the modal gets initialised again. Keeps the dom clean.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Gotcha. Would you be able to write some tests to ensure this continues working as expected going forward? It also looks like we have some lint issues to fix.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I've fixed the lint issues.
Regarding the tests: I haven't written any tests for JS so far but i'll give it a try when i'm back on my machine next week. What would you like me to write a test for?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think we just need a test that covers the workflow you are trying to accomplish like start tour -> advance a couple steps -> end tour -> call show on the step you left off on -> assert that the modal overlay exists and is shown.
If the tour was cancelled at some point the overlay is only shown if you use
tour.start()
if you want to continue the tour afterwards (tour.next()
ortour.show(x)
the overlay is missing.While i get that you should use
tour.start()
after the tour is done, i don't really want to go through everything from the beginning again if i cancel mid tour... especially not sincetour.getCurrentStep()
keeps reporting the last step before the tour was cancelled.This fixes the need of a workaround by manually calling
_setupActiveTour
and_setupModal
when the tour was cancelled and should be resumed.EDIT: oh well... this is basically a enhanced version of #1237
EDIT2: Since you where talking about "coming up with a good fix" in the pull-request linked above... i'm not sure if this would be considered a "good" fix. It's a fix without changing to much of the existing code.
a proposed "better" fix (which requires a bit more changes to the code) might be:
tour.start()
logic in a_init
functioninitialized
state which then will be reset in_done
step.show()
make sure to check ifinitialized
is still valid, else fire_init
againThat would do more or less the same, but IF something should change on the
start/setup
part it would only require one place to keep updated