From 7a9252ba7da5799f1e1b3a0b94fa0585d13139e9 Mon Sep 17 00:00:00 2001 From: Kaspars Date: Thu, 8 Oct 2015 22:38:18 +0300 Subject: [PATCH] toggleClass parameter, when set to true will use toggleClass, rather than addClass/removeClass --- .../ScrollMagic/Scene/feature-classToggles.js | 35 ++++++++++++++----- dev/src/ScrollMagic/_util.js | 8 +++++ 2 files changed, 34 insertions(+), 9 deletions(-) diff --git a/dev/src/ScrollMagic/Scene/feature-classToggles.js b/dev/src/ScrollMagic/Scene/feature-classToggles.js index 2cec1e84..81dc757b 100644 --- a/dev/src/ScrollMagic/Scene/feature-classToggles.js +++ b/dev/src/ScrollMagic/Scene/feature-classToggles.js @@ -1,6 +1,8 @@ var _cssClasses, - _cssClassElems = []; + _cssClassElems = [], + _cssClassToggle = false, + _cssClassToggleOnRemove = false; Scene .on("destroy.internal", function (e) { @@ -20,10 +22,11 @@ Scene * * @param {(string|object)} element - A Selector targeting one or more elements or a DOM object that is supposed to be modified. * @param {string} classes - One or more Classnames (separated by space) that should be added to the element during the scene. + * @param {boolean} toggleClass - Whether to use toggleClass jQuery method, rather than addClass and removeClass * * @returns {Scene} Parent object for chaining. */ -this.setClassToggle = function (element, classes) { +this.setClassToggle = function (element, classes, toggleClass) { var elems = _util.get.elements(element); if (elems.length === 0 || !_util.type.String(classes)) { log(1, "ERROR calling method 'setClassToggle()': Invalid " + (elems.length === 0 ? "element" : "classes") + " supplied."); @@ -35,12 +38,19 @@ this.setClassToggle = function (element, classes) { } _cssClasses = classes; _cssClassElems = elems; - Scene.on("enter.internal_class leave.internal_class", function (e) { - var toggle = e.type === "enter" ? _util.addClass : _util.removeClass; - _cssClassElems.forEach(function (elem, key) { - toggle(elem, _cssClasses); - }); - }); + _cssClassToggle = toggleClass; + Scene.on("enter.internal_class leave.internal_class", function (e) { + var toggle = e.type === "enter" ? _util.addClass : _util.removeClass; + _cssClassElems.forEach(function (elem, key) { + if (_cssClassToggle) { + _util.toggleClass(elem, _cssClasses); + _cssClassToggleOnRemove = !_cssClassToggleOnRemove; + } + else { + toggle(elem, _cssClasses); + } + }); + }); return Scene; }; @@ -60,11 +70,18 @@ this.setClassToggle = function (element, classes) { this.removeClassToggle = function (reset) { if (reset) { _cssClassElems.forEach(function (elem, key) { - _util.removeClass(elem, _cssClasses); + if (!_cssClassToggle) { + _util.removeClass(elem, _cssClasses); + } + else if (_cssClassToggleOnRemove) { + _util.toggleClass(elem, _cssClasses); + } }); } Scene.off("start.internal_class end.internal_class"); _cssClasses = undefined; _cssClassElems = []; + _cssClassToggle = false; + _cssClassToggleOnRemove = false; return Scene; }; \ No newline at end of file diff --git a/dev/src/ScrollMagic/_util.js b/dev/src/ScrollMagic/_util.js index 9ec46123..1ddc97ee 100644 --- a/dev/src/ScrollMagic/_util.js +++ b/dev/src/ScrollMagic/_util.js @@ -233,6 +233,14 @@ var _util = ScrollMagic._util = (function (window) { elem.className = elem.className.replace(new RegExp('(^|\\b)' + classname.split(' ').join('|') + '(\\b|$)', 'gi'), ' '); } }; + U.toggleClass = function(elem, classname) { + if (classname) { + if (elem.className.split(/\s+/).indexOf(classname) > -1) + U.removeClass(elem, classname); + else + U.addClass(elem, classname); + } + }; // if options is string -> returns css value // if options is array -> returns object with css value pairs // if options is object -> set new css values