annotate core/modules/tour/js/tour.js @ 19:fa3358dc1485 tip

Add ndrum files
author Chris Cannam
date Wed, 28 Aug 2019 13:14:47 +0100
parents 129ea1e6d783
children
rev   line source
Chris@0 1 /**
Chris@0 2 * DO NOT EDIT THIS FILE.
Chris@0 3 * See the following change record for more information,
Chris@0 4 * https://www.drupal.org/node/2815083
Chris@0 5 * @preserve
Chris@0 6 **/
Chris@0 7
Chris@0 8 (function ($, Backbone, Drupal, document) {
Chris@0 9 var queryString = decodeURI(window.location.search);
Chris@0 10
Chris@0 11 Drupal.behaviors.tour = {
Chris@0 12 attach: function attach(context) {
Chris@0 13 $('body').once('tour').each(function () {
Chris@0 14 var model = new Drupal.tour.models.StateModel();
Chris@0 15 new Drupal.tour.views.ToggleTourView({
Chris@0 16 el: $(context).find('#toolbar-tab-tour'),
Chris@0 17 model: model
Chris@0 18 });
Chris@0 19
Chris@0 20 model.on('change:isActive', function (model, isActive) {
Chris@0 21 $(document).trigger(isActive ? 'drupalTourStarted' : 'drupalTourStopped');
Chris@0 22 }).set('tour', $(context).find('ol#tour'));
Chris@0 23
Chris@0 24 if (/tour=?/i.test(queryString)) {
Chris@0 25 model.set('isActive', true);
Chris@0 26 }
Chris@0 27 });
Chris@0 28 }
Chris@0 29 };
Chris@0 30
Chris@0 31 Drupal.tour = Drupal.tour || {
Chris@0 32 models: {},
Chris@0 33
Chris@0 34 views: {}
Chris@0 35 };
Chris@0 36
Chris@0 37 Drupal.tour.models.StateModel = Backbone.Model.extend({
Chris@0 38 defaults: {
Chris@0 39 tour: [],
Chris@0 40
Chris@0 41 isActive: false,
Chris@0 42
Chris@0 43 activeTour: []
Chris@0 44 }
Chris@0 45 });
Chris@0 46
Chris@0 47 Drupal.tour.views.ToggleTourView = Backbone.View.extend({
Chris@0 48 events: { click: 'onClick' },
Chris@0 49
Chris@0 50 initialize: function initialize() {
Chris@0 51 this.listenTo(this.model, 'change:tour change:isActive', this.render);
Chris@0 52 this.listenTo(this.model, 'change:isActive', this.toggleTour);
Chris@0 53 },
Chris@0 54 render: function render() {
Chris@0 55 this.$el.toggleClass('hidden', this._getTour().length === 0);
Chris@0 56
Chris@0 57 var isActive = this.model.get('isActive');
Chris@0 58 this.$el.find('button').toggleClass('is-active', isActive).prop('aria-pressed', isActive);
Chris@0 59 return this;
Chris@0 60 },
Chris@0 61 toggleTour: function toggleTour() {
Chris@0 62 if (this.model.get('isActive')) {
Chris@0 63 var $tour = this._getTour();
Chris@0 64 this._removeIrrelevantTourItems($tour, this._getDocument());
Chris@0 65 var that = this;
Chris@14 66 var close = Drupal.t('Close');
Chris@0 67 if ($tour.find('li').length) {
Chris@0 68 $tour.joyride({
Chris@0 69 autoStart: true,
Chris@0 70 postRideCallback: function postRideCallback() {
Chris@0 71 that.model.set('isActive', false);
Chris@0 72 },
Chris@0 73
Chris@0 74 template: {
Chris@14 75 link: '<a href="#close" class="joyride-close-tip" aria-label="' + close + '">&times;</a>',
Chris@14 76 button: '<a href="#" class="button button--primary joyride-next-tip"></a>'
Chris@0 77 }
Chris@0 78 });
Chris@0 79 this.model.set({ isActive: true, activeTour: $tour });
Chris@0 80 }
Chris@0 81 } else {
Chris@0 82 this.model.get('activeTour').joyride('destroy');
Chris@0 83 this.model.set({ isActive: false, activeTour: [] });
Chris@0 84 }
Chris@0 85 },
Chris@0 86 onClick: function onClick(event) {
Chris@0 87 this.model.set('isActive', !this.model.get('isActive'));
Chris@0 88 event.preventDefault();
Chris@0 89 event.stopPropagation();
Chris@0 90 },
Chris@0 91 _getTour: function _getTour() {
Chris@0 92 return this.model.get('tour');
Chris@0 93 },
Chris@0 94 _getDocument: function _getDocument() {
Chris@0 95 return $(document);
Chris@0 96 },
Chris@0 97 _removeIrrelevantTourItems: function _removeIrrelevantTourItems($tour, $document) {
Chris@0 98 var removals = false;
Chris@0 99 var tips = /tips=([^&]+)/.exec(queryString);
Chris@0 100 $tour.find('li').each(function () {
Chris@0 101 var $this = $(this);
Chris@0 102 var itemId = $this.attr('data-id');
Chris@0 103 var itemClass = $this.attr('data-class');
Chris@0 104
Chris@0 105 if (tips && !$(this).hasClass(tips[1])) {
Chris@0 106 removals = true;
Chris@0 107 $this.remove();
Chris@0 108 return;
Chris@0 109 }
Chris@0 110
Chris@0 111 if (!itemId && !itemClass || itemId && $document.find('#' + itemId).length || itemClass && $document.find('.' + itemClass).length) {
Chris@0 112 return;
Chris@0 113 }
Chris@0 114 removals = true;
Chris@0 115 $this.remove();
Chris@0 116 });
Chris@0 117
Chris@0 118 if (removals) {
Chris@0 119 var total = $tour.find('li').length;
Chris@0 120 if (!total) {
Chris@0 121 this.model.set({ tour: [] });
Chris@0 122 }
Chris@0 123
Chris@0 124 $tour.find('li').each(function (index) {
Chris@17 125 var progress = Drupal.t('!tour_item of !total', {
Chris@17 126 '!tour_item': index + 1,
Chris@17 127 '!total': total
Chris@17 128 });
Chris@0 129 $(this).find('.tour-progress').text(progress);
Chris@0 130 }).eq(-1).attr('data-text', Drupal.t('End tour'));
Chris@0 131 }
Chris@0 132 }
Chris@0 133 });
Chris@0 134 })(jQuery, Backbone, Drupal, document);