Skip to content
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

Enable tour features #639

Merged
merged 9 commits into from
Jan 3, 2018
Merged

Enable tour features #639

merged 9 commits into from
Jan 3, 2018

Conversation

ZachTRice
Copy link
Contributor

@ZachTRice ZachTRice commented Dec 8, 2017

This is a WIP...

Changes in this pull request:

  • Enable tour config feature in main.js
  • Add jquery-ui dialog
  • Change name of Google analytics import name to be consistent with codebase
  • Add autoStart: true to initiate joyride v2.2.0
  • Change feedback.js to export default
  • Fix stylesheet differences between joyride 2.0 and 2.2
  • Re-implement page counter.*
    Note*: The previous version of joyride was customized directly to add this feature:
    https://github.com/nasa-gibs/worldview/search?utf8=%E2%9C%93&q=wv-tour-page-count
  • Restore Previous buttons

- Enable tour config feature in main.js
- Add jquery-ui dialog
- Change name of Google analytics import name to be consistent with codebase
@ghost ghost assigned ZachTRice Dec 8, 2017
@ghost ghost added the under development label Dec 8, 2017
@ZachTRice ZachTRice changed the base branch from master to module-loaders December 8, 2017 20:40
- Add `autoStart: true` to initiate joyride v2.2.0
- Change feedback.js to export default
@ZachTRice ZachTRice force-pushed the module-loaders-tour branch from 0962a9c to 9a7f1c3 Compare December 8, 2017 20:46
- Remove unsupported data-options
- Move depreciated data-option joyride options to html classes
- Fix multiple HTML errors in tour.html and format the HTML properly
- Create CSS to style the tour windows as they were in previous joyride version*
*Note !important classes were used to overwrite !important declarations found in the defauly joyride stylesheets
- Restore step page indicator
- Fix styles related to modal arrow and button hover state
@ZachTRice
Copy link
Contributor Author

@bking, @localjo I can't seem to get the previous buttons to show up. If you get a chance to break away and look at this feature, here is where I am at:

I see joyride examples with previous buttons here: http://zurb.github.io/joyride/

But then I see references to the functionality not working for others, see:
zurb/joyride#184

And it is nowhere mentioned on the official page:
https://zurb.com/playground/jquery-joyride-feature-tour-plugin

Looking at the version we are running on production, it looks like there was significant modification to the previous button code:
https://github.com/nasa-gibs/worldview/blob/e8c796d012ada1f7e9118c27230391dd58042963/web/ext/tour/joyride-2.0.3-3/joyride.js
(If you go through and search for the comment "//BETH" all the code around it seems to have been modified at some point from the original.

Also a few commits related to previous button in the file blame suggest the same
https://github.com/nasa-gibs/worldview/blame/e8c796d012ada1f7e9118c27230391dd58042963/web/ext/tour/joyride-2.0.3-3/joyride.js


If there is no obvious solution here, then it might be best to test the fix linked above, fork the repo, add that fix and then link to our fork in package.json.

@Benjaki2
Copy link
Collaborator

I took a look and agree that a fork is probably necessary.

The working example (http://zurb.github.io/joyride/) isn't using Jquery-joyride so maybe the non-jquery version would work for us if it isn't a lot of work to migrate?

@Benjaki2 Benjaki2 mentioned this pull request Dec 22, 2017
2 tasks
web/css/tour.css Outdated
@@ -22,6 +22,10 @@
width: 450px;
}

.joyride-close-tip {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We didn't have custom .joyride CSS before, and we're including the Joyride stylesheet in this branch already.

We shouldn't have to add custom CSS to our stylesheets to achieve style parity with production. @ZachTRice @Benjaki2 I might have missed something when I included the dependency stylesheets. Maybe the paths aren't correct, or maybe they're in the wrong order or something. Both of you have added dependency styles to stylesheets in your PRs, but I think maybe there's a problem with how I did the CSS originally. Have either of you looked into that?

Copy link
Contributor Author

@ZachTRice ZachTRice Jan 2, 2018

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The version we were using before was modified to add css directly to the plugin. Here is the css blame: https://github.com/nasa-gibs/worldview/blame/master/web/ext/tour/joyride-2.0.3-3/joyride.css

@@ -119,6 +119,7 @@ <h3>Timeline</h3>
<li>Change the interval to "Days" and explore the imagery for that month.</li>
</ul>
</div>
<p class="wv-tour-page-count">(page 1 of 6)</p>
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

How were these <p> tags being added before?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The plugin was a complete hack before. These were added into the core plugin before. There is no native support for this type of functionality.

@Benjaki2 Benjaki2 mentioned this pull request Jan 2, 2018
58 tasks
@@ -30,4 +29,4 @@ export const feedbackModal = (function () {
};

return self;
})();
})({});
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why did you move self from being defined inside the function to being passed in as a parameter?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Discussed in slack chat; export constant does not work in this case. We can look at changing this to a named function when we do a review. Util functions are setup in a similar manner as this.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Does a naming the function change how parameters are passed in? Before, you could call this function with no parameters, feedbackModal(), and it would work fine. Now we have to call the function with an empty object for it to work, feedbackModal({}). Why can't we do var self = {} inside the function like it was before?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good call, I have made this change and tested it.

@@ -7,8 +7,7 @@

import util from './util/util';

export const feedbackModal = (function () {
var self = {};
export default (function (self) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why go from a named export to an unnamed default export?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Discussed in slack chat; export constant does not work in this case. We can look at changing this to a named function when we do a review. Util functions are setup in a similar manner as this.

- Add fork version of jquery.joyride which is a fork of the npm module jquery.joyride and includes a fix to add previous buttons
- Add styling for previous buttons
- Add jquery-ui dark theme
- Fix page count position on last step
- Fix dialog background from not closing properly
- Fix tour completion window appearing when clicking previous on last step
- Add css to move nub position to the right on the last tour step
Copy link
Contributor

@localjo localjo left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good to me!

@localjo localjo merged commit e5dcbdf into module-loaders Jan 3, 2018
@ghost ghost removed the under development label Jan 3, 2018
@localjo localjo deleted the module-loaders-tour branch January 3, 2018 17:51
@localjo localjo added this to the Module Loaders Release (v2.0) milestone Jan 12, 2018
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants