| /** | 
|  * @license AngularJS v1.5.7 | 
|  * (c) 2010-2016 Google, Inc. http://angularjs.org | 
|  * License: MIT | 
|  */ | 
| (function(window, angular) {'use strict'; | 
|   | 
| /** | 
|  * @ngdoc module | 
|  * @name ngCookies | 
|  * @description | 
|  * | 
|  * # ngCookies | 
|  * | 
|  * The `ngCookies` module provides a convenient wrapper for reading and writing browser cookies. | 
|  * | 
|  * | 
|  * <div doc-module-components="ngCookies"></div> | 
|  * | 
|  * See {@link ngCookies.$cookies `$cookies`} for usage. | 
|  */ | 
|   | 
|   | 
| angular.module('ngCookies', ['ng']). | 
|   /** | 
|    * @ngdoc provider | 
|    * @name $cookiesProvider | 
|    * @description | 
|    * Use `$cookiesProvider` to change the default behavior of the {@link ngCookies.$cookies $cookies} service. | 
|    * */ | 
|    provider('$cookies', [function $CookiesProvider() { | 
|     /** | 
|      * @ngdoc property | 
|      * @name $cookiesProvider#defaults | 
|      * @description | 
|      * | 
|      * Object containing default options to pass when setting cookies. | 
|      * | 
|      * The object may have following properties: | 
|      * | 
|      * - **path** - `{string}` - The cookie will be available only for this path and its | 
|      *   sub-paths. By default, this is the URL that appears in your `<base>` tag. | 
|      * - **domain** - `{string}` - The cookie will be available only for this domain and | 
|      *   its sub-domains. For security reasons the user agent will not accept the cookie | 
|      *   if the current domain is not a sub-domain of this domain or equal to it. | 
|      * - **expires** - `{string|Date}` - String of the form "Wdy, DD Mon YYYY HH:MM:SS GMT" | 
|      *   or a Date object indicating the exact date/time this cookie will expire. | 
|      * - **secure** - `{boolean}` - If `true`, then the cookie will only be available through a | 
|      *   secured connection. | 
|      * | 
|      * Note: By default, the address that appears in your `<base>` tag will be used as the path. | 
|      * This is important so that cookies will be visible for all routes when html5mode is enabled. | 
|      * | 
|      **/ | 
|     var defaults = this.defaults = {}; | 
|   | 
|     function calcOptions(options) { | 
|       return options ? angular.extend({}, defaults, options) : defaults; | 
|     } | 
|   | 
|     /** | 
|      * @ngdoc service | 
|      * @name $cookies | 
|      * | 
|      * @description | 
|      * Provides read/write access to browser's cookies. | 
|      * | 
|      * <div class="alert alert-info"> | 
|      * Up until Angular 1.3, `$cookies` exposed properties that represented the | 
|      * current browser cookie values. In version 1.4, this behavior has changed, and | 
|      * `$cookies` now provides a standard api of getters, setters etc. | 
|      * </div> | 
|      * | 
|      * Requires the {@link ngCookies `ngCookies`} module to be installed. | 
|      * | 
|      * @example | 
|      * | 
|      * ```js | 
|      * angular.module('cookiesExample', ['ngCookies']) | 
|      *   .controller('ExampleController', ['$cookies', function($cookies) { | 
|      *     // Retrieving a cookie | 
|      *     var favoriteCookie = $cookies.get('myFavorite'); | 
|      *     // Setting a cookie | 
|      *     $cookies.put('myFavorite', 'oatmeal'); | 
|      *   }]); | 
|      * ``` | 
|      */ | 
|     this.$get = ['$$cookieReader', '$$cookieWriter', function($$cookieReader, $$cookieWriter) { | 
|       return { | 
|         /** | 
|          * @ngdoc method | 
|          * @name $cookies#get | 
|          * | 
|          * @description | 
|          * Returns the value of given cookie key | 
|          * | 
|          * @param {string} key Id to use for lookup. | 
|          * @returns {string} Raw cookie value. | 
|          */ | 
|         get: function(key) { | 
|           return $$cookieReader()[key]; | 
|         }, | 
|   | 
|         /** | 
|          * @ngdoc method | 
|          * @name $cookies#getObject | 
|          * | 
|          * @description | 
|          * Returns the deserialized value of given cookie key | 
|          * | 
|          * @param {string} key Id to use for lookup. | 
|          * @returns {Object} Deserialized cookie value. | 
|          */ | 
|         getObject: function(key) { | 
|           var value = this.get(key); | 
|           return value ? angular.fromJson(value) : value; | 
|         }, | 
|   | 
|         /** | 
|          * @ngdoc method | 
|          * @name $cookies#getAll | 
|          * | 
|          * @description | 
|          * Returns a key value object with all the cookies | 
|          * | 
|          * @returns {Object} All cookies | 
|          */ | 
|         getAll: function() { | 
|           return $$cookieReader(); | 
|         }, | 
|   | 
|         /** | 
|          * @ngdoc method | 
|          * @name $cookies#put | 
|          * | 
|          * @description | 
|          * Sets a value for given cookie key | 
|          * | 
|          * @param {string} key Id for the `value`. | 
|          * @param {string} value Raw value to be stored. | 
|          * @param {Object=} options Options object. | 
|          *    See {@link ngCookies.$cookiesProvider#defaults $cookiesProvider.defaults} | 
|          */ | 
|         put: function(key, value, options) { | 
|           $$cookieWriter(key, value, calcOptions(options)); | 
|         }, | 
|   | 
|         /** | 
|          * @ngdoc method | 
|          * @name $cookies#putObject | 
|          * | 
|          * @description | 
|          * Serializes and sets a value for given cookie key | 
|          * | 
|          * @param {string} key Id for the `value`. | 
|          * @param {Object} value Value to be stored. | 
|          * @param {Object=} options Options object. | 
|          *    See {@link ngCookies.$cookiesProvider#defaults $cookiesProvider.defaults} | 
|          */ | 
|         putObject: function(key, value, options) { | 
|           this.put(key, angular.toJson(value), options); | 
|         }, | 
|   | 
|         /** | 
|          * @ngdoc method | 
|          * @name $cookies#remove | 
|          * | 
|          * @description | 
|          * Remove given cookie | 
|          * | 
|          * @param {string} key Id of the key-value pair to delete. | 
|          * @param {Object=} options Options object. | 
|          *    See {@link ngCookies.$cookiesProvider#defaults $cookiesProvider.defaults} | 
|          */ | 
|         remove: function(key, options) { | 
|           $$cookieWriter(key, undefined, calcOptions(options)); | 
|         } | 
|       }; | 
|     }]; | 
|   }]); | 
|   | 
| angular.module('ngCookies'). | 
| /** | 
|  * @ngdoc service | 
|  * @name $cookieStore | 
|  * @deprecated | 
|  * @requires $cookies | 
|  * | 
|  * @description | 
|  * Provides a key-value (string-object) storage, that is backed by session cookies. | 
|  * Objects put or retrieved from this storage are automatically serialized or | 
|  * deserialized by angular's toJson/fromJson. | 
|  * | 
|  * Requires the {@link ngCookies `ngCookies`} module to be installed. | 
|  * | 
|  * <div class="alert alert-danger"> | 
|  * **Note:** The $cookieStore service is **deprecated**. | 
|  * Please use the {@link ngCookies.$cookies `$cookies`} service instead. | 
|  * </div> | 
|  * | 
|  * @example | 
|  * | 
|  * ```js | 
|  * angular.module('cookieStoreExample', ['ngCookies']) | 
|  *   .controller('ExampleController', ['$cookieStore', function($cookieStore) { | 
|  *     // Put cookie | 
|  *     $cookieStore.put('myFavorite','oatmeal'); | 
|  *     // Get cookie | 
|  *     var favoriteCookie = $cookieStore.get('myFavorite'); | 
|  *     // Removing a cookie | 
|  *     $cookieStore.remove('myFavorite'); | 
|  *   }]); | 
|  * ``` | 
|  */ | 
|  factory('$cookieStore', ['$cookies', function($cookies) { | 
|   | 
|     return { | 
|       /** | 
|        * @ngdoc method | 
|        * @name $cookieStore#get | 
|        * | 
|        * @description | 
|        * Returns the value of given cookie key | 
|        * | 
|        * @param {string} key Id to use for lookup. | 
|        * @returns {Object} Deserialized cookie value, undefined if the cookie does not exist. | 
|        */ | 
|       get: function(key) { | 
|         return $cookies.getObject(key); | 
|       }, | 
|   | 
|       /** | 
|        * @ngdoc method | 
|        * @name $cookieStore#put | 
|        * | 
|        * @description | 
|        * Sets a value for given cookie key | 
|        * | 
|        * @param {string} key Id for the `value`. | 
|        * @param {Object} value Value to be stored. | 
|        */ | 
|       put: function(key, value) { | 
|         $cookies.putObject(key, value); | 
|       }, | 
|   | 
|       /** | 
|        * @ngdoc method | 
|        * @name $cookieStore#remove | 
|        * | 
|        * @description | 
|        * Remove given cookie | 
|        * | 
|        * @param {string} key Id of the key-value pair to delete. | 
|        */ | 
|       remove: function(key) { | 
|         $cookies.remove(key); | 
|       } | 
|     }; | 
|   | 
|   }]); | 
|   | 
| /** | 
|  * @name $$cookieWriter | 
|  * @requires $document | 
|  * | 
|  * @description | 
|  * This is a private service for writing cookies | 
|  * | 
|  * @param {string} name Cookie name | 
|  * @param {string=} value Cookie value (if undefined, cookie will be deleted) | 
|  * @param {Object=} options Object with options that need to be stored for the cookie. | 
|  */ | 
| function $$CookieWriter($document, $log, $browser) { | 
|   var cookiePath = $browser.baseHref(); | 
|   var rawDocument = $document[0]; | 
|   | 
|   function buildCookieString(name, value, options) { | 
|     var path, expires; | 
|     options = options || {}; | 
|     expires = options.expires; | 
|     path = angular.isDefined(options.path) ? options.path : cookiePath; | 
|     if (angular.isUndefined(value)) { | 
|       expires = 'Thu, 01 Jan 1970 00:00:00 GMT'; | 
|       value = ''; | 
|     } | 
|     if (angular.isString(expires)) { | 
|       expires = new Date(expires); | 
|     } | 
|   | 
|     var str = encodeURIComponent(name) + '=' + encodeURIComponent(value); | 
|     str += path ? ';path=' + path : ''; | 
|     str += options.domain ? ';domain=' + options.domain : ''; | 
|     str += expires ? ';expires=' + expires.toUTCString() : ''; | 
|     str += options.secure ? ';secure' : ''; | 
|   | 
|     // per http://www.ietf.org/rfc/rfc2109.txt browser must allow at minimum: | 
|     // - 300 cookies | 
|     // - 20 cookies per unique domain | 
|     // - 4096 bytes per cookie | 
|     var cookieLength = str.length + 1; | 
|     if (cookieLength > 4096) { | 
|       $log.warn("Cookie '" + name + | 
|         "' possibly not set or overflowed because it was too large (" + | 
|         cookieLength + " > 4096 bytes)!"); | 
|     } | 
|   | 
|     return str; | 
|   } | 
|   | 
|   return function(name, value, options) { | 
|     rawDocument.cookie = buildCookieString(name, value, options); | 
|   }; | 
| } | 
|   | 
| $$CookieWriter.$inject = ['$document', '$log', '$browser']; | 
|   | 
| angular.module('ngCookies').provider('$$cookieWriter', function $$CookieWriterProvider() { | 
|   this.$get = $$CookieWriter; | 
| }); | 
|   | 
|   | 
| })(window, window.angular); |