{"version":3,"file":"use-chart-layout-global-model.d1f2c67b.js","mappings":"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","sources":["webpack://@finviz/website/../charts/app/controllers/chart-settings/useChartLayoutGlobalModel/useChartLayoutGlobalModel.ts","webpack://@finviz/website/../charts/app/utils/global-state.ts","webpack://@finviz/website/../node_modules/lodash.isequal/index.js"],"sourcesContent":["import isEqual from 'lodash.isequal'\r\nimport React from 'react'\r\n\r\nimport { ObjectHash } from '../../../../types/shared'\r\nimport { CanvasElementType } from '../../../constants/common'\r\nimport ChartLayoutModel from '../../../models/chart_layout'\r\nimport Quote from '../../../models/quote'\r\nimport { GlobalState, useGlobalState } from '../../../utils/global-state'\r\n\r\ninterface ChartLayoutModelGlobalState {\r\n chartLayoutModel: ChartLayoutModel | null\r\n chartLayoutModelConfigSnapshot: ObjectHash | null\r\n chartLayoutModelConfigSnapshotToCompare: ObjectHash | null\r\n lastGlobalRerender: number\r\n}\r\n\r\nexport const chartLayoutGlobalState = new GlobalState({\r\n chartLayoutModel: null,\r\n chartLayoutModelConfigSnapshot: null,\r\n chartLayoutModelConfigSnapshotToCompare: null,\r\n lastGlobalRerender: Date.now(),\r\n})\r\n\r\nconst CONFIG_PROPS_TO_OMIT = ['width', 'height', 'isScrolled', 'leftOffset', 'zoomFactor']\r\nconst CANVAS_ELEMENT_TYPES: string[] = Object.values(CanvasElementType)\r\n\r\nfunction getConfigSnapshotToCompare(chartLayoutModel: ChartLayoutModel | null) {\r\n if (!chartLayoutModel) {\r\n return null\r\n }\r\n const config = chartLayoutModel.toConfig(CONFIG_PROPS_TO_OMIT)\r\n return {\r\n ...config,\r\n charts: config.charts.map((chart) => ({\r\n ...chart,\r\n panes: chart.panes.map((pane) => ({\r\n ...pane,\r\n elements: pane.elements.filter(({ type }) => !CANVAS_ELEMENT_TYPES.includes(type)),\r\n })),\r\n })),\r\n }\r\n}\r\n\r\nexport function useChartLayoutGlobalModel() {\r\n const [stateGetter, setState] = useGlobalState(chartLayoutGlobalState)\r\n const currentState = stateGetter()\r\n\r\n const getIsConfigChanged = () => {\r\n const state = stateGetter()\r\n return !isEqual(state.chartLayoutModelConfigSnapshotToCompare, getConfigSnapshotToCompare(state.chartLayoutModel))\r\n }\r\n const getIsConfigChangedRef = React.useRef(getIsConfigChanged)\r\n\r\n getIsConfigChangedRef.current = getIsConfigChanged\r\n\r\n return React.useMemo(\r\n () => ({\r\n ...currentState,\r\n getIsConfigChanged: () => getIsConfigChangedRef.current(),\r\n setChartLayoutModel: (chartLayoutModel: ChartLayoutModel) => {\r\n setState({\r\n chartLayoutModel,\r\n chartLayoutModelConfigSnapshot: chartLayoutModel.toConfig(),\r\n chartLayoutModelConfigSnapshotToCompare: getConfigSnapshotToCompare(chartLayoutModel),\r\n })\r\n },\r\n generateNewLayoutModelConfigSnapshot: () => {\r\n const state = stateGetter()\r\n\r\n if (state.chartLayoutModel) {\r\n setState({\r\n chartLayoutModelConfigSnapshot: state.chartLayoutModel.toConfig(),\r\n chartLayoutModelConfigSnapshotToCompare: getConfigSnapshotToCompare(state.chartLayoutModel),\r\n })\r\n }\r\n },\r\n getChartLayoutModelConfig: ({ fallback }: { fallback: ObjectHash }) => {\r\n const state = stateGetter()\r\n return state.chartLayoutModelConfigSnapshot ?? fallback\r\n },\r\n forceGlobalRerender: () => {\r\n const state = stateGetter()\r\n state.chartLayoutModel?.destroyCascade()\r\n Quote.deleteAll()\r\n /*\r\n * We don't want to override chartLayoutModelConfigSnapshot to null\r\n * because it is most likely used to build new chart layout model\r\n * */\r\n setState({\r\n lastGlobalRerender: Date.now(),\r\n chartLayoutModel: null,\r\n chartLayoutModelConfigSnapshotToCompare: null,\r\n })\r\n },\r\n }),\r\n // stateGetter has a stable reference, but isn’t wrapped in a ref, that’s why it’s here\r\n [currentState, setState, stateGetter]\r\n )\r\n}\r\n\r\nexport type ChartLayoutGlobalModelType = ReturnType\r\n","import React from 'react'\r\n\r\nimport { ObjectHash } from '../../types/shared'\r\nimport { useForceUpdate } from './force-update'\r\n\r\ntype SubscriberFunc = (value: T) => void\r\n\r\nexport class GlobalState {\r\n value: StateType\r\n subscribers: Array> = []\r\n\r\n constructor(initialValue: StateType = JSON.parse('{}')) {\r\n this.value = initialValue\r\n }\r\n\r\n getValue = () => this.value\r\n\r\n setValue = (newState: Partial, shouldReplace = false) => {\r\n this.value = shouldReplace ? (newState as StateType) : { ...this.value, ...newState }\r\n\r\n this.subscribers.forEach((subscriber) => {\r\n subscriber(this.value)\r\n })\r\n }\r\n\r\n subscribe = (itemToSubscribe: SubscriberFunc) => {\r\n if (this.subscribers.indexOf(itemToSubscribe) > -1) {\r\n // Already subsribed\r\n return\r\n }\r\n this.subscribers.push(itemToSubscribe)\r\n }\r\n\r\n unsubscribe = (itemToUnsubscribe: SubscriberFunc) => {\r\n this.subscribers = this.subscribers.filter((subscriber) => subscriber !== itemToUnsubscribe)\r\n }\r\n}\r\n\r\nexport function useGlobalState>(\r\n globalState: GlobalState\r\n): [stateGetter: () => T, setState: SubscriberFunc>] {\r\n const { forceUpdate } = useForceUpdate()\r\n\r\n React.useEffect(() => {\r\n globalState.subscribe(forceUpdate)\r\n return function () {\r\n globalState.unsubscribe(forceUpdate)\r\n }\r\n }, [forceUpdate, globalState])\r\n\r\n const setState = React.useCallback(\r\n (value: Partial, shouldReplace = false) => {\r\n globalState.setValue(value, shouldReplace)\r\n },\r\n [globalState]\r\n )\r\n\r\n return [globalState.getValue, setState]\r\n}\r\n","/**\n * Lodash (Custom Build) \n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright JS Foundation and other contributors \n * Released under MIT license \n * Based on Underscore.js 1.8.3 \n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n asyncTag = '[object AsyncFunction]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n nullTag = '[object Null]',\n objectTag = '[object Object]',\n promiseTag = '[object Promise]',\n proxyTag = '[object Proxy]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]',\n undefinedTag = '[object Undefined]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\ntypedArrayTags[errorTag] = typedArrayTags[funcTag] =\ntypedArrayTags[mapTag] = typedArrayTags[numberTag] =\ntypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\ntypedArrayTags[setTag] = typedArrayTags[stringTag] =\ntypedArrayTags[weakMapTag] = false;\n\n/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar nodeUtil = (function() {\n try {\n return freeProcess && freeProcess.binding && freeProcess.binding('util');\n } catch (e) {}\n}());\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n/**\n * A specialized version of `_.filter` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\nfunction arrayFilter(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (predicate(value, index, array)) {\n result[resIndex++] = value;\n }\n }\n return result;\n}\n\n/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n var index = -1,\n length = values.length,\n offset = array.length;\n\n while (++index < length) {\n array[offset + index] = values[index];\n }\n return array;\n}\n\n/**\n * A specialized version of `_.some` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n * else `false`.\n */\nfunction arraySome(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (predicate(array[index], index, array)) {\n return true;\n }\n }\n return false;\n}\n\n/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n var index = -1,\n result = Array(n);\n\n while (++index < n) {\n result[index] = iteratee(index);\n }\n return result;\n}\n\n/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func) {\n return function(value) {\n return func(value);\n };\n}\n\n/**\n * Checks if a `cache` value for `key` exists.\n *\n * @private\n * @param {Object} cache The cache to query.\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction cacheHas(cache, key) {\n return cache.has(key);\n}\n\n/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n return object == null ? undefined : object[key];\n}\n\n/**\n * Converts `map` to its key-value pairs.\n *\n * @private\n * @param {Object} map The map to convert.\n * @returns {Array} Returns the key-value pairs.\n */\nfunction mapToArray(map) {\n var index = -1,\n result = Array(map.size);\n\n map.forEach(function(value, key) {\n result[++index] = [key, value];\n });\n return result;\n}\n\n/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n return function(arg) {\n return func(transform(arg));\n };\n}\n\n/**\n * Converts `set` to an array of its values.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the values.\n */\nfunction setToArray(set) {\n var index = -1,\n result = Array(set.size);\n\n set.forEach(function(value) {\n result[++index] = value;\n });\n return result;\n}\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype,\n funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined,\n Symbol = root.Symbol,\n Uint8Array = root.Uint8Array,\n propertyIsEnumerable = objectProto.propertyIsEnumerable,\n splice = arrayProto.splice,\n symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols,\n nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined,\n nativeKeys = overArg(Object.keys, Object);\n\n/* Built-in method references that are verified to be native. */\nvar DataView = getNative(root, 'DataView'),\n Map = getNative(root, 'Map'),\n Promise = getNative(root, 'Promise'),\n Set = getNative(root, 'Set'),\n WeakMap = getNative(root, 'WeakMap'),\n nativeCreate = getNative(Object, 'create');\n\n/** Used to detect maps, sets, and weakmaps. */\nvar dataViewCtorString = toSource(DataView),\n mapCtorString = toSource(Map),\n promiseCtorString = toSource(Promise),\n setCtorString = toSource(Set),\n weakMapCtorString = toSource(WeakMap);\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\n this.size = 0;\n}\n\n/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n var result = this.has(key) && delete this.__data__[key];\n this.size -= result ? 1 : 0;\n return result;\n}\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n var data = this.__data__;\n if (nativeCreate) {\n var result = data[key];\n return result === HASH_UNDEFINED ? undefined : result;\n }\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction hashHas(key) {\n var data = this.__data__;\n return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n}\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\nfunction hashSet(key, value) {\n var data = this.__data__;\n this.size += this.has(key) ? 0 : 1;\n data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n return this;\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n this.__data__ = [];\n this.size = 0;\n}\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n return false;\n }\n var lastIndex = data.length - 1;\n if (index == lastIndex) {\n data.pop();\n } else {\n splice.call(data, index, 1);\n }\n --this.size;\n return true;\n}\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n return index < 0 ? undefined : data[index][1];\n}\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n return assocIndexOf(this.__data__, key) > -1;\n}\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n ++this.size;\n data.push([key, value]);\n } else {\n data[index][1] = value;\n }\n return this;\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction MapCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n this.size = 0;\n this.__data__ = {\n 'hash': new Hash,\n 'map': new (Map || ListCache),\n 'string': new Hash\n };\n}\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n var result = getMapData(this, key)['delete'](key);\n this.size -= result ? 1 : 0;\n return result;\n}\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n return getMapData(this, key).get(key);\n}\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n return getMapData(this, key).has(key);\n}\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n var data = getMapData(this, key),\n size = data.size;\n\n data.set(key, value);\n this.size += data.size == size ? 0 : 1;\n return this;\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\n/**\n *\n * Creates an array cache object to store unique values.\n *\n * @private\n * @constructor\n * @param {Array} [values] The values to cache.\n */\nfunction SetCache(values) {\n var index = -1,\n length = values == null ? 0 : values.length;\n\n this.__data__ = new MapCache;\n while (++index < length) {\n this.add(values[index]);\n }\n}\n\n/**\n * Adds `value` to the array cache.\n *\n * @private\n * @name add\n * @memberOf SetCache\n * @alias push\n * @param {*} value The value to cache.\n * @returns {Object} Returns the cache instance.\n */\nfunction setCacheAdd(value) {\n this.__data__.set(value, HASH_UNDEFINED);\n return this;\n}\n\n/**\n * Checks if `value` is in the array cache.\n *\n * @private\n * @name has\n * @memberOf SetCache\n * @param {*} value The value to search for.\n * @returns {number} Returns `true` if `value` is found, else `false`.\n */\nfunction setCacheHas(value) {\n return this.__data__.has(value);\n}\n\n// Add methods to `SetCache`.\nSetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\nSetCache.prototype.has = setCacheHas;\n\n/**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Stack(entries) {\n var data = this.__data__ = new ListCache(entries);\n this.size = data.size;\n}\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n this.__data__ = new ListCache;\n this.size = 0;\n}\n\n/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n var data = this.__data__,\n result = data['delete'](key);\n\n this.size = data.size;\n return result;\n}\n\n/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n return this.__data__.get(key);\n}\n\n/**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n return this.__data__.has(key);\n}\n\n/**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\nfunction stackSet(key, value) {\n var data = this.__data__;\n if (data instanceof ListCache) {\n var pairs = data.__data__;\n if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n pairs.push([key, value]);\n this.size = ++data.size;\n return this;\n }\n data = this.__data__ = new MapCache(pairs);\n }\n data.set(key, value);\n this.size = data.size;\n return this;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n var isArr = isArray(value),\n isArg = !isArr && isArguments(value),\n isBuff = !isArr && !isArg && isBuffer(value),\n isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n skipIndexes = isArr || isArg || isBuff || isType,\n result = skipIndexes ? baseTimes(value.length, String) : [],\n length = result.length;\n\n for (var key in value) {\n if ((inherited || hasOwnProperty.call(value, key)) &&\n !(skipIndexes && (\n // Safari 9 has enumerable `arguments.length` in strict mode.\n key == 'length' ||\n // Node.js 0.10 has enumerable non-index properties on buffers.\n (isBuff && (key == 'offset' || key == 'parent')) ||\n // PhantomJS 2 has enumerable non-index properties on typed arrays.\n (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n // Skip index properties.\n isIndex(key, length)\n ))) {\n result.push(key);\n }\n }\n return result;\n}\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n var length = array.length;\n while (length--) {\n if (eq(array[length][0], key)) {\n return length;\n }\n }\n return -1;\n}\n\n/**\n * The base implementation of `getAllKeys` and `getAllKeysIn` which uses\n * `keysFunc` and `symbolsFunc` to get the enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @param {Function} symbolsFunc The function to get the symbols of `object`.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction baseGetAllKeys(object, keysFunc, symbolsFunc) {\n var result = keysFunc(object);\n return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\n}\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n}\n\n/**\n * The base implementation of `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\nfunction baseIsArguments(value) {\n return isObjectLike(value) && baseGetTag(value) == argsTag;\n}\n\n/**\n * The base implementation of `_.isEqual` which supports partial comparisons\n * and tracks traversed objects.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Unordered comparison\n * 2 - Partial comparison\n * @param {Function} [customizer] The function to customize comparisons.\n * @param {Object} [stack] Tracks traversed `value` and `other` objects.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n */\nfunction baseIsEqual(value, other, bitmask, customizer, stack) {\n if (value === other) {\n return true;\n }\n if (value == null || other == null || (!isObjectLike(value) && !isObjectLike(other))) {\n return value !== value && other !== other;\n }\n return baseIsEqualDeep(value, other, bitmask, customizer, baseIsEqual, stack);\n}\n\n/**\n * A specialized version of `baseIsEqual` for arrays and objects which performs\n * deep comparisons and tracks traversed objects enabling objects with circular\n * references to be compared.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} [stack] Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction baseIsEqualDeep(object, other, bitmask, customizer, equalFunc, stack) {\n var objIsArr = isArray(object),\n othIsArr = isArray(other),\n objTag = objIsArr ? arrayTag : getTag(object),\n othTag = othIsArr ? arrayTag : getTag(other);\n\n objTag = objTag == argsTag ? objectTag : objTag;\n othTag = othTag == argsTag ? objectTag : othTag;\n\n var objIsObj = objTag == objectTag,\n othIsObj = othTag == objectTag,\n isSameTag = objTag == othTag;\n\n if (isSameTag && isBuffer(object)) {\n if (!isBuffer(other)) {\n return false;\n }\n objIsArr = true;\n objIsObj = false;\n }\n if (isSameTag && !objIsObj) {\n stack || (stack = new Stack);\n return (objIsArr || isTypedArray(object))\n ? equalArrays(object, other, bitmask, customizer, equalFunc, stack)\n : equalByTag(object, other, objTag, bitmask, customizer, equalFunc, stack);\n }\n if (!(bitmask & COMPARE_PARTIAL_FLAG)) {\n var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'),\n othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__');\n\n if (objIsWrapped || othIsWrapped) {\n var objUnwrapped = objIsWrapped ? object.value() : object,\n othUnwrapped = othIsWrapped ? other.value() : other;\n\n stack || (stack = new Stack);\n return equalFunc(objUnwrapped, othUnwrapped, bitmask, customizer, stack);\n }\n }\n if (!isSameTag) {\n return false;\n }\n stack || (stack = new Stack);\n return equalObjects(object, other, bitmask, customizer, equalFunc, stack);\n}\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n */\nfunction baseIsNative(value) {\n if (!isObject(value) || isMasked(value)) {\n return false;\n }\n var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n return pattern.test(toSource(value));\n}\n\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\nfunction baseIsTypedArray(value) {\n return isObjectLike(value) &&\n isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n}\n\n/**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeys(object) {\n if (!isPrototype(object)) {\n return nativeKeys(object);\n }\n var result = [];\n for (var key in Object(object)) {\n if (hasOwnProperty.call(object, key) && key != 'constructor') {\n result.push(key);\n }\n }\n return result;\n}\n\n/**\n * A specialized version of `baseIsEqualDeep` for arrays with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Array} array The array to compare.\n * @param {Array} other The other array to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `array` and `other` objects.\n * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`.\n */\nfunction equalArrays(array, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n arrLength = array.length,\n othLength = other.length;\n\n if (arrLength != othLength && !(isPartial && othLength > arrLength)) {\n return false;\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(array);\n if (stacked && stack.get(other)) {\n return stacked == other;\n }\n var index = -1,\n result = true,\n seen = (bitmask & COMPARE_UNORDERED_FLAG) ? new SetCache : undefined;\n\n stack.set(array, other);\n stack.set(other, array);\n\n // Ignore non-index properties.\n while (++index < arrLength) {\n var arrValue = array[index],\n othValue = other[index];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, arrValue, index, other, array, stack)\n : customizer(arrValue, othValue, index, array, other, stack);\n }\n if (compared !== undefined) {\n if (compared) {\n continue;\n }\n result = false;\n break;\n }\n // Recursively compare arrays (susceptible to call stack limits).\n if (seen) {\n if (!arraySome(other, function(othValue, othIndex) {\n if (!cacheHas(seen, othIndex) &&\n (arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) {\n return seen.push(othIndex);\n }\n })) {\n result = false;\n break;\n }\n } else if (!(\n arrValue === othValue ||\n equalFunc(arrValue, othValue, bitmask, customizer, stack)\n )) {\n result = false;\n break;\n }\n }\n stack['delete'](array);\n stack['delete'](other);\n return result;\n}\n\n/**\n * A specialized version of `baseIsEqualDeep` for comparing objects of\n * the same `toStringTag`.\n *\n * **Note:** This function only supports comparing values with tags of\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {string} tag The `toStringTag` of the objects to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalByTag(object, other, tag, bitmask, customizer, equalFunc, stack) {\n switch (tag) {\n case dataViewTag:\n if ((object.byteLength != other.byteLength) ||\n (object.byteOffset != other.byteOffset)) {\n return false;\n }\n object = object.buffer;\n other = other.buffer;\n\n case arrayBufferTag:\n if ((object.byteLength != other.byteLength) ||\n !equalFunc(new Uint8Array(object), new Uint8Array(other))) {\n return false;\n }\n return true;\n\n case boolTag:\n case dateTag:\n case numberTag:\n // Coerce booleans to `1` or `0` and dates to milliseconds.\n // Invalid dates are coerced to `NaN`.\n return eq(+object, +other);\n\n case errorTag:\n return object.name == other.name && object.message == other.message;\n\n case regexpTag:\n case stringTag:\n // Coerce regexes to strings and treat strings, primitives and objects,\n // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring\n // for more details.\n return object == (other + '');\n\n case mapTag:\n var convert = mapToArray;\n\n case setTag:\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG;\n convert || (convert = setToArray);\n\n if (object.size != other.size && !isPartial) {\n return false;\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(object);\n if (stacked) {\n return stacked == other;\n }\n bitmask |= COMPARE_UNORDERED_FLAG;\n\n // Recursively compare objects (susceptible to call stack limits).\n stack.set(object, other);\n var result = equalArrays(convert(object), convert(other), bitmask, customizer, equalFunc, stack);\n stack['delete'](object);\n return result;\n\n case symbolTag:\n if (symbolValueOf) {\n return symbolValueOf.call(object) == symbolValueOf.call(other);\n }\n }\n return false;\n}\n\n/**\n * A specialized version of `baseIsEqualDeep` for objects with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalObjects(object, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n objProps = getAllKeys(object),\n objLength = objProps.length,\n othProps = getAllKeys(other),\n othLength = othProps.length;\n\n if (objLength != othLength && !isPartial) {\n return false;\n }\n var index = objLength;\n while (index--) {\n var key = objProps[index];\n if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) {\n return false;\n }\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(object);\n if (stacked && stack.get(other)) {\n return stacked == other;\n }\n var result = true;\n stack.set(object, other);\n stack.set(other, object);\n\n var skipCtor = isPartial;\n while (++index < objLength) {\n key = objProps[index];\n var objValue = object[key],\n othValue = other[key];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, objValue, key, other, object, stack)\n : customizer(objValue, othValue, key, object, other, stack);\n }\n // Recursively compare objects (susceptible to call stack limits).\n if (!(compared === undefined\n ? (objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack))\n : compared\n )) {\n result = false;\n break;\n }\n skipCtor || (skipCtor = key == 'constructor');\n }\n if (result && !skipCtor) {\n var objCtor = object.constructor,\n othCtor = other.constructor;\n\n // Non `Object` object instances with different constructors are not equal.\n if (objCtor != othCtor &&\n ('constructor' in object && 'constructor' in other) &&\n !(typeof objCtor == 'function' && objCtor instanceof objCtor &&\n typeof othCtor == 'function' && othCtor instanceof othCtor)) {\n result = false;\n }\n }\n stack['delete'](object);\n stack['delete'](other);\n return result;\n}\n\n/**\n * Creates an array of own enumerable property names and symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeys(object) {\n return baseGetAllKeys(object, keys, getSymbols);\n}\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n var data = map.__data__;\n return isKeyable(key)\n ? data[typeof key == 'string' ? 'string' : 'hash']\n : data.map;\n}\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n var value = getValue(object, key);\n return baseIsNative(value) ? value : undefined;\n}\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\n/**\n * Creates an array of the own enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbols = !nativeGetSymbols ? stubArray : function(object) {\n if (object == null) {\n return [];\n }\n object = Object(object);\n return arrayFilter(nativeGetSymbols(object), function(symbol) {\n return propertyIsEnumerable.call(object, symbol);\n });\n};\n\n/**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nvar getTag = baseGetTag;\n\n// Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\nif ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||\n (Map && getTag(new Map) != mapTag) ||\n (Promise && getTag(Promise.resolve()) != promiseTag) ||\n (Set && getTag(new Set) != setTag) ||\n (WeakMap && getTag(new WeakMap) != weakMapTag)) {\n getTag = function(value) {\n var result = baseGetTag(value),\n Ctor = result == objectTag ? value.constructor : undefined,\n ctorString = Ctor ? toSource(Ctor) : '';\n\n if (ctorString) {\n switch (ctorString) {\n case dataViewCtorString: return dataViewTag;\n case mapCtorString: return mapTag;\n case promiseCtorString: return promiseTag;\n case setCtorString: return setTag;\n case weakMapCtorString: return weakMapTag;\n }\n }\n return result;\n };\n}\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n length = length == null ? MAX_SAFE_INTEGER : length;\n return !!length &&\n (typeof value == 'number' || reIsUint.test(value)) &&\n (value > -1 && value % 1 == 0 && value < length);\n}\n\n/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n var type = typeof value;\n return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n ? (value !== '__proto__')\n : (value === null);\n}\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n return !!maskSrcKey && (maskSrcKey in func);\n}\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n var Ctor = value && value.constructor,\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n return value === proto;\n}\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n if (func != null) {\n try {\n return funcToString.call(func);\n } catch (e) {}\n try {\n return (func + '');\n } catch (e) {}\n }\n return '';\n}\n\n/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n return value === other || (value !== value && other !== other);\n}\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n * else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nvar isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n !propertyIsEnumerable.call(value, 'callee');\n};\n\n/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n}\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\n/**\n * Performs a deep comparison between two values to determine if they are\n * equivalent.\n *\n * **Note:** This method supports comparing arrays, array buffers, booleans,\n * date objects, error objects, maps, numbers, `Object` objects, regexes,\n * sets, strings, symbols, and typed arrays. `Object` objects are compared\n * by their own, not inherited, enumerable properties. Functions and DOM\n * nodes are compared by strict equality, i.e. `===`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.isEqual(object, other);\n * // => true\n *\n * object === other;\n * // => false\n */\nfunction isEqual(value, other) {\n return baseIsEqual(value, other);\n}\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\n/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n}\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nfunction keys(object) {\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\n\n/**\n * This method returns a new empty array.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {Array} Returns the new empty array.\n * @example\n *\n * var arrays = _.times(2, _.stubArray);\n *\n * console.log(arrays);\n * // => [[], []]\n *\n * console.log(arrays[0] === arrays[1]);\n * // => false\n */\nfunction stubArray() {\n return [];\n}\n\n/**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n return false;\n}\n\nmodule.exports = isEqual;\n"],"names":["chartLayoutGlobalState","value","subscribers","constructor","initialValue","arguments","length","undefined","JSON","parse","this","getValue","setValue","_this","newState","shouldReplace","forEach","subscriber","subscribe","itemToSubscribe","indexOf","push","unsubscribe","itemToUnsubscribe","filter","chartLayoutModel","chartLayoutModelConfigSnapshot","chartLayoutModelConfigSnapshotToCompare","lastGlobalRerender","Date","now","CONFIG_PROPS_TO_OMIT","CANVAS_ELEMENT_TYPES","Object","values","CanvasElementType","getConfigSnapshotToCompare","config","toConfig","charts","map","chart","panes","pane","elements","_ref","type","includes","useChartLayoutGlobalModel","stateGetter","setState","globalState","forceUpdate","useForceUpdate","React","useGlobalState","currentState","getIsConfigChanged","state","isEqual","getIsConfigChangedRef","current","setChartLayoutModel","generateNewLayoutModelConfigSnapshot","getChartLayoutModelConfig","_ref2","fallback","forceGlobalRerender","destroyCascade","Quote","deleteAll","HASH_UNDEFINED","COMPARE_PARTIAL_FLAG","COMPARE_UNORDERED_FLAG","MAX_SAFE_INTEGER","argsTag","arrayTag","asyncTag","boolTag","dateTag","errorTag","funcTag","genTag","mapTag","numberTag","nullTag","objectTag","promiseTag","proxyTag","regexpTag","setTag","stringTag","symbolTag","undefinedTag","weakMapTag","arrayBufferTag","dataViewTag","reIsHostCtor","reIsUint","typedArrayTags","freeGlobal","g","freeSelf","self","root","Function","freeExports","exports","nodeType","freeModule","module","moduleExports","freeProcess","process","nodeUtil","binding","e","nodeIsTypedArray","isTypedArray","arraySome","array","predicate","index","mapToArray","result","Array","size","key","setToArray","set","uid","func","transform","arrayProto","prototype","funcProto","objectProto","coreJsData","funcToString","toString","hasOwnProperty","maskSrcKey","exec","keys","IE_PROTO","nativeObjectToString","reIsNative","RegExp","call","replace","Buffer","Symbol","Uint8Array","propertyIsEnumerable","splice","symToStringTag","toStringTag","nativeGetSymbols","getOwnPropertySymbols","nativeIsBuffer","isBuffer","nativeKeys","arg","DataView","getNative","Map","Promise","Set","WeakMap","nativeCreate","dataViewCtorString","toSource","mapCtorString","promiseCtorString","setCtorString","weakMapCtorString","symbolProto","symbolValueOf","valueOf","Hash","entries","clear","entry","ListCache","MapCache","SetCache","__data__","add","Stack","data","arrayLikeKeys","inherited","isArr","isArray","isArg","isArguments","isBuff","isType","skipIndexes","n","iteratee","baseTimes","String","isIndex","assocIndexOf","eq","baseGetTag","isOwn","tag","unmasked","getRawTag","objectToString","baseIsArguments","isObjectLike","baseIsEqual","other","bitmask","customizer","stack","object","equalFunc","objIsArr","othIsArr","objTag","getTag","othTag","objIsObj","othIsObj","isSameTag","equalArrays","byteLength","byteOffset","buffer","name","message","convert","isPartial","stacked","get","equalByTag","objIsWrapped","othIsWrapped","objUnwrapped","othUnwrapped","objProps","getAllKeys","objLength","othProps","othLength","skipCtor","objValue","othValue","compared","objCtor","othCtor","equalObjects","baseIsEqualDeep","baseIsNative","isObject","isMasked","isFunction","test","baseKeys","Ctor","proto","arrLength","seen","arrValue","othIndex","has","keysFunc","symbolsFunc","offset","arrayPush","baseGetAllKeys","getSymbols","getMapData","pop","pairs","LARGE_ARRAY_SIZE","resIndex","arrayFilter","symbol","ArrayBuffer","resolve","ctorString","isLength","baseUnary"],"sourceRoot":""}