{"version":3,"sources":["webpack:///./scripts/Components/MiniCart/styles|lazy|/^\\.\\/.*\\.scss$/|groupOptions: {}|namespace object","webpack:///./scripts/Actions/Overlay.action.js","webpack:///./scripts/Components/QuantityInput.js","webpack:///./scripts/Components/MiniCart/MiniCart.js","webpack:///./scripts/Components/SideMenu.js","webpack:///../node_modules/lodash.debounce/index.js"],"names":["map","webpackAsyncContext","req","__webpack_require__","o","Promise","resolve","then","e","Error","code","ids","id","keys","Object","module","exports","addOverlay","componentName","onOverlayClick","type","OVERLAY_ADD_OVERLAY","payload","updateOverlay","OVERLAY_UPDATE_OVERLAY","removeOverlay","OVERLAY_REMOVE_OVERLAY","closeOverlay","OVERLAY_CLOSE_OVERLAY","activeOverlays","QuantityInput","value","onChange","onBlur","onQuantityIncrease","onQuantityDecrease","showButtons","disabled","active","setActive","useState","React","className","Icon","iconCode","onClick","target","onFocus","window","__litium","themeName","MiniCart","dispatch","useDispatch","quantity","orderRows","fees","grandTotal","orderTotal","gtmGrandTotal","vat","checkoutUrl","showInfo","addToCartAnimating","discount","showMiniCartGrandTotal","miniCartGrandTotal","earliestDelivery","leftToFreeShipping","freeShipping","isForConsumer","b2B","useSelector","state","cart","currentDate","Date","toJSON","slice","abortController","setAbortController","useEffect","AbortController","updateOrderRowQuantity","debounce","articleNumber","rowSystemId","update","hasOrderRows","length","footer","translate","href","OrderRowItem","row","onQuantityChange","key","brandLogoUrl","src","loading","url","image","brandName","baseProductName","name","totalPrice","unitPrice","stockDescription","canEdit","parseInt","orderRowItems","_extends","headerRef","messageItem","MessageBar","text","undefined","icon","replace","onClickShowMiniCart","toggle","gtmOrderRows","gtmOrderRowIndex","findIndex","gtmEcommerceItem","index","push","dataLayerGtmViewCart","currency","err","console","log","SideMenu","open","messageBar","onClosed","CartProducts","mobile","b2c","forwardRef","duration","from","showCloseButton","children","title","disableClosing","closeButton","languageSwitcher","ref","slideIn","setSlideIn","timeoutId","setTimeoutId","close","useCallback","clearTimeout","newTimeoutId","setTimeout","substr","ReactDOM","style","transitionDuration","cloneElement","iconClass","props","currentChannel","document","body","reTrim","reIsBadHex","reIsBinary","reIsOctal","freeParseInt","freeGlobal","g","freeSelf","self","root","Function","objectToString","prototype","toString","nativeMax","Math","max","nativeMin","min","now","isObject","toNumber","isObjectLike","call","isSymbol","other","valueOf","isBinary","test","func","wait","options","lastArgs","lastThis","maxWait","result","timerId","lastCallTime","lastInvokeTime","leading","maxing","trailing","TypeError","invokeFunc","time","args","thisArg","apply","shouldInvoke","timeSinceLastCall","timerExpired","trailingEdge","remainingWait","debounced","isInvoking","arguments","this","leadingEdge","cancel","flush"],"mappings":"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","file":"1879.55c37d15f562a41edebd.js","sourcesContent":["var map = {\n\t\"./alf.scss\": [\n\t\t52620,\n\t\t2620\n\t],\n\t\"./main.scss\": [\n\t\t79160,\n\t\t9160\n\t],\n\t\"./oh-poppy.scss\": [\n\t\t27465,\n\t\t7465\n\t],\n\t\"./vincent.scss\": [\n\t\t4040,\n\t\t4040\n\t],\n\t\"./wtg.scss\": [\n\t\t93875,\n\t\t3875\n\t]\n};\nfunction webpackAsyncContext(req) {\n\tif(!__webpack_require__.o(map, req)) {\n\t\treturn Promise.resolve().then(() => {\n\t\t\tvar e = new Error(\"Cannot find module '\" + req + \"'\");\n\t\t\te.code = 'MODULE_NOT_FOUND';\n\t\t\tthrow e;\n\t\t});\n\t}\n\n\tvar ids = map[req], id = ids[0];\n\treturn __webpack_require__.e(ids[1]).then(() => {\n\t\treturn __webpack_require__(id);\n\t});\n}\nwebpackAsyncContext.keys = () => (Object.keys(map));\nwebpackAsyncContext.id = 84894;\nmodule.exports = webpackAsyncContext;","import {\n  OVERLAY_ADD_OVERLAY,\n  OVERLAY_CLOSE_OVERLAY,\n  OVERLAY_REMOVE_OVERLAY,\n  OVERLAY_UPDATE_OVERLAY,\n} from '../constants';\n\nexport const addOverlay = (componentName, onOverlayClick) => ({\n  type: OVERLAY_ADD_OVERLAY,\n  payload: {\n    componentName,\n    onOverlayClick,\n  },\n});\n\nexport const updateOverlay = (componentName, onOverlayClick) => ({\n  type: OVERLAY_UPDATE_OVERLAY,\n  payload: {\n    componentName,\n    onOverlayClick,\n  },\n});\n\nexport const removeOverlay = (componentName) => ({\n  type: OVERLAY_REMOVE_OVERLAY,\n  payload: {\n    componentName,\n  },\n});\n\nexport const closeOverlay = () => ({\n  type: OVERLAY_CLOSE_OVERLAY,\n  payload: {\n    activeOverlays: [],\n  },\n});\n","import React, { useState } from 'react';\nimport Icon from './IconBase/Icon';\n\nconst QuantityInput = ({\n  value,\n  onChange,\n  onBlur,\n  onQuantityIncrease,\n  onQuantityDecrease,\n  showButtons = true,\n  disabled = false,\n}) => {\n  const [active, setActive] = useState(false);\n\n  return (\n    <div className={`quantity-input ${active ? 'active' : ''}`}>\n      {!disabled && showButtons && (\n        <Icon iconCode=\"remove\" onClick={onQuantityDecrease} />\n      )}\n      <input\n        disabled={disabled}\n        type=\"number\"\n        value={value}\n        onChange={(e) => onChange(e.target.value)}\n        onBlur={(e) => {\n          setActive(false);\n          onBlur && onBlur(e);\n        }}\n        onFocus={() => setActive(true)}\n      />\n      {!disabled && showButtons && (\n        <Icon iconCode=\"add\" onClick={onQuantityIncrease} />\n      )}\n    </div>\n  );\n};\n\nexport default QuantityInput;\n","import React, { useEffect, useState } from 'react';\nimport * as debounce from 'lodash.debounce';\nimport { translate } from '../../Services/translation';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { toggle, update } from '../../Actions/Cart.action';\nimport QuantityInput from '../QuantityInput';\nimport SideMenu from '../SideMenu';\nimport Icon from '../IconBase/Icon';\nimport MessageBar from '../MessageBar/MessageBar';\nimport CartProducts from '../Cart/CartProducts';\nimport { dataLayerGtmViewCart } from '../../Services/Gtm.service';\nimport(`./styles/${window.__litium.themeName}.scss`);\n\nconst MiniCart = () => {\n  const dispatch = useDispatch();\n  const {\n    quantity,\n    orderRows,\n    fees,\n    grandTotal,\n    orderTotal,\n    gtmGrandTotal,\n    vat,\n    checkoutUrl,\n    showInfo,\n    addToCartAnimating = false,\n    discount,\n    showMiniCartGrandTotal,\n    miniCartGrandTotal,\n    earliestDelivery = null,\n    leftToFreeShipping = null,\n    freeShipping = null,\n    isForConsumer,\n    b2B,\n  } = useSelector((state) => state.cart);\n\n  const cart = {\n    quantity: quantity,\n    orderRows: orderRows,\n    fees: fees,\n    grandTotal: grandTotal,\n    vat: vat,\n    checkoutUrl: checkoutUrl,\n    showInfo: showInfo,\n    addToCartAnimating: addToCartAnimating,\n    discount: discount,\n    showMiniCartGrandTotal: showMiniCartGrandTotal,\n    miniCartGrandTotal: miniCartGrandTotal,\n    earliestDelivery: earliestDelivery,\n    leftToFreeShipping: leftToFreeShipping,\n    freeShipping: freeShipping,\n    isForConsumer: isForConsumer,\n  };\n\n  const formatDate = (input) => {\n    return input.toJSON().slice(0, 10);\n  };\n\n  const currentDate = formatDate(new Date());\n\n  const onToggle = () => {\n    dispatch(toggle());\n  };\n  const onClose = () => {\n    dispatch(toggle(false));\n  };\n\n  const [abortController, setAbortController] = useState();\n\n  // Must be set after client initialized\n  useEffect(() => setAbortController(new AbortController()), []);\n\n  const updateOrderRowQuantity = debounce(\n    (articleNumber, quantity, rowSystemId) =>\n      dispatch(update(articleNumber, quantity, rowSystemId, abortController)),\n    200\n  );\n\n  const hasOrderRows = orderRows && Object.keys(orderRows).length > 0;\n\n  const footer = (\n    <>\n      <div className=\"cart__sidemenu-footer-row\">\n        <h5>\n          {b2B\n            ? translate('checkout.order.total')\n            : translate('checkout.order.totalwithvat')}\n        </h5>\n        <div className=\"cart__sidemenu-footer-row-section\">\n          <h5>{orderTotal}</h5>\n          <span className=\"side-menu__footer-info\">\n            {translate(\n              cart.freeShipping\n                ? 'checkout.order.freeshipping'\n                : 'checkout.order.shippinginfo'\n            )}\n          </span>\n          {currentDate <= earliestDelivery ? (\n            <span className=\"side-menu__footer-info\">\n              {translate('minicart.shiplater')}: {earliestDelivery}\n            </span>\n          ) : (\n            <span className=\"side-menu__footer-info\">\n              {translate('minicart.sentimmidiately')}\n            </span>\n          )}\n        </div>\n      </div>\n      <div className=\"cart__sidemenu-footer-row\">\n        <a href={checkoutUrl} className=\"btn btn--secondary\">\n          {translate('minicart.checkout')}\n        </a>\n      </div>\n      <div className=\"cart__sidemenu-footer-row\">\n        <ul>\n          <li>\n            <Icon iconCode=\"local_shipping\" />\n            {translate('minicart.deliveryusp')}\n          </li>\n          <li>\n            <Icon iconCode=\"credit_card\" />\n            {translate('minicart.paymentusp')}\n          </li>\n          <li>\n            <Icon iconCode=\"new_releases\" />\n            {translate('minicart.warrantyusp')}\n          </li>\n        </ul>\n      </div>\n    </>\n  );\n\n  const OrderRowItem = (row) => {\n    const onQuantityChange = (value) => {\n      updateOrderRowQuantity(row.articleNumber, value, row.rowSystemId);\n    };\n\n    return (\n      <li key={row.rowSystemId} className=\"cart__sidemenu-orderrow\">\n        <div className=\"cart__sidemenu-orderrow-wrapper\">\n          <div className=\"cart__sidemenu-orderrow-images\">\n            {row.brandLogoUrl ? (\n              <img src={row.brandLogoUrl} loading=\"lazy\" />\n            ) : null}\n            <a href={row.url}>\n              <img src={row.image} loading=\"lazy\" />\n            </a>\n          </div>\n          <div className=\"cart__sidemenu-orderrow-information-container\">\n            <div className=\"cart__sidemenu-orderrow-information\">\n              <div className=\"cart__sidemenu-orderrow-text\">\n                <span className=\"product__info--art-nr\">\n                  <span>{row.articleNumber}</span>\n                </span>\n                <h3 className=\"cart__sidemenu-orderrow-header\">\n                  <a className=\"color-grey-900\" href={row.url}>\n                    {row.brandName} {row.baseProductName}\n                  </a>\n                </h3>\n                <span>{row.name}</span>\n              </div>\n              <div className=\"cart__sidemenu-orderrow-price\">\n                <span className=\"cart__sidemenu-orderrow-mainprice\">\n                  {row.totalPrice}\n                </span>\n                <span className=\"cart__sidemenu-orderrow-subprice\">\n                  {row.unitPrice}\n                </span>\n              </div>\n            </div>\n            <div className=\"cart__sidemenu-orderrow-information-subcontainer show-for-large\">\n              <div className=\"cart__sidemenu-orderrow-information cart__sidemenu-orderrow-information--footer\">\n                <div className=\"in-stock-tag\">\n                  <Icon iconCode=\"package\" />\n                  <span>{row.stockDescription}</span>\n                </div>\n                <div className=\"cart__sidemenu-orderrow-quantity\">\n                  <QuantityInput\n                    disabled={!row.canEdit}\n                    value={row.quantity}\n                    id={row.rowSystemId}\n                    onQuantityIncrease={() =>\n                      onQuantityChange(parseInt(row.quantity) + 1)\n                    }\n                    onQuantityDecrease={() =>\n                      onQuantityChange(parseInt(row.quantity) - 1)\n                    }\n                    onChange={(quantity) => onQuantityChange(quantity)}\n                  />\n                </div>\n                {row.canEdit && (\n                  <div className=\"cart__sidemenu-orderrow-remove\"></div>\n                )}\n              </div>\n            </div>\n          </div>\n        </div>\n        <div className=\"cart__sidemenu-orderrow-information-subcontainer hide-for-large \">\n          <div className=\"cart__sidemenu-orderrow-information cart__sidemenu-orderrow-information--footer\">\n            <div className=\"in-stock-tag\">\n              <Icon iconCode=\"package\" />\n              <span>{row.stockDescription}</span>\n            </div>\n            <div className=\"cart__sidemenu-orderrow-quantity\">\n              <QuantityInput\n                disabled={!row.canEdit}\n                value={row.quantity}\n                id={row.rowSystemId}\n                onQuantityIncrease={() =>\n                  onQuantityChange(parseInt(row.quantity) + 1)\n                }\n                onQuantityDecrease={() =>\n                  onQuantityChange(parseInt(row.quantity) - 1)\n                }\n                onChange={(quantity) => onQuantityChange(quantity)}\n              />\n            </div>\n            {row.canEdit && (\n              <div className=\"cart__sidemenu-orderrow-remove\">\n                <Icon iconCode=\"trash\" onClick={() => onQuantityChange(0)} />\n              </div>\n            )}\n          </div>\n        </div>\n      </li>\n    );\n  };\n\n  const orderRowItems = hasOrderRows\n    ? orderRows?.map((row) => <OrderRowItem key={row.rowSystemId} {...row} />)\n    : null;\n\n  const headerRef = (\n    <div className=\"cart__sidemenu\">\n      <div className=\"row cart cart--mini cart__sidemenu-header\">\n        <h5>{translate('checkout.cart.title')}</h5>\n        <span className=\"cart__title\">\n          {orderRowItems ? '(' + orderRowItems.length + ')' : '(0)'}\n        </span>\n      </div>\n    </div>\n  );\n\n  const messageItem = !isForConsumer ? (\n    leftToFreeShipping ? (\n      <MessageBar\n        text={translate('checkout.order.messagebar').replace(\n          '{0}',\n          leftToFreeShipping\n        )}\n        type={'error'}\n        icon=\"local_shipping\"\n      />\n    ) : null\n  ) : (\n    <MessageBar\n      text={\n        translate('checkout.order.messagebar') !== 'checkout.order.messagebar'\n          ? translate('checkout.order.messagebar')\n          : undefined\n      }\n      type={'info'}\n      icon=\"local_shipping\"\n    />\n  );\n\n  const onClickShowMiniCart = () => {\n    onToggle();\n\n    try {\n      let gtmOrderRows = [];\n      orderRows.map((row) => {\n        const gtmOrderRowIndex = gtmOrderRows.findIndex(\n          (e) => e.articleNumber === row.articleNumber\n        );\n        if (gtmOrderRowIndex === -1) {\n          row.gtmEcommerceItem.quantity = row.quantity;\n          row.gtmEcommerceItem.index = gtmOrderRows.length;\n          gtmOrderRows.push(row);\n        } else {\n          gtmOrderRows[gtmOrderRowIndex].gtmEcommerceItem.quantity +=\n            row.quantity;\n        }\n      });\n\n      if (gtmOrderRows.length > 0) {\n        dataLayerGtmViewCart({\n          currency: gtmOrderRows[0].gtmEcommerceItem.currency,\n          gtmGrandTotal: gtmGrandTotal,\n          orderRows: gtmOrderRows,\n        });\n      }\n    } catch (err) {\n      console.log(err);\n    }\n  };\n\n  return (\n    <div\n      className={`cart cart--mini ${addToCartAnimating ? 'cart--animate' : ''}`}\n    >\n      <a className=\"cart__button\" onClick={() => onClickShowMiniCart()}>\n        <div className=\"cart__icon\">\n          <span className=\"cart__quantity\">{quantity}</span>\n          <Icon\n            iconCode={\n              window.__litium.themeName == 'WTG'\n                ? 'shopping_cart'\n                : window.__litium.themeName == 'ALF'\n                ? 'local_mall'\n                : 'shopping_bag'\n            }\n          />\n        </div>\n        <span className=\"cart__title show-for-large\">\n          {showMiniCartGrandTotal && <div>{miniCartGrandTotal}</div>}\n        </span>\n      </a>\n      <SideMenu\n        id=\"cart\"\n        className=\"side-menu--cart\"\n        open={showInfo}\n        headerRef={headerRef}\n        messageBar={messageItem}\n        onClosed={() => onClose(false)}\n        footer={hasOrderRows ? footer : null}\n      >\n        <div className=\"cart__sidemenu-content\">\n          {hasOrderRows ? (\n            <>\n              <CartProducts\n                cart={cart}\n                mobile={true}\n                type=\"minicart\"\n                b2c={isForConsumer}\n              />\n            </>\n          ) : (\n            <div className=\"cart__sidemenu-empty\">\n              <h4>{translate('checkout.cart.empty')}</h4>\n            </div>\n          )}\n        </div>\n      </SideMenu>\n    </div>\n  );\n};\n\nexport default MiniCart;\n","import React, {\n  cloneElement,\n  createElement,\n  createRef,\n  forwardRef,\n  useCallback,\n  useEffect,\n  useState,\n} from 'react';\nimport ReactDOM, { render } from 'react-dom';\nimport { useDispatch } from 'react-redux';\nimport {\n  addOverlay,\n  removeOverlay,\n  updateOverlay,\n} from '../Actions/Overlay.action';\nimport Icon from './IconBase/Icon';\n// import colors from 'Exports/colors.scss';\n\nexport default forwardRef(\n  (\n    {\n      id,\n      duration = '0.2s',\n      from = 'right',\n      className,\n      open,\n      onClosed,\n      showCloseButton = true,\n      children,\n      title,\n      headerRef,\n      footer,\n      disableClosing = false,\n      closeButton = null,\n      languageSwitcher = null,\n      messageBar = null,\n    },\n    ref\n  ) => {\n    const [slideIn, setSlideIn] = useState();\n    const [timeoutId, setTimeoutId] = useState();\n    const dispatch = useDispatch();\n\n    if (!id || id == '') {\n      throw new Error(\n        'A unique side-menu \"id\" must be passed to side menu component'\n      );\n    }\n\n    const close = useCallback(() => {\n      if (!disableClosing) {\n        // Just sets \"slideIn\" to false, which triggers the animation to close it\n        setSlideIn(false);\n        return true;\n      }\n\n      // False disables overlay click\n      return false;\n    }, [disableClosing]);\n\n    useEffect(() => {\n      dispatch(updateOverlay(id, close));\n    }, [dispatch, close, id]);\n\n    useEffect(() => {\n      if (!slideIn) {\n        // If not slide in, slide out :^)\n        if (timeoutId) {\n          // Clear previous timeout to avoid animation delay bug\n          clearTimeout(timeoutId);\n        }\n\n        var newTimeoutId = setTimeout(() => {\n          setTimeoutId(undefined);\n          onClosed && onClosed();\n        }, duration.substr(0, duration.length - 1) * 1000);\n\n        setTimeoutId(newTimeoutId);\n        dispatch(removeOverlay(id));\n      }\n    }, [slideIn]);\n\n    useEffect(() => {\n      // Triggered every time \"open\" is changed, initially as well\n      // Timeout to not trigger on the same frame as the render, to enable the slide-in\n\n      setTimeout(() => setSlideIn(open), 1);\n\n      if (open) {\n        dispatch(addOverlay(id, close));\n      }\n    }, [open]);\n\n    return open\n      ? ReactDOM.createPortal(\n          <div\n            className={\n              'side-menu' +\n              (slideIn ? ' side-menu--open' : '') +\n              (' from-' + from) +\n              (className ? ' ' + className : '')\n            }\n            ref={ref}\n            style={{ transitionDuration: duration }}\n          >\n            {headerRef && (\n              <div className=\"side-menu__header\">\n                {showCloseButton &&\n                  !disableClosing &&\n                  (!closeButton ? (\n                    <Icon\n                      iconCode=\"close\"\n                      onClick={close}\n                      iconClass=\"side-menu__close-icon\"\n                    />\n                  ) : (\n                    cloneElement(closeButton, {\n                      onClick: close,\n                    })\n                  ))}\n                {languageSwitcher?.props.currentChannel\n                  ? languageSwitcher\n                  : null}\n                {headerRef}\n              </div>\n            )}\n            {!headerRef &&\n              showCloseButton &&\n              !disableClosing &&\n              (!closeButton ? (\n                <Icon\n                  iconCode=\"close\"\n                  onClick={close}\n                  iconClass=\"side-menu__close-icon\"\n                />\n              ) : (\n                cloneElement(closeButton, {\n                  onClick: close,\n                })\n              ))}\n            {title && <h3 className=\"side-menu__title\">{title}</h3>}\n            {messageBar && (\n              <div className=\"side-menu__message-bar\">{messageBar}</div>\n            )}\n            <div className=\"side-menu__content\">{children}</div>\n            {footer && <div className=\"side-menu__footer\">{footer}</div>}\n          </div>,\n          document.body\n        )\n      : null;\n  }\n);\n","/**\n * lodash (Custom Build) <https://lodash.com/>\n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright jQuery Foundation and other contributors <https://jquery.org/>\n * Released under MIT license <https://lodash.com/license>\n * Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>\n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\n\n/** Used as the `TypeError` message for \"Functions\" methods. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/** Used as references for various `Number` constants. */\nvar NAN = 0 / 0;\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/** Used to match leading and trailing whitespace. */\nvar reTrim = /^\\s+|\\s+$/g;\n\n/** Used to detect bad signed hexadecimal string values. */\nvar reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n/** Used to detect binary string values. */\nvar reIsBinary = /^0b[01]+$/i;\n\n/** Used to detect octal string values. */\nvar reIsOctal = /^0o[0-7]+$/i;\n\n/** Built-in method references without a dependency on `root`. */\nvar freeParseInt = parseInt;\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/** Used for built-in method references. */\nvar objectProto = Object.prototype;\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/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max,\n    nativeMin = Math.min;\n\n/**\n * Gets the timestamp of the number of milliseconds that have elapsed since\n * the Unix epoch (1 January 1970 00:00:00 UTC).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Date\n * @returns {number} Returns the timestamp.\n * @example\n *\n * _.defer(function(stamp) {\n *   console.log(_.now() - stamp);\n * }, _.now());\n * // => Logs the number of milliseconds it took for the deferred invocation.\n */\nvar now = function() {\n  return root.Date.now();\n};\n\n/**\n * Creates a debounced function that delays invoking `func` until after `wait`\n * milliseconds have elapsed since the last time the debounced function was\n * invoked. The debounced function comes with a `cancel` method to cancel\n * delayed `func` invocations and a `flush` method to immediately invoke them.\n * Provide `options` to indicate whether `func` should be invoked on the\n * leading and/or trailing edge of the `wait` timeout. The `func` is invoked\n * with the last arguments provided to the debounced function. Subsequent\n * calls to the debounced function return the result of the last `func`\n * invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the debounced function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.debounce` and `_.throttle`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to debounce.\n * @param {number} [wait=0] The number of milliseconds to delay.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=false]\n *  Specify invoking on the leading edge of the timeout.\n * @param {number} [options.maxWait]\n *  The maximum time `func` is allowed to be delayed before it's invoked.\n * @param {boolean} [options.trailing=true]\n *  Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new debounced function.\n * @example\n *\n * // Avoid costly calculations while the window size is in flux.\n * jQuery(window).on('resize', _.debounce(calculateLayout, 150));\n *\n * // Invoke `sendMail` when clicked, debouncing subsequent calls.\n * jQuery(element).on('click', _.debounce(sendMail, 300, {\n *   'leading': true,\n *   'trailing': false\n * }));\n *\n * // Ensure `batchLog` is invoked once after 1 second of debounced calls.\n * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 });\n * var source = new EventSource('/stream');\n * jQuery(source).on('message', debounced);\n *\n * // Cancel the trailing debounced invocation.\n * jQuery(window).on('popstate', debounced.cancel);\n */\nfunction debounce(func, wait, options) {\n  var lastArgs,\n      lastThis,\n      maxWait,\n      result,\n      timerId,\n      lastCallTime,\n      lastInvokeTime = 0,\n      leading = false,\n      maxing = false,\n      trailing = true;\n\n  if (typeof func != 'function') {\n    throw new TypeError(FUNC_ERROR_TEXT);\n  }\n  wait = toNumber(wait) || 0;\n  if (isObject(options)) {\n    leading = !!options.leading;\n    maxing = 'maxWait' in options;\n    maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait;\n    trailing = 'trailing' in options ? !!options.trailing : trailing;\n  }\n\n  function invokeFunc(time) {\n    var args = lastArgs,\n        thisArg = lastThis;\n\n    lastArgs = lastThis = undefined;\n    lastInvokeTime = time;\n    result = func.apply(thisArg, args);\n    return result;\n  }\n\n  function leadingEdge(time) {\n    // Reset any `maxWait` timer.\n    lastInvokeTime = time;\n    // Start the timer for the trailing edge.\n    timerId = setTimeout(timerExpired, wait);\n    // Invoke the leading edge.\n    return leading ? invokeFunc(time) : result;\n  }\n\n  function remainingWait(time) {\n    var timeSinceLastCall = time - lastCallTime,\n        timeSinceLastInvoke = time - lastInvokeTime,\n        result = wait - timeSinceLastCall;\n\n    return maxing ? nativeMin(result, maxWait - timeSinceLastInvoke) : result;\n  }\n\n  function shouldInvoke(time) {\n    var timeSinceLastCall = time - lastCallTime,\n        timeSinceLastInvoke = time - lastInvokeTime;\n\n    // Either this is the first call, activity has stopped and we're at the\n    // trailing edge, the system time has gone backwards and we're treating\n    // it as the trailing edge, or we've hit the `maxWait` limit.\n    return (lastCallTime === undefined || (timeSinceLastCall >= wait) ||\n      (timeSinceLastCall < 0) || (maxing && timeSinceLastInvoke >= maxWait));\n  }\n\n  function timerExpired() {\n    var time = now();\n    if (shouldInvoke(time)) {\n      return trailingEdge(time);\n    }\n    // Restart the timer.\n    timerId = setTimeout(timerExpired, remainingWait(time));\n  }\n\n  function trailingEdge(time) {\n    timerId = undefined;\n\n    // Only invoke if we have `lastArgs` which means `func` has been\n    // debounced at least once.\n    if (trailing && lastArgs) {\n      return invokeFunc(time);\n    }\n    lastArgs = lastThis = undefined;\n    return result;\n  }\n\n  function cancel() {\n    if (timerId !== undefined) {\n      clearTimeout(timerId);\n    }\n    lastInvokeTime = 0;\n    lastArgs = lastCallTime = lastThis = timerId = undefined;\n  }\n\n  function flush() {\n    return timerId === undefined ? result : trailingEdge(now());\n  }\n\n  function debounced() {\n    var time = now(),\n        isInvoking = shouldInvoke(time);\n\n    lastArgs = arguments;\n    lastThis = this;\n    lastCallTime = time;\n\n    if (isInvoking) {\n      if (timerId === undefined) {\n        return leadingEdge(lastCallTime);\n      }\n      if (maxing) {\n        // Handle invocations in a tight loop.\n        timerId = setTimeout(timerExpired, wait);\n        return invokeFunc(lastCallTime);\n      }\n    }\n    if (timerId === undefined) {\n      timerId = setTimeout(timerExpired, wait);\n    }\n    return result;\n  }\n  debounced.cancel = cancel;\n  debounced.flush = flush;\n  return debounced;\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 * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3.2);\n * // => 3.2\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3.2');\n * // => 3.2\n */\nfunction toNumber(value) {\n  if (typeof value == 'number') {\n    return value;\n  }\n  if (isSymbol(value)) {\n    return NAN;\n  }\n  if (isObject(value)) {\n    var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\n    value = isObject(other) ? (other + '') : other;\n  }\n  if (typeof value != 'string') {\n    return value === 0 ? value : +value;\n  }\n  value = value.replace(reTrim, '');\n  var isBinary = reIsBinary.test(value);\n  return (isBinary || reIsOctal.test(value))\n    ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n    : (reIsBadHex.test(value) ? NAN : +value);\n}\n\nmodule.exports = debounce;\n"],"sourceRoot":""}