Skip to content

Commit

Permalink
Remove unnecessary id attribute on step tooltip containers.
Browse files Browse the repository at this point in the history
Follows up on the discussion [here](#282 (comment)).
  • Loading branch information
BrianSipple committed Nov 22, 2018
1 parent b8014d7 commit 008f665
Show file tree
Hide file tree
Showing 4 changed files with 61 additions and 3 deletions.
2 changes: 2 additions & 0 deletions index.md
Original file line number Diff line number Diff line change
Expand Up @@ -124,6 +124,8 @@ const myTour = new Shepherd.Tour(options);

- `steps`: An array of Step instances to initialize the tour with
- `defaultStepOptions`: Default options for Steps created through `addStep`
- `tourName`: An optional "name" for the tour. This will be appended to the the tour's
dynamically generated `id` property -- which is also set on the `body` element as the `data-shepherd-active-tour` attribute whenever the tour becomes active.
- `confirmCancel`: If true, will issue a window.confirm before cancelling
- `confirmCancelMessage`: The message to display in the confirm dialog

Expand Down
2 changes: 1 addition & 1 deletion src/js/step.js
Original file line number Diff line number Diff line change
Expand Up @@ -190,7 +190,7 @@ export class Step extends Evented {
_createTooltipContent() {
const content = document.createElement('div');
const classes = this.options.classes || '';
const element = createFromHTML(`<div class='${classes}' data-shepherd-step-id='${this.id}' id="step-${this.options.id}-${uniqueId()}"}>`);
const element = createFromHTML(`<div class="${classes}" data-shepherd-step-id="${this.id}">`);
const header = document.createElement('header');

if (this.options.title) {
Expand Down
39 changes: 37 additions & 2 deletions src/js/tour.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,19 @@ import { bindMethods } from './bind.js';
import tippy from 'tippy.js';
import { defaults as tooltipDefaults } from './utils/tooltip-defaults';

/**
* Creates incremented ID for each newly created tour
*
* @private
* @return {Number} The unique id for the tour
*/
const uniqueId = (function() {
let id = 0;
return function() {
return ++id;
};
})();

const Shepherd = new Evented();

/**
Expand All @@ -17,6 +30,9 @@ export class Tour extends Evented {
* @param {Object} options The options for the tour
* @param {Object} options.defaultStepOptions Default options for Steps created through `addStep`
* @param {Step[]} options.steps An array of Step instances to initialize the tour with
* @param {string} options.tourName An optional "name" for the tour. This will be appended to the the tour's
* dynamically generated `id` property -- which is also set on the `body` element as the `data-shepherd-active-tour` attribute
* whenever the tour becomes active.
* @returns {Tour}
*/
constructor(options = {}) {
Expand All @@ -43,6 +59,7 @@ export class Tour extends Evented {
});

this._setTooltipDefaults();
this._setTourID();

return this;
}
Expand Down Expand Up @@ -119,7 +136,7 @@ export class Tour extends Evented {
this.trigger(event);

Shepherd.activeTour = null;
document.body.classList.remove('shepherd-active');
this._removeBodyAttrs();
this.trigger('inactive', { tour: this });
}

Expand Down Expand Up @@ -260,7 +277,7 @@ export class Tour extends Evented {
* @private
*/
_setupActiveTour() {
document.body.classList.add('shepherd-active');
this._addBodyAttrs();
this.trigger('active', { tour: this });

Shepherd.activeTour = this;
Expand Down Expand Up @@ -291,6 +308,24 @@ export class Tour extends Evented {
this._setupActiveTour();
}
}

_setTourID() {
const tourName = this.options.tourName || 'tour';
const uuid = uniqueId();

this.id = `${tourName}--${uuid}`;
}

_addBodyAttrs() {
document.body.setAttribute('data-shepherd-active-tour', this.id);
document.body.classList.add('shepherd-active');
}

_removeBodyAttrs() {
document.body.removeAttribute('data-shepherd-active-tour', this.id);
document.body.classList.remove('shepherd-active');
}

}

export { Shepherd };
21 changes: 21 additions & 0 deletions test/unit/test.tour.js
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,19 @@ describe('Tour | Top-Level Class', function() {
assert.equal(tippySpy.callCount, 1);
assert.equal(tippySpy.calledWith(tooltipDefaults), true);
});

it('generates a unique `id` property, optionally based upon the `tourName` option', function() {
const instance1 = new Shepherd.Tour();
const instance2 = new Shepherd.Tour({ tourName: 'select-avatar'});

assert.equal(instance1.id.startsWith('tour--'), true);
assert.equal(instance2.id.startsWith('select-avatar--'), true);

const uniqueId1 = instance1.id.split('--')[1];
const uniqueId2 = instance2.id.split('--')[1];

assert.notEqual(uniqueId1, uniqueId2);
});
});

describe('methods', () => {
Expand Down Expand Up @@ -142,6 +155,14 @@ describe('Tour | Top-Level Class', function() {

assert.equal(instance, Shepherd.activeTour);
});

it('adds the current tour\'s "id" property to the body as a data attribute', function() {
instance.id = 'test-id';
instance.start();

assert.equal(document.body.hasAttribute('data-shepherd-active-tour'), true);
assert.equal(document.body.getAttribute('data-shepherd-active-tour'), 'test-id');
});
});

describe('.getCurrentStep()', function() {
Expand Down

0 comments on commit 008f665

Please sign in to comment.