|
| 1 | +/** |
| 2 | + * Cookie plugin |
| 3 | + * |
| 4 | + * Copyright (c) 2006 Klaus Hartl (stilbuero.de) |
| 5 | + * Dual licensed under the MIT and GPL licenses: |
| 6 | + * http://www.opensource.org/licenses/mit-license.php |
| 7 | + * http://www.gnu.org/licenses/gpl.html |
| 8 | + * |
| 9 | + */ |
| 10 | + |
| 11 | +/** |
| 12 | + * Create a cookie with the given name and value and other optional parameters. |
| 13 | + * |
| 14 | + * @example $.cookie('the_cookie', 'the_value'); |
| 15 | + * @desc Set the value of a cookie. |
| 16 | + * @example $.cookie('the_cookie', 'the_value', { expires: 7, path: '/', domain: 'jquery.com', secure: true }); |
| 17 | + * @desc Create a cookie with all available options. |
| 18 | + * @example $.cookie('the_cookie', 'the_value'); |
| 19 | + * @desc Create a session cookie. |
| 20 | + * @example $.cookie('the_cookie', null); |
| 21 | + * @desc Delete a cookie by passing null as value. Keep in mind that you have to use the same path and domain |
| 22 | + * used when the cookie was set. |
| 23 | + * |
| 24 | + * @param String name The name of the cookie. |
| 25 | + * @param String value The value of the cookie. |
| 26 | + * @param Object options An object literal containing key/value pairs to provide optional cookie attributes. |
| 27 | + * @option Number|Date expires Either an integer specifying the expiration date from now on in days or a Date object. |
| 28 | + * If a negative value is specified (e.g. a date in the past), the cookie will be deleted. |
| 29 | + * If set to null or omitted, the cookie will be a session cookie and will not be retained |
| 30 | + * when the the browser exits. |
| 31 | + * @option String path The value of the path atribute of the cookie (default: path of page that created the cookie). |
| 32 | + * @option String domain The value of the domain attribute of the cookie (default: domain of page that created the cookie). |
| 33 | + * @option Boolean secure If true, the secure attribute of the cookie will be set and the cookie transmission will |
| 34 | + * require a secure protocol (like HTTPS). |
| 35 | + * @type undefined |
| 36 | + * |
| 37 | + * @name $.cookie |
| 38 | + * @cat Plugins/Cookie |
| 39 | + * @author Klaus Hartl/[email protected] |
| 40 | + */ |
| 41 | + |
| 42 | +!function(e){e.cookie=function(n,o,i){if("undefined"==typeof o){var t=null;if(document.cookie&&""!=document.cookie)for(var r=document.cookie.split(";"),p=0;p<r.length;p++){var u=e.trim(r[p]);if(u.substring(0,n.length+1)==n+"="){t=decodeURIComponent(u.substring(n.length+1));break}}return t}i=i||{},null===o&&(o="",i=$.extend({},i),i.expires=-1);var s="";if(i.expires&&("number"==typeof i.expires||i.expires.toUTCString)){var a;"number"==typeof i.expires?(a=new Date,a.setTime(a.getTime()+24*i.expires*60*60*1e3)):a=i.expires,s="; expires="+a.toUTCString()}var c=i.path?"; path="+i.path:"",d=i.domain?"; domain="+i.domain:"",m=i.secure?"; secure":"";document.cookie=[n,"=",encodeURIComponent(o),s,c,d,m].join("")}}(django.jQuery); |
0 commit comments