{"version":3,"sources":["webpack:///src/presentation/hocs/errorBoundary.tsx","webpack:///./presentation/hocs/visibilitySet.tsx","webpack:///./presentation/utils/ribbonWidth.ts","webpack:///./domain/impression/index.ts","webpack:///./presentation/components/ribbons/Ribbon/RibbonImpression.tsx","webpack:///./presentation/components/ribbons/Ribbon/Ribbon.tsx","webpack:///./presentation/components/ribbons/Ribbon/Ribbon.stylesheet.ts","webpack:///../node_modules/@team-griffin/css-sides/dist/es/css-sides.js","webpack:///../node_modules/ramda/es/contains.js","webpack:///../node_modules/ramda/es/of.js","webpack:///../node_modules/@ux/style-utils/dist/es/style-utils.js","webpack:///../node_modules/@team-griffin/css-longhand/dist/es/css-longhand.js","webpack:///./domain/transformers/ribbons/index.ts","webpack:///../node_modules/ramda/es/toLower.js","webpack:///../node_modules/ramda/es/replace.js","webpack:///./domain/logic/promotion.ts","webpack:///./infrastructure/cta/getProductData.ts","webpack:///./infrastructure/drivers/middleware.ts","webpack:///./presentation/utils/ribbonPadding.ts","webpack:///../node_modules/webpack/buildin/module.js","webpack:///./presentation/hooks/useIntersectionObserver.ts","webpack:///../node_modules/lodash.reduce/index.js","webpack:///../node_modules/ramda/es/always.js"],"names":["useStylesheet","flush","theme","useTheme","isMinLg","useBreakpoints","spacing","useStyles","default","root","backgroundColor","getBackgroundColor","color","getTitleColor","ribbonPadding","cssSides","Side","gu2px","textAlign","isMinSm","colorway","isMinMd","ErrorBoundary","r","styles","style","id","compose","withState","lifecycle","componentDidCatch","this","withProps","BaseComponent","props","display","getProductIds","productIds","toString","split","map","trim","filter","Boolean","productId","ImpressionRibbon","name","type","analytics","useRibbonAnalytics","ref","useRef","entry","useIntersectionObserver","freezeOnceVisible","useEffect","isIntersecting","list","createRibbonName","view","async","promises","getProductData","impressions","Promise","all","product","ecommerce","nonInteraction","sendProductDetail","sendProductImpression","promotion","promoId","promoNameToPromoId","sendPromotionImpression","className","component","children","displayName","PureRibbon","loading","layout","duoLayout","palette","fit","breakpoints","activeFit","findResponsiveItem","padding","duoLayoutFlex","flex","duoRibbonWidth","position","flexDirection","width","mapFit","inner","flexBasis","height","ribbon","modifier","Colorway","PRIMARY_GRADIENT","backgroundImage","primary","primaryGradient","targetRef","useLayoutEffect","process","RibbonImpression","_sidesMap","defineProperty","obj","key","value","Object","enumerable","configurable","writable","A","X","Y","actualSides","sidesMap","prop","sides","result","idx","assign","_includes","assoc","namespace","concat","clr","opacity","alpha","string","coreProp","keys","reduce","k","str","charAt","toUpperCase","substr","upperFirst","v","join","invoker","_curry3","regex","replacement","replace","skuId","locale","middleware","bodyOnly","jsonRpc","json","xray","fetch","getPaddingSize","shrinkSide","isFlush","shrinkLeading","shrinkTrailing","linariaPadding","leading","trailing","Flush","LEADING","TRAILING","getSizes","paddingTop","paddingBottom","module","exports","webpackPolyfill","deprecate","paths","get","l","i","elementRef","threshold","rootMargin","setEntry","useState","frozen","updateEntry","node","current","window","IntersectionObserver","observer","observe","disconnect","JSON","stringify","argsTag","mapTag","objectTag","setTag","reIsDeepProp","reIsPlainProp","reLeadingDot","rePropName","reEscapeChar","reIsHostCtor","reIsUint","typedArrayTags","freeGlobal","global","freeSelf","self","Function","freeExports","nodeType","freeModule","freeProcess","nodeUtil","binding","e","nodeIsTypedArray","isTypedArray","arrayReduce","array","iteratee","accumulator","initAccum","index","length","arraySome","predicate","baseReduce","collection","eachFunc","isHostObject","mapToArray","Array","size","forEach","setToArray","set","arrayProto","prototype","funcProto","objectProto","coreJsData","maskSrcKey","uid","exec","IE_PROTO","funcToString","hasOwnProperty","objectToString","reIsNative","RegExp","call","Symbol","Uint8Array","propertyIsEnumerable","splice","nativeKeys","func","transform","arg","overArg","DataView","getNative","Map","Set","WeakMap","nativeCreate","dataViewCtorString","toSource","mapCtorString","promiseCtorString","setCtorString","weakMapCtorString","symbolProto","undefined","symbolValueOf","valueOf","symbolToString","Hash","entries","clear","ListCache","MapCache","SetCache","values","__data__","add","Stack","arrayLikeKeys","inherited","isArray","isArguments","n","baseTimes","String","skipIndexes","isIndex","push","assocIndexOf","eq","has","data","pop","getMapData","cache","pairs","LARGE_ARRAY_SIZE","baseEach","fromRight","isArrayLike","iterable","createBaseEach","object","baseFor","keysFunc","createBaseFor","baseGet","path","isKey","castPath","toKey","baseHasIn","baseIsEqual","other","customizer","bitmask","stack","isObject","isObjectLike","equalFunc","objIsArr","othIsArr","objTag","othTag","getTag","objIsObj","othIsObj","isSameTag","equalArrays","tag","byteLength","byteOffset","buffer","message","convert","isPartial","stacked","equalByTag","objIsWrapped","othIsWrapped","objUnwrapped","othUnwrapped","objProps","objLength","othLength","skipCtor","objValue","othValue","compared","objCtor","constructor","othCtor","equalObjects","baseIsEqualDeep","baseIsNative","isMasked","isFunction","test","baseIteratee","identity","srcValue","isStrictComparable","matchesStrictComparable","defaultValue","hasFunc","isLength","hasPath","hasIn","UNORDERED_COMPARE_FLAG","baseMatchesProperty","source","matchData","getMatchData","noCustomizer","baseIsMatch","baseMatches","baseProperty","basePropertyDeep","property","baseKeys","Ctor","proto","isPrototype","stringToPath","arrLength","seen","arrValue","othIndex","isKeyable","getValue","isSymbol","ArrayBuffer","resolve","ctorString","memoize","baseToString","match","number","quote","resolver","TypeError","memoized","args","arguments","apply","Cache","isArrayLikeObject","baseUnary","always","val"],"mappings":"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","file":"pex-static/34/0.0701a07ff495134c1eb5.chunk.js","sourcesContent":["import React, { CSSProperties } from 'react';\nimport { compose, lifecycle, withState, withProps } from 'recompose';\nimport { Container } from '@uds/grid';\nimport Message from '@uds/message';\nimport * as r from 'ramda';\nimport cssSides, { Side } from '@team-griffin/css-sides';\nimport { getBackgroundColor, getTitleColor } from 'presentation/utils/colorway';\nimport { gu2px, useTheme, Colorway } from '@uds/theme-utils';\nimport ribbonPadding from 'presentation/utils/ribbonPadding';\nimport { useStyles } from '@team-griffin/stylr';\nimport { Layout } from 'domain/constants/layout';\nimport { Flush } from 'domain/constants/ribbons';\nimport { BreakpointProps, useBreakpoints } from '@ux/responsive';\n\ninterface OuterProps extends BreakpointProps {\n colorway: Colorway;\n layout: Layout;\n flush?: Flush | boolean;\n}\n\ninterface InnerProps extends OuterProps {\n styles: {\n root: CSSProperties;\n };\n hasErrored: boolean;\n}\nconst useStylesheet = ({ colorway, layout, flush }: InnerProps) => {\n const { theme } = useTheme();\n const { isMinSm, isMinMd, isMinLg } = useBreakpoints();\n const { spacing } = theme;\n\n return useStyles(\n {\n default: {\n // @ts-ignore: error when upgrading to @ux/config\n root: {\n backgroundColor: getBackgroundColor(theme, colorway),\n color: getTitleColor(theme, colorway),\n ...ribbonPadding({\n spacing,\n isMinSm,\n isMinLg,\n layout,\n flush,\n }),\n ...cssSides('Side', Side.X, gu2px(3, spacing)),\n textAlign: 'center',\n },\n },\n isMinSm: {\n root: {\n ...cssSides('Side', Side.X, gu2px(4, spacing)),\n },\n },\n },\n [{ colorway }, { isMinSm }, { isMinMd }],\n );\n};\n\nexport default (WrappedComponent: any) => {\n const ErrorBoundary = r.ifElse(\n r.propEq('hasErrored', true),\n ({ styles }) => (\n
\n \n \n \n
\n ),\n (props: InnerProps) => ,\n );\n\n return compose(\n withState('hasErrored', 'setHasErrored', false),\n lifecycle({\n componentDidCatch: function () {\n // @ts-ignore: error after upgrading eslint config. Please replace with relevant comment\n this.props.setHasErrored(true);\n },\n }),\n withProps(useStylesheet),\n )(ErrorBoundary);\n};\n","import React from 'react';\nimport * as r from 'ramda';\n\nexport default (BaseComponent: any) =>\n r.ifElse(\n r.prop('visible'),\n (props) => ,\n (props) => (\n
\n \n
\n ),\n );\n","export const duoRibbonWidth = ({ isMinMd, duoLayout }: { isMinMd: boolean; duoLayout?: boolean }) => {\n if (!isMinMd || duoLayout == null) {\n return {};\n }\n\n const flexSize = isMinMd && duoLayout ? 50 : 100;\n return {\n flex: `${flexSize}%`,\n };\n};\n\nexport default null;\n","import { Product } from '@uds/product';\nimport { ecommerce } from '@uds/tagmg';\nimport { Maybe } from 'core';\nimport { Analytics } from 'domain/constants/ribbons';\nimport { promoNameToPromoId } from 'domain/logic/promotion';\nimport { getProductData } from 'infrastructure/cta';\n\ntype Impression = [\n string,\n {\n id: number;\n name: string;\n list?: string;\n },\n];\n\nconst getProductIds = (productIds: Maybe = '') =>\n (productIds ?? '')\n .toString()\n .split(',')\n .map((id: string) => id.trim())\n .filter(Boolean)\n .map((productId) => ({ productId }));\n\nexport const sendProductDetail = async (analytics: Analytics) => {\n const { productId } = analytics ?? {};\n const productIds = getProductIds(productId);\n const promises = productIds.map(getProductData);\n const products = await Promise.all(promises);\n const impressions = products.map((product: Product) => {\n const impression: Impression = [\n 'addProduct',\n {\n id: product.id,\n name: product.name,\n },\n ];\n return impression;\n });\n ecommerce([...impressions, ['setAction', 'detail']], { nonInteraction: true });\n};\n\nexport const sendProductImpression = async (analytics: Analytics, list: string) => {\n const { productId } = analytics ?? {};\n const productIds = getProductIds(productId);\n const promises = productIds.map(getProductData);\n const products = await Promise.all(promises);\n const impressions = products.map((product: Product) => {\n const impression: Impression = [\n 'addImpression',\n {\n id: product.id,\n name: product.name,\n list,\n },\n ];\n return impression;\n });\n ecommerce(impressions, { nonInteraction: true });\n};\n\nexport const sendPromotionImpression = (analytics: Analytics, list: string) => {\n const { promotion } = analytics ?? {};\n\n if (promotion == null || promotion === '') {\n return null;\n }\n\n const promoId = promoNameToPromoId(promotion);\n ecommerce(\n [\n [\n 'addImpression',\n {\n id: promoId,\n name: promotion,\n list,\n },\n ],\n ],\n { nonInteraction: true },\n );\n};\n","import { PropsWithChildren, useRef, useEffect, StyleHTMLAttributes } from 'react';\nimport { Type } from 'domain/constants/ribbons';\nimport useIntersectionObserver from 'presentation/hooks/useIntersectionObserver';\nimport { useRibbonAnalytics } from 'domain/selectors/ribbons';\nimport { createRibbonName } from 'domain/transformers/ribbons';\nimport { sendProductDetail, sendProductImpression, sendPromotionImpression } from 'domain/impression';\nimport Colorway, { Colorways } from '@uds/colorway';\n\ninterface OuterProps {\n id: string;\n name: string;\n type?: Type;\n style?: StyleHTMLAttributes;\n colorway: Colorways;\n className?: string | undefined;\n}\n\nconst ImpressionRibbon = (props: PropsWithChildren) => {\n const { id, name, type } = props;\n const analytics = useRibbonAnalytics(id);\n const ref = useRef(null);\n const entry = useIntersectionObserver(ref, {\n freezeOnceVisible: true,\n });\n\n useEffect(() => {\n if (analytics == null || entry?.isIntersecting !== true) {\n return;\n }\n const list = createRibbonName(type, name);\n\n if (analytics.type === 'PRODUCT' && analytics.view === 'DETAIL') {\n sendProductDetail(analytics);\n } else if (analytics.type === 'PRODUCT' && analytics.view === 'IMPRESSION') {\n sendProductImpression(analytics, list);\n } else if (analytics.type === 'PROMOTION') {\n sendPromotionImpression(analytics, list);\n }\n }, [entry?.isIntersecting, analytics, name, type]);\n\n return (\n \n {props.children}\n \n );\n};\n\nImpressionRibbon.displayName = 'ImpressionRibbon';\n\nexport default ImpressionRibbon;\n","import React, { useRef, useLayoutEffect, ReactNode, ComponentType } from 'react';\nimport { Flush, RibbonProps } from 'domain/constants/ribbons';\n\nimport useStylesheet from './Ribbon.stylesheet';\nimport RibbonImpression from './RibbonImpression';\n\nexport { Flush };\n\ninterface OuterProps extends RibbonProps {\n children?: ReactNode;\n className?: string | undefined;\n}\n\nexport const PureRibbon = ({\n children,\n colorway,\n loading,\n layout,\n flush,\n duoLayout,\n id,\n name,\n type,\n className,\n}: OuterProps) => {\n const { styles } = useStylesheet({\n colorway,\n loading,\n layout,\n flush,\n duoLayout,\n });\n const targetRef = useRef(null);\n\n useLayoutEffect(() => {\n // when backstop runs on ribbons, this lets us filter out a lot of false\n // positives and a lot of race condition fails by only initialising\n // the snapshot once loading has finished + a delay to wait for fonts etc to load\n if (process.env.NODE_ENV !== 'production') {\n setTimeout(() => {\n // eslint-disable-next-line no-console\n console.log('BACKSTOP_RIBBON_READY');\n }, 3000);\n }\n }, []);\n\n return (\n \n
\n
\n {children}\n
\n
\n
\n );\n};\n\nPureRibbon.displayName = 'Ribbon';\n\nexport default PureRibbon as ComponentType;\n","import { useBreakpoints } from '@ux/responsive';\nimport { useStyles } from '@team-griffin/stylr';\nimport { modifier } from '@ux/style-utils';\nimport { useTheme, Colorway } from '@uds/theme-utils';\nimport { Flush } from 'domain/constants/ribbons';\nimport { Layout } from 'domain/constants/layout';\nimport findResponsiveItem from 'presentation/utils/findResponsiveItem';\nimport ribbonPadding from 'presentation/utils/ribbonPadding';\nimport { duoRibbonWidth } from 'presentation/utils/ribbonWidth';\n\nimport { mapFit } from './utils';\n\nexport default ({\n colorway,\n loading,\n layout,\n flush,\n duoLayout,\n}: {\n colorway: Colorway;\n loading: boolean;\n layout: Layout;\n flush?: Flush | boolean;\n duoLayout?: boolean;\n}) => {\n const { theme } = useTheme();\n const { palette, spacing } = theme;\n const { fit } = layout ?? {};\n const breakpoints = useBreakpoints();\n const { isMinSm, isMinMd, isMinLg } = breakpoints;\n\n const activeFit = findResponsiveItem(breakpoints, fit);\n\n const padding = ribbonPadding({\n spacing,\n isMinSm,\n isMinLg,\n layout,\n flush,\n });\n\n const duoLayoutFlex = duoRibbonWidth({\n isMinMd,\n duoLayout,\n });\n\n return useStyles(\n {\n default: {\n // @ts-ignore: error after upgrading to ux-configs\n root: {\n position: 'relative',\n display: 'flex',\n flexDirection: 'column',\n width: '100%',\n ...mapFit(activeFit, true),\n ...padding,\n ...duoLayoutFlex,\n },\n inner: {\n flex: 1,\n flexBasis: 'auto',\n display: 'flex',\n height: 'auto',\n },\n ribbon: {\n display: 'flex',\n flexDirection: 'column',\n width: '100%',\n },\n },\n\n [modifier('colorway', Colorway.PRIMARY_GRADIENT)]: {\n root: {\n backgroundImage: `linear-gradient(to right, ${palette.primary}, ${palette.primaryGradient})`,\n },\n },\n },\n [{ loading }, { colorway }, { isMinSm }, { isMinMd }, { isMinLg }],\n );\n};\n","import cssLonghand from '@team-griffin/css-longhand';\nimport reduce from 'lodash.reduce';\n\nvar defineProperty = function (obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n};\n\nvar _sidesMap;\n\nvar Side = {\n A: 'a',\n X: 'x',\n Y: 'y'\n};\n\nvar actualSides = ['left', 'top', 'right', 'bottom'];\n\nvar sidesMap = (_sidesMap = {}, defineProperty(_sidesMap, Side.A, [0, 1, 2, 3]), defineProperty(_sidesMap, Side.X, [0, 2]), defineProperty(_sidesMap, Side.Y, [1, 3]), _sidesMap);\n\nvar cssSides = function cssSides(prop, sides, value) {\n return cssLonghand(prop, reduce(sidesMap[sides], function (result, idx) {\n return Object.assign({}, result, defineProperty({}, actualSides[idx], value));\n }, {}));\n};\n\nexport default cssSides;\nexport { Side };\n","import _includes from \"./internal/_includes.js\";\nimport _curry2 from \"./internal/_curry2.js\";\n/**\n * Returns `true` if the specified value is equal, in [`R.equals`](#equals)\n * terms, to at least one element of the given list; `false` otherwise.\n * Works also with strings.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig a -> [a] -> Boolean\n * @param {Object} a The item to compare against.\n * @param {Array} list The array to consider.\n * @return {Boolean} `true` if an equivalent item is in the list, `false` otherwise.\n * @see R.includes\n * @deprecated since v0.26.0\n * @example\n *\n * R.contains(3, [1, 2, 3]); //=> true\n * R.contains(4, [1, 2, 3]); //=> false\n * R.contains({ name: 'Fred' }, [{ name: 'Fred' }]); //=> true\n * R.contains([42], [[42]]); //=> true\n * R.contains('ba', 'banana'); //=>true\n */\n\nvar contains =\n/*#__PURE__*/\n_curry2(_includes);\n\nexport default contains;","import _curry1 from \"./internal/_curry1.js\";\nimport _of from \"./internal/_of.js\";\n/**\n * Returns a singleton array containing the value provided.\n *\n * Note this `of` is different from the ES6 `of`; See\n * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/of\n *\n * @func\n * @memberOf R\n * @since v0.3.0\n * @category Function\n * @sig a -> [a]\n * @param {*} x any value\n * @return {Array} An array wrapping `x`.\n * @example\n *\n * R.of(null); //=> [null]\n * R.of([42]); //=> [[42]]\n */\n\nvar of =\n/*#__PURE__*/\n_curry1(_of);\n\nexport default of;","import { compose, withState, lifecycle, withProps, branch } from 'recompose';\nimport { always, mergeDeepRight, pipe, prop, isNil, defaultTo, filter, either, is, mapObjIndexed, ifElse, contains, __, find, equals, assoc, of, ap, identity, apply } from 'ramda';\nimport color from 'color';\n\nvar srOnly = {\n position: 'absolute',\n width: 1,\n height: 1,\n padding: 0,\n overflow: 'hidden',\n clip: 'rect(0, 0, 0, 0)',\n whiteSpace: 'nowrap',\n clipPath: 'inset(50%)',\n border: 0\n};\n\nvar isInCache = function isInCache(key, values, cache) {\n return pipe(prop(key), contains(__, values))(cache);\n};\n\nvar addToCache = assoc;\n\nvar getKeyPath = function getKeyPath(key, path) {\n return path ? \"\".concat(path, \".\").concat(key) : key;\n};\n\nvar getSameKeyStyles = function getSameKeyStyles(document, styleObj) {\n var inCache = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n var path = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : '';\n var div,\n cache = inCache;\n return pipe(defaultTo({}), filter(either(is(Array), is(Object))), mapObjIndexed(function (values, key) {\n return ifElse(is(Array), function (values) {\n var keyPath = getKeyPath(key, path);\n\n if (isInCache(keyPath, values, cache)) {\n return cache[keyPath];\n }\n\n div = div || document.createElement('div');\n var property = find(function (value) {\n // @ts-ignore\n div.style[key] = value; // @ts-ignore\n\n if (div.style[key] === value) {\n cache = addToCache(keyPath, value, cache);\n return true;\n }\n }, values);\n return property;\n }, function (values) {\n var keyPath = getKeyPath(key, path);\n var result = getSameKeyStyles(document, values, cache, keyPath);\n cache = result.cache;\n return result.resolvedStyles;\n })(values);\n }), function (resolvedStyles) {\n return {\n resolvedStyles: resolvedStyles,\n cache: cache\n };\n })(styleObj);\n};\n\nvar resolveStyles = function resolveStyles(props) {\n var _getSameKeyStyles = getSameKeyStyles(document, props.styles, props.resolvedStylesCache),\n resolvedStyles = _getSameKeyStyles.resolvedStyles,\n cache = _getSameKeyStyles.cache;\n\n if (equals(resolvedStyles, props.resolvedStyles) === false) {\n props.setResolvedStyles(resolvedStyles);\n props.setResolvedStylesCache(cache);\n }\n};\n\nvar sameKeyStyles = function sameKeyStyles() {\n return compose(withState('resolvedStyles', 'setResolvedStyles', null), withState('resolvedStylesCache', 'setResolvedStylesCache', always({})), lifecycle({\n componentWillMount: function componentWillMount() {\n resolveStyles(this.props);\n },\n componentWillUpdate: function componentWillUpdate() {\n resolveStyles(this.props);\n }\n }), withProps(function (ownerProps) {\n return {\n styles: mergeDeepRight(ownerProps.styles || {}, ownerProps.resolvedStyles || {})\n };\n }), branch(pipe(prop('resolvedStyles'), isNil), always(always(null))));\n};\n\nvar withStyles = function withStyles(stylesheet) {\n return withProps(function (props) {\n return {\n styles: stylesheet(props)\n };\n });\n};\n\nvar withStyles$1 = function withStyles(stylesheet) {\n return function (props) {\n return Object.assign({}, props, {\n styles: stylesheet(props)\n });\n };\n};\n\nvar getStyles = function getStyles(stylesheet, stylesheetToStyles, props) {\n var pipeStyles = pipe(of, ap([stylesheet, identity]), apply(stylesheetToStyles));\n return pipeStyles(props);\n};\n\n/* eslint-disable max-len */\nvar modifier = function modifier(namespace, value) {\n return \"\".concat(namespace, \"-\").concat(value);\n};\n\nvar opacify = function opacify(clr, opacity) {\n return color(clr).alpha(opacity).string();\n};\n\nfunction percentage(value) {\n return \"\".concat(value, \"%\");\n}\n\nexport { srOnly, sameKeyStyles, withStyles, withStyles$1 as withStylesHook, getStyles, modifier, opacify, percentage };\n","var defineProperty = function (obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n};\n\nvar upperFirst = function upperFirst(str) {\n return str.charAt(0).toUpperCase() + str.substr(1);\n};\n\nvar longhand = function longhand(coreProp, prop) {\n return Object.keys(prop).reduce(function (result, key) {\n var k = \"\" + coreProp + upperFirst(key);\n var v = prop[key];\n\n return Object.assign({}, result, defineProperty({}, k, v));\n }, {});\n};\n\nexport default longhand;\n","export const createRibbonName = (type?: string, name?: string) => ['Ribbon', type, name].filter(Boolean).join(' - ');\n\nexport default null;\n","import invoker from \"./invoker.js\";\n/**\n * The lower case version of a string.\n *\n * @func\n * @memberOf R\n * @since v0.9.0\n * @category String\n * @sig String -> String\n * @param {String} str The string to lower case.\n * @return {String} The lower case version of `str`.\n * @see R.toUpper\n * @example\n *\n * R.toLower('XYZ'); //=> 'xyz'\n */\n\nvar toLower =\n/*#__PURE__*/\ninvoker(0, 'toLowerCase');\nexport default toLower;","import _curry3 from \"./internal/_curry3.js\";\n/**\n * Replace a substring or regex match in a string with a replacement.\n *\n * The first two parameters correspond to the parameters of the\n * `String.prototype.replace()` function, so the second parameter can also be a\n * function.\n *\n * @func\n * @memberOf R\n * @since v0.7.0\n * @category String\n * @sig RegExp|String -> String -> String -> String\n * @param {RegExp|String} pattern A regular expression or a substring to match.\n * @param {String} replacement The string to replace the matches with.\n * @param {String} str The String to do the search and replacement in.\n * @return {String} The result.\n * @example\n *\n * R.replace('foo', 'bar', 'foo foo foo'); //=> 'bar foo foo'\n * R.replace(/foo/, 'bar', 'foo foo foo'); //=> 'bar foo foo'\n *\n * // Use the \"g\" (global) flag to replace all occurrences:\n * R.replace(/foo/g, 'bar', 'foo foo foo'); //=> 'bar bar bar'\n */\n\nvar replace =\n/*#__PURE__*/\n_curry3(function replace(regex, replacement, str) {\n return str.replace(regex, replacement);\n});\n\nexport default replace;","import * as r from 'ramda';\n\n// \"My Promotion\" -> \"my_promotion\"\n// as GA ids have to adhere to certain rules (like no spaces)\n// and we don't get a specific id, just a promotion name\n// we remove spaces and strip any invalid characters (anything that's not a letter, number, or _)\nexport const promoNameToPromoId = r.pipe(r.toLower, r.replace(/ +?/g, '_'), r.replace(/[^a-z0-9_]/gim, ''));\n\nexport default null;\n","import { GetProductData } from 'core/cta';\n\nimport middleware from '../drivers/middleware';\n\nconst getProductData: GetProductData = ({ productId, skuId, locale = 'en' }) => {\n return middleware()('0', 'getProduct', {\n productId,\n skuId,\n locale,\n });\n};\n\nexport default getProductData;\n","import { json, jsonRpc, middleware, xray, fetch, bodyOnly } from '@ux/drivers';\nimport * as r from 'ramda';\n\nexport default () => r.compose(middleware(), bodyOnly(), jsonRpc(), json(), xray())(fetch);\n","import { Flush } from 'domain/constants/ribbons';\nimport { gu2px } from '@uds/theme-utils';\nimport { Layout } from 'domain/constants/layout';\n\n/*\n shrinkSide:\n shrink[Leading/Trailing] prop is true then return a reduced padding\n depending on screen size\n isFlush:\n leading or trailing edge has been designated as flush, no padding\n*/\nconst getPaddingSize = ({\n shrinkSide,\n isFlush,\n layout,\n isMinSm,\n isMinLg,\n}: {\n shrinkSide: 'shrinkLeading' | 'shrinkTrailing';\n isFlush: boolean;\n layout: Layout;\n isMinSm: boolean;\n isMinLg: boolean;\n}) => {\n const { shrinkLeading, shrinkTrailing } = layout;\n\n const sides = {\n shrinkLeading,\n shrinkTrailing,\n };\n if (isFlush) {\n return 0;\n }\n\n if (sides[shrinkSide] === true) {\n if (isMinSm) {\n return 1;\n }\n return 0.5;\n }\n if (isMinLg) {\n return 6;\n }\n if (isMinSm) {\n return 5;\n }\n return 4;\n};\n\nconst getSizes = ({\n flush,\n layout,\n isMinSm,\n isMinLg,\n}: {\n flush?: Flush | boolean;\n layout: Layout;\n isMinSm: boolean;\n isMinLg: boolean;\n}) => {\n const leading = getPaddingSize({\n shrinkSide: 'shrinkLeading',\n isFlush: flush === Flush.LEADING,\n layout,\n isMinSm,\n isMinLg,\n });\n const trailing = getPaddingSize({\n shrinkSide: 'shrinkTrailing',\n isFlush: flush === Flush.TRAILING,\n layout,\n isMinSm,\n isMinLg,\n });\n return {\n leading,\n trailing,\n };\n};\n\nexport default ({\n spacing,\n isMinSm,\n isMinLg,\n layout = {},\n flush,\n linariaPadding = false,\n}: {\n spacing: number;\n isMinSm: boolean;\n isMinLg: boolean;\n layout?: Layout;\n flush?: Flush | boolean;\n linariaPadding?: boolean;\n}) => {\n if (flush === true) {\n // Component will handle all padding, used on full bleed image ribbons\n return {};\n }\n const { leading, trailing } = getSizes({\n flush,\n layout,\n isMinSm,\n isMinLg,\n });\n\n if (linariaPadding) {\n return { '--centerfold-padding-top': leading, '--centerfold-padding-bottom': trailing };\n }\n return {\n paddingTop: gu2px(leading, spacing),\n paddingBottom: gu2px(trailing, spacing),\n };\n};\n","module.exports = function(module) {\n\tif (!module.webpackPolyfill) {\n\t\tmodule.deprecate = function() {};\n\t\tmodule.paths = [];\n\t\t// module.parent = undefined by default\n\t\tif (!module.children) module.children = [];\n\t\tObject.defineProperty(module, \"loaded\", {\n\t\t\tenumerable: true,\n\t\t\tget: function() {\n\t\t\t\treturn module.l;\n\t\t\t}\n\t\t});\n\t\tObject.defineProperty(module, \"id\", {\n\t\t\tenumerable: true,\n\t\t\tget: function() {\n\t\t\t\treturn module.i;\n\t\t\t}\n\t\t});\n\t\tmodule.webpackPolyfill = 1;\n\t}\n\treturn module;\n};\n","// SOURCE: I stole it. (https://usehooks-ts.com/react-hook/use-intersection-observer)\n\nimport { RefObject, useEffect, useState } from 'react';\n\ninterface Args extends IntersectionObserverInit {\n freezeOnceVisible?: boolean;\n}\n\nfunction useIntersectionObserver(\n elementRef: RefObject,\n { threshold = 0, root = null, rootMargin = '0%', freezeOnceVisible = false }: Args,\n): IntersectionObserverEntry | undefined {\n const [entry, setEntry] = useState();\n\n const frozen = entry?.isIntersecting && freezeOnceVisible;\n\n const updateEntry = ([entry]: Array): void => {\n setEntry(entry);\n };\n\n useEffect(() => {\n const node = elementRef?.current; // DOM Ref\n const hasIOSupport = !!window.IntersectionObserver;\n\n if (!hasIOSupport || frozen || !node) return;\n\n const observerParams = { threshold, root, rootMargin };\n const observer = new IntersectionObserver(updateEntry, observerParams);\n\n observer.observe(node);\n\n return () => observer.disconnect();\n\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [elementRef, JSON.stringify(threshold), root, rootMargin, frozen]);\n\n return entry;\n}\n\nexport default useIntersectionObserver;\n","/**\n * lodash (Custom Build) \n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright jQuery 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 as the `TypeError` message for \"Functions\" methods. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used to compose bitmasks for comparison styles. */\nvar UNORDERED_COMPARE_FLAG = 1,\n PARTIAL_COMPARE_FLAG = 2;\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0,\n MAX_SAFE_INTEGER = 9007199254740991;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\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 objectTag = '[object Object]',\n promiseTag = '[object Promise]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]',\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/** Used to match property names within property paths. */\nvar reIsDeepProp = /\\.|\\[(?:[^[\\]]*|([\"'])(?:(?!\\1)[^\\\\]|\\\\.)*?\\1)\\]/,\n reIsPlainProp = /^\\w*$/,\n reLeadingDot = /^\\./,\n rePropName = /[^.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|$))/g;\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 match backslashes in property paths. */\nvar reEscapeChar = /\\\\(\\\\)?/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('util');\n } catch (e) {}\n}());\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n/**\n * A specialized version of `_.reduce` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @param {boolean} [initAccum] Specify using the first element of `array` as\n * the initial value.\n * @returns {*} Returns the accumulated value.\n */\nfunction arrayReduce(array, iteratee, accumulator, initAccum) {\n var index = -1,\n length = array ? array.length : 0;\n\n if (initAccum && length) {\n accumulator = array[++index];\n }\n while (++index < length) {\n accumulator = iteratee(accumulator, array[index], index, array);\n }\n return accumulator;\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 ? array.length : 0;\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 `_.property` without support for deep paths.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @returns {Function} Returns the new accessor function.\n */\nfunction baseProperty(key) {\n return function(object) {\n return object == null ? undefined : object[key];\n };\n}\n\n/**\n * The base implementation of `_.reduce` and `_.reduceRight`, without support\n * for iteratee shorthands, which iterates over `collection` using `eachFunc`.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {*} accumulator The initial value.\n * @param {boolean} initAccum Specify using the first or last element of\n * `collection` as the initial value.\n * @param {Function} eachFunc The function to iterate over `collection`.\n * @returns {*} Returns the accumulated value.\n */\nfunction baseReduce(collection, iteratee, accumulator, initAccum, eachFunc) {\n eachFunc(collection, function(value, index, collection) {\n accumulator = initAccum\n ? (initAccum = false, value)\n : iteratee(accumulator, value, index, collection);\n });\n return accumulator;\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 * 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 * Checks if `value` is a host object in IE < 9.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a host object, else `false`.\n */\nfunction isHostObject(value) {\n // Many host objects are `Object` objects that can coerce to strings\n // despite having improperly defined `toString` methods.\n var result = false;\n if (value != null && typeof value.toString != 'function') {\n try {\n result = !!(value + '');\n } catch (e) {}\n }\n return result;\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 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/** 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/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = 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 Symbol = root.Symbol,\n Uint8Array = root.Uint8Array,\n propertyIsEnumerable = objectProto.propertyIsEnumerable,\n splice = arrayProto.splice;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar 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 symbolToString = symbolProto ? symbolProto.toString : 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 ? entries.length : 0;\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}\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 return this.has(key) && delete this.__data__[key];\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 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 ? entries.length : 0;\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}\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 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 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 ? entries.length : 0;\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.__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 return getMapData(this, key)['delete'](key);\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 getMapData(this, key).set(key, value);\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 ? values.length : 0;\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 this.__data__ = new ListCache(entries);\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}\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 return this.__data__['delete'](key);\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 cache = this.__data__;\n if (cache instanceof ListCache) {\n var pairs = cache.__data__;\n if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n pairs.push([key, value]);\n return this;\n }\n cache = this.__data__ = new MapCache(pairs);\n }\n cache.set(key, value);\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 // Safari 8.1 makes `arguments.callee` enumerable in strict mode.\n // Safari 9 makes `arguments.length` enumerable in strict mode.\n var result = (isArray(value) || isArguments(value))\n ? baseTimes(value.length, String)\n : [];\n\n var length = result.length,\n skipIndexes = !!length;\n\n for (var key in value) {\n if ((inherited || hasOwnProperty.call(value, key)) &&\n !(skipIndexes && (key == 'length' || isIndex(key, length)))) {\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 `_.forEach` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n */\nvar baseEach = createBaseEach(baseForOwn);\n\n/**\n * The base implementation of `baseForOwn` which iterates over `object`\n * properties returned by `keysFunc` and invokes `iteratee` for each property.\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @returns {Object} Returns `object`.\n */\nvar baseFor = createBaseFor();\n\n/**\n * The base implementation of `_.forOwn` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Object} Returns `object`.\n */\nfunction baseForOwn(object, iteratee) {\n return object && baseFor(object, iteratee, keys);\n}\n\n/**\n * The base implementation of `_.get` without support for default values.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @returns {*} Returns the resolved value.\n */\nfunction baseGet(object, path) {\n path = isKey(path, object) ? [path] : castPath(path);\n\n var index = 0,\n length = path.length;\n\n while (object != null && index < length) {\n object = object[toKey(path[index++])];\n }\n return (index && index == length) ? object : undefined;\n}\n\n/**\n * The base implementation of `getTag`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n return objectToString.call(value);\n}\n\n/**\n * The base implementation of `_.hasIn` without support for deep paths.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {Array|string} key The key to check.\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\n */\nfunction baseHasIn(object, key) {\n return object != null && key in Object(object);\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 {Function} [customizer] The function to customize comparisons.\n * @param {boolean} [bitmask] The bitmask of comparison flags.\n * The bitmask may be composed of the following flags:\n * 1 - Unordered comparison\n * 2 - Partial comparison\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, customizer, bitmask, stack) {\n if (value === other) {\n return true;\n }\n if (value == null || other == null || (!isObject(value) && !isObjectLike(other))) {\n return value !== value && other !== other;\n }\n return baseIsEqualDeep(value, other, baseIsEqual, customizer, bitmask, 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 {Function} equalFunc The function to determine equivalents of values.\n * @param {Function} [customizer] The function to customize comparisons.\n * @param {number} [bitmask] The bitmask of comparison flags. See `baseIsEqual`\n * for more details.\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, equalFunc, customizer, bitmask, stack) {\n var objIsArr = isArray(object),\n othIsArr = isArray(other),\n objTag = arrayTag,\n othTag = arrayTag;\n\n if (!objIsArr) {\n objTag = getTag(object);\n objTag = objTag == argsTag ? objectTag : objTag;\n }\n if (!othIsArr) {\n othTag = getTag(other);\n othTag = othTag == argsTag ? objectTag : othTag;\n }\n var objIsObj = objTag == objectTag && !isHostObject(object),\n othIsObj = othTag == objectTag && !isHostObject(other),\n isSameTag = objTag == othTag;\n\n if (isSameTag && !objIsObj) {\n stack || (stack = new Stack);\n return (objIsArr || isTypedArray(object))\n ? equalArrays(object, other, equalFunc, customizer, bitmask, stack)\n : equalByTag(object, other, objTag, equalFunc, customizer, bitmask, stack);\n }\n if (!(bitmask & PARTIAL_COMPARE_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, customizer, bitmask, stack);\n }\n }\n if (!isSameTag) {\n return false;\n }\n stack || (stack = new Stack);\n return equalObjects(object, other, equalFunc, customizer, bitmask, stack);\n}\n\n/**\n * The base implementation of `_.isMatch` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property values to match.\n * @param {Array} matchData The property names, values, and compare flags to match.\n * @param {Function} [customizer] The function to customize comparisons.\n * @returns {boolean} Returns `true` if `object` is a match, else `false`.\n */\nfunction baseIsMatch(object, source, matchData, customizer) {\n var index = matchData.length,\n length = index,\n noCustomizer = !customizer;\n\n if (object == null) {\n return !length;\n }\n object = Object(object);\n while (index--) {\n var data = matchData[index];\n if ((noCustomizer && data[2])\n ? data[1] !== object[data[0]]\n : !(data[0] in object)\n ) {\n return false;\n }\n }\n while (++index < length) {\n data = matchData[index];\n var key = data[0],\n objValue = object[key],\n srcValue = data[1];\n\n if (noCustomizer && data[2]) {\n if (objValue === undefined && !(key in object)) {\n return false;\n }\n } else {\n var stack = new Stack;\n if (customizer) {\n var result = customizer(objValue, srcValue, key, object, source, stack);\n }\n if (!(result === undefined\n ? baseIsEqual(srcValue, objValue, customizer, UNORDERED_COMPARE_FLAG | PARTIAL_COMPARE_FLAG, stack)\n : result\n )) {\n return false;\n }\n }\n }\n return true;\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) || isHostObject(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[objectToString.call(value)];\n}\n\n/**\n * The base implementation of `_.iteratee`.\n *\n * @private\n * @param {*} [value=_.identity] The value to convert to an iteratee.\n * @returns {Function} Returns the iteratee.\n */\nfunction baseIteratee(value) {\n // Don't store the `typeof` result in a variable to avoid a JIT bug in Safari 9.\n // See https://bugs.webkit.org/show_bug.cgi?id=156034 for more details.\n if (typeof value == 'function') {\n return value;\n }\n if (value == null) {\n return identity;\n }\n if (typeof value == 'object') {\n return isArray(value)\n ? baseMatchesProperty(value[0], value[1])\n : baseMatches(value);\n }\n return property(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 * The base implementation of `_.matches` which doesn't clone `source`.\n *\n * @private\n * @param {Object} source The object of property values to match.\n * @returns {Function} Returns the new spec function.\n */\nfunction baseMatches(source) {\n var matchData = getMatchData(source);\n if (matchData.length == 1 && matchData[0][2]) {\n return matchesStrictComparable(matchData[0][0], matchData[0][1]);\n }\n return function(object) {\n return object === source || baseIsMatch(object, source, matchData);\n };\n}\n\n/**\n * The base implementation of `_.matchesProperty` which doesn't clone `srcValue`.\n *\n * @private\n * @param {string} path The path of the property to get.\n * @param {*} srcValue The value to match.\n * @returns {Function} Returns the new spec function.\n */\nfunction baseMatchesProperty(path, srcValue) {\n if (isKey(path) && isStrictComparable(srcValue)) {\n return matchesStrictComparable(toKey(path), srcValue);\n }\n return function(object) {\n var objValue = get(object, path);\n return (objValue === undefined && objValue === srcValue)\n ? hasIn(object, path)\n : baseIsEqual(srcValue, objValue, undefined, UNORDERED_COMPARE_FLAG | PARTIAL_COMPARE_FLAG);\n };\n}\n\n/**\n * A specialized version of `baseProperty` which supports deep paths.\n *\n * @private\n * @param {Array|string} path The path of the property to get.\n * @returns {Function} Returns the new accessor function.\n */\nfunction basePropertyDeep(path) {\n return function(object) {\n return baseGet(object, path);\n };\n}\n\n/**\n * The base implementation of `_.toString` which doesn't convert nullish\n * values to empty strings.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {string} Returns the string.\n */\nfunction baseToString(value) {\n // Exit early for strings to avoid a performance hit in some environments.\n if (typeof value == 'string') {\n return value;\n }\n if (isSymbol(value)) {\n return symbolToString ? symbolToString.call(value) : '';\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\n/**\n * Casts `value` to a path array if it's not one.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {Array} Returns the cast property path array.\n */\nfunction castPath(value) {\n return isArray(value) ? value : stringToPath(value);\n}\n\n/**\n * Creates a `baseEach` or `baseEachRight` function.\n *\n * @private\n * @param {Function} eachFunc The function to iterate over a collection.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\nfunction createBaseEach(eachFunc, fromRight) {\n return function(collection, iteratee) {\n if (collection == null) {\n return collection;\n }\n if (!isArrayLike(collection)) {\n return eachFunc(collection, iteratee);\n }\n var length = collection.length,\n index = fromRight ? length : -1,\n iterable = Object(collection);\n\n while ((fromRight ? index-- : ++index < length)) {\n if (iteratee(iterable[index], index, iterable) === false) {\n break;\n }\n }\n return collection;\n };\n}\n\n/**\n * Creates a base function for methods like `_.forIn` and `_.forOwn`.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\nfunction createBaseFor(fromRight) {\n return function(object, iteratee, keysFunc) {\n var index = -1,\n iterable = Object(object),\n props = keysFunc(object),\n length = props.length;\n\n while (length--) {\n var key = props[fromRight ? length : ++index];\n if (iteratee(iterable[key], key, iterable) === false) {\n break;\n }\n }\n return object;\n };\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 {Function} equalFunc The function to determine equivalents of values.\n * @param {Function} customizer The function to customize comparisons.\n * @param {number} bitmask The bitmask of comparison flags. See `baseIsEqual`\n * for more details.\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, equalFunc, customizer, bitmask, stack) {\n var isPartial = bitmask & PARTIAL_COMPARE_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 & UNORDERED_COMPARE_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 (!seen.has(othIndex) &&\n (arrValue === othValue || equalFunc(arrValue, othValue, customizer, bitmask, stack))) {\n return seen.add(othIndex);\n }\n })) {\n result = false;\n break;\n }\n } else if (!(\n arrValue === othValue ||\n equalFunc(arrValue, othValue, customizer, bitmask, 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 {Function} equalFunc The function to determine equivalents of values.\n * @param {Function} customizer The function to customize comparisons.\n * @param {number} bitmask The bitmask of comparison flags. See `baseIsEqual`\n * for more details.\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, equalFunc, customizer, bitmask, 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 & PARTIAL_COMPARE_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 |= UNORDERED_COMPARE_FLAG;\n\n // Recursively compare objects (susceptible to call stack limits).\n stack.set(object, other);\n var result = equalArrays(convert(object), convert(other), equalFunc, customizer, bitmask, 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 {Function} equalFunc The function to determine equivalents of values.\n * @param {Function} customizer The function to customize comparisons.\n * @param {number} bitmask The bitmask of comparison flags. See `baseIsEqual`\n * for more details.\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, equalFunc, customizer, bitmask, stack) {\n var isPartial = bitmask & PARTIAL_COMPARE_FLAG,\n objProps = keys(object),\n objLength = objProps.length,\n othProps = keys(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, customizer, bitmask, 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 * 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 property names, values, and compare flags of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the match data of `object`.\n */\nfunction getMatchData(object) {\n var result = keys(object),\n length = result.length;\n\n while (length--) {\n var key = result[length],\n value = object[key];\n\n result[length] = [key, value, isStrictComparable(value)];\n }\n return result;\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 * 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,\n// for data views in Edge < 14, and promises in Node.js.\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 = objectToString.call(value),\n Ctor = result == objectTag ? value.constructor : undefined,\n ctorString = Ctor ? toSource(Ctor) : undefined;\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 `path` exists on `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @param {Function} hasFunc The function to check properties.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n */\nfunction hasPath(object, path, hasFunc) {\n path = isKey(path, object) ? [path] : castPath(path);\n\n var result,\n index = -1,\n length = path.length;\n\n while (++index < length) {\n var key = toKey(path[index]);\n if (!(result = object != null && hasFunc(object, key))) {\n break;\n }\n object = object[key];\n }\n if (result) {\n return result;\n }\n var length = object ? object.length : 0;\n return !!length && isLength(length) && isIndex(key, length) &&\n (isArray(object) || isArguments(object));\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 a property name and not a property path.\n *\n * @private\n * @param {*} value The value to check.\n * @param {Object} [object] The object to query keys on.\n * @returns {boolean} Returns `true` if `value` is a property name, else `false`.\n */\nfunction isKey(value, object) {\n if (isArray(value)) {\n return false;\n }\n var type = typeof value;\n if (type == 'number' || type == 'symbol' || type == 'boolean' ||\n value == null || isSymbol(value)) {\n return true;\n }\n return reIsPlainProp.test(value) || !reIsDeepProp.test(value) ||\n (object != null && value in Object(object));\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 * Checks if `value` is suitable for strict equality comparisons, i.e. `===`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` if suitable for strict\n * equality comparisons, else `false`.\n */\nfunction isStrictComparable(value) {\n return value === value && !isObject(value);\n}\n\n/**\n * A specialized version of `matchesProperty` for source values suitable\n * for strict equality comparisons, i.e. `===`.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @param {*} srcValue The value to match.\n * @returns {Function} Returns the new spec function.\n */\nfunction matchesStrictComparable(key, srcValue) {\n return function(object) {\n if (object == null) {\n return false;\n }\n return object[key] === srcValue &&\n (srcValue !== undefined || (key in Object(object)));\n };\n}\n\n/**\n * Converts `string` to a property path array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the property path array.\n */\nvar stringToPath = memoize(function(string) {\n string = toString(string);\n\n var result = [];\n if (reLeadingDot.test(string)) {\n result.push('');\n }\n string.replace(rePropName, function(match, number, quote, string) {\n result.push(quote ? string.replace(reEscapeChar, '$1') : (number || match));\n });\n return result;\n});\n\n/**\n * Converts `value` to a string key if it's not a string or symbol.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {string|symbol} Returns the key.\n */\nfunction toKey(value) {\n if (typeof value == 'string' || isSymbol(value)) {\n return value;\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to process.\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 * Reduces `collection` to a value which is the accumulated result of running\n * each element in `collection` thru `iteratee`, where each successive\n * invocation is supplied the return value of the previous. If `accumulator`\n * is not given, the first element of `collection` is used as the initial\n * value. The iteratee is invoked with four arguments:\n * (accumulator, value, index|key, collection).\n *\n * Many lodash methods are guarded to work as iteratees for methods like\n * `_.reduce`, `_.reduceRight`, and `_.transform`.\n *\n * The guarded methods are:\n * `assign`, `defaults`, `defaultsDeep`, `includes`, `merge`, `orderBy`,\n * and `sortBy`\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @returns {*} Returns the accumulated value.\n * @see _.reduceRight\n * @example\n *\n * _.reduce([1, 2], function(sum, n) {\n * return sum + n;\n * }, 0);\n * // => 3\n *\n * _.reduce({ 'a': 1, 'b': 2, 'c': 1 }, function(result, value, key) {\n * (result[value] || (result[value] = [])).push(key);\n * return result;\n * }, {});\n * // => { '1': ['a', 'c'], '2': ['b'] } (iteration order is not guaranteed)\n */\nfunction reduce(collection, iteratee, accumulator) {\n var func = isArray(collection) ? arrayReduce : baseReduce,\n initAccum = arguments.length < 3;\n\n return func(collection, baseIteratee(iteratee, 4), accumulator, initAccum, baseEach);\n}\n\n/**\n * Creates a function that memoizes the result of `func`. If `resolver` is\n * provided, it determines the cache key for storing the result based on the\n * arguments provided to the memoized function. By default, the first argument\n * provided to the memoized function is used as the map cache key. The `func`\n * is invoked with the `this` binding of the memoized function.\n *\n * **Note:** The cache is exposed as the `cache` property on the memoized\n * function. Its creation may be customized by replacing the `_.memoize.Cache`\n * constructor with one whose instances implement the\n * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object)\n * method interface of `delete`, `get`, `has`, and `set`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to have its output memoized.\n * @param {Function} [resolver] The function to resolve the cache key.\n * @returns {Function} Returns the new memoized function.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n * var other = { 'c': 3, 'd': 4 };\n *\n * var values = _.memoize(_.values);\n * values(object);\n * // => [1, 2]\n *\n * values(other);\n * // => [3, 4]\n *\n * object.a = 2;\n * values(object);\n * // => [1, 2]\n *\n * // Modify the result cache.\n * values.cache.set(object, ['a', 'b']);\n * values(object);\n * // => ['a', 'b']\n *\n * // Replace `_.memoize.Cache`.\n * _.memoize.Cache = WeakMap;\n */\nfunction memoize(func, resolver) {\n if (typeof func != 'function' || (resolver && typeof resolver != 'function')) {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n var memoized = function() {\n var args = arguments,\n key = resolver ? resolver.apply(this, args) : args[0],\n cache = memoized.cache;\n\n if (cache.has(key)) {\n return cache.get(key);\n }\n var result = func.apply(this, args);\n memoized.cache = cache.set(key, result);\n return result;\n };\n memoized.cache = new (memoize.Cache || MapCache);\n return memoized;\n}\n\n// Assign cache to `_.memoize`.\nmemoize.Cache = MapCache;\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 */\nfunction isArguments(value) {\n // Safari 8.1 makes `arguments.callee` enumerable in strict mode.\n return isArrayLikeObject(value) && hasOwnProperty.call(value, 'callee') &&\n (!propertyIsEnumerable.call(value, 'callee') || objectToString.call(value) == argsTag);\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 * This method is like `_.isArrayLike` except that it also checks if `value`\n * is an 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 an array-like object,\n * else `false`.\n * @example\n *\n * _.isArrayLikeObject([1, 2, 3]);\n * // => true\n *\n * _.isArrayLikeObject(document.body.children);\n * // => true\n *\n * _.isArrayLikeObject('abc');\n * // => false\n *\n * _.isArrayLikeObject(_.noop);\n * // => false\n */\nfunction isArrayLikeObject(value) {\n return isObjectLike(value) && isArrayLike(value);\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 // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 8-9 which returns 'object' for typed array and other constructors.\n var tag = isObject(value) ? objectToString.call(value) : '';\n return tag == funcTag || tag == genTag;\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 && (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 && typeof value == 'object';\n}\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or 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 a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n return typeof value == 'symbol' ||\n (isObjectLike(value) && objectToString.call(value) == symbolTag);\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 * Converts `value` to a string. An empty string is returned for `null`\n * and `undefined` values. The sign of `-0` is preserved.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {string} Returns the string.\n * @example\n *\n * _.toString(null);\n * // => ''\n *\n * _.toString(-0);\n * // => '-0'\n *\n * _.toString([1, 2, 3]);\n * // => '1,2,3'\n */\nfunction toString(value) {\n return value == null ? '' : baseToString(value);\n}\n\n/**\n * Gets the value at `path` of `object`. If the resolved value is\n * `undefined`, the `defaultValue` is returned in its place.\n *\n * @static\n * @memberOf _\n * @since 3.7.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @param {*} [defaultValue] The value returned for `undefined` resolved values.\n * @returns {*} Returns the resolved value.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\n *\n * _.get(object, 'a[0].b.c');\n * // => 3\n *\n * _.get(object, ['a', '0', 'b', 'c']);\n * // => 3\n *\n * _.get(object, 'a.b.c', 'default');\n * // => 'default'\n */\nfunction get(object, path, defaultValue) {\n var result = object == null ? undefined : baseGet(object, path);\n return result === undefined ? defaultValue : result;\n}\n\n/**\n * Checks if `path` is a direct or inherited property of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n * @example\n *\n * var object = _.create({ 'a': _.create({ 'b': 2 }) });\n *\n * _.hasIn(object, 'a');\n * // => true\n *\n * _.hasIn(object, 'a.b');\n * // => true\n *\n * _.hasIn(object, ['a', 'b']);\n * // => true\n *\n * _.hasIn(object, 'b');\n * // => false\n */\nfunction hasIn(object, path) {\n return object != null && hasPath(object, path, baseHasIn);\n}\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 the first argument it receives.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {*} value Any value.\n * @returns {*} Returns `value`.\n * @example\n *\n * var object = { 'a': 1 };\n *\n * console.log(_.identity(object) === object);\n * // => true\n */\nfunction identity(value) {\n return value;\n}\n\n/**\n * Creates a function that returns the value at `path` of a given object.\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Util\n * @param {Array|string} path The path of the property to get.\n * @returns {Function} Returns the new accessor function.\n * @example\n *\n * var objects = [\n * { 'a': { 'b': 2 } },\n * { 'a': { 'b': 1 } }\n * ];\n *\n * _.map(objects, _.property('a.b'));\n * // => [2, 1]\n *\n * _.map(_.sortBy(objects, _.property(['a', 'b'])), 'a.b');\n * // => [1, 2]\n */\nfunction property(path) {\n return isKey(path) ? baseProperty(toKey(path)) : basePropertyDeep(path);\n}\n\nmodule.exports = reduce;\n","import _curry1 from \"./internal/_curry1.js\";\n/**\n * Returns a function that always returns the given value. Note that for\n * non-primitives the value returned is a reference to the original value.\n *\n * This function is known as `const`, `constant`, or `K` (for K combinator) in\n * other languages and libraries.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Function\n * @sig a -> (* -> a)\n * @param {*} val The value to wrap in a function\n * @return {Function} A Function :: * -> val.\n * @example\n *\n * const t = R.always('Tee');\n * t(); //=> 'Tee'\n */\n\nvar always =\n/*#__PURE__*/\n_curry1(function always(val) {\n return function () {\n return val;\n };\n});\n\nexport default always;"],"sourceRoot":""}