Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
revert to last jquery cookie plugin which is BC compatible
- Loading branch information
Showing
1 changed file
with
110 additions
and
102 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,139 +1,147 @@ | ||
/*! | ||
* JavaScript Cookie v2.0.3 | ||
* Javascript Cookie v1.5.1 | ||
* https://github.com/js-cookie/js-cookie | ||
* | ||
* Copyright 2006, 2015 Klaus Hartl & Fagner Brack | ||
* Copyright 2006, 2014 Klaus Hartl | ||
* Released under the MIT license | ||
*/ | ||
(function (factory) { | ||
var jQuery; | ||
if (typeof define === 'function' && define.amd) { | ||
define(factory); | ||
// AMD (Register as an anonymous module) | ||
define(['jquery'], factory); | ||
} else if (typeof exports === 'object') { | ||
module.exports = factory(); | ||
// Node/CommonJS | ||
try { | ||
jQuery = require('jquery'); | ||
} catch(e) {} | ||
module.exports = factory(jQuery); | ||
} else { | ||
// Browser globals | ||
var _OldCookies = window.Cookies; | ||
var api = window.Cookies = factory(); | ||
api.noConflict = function () { | ||
var api = window.Cookies = factory(window.jQuery); | ||
api.noConflict = function() { | ||
window.Cookies = _OldCookies; | ||
return api; | ||
}; | ||
} | ||
}(function () { | ||
function extend () { | ||
}(function ($) { | ||
|
||
var pluses = /\+/g; | ||
|
||
function encode(s) { | ||
return api.raw ? s : encodeURIComponent(s); | ||
} | ||
|
||
function decode(s) { | ||
return api.raw ? s : decodeURIComponent(s); | ||
} | ||
|
||
function stringifyCookieValue(value) { | ||
return encode(api.json ? JSON.stringify(value) : String(value)); | ||
} | ||
|
||
function parseCookieValue(s) { | ||
if (s.indexOf('"') === 0) { | ||
// This is a quoted cookie as according to RFC2068, unescape... | ||
s = s.slice(1, -1).replace(/\\"/g, '"').replace(/\\\\/g, '\\'); | ||
} | ||
|
||
try { | ||
// Replace server-side written pluses with spaces. | ||
// If we can't decode the cookie, ignore it, it's unusable. | ||
// If we can't parse the cookie, ignore it, it's unusable. | ||
s = decodeURIComponent(s.replace(pluses, ' ')); | ||
return api.json ? JSON.parse(s) : s; | ||
} catch(e) {} | ||
} | ||
|
||
function read(s, converter) { | ||
var value = api.raw ? s : parseCookieValue(s); | ||
return isFunction(converter) ? converter(value) : value; | ||
} | ||
|
||
function extend() { | ||
var key, options; | ||
var i = 0; | ||
var result = {}; | ||
for (; i < arguments.length; i++) { | ||
var attributes = arguments[ i ]; | ||
for (var key in attributes) { | ||
result[key] = attributes[key]; | ||
options = arguments[ i ]; | ||
for (key in options) { | ||
result[key] = options[key]; | ||
} | ||
} | ||
return result; | ||
} | ||
|
||
function init (converter) { | ||
function api (key, value, attributes) { | ||
var result; | ||
|
||
// Write | ||
|
||
if (arguments.length > 1) { | ||
attributes = extend({ | ||
path: '/' | ||
}, api.defaults, attributes); | ||
|
||
if (typeof attributes.expires === 'number') { | ||
var expires = new Date(); | ||
expires.setMilliseconds(expires.getMilliseconds() + attributes.expires * 864e+5); | ||
attributes.expires = expires; | ||
} | ||
|
||
try { | ||
result = JSON.stringify(value); | ||
if (/^[\{\[]/.test(result)) { | ||
value = result; | ||
} | ||
} catch (e) {} | ||
|
||
value = encodeURIComponent(String(value)); | ||
value = value.replace(/%(23|24|26|2B|3A|3C|3E|3D|2F|3F|40|5B|5D|5E|60|7B|7D|7C)/g, decodeURIComponent); | ||
|
||
key = encodeURIComponent(String(key)); | ||
key = key.replace(/%(23|24|26|2B|5E|60|7C)/g, decodeURIComponent); | ||
key = key.replace(/[\(\)]/g, escape); | ||
|
||
return (document.cookie = [ | ||
key, '=', value, | ||
attributes.expires && '; expires=' + attributes.expires.toUTCString(), // use expires attribute, max-age is not supported by IE | ||
attributes.path && '; path=' + attributes.path, | ||
attributes.domain && '; domain=' + attributes.domain, | ||
attributes.secure ? '; secure' : '' | ||
].join('')); | ||
} | ||
function isFunction(obj) { | ||
return Object.prototype.toString.call(obj) === '[object Function]'; | ||
} | ||
|
||
// Read | ||
var api = function (key, value, options) { | ||
|
||
if (!key) { | ||
result = {}; | ||
// Write | ||
|
||
if (arguments.length > 1 && !isFunction(value)) { | ||
options = extend(api.defaults, options); | ||
|
||
if (typeof options.expires === 'number') { | ||
var days = options.expires, t = options.expires = new Date(); | ||
t.setMilliseconds(t.getMilliseconds() + days * 864e+5); | ||
} | ||
|
||
return (document.cookie = [ | ||
encode(key), '=', stringifyCookieValue(value), | ||
options.expires ? '; expires=' + options.expires.toUTCString() : '', // use expires attribute, max-age is not supported by IE | ||
options.path ? '; path=' + options.path : '', | ||
options.domain ? '; domain=' + options.domain : '', | ||
options.secure ? '; secure' : '' | ||
].join('')); | ||
} | ||
|
||
// Read | ||
|
||
var result = key ? undefined : {}, | ||
// To prevent the for loop in the first place assign an empty array | ||
// in case there are no cookies at all. Also prevents odd result when | ||
// calling "get()" | ||
var cookies = document.cookie ? document.cookie.split('; ') : []; | ||
var rdecode = /(%[0-9A-Z]{2})+/g; | ||
var i = 0; | ||
|
||
for (; i < cookies.length; i++) { | ||
var parts = cookies[i].split('='); | ||
var name = parts[0].replace(rdecode, decodeURIComponent); | ||
var cookie = parts.slice(1).join('='); | ||
|
||
if (cookie.charAt(0) === '"') { | ||
cookie = cookie.slice(1, -1); | ||
} | ||
|
||
try { | ||
cookie = converter && converter(cookie, name) || cookie.replace(rdecode, decodeURIComponent); | ||
|
||
if (this.json) { | ||
try { | ||
cookie = JSON.parse(cookie); | ||
} catch (e) {} | ||
} | ||
|
||
if (key === name) { | ||
result = cookie; | ||
break; | ||
} | ||
|
||
if (!key) { | ||
result[name] = cookie; | ||
} | ||
} catch (e) {} | ||
// calling "get()". | ||
cookies = document.cookie ? document.cookie.split('; ') : [], | ||
i = 0, | ||
l = cookies.length; | ||
|
||
for (; i < l; i++) { | ||
var parts = cookies[i].split('='), | ||
name = decode(parts.shift()), | ||
cookie = parts.join('='); | ||
|
||
if (key === name) { | ||
// If second argument (value) is a function it's a converter... | ||
result = read(cookie, value); | ||
break; | ||
} | ||
|
||
return result; | ||
// Prevent storing a cookie that we couldn't decode. | ||
if (!key && (cookie = read(cookie)) !== undefined) { | ||
result[name] = cookie; | ||
} | ||
} | ||
|
||
api.get = api.set = api; | ||
api.getJSON = function () { | ||
return api.apply({ | ||
json: true | ||
}, [].slice.call(arguments)); | ||
}; | ||
api.defaults = {}; | ||
return result; | ||
}; | ||
|
||
api.remove = function (key, attributes) { | ||
api(key, '', extend(attributes, { | ||
expires: -1 | ||
})); | ||
}; | ||
api.get = api.set = api; | ||
api.defaults = {}; | ||
|
||
api.withConverter = init; | ||
api.remove = function (key, options) { | ||
// Must not alter options, thus extending a fresh object... | ||
api(key, '', extend(options, { expires: -1 })); | ||
return !api(key); | ||
}; | ||
|
||
return api; | ||
if ( $ ) { | ||
$.cookie = api; | ||
$.removeCookie = api.remove; | ||
} | ||
|
||
return init(); | ||
})); | ||
return api; | ||
})); |