Skip to content
This repository has been archived by the owner on Feb 17, 2021. It is now read-only.

Commit

Permalink
Fix for issue #17
Browse files Browse the repository at this point in the history
  • Loading branch information
Gordon Koo committed Aug 21, 2013
1 parent 02694a6 commit e802bac
Show file tree
Hide file tree
Showing 4 changed files with 83 additions and 6 deletions.
2 changes: 1 addition & 1 deletion css/hopscotch-0.1.1.min.css

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

16 changes: 12 additions & 4 deletions js/hopscotch-0.1.1.js
Original file line number Diff line number Diff line change
Expand Up @@ -815,8 +815,7 @@

// Create callback to remove the callout. If a onCTA callback is
// provided, call it from within this one.
callback = function() {
utils.removeEvtListener(self.ctaBtnEl, 'click', callback);
this._ctaFn = function() {
if (!self.opt.isTourBubble) {
// This is a callout. Close the callout when CTA is clicked.
winHopscotch.getCalloutManager().removeCallout(step.id);
Expand All @@ -827,10 +826,19 @@
}
};

utils.addEvtListener(this.ctaBtnEl, 'click', callback);
utils.addEvtListener(this.ctaBtnEl, 'click', this._ctaFn);
}
},

/**
* Remove any previously attached CTA listener.
*
* @private
*/
_removeCTACallback: function() {
utils.removeEvtListener(this.ctaBtnEl, 'click', this._ctaFn);
},

/**
* Renders the bubble according to the step JSON.
*
Expand Down Expand Up @@ -1578,7 +1586,7 @@
wasMultiPage,
changeStepCb;

bubble.hide();
bubble.hide()._removeCTACallback();

doCallbacks = utils.valOrDefault(doCallbacks, true);
step = getCurrStep();
Expand Down
2 changes: 1 addition & 1 deletion js/hopscotch-0.1.1.min.js

Large diffs are not rendered by default.

69 changes: 69 additions & 0 deletions test/js/test.hopscotch.js
Original file line number Diff line number Diff line change
Expand Up @@ -881,6 +881,75 @@ describe('HopscotchBubble', function() {
$body.removeClass(testClassName);
});

it('should invoke the CTA callback when the CTA button is clicked', function() {
var testClassName = "testingCTAButton",
tour = {
id: 'hopscotch-test-tour',
steps: [
{
target: 'shopping-list',
orientation: 'left',
title: 'Shopping List',
content: 'It\'s a shopping list',
showCTAButton: true,
ctaLabel: 'test',
onCTA: function() {
$body.addClass(testClassName);
}
}
]
};

expect($body.hasClass(testClassName)).to.not.be.ok();
hopscotch.startTour(tour);
$('#hopscotch-cta').click();
expect($body.hasClass(testClassName)).to.be.ok();
hopscotch.endTour(tour);
$body.removeClass(testClassName);
});

it('should remove the CTA callback after advancing to the next step', function() {
var testClassName1 = "testingCTAButton1",
testClassName2 = "testingCTAButton2",
tour = {
id: 'hopscotch-test-tour',
steps: [
{
target: 'shopping-list',
orientation: 'left',
title: 'Shopping List',
content: 'It\'s a shopping list',
showCTAButton: true,
ctaLabel: 'test',
onCTA: function() {
$body.addClass(testClassName1);
}
},
{
target: 'shopping-list',
orientation: 'left',
title: 'Shopping List',
content: 'It\'s a shopping list',
showCTAButton: true,
ctaLabel: 'test',
onCTA: function() {
$body.addClass(testClassName2);
}
}
]
};

expect($body.hasClass(testClassName1)).to.not.be.ok();
expect($body.hasClass(testClassName2)).to.not.be.ok();
hopscotch.startTour(tour);
hopscotch.nextStep();
$('#hopscotch-cta').click();
expect($body.hasClass(testClassName1)).to.not.be.ok();
expect($body.hasClass(testClassName2)).to.be.ok();
hopscotch.endTour(tour);
$body.removeClass(testClassName1).removeClass(testClassName2);
});

it('should be able to invoke a callback that was registered as a helper', function() {
var testClassName = 'testingOnNext',
helperName = 'addClassToBody';
Expand Down

0 comments on commit e802bac

Please sign in to comment.