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@0
|
66 if ($tour.find('li').length) {
|
Chris@0
|
67 $tour.joyride({
|
Chris@0
|
68 autoStart: true,
|
Chris@0
|
69 postRideCallback: function postRideCallback() {
|
Chris@0
|
70 that.model.set('isActive', false);
|
Chris@0
|
71 },
|
Chris@0
|
72
|
Chris@0
|
73 template: {
|
Chris@0
|
74 link: '<a href=\"#close\" class=\"joyride-close-tip\">×</a>',
|
Chris@0
|
75 button: '<a href=\"#\" class=\"button button--primary joyride-next-tip\"></a>'
|
Chris@0
|
76 }
|
Chris@0
|
77 });
|
Chris@0
|
78 this.model.set({ isActive: true, activeTour: $tour });
|
Chris@0
|
79 }
|
Chris@0
|
80 } else {
|
Chris@0
|
81 this.model.get('activeTour').joyride('destroy');
|
Chris@0
|
82 this.model.set({ isActive: false, activeTour: [] });
|
Chris@0
|
83 }
|
Chris@0
|
84 },
|
Chris@0
|
85 onClick: function onClick(event) {
|
Chris@0
|
86 this.model.set('isActive', !this.model.get('isActive'));
|
Chris@0
|
87 event.preventDefault();
|
Chris@0
|
88 event.stopPropagation();
|
Chris@0
|
89 },
|
Chris@0
|
90 _getTour: function _getTour() {
|
Chris@0
|
91 return this.model.get('tour');
|
Chris@0
|
92 },
|
Chris@0
|
93 _getDocument: function _getDocument() {
|
Chris@0
|
94 return $(document);
|
Chris@0
|
95 },
|
Chris@0
|
96 _removeIrrelevantTourItems: function _removeIrrelevantTourItems($tour, $document) {
|
Chris@0
|
97 var removals = false;
|
Chris@0
|
98 var tips = /tips=([^&]+)/.exec(queryString);
|
Chris@0
|
99 $tour.find('li').each(function () {
|
Chris@0
|
100 var $this = $(this);
|
Chris@0
|
101 var itemId = $this.attr('data-id');
|
Chris@0
|
102 var itemClass = $this.attr('data-class');
|
Chris@0
|
103
|
Chris@0
|
104 if (tips && !$(this).hasClass(tips[1])) {
|
Chris@0
|
105 removals = true;
|
Chris@0
|
106 $this.remove();
|
Chris@0
|
107 return;
|
Chris@0
|
108 }
|
Chris@0
|
109
|
Chris@0
|
110 if (!itemId && !itemClass || itemId && $document.find('#' + itemId).length || itemClass && $document.find('.' + itemClass).length) {
|
Chris@0
|
111 return;
|
Chris@0
|
112 }
|
Chris@0
|
113 removals = true;
|
Chris@0
|
114 $this.remove();
|
Chris@0
|
115 });
|
Chris@0
|
116
|
Chris@0
|
117 if (removals) {
|
Chris@0
|
118 var total = $tour.find('li').length;
|
Chris@0
|
119 if (!total) {
|
Chris@0
|
120 this.model.set({ tour: [] });
|
Chris@0
|
121 }
|
Chris@0
|
122
|
Chris@0
|
123 $tour.find('li').each(function (index) {
|
Chris@0
|
124 var progress = Drupal.t('!tour_item of !total', { '!tour_item': index + 1, '!total': total });
|
Chris@0
|
125 $(this).find('.tour-progress').text(progress);
|
Chris@0
|
126 }).eq(-1).attr('data-text', Drupal.t('End tour'));
|
Chris@0
|
127 }
|
Chris@0
|
128 }
|
Chris@0
|
129 });
|
Chris@0
|
130 })(jQuery, Backbone, Drupal, document); |