123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235 |
- // https://github.com/camsjams/jquery-style-switcher
- /**
- @author Cameron Manavian
- jQuery Style Switcher
-
- The MIT License (MIT)
-
- Copyright (c) 2014 Cameron Manavian
-
- Permission is hereby granted, free of charge, to any person obtaining a copy
- of this software and associated documentation files (the "Software"), to deal
- in the Software without restriction, including without limitation the rights
- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- copies of the Software, and to permit persons to whom the Software is
- furnished to do so, subject to the following conditions:
-
- The above copyright notice and this permission notice shall be included in all
- copies or substantial portions of the Software.
-
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- SOFTWARE.
- **/
-
- (function ($) {
- var jStyleSwitcher,
- _defaultOptions = {
- hasPreview: true,
- defaultThemeId: 'jssDefault',
- fullPath: 'css/',
- cookie: {
- expires: 30,
- isManagingLoad: true
- }
- },
- // private
- _cookieKey = 'jss_selected',
- _docCookies = {};
-
- /*\
- |*|
- |*| :: cookies.js ::
- |*|
- |*| A complete cookies reader/writer framework with full unicode support.
- |*|
- |*| revision #1
- |*|
- |*| https://developer.mozilla.org/en-US/docs/Web/API/document.cookie
- |*|
- |*| This framework is released under the GNU Public License, version 3 or later.
- |*| http://www.gnu.org/licenses/gpl-3.0-standalone.html
- |*|
- |*| Syntaxes:
- |*|
- |*| * docCookies.setItem(name, value[, end[, path[, domain[, secure]]]])
- |*| * docCookies.getItem(name)
- |*| * docCookies.removeItem(name[, path[, domain]])
- |*| * docCookies.hasItem(name)
- |*| * docCookies.keys()
- |*|
- \*/
- _docCookies = {
- getItem: function (sKey) {
- if (!sKey) {
- return null;
- }
- return decodeURIComponent(document.cookie.replace(new RegExp("(?:(?:^|.*;)\\s*" + encodeURIComponent(sKey).replace(/[\-\.\+\*]/g, "\\$&") + "\\s*\\=\\s*([^;]*).*$)|^.*$"), "$1")) || null;
- },
- setItem: function (sKey, sValue, vEnd, sPath, sDomain, bSecure) {
- if (!sKey || /^(?:expires|max\-age|path|domain|secure)$/i.test(sKey)) {
- return false;
- }
- var sExpires = "";
- if (vEnd) {
- switch (vEnd.constructor) {
- case Number:
- sExpires = vEnd === Infinity ? "; expires=Fri, 31 Dec 9999 23:59:59 GMT" : "; max-age=" + vEnd;
- break;
- case String:
- sExpires = "; expires=" + vEnd;
- break;
- case Date:
- sExpires = "; expires=" + vEnd.toUTCString();
- break;
- }
- }
- document.cookie = encodeURIComponent(sKey) + "=" + encodeURIComponent(sValue) + sExpires + (sDomain ? "; domain=" + sDomain : "") + (sPath ? "; path=" + sPath : "") + (bSecure ? "; secure" : "");
- return true;
- },
- removeItem: function (sKey, sPath, sDomain) {
- if (!this.hasItem(sKey)) {
- return false;
- }
- document.cookie = encodeURIComponent(sKey) + "=; expires=Thu, 01 Jan 1970 00:00:00 GMT" + (sDomain ? "; domain=" + sDomain : "") + (sPath ? "; path=" + sPath : "");
- return true;
- },
- hasItem: function (sKey) {
- if (!sKey) {
- return false;
- }
- return (new RegExp("(?:^|;\\s*)" + encodeURIComponent(sKey).replace(/[\-\.\+\*]/g, "\\$&") + "\\s*\\=")).test(document.cookie);
- },
- keys: function () {
- var aKeys = document.cookie.replace(/((?:^|\s*;)[^\=]+)(?=;|$)|^\s*|\s*(?:\=[^;]*)?(?:\1|$)/g, "").split(/\s*(?:\=[^;]*)?;\s*/);
- for (var nLen = aKeys.length, nIdx = 0; nIdx < nLen; nIdx++) {
- aKeys[nIdx] = decodeURIComponent(aKeys[nIdx]);
- }
- return aKeys;
- }
- };
-
- jStyleSwitcher = function ($root, config) {
- return this.init($root, config);
- };
-
- jStyleSwitcher.prototype = {
-
- /**
- * {Object} DOM reference to style option list
- */
- $root: null,
-
- /**
- * {Object} configs for the style switcher
- */
- config: {},
-
- /**
- * {Object} jQuery reference to <link> tag for swapping CSS
- */
- $themeCss: null,
-
- /**
- * {String} default theme page was loaded with
- */
- defaultTheme: null,
-
- init: function ($root, config) {
- this.$root = $root;
- this.config = config ? config : {};
- this.setDefaultTheme();
- if(this.defaultTheme) {
- // try cookies
- if (this.config.cookie) {
- this.checkCookie();
- }
- // try hover
- if (this.config.hasPreview) {
- this.addHoverEvents();
- }
- // finally, add click events
- this.addClickEvents();
- } else {
- this.$root.addClass('jssError error level0');
- }
- },
-
- setDefaultTheme: function () {
- this.$themeCss = $('link[id=' + this.config.defaultThemeId + ']');
- if(this.$themeCss.length) {
- this.defaultTheme = this.$themeCss.attr('href');
- }
- },
-
- resetStyle: function() {
- this.updateStyle(this.defaultTheme);
- },
-
- updateStyle: function(newStyle) {
- this.$themeCss.attr('href', newStyle);
- },
-
- getFullAssetPath: function(asset) {
- return this.config.fullPath + asset + '.css';
- },
-
- checkCookie: function () {
- var styleCookie;
- // if using cookies and using JavaScript to load css
- if (this.config.cookie && this.config.cookie.isManagingLoad) {
- // check if css is set in cookie
- styleCookie = _docCookies.getItem(_cookieKey);
- if (styleCookie) {
- newStyle = this.getFullAssetPath(styleCookie);
- // update link tag
- this.updateStyle(newStyle);
- // update default ref
- this.defaultTheme = newStyle;
- }
- }
- },
-
- addHoverEvents: function () {
- var self = this;
- this.$root.find('a').hover(
- function () {
- var asset = $(this).data('theme'),
- newStyle = self.getFullAssetPath(asset);
- // update link tag
- self.updateStyle(newStyle);
- },
- function () {
- // reset link tag
- self.resetStyle();
- }
- );
- },
-
- addClickEvents: function () {
- var self = this;
- this.$root.find('a').click(
- function () {
- var asset = $(this).data('theme'),
- newStyle = self.getFullAssetPath(asset);
- // update link tag
- self.updateStyle(newStyle);
- // update default ref
- self.defaultTheme = newStyle;
- // try to store cookie
- if (self.config.cookie) {
- _docCookies.setItem(_cookieKey, asset, self.config.cookie.expires, '/');
- }
- }
- );
- }
- };
-
- $.fn.styleSwitcher = function (options) {
- return new jStyleSwitcher(this, $.extend(true, _defaultOptions, options));
- };
- })(jQuery);
|