var blocksyOptions;(()=>{var __webpack_modules__={1314:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "He": () => (/* binding */ getPayload),\n/* harmony export */ "Ld": () => (/* binding */ createHost),\n/* harmony export */ "eC": () => (/* binding */ AnimatedString),\n/* harmony export */ "f3": () => (/* binding */ setAnimated),\n/* harmony export */ "iG": () => (/* binding */ AnimatedValue),\n/* harmony export */ "rS": () => (/* binding */ AnimatedObject),\n/* harmony export */ "sb": () => (/* binding */ getAnimatedType),\n/* harmony export */ "ys": () => (/* binding */ getAnimated)\n/* harmony export */ });\n/* unused harmony exports Animated, AnimatedArray, isAnimated */\n/* harmony import */ var _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(4813);\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7363);\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_1__);\n\n\n\n\nconst $node = Symbol.for(\'Animated:node\');\nconst isAnimated = value => !!value && value[$node] === value;\nconst getAnimated = owner => owner && owner[$node];\nconst setAnimated = (owner, node) => (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .defineHidden */ .dE)(owner, $node, node);\nconst getPayload = owner => owner && owner[$node] && owner[$node].getPayload();\nclass Animated {\n constructor() {\n this.payload = void 0;\n setAnimated(this, this);\n }\n\n getPayload() {\n return this.payload || [];\n }\n\n}\n\nclass AnimatedValue extends Animated {\n constructor(_value) {\n super();\n this.done = true;\n this.elapsedTime = void 0;\n this.lastPosition = void 0;\n this.lastVelocity = void 0;\n this.v0 = void 0;\n this.durationProgress = 0;\n this._value = _value;\n\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.num(this._value)) {\n this.lastPosition = this._value;\n }\n }\n\n static create(value) {\n return new AnimatedValue(value);\n }\n\n getPayload() {\n return [this];\n }\n\n getValue() {\n return this._value;\n }\n\n setValue(value, step) {\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.num(value)) {\n this.lastPosition = value;\n\n if (step) {\n value = Math.round(value / step) * step;\n\n if (this.done) {\n this.lastPosition = value;\n }\n }\n }\n\n if (this._value === value) {\n return false;\n }\n\n this._value = value;\n return true;\n }\n\n reset() {\n const {\n done\n } = this;\n this.done = false;\n\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.num(this._value)) {\n this.elapsedTime = 0;\n this.durationProgress = 0;\n this.lastPosition = this._value;\n if (done) this.lastVelocity = null;\n this.v0 = null;\n }\n }\n\n}\n\nclass AnimatedString extends AnimatedValue {\n constructor(value) {\n super(0);\n this._string = null;\n this._toString = void 0;\n this._toString = (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .createInterpolator */ .mD)({\n output: [value, value]\n });\n }\n\n static create(value) {\n return new AnimatedString(value);\n }\n\n getValue() {\n let value = this._string;\n return value == null ? this._string = this._toString(this._value) : value;\n }\n\n setValue(value) {\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.str(value)) {\n if (value == this._string) {\n return false;\n }\n\n this._string = value;\n this._value = 1;\n } else if (super.setValue(value)) {\n this._string = null;\n } else {\n return false;\n }\n\n return true;\n }\n\n reset(goal) {\n if (goal) {\n this._toString = (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .createInterpolator */ .mD)({\n output: [this.getValue(), goal]\n });\n }\n\n this._value = 0;\n super.reset();\n }\n\n}\n\nconst TreeContext = {\n dependencies: null\n};\n\nclass AnimatedObject extends Animated {\n constructor(source) {\n super();\n this.source = source;\n this.setValue(source);\n }\n\n getValue(animated) {\n const values = {};\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .eachProp */ .rU)(this.source, (source, key) => {\n if (isAnimated(source)) {\n values[key] = source.getValue(animated);\n } else if ((0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .hasFluidValue */ .j$)(source)) {\n values[key] = (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .getFluidValue */ .je)(source);\n } else if (!animated) {\n values[key] = source;\n }\n });\n return values;\n }\n\n setValue(source) {\n this.source = source;\n this.payload = this._makePayload(source);\n }\n\n reset() {\n if (this.payload) {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(this.payload, node => node.reset());\n }\n }\n\n _makePayload(source) {\n if (source) {\n const payload = new Set();\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .eachProp */ .rU)(source, this._addToPayload, payload);\n return Array.from(payload);\n }\n }\n\n _addToPayload(source) {\n if (TreeContext.dependencies && (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .hasFluidValue */ .j$)(source)) {\n TreeContext.dependencies.add(source);\n }\n\n const payload = getPayload(source);\n\n if (payload) {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(payload, node => this.add(node));\n }\n }\n\n}\n\nclass AnimatedArray extends AnimatedObject {\n constructor(source) {\n super(source);\n }\n\n static create(source) {\n return new AnimatedArray(source);\n }\n\n getValue() {\n return this.source.map(node => node.getValue());\n }\n\n setValue(source) {\n const payload = this.getPayload();\n\n if (source.length == payload.length) {\n return payload.map((node, i) => node.setValue(source[i])).some(Boolean);\n }\n\n super.setValue(source.map(makeAnimated));\n return true;\n }\n\n}\n\nfunction makeAnimated(value) {\n const nodeType = (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .isAnimatedString */ .Df)(value) ? AnimatedString : AnimatedValue;\n return nodeType.create(value);\n}\n\nfunction getAnimatedType(value) {\n const parentNode = getAnimated(value);\n return parentNode ? parentNode.constructor : _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.arr(value) ? AnimatedArray : (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .isAnimatedString */ .Df)(value) ? AnimatedString : AnimatedValue;\n}\n\nfunction _extends() {\n _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n };\n\n return _extends.apply(this, arguments);\n}\n\nconst withAnimated = (Component, host) => {\n const hasInstance = !_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.fun(Component) || Component.prototype && Component.prototype.isReactComponent;\n return (0,react__WEBPACK_IMPORTED_MODULE_1__.forwardRef)((givenProps, givenRef) => {\n const instanceRef = (0,react__WEBPACK_IMPORTED_MODULE_1__.useRef)(null);\n const ref = hasInstance && (0,react__WEBPACK_IMPORTED_MODULE_1__.useCallback)(value => {\n instanceRef.current = updateRef(givenRef, value);\n }, [givenRef]);\n const [props, deps] = getAnimatedState(givenProps, host);\n const forceUpdate = (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .useForceUpdate */ .NW)();\n\n const callback = () => {\n const instance = instanceRef.current;\n\n if (hasInstance && !instance) {\n return;\n }\n\n const didUpdate = instance ? host.applyAnimatedValues(instance, props.getValue(true)) : false;\n\n if (didUpdate === false) {\n forceUpdate();\n }\n };\n\n const observer = new PropsObserver(callback, deps);\n const observerRef = (0,react__WEBPACK_IMPORTED_MODULE_1__.useRef)();\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .useLayoutEffect */ .bt)(() => {\n observerRef.current = observer;\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(deps, dep => (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .addFluidObserver */ .UI)(dep, observer));\n return () => {\n if (observerRef.current) {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(observerRef.current.deps, dep => (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .removeFluidObserver */ .iL)(dep, observerRef.current));\n _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .raf.cancel */ .Wn.cancel(observerRef.current.update);\n }\n };\n });\n (0,react__WEBPACK_IMPORTED_MODULE_1__.useEffect)(callback, []);\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .useOnce */ .tf)(() => () => {\n const observer = observerRef.current;\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(observer.deps, dep => (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .removeFluidObserver */ .iL)(dep, observer));\n });\n const usedProps = host.getComponentProps(props.getValue());\n return react__WEBPACK_IMPORTED_MODULE_1__.createElement(Component, _extends({}, usedProps, {\n ref: ref\n }));\n });\n};\n\nclass PropsObserver {\n constructor(update, deps) {\n this.update = update;\n this.deps = deps;\n }\n\n eventObserved(event) {\n if (event.type == \'change\') {\n _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .raf.write */ .Wn.write(this.update);\n }\n }\n\n}\n\nfunction getAnimatedState(props, host) {\n const dependencies = new Set();\n TreeContext.dependencies = dependencies;\n if (props.style) props = _extends({}, props, {\n style: host.createAnimatedStyle(props.style)\n });\n props = new AnimatedObject(props);\n TreeContext.dependencies = null;\n return [props, dependencies];\n}\n\nfunction updateRef(ref, value) {\n if (ref) {\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.fun(ref)) ref(value);else ref.current = value;\n }\n\n return value;\n}\n\nconst cacheKey = Symbol.for(\'AnimatedComponent\');\nconst createHost = (components, {\n applyAnimatedValues: _applyAnimatedValues = () => false,\n createAnimatedStyle: _createAnimatedStyle = style => new AnimatedObject(style),\n getComponentProps: _getComponentProps = props => props\n} = {}) => {\n const hostConfig = {\n applyAnimatedValues: _applyAnimatedValues,\n createAnimatedStyle: _createAnimatedStyle,\n getComponentProps: _getComponentProps\n };\n\n const animated = Component => {\n const displayName = getDisplayName(Component) || \'Anonymous\';\n\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.str(Component)) {\n Component = animated[Component] || (animated[Component] = withAnimated(Component, hostConfig));\n } else {\n Component = Component[cacheKey] || (Component[cacheKey] = withAnimated(Component, hostConfig));\n }\n\n Component.displayName = `Animated(${displayName})`;\n return Component;\n };\n\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .eachProp */ .rU)(components, (Component, key) => {\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.arr(components)) {\n key = getDisplayName(Component);\n }\n\n animated[key] = animated(Component);\n });\n return {\n animated\n };\n};\n\nconst getDisplayName = arg => _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.str(arg) ? arg : arg && _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.str(arg.displayName) ? arg.displayName : _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.fun(arg) && arg.name || null;\n\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"1314.js","mappings":";;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./node_modules/@react-spring/animated/dist/react-spring-animated.esm.js?75f6"],"sourcesContent":["import { defineHidden, is, createInterpolator, eachProp, hasFluidValue, getFluidValue, each, isAnimatedString, useForceUpdate, useLayoutEffect, addFluidObserver, removeFluidObserver, raf, useOnce } from '@react-spring/shared';\nimport * as React from 'react';\nimport { forwardRef, useRef, useCallback, useEffect } from 'react';\n\nconst $node = Symbol.for('Animated:node');\nconst isAnimated = value => !!value && value[$node] === value;\nconst getAnimated = owner => owner && owner[$node];\nconst setAnimated = (owner, node) => defineHidden(owner, $node, node);\nconst getPayload = owner => owner && owner[$node] && owner[$node].getPayload();\nclass Animated {\n  constructor() {\n    this.payload = void 0;\n    setAnimated(this, this);\n  }\n\n  getPayload() {\n    return this.payload || [];\n  }\n\n}\n\nclass AnimatedValue extends Animated {\n  constructor(_value) {\n    super();\n    this.done = true;\n    this.elapsedTime = void 0;\n    this.lastPosition = void 0;\n    this.lastVelocity = void 0;\n    this.v0 = void 0;\n    this.durationProgress = 0;\n    this._value = _value;\n\n    if (is.num(this._value)) {\n      this.lastPosition = this._value;\n    }\n  }\n\n  static create(value) {\n    return new AnimatedValue(value);\n  }\n\n  getPayload() {\n    return [this];\n  }\n\n  getValue() {\n    return this._value;\n  }\n\n  setValue(value, step) {\n    if (is.num(value)) {\n      this.lastPosition = value;\n\n      if (step) {\n        value = Math.round(value / step) * step;\n\n        if (this.done) {\n          this.lastPosition = value;\n        }\n      }\n    }\n\n    if (this._value === value) {\n      return false;\n    }\n\n    this._value = value;\n    return true;\n  }\n\n  reset() {\n    const {\n      done\n    } = this;\n    this.done = false;\n\n    if (is.num(this._value)) {\n      this.elapsedTime = 0;\n      this.durationProgress = 0;\n      this.lastPosition = this._value;\n      if (done) this.lastVelocity = null;\n      this.v0 = null;\n    }\n  }\n\n}\n\nclass AnimatedString extends AnimatedValue {\n  constructor(value) {\n    super(0);\n    this._string = null;\n    this._toString = void 0;\n    this._toString = createInterpolator({\n      output: [value, value]\n    });\n  }\n\n  static create(value) {\n    return new AnimatedString(value);\n  }\n\n  getValue() {\n    let value = this._string;\n    return value == null ? this._string = this._toString(this._value) : value;\n  }\n\n  setValue(value) {\n    if (is.str(value)) {\n      if (value == this._string) {\n        return false;\n      }\n\n      this._string = value;\n      this._value = 1;\n    } else if (super.setValue(value)) {\n      this._string = null;\n    } else {\n      return false;\n    }\n\n    return true;\n  }\n\n  reset(goal) {\n    if (goal) {\n      this._toString = createInterpolator({\n        output: [this.getValue(), goal]\n      });\n    }\n\n    this._value = 0;\n    super.reset();\n  }\n\n}\n\nconst TreeContext = {\n  dependencies: null\n};\n\nclass AnimatedObject extends Animated {\n  constructor(source) {\n    super();\n    this.source = source;\n    this.setValue(source);\n  }\n\n  getValue(animated) {\n    const values = {};\n    eachProp(this.source, (source, key) => {\n      if (isAnimated(source)) {\n        values[key] = source.getValue(animated);\n      } else if (hasFluidValue(source)) {\n        values[key] = getFluidValue(source);\n      } else if (!animated) {\n        values[key] = source;\n      }\n    });\n    return values;\n  }\n\n  setValue(source) {\n    this.source = source;\n    this.payload = this._makePayload(source);\n  }\n\n  reset() {\n    if (this.payload) {\n      each(this.payload, node => node.reset());\n    }\n  }\n\n  _makePayload(source) {\n    if (source) {\n      const payload = new Set();\n      eachProp(source, this._addToPayload, payload);\n      return Array.from(payload);\n    }\n  }\n\n  _addToPayload(source) {\n    if (TreeContext.dependencies && hasFluidValue(source)) {\n      TreeContext.dependencies.add(source);\n    }\n\n    const payload = getPayload(source);\n\n    if (payload) {\n      each(payload, node => this.add(node));\n    }\n  }\n\n}\n\nclass AnimatedArray extends AnimatedObject {\n  constructor(source) {\n    super(source);\n  }\n\n  static create(source) {\n    return new AnimatedArray(source);\n  }\n\n  getValue() {\n    return this.source.map(node => node.getValue());\n  }\n\n  setValue(source) {\n    const payload = this.getPayload();\n\n    if (source.length == payload.length) {\n      return payload.map((node, i) => node.setValue(source[i])).some(Boolean);\n    }\n\n    super.setValue(source.map(makeAnimated));\n    return true;\n  }\n\n}\n\nfunction makeAnimated(value) {\n  const nodeType = isAnimatedString(value) ? AnimatedString : AnimatedValue;\n  return nodeType.create(value);\n}\n\nfunction getAnimatedType(value) {\n  const parentNode = getAnimated(value);\n  return parentNode ? parentNode.constructor : is.arr(value) ? AnimatedArray : isAnimatedString(value) ? AnimatedString : AnimatedValue;\n}\n\nfunction _extends() {\n  _extends = Object.assign || function (target) {\n    for (var i = 1; i < arguments.length; i++) {\n      var source = arguments[i];\n\n      for (var key in source) {\n        if (Object.prototype.hasOwnProperty.call(source, key)) {\n          target[key] = source[key];\n        }\n      }\n    }\n\n    return target;\n  };\n\n  return _extends.apply(this, arguments);\n}\n\nconst withAnimated = (Component, host) => {\n  const hasInstance = !is.fun(Component) || Component.prototype && Component.prototype.isReactComponent;\n  return forwardRef((givenProps, givenRef) => {\n    const instanceRef = useRef(null);\n    const ref = hasInstance && useCallback(value => {\n      instanceRef.current = updateRef(givenRef, value);\n    }, [givenRef]);\n    const [props, deps] = getAnimatedState(givenProps, host);\n    const forceUpdate = useForceUpdate();\n\n    const callback = () => {\n      const instance = instanceRef.current;\n\n      if (hasInstance && !instance) {\n        return;\n      }\n\n      const didUpdate = instance ? host.applyAnimatedValues(instance, props.getValue(true)) : false;\n\n      if (didUpdate === false) {\n        forceUpdate();\n      }\n    };\n\n    const observer = new PropsObserver(callback, deps);\n    const observerRef = useRef();\n    useLayoutEffect(() => {\n      observerRef.current = observer;\n      each(deps, dep => addFluidObserver(dep, observer));\n      return () => {\n        if (observerRef.current) {\n          each(observerRef.current.deps, dep => removeFluidObserver(dep, observerRef.current));\n          raf.cancel(observerRef.current.update);\n        }\n      };\n    });\n    useEffect(callback, []);\n    useOnce(() => () => {\n      const observer = observerRef.current;\n      each(observer.deps, dep => removeFluidObserver(dep, observer));\n    });\n    const usedProps = host.getComponentProps(props.getValue());\n    return React.createElement(Component, _extends({}, usedProps, {\n      ref: ref\n    }));\n  });\n};\n\nclass PropsObserver {\n  constructor(update, deps) {\n    this.update = update;\n    this.deps = deps;\n  }\n\n  eventObserved(event) {\n    if (event.type == 'change') {\n      raf.write(this.update);\n    }\n  }\n\n}\n\nfunction getAnimatedState(props, host) {\n  const dependencies = new Set();\n  TreeContext.dependencies = dependencies;\n  if (props.style) props = _extends({}, props, {\n    style: host.createAnimatedStyle(props.style)\n  });\n  props = new AnimatedObject(props);\n  TreeContext.dependencies = null;\n  return [props, dependencies];\n}\n\nfunction updateRef(ref, value) {\n  if (ref) {\n    if (is.fun(ref)) ref(value);else ref.current = value;\n  }\n\n  return value;\n}\n\nconst cacheKey = Symbol.for('AnimatedComponent');\nconst createHost = (components, {\n  applyAnimatedValues: _applyAnimatedValues = () => false,\n  createAnimatedStyle: _createAnimatedStyle = style => new AnimatedObject(style),\n  getComponentProps: _getComponentProps = props => props\n} = {}) => {\n  const hostConfig = {\n    applyAnimatedValues: _applyAnimatedValues,\n    createAnimatedStyle: _createAnimatedStyle,\n    getComponentProps: _getComponentProps\n  };\n\n  const animated = Component => {\n    const displayName = getDisplayName(Component) || 'Anonymous';\n\n    if (is.str(Component)) {\n      Component = animated[Component] || (animated[Component] = withAnimated(Component, hostConfig));\n    } else {\n      Component = Component[cacheKey] || (Component[cacheKey] = withAnimated(Component, hostConfig));\n    }\n\n    Component.displayName = `Animated(${displayName})`;\n    return Component;\n  };\n\n  eachProp(components, (Component, key) => {\n    if (is.arr(components)) {\n      key = getDisplayName(Component);\n    }\n\n    animated[key] = animated(Component);\n  });\n  return {\n    animated\n  };\n};\n\nconst getDisplayName = arg => is.str(arg) ? arg : arg && is.str(arg.displayName) ? arg.displayName : is.fun(arg) && arg.name || null;\n\nexport { Animated, AnimatedArray, AnimatedObject, AnimatedString, AnimatedValue, createHost, getAnimated, getAnimatedType, getPayload, isAnimated, setAnimated };\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///1314\n')},4928:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"Globals\": () => (/* reexport safe */ _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.OH),\n/* harmony export */ \"Transition\": () => (/* binding */ Transition)\n/* harmony export */ });\n/* unused harmony exports BailSignal, Controller, FrameValue, Interpolation, Spring, SpringContext, SpringRef, SpringValue, Trail, config, easings, inferTo, interpolate, to, update, useChain, useSpring, useSpringRef, useSprings, useTrail, useTransition */\n/* harmony import */ var _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(4813);\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7363);\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _react_spring_animated__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(1314);\n\n\n\n\n\n\n\n\nfunction _extends() {\n _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n };\n\n return _extends.apply(this, arguments);\n}\n\nfunction callProp(value, ...args) {\n return _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.fun(value) ? value(...args) : value;\n}\nconst matchProp = (value, key) => value === true || !!(key && value && (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.fun(value) ? value(key) : (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .toArray */ .qo)(value).includes(key)));\nconst resolveProp = (prop, key) => _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.obj(prop) ? key && prop[key] : prop;\nconst getDefaultProp = (props, key) => props.default === true ? props[key] : props.default ? props.default[key] : undefined;\n\nconst noopTransform = value => value;\n\nconst getDefaultProps = (props, transform = noopTransform) => {\n let keys = DEFAULT_PROPS;\n\n if (props.default && props.default !== true) {\n props = props.default;\n keys = Object.keys(props);\n }\n\n const defaults = {};\n\n for (const key of keys) {\n const value = transform(props[key], key);\n\n if (!_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(value)) {\n defaults[key] = value;\n }\n }\n\n return defaults;\n};\nconst DEFAULT_PROPS = ['config', 'onProps', 'onStart', 'onChange', 'onPause', 'onResume', 'onRest'];\nconst RESERVED_PROPS = {\n config: 1,\n from: 1,\n to: 1,\n ref: 1,\n loop: 1,\n reset: 1,\n pause: 1,\n cancel: 1,\n reverse: 1,\n immediate: 1,\n default: 1,\n delay: 1,\n onProps: 1,\n onStart: 1,\n onChange: 1,\n onPause: 1,\n onResume: 1,\n onRest: 1,\n onResolve: 1,\n items: 1,\n trail: 1,\n sort: 1,\n expires: 1,\n initial: 1,\n enter: 1,\n update: 1,\n leave: 1,\n children: 1,\n onDestroyed: 1,\n keys: 1,\n callId: 1,\n parentId: 1\n};\n\nfunction getForwardProps(props) {\n const forward = {};\n let count = 0;\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .eachProp */ .rU)(props, (value, prop) => {\n if (!RESERVED_PROPS[prop]) {\n forward[prop] = value;\n count++;\n }\n });\n\n if (count) {\n return forward;\n }\n}\n\nfunction inferTo(props) {\n const to = getForwardProps(props);\n\n if (to) {\n const out = {\n to\n };\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .eachProp */ .rU)(props, (val, key) => key in to || (out[key] = val));\n return out;\n }\n\n return _extends({}, props);\n}\nfunction computeGoal(value) {\n value = (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .getFluidValue */ .je)(value);\n return _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.arr(value) ? value.map(computeGoal) : (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .isAnimatedString */ .Df)(value) ? _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .Globals.createStringInterpolator */ .OH.createStringInterpolator({\n range: [0, 1],\n output: [value, value]\n })(1) : value;\n}\nfunction hasProps(props) {\n for (const _ in props) return true;\n\n return false;\n}\nfunction isAsyncTo(to) {\n return _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.fun(to) || _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.arr(to) && _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.obj(to[0]);\n}\nfunction detachRefs(ctrl, ref) {\n var _ctrl$ref;\n\n (_ctrl$ref = ctrl.ref) == null ? void 0 : _ctrl$ref.delete(ctrl);\n ref == null ? void 0 : ref.delete(ctrl);\n}\nfunction replaceRef(ctrl, ref) {\n if (ref && ctrl.ref !== ref) {\n var _ctrl$ref2;\n\n (_ctrl$ref2 = ctrl.ref) == null ? void 0 : _ctrl$ref2.delete(ctrl);\n ref.add(ctrl);\n ctrl.ref = ref;\n }\n}\n\nfunction useChain(refs, timeSteps, timeFrame = 1000) {\n useLayoutEffect(() => {\n if (timeSteps) {\n let prevDelay = 0;\n each(refs, (ref, i) => {\n const controllers = ref.current;\n\n if (controllers.length) {\n let delay = timeFrame * timeSteps[i];\n if (isNaN(delay)) delay = prevDelay;else prevDelay = delay;\n each(controllers, ctrl => {\n each(ctrl.queue, props => {\n const memoizedDelayProp = props.delay;\n\n props.delay = key => delay + callProp(memoizedDelayProp || 0, key);\n });\n });\n ref.start();\n }\n });\n } else {\n let p = Promise.resolve();\n each(refs, ref => {\n const controllers = ref.current;\n\n if (controllers.length) {\n const queues = controllers.map(ctrl => {\n const q = ctrl.queue;\n ctrl.queue = [];\n return q;\n });\n p = p.then(() => {\n each(controllers, (ctrl, i) => each(queues[i] || [], update => ctrl.queue.push(update)));\n return Promise.all(ref.start());\n });\n }\n });\n }\n });\n}\n\nconst config = {\n default: {\n tension: 170,\n friction: 26\n },\n gentle: {\n tension: 120,\n friction: 14\n },\n wobbly: {\n tension: 180,\n friction: 12\n },\n stiff: {\n tension: 210,\n friction: 20\n },\n slow: {\n tension: 280,\n friction: 60\n },\n molasses: {\n tension: 280,\n friction: 120\n }\n};\nconst c1 = 1.70158;\nconst c2 = c1 * 1.525;\nconst c3 = c1 + 1;\nconst c4 = 2 * Math.PI / 3;\nconst c5 = 2 * Math.PI / 4.5;\n\nconst bounceOut = x => {\n const n1 = 7.5625;\n const d1 = 2.75;\n\n if (x < 1 / d1) {\n return n1 * x * x;\n } else if (x < 2 / d1) {\n return n1 * (x -= 1.5 / d1) * x + 0.75;\n } else if (x < 2.5 / d1) {\n return n1 * (x -= 2.25 / d1) * x + 0.9375;\n } else {\n return n1 * (x -= 2.625 / d1) * x + 0.984375;\n }\n};\n\nconst easings = {\n linear: x => x,\n easeInQuad: x => x * x,\n easeOutQuad: x => 1 - (1 - x) * (1 - x),\n easeInOutQuad: x => x < 0.5 ? 2 * x * x : 1 - Math.pow(-2 * x + 2, 2) / 2,\n easeInCubic: x => x * x * x,\n easeOutCubic: x => 1 - Math.pow(1 - x, 3),\n easeInOutCubic: x => x < 0.5 ? 4 * x * x * x : 1 - Math.pow(-2 * x + 2, 3) / 2,\n easeInQuart: x => x * x * x * x,\n easeOutQuart: x => 1 - Math.pow(1 - x, 4),\n easeInOutQuart: x => x < 0.5 ? 8 * x * x * x * x : 1 - Math.pow(-2 * x + 2, 4) / 2,\n easeInQuint: x => x * x * x * x * x,\n easeOutQuint: x => 1 - Math.pow(1 - x, 5),\n easeInOutQuint: x => x < 0.5 ? 16 * x * x * x * x * x : 1 - Math.pow(-2 * x + 2, 5) / 2,\n easeInSine: x => 1 - Math.cos(x * Math.PI / 2),\n easeOutSine: x => Math.sin(x * Math.PI / 2),\n easeInOutSine: x => -(Math.cos(Math.PI * x) - 1) / 2,\n easeInExpo: x => x === 0 ? 0 : Math.pow(2, 10 * x - 10),\n easeOutExpo: x => x === 1 ? 1 : 1 - Math.pow(2, -10 * x),\n easeInOutExpo: x => x === 0 ? 0 : x === 1 ? 1 : x < 0.5 ? Math.pow(2, 20 * x - 10) / 2 : (2 - Math.pow(2, -20 * x + 10)) / 2,\n easeInCirc: x => 1 - Math.sqrt(1 - Math.pow(x, 2)),\n easeOutCirc: x => Math.sqrt(1 - Math.pow(x - 1, 2)),\n easeInOutCirc: x => x < 0.5 ? (1 - Math.sqrt(1 - Math.pow(2 * x, 2))) / 2 : (Math.sqrt(1 - Math.pow(-2 * x + 2, 2)) + 1) / 2,\n easeInBack: x => c3 * x * x * x - c1 * x * x,\n easeOutBack: x => 1 + c3 * Math.pow(x - 1, 3) + c1 * Math.pow(x - 1, 2),\n easeInOutBack: x => x < 0.5 ? Math.pow(2 * x, 2) * ((c2 + 1) * 2 * x - c2) / 2 : (Math.pow(2 * x - 2, 2) * ((c2 + 1) * (x * 2 - 2) + c2) + 2) / 2,\n easeInElastic: x => x === 0 ? 0 : x === 1 ? 1 : -Math.pow(2, 10 * x - 10) * Math.sin((x * 10 - 10.75) * c4),\n easeOutElastic: x => x === 0 ? 0 : x === 1 ? 1 : Math.pow(2, -10 * x) * Math.sin((x * 10 - 0.75) * c4) + 1,\n easeInOutElastic: x => x === 0 ? 0 : x === 1 ? 1 : x < 0.5 ? -(Math.pow(2, 20 * x - 10) * Math.sin((20 * x - 11.125) * c5)) / 2 : Math.pow(2, -20 * x + 10) * Math.sin((20 * x - 11.125) * c5) / 2 + 1,\n easeInBounce: x => 1 - bounceOut(1 - x),\n easeOutBounce: bounceOut,\n easeInOutBounce: x => x < 0.5 ? (1 - bounceOut(1 - 2 * x)) / 2 : (1 + bounceOut(2 * x - 1)) / 2\n};\n\nconst defaults = _extends({}, config.default, {\n mass: 1,\n damping: 1,\n easing: easings.linear,\n clamp: false\n});\n\nclass AnimationConfig {\n constructor() {\n this.tension = void 0;\n this.friction = void 0;\n this.frequency = void 0;\n this.damping = void 0;\n this.mass = void 0;\n this.velocity = 0;\n this.restVelocity = void 0;\n this.precision = void 0;\n this.progress = void 0;\n this.duration = void 0;\n this.easing = void 0;\n this.clamp = void 0;\n this.bounce = void 0;\n this.decay = void 0;\n this.round = void 0;\n Object.assign(this, defaults);\n }\n\n}\nfunction mergeConfig(config, newConfig, defaultConfig) {\n if (defaultConfig) {\n defaultConfig = _extends({}, defaultConfig);\n sanitizeConfig(defaultConfig, newConfig);\n newConfig = _extends({}, defaultConfig, newConfig);\n }\n\n sanitizeConfig(config, newConfig);\n Object.assign(config, newConfig);\n\n for (const key in defaults) {\n if (config[key] == null) {\n config[key] = defaults[key];\n }\n }\n\n let {\n mass,\n frequency,\n damping\n } = config;\n\n if (!_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(frequency)) {\n if (frequency < 0.01) frequency = 0.01;\n if (damping < 0) damping = 0;\n config.tension = Math.pow(2 * Math.PI / frequency, 2) * mass;\n config.friction = 4 * Math.PI * damping * mass / frequency;\n }\n\n return config;\n}\n\nfunction sanitizeConfig(config, props) {\n if (!_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(props.decay)) {\n config.duration = undefined;\n } else {\n const isTensionConfig = !_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(props.tension) || !_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(props.friction);\n\n if (isTensionConfig || !_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(props.frequency) || !_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(props.damping) || !_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(props.mass)) {\n config.duration = undefined;\n config.decay = undefined;\n }\n\n if (isTensionConfig) {\n config.frequency = undefined;\n }\n }\n}\n\nconst emptyArray = [];\nclass Animation {\n constructor() {\n this.changed = false;\n this.values = emptyArray;\n this.toValues = null;\n this.fromValues = emptyArray;\n this.to = void 0;\n this.from = void 0;\n this.config = new AnimationConfig();\n this.immediate = false;\n }\n\n}\n\nfunction scheduleProps(callId, {\n key,\n props,\n defaultProps,\n state,\n actions\n}) {\n return new Promise((resolve, reject) => {\n var _props$cancel;\n\n let delay;\n let timeout;\n let cancel = matchProp((_props$cancel = props.cancel) != null ? _props$cancel : defaultProps == null ? void 0 : defaultProps.cancel, key);\n\n if (cancel) {\n onStart();\n } else {\n if (!_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(props.pause)) {\n state.paused = matchProp(props.pause, key);\n }\n\n let pause = defaultProps == null ? void 0 : defaultProps.pause;\n\n if (pause !== true) {\n pause = state.paused || matchProp(pause, key);\n }\n\n delay = callProp(props.delay || 0, key);\n\n if (pause) {\n state.resumeQueue.add(onResume);\n actions.pause();\n } else {\n actions.resume();\n onResume();\n }\n }\n\n function onPause() {\n state.resumeQueue.add(onResume);\n state.timeouts.delete(timeout);\n timeout.cancel();\n delay = timeout.time - _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .raf.now */ .Wn.now();\n }\n\n function onResume() {\n if (delay > 0 && !_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .Globals.skipAnimation */ .OH.skipAnimation) {\n state.delayed = true;\n timeout = _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .raf.setTimeout */ .Wn.setTimeout(onStart, delay);\n state.pauseQueue.add(onPause);\n state.timeouts.add(timeout);\n } else {\n onStart();\n }\n }\n\n function onStart() {\n if (state.delayed) {\n state.delayed = false;\n }\n\n state.pauseQueue.delete(onPause);\n state.timeouts.delete(timeout);\n\n if (callId <= (state.cancelId || 0)) {\n cancel = true;\n }\n\n try {\n actions.start(_extends({}, props, {\n callId,\n cancel\n }), resolve);\n } catch (err) {\n reject(err);\n }\n }\n });\n}\n\nconst getCombinedResult = (target, results) => results.length == 1 ? results[0] : results.some(result => result.cancelled) ? getCancelledResult(target.get()) : results.every(result => result.noop) ? getNoopResult(target.get()) : getFinishedResult(target.get(), results.every(result => result.finished));\nconst getNoopResult = value => ({\n value,\n noop: true,\n finished: true,\n cancelled: false\n});\nconst getFinishedResult = (value, finished, cancelled = false) => ({\n value,\n finished,\n cancelled\n});\nconst getCancelledResult = value => ({\n value,\n cancelled: true,\n finished: false\n});\n\nfunction runAsync(to, props, state, target) {\n const {\n callId,\n parentId,\n onRest\n } = props;\n const {\n asyncTo: prevTo,\n promise: prevPromise\n } = state;\n\n if (!parentId && to === prevTo && !props.reset) {\n return prevPromise;\n }\n\n return state.promise = (async () => {\n state.asyncId = callId;\n state.asyncTo = to;\n const defaultProps = getDefaultProps(props, (value, key) => key === 'onRest' ? undefined : value);\n let preventBail;\n let bail;\n const bailPromise = new Promise((resolve, reject) => (preventBail = resolve, bail = reject));\n\n const bailIfEnded = bailSignal => {\n const bailResult = callId <= (state.cancelId || 0) && getCancelledResult(target) || callId !== state.asyncId && getFinishedResult(target, false);\n\n if (bailResult) {\n bailSignal.result = bailResult;\n bail(bailSignal);\n throw bailSignal;\n }\n };\n\n const animate = (arg1, arg2) => {\n const bailSignal = new BailSignal();\n const skipAnimationSignal = new SkipAniamtionSignal();\n return (async () => {\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .Globals.skipAnimation */ .OH.skipAnimation) {\n stopAsync(state);\n skipAnimationSignal.result = getFinishedResult(target, false);\n bail(skipAnimationSignal);\n throw skipAnimationSignal;\n }\n\n bailIfEnded(bailSignal);\n const props = _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.obj(arg1) ? _extends({}, arg1) : _extends({}, arg2, {\n to: arg1\n });\n props.parentId = callId;\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .eachProp */ .rU)(defaultProps, (value, key) => {\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(props[key])) {\n props[key] = value;\n }\n });\n const result = await target.start(props);\n bailIfEnded(bailSignal);\n\n if (state.paused) {\n await new Promise(resume => {\n state.resumeQueue.add(resume);\n });\n }\n\n return result;\n })();\n };\n\n let result;\n\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .Globals.skipAnimation */ .OH.skipAnimation) {\n stopAsync(state);\n return getFinishedResult(target, false);\n }\n\n try {\n let animating;\n\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.arr(to)) {\n animating = (async queue => {\n for (const props of queue) {\n await animate(props);\n }\n })(to);\n } else {\n animating = Promise.resolve(to(animate, target.stop.bind(target)));\n }\n\n await Promise.all([animating.then(preventBail), bailPromise]);\n result = getFinishedResult(target.get(), true, false);\n } catch (err) {\n if (err instanceof BailSignal) {\n result = err.result;\n } else if (err instanceof SkipAniamtionSignal) {\n result = err.result;\n } else {\n throw err;\n }\n } finally {\n if (callId == state.asyncId) {\n state.asyncId = parentId;\n state.asyncTo = parentId ? prevTo : undefined;\n state.promise = parentId ? prevPromise : undefined;\n }\n }\n\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.fun(onRest)) {\n _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .raf.batchedUpdates */ .Wn.batchedUpdates(() => {\n onRest(result, target, target.item);\n });\n }\n\n return result;\n })();\n}\nfunction stopAsync(state, cancelId) {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .flush */ .yl)(state.timeouts, t => t.cancel());\n state.pauseQueue.clear();\n state.resumeQueue.clear();\n state.asyncId = state.asyncTo = state.promise = undefined;\n if (cancelId) state.cancelId = cancelId;\n}\nclass BailSignal extends Error {\n constructor() {\n super('An async animation has been interrupted. You see this error because you ' + 'forgot to use `await` or `.catch(...)` on its returned promise.');\n this.result = void 0;\n }\n\n}\nclass SkipAniamtionSignal extends Error {\n constructor() {\n super('SkipAnimationSignal');\n this.result = void 0;\n }\n\n}\n\nconst isFrameValue = value => value instanceof FrameValue;\nlet nextId$1 = 1;\nclass FrameValue extends _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .FluidValue */ .B0 {\n constructor(...args) {\n super(...args);\n this.id = nextId$1++;\n this.key = void 0;\n this._priority = 0;\n }\n\n get priority() {\n return this._priority;\n }\n\n set priority(priority) {\n if (this._priority != priority) {\n this._priority = priority;\n\n this._onPriorityChange(priority);\n }\n }\n\n get() {\n const node = (0,_react_spring_animated__WEBPACK_IMPORTED_MODULE_2__/* .getAnimated */ .ys)(this);\n return node && node.getValue();\n }\n\n to(...args) {\n return _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .Globals.to */ .OH.to(this, args);\n }\n\n interpolate(...args) {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .deprecateInterpolate */ .LW)();\n return _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .Globals.to */ .OH.to(this, args);\n }\n\n toJSON() {\n return this.get();\n }\n\n observerAdded(count) {\n if (count == 1) this._attach();\n }\n\n observerRemoved(count) {\n if (count == 0) this._detach();\n }\n\n _attach() {}\n\n _detach() {}\n\n _onChange(value, idle = false) {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .callFluidObservers */ .k0)(this, {\n type: 'change',\n parent: this,\n value,\n idle\n });\n }\n\n _onPriorityChange(priority) {\n if (!this.idle) {\n _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .frameLoop.sort */ .fT.sort(this);\n }\n\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .callFluidObservers */ .k0)(this, {\n type: 'priority',\n parent: this,\n priority\n });\n }\n\n}\n\nconst $P = Symbol.for('SpringPhase');\nconst HAS_ANIMATED = 1;\nconst IS_ANIMATING = 2;\nconst IS_PAUSED = 4;\nconst hasAnimated = target => (target[$P] & HAS_ANIMATED) > 0;\nconst isAnimating = target => (target[$P] & IS_ANIMATING) > 0;\nconst isPaused = target => (target[$P] & IS_PAUSED) > 0;\nconst setActiveBit = (target, active) => active ? target[$P] |= IS_ANIMATING | HAS_ANIMATED : target[$P] &= ~IS_ANIMATING;\nconst setPausedBit = (target, paused) => paused ? target[$P] |= IS_PAUSED : target[$P] &= ~IS_PAUSED;\n\nclass SpringValue extends FrameValue {\n constructor(arg1, arg2) {\n super();\n this.key = void 0;\n this.animation = new Animation();\n this.queue = void 0;\n this.defaultProps = {};\n this._state = {\n paused: false,\n delayed: false,\n pauseQueue: new Set(),\n resumeQueue: new Set(),\n timeouts: new Set()\n };\n this._pendingCalls = new Set();\n this._lastCallId = 0;\n this._lastToId = 0;\n this._memoizedDuration = 0;\n\n if (!_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(arg1) || !_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(arg2)) {\n const props = _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.obj(arg1) ? _extends({}, arg1) : _extends({}, arg2, {\n from: arg1\n });\n\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(props.default)) {\n props.default = true;\n }\n\n this.start(props);\n }\n }\n\n get idle() {\n return !(isAnimating(this) || this._state.asyncTo) || isPaused(this);\n }\n\n get goal() {\n return (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .getFluidValue */ .je)(this.animation.to);\n }\n\n get velocity() {\n const node = (0,_react_spring_animated__WEBPACK_IMPORTED_MODULE_2__/* .getAnimated */ .ys)(this);\n return node instanceof _react_spring_animated__WEBPACK_IMPORTED_MODULE_2__/* .AnimatedValue */ .iG ? node.lastVelocity || 0 : node.getPayload().map(node => node.lastVelocity || 0);\n }\n\n get hasAnimated() {\n return hasAnimated(this);\n }\n\n get isAnimating() {\n return isAnimating(this);\n }\n\n get isPaused() {\n return isPaused(this);\n }\n\n get isDelayed() {\n return this._state.delayed;\n }\n\n advance(dt) {\n let idle = true;\n let changed = false;\n const anim = this.animation;\n let {\n config,\n toValues\n } = anim;\n const payload = (0,_react_spring_animated__WEBPACK_IMPORTED_MODULE_2__/* .getPayload */ .He)(anim.to);\n\n if (!payload && (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .hasFluidValue */ .j$)(anim.to)) {\n toValues = (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .toArray */ .qo)((0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .getFluidValue */ .je)(anim.to));\n }\n\n anim.values.forEach((node, i) => {\n if (node.done) return;\n const to = node.constructor == _react_spring_animated__WEBPACK_IMPORTED_MODULE_2__/* .AnimatedString */ .eC ? 1 : payload ? payload[i].lastPosition : toValues[i];\n let finished = anim.immediate;\n let position = to;\n\n if (!finished) {\n position = node.lastPosition;\n\n if (config.tension <= 0) {\n node.done = true;\n return;\n }\n\n let elapsed = node.elapsedTime += dt;\n const from = anim.fromValues[i];\n const v0 = node.v0 != null ? node.v0 : node.v0 = _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.arr(config.velocity) ? config.velocity[i] : config.velocity;\n let velocity;\n\n if (!_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(config.duration)) {\n let p = 1;\n\n if (config.duration > 0) {\n if (this._memoizedDuration !== config.duration) {\n this._memoizedDuration = config.duration;\n\n if (node.durationProgress > 0) {\n node.elapsedTime = config.duration * node.durationProgress;\n elapsed = node.elapsedTime += dt;\n }\n }\n\n p = (config.progress || 0) + elapsed / this._memoizedDuration;\n p = p > 1 ? 1 : p < 0 ? 0 : p;\n node.durationProgress = p;\n }\n\n position = from + config.easing(p) * (to - from);\n velocity = (position - node.lastPosition) / dt;\n finished = p == 1;\n } else if (config.decay) {\n const decay = config.decay === true ? 0.998 : config.decay;\n const e = Math.exp(-(1 - decay) * elapsed);\n position = from + v0 / (1 - decay) * (1 - e);\n finished = Math.abs(node.lastPosition - position) < 0.1;\n velocity = v0 * e;\n } else {\n velocity = node.lastVelocity == null ? v0 : node.lastVelocity;\n const precision = config.precision || (from == to ? 0.005 : Math.min(1, Math.abs(to - from) * 0.001));\n const restVelocity = config.restVelocity || precision / 10;\n const bounceFactor = config.clamp ? 0 : config.bounce;\n const canBounce = !_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(bounceFactor);\n const isGrowing = from == to ? node.v0 > 0 : from < to;\n let isMoving;\n let isBouncing = false;\n const step = 1;\n const numSteps = Math.ceil(dt / step);\n\n for (let n = 0; n < numSteps; ++n) {\n isMoving = Math.abs(velocity) > restVelocity;\n\n if (!isMoving) {\n finished = Math.abs(to - position) <= precision;\n\n if (finished) {\n break;\n }\n }\n\n if (canBounce) {\n isBouncing = position == to || position > to == isGrowing;\n\n if (isBouncing) {\n velocity = -velocity * bounceFactor;\n position = to;\n }\n }\n\n const springForce = -config.tension * 0.000001 * (position - to);\n const dampingForce = -config.friction * 0.001 * velocity;\n const acceleration = (springForce + dampingForce) / config.mass;\n velocity = velocity + acceleration * step;\n position = position + velocity * step;\n }\n }\n\n node.lastVelocity = velocity;\n\n if (Number.isNaN(position)) {\n console.warn(`Got NaN while animating:`, this);\n finished = true;\n }\n }\n\n if (payload && !payload[i].done) {\n finished = false;\n }\n\n if (finished) {\n node.done = true;\n } else {\n idle = false;\n }\n\n if (node.setValue(position, config.round)) {\n changed = true;\n }\n });\n const node = (0,_react_spring_animated__WEBPACK_IMPORTED_MODULE_2__/* .getAnimated */ .ys)(this);\n const currVal = node.getValue();\n\n if (idle) {\n const finalVal = (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .getFluidValue */ .je)(anim.to);\n\n if ((currVal !== finalVal || changed) && !config.decay) {\n node.setValue(finalVal);\n\n this._onChange(finalVal);\n } else if (changed && config.decay) {\n this._onChange(currVal);\n }\n\n this._stop();\n } else if (changed) {\n this._onChange(currVal);\n }\n }\n\n set(value) {\n _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .raf.batchedUpdates */ .Wn.batchedUpdates(() => {\n this._stop();\n\n this._focus(value);\n\n this._set(value);\n });\n return this;\n }\n\n pause() {\n this._update({\n pause: true\n });\n }\n\n resume() {\n this._update({\n pause: false\n });\n }\n\n finish() {\n if (isAnimating(this)) {\n const {\n to,\n config\n } = this.animation;\n _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .raf.batchedUpdates */ .Wn.batchedUpdates(() => {\n this._onStart();\n\n if (!config.decay) {\n this._set(to, false);\n }\n\n this._stop();\n });\n }\n\n return this;\n }\n\n update(props) {\n const queue = this.queue || (this.queue = []);\n queue.push(props);\n return this;\n }\n\n start(to, arg2) {\n let queue;\n\n if (!_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(to)) {\n queue = [_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.obj(to) ? to : _extends({}, arg2, {\n to\n })];\n } else {\n queue = this.queue || [];\n this.queue = [];\n }\n\n return Promise.all(queue.map(props => {\n const up = this._update(props);\n\n return up;\n })).then(results => getCombinedResult(this, results));\n }\n\n stop(cancel) {\n const {\n to\n } = this.animation;\n\n this._focus(this.get());\n\n stopAsync(this._state, cancel && this._lastCallId);\n _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .raf.batchedUpdates */ .Wn.batchedUpdates(() => this._stop(to, cancel));\n return this;\n }\n\n reset() {\n this._update({\n reset: true\n });\n }\n\n eventObserved(event) {\n if (event.type == 'change') {\n this._start();\n } else if (event.type == 'priority') {\n this.priority = event.priority + 1;\n }\n }\n\n _prepareNode(props) {\n const key = this.key || '';\n let {\n to,\n from\n } = props;\n to = _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.obj(to) ? to[key] : to;\n\n if (to == null || isAsyncTo(to)) {\n to = undefined;\n }\n\n from = _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.obj(from) ? from[key] : from;\n\n if (from == null) {\n from = undefined;\n }\n\n const range = {\n to,\n from\n };\n\n if (!hasAnimated(this)) {\n if (props.reverse) [to, from] = [from, to];\n from = (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .getFluidValue */ .je)(from);\n\n if (!_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(from)) {\n this._set(from);\n } else if (!(0,_react_spring_animated__WEBPACK_IMPORTED_MODULE_2__/* .getAnimated */ .ys)(this)) {\n this._set(to);\n }\n }\n\n return range;\n }\n\n _update(_ref, isLoop) {\n let props = _extends({}, _ref);\n\n const {\n key,\n defaultProps\n } = this;\n if (props.default) Object.assign(defaultProps, getDefaultProps(props, (value, prop) => /^on/.test(prop) ? resolveProp(value, key) : value));\n mergeActiveFn(this, props, 'onProps');\n sendEvent(this, 'onProps', props, this);\n\n const range = this._prepareNode(props);\n\n if (Object.isFrozen(this)) {\n throw Error('Cannot animate a `SpringValue` object that is frozen. ' + 'Did you forget to pass your component to `animated(...)` before animating its props?');\n }\n\n const state = this._state;\n return scheduleProps(++this._lastCallId, {\n key,\n props,\n defaultProps,\n state,\n actions: {\n pause: () => {\n if (!isPaused(this)) {\n setPausedBit(this, true);\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .flushCalls */ .bl)(state.pauseQueue);\n sendEvent(this, 'onPause', getFinishedResult(this, checkFinished(this, this.animation.to)), this);\n }\n },\n resume: () => {\n if (isPaused(this)) {\n setPausedBit(this, false);\n\n if (isAnimating(this)) {\n this._resume();\n }\n\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .flushCalls */ .bl)(state.resumeQueue);\n sendEvent(this, 'onResume', getFinishedResult(this, checkFinished(this, this.animation.to)), this);\n }\n },\n start: this._merge.bind(this, range)\n }\n }).then(result => {\n if (props.loop && result.finished && !(isLoop && result.noop)) {\n const nextProps = createLoopUpdate(props);\n\n if (nextProps) {\n return this._update(nextProps, true);\n }\n }\n\n return result;\n });\n }\n\n _merge(range, props, resolve) {\n if (props.cancel) {\n this.stop(true);\n return resolve(getCancelledResult(this));\n }\n\n const hasToProp = !_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(range.to);\n const hasFromProp = !_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(range.from);\n\n if (hasToProp || hasFromProp) {\n if (props.callId > this._lastToId) {\n this._lastToId = props.callId;\n } else {\n return resolve(getCancelledResult(this));\n }\n }\n\n const {\n key,\n defaultProps,\n animation: anim\n } = this;\n const {\n to: prevTo,\n from: prevFrom\n } = anim;\n let {\n to = prevTo,\n from = prevFrom\n } = range;\n\n if (hasFromProp && !hasToProp && (!props.default || _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(to))) {\n to = from;\n }\n\n if (props.reverse) [to, from] = [from, to];\n const hasFromChanged = !(0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .isEqual */ .Xy)(from, prevFrom);\n\n if (hasFromChanged) {\n anim.from = from;\n }\n\n from = (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .getFluidValue */ .je)(from);\n const hasToChanged = !(0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .isEqual */ .Xy)(to, prevTo);\n\n if (hasToChanged) {\n this._focus(to);\n }\n\n const hasAsyncTo = isAsyncTo(props.to);\n const {\n config\n } = anim;\n const {\n decay,\n velocity\n } = config;\n\n if (hasToProp || hasFromProp) {\n config.velocity = 0;\n }\n\n if (props.config && !hasAsyncTo) {\n mergeConfig(config, callProp(props.config, key), props.config !== defaultProps.config ? callProp(defaultProps.config, key) : void 0);\n }\n\n let node = (0,_react_spring_animated__WEBPACK_IMPORTED_MODULE_2__/* .getAnimated */ .ys)(this);\n\n if (!node || _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(to)) {\n return resolve(getFinishedResult(this, true));\n }\n\n const reset = _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(props.reset) ? hasFromProp && !props.default : !_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(from) && matchProp(props.reset, key);\n const value = reset ? from : this.get();\n const goal = computeGoal(to);\n const isAnimatable = _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.num(goal) || _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.arr(goal) || (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .isAnimatedString */ .Df)(goal);\n const immediate = !hasAsyncTo && (!isAnimatable || matchProp(defaultProps.immediate || props.immediate, key));\n\n if (hasToChanged) {\n const nodeType = (0,_react_spring_animated__WEBPACK_IMPORTED_MODULE_2__/* .getAnimatedType */ .sb)(to);\n\n if (nodeType !== node.constructor) {\n if (immediate) {\n node = this._set(goal);\n } else throw Error(`Cannot animate between ${node.constructor.name} and ${nodeType.name}, as the \"to\" prop suggests`);\n }\n }\n\n const goalType = node.constructor;\n let started = (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .hasFluidValue */ .j$)(to);\n let finished = false;\n\n if (!started) {\n const hasValueChanged = reset || !hasAnimated(this) && hasFromChanged;\n\n if (hasToChanged || hasValueChanged) {\n finished = (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .isEqual */ .Xy)(computeGoal(value), goal);\n started = !finished;\n }\n\n if (!(0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .isEqual */ .Xy)(anim.immediate, immediate) && !immediate || !(0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .isEqual */ .Xy)(config.decay, decay) || !(0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .isEqual */ .Xy)(config.velocity, velocity)) {\n started = true;\n }\n }\n\n if (finished && isAnimating(this)) {\n if (anim.changed && !reset) {\n started = true;\n } else if (!started) {\n this._stop(prevTo);\n }\n }\n\n if (!hasAsyncTo) {\n if (started || (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .hasFluidValue */ .j$)(prevTo)) {\n anim.values = node.getPayload();\n anim.toValues = (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .hasFluidValue */ .j$)(to) ? null : goalType == _react_spring_animated__WEBPACK_IMPORTED_MODULE_2__/* .AnimatedString */ .eC ? [1] : (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .toArray */ .qo)(goal);\n }\n\n if (anim.immediate != immediate) {\n anim.immediate = immediate;\n\n if (!immediate && !reset) {\n this._set(prevTo);\n }\n }\n\n if (started) {\n const {\n onRest\n } = anim;\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(ACTIVE_EVENTS, type => mergeActiveFn(this, props, type));\n const result = getFinishedResult(this, checkFinished(this, prevTo));\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .flushCalls */ .bl)(this._pendingCalls, result);\n\n this._pendingCalls.add(resolve);\n\n if (anim.changed) _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .raf.batchedUpdates */ .Wn.batchedUpdates(() => {\n anim.changed = !reset;\n onRest == null ? void 0 : onRest(result, this);\n\n if (reset) {\n callProp(defaultProps.onRest, result);\n } else {\n anim.onStart == null ? void 0 : anim.onStart(result, this);\n }\n });\n }\n }\n\n if (reset) {\n this._set(value);\n }\n\n if (hasAsyncTo) {\n resolve(runAsync(props.to, props, this._state, this));\n } else if (started) {\n this._start();\n } else if (isAnimating(this) && !hasToChanged) {\n this._pendingCalls.add(resolve);\n } else {\n resolve(getNoopResult(value));\n }\n }\n\n _focus(value) {\n const anim = this.animation;\n\n if (value !== anim.to) {\n if ((0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .getFluidObservers */ .Ll)(this)) {\n this._detach();\n }\n\n anim.to = value;\n\n if ((0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .getFluidObservers */ .Ll)(this)) {\n this._attach();\n }\n }\n }\n\n _attach() {\n let priority = 0;\n const {\n to\n } = this.animation;\n\n if ((0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .hasFluidValue */ .j$)(to)) {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .addFluidObserver */ .UI)(to, this);\n\n if (isFrameValue(to)) {\n priority = to.priority + 1;\n }\n }\n\n this.priority = priority;\n }\n\n _detach() {\n const {\n to\n } = this.animation;\n\n if ((0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .hasFluidValue */ .j$)(to)) {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .removeFluidObserver */ .iL)(to, this);\n }\n }\n\n _set(arg, idle = true) {\n const value = (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .getFluidValue */ .je)(arg);\n\n if (!_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(value)) {\n const oldNode = (0,_react_spring_animated__WEBPACK_IMPORTED_MODULE_2__/* .getAnimated */ .ys)(this);\n\n if (!oldNode || !(0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .isEqual */ .Xy)(value, oldNode.getValue())) {\n const nodeType = (0,_react_spring_animated__WEBPACK_IMPORTED_MODULE_2__/* .getAnimatedType */ .sb)(value);\n\n if (!oldNode || oldNode.constructor != nodeType) {\n (0,_react_spring_animated__WEBPACK_IMPORTED_MODULE_2__/* .setAnimated */ .f3)(this, nodeType.create(value));\n } else {\n oldNode.setValue(value);\n }\n\n if (oldNode) {\n _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .raf.batchedUpdates */ .Wn.batchedUpdates(() => {\n this._onChange(value, idle);\n });\n }\n }\n }\n\n return (0,_react_spring_animated__WEBPACK_IMPORTED_MODULE_2__/* .getAnimated */ .ys)(this);\n }\n\n _onStart() {\n const anim = this.animation;\n\n if (!anim.changed) {\n anim.changed = true;\n sendEvent(this, 'onStart', getFinishedResult(this, checkFinished(this, anim.to)), this);\n }\n }\n\n _onChange(value, idle) {\n if (!idle) {\n this._onStart();\n\n callProp(this.animation.onChange, value, this);\n }\n\n callProp(this.defaultProps.onChange, value, this);\n\n super._onChange(value, idle);\n }\n\n _start() {\n const anim = this.animation;\n (0,_react_spring_animated__WEBPACK_IMPORTED_MODULE_2__/* .getAnimated */ .ys)(this).reset((0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .getFluidValue */ .je)(anim.to));\n\n if (!anim.immediate) {\n anim.fromValues = anim.values.map(node => node.lastPosition);\n }\n\n if (!isAnimating(this)) {\n setActiveBit(this, true);\n\n if (!isPaused(this)) {\n this._resume();\n }\n }\n }\n\n _resume() {\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .Globals.skipAnimation */ .OH.skipAnimation) {\n this.finish();\n } else {\n _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .frameLoop.start */ .fT.start(this);\n }\n }\n\n _stop(goal, cancel) {\n if (isAnimating(this)) {\n setActiveBit(this, false);\n const anim = this.animation;\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(anim.values, node => {\n node.done = true;\n });\n\n if (anim.toValues) {\n anim.onChange = anim.onPause = anim.onResume = undefined;\n }\n\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .callFluidObservers */ .k0)(this, {\n type: 'idle',\n parent: this\n });\n const result = cancel ? getCancelledResult(this.get()) : getFinishedResult(this.get(), checkFinished(this, goal != null ? goal : anim.to));\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .flushCalls */ .bl)(this._pendingCalls, result);\n\n if (anim.changed) {\n anim.changed = false;\n sendEvent(this, 'onRest', result, this);\n }\n }\n }\n\n}\n\nfunction checkFinished(target, to) {\n const goal = computeGoal(to);\n const value = computeGoal(target.get());\n return (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .isEqual */ .Xy)(value, goal);\n}\n\nfunction createLoopUpdate(props, loop = props.loop, to = props.to) {\n let loopRet = callProp(loop);\n\n if (loopRet) {\n const overrides = loopRet !== true && inferTo(loopRet);\n const reverse = (overrides || props).reverse;\n const reset = !overrides || overrides.reset;\n return createUpdate(_extends({}, props, {\n loop,\n default: false,\n pause: undefined,\n to: !reverse || isAsyncTo(to) ? to : undefined,\n from: reset ? props.from : undefined,\n reset\n }, overrides));\n }\n}\nfunction createUpdate(props) {\n const {\n to,\n from\n } = props = inferTo(props);\n const keys = new Set();\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.obj(to)) findDefined(to, keys);\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.obj(from)) findDefined(from, keys);\n props.keys = keys.size ? Array.from(keys) : null;\n return props;\n}\nfunction declareUpdate(props) {\n const update = createUpdate(props);\n\n if (is.und(update.default)) {\n update.default = getDefaultProps(update);\n }\n\n return update;\n}\n\nfunction findDefined(values, keys) {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .eachProp */ .rU)(values, (value, key) => value != null && keys.add(key));\n}\n\nconst ACTIVE_EVENTS = ['onStart', 'onRest', 'onChange', 'onPause', 'onResume'];\n\nfunction mergeActiveFn(target, props, type) {\n target.animation[type] = props[type] !== getDefaultProp(props, type) ? resolveProp(props[type], target.key) : undefined;\n}\n\nfunction sendEvent(target, type, ...args) {\n var _target$animation$typ, _target$animation, _target$defaultProps$, _target$defaultProps;\n\n (_target$animation$typ = (_target$animation = target.animation)[type]) == null ? void 0 : _target$animation$typ.call(_target$animation, ...args);\n (_target$defaultProps$ = (_target$defaultProps = target.defaultProps)[type]) == null ? void 0 : _target$defaultProps$.call(_target$defaultProps, ...args);\n}\n\nconst BATCHED_EVENTS = ['onStart', 'onChange', 'onRest'];\nlet nextId = 1;\nclass Controller {\n constructor(props, flush) {\n this.id = nextId++;\n this.springs = {};\n this.queue = [];\n this.ref = void 0;\n this._flush = void 0;\n this._initialProps = void 0;\n this._lastAsyncId = 0;\n this._active = new Set();\n this._changed = new Set();\n this._started = false;\n this._item = void 0;\n this._state = {\n paused: false,\n pauseQueue: new Set(),\n resumeQueue: new Set(),\n timeouts: new Set()\n };\n this._events = {\n onStart: new Map(),\n onChange: new Map(),\n onRest: new Map()\n };\n this._onFrame = this._onFrame.bind(this);\n\n if (flush) {\n this._flush = flush;\n }\n\n if (props) {\n this.start(_extends({\n default: true\n }, props));\n }\n }\n\n get idle() {\n return !this._state.asyncTo && Object.values(this.springs).every(spring => {\n return spring.idle && !spring.isDelayed && !spring.isPaused;\n });\n }\n\n get item() {\n return this._item;\n }\n\n set item(item) {\n this._item = item;\n }\n\n get() {\n const values = {};\n this.each((spring, key) => values[key] = spring.get());\n return values;\n }\n\n set(values) {\n for (const key in values) {\n const value = values[key];\n\n if (!_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(value)) {\n this.springs[key].set(value);\n }\n }\n }\n\n update(props) {\n if (props) {\n this.queue.push(createUpdate(props));\n }\n\n return this;\n }\n\n start(props) {\n let {\n queue\n } = this;\n\n if (props) {\n queue = (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .toArray */ .qo)(props).map(createUpdate);\n } else {\n this.queue = [];\n }\n\n if (this._flush) {\n return this._flush(this, queue);\n }\n\n prepareKeys(this, queue);\n return flushUpdateQueue(this, queue);\n }\n\n stop(arg, keys) {\n if (arg !== !!arg) {\n keys = arg;\n }\n\n if (keys) {\n const springs = this.springs;\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)((0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .toArray */ .qo)(keys), key => springs[key].stop(!!arg));\n } else {\n stopAsync(this._state, this._lastAsyncId);\n this.each(spring => spring.stop(!!arg));\n }\n\n return this;\n }\n\n pause(keys) {\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(keys)) {\n this.start({\n pause: true\n });\n } else {\n const springs = this.springs;\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)((0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .toArray */ .qo)(keys), key => springs[key].pause());\n }\n\n return this;\n }\n\n resume(keys) {\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(keys)) {\n this.start({\n pause: false\n });\n } else {\n const springs = this.springs;\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)((0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .toArray */ .qo)(keys), key => springs[key].resume());\n }\n\n return this;\n }\n\n each(iterator) {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .eachProp */ .rU)(this.springs, iterator);\n }\n\n _onFrame() {\n const {\n onStart,\n onChange,\n onRest\n } = this._events;\n const active = this._active.size > 0;\n const changed = this._changed.size > 0;\n\n if (active && !this._started || changed && !this._started) {\n this._started = true;\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .flush */ .yl)(onStart, ([onStart, result]) => {\n result.value = this.get();\n onStart(result, this, this._item);\n });\n }\n\n const idle = !active && this._started;\n const values = changed || idle && onRest.size ? this.get() : null;\n\n if (changed && onChange.size) {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .flush */ .yl)(onChange, ([onChange, result]) => {\n result.value = values;\n onChange(result, this, this._item);\n });\n }\n\n if (idle) {\n this._started = false;\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .flush */ .yl)(onRest, ([onRest, result]) => {\n result.value = values;\n onRest(result, this, this._item);\n });\n }\n }\n\n eventObserved(event) {\n if (event.type == 'change') {\n this._changed.add(event.parent);\n\n if (!event.idle) {\n this._active.add(event.parent);\n }\n } else if (event.type == 'idle') {\n this._active.delete(event.parent);\n } else return;\n\n _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .raf.onFrame */ .Wn.onFrame(this._onFrame);\n }\n\n}\nfunction flushUpdateQueue(ctrl, queue) {\n return Promise.all(queue.map(props => flushUpdate(ctrl, props))).then(results => getCombinedResult(ctrl, results));\n}\nasync function flushUpdate(ctrl, props, isLoop) {\n const {\n keys,\n to,\n from,\n loop,\n onRest,\n onResolve\n } = props;\n const defaults = _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.obj(props.default) && props.default;\n\n if (loop) {\n props.loop = false;\n }\n\n if (to === false) props.to = null;\n if (from === false) props.from = null;\n const asyncTo = _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.arr(to) || _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.fun(to) ? to : undefined;\n\n if (asyncTo) {\n props.to = undefined;\n props.onRest = undefined;\n\n if (defaults) {\n defaults.onRest = undefined;\n }\n } else {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(BATCHED_EVENTS, key => {\n const handler = props[key];\n\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.fun(handler)) {\n const queue = ctrl['_events'][key];\n\n props[key] = ({\n finished,\n cancelled\n }) => {\n const result = queue.get(handler);\n\n if (result) {\n if (!finished) result.finished = false;\n if (cancelled) result.cancelled = true;\n } else {\n queue.set(handler, {\n value: null,\n finished: finished || false,\n cancelled: cancelled || false\n });\n }\n };\n\n if (defaults) {\n defaults[key] = props[key];\n }\n }\n });\n }\n\n const state = ctrl['_state'];\n\n if (props.pause === !state.paused) {\n state.paused = props.pause;\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .flushCalls */ .bl)(props.pause ? state.pauseQueue : state.resumeQueue);\n } else if (state.paused) {\n props.pause = true;\n }\n\n const promises = (keys || Object.keys(ctrl.springs)).map(key => ctrl.springs[key].start(props));\n const cancel = props.cancel === true || getDefaultProp(props, 'cancel') === true;\n\n if (asyncTo || cancel && state.asyncId) {\n promises.push(scheduleProps(++ctrl['_lastAsyncId'], {\n props,\n state,\n actions: {\n pause: _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .noop */ .ZT,\n resume: _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .noop */ .ZT,\n\n start(props, resolve) {\n if (cancel) {\n stopAsync(state, ctrl['_lastAsyncId']);\n resolve(getCancelledResult(ctrl));\n } else {\n props.onRest = onRest;\n resolve(runAsync(asyncTo, props, state, ctrl));\n }\n }\n\n }\n }));\n }\n\n if (state.paused) {\n await new Promise(resume => {\n state.resumeQueue.add(resume);\n });\n }\n\n const result = getCombinedResult(ctrl, await Promise.all(promises));\n\n if (loop && result.finished && !(isLoop && result.noop)) {\n const nextProps = createLoopUpdate(props, loop, to);\n\n if (nextProps) {\n prepareKeys(ctrl, [nextProps]);\n return flushUpdate(ctrl, nextProps, true);\n }\n }\n\n if (onResolve) {\n _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .raf.batchedUpdates */ .Wn.batchedUpdates(() => onResolve(result, ctrl, ctrl.item));\n }\n\n return result;\n}\nfunction getSprings(ctrl, props) {\n const springs = _extends({}, ctrl.springs);\n\n if (props) {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)((0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .toArray */ .qo)(props), props => {\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(props.keys)) {\n props = createUpdate(props);\n }\n\n if (!_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.obj(props.to)) {\n props = _extends({}, props, {\n to: undefined\n });\n }\n\n prepareSprings(springs, props, key => {\n return createSpring(key);\n });\n });\n }\n\n setSprings(ctrl, springs);\n return springs;\n}\nfunction setSprings(ctrl, springs) {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .eachProp */ .rU)(springs, (spring, key) => {\n if (!ctrl.springs[key]) {\n ctrl.springs[key] = spring;\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .addFluidObserver */ .UI)(spring, ctrl);\n }\n });\n}\n\nfunction createSpring(key, observer) {\n const spring = new SpringValue();\n spring.key = key;\n\n if (observer) {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .addFluidObserver */ .UI)(spring, observer);\n }\n\n return spring;\n}\n\nfunction prepareSprings(springs, props, create) {\n if (props.keys) {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(props.keys, key => {\n const spring = springs[key] || (springs[key] = create(key));\n spring['_prepareNode'](props);\n });\n }\n}\n\nfunction prepareKeys(ctrl, queue) {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(queue, props => {\n prepareSprings(ctrl.springs, props, key => {\n return createSpring(key, ctrl);\n });\n });\n}\n\nfunction _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n\n return target;\n}\n\nconst _excluded$3 = [\"children\"];\nconst SpringContext = _ref => {\n let {\n children\n } = _ref,\n props = _objectWithoutPropertiesLoose(_ref, _excluded$3);\n\n const inherited = (0,react__WEBPACK_IMPORTED_MODULE_1__.useContext)(ctx);\n const pause = props.pause || !!inherited.pause,\n immediate = props.immediate || !!inherited.immediate;\n props = (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .useMemoOne */ .Pr)(() => ({\n pause,\n immediate\n }), [pause, immediate]);\n const {\n Provider\n } = ctx;\n return react__WEBPACK_IMPORTED_MODULE_1__.createElement(Provider, {\n value: props\n }, children);\n};\nconst ctx = makeContext(SpringContext, {});\nSpringContext.Provider = ctx.Provider;\nSpringContext.Consumer = ctx.Consumer;\n\nfunction makeContext(target, init) {\n Object.assign(target, react__WEBPACK_IMPORTED_MODULE_1__.createContext(init));\n target.Provider._context = target;\n target.Consumer._context = target;\n return target;\n}\n\nconst SpringRef = () => {\n const current = [];\n\n const SpringRef = function SpringRef(props) {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .deprecateDirectCall */ .ZR)();\n const results = [];\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(current, (ctrl, i) => {\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(props)) {\n results.push(ctrl.start());\n } else {\n const update = _getProps(props, ctrl, i);\n\n if (update) {\n results.push(ctrl.start(update));\n }\n }\n });\n return results;\n };\n\n SpringRef.current = current;\n\n SpringRef.add = function (ctrl) {\n if (!current.includes(ctrl)) {\n current.push(ctrl);\n }\n };\n\n SpringRef.delete = function (ctrl) {\n const i = current.indexOf(ctrl);\n if (~i) current.splice(i, 1);\n };\n\n SpringRef.pause = function () {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(current, ctrl => ctrl.pause(...arguments));\n return this;\n };\n\n SpringRef.resume = function () {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(current, ctrl => ctrl.resume(...arguments));\n return this;\n };\n\n SpringRef.set = function (values) {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(current, ctrl => ctrl.set(values));\n };\n\n SpringRef.start = function (props) {\n const results = [];\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(current, (ctrl, i) => {\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(props)) {\n results.push(ctrl.start());\n } else {\n const update = this._getProps(props, ctrl, i);\n\n if (update) {\n results.push(ctrl.start(update));\n }\n }\n });\n return results;\n };\n\n SpringRef.stop = function () {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(current, ctrl => ctrl.stop(...arguments));\n return this;\n };\n\n SpringRef.update = function (props) {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(current, (ctrl, i) => ctrl.update(this._getProps(props, ctrl, i)));\n return this;\n };\n\n const _getProps = function _getProps(arg, ctrl, index) {\n return _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.fun(arg) ? arg(index, ctrl) : arg;\n };\n\n SpringRef._getProps = _getProps;\n return SpringRef;\n};\n\nfunction useSprings(length, props, deps) {\n const propsFn = is.fun(props) && props;\n if (propsFn && !deps) deps = [];\n const ref = useMemo(() => propsFn || arguments.length == 3 ? SpringRef() : void 0, []);\n const layoutId = useRef(0);\n const forceUpdate = useForceUpdate();\n const state = useMemo(() => ({\n ctrls: [],\n queue: [],\n\n flush(ctrl, updates) {\n const springs = getSprings(ctrl, updates);\n const canFlushSync = layoutId.current > 0 && !state.queue.length && !Object.keys(springs).some(key => !ctrl.springs[key]);\n return canFlushSync ? flushUpdateQueue(ctrl, updates) : new Promise(resolve => {\n setSprings(ctrl, springs);\n state.queue.push(() => {\n resolve(flushUpdateQueue(ctrl, updates));\n });\n forceUpdate();\n });\n }\n\n }), []);\n const ctrls = useRef([...state.ctrls]);\n const updates = [];\n const prevLength = usePrev(length) || 0;\n useMemo(() => {\n each(ctrls.current.slice(length, prevLength), ctrl => {\n detachRefs(ctrl, ref);\n ctrl.stop(true);\n });\n ctrls.current.length = length;\n declareUpdates(prevLength, length);\n }, [length]);\n useMemo(() => {\n declareUpdates(0, Math.min(prevLength, length));\n }, deps);\n\n function declareUpdates(startIndex, endIndex) {\n for (let i = startIndex; i < endIndex; i++) {\n const ctrl = ctrls.current[i] || (ctrls.current[i] = new Controller(null, state.flush));\n const update = propsFn ? propsFn(i, ctrl) : props[i];\n\n if (update) {\n updates[i] = declareUpdate(update);\n }\n }\n }\n\n const springs = ctrls.current.map((ctrl, i) => getSprings(ctrl, updates[i]));\n const context = useContext(SpringContext);\n const prevContext = usePrev(context);\n const hasContext = context !== prevContext && hasProps(context);\n useLayoutEffect(() => {\n layoutId.current++;\n state.ctrls = ctrls.current;\n const {\n queue\n } = state;\n\n if (queue.length) {\n state.queue = [];\n each(queue, cb => cb());\n }\n\n each(ctrls.current, (ctrl, i) => {\n ref == null ? void 0 : ref.add(ctrl);\n\n if (hasContext) {\n ctrl.start({\n default: context\n });\n }\n\n const update = updates[i];\n\n if (update) {\n replaceRef(ctrl, update.ref);\n\n if (ctrl.ref) {\n ctrl.queue.push(update);\n } else {\n ctrl.start(update);\n }\n }\n });\n });\n useOnce(() => () => {\n each(state.ctrls, ctrl => ctrl.stop(true));\n });\n const values = springs.map(x => _extends({}, x));\n return ref ? [values, ref] : values;\n}\n\nfunction useSpring(props, deps) {\n const isFn = is.fun(props);\n const [[values], ref] = useSprings(1, isFn ? props : [props], isFn ? deps || [] : deps);\n return isFn || arguments.length == 2 ? [values, ref] : values;\n}\n\nconst initSpringRef = () => SpringRef();\n\nconst useSpringRef = () => useState(initSpringRef)[0];\n\nfunction useTrail(length, propsArg, deps) {\n var _passedRef;\n\n const propsFn = is.fun(propsArg) && propsArg;\n if (propsFn && !deps) deps = [];\n let reverse = true;\n let passedRef = undefined;\n const result = useSprings(length, (i, ctrl) => {\n const props = propsFn ? propsFn(i, ctrl) : propsArg;\n passedRef = props.ref;\n reverse = reverse && props.reverse;\n return props;\n }, deps || [{}]);\n const ref = (_passedRef = passedRef) != null ? _passedRef : result[1];\n useLayoutEffect(() => {\n each(ref.current, (ctrl, i) => {\n const parent = ref.current[i + (reverse ? 1 : -1)];\n\n if (parent) {\n ctrl.start({\n to: parent.springs\n });\n } else {\n ctrl.start();\n }\n });\n }, deps);\n\n if (propsFn || arguments.length == 3) {\n ref['_getProps'] = (propsArg, ctrl, i) => {\n const props = is.fun(propsArg) ? propsArg(i, ctrl) : propsArg;\n\n if (props) {\n const parent = ref.current[i + (props.reverse ? 1 : -1)];\n if (parent) props.to = parent.springs;\n return props;\n }\n };\n\n return result;\n }\n\n ref['start'] = propsArg => {\n const results = [];\n each(ref.current, (ctrl, i) => {\n const props = is.fun(propsArg) ? propsArg(i, ctrl) : propsArg;\n const parent = ref.current[i + (reverse ? 1 : -1)];\n\n if (parent) {\n results.push(ctrl.start(_extends({}, props, {\n to: parent.springs\n })));\n } else {\n results.push(ctrl.start(_extends({}, props)));\n }\n });\n return results;\n };\n\n return result[0];\n}\n\nlet TransitionPhase;\n\n(function (TransitionPhase) {\n TransitionPhase[\"MOUNT\"] = \"mount\";\n TransitionPhase[\"ENTER\"] = \"enter\";\n TransitionPhase[\"UPDATE\"] = \"update\";\n TransitionPhase[\"LEAVE\"] = \"leave\";\n})(TransitionPhase || (TransitionPhase = {}));\n\nfunction useTransition(data, props, deps) {\n const propsFn = _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.fun(props) && props;\n const {\n reset,\n sort,\n trail = 0,\n expires = true,\n exitBeforeEnter = false,\n onDestroyed,\n ref: propsRef,\n config: propsConfig\n } = propsFn ? propsFn() : props;\n const ref = (0,react__WEBPACK_IMPORTED_MODULE_1__.useMemo)(() => propsFn || arguments.length == 3 ? SpringRef() : void 0, []);\n const items = (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .toArray */ .qo)(data);\n const transitions = [];\n const usedTransitions = (0,react__WEBPACK_IMPORTED_MODULE_1__.useRef)(null);\n const prevTransitions = reset ? null : usedTransitions.current;\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .useLayoutEffect */ .bt)(() => {\n usedTransitions.current = transitions;\n });\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .useOnce */ .tf)(() => {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(usedTransitions.current, t => {\n var _t$ctrl$ref;\n\n (_t$ctrl$ref = t.ctrl.ref) == null ? void 0 : _t$ctrl$ref.add(t.ctrl);\n const change = changes.get(t);\n\n if (change) {\n t.ctrl.start(change.payload);\n }\n });\n return () => {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(usedTransitions.current, t => {\n if (t.expired) {\n clearTimeout(t.expirationId);\n }\n\n detachRefs(t.ctrl, ref);\n t.ctrl.stop(true);\n });\n };\n });\n const keys = getKeys(items, propsFn ? propsFn() : props, prevTransitions);\n const expired = reset && usedTransitions.current || [];\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .useLayoutEffect */ .bt)(() => (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(expired, ({\n ctrl,\n item,\n key\n }) => {\n detachRefs(ctrl, ref);\n callProp(onDestroyed, item, key);\n }));\n const reused = [];\n if (prevTransitions) (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(prevTransitions, (t, i) => {\n if (t.expired) {\n clearTimeout(t.expirationId);\n expired.push(t);\n } else {\n i = reused[i] = keys.indexOf(t.key);\n if (~i) transitions[i] = t;\n }\n });\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(items, (item, i) => {\n if (!transitions[i]) {\n transitions[i] = {\n key: keys[i],\n item,\n phase: TransitionPhase.MOUNT,\n ctrl: new Controller()\n };\n transitions[i].ctrl.item = item;\n }\n });\n\n if (reused.length) {\n let i = -1;\n const {\n leave\n } = propsFn ? propsFn() : props;\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(reused, (keyIndex, prevIndex) => {\n const t = prevTransitions[prevIndex];\n\n if (~keyIndex) {\n i = transitions.indexOf(t);\n transitions[i] = _extends({}, t, {\n item: items[keyIndex]\n });\n } else if (leave) {\n transitions.splice(++i, 0, t);\n }\n });\n }\n\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.fun(sort)) {\n transitions.sort((a, b) => sort(a.item, b.item));\n }\n\n let delay = -trail;\n const forceUpdate = (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .useForceUpdate */ .NW)();\n const defaultProps = getDefaultProps(props);\n const changes = new Map();\n const exitingTransitions = (0,react__WEBPACK_IMPORTED_MODULE_1__.useRef)(new Map());\n const forceChange = (0,react__WEBPACK_IMPORTED_MODULE_1__.useRef)(false);\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(transitions, (t, i) => {\n const key = t.key;\n const prevPhase = t.phase;\n const p = propsFn ? propsFn() : props;\n let to;\n let phase;\n let propsDelay = callProp(p.delay || 0, key);\n\n if (prevPhase == TransitionPhase.MOUNT) {\n to = p.enter;\n phase = TransitionPhase.ENTER;\n } else {\n const isLeave = keys.indexOf(key) < 0;\n\n if (prevPhase != TransitionPhase.LEAVE) {\n if (isLeave) {\n to = p.leave;\n phase = TransitionPhase.LEAVE;\n } else if (to = p.update) {\n phase = TransitionPhase.UPDATE;\n } else return;\n } else if (!isLeave) {\n to = p.enter;\n phase = TransitionPhase.ENTER;\n } else return;\n }\n\n to = callProp(to, t.item, i);\n to = _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.obj(to) ? inferTo(to) : {\n to\n };\n\n if (!to.config) {\n const config = propsConfig || defaultProps.config;\n to.config = callProp(config, t.item, i, phase);\n }\n\n delay += trail;\n\n const payload = _extends({}, defaultProps, {\n delay: propsDelay + delay,\n ref: propsRef,\n immediate: p.immediate,\n reset: false\n }, to);\n\n if (phase == TransitionPhase.ENTER && _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(payload.from)) {\n const _p = propsFn ? propsFn() : props;\n\n const from = _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(_p.initial) || prevTransitions ? _p.from : _p.initial;\n payload.from = callProp(from, t.item, i);\n }\n\n const {\n onResolve\n } = payload;\n\n payload.onResolve = result => {\n callProp(onResolve, result);\n const transitions = usedTransitions.current;\n const t = transitions.find(t => t.key === key);\n if (!t) return;\n\n if (result.cancelled && t.phase != TransitionPhase.UPDATE) {\n return;\n }\n\n if (t.ctrl.idle) {\n const idle = transitions.every(t => t.ctrl.idle);\n\n if (t.phase == TransitionPhase.LEAVE) {\n const expiry = callProp(expires, t.item);\n\n if (expiry !== false) {\n const expiryMs = expiry === true ? 0 : expiry;\n t.expired = true;\n\n if (!idle && expiryMs > 0) {\n if (expiryMs <= 0x7fffffff) t.expirationId = setTimeout(forceUpdate, expiryMs);\n return;\n }\n }\n }\n\n if (idle && transitions.some(t => t.expired)) {\n exitingTransitions.current.delete(t);\n\n if (exitBeforeEnter) {\n forceChange.current = true;\n }\n\n forceUpdate();\n }\n }\n };\n\n const springs = getSprings(t.ctrl, payload);\n\n if (phase === TransitionPhase.LEAVE && exitBeforeEnter) {\n exitingTransitions.current.set(t, {\n phase,\n springs,\n payload\n });\n } else {\n changes.set(t, {\n phase,\n springs,\n payload\n });\n }\n });\n const context = (0,react__WEBPACK_IMPORTED_MODULE_1__.useContext)(SpringContext);\n const prevContext = (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .usePrev */ .zH)(context);\n const hasContext = context !== prevContext && hasProps(context);\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .useLayoutEffect */ .bt)(() => {\n if (hasContext) {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(transitions, t => {\n t.ctrl.start({\n default: context\n });\n });\n }\n }, [context]);\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(changes, (_, t) => {\n if (exitingTransitions.current.size) {\n const ind = transitions.findIndex(state => state.key === t.key);\n transitions.splice(ind, 1);\n }\n });\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .useLayoutEffect */ .bt)(() => {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)(exitingTransitions.current.size ? exitingTransitions.current : changes, ({\n phase,\n payload\n }, t) => {\n const {\n ctrl\n } = t;\n t.phase = phase;\n ref == null ? void 0 : ref.add(ctrl);\n\n if (hasContext && phase == TransitionPhase.ENTER) {\n ctrl.start({\n default: context\n });\n }\n\n if (payload) {\n replaceRef(ctrl, payload.ref);\n\n if (ctrl.ref && !forceChange.current) {\n ctrl.update(payload);\n } else {\n ctrl.start(payload);\n\n if (forceChange.current) {\n forceChange.current = false;\n }\n }\n }\n });\n }, reset ? void 0 : deps);\n\n const renderTransitions = render => react__WEBPACK_IMPORTED_MODULE_1__.createElement(react__WEBPACK_IMPORTED_MODULE_1__.Fragment, null, transitions.map((t, i) => {\n const {\n springs\n } = changes.get(t) || t.ctrl;\n const elem = render(_extends({}, springs), t.item, t, i);\n return elem && elem.type ? react__WEBPACK_IMPORTED_MODULE_1__.createElement(elem.type, _extends({}, elem.props, {\n key: _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.str(t.key) || _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.num(t.key) ? t.key : t.ctrl.id,\n ref: elem.ref\n })) : elem;\n }));\n\n return ref ? [renderTransitions, ref] : renderTransitions;\n}\nlet nextKey = 1;\n\nfunction getKeys(items, {\n key,\n keys = key\n}, prevTransitions) {\n if (keys === null) {\n const reused = new Set();\n return items.map(item => {\n const t = prevTransitions && prevTransitions.find(t => t.item === item && t.phase !== TransitionPhase.LEAVE && !reused.has(t));\n\n if (t) {\n reused.add(t);\n return t.key;\n }\n\n return nextKey++;\n });\n }\n\n return _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.und(keys) ? items : _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.fun(keys) ? items.map(keys) : (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .toArray */ .qo)(keys);\n}\n\nconst _excluded$2 = (/* unused pure expression or super */ null && ([\"children\"]));\nfunction Spring(_ref) {\n let {\n children\n } = _ref,\n props = _objectWithoutPropertiesLoose(_ref, _excluded$2);\n\n return children(useSpring(props));\n}\n\nconst _excluded$1 = (/* unused pure expression or super */ null && ([\"items\", \"children\"]));\nfunction Trail(_ref) {\n let {\n items,\n children\n } = _ref,\n props = _objectWithoutPropertiesLoose(_ref, _excluded$1);\n\n const trails = useTrail(items.length, props);\n return items.map((item, index) => {\n const result = children(item, index);\n return is.fun(result) ? result(trails[index]) : result;\n });\n}\n\nconst _excluded = [\"items\", \"children\"];\nfunction Transition(_ref) {\n let {\n items,\n children\n } = _ref,\n props = _objectWithoutPropertiesLoose(_ref, _excluded);\n\n return useTransition(items, props)(children);\n}\n\nclass Interpolation extends FrameValue {\n constructor(source, args) {\n super();\n this.key = void 0;\n this.idle = true;\n this.calc = void 0;\n this._active = new Set();\n this.source = source;\n this.calc = (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .createInterpolator */ .mD)(...args);\n\n const value = this._get();\n\n const nodeType = (0,_react_spring_animated__WEBPACK_IMPORTED_MODULE_2__/* .getAnimatedType */ .sb)(value);\n (0,_react_spring_animated__WEBPACK_IMPORTED_MODULE_2__/* .setAnimated */ .f3)(this, nodeType.create(value));\n }\n\n advance(_dt) {\n const value = this._get();\n\n const oldValue = this.get();\n\n if (!(0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .isEqual */ .Xy)(value, oldValue)) {\n (0,_react_spring_animated__WEBPACK_IMPORTED_MODULE_2__/* .getAnimated */ .ys)(this).setValue(value);\n\n this._onChange(value, this.idle);\n }\n\n if (!this.idle && checkIdle(this._active)) {\n becomeIdle(this);\n }\n }\n\n _get() {\n const inputs = _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__.is.arr(this.source) ? this.source.map(_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .getFluidValue */ .je) : (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .toArray */ .qo)((0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .getFluidValue */ .je)(this.source));\n return this.calc(...inputs);\n }\n\n _start() {\n if (this.idle && !checkIdle(this._active)) {\n this.idle = false;\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)((0,_react_spring_animated__WEBPACK_IMPORTED_MODULE_2__/* .getPayload */ .He)(this), node => {\n node.done = false;\n });\n\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .Globals.skipAnimation */ .OH.skipAnimation) {\n _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .raf.batchedUpdates */ .Wn.batchedUpdates(() => this.advance());\n becomeIdle(this);\n } else {\n _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .frameLoop.start */ .fT.start(this);\n }\n }\n }\n\n _attach() {\n let priority = 1;\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)((0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .toArray */ .qo)(this.source), source => {\n if ((0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .hasFluidValue */ .j$)(source)) {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .addFluidObserver */ .UI)(source, this);\n }\n\n if (isFrameValue(source)) {\n if (!source.idle) {\n this._active.add(source);\n }\n\n priority = Math.max(priority, source.priority + 1);\n }\n });\n this.priority = priority;\n\n this._start();\n }\n\n _detach() {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)((0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .toArray */ .qo)(this.source), source => {\n if ((0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .hasFluidValue */ .j$)(source)) {\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .removeFluidObserver */ .iL)(source, this);\n }\n });\n\n this._active.clear();\n\n becomeIdle(this);\n }\n\n eventObserved(event) {\n if (event.type == 'change') {\n if (event.idle) {\n this.advance();\n } else {\n this._active.add(event.parent);\n\n this._start();\n }\n } else if (event.type == 'idle') {\n this._active.delete(event.parent);\n } else if (event.type == 'priority') {\n this.priority = (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .toArray */ .qo)(this.source).reduce((highest, parent) => Math.max(highest, (isFrameValue(parent) ? parent.priority : 0) + 1), 0);\n }\n }\n\n}\n\nfunction isIdle(source) {\n return source.idle !== false;\n}\n\nfunction checkIdle(active) {\n return !active.size || Array.from(active).every(isIdle);\n}\n\nfunction becomeIdle(self) {\n if (!self.idle) {\n self.idle = true;\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .each */ .S6)((0,_react_spring_animated__WEBPACK_IMPORTED_MODULE_2__/* .getPayload */ .He)(self), node => {\n node.done = true;\n });\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .callFluidObservers */ .k0)(self, {\n type: 'idle',\n parent: self\n });\n }\n}\n\nconst to = (source, ...args) => new Interpolation(source, args);\nconst interpolate = (source, ...args) => (deprecateInterpolate(), new Interpolation(source, args));\n\n_react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .Globals.assign */ .OH.assign({\n createStringInterpolator: _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .createStringInterpolator */ .qS,\n to: (source, args) => new Interpolation(source, args)\n});\nconst update = _react_spring_shared__WEBPACK_IMPORTED_MODULE_0__/* .frameLoop.advance */ .fT.advance;\n\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"4928.js","mappings":";;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./node_modules/@react-spring/core/dist/react-spring-core.esm.js?926a"],"sourcesContent":["import { eachProp, is, toArray, isAnimatedString, Globals, getFluidValue, useLayoutEffect, each, raf, flush, FluidValue, deprecateInterpolate, callFluidObservers, frameLoop, hasFluidValue, flushCalls, isEqual, getFluidObservers, addFluidObserver, removeFluidObserver, noop, useMemoOne, deprecateDirectCall, useForceUpdate, usePrev, useOnce, createInterpolator, createStringInterpolator } from '@react-spring/shared';\nexport { Globals, createInterpolator } from '@react-spring/shared';\nimport * as React from 'react';\nimport { useContext, useMemo, useRef, useState } from 'react';\nimport { getAnimated, AnimatedValue, getPayload, AnimatedString, getAnimatedType, setAnimated } from '@react-spring/animated';\nexport * from '@react-spring/types/animated';\nexport * from '@react-spring/types/interpolation';\n\nfunction _extends() {\n  _extends = Object.assign || function (target) {\n    for (var i = 1; i < arguments.length; i++) {\n      var source = arguments[i];\n\n      for (var key in source) {\n        if (Object.prototype.hasOwnProperty.call(source, key)) {\n          target[key] = source[key];\n        }\n      }\n    }\n\n    return target;\n  };\n\n  return _extends.apply(this, arguments);\n}\n\nfunction callProp(value, ...args) {\n  return is.fun(value) ? value(...args) : value;\n}\nconst matchProp = (value, key) => value === true || !!(key && value && (is.fun(value) ? value(key) : toArray(value).includes(key)));\nconst resolveProp = (prop, key) => is.obj(prop) ? key && prop[key] : prop;\nconst getDefaultProp = (props, key) => props.default === true ? props[key] : props.default ? props.default[key] : undefined;\n\nconst noopTransform = value => value;\n\nconst getDefaultProps = (props, transform = noopTransform) => {\n  let keys = DEFAULT_PROPS;\n\n  if (props.default && props.default !== true) {\n    props = props.default;\n    keys = Object.keys(props);\n  }\n\n  const defaults = {};\n\n  for (const key of keys) {\n    const value = transform(props[key], key);\n\n    if (!is.und(value)) {\n      defaults[key] = value;\n    }\n  }\n\n  return defaults;\n};\nconst DEFAULT_PROPS = ['config', 'onProps', 'onStart', 'onChange', 'onPause', 'onResume', 'onRest'];\nconst RESERVED_PROPS = {\n  config: 1,\n  from: 1,\n  to: 1,\n  ref: 1,\n  loop: 1,\n  reset: 1,\n  pause: 1,\n  cancel: 1,\n  reverse: 1,\n  immediate: 1,\n  default: 1,\n  delay: 1,\n  onProps: 1,\n  onStart: 1,\n  onChange: 1,\n  onPause: 1,\n  onResume: 1,\n  onRest: 1,\n  onResolve: 1,\n  items: 1,\n  trail: 1,\n  sort: 1,\n  expires: 1,\n  initial: 1,\n  enter: 1,\n  update: 1,\n  leave: 1,\n  children: 1,\n  onDestroyed: 1,\n  keys: 1,\n  callId: 1,\n  parentId: 1\n};\n\nfunction getForwardProps(props) {\n  const forward = {};\n  let count = 0;\n  eachProp(props, (value, prop) => {\n    if (!RESERVED_PROPS[prop]) {\n      forward[prop] = value;\n      count++;\n    }\n  });\n\n  if (count) {\n    return forward;\n  }\n}\n\nfunction inferTo(props) {\n  const to = getForwardProps(props);\n\n  if (to) {\n    const out = {\n      to\n    };\n    eachProp(props, (val, key) => key in to || (out[key] = val));\n    return out;\n  }\n\n  return _extends({}, props);\n}\nfunction computeGoal(value) {\n  value = getFluidValue(value);\n  return is.arr(value) ? value.map(computeGoal) : isAnimatedString(value) ? Globals.createStringInterpolator({\n    range: [0, 1],\n    output: [value, value]\n  })(1) : value;\n}\nfunction hasProps(props) {\n  for (const _ in props) return true;\n\n  return false;\n}\nfunction isAsyncTo(to) {\n  return is.fun(to) || is.arr(to) && is.obj(to[0]);\n}\nfunction detachRefs(ctrl, ref) {\n  var _ctrl$ref;\n\n  (_ctrl$ref = ctrl.ref) == null ? void 0 : _ctrl$ref.delete(ctrl);\n  ref == null ? void 0 : ref.delete(ctrl);\n}\nfunction replaceRef(ctrl, ref) {\n  if (ref && ctrl.ref !== ref) {\n    var _ctrl$ref2;\n\n    (_ctrl$ref2 = ctrl.ref) == null ? void 0 : _ctrl$ref2.delete(ctrl);\n    ref.add(ctrl);\n    ctrl.ref = ref;\n  }\n}\n\nfunction useChain(refs, timeSteps, timeFrame = 1000) {\n  useLayoutEffect(() => {\n    if (timeSteps) {\n      let prevDelay = 0;\n      each(refs, (ref, i) => {\n        const controllers = ref.current;\n\n        if (controllers.length) {\n          let delay = timeFrame * timeSteps[i];\n          if (isNaN(delay)) delay = prevDelay;else prevDelay = delay;\n          each(controllers, ctrl => {\n            each(ctrl.queue, props => {\n              const memoizedDelayProp = props.delay;\n\n              props.delay = key => delay + callProp(memoizedDelayProp || 0, key);\n            });\n          });\n          ref.start();\n        }\n      });\n    } else {\n      let p = Promise.resolve();\n      each(refs, ref => {\n        const controllers = ref.current;\n\n        if (controllers.length) {\n          const queues = controllers.map(ctrl => {\n            const q = ctrl.queue;\n            ctrl.queue = [];\n            return q;\n          });\n          p = p.then(() => {\n            each(controllers, (ctrl, i) => each(queues[i] || [], update => ctrl.queue.push(update)));\n            return Promise.all(ref.start());\n          });\n        }\n      });\n    }\n  });\n}\n\nconst config = {\n  default: {\n    tension: 170,\n    friction: 26\n  },\n  gentle: {\n    tension: 120,\n    friction: 14\n  },\n  wobbly: {\n    tension: 180,\n    friction: 12\n  },\n  stiff: {\n    tension: 210,\n    friction: 20\n  },\n  slow: {\n    tension: 280,\n    friction: 60\n  },\n  molasses: {\n    tension: 280,\n    friction: 120\n  }\n};\nconst c1 = 1.70158;\nconst c2 = c1 * 1.525;\nconst c3 = c1 + 1;\nconst c4 = 2 * Math.PI / 3;\nconst c5 = 2 * Math.PI / 4.5;\n\nconst bounceOut = x => {\n  const n1 = 7.5625;\n  const d1 = 2.75;\n\n  if (x < 1 / d1) {\n    return n1 * x * x;\n  } else if (x < 2 / d1) {\n    return n1 * (x -= 1.5 / d1) * x + 0.75;\n  } else if (x < 2.5 / d1) {\n    return n1 * (x -= 2.25 / d1) * x + 0.9375;\n  } else {\n    return n1 * (x -= 2.625 / d1) * x + 0.984375;\n  }\n};\n\nconst easings = {\n  linear: x => x,\n  easeInQuad: x => x * x,\n  easeOutQuad: x => 1 - (1 - x) * (1 - x),\n  easeInOutQuad: x => x < 0.5 ? 2 * x * x : 1 - Math.pow(-2 * x + 2, 2) / 2,\n  easeInCubic: x => x * x * x,\n  easeOutCubic: x => 1 - Math.pow(1 - x, 3),\n  easeInOutCubic: x => x < 0.5 ? 4 * x * x * x : 1 - Math.pow(-2 * x + 2, 3) / 2,\n  easeInQuart: x => x * x * x * x,\n  easeOutQuart: x => 1 - Math.pow(1 - x, 4),\n  easeInOutQuart: x => x < 0.5 ? 8 * x * x * x * x : 1 - Math.pow(-2 * x + 2, 4) / 2,\n  easeInQuint: x => x * x * x * x * x,\n  easeOutQuint: x => 1 - Math.pow(1 - x, 5),\n  easeInOutQuint: x => x < 0.5 ? 16 * x * x * x * x * x : 1 - Math.pow(-2 * x + 2, 5) / 2,\n  easeInSine: x => 1 - Math.cos(x * Math.PI / 2),\n  easeOutSine: x => Math.sin(x * Math.PI / 2),\n  easeInOutSine: x => -(Math.cos(Math.PI * x) - 1) / 2,\n  easeInExpo: x => x === 0 ? 0 : Math.pow(2, 10 * x - 10),\n  easeOutExpo: x => x === 1 ? 1 : 1 - Math.pow(2, -10 * x),\n  easeInOutExpo: x => x === 0 ? 0 : x === 1 ? 1 : x < 0.5 ? Math.pow(2, 20 * x - 10) / 2 : (2 - Math.pow(2, -20 * x + 10)) / 2,\n  easeInCirc: x => 1 - Math.sqrt(1 - Math.pow(x, 2)),\n  easeOutCirc: x => Math.sqrt(1 - Math.pow(x - 1, 2)),\n  easeInOutCirc: x => x < 0.5 ? (1 - Math.sqrt(1 - Math.pow(2 * x, 2))) / 2 : (Math.sqrt(1 - Math.pow(-2 * x + 2, 2)) + 1) / 2,\n  easeInBack: x => c3 * x * x * x - c1 * x * x,\n  easeOutBack: x => 1 + c3 * Math.pow(x - 1, 3) + c1 * Math.pow(x - 1, 2),\n  easeInOutBack: x => x < 0.5 ? Math.pow(2 * x, 2) * ((c2 + 1) * 2 * x - c2) / 2 : (Math.pow(2 * x - 2, 2) * ((c2 + 1) * (x * 2 - 2) + c2) + 2) / 2,\n  easeInElastic: x => x === 0 ? 0 : x === 1 ? 1 : -Math.pow(2, 10 * x - 10) * Math.sin((x * 10 - 10.75) * c4),\n  easeOutElastic: x => x === 0 ? 0 : x === 1 ? 1 : Math.pow(2, -10 * x) * Math.sin((x * 10 - 0.75) * c4) + 1,\n  easeInOutElastic: x => x === 0 ? 0 : x === 1 ? 1 : x < 0.5 ? -(Math.pow(2, 20 * x - 10) * Math.sin((20 * x - 11.125) * c5)) / 2 : Math.pow(2, -20 * x + 10) * Math.sin((20 * x - 11.125) * c5) / 2 + 1,\n  easeInBounce: x => 1 - bounceOut(1 - x),\n  easeOutBounce: bounceOut,\n  easeInOutBounce: x => x < 0.5 ? (1 - bounceOut(1 - 2 * x)) / 2 : (1 + bounceOut(2 * x - 1)) / 2\n};\n\nconst defaults = _extends({}, config.default, {\n  mass: 1,\n  damping: 1,\n  easing: easings.linear,\n  clamp: false\n});\n\nclass AnimationConfig {\n  constructor() {\n    this.tension = void 0;\n    this.friction = void 0;\n    this.frequency = void 0;\n    this.damping = void 0;\n    this.mass = void 0;\n    this.velocity = 0;\n    this.restVelocity = void 0;\n    this.precision = void 0;\n    this.progress = void 0;\n    this.duration = void 0;\n    this.easing = void 0;\n    this.clamp = void 0;\n    this.bounce = void 0;\n    this.decay = void 0;\n    this.round = void 0;\n    Object.assign(this, defaults);\n  }\n\n}\nfunction mergeConfig(config, newConfig, defaultConfig) {\n  if (defaultConfig) {\n    defaultConfig = _extends({}, defaultConfig);\n    sanitizeConfig(defaultConfig, newConfig);\n    newConfig = _extends({}, defaultConfig, newConfig);\n  }\n\n  sanitizeConfig(config, newConfig);\n  Object.assign(config, newConfig);\n\n  for (const key in defaults) {\n    if (config[key] == null) {\n      config[key] = defaults[key];\n    }\n  }\n\n  let {\n    mass,\n    frequency,\n    damping\n  } = config;\n\n  if (!is.und(frequency)) {\n    if (frequency < 0.01) frequency = 0.01;\n    if (damping < 0) damping = 0;\n    config.tension = Math.pow(2 * Math.PI / frequency, 2) * mass;\n    config.friction = 4 * Math.PI * damping * mass / frequency;\n  }\n\n  return config;\n}\n\nfunction sanitizeConfig(config, props) {\n  if (!is.und(props.decay)) {\n    config.duration = undefined;\n  } else {\n    const isTensionConfig = !is.und(props.tension) || !is.und(props.friction);\n\n    if (isTensionConfig || !is.und(props.frequency) || !is.und(props.damping) || !is.und(props.mass)) {\n      config.duration = undefined;\n      config.decay = undefined;\n    }\n\n    if (isTensionConfig) {\n      config.frequency = undefined;\n    }\n  }\n}\n\nconst emptyArray = [];\nclass Animation {\n  constructor() {\n    this.changed = false;\n    this.values = emptyArray;\n    this.toValues = null;\n    this.fromValues = emptyArray;\n    this.to = void 0;\n    this.from = void 0;\n    this.config = new AnimationConfig();\n    this.immediate = false;\n  }\n\n}\n\nfunction scheduleProps(callId, {\n  key,\n  props,\n  defaultProps,\n  state,\n  actions\n}) {\n  return new Promise((resolve, reject) => {\n    var _props$cancel;\n\n    let delay;\n    let timeout;\n    let cancel = matchProp((_props$cancel = props.cancel) != null ? _props$cancel : defaultProps == null ? void 0 : defaultProps.cancel, key);\n\n    if (cancel) {\n      onStart();\n    } else {\n      if (!is.und(props.pause)) {\n        state.paused = matchProp(props.pause, key);\n      }\n\n      let pause = defaultProps == null ? void 0 : defaultProps.pause;\n\n      if (pause !== true) {\n        pause = state.paused || matchProp(pause, key);\n      }\n\n      delay = callProp(props.delay || 0, key);\n\n      if (pause) {\n        state.resumeQueue.add(onResume);\n        actions.pause();\n      } else {\n        actions.resume();\n        onResume();\n      }\n    }\n\n    function onPause() {\n      state.resumeQueue.add(onResume);\n      state.timeouts.delete(timeout);\n      timeout.cancel();\n      delay = timeout.time - raf.now();\n    }\n\n    function onResume() {\n      if (delay > 0 && !Globals.skipAnimation) {\n        state.delayed = true;\n        timeout = raf.setTimeout(onStart, delay);\n        state.pauseQueue.add(onPause);\n        state.timeouts.add(timeout);\n      } else {\n        onStart();\n      }\n    }\n\n    function onStart() {\n      if (state.delayed) {\n        state.delayed = false;\n      }\n\n      state.pauseQueue.delete(onPause);\n      state.timeouts.delete(timeout);\n\n      if (callId <= (state.cancelId || 0)) {\n        cancel = true;\n      }\n\n      try {\n        actions.start(_extends({}, props, {\n          callId,\n          cancel\n        }), resolve);\n      } catch (err) {\n        reject(err);\n      }\n    }\n  });\n}\n\nconst getCombinedResult = (target, results) => results.length == 1 ? results[0] : results.some(result => result.cancelled) ? getCancelledResult(target.get()) : results.every(result => result.noop) ? getNoopResult(target.get()) : getFinishedResult(target.get(), results.every(result => result.finished));\nconst getNoopResult = value => ({\n  value,\n  noop: true,\n  finished: true,\n  cancelled: false\n});\nconst getFinishedResult = (value, finished, cancelled = false) => ({\n  value,\n  finished,\n  cancelled\n});\nconst getCancelledResult = value => ({\n  value,\n  cancelled: true,\n  finished: false\n});\n\nfunction runAsync(to, props, state, target) {\n  const {\n    callId,\n    parentId,\n    onRest\n  } = props;\n  const {\n    asyncTo: prevTo,\n    promise: prevPromise\n  } = state;\n\n  if (!parentId && to === prevTo && !props.reset) {\n    return prevPromise;\n  }\n\n  return state.promise = (async () => {\n    state.asyncId = callId;\n    state.asyncTo = to;\n    const defaultProps = getDefaultProps(props, (value, key) => key === 'onRest' ? undefined : value);\n    let preventBail;\n    let bail;\n    const bailPromise = new Promise((resolve, reject) => (preventBail = resolve, bail = reject));\n\n    const bailIfEnded = bailSignal => {\n      const bailResult = callId <= (state.cancelId || 0) && getCancelledResult(target) || callId !== state.asyncId && getFinishedResult(target, false);\n\n      if (bailResult) {\n        bailSignal.result = bailResult;\n        bail(bailSignal);\n        throw bailSignal;\n      }\n    };\n\n    const animate = (arg1, arg2) => {\n      const bailSignal = new BailSignal();\n      const skipAnimationSignal = new SkipAniamtionSignal();\n      return (async () => {\n        if (Globals.skipAnimation) {\n          stopAsync(state);\n          skipAnimationSignal.result = getFinishedResult(target, false);\n          bail(skipAnimationSignal);\n          throw skipAnimationSignal;\n        }\n\n        bailIfEnded(bailSignal);\n        const props = is.obj(arg1) ? _extends({}, arg1) : _extends({}, arg2, {\n          to: arg1\n        });\n        props.parentId = callId;\n        eachProp(defaultProps, (value, key) => {\n          if (is.und(props[key])) {\n            props[key] = value;\n          }\n        });\n        const result = await target.start(props);\n        bailIfEnded(bailSignal);\n\n        if (state.paused) {\n          await new Promise(resume => {\n            state.resumeQueue.add(resume);\n          });\n        }\n\n        return result;\n      })();\n    };\n\n    let result;\n\n    if (Globals.skipAnimation) {\n      stopAsync(state);\n      return getFinishedResult(target, false);\n    }\n\n    try {\n      let animating;\n\n      if (is.arr(to)) {\n        animating = (async queue => {\n          for (const props of queue) {\n            await animate(props);\n          }\n        })(to);\n      } else {\n          animating = Promise.resolve(to(animate, target.stop.bind(target)));\n        }\n\n      await Promise.all([animating.then(preventBail), bailPromise]);\n      result = getFinishedResult(target.get(), true, false);\n    } catch (err) {\n      if (err instanceof BailSignal) {\n        result = err.result;\n      } else if (err instanceof SkipAniamtionSignal) {\n        result = err.result;\n      } else {\n        throw err;\n      }\n    } finally {\n      if (callId == state.asyncId) {\n        state.asyncId = parentId;\n        state.asyncTo = parentId ? prevTo : undefined;\n        state.promise = parentId ? prevPromise : undefined;\n      }\n    }\n\n    if (is.fun(onRest)) {\n      raf.batchedUpdates(() => {\n        onRest(result, target, target.item);\n      });\n    }\n\n    return result;\n  })();\n}\nfunction stopAsync(state, cancelId) {\n  flush(state.timeouts, t => t.cancel());\n  state.pauseQueue.clear();\n  state.resumeQueue.clear();\n  state.asyncId = state.asyncTo = state.promise = undefined;\n  if (cancelId) state.cancelId = cancelId;\n}\nclass BailSignal extends Error {\n  constructor() {\n    super('An async animation has been interrupted. You see this error because you ' + 'forgot to use `await` or `.catch(...)` on its returned promise.');\n    this.result = void 0;\n  }\n\n}\nclass SkipAniamtionSignal extends Error {\n  constructor() {\n    super('SkipAnimationSignal');\n    this.result = void 0;\n  }\n\n}\n\nconst isFrameValue = value => value instanceof FrameValue;\nlet nextId$1 = 1;\nclass FrameValue extends FluidValue {\n  constructor(...args) {\n    super(...args);\n    this.id = nextId$1++;\n    this.key = void 0;\n    this._priority = 0;\n  }\n\n  get priority() {\n    return this._priority;\n  }\n\n  set priority(priority) {\n    if (this._priority != priority) {\n      this._priority = priority;\n\n      this._onPriorityChange(priority);\n    }\n  }\n\n  get() {\n    const node = getAnimated(this);\n    return node && node.getValue();\n  }\n\n  to(...args) {\n    return Globals.to(this, args);\n  }\n\n  interpolate(...args) {\n    deprecateInterpolate();\n    return Globals.to(this, args);\n  }\n\n  toJSON() {\n    return this.get();\n  }\n\n  observerAdded(count) {\n    if (count == 1) this._attach();\n  }\n\n  observerRemoved(count) {\n    if (count == 0) this._detach();\n  }\n\n  _attach() {}\n\n  _detach() {}\n\n  _onChange(value, idle = false) {\n    callFluidObservers(this, {\n      type: 'change',\n      parent: this,\n      value,\n      idle\n    });\n  }\n\n  _onPriorityChange(priority) {\n    if (!this.idle) {\n      frameLoop.sort(this);\n    }\n\n    callFluidObservers(this, {\n      type: 'priority',\n      parent: this,\n      priority\n    });\n  }\n\n}\n\nconst $P = Symbol.for('SpringPhase');\nconst HAS_ANIMATED = 1;\nconst IS_ANIMATING = 2;\nconst IS_PAUSED = 4;\nconst hasAnimated = target => (target[$P] & HAS_ANIMATED) > 0;\nconst isAnimating = target => (target[$P] & IS_ANIMATING) > 0;\nconst isPaused = target => (target[$P] & IS_PAUSED) > 0;\nconst setActiveBit = (target, active) => active ? target[$P] |= IS_ANIMATING | HAS_ANIMATED : target[$P] &= ~IS_ANIMATING;\nconst setPausedBit = (target, paused) => paused ? target[$P] |= IS_PAUSED : target[$P] &= ~IS_PAUSED;\n\nclass SpringValue extends FrameValue {\n  constructor(arg1, arg2) {\n    super();\n    this.key = void 0;\n    this.animation = new Animation();\n    this.queue = void 0;\n    this.defaultProps = {};\n    this._state = {\n      paused: false,\n      delayed: false,\n      pauseQueue: new Set(),\n      resumeQueue: new Set(),\n      timeouts: new Set()\n    };\n    this._pendingCalls = new Set();\n    this._lastCallId = 0;\n    this._lastToId = 0;\n    this._memoizedDuration = 0;\n\n    if (!is.und(arg1) || !is.und(arg2)) {\n      const props = is.obj(arg1) ? _extends({}, arg1) : _extends({}, arg2, {\n        from: arg1\n      });\n\n      if (is.und(props.default)) {\n        props.default = true;\n      }\n\n      this.start(props);\n    }\n  }\n\n  get idle() {\n    return !(isAnimating(this) || this._state.asyncTo) || isPaused(this);\n  }\n\n  get goal() {\n    return getFluidValue(this.animation.to);\n  }\n\n  get velocity() {\n    const node = getAnimated(this);\n    return node instanceof AnimatedValue ? node.lastVelocity || 0 : node.getPayload().map(node => node.lastVelocity || 0);\n  }\n\n  get hasAnimated() {\n    return hasAnimated(this);\n  }\n\n  get isAnimating() {\n    return isAnimating(this);\n  }\n\n  get isPaused() {\n    return isPaused(this);\n  }\n\n  get isDelayed() {\n    return this._state.delayed;\n  }\n\n  advance(dt) {\n    let idle = true;\n    let changed = false;\n    const anim = this.animation;\n    let {\n      config,\n      toValues\n    } = anim;\n    const payload = getPayload(anim.to);\n\n    if (!payload && hasFluidValue(anim.to)) {\n      toValues = toArray(getFluidValue(anim.to));\n    }\n\n    anim.values.forEach((node, i) => {\n      if (node.done) return;\n      const to = node.constructor == AnimatedString ? 1 : payload ? payload[i].lastPosition : toValues[i];\n      let finished = anim.immediate;\n      let position = to;\n\n      if (!finished) {\n        position = node.lastPosition;\n\n        if (config.tension <= 0) {\n          node.done = true;\n          return;\n        }\n\n        let elapsed = node.elapsedTime += dt;\n        const from = anim.fromValues[i];\n        const v0 = node.v0 != null ? node.v0 : node.v0 = is.arr(config.velocity) ? config.velocity[i] : config.velocity;\n        let velocity;\n\n        if (!is.und(config.duration)) {\n          let p = 1;\n\n          if (config.duration > 0) {\n            if (this._memoizedDuration !== config.duration) {\n              this._memoizedDuration = config.duration;\n\n              if (node.durationProgress > 0) {\n                node.elapsedTime = config.duration * node.durationProgress;\n                elapsed = node.elapsedTime += dt;\n              }\n            }\n\n            p = (config.progress || 0) + elapsed / this._memoizedDuration;\n            p = p > 1 ? 1 : p < 0 ? 0 : p;\n            node.durationProgress = p;\n          }\n\n          position = from + config.easing(p) * (to - from);\n          velocity = (position - node.lastPosition) / dt;\n          finished = p == 1;\n        } else if (config.decay) {\n            const decay = config.decay === true ? 0.998 : config.decay;\n            const e = Math.exp(-(1 - decay) * elapsed);\n            position = from + v0 / (1 - decay) * (1 - e);\n            finished = Math.abs(node.lastPosition - position) < 0.1;\n            velocity = v0 * e;\n          } else {\n              velocity = node.lastVelocity == null ? v0 : node.lastVelocity;\n              const precision = config.precision || (from == to ? 0.005 : Math.min(1, Math.abs(to - from) * 0.001));\n              const restVelocity = config.restVelocity || precision / 10;\n              const bounceFactor = config.clamp ? 0 : config.bounce;\n              const canBounce = !is.und(bounceFactor);\n              const isGrowing = from == to ? node.v0 > 0 : from < to;\n              let isMoving;\n              let isBouncing = false;\n              const step = 1;\n              const numSteps = Math.ceil(dt / step);\n\n              for (let n = 0; n < numSteps; ++n) {\n                isMoving = Math.abs(velocity) > restVelocity;\n\n                if (!isMoving) {\n                  finished = Math.abs(to - position) <= precision;\n\n                  if (finished) {\n                    break;\n                  }\n                }\n\n                if (canBounce) {\n                  isBouncing = position == to || position > to == isGrowing;\n\n                  if (isBouncing) {\n                    velocity = -velocity * bounceFactor;\n                    position = to;\n                  }\n                }\n\n                const springForce = -config.tension * 0.000001 * (position - to);\n                const dampingForce = -config.friction * 0.001 * velocity;\n                const acceleration = (springForce + dampingForce) / config.mass;\n                velocity = velocity + acceleration * step;\n                position = position + velocity * step;\n              }\n            }\n\n        node.lastVelocity = velocity;\n\n        if (Number.isNaN(position)) {\n          console.warn(`Got NaN while animating:`, this);\n          finished = true;\n        }\n      }\n\n      if (payload && !payload[i].done) {\n        finished = false;\n      }\n\n      if (finished) {\n        node.done = true;\n      } else {\n        idle = false;\n      }\n\n      if (node.setValue(position, config.round)) {\n        changed = true;\n      }\n    });\n    const node = getAnimated(this);\n    const currVal = node.getValue();\n\n    if (idle) {\n      const finalVal = getFluidValue(anim.to);\n\n      if ((currVal !== finalVal || changed) && !config.decay) {\n        node.setValue(finalVal);\n\n        this._onChange(finalVal);\n      } else if (changed && config.decay) {\n        this._onChange(currVal);\n      }\n\n      this._stop();\n    } else if (changed) {\n      this._onChange(currVal);\n    }\n  }\n\n  set(value) {\n    raf.batchedUpdates(() => {\n      this._stop();\n\n      this._focus(value);\n\n      this._set(value);\n    });\n    return this;\n  }\n\n  pause() {\n    this._update({\n      pause: true\n    });\n  }\n\n  resume() {\n    this._update({\n      pause: false\n    });\n  }\n\n  finish() {\n    if (isAnimating(this)) {\n      const {\n        to,\n        config\n      } = this.animation;\n      raf.batchedUpdates(() => {\n        this._onStart();\n\n        if (!config.decay) {\n          this._set(to, false);\n        }\n\n        this._stop();\n      });\n    }\n\n    return this;\n  }\n\n  update(props) {\n    const queue = this.queue || (this.queue = []);\n    queue.push(props);\n    return this;\n  }\n\n  start(to, arg2) {\n    let queue;\n\n    if (!is.und(to)) {\n      queue = [is.obj(to) ? to : _extends({}, arg2, {\n        to\n      })];\n    } else {\n      queue = this.queue || [];\n      this.queue = [];\n    }\n\n    return Promise.all(queue.map(props => {\n      const up = this._update(props);\n\n      return up;\n    })).then(results => getCombinedResult(this, results));\n  }\n\n  stop(cancel) {\n    const {\n      to\n    } = this.animation;\n\n    this._focus(this.get());\n\n    stopAsync(this._state, cancel && this._lastCallId);\n    raf.batchedUpdates(() => this._stop(to, cancel));\n    return this;\n  }\n\n  reset() {\n    this._update({\n      reset: true\n    });\n  }\n\n  eventObserved(event) {\n    if (event.type == 'change') {\n      this._start();\n    } else if (event.type == 'priority') {\n      this.priority = event.priority + 1;\n    }\n  }\n\n  _prepareNode(props) {\n    const key = this.key || '';\n    let {\n      to,\n      from\n    } = props;\n    to = is.obj(to) ? to[key] : to;\n\n    if (to == null || isAsyncTo(to)) {\n      to = undefined;\n    }\n\n    from = is.obj(from) ? from[key] : from;\n\n    if (from == null) {\n      from = undefined;\n    }\n\n    const range = {\n      to,\n      from\n    };\n\n    if (!hasAnimated(this)) {\n      if (props.reverse) [to, from] = [from, to];\n      from = getFluidValue(from);\n\n      if (!is.und(from)) {\n        this._set(from);\n      } else if (!getAnimated(this)) {\n          this._set(to);\n        }\n    }\n\n    return range;\n  }\n\n  _update(_ref, isLoop) {\n    let props = _extends({}, _ref);\n\n    const {\n      key,\n      defaultProps\n    } = this;\n    if (props.default) Object.assign(defaultProps, getDefaultProps(props, (value, prop) => /^on/.test(prop) ? resolveProp(value, key) : value));\n    mergeActiveFn(this, props, 'onProps');\n    sendEvent(this, 'onProps', props, this);\n\n    const range = this._prepareNode(props);\n\n    if (Object.isFrozen(this)) {\n      throw Error('Cannot animate a `SpringValue` object that is frozen. ' + 'Did you forget to pass your component to `animated(...)` before animating its props?');\n    }\n\n    const state = this._state;\n    return scheduleProps(++this._lastCallId, {\n      key,\n      props,\n      defaultProps,\n      state,\n      actions: {\n        pause: () => {\n          if (!isPaused(this)) {\n            setPausedBit(this, true);\n            flushCalls(state.pauseQueue);\n            sendEvent(this, 'onPause', getFinishedResult(this, checkFinished(this, this.animation.to)), this);\n          }\n        },\n        resume: () => {\n          if (isPaused(this)) {\n            setPausedBit(this, false);\n\n            if (isAnimating(this)) {\n              this._resume();\n            }\n\n            flushCalls(state.resumeQueue);\n            sendEvent(this, 'onResume', getFinishedResult(this, checkFinished(this, this.animation.to)), this);\n          }\n        },\n        start: this._merge.bind(this, range)\n      }\n    }).then(result => {\n      if (props.loop && result.finished && !(isLoop && result.noop)) {\n        const nextProps = createLoopUpdate(props);\n\n        if (nextProps) {\n          return this._update(nextProps, true);\n        }\n      }\n\n      return result;\n    });\n  }\n\n  _merge(range, props, resolve) {\n    if (props.cancel) {\n      this.stop(true);\n      return resolve(getCancelledResult(this));\n    }\n\n    const hasToProp = !is.und(range.to);\n    const hasFromProp = !is.und(range.from);\n\n    if (hasToProp || hasFromProp) {\n      if (props.callId > this._lastToId) {\n        this._lastToId = props.callId;\n      } else {\n        return resolve(getCancelledResult(this));\n      }\n    }\n\n    const {\n      key,\n      defaultProps,\n      animation: anim\n    } = this;\n    const {\n      to: prevTo,\n      from: prevFrom\n    } = anim;\n    let {\n      to = prevTo,\n      from = prevFrom\n    } = range;\n\n    if (hasFromProp && !hasToProp && (!props.default || is.und(to))) {\n      to = from;\n    }\n\n    if (props.reverse) [to, from] = [from, to];\n    const hasFromChanged = !isEqual(from, prevFrom);\n\n    if (hasFromChanged) {\n      anim.from = from;\n    }\n\n    from = getFluidValue(from);\n    const hasToChanged = !isEqual(to, prevTo);\n\n    if (hasToChanged) {\n      this._focus(to);\n    }\n\n    const hasAsyncTo = isAsyncTo(props.to);\n    const {\n      config\n    } = anim;\n    const {\n      decay,\n      velocity\n    } = config;\n\n    if (hasToProp || hasFromProp) {\n      config.velocity = 0;\n    }\n\n    if (props.config && !hasAsyncTo) {\n      mergeConfig(config, callProp(props.config, key), props.config !== defaultProps.config ? callProp(defaultProps.config, key) : void 0);\n    }\n\n    let node = getAnimated(this);\n\n    if (!node || is.und(to)) {\n      return resolve(getFinishedResult(this, true));\n    }\n\n    const reset = is.und(props.reset) ? hasFromProp && !props.default : !is.und(from) && matchProp(props.reset, key);\n    const value = reset ? from : this.get();\n    const goal = computeGoal(to);\n    const isAnimatable = is.num(goal) || is.arr(goal) || isAnimatedString(goal);\n    const immediate = !hasAsyncTo && (!isAnimatable || matchProp(defaultProps.immediate || props.immediate, key));\n\n    if (hasToChanged) {\n      const nodeType = getAnimatedType(to);\n\n      if (nodeType !== node.constructor) {\n        if (immediate) {\n          node = this._set(goal);\n        } else throw Error(`Cannot animate between ${node.constructor.name} and ${nodeType.name}, as the \"to\" prop suggests`);\n      }\n    }\n\n    const goalType = node.constructor;\n    let started = hasFluidValue(to);\n    let finished = false;\n\n    if (!started) {\n      const hasValueChanged = reset || !hasAnimated(this) && hasFromChanged;\n\n      if (hasToChanged || hasValueChanged) {\n        finished = isEqual(computeGoal(value), goal);\n        started = !finished;\n      }\n\n      if (!isEqual(anim.immediate, immediate) && !immediate || !isEqual(config.decay, decay) || !isEqual(config.velocity, velocity)) {\n        started = true;\n      }\n    }\n\n    if (finished && isAnimating(this)) {\n      if (anim.changed && !reset) {\n        started = true;\n      } else if (!started) {\n          this._stop(prevTo);\n        }\n    }\n\n    if (!hasAsyncTo) {\n      if (started || hasFluidValue(prevTo)) {\n        anim.values = node.getPayload();\n        anim.toValues = hasFluidValue(to) ? null : goalType == AnimatedString ? [1] : toArray(goal);\n      }\n\n      if (anim.immediate != immediate) {\n        anim.immediate = immediate;\n\n        if (!immediate && !reset) {\n          this._set(prevTo);\n        }\n      }\n\n      if (started) {\n        const {\n          onRest\n        } = anim;\n        each(ACTIVE_EVENTS, type => mergeActiveFn(this, props, type));\n        const result = getFinishedResult(this, checkFinished(this, prevTo));\n        flushCalls(this._pendingCalls, result);\n\n        this._pendingCalls.add(resolve);\n\n        if (anim.changed) raf.batchedUpdates(() => {\n          anim.changed = !reset;\n          onRest == null ? void 0 : onRest(result, this);\n\n          if (reset) {\n            callProp(defaultProps.onRest, result);\n          } else {\n              anim.onStart == null ? void 0 : anim.onStart(result, this);\n            }\n        });\n      }\n    }\n\n    if (reset) {\n      this._set(value);\n    }\n\n    if (hasAsyncTo) {\n      resolve(runAsync(props.to, props, this._state, this));\n    } else if (started) {\n        this._start();\n      } else if (isAnimating(this) && !hasToChanged) {\n          this._pendingCalls.add(resolve);\n        } else {\n            resolve(getNoopResult(value));\n          }\n  }\n\n  _focus(value) {\n    const anim = this.animation;\n\n    if (value !== anim.to) {\n      if (getFluidObservers(this)) {\n        this._detach();\n      }\n\n      anim.to = value;\n\n      if (getFluidObservers(this)) {\n        this._attach();\n      }\n    }\n  }\n\n  _attach() {\n    let priority = 0;\n    const {\n      to\n    } = this.animation;\n\n    if (hasFluidValue(to)) {\n      addFluidObserver(to, this);\n\n      if (isFrameValue(to)) {\n        priority = to.priority + 1;\n      }\n    }\n\n    this.priority = priority;\n  }\n\n  _detach() {\n    const {\n      to\n    } = this.animation;\n\n    if (hasFluidValue(to)) {\n      removeFluidObserver(to, this);\n    }\n  }\n\n  _set(arg, idle = true) {\n    const value = getFluidValue(arg);\n\n    if (!is.und(value)) {\n      const oldNode = getAnimated(this);\n\n      if (!oldNode || !isEqual(value, oldNode.getValue())) {\n        const nodeType = getAnimatedType(value);\n\n        if (!oldNode || oldNode.constructor != nodeType) {\n          setAnimated(this, nodeType.create(value));\n        } else {\n          oldNode.setValue(value);\n        }\n\n        if (oldNode) {\n          raf.batchedUpdates(() => {\n            this._onChange(value, idle);\n          });\n        }\n      }\n    }\n\n    return getAnimated(this);\n  }\n\n  _onStart() {\n    const anim = this.animation;\n\n    if (!anim.changed) {\n      anim.changed = true;\n      sendEvent(this, 'onStart', getFinishedResult(this, checkFinished(this, anim.to)), this);\n    }\n  }\n\n  _onChange(value, idle) {\n    if (!idle) {\n      this._onStart();\n\n      callProp(this.animation.onChange, value, this);\n    }\n\n    callProp(this.defaultProps.onChange, value, this);\n\n    super._onChange(value, idle);\n  }\n\n  _start() {\n    const anim = this.animation;\n    getAnimated(this).reset(getFluidValue(anim.to));\n\n    if (!anim.immediate) {\n      anim.fromValues = anim.values.map(node => node.lastPosition);\n    }\n\n    if (!isAnimating(this)) {\n      setActiveBit(this, true);\n\n      if (!isPaused(this)) {\n        this._resume();\n      }\n    }\n  }\n\n  _resume() {\n    if (Globals.skipAnimation) {\n      this.finish();\n    } else {\n      frameLoop.start(this);\n    }\n  }\n\n  _stop(goal, cancel) {\n    if (isAnimating(this)) {\n      setActiveBit(this, false);\n      const anim = this.animation;\n      each(anim.values, node => {\n        node.done = true;\n      });\n\n      if (anim.toValues) {\n        anim.onChange = anim.onPause = anim.onResume = undefined;\n      }\n\n      callFluidObservers(this, {\n        type: 'idle',\n        parent: this\n      });\n      const result = cancel ? getCancelledResult(this.get()) : getFinishedResult(this.get(), checkFinished(this, goal != null ? goal : anim.to));\n      flushCalls(this._pendingCalls, result);\n\n      if (anim.changed) {\n        anim.changed = false;\n        sendEvent(this, 'onRest', result, this);\n      }\n    }\n  }\n\n}\n\nfunction checkFinished(target, to) {\n  const goal = computeGoal(to);\n  const value = computeGoal(target.get());\n  return isEqual(value, goal);\n}\n\nfunction createLoopUpdate(props, loop = props.loop, to = props.to) {\n  let loopRet = callProp(loop);\n\n  if (loopRet) {\n    const overrides = loopRet !== true && inferTo(loopRet);\n    const reverse = (overrides || props).reverse;\n    const reset = !overrides || overrides.reset;\n    return createUpdate(_extends({}, props, {\n      loop,\n      default: false,\n      pause: undefined,\n      to: !reverse || isAsyncTo(to) ? to : undefined,\n      from: reset ? props.from : undefined,\n      reset\n    }, overrides));\n  }\n}\nfunction createUpdate(props) {\n  const {\n    to,\n    from\n  } = props = inferTo(props);\n  const keys = new Set();\n  if (is.obj(to)) findDefined(to, keys);\n  if (is.obj(from)) findDefined(from, keys);\n  props.keys = keys.size ? Array.from(keys) : null;\n  return props;\n}\nfunction declareUpdate(props) {\n  const update = createUpdate(props);\n\n  if (is.und(update.default)) {\n    update.default = getDefaultProps(update);\n  }\n\n  return update;\n}\n\nfunction findDefined(values, keys) {\n  eachProp(values, (value, key) => value != null && keys.add(key));\n}\n\nconst ACTIVE_EVENTS = ['onStart', 'onRest', 'onChange', 'onPause', 'onResume'];\n\nfunction mergeActiveFn(target, props, type) {\n  target.animation[type] = props[type] !== getDefaultProp(props, type) ? resolveProp(props[type], target.key) : undefined;\n}\n\nfunction sendEvent(target, type, ...args) {\n  var _target$animation$typ, _target$animation, _target$defaultProps$, _target$defaultProps;\n\n  (_target$animation$typ = (_target$animation = target.animation)[type]) == null ? void 0 : _target$animation$typ.call(_target$animation, ...args);\n  (_target$defaultProps$ = (_target$defaultProps = target.defaultProps)[type]) == null ? void 0 : _target$defaultProps$.call(_target$defaultProps, ...args);\n}\n\nconst BATCHED_EVENTS = ['onStart', 'onChange', 'onRest'];\nlet nextId = 1;\nclass Controller {\n  constructor(props, flush) {\n    this.id = nextId++;\n    this.springs = {};\n    this.queue = [];\n    this.ref = void 0;\n    this._flush = void 0;\n    this._initialProps = void 0;\n    this._lastAsyncId = 0;\n    this._active = new Set();\n    this._changed = new Set();\n    this._started = false;\n    this._item = void 0;\n    this._state = {\n      paused: false,\n      pauseQueue: new Set(),\n      resumeQueue: new Set(),\n      timeouts: new Set()\n    };\n    this._events = {\n      onStart: new Map(),\n      onChange: new Map(),\n      onRest: new Map()\n    };\n    this._onFrame = this._onFrame.bind(this);\n\n    if (flush) {\n      this._flush = flush;\n    }\n\n    if (props) {\n      this.start(_extends({\n        default: true\n      }, props));\n    }\n  }\n\n  get idle() {\n    return !this._state.asyncTo && Object.values(this.springs).every(spring => {\n      return spring.idle && !spring.isDelayed && !spring.isPaused;\n    });\n  }\n\n  get item() {\n    return this._item;\n  }\n\n  set item(item) {\n    this._item = item;\n  }\n\n  get() {\n    const values = {};\n    this.each((spring, key) => values[key] = spring.get());\n    return values;\n  }\n\n  set(values) {\n    for (const key in values) {\n      const value = values[key];\n\n      if (!is.und(value)) {\n        this.springs[key].set(value);\n      }\n    }\n  }\n\n  update(props) {\n    if (props) {\n      this.queue.push(createUpdate(props));\n    }\n\n    return this;\n  }\n\n  start(props) {\n    let {\n      queue\n    } = this;\n\n    if (props) {\n      queue = toArray(props).map(createUpdate);\n    } else {\n      this.queue = [];\n    }\n\n    if (this._flush) {\n      return this._flush(this, queue);\n    }\n\n    prepareKeys(this, queue);\n    return flushUpdateQueue(this, queue);\n  }\n\n  stop(arg, keys) {\n    if (arg !== !!arg) {\n      keys = arg;\n    }\n\n    if (keys) {\n      const springs = this.springs;\n      each(toArray(keys), key => springs[key].stop(!!arg));\n    } else {\n      stopAsync(this._state, this._lastAsyncId);\n      this.each(spring => spring.stop(!!arg));\n    }\n\n    return this;\n  }\n\n  pause(keys) {\n    if (is.und(keys)) {\n      this.start({\n        pause: true\n      });\n    } else {\n      const springs = this.springs;\n      each(toArray(keys), key => springs[key].pause());\n    }\n\n    return this;\n  }\n\n  resume(keys) {\n    if (is.und(keys)) {\n      this.start({\n        pause: false\n      });\n    } else {\n      const springs = this.springs;\n      each(toArray(keys), key => springs[key].resume());\n    }\n\n    return this;\n  }\n\n  each(iterator) {\n    eachProp(this.springs, iterator);\n  }\n\n  _onFrame() {\n    const {\n      onStart,\n      onChange,\n      onRest\n    } = this._events;\n    const active = this._active.size > 0;\n    const changed = this._changed.size > 0;\n\n    if (active && !this._started || changed && !this._started) {\n      this._started = true;\n      flush(onStart, ([onStart, result]) => {\n        result.value = this.get();\n        onStart(result, this, this._item);\n      });\n    }\n\n    const idle = !active && this._started;\n    const values = changed || idle && onRest.size ? this.get() : null;\n\n    if (changed && onChange.size) {\n      flush(onChange, ([onChange, result]) => {\n        result.value = values;\n        onChange(result, this, this._item);\n      });\n    }\n\n    if (idle) {\n      this._started = false;\n      flush(onRest, ([onRest, result]) => {\n        result.value = values;\n        onRest(result, this, this._item);\n      });\n    }\n  }\n\n  eventObserved(event) {\n    if (event.type == 'change') {\n      this._changed.add(event.parent);\n\n      if (!event.idle) {\n        this._active.add(event.parent);\n      }\n    } else if (event.type == 'idle') {\n      this._active.delete(event.parent);\n    } else return;\n\n    raf.onFrame(this._onFrame);\n  }\n\n}\nfunction flushUpdateQueue(ctrl, queue) {\n  return Promise.all(queue.map(props => flushUpdate(ctrl, props))).then(results => getCombinedResult(ctrl, results));\n}\nasync function flushUpdate(ctrl, props, isLoop) {\n  const {\n    keys,\n    to,\n    from,\n    loop,\n    onRest,\n    onResolve\n  } = props;\n  const defaults = is.obj(props.default) && props.default;\n\n  if (loop) {\n    props.loop = false;\n  }\n\n  if (to === false) props.to = null;\n  if (from === false) props.from = null;\n  const asyncTo = is.arr(to) || is.fun(to) ? to : undefined;\n\n  if (asyncTo) {\n    props.to = undefined;\n    props.onRest = undefined;\n\n    if (defaults) {\n      defaults.onRest = undefined;\n    }\n  } else {\n      each(BATCHED_EVENTS, key => {\n        const handler = props[key];\n\n        if (is.fun(handler)) {\n          const queue = ctrl['_events'][key];\n\n          props[key] = ({\n            finished,\n            cancelled\n          }) => {\n            const result = queue.get(handler);\n\n            if (result) {\n              if (!finished) result.finished = false;\n              if (cancelled) result.cancelled = true;\n            } else {\n              queue.set(handler, {\n                value: null,\n                finished: finished || false,\n                cancelled: cancelled || false\n              });\n            }\n          };\n\n          if (defaults) {\n            defaults[key] = props[key];\n          }\n        }\n      });\n    }\n\n  const state = ctrl['_state'];\n\n  if (props.pause === !state.paused) {\n    state.paused = props.pause;\n    flushCalls(props.pause ? state.pauseQueue : state.resumeQueue);\n  } else if (state.paused) {\n      props.pause = true;\n    }\n\n  const promises = (keys || Object.keys(ctrl.springs)).map(key => ctrl.springs[key].start(props));\n  const cancel = props.cancel === true || getDefaultProp(props, 'cancel') === true;\n\n  if (asyncTo || cancel && state.asyncId) {\n    promises.push(scheduleProps(++ctrl['_lastAsyncId'], {\n      props,\n      state,\n      actions: {\n        pause: noop,\n        resume: noop,\n\n        start(props, resolve) {\n          if (cancel) {\n            stopAsync(state, ctrl['_lastAsyncId']);\n            resolve(getCancelledResult(ctrl));\n          } else {\n            props.onRest = onRest;\n            resolve(runAsync(asyncTo, props, state, ctrl));\n          }\n        }\n\n      }\n    }));\n  }\n\n  if (state.paused) {\n    await new Promise(resume => {\n      state.resumeQueue.add(resume);\n    });\n  }\n\n  const result = getCombinedResult(ctrl, await Promise.all(promises));\n\n  if (loop && result.finished && !(isLoop && result.noop)) {\n    const nextProps = createLoopUpdate(props, loop, to);\n\n    if (nextProps) {\n      prepareKeys(ctrl, [nextProps]);\n      return flushUpdate(ctrl, nextProps, true);\n    }\n  }\n\n  if (onResolve) {\n    raf.batchedUpdates(() => onResolve(result, ctrl, ctrl.item));\n  }\n\n  return result;\n}\nfunction getSprings(ctrl, props) {\n  const springs = _extends({}, ctrl.springs);\n\n  if (props) {\n    each(toArray(props), props => {\n      if (is.und(props.keys)) {\n        props = createUpdate(props);\n      }\n\n      if (!is.obj(props.to)) {\n        props = _extends({}, props, {\n          to: undefined\n        });\n      }\n\n      prepareSprings(springs, props, key => {\n        return createSpring(key);\n      });\n    });\n  }\n\n  setSprings(ctrl, springs);\n  return springs;\n}\nfunction setSprings(ctrl, springs) {\n  eachProp(springs, (spring, key) => {\n    if (!ctrl.springs[key]) {\n      ctrl.springs[key] = spring;\n      addFluidObserver(spring, ctrl);\n    }\n  });\n}\n\nfunction createSpring(key, observer) {\n  const spring = new SpringValue();\n  spring.key = key;\n\n  if (observer) {\n    addFluidObserver(spring, observer);\n  }\n\n  return spring;\n}\n\nfunction prepareSprings(springs, props, create) {\n  if (props.keys) {\n    each(props.keys, key => {\n      const spring = springs[key] || (springs[key] = create(key));\n      spring['_prepareNode'](props);\n    });\n  }\n}\n\nfunction prepareKeys(ctrl, queue) {\n  each(queue, props => {\n    prepareSprings(ctrl.springs, props, key => {\n      return createSpring(key, ctrl);\n    });\n  });\n}\n\nfunction _objectWithoutPropertiesLoose(source, excluded) {\n  if (source == null) return {};\n  var target = {};\n  var sourceKeys = Object.keys(source);\n  var key, i;\n\n  for (i = 0; i < sourceKeys.length; i++) {\n    key = sourceKeys[i];\n    if (excluded.indexOf(key) >= 0) continue;\n    target[key] = source[key];\n  }\n\n  return target;\n}\n\nconst _excluded$3 = [\"children\"];\nconst SpringContext = _ref => {\n  let {\n    children\n  } = _ref,\n      props = _objectWithoutPropertiesLoose(_ref, _excluded$3);\n\n  const inherited = useContext(ctx);\n  const pause = props.pause || !!inherited.pause,\n        immediate = props.immediate || !!inherited.immediate;\n  props = useMemoOne(() => ({\n    pause,\n    immediate\n  }), [pause, immediate]);\n  const {\n    Provider\n  } = ctx;\n  return React.createElement(Provider, {\n    value: props\n  }, children);\n};\nconst ctx = makeContext(SpringContext, {});\nSpringContext.Provider = ctx.Provider;\nSpringContext.Consumer = ctx.Consumer;\n\nfunction makeContext(target, init) {\n  Object.assign(target, React.createContext(init));\n  target.Provider._context = target;\n  target.Consumer._context = target;\n  return target;\n}\n\nconst SpringRef = () => {\n  const current = [];\n\n  const SpringRef = function SpringRef(props) {\n    deprecateDirectCall();\n    const results = [];\n    each(current, (ctrl, i) => {\n      if (is.und(props)) {\n        results.push(ctrl.start());\n      } else {\n        const update = _getProps(props, ctrl, i);\n\n        if (update) {\n          results.push(ctrl.start(update));\n        }\n      }\n    });\n    return results;\n  };\n\n  SpringRef.current = current;\n\n  SpringRef.add = function (ctrl) {\n    if (!current.includes(ctrl)) {\n      current.push(ctrl);\n    }\n  };\n\n  SpringRef.delete = function (ctrl) {\n    const i = current.indexOf(ctrl);\n    if (~i) current.splice(i, 1);\n  };\n\n  SpringRef.pause = function () {\n    each(current, ctrl => ctrl.pause(...arguments));\n    return this;\n  };\n\n  SpringRef.resume = function () {\n    each(current, ctrl => ctrl.resume(...arguments));\n    return this;\n  };\n\n  SpringRef.set = function (values) {\n    each(current, ctrl => ctrl.set(values));\n  };\n\n  SpringRef.start = function (props) {\n    const results = [];\n    each(current, (ctrl, i) => {\n      if (is.und(props)) {\n        results.push(ctrl.start());\n      } else {\n        const update = this._getProps(props, ctrl, i);\n\n        if (update) {\n          results.push(ctrl.start(update));\n        }\n      }\n    });\n    return results;\n  };\n\n  SpringRef.stop = function () {\n    each(current, ctrl => ctrl.stop(...arguments));\n    return this;\n  };\n\n  SpringRef.update = function (props) {\n    each(current, (ctrl, i) => ctrl.update(this._getProps(props, ctrl, i)));\n    return this;\n  };\n\n  const _getProps = function _getProps(arg, ctrl, index) {\n    return is.fun(arg) ? arg(index, ctrl) : arg;\n  };\n\n  SpringRef._getProps = _getProps;\n  return SpringRef;\n};\n\nfunction useSprings(length, props, deps) {\n  const propsFn = is.fun(props) && props;\n  if (propsFn && !deps) deps = [];\n  const ref = useMemo(() => propsFn || arguments.length == 3 ? SpringRef() : void 0, []);\n  const layoutId = useRef(0);\n  const forceUpdate = useForceUpdate();\n  const state = useMemo(() => ({\n    ctrls: [],\n    queue: [],\n\n    flush(ctrl, updates) {\n      const springs = getSprings(ctrl, updates);\n      const canFlushSync = layoutId.current > 0 && !state.queue.length && !Object.keys(springs).some(key => !ctrl.springs[key]);\n      return canFlushSync ? flushUpdateQueue(ctrl, updates) : new Promise(resolve => {\n        setSprings(ctrl, springs);\n        state.queue.push(() => {\n          resolve(flushUpdateQueue(ctrl, updates));\n        });\n        forceUpdate();\n      });\n    }\n\n  }), []);\n  const ctrls = useRef([...state.ctrls]);\n  const updates = [];\n  const prevLength = usePrev(length) || 0;\n  useMemo(() => {\n    each(ctrls.current.slice(length, prevLength), ctrl => {\n      detachRefs(ctrl, ref);\n      ctrl.stop(true);\n    });\n    ctrls.current.length = length;\n    declareUpdates(prevLength, length);\n  }, [length]);\n  useMemo(() => {\n    declareUpdates(0, Math.min(prevLength, length));\n  }, deps);\n\n  function declareUpdates(startIndex, endIndex) {\n    for (let i = startIndex; i < endIndex; i++) {\n      const ctrl = ctrls.current[i] || (ctrls.current[i] = new Controller(null, state.flush));\n      const update = propsFn ? propsFn(i, ctrl) : props[i];\n\n      if (update) {\n        updates[i] = declareUpdate(update);\n      }\n    }\n  }\n\n  const springs = ctrls.current.map((ctrl, i) => getSprings(ctrl, updates[i]));\n  const context = useContext(SpringContext);\n  const prevContext = usePrev(context);\n  const hasContext = context !== prevContext && hasProps(context);\n  useLayoutEffect(() => {\n    layoutId.current++;\n    state.ctrls = ctrls.current;\n    const {\n      queue\n    } = state;\n\n    if (queue.length) {\n      state.queue = [];\n      each(queue, cb => cb());\n    }\n\n    each(ctrls.current, (ctrl, i) => {\n      ref == null ? void 0 : ref.add(ctrl);\n\n      if (hasContext) {\n        ctrl.start({\n          default: context\n        });\n      }\n\n      const update = updates[i];\n\n      if (update) {\n        replaceRef(ctrl, update.ref);\n\n        if (ctrl.ref) {\n          ctrl.queue.push(update);\n        } else {\n          ctrl.start(update);\n        }\n      }\n    });\n  });\n  useOnce(() => () => {\n    each(state.ctrls, ctrl => ctrl.stop(true));\n  });\n  const values = springs.map(x => _extends({}, x));\n  return ref ? [values, ref] : values;\n}\n\nfunction useSpring(props, deps) {\n  const isFn = is.fun(props);\n  const [[values], ref] = useSprings(1, isFn ? props : [props], isFn ? deps || [] : deps);\n  return isFn || arguments.length == 2 ? [values, ref] : values;\n}\n\nconst initSpringRef = () => SpringRef();\n\nconst useSpringRef = () => useState(initSpringRef)[0];\n\nfunction useTrail(length, propsArg, deps) {\n  var _passedRef;\n\n  const propsFn = is.fun(propsArg) && propsArg;\n  if (propsFn && !deps) deps = [];\n  let reverse = true;\n  let passedRef = undefined;\n  const result = useSprings(length, (i, ctrl) => {\n    const props = propsFn ? propsFn(i, ctrl) : propsArg;\n    passedRef = props.ref;\n    reverse = reverse && props.reverse;\n    return props;\n  }, deps || [{}]);\n  const ref = (_passedRef = passedRef) != null ? _passedRef : result[1];\n  useLayoutEffect(() => {\n    each(ref.current, (ctrl, i) => {\n      const parent = ref.current[i + (reverse ? 1 : -1)];\n\n      if (parent) {\n        ctrl.start({\n          to: parent.springs\n        });\n      } else {\n        ctrl.start();\n      }\n    });\n  }, deps);\n\n  if (propsFn || arguments.length == 3) {\n    ref['_getProps'] = (propsArg, ctrl, i) => {\n      const props = is.fun(propsArg) ? propsArg(i, ctrl) : propsArg;\n\n      if (props) {\n        const parent = ref.current[i + (props.reverse ? 1 : -1)];\n        if (parent) props.to = parent.springs;\n        return props;\n      }\n    };\n\n    return result;\n  }\n\n  ref['start'] = propsArg => {\n    const results = [];\n    each(ref.current, (ctrl, i) => {\n      const props = is.fun(propsArg) ? propsArg(i, ctrl) : propsArg;\n      const parent = ref.current[i + (reverse ? 1 : -1)];\n\n      if (parent) {\n        results.push(ctrl.start(_extends({}, props, {\n          to: parent.springs\n        })));\n      } else {\n        results.push(ctrl.start(_extends({}, props)));\n      }\n    });\n    return results;\n  };\n\n  return result[0];\n}\n\nlet TransitionPhase;\n\n(function (TransitionPhase) {\n  TransitionPhase[\"MOUNT\"] = \"mount\";\n  TransitionPhase[\"ENTER\"] = \"enter\";\n  TransitionPhase[\"UPDATE\"] = \"update\";\n  TransitionPhase[\"LEAVE\"] = \"leave\";\n})(TransitionPhase || (TransitionPhase = {}));\n\nfunction useTransition(data, props, deps) {\n  const propsFn = is.fun(props) && props;\n  const {\n    reset,\n    sort,\n    trail = 0,\n    expires = true,\n    exitBeforeEnter = false,\n    onDestroyed,\n    ref: propsRef,\n    config: propsConfig\n  } = propsFn ? propsFn() : props;\n  const ref = useMemo(() => propsFn || arguments.length == 3 ? SpringRef() : void 0, []);\n  const items = toArray(data);\n  const transitions = [];\n  const usedTransitions = useRef(null);\n  const prevTransitions = reset ? null : usedTransitions.current;\n  useLayoutEffect(() => {\n    usedTransitions.current = transitions;\n  });\n  useOnce(() => {\n    each(usedTransitions.current, t => {\n      var _t$ctrl$ref;\n\n      (_t$ctrl$ref = t.ctrl.ref) == null ? void 0 : _t$ctrl$ref.add(t.ctrl);\n      const change = changes.get(t);\n\n      if (change) {\n        t.ctrl.start(change.payload);\n      }\n    });\n    return () => {\n      each(usedTransitions.current, t => {\n        if (t.expired) {\n          clearTimeout(t.expirationId);\n        }\n\n        detachRefs(t.ctrl, ref);\n        t.ctrl.stop(true);\n      });\n    };\n  });\n  const keys = getKeys(items, propsFn ? propsFn() : props, prevTransitions);\n  const expired = reset && usedTransitions.current || [];\n  useLayoutEffect(() => each(expired, ({\n    ctrl,\n    item,\n    key\n  }) => {\n    detachRefs(ctrl, ref);\n    callProp(onDestroyed, item, key);\n  }));\n  const reused = [];\n  if (prevTransitions) each(prevTransitions, (t, i) => {\n    if (t.expired) {\n      clearTimeout(t.expirationId);\n      expired.push(t);\n    } else {\n      i = reused[i] = keys.indexOf(t.key);\n      if (~i) transitions[i] = t;\n    }\n  });\n  each(items, (item, i) => {\n    if (!transitions[i]) {\n      transitions[i] = {\n        key: keys[i],\n        item,\n        phase: TransitionPhase.MOUNT,\n        ctrl: new Controller()\n      };\n      transitions[i].ctrl.item = item;\n    }\n  });\n\n  if (reused.length) {\n    let i = -1;\n    const {\n      leave\n    } = propsFn ? propsFn() : props;\n    each(reused, (keyIndex, prevIndex) => {\n      const t = prevTransitions[prevIndex];\n\n      if (~keyIndex) {\n        i = transitions.indexOf(t);\n        transitions[i] = _extends({}, t, {\n          item: items[keyIndex]\n        });\n      } else if (leave) {\n        transitions.splice(++i, 0, t);\n      }\n    });\n  }\n\n  if (is.fun(sort)) {\n    transitions.sort((a, b) => sort(a.item, b.item));\n  }\n\n  let delay = -trail;\n  const forceUpdate = useForceUpdate();\n  const defaultProps = getDefaultProps(props);\n  const changes = new Map();\n  const exitingTransitions = useRef(new Map());\n  const forceChange = useRef(false);\n  each(transitions, (t, i) => {\n    const key = t.key;\n    const prevPhase = t.phase;\n    const p = propsFn ? propsFn() : props;\n    let to;\n    let phase;\n    let propsDelay = callProp(p.delay || 0, key);\n\n    if (prevPhase == TransitionPhase.MOUNT) {\n      to = p.enter;\n      phase = TransitionPhase.ENTER;\n    } else {\n      const isLeave = keys.indexOf(key) < 0;\n\n      if (prevPhase != TransitionPhase.LEAVE) {\n        if (isLeave) {\n          to = p.leave;\n          phase = TransitionPhase.LEAVE;\n        } else if (to = p.update) {\n          phase = TransitionPhase.UPDATE;\n        } else return;\n      } else if (!isLeave) {\n        to = p.enter;\n        phase = TransitionPhase.ENTER;\n      } else return;\n    }\n\n    to = callProp(to, t.item, i);\n    to = is.obj(to) ? inferTo(to) : {\n      to\n    };\n\n    if (!to.config) {\n      const config = propsConfig || defaultProps.config;\n      to.config = callProp(config, t.item, i, phase);\n    }\n\n    delay += trail;\n\n    const payload = _extends({}, defaultProps, {\n      delay: propsDelay + delay,\n      ref: propsRef,\n      immediate: p.immediate,\n      reset: false\n    }, to);\n\n    if (phase == TransitionPhase.ENTER && is.und(payload.from)) {\n      const _p = propsFn ? propsFn() : props;\n\n      const from = is.und(_p.initial) || prevTransitions ? _p.from : _p.initial;\n      payload.from = callProp(from, t.item, i);\n    }\n\n    const {\n      onResolve\n    } = payload;\n\n    payload.onResolve = result => {\n      callProp(onResolve, result);\n      const transitions = usedTransitions.current;\n      const t = transitions.find(t => t.key === key);\n      if (!t) return;\n\n      if (result.cancelled && t.phase != TransitionPhase.UPDATE) {\n        return;\n      }\n\n      if (t.ctrl.idle) {\n        const idle = transitions.every(t => t.ctrl.idle);\n\n        if (t.phase == TransitionPhase.LEAVE) {\n          const expiry = callProp(expires, t.item);\n\n          if (expiry !== false) {\n            const expiryMs = expiry === true ? 0 : expiry;\n            t.expired = true;\n\n            if (!idle && expiryMs > 0) {\n              if (expiryMs <= 0x7fffffff) t.expirationId = setTimeout(forceUpdate, expiryMs);\n              return;\n            }\n          }\n        }\n\n        if (idle && transitions.some(t => t.expired)) {\n          exitingTransitions.current.delete(t);\n\n          if (exitBeforeEnter) {\n            forceChange.current = true;\n          }\n\n          forceUpdate();\n        }\n      }\n    };\n\n    const springs = getSprings(t.ctrl, payload);\n\n    if (phase === TransitionPhase.LEAVE && exitBeforeEnter) {\n      exitingTransitions.current.set(t, {\n        phase,\n        springs,\n        payload\n      });\n    } else {\n      changes.set(t, {\n        phase,\n        springs,\n        payload\n      });\n    }\n  });\n  const context = useContext(SpringContext);\n  const prevContext = usePrev(context);\n  const hasContext = context !== prevContext && hasProps(context);\n  useLayoutEffect(() => {\n    if (hasContext) {\n      each(transitions, t => {\n        t.ctrl.start({\n          default: context\n        });\n      });\n    }\n  }, [context]);\n  each(changes, (_, t) => {\n    if (exitingTransitions.current.size) {\n      const ind = transitions.findIndex(state => state.key === t.key);\n      transitions.splice(ind, 1);\n    }\n  });\n  useLayoutEffect(() => {\n    each(exitingTransitions.current.size ? exitingTransitions.current : changes, ({\n      phase,\n      payload\n    }, t) => {\n      const {\n        ctrl\n      } = t;\n      t.phase = phase;\n      ref == null ? void 0 : ref.add(ctrl);\n\n      if (hasContext && phase == TransitionPhase.ENTER) {\n        ctrl.start({\n          default: context\n        });\n      }\n\n      if (payload) {\n        replaceRef(ctrl, payload.ref);\n\n        if (ctrl.ref && !forceChange.current) {\n          ctrl.update(payload);\n        } else {\n          ctrl.start(payload);\n\n          if (forceChange.current) {\n            forceChange.current = false;\n          }\n        }\n      }\n    });\n  }, reset ? void 0 : deps);\n\n  const renderTransitions = render => React.createElement(React.Fragment, null, transitions.map((t, i) => {\n    const {\n      springs\n    } = changes.get(t) || t.ctrl;\n    const elem = render(_extends({}, springs), t.item, t, i);\n    return elem && elem.type ? React.createElement(elem.type, _extends({}, elem.props, {\n      key: is.str(t.key) || is.num(t.key) ? t.key : t.ctrl.id,\n      ref: elem.ref\n    })) : elem;\n  }));\n\n  return ref ? [renderTransitions, ref] : renderTransitions;\n}\nlet nextKey = 1;\n\nfunction getKeys(items, {\n  key,\n  keys = key\n}, prevTransitions) {\n  if (keys === null) {\n    const reused = new Set();\n    return items.map(item => {\n      const t = prevTransitions && prevTransitions.find(t => t.item === item && t.phase !== TransitionPhase.LEAVE && !reused.has(t));\n\n      if (t) {\n        reused.add(t);\n        return t.key;\n      }\n\n      return nextKey++;\n    });\n  }\n\n  return is.und(keys) ? items : is.fun(keys) ? items.map(keys) : toArray(keys);\n}\n\nconst _excluded$2 = [\"children\"];\nfunction Spring(_ref) {\n  let {\n    children\n  } = _ref,\n      props = _objectWithoutPropertiesLoose(_ref, _excluded$2);\n\n  return children(useSpring(props));\n}\n\nconst _excluded$1 = [\"items\", \"children\"];\nfunction Trail(_ref) {\n  let {\n    items,\n    children\n  } = _ref,\n      props = _objectWithoutPropertiesLoose(_ref, _excluded$1);\n\n  const trails = useTrail(items.length, props);\n  return items.map((item, index) => {\n    const result = children(item, index);\n    return is.fun(result) ? result(trails[index]) : result;\n  });\n}\n\nconst _excluded = [\"items\", \"children\"];\nfunction Transition(_ref) {\n  let {\n    items,\n    children\n  } = _ref,\n      props = _objectWithoutPropertiesLoose(_ref, _excluded);\n\n  return useTransition(items, props)(children);\n}\n\nclass Interpolation extends FrameValue {\n  constructor(source, args) {\n    super();\n    this.key = void 0;\n    this.idle = true;\n    this.calc = void 0;\n    this._active = new Set();\n    this.source = source;\n    this.calc = createInterpolator(...args);\n\n    const value = this._get();\n\n    const nodeType = getAnimatedType(value);\n    setAnimated(this, nodeType.create(value));\n  }\n\n  advance(_dt) {\n    const value = this._get();\n\n    const oldValue = this.get();\n\n    if (!isEqual(value, oldValue)) {\n      getAnimated(this).setValue(value);\n\n      this._onChange(value, this.idle);\n    }\n\n    if (!this.idle && checkIdle(this._active)) {\n      becomeIdle(this);\n    }\n  }\n\n  _get() {\n    const inputs = is.arr(this.source) ? this.source.map(getFluidValue) : toArray(getFluidValue(this.source));\n    return this.calc(...inputs);\n  }\n\n  _start() {\n    if (this.idle && !checkIdle(this._active)) {\n      this.idle = false;\n      each(getPayload(this), node => {\n        node.done = false;\n      });\n\n      if (Globals.skipAnimation) {\n        raf.batchedUpdates(() => this.advance());\n        becomeIdle(this);\n      } else {\n        frameLoop.start(this);\n      }\n    }\n  }\n\n  _attach() {\n    let priority = 1;\n    each(toArray(this.source), source => {\n      if (hasFluidValue(source)) {\n        addFluidObserver(source, this);\n      }\n\n      if (isFrameValue(source)) {\n        if (!source.idle) {\n          this._active.add(source);\n        }\n\n        priority = Math.max(priority, source.priority + 1);\n      }\n    });\n    this.priority = priority;\n\n    this._start();\n  }\n\n  _detach() {\n    each(toArray(this.source), source => {\n      if (hasFluidValue(source)) {\n        removeFluidObserver(source, this);\n      }\n    });\n\n    this._active.clear();\n\n    becomeIdle(this);\n  }\n\n  eventObserved(event) {\n    if (event.type == 'change') {\n      if (event.idle) {\n        this.advance();\n      } else {\n        this._active.add(event.parent);\n\n        this._start();\n      }\n    } else if (event.type == 'idle') {\n        this._active.delete(event.parent);\n      } else if (event.type == 'priority') {\n          this.priority = toArray(this.source).reduce((highest, parent) => Math.max(highest, (isFrameValue(parent) ? parent.priority : 0) + 1), 0);\n        }\n  }\n\n}\n\nfunction isIdle(source) {\n  return source.idle !== false;\n}\n\nfunction checkIdle(active) {\n  return !active.size || Array.from(active).every(isIdle);\n}\n\nfunction becomeIdle(self) {\n  if (!self.idle) {\n    self.idle = true;\n    each(getPayload(self), node => {\n      node.done = true;\n    });\n    callFluidObservers(self, {\n      type: 'idle',\n      parent: self\n    });\n  }\n}\n\nconst to = (source, ...args) => new Interpolation(source, args);\nconst interpolate = (source, ...args) => (deprecateInterpolate(), new Interpolation(source, args));\n\nGlobals.assign({\n  createStringInterpolator,\n  to: (source, args) => new Interpolation(source, args)\n});\nconst update = frameLoop.advance;\n\nexport { BailSignal, Controller, FrameValue, Interpolation, Spring, SpringContext, SpringRef, SpringValue, Trail, Transition, config, easings, inferTo, interpolate, to, update, useChain, useSpring, useSpringRef, useSprings, useTrail, useTransition };\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///4928\n")},4813:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n \"B0\": () => (/* binding */ FluidValue),\n \"OH\": () => (/* binding */ globals),\n \"UI\": () => (/* binding */ addFluidObserver),\n \"k0\": () => (/* binding */ callFluidObservers),\n \"O9\": () => (/* binding */ colors),\n \"mD\": () => (/* binding */ createInterpolator),\n \"qS\": () => (/* binding */ createStringInterpolator),\n \"dE\": () => (/* binding */ defineHidden),\n \"ZR\": () => (/* binding */ deprecateDirectCall),\n \"LW\": () => (/* binding */ deprecateInterpolate),\n \"S6\": () => (/* binding */ each),\n \"rU\": () => (/* binding */ eachProp),\n \"yl\": () => (/* binding */ flush),\n \"bl\": () => (/* binding */ flushCalls),\n \"fT\": () => (/* binding */ frameLoop),\n \"Ll\": () => (/* binding */ getFluidObservers),\n \"je\": () => (/* binding */ getFluidValue),\n \"j$\": () => (/* binding */ hasFluidValue),\n \"is\": () => (/* binding */ is),\n \"Df\": () => (/* binding */ isAnimatedString),\n \"Xy\": () => (/* binding */ isEqual),\n \"ZT\": () => (/* binding */ noop),\n \"Wn\": () => (/* reexport */ raf),\n \"iL\": () => (/* binding */ removeFluidObserver),\n \"qo\": () => (/* binding */ toArray),\n \"NW\": () => (/* binding */ useForceUpdate),\n \"bt\": () => (/* binding */ useLayoutEffect),\n \"Pr\": () => (/* binding */ useMemoOne),\n \"tf\": () => (/* binding */ useOnce),\n \"zH\": () => (/* binding */ usePrev)\n});\n\n// UNUSED EXPORTS: callFluidObserver, colorToRgba, hex3, hex4, hex6, hex8, hsl, hsla, isSSR, rgb, rgba, setFluidGetter\n\n;// CONCATENATED MODULE: ./node_modules/@react-spring/rafz/dist/react-spring-rafz.esm.js\nlet updateQueue = makeQueue();\nconst raf = fn => schedule(fn, updateQueue);\nlet writeQueue = makeQueue();\n\nraf.write = fn => schedule(fn, writeQueue);\n\nlet onStartQueue = makeQueue();\n\nraf.onStart = fn => schedule(fn, onStartQueue);\n\nlet onFrameQueue = makeQueue();\n\nraf.onFrame = fn => schedule(fn, onFrameQueue);\n\nlet onFinishQueue = makeQueue();\n\nraf.onFinish = fn => schedule(fn, onFinishQueue);\n\nlet timeouts = [];\n\nraf.setTimeout = (handler, ms) => {\n let time = raf.now() + ms;\n\n let cancel = () => {\n let i = timeouts.findIndex(t => t.cancel == cancel);\n if (~i) timeouts.splice(i, 1);\n pendingCount -= ~i ? 1 : 0;\n };\n\n let timeout = {\n time,\n handler,\n cancel\n };\n timeouts.splice(findTimeout(time), 0, timeout);\n pendingCount += 1;\n start();\n return timeout;\n};\n\nlet findTimeout = time => ~(~timeouts.findIndex(t => t.time > time) || ~timeouts.length);\n\nraf.cancel = fn => {\n onStartQueue.delete(fn);\n onFrameQueue.delete(fn);\n updateQueue.delete(fn);\n writeQueue.delete(fn);\n onFinishQueue.delete(fn);\n};\n\nraf.sync = fn => {\n sync = true;\n raf.batchedUpdates(fn);\n sync = false;\n};\n\nraf.throttle = fn => {\n let lastArgs;\n\n function queuedFn() {\n try {\n fn(...lastArgs);\n } finally {\n lastArgs = null;\n }\n }\n\n function throttled(...args) {\n lastArgs = args;\n raf.onStart(queuedFn);\n }\n\n throttled.handler = fn;\n\n throttled.cancel = () => {\n onStartQueue.delete(queuedFn);\n lastArgs = null;\n };\n\n return throttled;\n};\n\nlet nativeRaf = typeof window != 'undefined' ? window.requestAnimationFrame : () => {};\n\nraf.use = impl => nativeRaf = impl;\n\nraf.now = typeof performance != 'undefined' ? () => performance.now() : Date.now;\n\nraf.batchedUpdates = fn => fn();\n\nraf.catch = console.error;\nraf.frameLoop = 'always';\n\nraf.advance = () => {\n if (raf.frameLoop !== 'demand') {\n console.warn('Cannot call the manual advancement of rafz whilst frameLoop is not set as demand');\n } else {\n update();\n }\n};\n\nlet ts = -1;\nlet pendingCount = 0;\nlet sync = false;\n\nfunction schedule(fn, queue) {\n if (sync) {\n queue.delete(fn);\n fn(0);\n } else {\n queue.add(fn);\n start();\n }\n}\n\nfunction start() {\n if (ts < 0) {\n ts = 0;\n\n if (raf.frameLoop !== 'demand') {\n nativeRaf(loop);\n }\n }\n}\n\nfunction stop() {\n ts = -1;\n}\n\nfunction loop() {\n if (~ts) {\n nativeRaf(loop);\n raf.batchedUpdates(update);\n }\n}\n\nfunction update() {\n let prevTs = ts;\n ts = raf.now();\n let count = findTimeout(ts);\n\n if (count) {\n eachSafely(timeouts.splice(0, count), t => t.handler());\n pendingCount -= count;\n }\n\n onStartQueue.flush();\n updateQueue.flush(prevTs ? Math.min(64, ts - prevTs) : 16.667);\n onFrameQueue.flush();\n writeQueue.flush();\n onFinishQueue.flush();\n\n if (!pendingCount) {\n stop();\n }\n}\n\nfunction makeQueue() {\n let next = new Set();\n let current = next;\n return {\n add(fn) {\n pendingCount += current == next && !next.has(fn) ? 1 : 0;\n next.add(fn);\n },\n\n delete(fn) {\n pendingCount -= current == next && next.has(fn) ? 1 : 0;\n return next.delete(fn);\n },\n\n flush(arg) {\n if (current.size) {\n next = new Set();\n pendingCount -= current.size;\n eachSafely(current, fn => fn(arg) && next.add(fn));\n pendingCount += next.size;\n current = next;\n }\n }\n\n };\n}\n\nfunction eachSafely(values, each) {\n values.forEach(value => {\n try {\n each(value);\n } catch (e) {\n raf.catch(e);\n }\n });\n}\n\nconst __raf = {\n count() {\n return pendingCount;\n },\n\n isRunning() {\n return ts >= 0;\n },\n\n clear() {\n ts = -1;\n timeouts = [];\n onStartQueue = makeQueue();\n updateQueue = makeQueue();\n onFrameQueue = makeQueue();\n writeQueue = makeQueue();\n onFinishQueue = makeQueue();\n pendingCount = 0;\n }\n\n};\n\n\n\n// EXTERNAL MODULE: external \"React\"\nvar external_React_ = __webpack_require__(7363);\n;// CONCATENATED MODULE: ./node_modules/@react-spring/shared/dist/react-spring-shared.esm.js\n\n\n\n\n\nfunction noop() {}\nconst defineHidden = (obj, key, value) => Object.defineProperty(obj, key, {\n value,\n writable: true,\n configurable: true\n});\nconst is = {\n arr: Array.isArray,\n obj: a => !!a && a.constructor.name === 'Object',\n fun: a => typeof a === 'function',\n str: a => typeof a === 'string',\n num: a => typeof a === 'number',\n und: a => a === undefined\n};\nfunction isEqual(a, b) {\n if (is.arr(a)) {\n if (!is.arr(b) || a.length !== b.length) return false;\n\n for (let i = 0; i < a.length; i++) {\n if (a[i] !== b[i]) return false;\n }\n\n return true;\n }\n\n return a === b;\n}\nconst each = (obj, fn) => obj.forEach(fn);\nfunction eachProp(obj, fn, ctx) {\n if (is.arr(obj)) {\n for (let i = 0; i < obj.length; i++) {\n fn.call(ctx, obj[i], `${i}`);\n }\n\n return;\n }\n\n for (const key in obj) {\n if (obj.hasOwnProperty(key)) {\n fn.call(ctx, obj[key], key);\n }\n }\n}\nconst toArray = a => is.und(a) ? [] : is.arr(a) ? a : [a];\nfunction flush(queue, iterator) {\n if (queue.size) {\n const items = Array.from(queue);\n queue.clear();\n each(items, iterator);\n }\n}\nconst flushCalls = (queue, ...args) => flush(queue, fn => fn(...args));\nconst isSSR = () => typeof window === 'undefined' || !window.navigator || /ServerSideRendering|^Deno\\//.test(window.navigator.userAgent);\n\nlet createStringInterpolator$1;\nlet to;\nlet colors$1 = null;\nlet skipAnimation = false;\nlet willAdvance = noop;\nconst react_spring_shared_esm_assign = globals => {\n if (globals.to) to = globals.to;\n if (globals.now) raf.now = globals.now;\n if (globals.colors !== undefined) colors$1 = globals.colors;\n if (globals.skipAnimation != null) skipAnimation = globals.skipAnimation;\n if (globals.createStringInterpolator) createStringInterpolator$1 = globals.createStringInterpolator;\n if (globals.requestAnimationFrame) raf.use(globals.requestAnimationFrame);\n if (globals.batchedUpdates) raf.batchedUpdates = globals.batchedUpdates;\n if (globals.willAdvance) willAdvance = globals.willAdvance;\n if (globals.frameLoop) raf.frameLoop = globals.frameLoop;\n};\n\nvar globals = /*#__PURE__*/Object.freeze({\n __proto__: null,\n get createStringInterpolator () { return createStringInterpolator$1; },\n get to () { return to; },\n get colors () { return colors$1; },\n get skipAnimation () { return skipAnimation; },\n get willAdvance () { return willAdvance; },\n assign: react_spring_shared_esm_assign\n});\n\nconst startQueue = new Set();\nlet currentFrame = [];\nlet prevFrame = [];\nlet priority = 0;\nconst frameLoop = {\n get idle() {\n return !startQueue.size && !currentFrame.length;\n },\n\n start(animation) {\n if (priority > animation.priority) {\n startQueue.add(animation);\n raf.onStart(flushStartQueue);\n } else {\n startSafely(animation);\n raf(advance);\n }\n },\n\n advance,\n\n sort(animation) {\n if (priority) {\n raf.onFrame(() => frameLoop.sort(animation));\n } else {\n const prevIndex = currentFrame.indexOf(animation);\n\n if (~prevIndex) {\n currentFrame.splice(prevIndex, 1);\n startUnsafely(animation);\n }\n }\n },\n\n clear() {\n currentFrame = [];\n startQueue.clear();\n }\n\n};\n\nfunction flushStartQueue() {\n startQueue.forEach(startSafely);\n startQueue.clear();\n raf(advance);\n}\n\nfunction startSafely(animation) {\n if (!currentFrame.includes(animation)) startUnsafely(animation);\n}\n\nfunction startUnsafely(animation) {\n currentFrame.splice(findIndex(currentFrame, other => other.priority > animation.priority), 0, animation);\n}\n\nfunction advance(dt) {\n const nextFrame = prevFrame;\n\n for (let i = 0; i < currentFrame.length; i++) {\n const animation = currentFrame[i];\n priority = animation.priority;\n\n if (!animation.idle) {\n willAdvance(animation);\n animation.advance(dt);\n\n if (!animation.idle) {\n nextFrame.push(animation);\n }\n }\n }\n\n priority = 0;\n prevFrame = currentFrame;\n prevFrame.length = 0;\n currentFrame = nextFrame;\n return currentFrame.length > 0;\n}\n\nfunction findIndex(arr, test) {\n const index = arr.findIndex(test);\n return index < 0 ? arr.length : index;\n}\n\nconst colors = {\n transparent: 0x00000000,\n aliceblue: 0xf0f8ffff,\n antiquewhite: 0xfaebd7ff,\n aqua: 0x00ffffff,\n aquamarine: 0x7fffd4ff,\n azure: 0xf0ffffff,\n beige: 0xf5f5dcff,\n bisque: 0xffe4c4ff,\n black: 0x000000ff,\n blanchedalmond: 0xffebcdff,\n blue: 0x0000ffff,\n blueviolet: 0x8a2be2ff,\n brown: 0xa52a2aff,\n burlywood: 0xdeb887ff,\n burntsienna: 0xea7e5dff,\n cadetblue: 0x5f9ea0ff,\n chartreuse: 0x7fff00ff,\n chocolate: 0xd2691eff,\n coral: 0xff7f50ff,\n cornflowerblue: 0x6495edff,\n cornsilk: 0xfff8dcff,\n crimson: 0xdc143cff,\n cyan: 0x00ffffff,\n darkblue: 0x00008bff,\n darkcyan: 0x008b8bff,\n darkgoldenrod: 0xb8860bff,\n darkgray: 0xa9a9a9ff,\n darkgreen: 0x006400ff,\n darkgrey: 0xa9a9a9ff,\n darkkhaki: 0xbdb76bff,\n darkmagenta: 0x8b008bff,\n darkolivegreen: 0x556b2fff,\n darkorange: 0xff8c00ff,\n darkorchid: 0x9932ccff,\n darkred: 0x8b0000ff,\n darksalmon: 0xe9967aff,\n darkseagreen: 0x8fbc8fff,\n darkslateblue: 0x483d8bff,\n darkslategray: 0x2f4f4fff,\n darkslategrey: 0x2f4f4fff,\n darkturquoise: 0x00ced1ff,\n darkviolet: 0x9400d3ff,\n deeppink: 0xff1493ff,\n deepskyblue: 0x00bfffff,\n dimgray: 0x696969ff,\n dimgrey: 0x696969ff,\n dodgerblue: 0x1e90ffff,\n firebrick: 0xb22222ff,\n floralwhite: 0xfffaf0ff,\n forestgreen: 0x228b22ff,\n fuchsia: 0xff00ffff,\n gainsboro: 0xdcdcdcff,\n ghostwhite: 0xf8f8ffff,\n gold: 0xffd700ff,\n goldenrod: 0xdaa520ff,\n gray: 0x808080ff,\n green: 0x008000ff,\n greenyellow: 0xadff2fff,\n grey: 0x808080ff,\n honeydew: 0xf0fff0ff,\n hotpink: 0xff69b4ff,\n indianred: 0xcd5c5cff,\n indigo: 0x4b0082ff,\n ivory: 0xfffff0ff,\n khaki: 0xf0e68cff,\n lavender: 0xe6e6faff,\n lavenderblush: 0xfff0f5ff,\n lawngreen: 0x7cfc00ff,\n lemonchiffon: 0xfffacdff,\n lightblue: 0xadd8e6ff,\n lightcoral: 0xf08080ff,\n lightcyan: 0xe0ffffff,\n lightgoldenrodyellow: 0xfafad2ff,\n lightgray: 0xd3d3d3ff,\n lightgreen: 0x90ee90ff,\n lightgrey: 0xd3d3d3ff,\n lightpink: 0xffb6c1ff,\n lightsalmon: 0xffa07aff,\n lightseagreen: 0x20b2aaff,\n lightskyblue: 0x87cefaff,\n lightslategray: 0x778899ff,\n lightslategrey: 0x778899ff,\n lightsteelblue: 0xb0c4deff,\n lightyellow: 0xffffe0ff,\n lime: 0x00ff00ff,\n limegreen: 0x32cd32ff,\n linen: 0xfaf0e6ff,\n magenta: 0xff00ffff,\n maroon: 0x800000ff,\n mediumaquamarine: 0x66cdaaff,\n mediumblue: 0x0000cdff,\n mediumorchid: 0xba55d3ff,\n mediumpurple: 0x9370dbff,\n mediumseagreen: 0x3cb371ff,\n mediumslateblue: 0x7b68eeff,\n mediumspringgreen: 0x00fa9aff,\n mediumturquoise: 0x48d1ccff,\n mediumvioletred: 0xc71585ff,\n midnightblue: 0x191970ff,\n mintcream: 0xf5fffaff,\n mistyrose: 0xffe4e1ff,\n moccasin: 0xffe4b5ff,\n navajowhite: 0xffdeadff,\n navy: 0x000080ff,\n oldlace: 0xfdf5e6ff,\n olive: 0x808000ff,\n olivedrab: 0x6b8e23ff,\n orange: 0xffa500ff,\n orangered: 0xff4500ff,\n orchid: 0xda70d6ff,\n palegoldenrod: 0xeee8aaff,\n palegreen: 0x98fb98ff,\n paleturquoise: 0xafeeeeff,\n palevioletred: 0xdb7093ff,\n papayawhip: 0xffefd5ff,\n peachpuff: 0xffdab9ff,\n peru: 0xcd853fff,\n pink: 0xffc0cbff,\n plum: 0xdda0ddff,\n powderblue: 0xb0e0e6ff,\n purple: 0x800080ff,\n rebeccapurple: 0x663399ff,\n red: 0xff0000ff,\n rosybrown: 0xbc8f8fff,\n royalblue: 0x4169e1ff,\n saddlebrown: 0x8b4513ff,\n salmon: 0xfa8072ff,\n sandybrown: 0xf4a460ff,\n seagreen: 0x2e8b57ff,\n seashell: 0xfff5eeff,\n sienna: 0xa0522dff,\n silver: 0xc0c0c0ff,\n skyblue: 0x87ceebff,\n slateblue: 0x6a5acdff,\n slategray: 0x708090ff,\n slategrey: 0x708090ff,\n snow: 0xfffafaff,\n springgreen: 0x00ff7fff,\n steelblue: 0x4682b4ff,\n tan: 0xd2b48cff,\n teal: 0x008080ff,\n thistle: 0xd8bfd8ff,\n tomato: 0xff6347ff,\n turquoise: 0x40e0d0ff,\n violet: 0xee82eeff,\n wheat: 0xf5deb3ff,\n white: 0xffffffff,\n whitesmoke: 0xf5f5f5ff,\n yellow: 0xffff00ff,\n yellowgreen: 0x9acd32ff\n};\n\nconst NUMBER = '[-+]?\\\\d*\\\\.?\\\\d+';\nconst PERCENTAGE = NUMBER + '%';\n\nfunction call(...parts) {\n return '\\\\(\\\\s*(' + parts.join(')\\\\s*,\\\\s*(') + ')\\\\s*\\\\)';\n}\n\nconst rgb = new RegExp('rgb' + call(NUMBER, NUMBER, NUMBER));\nconst rgba = new RegExp('rgba' + call(NUMBER, NUMBER, NUMBER, NUMBER));\nconst hsl = new RegExp('hsl' + call(NUMBER, PERCENTAGE, PERCENTAGE));\nconst hsla = new RegExp('hsla' + call(NUMBER, PERCENTAGE, PERCENTAGE, NUMBER));\nconst hex3 = /^#([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/;\nconst hex4 = /^#([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/;\nconst hex6 = /^#([0-9a-fA-F]{6})$/;\nconst hex8 = /^#([0-9a-fA-F]{8})$/;\n\nfunction normalizeColor(color) {\n let match;\n\n if (typeof color === 'number') {\n return color >>> 0 === color && color >= 0 && color <= 0xffffffff ? color : null;\n }\n\n if (match = hex6.exec(color)) return parseInt(match[1] + 'ff', 16) >>> 0;\n\n if (colors$1 && colors$1[color] !== undefined) {\n return colors$1[color];\n }\n\n if (match = rgb.exec(color)) {\n return (parse255(match[1]) << 24 | parse255(match[2]) << 16 | parse255(match[3]) << 8 | 0x000000ff) >>> 0;\n }\n\n if (match = rgba.exec(color)) {\n return (parse255(match[1]) << 24 | parse255(match[2]) << 16 | parse255(match[3]) << 8 | parse1(match[4])) >>> 0;\n }\n\n if (match = hex3.exec(color)) {\n return parseInt(match[1] + match[1] + match[2] + match[2] + match[3] + match[3] + 'ff', 16) >>> 0;\n }\n\n if (match = hex8.exec(color)) return parseInt(match[1], 16) >>> 0;\n\n if (match = hex4.exec(color)) {\n return parseInt(match[1] + match[1] + match[2] + match[2] + match[3] + match[3] + match[4] + match[4], 16) >>> 0;\n }\n\n if (match = hsl.exec(color)) {\n return (hslToRgb(parse360(match[1]), parsePercentage(match[2]), parsePercentage(match[3])) | 0x000000ff) >>> 0;\n }\n\n if (match = hsla.exec(color)) {\n return (hslToRgb(parse360(match[1]), parsePercentage(match[2]), parsePercentage(match[3])) | parse1(match[4])) >>> 0;\n }\n\n return null;\n}\n\nfunction hue2rgb(p, q, t) {\n if (t < 0) t += 1;\n if (t > 1) t -= 1;\n if (t < 1 / 6) return p + (q - p) * 6 * t;\n if (t < 1 / 2) return q;\n if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6;\n return p;\n}\n\nfunction hslToRgb(h, s, l) {\n const q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n const p = 2 * l - q;\n const r = hue2rgb(p, q, h + 1 / 3);\n const g = hue2rgb(p, q, h);\n const b = hue2rgb(p, q, h - 1 / 3);\n return Math.round(r * 255) << 24 | Math.round(g * 255) << 16 | Math.round(b * 255) << 8;\n}\n\nfunction parse255(str) {\n const int = parseInt(str, 10);\n if (int < 0) return 0;\n if (int > 255) return 255;\n return int;\n}\n\nfunction parse360(str) {\n const int = parseFloat(str);\n return (int % 360 + 360) % 360 / 360;\n}\n\nfunction parse1(str) {\n const num = parseFloat(str);\n if (num < 0) return 0;\n if (num > 1) return 255;\n return Math.round(num * 255);\n}\n\nfunction parsePercentage(str) {\n const int = parseFloat(str);\n if (int < 0) return 0;\n if (int > 100) return 1;\n return int / 100;\n}\n\nfunction colorToRgba(input) {\n let int32Color = normalizeColor(input);\n if (int32Color === null) return input;\n int32Color = int32Color || 0;\n let r = (int32Color & 0xff000000) >>> 24;\n let g = (int32Color & 0x00ff0000) >>> 16;\n let b = (int32Color & 0x0000ff00) >>> 8;\n let a = (int32Color & 0x000000ff) / 255;\n return `rgba(${r}, ${g}, ${b}, ${a})`;\n}\n\nconst createInterpolator = (range, output, extrapolate) => {\n if (is.fun(range)) {\n return range;\n }\n\n if (is.arr(range)) {\n return createInterpolator({\n range,\n output: output,\n extrapolate\n });\n }\n\n if (is.str(range.output[0])) {\n return createStringInterpolator$1(range);\n }\n\n const config = range;\n const outputRange = config.output;\n const inputRange = config.range || [0, 1];\n const extrapolateLeft = config.extrapolateLeft || config.extrapolate || 'extend';\n const extrapolateRight = config.extrapolateRight || config.extrapolate || 'extend';\n\n const easing = config.easing || (t => t);\n\n return input => {\n const range = findRange(input, inputRange);\n return interpolate(input, inputRange[range], inputRange[range + 1], outputRange[range], outputRange[range + 1], easing, extrapolateLeft, extrapolateRight, config.map);\n };\n};\n\nfunction interpolate(input, inputMin, inputMax, outputMin, outputMax, easing, extrapolateLeft, extrapolateRight, map) {\n let result = map ? map(input) : input;\n\n if (result < inputMin) {\n if (extrapolateLeft === 'identity') return result;else if (extrapolateLeft === 'clamp') result = inputMin;\n }\n\n if (result > inputMax) {\n if (extrapolateRight === 'identity') return result;else if (extrapolateRight === 'clamp') result = inputMax;\n }\n\n if (outputMin === outputMax) return outputMin;\n if (inputMin === inputMax) return input <= inputMin ? outputMin : outputMax;\n if (inputMin === -Infinity) result = -result;else if (inputMax === Infinity) result = result - inputMin;else result = (result - inputMin) / (inputMax - inputMin);\n result = easing(result);\n if (outputMin === -Infinity) result = -result;else if (outputMax === Infinity) result = result + outputMin;else result = result * (outputMax - outputMin) + outputMin;\n return result;\n}\n\nfunction findRange(input, inputRange) {\n for (var i = 1; i < inputRange.length - 1; ++i) if (inputRange[i] >= input) break;\n\n return i - 1;\n}\n\nfunction _extends() {\n _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n };\n\n return _extends.apply(this, arguments);\n}\n\nconst $get = Symbol.for('FluidValue.get');\nconst $observers = Symbol.for('FluidValue.observers');\n\nconst hasFluidValue = arg => Boolean(arg && arg[$get]);\n\nconst getFluidValue = arg => arg && arg[$get] ? arg[$get]() : arg;\n\nconst getFluidObservers = target => target[$observers] || null;\n\nfunction callFluidObserver(observer, event) {\n if (observer.eventObserved) {\n observer.eventObserved(event);\n } else {\n observer(event);\n }\n}\n\nfunction callFluidObservers(target, event) {\n let observers = target[$observers];\n\n if (observers) {\n observers.forEach(observer => {\n callFluidObserver(observer, event);\n });\n }\n}\n\nclass FluidValue {\n constructor(get) {\n this[$get] = void 0;\n this[$observers] = void 0;\n\n if (!get && !(get = this.get)) {\n throw Error('Unknown getter');\n }\n\n setFluidGetter(this, get);\n }\n\n}\n\nconst setFluidGetter = (target, get) => setHidden(target, $get, get);\n\nfunction addFluidObserver(target, observer) {\n if (target[$get]) {\n let observers = target[$observers];\n\n if (!observers) {\n setHidden(target, $observers, observers = new Set());\n }\n\n if (!observers.has(observer)) {\n observers.add(observer);\n\n if (target.observerAdded) {\n target.observerAdded(observers.size, observer);\n }\n }\n }\n\n return observer;\n}\n\nfunction removeFluidObserver(target, observer) {\n let observers = target[$observers];\n\n if (observers && observers.has(observer)) {\n const count = observers.size - 1;\n\n if (count) {\n observers.delete(observer);\n } else {\n target[$observers] = null;\n }\n\n if (target.observerRemoved) {\n target.observerRemoved(count, observer);\n }\n }\n}\n\nconst setHidden = (target, key, value) => Object.defineProperty(target, key, {\n value,\n writable: true,\n configurable: true\n});\n\nconst numberRegex = /[+\\-]?(?:0|[1-9]\\d*)(?:\\.\\d*)?(?:[eE][+\\-]?\\d+)?/g;\nconst colorRegex = /(#(?:[0-9a-f]{2}){2,4}|(#[0-9a-f]{3})|(rgb|hsl)a?\\((-?\\d+%?[,\\s]+){2,3}\\s*[\\d\\.]+%?\\))/gi;\nconst unitRegex = new RegExp(`(${numberRegex.source})(%|[a-z]+)`, 'i');\nconst rgbaRegex = /rgba\\(([0-9\\.-]+), ([0-9\\.-]+), ([0-9\\.-]+), ([0-9\\.-]+)\\)/gi;\nconst cssVariableRegex = /var\\((--[a-zA-Z0-9-_]+),? ?([a-zA-Z0-9 ()%#.,-]+)?\\)/;\n\nconst variableToRgba = input => {\n const [token, fallback] = parseCSSVariable(input);\n\n if (!token || isSSR()) {\n return input;\n }\n\n const value = window.getComputedStyle(document.documentElement).getPropertyValue(token);\n\n if (value) {\n return value.trim();\n } else if (fallback && fallback.startsWith('--')) {\n const _value = window.getComputedStyle(document.documentElement).getPropertyValue(fallback);\n\n if (_value) {\n return _value;\n } else {\n return input;\n }\n } else if (fallback && cssVariableRegex.test(fallback)) {\n return variableToRgba(fallback);\n } else if (fallback) {\n return fallback;\n }\n\n return input;\n};\n\nconst parseCSSVariable = current => {\n const match = cssVariableRegex.exec(current);\n if (!match) return [,];\n const [, token, fallback] = match;\n return [token, fallback];\n};\n\nlet namedColorRegex;\n\nconst rgbaRound = (_, p1, p2, p3, p4) => `rgba(${Math.round(p1)}, ${Math.round(p2)}, ${Math.round(p3)}, ${p4})`;\n\nconst createStringInterpolator = config => {\n if (!namedColorRegex) namedColorRegex = colors$1 ? new RegExp(`(${Object.keys(colors$1).join('|')})(?!\\\\w)`, 'g') : /^\\b$/;\n const output = config.output.map(value => {\n return getFluidValue(value).replace(cssVariableRegex, variableToRgba).replace(colorRegex, colorToRgba).replace(namedColorRegex, colorToRgba);\n });\n const keyframes = output.map(value => value.match(numberRegex).map(Number));\n const outputRanges = keyframes[0].map((_, i) => keyframes.map(values => {\n if (!(i in values)) {\n throw Error('The arity of each \"output\" value must be equal');\n }\n\n return values[i];\n }));\n const interpolators = outputRanges.map(output => createInterpolator(_extends({}, config, {\n output\n })));\n return input => {\n var _output$find;\n\n const missingUnit = !unitRegex.test(output[0]) && ((_output$find = output.find(value => unitRegex.test(value))) == null ? void 0 : _output$find.replace(numberRegex, ''));\n let i = 0;\n return output[0].replace(numberRegex, () => `${interpolators[i++](input)}${missingUnit || ''}`).replace(rgbaRegex, rgbaRound);\n };\n};\n\nconst prefix = 'react-spring: ';\n\nconst once = fn => {\n const func = fn;\n let called = false;\n\n if (typeof func != 'function') {\n throw new TypeError(`${prefix}once requires a function parameter`);\n }\n\n return (...args) => {\n if (!called) {\n func(...args);\n called = true;\n }\n };\n};\n\nconst warnInterpolate = once(console.warn);\nfunction deprecateInterpolate() {\n warnInterpolate(`${prefix}The \"interpolate\" function is deprecated in v9 (use \"to\" instead)`);\n}\nconst warnDirectCall = once(console.warn);\nfunction deprecateDirectCall() {\n warnDirectCall(`${prefix}Directly calling start instead of using the api object is deprecated in v9 (use \".start\" instead), this will be removed in later 0.X.0 versions`);\n}\n\nfunction isAnimatedString(value) {\n return is.str(value) && (value[0] == '#' || /\\d/.test(value) || !isSSR() && cssVariableRegex.test(value) || value in (colors$1 || {}));\n}\n\nconst useLayoutEffect = typeof window !== 'undefined' && window.document && window.document.createElement ? external_React_.useLayoutEffect : external_React_.useEffect;\n\nconst useIsMounted = () => {\n const isMounted = (0,external_React_.useRef)(false);\n useLayoutEffect(() => {\n isMounted.current = true;\n return () => {\n isMounted.current = false;\n };\n }, []);\n return isMounted;\n};\n\nfunction useForceUpdate() {\n const update = (0,external_React_.useState)()[1];\n const isMounted = useIsMounted();\n return () => {\n if (isMounted.current) {\n update(Math.random());\n }\n };\n}\n\nfunction useMemoOne(getResult, inputs) {\n const [initial] = (0,external_React_.useState)(() => ({\n inputs,\n result: getResult()\n }));\n const committed = (0,external_React_.useRef)();\n const prevCache = committed.current;\n let cache = prevCache;\n\n if (cache) {\n const useCache = Boolean(inputs && cache.inputs && areInputsEqual(inputs, cache.inputs));\n\n if (!useCache) {\n cache = {\n inputs,\n result: getResult()\n };\n }\n } else {\n cache = initial;\n }\n\n (0,external_React_.useEffect)(() => {\n committed.current = cache;\n\n if (prevCache == initial) {\n initial.inputs = initial.result = undefined;\n }\n }, [cache]);\n return cache.result;\n}\n\nfunction areInputsEqual(next, prev) {\n if (next.length !== prev.length) {\n return false;\n }\n\n for (let i = 0; i < next.length; i++) {\n if (next[i] !== prev[i]) {\n return false;\n }\n }\n\n return true;\n}\n\nconst useOnce = effect => (0,external_React_.useEffect)(effect, emptyDeps);\nconst emptyDeps = [];\n\nfunction usePrev(value) {\n const prevRef = (0,external_React_.useRef)();\n (0,external_React_.useEffect)(() => {\n prevRef.current = value;\n });\n return prevRef.current;\n}\n\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"4813.js","mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACxNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./node_modules/@react-spring/rafz/dist/react-spring-rafz.esm.js?ff52","webpack://blocksyOptions/./node_modules/@react-spring/shared/dist/react-spring-shared.esm.js?9c45"],"sourcesContent":["let updateQueue = makeQueue();\nconst raf = fn => schedule(fn, updateQueue);\nlet writeQueue = makeQueue();\n\nraf.write = fn => schedule(fn, writeQueue);\n\nlet onStartQueue = makeQueue();\n\nraf.onStart = fn => schedule(fn, onStartQueue);\n\nlet onFrameQueue = makeQueue();\n\nraf.onFrame = fn => schedule(fn, onFrameQueue);\n\nlet onFinishQueue = makeQueue();\n\nraf.onFinish = fn => schedule(fn, onFinishQueue);\n\nlet timeouts = [];\n\nraf.setTimeout = (handler, ms) => {\n  let time = raf.now() + ms;\n\n  let cancel = () => {\n    let i = timeouts.findIndex(t => t.cancel == cancel);\n    if (~i) timeouts.splice(i, 1);\n    pendingCount -= ~i ? 1 : 0;\n  };\n\n  let timeout = {\n    time,\n    handler,\n    cancel\n  };\n  timeouts.splice(findTimeout(time), 0, timeout);\n  pendingCount += 1;\n  start();\n  return timeout;\n};\n\nlet findTimeout = time => ~(~timeouts.findIndex(t => t.time > time) || ~timeouts.length);\n\nraf.cancel = fn => {\n  onStartQueue.delete(fn);\n  onFrameQueue.delete(fn);\n  updateQueue.delete(fn);\n  writeQueue.delete(fn);\n  onFinishQueue.delete(fn);\n};\n\nraf.sync = fn => {\n  sync = true;\n  raf.batchedUpdates(fn);\n  sync = false;\n};\n\nraf.throttle = fn => {\n  let lastArgs;\n\n  function queuedFn() {\n    try {\n      fn(...lastArgs);\n    } finally {\n      lastArgs = null;\n    }\n  }\n\n  function throttled(...args) {\n    lastArgs = args;\n    raf.onStart(queuedFn);\n  }\n\n  throttled.handler = fn;\n\n  throttled.cancel = () => {\n    onStartQueue.delete(queuedFn);\n    lastArgs = null;\n  };\n\n  return throttled;\n};\n\nlet nativeRaf = typeof window != 'undefined' ? window.requestAnimationFrame : () => {};\n\nraf.use = impl => nativeRaf = impl;\n\nraf.now = typeof performance != 'undefined' ? () => performance.now() : Date.now;\n\nraf.batchedUpdates = fn => fn();\n\nraf.catch = console.error;\nraf.frameLoop = 'always';\n\nraf.advance = () => {\n  if (raf.frameLoop !== 'demand') {\n    console.warn('Cannot call the manual advancement of rafz whilst frameLoop is not set as demand');\n  } else {\n    update();\n  }\n};\n\nlet ts = -1;\nlet pendingCount = 0;\nlet sync = false;\n\nfunction schedule(fn, queue) {\n  if (sync) {\n    queue.delete(fn);\n    fn(0);\n  } else {\n    queue.add(fn);\n    start();\n  }\n}\n\nfunction start() {\n  if (ts < 0) {\n    ts = 0;\n\n    if (raf.frameLoop !== 'demand') {\n      nativeRaf(loop);\n    }\n  }\n}\n\nfunction stop() {\n  ts = -1;\n}\n\nfunction loop() {\n  if (~ts) {\n    nativeRaf(loop);\n    raf.batchedUpdates(update);\n  }\n}\n\nfunction update() {\n  let prevTs = ts;\n  ts = raf.now();\n  let count = findTimeout(ts);\n\n  if (count) {\n    eachSafely(timeouts.splice(0, count), t => t.handler());\n    pendingCount -= count;\n  }\n\n  onStartQueue.flush();\n  updateQueue.flush(prevTs ? Math.min(64, ts - prevTs) : 16.667);\n  onFrameQueue.flush();\n  writeQueue.flush();\n  onFinishQueue.flush();\n\n  if (!pendingCount) {\n    stop();\n  }\n}\n\nfunction makeQueue() {\n  let next = new Set();\n  let current = next;\n  return {\n    add(fn) {\n      pendingCount += current == next && !next.has(fn) ? 1 : 0;\n      next.add(fn);\n    },\n\n    delete(fn) {\n      pendingCount -= current == next && next.has(fn) ? 1 : 0;\n      return next.delete(fn);\n    },\n\n    flush(arg) {\n      if (current.size) {\n        next = new Set();\n        pendingCount -= current.size;\n        eachSafely(current, fn => fn(arg) && next.add(fn));\n        pendingCount += next.size;\n        current = next;\n      }\n    }\n\n  };\n}\n\nfunction eachSafely(values, each) {\n  values.forEach(value => {\n    try {\n      each(value);\n    } catch (e) {\n      raf.catch(e);\n    }\n  });\n}\n\nconst __raf = {\n  count() {\n    return pendingCount;\n  },\n\n  isRunning() {\n    return ts >= 0;\n  },\n\n  clear() {\n    ts = -1;\n    timeouts = [];\n    onStartQueue = makeQueue();\n    updateQueue = makeQueue();\n    onFrameQueue = makeQueue();\n    writeQueue = makeQueue();\n    onFinishQueue = makeQueue();\n    pendingCount = 0;\n  }\n\n};\n\nexport { __raf, raf };\n","import { raf } from '@react-spring/rafz';\nexport { raf } from '@react-spring/rafz';\nimport * as React from 'react';\nimport { useRef, useState, useEffect } from 'react';\n\nfunction noop() {}\nconst defineHidden = (obj, key, value) => Object.defineProperty(obj, key, {\n  value,\n  writable: true,\n  configurable: true\n});\nconst is = {\n  arr: Array.isArray,\n  obj: a => !!a && a.constructor.name === 'Object',\n  fun: a => typeof a === 'function',\n  str: a => typeof a === 'string',\n  num: a => typeof a === 'number',\n  und: a => a === undefined\n};\nfunction isEqual(a, b) {\n  if (is.arr(a)) {\n    if (!is.arr(b) || a.length !== b.length) return false;\n\n    for (let i = 0; i < a.length; i++) {\n      if (a[i] !== b[i]) return false;\n    }\n\n    return true;\n  }\n\n  return a === b;\n}\nconst each = (obj, fn) => obj.forEach(fn);\nfunction eachProp(obj, fn, ctx) {\n  if (is.arr(obj)) {\n    for (let i = 0; i < obj.length; i++) {\n      fn.call(ctx, obj[i], `${i}`);\n    }\n\n    return;\n  }\n\n  for (const key in obj) {\n    if (obj.hasOwnProperty(key)) {\n      fn.call(ctx, obj[key], key);\n    }\n  }\n}\nconst toArray = a => is.und(a) ? [] : is.arr(a) ? a : [a];\nfunction flush(queue, iterator) {\n  if (queue.size) {\n    const items = Array.from(queue);\n    queue.clear();\n    each(items, iterator);\n  }\n}\nconst flushCalls = (queue, ...args) => flush(queue, fn => fn(...args));\nconst isSSR = () => typeof window === 'undefined' || !window.navigator || /ServerSideRendering|^Deno\\//.test(window.navigator.userAgent);\n\nlet createStringInterpolator$1;\nlet to;\nlet colors$1 = null;\nlet skipAnimation = false;\nlet willAdvance = noop;\nconst assign = globals => {\n  if (globals.to) to = globals.to;\n  if (globals.now) raf.now = globals.now;\n  if (globals.colors !== undefined) colors$1 = globals.colors;\n  if (globals.skipAnimation != null) skipAnimation = globals.skipAnimation;\n  if (globals.createStringInterpolator) createStringInterpolator$1 = globals.createStringInterpolator;\n  if (globals.requestAnimationFrame) raf.use(globals.requestAnimationFrame);\n  if (globals.batchedUpdates) raf.batchedUpdates = globals.batchedUpdates;\n  if (globals.willAdvance) willAdvance = globals.willAdvance;\n  if (globals.frameLoop) raf.frameLoop = globals.frameLoop;\n};\n\nvar globals = /*#__PURE__*/Object.freeze({\n  __proto__: null,\n  get createStringInterpolator () { return createStringInterpolator$1; },\n  get to () { return to; },\n  get colors () { return colors$1; },\n  get skipAnimation () { return skipAnimation; },\n  get willAdvance () { return willAdvance; },\n  assign: assign\n});\n\nconst startQueue = new Set();\nlet currentFrame = [];\nlet prevFrame = [];\nlet priority = 0;\nconst frameLoop = {\n  get idle() {\n    return !startQueue.size && !currentFrame.length;\n  },\n\n  start(animation) {\n    if (priority > animation.priority) {\n      startQueue.add(animation);\n      raf.onStart(flushStartQueue);\n    } else {\n      startSafely(animation);\n      raf(advance);\n    }\n  },\n\n  advance,\n\n  sort(animation) {\n    if (priority) {\n      raf.onFrame(() => frameLoop.sort(animation));\n    } else {\n      const prevIndex = currentFrame.indexOf(animation);\n\n      if (~prevIndex) {\n        currentFrame.splice(prevIndex, 1);\n        startUnsafely(animation);\n      }\n    }\n  },\n\n  clear() {\n    currentFrame = [];\n    startQueue.clear();\n  }\n\n};\n\nfunction flushStartQueue() {\n  startQueue.forEach(startSafely);\n  startQueue.clear();\n  raf(advance);\n}\n\nfunction startSafely(animation) {\n  if (!currentFrame.includes(animation)) startUnsafely(animation);\n}\n\nfunction startUnsafely(animation) {\n  currentFrame.splice(findIndex(currentFrame, other => other.priority > animation.priority), 0, animation);\n}\n\nfunction advance(dt) {\n  const nextFrame = prevFrame;\n\n  for (let i = 0; i < currentFrame.length; i++) {\n    const animation = currentFrame[i];\n    priority = animation.priority;\n\n    if (!animation.idle) {\n      willAdvance(animation);\n      animation.advance(dt);\n\n      if (!animation.idle) {\n        nextFrame.push(animation);\n      }\n    }\n  }\n\n  priority = 0;\n  prevFrame = currentFrame;\n  prevFrame.length = 0;\n  currentFrame = nextFrame;\n  return currentFrame.length > 0;\n}\n\nfunction findIndex(arr, test) {\n  const index = arr.findIndex(test);\n  return index < 0 ? arr.length : index;\n}\n\nconst colors = {\n  transparent: 0x00000000,\n  aliceblue: 0xf0f8ffff,\n  antiquewhite: 0xfaebd7ff,\n  aqua: 0x00ffffff,\n  aquamarine: 0x7fffd4ff,\n  azure: 0xf0ffffff,\n  beige: 0xf5f5dcff,\n  bisque: 0xffe4c4ff,\n  black: 0x000000ff,\n  blanchedalmond: 0xffebcdff,\n  blue: 0x0000ffff,\n  blueviolet: 0x8a2be2ff,\n  brown: 0xa52a2aff,\n  burlywood: 0xdeb887ff,\n  burntsienna: 0xea7e5dff,\n  cadetblue: 0x5f9ea0ff,\n  chartreuse: 0x7fff00ff,\n  chocolate: 0xd2691eff,\n  coral: 0xff7f50ff,\n  cornflowerblue: 0x6495edff,\n  cornsilk: 0xfff8dcff,\n  crimson: 0xdc143cff,\n  cyan: 0x00ffffff,\n  darkblue: 0x00008bff,\n  darkcyan: 0x008b8bff,\n  darkgoldenrod: 0xb8860bff,\n  darkgray: 0xa9a9a9ff,\n  darkgreen: 0x006400ff,\n  darkgrey: 0xa9a9a9ff,\n  darkkhaki: 0xbdb76bff,\n  darkmagenta: 0x8b008bff,\n  darkolivegreen: 0x556b2fff,\n  darkorange: 0xff8c00ff,\n  darkorchid: 0x9932ccff,\n  darkred: 0x8b0000ff,\n  darksalmon: 0xe9967aff,\n  darkseagreen: 0x8fbc8fff,\n  darkslateblue: 0x483d8bff,\n  darkslategray: 0x2f4f4fff,\n  darkslategrey: 0x2f4f4fff,\n  darkturquoise: 0x00ced1ff,\n  darkviolet: 0x9400d3ff,\n  deeppink: 0xff1493ff,\n  deepskyblue: 0x00bfffff,\n  dimgray: 0x696969ff,\n  dimgrey: 0x696969ff,\n  dodgerblue: 0x1e90ffff,\n  firebrick: 0xb22222ff,\n  floralwhite: 0xfffaf0ff,\n  forestgreen: 0x228b22ff,\n  fuchsia: 0xff00ffff,\n  gainsboro: 0xdcdcdcff,\n  ghostwhite: 0xf8f8ffff,\n  gold: 0xffd700ff,\n  goldenrod: 0xdaa520ff,\n  gray: 0x808080ff,\n  green: 0x008000ff,\n  greenyellow: 0xadff2fff,\n  grey: 0x808080ff,\n  honeydew: 0xf0fff0ff,\n  hotpink: 0xff69b4ff,\n  indianred: 0xcd5c5cff,\n  indigo: 0x4b0082ff,\n  ivory: 0xfffff0ff,\n  khaki: 0xf0e68cff,\n  lavender: 0xe6e6faff,\n  lavenderblush: 0xfff0f5ff,\n  lawngreen: 0x7cfc00ff,\n  lemonchiffon: 0xfffacdff,\n  lightblue: 0xadd8e6ff,\n  lightcoral: 0xf08080ff,\n  lightcyan: 0xe0ffffff,\n  lightgoldenrodyellow: 0xfafad2ff,\n  lightgray: 0xd3d3d3ff,\n  lightgreen: 0x90ee90ff,\n  lightgrey: 0xd3d3d3ff,\n  lightpink: 0xffb6c1ff,\n  lightsalmon: 0xffa07aff,\n  lightseagreen: 0x20b2aaff,\n  lightskyblue: 0x87cefaff,\n  lightslategray: 0x778899ff,\n  lightslategrey: 0x778899ff,\n  lightsteelblue: 0xb0c4deff,\n  lightyellow: 0xffffe0ff,\n  lime: 0x00ff00ff,\n  limegreen: 0x32cd32ff,\n  linen: 0xfaf0e6ff,\n  magenta: 0xff00ffff,\n  maroon: 0x800000ff,\n  mediumaquamarine: 0x66cdaaff,\n  mediumblue: 0x0000cdff,\n  mediumorchid: 0xba55d3ff,\n  mediumpurple: 0x9370dbff,\n  mediumseagreen: 0x3cb371ff,\n  mediumslateblue: 0x7b68eeff,\n  mediumspringgreen: 0x00fa9aff,\n  mediumturquoise: 0x48d1ccff,\n  mediumvioletred: 0xc71585ff,\n  midnightblue: 0x191970ff,\n  mintcream: 0xf5fffaff,\n  mistyrose: 0xffe4e1ff,\n  moccasin: 0xffe4b5ff,\n  navajowhite: 0xffdeadff,\n  navy: 0x000080ff,\n  oldlace: 0xfdf5e6ff,\n  olive: 0x808000ff,\n  olivedrab: 0x6b8e23ff,\n  orange: 0xffa500ff,\n  orangered: 0xff4500ff,\n  orchid: 0xda70d6ff,\n  palegoldenrod: 0xeee8aaff,\n  palegreen: 0x98fb98ff,\n  paleturquoise: 0xafeeeeff,\n  palevioletred: 0xdb7093ff,\n  papayawhip: 0xffefd5ff,\n  peachpuff: 0xffdab9ff,\n  peru: 0xcd853fff,\n  pink: 0xffc0cbff,\n  plum: 0xdda0ddff,\n  powderblue: 0xb0e0e6ff,\n  purple: 0x800080ff,\n  rebeccapurple: 0x663399ff,\n  red: 0xff0000ff,\n  rosybrown: 0xbc8f8fff,\n  royalblue: 0x4169e1ff,\n  saddlebrown: 0x8b4513ff,\n  salmon: 0xfa8072ff,\n  sandybrown: 0xf4a460ff,\n  seagreen: 0x2e8b57ff,\n  seashell: 0xfff5eeff,\n  sienna: 0xa0522dff,\n  silver: 0xc0c0c0ff,\n  skyblue: 0x87ceebff,\n  slateblue: 0x6a5acdff,\n  slategray: 0x708090ff,\n  slategrey: 0x708090ff,\n  snow: 0xfffafaff,\n  springgreen: 0x00ff7fff,\n  steelblue: 0x4682b4ff,\n  tan: 0xd2b48cff,\n  teal: 0x008080ff,\n  thistle: 0xd8bfd8ff,\n  tomato: 0xff6347ff,\n  turquoise: 0x40e0d0ff,\n  violet: 0xee82eeff,\n  wheat: 0xf5deb3ff,\n  white: 0xffffffff,\n  whitesmoke: 0xf5f5f5ff,\n  yellow: 0xffff00ff,\n  yellowgreen: 0x9acd32ff\n};\n\nconst NUMBER = '[-+]?\\\\d*\\\\.?\\\\d+';\nconst PERCENTAGE = NUMBER + '%';\n\nfunction call(...parts) {\n  return '\\\\(\\\\s*(' + parts.join(')\\\\s*,\\\\s*(') + ')\\\\s*\\\\)';\n}\n\nconst rgb = new RegExp('rgb' + call(NUMBER, NUMBER, NUMBER));\nconst rgba = new RegExp('rgba' + call(NUMBER, NUMBER, NUMBER, NUMBER));\nconst hsl = new RegExp('hsl' + call(NUMBER, PERCENTAGE, PERCENTAGE));\nconst hsla = new RegExp('hsla' + call(NUMBER, PERCENTAGE, PERCENTAGE, NUMBER));\nconst hex3 = /^#([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/;\nconst hex4 = /^#([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/;\nconst hex6 = /^#([0-9a-fA-F]{6})$/;\nconst hex8 = /^#([0-9a-fA-F]{8})$/;\n\nfunction normalizeColor(color) {\n  let match;\n\n  if (typeof color === 'number') {\n    return color >>> 0 === color && color >= 0 && color <= 0xffffffff ? color : null;\n  }\n\n  if (match = hex6.exec(color)) return parseInt(match[1] + 'ff', 16) >>> 0;\n\n  if (colors$1 && colors$1[color] !== undefined) {\n    return colors$1[color];\n  }\n\n  if (match = rgb.exec(color)) {\n    return (parse255(match[1]) << 24 | parse255(match[2]) << 16 | parse255(match[3]) << 8 | 0x000000ff) >>> 0;\n  }\n\n  if (match = rgba.exec(color)) {\n    return (parse255(match[1]) << 24 | parse255(match[2]) << 16 | parse255(match[3]) << 8 | parse1(match[4])) >>> 0;\n  }\n\n  if (match = hex3.exec(color)) {\n    return parseInt(match[1] + match[1] + match[2] + match[2] + match[3] + match[3] + 'ff', 16) >>> 0;\n  }\n\n  if (match = hex8.exec(color)) return parseInt(match[1], 16) >>> 0;\n\n  if (match = hex4.exec(color)) {\n    return parseInt(match[1] + match[1] + match[2] + match[2] + match[3] + match[3] + match[4] + match[4], 16) >>> 0;\n  }\n\n  if (match = hsl.exec(color)) {\n    return (hslToRgb(parse360(match[1]), parsePercentage(match[2]), parsePercentage(match[3])) | 0x000000ff) >>> 0;\n  }\n\n  if (match = hsla.exec(color)) {\n    return (hslToRgb(parse360(match[1]), parsePercentage(match[2]), parsePercentage(match[3])) | parse1(match[4])) >>> 0;\n  }\n\n  return null;\n}\n\nfunction hue2rgb(p, q, t) {\n  if (t < 0) t += 1;\n  if (t > 1) t -= 1;\n  if (t < 1 / 6) return p + (q - p) * 6 * t;\n  if (t < 1 / 2) return q;\n  if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6;\n  return p;\n}\n\nfunction hslToRgb(h, s, l) {\n  const q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n  const p = 2 * l - q;\n  const r = hue2rgb(p, q, h + 1 / 3);\n  const g = hue2rgb(p, q, h);\n  const b = hue2rgb(p, q, h - 1 / 3);\n  return Math.round(r * 255) << 24 | Math.round(g * 255) << 16 | Math.round(b * 255) << 8;\n}\n\nfunction parse255(str) {\n  const int = parseInt(str, 10);\n  if (int < 0) return 0;\n  if (int > 255) return 255;\n  return int;\n}\n\nfunction parse360(str) {\n  const int = parseFloat(str);\n  return (int % 360 + 360) % 360 / 360;\n}\n\nfunction parse1(str) {\n  const num = parseFloat(str);\n  if (num < 0) return 0;\n  if (num > 1) return 255;\n  return Math.round(num * 255);\n}\n\nfunction parsePercentage(str) {\n  const int = parseFloat(str);\n  if (int < 0) return 0;\n  if (int > 100) return 1;\n  return int / 100;\n}\n\nfunction colorToRgba(input) {\n  let int32Color = normalizeColor(input);\n  if (int32Color === null) return input;\n  int32Color = int32Color || 0;\n  let r = (int32Color & 0xff000000) >>> 24;\n  let g = (int32Color & 0x00ff0000) >>> 16;\n  let b = (int32Color & 0x0000ff00) >>> 8;\n  let a = (int32Color & 0x000000ff) / 255;\n  return `rgba(${r}, ${g}, ${b}, ${a})`;\n}\n\nconst createInterpolator = (range, output, extrapolate) => {\n  if (is.fun(range)) {\n    return range;\n  }\n\n  if (is.arr(range)) {\n    return createInterpolator({\n      range,\n      output: output,\n      extrapolate\n    });\n  }\n\n  if (is.str(range.output[0])) {\n    return createStringInterpolator$1(range);\n  }\n\n  const config = range;\n  const outputRange = config.output;\n  const inputRange = config.range || [0, 1];\n  const extrapolateLeft = config.extrapolateLeft || config.extrapolate || 'extend';\n  const extrapolateRight = config.extrapolateRight || config.extrapolate || 'extend';\n\n  const easing = config.easing || (t => t);\n\n  return input => {\n    const range = findRange(input, inputRange);\n    return interpolate(input, inputRange[range], inputRange[range + 1], outputRange[range], outputRange[range + 1], easing, extrapolateLeft, extrapolateRight, config.map);\n  };\n};\n\nfunction interpolate(input, inputMin, inputMax, outputMin, outputMax, easing, extrapolateLeft, extrapolateRight, map) {\n  let result = map ? map(input) : input;\n\n  if (result < inputMin) {\n    if (extrapolateLeft === 'identity') return result;else if (extrapolateLeft === 'clamp') result = inputMin;\n  }\n\n  if (result > inputMax) {\n    if (extrapolateRight === 'identity') return result;else if (extrapolateRight === 'clamp') result = inputMax;\n  }\n\n  if (outputMin === outputMax) return outputMin;\n  if (inputMin === inputMax) return input <= inputMin ? outputMin : outputMax;\n  if (inputMin === -Infinity) result = -result;else if (inputMax === Infinity) result = result - inputMin;else result = (result - inputMin) / (inputMax - inputMin);\n  result = easing(result);\n  if (outputMin === -Infinity) result = -result;else if (outputMax === Infinity) result = result + outputMin;else result = result * (outputMax - outputMin) + outputMin;\n  return result;\n}\n\nfunction findRange(input, inputRange) {\n  for (var i = 1; i < inputRange.length - 1; ++i) if (inputRange[i] >= input) break;\n\n  return i - 1;\n}\n\nfunction _extends() {\n  _extends = Object.assign || function (target) {\n    for (var i = 1; i < arguments.length; i++) {\n      var source = arguments[i];\n\n      for (var key in source) {\n        if (Object.prototype.hasOwnProperty.call(source, key)) {\n          target[key] = source[key];\n        }\n      }\n    }\n\n    return target;\n  };\n\n  return _extends.apply(this, arguments);\n}\n\nconst $get = Symbol.for('FluidValue.get');\nconst $observers = Symbol.for('FluidValue.observers');\n\nconst hasFluidValue = arg => Boolean(arg && arg[$get]);\n\nconst getFluidValue = arg => arg && arg[$get] ? arg[$get]() : arg;\n\nconst getFluidObservers = target => target[$observers] || null;\n\nfunction callFluidObserver(observer, event) {\n  if (observer.eventObserved) {\n    observer.eventObserved(event);\n  } else {\n    observer(event);\n  }\n}\n\nfunction callFluidObservers(target, event) {\n  let observers = target[$observers];\n\n  if (observers) {\n    observers.forEach(observer => {\n      callFluidObserver(observer, event);\n    });\n  }\n}\n\nclass FluidValue {\n  constructor(get) {\n    this[$get] = void 0;\n    this[$observers] = void 0;\n\n    if (!get && !(get = this.get)) {\n      throw Error('Unknown getter');\n    }\n\n    setFluidGetter(this, get);\n  }\n\n}\n\nconst setFluidGetter = (target, get) => setHidden(target, $get, get);\n\nfunction addFluidObserver(target, observer) {\n  if (target[$get]) {\n    let observers = target[$observers];\n\n    if (!observers) {\n      setHidden(target, $observers, observers = new Set());\n    }\n\n    if (!observers.has(observer)) {\n      observers.add(observer);\n\n      if (target.observerAdded) {\n        target.observerAdded(observers.size, observer);\n      }\n    }\n  }\n\n  return observer;\n}\n\nfunction removeFluidObserver(target, observer) {\n  let observers = target[$observers];\n\n  if (observers && observers.has(observer)) {\n    const count = observers.size - 1;\n\n    if (count) {\n      observers.delete(observer);\n    } else {\n      target[$observers] = null;\n    }\n\n    if (target.observerRemoved) {\n      target.observerRemoved(count, observer);\n    }\n  }\n}\n\nconst setHidden = (target, key, value) => Object.defineProperty(target, key, {\n  value,\n  writable: true,\n  configurable: true\n});\n\nconst numberRegex = /[+\\-]?(?:0|[1-9]\\d*)(?:\\.\\d*)?(?:[eE][+\\-]?\\d+)?/g;\nconst colorRegex = /(#(?:[0-9a-f]{2}){2,4}|(#[0-9a-f]{3})|(rgb|hsl)a?\\((-?\\d+%?[,\\s]+){2,3}\\s*[\\d\\.]+%?\\))/gi;\nconst unitRegex = new RegExp(`(${numberRegex.source})(%|[a-z]+)`, 'i');\nconst rgbaRegex = /rgba\\(([0-9\\.-]+), ([0-9\\.-]+), ([0-9\\.-]+), ([0-9\\.-]+)\\)/gi;\nconst cssVariableRegex = /var\\((--[a-zA-Z0-9-_]+),? ?([a-zA-Z0-9 ()%#.,-]+)?\\)/;\n\nconst variableToRgba = input => {\n  const [token, fallback] = parseCSSVariable(input);\n\n  if (!token || isSSR()) {\n    return input;\n  }\n\n  const value = window.getComputedStyle(document.documentElement).getPropertyValue(token);\n\n  if (value) {\n    return value.trim();\n  } else if (fallback && fallback.startsWith('--')) {\n    const _value = window.getComputedStyle(document.documentElement).getPropertyValue(fallback);\n\n    if (_value) {\n      return _value;\n    } else {\n      return input;\n    }\n  } else if (fallback && cssVariableRegex.test(fallback)) {\n    return variableToRgba(fallback);\n  } else if (fallback) {\n    return fallback;\n  }\n\n  return input;\n};\n\nconst parseCSSVariable = current => {\n  const match = cssVariableRegex.exec(current);\n  if (!match) return [,];\n  const [, token, fallback] = match;\n  return [token, fallback];\n};\n\nlet namedColorRegex;\n\nconst rgbaRound = (_, p1, p2, p3, p4) => `rgba(${Math.round(p1)}, ${Math.round(p2)}, ${Math.round(p3)}, ${p4})`;\n\nconst createStringInterpolator = config => {\n  if (!namedColorRegex) namedColorRegex = colors$1 ? new RegExp(`(${Object.keys(colors$1).join('|')})(?!\\\\w)`, 'g') : /^\\b$/;\n  const output = config.output.map(value => {\n    return getFluidValue(value).replace(cssVariableRegex, variableToRgba).replace(colorRegex, colorToRgba).replace(namedColorRegex, colorToRgba);\n  });\n  const keyframes = output.map(value => value.match(numberRegex).map(Number));\n  const outputRanges = keyframes[0].map((_, i) => keyframes.map(values => {\n    if (!(i in values)) {\n      throw Error('The arity of each \"output\" value must be equal');\n    }\n\n    return values[i];\n  }));\n  const interpolators = outputRanges.map(output => createInterpolator(_extends({}, config, {\n    output\n  })));\n  return input => {\n    var _output$find;\n\n    const missingUnit = !unitRegex.test(output[0]) && ((_output$find = output.find(value => unitRegex.test(value))) == null ? void 0 : _output$find.replace(numberRegex, ''));\n    let i = 0;\n    return output[0].replace(numberRegex, () => `${interpolators[i++](input)}${missingUnit || ''}`).replace(rgbaRegex, rgbaRound);\n  };\n};\n\nconst prefix = 'react-spring: ';\n\nconst once = fn => {\n  const func = fn;\n  let called = false;\n\n  if (typeof func != 'function') {\n    throw new TypeError(`${prefix}once requires a function parameter`);\n  }\n\n  return (...args) => {\n    if (!called) {\n      func(...args);\n      called = true;\n    }\n  };\n};\n\nconst warnInterpolate = once(console.warn);\nfunction deprecateInterpolate() {\n  warnInterpolate(`${prefix}The \"interpolate\" function is deprecated in v9 (use \"to\" instead)`);\n}\nconst warnDirectCall = once(console.warn);\nfunction deprecateDirectCall() {\n  warnDirectCall(`${prefix}Directly calling start instead of using the api object is deprecated in v9 (use \".start\" instead), this will be removed in later 0.X.0 versions`);\n}\n\nfunction isAnimatedString(value) {\n  return is.str(value) && (value[0] == '#' || /\\d/.test(value) || !isSSR() && cssVariableRegex.test(value) || value in (colors$1 || {}));\n}\n\nconst useLayoutEffect = typeof window !== 'undefined' && window.document && window.document.createElement ? React.useLayoutEffect : React.useEffect;\n\nconst useIsMounted = () => {\n  const isMounted = useRef(false);\n  useLayoutEffect(() => {\n    isMounted.current = true;\n    return () => {\n      isMounted.current = false;\n    };\n  }, []);\n  return isMounted;\n};\n\nfunction useForceUpdate() {\n  const update = useState()[1];\n  const isMounted = useIsMounted();\n  return () => {\n    if (isMounted.current) {\n      update(Math.random());\n    }\n  };\n}\n\nfunction useMemoOne(getResult, inputs) {\n  const [initial] = useState(() => ({\n    inputs,\n    result: getResult()\n  }));\n  const committed = useRef();\n  const prevCache = committed.current;\n  let cache = prevCache;\n\n  if (cache) {\n    const useCache = Boolean(inputs && cache.inputs && areInputsEqual(inputs, cache.inputs));\n\n    if (!useCache) {\n      cache = {\n        inputs,\n        result: getResult()\n      };\n    }\n  } else {\n    cache = initial;\n  }\n\n  useEffect(() => {\n    committed.current = cache;\n\n    if (prevCache == initial) {\n      initial.inputs = initial.result = undefined;\n    }\n  }, [cache]);\n  return cache.result;\n}\n\nfunction areInputsEqual(next, prev) {\n  if (next.length !== prev.length) {\n    return false;\n  }\n\n  for (let i = 0; i < next.length; i++) {\n    if (next[i] !== prev[i]) {\n      return false;\n    }\n  }\n\n  return true;\n}\n\nconst useOnce = effect => useEffect(effect, emptyDeps);\nconst emptyDeps = [];\n\nfunction usePrev(value) {\n  const prevRef = useRef();\n  useEffect(() => {\n    prevRef.current = value;\n  });\n  return prevRef.current;\n}\n\nexport { FluidValue, globals as Globals, addFluidObserver, callFluidObserver, callFluidObservers, colorToRgba, colors, createInterpolator, createStringInterpolator, defineHidden, deprecateDirectCall, deprecateInterpolate, each, eachProp, flush, flushCalls, frameLoop, getFluidObservers, getFluidValue, hasFluidValue, hex3, hex4, hex6, hex8, hsl, hsla, is, isAnimatedString, isEqual, isSSR, noop, removeFluidObserver, rgb, rgba, setFluidGetter, toArray, useForceUpdate, useLayoutEffect, useMemoOne, useOnce, usePrev };\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///4813\n")},1472:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"Transition\": () => (/* reexport safe */ _react_spring_core__WEBPACK_IMPORTED_MODULE_0__.Transition),\n/* harmony export */ \"animated\": () => (/* binding */ animated)\n/* harmony export */ });\n/* unused harmony export a */\n/* harmony import */ var _react_spring_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(4928);\n/* harmony import */ var react_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(1533);\n/* harmony import */ var react_dom__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(react_dom__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _react_spring_shared__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(4813);\n/* harmony import */ var _react_spring_animated__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(1314);\n\n\n\n\n\n\nfunction _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n\n return target;\n}\n\nconst _excluded$2 = [\"style\", \"children\", \"scrollTop\", \"scrollLeft\"];\nconst isCustomPropRE = /^--/;\n\nfunction dangerousStyleValue(name, value) {\n if (value == null || typeof value === 'boolean' || value === '') return '';\n if (typeof value === 'number' && value !== 0 && !isCustomPropRE.test(name) && !(isUnitlessNumber.hasOwnProperty(name) && isUnitlessNumber[name])) return value + 'px';\n return ('' + value).trim();\n}\n\nconst attributeCache = {};\nfunction applyAnimatedValues(instance, props) {\n if (!instance.nodeType || !instance.setAttribute) {\n return false;\n }\n\n const isFilterElement = instance.nodeName === 'filter' || instance.parentNode && instance.parentNode.nodeName === 'filter';\n\n const _ref = props,\n {\n style,\n children,\n scrollTop,\n scrollLeft\n } = _ref,\n attributes = _objectWithoutPropertiesLoose(_ref, _excluded$2);\n\n const values = Object.values(attributes);\n const names = Object.keys(attributes).map(name => isFilterElement || instance.hasAttribute(name) ? name : attributeCache[name] || (attributeCache[name] = name.replace(/([A-Z])/g, n => '-' + n.toLowerCase())));\n\n if (children !== void 0) {\n instance.textContent = children;\n }\n\n for (let name in style) {\n if (style.hasOwnProperty(name)) {\n const value = dangerousStyleValue(name, style[name]);\n\n if (isCustomPropRE.test(name)) {\n instance.style.setProperty(name, value);\n } else {\n instance.style[name] = value;\n }\n }\n }\n\n names.forEach((name, i) => {\n instance.setAttribute(name, values[i]);\n });\n\n if (scrollTop !== void 0) {\n instance.scrollTop = scrollTop;\n }\n\n if (scrollLeft !== void 0) {\n instance.scrollLeft = scrollLeft;\n }\n}\nlet isUnitlessNumber = {\n animationIterationCount: true,\n borderImageOutset: true,\n borderImageSlice: true,\n borderImageWidth: true,\n boxFlex: true,\n boxFlexGroup: true,\n boxOrdinalGroup: true,\n columnCount: true,\n columns: true,\n flex: true,\n flexGrow: true,\n flexPositive: true,\n flexShrink: true,\n flexNegative: true,\n flexOrder: true,\n gridRow: true,\n gridRowEnd: true,\n gridRowSpan: true,\n gridRowStart: true,\n gridColumn: true,\n gridColumnEnd: true,\n gridColumnSpan: true,\n gridColumnStart: true,\n fontWeight: true,\n lineClamp: true,\n lineHeight: true,\n opacity: true,\n order: true,\n orphans: true,\n tabSize: true,\n widows: true,\n zIndex: true,\n zoom: true,\n fillOpacity: true,\n floodOpacity: true,\n stopOpacity: true,\n strokeDasharray: true,\n strokeDashoffset: true,\n strokeMiterlimit: true,\n strokeOpacity: true,\n strokeWidth: true\n};\n\nconst prefixKey = (prefix, key) => prefix + key.charAt(0).toUpperCase() + key.substring(1);\n\nconst prefixes = ['Webkit', 'Ms', 'Moz', 'O'];\nisUnitlessNumber = Object.keys(isUnitlessNumber).reduce((acc, prop) => {\n prefixes.forEach(prefix => acc[prefixKey(prefix, prop)] = acc[prop]);\n return acc;\n}, isUnitlessNumber);\n\nconst _excluded$1 = [\"x\", \"y\", \"z\"];\nconst domTransforms = /^(matrix|translate|scale|rotate|skew)/;\nconst pxTransforms = /^(translate)/;\nconst degTransforms = /^(rotate|skew)/;\n\nconst addUnit = (value, unit) => _react_spring_shared__WEBPACK_IMPORTED_MODULE_2__.is.num(value) && value !== 0 ? value + unit : value;\n\nconst isValueIdentity = (value, id) => _react_spring_shared__WEBPACK_IMPORTED_MODULE_2__.is.arr(value) ? value.every(v => isValueIdentity(v, id)) : _react_spring_shared__WEBPACK_IMPORTED_MODULE_2__.is.num(value) ? value === id : parseFloat(value) === id;\n\nclass AnimatedStyle extends _react_spring_animated__WEBPACK_IMPORTED_MODULE_3__/* .AnimatedObject */ .rS {\n constructor(_ref) {\n let {\n x,\n y,\n z\n } = _ref,\n style = _objectWithoutPropertiesLoose(_ref, _excluded$1);\n\n const inputs = [];\n const transforms = [];\n\n if (x || y || z) {\n inputs.push([x || 0, y || 0, z || 0]);\n transforms.push(xyz => [`translate3d(${xyz.map(v => addUnit(v, 'px')).join(',')})`, isValueIdentity(xyz, 0)]);\n }\n\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_2__/* .eachProp */ .rU)(style, (value, key) => {\n if (key === 'transform') {\n inputs.push([value || '']);\n transforms.push(transform => [transform, transform === '']);\n } else if (domTransforms.test(key)) {\n delete style[key];\n if (_react_spring_shared__WEBPACK_IMPORTED_MODULE_2__.is.und(value)) return;\n const unit = pxTransforms.test(key) ? 'px' : degTransforms.test(key) ? 'deg' : '';\n inputs.push((0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_2__/* .toArray */ .qo)(value));\n transforms.push(key === 'rotate3d' ? ([x, y, z, deg]) => [`rotate3d(${x},${y},${z},${addUnit(deg, unit)})`, isValueIdentity(deg, 0)] : input => [`${key}(${input.map(v => addUnit(v, unit)).join(',')})`, isValueIdentity(input, key.startsWith('scale') ? 1 : 0)]);\n }\n });\n\n if (inputs.length) {\n style.transform = new FluidTransform(inputs, transforms);\n }\n\n super(style);\n }\n\n}\n\nclass FluidTransform extends _react_spring_shared__WEBPACK_IMPORTED_MODULE_2__/* .FluidValue */ .B0 {\n constructor(inputs, transforms) {\n super();\n this._value = null;\n this.inputs = inputs;\n this.transforms = transforms;\n }\n\n get() {\n return this._value || (this._value = this._get());\n }\n\n _get() {\n let transform = '';\n let identity = true;\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_2__/* .each */ .S6)(this.inputs, (input, i) => {\n const arg1 = (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_2__/* .getFluidValue */ .je)(input[0]);\n const [t, id] = this.transforms[i](_react_spring_shared__WEBPACK_IMPORTED_MODULE_2__.is.arr(arg1) ? arg1 : input.map(_react_spring_shared__WEBPACK_IMPORTED_MODULE_2__/* .getFluidValue */ .je));\n transform += ' ' + t;\n identity = identity && id;\n });\n return identity ? 'none' : transform;\n }\n\n observerAdded(count) {\n if (count == 1) (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_2__/* .each */ .S6)(this.inputs, input => (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_2__/* .each */ .S6)(input, value => (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_2__/* .hasFluidValue */ .j$)(value) && (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_2__/* .addFluidObserver */ .UI)(value, this)));\n }\n\n observerRemoved(count) {\n if (count == 0) (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_2__/* .each */ .S6)(this.inputs, input => (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_2__/* .each */ .S6)(input, value => (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_2__/* .hasFluidValue */ .j$)(value) && (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_2__/* .removeFluidObserver */ .iL)(value, this)));\n }\n\n eventObserved(event) {\n if (event.type == 'change') {\n this._value = null;\n }\n\n (0,_react_spring_shared__WEBPACK_IMPORTED_MODULE_2__/* .callFluidObservers */ .k0)(this, event);\n }\n\n}\n\nconst primitives = ['a', 'abbr', 'address', 'area', 'article', 'aside', 'audio', 'b', 'base', 'bdi', 'bdo', 'big', 'blockquote', 'body', 'br', 'button', 'canvas', 'caption', 'cite', 'code', 'col', 'colgroup', 'data', 'datalist', 'dd', 'del', 'details', 'dfn', 'dialog', 'div', 'dl', 'dt', 'em', 'embed', 'fieldset', 'figcaption', 'figure', 'footer', 'form', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'head', 'header', 'hgroup', 'hr', 'html', 'i', 'iframe', 'img', 'input', 'ins', 'kbd', 'keygen', 'label', 'legend', 'li', 'link', 'main', 'map', 'mark', 'menu', 'menuitem', 'meta', 'meter', 'nav', 'noscript', 'object', 'ol', 'optgroup', 'option', 'output', 'p', 'param', 'picture', 'pre', 'progress', 'q', 'rp', 'rt', 'ruby', 's', 'samp', 'script', 'section', 'select', 'small', 'source', 'span', 'strong', 'style', 'sub', 'summary', 'sup', 'table', 'tbody', 'td', 'textarea', 'tfoot', 'th', 'thead', 'time', 'title', 'tr', 'track', 'u', 'ul', 'var', 'video', 'wbr', 'circle', 'clipPath', 'defs', 'ellipse', 'foreignObject', 'g', 'image', 'line', 'linearGradient', 'mask', 'path', 'pattern', 'polygon', 'polyline', 'radialGradient', 'rect', 'stop', 'svg', 'text', 'tspan'];\n\nconst _excluded = [\"scrollTop\", \"scrollLeft\"];\n_react_spring_core__WEBPACK_IMPORTED_MODULE_0__.Globals.assign({\n batchedUpdates: react_dom__WEBPACK_IMPORTED_MODULE_1__.unstable_batchedUpdates,\n createStringInterpolator: _react_spring_shared__WEBPACK_IMPORTED_MODULE_2__/* .createStringInterpolator */ .qS,\n colors: _react_spring_shared__WEBPACK_IMPORTED_MODULE_2__/* .colors */ .O9\n});\nconst host = (0,_react_spring_animated__WEBPACK_IMPORTED_MODULE_3__/* .createHost */ .Ld)(primitives, {\n applyAnimatedValues,\n createAnimatedStyle: style => new AnimatedStyle(style),\n getComponentProps: _ref => {\n let props = _objectWithoutPropertiesLoose(_ref, _excluded);\n\n return props;\n }\n});\nconst animated = host.animated;\n\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"1472.js","mappings":";;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./node_modules/@react-spring/web/dist/react-spring-web.esm.js?f835"],"sourcesContent":["import { Globals } from '@react-spring/core';\nexport * from '@react-spring/core';\nimport { unstable_batchedUpdates } from 'react-dom';\nimport { eachProp, is, toArray, FluidValue, each, getFluidValue, hasFluidValue, addFluidObserver, removeFluidObserver, callFluidObservers, createStringInterpolator, colors } from '@react-spring/shared';\nimport { AnimatedObject, createHost } from '@react-spring/animated';\n\nfunction _objectWithoutPropertiesLoose(source, excluded) {\n  if (source == null) return {};\n  var target = {};\n  var sourceKeys = Object.keys(source);\n  var key, i;\n\n  for (i = 0; i < sourceKeys.length; i++) {\n    key = sourceKeys[i];\n    if (excluded.indexOf(key) >= 0) continue;\n    target[key] = source[key];\n  }\n\n  return target;\n}\n\nconst _excluded$2 = [\"style\", \"children\", \"scrollTop\", \"scrollLeft\"];\nconst isCustomPropRE = /^--/;\n\nfunction dangerousStyleValue(name, value) {\n  if (value == null || typeof value === 'boolean' || value === '') return '';\n  if (typeof value === 'number' && value !== 0 && !isCustomPropRE.test(name) && !(isUnitlessNumber.hasOwnProperty(name) && isUnitlessNumber[name])) return value + 'px';\n  return ('' + value).trim();\n}\n\nconst attributeCache = {};\nfunction applyAnimatedValues(instance, props) {\n  if (!instance.nodeType || !instance.setAttribute) {\n    return false;\n  }\n\n  const isFilterElement = instance.nodeName === 'filter' || instance.parentNode && instance.parentNode.nodeName === 'filter';\n\n  const _ref = props,\n        {\n    style,\n    children,\n    scrollTop,\n    scrollLeft\n  } = _ref,\n        attributes = _objectWithoutPropertiesLoose(_ref, _excluded$2);\n\n  const values = Object.values(attributes);\n  const names = Object.keys(attributes).map(name => isFilterElement || instance.hasAttribute(name) ? name : attributeCache[name] || (attributeCache[name] = name.replace(/([A-Z])/g, n => '-' + n.toLowerCase())));\n\n  if (children !== void 0) {\n    instance.textContent = children;\n  }\n\n  for (let name in style) {\n    if (style.hasOwnProperty(name)) {\n      const value = dangerousStyleValue(name, style[name]);\n\n      if (isCustomPropRE.test(name)) {\n        instance.style.setProperty(name, value);\n      } else {\n        instance.style[name] = value;\n      }\n    }\n  }\n\n  names.forEach((name, i) => {\n    instance.setAttribute(name, values[i]);\n  });\n\n  if (scrollTop !== void 0) {\n    instance.scrollTop = scrollTop;\n  }\n\n  if (scrollLeft !== void 0) {\n    instance.scrollLeft = scrollLeft;\n  }\n}\nlet isUnitlessNumber = {\n  animationIterationCount: true,\n  borderImageOutset: true,\n  borderImageSlice: true,\n  borderImageWidth: true,\n  boxFlex: true,\n  boxFlexGroup: true,\n  boxOrdinalGroup: true,\n  columnCount: true,\n  columns: true,\n  flex: true,\n  flexGrow: true,\n  flexPositive: true,\n  flexShrink: true,\n  flexNegative: true,\n  flexOrder: true,\n  gridRow: true,\n  gridRowEnd: true,\n  gridRowSpan: true,\n  gridRowStart: true,\n  gridColumn: true,\n  gridColumnEnd: true,\n  gridColumnSpan: true,\n  gridColumnStart: true,\n  fontWeight: true,\n  lineClamp: true,\n  lineHeight: true,\n  opacity: true,\n  order: true,\n  orphans: true,\n  tabSize: true,\n  widows: true,\n  zIndex: true,\n  zoom: true,\n  fillOpacity: true,\n  floodOpacity: true,\n  stopOpacity: true,\n  strokeDasharray: true,\n  strokeDashoffset: true,\n  strokeMiterlimit: true,\n  strokeOpacity: true,\n  strokeWidth: true\n};\n\nconst prefixKey = (prefix, key) => prefix + key.charAt(0).toUpperCase() + key.substring(1);\n\nconst prefixes = ['Webkit', 'Ms', 'Moz', 'O'];\nisUnitlessNumber = Object.keys(isUnitlessNumber).reduce((acc, prop) => {\n  prefixes.forEach(prefix => acc[prefixKey(prefix, prop)] = acc[prop]);\n  return acc;\n}, isUnitlessNumber);\n\nconst _excluded$1 = [\"x\", \"y\", \"z\"];\nconst domTransforms = /^(matrix|translate|scale|rotate|skew)/;\nconst pxTransforms = /^(translate)/;\nconst degTransforms = /^(rotate|skew)/;\n\nconst addUnit = (value, unit) => is.num(value) && value !== 0 ? value + unit : value;\n\nconst isValueIdentity = (value, id) => is.arr(value) ? value.every(v => isValueIdentity(v, id)) : is.num(value) ? value === id : parseFloat(value) === id;\n\nclass AnimatedStyle extends AnimatedObject {\n  constructor(_ref) {\n    let {\n      x,\n      y,\n      z\n    } = _ref,\n        style = _objectWithoutPropertiesLoose(_ref, _excluded$1);\n\n    const inputs = [];\n    const transforms = [];\n\n    if (x || y || z) {\n      inputs.push([x || 0, y || 0, z || 0]);\n      transforms.push(xyz => [`translate3d(${xyz.map(v => addUnit(v, 'px')).join(',')})`, isValueIdentity(xyz, 0)]);\n    }\n\n    eachProp(style, (value, key) => {\n      if (key === 'transform') {\n        inputs.push([value || '']);\n        transforms.push(transform => [transform, transform === '']);\n      } else if (domTransforms.test(key)) {\n        delete style[key];\n        if (is.und(value)) return;\n        const unit = pxTransforms.test(key) ? 'px' : degTransforms.test(key) ? 'deg' : '';\n        inputs.push(toArray(value));\n        transforms.push(key === 'rotate3d' ? ([x, y, z, deg]) => [`rotate3d(${x},${y},${z},${addUnit(deg, unit)})`, isValueIdentity(deg, 0)] : input => [`${key}(${input.map(v => addUnit(v, unit)).join(',')})`, isValueIdentity(input, key.startsWith('scale') ? 1 : 0)]);\n      }\n    });\n\n    if (inputs.length) {\n      style.transform = new FluidTransform(inputs, transforms);\n    }\n\n    super(style);\n  }\n\n}\n\nclass FluidTransform extends FluidValue {\n  constructor(inputs, transforms) {\n    super();\n    this._value = null;\n    this.inputs = inputs;\n    this.transforms = transforms;\n  }\n\n  get() {\n    return this._value || (this._value = this._get());\n  }\n\n  _get() {\n    let transform = '';\n    let identity = true;\n    each(this.inputs, (input, i) => {\n      const arg1 = getFluidValue(input[0]);\n      const [t, id] = this.transforms[i](is.arr(arg1) ? arg1 : input.map(getFluidValue));\n      transform += ' ' + t;\n      identity = identity && id;\n    });\n    return identity ? 'none' : transform;\n  }\n\n  observerAdded(count) {\n    if (count == 1) each(this.inputs, input => each(input, value => hasFluidValue(value) && addFluidObserver(value, this)));\n  }\n\n  observerRemoved(count) {\n    if (count == 0) each(this.inputs, input => each(input, value => hasFluidValue(value) && removeFluidObserver(value, this)));\n  }\n\n  eventObserved(event) {\n    if (event.type == 'change') {\n      this._value = null;\n    }\n\n    callFluidObservers(this, event);\n  }\n\n}\n\nconst primitives = ['a', 'abbr', 'address', 'area', 'article', 'aside', 'audio', 'b', 'base', 'bdi', 'bdo', 'big', 'blockquote', 'body', 'br', 'button', 'canvas', 'caption', 'cite', 'code', 'col', 'colgroup', 'data', 'datalist', 'dd', 'del', 'details', 'dfn', 'dialog', 'div', 'dl', 'dt', 'em', 'embed', 'fieldset', 'figcaption', 'figure', 'footer', 'form', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'head', 'header', 'hgroup', 'hr', 'html', 'i', 'iframe', 'img', 'input', 'ins', 'kbd', 'keygen', 'label', 'legend', 'li', 'link', 'main', 'map', 'mark', 'menu', 'menuitem', 'meta', 'meter', 'nav', 'noscript', 'object', 'ol', 'optgroup', 'option', 'output', 'p', 'param', 'picture', 'pre', 'progress', 'q', 'rp', 'rt', 'ruby', 's', 'samp', 'script', 'section', 'select', 'small', 'source', 'span', 'strong', 'style', 'sub', 'summary', 'sup', 'table', 'tbody', 'td', 'textarea', 'tfoot', 'th', 'thead', 'time', 'title', 'tr', 'track', 'u', 'ul', 'var', 'video', 'wbr', 'circle', 'clipPath', 'defs', 'ellipse', 'foreignObject', 'g', 'image', 'line', 'linearGradient', 'mask', 'path', 'pattern', 'polygon', 'polyline', 'radialGradient', 'rect', 'stop', 'svg', 'text', 'tspan'];\n\nconst _excluded = [\"scrollTop\", \"scrollLeft\"];\nGlobals.assign({\n  batchedUpdates: unstable_batchedUpdates,\n  createStringInterpolator,\n  colors\n});\nconst host = createHost(primitives, {\n  applyAnimatedValues,\n  createAnimatedStyle: style => new AnimatedStyle(style),\n  getComponentProps: _ref => {\n    let props = _objectWithoutPropertiesLoose(_ref, _excluded);\n\n    return props;\n  }\n});\nconst animated = host.animated;\n\nexport { animated as a, animated };\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///1472\n")},454:module=>{"use strict";eval('\n\nconst arrayMoveMutate = (array, from, to) => {\n\tconst startIndex = to < 0 ? array.length + to : to;\n\tconst item = array.splice(from, 1)[0];\n\tarray.splice(startIndex, 0, item);\n};\n\nconst arrayMove = (array, from, to) => {\n\tarray = array.slice();\n\tarrayMoveMutate(array, from, to);\n\treturn array;\n};\n\nmodule.exports = arrayMove;\n// TODO: Remove this for the next major release\nmodule.exports["default"] = arrayMove;\n\nmodule.exports.mutate = arrayMoveMutate;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNDU0LmpzIiwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9ub2RlX21vZHVsZXMvYXJyYXktbW92ZS9pbmRleC5qcz9jMThjIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY29uc3QgYXJyYXlNb3ZlTXV0YXRlID0gKGFycmF5LCBmcm9tLCB0bykgPT4ge1xuXHRjb25zdCBzdGFydEluZGV4ID0gdG8gPCAwID8gYXJyYXkubGVuZ3RoICsgdG8gOiB0bztcblx0Y29uc3QgaXRlbSA9IGFycmF5LnNwbGljZShmcm9tLCAxKVswXTtcblx0YXJyYXkuc3BsaWNlKHN0YXJ0SW5kZXgsIDAsIGl0ZW0pO1xufTtcblxuY29uc3QgYXJyYXlNb3ZlID0gKGFycmF5LCBmcm9tLCB0bykgPT4ge1xuXHRhcnJheSA9IGFycmF5LnNsaWNlKCk7XG5cdGFycmF5TW92ZU11dGF0ZShhcnJheSwgZnJvbSwgdG8pO1xuXHRyZXR1cm4gYXJyYXk7XG59O1xuXG5tb2R1bGUuZXhwb3J0cyA9IGFycmF5TW92ZTtcbi8vIFRPRE86IFJlbW92ZSB0aGlzIGZvciB0aGUgbmV4dCBtYWpvciByZWxlYXNlXG5tb2R1bGUuZXhwb3J0cy5kZWZhdWx0ID0gYXJyYXlNb3ZlO1xuXG5tb2R1bGUuZXhwb3J0cy5tdXRhdGUgPSBhcnJheU1vdmVNdXRhdGU7XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///454\n')},7136:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n "Z": () => (/* binding */ components_Overlay)\n});\n\n// EXTERNAL MODULE: external "window.wp.element"\nvar external_window_wp_element_ = __webpack_require__(1381);\n// EXTERNAL MODULE: external "React"\nvar external_React_ = __webpack_require__(7363);\nvar external_React_default = /*#__PURE__*/__webpack_require__.n(external_React_);\n;// CONCATENATED MODULE: ./node_modules/@reach/component-component/es/index.js\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn\'t been initialised - super() hasn\'t been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nfunction _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }\n\n\n\n\nvar cleanProps = function cleanProps(props) {\n var initialState = props.initialState,\n getInitialState = props.getInitialState,\n refs = props.refs,\n getRefs = props.getRefs,\n didMount = props.didMount,\n didUpdate = props.didUpdate,\n willUnmount = props.willUnmount,\n getSnapshotBeforeUpdate = props.getSnapshotBeforeUpdate,\n shouldUpdate = props.shouldUpdate,\n render = props.render,\n rest = _objectWithoutProperties(props, ["initialState", "getInitialState", "refs", "getRefs", "didMount", "didUpdate", "willUnmount", "getSnapshotBeforeUpdate", "shouldUpdate", "render"]);\n\n return rest;\n};\n\nvar Component = function (_React$Component) {\n _inherits(Component, _React$Component);\n\n function Component() {\n var _temp, _this, _ret;\n\n _classCallCheck(this, Component);\n\n for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return _ret = (_temp = (_this = _possibleConstructorReturn(this, _React$Component.call.apply(_React$Component, [this].concat(args))), _this), _initialiseProps.call(_this), _temp), _possibleConstructorReturn(_this, _ret);\n }\n\n Component.prototype.getArgs = function getArgs() {\n var state = this.state,\n props = this.props,\n setState = this._setState,\n forceUpdate = this._forceUpdate,\n refs = this._refs;\n\n return {\n state: state,\n props: cleanProps(props),\n refs: refs,\n setState: setState,\n forceUpdate: forceUpdate\n };\n };\n\n Component.prototype.componentDidMount = function componentDidMount() {\n if (this.props.didMount) this.props.didMount(this.getArgs());\n };\n\n Component.prototype.shouldComponentUpdate = function shouldComponentUpdate(nextProps, nextState) {\n if (this.props.shouldUpdate) return this.props.shouldUpdate({\n props: this.props,\n state: this.state,\n nextProps: cleanProps(nextProps),\n nextState: nextState\n });else return true;\n };\n\n Component.prototype.componentWillUnmount = function componentWillUnmount() {\n if (this.props.willUnmount) this.props.willUnmount({\n state: this.state,\n props: cleanProps(this.props),\n refs: this._refs\n });\n };\n\n Component.prototype.componentDidUpdate = function componentDidUpdate(prevProps, prevState, snapshot) {\n if (this.props.didUpdate) this.props.didUpdate(Object.assign(this.getArgs(), {\n prevProps: cleanProps(prevProps),\n prevState: prevState\n }), snapshot);\n };\n\n Component.prototype.getSnapshotBeforeUpdate = function getSnapshotBeforeUpdate(prevProps, prevState) {\n if (this.props.getSnapshotBeforeUpdate) {\n return this.props.getSnapshotBeforeUpdate(Object.assign(this.getArgs(), {\n prevProps: cleanProps(prevProps),\n prevState: prevState\n }));\n } else {\n return null;\n }\n };\n\n Component.prototype.render = function render() {\n var _props = this.props,\n children = _props.children,\n render = _props.render;\n\n return render ? render(this.getArgs()) : typeof children === "function" ? children(this.getArgs()) : children || null;\n };\n\n return Component;\n}((external_React_default()).Component);\n\nComponent.defaultProps = {\n getInitialState: function getInitialState() {},\n getRefs: function getRefs() {\n return {};\n }\n};\n\nvar _initialiseProps = function _initialiseProps() {\n var _this2 = this;\n\n this.state = this.props.initialState || this.props.getInitialState(this.props);\n this._refs = this.props.refs || this.props.getRefs(this.getArgs());\n\n this._setState = function () {\n return _this2.setState.apply(_this2, arguments);\n };\n\n this._forceUpdate = function () {\n return _this2.forceUpdate.apply(_this2, arguments);\n };\n};\n\n false ? 0 : void 0;\n\n\n/* harmony default export */ const es = (Component);\n;// CONCATENATED MODULE: ./static/js/customizer/components/reach/portal.js\n\n\n\nlet Portal = _ref => {\n let {\n children,\n container = document.body,\n type = \'reach-portal\'\n } = _ref;\n return (0,external_window_wp_element_.createElement)(es, {\n getRefs: () => ({\n node: null\n }),\n didMount: _ref2 => {\n let {\n refs,\n forceUpdate\n } = _ref2;\n let containerNode = container.hasOwnProperty(\'current\') ? container.current : container;\n refs.node = document.createElement(type);\n containerNode.appendChild(refs.node);\n forceUpdate();\n },\n willUnmount: _ref3 => {\n let {\n refs: {\n node\n }\n } = _ref3;\n let containerNode = container.hasOwnProperty(\'current\') ? container.current : container;\n\n if (containerNode) {\n containerNode.removeChild(node);\n }\n },\n render: _ref4 => {\n let {\n refs: {\n node\n }\n } = _ref4;\n return node ? (0,external_window_wp_element_.createPortal)(children, node) : null;\n }\n });\n};\n\n/* harmony default export */ const portal = (Portal);\n;// CONCATENATED MODULE: ./node_modules/@reach/utils/es/index.js\nvar checkedPkgs = {};\n\nvar checkStyles = function checkStyles() {};\n\nif (false) {}\n\n\n\nvar wrapEvent = function wrapEvent(theirHandler, ourHandler) {\n return function (event) {\n theirHandler && theirHandler(event);\n if (!event.defaultPrevented) {\n return ourHandler(event);\n }\n };\n};\n\nvar assignRef = function assignRef(ref, value) {\n if (ref == null) return;\n if (typeof ref === "function") {\n ref(value);\n } else {\n try {\n ref.current = value;\n } catch (error) {\n throw new Error("Cannot assign value \\"" + value + "\\" to ref \\"" + ref + "\\"");\n }\n }\n};\n// EXTERNAL MODULE: ./node_modules/focus-trap/index.js\nvar focus_trap = __webpack_require__(3172);\nvar focus_trap_default = /*#__PURE__*/__webpack_require__.n(focus_trap);\n;// CONCATENATED MODULE: ./static/js/customizer/components/reach/dialog.js\nconst _excluded = ["container", "isOpen", "onDismiss", "initialFocusRef", "onClick", "onKeyDown"],\n _excluded2 = ["onClick", "onKeyDown"],\n _excluded3 = (/* unused pure expression or super */ null && (["container", "isOpen", "onDismiss"]));\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction dialog_objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\n\n\n\n\n\n\nlet createAriaHider = dialogNode => {\n let originalValues = [];\n let rootNodes = [];\n Array.prototype.forEach.call(document.querySelectorAll(\'body > *\'), node => {\n if (node === dialogNode.parentNode) {\n return;\n }\n\n let attr = node.getAttribute(\'aria-hidden\');\n let alreadyHidden = attr !== null && attr !== \'false\';\n\n if (alreadyHidden) {\n return;\n }\n\n originalValues.push(attr);\n rootNodes.push(node);\n node.setAttribute(\'aria-hidden\', \'true\');\n });\n return () => {\n rootNodes.forEach((node, index) => {\n let originalValue = originalValues[index];\n\n if (originalValue === null) {\n node.removeAttribute(\'aria-hidden\');\n } else {\n node.setAttribute(\'aria-hidden\', originalValue);\n }\n });\n };\n};\n\nlet k = () => {};\n\nlet checkDialogStyles = () => checkStyles(\'dialog\');\n\nlet portalDidMount = (refs, initialFocusRef) => {\n refs.disposeAriaHider = createAriaHider(refs.overlayNode);\n refs.trap = focus_trap_default()(refs.overlayNode, {\n initialFocus: initialFocusRef ? () => initialFocusRef.current : undefined,\n fallbackFocus: refs.contentNode,\n escapeDeactivates: false,\n clickOutsideDeactivates: false\n }); // refs.trap.activate()\n};\n\nlet contentWillUnmount = _ref => {\n let {\n refs\n } = _ref;\n refs.trap.deactivate();\n refs.disposeAriaHider();\n};\n\nlet FocusContext = React.createContext();\nlet DialogOverlay = React.forwardRef((_ref2, forwardRef) => {\n let {\n container,\n isOpen = true,\n onDismiss = k,\n initialFocusRef,\n onClick,\n onKeyDown\n } = _ref2,\n props = dialog_objectWithoutProperties(_ref2, _excluded);\n\n return (0,external_window_wp_element_.createElement)(es, {\n didMount: checkDialogStyles\n }, isOpen ? (0,external_window_wp_element_.createElement)(portal, {\n container: container,\n "data-reach-dialog-wrapper": true\n }, (0,external_window_wp_element_.createElement)(es, {\n refs: {\n overlayNode: null,\n contentNode: null\n },\n didMount: _ref3 => {\n let {\n refs\n } = _ref3;\n portalDidMount(refs, initialFocusRef);\n },\n willUnmount: contentWillUnmount\n }, _ref4 => {\n let {\n refs\n } = _ref4;\n return (0,external_window_wp_element_.createElement)(FocusContext.Provider, {\n value: node => refs.contentNode = node\n }, (0,external_window_wp_element_.createElement)("div", _extends({\n "data-reach-dialog-overlay": true,\n onClick: wrapEvent(onClick, event => {\n event.stopPropagation();\n onDismiss();\n }),\n onKeyDown: wrapEvent(onKeyDown, event => {\n if (event.key === \'Escape\') {\n event.stopPropagation();\n onDismiss();\n }\n }),\n ref: node => {\n refs.overlayNode = node;\n forwardRef && forwardRef(node);\n }\n }, props)));\n })) : null);\n});\nDialogOverlay.propTypes = {\n initialFocusRef: () => {}\n};\n\nlet stopPropagation = event => event.stopPropagation();\n\nlet DialogContent = React.forwardRef((_ref5, forwardRef) => {\n let {\n onClick,\n onKeyDown\n } = _ref5,\n props = dialog_objectWithoutProperties(_ref5, _excluded2);\n\n return (0,external_window_wp_element_.createElement)(FocusContext.Consumer, null, contentRef => (0,external_window_wp_element_.createElement)("div", _extends({\n "aria-modal": "true",\n "data-reach-dialog-content": true,\n tabIndex: "-1",\n onClick: wrapEvent(onClick, stopPropagation),\n ref: node => {\n contentRef(node);\n forwardRef && forwardRef(node);\n }\n }, props)));\n});\n\nlet Dialog = _ref6 => {\n let {\n container,\n isOpen,\n onDismiss = k\n } = _ref6,\n props = dialog_objectWithoutProperties(_ref6, _excluded3);\n\n return createElement(DialogOverlay, {\n container: container,\n isOpen: isOpen,\n onDismiss: onDismiss\n }, createElement(DialogContent, props));\n};\n\n\n// EXTERNAL MODULE: ./node_modules/react-spring/renderprops.js\nvar renderprops = __webpack_require__(4823);\n// EXTERNAL MODULE: external "window.wp.i18n"\nvar external_window_wp_i18n_ = __webpack_require__(5652);\n// EXTERNAL MODULE: ./node_modules/classnames/index.js\nvar classnames = __webpack_require__(4184);\n;// CONCATENATED MODULE: ./static/js/customizer/components/Overlay.js\n\n\n\n\n\n\nconst defaultIsVisible = i => !!i;\n\nconst Overlay = _ref => {\n let {\n items,\n isVisible = defaultIsVisible,\n render,\n className,\n initialFocusRef,\n onDismiss\n } = _ref;\n return (0,external_window_wp_element_.createElement)(renderprops/* Transition */.uT, {\n items: items,\n onStart: () => document.body.classList[isVisible(items) ? \'add\' : \'remove\'](\'ct-dashboard-overlay-open\'),\n config: {\n duration: 200\n },\n from: {\n opacity: 0,\n y: -10\n },\n enter: {\n opacity: 1,\n y: 0\n },\n leave: {\n opacity: 0,\n y: 10\n }\n }, items => isVisible(items) && (props => (0,external_window_wp_element_.createElement)(DialogOverlay, {\n style: {\n opacity: props.opacity\n },\n container: document.body,\n onDismiss: () => onDismiss(),\n initialFocusRef: initialFocusRef\n }, (0,external_window_wp_element_.createElement)(DialogContent, {\n className: className,\n style: {\n transform: `translate3d(0px, ${props.y}px, 0px)`\n }\n }, (0,external_window_wp_element_.createElement)("button", {\n className: "close-button",\n onClick: () => onDismiss()\n }, "\\xD7"), render(items, props)))));\n};\n\n/* harmony default export */ const components_Overlay = (Overlay);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"7136.js","mappings":";;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAaA;AACA;AACA;;ACjJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9CA;AACA;AACA;AACA;AACA;AAWA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACtCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACnKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./node_modules/@reach/component-component/es/index.js?0643","webpack://blocksyOptions/./static/js/customizer/components/reach/portal.js?60f9","webpack://blocksyOptions/./node_modules/@reach/utils/es/index.js?5e8f","webpack://blocksyOptions/./static/js/customizer/components/reach/dialog.js?0cca","webpack://blocksyOptions/./static/js/customizer/components/Overlay.js?cb00"],"sourcesContent":["function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nfunction _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }\n\nimport React from \"react\";\nimport { object, func, oneOfType, node } from \"prop-types\";\n\nvar cleanProps = function cleanProps(props) {\n  var initialState = props.initialState,\n      getInitialState = props.getInitialState,\n      refs = props.refs,\n      getRefs = props.getRefs,\n      didMount = props.didMount,\n      didUpdate = props.didUpdate,\n      willUnmount = props.willUnmount,\n      getSnapshotBeforeUpdate = props.getSnapshotBeforeUpdate,\n      shouldUpdate = props.shouldUpdate,\n      render = props.render,\n      rest = _objectWithoutProperties(props, [\"initialState\", \"getInitialState\", \"refs\", \"getRefs\", \"didMount\", \"didUpdate\", \"willUnmount\", \"getSnapshotBeforeUpdate\", \"shouldUpdate\", \"render\"]);\n\n  return rest;\n};\n\nvar Component = function (_React$Component) {\n  _inherits(Component, _React$Component);\n\n  function Component() {\n    var _temp, _this, _ret;\n\n    _classCallCheck(this, Component);\n\n    for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    return _ret = (_temp = (_this = _possibleConstructorReturn(this, _React$Component.call.apply(_React$Component, [this].concat(args))), _this), _initialiseProps.call(_this), _temp), _possibleConstructorReturn(_this, _ret);\n  }\n\n  Component.prototype.getArgs = function getArgs() {\n    var state = this.state,\n        props = this.props,\n        setState = this._setState,\n        forceUpdate = this._forceUpdate,\n        refs = this._refs;\n\n    return {\n      state: state,\n      props: cleanProps(props),\n      refs: refs,\n      setState: setState,\n      forceUpdate: forceUpdate\n    };\n  };\n\n  Component.prototype.componentDidMount = function componentDidMount() {\n    if (this.props.didMount) this.props.didMount(this.getArgs());\n  };\n\n  Component.prototype.shouldComponentUpdate = function shouldComponentUpdate(nextProps, nextState) {\n    if (this.props.shouldUpdate) return this.props.shouldUpdate({\n      props: this.props,\n      state: this.state,\n      nextProps: cleanProps(nextProps),\n      nextState: nextState\n    });else return true;\n  };\n\n  Component.prototype.componentWillUnmount = function componentWillUnmount() {\n    if (this.props.willUnmount) this.props.willUnmount({\n      state: this.state,\n      props: cleanProps(this.props),\n      refs: this._refs\n    });\n  };\n\n  Component.prototype.componentDidUpdate = function componentDidUpdate(prevProps, prevState, snapshot) {\n    if (this.props.didUpdate) this.props.didUpdate(Object.assign(this.getArgs(), {\n      prevProps: cleanProps(prevProps),\n      prevState: prevState\n    }), snapshot);\n  };\n\n  Component.prototype.getSnapshotBeforeUpdate = function getSnapshotBeforeUpdate(prevProps, prevState) {\n    if (this.props.getSnapshotBeforeUpdate) {\n      return this.props.getSnapshotBeforeUpdate(Object.assign(this.getArgs(), {\n        prevProps: cleanProps(prevProps),\n        prevState: prevState\n      }));\n    } else {\n      return null;\n    }\n  };\n\n  Component.prototype.render = function render() {\n    var _props = this.props,\n        children = _props.children,\n        render = _props.render;\n\n    return render ? render(this.getArgs()) : typeof children === \"function\" ? children(this.getArgs()) : children || null;\n  };\n\n  return Component;\n}(React.Component);\n\nComponent.defaultProps = {\n  getInitialState: function getInitialState() {},\n  getRefs: function getRefs() {\n    return {};\n  }\n};\n\nvar _initialiseProps = function _initialiseProps() {\n  var _this2 = this;\n\n  this.state = this.props.initialState || this.props.getInitialState(this.props);\n  this._refs = this.props.refs || this.props.getRefs(this.getArgs());\n\n  this._setState = function () {\n    return _this2.setState.apply(_this2, arguments);\n  };\n\n  this._forceUpdate = function () {\n    return _this2.forceUpdate.apply(_this2, arguments);\n  };\n};\n\nprocess.env.NODE_ENV !== \"production\" ? Component.propTypes = {\n  initialState: object,\n  getInitialState: func,\n  refs: object,\n  getRefs: func,\n  didMount: func,\n  didUpdate: func,\n  willUnmount: func,\n  getSnapshotBeforeUpdate: func,\n  shouldUpdate: func,\n  render: func,\n  children: oneOfType([func, node])\n} : void 0;\n\n\nexport default Component;","import { createElement, useEffect, createPortal, useState, Fragment } from '@wordpress/element';\nimport Component from '@reach/component-component';\n\nlet Portal = _ref => {\n  let {\n    children,\n    container = document.body,\n    type = 'reach-portal'\n  } = _ref;\n  return createElement(Component, {\n    getRefs: () => ({\n      node: null\n    }),\n    didMount: _ref2 => {\n      let {\n        refs,\n        forceUpdate\n      } = _ref2;\n      let containerNode = container.hasOwnProperty('current') ? container.current : container;\n      refs.node = document.createElement(type);\n      containerNode.appendChild(refs.node);\n      forceUpdate();\n    },\n    willUnmount: _ref3 => {\n      let {\n        refs: {\n          node\n        }\n      } = _ref3;\n      let containerNode = container.hasOwnProperty('current') ? container.current : container;\n\n      if (containerNode) {\n        containerNode.removeChild(node);\n      }\n    },\n    render: _ref4 => {\n      let {\n        refs: {\n          node\n        }\n      } = _ref4;\n      return node ? createPortal(children, node) : null;\n    }\n  });\n};\n\nexport default Portal;","var checkedPkgs = {};\n\nvar checkStyles = function checkStyles() {};\n\nif (process.env.NODE_ENV !== \"production\") {\n  checkStyles = function checkStyles(pkg) {\n    // only check once per package\n    if (checkedPkgs[pkg]) return;\n    checkedPkgs[pkg] = true;\n\n    if (parseInt(window.getComputedStyle(document.body).getPropertyValue(\"--reach-\" + pkg), 10) !== 1) {\n      console.warn(\"@reach/\" + pkg + \" styles not found. If you are using a bundler like webpack or parcel include this in the entry file of your app before any of your own styles:\\n\\n    import \\\"@reach/\" + pkg + \"/styles.css\\\";\\n\\n  Otherwise you'll need to include them some other way:\\n\\n    <link rel=\\\"stylesheet\\\" type=\\\"text/css\\\" href=\\\"node_modules/@reach/\" + pkg + \"/styles.css\\\" />\\n\\n  For more information visit https://ui.reach.tech/styling.\\n  \");\n    }\n  };\n}\n\nexport { checkStyles };\n\nexport var wrapEvent = function wrapEvent(theirHandler, ourHandler) {\n  return function (event) {\n    theirHandler && theirHandler(event);\n    if (!event.defaultPrevented) {\n      return ourHandler(event);\n    }\n  };\n};\n\nexport var assignRef = function assignRef(ref, value) {\n  if (ref == null) return;\n  if (typeof ref === \"function\") {\n    ref(value);\n  } else {\n    try {\n      ref.current = value;\n    } catch (error) {\n      throw new Error(\"Cannot assign value \\\"\" + value + \"\\\" to ref \\\"\" + ref + \"\\\"\");\n    }\n  }\n};","const _excluded = [\"container\", \"isOpen\", \"onDismiss\", \"initialFocusRef\", \"onClick\", \"onKeyDown\"],\n      _excluded2 = [\"onClick\", \"onKeyDown\"],\n      _excluded3 = [\"container\", \"isOpen\", \"onDismiss\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport Component from '@reach/component-component';\nimport Portal from './portal';\nimport { checkStyles, wrapEvent } from '@reach/utils';\nimport createFocusTrap from 'focus-trap';\nimport { createElement, useEffect, useState, Fragment } from '@wordpress/element';\n\nlet createAriaHider = dialogNode => {\n  let originalValues = [];\n  let rootNodes = [];\n  Array.prototype.forEach.call(document.querySelectorAll('body > *'), node => {\n    if (node === dialogNode.parentNode) {\n      return;\n    }\n\n    let attr = node.getAttribute('aria-hidden');\n    let alreadyHidden = attr !== null && attr !== 'false';\n\n    if (alreadyHidden) {\n      return;\n    }\n\n    originalValues.push(attr);\n    rootNodes.push(node);\n    node.setAttribute('aria-hidden', 'true');\n  });\n  return () => {\n    rootNodes.forEach((node, index) => {\n      let originalValue = originalValues[index];\n\n      if (originalValue === null) {\n        node.removeAttribute('aria-hidden');\n      } else {\n        node.setAttribute('aria-hidden', originalValue);\n      }\n    });\n  };\n};\n\nlet k = () => {};\n\nlet checkDialogStyles = () => checkStyles('dialog');\n\nlet portalDidMount = (refs, initialFocusRef) => {\n  refs.disposeAriaHider = createAriaHider(refs.overlayNode);\n  refs.trap = createFocusTrap(refs.overlayNode, {\n    initialFocus: initialFocusRef ? () => initialFocusRef.current : undefined,\n    fallbackFocus: refs.contentNode,\n    escapeDeactivates: false,\n    clickOutsideDeactivates: false\n  }); // refs.trap.activate()\n};\n\nlet contentWillUnmount = _ref => {\n  let {\n    refs\n  } = _ref;\n  refs.trap.deactivate();\n  refs.disposeAriaHider();\n};\n\nlet FocusContext = React.createContext();\nlet DialogOverlay = React.forwardRef((_ref2, forwardRef) => {\n  let {\n    container,\n    isOpen = true,\n    onDismiss = k,\n    initialFocusRef,\n    onClick,\n    onKeyDown\n  } = _ref2,\n      props = _objectWithoutProperties(_ref2, _excluded);\n\n  return createElement(Component, {\n    didMount: checkDialogStyles\n  }, isOpen ? createElement(Portal, {\n    container: container,\n    \"data-reach-dialog-wrapper\": true\n  }, createElement(Component, {\n    refs: {\n      overlayNode: null,\n      contentNode: null\n    },\n    didMount: _ref3 => {\n      let {\n        refs\n      } = _ref3;\n      portalDidMount(refs, initialFocusRef);\n    },\n    willUnmount: contentWillUnmount\n  }, _ref4 => {\n    let {\n      refs\n    } = _ref4;\n    return createElement(FocusContext.Provider, {\n      value: node => refs.contentNode = node\n    }, createElement(\"div\", _extends({\n      \"data-reach-dialog-overlay\": true,\n      onClick: wrapEvent(onClick, event => {\n        event.stopPropagation();\n        onDismiss();\n      }),\n      onKeyDown: wrapEvent(onKeyDown, event => {\n        if (event.key === 'Escape') {\n          event.stopPropagation();\n          onDismiss();\n        }\n      }),\n      ref: node => {\n        refs.overlayNode = node;\n        forwardRef && forwardRef(node);\n      }\n    }, props)));\n  })) : null);\n});\nDialogOverlay.propTypes = {\n  initialFocusRef: () => {}\n};\n\nlet stopPropagation = event => event.stopPropagation();\n\nlet DialogContent = React.forwardRef((_ref5, forwardRef) => {\n  let {\n    onClick,\n    onKeyDown\n  } = _ref5,\n      props = _objectWithoutProperties(_ref5, _excluded2);\n\n  return createElement(FocusContext.Consumer, null, contentRef => createElement(\"div\", _extends({\n    \"aria-modal\": \"true\",\n    \"data-reach-dialog-content\": true,\n    tabIndex: \"-1\",\n    onClick: wrapEvent(onClick, stopPropagation),\n    ref: node => {\n      contentRef(node);\n      forwardRef && forwardRef(node);\n    }\n  }, props)));\n});\n\nlet Dialog = _ref6 => {\n  let {\n    container,\n    isOpen,\n    onDismiss = k\n  } = _ref6,\n      props = _objectWithoutProperties(_ref6, _excluded3);\n\n  return createElement(DialogOverlay, {\n    container: container,\n    isOpen: isOpen,\n    onDismiss: onDismiss\n  }, createElement(DialogContent, props));\n};\n\nexport { DialogOverlay, DialogContent, Dialog };","import { createElement, Component, useEffect, useState, useContext, createContext, Fragment } from '@wordpress/element';\nimport { Dialog, DialogOverlay, DialogContent } from './reach/dialog';\nimport { Transition } from 'react-spring/renderprops';\nimport { __ } from 'ct-i18n';\nimport classnames from 'classnames';\n\nconst defaultIsVisible = i => !!i;\n\nconst Overlay = _ref => {\n  let {\n    items,\n    isVisible = defaultIsVisible,\n    render,\n    className,\n    initialFocusRef,\n    onDismiss\n  } = _ref;\n  return createElement(Transition, {\n    items: items,\n    onStart: () => document.body.classList[isVisible(items) ? 'add' : 'remove']('ct-dashboard-overlay-open'),\n    config: {\n      duration: 200\n    },\n    from: {\n      opacity: 0,\n      y: -10\n    },\n    enter: {\n      opacity: 1,\n      y: 0\n    },\n    leave: {\n      opacity: 0,\n      y: 10\n    }\n  }, items => isVisible(items) && (props => createElement(DialogOverlay, {\n    style: {\n      opacity: props.opacity\n    },\n    container: document.body,\n    onDismiss: () => onDismiss(),\n    initialFocusRef: initialFocusRef\n  }, createElement(DialogContent, {\n    className: className,\n    style: {\n      transform: `translate3d(0px, ${props.y}px, 0px)`\n    }\n  }, createElement(\"button\", {\n    className: \"close-button\",\n    onClick: () => onDismiss()\n  }, \"\\xD7\"), render(items, props)))));\n};\n\nexport default Overlay;"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///7136\n')},4616:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"Oi\": () => (/* binding */ getValueForDevice),\n/* harmony export */ \"S0\": () => (/* binding */ isOptionEnabledFor),\n/* harmony export */ \"T\": () => (/* reexport safe */ customizer_sync_helpers_dist_promote_into_responsive__WEBPACK_IMPORTED_MODULE_2__.T),\n/* harmony export */ \"W\": () => (/* binding */ isOptionResponsiveFor),\n/* harmony export */ \"ZP\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(4184);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var customizer_sync_helpers_dist_promote_into_responsive__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(600);\n/* harmony import */ var _options_GenericOptionType__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(6095);\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n/**\n * true\n * false\n * skip\n */\n\nconst isOptionEnabledFor = (currentDevice, responsiveDescriptor) => _objectSpread({\n desktop: true,\n tablet: true,\n mobile: true\n}, typeof responsiveDescriptor === 'boolean' ? {} : responsiveDescriptor || {})[currentDevice];\nconst isOptionResponsiveFor = function (option) {\n let args = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n let {\n ignoreHidden = false\n } = args;\n let OptionComponent = (0,_options_GenericOptionType__WEBPACK_IMPORTED_MODULE_3__/* .getOptionFor */ .fg)(option);\n\n if (OptionComponent.hiddenResponsive) {\n if (!ignoreHidden) {\n return true;\n }\n }\n\n return !!option.responsive;\n};\nconst getValueForDevice = _ref => {\n let {\n value,\n option,\n device\n } = _ref;\n const devices = ['desktop', 'tablet', 'mobile'];\n\n if (device === 'tablet' && isOptionEnabledFor(device, option.responsive) === 'skip') {\n return value.mobile;\n }\n\n return value[device];\n};\n\nconst ResponsiveControls = _ref2 => {\n let {\n device,\n setDevice,\n responsiveDescriptor\n } = _ref2;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", {\n className: \"ct-control-options\"\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"ul\", {\n className: \"ct-responsive-controls ct-devices\"\n }, ['desktop', 'tablet', 'mobile'].filter(d => isOptionEnabledFor(d, responsiveDescriptor) !== 'skip').map(d => (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"li\", {\n onClick: () => setDevice(d),\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()({\n active: d === device,\n 'ct-disabled': !isOptionEnabledFor(d, responsiveDescriptor)\n }, `ct-${d}`),\n key: d\n }))));\n};\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (ResponsiveControls);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNDYxNi5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7O0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9zdGF0aWMvanMvY3VzdG9taXplci9jb21wb25lbnRzL3Jlc3BvbnNpdmUtY29udHJvbHMuanM/MjZmOCJdLCJzb3VyY2VzQ29udGVudCI6WyJmdW5jdGlvbiBvd25LZXlzKG9iamVjdCwgZW51bWVyYWJsZU9ubHkpIHsgdmFyIGtleXMgPSBPYmplY3Qua2V5cyhvYmplY3QpOyBpZiAoT2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9scykgeyB2YXIgc3ltYm9scyA9IE9iamVjdC5nZXRPd25Qcm9wZXJ0eVN5bWJvbHMob2JqZWN0KTsgZW51bWVyYWJsZU9ubHkgJiYgKHN5bWJvbHMgPSBzeW1ib2xzLmZpbHRlcihmdW5jdGlvbiAoc3ltKSB7IHJldHVybiBPYmplY3QuZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9yKG9iamVjdCwgc3ltKS5lbnVtZXJhYmxlOyB9KSksIGtleXMucHVzaC5hcHBseShrZXlzLCBzeW1ib2xzKTsgfSByZXR1cm4ga2V5czsgfVxuXG5mdW5jdGlvbiBfb2JqZWN0U3ByZWFkKHRhcmdldCkgeyBmb3IgKHZhciBpID0gMTsgaSA8IGFyZ3VtZW50cy5sZW5ndGg7IGkrKykgeyB2YXIgc291cmNlID0gbnVsbCAhPSBhcmd1bWVudHNbaV0gPyBhcmd1bWVudHNbaV0gOiB7fTsgaSAlIDIgPyBvd25LZXlzKE9iamVjdChzb3VyY2UpLCAhMCkuZm9yRWFjaChmdW5jdGlvbiAoa2V5KSB7IF9kZWZpbmVQcm9wZXJ0eSh0YXJnZXQsIGtleSwgc291cmNlW2tleV0pOyB9KSA6IE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3JzID8gT2JqZWN0LmRlZmluZVByb3BlcnRpZXModGFyZ2V0LCBPYmplY3QuZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9ycyhzb3VyY2UpKSA6IG93bktleXMoT2JqZWN0KHNvdXJjZSkpLmZvckVhY2goZnVuY3Rpb24gKGtleSkgeyBPYmplY3QuZGVmaW5lUHJvcGVydHkodGFyZ2V0LCBrZXksIE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3Ioc291cmNlLCBrZXkpKTsgfSk7IH0gcmV0dXJuIHRhcmdldDsgfVxuXG5mdW5jdGlvbiBfZGVmaW5lUHJvcGVydHkob2JqLCBrZXksIHZhbHVlKSB7IGlmIChrZXkgaW4gb2JqKSB7IE9iamVjdC5kZWZpbmVQcm9wZXJ0eShvYmosIGtleSwgeyB2YWx1ZTogdmFsdWUsIGVudW1lcmFibGU6IHRydWUsIGNvbmZpZ3VyYWJsZTogdHJ1ZSwgd3JpdGFibGU6IHRydWUgfSk7IH0gZWxzZSB7IG9ialtrZXldID0gdmFsdWU7IH0gcmV0dXJuIG9iajsgfVxuXG5pbXBvcnQgeyBjcmVhdGVFbGVtZW50LCBDb21wb25lbnQsIEZyYWdtZW50IH0gZnJvbSAnQHdvcmRwcmVzcy9lbGVtZW50JztcbmltcG9ydCBjbGFzc25hbWVzIGZyb20gJ2NsYXNzbmFtZXMnO1xuZXhwb3J0IHsgbWF5YmVQcm9tb3RlU2NhbGFyVmFsdWVJbnRvUmVzcG9uc2l2ZSB9IGZyb20gJ2N1c3RvbWl6ZXItc3luYy1oZWxwZXJzL2Rpc3QvcHJvbW90ZS1pbnRvLXJlc3BvbnNpdmUnO1xuaW1wb3J0IHsgZ2V0T3B0aW9uRm9yIH0gZnJvbSAnLi4vLi4vb3B0aW9ucy9HZW5lcmljT3B0aW9uVHlwZSc7XG4vKipcbiAqIHRydWVcbiAqIGZhbHNlXG4gKiBza2lwXG4gKi9cblxuZXhwb3J0IGNvbnN0IGlzT3B0aW9uRW5hYmxlZEZvciA9IChjdXJyZW50RGV2aWNlLCByZXNwb25zaXZlRGVzY3JpcHRvcikgPT4gX29iamVjdFNwcmVhZCh7XG4gIGRlc2t0b3A6IHRydWUsXG4gIHRhYmxldDogdHJ1ZSxcbiAgbW9iaWxlOiB0cnVlXG59LCB0eXBlb2YgcmVzcG9uc2l2ZURlc2NyaXB0b3IgPT09ICdib29sZWFuJyA/IHt9IDogcmVzcG9uc2l2ZURlc2NyaXB0b3IgfHwge30pW2N1cnJlbnREZXZpY2VdO1xuZXhwb3J0IGNvbnN0IGlzT3B0aW9uUmVzcG9uc2l2ZUZvciA9IGZ1bmN0aW9uIChvcHRpb24pIHtcbiAgbGV0IGFyZ3MgPSBhcmd1bWVudHMubGVuZ3RoID4gMSAmJiBhcmd1bWVudHNbMV0gIT09IHVuZGVmaW5lZCA/IGFyZ3VtZW50c1sxXSA6IHt9O1xuICBsZXQge1xuICAgIGlnbm9yZUhpZGRlbiA9IGZhbHNlXG4gIH0gPSBhcmdzO1xuICBsZXQgT3B0aW9uQ29tcG9uZW50ID0gZ2V0T3B0aW9uRm9yKG9wdGlvbik7XG5cbiAgaWYgKE9wdGlvbkNvbXBvbmVudC5oaWRkZW5SZXNwb25zaXZlKSB7XG4gICAgaWYgKCFpZ25vcmVIaWRkZW4pIHtcbiAgICAgIHJldHVybiB0cnVlO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiAhIW9wdGlvbi5yZXNwb25zaXZlO1xufTtcbmV4cG9ydCBjb25zdCBnZXRWYWx1ZUZvckRldmljZSA9IF9yZWYgPT4ge1xuICBsZXQge1xuICAgIHZhbHVlLFxuICAgIG9wdGlvbixcbiAgICBkZXZpY2VcbiAgfSA9IF9yZWY7XG4gIGNvbnN0IGRldmljZXMgPSBbJ2Rlc2t0b3AnLCAndGFibGV0JywgJ21vYmlsZSddO1xuXG4gIGlmIChkZXZpY2UgPT09ICd0YWJsZXQnICYmIGlzT3B0aW9uRW5hYmxlZEZvcihkZXZpY2UsIG9wdGlvbi5yZXNwb25zaXZlKSA9PT0gJ3NraXAnKSB7XG4gICAgcmV0dXJuIHZhbHVlLm1vYmlsZTtcbiAgfVxuXG4gIHJldHVybiB2YWx1ZVtkZXZpY2VdO1xufTtcblxuY29uc3QgUmVzcG9uc2l2ZUNvbnRyb2xzID0gX3JlZjIgPT4ge1xuICBsZXQge1xuICAgIGRldmljZSxcbiAgICBzZXREZXZpY2UsXG4gICAgcmVzcG9uc2l2ZURlc2NyaXB0b3JcbiAgfSA9IF9yZWYyO1xuICByZXR1cm4gY3JlYXRlRWxlbWVudChcImRpdlwiLCB7XG4gICAgY2xhc3NOYW1lOiBcImN0LWNvbnRyb2wtb3B0aW9uc1wiXG4gIH0sIGNyZWF0ZUVsZW1lbnQoXCJ1bFwiLCB7XG4gICAgY2xhc3NOYW1lOiBcImN0LXJlc3BvbnNpdmUtY29udHJvbHMgY3QtZGV2aWNlc1wiXG4gIH0sIFsnZGVza3RvcCcsICd0YWJsZXQnLCAnbW9iaWxlJ10uZmlsdGVyKGQgPT4gaXNPcHRpb25FbmFibGVkRm9yKGQsIHJlc3BvbnNpdmVEZXNjcmlwdG9yKSAhPT0gJ3NraXAnKS5tYXAoZCA9PiBjcmVhdGVFbGVtZW50KFwibGlcIiwge1xuICAgIG9uQ2xpY2s6ICgpID0+IHNldERldmljZShkKSxcbiAgICBjbGFzc05hbWU6IGNsYXNzbmFtZXMoe1xuICAgICAgYWN0aXZlOiBkID09PSBkZXZpY2UsXG4gICAgICAnY3QtZGlzYWJsZWQnOiAhaXNPcHRpb25FbmFibGVkRm9yKGQsIHJlc3BvbnNpdmVEZXNjcmlwdG9yKVxuICAgIH0sIGBjdC0ke2R9YCksXG4gICAga2V5OiBkXG4gIH0pKSkpO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgUmVzcG9uc2l2ZUNvbnRyb2xzOyJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///4616\n")},5458:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"$M\": () => (/* binding */ useDeviceManagerState),\n/* harmony export */ \"Id\": () => (/* binding */ useDeviceManagerActions),\n/* harmony export */ \"Or\": () => (/* binding */ useDeviceManager),\n/* harmony export */ \"jd\": () => (/* binding */ DeviceManagerProvider)\n/* harmony export */ });\n/* unused harmony exports DeviceManagerStateContext, DeviceManagerActionsContext */\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n\nconst DeviceManagerStateContext = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createContext)();\nconst DeviceManagerActionsContext = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createContext)();\nconst useDeviceManagerState = () => {\n const context = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useContext)(DeviceManagerStateContext);\n return context || {\n currentView: 'desktop'\n };\n};\nconst useDeviceManagerActions = () => {\n const context = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useContext)(DeviceManagerActionsContext);\n return context || {};\n};\nconst useDeviceManager = function () {\n let args = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n const {\n withTablet = true\n } = args;\n const [currentView, setCurrentView] = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useState)(wp.customize && wp.customize.previewedDevice ? wp.customize.previewedDevice() : 'desktop');\n\n const listener = () => {\n setCurrentView(wp.customize && wp.customize.previewedDevice ? wp.customize.previewedDevice() : 'desktop');\n };\n\n (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useEffect)(() => {\n if (!wp.customize) return;\n setTimeout(() => wp.customize.previewedDevice.bind(listener), 1000);\n return () => {\n if (!wp.customize) return;\n wp.customize.previewedDevice.unbind(listener);\n };\n }, []);\n return [withTablet ? currentView : currentView === 'tablet' ? 'mobile' : currentView, device => {\n setCurrentView(device);\n wp.customize && wp.customize.previewedDevice.set(device);\n }];\n};\nconst DeviceManagerProvider = _ref => {\n let {\n children\n } = _ref;\n const [currentView, setDevice] = useDeviceManager();\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(DeviceManagerStateContext.Provider, {\n value: {\n currentView\n }\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(DeviceManagerActionsContext.Provider, {\n value: {\n setDevice\n }\n }, children));\n};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNTQ1OC5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vc3RhdGljL2pzL2N1c3RvbWl6ZXIvY29tcG9uZW50cy91c2VEZXZpY2VNYW5hZ2VyLmpzPzNiMGEiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlU3RhdGUsIHVzZUVmZmVjdCwgdXNlQ2FsbGJhY2ssIGNyZWF0ZUNvbnRleHQsIGNyZWF0ZUVsZW1lbnQsIHVzZUNvbnRleHQgfSBmcm9tICdAd29yZHByZXNzL2VsZW1lbnQnO1xuZXhwb3J0IGNvbnN0IERldmljZU1hbmFnZXJTdGF0ZUNvbnRleHQgPSBjcmVhdGVDb250ZXh0KCk7XG5leHBvcnQgY29uc3QgRGV2aWNlTWFuYWdlckFjdGlvbnNDb250ZXh0ID0gY3JlYXRlQ29udGV4dCgpO1xuZXhwb3J0IGNvbnN0IHVzZURldmljZU1hbmFnZXJTdGF0ZSA9ICgpID0+IHtcbiAgY29uc3QgY29udGV4dCA9IHVzZUNvbnRleHQoRGV2aWNlTWFuYWdlclN0YXRlQ29udGV4dCk7XG4gIHJldHVybiBjb250ZXh0IHx8IHtcbiAgICBjdXJyZW50VmlldzogJ2Rlc2t0b3AnXG4gIH07XG59O1xuZXhwb3J0IGNvbnN0IHVzZURldmljZU1hbmFnZXJBY3Rpb25zID0gKCkgPT4ge1xuICBjb25zdCBjb250ZXh0ID0gdXNlQ29udGV4dChEZXZpY2VNYW5hZ2VyQWN0aW9uc0NvbnRleHQpO1xuICByZXR1cm4gY29udGV4dCB8fCB7fTtcbn07XG5leHBvcnQgY29uc3QgdXNlRGV2aWNlTWFuYWdlciA9IGZ1bmN0aW9uICgpIHtcbiAgbGV0IGFyZ3MgPSBhcmd1bWVudHMubGVuZ3RoID4gMCAmJiBhcmd1bWVudHNbMF0gIT09IHVuZGVmaW5lZCA/IGFyZ3VtZW50c1swXSA6IHt9O1xuICBjb25zdCB7XG4gICAgd2l0aFRhYmxldCA9IHRydWVcbiAgfSA9IGFyZ3M7XG4gIGNvbnN0IFtjdXJyZW50Vmlldywgc2V0Q3VycmVudFZpZXddID0gdXNlU3RhdGUod3AuY3VzdG9taXplICYmIHdwLmN1c3RvbWl6ZS5wcmV2aWV3ZWREZXZpY2UgPyB3cC5jdXN0b21pemUucHJldmlld2VkRGV2aWNlKCkgOiAnZGVza3RvcCcpO1xuXG4gIGNvbnN0IGxpc3RlbmVyID0gKCkgPT4ge1xuICAgIHNldEN1cnJlbnRWaWV3KHdwLmN1c3RvbWl6ZSAmJiB3cC5jdXN0b21pemUucHJldmlld2VkRGV2aWNlID8gd3AuY3VzdG9taXplLnByZXZpZXdlZERldmljZSgpIDogJ2Rlc2t0b3AnKTtcbiAgfTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmICghd3AuY3VzdG9taXplKSByZXR1cm47XG4gICAgc2V0VGltZW91dCgoKSA9PiB3cC5jdXN0b21pemUucHJldmlld2VkRGV2aWNlLmJpbmQobGlzdGVuZXIpLCAxMDAwKTtcbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgaWYgKCF3cC5jdXN0b21pemUpIHJldHVybjtcbiAgICAgIHdwLmN1c3RvbWl6ZS5wcmV2aWV3ZWREZXZpY2UudW5iaW5kKGxpc3RlbmVyKTtcbiAgICB9O1xuICB9LCBbXSk7XG4gIHJldHVybiBbd2l0aFRhYmxldCA/IGN1cnJlbnRWaWV3IDogY3VycmVudFZpZXcgPT09ICd0YWJsZXQnID8gJ21vYmlsZScgOiBjdXJyZW50VmlldywgZGV2aWNlID0+IHtcbiAgICBzZXRDdXJyZW50VmlldyhkZXZpY2UpO1xuICAgIHdwLmN1c3RvbWl6ZSAmJiB3cC5jdXN0b21pemUucHJldmlld2VkRGV2aWNlLnNldChkZXZpY2UpO1xuICB9XTtcbn07XG5leHBvcnQgY29uc3QgRGV2aWNlTWFuYWdlclByb3ZpZGVyID0gX3JlZiA9PiB7XG4gIGxldCB7XG4gICAgY2hpbGRyZW5cbiAgfSA9IF9yZWY7XG4gIGNvbnN0IFtjdXJyZW50Vmlldywgc2V0RGV2aWNlXSA9IHVzZURldmljZU1hbmFnZXIoKTtcbiAgcmV0dXJuIGNyZWF0ZUVsZW1lbnQoRGV2aWNlTWFuYWdlclN0YXRlQ29udGV4dC5Qcm92aWRlciwge1xuICAgIHZhbHVlOiB7XG4gICAgICBjdXJyZW50Vmlld1xuICAgIH1cbiAgfSwgY3JlYXRlRWxlbWVudChEZXZpY2VNYW5hZ2VyQWN0aW9uc0NvbnRleHQuUHJvdmlkZXIsIHtcbiAgICB2YWx1ZToge1xuICAgICAgc2V0RGV2aWNlXG4gICAgfVxuICB9LCBjaGlsZHJlbikpO1xufTsiXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///5458\n")},7229:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"Z\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _sortablejs__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(4617);\n/* harmony import */ var _sortablejs__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_sortablejs__WEBPACK_IMPORTED_MODULE_1__);\nconst _excluded = [\"tag\", \"options\", \"onChange\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\nconst store = {\n nextSibling: null,\n activeComponent: null\n};\n\nclass Sortable extends _wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Component {\n constructor() {\n super(...arguments);\n\n _defineProperty(this, \"sortable\", null);\n }\n\n componentDidMount() {\n var _this = this;\n\n const options = _objectSpread({}, this.props.options);\n\n ['onChoose', 'onStart', 'onEnd', 'onAdd', 'onUpdate', 'onSort', 'onRemove', 'onFilter', 'onMove', 'onClone'].forEach(name => {\n const eventHandler = options[name];\n\n options[name] = function () {\n for (var _len = arguments.length, params = new Array(_len), _key = 0; _key < _len; _key++) {\n params[_key] = arguments[_key];\n }\n\n const [evt] = params;\n\n if (name === 'onChoose') {\n store.nextSibling = evt.item.nextElementSibling;\n store.activeComponent = _this;\n } else if ((name === 'onAdd' || name === 'onUpdate') && _this.props.onChange) {\n const items = _this.sortable.toArray();\n\n const remote = store.activeComponent;\n const remoteItems = remote.sortable.toArray();\n const referenceNode = store.nextSibling && store.nextSibling.parentNode !== null ? store.nextSibling : null;\n evt.from.insertBefore(evt.item, referenceNode);\n\n if (remote !== _this) {\n const remoteOptions = remote.props.options || {};\n\n if (typeof remoteOptions.group === 'object' && remoteOptions.group.pull === 'clone') {\n // Remove the node with the same data-reactid\n // evt.item.parentNode.removeChild(evt.item)\n ;\n [...evt.item.parentNode.children].filter(el => el.dataset.id === evt.item.dataset.id && el !== evt.item).map(el => el.remove());\n }\n\n remote.props.onChange && remote.props.onChange(remoteItems, remote.sortable, evt);\n }\n\n _this.props.onChange && _this.props.onChange(items, _this.sortable, evt);\n }\n\n if (evt.type === 'move') {\n const [evt, originalEvent] = params;\n const canMove = eventHandler ? eventHandler(evt, originalEvent) : true;\n return canMove;\n }\n\n setTimeout(() => {\n eventHandler && eventHandler(evt);\n }, 0);\n };\n });\n this.sortable = _sortablejs__WEBPACK_IMPORTED_MODULE_1___default().create(this.node, options);\n }\n\n componentWillUnmount() {\n if (this.sortable) {\n this.sortable.destroy();\n this.sortable = null;\n }\n }\n\n render() {\n const _this$props = this.props,\n {\n tag: Component,\n options,\n onChange\n } = _this$props,\n props = _objectWithoutProperties(_this$props, _excluded);\n\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(Component, _extends({}, props, {\n ref: node => this.node = node\n }));\n }\n\n}\n\n_defineProperty(Sortable, \"defaultProps\", {\n options: {},\n tag: 'div',\n style: {}\n});\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Sortable);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"7229.js","mappings":";;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./static/js/customizer/panels-builder/placements/Sortable.js?930c"],"sourcesContent":["const _excluded = [\"tag\", \"options\", \"onChange\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, Component } from '@wordpress/element';\nimport SortableJS, { Sortable as SortableChanged } from './sortablejs';\nconst store = {\n  nextSibling: null,\n  activeComponent: null\n};\n\nclass Sortable extends Component {\n  constructor() {\n    super(...arguments);\n\n    _defineProperty(this, \"sortable\", null);\n  }\n\n  componentDidMount() {\n    var _this = this;\n\n    const options = _objectSpread({}, this.props.options);\n\n    ['onChoose', 'onStart', 'onEnd', 'onAdd', 'onUpdate', 'onSort', 'onRemove', 'onFilter', 'onMove', 'onClone'].forEach(name => {\n      const eventHandler = options[name];\n\n      options[name] = function () {\n        for (var _len = arguments.length, params = new Array(_len), _key = 0; _key < _len; _key++) {\n          params[_key] = arguments[_key];\n        }\n\n        const [evt] = params;\n\n        if (name === 'onChoose') {\n          store.nextSibling = evt.item.nextElementSibling;\n          store.activeComponent = _this;\n        } else if ((name === 'onAdd' || name === 'onUpdate') && _this.props.onChange) {\n          const items = _this.sortable.toArray();\n\n          const remote = store.activeComponent;\n          const remoteItems = remote.sortable.toArray();\n          const referenceNode = store.nextSibling && store.nextSibling.parentNode !== null ? store.nextSibling : null;\n          evt.from.insertBefore(evt.item, referenceNode);\n\n          if (remote !== _this) {\n            const remoteOptions = remote.props.options || {};\n\n            if (typeof remoteOptions.group === 'object' && remoteOptions.group.pull === 'clone') {\n              // Remove the node with the same data-reactid\n              // evt.item.parentNode.removeChild(evt.item)\n              ;\n              [...evt.item.parentNode.children].filter(el => el.dataset.id === evt.item.dataset.id && el !== evt.item).map(el => el.remove());\n            }\n\n            remote.props.onChange && remote.props.onChange(remoteItems, remote.sortable, evt);\n          }\n\n          _this.props.onChange && _this.props.onChange(items, _this.sortable, evt);\n        }\n\n        if (evt.type === 'move') {\n          const [evt, originalEvent] = params;\n          const canMove = eventHandler ? eventHandler(evt, originalEvent) : true;\n          return canMove;\n        }\n\n        setTimeout(() => {\n          eventHandler && eventHandler(evt);\n        }, 0);\n      };\n    });\n    this.sortable = SortableJS.create(this.node, options);\n  }\n\n  componentWillUnmount() {\n    if (this.sortable) {\n      this.sortable.destroy();\n      this.sortable = null;\n    }\n  }\n\n  render() {\n    const _this$props = this.props,\n          {\n      tag: Component,\n      options,\n      onChange\n    } = _this$props,\n          props = _objectWithoutProperties(_this$props, _excluded);\n\n    return createElement(Component, _extends({}, props, {\n      ref: node => this.node = node\n    }));\n  }\n\n}\n\n_defineProperty(Sortable, \"defaultProps\", {\n  options: {},\n  tag: 'div',\n  style: {}\n});\n\nexport default Sortable;"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///7229\n")},8382:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"SU\": () => (/* binding */ customItemsSeparator),\n/* harmony export */ \"t_\": () => (/* binding */ getOriginalId)\n/* harmony export */ });\n/* unused harmony export shortenItemId */\nconst customItemsSeparator = () => '~';\nconst getOriginalId = id => id.split('~')[0];\nconst shortenItemId = id => {\n let components = id.split(customItemsSeparator());\n\n if (components.length === 1) {\n return components[0];\n }\n\n return components[1].substring(0, 6);\n};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiODM4Mi5qcyIsIm1hcHBpbmdzIjoiOzs7OztBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9ibG9ja3N5T3B0aW9ucy8uL3N0YXRpYy9qcy9jdXN0b21pemVyL3BhbmVscy1idWlsZGVyL3BsYWNlbWVudHMvaGVscGVycy5qcz81YzI5Il0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBjdXN0b21JdGVtc1NlcGFyYXRvciA9ICgpID0+ICd+JztcbmV4cG9ydCBjb25zdCBnZXRPcmlnaW5hbElkID0gaWQgPT4gaWQuc3BsaXQoJ34nKVswXTtcbmV4cG9ydCBjb25zdCBzaG9ydGVuSXRlbUlkID0gaWQgPT4ge1xuICBsZXQgY29tcG9uZW50cyA9IGlkLnNwbGl0KGN1c3RvbUl0ZW1zU2VwYXJhdG9yKCkpO1xuXG4gIGlmIChjb21wb25lbnRzLmxlbmd0aCA9PT0gMSkge1xuICAgIHJldHVybiBjb21wb25lbnRzWzBdO1xuICB9XG5cbiAgcmV0dXJuIGNvbXBvbmVudHNbMV0uc3Vic3RyaW5nKDAsIDYpO1xufTsiXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///8382\n")},4617:function(module){eval('const _excluded = ["evt"];\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n/**!\n * Sortable 1.11.0\n * @author\tRubaXa \n * @author\towenm \n * @license MIT\n */\n(function (global, factory) {\n true ? module.exports = factory() : 0;\n})(this, function () {\n "use strict";\n\n const __warn = "" + "Importing Sortable directly from GitHub is deprecated.\\n" + "This file will not receive any more updates.\\n" + "Please follow the usage instructions to continue getting support: https://github.com/SortableJS/Sortable"; // console.warn(__warn);\n\n\n var version = "1.11.0";\n\n function userAgent(pattern) {\n if (typeof window !== "undefined" && window.navigator) {\n return !! /*@__PURE__*/navigator.userAgent.match(pattern);\n }\n }\n\n const IE11OrLess = userAgent(/(?:Trident.*rv[ :]?11\\.|msie|iemobile|Windows Phone)/i);\n const Edge = userAgent(/Edge/i);\n const FireFox = userAgent(/firefox/i);\n const Safari = userAgent(/safari/i) && !userAgent(/chrome/i) && !userAgent(/android/i);\n const IOS = userAgent(/iP(ad|od|hone)/i);\n const ChromeForAndroid = userAgent(/chrome/i) && userAgent(/android/i);\n const captureMode = {\n capture: false,\n passive: false\n };\n\n function on(el, event, fn) {\n el.addEventListener(event, fn, !IE11OrLess && captureMode);\n }\n\n function off(el, event, fn) {\n el.removeEventListener(event, fn, !IE11OrLess && captureMode);\n }\n\n function matches(\n /**HTMLElement*/\n el,\n /**String*/\n selector) {\n if (!selector) return;\n selector[0] === ">" && (selector = selector.substring(1));\n\n if (el) {\n try {\n if (el.matches) {\n return el.matches(selector);\n } else if (el.msMatchesSelector) {\n return el.msMatchesSelector(selector);\n } else if (el.webkitMatchesSelector) {\n return el.webkitMatchesSelector(selector);\n }\n } catch (_) {\n return false;\n }\n }\n\n return false;\n }\n\n function getParentOrHost(el) {\n return el.host && el !== document && el.host.nodeType ? el.host : el.parentNode;\n }\n\n function closest(\n /**HTMLElement*/\n el,\n /**String*/\n selector,\n /**HTMLElement*/\n ctx, includeCTX) {\n if (el) {\n ctx = ctx || document;\n\n do {\n if (selector != null && (selector[0] === ">" ? el.parentNode === ctx && matches(el, selector) : matches(el, selector)) || includeCTX && el === ctx) {\n return el;\n }\n\n if (el === ctx) break;\n /* jshint boss:true */\n } while (el = getParentOrHost(el));\n }\n\n return null;\n }\n\n const R_SPACE = /\\s+/g;\n\n function toggleClass(el, name, state) {\n if (el && name) {\n if (el.classList) {\n el.classList[state ? "add" : "remove"](name);\n } else {\n let className = (" " + el.className + " ").replace(R_SPACE, " ").replace(" " + name + " ", " ");\n el.className = (className + (state ? " " + name : "")).replace(R_SPACE, " ");\n }\n }\n }\n\n function css(el, prop, val) {\n let style = el && el.style;\n\n if (style) {\n if (val === void 0) {\n if (document.defaultView && document.defaultView.getComputedStyle) {\n val = document.defaultView.getComputedStyle(el, "");\n } else if (el.currentStyle) {\n val = el.currentStyle;\n }\n\n return prop === void 0 ? val : val[prop];\n } else {\n if (!(prop in style) && prop.indexOf("webkit") === -1) {\n prop = "-webkit-" + prop;\n }\n\n style[prop] = val + (typeof val === "string" ? "" : "px");\n }\n }\n }\n\n function matrix(el, selfOnly) {\n let appliedTransforms = "";\n\n if (typeof el === "string") {\n appliedTransforms = el;\n } else {\n do {\n //@ts-ignore\n let transform = css(el, "transform");\n\n if (transform && transform !== "none") {\n appliedTransforms = transform + " " + appliedTransforms;\n }\n /* jshint boss:true */\n\n } while (!selfOnly && (el = el.parentNode));\n } //@ts-ignore\n\n\n const matrixFn = window.DOMMatrix || window.WebKitCSSMatrix || window.CSSMatrix || window.MSCSSMatrix;\n /*jshint -W056 */\n\n return matrixFn && new matrixFn(appliedTransforms);\n }\n\n function find(ctx, tagName, iterator) {\n if (ctx) {\n let list = ctx.getElementsByTagName(tagName),\n i = 0,\n n = list.length;\n\n if (iterator) {\n for (; i < n; i++) {\n iterator(list[i], i);\n }\n }\n\n return list;\n }\n\n return [];\n }\n\n function getWindowScrollingElement() {\n let scrollingElement = document.scrollingElement;\n\n if (scrollingElement) {\n return scrollingElement;\n } else {\n return document.documentElement;\n }\n }\n /**\n * Returns the "bounding client rect" of given element\n * @param {HTMLElement} el The element whose boundingClientRect is wanted\n * @param {[Boolean]} relativeToContainingBlock Whether the rect should be relative to the containing block of (including) the container\n * @param {[Boolean]} relativeToNonStaticParent Whether the rect should be relative to the relative parent of (including) the contaienr\n * @param {[Boolean]} undoScale Whether the container\'s scale() should be undone\n * @param {[HTMLElement]} container The parent the element will be placed in\n * @return {Object} The boundingClientRect of el, with specified adjustments\n */\n\n\n function getRect(el, relativeToContainingBlock, relativeToNonStaticParent, undoScale, container) {\n if (!el.getBoundingClientRect && el !== window) return;\n let elRect, top, left, bottom, right, height, width;\n\n if (el !== window && el !== getWindowScrollingElement()) {\n elRect = el.getBoundingClientRect();\n top = elRect.top;\n left = elRect.left;\n bottom = elRect.bottom;\n right = elRect.right;\n height = elRect.height;\n width = elRect.width;\n } else {\n top = 0;\n left = 0;\n bottom = window.innerHeight;\n right = window.innerWidth;\n height = window.innerHeight;\n width = window.innerWidth;\n }\n\n if ((relativeToContainingBlock || relativeToNonStaticParent) && el !== window) {\n // Adjust for translate()\n container = container || el.parentNode; // solves #1123 (see: https://stackoverflow.com/a/37953806/6088312)\n // Not needed on <= IE11\n\n if (!IE11OrLess) {\n do {\n if (container && container.getBoundingClientRect && ( //@ts-ignore\n css(container, "transform") !== "none" || relativeToNonStaticParent && //@ts-ignore\n css(container, "position") !== "static")) {\n let containerRect = container.getBoundingClientRect(); // Set relative to edges of padding box of container\n //@ts-ignore\n\n top -= containerRect.top + parseInt(css(container, "border-top-width")); //@ts-ignore\n\n left -= containerRect.left + parseInt(css(container, "border-left-width"));\n bottom = top + elRect.height;\n right = left + elRect.width;\n break;\n }\n /* jshint boss:true */\n\n } while (container = container.parentNode);\n }\n }\n\n if (undoScale && el !== window) {\n // Adjust for scale()\n //@ts-ignore\n let elMatrix = matrix(container || el),\n scaleX = elMatrix && elMatrix.a,\n scaleY = elMatrix && elMatrix.d;\n\n if (elMatrix) {\n top /= scaleY;\n left /= scaleX;\n width /= scaleX;\n height /= scaleY;\n bottom = top + height;\n right = left + width;\n }\n }\n\n return {\n top: top,\n left: left,\n bottom: bottom,\n right: right,\n width: width,\n height: height\n };\n }\n /**\n * Checks if a side of an element is scrolled past a side of its parents\n * @param {HTMLElement} el The element who\'s side being scrolled out of view is in question\n * @param {String} elSide Side of the element in question (\'top\', \'left\', \'right\', \'bottom\')\n * @param {String} parentSide Side of the parent in question (\'top\', \'left\', \'right\', \'bottom\')\n * @return {HTMLElement} The parent scroll element that the el\'s side is scrolled past, or null if there is no such element\n */\n\n\n function isScrolledPast(el, elSide, parentSide) {\n let parent = getParentAutoScrollElement(el, true),\n //@ts-ignore\n elSideVal = getRect(el)[elSide];\n /* jshint boss:true */\n\n while (parent) {\n //@ts-ignore\n let parentSideVal = getRect(parent)[parentSide],\n visible;\n\n if (parentSide === "top" || parentSide === "left") {\n visible = elSideVal >= parentSideVal;\n } else {\n visible = elSideVal <= parentSideVal;\n }\n\n if (!visible) return parent;\n if (parent === getWindowScrollingElement()) break;\n parent = getParentAutoScrollElement(parent, false);\n }\n\n return false;\n }\n /**\n * Gets nth child of el, ignoring hidden children, sortable\'s elements (does not ignore clone if it\'s visible)\n * and non-draggable elements\n * @param {HTMLElement} el The parent element\n * @param {Number} childNum The index of the child\n * @param {Object} options Parent Sortable\'s options\n * @return {HTMLElement} The child at index childNum, or null if not found\n */\n\n\n function getChild(el, childNum, options) {\n let currentChild = 0,\n i = 0,\n children = el.children;\n\n while (i < children.length) {\n if (children[i].style.display !== "none" && //@ts-ignore\n children[i] !== Sortable.ghost && //@ts-ignore\n children[i] !== Sortable.dragged && closest(children[i], options.draggable, el, false)) {\n if (currentChild === childNum) {\n return children[i];\n }\n\n currentChild++;\n }\n\n i++;\n }\n\n return null;\n }\n /**\n * Gets the last child in the el, ignoring ghostEl or invisible elements (clones)\n * @param {HTMLElement} el Parent element\n * @param {selector} selector Any other elements that should be ignored\n * @return {HTMLElement} The last child, ignoring ghostEl\n */\n\n\n function lastChild(el, selector) {\n let last = el.lastElementChild;\n\n while (last && ( //@ts-ignore\n last === Sortable.ghost || //@ts-ignore\n css(last, "display") === "none" || selector && !matches(last, selector))) {\n last = last.previousElementSibling;\n }\n\n return last || null;\n }\n /**\n * Returns the index of an element within its parent for a selected set of\n * elements\n * @param {HTMLElement} el\n * @param {selector} selector\n * @return {number}\n */\n\n\n function index(el, selector) {\n let index = 0;\n\n if (!el || !el.parentNode) {\n return -1;\n }\n /* jshint boss:true */\n\n\n while (el = el.previousElementSibling) {\n //@ts-ignore\n if (el.nodeName.toUpperCase() !== "TEMPLATE" && !el.matches(\'.ct-pointer\') && el !== Sortable.clone && (!selector || matches(el, selector))) {\n index++;\n }\n }\n\n return index;\n }\n /**\n * Returns the scroll offset of the given element, added with all the scroll offsets of parent elements.\n * The value is returned in real pixels.\n * @param {HTMLElement} el\n * @return {Array} Offsets in the format of [left, top]\n */\n\n\n function getRelativeScrollOffset(el) {\n let offsetLeft = 0,\n offsetTop = 0,\n winScroller = getWindowScrollingElement();\n\n if (el) {\n do {\n //@ts-ignore\n let elMatrix = matrix(el),\n scaleX = elMatrix.a,\n scaleY = elMatrix.d;\n offsetLeft += el.scrollLeft * scaleX;\n offsetTop += el.scrollTop * scaleY;\n } while (el !== winScroller && (el = el.parentNode));\n }\n\n return [offsetLeft, offsetTop];\n }\n /**\n * Returns the index of the object within the given array\n * @param {Array} arr Array that may or may not hold the object\n * @param {Object} obj An object that has a key-value pair unique to and identical to a key-value pair in the object you want to find\n * @return {Number} The index of the object in the array, or -1\n */\n\n\n function indexOfObject(arr, obj) {\n for (let i in arr) {\n if (!arr.hasOwnProperty(i)) continue;\n\n for (let key in obj) {\n if (obj.hasOwnProperty(key) && obj[key] === arr[i][key]) return Number(i);\n }\n }\n\n return -1;\n }\n\n function getParentAutoScrollElement(el, includeSelf) {\n // skip to window\n if (!el || !el.getBoundingClientRect) return getWindowScrollingElement();\n let elem = el;\n let gotSelf = false;\n\n do {\n // we don\'t need to get elem css if it isn\'t even overflowing in the first place (performance)\n if (elem.clientWidth < elem.scrollWidth || elem.clientHeight < elem.scrollHeight) {\n //@ts-ignore\n let elemCSS = css(elem);\n\n if (elem.clientWidth < elem.scrollWidth && (elemCSS.overflowX == "auto" || elemCSS.overflowX == "scroll") || elem.clientHeight < elem.scrollHeight && (elemCSS.overflowY == "auto" || elemCSS.overflowY == "scroll")) {\n if (!elem.getBoundingClientRect || elem === document.body) return getWindowScrollingElement();\n if (gotSelf || includeSelf) return elem;\n gotSelf = true;\n }\n }\n /* jshint boss:true */\n\n } while (elem = elem.parentNode);\n\n return getWindowScrollingElement();\n }\n\n function extend(dst, src) {\n if (dst && src) {\n for (let key in src) {\n if (src.hasOwnProperty(key)) {\n dst[key] = src[key];\n }\n }\n }\n\n return dst;\n }\n\n function isRectEqual(rect1, rect2) {\n return Math.round(rect1.top) === Math.round(rect2.top) && Math.round(rect1.left) === Math.round(rect2.left) && Math.round(rect1.height) === Math.round(rect2.height) && Math.round(rect1.width) === Math.round(rect2.width);\n }\n\n let _throttleTimeout;\n\n function throttle(callback, ms) {\n return function () {\n if (!_throttleTimeout) {\n let args = arguments,\n _this = this;\n\n if (args.length === 1) {\n callback.call(_this, args[0]);\n } else {\n callback.apply(_this, args);\n }\n\n _throttleTimeout = setTimeout(function () {\n _throttleTimeout = void 0;\n }, ms);\n }\n };\n }\n\n function cancelThrottle() {\n clearTimeout(_throttleTimeout);\n _throttleTimeout = void 0;\n }\n\n function scrollBy(el, x, y) {\n el.scrollLeft += x;\n el.scrollTop += y;\n }\n\n function clone(el) {\n //@ts-ignore\n let Polymer = window.Polymer; //@ts-ignore\n\n let $ = window.jQuery || window.Zepto;\n\n if (Polymer && Polymer.dom) {\n return Polymer.dom(el).cloneNode(true);\n } else if ($) {\n return $(el).clone(true)[0];\n } else {\n return el.cloneNode(true);\n }\n }\n\n function setRect(el, rect) {\n css(el, "position", "absolute");\n css(el, "top", rect.top);\n css(el, "left", rect.left);\n css(el, "width", rect.width);\n css(el, "height", rect.height);\n }\n\n function unsetRect(el) {\n css(el, "position", "");\n css(el, "top", "");\n css(el, "left", "");\n css(el, "width", "");\n css(el, "height", "");\n }\n\n const expando = "Sortable" + new Date().getTime();\n\n function AnimationStateManager() {\n let animationStates = [],\n animationCallbackId;\n return {\n captureAnimationState() {\n animationStates = [];\n if (!this.options.animation) return;\n let children = [].slice.call(this.el.children);\n children.forEach(child => {\n if (css(child, "display") === "none" || child === Sortable.ghost) return;\n animationStates.push({\n target: child,\n rect: getRect(child)\n });\n\n let fromRect = _objectSpread({}, animationStates[animationStates.length - 1].rect); // If animating: compensate for current animation\n\n\n if (child.thisAnimationDuration) {\n let childMatrix = matrix(child, true);\n\n if (childMatrix) {\n fromRect.top -= childMatrix.f;\n fromRect.left -= childMatrix.e;\n }\n }\n\n child.fromRect = fromRect;\n });\n },\n\n addAnimationState(state) {\n animationStates.push(state);\n },\n\n removeAnimationState(target) {\n animationStates.splice(indexOfObject(animationStates, {\n target\n }), 1);\n },\n\n animateAll(callback) {\n if (!this.options.animation) {\n clearTimeout(animationCallbackId);\n if (typeof callback === "function") callback();\n return;\n }\n\n let animating = false,\n animationTime = 0;\n animationStates.forEach(state => {\n let time = 0,\n target = state.target,\n fromRect = target.fromRect,\n toRect = getRect(target),\n prevFromRect = target.prevFromRect,\n prevToRect = target.prevToRect,\n animatingRect = state.rect,\n targetMatrix = matrix(target, true);\n\n if (targetMatrix) {\n // Compensate for current animation\n toRect.top -= targetMatrix.f;\n toRect.left -= targetMatrix.e;\n }\n\n target.toRect = toRect;\n\n if (target.thisAnimationDuration) {\n // Could also check if animatingRect is between fromRect and toRect\n if (isRectEqual(prevFromRect, toRect) && !isRectEqual(fromRect, toRect) && // Make sure animatingRect is on line between toRect & fromRect\n (animatingRect.top - toRect.top) / (animatingRect.left - toRect.left) === (fromRect.top - toRect.top) / (fromRect.left - toRect.left)) {\n // If returning to same place as started from animation and on same axis\n time = calculateRealTime(animatingRect, prevFromRect, prevToRect, this.options);\n }\n } // if fromRect != toRect: animate\n\n\n if (!isRectEqual(toRect, fromRect)) {\n target.prevFromRect = fromRect;\n target.prevToRect = toRect;\n\n if (!time) {\n time = this.options.animation;\n }\n\n this.animate(target, animatingRect, toRect, time);\n }\n\n if (time) {\n animating = true;\n animationTime = Math.max(animationTime, time);\n clearTimeout(target.animationResetTimer);\n target.animationResetTimer = setTimeout(function () {\n target.animationTime = 0;\n target.prevFromRect = null;\n target.fromRect = null;\n target.prevToRect = null;\n target.thisAnimationDuration = null;\n }, time);\n target.thisAnimationDuration = time;\n }\n });\n clearTimeout(animationCallbackId);\n\n if (!animating) {\n if (typeof callback === "function") callback();\n } else {\n animationCallbackId = setTimeout(function () {\n if (typeof callback === "function") callback();\n }, animationTime);\n }\n\n animationStates = [];\n },\n\n animate(target, currentRect, toRect, duration) {\n if (duration) {\n css(target, "transition", "");\n css(target, "transform", "");\n let elMatrix = matrix(this.el),\n scaleX = elMatrix && elMatrix.a,\n scaleY = elMatrix && elMatrix.d,\n translateX = (currentRect.left - toRect.left) / (scaleX || 1),\n translateY = (currentRect.top - toRect.top) / (scaleY || 1);\n target.animatingX = !!translateX;\n target.animatingY = !!translateY;\n css(target, "transform", "translate3d(" + translateX + "px," + translateY + "px,0)");\n this.forRepaintDummy = repaint(target); // repaint\n\n css(target, "transition", "transform " + duration + "ms" + (this.options.easing ? " " + this.options.easing : ""));\n css(target, "transform", "translate3d(0,0,0)");\n typeof target.animated === "number" && clearTimeout(target.animated);\n target.animated = setTimeout(function () {\n css(target, "transition", "");\n css(target, "transform", "");\n target.animated = false;\n target.animatingX = false;\n target.animatingY = false;\n }, duration);\n }\n }\n\n };\n }\n\n function repaint(target) {\n return target.offsetWidth;\n }\n\n function calculateRealTime(animatingRect, fromRect, toRect, options) {\n return Math.sqrt(Math.pow(fromRect.top - animatingRect.top, 2) + Math.pow(fromRect.left - animatingRect.left, 2)) / Math.sqrt(Math.pow(fromRect.top - toRect.top, 2) + Math.pow(fromRect.left - toRect.left, 2)) * options.animation;\n }\n\n let plugins = [];\n const defaults = {\n initializeByDefault: true\n };\n var PluginManager = {\n mount(plugin) {\n // Set default static properties\n for (let option in defaults) {\n if (defaults.hasOwnProperty(option) && !(option in plugin)) {\n plugin[option] = defaults[option];\n }\n }\n\n plugins.push(plugin);\n },\n\n pluginEvent(eventName, sortable, evt) {\n this.eventCanceled = false;\n\n evt.cancel = () => {\n this.eventCanceled = true;\n };\n\n const eventNameGlobal = eventName + "Global";\n plugins.forEach(plugin => {\n if (!sortable[plugin.pluginName]) return; // Fire global events if it exists in this sortable\n\n if (sortable[plugin.pluginName][eventNameGlobal]) {\n sortable[plugin.pluginName][eventNameGlobal](_objectSpread({\n sortable\n }, evt));\n } // Only fire plugin event if plugin is enabled in this sortable,\n // and plugin has event defined\n\n\n if (sortable.options[plugin.pluginName] && sortable[plugin.pluginName][eventName]) {\n sortable[plugin.pluginName][eventName](_objectSpread({\n sortable\n }, evt));\n }\n });\n },\n\n initializePlugins(sortable, el, defaults, options) {\n plugins.forEach(plugin => {\n const pluginName = plugin.pluginName;\n if (!sortable.options[pluginName] && !plugin.initializeByDefault) return;\n let initialized = new plugin(sortable, el, sortable.options);\n initialized.sortable = sortable;\n initialized.options = sortable.options;\n sortable[pluginName] = initialized; // Add default options from plugin\n\n Object.assign(defaults, initialized.defaults);\n });\n\n for (let option in sortable.options) {\n if (!sortable.options.hasOwnProperty(option)) continue;\n let modified = this.modifyOption(sortable, option, sortable.options[option]);\n\n if (typeof modified !== "undefined") {\n sortable.options[option] = modified;\n }\n }\n },\n\n getEventProperties(name, sortable) {\n let eventProperties = {};\n plugins.forEach(plugin => {\n if (typeof plugin.eventProperties !== "function") return;\n Object.assign(eventProperties, plugin.eventProperties.call(sortable[plugin.pluginName], name));\n });\n return eventProperties;\n },\n\n modifyOption(sortable, name, value) {\n let modifiedValue;\n plugins.forEach(plugin => {\n // Plugin must exist on the Sortable\n if (!sortable[plugin.pluginName]) return; // If static option listener exists for this option, call in the context of the Sortable\'s instance of this plugin\n\n if (plugin.optionListeners && typeof plugin.optionListeners[name] === "function") {\n modifiedValue = plugin.optionListeners[name].call(sortable[plugin.pluginName], value);\n }\n });\n return modifiedValue;\n }\n\n };\n\n function dispatchEvent(_ref) {\n let {\n sortable,\n rootEl,\n name,\n targetEl,\n cloneEl,\n toEl,\n fromEl,\n oldIndex,\n newIndex,\n oldDraggableIndex,\n newDraggableIndex,\n originalEvent,\n putSortable,\n extraEventProperties\n } = _ref;\n sortable = sortable || rootEl && rootEl[expando];\n if (!sortable) return;\n let evt,\n options = sortable.options,\n onName = "on" + name.charAt(0).toUpperCase() + name.substr(1); // Support for new CustomEvent feature\n\n if (window.CustomEvent && !IE11OrLess && !Edge) {\n evt = new CustomEvent(name, {\n bubbles: true,\n cancelable: true\n });\n } else {\n evt = document.createEvent("Event");\n evt.initEvent(name, true, true);\n }\n\n evt.to = toEl || rootEl;\n evt.from = fromEl || rootEl;\n evt.item = targetEl || rootEl;\n evt.clone = cloneEl;\n evt.oldIndex = oldIndex;\n evt.newIndex = newIndex;\n evt.oldDraggableIndex = oldDraggableIndex;\n evt.newDraggableIndex = newDraggableIndex;\n evt.originalEvent = originalEvent;\n evt.pullMode = putSortable ? putSortable.lastPutMode : undefined;\n\n let allEventProperties = _objectSpread(_objectSpread({}, extraEventProperties), PluginManager.getEventProperties(name, sortable));\n\n for (let option in allEventProperties) {\n evt[option] = allEventProperties[option];\n }\n\n if (rootEl) {\n rootEl.dispatchEvent(evt);\n }\n\n if (options[onName]) {\n options[onName].call(sortable, evt);\n }\n }\n /**!\n * Sortable\n * @author\tRubaXa \n * @author\towenm \n * @license MIT\n */\n\n\n let pluginEvent = function (eventName, sortable) {\n let _ref2 = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n\n let {\n evt: originalEvent\n } = _ref2,\n data = _objectWithoutProperties(_ref2, _excluded);\n\n PluginManager.pluginEvent.bind(Sortable)(eventName, sortable, _objectSpread({\n dragEl,\n parentEl,\n ghostEl,\n rootEl,\n nextEl,\n lastDownEl,\n cloneEl,\n cloneHidden,\n dragStarted: moved,\n putSortable,\n activeSortable: Sortable.active,\n originalEvent,\n oldIndex,\n oldDraggableIndex,\n newIndex,\n newDraggableIndex,\n hideGhostForTarget: _hideGhostForTarget,\n unhideGhostForTarget: _unhideGhostForTarget,\n\n cloneNowHidden() {\n cloneHidden = true;\n },\n\n cloneNowShown() {\n cloneHidden = false;\n },\n\n dispatchSortableEvent(name) {\n _dispatchEvent({\n sortable,\n name,\n originalEvent\n });\n }\n\n }, data));\n };\n\n function _dispatchEvent(info) {\n dispatchEvent(_objectSpread({\n putSortable,\n cloneEl,\n targetEl: dragEl,\n rootEl,\n oldIndex,\n oldDraggableIndex,\n newIndex,\n newDraggableIndex\n }, info));\n }\n\n let dragEl,\n parentEl,\n ghostEl,\n rootEl,\n nextEl,\n lastDownEl,\n cloneEl,\n cloneHidden,\n oldIndex,\n newIndex,\n oldDraggableIndex,\n newDraggableIndex,\n activeGroup,\n putSortable,\n awaitingDragStarted = false,\n ignoreNextClick = false,\n sortables = [],\n tapEvt,\n touchEvt,\n lastDx,\n lastDy,\n tapDistanceLeft,\n tapDistanceTop,\n moved,\n lastTarget,\n lastDirection,\n pastFirstInvertThresh = false,\n isCircumstantialInvert = false,\n targetMoveDistance,\n // For positioning ghost absolutely\n ghostRelativeParent,\n ghostRelativeParentInitialScroll = [],\n // (left, top)\n _silent = false,\n savedInputChecked = [];\n /** @const */\n\n const documentExists = typeof document !== "undefined",\n PositionGhostAbsolutely = IOS,\n CSSFloatProperty = Edge || IE11OrLess ? "cssFloat" : "float",\n // This will not pass for IE9, because IE9 DnD only works on anchors\n supportDraggable = documentExists && !ChromeForAndroid && !IOS && "draggable" in document.createElement("div"),\n supportCssPointerEvents = function () {\n if (!documentExists) return; // false when <= IE11\n\n if (IE11OrLess) {\n return false;\n }\n\n let el = document.createElement("x");\n el.style.cssText = "pointer-events:auto";\n return el.style.pointerEvents === "auto";\n }(),\n _detectDirection = function (el, options) {\n let elCSS = css(el),\n elWidth = parseInt(elCSS.width) - parseInt(elCSS.paddingLeft) - parseInt(elCSS.paddingRight) - parseInt(elCSS.borderLeftWidth) - parseInt(elCSS.borderRightWidth),\n child1 = getChild(el, 0, options),\n child2 = getChild(el, 1, options),\n firstChildCSS = child1 && css(child1),\n secondChildCSS = child2 && css(child2),\n firstChildWidth = firstChildCSS && parseInt(firstChildCSS.marginLeft) + parseInt(firstChildCSS.marginRight) + getRect(child1).width,\n secondChildWidth = secondChildCSS && parseInt(secondChildCSS.marginLeft) + parseInt(secondChildCSS.marginRight) + getRect(child2).width;\n\n if (elCSS.display === "flex") {\n return elCSS.flexDirection === "column" || elCSS.flexDirection === "column-reverse" ? "vertical" : "horizontal";\n }\n\n if (elCSS.display === "grid") {\n return elCSS.gridTemplateColumns.split(" ").length <= 1 ? "vertical" : "horizontal";\n }\n\n if (child1 && firstChildCSS.float && firstChildCSS.float !== "none") {\n let touchingSideChild2 = firstChildCSS.float === "left" ? "left" : "right";\n return child2 && (secondChildCSS.clear === "both" || secondChildCSS.clear === touchingSideChild2) ? "vertical" : "horizontal";\n }\n\n return child1 && (firstChildCSS.display === "block" || firstChildCSS.display === "flex" || firstChildCSS.display === "table" || firstChildCSS.display === "grid" || firstChildWidth >= elWidth && elCSS[CSSFloatProperty] === "none" || child2 && elCSS[CSSFloatProperty] === "none" && firstChildWidth + secondChildWidth > elWidth) ? "vertical" : "horizontal";\n },\n _dragElInRowColumn = function (dragRect, targetRect, vertical) {\n let dragElS1Opp = vertical ? dragRect.left : dragRect.top,\n dragElS2Opp = vertical ? dragRect.right : dragRect.bottom,\n dragElOppLength = vertical ? dragRect.width : dragRect.height,\n targetS1Opp = vertical ? targetRect.left : targetRect.top,\n targetS2Opp = vertical ? targetRect.right : targetRect.bottom,\n targetOppLength = vertical ? targetRect.width : targetRect.height;\n return dragElS1Opp === targetS1Opp || dragElS2Opp === targetS2Opp || dragElS1Opp + dragElOppLength / 2 === targetS1Opp + targetOppLength / 2;\n },\n\n /**\n * Detects first nearest empty sortable to X and Y position using emptyInsertThreshold.\n * @param {Number} x X position\n * @param {Number} y Y position\n * @return {HTMLElement} Element of the first found nearest Sortable\n */\n _detectNearestEmptySortable = function (x, y) {\n let ret;\n sortables.some(sortable => {\n if (lastChild(sortable)) return;\n let rect = getRect(sortable),\n threshold = sortable[expando].options.emptyInsertThreshold,\n insideHorizontally = x >= rect.left - threshold && x <= rect.right + threshold,\n insideVertically = y >= rect.top - threshold && y <= rect.bottom + threshold;\n\n if (threshold && insideHorizontally && insideVertically) {\n return ret = sortable;\n }\n });\n return ret;\n },\n _prepareGroup = function (options) {\n function toFn(value, pull) {\n return function (to, from, dragEl, evt) {\n let sameGroup = to.options.group.name && from.options.group.name && to.options.group.name === from.options.group.name;\n\n if (value == null && (pull || sameGroup)) {\n // Default pull value\n // Default pull and put value if same group\n return true;\n } else if (value == null || value === false) {\n return false;\n } else if (pull && value === "clone") {\n return value;\n } else if (typeof value === "function") {\n return toFn(value(to, from, dragEl, evt), pull)(to, from, dragEl, evt);\n } else {\n let otherGroup = (pull ? to : from).options.group.name;\n return value === true || typeof value === "string" && value === otherGroup || value.join && value.indexOf(otherGroup) > -1;\n }\n };\n }\n\n let group = {};\n let originalGroup = options.group;\n\n if (!originalGroup || typeof originalGroup != "object") {\n originalGroup = {\n name: originalGroup\n };\n }\n\n group.name = originalGroup.name;\n group.checkPull = toFn(originalGroup.pull, true);\n group.checkPut = toFn(originalGroup.put);\n group.revertClone = originalGroup.revertClone;\n options.group = group;\n },\n _hideGhostForTarget = function () {\n if (!supportCssPointerEvents && ghostEl) {\n css(ghostEl, "display", "none");\n }\n },\n _unhideGhostForTarget = function () {\n if (!supportCssPointerEvents && ghostEl) {\n css(ghostEl, "display", "");\n }\n }; // #1184 fix - Prevent click event on fallback if dragged but item not changed position\n\n\n if (documentExists) {\n document.addEventListener("click", function (evt) {\n if (ignoreNextClick) {\n evt.preventDefault();\n evt.stopPropagation && evt.stopPropagation();\n evt.stopImmediatePropagation && evt.stopImmediatePropagation();\n ignoreNextClick = false;\n return false;\n }\n }, true);\n }\n\n let nearestEmptyInsertDetectEvent = function (evt) {\n if (dragEl) {\n evt = evt.touches ? evt.touches[0] : evt;\n\n let nearest = _detectNearestEmptySortable(evt.clientX, evt.clientY);\n\n if (nearest) {\n // Create imitation event\n let event = {};\n\n for (let i in evt) {\n if (evt.hasOwnProperty(i)) {\n event[i] = evt[i];\n }\n }\n\n event.target = event.rootEl = nearest;\n event.preventDefault = void 0;\n event.stopPropagation = void 0;\n\n nearest[expando]._onDragOver(event);\n }\n }\n };\n\n let _checkOutsideTargetEl = function (evt) {\n if (dragEl) {\n dragEl.parentNode[expando]._isOutsideThisEl(evt.target);\n }\n };\n /**\n * @class Sortable\n * @param {HTMLElement} el\n * @param {Object} [options]\n */\n\n\n function Sortable(el, options) {\n if (!(el && el.nodeType && el.nodeType === 1)) {\n throw `Sortable: \\`el\\` must be an HTMLElement, not ${{}.toString.call(el)}`;\n }\n\n this.el = el; // root element\n\n this.options = options = Object.assign({}, options); // Export instance\n\n el[expando] = this;\n let defaults = {\n group: null,\n sort: true,\n disabled: false,\n store: null,\n handle: null,\n draggable: /^[uo]l$/i.test(el.nodeName) ? ">li" : ">*",\n swapThreshold: 1,\n // percentage; 0 <= x <= 1\n invertSwap: false,\n // invert always\n invertedSwapThreshold: null,\n // will be set to same as swapThreshold if default\n removeCloneOnHide: true,\n direction: function () {\n return _detectDirection(el, this.options);\n },\n ghostClass: "sortable-ghost",\n chosenClass: "sortable-chosen",\n dragClass: "sortable-drag",\n ignore: "a, img",\n filter: null,\n preventOnFilter: true,\n animation: 0,\n easing: null,\n setData: function (dataTransfer, dragEl) {\n dataTransfer.setData("Text", dragEl.textContent);\n },\n dropBubble: false,\n dragoverBubble: false,\n dataIdAttr: "data-id",\n delay: 0,\n delayOnTouchOnly: false,\n touchStartThreshold: (Number.parseInt ? Number : window).parseInt(window.devicePixelRatio, 10) || 1,\n forceFallback: false,\n fallbackClass: "sortable-fallback",\n fallbackOnBody: false,\n fallbackTolerance: 0,\n fallbackOffset: {\n x: 0,\n y: 0\n },\n supportPointer: Sortable.supportPointer !== false && "PointerEvent" in window,\n emptyInsertThreshold: 5\n };\n PluginManager.initializePlugins(this, el, defaults); // Set default options\n\n for (let name in defaults) {\n !(name in options) && (options[name] = defaults[name]);\n }\n\n _prepareGroup(options); // Bind all private methods\n\n\n for (let fn in this) {\n if (fn.charAt(0) === "_" && typeof this[fn] === "function") {\n this[fn] = this[fn].bind(this);\n }\n } // Setup drag mode\n\n\n this.nativeDraggable = options.forceFallback ? false : supportDraggable;\n\n if (this.nativeDraggable) {\n // Touch start threshold cannot be greater than the native dragstart threshold\n this.options.touchStartThreshold = 1;\n } // Bind events\n\n\n if (options.supportPointer) {\n on(el, "pointerdown", this._onTapStart);\n } else {\n on(el, "mousedown", this._onTapStart);\n on(el, "touchstart", this._onTapStart);\n }\n\n if (this.nativeDraggable) {\n on(el, "dragover", this);\n on(el, "dragenter", this);\n }\n\n sortables.push(this.el); // Restore sorting\n\n options.store && options.store.get && this.sort(options.store.get(this) || []); // Add animation state manager\n\n Object.assign(this, AnimationStateManager());\n }\n\n Sortable.prototype =\n /** @lends Sortable.prototype */\n {\n constructor: Sortable,\n _isOutsideThisEl: function (target) {\n if (!this.el.contains(target) && target !== this.el) {\n lastTarget = null;\n }\n },\n _getDirection: function (evt, target) {\n return typeof this.options.direction === "function" ? this.options.direction.call(this, evt, target, dragEl) : this.options.direction;\n },\n _onTapStart: function (\n /** Event|TouchEvent */\n evt) {\n if (!evt.cancelable) return;\n\n let _this = this,\n el = this.el,\n options = this.options,\n preventOnFilter = options.preventOnFilter,\n type = evt.type,\n touch = evt.touches && evt.touches[0] || evt.pointerType && evt.pointerType === "touch" && evt,\n target = (touch || evt).target,\n originalTarget = evt.target.shadowRoot && (evt.path && evt.path[0] || evt.composedPath && evt.composedPath()[0]) || target,\n filter = options.filter;\n\n _saveInputCheckedState(el); // Don\'t trigger start event when an element is been dragged, otherwise the evt.oldindex always wrong when set option.group.\n\n\n if (dragEl) {\n return;\n }\n\n if (/mousedown|pointerdown/.test(type) && evt.button !== 0 || options.disabled) {\n return; // only left button and enabled\n } // cancel dnd if original target is content editable\n\n\n if (originalTarget.isContentEditable) {\n return;\n } // Safari ignores further event handling after mousedown\n\n\n if (!this.nativeDraggable && Safari && target && target.tagName.toUpperCase() === "SELECT") {\n return;\n }\n\n target = closest(target, options.draggable, el, false);\n\n if (target && target.animated) {\n return;\n }\n\n if (lastDownEl === target) {\n // Ignoring duplicate `down`\n return;\n } // Get the index of the dragged element within its parent\n\n\n oldIndex = index(target);\n oldDraggableIndex = index(target, options.draggable); // Check filter\n\n if (typeof filter === "function") {\n if (filter.call(this, evt, target, this)) {\n _dispatchEvent({\n sortable: _this,\n rootEl: originalTarget,\n name: "filter",\n targetEl: target,\n toEl: el,\n fromEl: el\n });\n\n pluginEvent("filter", _this, {\n evt\n });\n preventOnFilter && evt.cancelable && evt.preventDefault();\n return; // cancel dnd\n }\n } else if (filter) {\n filter = filter.split(",").some(function (criteria) {\n criteria = closest(originalTarget, criteria.trim(), el, false);\n\n if (criteria) {\n _dispatchEvent({\n sortable: _this,\n rootEl: criteria,\n name: "filter",\n targetEl: target,\n fromEl: el,\n toEl: el\n });\n\n pluginEvent("filter", _this, {\n evt\n });\n return true;\n }\n });\n\n if (filter) {\n preventOnFilter && evt.cancelable && evt.preventDefault();\n return; // cancel dnd\n }\n }\n\n if (options.handle && !closest(originalTarget, options.handle, el, false)) {\n return;\n } // Prepare `dragstart`\n\n\n this._prepareDragStart(evt, touch, target);\n },\n _prepareDragStart: function (\n /** Event */\n evt,\n /** Touch */\n touch,\n /** HTMLElement */\n target) {\n let _this = this,\n el = _this.el,\n options = _this.options,\n ownerDocument = el.ownerDocument,\n dragStartFn;\n\n if (target && !dragEl && target.parentNode === el) {\n let dragRect = getRect(target);\n rootEl = el;\n dragEl = target;\n parentEl = dragEl.parentNode;\n nextEl = dragEl.nextSibling;\n lastDownEl = target;\n activeGroup = options.group;\n Sortable.dragged = dragEl; // PORTME: added offset\n\n let offset = 0;\n const targetBoundingRect = target.getBoundingClientRect();\n\n if (targetBoundingRect.left + 95 < (touch || evt).clientX) {\n offset = (touch || evt).clientX - targetBoundingRect.left - 95 / 2;\n }\n\n tapEvt = {\n target: dragEl,\n clientX: (touch || evt).clientX - offset,\n clientY: (touch || evt).clientY\n };\n tapDistanceLeft = tapEvt.clientX - dragRect.left;\n tapDistanceTop = tapEvt.clientY - dragRect.top;\n this._lastX = (touch || evt).clientX - offset;\n this._lastY = (touch || evt).clientY;\n dragEl.style["will-change"] = "all";\n\n dragStartFn = function () {\n pluginEvent("delayEnded", _this, {\n evt\n });\n\n if (Sortable.eventCanceled) {\n _this._onDrop();\n\n return;\n } // Delayed drag has been triggered\n // we can re-enable the events: touchmove/mousemove\n\n\n _this._disableDelayedDragEvents();\n\n if (!FireFox && _this.nativeDraggable) {\n dragEl.draggable = true;\n } // Bind the events: dragstart/dragend\n\n\n _this._triggerDragStart(evt, touch); // Drag start event\n\n\n _dispatchEvent({\n sortable: _this,\n name: "choose",\n originalEvent: evt\n }); // Chosen item\n\n\n toggleClass(dragEl, options.chosenClass, true);\n }; // Disable "draggable"\n\n\n options.ignore.split(",").forEach(function (criteria) {\n find(dragEl, criteria.trim(), _disableDraggable);\n });\n on(ownerDocument, "dragover", nearestEmptyInsertDetectEvent);\n on(ownerDocument, "mousemove", nearestEmptyInsertDetectEvent);\n on(ownerDocument, "touchmove", nearestEmptyInsertDetectEvent);\n on(ownerDocument, "mouseup", _this._onDrop);\n on(ownerDocument, "touchend", _this._onDrop);\n on(ownerDocument, "touchcancel", _this._onDrop); // Make dragEl draggable (must be before delay for FireFox)\n\n if (FireFox && this.nativeDraggable) {\n this.options.touchStartThreshold = 4;\n dragEl.draggable = true;\n }\n\n pluginEvent("delayStart", this, {\n evt\n }); // Delay is impossible for native DnD in Edge or IE\n\n if (options.delay && (!options.delayOnTouchOnly || touch) && (!this.nativeDraggable || !(Edge || IE11OrLess))) {\n if (Sortable.eventCanceled) {\n this._onDrop();\n\n return;\n } // If the user moves the pointer or let go the click or touch\n // before the delay has been reached:\n // disable the delayed drag\n\n\n on(ownerDocument, "mouseup", _this._disableDelayedDrag);\n on(ownerDocument, "touchend", _this._disableDelayedDrag);\n on(ownerDocument, "touchcancel", _this._disableDelayedDrag);\n on(ownerDocument, "mousemove", _this._delayedDragTouchMoveHandler);\n on(ownerDocument, "touchmove", _this._delayedDragTouchMoveHandler);\n options.supportPointer && on(ownerDocument, "pointermove", _this._delayedDragTouchMoveHandler);\n _this._dragStartTimer = setTimeout(dragStartFn, options.delay);\n } else {\n dragStartFn();\n }\n }\n },\n _delayedDragTouchMoveHandler: function (\n /** TouchEvent|PointerEvent **/\n e) {\n let touch = e.touches ? e.touches[0] : e;\n\n if (Math.max(Math.abs(touch.clientX - this._lastX), Math.abs(touch.clientY - this._lastY)) >= Math.floor(this.options.touchStartThreshold / (this.nativeDraggable && window.devicePixelRatio || 1))) {\n this._disableDelayedDrag();\n }\n },\n _disableDelayedDrag: function () {\n dragEl && _disableDraggable(dragEl);\n clearTimeout(this._dragStartTimer);\n\n this._disableDelayedDragEvents();\n },\n _disableDelayedDragEvents: function () {\n let ownerDocument = this.el.ownerDocument;\n off(ownerDocument, "mouseup", this._disableDelayedDrag);\n off(ownerDocument, "touchend", this._disableDelayedDrag);\n off(ownerDocument, "touchcancel", this._disableDelayedDrag);\n off(ownerDocument, "mousemove", this._delayedDragTouchMoveHandler);\n off(ownerDocument, "touchmove", this._delayedDragTouchMoveHandler);\n off(ownerDocument, "pointermove", this._delayedDragTouchMoveHandler);\n },\n _triggerDragStart: function (\n /** Event */\n evt,\n /** Touch */\n touch) {\n touch = touch || evt.pointerType == "touch" && evt;\n\n if (!this.nativeDraggable || touch) {\n if (this.options.supportPointer) {\n on(document, "pointermove", this._onTouchMove);\n } else if (touch) {\n on(document, "touchmove", this._onTouchMove);\n } else {\n on(document, "mousemove", this._onTouchMove);\n }\n } else {\n on(dragEl, "dragend", this);\n on(rootEl, "dragstart", this._onDragStart);\n }\n\n try {\n if (document.selection) {\n // Timeout neccessary for IE9\n _nextTick(function () {\n document.selection.empty();\n });\n } else {\n window.getSelection().removeAllRanges();\n }\n } catch (err) {}\n },\n _dragStarted: function (fallback, evt) {\n awaitingDragStarted = false;\n\n if (rootEl && dragEl) {\n pluginEvent("dragStarted", this, {\n evt\n });\n\n if (this.nativeDraggable) {\n on(document, "dragover", _checkOutsideTargetEl);\n }\n\n let options = this.options; // Apply effect\n\n !fallback && toggleClass(dragEl, options.dragClass, false);\n toggleClass(dragEl, options.ghostClass, true);\n Sortable.active = this;\n fallback && this._appendGhost(); // Drag start event\n\n _dispatchEvent({\n sortable: this,\n name: "start",\n originalEvent: evt\n });\n } else {\n this._nulling();\n }\n },\n _emulateDragOver: function () {\n if (touchEvt) {\n this._lastX = touchEvt.clientX;\n this._lastY = touchEvt.clientY;\n\n _hideGhostForTarget();\n\n let target = document.elementFromPoint(touchEvt.clientX, touchEvt.clientY);\n let parent = target;\n\n while (target && target.shadowRoot) {\n target = target.shadowRoot.elementFromPoint(touchEvt.clientX, touchEvt.clientY);\n if (target === parent) break;\n parent = target;\n }\n\n dragEl.parentNode[expando]._isOutsideThisEl(target);\n\n if (parent) {\n do {\n if (parent[expando]) {\n let inserted;\n inserted = parent[expando]._onDragOver({\n clientX: touchEvt.clientX,\n clientY: touchEvt.clientY,\n target: target,\n rootEl: parent\n });\n\n if (inserted && !this.options.dragoverBubble) {\n break;\n }\n }\n\n target = parent; // store last element\n } while (\n /* jshint boss:true */\n parent = parent.parentNode);\n }\n\n _unhideGhostForTarget();\n }\n },\n _onTouchMove: function (\n /**TouchEvent*/\n evt) {\n if (tapEvt) {\n let options = this.options,\n fallbackTolerance = options.fallbackTolerance,\n fallbackOffset = options.fallbackOffset,\n touch = evt.touches ? evt.touches[0] : evt,\n ghostMatrix = ghostEl && matrix(ghostEl, true),\n scaleX = ghostEl && ghostMatrix && ghostMatrix.a,\n scaleY = ghostEl && ghostMatrix && ghostMatrix.d,\n relativeScrollOffset = PositionGhostAbsolutely && ghostRelativeParent && getRelativeScrollOffset(ghostRelativeParent),\n dx = (touch.clientX - tapEvt.clientX + fallbackOffset.x) / (scaleX || 1) + (relativeScrollOffset ? relativeScrollOffset[0] - ghostRelativeParentInitialScroll[0] : 0) / (scaleX || 1),\n dy = (touch.clientY - tapEvt.clientY + fallbackOffset.y) / (scaleY || 1) + (relativeScrollOffset ? relativeScrollOffset[1] - ghostRelativeParentInitialScroll[1] : 0) / (scaleY || 1); // only set the status to dragging, when we are actually dragging\n\n if (!Sortable.active && !awaitingDragStarted) {\n if (fallbackTolerance && Math.max(Math.abs(touch.clientX - this._lastX), Math.abs(touch.clientY - this._lastY)) < fallbackTolerance) {\n return;\n }\n\n this._onDragStart(evt, true);\n }\n\n if (ghostEl) {\n if (ghostMatrix) {\n ghostMatrix.e += dx - (lastDx || 0);\n ghostMatrix.f += dy - (lastDy || 0);\n } else {\n ghostMatrix = {\n a: 1,\n b: 0,\n c: 0,\n d: 1,\n e: dx,\n f: dy\n };\n }\n\n let cssMatrix = `matrix(${ghostMatrix.a},${ghostMatrix.b},${ghostMatrix.c},${ghostMatrix.d},${ghostMatrix.e},${ghostMatrix.f})`;\n css(ghostEl, "webkitTransform", cssMatrix);\n css(ghostEl, "mozTransform", cssMatrix);\n css(ghostEl, "msTransform", cssMatrix);\n css(ghostEl, "transform", cssMatrix);\n lastDx = dx;\n lastDy = dy;\n touchEvt = touch;\n }\n\n evt.cancelable && evt.preventDefault();\n }\n },\n _appendGhost: function () {\n // Bug if using scale(): https://stackoverflow.com/questions/2637058\n // Not being adjusted for\n if (!ghostEl) {\n let container = this.options.fallbackOnBody ? document.body : rootEl,\n rect = getRect(dragEl, true, PositionGhostAbsolutely, true, container),\n options = this.options; // Position absolutely\n\n if (PositionGhostAbsolutely) {\n // Get relatively positioned parent\n ghostRelativeParent = container;\n\n while (css(ghostRelativeParent, "position") === "static" && css(ghostRelativeParent, "transform") === "none" && ghostRelativeParent !== document) {\n ghostRelativeParent = ghostRelativeParent.parentNode;\n }\n\n if (ghostRelativeParent !== document.body && ghostRelativeParent !== document.documentElement) {\n if (ghostRelativeParent === document) ghostRelativeParent = getWindowScrollingElement();\n rect.top += ghostRelativeParent.scrollTop;\n rect.left += ghostRelativeParent.scrollLeft;\n } else {\n ghostRelativeParent = getWindowScrollingElement();\n }\n\n ghostRelativeParentInitialScroll = getRelativeScrollOffset(ghostRelativeParent);\n }\n\n ghostEl = dragEl.cloneNode(true);\n toggleClass(ghostEl, options.ghostClass, false);\n toggleClass(ghostEl, options.fallbackClass, true);\n toggleClass(ghostEl, options.dragClass, true);\n css(ghostEl, "transition", "");\n css(ghostEl, "transform", "");\n css(ghostEl, "box-sizing", "border-box");\n css(ghostEl, "margin", 0);\n css(ghostEl, "top", rect.top);\n css(ghostEl, "left", rect.left);\n css(ghostEl, "width", rect.width);\n css(ghostEl, "height", rect.height);\n css(ghostEl, "opacity", "0.8");\n css(ghostEl, "position", PositionGhostAbsolutely ? "absolute" : "fixed");\n css(ghostEl, "zIndex", "100000");\n css(ghostEl, "pointerEvents", "none");\n Sortable.ghost = ghostEl;\n container.appendChild(ghostEl); // Set transform-origin\n\n css(ghostEl, "transform-origin", tapDistanceLeft / parseInt(ghostEl.style.width) * 100 + "% " + tapDistanceTop / parseInt(ghostEl.style.height) * 100 + "%");\n }\n },\n _onDragStart: function (\n /**Event*/\n evt,\n /**boolean*/\n fallback) {\n let _this = this;\n\n let dataTransfer = evt.dataTransfer;\n let options = _this.options;\n pluginEvent("dragStart", this, {\n evt\n });\n\n if (Sortable.eventCanceled) {\n this._onDrop();\n\n return;\n }\n\n pluginEvent("setupClone", this);\n\n if (!Sortable.eventCanceled) {\n cloneEl = clone(dragEl);\n cloneEl.draggable = false;\n cloneEl.style["will-change"] = "";\n\n this._hideClone();\n\n toggleClass(cloneEl, this.options.chosenClass, false);\n Sortable.clone = cloneEl;\n } // #1143: IFrame support workaround\n\n\n _this.cloneId = _nextTick(function () {\n pluginEvent("clone", _this);\n if (Sortable.eventCanceled) return;\n\n if (!_this.options.removeCloneOnHide) {\n rootEl.insertBefore(cloneEl, dragEl);\n }\n\n _this._hideClone();\n\n _dispatchEvent({\n sortable: _this,\n name: "clone"\n });\n });\n !fallback && toggleClass(dragEl, options.dragClass, true); // Set proper drop events\n\n if (fallback) {\n ignoreNextClick = true;\n _this._loopId = setInterval(_this._emulateDragOver, 50);\n } else {\n // Undo what was set in _prepareDragStart before drag started\n off(document, "mouseup", _this._onDrop);\n off(document, "touchend", _this._onDrop);\n off(document, "touchcancel", _this._onDrop);\n\n if (dataTransfer) {\n dataTransfer.effectAllowed = "move";\n options.setData && options.setData.call(_this, dataTransfer, dragEl);\n }\n\n on(document, "drop", _this); // #1276 fix:\n\n css(dragEl, "transform", "translateZ(0)");\n }\n\n awaitingDragStarted = true;\n _this._dragStartId = _nextTick(_this._dragStarted.bind(_this, fallback, evt));\n on(document, "selectstart", _this);\n moved = true;\n\n if (Safari) {\n css(document.body, "user-select", "none");\n }\n },\n // Returns true - if no further action is needed (either inserted or another condition)\n _onDragOver: function (\n /**Event*/\n evt) {\n let el = this.el,\n target = evt.target,\n dragRect,\n targetRect,\n revert,\n options = this.options,\n group = options.group,\n activeSortable = Sortable.active,\n isOwner = activeGroup === group,\n canSort = options.sort,\n fromSortable = putSortable || activeSortable,\n vertical,\n _this = this,\n completedFired = false;\n\n if (_silent) return;\n\n function dragOverEvent(name, extra) {\n pluginEvent(name, _this, _objectSpread({\n evt,\n isOwner,\n axis: vertical ? "vertical" : "horizontal",\n revert,\n dragRect,\n targetRect,\n canSort,\n fromSortable,\n target,\n completed,\n\n onMove(target, after) {\n return onMove(rootEl, el, dragEl, dragRect, target, getRect(target), evt, after);\n },\n\n changed\n }, extra));\n } // Capture animation state\n\n\n function capture() {\n dragOverEvent("dragOverAnimationCapture");\n\n _this.captureAnimationState();\n\n if (_this !== fromSortable) {\n fromSortable.captureAnimationState();\n }\n } // Return invocation when dragEl is inserted (or completed)\n\n\n function completed(insertion) {\n dragOverEvent("dragOverCompleted", {\n insertion\n });\n\n if (insertion) {\n // Clones must be hidden before folding animation to capture dragRectAbsolute properly\n if (isOwner) {\n activeSortable._hideClone();\n } else {\n activeSortable._showClone(_this);\n }\n\n if (_this !== fromSortable) {\n // Set ghost class to new sortable\'s ghost class\n toggleClass(dragEl, putSortable ? putSortable.options.ghostClass : activeSortable.options.ghostClass, false);\n toggleClass(dragEl, options.ghostClass, true);\n }\n\n if (putSortable !== _this && _this !== Sortable.active) {\n putSortable = _this;\n } else if (_this === Sortable.active && putSortable) {\n putSortable = null;\n } // Animation\n\n\n if (fromSortable === _this) {\n _this._ignoreWhileAnimating = target;\n }\n\n _this.animateAll(function () {\n dragOverEvent("dragOverAnimationComplete");\n _this._ignoreWhileAnimating = null;\n });\n\n if (_this !== fromSortable) {\n fromSortable.animateAll();\n fromSortable._ignoreWhileAnimating = null;\n }\n } // Null lastTarget if it is not inside a previously swapped element\n\n\n if (target === dragEl && !dragEl.animated || target === el && !target.animated) {\n lastTarget = null;\n } // no bubbling and not fallback\n\n\n if (!options.dragoverBubble && !evt.rootEl && target !== document) {\n dragEl.parentNode[expando]._isOutsideThisEl(evt.target); // Do not detect for empty insert if already inserted\n\n\n !insertion && nearestEmptyInsertDetectEvent(evt);\n }\n\n !options.dragoverBubble && evt.stopPropagation && evt.stopPropagation();\n return completedFired = true;\n } // Call when dragEl has been inserted\n\n\n function changed() {\n newIndex = index(dragEl);\n newDraggableIndex = index(dragEl, options.draggable);\n\n _dispatchEvent({\n sortable: _this,\n name: "change",\n toEl: el,\n newIndex,\n newDraggableIndex,\n originalEvent: evt\n });\n }\n\n if (evt.preventDefault !== void 0) {\n evt.cancelable && evt.preventDefault();\n }\n\n target = closest(target, options.draggable, el, true);\n dragOverEvent("dragOver");\n if (Sortable.eventCanceled) return completedFired;\n\n if (dragEl.contains(evt.target) || target.animated && target.animatingX && target.animatingY || _this._ignoreWhileAnimating === target) {\n return completed(false);\n }\n\n ignoreNextClick = false;\n\n if (activeSortable && !options.disabled && (isOwner ? canSort || (revert = !rootEl.contains(dragEl)) // Reverting item into the original list\n : putSortable === this || (this.lastPutMode = activeGroup.checkPull(this, activeSortable, dragEl, evt)) && group.checkPut(this, activeSortable, dragEl, evt))) {\n vertical = this._getDirection(evt, target) === "vertical";\n dragRect = getRect(dragEl);\n dragOverEvent("dragOverValid");\n if (Sortable.eventCanceled) return completedFired;\n\n if (revert) {\n parentEl = rootEl; // actualization\n\n capture();\n\n this._hideClone();\n\n dragOverEvent("revert");\n\n if (!Sortable.eventCanceled) {\n if (nextEl) {\n rootEl.insertBefore(dragEl, nextEl);\n } else {\n rootEl.appendChild(dragEl);\n }\n }\n\n return completed(true);\n }\n\n let elLastChild = lastChild(el, options.draggable);\n\n if (!elLastChild || _ghostIsLast(evt, vertical, this) && !elLastChild.animated) {\n // If already at end of list: Do not insert\n if (elLastChild === dragEl) {\n return completed(false);\n } // assign target only if condition is true\n\n\n if (elLastChild && el === evt.target) {\n target = elLastChild;\n }\n\n if (target) {\n targetRect = getRect(target);\n }\n\n if (onMove(rootEl, el, dragEl, dragRect, target, targetRect, evt, !!target) !== false) {\n capture();\n el.appendChild(dragEl);\n parentEl = el; // actualization\n\n changed();\n return completed(true);\n }\n } else if (target.parentNode === el) {\n targetRect = getRect(target);\n let direction = 0,\n targetBeforeFirstSwap,\n differentLevel = dragEl.parentNode !== el,\n differentRowCol = !_dragElInRowColumn(dragEl.animated && dragEl.toRect || dragRect, target.animated && target.toRect || targetRect, vertical),\n side1 = vertical ? "top" : "left",\n scrolledPastTop = isScrolledPast(target, "top", "top") || isScrolledPast(dragEl, "top", "top"),\n scrollBefore = scrolledPastTop ? scrolledPastTop.scrollTop : void 0;\n\n if (lastTarget !== target) {\n targetBeforeFirstSwap = targetRect[side1];\n pastFirstInvertThresh = false;\n isCircumstantialInvert = !differentRowCol && options.invertSwap || differentLevel;\n }\n\n direction = _getSwapDirection(evt, target, targetRect, vertical, differentRowCol ? 1 : options.swapThreshold, options.invertedSwapThreshold == null ? options.swapThreshold : options.invertedSwapThreshold, isCircumstantialInvert, lastTarget === target);\n let sibling;\n\n if (direction !== 0) {\n // Check if target is beside dragEl in respective direction (ignoring hidden elements)\n let dragIndex = index(dragEl);\n\n do {\n dragIndex -= direction;\n sibling = parentEl.children[dragIndex];\n } while (sibling && (css(sibling, "display") === "none" || sibling === ghostEl));\n } // If dragEl is already beside target: Do not insert\n\n\n if (direction === 0 || sibling === target) {\n return completed(false);\n }\n\n lastTarget = target;\n lastDirection = direction;\n let nextSibling = target.nextElementSibling,\n after = false;\n after = direction === 1;\n let moveVector = onMove(rootEl, el, dragEl, dragRect, target, targetRect, evt, after);\n\n if (moveVector !== false) {\n if (moveVector === 1 || moveVector === -1) {\n after = moveVector === 1;\n }\n\n _silent = true;\n setTimeout(_unsilent, 30);\n capture();\n\n if (after && !nextSibling) {\n el.appendChild(dragEl);\n } else {\n target.parentNode.insertBefore(dragEl, after ? nextSibling : target);\n } // Undo chrome\'s scroll adjustment (has no effect on other browsers)\n\n\n if (scrolledPastTop) {\n scrollBy(scrolledPastTop, 0, scrollBefore - scrolledPastTop.scrollTop);\n }\n\n parentEl = dragEl.parentNode; // actualization\n // must be done before animation\n\n if (targetBeforeFirstSwap !== undefined && !isCircumstantialInvert) {\n targetMoveDistance = Math.abs(targetBeforeFirstSwap - getRect(target)[side1]);\n }\n\n changed();\n return completed(true);\n }\n }\n\n if (el.contains(dragEl)) {\n return completed(false);\n }\n }\n\n return false;\n },\n _ignoreWhileAnimating: null,\n _offMoveEvents: function () {\n off(document, "mousemove", this._onTouchMove);\n off(document, "touchmove", this._onTouchMove);\n off(document, "pointermove", this._onTouchMove);\n off(document, "dragover", nearestEmptyInsertDetectEvent);\n off(document, "mousemove", nearestEmptyInsertDetectEvent);\n off(document, "touchmove", nearestEmptyInsertDetectEvent);\n },\n _offUpEvents: function () {\n let ownerDocument = this.el.ownerDocument;\n off(ownerDocument, "mouseup", this._onDrop);\n off(ownerDocument, "touchend", this._onDrop);\n off(ownerDocument, "pointerup", this._onDrop);\n off(ownerDocument, "touchcancel", this._onDrop);\n off(document, "selectstart", this);\n },\n _onDrop: function (\n /**Event*/\n evt) {\n let el = this.el,\n options = this.options; // Get the index of the dragged element within its parent\n\n newIndex = index(dragEl);\n newDraggableIndex = index(dragEl, options.draggable);\n pluginEvent("drop", this, {\n evt\n });\n parentEl = dragEl && dragEl.parentNode; // Get again after plugin event\n\n newIndex = index(dragEl);\n newDraggableIndex = index(dragEl, options.draggable);\n\n if (Sortable.eventCanceled) {\n this._nulling();\n\n return;\n }\n\n awaitingDragStarted = false;\n isCircumstantialInvert = false;\n pastFirstInvertThresh = false;\n clearInterval(this._loopId);\n clearTimeout(this._dragStartTimer);\n\n _cancelNextTick(this.cloneId);\n\n _cancelNextTick(this._dragStartId); // Unbind events\n\n\n if (this.nativeDraggable) {\n off(document, "drop", this);\n off(el, "dragstart", this._onDragStart);\n }\n\n this._offMoveEvents();\n\n this._offUpEvents();\n\n if (Safari) {\n css(document.body, "user-select", "");\n }\n\n css(dragEl, "transform", "");\n\n if (evt) {\n if (moved) {\n evt.cancelable && evt.preventDefault();\n !options.dropBubble && evt.stopPropagation();\n }\n\n ghostEl && ghostEl.parentNode && ghostEl.parentNode.removeChild(ghostEl);\n\n if (rootEl === parentEl || putSortable && putSortable.lastPutMode !== "clone") {\n // Remove clone(s)\n cloneEl && cloneEl.parentNode && cloneEl.parentNode.removeChild(cloneEl);\n }\n\n if (dragEl) {\n if (this.nativeDraggable) {\n off(dragEl, "dragend", this);\n }\n\n _disableDraggable(dragEl);\n\n dragEl.style["will-change"] = ""; // Remove classes\n // ghostClass is added in dragStarted\n\n if (moved && !awaitingDragStarted) {\n toggleClass(dragEl, putSortable ? putSortable.options.ghostClass : this.options.ghostClass, false);\n }\n\n toggleClass(dragEl, this.options.chosenClass, false); // Drag stop event\n\n _dispatchEvent({\n sortable: this,\n name: "unchoose",\n toEl: parentEl,\n newIndex: null,\n newDraggableIndex: null,\n originalEvent: evt\n });\n\n if (rootEl !== parentEl) {\n if (newIndex >= 0) {\n // Add event\n _dispatchEvent({\n rootEl: parentEl,\n name: "add",\n toEl: parentEl,\n fromEl: rootEl,\n originalEvent: evt\n }); // Remove event\n\n\n _dispatchEvent({\n sortable: this,\n name: "remove",\n toEl: parentEl,\n originalEvent: evt\n }); // drag from one list and drop into another\n\n\n _dispatchEvent({\n rootEl: parentEl,\n name: "sort",\n toEl: parentEl,\n fromEl: rootEl,\n originalEvent: evt\n });\n\n _dispatchEvent({\n sortable: this,\n name: "sort",\n toEl: parentEl,\n originalEvent: evt\n });\n }\n\n putSortable && putSortable.save();\n } else {\n if (newIndex !== oldIndex) {\n if (newIndex >= 0) {\n // drag & drop within the same list\n _dispatchEvent({\n sortable: this,\n name: "update",\n toEl: parentEl,\n originalEvent: evt\n });\n\n _dispatchEvent({\n sortable: this,\n name: "sort",\n toEl: parentEl,\n originalEvent: evt\n });\n }\n }\n }\n\n if (Sortable.active) {\n /* jshint eqnull:true */\n if (newIndex == null || newIndex === -1) {\n newIndex = oldIndex;\n newDraggableIndex = oldDraggableIndex;\n }\n\n _dispatchEvent({\n sortable: this,\n name: "end",\n toEl: parentEl,\n originalEvent: evt\n }); // Save sorting\n\n\n this.save();\n } else {\n // PORTME: added the dispatch block\n _dispatchEvent({\n sortable: this,\n name: \'end\',\n toEl: parentEl,\n originalEvent: evt\n });\n }\n }\n }\n\n this._nulling();\n },\n _nulling: function () {\n pluginEvent("nulling", this);\n rootEl = dragEl = parentEl = ghostEl = nextEl = cloneEl = lastDownEl = cloneHidden = tapEvt = touchEvt = moved = newIndex = newDraggableIndex = oldIndex = oldDraggableIndex = lastTarget = lastDirection = putSortable = activeGroup = Sortable.dragged = Sortable.ghost = Sortable.clone = Sortable.active = null;\n savedInputChecked.forEach(function (el) {\n el.checked = true;\n });\n savedInputChecked.length = lastDx = lastDy = 0;\n },\n handleEvent: function (\n /**Event*/\n evt) {\n switch (evt.type) {\n case "drop":\n case "dragend":\n this._onDrop(evt);\n\n break;\n\n case "dragenter":\n case "dragover":\n if (dragEl) {\n this._onDragOver(evt);\n\n _globalDragOver(evt);\n }\n\n break;\n\n case "selectstart":\n evt.preventDefault();\n break;\n }\n },\n\n /**\n * Serializes the item into an array of string.\n * @returns {String[]}\n */\n toArray: function () {\n let order = [],\n el,\n children = this.el.children,\n i = 0,\n n = children.length,\n options = this.options;\n\n for (; i < n; i++) {\n el = children[i];\n\n if (closest(el, options.draggable, this.el, false)) {\n order.push(el.getAttribute(options.dataIdAttr) || _generateId(el));\n }\n }\n\n return order;\n },\n\n /**\n * Sorts the elements according to the array.\n * @param {String[]} order order of the items\n */\n sort: function (order) {\n let items = {},\n rootEl = this.el;\n this.toArray().forEach(function (id, i) {\n let el = rootEl.children[i];\n\n if (closest(el, this.options.draggable, rootEl, false)) {\n items[id] = el;\n }\n }, this);\n order.forEach(function (id) {\n if (items[id]) {\n rootEl.removeChild(items[id]);\n rootEl.appendChild(items[id]);\n }\n });\n },\n\n /**\n * Save the current sorting\n */\n save: function () {\n let store = this.options.store;\n store && store.set && store.set(this);\n },\n\n /**\n * For each element in the set, get the first element that matches the selector by testing the element itself and traversing up through its ancestors in the DOM tree.\n * @param {HTMLElement} el\n * @param {String} [selector] default: `options.draggable`\n * @returns {HTMLElement|null}\n */\n closest: function (el, selector) {\n return closest(el, selector || this.options.draggable, this.el, false);\n },\n\n /**\n * Set/get option\n * @param {string} name\n * @param {*} [value]\n * @returns {*}\n */\n option: function (name, value) {\n let options = this.options;\n\n if (value === void 0) {\n return options[name];\n } else {\n let modifiedValue = PluginManager.modifyOption(this, name, value);\n\n if (typeof modifiedValue !== "undefined") {\n options[name] = modifiedValue;\n } else {\n options[name] = value;\n }\n\n if (name === "group") {\n _prepareGroup(options);\n }\n }\n },\n\n /**\n * Destroy\n */\n destroy: function () {\n pluginEvent("destroy", this);\n let el = this.el;\n el[expando] = null;\n off(el, "mousedown", this._onTapStart);\n off(el, "touchstart", this._onTapStart);\n off(el, "pointerdown", this._onTapStart);\n\n if (this.nativeDraggable) {\n off(el, "dragover", this);\n off(el, "dragenter", this);\n } // Remove draggable attributes\n\n\n Array.prototype.forEach.call(el.querySelectorAll("[draggable]"), function (el) {\n el.removeAttribute("draggable");\n });\n\n this._onDrop();\n\n this._disableDelayedDragEvents();\n\n sortables.splice(sortables.indexOf(this.el), 1);\n this.el = el = null;\n },\n _hideClone: function () {\n if (!cloneHidden) {\n pluginEvent("hideClone", this);\n if (Sortable.eventCanceled) return;\n css(cloneEl, "display", "none");\n\n if (this.options.removeCloneOnHide && cloneEl.parentNode) {\n cloneEl.parentNode.removeChild(cloneEl);\n }\n\n cloneHidden = true;\n }\n },\n _showClone: function (putSortable) {\n if (putSortable.lastPutMode !== "clone") {\n this._hideClone();\n\n return;\n }\n\n if (cloneHidden) {\n pluginEvent("showClone", this);\n if (Sortable.eventCanceled) return; // show clone at dragEl or original position\n\n if (dragEl.parentNode == rootEl && !this.options.group.revertClone) {\n rootEl.insertBefore(cloneEl, dragEl);\n } else if (nextEl) {\n rootEl.insertBefore(cloneEl, nextEl);\n } else {\n rootEl.appendChild(cloneEl);\n }\n\n if (this.options.group.revertClone) {\n this.animate(dragEl, cloneEl);\n }\n\n css(cloneEl, "display", "");\n cloneHidden = false;\n }\n }\n };\n\n function _globalDragOver(\n /**Event*/\n evt) {\n if (evt.dataTransfer) {\n evt.dataTransfer.dropEffect = "move";\n }\n\n evt.cancelable && evt.preventDefault();\n }\n\n function onMove(fromEl, toEl, dragEl, dragRect, targetEl, targetRect, originalEvent, willInsertAfter) {\n let evt,\n sortable = fromEl[expando],\n onMoveFn = sortable.options.onMove,\n retVal; // Support for new CustomEvent feature\n\n if (window.CustomEvent && !IE11OrLess && !Edge) {\n evt = new CustomEvent("move", {\n bubbles: true,\n cancelable: true\n });\n } else {\n evt = document.createEvent("Event");\n evt.initEvent("move", true, true);\n }\n\n evt.to = toEl;\n evt.from = fromEl;\n evt.dragged = dragEl;\n evt.draggedRect = dragRect;\n evt.related = targetEl || toEl;\n evt.relatedRect = targetRect || getRect(toEl);\n evt.willInsertAfter = willInsertAfter;\n evt.originalEvent = originalEvent;\n fromEl.dispatchEvent(evt);\n\n if (onMoveFn) {\n retVal = onMoveFn.call(sortable, evt, originalEvent);\n }\n\n return retVal;\n }\n\n function _disableDraggable(el) {\n el.draggable = false;\n }\n\n function _unsilent() {\n _silent = false;\n }\n\n function _ghostIsLast(evt, vertical, sortable) {\n let rect = getRect(lastChild(sortable.el, sortable.options.draggable));\n const spacer = 10;\n return vertical ? evt.clientX > rect.right + spacer || evt.clientX <= rect.right && evt.clientY > rect.bottom && evt.clientX >= rect.left : evt.clientX > rect.right && evt.clientY > rect.top || evt.clientX <= rect.right && evt.clientY > rect.bottom + spacer;\n }\n\n function _getSwapDirection(evt, target, targetRect, vertical, swapThreshold, invertedSwapThreshold, invertSwap, isLastTarget) {\n let mouseOnAxis = vertical ? evt.clientY : evt.clientX,\n targetLength = vertical ? targetRect.height : targetRect.width,\n targetS1 = vertical ? targetRect.top : targetRect.left,\n targetS2 = vertical ? targetRect.bottom : targetRect.right,\n invert = false;\n\n if (!invertSwap) {\n // Never invert or create dragEl shadow when target movemenet causes mouse to move past the end of regular swapThreshold\n if (isLastTarget && targetMoveDistance < targetLength * swapThreshold) {\n // multiplied only by swapThreshold because mouse will already be inside target by (1 - threshold) * targetLength / 2\n // check if past first invert threshold on side opposite of lastDirection\n if (!pastFirstInvertThresh && (lastDirection === 1 ? mouseOnAxis > targetS1 + targetLength * invertedSwapThreshold / 2 : mouseOnAxis < targetS2 - targetLength * invertedSwapThreshold / 2)) {\n // past first invert threshold, do not restrict inverted threshold to dragEl shadow\n pastFirstInvertThresh = true;\n }\n\n if (!pastFirstInvertThresh) {\n // dragEl shadow (target move distance shadow)\n if (lastDirection === 1 ? mouseOnAxis < targetS1 + targetMoveDistance // over dragEl shadow\n : mouseOnAxis > targetS2 - targetMoveDistance) {\n return -lastDirection;\n }\n } else {\n invert = true;\n }\n } else {\n // Regular\n if (mouseOnAxis > targetS1 + targetLength * (1 - swapThreshold) / 2 && mouseOnAxis < targetS2 - targetLength * (1 - swapThreshold) / 2) {\n return _getInsertDirection(target);\n }\n }\n }\n\n invert = invert || invertSwap;\n\n if (invert) {\n // Invert of regular\n if (mouseOnAxis < targetS1 + targetLength * invertedSwapThreshold / 2 || mouseOnAxis > targetS2 - targetLength * invertedSwapThreshold / 2) {\n return mouseOnAxis > targetS1 + targetLength / 2 ? 1 : -1;\n }\n }\n\n return 0;\n }\n /**\n * Gets the direction dragEl must be swapped relative to target in order to make it\n * seem that dragEl has been "inserted" into that element\'s position\n * @param {HTMLElement} target The target whose position dragEl is being inserted at\n * @return {Number} Direction dragEl must be swapped\n */\n\n\n function _getInsertDirection(target) {\n if (index(dragEl) < index(target)) {\n return 1;\n } else {\n return -1;\n }\n }\n /**\n * Generate id\n * @param {HTMLElement} el\n * @returns {String}\n * @private\n */\n\n\n function _generateId(el) {\n let str = el.tagName + el.className + el.src + el.href + el.textContent,\n i = str.length,\n sum = 0;\n\n while (i--) {\n sum += str.charCodeAt(i);\n }\n\n return sum.toString(36);\n }\n\n function _saveInputCheckedState(root) {\n savedInputChecked.length = 0;\n let inputs = root.getElementsByTagName("input");\n let idx = inputs.length;\n\n while (idx--) {\n let el = inputs[idx];\n el.checked && savedInputChecked.push(el);\n }\n }\n\n function _nextTick(fn) {\n return setTimeout(fn, 0);\n }\n\n function _cancelNextTick(id) {\n return clearTimeout(id);\n } // Fixed #973:\n\n\n if (documentExists) {\n on(document, "touchmove", function (evt) {\n if ((Sortable.active || awaitingDragStarted) && evt.cancelable) {\n evt.preventDefault();\n }\n });\n } // Export utils\n\n\n Sortable.utils = {\n on: on,\n off: off,\n css: css,\n find: find,\n is: function (el, selector) {\n return !!closest(el, selector, el, false);\n },\n extend: extend,\n throttle: throttle,\n closest: closest,\n toggleClass: toggleClass,\n clone: clone,\n index: index,\n nextTick: _nextTick,\n cancelNextTick: _cancelNextTick,\n detectDirection: _detectDirection,\n getChild: getChild\n };\n /**\n * Get the Sortable instance of an element\n * @param {HTMLElement} element The element\n * @return {Sortable|undefined} The instance of Sortable\n */\n\n Sortable.get = function (element) {\n return element[expando];\n };\n /**\n * Mount a plugin to Sortable\n * @param {...SortablePlugin|SortablePlugin[]} plugins Plugins being mounted\n */\n\n\n Sortable.mount = function () {\n for (var _len = arguments.length, plugins = new Array(_len), _key = 0; _key < _len; _key++) {\n plugins[_key] = arguments[_key];\n }\n\n if (plugins[0].constructor === Array) plugins = plugins[0];\n plugins.forEach(plugin => {\n if (!plugin.prototype || !plugin.prototype.constructor) {\n throw `Sortable: Mounted plugin must be a constructor function, not ${{}.toString.call(plugin)}`;\n }\n\n if (plugin.utils) Sortable.utils = _objectSpread(_objectSpread({}, Sortable.utils), plugin.utils);\n PluginManager.mount(plugin);\n });\n };\n /**\n * Create sortable instance\n * @param {HTMLElement} el\n * @param {Object} [options]\n */\n\n\n Sortable.create = function (el, options) {\n return new Sortable(el, options);\n }; // Export\n\n\n Sortable.version = version;\n let autoScrolls = [],\n scrollEl,\n scrollRootEl,\n scrolling = false,\n lastAutoScrollX,\n lastAutoScrollY,\n touchEvt$1,\n pointerElemChangedInterval;\n\n function AutoScrollPlugin() {\n function AutoScroll() {\n this.defaults = {\n scroll: true,\n scrollSensitivity: 30,\n scrollSpeed: 10,\n bubbleScroll: true\n }; // Bind all private methods\n\n for (let fn in this) {\n if (fn.charAt(0) === "_" && typeof this[fn] === "function") {\n this[fn] = this[fn].bind(this);\n }\n }\n }\n\n AutoScroll.prototype = {\n dragStarted(_ref3) {\n let {\n originalEvent\n } = _ref3;\n\n if (this.sortable.nativeDraggable) {\n on(document, "dragover", this._handleAutoScroll);\n } else {\n if (this.options.supportPointer) {\n on(document, "pointermove", this._handleFallbackAutoScroll);\n } else if (originalEvent.touches) {\n on(document, "touchmove", this._handleFallbackAutoScroll);\n } else {\n on(document, "mousemove", this._handleFallbackAutoScroll);\n }\n }\n },\n\n dragOverCompleted(_ref4) {\n let {\n originalEvent\n } = _ref4;\n\n // For when bubbling is canceled and using fallback (fallback \'touchmove\' always reached)\n if (!this.options.dragOverBubble && !originalEvent.rootEl) {\n this._handleAutoScroll(originalEvent);\n }\n },\n\n drop() {\n if (this.sortable.nativeDraggable) {\n off(document, "dragover", this._handleAutoScroll);\n } else {\n off(document, "pointermove", this._handleFallbackAutoScroll);\n off(document, "touchmove", this._handleFallbackAutoScroll);\n off(document, "mousemove", this._handleFallbackAutoScroll);\n }\n\n clearPointerElemChangedInterval();\n clearAutoScrolls();\n cancelThrottle();\n },\n\n nulling() {\n touchEvt$1 = scrollRootEl = scrollEl = scrolling = pointerElemChangedInterval = lastAutoScrollX = lastAutoScrollY = null;\n autoScrolls.length = 0;\n },\n\n _handleFallbackAutoScroll(evt) {\n this._handleAutoScroll(evt, true);\n },\n\n _handleAutoScroll(evt, fallback) {\n const x = (evt.touches ? evt.touches[0] : evt).clientX,\n y = (evt.touches ? evt.touches[0] : evt).clientY,\n elem = document.elementFromPoint(x, y);\n touchEvt$1 = evt; // IE does not seem to have native autoscroll,\n // Edge\'s autoscroll seems too conditional,\n // MACOS Safari does not have autoscroll,\n // Firefox and Chrome are good\n\n if (fallback || Edge || IE11OrLess || Safari) {\n autoScroll(evt, this.options, elem, fallback); // Listener for pointer element change\n\n let ogElemScroller = getParentAutoScrollElement(elem, true);\n\n if (scrolling && (!pointerElemChangedInterval || x !== lastAutoScrollX || y !== lastAutoScrollY)) {\n pointerElemChangedInterval && clearPointerElemChangedInterval(); // Detect for pointer elem change, emulating native DnD behaviour\n\n pointerElemChangedInterval = setInterval(() => {\n let newElem = getParentAutoScrollElement(document.elementFromPoint(x, y), true);\n\n if (newElem !== ogElemScroller) {\n ogElemScroller = newElem;\n clearAutoScrolls();\n }\n\n autoScroll(evt, this.options, newElem, fallback);\n }, 10);\n lastAutoScrollX = x;\n lastAutoScrollY = y;\n }\n } else {\n // if DnD is enabled (and browser has good autoscrolling), first autoscroll will already scroll, so get parent autoscroll of first autoscroll\n if (!this.options.bubbleScroll || getParentAutoScrollElement(elem, true) === getWindowScrollingElement()) {\n clearAutoScrolls();\n return;\n }\n\n autoScroll(evt, this.options, getParentAutoScrollElement(elem, false), false);\n }\n }\n\n };\n return Object.assign(AutoScroll, {\n pluginName: "scroll",\n initializeByDefault: true\n });\n }\n\n function clearAutoScrolls() {\n autoScrolls.forEach(function (autoScroll) {\n clearInterval(autoScroll.pid);\n });\n autoScrolls = [];\n }\n\n function clearPointerElemChangedInterval() {\n clearInterval(pointerElemChangedInterval);\n }\n\n const autoScroll = throttle(function (evt, options, rootEl, isFallback) {\n // Bug: https://bugzilla.mozilla.org/show_bug.cgi?id=505521\n if (!options.scroll) return;\n const x = (evt.touches ? evt.touches[0] : evt).clientX,\n y = (evt.touches ? evt.touches[0] : evt).clientY,\n sens = options.scrollSensitivity,\n speed = options.scrollSpeed,\n winScroller = getWindowScrollingElement();\n let scrollThisInstance = false,\n scrollCustomFn; // New scroll root, set scrollEl\n\n if (scrollRootEl !== rootEl) {\n scrollRootEl = rootEl;\n clearAutoScrolls();\n scrollEl = options.scroll;\n scrollCustomFn = options.scrollFn;\n\n if (scrollEl === true) {\n scrollEl = getParentAutoScrollElement(rootEl, true);\n }\n }\n\n let layersOut = 0;\n let currentParent = scrollEl;\n\n do {\n let el = currentParent,\n rect = getRect(el),\n top = rect.top,\n bottom = rect.bottom,\n left = rect.left,\n right = rect.right,\n width = rect.width,\n height = rect.height,\n canScrollX,\n canScrollY,\n scrollWidth = el.scrollWidth,\n scrollHeight = el.scrollHeight,\n elCSS = css(el),\n scrollPosX = el.scrollLeft,\n scrollPosY = el.scrollTop;\n\n if (el === winScroller) {\n canScrollX = width < scrollWidth && (elCSS.overflowX === "auto" || elCSS.overflowX === "scroll" || elCSS.overflowX === "visible");\n canScrollY = height < scrollHeight && (elCSS.overflowY === "auto" || elCSS.overflowY === "scroll" || elCSS.overflowY === "visible");\n } else {\n canScrollX = width < scrollWidth && (elCSS.overflowX === "auto" || elCSS.overflowX === "scroll");\n canScrollY = height < scrollHeight && (elCSS.overflowY === "auto" || elCSS.overflowY === "scroll");\n }\n\n let vx = canScrollX && (Math.abs(right - x) <= sens && scrollPosX + width < scrollWidth) - (Math.abs(left - x) <= sens && !!scrollPosX);\n let vy = canScrollY && (Math.abs(bottom - y) <= sens && scrollPosY + height < scrollHeight) - (Math.abs(top - y) <= sens && !!scrollPosY);\n\n if (!autoScrolls[layersOut]) {\n for (let i = 0; i <= layersOut; i++) {\n if (!autoScrolls[i]) {\n autoScrolls[i] = {};\n }\n }\n }\n\n if (autoScrolls[layersOut].vx != vx || autoScrolls[layersOut].vy != vy || autoScrolls[layersOut].el !== el) {\n autoScrolls[layersOut].el = el;\n autoScrolls[layersOut].vx = vx;\n autoScrolls[layersOut].vy = vy;\n clearInterval(autoScrolls[layersOut].pid);\n\n if (vx != 0 || vy != 0) {\n scrollThisInstance = true;\n /* jshint loopfunc:true */\n\n autoScrolls[layersOut].pid = setInterval(function () {\n // emulate drag over during autoscroll (fallback), emulating native DnD behaviour\n if (isFallback && this.layer === 0) {\n Sortable.active._onTouchMove(touchEvt$1); // To move ghost if it is positioned absolutely\n\n }\n\n let scrollOffsetY = autoScrolls[this.layer].vy ? autoScrolls[this.layer].vy * speed : 0;\n let scrollOffsetX = autoScrolls[this.layer].vx ? autoScrolls[this.layer].vx * speed : 0;\n\n if (typeof scrollCustomFn === "function") {\n if (scrollCustomFn.call(Sortable.dragged.parentNode[expando], scrollOffsetX, scrollOffsetY, evt, touchEvt$1, autoScrolls[this.layer].el) !== "continue") {\n return;\n }\n }\n\n scrollBy(autoScrolls[this.layer].el, scrollOffsetX, scrollOffsetY);\n }.bind({\n layer: layersOut\n }), 24);\n }\n }\n\n layersOut++;\n } while (options.bubbleScroll && currentParent !== winScroller && (currentParent = getParentAutoScrollElement(currentParent, false)));\n\n scrolling = scrollThisInstance; // in case another function catches scrolling as false in between when it is not\n }, 30);\n\n const drop = function (_ref5) {\n let {\n originalEvent,\n putSortable,\n dragEl,\n activeSortable,\n dispatchSortableEvent,\n hideGhostForTarget,\n unhideGhostForTarget\n } = _ref5;\n if (!originalEvent) return;\n let toSortable = putSortable || activeSortable;\n hideGhostForTarget();\n let touch = originalEvent.changedTouches && originalEvent.changedTouches.length ? originalEvent.changedTouches[0] : originalEvent;\n let target = document.elementFromPoint(touch.clientX, touch.clientY);\n unhideGhostForTarget();\n\n if (toSortable && !toSortable.el.contains(target)) {\n dispatchSortableEvent("spill");\n this.onSpill({\n dragEl,\n putSortable\n });\n }\n };\n\n function Revert() {}\n\n Revert.prototype = {\n startIndex: null,\n\n dragStart(_ref6) {\n let {\n oldDraggableIndex\n } = _ref6;\n this.startIndex = oldDraggableIndex;\n },\n\n onSpill(_ref7) {\n let {\n dragEl,\n putSortable\n } = _ref7;\n this.sortable.captureAnimationState();\n\n if (putSortable) {\n putSortable.captureAnimationState();\n }\n\n let nextSibling = getChild(this.sortable.el, this.startIndex, this.options);\n\n if (nextSibling) {\n this.sortable.el.insertBefore(dragEl, nextSibling);\n } else {\n this.sortable.el.appendChild(dragEl);\n }\n\n this.sortable.animateAll();\n\n if (putSortable) {\n putSortable.animateAll();\n }\n },\n\n drop\n };\n Object.assign(Revert, {\n pluginName: "revertOnSpill"\n });\n\n function Remove() {}\n\n Remove.prototype = {\n onSpill(_ref8) {\n let {\n dragEl,\n putSortable\n } = _ref8;\n const parentSortable = putSortable || this.sortable;\n parentSortable.captureAnimationState();\n dragEl.parentNode && dragEl.parentNode.removeChild(dragEl);\n parentSortable.animateAll();\n },\n\n drop\n };\n Object.assign(Remove, {\n pluginName: "removeOnSpill"\n });\n let lastSwapEl;\n\n function SwapPlugin() {\n function Swap() {\n this.defaults = {\n swapClass: "sortable-swap-highlight"\n };\n }\n\n Swap.prototype = {\n dragStart(_ref9) {\n let {\n dragEl\n } = _ref9;\n lastSwapEl = dragEl;\n },\n\n dragOverValid(_ref10) {\n let {\n completed,\n target,\n onMove,\n activeSortable,\n changed,\n cancel\n } = _ref10;\n if (!activeSortable.options.swap) return;\n let el = this.sortable.el,\n options = this.options;\n\n if (target && target !== el) {\n let prevSwapEl = lastSwapEl;\n\n if (onMove(target) !== false) {\n toggleClass(target, options.swapClass, true);\n lastSwapEl = target;\n } else {\n lastSwapEl = null;\n }\n\n if (prevSwapEl && prevSwapEl !== lastSwapEl) {\n toggleClass(prevSwapEl, options.swapClass, false);\n }\n }\n\n changed();\n completed(true);\n cancel();\n },\n\n drop(_ref11) {\n let {\n activeSortable,\n putSortable,\n dragEl\n } = _ref11;\n let toSortable = putSortable || this.sortable;\n let options = this.options;\n lastSwapEl && toggleClass(lastSwapEl, options.swapClass, false);\n\n if (lastSwapEl && (options.swap || putSortable && putSortable.options.swap)) {\n if (dragEl !== lastSwapEl) {\n toSortable.captureAnimationState();\n if (toSortable !== activeSortable) activeSortable.captureAnimationState();\n swapNodes(dragEl, lastSwapEl);\n toSortable.animateAll();\n if (toSortable !== activeSortable) activeSortable.animateAll();\n }\n }\n },\n\n nulling() {\n lastSwapEl = null;\n }\n\n };\n return Object.assign(Swap, {\n pluginName: "swap",\n\n eventProperties() {\n return {\n swapItem: lastSwapEl\n };\n }\n\n });\n }\n\n function swapNodes(n1, n2) {\n let p1 = n1.parentNode,\n p2 = n2.parentNode,\n i1,\n i2;\n if (!p1 || !p2 || p1.isEqualNode(n2) || p2.isEqualNode(n1)) return;\n i1 = index(n1);\n i2 = index(n2);\n\n if (p1.isEqualNode(p2) && i1 < i2) {\n i2++;\n }\n\n p1.insertBefore(n2, p1.children[i1]);\n p2.insertBefore(n1, p2.children[i2]);\n }\n\n let multiDragElements = [],\n multiDragClones = [],\n lastMultiDragSelect,\n // for selection with modifier key down (SHIFT)\n multiDragSortable,\n initialFolding = false,\n // Initial multi-drag fold when drag started\n folding = false,\n // Folding any other time\n dragStarted = false,\n dragEl$1,\n clonesFromRect,\n clonesHidden;\n\n function MultiDragPlugin() {\n function MultiDrag(sortable) {\n // Bind all private methods\n for (let fn in this) {\n if (fn.charAt(0) === "_" && typeof this[fn] === "function") {\n this[fn] = this[fn].bind(this);\n }\n }\n\n if (sortable.options.supportPointer) {\n on(document, "pointerup", this._deselectMultiDrag);\n } else {\n on(document, "mouseup", this._deselectMultiDrag);\n on(document, "touchend", this._deselectMultiDrag);\n }\n\n on(document, "keydown", this._checkKeyDown);\n on(document, "keyup", this._checkKeyUp);\n this.defaults = {\n selectedClass: "sortable-selected",\n multiDragKey: null,\n\n setData(dataTransfer, dragEl) {\n let data = "";\n\n if (multiDragElements.length && multiDragSortable === sortable) {\n multiDragElements.forEach((multiDragElement, i) => {\n data += (!i ? "" : ", ") + multiDragElement.textContent;\n });\n } else {\n data = dragEl.textContent;\n }\n\n dataTransfer.setData("Text", data);\n }\n\n };\n }\n\n MultiDrag.prototype = {\n multiDragKeyDown: false,\n isMultiDrag: false,\n\n delayStartGlobal(_ref12) {\n let {\n dragEl: dragged\n } = _ref12;\n dragEl$1 = dragged;\n },\n\n delayEnded() {\n this.isMultiDrag = ~multiDragElements.indexOf(dragEl$1);\n },\n\n setupClone(_ref13) {\n let {\n sortable,\n cancel\n } = _ref13;\n if (!this.isMultiDrag) return;\n\n for (let i = 0; i < multiDragElements.length; i++) {\n multiDragClones.push(clone(multiDragElements[i]));\n multiDragClones[i].sortableIndex = multiDragElements[i].sortableIndex;\n multiDragClones[i].draggable = false;\n multiDragClones[i].style["will-change"] = "";\n toggleClass(multiDragClones[i], this.options.selectedClass, false);\n multiDragElements[i] === dragEl$1 && toggleClass(multiDragClones[i], this.options.chosenClass, false);\n }\n\n sortable._hideClone();\n\n cancel();\n },\n\n clone(_ref14) {\n let {\n sortable,\n rootEl,\n dispatchSortableEvent,\n cancel\n } = _ref14;\n if (!this.isMultiDrag) return;\n\n if (!this.options.removeCloneOnHide) {\n if (multiDragElements.length && multiDragSortable === sortable) {\n insertMultiDragClones(true, rootEl);\n dispatchSortableEvent("clone");\n cancel();\n }\n }\n },\n\n showClone(_ref15) {\n let {\n cloneNowShown,\n rootEl,\n cancel\n } = _ref15;\n if (!this.isMultiDrag) return;\n insertMultiDragClones(false, rootEl);\n multiDragClones.forEach(clone => {\n css(clone, "display", "");\n });\n cloneNowShown();\n clonesHidden = false;\n cancel();\n },\n\n hideClone(_ref16) {\n let {\n sortable,\n cloneNowHidden,\n cancel\n } = _ref16;\n if (!this.isMultiDrag) return;\n multiDragClones.forEach(clone => {\n css(clone, "display", "none");\n\n if (this.options.removeCloneOnHide && clone.parentNode) {\n clone.parentNode.removeChild(clone);\n }\n });\n cloneNowHidden();\n clonesHidden = true;\n cancel();\n },\n\n dragStartGlobal(_ref17) {\n let {\n sortable\n } = _ref17;\n\n if (!this.isMultiDrag && multiDragSortable) {\n multiDragSortable.multiDrag._deselectMultiDrag();\n }\n\n multiDragElements.forEach(multiDragElement => {\n multiDragElement.sortableIndex = index(multiDragElement);\n }); // Sort multi-drag elements\n\n multiDragElements = multiDragElements.sort(function (a, b) {\n return a.sortableIndex - b.sortableIndex;\n });\n dragStarted = true;\n },\n\n dragStarted(_ref18) {\n let {\n sortable\n } = _ref18;\n if (!this.isMultiDrag) return;\n\n if (this.options.sort) {\n // Capture rects,\n // hide multi drag elements (by positioning them absolute),\n // set multi drag elements rects to dragRect,\n // show multi drag elements,\n // animate to rects,\n // unset rects & remove from DOM\n sortable.captureAnimationState();\n\n if (this.options.animation) {\n multiDragElements.forEach(multiDragElement => {\n if (multiDragElement === dragEl$1) return;\n css(multiDragElement, "position", "absolute");\n });\n let dragRect = getRect(dragEl$1, false, true, true);\n multiDragElements.forEach(multiDragElement => {\n if (multiDragElement === dragEl$1) return;\n setRect(multiDragElement, dragRect);\n });\n folding = true;\n initialFolding = true;\n }\n }\n\n sortable.animateAll(() => {\n folding = false;\n initialFolding = false;\n\n if (this.options.animation) {\n multiDragElements.forEach(multiDragElement => {\n unsetRect(multiDragElement);\n });\n } // Remove all auxiliary multidrag items from el, if sorting enabled\n\n\n if (this.options.sort) {\n removeMultiDragElements();\n }\n });\n },\n\n dragOver(_ref19) {\n let {\n target,\n completed,\n cancel\n } = _ref19;\n\n if (folding && ~multiDragElements.indexOf(target)) {\n completed(false);\n cancel();\n }\n },\n\n revert(_ref20) {\n let {\n fromSortable,\n rootEl,\n sortable,\n dragRect\n } = _ref20;\n\n if (multiDragElements.length > 1) {\n // Setup unfold animation\n multiDragElements.forEach(multiDragElement => {\n sortable.addAnimationState({\n target: multiDragElement,\n rect: folding ? getRect(multiDragElement) : dragRect\n });\n unsetRect(multiDragElement);\n multiDragElement.fromRect = dragRect;\n fromSortable.removeAnimationState(multiDragElement);\n });\n folding = false;\n insertMultiDragElements(!this.options.removeCloneOnHide, rootEl);\n }\n },\n\n dragOverCompleted(_ref21) {\n let {\n sortable,\n isOwner,\n insertion,\n activeSortable,\n parentEl,\n putSortable\n } = _ref21;\n let options = this.options;\n\n if (insertion) {\n // Clones must be hidden before folding animation to capture dragRectAbsolute properly\n if (isOwner) {\n activeSortable._hideClone();\n }\n\n initialFolding = false; // If leaving sort:false root, or already folding - Fold to new location\n\n if (options.animation && multiDragElements.length > 1 && (folding || !isOwner && !activeSortable.options.sort && !putSortable)) {\n // Fold: Set all multi drag elements\'s rects to dragEl\'s rect when multi-drag elements are invisible\n let dragRectAbsolute = getRect(dragEl$1, false, true, true);\n multiDragElements.forEach(multiDragElement => {\n if (multiDragElement === dragEl$1) return;\n setRect(multiDragElement, dragRectAbsolute); // Move element(s) to end of parentEl so that it does not interfere with multi-drag clones insertion if they are inserted\n // while folding, and so that we can capture them again because old sortable will no longer be fromSortable\n\n parentEl.appendChild(multiDragElement);\n });\n folding = true;\n } // Clones must be shown (and check to remove multi drags) after folding when interfering multiDragElements are moved out\n\n\n if (!isOwner) {\n // Only remove if not folding (folding will remove them anyways)\n if (!folding) {\n removeMultiDragElements();\n }\n\n if (multiDragElements.length > 1) {\n let clonesHiddenBefore = clonesHidden;\n\n activeSortable._showClone(sortable); // Unfold animation for clones if showing from hidden\n\n\n if (activeSortable.options.animation && !clonesHidden && clonesHiddenBefore) {\n multiDragClones.forEach(clone => {\n activeSortable.addAnimationState({\n target: clone,\n rect: clonesFromRect\n });\n clone.fromRect = clonesFromRect;\n clone.thisAnimationDuration = null;\n });\n }\n } else {\n activeSortable._showClone(sortable);\n }\n }\n }\n },\n\n dragOverAnimationCapture(_ref22) {\n let {\n dragRect,\n isOwner,\n activeSortable\n } = _ref22;\n multiDragElements.forEach(multiDragElement => {\n multiDragElement.thisAnimationDuration = null;\n });\n\n if (activeSortable.options.animation && !isOwner && activeSortable.multiDrag.isMultiDrag) {\n clonesFromRect = Object.assign({}, dragRect);\n let dragMatrix = matrix(dragEl$1, true);\n clonesFromRect.top -= dragMatrix.f;\n clonesFromRect.left -= dragMatrix.e;\n }\n },\n\n dragOverAnimationComplete() {\n if (folding) {\n folding = false;\n removeMultiDragElements();\n }\n },\n\n drop(_ref23) {\n let {\n originalEvent: evt,\n rootEl,\n parentEl,\n sortable,\n dispatchSortableEvent,\n oldIndex,\n putSortable\n } = _ref23;\n let toSortable = putSortable || this.sortable;\n if (!evt) return;\n let options = this.options,\n children = parentEl.children; // Multi-drag selection\n\n if (!dragStarted) {\n if (options.multiDragKey && !this.multiDragKeyDown) {\n this._deselectMultiDrag();\n }\n\n toggleClass(dragEl$1, options.selectedClass, !~multiDragElements.indexOf(dragEl$1));\n\n if (!~multiDragElements.indexOf(dragEl$1)) {\n multiDragElements.push(dragEl$1);\n dispatchEvent({\n sortable,\n rootEl,\n name: "select",\n targetEl: dragEl$1,\n originalEvt: evt\n }); // Modifier activated, select from last to dragEl\n\n if (evt.shiftKey && lastMultiDragSelect && sortable.el.contains(lastMultiDragSelect)) {\n let lastIndex = index(lastMultiDragSelect),\n currentIndex = index(dragEl$1);\n\n if (~lastIndex && ~currentIndex && lastIndex !== currentIndex) {\n // Must include lastMultiDragSelect (select it), in case modified selection from no selection\n // (but previous selection existed)\n let n, i;\n\n if (currentIndex > lastIndex) {\n i = lastIndex;\n n = currentIndex;\n } else {\n i = currentIndex;\n n = lastIndex + 1;\n }\n\n for (; i < n; i++) {\n if (~multiDragElements.indexOf(children[i])) continue;\n toggleClass(children[i], options.selectedClass, true);\n multiDragElements.push(children[i]);\n dispatchEvent({\n sortable,\n rootEl,\n name: "select",\n targetEl: children[i],\n originalEvt: evt\n });\n }\n }\n } else {\n lastMultiDragSelect = dragEl$1;\n }\n\n multiDragSortable = toSortable;\n } else {\n multiDragElements.splice(multiDragElements.indexOf(dragEl$1), 1);\n lastMultiDragSelect = null;\n dispatchEvent({\n sortable,\n rootEl,\n name: "deselect",\n targetEl: dragEl$1,\n originalEvt: evt\n });\n }\n } // Multi-drag drop\n\n\n if (dragStarted && this.isMultiDrag) {\n // Do not "unfold" after around dragEl if reverted\n if ((parentEl[expando].options.sort || parentEl !== rootEl) && multiDragElements.length > 1) {\n let dragRect = getRect(dragEl$1),\n multiDragIndex = index(dragEl$1, ":not(." + this.options.selectedClass + ")");\n if (!initialFolding && options.animation) dragEl$1.thisAnimationDuration = null;\n toSortable.captureAnimationState();\n\n if (!initialFolding) {\n if (options.animation) {\n dragEl$1.fromRect = dragRect;\n multiDragElements.forEach(multiDragElement => {\n multiDragElement.thisAnimationDuration = null;\n\n if (multiDragElement !== dragEl$1) {\n let rect = folding ? getRect(multiDragElement) : dragRect;\n multiDragElement.fromRect = rect; // Prepare unfold animation\n\n toSortable.addAnimationState({\n target: multiDragElement,\n rect: rect\n });\n }\n });\n } // Multi drag elements are not necessarily removed from the DOM on drop, so to reinsert\n // properly they must all be removed\n\n\n removeMultiDragElements();\n multiDragElements.forEach(multiDragElement => {\n if (children[multiDragIndex]) {\n parentEl.insertBefore(multiDragElement, children[multiDragIndex]);\n } else {\n parentEl.appendChild(multiDragElement);\n }\n\n multiDragIndex++;\n }); // If initial folding is done, the elements may have changed position because they are now\n // unfolding around dragEl, even though dragEl may not have his index changed, so update event\n // must be fired here as Sortable will not.\n\n if (oldIndex === index(dragEl$1)) {\n let update = false;\n multiDragElements.forEach(multiDragElement => {\n if (multiDragElement.sortableIndex !== index(multiDragElement)) {\n update = true;\n return;\n }\n });\n\n if (update) {\n dispatchSortableEvent("update");\n }\n }\n } // Must be done after capturing individual rects (scroll bar)\n\n\n multiDragElements.forEach(multiDragElement => {\n unsetRect(multiDragElement);\n });\n toSortable.animateAll();\n }\n\n multiDragSortable = toSortable;\n } // Remove clones if necessary\n\n\n if (rootEl === parentEl || putSortable && putSortable.lastPutMode !== "clone") {\n multiDragClones.forEach(clone => {\n clone.parentNode && clone.parentNode.removeChild(clone);\n });\n }\n },\n\n nullingGlobal() {\n this.isMultiDrag = dragStarted = false;\n multiDragClones.length = 0;\n },\n\n destroyGlobal() {\n this._deselectMultiDrag();\n\n off(document, "pointerup", this._deselectMultiDrag);\n off(document, "mouseup", this._deselectMultiDrag);\n off(document, "touchend", this._deselectMultiDrag);\n off(document, "keydown", this._checkKeyDown);\n off(document, "keyup", this._checkKeyUp);\n },\n\n _deselectMultiDrag(evt) {\n if (typeof dragStarted !== "undefined" && dragStarted) return; // Only deselect if selection is in this sortable\n\n if (multiDragSortable !== this.sortable) return; // Only deselect if target is not item in this sortable\n\n if (evt && closest(evt.target, this.options.draggable, this.sortable.el, false)) return; // Only deselect if left click\n\n if (evt && evt.button !== 0) return;\n\n while (multiDragElements.length) {\n let el = multiDragElements[0];\n toggleClass(el, this.options.selectedClass, false);\n multiDragElements.shift();\n dispatchEvent({\n sortable: this.sortable,\n rootEl: this.sortable.el,\n name: "deselect",\n targetEl: el,\n originalEvt: evt\n });\n }\n },\n\n _checkKeyDown(evt) {\n if (evt.key === this.options.multiDragKey) {\n this.multiDragKeyDown = true;\n }\n },\n\n _checkKeyUp(evt) {\n if (evt.key === this.options.multiDragKey) {\n this.multiDragKeyDown = false;\n }\n }\n\n };\n return Object.assign(MultiDrag, {\n // Static methods & properties\n pluginName: "multiDrag",\n utils: {\n /**\n * Selects the provided multi-drag item\n * @param {HTMLElement} el The element to be selected\n */\n select(el) {\n let sortable = el.parentNode[expando];\n if (!sortable || !sortable.options.multiDrag || ~multiDragElements.indexOf(el)) return;\n\n if (multiDragSortable && multiDragSortable !== sortable) {\n multiDragSortable.multiDrag._deselectMultiDrag();\n\n multiDragSortable = sortable;\n }\n\n toggleClass(el, sortable.options.selectedClass, true);\n multiDragElements.push(el);\n },\n\n /**\n * Deselects the provided multi-drag item\n * @param {HTMLElement} el The element to be deselected\n */\n deselect(el) {\n let sortable = el.parentNode[expando],\n index = multiDragElements.indexOf(el);\n if (!sortable || !sortable.options.multiDrag || !~index) return;\n toggleClass(el, sortable.options.selectedClass, false);\n multiDragElements.splice(index, 1);\n }\n\n },\n\n eventProperties() {\n const oldIndicies = [],\n newIndicies = [];\n multiDragElements.forEach(multiDragElement => {\n oldIndicies.push({\n multiDragElement,\n index: multiDragElement.sortableIndex\n }); // multiDragElements will already be sorted if folding\n\n let newIndex;\n\n if (folding && multiDragElement !== dragEl$1) {\n newIndex = -1;\n } else if (folding) {\n newIndex = index(multiDragElement, ":not(." + this.options.selectedClass + ")");\n } else {\n newIndex = index(multiDragElement);\n }\n\n newIndicies.push({\n multiDragElement,\n index: newIndex\n });\n });\n return {\n items: [...multiDragElements],\n clones: [...multiDragClones],\n oldIndicies,\n newIndicies\n };\n },\n\n optionListeners: {\n multiDragKey(key) {\n key = key.toLowerCase();\n\n if (key === "ctrl") {\n key = "Control";\n } else if (key.length > 1) {\n key = key.charAt(0).toUpperCase() + key.substr(1);\n }\n\n return key;\n }\n\n }\n });\n }\n\n function insertMultiDragElements(clonesInserted, rootEl) {\n multiDragElements.forEach((multiDragElement, i) => {\n let target = rootEl.children[multiDragElement.sortableIndex + (clonesInserted ? Number(i) : 0)];\n\n if (target) {\n rootEl.insertBefore(multiDragElement, target);\n } else {\n rootEl.appendChild(multiDragElement);\n }\n });\n }\n /**\n * Insert multi-drag clones\n * @param {[Boolean]} elementsInserted Whether the multi-drag elements are inserted\n * @param {HTMLElement} rootEl\n */\n\n\n function insertMultiDragClones(elementsInserted, rootEl) {\n multiDragClones.forEach((clone, i) => {\n let target = rootEl.children[clone.sortableIndex + (elementsInserted ? Number(i) : 0)];\n\n if (target) {\n rootEl.insertBefore(clone, target);\n } else {\n rootEl.appendChild(clone);\n }\n });\n }\n\n function removeMultiDragElements() {\n multiDragElements.forEach(multiDragElement => {\n if (multiDragElement === dragEl$1) return;\n multiDragElement.parentNode && multiDragElement.parentNode.removeChild(multiDragElement);\n });\n }\n\n Sortable.mount(new AutoScrollPlugin());\n Sortable.mount(Remove, Revert);\n Sortable.mount(new SwapPlugin());\n Sortable.mount(new MultiDragPlugin());\n return Sortable;\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"4617.js","mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./static/js/customizer/panels-builder/placements/sortablejs.js?74ea"],"sourcesContent":["const _excluded = [\"evt\"];\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n/**!\n * Sortable 1.11.0\n * @author\tRubaXa   <trash@rubaxa.org>\n * @author\towenm    <owen23355@gmail.com>\n * @license MIT\n */\n(function (global, factory) {\n  typeof exports === \"object\" && typeof module !== \"undefined\" ? module.exports = factory() : typeof define === \"function\" && define.amd ? define(factory) : (global = typeof globalThis !== \"undefined\" ? globalThis : global || self, global.Sortable = factory());\n})(this, function () {\n  \"use strict\";\n\n  const __warn = \"\" + \"Importing Sortable directly from GitHub is deprecated.\\n\" + \"This file will not receive any more updates.\\n\" + \"Please follow the usage instructions to continue getting support: https://github.com/SortableJS/Sortable\"; // console.warn(__warn);\n\n\n  var version = \"1.11.0\";\n\n  function userAgent(pattern) {\n    if (typeof window !== \"undefined\" && window.navigator) {\n      return !! /*@__PURE__*/navigator.userAgent.match(pattern);\n    }\n  }\n\n  const IE11OrLess = userAgent(/(?:Trident.*rv[ :]?11\\.|msie|iemobile|Windows Phone)/i);\n  const Edge = userAgent(/Edge/i);\n  const FireFox = userAgent(/firefox/i);\n  const Safari = userAgent(/safari/i) && !userAgent(/chrome/i) && !userAgent(/android/i);\n  const IOS = userAgent(/iP(ad|od|hone)/i);\n  const ChromeForAndroid = userAgent(/chrome/i) && userAgent(/android/i);\n  const captureMode = {\n    capture: false,\n    passive: false\n  };\n\n  function on(el, event, fn) {\n    el.addEventListener(event, fn, !IE11OrLess && captureMode);\n  }\n\n  function off(el, event, fn) {\n    el.removeEventListener(event, fn, !IE11OrLess && captureMode);\n  }\n\n  function matches(\n  /**HTMLElement*/\n  el,\n  /**String*/\n  selector) {\n    if (!selector) return;\n    selector[0] === \">\" && (selector = selector.substring(1));\n\n    if (el) {\n      try {\n        if (el.matches) {\n          return el.matches(selector);\n        } else if (el.msMatchesSelector) {\n          return el.msMatchesSelector(selector);\n        } else if (el.webkitMatchesSelector) {\n          return el.webkitMatchesSelector(selector);\n        }\n      } catch (_) {\n        return false;\n      }\n    }\n\n    return false;\n  }\n\n  function getParentOrHost(el) {\n    return el.host && el !== document && el.host.nodeType ? el.host : el.parentNode;\n  }\n\n  function closest(\n  /**HTMLElement*/\n  el,\n  /**String*/\n  selector,\n  /**HTMLElement*/\n  ctx, includeCTX) {\n    if (el) {\n      ctx = ctx || document;\n\n      do {\n        if (selector != null && (selector[0] === \">\" ? el.parentNode === ctx && matches(el, selector) : matches(el, selector)) || includeCTX && el === ctx) {\n          return el;\n        }\n\n        if (el === ctx) break;\n        /* jshint boss:true */\n      } while (el = getParentOrHost(el));\n    }\n\n    return null;\n  }\n\n  const R_SPACE = /\\s+/g;\n\n  function toggleClass(el, name, state) {\n    if (el && name) {\n      if (el.classList) {\n        el.classList[state ? \"add\" : \"remove\"](name);\n      } else {\n        let className = (\" \" + el.className + \" \").replace(R_SPACE, \" \").replace(\" \" + name + \" \", \" \");\n        el.className = (className + (state ? \" \" + name : \"\")).replace(R_SPACE, \" \");\n      }\n    }\n  }\n\n  function css(el, prop, val) {\n    let style = el && el.style;\n\n    if (style) {\n      if (val === void 0) {\n        if (document.defaultView && document.defaultView.getComputedStyle) {\n          val = document.defaultView.getComputedStyle(el, \"\");\n        } else if (el.currentStyle) {\n          val = el.currentStyle;\n        }\n\n        return prop === void 0 ? val : val[prop];\n      } else {\n        if (!(prop in style) && prop.indexOf(\"webkit\") === -1) {\n          prop = \"-webkit-\" + prop;\n        }\n\n        style[prop] = val + (typeof val === \"string\" ? \"\" : \"px\");\n      }\n    }\n  }\n\n  function matrix(el, selfOnly) {\n    let appliedTransforms = \"\";\n\n    if (typeof el === \"string\") {\n      appliedTransforms = el;\n    } else {\n      do {\n        //@ts-ignore\n        let transform = css(el, \"transform\");\n\n        if (transform && transform !== \"none\") {\n          appliedTransforms = transform + \" \" + appliedTransforms;\n        }\n        /* jshint boss:true */\n\n      } while (!selfOnly && (el = el.parentNode));\n    } //@ts-ignore\n\n\n    const matrixFn = window.DOMMatrix || window.WebKitCSSMatrix || window.CSSMatrix || window.MSCSSMatrix;\n    /*jshint -W056 */\n\n    return matrixFn && new matrixFn(appliedTransforms);\n  }\n\n  function find(ctx, tagName, iterator) {\n    if (ctx) {\n      let list = ctx.getElementsByTagName(tagName),\n          i = 0,\n          n = list.length;\n\n      if (iterator) {\n        for (; i < n; i++) {\n          iterator(list[i], i);\n        }\n      }\n\n      return list;\n    }\n\n    return [];\n  }\n\n  function getWindowScrollingElement() {\n    let scrollingElement = document.scrollingElement;\n\n    if (scrollingElement) {\n      return scrollingElement;\n    } else {\n      return document.documentElement;\n    }\n  }\n  /**\n   * Returns the \"bounding client rect\" of given element\n   * @param  {HTMLElement} el                       The element whose boundingClientRect is wanted\n   * @param  {[Boolean]} relativeToContainingBlock  Whether the rect should be relative to the containing block of (including) the container\n   * @param  {[Boolean]} relativeToNonStaticParent  Whether the rect should be relative to the relative parent of (including) the contaienr\n   * @param  {[Boolean]} undoScale                  Whether the container's scale() should be undone\n   * @param  {[HTMLElement]} container              The parent the element will be placed in\n   * @return {Object}                               The boundingClientRect of el, with specified adjustments\n   */\n\n\n  function getRect(el, relativeToContainingBlock, relativeToNonStaticParent, undoScale, container) {\n    if (!el.getBoundingClientRect && el !== window) return;\n    let elRect, top, left, bottom, right, height, width;\n\n    if (el !== window && el !== getWindowScrollingElement()) {\n      elRect = el.getBoundingClientRect();\n      top = elRect.top;\n      left = elRect.left;\n      bottom = elRect.bottom;\n      right = elRect.right;\n      height = elRect.height;\n      width = elRect.width;\n    } else {\n      top = 0;\n      left = 0;\n      bottom = window.innerHeight;\n      right = window.innerWidth;\n      height = window.innerHeight;\n      width = window.innerWidth;\n    }\n\n    if ((relativeToContainingBlock || relativeToNonStaticParent) && el !== window) {\n      // Adjust for translate()\n      container = container || el.parentNode; // solves #1123 (see: https://stackoverflow.com/a/37953806/6088312)\n      // Not needed on <= IE11\n\n      if (!IE11OrLess) {\n        do {\n          if (container && container.getBoundingClientRect && ( //@ts-ignore\n          css(container, \"transform\") !== \"none\" || relativeToNonStaticParent && //@ts-ignore\n          css(container, \"position\") !== \"static\")) {\n            let containerRect = container.getBoundingClientRect(); // Set relative to edges of padding box of container\n            //@ts-ignore\n\n            top -= containerRect.top + parseInt(css(container, \"border-top-width\")); //@ts-ignore\n\n            left -= containerRect.left + parseInt(css(container, \"border-left-width\"));\n            bottom = top + elRect.height;\n            right = left + elRect.width;\n            break;\n          }\n          /* jshint boss:true */\n\n        } while (container = container.parentNode);\n      }\n    }\n\n    if (undoScale && el !== window) {\n      // Adjust for scale()\n      //@ts-ignore\n      let elMatrix = matrix(container || el),\n          scaleX = elMatrix && elMatrix.a,\n          scaleY = elMatrix && elMatrix.d;\n\n      if (elMatrix) {\n        top /= scaleY;\n        left /= scaleX;\n        width /= scaleX;\n        height /= scaleY;\n        bottom = top + height;\n        right = left + width;\n      }\n    }\n\n    return {\n      top: top,\n      left: left,\n      bottom: bottom,\n      right: right,\n      width: width,\n      height: height\n    };\n  }\n  /**\n   * Checks if a side of an element is scrolled past a side of its parents\n   * @param  {HTMLElement}  el           The element who's side being scrolled out of view is in question\n   * @param  {String}       elSide       Side of the element in question ('top', 'left', 'right', 'bottom')\n   * @param  {String}       parentSide   Side of the parent in question ('top', 'left', 'right', 'bottom')\n   * @return {HTMLElement}               The parent scroll element that the el's side is scrolled past, or null if there is no such element\n   */\n\n\n  function isScrolledPast(el, elSide, parentSide) {\n    let parent = getParentAutoScrollElement(el, true),\n        //@ts-ignore\n    elSideVal = getRect(el)[elSide];\n    /* jshint boss:true */\n\n    while (parent) {\n      //@ts-ignore\n      let parentSideVal = getRect(parent)[parentSide],\n          visible;\n\n      if (parentSide === \"top\" || parentSide === \"left\") {\n        visible = elSideVal >= parentSideVal;\n      } else {\n        visible = elSideVal <= parentSideVal;\n      }\n\n      if (!visible) return parent;\n      if (parent === getWindowScrollingElement()) break;\n      parent = getParentAutoScrollElement(parent, false);\n    }\n\n    return false;\n  }\n  /**\n   * Gets nth child of el, ignoring hidden children, sortable's elements (does not ignore clone if it's visible)\n   * and non-draggable elements\n   * @param  {HTMLElement} el       The parent element\n   * @param  {Number} childNum      The index of the child\n   * @param  {Object} options       Parent Sortable's options\n   * @return {HTMLElement}          The child at index childNum, or null if not found\n   */\n\n\n  function getChild(el, childNum, options) {\n    let currentChild = 0,\n        i = 0,\n        children = el.children;\n\n    while (i < children.length) {\n      if (children[i].style.display !== \"none\" && //@ts-ignore\n      children[i] !== Sortable.ghost && //@ts-ignore\n      children[i] !== Sortable.dragged && closest(children[i], options.draggable, el, false)) {\n        if (currentChild === childNum) {\n          return children[i];\n        }\n\n        currentChild++;\n      }\n\n      i++;\n    }\n\n    return null;\n  }\n  /**\n   * Gets the last child in the el, ignoring ghostEl or invisible elements (clones)\n   * @param  {HTMLElement} el       Parent element\n   * @param  {selector} selector    Any other elements that should be ignored\n   * @return {HTMLElement}          The last child, ignoring ghostEl\n   */\n\n\n  function lastChild(el, selector) {\n    let last = el.lastElementChild;\n\n    while (last && ( //@ts-ignore\n    last === Sortable.ghost || //@ts-ignore\n    css(last, \"display\") === \"none\" || selector && !matches(last, selector))) {\n      last = last.previousElementSibling;\n    }\n\n    return last || null;\n  }\n  /**\n   * Returns the index of an element within its parent for a selected set of\n   * elements\n   * @param  {HTMLElement} el\n   * @param  {selector} selector\n   * @return {number}\n   */\n\n\n  function index(el, selector) {\n    let index = 0;\n\n    if (!el || !el.parentNode) {\n      return -1;\n    }\n    /* jshint boss:true */\n\n\n    while (el = el.previousElementSibling) {\n      //@ts-ignore\n      if (el.nodeName.toUpperCase() !== \"TEMPLATE\" && !el.matches('.ct-pointer') && el !== Sortable.clone && (!selector || matches(el, selector))) {\n        index++;\n      }\n    }\n\n    return index;\n  }\n  /**\n   * Returns the scroll offset of the given element, added with all the scroll offsets of parent elements.\n   * The value is returned in real pixels.\n   * @param  {HTMLElement} el\n   * @return {Array}             Offsets in the format of [left, top]\n   */\n\n\n  function getRelativeScrollOffset(el) {\n    let offsetLeft = 0,\n        offsetTop = 0,\n        winScroller = getWindowScrollingElement();\n\n    if (el) {\n      do {\n        //@ts-ignore\n        let elMatrix = matrix(el),\n            scaleX = elMatrix.a,\n            scaleY = elMatrix.d;\n        offsetLeft += el.scrollLeft * scaleX;\n        offsetTop += el.scrollTop * scaleY;\n      } while (el !== winScroller && (el = el.parentNode));\n    }\n\n    return [offsetLeft, offsetTop];\n  }\n  /**\n   * Returns the index of the object within the given array\n   * @param  {Array} arr   Array that may or may not hold the object\n   * @param  {Object} obj  An object that has a key-value pair unique to and identical to a key-value pair in the object you want to find\n   * @return {Number}      The index of the object in the array, or -1\n   */\n\n\n  function indexOfObject(arr, obj) {\n    for (let i in arr) {\n      if (!arr.hasOwnProperty(i)) continue;\n\n      for (let key in obj) {\n        if (obj.hasOwnProperty(key) && obj[key] === arr[i][key]) return Number(i);\n      }\n    }\n\n    return -1;\n  }\n\n  function getParentAutoScrollElement(el, includeSelf) {\n    // skip to window\n    if (!el || !el.getBoundingClientRect) return getWindowScrollingElement();\n    let elem = el;\n    let gotSelf = false;\n\n    do {\n      // we don't need to get elem css if it isn't even overflowing in the first place (performance)\n      if (elem.clientWidth < elem.scrollWidth || elem.clientHeight < elem.scrollHeight) {\n        //@ts-ignore\n        let elemCSS = css(elem);\n\n        if (elem.clientWidth < elem.scrollWidth && (elemCSS.overflowX == \"auto\" || elemCSS.overflowX == \"scroll\") || elem.clientHeight < elem.scrollHeight && (elemCSS.overflowY == \"auto\" || elemCSS.overflowY == \"scroll\")) {\n          if (!elem.getBoundingClientRect || elem === document.body) return getWindowScrollingElement();\n          if (gotSelf || includeSelf) return elem;\n          gotSelf = true;\n        }\n      }\n      /* jshint boss:true */\n\n    } while (elem = elem.parentNode);\n\n    return getWindowScrollingElement();\n  }\n\n  function extend(dst, src) {\n    if (dst && src) {\n      for (let key in src) {\n        if (src.hasOwnProperty(key)) {\n          dst[key] = src[key];\n        }\n      }\n    }\n\n    return dst;\n  }\n\n  function isRectEqual(rect1, rect2) {\n    return Math.round(rect1.top) === Math.round(rect2.top) && Math.round(rect1.left) === Math.round(rect2.left) && Math.round(rect1.height) === Math.round(rect2.height) && Math.round(rect1.width) === Math.round(rect2.width);\n  }\n\n  let _throttleTimeout;\n\n  function throttle(callback, ms) {\n    return function () {\n      if (!_throttleTimeout) {\n        let args = arguments,\n            _this = this;\n\n        if (args.length === 1) {\n          callback.call(_this, args[0]);\n        } else {\n          callback.apply(_this, args);\n        }\n\n        _throttleTimeout = setTimeout(function () {\n          _throttleTimeout = void 0;\n        }, ms);\n      }\n    };\n  }\n\n  function cancelThrottle() {\n    clearTimeout(_throttleTimeout);\n    _throttleTimeout = void 0;\n  }\n\n  function scrollBy(el, x, y) {\n    el.scrollLeft += x;\n    el.scrollTop += y;\n  }\n\n  function clone(el) {\n    //@ts-ignore\n    let Polymer = window.Polymer; //@ts-ignore\n\n    let $ = window.jQuery || window.Zepto;\n\n    if (Polymer && Polymer.dom) {\n      return Polymer.dom(el).cloneNode(true);\n    } else if ($) {\n      return $(el).clone(true)[0];\n    } else {\n      return el.cloneNode(true);\n    }\n  }\n\n  function setRect(el, rect) {\n    css(el, \"position\", \"absolute\");\n    css(el, \"top\", rect.top);\n    css(el, \"left\", rect.left);\n    css(el, \"width\", rect.width);\n    css(el, \"height\", rect.height);\n  }\n\n  function unsetRect(el) {\n    css(el, \"position\", \"\");\n    css(el, \"top\", \"\");\n    css(el, \"left\", \"\");\n    css(el, \"width\", \"\");\n    css(el, \"height\", \"\");\n  }\n\n  const expando = \"Sortable\" + new Date().getTime();\n\n  function AnimationStateManager() {\n    let animationStates = [],\n        animationCallbackId;\n    return {\n      captureAnimationState() {\n        animationStates = [];\n        if (!this.options.animation) return;\n        let children = [].slice.call(this.el.children);\n        children.forEach(child => {\n          if (css(child, \"display\") === \"none\" || child === Sortable.ghost) return;\n          animationStates.push({\n            target: child,\n            rect: getRect(child)\n          });\n\n          let fromRect = _objectSpread({}, animationStates[animationStates.length - 1].rect); // If animating: compensate for current animation\n\n\n          if (child.thisAnimationDuration) {\n            let childMatrix = matrix(child, true);\n\n            if (childMatrix) {\n              fromRect.top -= childMatrix.f;\n              fromRect.left -= childMatrix.e;\n            }\n          }\n\n          child.fromRect = fromRect;\n        });\n      },\n\n      addAnimationState(state) {\n        animationStates.push(state);\n      },\n\n      removeAnimationState(target) {\n        animationStates.splice(indexOfObject(animationStates, {\n          target\n        }), 1);\n      },\n\n      animateAll(callback) {\n        if (!this.options.animation) {\n          clearTimeout(animationCallbackId);\n          if (typeof callback === \"function\") callback();\n          return;\n        }\n\n        let animating = false,\n            animationTime = 0;\n        animationStates.forEach(state => {\n          let time = 0,\n              target = state.target,\n              fromRect = target.fromRect,\n              toRect = getRect(target),\n              prevFromRect = target.prevFromRect,\n              prevToRect = target.prevToRect,\n              animatingRect = state.rect,\n              targetMatrix = matrix(target, true);\n\n          if (targetMatrix) {\n            // Compensate for current animation\n            toRect.top -= targetMatrix.f;\n            toRect.left -= targetMatrix.e;\n          }\n\n          target.toRect = toRect;\n\n          if (target.thisAnimationDuration) {\n            // Could also check if animatingRect is between fromRect and toRect\n            if (isRectEqual(prevFromRect, toRect) && !isRectEqual(fromRect, toRect) && // Make sure animatingRect is on line between toRect & fromRect\n            (animatingRect.top - toRect.top) / (animatingRect.left - toRect.left) === (fromRect.top - toRect.top) / (fromRect.left - toRect.left)) {\n              // If returning to same place as started from animation and on same axis\n              time = calculateRealTime(animatingRect, prevFromRect, prevToRect, this.options);\n            }\n          } // if fromRect != toRect: animate\n\n\n          if (!isRectEqual(toRect, fromRect)) {\n            target.prevFromRect = fromRect;\n            target.prevToRect = toRect;\n\n            if (!time) {\n              time = this.options.animation;\n            }\n\n            this.animate(target, animatingRect, toRect, time);\n          }\n\n          if (time) {\n            animating = true;\n            animationTime = Math.max(animationTime, time);\n            clearTimeout(target.animationResetTimer);\n            target.animationResetTimer = setTimeout(function () {\n              target.animationTime = 0;\n              target.prevFromRect = null;\n              target.fromRect = null;\n              target.prevToRect = null;\n              target.thisAnimationDuration = null;\n            }, time);\n            target.thisAnimationDuration = time;\n          }\n        });\n        clearTimeout(animationCallbackId);\n\n        if (!animating) {\n          if (typeof callback === \"function\") callback();\n        } else {\n          animationCallbackId = setTimeout(function () {\n            if (typeof callback === \"function\") callback();\n          }, animationTime);\n        }\n\n        animationStates = [];\n      },\n\n      animate(target, currentRect, toRect, duration) {\n        if (duration) {\n          css(target, \"transition\", \"\");\n          css(target, \"transform\", \"\");\n          let elMatrix = matrix(this.el),\n              scaleX = elMatrix && elMatrix.a,\n              scaleY = elMatrix && elMatrix.d,\n              translateX = (currentRect.left - toRect.left) / (scaleX || 1),\n              translateY = (currentRect.top - toRect.top) / (scaleY || 1);\n          target.animatingX = !!translateX;\n          target.animatingY = !!translateY;\n          css(target, \"transform\", \"translate3d(\" + translateX + \"px,\" + translateY + \"px,0)\");\n          this.forRepaintDummy = repaint(target); // repaint\n\n          css(target, \"transition\", \"transform \" + duration + \"ms\" + (this.options.easing ? \" \" + this.options.easing : \"\"));\n          css(target, \"transform\", \"translate3d(0,0,0)\");\n          typeof target.animated === \"number\" && clearTimeout(target.animated);\n          target.animated = setTimeout(function () {\n            css(target, \"transition\", \"\");\n            css(target, \"transform\", \"\");\n            target.animated = false;\n            target.animatingX = false;\n            target.animatingY = false;\n          }, duration);\n        }\n      }\n\n    };\n  }\n\n  function repaint(target) {\n    return target.offsetWidth;\n  }\n\n  function calculateRealTime(animatingRect, fromRect, toRect, options) {\n    return Math.sqrt(Math.pow(fromRect.top - animatingRect.top, 2) + Math.pow(fromRect.left - animatingRect.left, 2)) / Math.sqrt(Math.pow(fromRect.top - toRect.top, 2) + Math.pow(fromRect.left - toRect.left, 2)) * options.animation;\n  }\n\n  let plugins = [];\n  const defaults = {\n    initializeByDefault: true\n  };\n  var PluginManager = {\n    mount(plugin) {\n      // Set default static properties\n      for (let option in defaults) {\n        if (defaults.hasOwnProperty(option) && !(option in plugin)) {\n          plugin[option] = defaults[option];\n        }\n      }\n\n      plugins.push(plugin);\n    },\n\n    pluginEvent(eventName, sortable, evt) {\n      this.eventCanceled = false;\n\n      evt.cancel = () => {\n        this.eventCanceled = true;\n      };\n\n      const eventNameGlobal = eventName + \"Global\";\n      plugins.forEach(plugin => {\n        if (!sortable[plugin.pluginName]) return; // Fire global events if it exists in this sortable\n\n        if (sortable[plugin.pluginName][eventNameGlobal]) {\n          sortable[plugin.pluginName][eventNameGlobal](_objectSpread({\n            sortable\n          }, evt));\n        } // Only fire plugin event if plugin is enabled in this sortable,\n        // and plugin has event defined\n\n\n        if (sortable.options[plugin.pluginName] && sortable[plugin.pluginName][eventName]) {\n          sortable[plugin.pluginName][eventName](_objectSpread({\n            sortable\n          }, evt));\n        }\n      });\n    },\n\n    initializePlugins(sortable, el, defaults, options) {\n      plugins.forEach(plugin => {\n        const pluginName = plugin.pluginName;\n        if (!sortable.options[pluginName] && !plugin.initializeByDefault) return;\n        let initialized = new plugin(sortable, el, sortable.options);\n        initialized.sortable = sortable;\n        initialized.options = sortable.options;\n        sortable[pluginName] = initialized; // Add default options from plugin\n\n        Object.assign(defaults, initialized.defaults);\n      });\n\n      for (let option in sortable.options) {\n        if (!sortable.options.hasOwnProperty(option)) continue;\n        let modified = this.modifyOption(sortable, option, sortable.options[option]);\n\n        if (typeof modified !== \"undefined\") {\n          sortable.options[option] = modified;\n        }\n      }\n    },\n\n    getEventProperties(name, sortable) {\n      let eventProperties = {};\n      plugins.forEach(plugin => {\n        if (typeof plugin.eventProperties !== \"function\") return;\n        Object.assign(eventProperties, plugin.eventProperties.call(sortable[plugin.pluginName], name));\n      });\n      return eventProperties;\n    },\n\n    modifyOption(sortable, name, value) {\n      let modifiedValue;\n      plugins.forEach(plugin => {\n        // Plugin must exist on the Sortable\n        if (!sortable[plugin.pluginName]) return; // If static option listener exists for this option, call in the context of the Sortable's instance of this plugin\n\n        if (plugin.optionListeners && typeof plugin.optionListeners[name] === \"function\") {\n          modifiedValue = plugin.optionListeners[name].call(sortable[plugin.pluginName], value);\n        }\n      });\n      return modifiedValue;\n    }\n\n  };\n\n  function dispatchEvent(_ref) {\n    let {\n      sortable,\n      rootEl,\n      name,\n      targetEl,\n      cloneEl,\n      toEl,\n      fromEl,\n      oldIndex,\n      newIndex,\n      oldDraggableIndex,\n      newDraggableIndex,\n      originalEvent,\n      putSortable,\n      extraEventProperties\n    } = _ref;\n    sortable = sortable || rootEl && rootEl[expando];\n    if (!sortable) return;\n    let evt,\n        options = sortable.options,\n        onName = \"on\" + name.charAt(0).toUpperCase() + name.substr(1); // Support for new CustomEvent feature\n\n    if (window.CustomEvent && !IE11OrLess && !Edge) {\n      evt = new CustomEvent(name, {\n        bubbles: true,\n        cancelable: true\n      });\n    } else {\n      evt = document.createEvent(\"Event\");\n      evt.initEvent(name, true, true);\n    }\n\n    evt.to = toEl || rootEl;\n    evt.from = fromEl || rootEl;\n    evt.item = targetEl || rootEl;\n    evt.clone = cloneEl;\n    evt.oldIndex = oldIndex;\n    evt.newIndex = newIndex;\n    evt.oldDraggableIndex = oldDraggableIndex;\n    evt.newDraggableIndex = newDraggableIndex;\n    evt.originalEvent = originalEvent;\n    evt.pullMode = putSortable ? putSortable.lastPutMode : undefined;\n\n    let allEventProperties = _objectSpread(_objectSpread({}, extraEventProperties), PluginManager.getEventProperties(name, sortable));\n\n    for (let option in allEventProperties) {\n      evt[option] = allEventProperties[option];\n    }\n\n    if (rootEl) {\n      rootEl.dispatchEvent(evt);\n    }\n\n    if (options[onName]) {\n      options[onName].call(sortable, evt);\n    }\n  }\n  /**!\n   * Sortable\n   * @author\tRubaXa   <trash@rubaxa.org>\n   * @author\towenm    <owen23355@gmail.com>\n   * @license MIT\n   */\n\n\n  let pluginEvent = function (eventName, sortable) {\n    let _ref2 = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n\n    let {\n      evt: originalEvent\n    } = _ref2,\n        data = _objectWithoutProperties(_ref2, _excluded);\n\n    PluginManager.pluginEvent.bind(Sortable)(eventName, sortable, _objectSpread({\n      dragEl,\n      parentEl,\n      ghostEl,\n      rootEl,\n      nextEl,\n      lastDownEl,\n      cloneEl,\n      cloneHidden,\n      dragStarted: moved,\n      putSortable,\n      activeSortable: Sortable.active,\n      originalEvent,\n      oldIndex,\n      oldDraggableIndex,\n      newIndex,\n      newDraggableIndex,\n      hideGhostForTarget: _hideGhostForTarget,\n      unhideGhostForTarget: _unhideGhostForTarget,\n\n      cloneNowHidden() {\n        cloneHidden = true;\n      },\n\n      cloneNowShown() {\n        cloneHidden = false;\n      },\n\n      dispatchSortableEvent(name) {\n        _dispatchEvent({\n          sortable,\n          name,\n          originalEvent\n        });\n      }\n\n    }, data));\n  };\n\n  function _dispatchEvent(info) {\n    dispatchEvent(_objectSpread({\n      putSortable,\n      cloneEl,\n      targetEl: dragEl,\n      rootEl,\n      oldIndex,\n      oldDraggableIndex,\n      newIndex,\n      newDraggableIndex\n    }, info));\n  }\n\n  let dragEl,\n      parentEl,\n      ghostEl,\n      rootEl,\n      nextEl,\n      lastDownEl,\n      cloneEl,\n      cloneHidden,\n      oldIndex,\n      newIndex,\n      oldDraggableIndex,\n      newDraggableIndex,\n      activeGroup,\n      putSortable,\n      awaitingDragStarted = false,\n      ignoreNextClick = false,\n      sortables = [],\n      tapEvt,\n      touchEvt,\n      lastDx,\n      lastDy,\n      tapDistanceLeft,\n      tapDistanceTop,\n      moved,\n      lastTarget,\n      lastDirection,\n      pastFirstInvertThresh = false,\n      isCircumstantialInvert = false,\n      targetMoveDistance,\n      // For positioning ghost absolutely\n  ghostRelativeParent,\n      ghostRelativeParentInitialScroll = [],\n      // (left, top)\n  _silent = false,\n      savedInputChecked = [];\n  /** @const */\n\n  const documentExists = typeof document !== \"undefined\",\n        PositionGhostAbsolutely = IOS,\n        CSSFloatProperty = Edge || IE11OrLess ? \"cssFloat\" : \"float\",\n        // This will not pass for IE9, because IE9 DnD only works on anchors\n  supportDraggable = documentExists && !ChromeForAndroid && !IOS && \"draggable\" in document.createElement(\"div\"),\n        supportCssPointerEvents = function () {\n    if (!documentExists) return; // false when <= IE11\n\n    if (IE11OrLess) {\n      return false;\n    }\n\n    let el = document.createElement(\"x\");\n    el.style.cssText = \"pointer-events:auto\";\n    return el.style.pointerEvents === \"auto\";\n  }(),\n        _detectDirection = function (el, options) {\n    let elCSS = css(el),\n        elWidth = parseInt(elCSS.width) - parseInt(elCSS.paddingLeft) - parseInt(elCSS.paddingRight) - parseInt(elCSS.borderLeftWidth) - parseInt(elCSS.borderRightWidth),\n        child1 = getChild(el, 0, options),\n        child2 = getChild(el, 1, options),\n        firstChildCSS = child1 && css(child1),\n        secondChildCSS = child2 && css(child2),\n        firstChildWidth = firstChildCSS && parseInt(firstChildCSS.marginLeft) + parseInt(firstChildCSS.marginRight) + getRect(child1).width,\n        secondChildWidth = secondChildCSS && parseInt(secondChildCSS.marginLeft) + parseInt(secondChildCSS.marginRight) + getRect(child2).width;\n\n    if (elCSS.display === \"flex\") {\n      return elCSS.flexDirection === \"column\" || elCSS.flexDirection === \"column-reverse\" ? \"vertical\" : \"horizontal\";\n    }\n\n    if (elCSS.display === \"grid\") {\n      return elCSS.gridTemplateColumns.split(\" \").length <= 1 ? \"vertical\" : \"horizontal\";\n    }\n\n    if (child1 && firstChildCSS.float && firstChildCSS.float !== \"none\") {\n      let touchingSideChild2 = firstChildCSS.float === \"left\" ? \"left\" : \"right\";\n      return child2 && (secondChildCSS.clear === \"both\" || secondChildCSS.clear === touchingSideChild2) ? \"vertical\" : \"horizontal\";\n    }\n\n    return child1 && (firstChildCSS.display === \"block\" || firstChildCSS.display === \"flex\" || firstChildCSS.display === \"table\" || firstChildCSS.display === \"grid\" || firstChildWidth >= elWidth && elCSS[CSSFloatProperty] === \"none\" || child2 && elCSS[CSSFloatProperty] === \"none\" && firstChildWidth + secondChildWidth > elWidth) ? \"vertical\" : \"horizontal\";\n  },\n        _dragElInRowColumn = function (dragRect, targetRect, vertical) {\n    let dragElS1Opp = vertical ? dragRect.left : dragRect.top,\n        dragElS2Opp = vertical ? dragRect.right : dragRect.bottom,\n        dragElOppLength = vertical ? dragRect.width : dragRect.height,\n        targetS1Opp = vertical ? targetRect.left : targetRect.top,\n        targetS2Opp = vertical ? targetRect.right : targetRect.bottom,\n        targetOppLength = vertical ? targetRect.width : targetRect.height;\n    return dragElS1Opp === targetS1Opp || dragElS2Opp === targetS2Opp || dragElS1Opp + dragElOppLength / 2 === targetS1Opp + targetOppLength / 2;\n  },\n\n  /**\n   * Detects first nearest empty sortable to X and Y position using emptyInsertThreshold.\n   * @param  {Number} x      X position\n   * @param  {Number} y      Y position\n   * @return {HTMLElement}   Element of the first found nearest Sortable\n   */\n  _detectNearestEmptySortable = function (x, y) {\n    let ret;\n    sortables.some(sortable => {\n      if (lastChild(sortable)) return;\n      let rect = getRect(sortable),\n          threshold = sortable[expando].options.emptyInsertThreshold,\n          insideHorizontally = x >= rect.left - threshold && x <= rect.right + threshold,\n          insideVertically = y >= rect.top - threshold && y <= rect.bottom + threshold;\n\n      if (threshold && insideHorizontally && insideVertically) {\n        return ret = sortable;\n      }\n    });\n    return ret;\n  },\n        _prepareGroup = function (options) {\n    function toFn(value, pull) {\n      return function (to, from, dragEl, evt) {\n        let sameGroup = to.options.group.name && from.options.group.name && to.options.group.name === from.options.group.name;\n\n        if (value == null && (pull || sameGroup)) {\n          // Default pull value\n          // Default pull and put value if same group\n          return true;\n        } else if (value == null || value === false) {\n          return false;\n        } else if (pull && value === \"clone\") {\n          return value;\n        } else if (typeof value === \"function\") {\n          return toFn(value(to, from, dragEl, evt), pull)(to, from, dragEl, evt);\n        } else {\n          let otherGroup = (pull ? to : from).options.group.name;\n          return value === true || typeof value === \"string\" && value === otherGroup || value.join && value.indexOf(otherGroup) > -1;\n        }\n      };\n    }\n\n    let group = {};\n    let originalGroup = options.group;\n\n    if (!originalGroup || typeof originalGroup != \"object\") {\n      originalGroup = {\n        name: originalGroup\n      };\n    }\n\n    group.name = originalGroup.name;\n    group.checkPull = toFn(originalGroup.pull, true);\n    group.checkPut = toFn(originalGroup.put);\n    group.revertClone = originalGroup.revertClone;\n    options.group = group;\n  },\n        _hideGhostForTarget = function () {\n    if (!supportCssPointerEvents && ghostEl) {\n      css(ghostEl, \"display\", \"none\");\n    }\n  },\n        _unhideGhostForTarget = function () {\n    if (!supportCssPointerEvents && ghostEl) {\n      css(ghostEl, \"display\", \"\");\n    }\n  }; // #1184 fix - Prevent click event on fallback if dragged but item not changed position\n\n\n  if (documentExists) {\n    document.addEventListener(\"click\", function (evt) {\n      if (ignoreNextClick) {\n        evt.preventDefault();\n        evt.stopPropagation && evt.stopPropagation();\n        evt.stopImmediatePropagation && evt.stopImmediatePropagation();\n        ignoreNextClick = false;\n        return false;\n      }\n    }, true);\n  }\n\n  let nearestEmptyInsertDetectEvent = function (evt) {\n    if (dragEl) {\n      evt = evt.touches ? evt.touches[0] : evt;\n\n      let nearest = _detectNearestEmptySortable(evt.clientX, evt.clientY);\n\n      if (nearest) {\n        // Create imitation event\n        let event = {};\n\n        for (let i in evt) {\n          if (evt.hasOwnProperty(i)) {\n            event[i] = evt[i];\n          }\n        }\n\n        event.target = event.rootEl = nearest;\n        event.preventDefault = void 0;\n        event.stopPropagation = void 0;\n\n        nearest[expando]._onDragOver(event);\n      }\n    }\n  };\n\n  let _checkOutsideTargetEl = function (evt) {\n    if (dragEl) {\n      dragEl.parentNode[expando]._isOutsideThisEl(evt.target);\n    }\n  };\n  /**\n   * @class  Sortable\n   * @param  {HTMLElement}  el\n   * @param  {Object}       [options]\n   */\n\n\n  function Sortable(el, options) {\n    if (!(el && el.nodeType && el.nodeType === 1)) {\n      throw `Sortable: \\`el\\` must be an HTMLElement, not ${{}.toString.call(el)}`;\n    }\n\n    this.el = el; // root element\n\n    this.options = options = Object.assign({}, options); // Export instance\n\n    el[expando] = this;\n    let defaults = {\n      group: null,\n      sort: true,\n      disabled: false,\n      store: null,\n      handle: null,\n      draggable: /^[uo]l$/i.test(el.nodeName) ? \">li\" : \">*\",\n      swapThreshold: 1,\n      // percentage; 0 <= x <= 1\n      invertSwap: false,\n      // invert always\n      invertedSwapThreshold: null,\n      // will be set to same as swapThreshold if default\n      removeCloneOnHide: true,\n      direction: function () {\n        return _detectDirection(el, this.options);\n      },\n      ghostClass: \"sortable-ghost\",\n      chosenClass: \"sortable-chosen\",\n      dragClass: \"sortable-drag\",\n      ignore: \"a, img\",\n      filter: null,\n      preventOnFilter: true,\n      animation: 0,\n      easing: null,\n      setData: function (dataTransfer, dragEl) {\n        dataTransfer.setData(\"Text\", dragEl.textContent);\n      },\n      dropBubble: false,\n      dragoverBubble: false,\n      dataIdAttr: \"data-id\",\n      delay: 0,\n      delayOnTouchOnly: false,\n      touchStartThreshold: (Number.parseInt ? Number : window).parseInt(window.devicePixelRatio, 10) || 1,\n      forceFallback: false,\n      fallbackClass: \"sortable-fallback\",\n      fallbackOnBody: false,\n      fallbackTolerance: 0,\n      fallbackOffset: {\n        x: 0,\n        y: 0\n      },\n      supportPointer: Sortable.supportPointer !== false && \"PointerEvent\" in window,\n      emptyInsertThreshold: 5\n    };\n    PluginManager.initializePlugins(this, el, defaults); // Set default options\n\n    for (let name in defaults) {\n      !(name in options) && (options[name] = defaults[name]);\n    }\n\n    _prepareGroup(options); // Bind all private methods\n\n\n    for (let fn in this) {\n      if (fn.charAt(0) === \"_\" && typeof this[fn] === \"function\") {\n        this[fn] = this[fn].bind(this);\n      }\n    } // Setup drag mode\n\n\n    this.nativeDraggable = options.forceFallback ? false : supportDraggable;\n\n    if (this.nativeDraggable) {\n      // Touch start threshold cannot be greater than the native dragstart threshold\n      this.options.touchStartThreshold = 1;\n    } // Bind events\n\n\n    if (options.supportPointer) {\n      on(el, \"pointerdown\", this._onTapStart);\n    } else {\n      on(el, \"mousedown\", this._onTapStart);\n      on(el, \"touchstart\", this._onTapStart);\n    }\n\n    if (this.nativeDraggable) {\n      on(el, \"dragover\", this);\n      on(el, \"dragenter\", this);\n    }\n\n    sortables.push(this.el); // Restore sorting\n\n    options.store && options.store.get && this.sort(options.store.get(this) || []); // Add animation state manager\n\n    Object.assign(this, AnimationStateManager());\n  }\n\n  Sortable.prototype =\n  /** @lends Sortable.prototype */\n  {\n    constructor: Sortable,\n    _isOutsideThisEl: function (target) {\n      if (!this.el.contains(target) && target !== this.el) {\n        lastTarget = null;\n      }\n    },\n    _getDirection: function (evt, target) {\n      return typeof this.options.direction === \"function\" ? this.options.direction.call(this, evt, target, dragEl) : this.options.direction;\n    },\n    _onTapStart: function (\n    /** Event|TouchEvent */\n    evt) {\n      if (!evt.cancelable) return;\n\n      let _this = this,\n          el = this.el,\n          options = this.options,\n          preventOnFilter = options.preventOnFilter,\n          type = evt.type,\n          touch = evt.touches && evt.touches[0] || evt.pointerType && evt.pointerType === \"touch\" && evt,\n          target = (touch || evt).target,\n          originalTarget = evt.target.shadowRoot && (evt.path && evt.path[0] || evt.composedPath && evt.composedPath()[0]) || target,\n          filter = options.filter;\n\n      _saveInputCheckedState(el); // Don't trigger start event when an element is been dragged, otherwise the evt.oldindex always wrong when set option.group.\n\n\n      if (dragEl) {\n        return;\n      }\n\n      if (/mousedown|pointerdown/.test(type) && evt.button !== 0 || options.disabled) {\n        return; // only left button and enabled\n      } // cancel dnd if original target is content editable\n\n\n      if (originalTarget.isContentEditable) {\n        return;\n      } // Safari ignores further event handling after mousedown\n\n\n      if (!this.nativeDraggable && Safari && target && target.tagName.toUpperCase() === \"SELECT\") {\n        return;\n      }\n\n      target = closest(target, options.draggable, el, false);\n\n      if (target && target.animated) {\n        return;\n      }\n\n      if (lastDownEl === target) {\n        // Ignoring duplicate `down`\n        return;\n      } // Get the index of the dragged element within its parent\n\n\n      oldIndex = index(target);\n      oldDraggableIndex = index(target, options.draggable); // Check filter\n\n      if (typeof filter === \"function\") {\n        if (filter.call(this, evt, target, this)) {\n          _dispatchEvent({\n            sortable: _this,\n            rootEl: originalTarget,\n            name: \"filter\",\n            targetEl: target,\n            toEl: el,\n            fromEl: el\n          });\n\n          pluginEvent(\"filter\", _this, {\n            evt\n          });\n          preventOnFilter && evt.cancelable && evt.preventDefault();\n          return; // cancel dnd\n        }\n      } else if (filter) {\n        filter = filter.split(\",\").some(function (criteria) {\n          criteria = closest(originalTarget, criteria.trim(), el, false);\n\n          if (criteria) {\n            _dispatchEvent({\n              sortable: _this,\n              rootEl: criteria,\n              name: \"filter\",\n              targetEl: target,\n              fromEl: el,\n              toEl: el\n            });\n\n            pluginEvent(\"filter\", _this, {\n              evt\n            });\n            return true;\n          }\n        });\n\n        if (filter) {\n          preventOnFilter && evt.cancelable && evt.preventDefault();\n          return; // cancel dnd\n        }\n      }\n\n      if (options.handle && !closest(originalTarget, options.handle, el, false)) {\n        return;\n      } // Prepare `dragstart`\n\n\n      this._prepareDragStart(evt, touch, target);\n    },\n    _prepareDragStart: function (\n    /** Event */\n    evt,\n    /** Touch */\n    touch,\n    /** HTMLElement */\n    target) {\n      let _this = this,\n          el = _this.el,\n          options = _this.options,\n          ownerDocument = el.ownerDocument,\n          dragStartFn;\n\n      if (target && !dragEl && target.parentNode === el) {\n        let dragRect = getRect(target);\n        rootEl = el;\n        dragEl = target;\n        parentEl = dragEl.parentNode;\n        nextEl = dragEl.nextSibling;\n        lastDownEl = target;\n        activeGroup = options.group;\n        Sortable.dragged = dragEl; // PORTME: added offset\n\n        let offset = 0;\n        const targetBoundingRect = target.getBoundingClientRect();\n\n        if (targetBoundingRect.left + 95 < (touch || evt).clientX) {\n          offset = (touch || evt).clientX - targetBoundingRect.left - 95 / 2;\n        }\n\n        tapEvt = {\n          target: dragEl,\n          clientX: (touch || evt).clientX - offset,\n          clientY: (touch || evt).clientY\n        };\n        tapDistanceLeft = tapEvt.clientX - dragRect.left;\n        tapDistanceTop = tapEvt.clientY - dragRect.top;\n        this._lastX = (touch || evt).clientX - offset;\n        this._lastY = (touch || evt).clientY;\n        dragEl.style[\"will-change\"] = \"all\";\n\n        dragStartFn = function () {\n          pluginEvent(\"delayEnded\", _this, {\n            evt\n          });\n\n          if (Sortable.eventCanceled) {\n            _this._onDrop();\n\n            return;\n          } // Delayed drag has been triggered\n          // we can re-enable the events: touchmove/mousemove\n\n\n          _this._disableDelayedDragEvents();\n\n          if (!FireFox && _this.nativeDraggable) {\n            dragEl.draggable = true;\n          } // Bind the events: dragstart/dragend\n\n\n          _this._triggerDragStart(evt, touch); // Drag start event\n\n\n          _dispatchEvent({\n            sortable: _this,\n            name: \"choose\",\n            originalEvent: evt\n          }); // Chosen item\n\n\n          toggleClass(dragEl, options.chosenClass, true);\n        }; // Disable \"draggable\"\n\n\n        options.ignore.split(\",\").forEach(function (criteria) {\n          find(dragEl, criteria.trim(), _disableDraggable);\n        });\n        on(ownerDocument, \"dragover\", nearestEmptyInsertDetectEvent);\n        on(ownerDocument, \"mousemove\", nearestEmptyInsertDetectEvent);\n        on(ownerDocument, \"touchmove\", nearestEmptyInsertDetectEvent);\n        on(ownerDocument, \"mouseup\", _this._onDrop);\n        on(ownerDocument, \"touchend\", _this._onDrop);\n        on(ownerDocument, \"touchcancel\", _this._onDrop); // Make dragEl draggable (must be before delay for FireFox)\n\n        if (FireFox && this.nativeDraggable) {\n          this.options.touchStartThreshold = 4;\n          dragEl.draggable = true;\n        }\n\n        pluginEvent(\"delayStart\", this, {\n          evt\n        }); // Delay is impossible for native DnD in Edge or IE\n\n        if (options.delay && (!options.delayOnTouchOnly || touch) && (!this.nativeDraggable || !(Edge || IE11OrLess))) {\n          if (Sortable.eventCanceled) {\n            this._onDrop();\n\n            return;\n          } // If the user moves the pointer or let go the click or touch\n          // before the delay has been reached:\n          // disable the delayed drag\n\n\n          on(ownerDocument, \"mouseup\", _this._disableDelayedDrag);\n          on(ownerDocument, \"touchend\", _this._disableDelayedDrag);\n          on(ownerDocument, \"touchcancel\", _this._disableDelayedDrag);\n          on(ownerDocument, \"mousemove\", _this._delayedDragTouchMoveHandler);\n          on(ownerDocument, \"touchmove\", _this._delayedDragTouchMoveHandler);\n          options.supportPointer && on(ownerDocument, \"pointermove\", _this._delayedDragTouchMoveHandler);\n          _this._dragStartTimer = setTimeout(dragStartFn, options.delay);\n        } else {\n          dragStartFn();\n        }\n      }\n    },\n    _delayedDragTouchMoveHandler: function (\n    /** TouchEvent|PointerEvent **/\n    e) {\n      let touch = e.touches ? e.touches[0] : e;\n\n      if (Math.max(Math.abs(touch.clientX - this._lastX), Math.abs(touch.clientY - this._lastY)) >= Math.floor(this.options.touchStartThreshold / (this.nativeDraggable && window.devicePixelRatio || 1))) {\n        this._disableDelayedDrag();\n      }\n    },\n    _disableDelayedDrag: function () {\n      dragEl && _disableDraggable(dragEl);\n      clearTimeout(this._dragStartTimer);\n\n      this._disableDelayedDragEvents();\n    },\n    _disableDelayedDragEvents: function () {\n      let ownerDocument = this.el.ownerDocument;\n      off(ownerDocument, \"mouseup\", this._disableDelayedDrag);\n      off(ownerDocument, \"touchend\", this._disableDelayedDrag);\n      off(ownerDocument, \"touchcancel\", this._disableDelayedDrag);\n      off(ownerDocument, \"mousemove\", this._delayedDragTouchMoveHandler);\n      off(ownerDocument, \"touchmove\", this._delayedDragTouchMoveHandler);\n      off(ownerDocument, \"pointermove\", this._delayedDragTouchMoveHandler);\n    },\n    _triggerDragStart: function (\n    /** Event */\n    evt,\n    /** Touch */\n    touch) {\n      touch = touch || evt.pointerType == \"touch\" && evt;\n\n      if (!this.nativeDraggable || touch) {\n        if (this.options.supportPointer) {\n          on(document, \"pointermove\", this._onTouchMove);\n        } else if (touch) {\n          on(document, \"touchmove\", this._onTouchMove);\n        } else {\n          on(document, \"mousemove\", this._onTouchMove);\n        }\n      } else {\n        on(dragEl, \"dragend\", this);\n        on(rootEl, \"dragstart\", this._onDragStart);\n      }\n\n      try {\n        if (document.selection) {\n          // Timeout neccessary for IE9\n          _nextTick(function () {\n            document.selection.empty();\n          });\n        } else {\n          window.getSelection().removeAllRanges();\n        }\n      } catch (err) {}\n    },\n    _dragStarted: function (fallback, evt) {\n      awaitingDragStarted = false;\n\n      if (rootEl && dragEl) {\n        pluginEvent(\"dragStarted\", this, {\n          evt\n        });\n\n        if (this.nativeDraggable) {\n          on(document, \"dragover\", _checkOutsideTargetEl);\n        }\n\n        let options = this.options; // Apply effect\n\n        !fallback && toggleClass(dragEl, options.dragClass, false);\n        toggleClass(dragEl, options.ghostClass, true);\n        Sortable.active = this;\n        fallback && this._appendGhost(); // Drag start event\n\n        _dispatchEvent({\n          sortable: this,\n          name: \"start\",\n          originalEvent: evt\n        });\n      } else {\n        this._nulling();\n      }\n    },\n    _emulateDragOver: function () {\n      if (touchEvt) {\n        this._lastX = touchEvt.clientX;\n        this._lastY = touchEvt.clientY;\n\n        _hideGhostForTarget();\n\n        let target = document.elementFromPoint(touchEvt.clientX, touchEvt.clientY);\n        let parent = target;\n\n        while (target && target.shadowRoot) {\n          target = target.shadowRoot.elementFromPoint(touchEvt.clientX, touchEvt.clientY);\n          if (target === parent) break;\n          parent = target;\n        }\n\n        dragEl.parentNode[expando]._isOutsideThisEl(target);\n\n        if (parent) {\n          do {\n            if (parent[expando]) {\n              let inserted;\n              inserted = parent[expando]._onDragOver({\n                clientX: touchEvt.clientX,\n                clientY: touchEvt.clientY,\n                target: target,\n                rootEl: parent\n              });\n\n              if (inserted && !this.options.dragoverBubble) {\n                break;\n              }\n            }\n\n            target = parent; // store last element\n          } while (\n          /* jshint boss:true */\n          parent = parent.parentNode);\n        }\n\n        _unhideGhostForTarget();\n      }\n    },\n    _onTouchMove: function (\n    /**TouchEvent*/\n    evt) {\n      if (tapEvt) {\n        let options = this.options,\n            fallbackTolerance = options.fallbackTolerance,\n            fallbackOffset = options.fallbackOffset,\n            touch = evt.touches ? evt.touches[0] : evt,\n            ghostMatrix = ghostEl && matrix(ghostEl, true),\n            scaleX = ghostEl && ghostMatrix && ghostMatrix.a,\n            scaleY = ghostEl && ghostMatrix && ghostMatrix.d,\n            relativeScrollOffset = PositionGhostAbsolutely && ghostRelativeParent && getRelativeScrollOffset(ghostRelativeParent),\n            dx = (touch.clientX - tapEvt.clientX + fallbackOffset.x) / (scaleX || 1) + (relativeScrollOffset ? relativeScrollOffset[0] - ghostRelativeParentInitialScroll[0] : 0) / (scaleX || 1),\n            dy = (touch.clientY - tapEvt.clientY + fallbackOffset.y) / (scaleY || 1) + (relativeScrollOffset ? relativeScrollOffset[1] - ghostRelativeParentInitialScroll[1] : 0) / (scaleY || 1); // only set the status to dragging, when we are actually dragging\n\n        if (!Sortable.active && !awaitingDragStarted) {\n          if (fallbackTolerance && Math.max(Math.abs(touch.clientX - this._lastX), Math.abs(touch.clientY - this._lastY)) < fallbackTolerance) {\n            return;\n          }\n\n          this._onDragStart(evt, true);\n        }\n\n        if (ghostEl) {\n          if (ghostMatrix) {\n            ghostMatrix.e += dx - (lastDx || 0);\n            ghostMatrix.f += dy - (lastDy || 0);\n          } else {\n            ghostMatrix = {\n              a: 1,\n              b: 0,\n              c: 0,\n              d: 1,\n              e: dx,\n              f: dy\n            };\n          }\n\n          let cssMatrix = `matrix(${ghostMatrix.a},${ghostMatrix.b},${ghostMatrix.c},${ghostMatrix.d},${ghostMatrix.e},${ghostMatrix.f})`;\n          css(ghostEl, \"webkitTransform\", cssMatrix);\n          css(ghostEl, \"mozTransform\", cssMatrix);\n          css(ghostEl, \"msTransform\", cssMatrix);\n          css(ghostEl, \"transform\", cssMatrix);\n          lastDx = dx;\n          lastDy = dy;\n          touchEvt = touch;\n        }\n\n        evt.cancelable && evt.preventDefault();\n      }\n    },\n    _appendGhost: function () {\n      // Bug if using scale(): https://stackoverflow.com/questions/2637058\n      // Not being adjusted for\n      if (!ghostEl) {\n        let container = this.options.fallbackOnBody ? document.body : rootEl,\n            rect = getRect(dragEl, true, PositionGhostAbsolutely, true, container),\n            options = this.options; // Position absolutely\n\n        if (PositionGhostAbsolutely) {\n          // Get relatively positioned parent\n          ghostRelativeParent = container;\n\n          while (css(ghostRelativeParent, \"position\") === \"static\" && css(ghostRelativeParent, \"transform\") === \"none\" && ghostRelativeParent !== document) {\n            ghostRelativeParent = ghostRelativeParent.parentNode;\n          }\n\n          if (ghostRelativeParent !== document.body && ghostRelativeParent !== document.documentElement) {\n            if (ghostRelativeParent === document) ghostRelativeParent = getWindowScrollingElement();\n            rect.top += ghostRelativeParent.scrollTop;\n            rect.left += ghostRelativeParent.scrollLeft;\n          } else {\n            ghostRelativeParent = getWindowScrollingElement();\n          }\n\n          ghostRelativeParentInitialScroll = getRelativeScrollOffset(ghostRelativeParent);\n        }\n\n        ghostEl = dragEl.cloneNode(true);\n        toggleClass(ghostEl, options.ghostClass, false);\n        toggleClass(ghostEl, options.fallbackClass, true);\n        toggleClass(ghostEl, options.dragClass, true);\n        css(ghostEl, \"transition\", \"\");\n        css(ghostEl, \"transform\", \"\");\n        css(ghostEl, \"box-sizing\", \"border-box\");\n        css(ghostEl, \"margin\", 0);\n        css(ghostEl, \"top\", rect.top);\n        css(ghostEl, \"left\", rect.left);\n        css(ghostEl, \"width\", rect.width);\n        css(ghostEl, \"height\", rect.height);\n        css(ghostEl, \"opacity\", \"0.8\");\n        css(ghostEl, \"position\", PositionGhostAbsolutely ? \"absolute\" : \"fixed\");\n        css(ghostEl, \"zIndex\", \"100000\");\n        css(ghostEl, \"pointerEvents\", \"none\");\n        Sortable.ghost = ghostEl;\n        container.appendChild(ghostEl); // Set transform-origin\n\n        css(ghostEl, \"transform-origin\", tapDistanceLeft / parseInt(ghostEl.style.width) * 100 + \"% \" + tapDistanceTop / parseInt(ghostEl.style.height) * 100 + \"%\");\n      }\n    },\n    _onDragStart: function (\n    /**Event*/\n    evt,\n    /**boolean*/\n    fallback) {\n      let _this = this;\n\n      let dataTransfer = evt.dataTransfer;\n      let options = _this.options;\n      pluginEvent(\"dragStart\", this, {\n        evt\n      });\n\n      if (Sortable.eventCanceled) {\n        this._onDrop();\n\n        return;\n      }\n\n      pluginEvent(\"setupClone\", this);\n\n      if (!Sortable.eventCanceled) {\n        cloneEl = clone(dragEl);\n        cloneEl.draggable = false;\n        cloneEl.style[\"will-change\"] = \"\";\n\n        this._hideClone();\n\n        toggleClass(cloneEl, this.options.chosenClass, false);\n        Sortable.clone = cloneEl;\n      } // #1143: IFrame support workaround\n\n\n      _this.cloneId = _nextTick(function () {\n        pluginEvent(\"clone\", _this);\n        if (Sortable.eventCanceled) return;\n\n        if (!_this.options.removeCloneOnHide) {\n          rootEl.insertBefore(cloneEl, dragEl);\n        }\n\n        _this._hideClone();\n\n        _dispatchEvent({\n          sortable: _this,\n          name: \"clone\"\n        });\n      });\n      !fallback && toggleClass(dragEl, options.dragClass, true); // Set proper drop events\n\n      if (fallback) {\n        ignoreNextClick = true;\n        _this._loopId = setInterval(_this._emulateDragOver, 50);\n      } else {\n        // Undo what was set in _prepareDragStart before drag started\n        off(document, \"mouseup\", _this._onDrop);\n        off(document, \"touchend\", _this._onDrop);\n        off(document, \"touchcancel\", _this._onDrop);\n\n        if (dataTransfer) {\n          dataTransfer.effectAllowed = \"move\";\n          options.setData && options.setData.call(_this, dataTransfer, dragEl);\n        }\n\n        on(document, \"drop\", _this); // #1276 fix:\n\n        css(dragEl, \"transform\", \"translateZ(0)\");\n      }\n\n      awaitingDragStarted = true;\n      _this._dragStartId = _nextTick(_this._dragStarted.bind(_this, fallback, evt));\n      on(document, \"selectstart\", _this);\n      moved = true;\n\n      if (Safari) {\n        css(document.body, \"user-select\", \"none\");\n      }\n    },\n    // Returns true - if no further action is needed (either inserted or another condition)\n    _onDragOver: function (\n    /**Event*/\n    evt) {\n      let el = this.el,\n          target = evt.target,\n          dragRect,\n          targetRect,\n          revert,\n          options = this.options,\n          group = options.group,\n          activeSortable = Sortable.active,\n          isOwner = activeGroup === group,\n          canSort = options.sort,\n          fromSortable = putSortable || activeSortable,\n          vertical,\n          _this = this,\n          completedFired = false;\n\n      if (_silent) return;\n\n      function dragOverEvent(name, extra) {\n        pluginEvent(name, _this, _objectSpread({\n          evt,\n          isOwner,\n          axis: vertical ? \"vertical\" : \"horizontal\",\n          revert,\n          dragRect,\n          targetRect,\n          canSort,\n          fromSortable,\n          target,\n          completed,\n\n          onMove(target, after) {\n            return onMove(rootEl, el, dragEl, dragRect, target, getRect(target), evt, after);\n          },\n\n          changed\n        }, extra));\n      } // Capture animation state\n\n\n      function capture() {\n        dragOverEvent(\"dragOverAnimationCapture\");\n\n        _this.captureAnimationState();\n\n        if (_this !== fromSortable) {\n          fromSortable.captureAnimationState();\n        }\n      } // Return invocation when dragEl is inserted (or completed)\n\n\n      function completed(insertion) {\n        dragOverEvent(\"dragOverCompleted\", {\n          insertion\n        });\n\n        if (insertion) {\n          // Clones must be hidden before folding animation to capture dragRectAbsolute properly\n          if (isOwner) {\n            activeSortable._hideClone();\n          } else {\n            activeSortable._showClone(_this);\n          }\n\n          if (_this !== fromSortable) {\n            // Set ghost class to new sortable's ghost class\n            toggleClass(dragEl, putSortable ? putSortable.options.ghostClass : activeSortable.options.ghostClass, false);\n            toggleClass(dragEl, options.ghostClass, true);\n          }\n\n          if (putSortable !== _this && _this !== Sortable.active) {\n            putSortable = _this;\n          } else if (_this === Sortable.active && putSortable) {\n            putSortable = null;\n          } // Animation\n\n\n          if (fromSortable === _this) {\n            _this._ignoreWhileAnimating = target;\n          }\n\n          _this.animateAll(function () {\n            dragOverEvent(\"dragOverAnimationComplete\");\n            _this._ignoreWhileAnimating = null;\n          });\n\n          if (_this !== fromSortable) {\n            fromSortable.animateAll();\n            fromSortable._ignoreWhileAnimating = null;\n          }\n        } // Null lastTarget if it is not inside a previously swapped element\n\n\n        if (target === dragEl && !dragEl.animated || target === el && !target.animated) {\n          lastTarget = null;\n        } // no bubbling and not fallback\n\n\n        if (!options.dragoverBubble && !evt.rootEl && target !== document) {\n          dragEl.parentNode[expando]._isOutsideThisEl(evt.target); // Do not detect for empty insert if already inserted\n\n\n          !insertion && nearestEmptyInsertDetectEvent(evt);\n        }\n\n        !options.dragoverBubble && evt.stopPropagation && evt.stopPropagation();\n        return completedFired = true;\n      } // Call when dragEl has been inserted\n\n\n      function changed() {\n        newIndex = index(dragEl);\n        newDraggableIndex = index(dragEl, options.draggable);\n\n        _dispatchEvent({\n          sortable: _this,\n          name: \"change\",\n          toEl: el,\n          newIndex,\n          newDraggableIndex,\n          originalEvent: evt\n        });\n      }\n\n      if (evt.preventDefault !== void 0) {\n        evt.cancelable && evt.preventDefault();\n      }\n\n      target = closest(target, options.draggable, el, true);\n      dragOverEvent(\"dragOver\");\n      if (Sortable.eventCanceled) return completedFired;\n\n      if (dragEl.contains(evt.target) || target.animated && target.animatingX && target.animatingY || _this._ignoreWhileAnimating === target) {\n        return completed(false);\n      }\n\n      ignoreNextClick = false;\n\n      if (activeSortable && !options.disabled && (isOwner ? canSort || (revert = !rootEl.contains(dragEl)) // Reverting item into the original list\n      : putSortable === this || (this.lastPutMode = activeGroup.checkPull(this, activeSortable, dragEl, evt)) && group.checkPut(this, activeSortable, dragEl, evt))) {\n        vertical = this._getDirection(evt, target) === \"vertical\";\n        dragRect = getRect(dragEl);\n        dragOverEvent(\"dragOverValid\");\n        if (Sortable.eventCanceled) return completedFired;\n\n        if (revert) {\n          parentEl = rootEl; // actualization\n\n          capture();\n\n          this._hideClone();\n\n          dragOverEvent(\"revert\");\n\n          if (!Sortable.eventCanceled) {\n            if (nextEl) {\n              rootEl.insertBefore(dragEl, nextEl);\n            } else {\n              rootEl.appendChild(dragEl);\n            }\n          }\n\n          return completed(true);\n        }\n\n        let elLastChild = lastChild(el, options.draggable);\n\n        if (!elLastChild || _ghostIsLast(evt, vertical, this) && !elLastChild.animated) {\n          // If already at end of list: Do not insert\n          if (elLastChild === dragEl) {\n            return completed(false);\n          } // assign target only if condition is true\n\n\n          if (elLastChild && el === evt.target) {\n            target = elLastChild;\n          }\n\n          if (target) {\n            targetRect = getRect(target);\n          }\n\n          if (onMove(rootEl, el, dragEl, dragRect, target, targetRect, evt, !!target) !== false) {\n            capture();\n            el.appendChild(dragEl);\n            parentEl = el; // actualization\n\n            changed();\n            return completed(true);\n          }\n        } else if (target.parentNode === el) {\n          targetRect = getRect(target);\n          let direction = 0,\n              targetBeforeFirstSwap,\n              differentLevel = dragEl.parentNode !== el,\n              differentRowCol = !_dragElInRowColumn(dragEl.animated && dragEl.toRect || dragRect, target.animated && target.toRect || targetRect, vertical),\n              side1 = vertical ? \"top\" : \"left\",\n              scrolledPastTop = isScrolledPast(target, \"top\", \"top\") || isScrolledPast(dragEl, \"top\", \"top\"),\n              scrollBefore = scrolledPastTop ? scrolledPastTop.scrollTop : void 0;\n\n          if (lastTarget !== target) {\n            targetBeforeFirstSwap = targetRect[side1];\n            pastFirstInvertThresh = false;\n            isCircumstantialInvert = !differentRowCol && options.invertSwap || differentLevel;\n          }\n\n          direction = _getSwapDirection(evt, target, targetRect, vertical, differentRowCol ? 1 : options.swapThreshold, options.invertedSwapThreshold == null ? options.swapThreshold : options.invertedSwapThreshold, isCircumstantialInvert, lastTarget === target);\n          let sibling;\n\n          if (direction !== 0) {\n            // Check if target is beside dragEl in respective direction (ignoring hidden elements)\n            let dragIndex = index(dragEl);\n\n            do {\n              dragIndex -= direction;\n              sibling = parentEl.children[dragIndex];\n            } while (sibling && (css(sibling, \"display\") === \"none\" || sibling === ghostEl));\n          } // If dragEl is already beside target: Do not insert\n\n\n          if (direction === 0 || sibling === target) {\n            return completed(false);\n          }\n\n          lastTarget = target;\n          lastDirection = direction;\n          let nextSibling = target.nextElementSibling,\n              after = false;\n          after = direction === 1;\n          let moveVector = onMove(rootEl, el, dragEl, dragRect, target, targetRect, evt, after);\n\n          if (moveVector !== false) {\n            if (moveVector === 1 || moveVector === -1) {\n              after = moveVector === 1;\n            }\n\n            _silent = true;\n            setTimeout(_unsilent, 30);\n            capture();\n\n            if (after && !nextSibling) {\n              el.appendChild(dragEl);\n            } else {\n              target.parentNode.insertBefore(dragEl, after ? nextSibling : target);\n            } // Undo chrome's scroll adjustment (has no effect on other browsers)\n\n\n            if (scrolledPastTop) {\n              scrollBy(scrolledPastTop, 0, scrollBefore - scrolledPastTop.scrollTop);\n            }\n\n            parentEl = dragEl.parentNode; // actualization\n            // must be done before animation\n\n            if (targetBeforeFirstSwap !== undefined && !isCircumstantialInvert) {\n              targetMoveDistance = Math.abs(targetBeforeFirstSwap - getRect(target)[side1]);\n            }\n\n            changed();\n            return completed(true);\n          }\n        }\n\n        if (el.contains(dragEl)) {\n          return completed(false);\n        }\n      }\n\n      return false;\n    },\n    _ignoreWhileAnimating: null,\n    _offMoveEvents: function () {\n      off(document, \"mousemove\", this._onTouchMove);\n      off(document, \"touchmove\", this._onTouchMove);\n      off(document, \"pointermove\", this._onTouchMove);\n      off(document, \"dragover\", nearestEmptyInsertDetectEvent);\n      off(document, \"mousemove\", nearestEmptyInsertDetectEvent);\n      off(document, \"touchmove\", nearestEmptyInsertDetectEvent);\n    },\n    _offUpEvents: function () {\n      let ownerDocument = this.el.ownerDocument;\n      off(ownerDocument, \"mouseup\", this._onDrop);\n      off(ownerDocument, \"touchend\", this._onDrop);\n      off(ownerDocument, \"pointerup\", this._onDrop);\n      off(ownerDocument, \"touchcancel\", this._onDrop);\n      off(document, \"selectstart\", this);\n    },\n    _onDrop: function (\n    /**Event*/\n    evt) {\n      let el = this.el,\n          options = this.options; // Get the index of the dragged element within its parent\n\n      newIndex = index(dragEl);\n      newDraggableIndex = index(dragEl, options.draggable);\n      pluginEvent(\"drop\", this, {\n        evt\n      });\n      parentEl = dragEl && dragEl.parentNode; // Get again after plugin event\n\n      newIndex = index(dragEl);\n      newDraggableIndex = index(dragEl, options.draggable);\n\n      if (Sortable.eventCanceled) {\n        this._nulling();\n\n        return;\n      }\n\n      awaitingDragStarted = false;\n      isCircumstantialInvert = false;\n      pastFirstInvertThresh = false;\n      clearInterval(this._loopId);\n      clearTimeout(this._dragStartTimer);\n\n      _cancelNextTick(this.cloneId);\n\n      _cancelNextTick(this._dragStartId); // Unbind events\n\n\n      if (this.nativeDraggable) {\n        off(document, \"drop\", this);\n        off(el, \"dragstart\", this._onDragStart);\n      }\n\n      this._offMoveEvents();\n\n      this._offUpEvents();\n\n      if (Safari) {\n        css(document.body, \"user-select\", \"\");\n      }\n\n      css(dragEl, \"transform\", \"\");\n\n      if (evt) {\n        if (moved) {\n          evt.cancelable && evt.preventDefault();\n          !options.dropBubble && evt.stopPropagation();\n        }\n\n        ghostEl && ghostEl.parentNode && ghostEl.parentNode.removeChild(ghostEl);\n\n        if (rootEl === parentEl || putSortable && putSortable.lastPutMode !== \"clone\") {\n          // Remove clone(s)\n          cloneEl && cloneEl.parentNode && cloneEl.parentNode.removeChild(cloneEl);\n        }\n\n        if (dragEl) {\n          if (this.nativeDraggable) {\n            off(dragEl, \"dragend\", this);\n          }\n\n          _disableDraggable(dragEl);\n\n          dragEl.style[\"will-change\"] = \"\"; // Remove classes\n          // ghostClass is added in dragStarted\n\n          if (moved && !awaitingDragStarted) {\n            toggleClass(dragEl, putSortable ? putSortable.options.ghostClass : this.options.ghostClass, false);\n          }\n\n          toggleClass(dragEl, this.options.chosenClass, false); // Drag stop event\n\n          _dispatchEvent({\n            sortable: this,\n            name: \"unchoose\",\n            toEl: parentEl,\n            newIndex: null,\n            newDraggableIndex: null,\n            originalEvent: evt\n          });\n\n          if (rootEl !== parentEl) {\n            if (newIndex >= 0) {\n              // Add event\n              _dispatchEvent({\n                rootEl: parentEl,\n                name: \"add\",\n                toEl: parentEl,\n                fromEl: rootEl,\n                originalEvent: evt\n              }); // Remove event\n\n\n              _dispatchEvent({\n                sortable: this,\n                name: \"remove\",\n                toEl: parentEl,\n                originalEvent: evt\n              }); // drag from one list and drop into another\n\n\n              _dispatchEvent({\n                rootEl: parentEl,\n                name: \"sort\",\n                toEl: parentEl,\n                fromEl: rootEl,\n                originalEvent: evt\n              });\n\n              _dispatchEvent({\n                sortable: this,\n                name: \"sort\",\n                toEl: parentEl,\n                originalEvent: evt\n              });\n            }\n\n            putSortable && putSortable.save();\n          } else {\n            if (newIndex !== oldIndex) {\n              if (newIndex >= 0) {\n                // drag & drop within the same list\n                _dispatchEvent({\n                  sortable: this,\n                  name: \"update\",\n                  toEl: parentEl,\n                  originalEvent: evt\n                });\n\n                _dispatchEvent({\n                  sortable: this,\n                  name: \"sort\",\n                  toEl: parentEl,\n                  originalEvent: evt\n                });\n              }\n            }\n          }\n\n          if (Sortable.active) {\n            /* jshint eqnull:true */\n            if (newIndex == null || newIndex === -1) {\n              newIndex = oldIndex;\n              newDraggableIndex = oldDraggableIndex;\n            }\n\n            _dispatchEvent({\n              sortable: this,\n              name: \"end\",\n              toEl: parentEl,\n              originalEvent: evt\n            }); // Save sorting\n\n\n            this.save();\n          } else {\n            // PORTME: added the dispatch block\n            _dispatchEvent({\n              sortable: this,\n              name: 'end',\n              toEl: parentEl,\n              originalEvent: evt\n            });\n          }\n        }\n      }\n\n      this._nulling();\n    },\n    _nulling: function () {\n      pluginEvent(\"nulling\", this);\n      rootEl = dragEl = parentEl = ghostEl = nextEl = cloneEl = lastDownEl = cloneHidden = tapEvt = touchEvt = moved = newIndex = newDraggableIndex = oldIndex = oldDraggableIndex = lastTarget = lastDirection = putSortable = activeGroup = Sortable.dragged = Sortable.ghost = Sortable.clone = Sortable.active = null;\n      savedInputChecked.forEach(function (el) {\n        el.checked = true;\n      });\n      savedInputChecked.length = lastDx = lastDy = 0;\n    },\n    handleEvent: function (\n    /**Event*/\n    evt) {\n      switch (evt.type) {\n        case \"drop\":\n        case \"dragend\":\n          this._onDrop(evt);\n\n          break;\n\n        case \"dragenter\":\n        case \"dragover\":\n          if (dragEl) {\n            this._onDragOver(evt);\n\n            _globalDragOver(evt);\n          }\n\n          break;\n\n        case \"selectstart\":\n          evt.preventDefault();\n          break;\n      }\n    },\n\n    /**\n     * Serializes the item into an array of string.\n     * @returns {String[]}\n     */\n    toArray: function () {\n      let order = [],\n          el,\n          children = this.el.children,\n          i = 0,\n          n = children.length,\n          options = this.options;\n\n      for (; i < n; i++) {\n        el = children[i];\n\n        if (closest(el, options.draggable, this.el, false)) {\n          order.push(el.getAttribute(options.dataIdAttr) || _generateId(el));\n        }\n      }\n\n      return order;\n    },\n\n    /**\n     * Sorts the elements according to the array.\n     * @param  {String[]}  order  order of the items\n     */\n    sort: function (order) {\n      let items = {},\n          rootEl = this.el;\n      this.toArray().forEach(function (id, i) {\n        let el = rootEl.children[i];\n\n        if (closest(el, this.options.draggable, rootEl, false)) {\n          items[id] = el;\n        }\n      }, this);\n      order.forEach(function (id) {\n        if (items[id]) {\n          rootEl.removeChild(items[id]);\n          rootEl.appendChild(items[id]);\n        }\n      });\n    },\n\n    /**\n     * Save the current sorting\n     */\n    save: function () {\n      let store = this.options.store;\n      store && store.set && store.set(this);\n    },\n\n    /**\n     * For each element in the set, get the first element that matches the selector by testing the element itself and traversing up through its ancestors in the DOM tree.\n     * @param   {HTMLElement}  el\n     * @param   {String}       [selector]  default: `options.draggable`\n     * @returns {HTMLElement|null}\n     */\n    closest: function (el, selector) {\n      return closest(el, selector || this.options.draggable, this.el, false);\n    },\n\n    /**\n     * Set/get option\n     * @param   {string} name\n     * @param   {*}      [value]\n     * @returns {*}\n     */\n    option: function (name, value) {\n      let options = this.options;\n\n      if (value === void 0) {\n        return options[name];\n      } else {\n        let modifiedValue = PluginManager.modifyOption(this, name, value);\n\n        if (typeof modifiedValue !== \"undefined\") {\n          options[name] = modifiedValue;\n        } else {\n          options[name] = value;\n        }\n\n        if (name === \"group\") {\n          _prepareGroup(options);\n        }\n      }\n    },\n\n    /**\n     * Destroy\n     */\n    destroy: function () {\n      pluginEvent(\"destroy\", this);\n      let el = this.el;\n      el[expando] = null;\n      off(el, \"mousedown\", this._onTapStart);\n      off(el, \"touchstart\", this._onTapStart);\n      off(el, \"pointerdown\", this._onTapStart);\n\n      if (this.nativeDraggable) {\n        off(el, \"dragover\", this);\n        off(el, \"dragenter\", this);\n      } // Remove draggable attributes\n\n\n      Array.prototype.forEach.call(el.querySelectorAll(\"[draggable]\"), function (el) {\n        el.removeAttribute(\"draggable\");\n      });\n\n      this._onDrop();\n\n      this._disableDelayedDragEvents();\n\n      sortables.splice(sortables.indexOf(this.el), 1);\n      this.el = el = null;\n    },\n    _hideClone: function () {\n      if (!cloneHidden) {\n        pluginEvent(\"hideClone\", this);\n        if (Sortable.eventCanceled) return;\n        css(cloneEl, \"display\", \"none\");\n\n        if (this.options.removeCloneOnHide && cloneEl.parentNode) {\n          cloneEl.parentNode.removeChild(cloneEl);\n        }\n\n        cloneHidden = true;\n      }\n    },\n    _showClone: function (putSortable) {\n      if (putSortable.lastPutMode !== \"clone\") {\n        this._hideClone();\n\n        return;\n      }\n\n      if (cloneHidden) {\n        pluginEvent(\"showClone\", this);\n        if (Sortable.eventCanceled) return; // show clone at dragEl or original position\n\n        if (dragEl.parentNode == rootEl && !this.options.group.revertClone) {\n          rootEl.insertBefore(cloneEl, dragEl);\n        } else if (nextEl) {\n          rootEl.insertBefore(cloneEl, nextEl);\n        } else {\n          rootEl.appendChild(cloneEl);\n        }\n\n        if (this.options.group.revertClone) {\n          this.animate(dragEl, cloneEl);\n        }\n\n        css(cloneEl, \"display\", \"\");\n        cloneHidden = false;\n      }\n    }\n  };\n\n  function _globalDragOver(\n  /**Event*/\n  evt) {\n    if (evt.dataTransfer) {\n      evt.dataTransfer.dropEffect = \"move\";\n    }\n\n    evt.cancelable && evt.preventDefault();\n  }\n\n  function onMove(fromEl, toEl, dragEl, dragRect, targetEl, targetRect, originalEvent, willInsertAfter) {\n    let evt,\n        sortable = fromEl[expando],\n        onMoveFn = sortable.options.onMove,\n        retVal; // Support for new CustomEvent feature\n\n    if (window.CustomEvent && !IE11OrLess && !Edge) {\n      evt = new CustomEvent(\"move\", {\n        bubbles: true,\n        cancelable: true\n      });\n    } else {\n      evt = document.createEvent(\"Event\");\n      evt.initEvent(\"move\", true, true);\n    }\n\n    evt.to = toEl;\n    evt.from = fromEl;\n    evt.dragged = dragEl;\n    evt.draggedRect = dragRect;\n    evt.related = targetEl || toEl;\n    evt.relatedRect = targetRect || getRect(toEl);\n    evt.willInsertAfter = willInsertAfter;\n    evt.originalEvent = originalEvent;\n    fromEl.dispatchEvent(evt);\n\n    if (onMoveFn) {\n      retVal = onMoveFn.call(sortable, evt, originalEvent);\n    }\n\n    return retVal;\n  }\n\n  function _disableDraggable(el) {\n    el.draggable = false;\n  }\n\n  function _unsilent() {\n    _silent = false;\n  }\n\n  function _ghostIsLast(evt, vertical, sortable) {\n    let rect = getRect(lastChild(sortable.el, sortable.options.draggable));\n    const spacer = 10;\n    return vertical ? evt.clientX > rect.right + spacer || evt.clientX <= rect.right && evt.clientY > rect.bottom && evt.clientX >= rect.left : evt.clientX > rect.right && evt.clientY > rect.top || evt.clientX <= rect.right && evt.clientY > rect.bottom + spacer;\n  }\n\n  function _getSwapDirection(evt, target, targetRect, vertical, swapThreshold, invertedSwapThreshold, invertSwap, isLastTarget) {\n    let mouseOnAxis = vertical ? evt.clientY : evt.clientX,\n        targetLength = vertical ? targetRect.height : targetRect.width,\n        targetS1 = vertical ? targetRect.top : targetRect.left,\n        targetS2 = vertical ? targetRect.bottom : targetRect.right,\n        invert = false;\n\n    if (!invertSwap) {\n      // Never invert or create dragEl shadow when target movemenet causes mouse to move past the end of regular swapThreshold\n      if (isLastTarget && targetMoveDistance < targetLength * swapThreshold) {\n        // multiplied only by swapThreshold because mouse will already be inside target by (1 - threshold) * targetLength / 2\n        // check if past first invert threshold on side opposite of lastDirection\n        if (!pastFirstInvertThresh && (lastDirection === 1 ? mouseOnAxis > targetS1 + targetLength * invertedSwapThreshold / 2 : mouseOnAxis < targetS2 - targetLength * invertedSwapThreshold / 2)) {\n          // past first invert threshold, do not restrict inverted threshold to dragEl shadow\n          pastFirstInvertThresh = true;\n        }\n\n        if (!pastFirstInvertThresh) {\n          // dragEl shadow (target move distance shadow)\n          if (lastDirection === 1 ? mouseOnAxis < targetS1 + targetMoveDistance // over dragEl shadow\n          : mouseOnAxis > targetS2 - targetMoveDistance) {\n            return -lastDirection;\n          }\n        } else {\n          invert = true;\n        }\n      } else {\n        // Regular\n        if (mouseOnAxis > targetS1 + targetLength * (1 - swapThreshold) / 2 && mouseOnAxis < targetS2 - targetLength * (1 - swapThreshold) / 2) {\n          return _getInsertDirection(target);\n        }\n      }\n    }\n\n    invert = invert || invertSwap;\n\n    if (invert) {\n      // Invert of regular\n      if (mouseOnAxis < targetS1 + targetLength * invertedSwapThreshold / 2 || mouseOnAxis > targetS2 - targetLength * invertedSwapThreshold / 2) {\n        return mouseOnAxis > targetS1 + targetLength / 2 ? 1 : -1;\n      }\n    }\n\n    return 0;\n  }\n  /**\n   * Gets the direction dragEl must be swapped relative to target in order to make it\n   * seem that dragEl has been \"inserted\" into that element's position\n   * @param  {HTMLElement} target       The target whose position dragEl is being inserted at\n   * @return {Number}                   Direction dragEl must be swapped\n   */\n\n\n  function _getInsertDirection(target) {\n    if (index(dragEl) < index(target)) {\n      return 1;\n    } else {\n      return -1;\n    }\n  }\n  /**\n   * Generate id\n   * @param   {HTMLElement} el\n   * @returns {String}\n   * @private\n   */\n\n\n  function _generateId(el) {\n    let str = el.tagName + el.className + el.src + el.href + el.textContent,\n        i = str.length,\n        sum = 0;\n\n    while (i--) {\n      sum += str.charCodeAt(i);\n    }\n\n    return sum.toString(36);\n  }\n\n  function _saveInputCheckedState(root) {\n    savedInputChecked.length = 0;\n    let inputs = root.getElementsByTagName(\"input\");\n    let idx = inputs.length;\n\n    while (idx--) {\n      let el = inputs[idx];\n      el.checked && savedInputChecked.push(el);\n    }\n  }\n\n  function _nextTick(fn) {\n    return setTimeout(fn, 0);\n  }\n\n  function _cancelNextTick(id) {\n    return clearTimeout(id);\n  } // Fixed #973:\n\n\n  if (documentExists) {\n    on(document, \"touchmove\", function (evt) {\n      if ((Sortable.active || awaitingDragStarted) && evt.cancelable) {\n        evt.preventDefault();\n      }\n    });\n  } // Export utils\n\n\n  Sortable.utils = {\n    on: on,\n    off: off,\n    css: css,\n    find: find,\n    is: function (el, selector) {\n      return !!closest(el, selector, el, false);\n    },\n    extend: extend,\n    throttle: throttle,\n    closest: closest,\n    toggleClass: toggleClass,\n    clone: clone,\n    index: index,\n    nextTick: _nextTick,\n    cancelNextTick: _cancelNextTick,\n    detectDirection: _detectDirection,\n    getChild: getChild\n  };\n  /**\n   * Get the Sortable instance of an element\n   * @param  {HTMLElement} element The element\n   * @return {Sortable|undefined}         The instance of Sortable\n   */\n\n  Sortable.get = function (element) {\n    return element[expando];\n  };\n  /**\n   * Mount a plugin to Sortable\n   * @param  {...SortablePlugin|SortablePlugin[]} plugins       Plugins being mounted\n   */\n\n\n  Sortable.mount = function () {\n    for (var _len = arguments.length, plugins = new Array(_len), _key = 0; _key < _len; _key++) {\n      plugins[_key] = arguments[_key];\n    }\n\n    if (plugins[0].constructor === Array) plugins = plugins[0];\n    plugins.forEach(plugin => {\n      if (!plugin.prototype || !plugin.prototype.constructor) {\n        throw `Sortable: Mounted plugin must be a constructor function, not ${{}.toString.call(plugin)}`;\n      }\n\n      if (plugin.utils) Sortable.utils = _objectSpread(_objectSpread({}, Sortable.utils), plugin.utils);\n      PluginManager.mount(plugin);\n    });\n  };\n  /**\n   * Create sortable instance\n   * @param {HTMLElement}  el\n   * @param {Object}      [options]\n   */\n\n\n  Sortable.create = function (el, options) {\n    return new Sortable(el, options);\n  }; // Export\n\n\n  Sortable.version = version;\n  let autoScrolls = [],\n      scrollEl,\n      scrollRootEl,\n      scrolling = false,\n      lastAutoScrollX,\n      lastAutoScrollY,\n      touchEvt$1,\n      pointerElemChangedInterval;\n\n  function AutoScrollPlugin() {\n    function AutoScroll() {\n      this.defaults = {\n        scroll: true,\n        scrollSensitivity: 30,\n        scrollSpeed: 10,\n        bubbleScroll: true\n      }; // Bind all private methods\n\n      for (let fn in this) {\n        if (fn.charAt(0) === \"_\" && typeof this[fn] === \"function\") {\n          this[fn] = this[fn].bind(this);\n        }\n      }\n    }\n\n    AutoScroll.prototype = {\n      dragStarted(_ref3) {\n        let {\n          originalEvent\n        } = _ref3;\n\n        if (this.sortable.nativeDraggable) {\n          on(document, \"dragover\", this._handleAutoScroll);\n        } else {\n          if (this.options.supportPointer) {\n            on(document, \"pointermove\", this._handleFallbackAutoScroll);\n          } else if (originalEvent.touches) {\n            on(document, \"touchmove\", this._handleFallbackAutoScroll);\n          } else {\n            on(document, \"mousemove\", this._handleFallbackAutoScroll);\n          }\n        }\n      },\n\n      dragOverCompleted(_ref4) {\n        let {\n          originalEvent\n        } = _ref4;\n\n        // For when bubbling is canceled and using fallback (fallback 'touchmove' always reached)\n        if (!this.options.dragOverBubble && !originalEvent.rootEl) {\n          this._handleAutoScroll(originalEvent);\n        }\n      },\n\n      drop() {\n        if (this.sortable.nativeDraggable) {\n          off(document, \"dragover\", this._handleAutoScroll);\n        } else {\n          off(document, \"pointermove\", this._handleFallbackAutoScroll);\n          off(document, \"touchmove\", this._handleFallbackAutoScroll);\n          off(document, \"mousemove\", this._handleFallbackAutoScroll);\n        }\n\n        clearPointerElemChangedInterval();\n        clearAutoScrolls();\n        cancelThrottle();\n      },\n\n      nulling() {\n        touchEvt$1 = scrollRootEl = scrollEl = scrolling = pointerElemChangedInterval = lastAutoScrollX = lastAutoScrollY = null;\n        autoScrolls.length = 0;\n      },\n\n      _handleFallbackAutoScroll(evt) {\n        this._handleAutoScroll(evt, true);\n      },\n\n      _handleAutoScroll(evt, fallback) {\n        const x = (evt.touches ? evt.touches[0] : evt).clientX,\n              y = (evt.touches ? evt.touches[0] : evt).clientY,\n              elem = document.elementFromPoint(x, y);\n        touchEvt$1 = evt; // IE does not seem to have native autoscroll,\n        // Edge's autoscroll seems too conditional,\n        // MACOS Safari does not have autoscroll,\n        // Firefox and Chrome are good\n\n        if (fallback || Edge || IE11OrLess || Safari) {\n          autoScroll(evt, this.options, elem, fallback); // Listener for pointer element change\n\n          let ogElemScroller = getParentAutoScrollElement(elem, true);\n\n          if (scrolling && (!pointerElemChangedInterval || x !== lastAutoScrollX || y !== lastAutoScrollY)) {\n            pointerElemChangedInterval && clearPointerElemChangedInterval(); // Detect for pointer elem change, emulating native DnD behaviour\n\n            pointerElemChangedInterval = setInterval(() => {\n              let newElem = getParentAutoScrollElement(document.elementFromPoint(x, y), true);\n\n              if (newElem !== ogElemScroller) {\n                ogElemScroller = newElem;\n                clearAutoScrolls();\n              }\n\n              autoScroll(evt, this.options, newElem, fallback);\n            }, 10);\n            lastAutoScrollX = x;\n            lastAutoScrollY = y;\n          }\n        } else {\n          // if DnD is enabled (and browser has good autoscrolling), first autoscroll will already scroll, so get parent autoscroll of first autoscroll\n          if (!this.options.bubbleScroll || getParentAutoScrollElement(elem, true) === getWindowScrollingElement()) {\n            clearAutoScrolls();\n            return;\n          }\n\n          autoScroll(evt, this.options, getParentAutoScrollElement(elem, false), false);\n        }\n      }\n\n    };\n    return Object.assign(AutoScroll, {\n      pluginName: \"scroll\",\n      initializeByDefault: true\n    });\n  }\n\n  function clearAutoScrolls() {\n    autoScrolls.forEach(function (autoScroll) {\n      clearInterval(autoScroll.pid);\n    });\n    autoScrolls = [];\n  }\n\n  function clearPointerElemChangedInterval() {\n    clearInterval(pointerElemChangedInterval);\n  }\n\n  const autoScroll = throttle(function (evt, options, rootEl, isFallback) {\n    // Bug: https://bugzilla.mozilla.org/show_bug.cgi?id=505521\n    if (!options.scroll) return;\n    const x = (evt.touches ? evt.touches[0] : evt).clientX,\n          y = (evt.touches ? evt.touches[0] : evt).clientY,\n          sens = options.scrollSensitivity,\n          speed = options.scrollSpeed,\n          winScroller = getWindowScrollingElement();\n    let scrollThisInstance = false,\n        scrollCustomFn; // New scroll root, set scrollEl\n\n    if (scrollRootEl !== rootEl) {\n      scrollRootEl = rootEl;\n      clearAutoScrolls();\n      scrollEl = options.scroll;\n      scrollCustomFn = options.scrollFn;\n\n      if (scrollEl === true) {\n        scrollEl = getParentAutoScrollElement(rootEl, true);\n      }\n    }\n\n    let layersOut = 0;\n    let currentParent = scrollEl;\n\n    do {\n      let el = currentParent,\n          rect = getRect(el),\n          top = rect.top,\n          bottom = rect.bottom,\n          left = rect.left,\n          right = rect.right,\n          width = rect.width,\n          height = rect.height,\n          canScrollX,\n          canScrollY,\n          scrollWidth = el.scrollWidth,\n          scrollHeight = el.scrollHeight,\n          elCSS = css(el),\n          scrollPosX = el.scrollLeft,\n          scrollPosY = el.scrollTop;\n\n      if (el === winScroller) {\n        canScrollX = width < scrollWidth && (elCSS.overflowX === \"auto\" || elCSS.overflowX === \"scroll\" || elCSS.overflowX === \"visible\");\n        canScrollY = height < scrollHeight && (elCSS.overflowY === \"auto\" || elCSS.overflowY === \"scroll\" || elCSS.overflowY === \"visible\");\n      } else {\n        canScrollX = width < scrollWidth && (elCSS.overflowX === \"auto\" || elCSS.overflowX === \"scroll\");\n        canScrollY = height < scrollHeight && (elCSS.overflowY === \"auto\" || elCSS.overflowY === \"scroll\");\n      }\n\n      let vx = canScrollX && (Math.abs(right - x) <= sens && scrollPosX + width < scrollWidth) - (Math.abs(left - x) <= sens && !!scrollPosX);\n      let vy = canScrollY && (Math.abs(bottom - y) <= sens && scrollPosY + height < scrollHeight) - (Math.abs(top - y) <= sens && !!scrollPosY);\n\n      if (!autoScrolls[layersOut]) {\n        for (let i = 0; i <= layersOut; i++) {\n          if (!autoScrolls[i]) {\n            autoScrolls[i] = {};\n          }\n        }\n      }\n\n      if (autoScrolls[layersOut].vx != vx || autoScrolls[layersOut].vy != vy || autoScrolls[layersOut].el !== el) {\n        autoScrolls[layersOut].el = el;\n        autoScrolls[layersOut].vx = vx;\n        autoScrolls[layersOut].vy = vy;\n        clearInterval(autoScrolls[layersOut].pid);\n\n        if (vx != 0 || vy != 0) {\n          scrollThisInstance = true;\n          /* jshint loopfunc:true */\n\n          autoScrolls[layersOut].pid = setInterval(function () {\n            // emulate drag over during autoscroll (fallback), emulating native DnD behaviour\n            if (isFallback && this.layer === 0) {\n              Sortable.active._onTouchMove(touchEvt$1); // To move ghost if it is positioned absolutely\n\n            }\n\n            let scrollOffsetY = autoScrolls[this.layer].vy ? autoScrolls[this.layer].vy * speed : 0;\n            let scrollOffsetX = autoScrolls[this.layer].vx ? autoScrolls[this.layer].vx * speed : 0;\n\n            if (typeof scrollCustomFn === \"function\") {\n              if (scrollCustomFn.call(Sortable.dragged.parentNode[expando], scrollOffsetX, scrollOffsetY, evt, touchEvt$1, autoScrolls[this.layer].el) !== \"continue\") {\n                return;\n              }\n            }\n\n            scrollBy(autoScrolls[this.layer].el, scrollOffsetX, scrollOffsetY);\n          }.bind({\n            layer: layersOut\n          }), 24);\n        }\n      }\n\n      layersOut++;\n    } while (options.bubbleScroll && currentParent !== winScroller && (currentParent = getParentAutoScrollElement(currentParent, false)));\n\n    scrolling = scrollThisInstance; // in case another function catches scrolling as false in between when it is not\n  }, 30);\n\n  const drop = function (_ref5) {\n    let {\n      originalEvent,\n      putSortable,\n      dragEl,\n      activeSortable,\n      dispatchSortableEvent,\n      hideGhostForTarget,\n      unhideGhostForTarget\n    } = _ref5;\n    if (!originalEvent) return;\n    let toSortable = putSortable || activeSortable;\n    hideGhostForTarget();\n    let touch = originalEvent.changedTouches && originalEvent.changedTouches.length ? originalEvent.changedTouches[0] : originalEvent;\n    let target = document.elementFromPoint(touch.clientX, touch.clientY);\n    unhideGhostForTarget();\n\n    if (toSortable && !toSortable.el.contains(target)) {\n      dispatchSortableEvent(\"spill\");\n      this.onSpill({\n        dragEl,\n        putSortable\n      });\n    }\n  };\n\n  function Revert() {}\n\n  Revert.prototype = {\n    startIndex: null,\n\n    dragStart(_ref6) {\n      let {\n        oldDraggableIndex\n      } = _ref6;\n      this.startIndex = oldDraggableIndex;\n    },\n\n    onSpill(_ref7) {\n      let {\n        dragEl,\n        putSortable\n      } = _ref7;\n      this.sortable.captureAnimationState();\n\n      if (putSortable) {\n        putSortable.captureAnimationState();\n      }\n\n      let nextSibling = getChild(this.sortable.el, this.startIndex, this.options);\n\n      if (nextSibling) {\n        this.sortable.el.insertBefore(dragEl, nextSibling);\n      } else {\n        this.sortable.el.appendChild(dragEl);\n      }\n\n      this.sortable.animateAll();\n\n      if (putSortable) {\n        putSortable.animateAll();\n      }\n    },\n\n    drop\n  };\n  Object.assign(Revert, {\n    pluginName: \"revertOnSpill\"\n  });\n\n  function Remove() {}\n\n  Remove.prototype = {\n    onSpill(_ref8) {\n      let {\n        dragEl,\n        putSortable\n      } = _ref8;\n      const parentSortable = putSortable || this.sortable;\n      parentSortable.captureAnimationState();\n      dragEl.parentNode && dragEl.parentNode.removeChild(dragEl);\n      parentSortable.animateAll();\n    },\n\n    drop\n  };\n  Object.assign(Remove, {\n    pluginName: \"removeOnSpill\"\n  });\n  let lastSwapEl;\n\n  function SwapPlugin() {\n    function Swap() {\n      this.defaults = {\n        swapClass: \"sortable-swap-highlight\"\n      };\n    }\n\n    Swap.prototype = {\n      dragStart(_ref9) {\n        let {\n          dragEl\n        } = _ref9;\n        lastSwapEl = dragEl;\n      },\n\n      dragOverValid(_ref10) {\n        let {\n          completed,\n          target,\n          onMove,\n          activeSortable,\n          changed,\n          cancel\n        } = _ref10;\n        if (!activeSortable.options.swap) return;\n        let el = this.sortable.el,\n            options = this.options;\n\n        if (target && target !== el) {\n          let prevSwapEl = lastSwapEl;\n\n          if (onMove(target) !== false) {\n            toggleClass(target, options.swapClass, true);\n            lastSwapEl = target;\n          } else {\n            lastSwapEl = null;\n          }\n\n          if (prevSwapEl && prevSwapEl !== lastSwapEl) {\n            toggleClass(prevSwapEl, options.swapClass, false);\n          }\n        }\n\n        changed();\n        completed(true);\n        cancel();\n      },\n\n      drop(_ref11) {\n        let {\n          activeSortable,\n          putSortable,\n          dragEl\n        } = _ref11;\n        let toSortable = putSortable || this.sortable;\n        let options = this.options;\n        lastSwapEl && toggleClass(lastSwapEl, options.swapClass, false);\n\n        if (lastSwapEl && (options.swap || putSortable && putSortable.options.swap)) {\n          if (dragEl !== lastSwapEl) {\n            toSortable.captureAnimationState();\n            if (toSortable !== activeSortable) activeSortable.captureAnimationState();\n            swapNodes(dragEl, lastSwapEl);\n            toSortable.animateAll();\n            if (toSortable !== activeSortable) activeSortable.animateAll();\n          }\n        }\n      },\n\n      nulling() {\n        lastSwapEl = null;\n      }\n\n    };\n    return Object.assign(Swap, {\n      pluginName: \"swap\",\n\n      eventProperties() {\n        return {\n          swapItem: lastSwapEl\n        };\n      }\n\n    });\n  }\n\n  function swapNodes(n1, n2) {\n    let p1 = n1.parentNode,\n        p2 = n2.parentNode,\n        i1,\n        i2;\n    if (!p1 || !p2 || p1.isEqualNode(n2) || p2.isEqualNode(n1)) return;\n    i1 = index(n1);\n    i2 = index(n2);\n\n    if (p1.isEqualNode(p2) && i1 < i2) {\n      i2++;\n    }\n\n    p1.insertBefore(n2, p1.children[i1]);\n    p2.insertBefore(n1, p2.children[i2]);\n  }\n\n  let multiDragElements = [],\n      multiDragClones = [],\n      lastMultiDragSelect,\n      // for selection with modifier key down (SHIFT)\n  multiDragSortable,\n      initialFolding = false,\n      // Initial multi-drag fold when drag started\n  folding = false,\n      // Folding any other time\n  dragStarted = false,\n      dragEl$1,\n      clonesFromRect,\n      clonesHidden;\n\n  function MultiDragPlugin() {\n    function MultiDrag(sortable) {\n      // Bind all private methods\n      for (let fn in this) {\n        if (fn.charAt(0) === \"_\" && typeof this[fn] === \"function\") {\n          this[fn] = this[fn].bind(this);\n        }\n      }\n\n      if (sortable.options.supportPointer) {\n        on(document, \"pointerup\", this._deselectMultiDrag);\n      } else {\n        on(document, \"mouseup\", this._deselectMultiDrag);\n        on(document, \"touchend\", this._deselectMultiDrag);\n      }\n\n      on(document, \"keydown\", this._checkKeyDown);\n      on(document, \"keyup\", this._checkKeyUp);\n      this.defaults = {\n        selectedClass: \"sortable-selected\",\n        multiDragKey: null,\n\n        setData(dataTransfer, dragEl) {\n          let data = \"\";\n\n          if (multiDragElements.length && multiDragSortable === sortable) {\n            multiDragElements.forEach((multiDragElement, i) => {\n              data += (!i ? \"\" : \", \") + multiDragElement.textContent;\n            });\n          } else {\n            data = dragEl.textContent;\n          }\n\n          dataTransfer.setData(\"Text\", data);\n        }\n\n      };\n    }\n\n    MultiDrag.prototype = {\n      multiDragKeyDown: false,\n      isMultiDrag: false,\n\n      delayStartGlobal(_ref12) {\n        let {\n          dragEl: dragged\n        } = _ref12;\n        dragEl$1 = dragged;\n      },\n\n      delayEnded() {\n        this.isMultiDrag = ~multiDragElements.indexOf(dragEl$1);\n      },\n\n      setupClone(_ref13) {\n        let {\n          sortable,\n          cancel\n        } = _ref13;\n        if (!this.isMultiDrag) return;\n\n        for (let i = 0; i < multiDragElements.length; i++) {\n          multiDragClones.push(clone(multiDragElements[i]));\n          multiDragClones[i].sortableIndex = multiDragElements[i].sortableIndex;\n          multiDragClones[i].draggable = false;\n          multiDragClones[i].style[\"will-change\"] = \"\";\n          toggleClass(multiDragClones[i], this.options.selectedClass, false);\n          multiDragElements[i] === dragEl$1 && toggleClass(multiDragClones[i], this.options.chosenClass, false);\n        }\n\n        sortable._hideClone();\n\n        cancel();\n      },\n\n      clone(_ref14) {\n        let {\n          sortable,\n          rootEl,\n          dispatchSortableEvent,\n          cancel\n        } = _ref14;\n        if (!this.isMultiDrag) return;\n\n        if (!this.options.removeCloneOnHide) {\n          if (multiDragElements.length && multiDragSortable === sortable) {\n            insertMultiDragClones(true, rootEl);\n            dispatchSortableEvent(\"clone\");\n            cancel();\n          }\n        }\n      },\n\n      showClone(_ref15) {\n        let {\n          cloneNowShown,\n          rootEl,\n          cancel\n        } = _ref15;\n        if (!this.isMultiDrag) return;\n        insertMultiDragClones(false, rootEl);\n        multiDragClones.forEach(clone => {\n          css(clone, \"display\", \"\");\n        });\n        cloneNowShown();\n        clonesHidden = false;\n        cancel();\n      },\n\n      hideClone(_ref16) {\n        let {\n          sortable,\n          cloneNowHidden,\n          cancel\n        } = _ref16;\n        if (!this.isMultiDrag) return;\n        multiDragClones.forEach(clone => {\n          css(clone, \"display\", \"none\");\n\n          if (this.options.removeCloneOnHide && clone.parentNode) {\n            clone.parentNode.removeChild(clone);\n          }\n        });\n        cloneNowHidden();\n        clonesHidden = true;\n        cancel();\n      },\n\n      dragStartGlobal(_ref17) {\n        let {\n          sortable\n        } = _ref17;\n\n        if (!this.isMultiDrag && multiDragSortable) {\n          multiDragSortable.multiDrag._deselectMultiDrag();\n        }\n\n        multiDragElements.forEach(multiDragElement => {\n          multiDragElement.sortableIndex = index(multiDragElement);\n        }); // Sort multi-drag elements\n\n        multiDragElements = multiDragElements.sort(function (a, b) {\n          return a.sortableIndex - b.sortableIndex;\n        });\n        dragStarted = true;\n      },\n\n      dragStarted(_ref18) {\n        let {\n          sortable\n        } = _ref18;\n        if (!this.isMultiDrag) return;\n\n        if (this.options.sort) {\n          // Capture rects,\n          // hide multi drag elements (by positioning them absolute),\n          // set multi drag elements rects to dragRect,\n          // show multi drag elements,\n          // animate to rects,\n          // unset rects & remove from DOM\n          sortable.captureAnimationState();\n\n          if (this.options.animation) {\n            multiDragElements.forEach(multiDragElement => {\n              if (multiDragElement === dragEl$1) return;\n              css(multiDragElement, \"position\", \"absolute\");\n            });\n            let dragRect = getRect(dragEl$1, false, true, true);\n            multiDragElements.forEach(multiDragElement => {\n              if (multiDragElement === dragEl$1) return;\n              setRect(multiDragElement, dragRect);\n            });\n            folding = true;\n            initialFolding = true;\n          }\n        }\n\n        sortable.animateAll(() => {\n          folding = false;\n          initialFolding = false;\n\n          if (this.options.animation) {\n            multiDragElements.forEach(multiDragElement => {\n              unsetRect(multiDragElement);\n            });\n          } // Remove all auxiliary multidrag items from el, if sorting enabled\n\n\n          if (this.options.sort) {\n            removeMultiDragElements();\n          }\n        });\n      },\n\n      dragOver(_ref19) {\n        let {\n          target,\n          completed,\n          cancel\n        } = _ref19;\n\n        if (folding && ~multiDragElements.indexOf(target)) {\n          completed(false);\n          cancel();\n        }\n      },\n\n      revert(_ref20) {\n        let {\n          fromSortable,\n          rootEl,\n          sortable,\n          dragRect\n        } = _ref20;\n\n        if (multiDragElements.length > 1) {\n          // Setup unfold animation\n          multiDragElements.forEach(multiDragElement => {\n            sortable.addAnimationState({\n              target: multiDragElement,\n              rect: folding ? getRect(multiDragElement) : dragRect\n            });\n            unsetRect(multiDragElement);\n            multiDragElement.fromRect = dragRect;\n            fromSortable.removeAnimationState(multiDragElement);\n          });\n          folding = false;\n          insertMultiDragElements(!this.options.removeCloneOnHide, rootEl);\n        }\n      },\n\n      dragOverCompleted(_ref21) {\n        let {\n          sortable,\n          isOwner,\n          insertion,\n          activeSortable,\n          parentEl,\n          putSortable\n        } = _ref21;\n        let options = this.options;\n\n        if (insertion) {\n          // Clones must be hidden before folding animation to capture dragRectAbsolute properly\n          if (isOwner) {\n            activeSortable._hideClone();\n          }\n\n          initialFolding = false; // If leaving sort:false root, or already folding - Fold to new location\n\n          if (options.animation && multiDragElements.length > 1 && (folding || !isOwner && !activeSortable.options.sort && !putSortable)) {\n            // Fold: Set all multi drag elements's rects to dragEl's rect when multi-drag elements are invisible\n            let dragRectAbsolute = getRect(dragEl$1, false, true, true);\n            multiDragElements.forEach(multiDragElement => {\n              if (multiDragElement === dragEl$1) return;\n              setRect(multiDragElement, dragRectAbsolute); // Move element(s) to end of parentEl so that it does not interfere with multi-drag clones insertion if they are inserted\n              // while folding, and so that we can capture them again because old sortable will no longer be fromSortable\n\n              parentEl.appendChild(multiDragElement);\n            });\n            folding = true;\n          } // Clones must be shown (and check to remove multi drags) after folding when interfering multiDragElements are moved out\n\n\n          if (!isOwner) {\n            // Only remove if not folding (folding will remove them anyways)\n            if (!folding) {\n              removeMultiDragElements();\n            }\n\n            if (multiDragElements.length > 1) {\n              let clonesHiddenBefore = clonesHidden;\n\n              activeSortable._showClone(sortable); // Unfold animation for clones if showing from hidden\n\n\n              if (activeSortable.options.animation && !clonesHidden && clonesHiddenBefore) {\n                multiDragClones.forEach(clone => {\n                  activeSortable.addAnimationState({\n                    target: clone,\n                    rect: clonesFromRect\n                  });\n                  clone.fromRect = clonesFromRect;\n                  clone.thisAnimationDuration = null;\n                });\n              }\n            } else {\n              activeSortable._showClone(sortable);\n            }\n          }\n        }\n      },\n\n      dragOverAnimationCapture(_ref22) {\n        let {\n          dragRect,\n          isOwner,\n          activeSortable\n        } = _ref22;\n        multiDragElements.forEach(multiDragElement => {\n          multiDragElement.thisAnimationDuration = null;\n        });\n\n        if (activeSortable.options.animation && !isOwner && activeSortable.multiDrag.isMultiDrag) {\n          clonesFromRect = Object.assign({}, dragRect);\n          let dragMatrix = matrix(dragEl$1, true);\n          clonesFromRect.top -= dragMatrix.f;\n          clonesFromRect.left -= dragMatrix.e;\n        }\n      },\n\n      dragOverAnimationComplete() {\n        if (folding) {\n          folding = false;\n          removeMultiDragElements();\n        }\n      },\n\n      drop(_ref23) {\n        let {\n          originalEvent: evt,\n          rootEl,\n          parentEl,\n          sortable,\n          dispatchSortableEvent,\n          oldIndex,\n          putSortable\n        } = _ref23;\n        let toSortable = putSortable || this.sortable;\n        if (!evt) return;\n        let options = this.options,\n            children = parentEl.children; // Multi-drag selection\n\n        if (!dragStarted) {\n          if (options.multiDragKey && !this.multiDragKeyDown) {\n            this._deselectMultiDrag();\n          }\n\n          toggleClass(dragEl$1, options.selectedClass, !~multiDragElements.indexOf(dragEl$1));\n\n          if (!~multiDragElements.indexOf(dragEl$1)) {\n            multiDragElements.push(dragEl$1);\n            dispatchEvent({\n              sortable,\n              rootEl,\n              name: \"select\",\n              targetEl: dragEl$1,\n              originalEvt: evt\n            }); // Modifier activated, select from last to dragEl\n\n            if (evt.shiftKey && lastMultiDragSelect && sortable.el.contains(lastMultiDragSelect)) {\n              let lastIndex = index(lastMultiDragSelect),\n                  currentIndex = index(dragEl$1);\n\n              if (~lastIndex && ~currentIndex && lastIndex !== currentIndex) {\n                // Must include lastMultiDragSelect (select it), in case modified selection from no selection\n                // (but previous selection existed)\n                let n, i;\n\n                if (currentIndex > lastIndex) {\n                  i = lastIndex;\n                  n = currentIndex;\n                } else {\n                  i = currentIndex;\n                  n = lastIndex + 1;\n                }\n\n                for (; i < n; i++) {\n                  if (~multiDragElements.indexOf(children[i])) continue;\n                  toggleClass(children[i], options.selectedClass, true);\n                  multiDragElements.push(children[i]);\n                  dispatchEvent({\n                    sortable,\n                    rootEl,\n                    name: \"select\",\n                    targetEl: children[i],\n                    originalEvt: evt\n                  });\n                }\n              }\n            } else {\n              lastMultiDragSelect = dragEl$1;\n            }\n\n            multiDragSortable = toSortable;\n          } else {\n            multiDragElements.splice(multiDragElements.indexOf(dragEl$1), 1);\n            lastMultiDragSelect = null;\n            dispatchEvent({\n              sortable,\n              rootEl,\n              name: \"deselect\",\n              targetEl: dragEl$1,\n              originalEvt: evt\n            });\n          }\n        } // Multi-drag drop\n\n\n        if (dragStarted && this.isMultiDrag) {\n          // Do not \"unfold\" after around dragEl if reverted\n          if ((parentEl[expando].options.sort || parentEl !== rootEl) && multiDragElements.length > 1) {\n            let dragRect = getRect(dragEl$1),\n                multiDragIndex = index(dragEl$1, \":not(.\" + this.options.selectedClass + \")\");\n            if (!initialFolding && options.animation) dragEl$1.thisAnimationDuration = null;\n            toSortable.captureAnimationState();\n\n            if (!initialFolding) {\n              if (options.animation) {\n                dragEl$1.fromRect = dragRect;\n                multiDragElements.forEach(multiDragElement => {\n                  multiDragElement.thisAnimationDuration = null;\n\n                  if (multiDragElement !== dragEl$1) {\n                    let rect = folding ? getRect(multiDragElement) : dragRect;\n                    multiDragElement.fromRect = rect; // Prepare unfold animation\n\n                    toSortable.addAnimationState({\n                      target: multiDragElement,\n                      rect: rect\n                    });\n                  }\n                });\n              } // Multi drag elements are not necessarily removed from the DOM on drop, so to reinsert\n              // properly they must all be removed\n\n\n              removeMultiDragElements();\n              multiDragElements.forEach(multiDragElement => {\n                if (children[multiDragIndex]) {\n                  parentEl.insertBefore(multiDragElement, children[multiDragIndex]);\n                } else {\n                  parentEl.appendChild(multiDragElement);\n                }\n\n                multiDragIndex++;\n              }); // If initial folding is done, the elements may have changed position because they are now\n              // unfolding around dragEl, even though dragEl may not have his index changed, so update event\n              // must be fired here as Sortable will not.\n\n              if (oldIndex === index(dragEl$1)) {\n                let update = false;\n                multiDragElements.forEach(multiDragElement => {\n                  if (multiDragElement.sortableIndex !== index(multiDragElement)) {\n                    update = true;\n                    return;\n                  }\n                });\n\n                if (update) {\n                  dispatchSortableEvent(\"update\");\n                }\n              }\n            } // Must be done after capturing individual rects (scroll bar)\n\n\n            multiDragElements.forEach(multiDragElement => {\n              unsetRect(multiDragElement);\n            });\n            toSortable.animateAll();\n          }\n\n          multiDragSortable = toSortable;\n        } // Remove clones if necessary\n\n\n        if (rootEl === parentEl || putSortable && putSortable.lastPutMode !== \"clone\") {\n          multiDragClones.forEach(clone => {\n            clone.parentNode && clone.parentNode.removeChild(clone);\n          });\n        }\n      },\n\n      nullingGlobal() {\n        this.isMultiDrag = dragStarted = false;\n        multiDragClones.length = 0;\n      },\n\n      destroyGlobal() {\n        this._deselectMultiDrag();\n\n        off(document, \"pointerup\", this._deselectMultiDrag);\n        off(document, \"mouseup\", this._deselectMultiDrag);\n        off(document, \"touchend\", this._deselectMultiDrag);\n        off(document, \"keydown\", this._checkKeyDown);\n        off(document, \"keyup\", this._checkKeyUp);\n      },\n\n      _deselectMultiDrag(evt) {\n        if (typeof dragStarted !== \"undefined\" && dragStarted) return; // Only deselect if selection is in this sortable\n\n        if (multiDragSortable !== this.sortable) return; // Only deselect if target is not item in this sortable\n\n        if (evt && closest(evt.target, this.options.draggable, this.sortable.el, false)) return; // Only deselect if left click\n\n        if (evt && evt.button !== 0) return;\n\n        while (multiDragElements.length) {\n          let el = multiDragElements[0];\n          toggleClass(el, this.options.selectedClass, false);\n          multiDragElements.shift();\n          dispatchEvent({\n            sortable: this.sortable,\n            rootEl: this.sortable.el,\n            name: \"deselect\",\n            targetEl: el,\n            originalEvt: evt\n          });\n        }\n      },\n\n      _checkKeyDown(evt) {\n        if (evt.key === this.options.multiDragKey) {\n          this.multiDragKeyDown = true;\n        }\n      },\n\n      _checkKeyUp(evt) {\n        if (evt.key === this.options.multiDragKey) {\n          this.multiDragKeyDown = false;\n        }\n      }\n\n    };\n    return Object.assign(MultiDrag, {\n      // Static methods & properties\n      pluginName: \"multiDrag\",\n      utils: {\n        /**\n         * Selects the provided multi-drag item\n         * @param  {HTMLElement} el    The element to be selected\n         */\n        select(el) {\n          let sortable = el.parentNode[expando];\n          if (!sortable || !sortable.options.multiDrag || ~multiDragElements.indexOf(el)) return;\n\n          if (multiDragSortable && multiDragSortable !== sortable) {\n            multiDragSortable.multiDrag._deselectMultiDrag();\n\n            multiDragSortable = sortable;\n          }\n\n          toggleClass(el, sortable.options.selectedClass, true);\n          multiDragElements.push(el);\n        },\n\n        /**\n         * Deselects the provided multi-drag item\n         * @param  {HTMLElement} el    The element to be deselected\n         */\n        deselect(el) {\n          let sortable = el.parentNode[expando],\n              index = multiDragElements.indexOf(el);\n          if (!sortable || !sortable.options.multiDrag || !~index) return;\n          toggleClass(el, sortable.options.selectedClass, false);\n          multiDragElements.splice(index, 1);\n        }\n\n      },\n\n      eventProperties() {\n        const oldIndicies = [],\n              newIndicies = [];\n        multiDragElements.forEach(multiDragElement => {\n          oldIndicies.push({\n            multiDragElement,\n            index: multiDragElement.sortableIndex\n          }); // multiDragElements will already be sorted if folding\n\n          let newIndex;\n\n          if (folding && multiDragElement !== dragEl$1) {\n            newIndex = -1;\n          } else if (folding) {\n            newIndex = index(multiDragElement, \":not(.\" + this.options.selectedClass + \")\");\n          } else {\n            newIndex = index(multiDragElement);\n          }\n\n          newIndicies.push({\n            multiDragElement,\n            index: newIndex\n          });\n        });\n        return {\n          items: [...multiDragElements],\n          clones: [...multiDragClones],\n          oldIndicies,\n          newIndicies\n        };\n      },\n\n      optionListeners: {\n        multiDragKey(key) {\n          key = key.toLowerCase();\n\n          if (key === \"ctrl\") {\n            key = \"Control\";\n          } else if (key.length > 1) {\n            key = key.charAt(0).toUpperCase() + key.substr(1);\n          }\n\n          return key;\n        }\n\n      }\n    });\n  }\n\n  function insertMultiDragElements(clonesInserted, rootEl) {\n    multiDragElements.forEach((multiDragElement, i) => {\n      let target = rootEl.children[multiDragElement.sortableIndex + (clonesInserted ? Number(i) : 0)];\n\n      if (target) {\n        rootEl.insertBefore(multiDragElement, target);\n      } else {\n        rootEl.appendChild(multiDragElement);\n      }\n    });\n  }\n  /**\n   * Insert multi-drag clones\n   * @param  {[Boolean]} elementsInserted  Whether the multi-drag elements are inserted\n   * @param  {HTMLElement} rootEl\n   */\n\n\n  function insertMultiDragClones(elementsInserted, rootEl) {\n    multiDragClones.forEach((clone, i) => {\n      let target = rootEl.children[clone.sortableIndex + (elementsInserted ? Number(i) : 0)];\n\n      if (target) {\n        rootEl.insertBefore(clone, target);\n      } else {\n        rootEl.appendChild(clone);\n      }\n    });\n  }\n\n  function removeMultiDragElements() {\n    multiDragElements.forEach(multiDragElement => {\n      if (multiDragElement === dragEl$1) return;\n      multiDragElement.parentNode && multiDragElement.parentNode.removeChild(multiDragElement);\n    });\n  }\n\n  Sortable.mount(new AutoScrollPlugin());\n  Sortable.mount(Remove, Revert);\n  Sortable.mount(new SwapPlugin());\n  Sortable.mount(new MultiDragPlugin());\n  return Sortable;\n});"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///4617\n')},3654:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("// ESM COMPAT FLAG\n__webpack_require__.r(__webpack_exports__);\n\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n \"DeviceManagerProvider\": () => (/* reexport */ useDeviceManager/* DeviceManagerProvider */.jd),\n \"ImageUploader\": () => (/* reexport */ ct_image_uploader[\"default\"]),\n \"OptionsPanel\": () => (/* reexport */ OptionsPanel/* default */.Z),\n \"OutsideClickHandler\": () => (/* reexport */ react_outside_click_handler[\"default\"]),\n \"Overlay\": () => (/* reexport */ Overlay/* default */.Z),\n \"Panel\": () => (/* reexport */ ct_panel[\"default\"]),\n \"PanelLevel\": () => (/* reexport */ PanelLevel/* default */.Z),\n \"PanelMetaWrapper\": () => (/* reexport */ ct_panel.PanelMetaWrapper),\n \"Select\": () => (/* reexport */ ct_select[\"default\"]),\n \"Switch\": () => (/* reexport */ ct_switch[\"default\"]),\n \"Transition\": () => (/* reexport */ renderprops/* Transition */.uT),\n \"animated\": () => (/* reexport */ renderprops/* animated */.q),\n \"bezierEasing\": () => (/* reexport */ (src_default())),\n \"getValueFromInput\": () => (/* reexport */ get_value_from_input/* getValueFromInput */.n6),\n \"onDocumentLoaded\": () => (/* binding */ onDocumentLoaded),\n \"usePopoverMaker\": () => (/* reexport */ usePopoverMaker/* default */.Z)\n});\n\n// EXTERNAL MODULE: ./static/js/public-path.js\nvar public_path = __webpack_require__(8683);\n// EXTERNAL MODULE: external \"jQuery\"\nvar external_jQuery_ = __webpack_require__(5311);\nvar external_jQuery_default = /*#__PURE__*/__webpack_require__.n(external_jQuery_);\n// EXTERNAL MODULE: external \"window.wp.element\"\nvar external_window_wp_element_ = __webpack_require__(1381);\n// EXTERNAL MODULE: ./static/js/options/OptionsPanel.js + 7 modules\nvar OptionsPanel = __webpack_require__(7429);\n// EXTERNAL MODULE: external \"ctEvents\"\nvar external_ctEvents_ = __webpack_require__(2243);\nvar external_ctEvents_default = /*#__PURE__*/__webpack_require__.n(external_ctEvents_);\n;// CONCATENATED MODULE: ./static/js/options/OptionsRoot.js\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\nconst INITIAL_VALUE = '__INITIAL__';\n\nconst OptionsRoot = _ref => {\n let {\n value,\n options,\n input_name,\n input_id,\n hasRevertButton\n } = _ref;\n const [internalValue, setInternalValue] = (0,external_window_wp_element_.useState)(value);\n const input = (0,external_window_wp_element_.useRef)();\n const handleChange = (0,external_window_wp_element_.useCallback)(_ref2 => {\n let {\n id,\n value,\n input: inputRef\n } = _ref2;\n\n if (inputRef === input.current) {\n setInternalValue(internalValue => _objectSpread(_objectSpread({}, internalValue), {}, {\n [id]: value\n }));\n }\n }, []);\n (0,external_window_wp_element_.useEffect)(() => {\n external_ctEvents_default().on('ct:options:trigger-change', handleChange);\n return () => {\n external_ctEvents_default().off('ct:options:trigger-change', handleChange);\n };\n }, []);\n return (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-options-root\"\n }, (0,external_window_wp_element_.createElement)(\"input\", {\n value: JSON.stringify(Array.isArray(internalValue) ? {} : internalValue),\n onChange: () => {},\n name: input_name,\n id: input_id,\n type: \"hidden\",\n ref: input\n }), (0,external_window_wp_element_.createElement)(OptionsPanel/* default */.Z, {\n hasRevertButton: hasRevertButton,\n onChange: (key, newValue) => {\n setInternalValue(internalValue => _objectSpread(_objectSpread({}, internalValue), {}, {\n [key]: newValue\n }));\n external_jQuery_default()(input.current).change();\n },\n value: internalValue,\n options: options\n }));\n};\n\n/* harmony default export */ const options_OptionsRoot = (OptionsRoot);\n// EXTERNAL MODULE: ./static/js/options/helpers/get-value-from-input.js\nvar get_value_from_input = __webpack_require__(7069);\n;// CONCATENATED MODULE: ./static/js/options/initPanels.js\n\n\n\n\nconst initAllPanels = () => [...document.querySelectorAll('.ct-options-panel')].map(singleTarget => {\n if (singleTarget.closest('[id=\"available-widgets\"]')) {\n return;\n }\n\n if (singleTarget.ctHasOptions) return;\n singleTarget.ctHasOptions = true;\n external_jQuery_default()(singleTarget).on('remove', () => setTimeout(() => initAllPanels()));\n external_jQuery_default()(singleTarget).on('remove', () => () => initAllPanels());\n (0,external_window_wp_element_.render)((0,external_window_wp_element_.createElement)(options_OptionsRoot, {\n options: JSON.parse(singleTarget.firstElementChild.dataset.ctOptions),\n value: (0,get_value_from_input/* getValueFromInput */.n6)(JSON.parse(singleTarget.firstElementChild.dataset.ctOptions), JSON.parse(singleTarget.firstElementChild.value), null, false),\n input_id: singleTarget.firstElementChild.id,\n input_name: singleTarget.firstElementChild.name,\n hasRevertButton: Object.keys(singleTarget.dataset).indexOf('disableReverseButton') === -1\n }), singleTarget);\n});\n;// CONCATENATED MODULE: ./static/js/backend/widgets.js\n\nconst initWidget = widget => {\n if (widget.querySelector('.ct-options-panel') && widget.querySelector('.ct-options-panel').innerHTML.indexOf('__i__') > -1) {\n const panel = widget.querySelector('.ct-options-panel');\n const widgetNumber = widget.querySelector('input.multi_number').value;\n panel.innerHTML = panel.innerHTML.replace(/__i__|%i%/g, widgetNumber);\n }\n\n initAllPanels();\n};\n// EXTERNAL MODULE: external \"window.wp.i18n\"\nvar external_window_wp_i18n_ = __webpack_require__(5652);\n;// CONCATENATED MODULE: ./static/js/backend/woo-variation.js\n\n\n\n\n\nconst initWooVariation = variationWrapper => {\n const uploadImage = variationWrapper.querySelector('.upload_image');\n\n if (!uploadImage) {\n return;\n }\n\n const div = document.createElement('p');\n div.classList.add('form-row');\n div.classList.add('form-row-full');\n div.classList.add('ct-variation-image-gallery');\n uploadImage.nextElementSibling.insertAdjacentElement('afterend', div);\n const input = variationWrapper.querySelector('[name*=\"blocksy_post_meta_options\"]');\n\n if (!input) {\n return;\n }\n\n const options = {\n gallery_source: {\n label: (0,external_window_wp_i18n_.__)('Variation Gallery Source', 'blocksy'),\n type: 'ct-radio',\n value: 'default',\n design: 'inline',\n divider: 'bottom',\n choices: {\n default: (0,external_window_wp_i18n_.__)('Default', 'blocksy'),\n custom: (0,external_window_wp_i18n_.__)('Custom', 'blocksy')\n }\n },\n condition: {\n type: 'ct-condition',\n condition: {\n gallery_source: 'custom'\n },\n options: {\n images: {\n label: (0,external_window_wp_i18n_.__)('Variation Image Gallery', 'blocksy'),\n type: 'ct-multi-image-uploader',\n design: _ref => {\n let {\n value\n } = _ref;\n return value.length === 0 ? 'inline' : 'block';\n },\n value: []\n }\n }\n }\n };\n (0,external_window_wp_element_.render)((0,external_window_wp_element_.createElement)(options_OptionsRoot, {\n options: options,\n value: (0,get_value_from_input/* getValueFromInput */.n6)(options, JSON.parse(input.value), null, false),\n input_id: input.id,\n input_name: input.name,\n hasRevertButton: false\n }), div);\n};\nconst initAllWooVariations = () => {\n ;\n [...document.querySelectorAll('.woocommerce_variations .woocommerce_variation')].map(variationWrapper => {\n if (variationWrapper.hasBlocksyOptions) {\n return;\n }\n\n variationWrapper.hasBlocksyOptions = true;\n initWooVariation(variationWrapper);\n });\n};\n// EXTERNAL MODULE: ./node_modules/deep-equal/index.js\nvar deep_equal = __webpack_require__(251);\nvar deep_equal_default = /*#__PURE__*/__webpack_require__.n(deep_equal);\n;// CONCATENATED MODULE: ./static/js/backend/taxonomies.js\nfunction taxonomies_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction taxonomies_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? taxonomies_ownKeys(Object(source), !0).forEach(function (key) { taxonomies_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : taxonomies_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction taxonomies_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\n\nconst TaxonomyRoot = _ref => {\n let {\n options,\n input_name,\n value\n } = _ref;\n const [internalValue, setInternalValue] = (0,external_window_wp_element_.useState)(value);\n const input = (0,external_window_wp_element_.useRef)();\n return (0,external_window_wp_element_.createElement)(external_window_wp_element_.Fragment, null, (0,external_window_wp_element_.createElement)(\"input\", {\n value: JSON.stringify(Array.isArray(internalValue) ? {} : internalValue),\n onChange: () => {},\n name: input_name,\n type: \"hidden\",\n ref: input\n }), (0,external_window_wp_element_.createPortal)((0,external_window_wp_element_.createElement)(OptionsPanel/* default */.Z, {\n value: internalValue,\n options: {\n accent_color: options.accent_color\n },\n onChange: (key, newValue) => {\n setInternalValue(internalValue => taxonomies_objectSpread(taxonomies_objectSpread({}, internalValue), {}, {\n [key]: newValue\n }));\n external_jQuery_default()(input.current).change();\n }\n }), document.querySelector('.term-blocksy-accent-color-wrap td')), (0,external_window_wp_element_.createPortal)((0,external_window_wp_element_.createElement)(\"button\", {\n type: \"button\",\n disabled: deep_equal_default()(options.accent_color.value, internalValue.accent_color),\n className: \"ct-revert\",\n onClick: () => {\n setInternalValue(internalValue => taxonomies_objectSpread(taxonomies_objectSpread({}, internalValue), {}, {\n accent_color: options.accent_color.value\n }));\n external_jQuery_default()(input.current).change();\n }\n }), document.querySelector('.term-blocksy-accent-color-wrap th label')), (0,external_window_wp_element_.createPortal)((0,external_window_wp_element_.createElement)(OptionsPanel/* default */.Z, {\n value: internalValue,\n options: {\n image: options.image\n },\n onChange: (key, newValue) => {\n setInternalValue(internalValue => taxonomies_objectSpread(taxonomies_objectSpread({}, internalValue), {}, {\n [key]: newValue\n }));\n external_jQuery_default()(input.current).change();\n }\n }), document.querySelector('.term-blocksy-image-wrap td')));\n};\n\nconst initTaxonomies = () => {\n const maybeTaxonomyField = document.querySelector('[name*=\"blocksy_taxonomy_meta_options\"]');\n\n if (!maybeTaxonomyField) {\n return;\n }\n\n let options = {\n image: {\n label: (0,external_window_wp_i18n_.__)('Transparent State Logo', 'blocksy'),\n type: 'ct-image-uploader',\n value: '',\n attr: {\n 'data-type': 'large'\n },\n design: 'none',\n emptyLabel: (0,external_window_wp_i18n_.__)('Select Image', 'blocksy')\n },\n accent_color: {\n label: (0,external_window_wp_i18n_.__)('Site Title Color', 'blocksy'),\n type: 'ct-color-picker',\n design: 'none',\n value: {\n default: {\n color: 'CT_CSS_SKIP_RULE'\n },\n hover: {\n color: 'CT_CSS_SKIP_RULE'\n },\n background_initial: {\n color: 'CT_CSS_SKIP_RULE'\n },\n background_hover: {\n color: 'CT_CSS_SKIP_RULE'\n }\n },\n pickers: [{\n title: (0,external_window_wp_i18n_.__)('Text Initial', 'blocksy'),\n id: 'default'\n }, {\n title: (0,external_window_wp_i18n_.__)('Text Hover', 'blocksy'),\n id: 'hover'\n }, {\n title: (0,external_window_wp_i18n_.__)('Background Initial', 'blocksy'),\n id: 'background_initial'\n }, {\n title: (0,external_window_wp_i18n_.__)('Background Hover', 'blocksy'),\n id: 'background_hover'\n }]\n }\n };\n (0,external_window_wp_element_.render)((0,external_window_wp_element_.createElement)(TaxonomyRoot, {\n input_name: maybeTaxonomyField.name,\n options: options,\n value: (0,get_value_from_input/* getValueFromInput */.n6)(options, JSON.parse(maybeTaxonomyField.value), null, false)\n }), maybeTaxonomyField.parentNode);\n};\n// EXTERNAL MODULE: ./static/js/customizer/components/Overlay.js + 4 modules\nvar Overlay = __webpack_require__(7136);\n// EXTERNAL MODULE: ./static/js/options/options/ct-panel.js\nvar ct_panel = __webpack_require__(3731);\n// EXTERNAL MODULE: ./static/js/customizer/components/useDeviceManager.js\nvar useDeviceManager = __webpack_require__(5458);\n// EXTERNAL MODULE: ./static/js/options/components/PanelLevel.js + 1 modules\nvar PanelLevel = __webpack_require__(956);\n// EXTERNAL MODULE: ./static/js/options/options/ct-switch.js\nvar ct_switch = __webpack_require__(9497);\n// EXTERNAL MODULE: ./static/js/options/options/ct-image-uploader.js\nvar ct_image_uploader = __webpack_require__(3048);\n// EXTERNAL MODULE: ./static/js/options/options/ct-select.js + 3 modules\nvar ct_select = __webpack_require__(1404);\n// EXTERNAL MODULE: ./static/js/options/options/react-outside-click-handler.js\nvar react_outside_click_handler = __webpack_require__(8204);\n// EXTERNAL MODULE: ./node_modules/react-spring/renderprops.js\nvar renderprops = __webpack_require__(4823);\n// EXTERNAL MODULE: ./node_modules/bezier-easing/src/index.js\nvar src = __webpack_require__(3431);\nvar src_default = /*#__PURE__*/__webpack_require__.n(src);\n// EXTERNAL MODULE: ./static/js/options/helpers/usePopoverMaker.js\nvar usePopoverMaker = __webpack_require__(9144);\n;// CONCATENATED MODULE: ./static/js/options.js\n\n\n\n\n\n\n\nif ((external_jQuery_default()) && (external_jQuery_default()).fn) {\n external_jQuery_default()(document).on('widget-added', (event, widget) => {\n initWidget(widget[0]);\n });\n initAllWooVariations();\n setTimeout(() => {\n external_jQuery_default()(document.body).on('woocommerce_variations_added woocommerce_variations_loaded', function () {\n initAllWooVariations();\n });\n }, 1000);\n}\n\ndocument.addEventListener('DOMContentLoaded', () => {\n initAllPanels();\n initTaxonomies();\n [...document.querySelectorAll('.notice-blocksy-plugin'), ...document.querySelectorAll('[data-dismiss]')].map(el => __webpack_require__.e(/* import() */ 149).then(__webpack_require__.bind(__webpack_require__, 2149)).then(_ref => {\n let {\n mount\n } = _ref;\n return mount(el);\n }));\n\n if ((external_jQuery_default())) {\n external_jQuery_default()(document).on('click', '[href*=\"technical_support\"][href*=\"ct-dashboard\"]', e => {\n e.preventDefault();\n location.href = 'https://creativethemes.com/blocksy/support';\n });\n }\n});\n\n\n\n\n\n\n\n\n\n\n\n\n\nconst onDocumentLoaded = cb => {\n if (/comp|inter|loaded/.test(document.readyState)) {\n cb();\n } else {\n document.addEventListener('DOMContentLoaded', cb, false);\n }\n};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"3654.js","mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC/DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACzEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;;;;;;;ACtHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./static/js/options/OptionsRoot.js?140e","webpack://blocksyOptions/./static/js/options/initPanels.js?727f","webpack://blocksyOptions/./static/js/backend/widgets.js?e560","webpack://blocksyOptions/./static/js/backend/woo-variation.js?acdb","webpack://blocksyOptions/./static/js/backend/taxonomies.js?46ca","webpack://blocksyOptions/./static/js/options.js?d225"],"sourcesContent":["function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, Component, createRef, useRef, useCallback, useEffect, useState } from '@wordpress/element';\nimport OptionsPanel from './OptionsPanel.js';\nimport $ from 'jquery';\nimport ctEvents from 'ct-events';\nconst INITIAL_VALUE = '__INITIAL__';\n\nconst OptionsRoot = _ref => {\n  let {\n    value,\n    options,\n    input_name,\n    input_id,\n    hasRevertButton\n  } = _ref;\n  const [internalValue, setInternalValue] = useState(value);\n  const input = useRef();\n  const handleChange = useCallback(_ref2 => {\n    let {\n      id,\n      value,\n      input: inputRef\n    } = _ref2;\n\n    if (inputRef === input.current) {\n      setInternalValue(internalValue => _objectSpread(_objectSpread({}, internalValue), {}, {\n        [id]: value\n      }));\n    }\n  }, []);\n  useEffect(() => {\n    ctEvents.on('ct:options:trigger-change', handleChange);\n    return () => {\n      ctEvents.off('ct:options:trigger-change', handleChange);\n    };\n  }, []);\n  return createElement(\"div\", {\n    className: \"ct-options-root\"\n  }, createElement(\"input\", {\n    value: JSON.stringify(Array.isArray(internalValue) ? {} : internalValue),\n    onChange: () => {},\n    name: input_name,\n    id: input_id,\n    type: \"hidden\",\n    ref: input\n  }), createElement(OptionsPanel, {\n    hasRevertButton: hasRevertButton,\n    onChange: (key, newValue) => {\n      setInternalValue(internalValue => _objectSpread(_objectSpread({}, internalValue), {}, {\n        [key]: newValue\n      }));\n      $(input.current).change();\n    },\n    value: internalValue,\n    options: options\n  }));\n};\n\nexport default OptionsRoot;","import { createElement, render } from '@wordpress/element';\nimport OptionsRoot from './OptionsRoot.js';\nimport { getValueFromInput } from './helpers/get-value-from-input';\nimport $ from 'jquery';\nexport const initAllPanels = () => [...document.querySelectorAll('.ct-options-panel')].map(singleTarget => {\n  if (singleTarget.closest('[id=\"available-widgets\"]')) {\n    return;\n  }\n\n  if (singleTarget.ctHasOptions) return;\n  singleTarget.ctHasOptions = true;\n  $(singleTarget).on('remove', () => setTimeout(() => initAllPanels()));\n  $(singleTarget).on('remove', () => () => initAllPanels());\n  render(createElement(OptionsRoot, {\n    options: JSON.parse(singleTarget.firstElementChild.dataset.ctOptions),\n    value: getValueFromInput(JSON.parse(singleTarget.firstElementChild.dataset.ctOptions), JSON.parse(singleTarget.firstElementChild.value), null, false),\n    input_id: singleTarget.firstElementChild.id,\n    input_name: singleTarget.firstElementChild.name,\n    hasRevertButton: Object.keys(singleTarget.dataset).indexOf('disableReverseButton') === -1\n  }), singleTarget);\n});","import { initAllPanels } from '../options/initPanels';\nexport const initWidget = widget => {\n  if (widget.querySelector('.ct-options-panel') && widget.querySelector('.ct-options-panel').innerHTML.indexOf('__i__') > -1) {\n    const panel = widget.querySelector('.ct-options-panel');\n    const widgetNumber = widget.querySelector('input.multi_number').value;\n    panel.innerHTML = panel.innerHTML.replace(/__i__|%i%/g, widgetNumber);\n  }\n\n  initAllPanels();\n};","import { createElement, render } from '@wordpress/element';\nimport OptionsRoot from '../options/OptionsRoot';\nimport { getValueFromInput } from '../options/helpers/get-value-from-input';\nimport $ from 'jquery';\nimport { __ } from 'ct-i18n';\nexport const initWooVariation = variationWrapper => {\n  const uploadImage = variationWrapper.querySelector('.upload_image');\n\n  if (!uploadImage) {\n    return;\n  }\n\n  const div = document.createElement('p');\n  div.classList.add('form-row');\n  div.classList.add('form-row-full');\n  div.classList.add('ct-variation-image-gallery');\n  uploadImage.nextElementSibling.insertAdjacentElement('afterend', div);\n  const input = variationWrapper.querySelector('[name*=\"blocksy_post_meta_options\"]');\n\n  if (!input) {\n    return;\n  }\n\n  const options = {\n    gallery_source: {\n      label: __('Variation Gallery Source', 'blocksy'),\n      type: 'ct-radio',\n      value: 'default',\n      design: 'inline',\n      divider: 'bottom',\n      choices: {\n        default: __('Default', 'blocksy'),\n        custom: __('Custom', 'blocksy')\n      }\n    },\n    condition: {\n      type: 'ct-condition',\n      condition: {\n        gallery_source: 'custom'\n      },\n      options: {\n        images: {\n          label: __('Variation Image Gallery', 'blocksy'),\n          type: 'ct-multi-image-uploader',\n          design: _ref => {\n            let {\n              value\n            } = _ref;\n            return value.length === 0 ? 'inline' : 'block';\n          },\n          value: []\n        }\n      }\n    }\n  };\n  render(createElement(OptionsRoot, {\n    options: options,\n    value: getValueFromInput(options, JSON.parse(input.value), null, false),\n    input_id: input.id,\n    input_name: input.name,\n    hasRevertButton: false\n  }), div);\n};\nexport const initAllWooVariations = () => {\n  ;\n  [...document.querySelectorAll('.woocommerce_variations .woocommerce_variation')].map(variationWrapper => {\n    if (variationWrapper.hasBlocksyOptions) {\n      return;\n    }\n\n    variationWrapper.hasBlocksyOptions = true;\n    initWooVariation(variationWrapper);\n  });\n};","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { __ } from 'ct-i18n';\nimport { useRef, useState, Fragment, createElement, createPortal, render } from '@wordpress/element';\nimport $ from 'jquery';\nimport OptionsPanel from '../options/OptionsPanel';\nimport { getValueFromInput } from '../options/helpers/get-value-from-input';\nimport deepEqual from 'deep-equal';\n\nconst TaxonomyRoot = _ref => {\n  let {\n    options,\n    input_name,\n    value\n  } = _ref;\n  const [internalValue, setInternalValue] = useState(value);\n  const input = useRef();\n  return createElement(Fragment, null, createElement(\"input\", {\n    value: JSON.stringify(Array.isArray(internalValue) ? {} : internalValue),\n    onChange: () => {},\n    name: input_name,\n    type: \"hidden\",\n    ref: input\n  }), createPortal(createElement(OptionsPanel, {\n    value: internalValue,\n    options: {\n      accent_color: options.accent_color\n    },\n    onChange: (key, newValue) => {\n      setInternalValue(internalValue => _objectSpread(_objectSpread({}, internalValue), {}, {\n        [key]: newValue\n      }));\n      $(input.current).change();\n    }\n  }), document.querySelector('.term-blocksy-accent-color-wrap td')), createPortal(createElement(\"button\", {\n    type: \"button\",\n    disabled: deepEqual(options.accent_color.value, internalValue.accent_color),\n    className: \"ct-revert\",\n    onClick: () => {\n      setInternalValue(internalValue => _objectSpread(_objectSpread({}, internalValue), {}, {\n        accent_color: options.accent_color.value\n      }));\n      $(input.current).change();\n    }\n  }), document.querySelector('.term-blocksy-accent-color-wrap th label')), createPortal(createElement(OptionsPanel, {\n    value: internalValue,\n    options: {\n      image: options.image\n    },\n    onChange: (key, newValue) => {\n      setInternalValue(internalValue => _objectSpread(_objectSpread({}, internalValue), {}, {\n        [key]: newValue\n      }));\n      $(input.current).change();\n    }\n  }), document.querySelector('.term-blocksy-image-wrap td')));\n};\n\nexport const initTaxonomies = () => {\n  const maybeTaxonomyField = document.querySelector('[name*=\"blocksy_taxonomy_meta_options\"]');\n\n  if (!maybeTaxonomyField) {\n    return;\n  }\n\n  let options = {\n    image: {\n      label: __('Transparent State Logo', 'blocksy'),\n      type: 'ct-image-uploader',\n      value: '',\n      attr: {\n        'data-type': 'large'\n      },\n      design: 'none',\n      emptyLabel: __('Select Image', 'blocksy')\n    },\n    accent_color: {\n      label: __('Site Title Color', 'blocksy'),\n      type: 'ct-color-picker',\n      design: 'none',\n      value: {\n        default: {\n          color: 'CT_CSS_SKIP_RULE'\n        },\n        hover: {\n          color: 'CT_CSS_SKIP_RULE'\n        },\n        background_initial: {\n          color: 'CT_CSS_SKIP_RULE'\n        },\n        background_hover: {\n          color: 'CT_CSS_SKIP_RULE'\n        }\n      },\n      pickers: [{\n        title: __('Text Initial', 'blocksy'),\n        id: 'default'\n      }, {\n        title: __('Text Hover', 'blocksy'),\n        id: 'hover'\n      }, {\n        title: __('Background Initial', 'blocksy'),\n        id: 'background_initial'\n      }, {\n        title: __('Background Hover', 'blocksy'),\n        id: 'background_hover'\n      }]\n    }\n  };\n  render(createElement(TaxonomyRoot, {\n    input_name: maybeTaxonomyField.name,\n    options: options,\n    value: getValueFromInput(options, JSON.parse(maybeTaxonomyField.value), null, false)\n  }), maybeTaxonomyField.parentNode);\n};","import './public-path';\nimport $ from 'jquery';\nimport { initAllPanels } from './options/initPanels';\nimport { initWidget } from './backend/widgets';\nimport { initAllWooVariations } from './backend/woo-variation';\nimport { initTaxonomies } from './backend/taxonomies';\n\nif ($ && $.fn) {\n  $(document).on('widget-added', (event, widget) => {\n    initWidget(widget[0]);\n  });\n  initAllWooVariations();\n  setTimeout(() => {\n    $(document.body).on('woocommerce_variations_added woocommerce_variations_loaded', function () {\n      initAllWooVariations();\n    });\n  }, 1000);\n}\n\ndocument.addEventListener('DOMContentLoaded', () => {\n  initAllPanels();\n  initTaxonomies();\n  [...document.querySelectorAll('.notice-blocksy-plugin'), ...document.querySelectorAll('[data-dismiss]')].map(el => import('./notification/main').then(_ref => {\n    let {\n      mount\n    } = _ref;\n    return mount(el);\n  }));\n\n  if ($) {\n    $(document).on('click', '[href*=\"technical_support\"][href*=\"ct-dashboard\"]', e => {\n      e.preventDefault();\n      location.href = 'https://creativethemes.com/blocksy/support';\n    });\n  }\n});\nexport { default as Overlay } from './customizer/components/Overlay';\nexport { getValueFromInput } from './options/helpers/get-value-from-input';\nexport { default as OptionsPanel } from './options/OptionsPanel';\nexport { default as Panel, PanelMetaWrapper } from './options/options/ct-panel';\nexport { DeviceManagerProvider } from './customizer/components/useDeviceManager';\nexport { default as PanelLevel } from './options/components/PanelLevel';\nexport { default as Switch } from './options/options/ct-switch';\nexport { default as ImageUploader } from './options/options/ct-image-uploader';\nexport { default as Select } from './options/options/ct-select';\nexport { default as OutsideClickHandler } from './options/options/react-outside-click-handler';\nexport { Transition, animated } from 'react-spring/renderprops';\nexport { default as bezierEasing } from 'bezier-easing';\nexport { default as usePopoverMaker } from './options/helpers/usePopoverMaker';\nexport const onDocumentLoaded = cb => {\n  if (/comp|inter|loaded/.test(document.readyState)) {\n    cb();\n  } else {\n    document.addEventListener('DOMContentLoaded', cb, false);\n  }\n};"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///3654\n")},6095:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"ZP\": () => (__WEBPACK_DEFAULT_EXPORT__),\n/* harmony export */ \"fg\": () => (/* binding */ getOptionFor),\n/* harmony export */ \"y1\": () => (/* binding */ optionWithDefault)\n/* harmony export */ });\n/* unused harmony export capitalizeFirstLetter */\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(4184);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(4616);\n/* harmony import */ var deep_equal__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(251);\n/* harmony import */ var deep_equal__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(deep_equal__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var match_conditions__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7465);\n/* harmony import */ var ct_i18n__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(5652);\n/* harmony import */ var ct_i18n__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(ct_i18n__WEBPACK_IMPORTED_MODULE_5__);\n/* harmony import */ var _helpers_get_label__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(7493);\n/* harmony import */ var ct_events__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(2243);\n/* harmony import */ var ct_events__WEBPACK_IMPORTED_MODULE_7___default = /*#__PURE__*/__webpack_require__.n(ct_events__WEBPACK_IMPORTED_MODULE_7__);\nconst _excluded = [\"className\"],\n _excluded2 = [\"wrapperAttr\"],\n _excluded3 = [\"className\"];\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\n\n\n\nconst CORE_OPTIONS_CONTEXT = __webpack_require__(1764);\n\nCORE_OPTIONS_CONTEXT.keys().forEach(CORE_OPTIONS_CONTEXT);\n\nconst hasCoreOptionModifier = type => {\n let index = CORE_OPTIONS_CONTEXT.keys().map(module => module.replace(/^\\.\\//, '').replace(/\\.js$/, '')).indexOf(type);\n return index > -1 && CORE_OPTIONS_CONTEXT.keys()[index];\n};\n\nconst capitalizeFirstLetter = str => {\n str = str == null ? '' : String(str);\n return str.charAt(0).toUpperCase() + str.slice(1);\n};\nconst getOptionFor = option => {\n const dynamicOptionTypes = {};\n ct_events__WEBPACK_IMPORTED_MODULE_7___default().trigger('blocksy:options:register', dynamicOptionTypes);\n\n if (hasCoreOptionModifier(option.type)) {\n return CORE_OPTIONS_CONTEXT(hasCoreOptionModifier(option.type)).default;\n }\n\n if (dynamicOptionTypes[option.type]) {\n return dynamicOptionTypes[option.type];\n }\n\n return null;\n};\nconst optionWithDefault = _ref => {\n let {\n option,\n value\n } = _ref;\n return value === undefined ? option.value : value;\n};\n\nconst GenericOptionType = _ref2 => {\n let {\n option,\n value,\n values,\n onChange,\n onChangeFor,\n hasRevertButton,\n id,\n purpose\n } = _ref2;\n let maybeGutenbergDevice = null;\n\n if (wp.data && wp.data.useSelect) {\n maybeGutenbergDevice = wp.data.useSelect(select => {\n if (!select('core/edit-post')) {\n return null;\n }\n\n return select('core/edit-post').__experimentalGetPreviewDeviceType();\n });\n }\n\n const getInitialDevice = () => {\n if (wp.customize && wp.customize.previewedDevice) {\n return wp.customize.previewedDevice();\n }\n\n if (wp.data && wp.data.select && wp.data.select('core/edit-post') && wp.data.select('core/edit-post').__experimentalGetPreviewDeviceType) {\n return wp.data.select('core/edit-post').__experimentalGetPreviewDeviceType().toLowerCase();\n }\n\n return 'desktop';\n };\n\n const [device, setInnerDevice] = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useState)(getInitialDevice());\n\n const listener = () => {\n setInnerDevice(getInitialDevice());\n };\n\n const ctEventsListener = _ref3 => {\n let {\n device\n } = _ref3;\n setInnerDevice(device);\n };\n\n const setDevice = device => {\n ct_events__WEBPACK_IMPORTED_MODULE_7___default().trigger('ct:options:device:update', {\n device\n });\n setInnerDevice(device);\n wp.customize && wp.customize.previewedDevice.set(device);\n\n if (wp.data && wp.data.dispatch && wp.data.dispatch('core/edit-post') && wp.data.dispatch('core/edit-post').__experimentalSetPreviewDeviceType) {\n wp.data.dispatch('core/edit-post').__experimentalSetPreviewDeviceType(device.replace(/\\w/, c => c.toUpperCase()));\n }\n };\n\n (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useEffect)(() => {\n if (maybeGutenbergDevice) {\n setInnerDevice(maybeGutenbergDevice.toLowerCase());\n }\n }, [maybeGutenbergDevice]);\n (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useEffect)(() => {\n if (option.type !== 'ct-typography') {\n if (!(0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .isOptionResponsiveFor */ .W)(option) && !option.markAsAutoFor) {\n return;\n }\n }\n\n if (wp.customize) {\n setTimeout(() => wp.customize.previewedDevice.bind(listener), 1000);\n }\n\n ct_events__WEBPACK_IMPORTED_MODULE_7___default().on('ct:options:device:update', ctEventsListener);\n setInnerDevice(getInitialDevice());\n return () => {\n if (option.type !== 'ct-typography') {\n if (!(0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .isOptionResponsiveFor */ .W)(option)) {\n return;\n }\n }\n\n if (wp.customize) {\n wp.customize.previewedDevice.unbind(listener);\n }\n\n ct_events__WEBPACK_IMPORTED_MODULE_7___default().off('ct:options:device:update', ctEventsListener);\n };\n }, []);\n let OptionComponent = getOptionFor(option);\n let BeforeOptionContent = {\n content: null,\n option\n };\n ct_events__WEBPACK_IMPORTED_MODULE_7___default().trigger('blocksy:options:before-option', BeforeOptionContent);\n const globalResponsiveValue = (0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .maybePromoteScalarValueIntoResponsive */ .T)(optionWithDefault({\n value,\n option\n }), (0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .isOptionResponsiveFor */ .W)(option));\n const valueWithResponsive = (0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .isOptionResponsiveFor */ .W)(option, {\n ignoreHidden: true\n }) ? (0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .getValueForDevice */ .Oi)({\n option,\n value: globalResponsiveValue,\n device\n }) : globalResponsiveValue;\n\n const onChangeWithMobileBridge = value => {\n if (option.triggerRefreshOnChange) {\n wp.customize && wp.customize.previewer && wp.customize.previewer.refresh();\n }\n\n if (option.switchDeviceOnChange && wp.customize && wp.customize.previewedDevice() !== option.switchDeviceOnChange) {\n wp.customize.previewedDevice.set(option.switchDeviceOnChange);\n }\n\n if (option.sync && (Object.keys(option.sync).length > 0 || Array.isArray(option.sync)) && wp.customize && wp.customize.previewer) {\n wp.customize.previewer.send('ct:sync:refresh_partial', {\n id: option.sync.id || option.id,\n option\n });\n }\n\n onChange(value);\n };\n\n const onChangeWithResponsiveBridge = scalarValue => {\n const responsiveValue = (0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .maybePromoteScalarValueIntoResponsive */ .T)(optionWithDefault({\n value,\n option\n }), (0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .isOptionResponsiveFor */ .W)(option));\n onChangeWithMobileBridge((0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .isOptionResponsiveFor */ .W)(option, {\n ignoreHidden: true\n }) ? _objectSpread(_objectSpread(_objectSpread(_objectSpread({}, responsiveValue), {}, {\n [device === 'tablet' && (0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .isOptionEnabledFor */ .S0)('tablet', option.responsive) === 'skip' ? 'mobile' : device]: scalarValue\n }, device === 'desktop' ? Object.keys(responsiveValue).reduce((currentValue, key) => _objectSpread(_objectSpread({}, currentValue), key !== 'desktop' && key !== '__changed' && Object.keys((0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .maybePromoteScalarValueIntoResponsive */ .T)(option.value)).reduce((result, key) => result ? (0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .maybePromoteScalarValueIntoResponsive */ .T)(option.value)[key] === (0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .maybePromoteScalarValueIntoResponsive */ .T)(option.value).desktop : false, true) && (responsiveValue.__changed || []).indexOf('tablet') === -1 ? {\n [key]: scalarValue\n } : {}), {}) : {}), device === 'tablet' && (0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .isOptionEnabledFor */ .S0)('tablet', option.responsive) !== 'skip' ? Object.keys(responsiveValue).reduce((currentValue, key) => _objectSpread(_objectSpread({}, currentValue), key !== 'desktop' && key !== 'tablet' && key !== '__changed' && Object.keys((0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .maybePromoteScalarValueIntoResponsive */ .T)(option.value)).reduce((result, key) => result ? (0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .maybePromoteScalarValueIntoResponsive */ .T)(option.value)[key] === (0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .maybePromoteScalarValueIntoResponsive */ .T)(option.value).desktop : false, true) && (responsiveValue.__changed || []).indexOf(key) === -1 ? {\n [key]: scalarValue\n } : {}), {}) : {}), {}, {\n __changed: [...(responsiveValue.__changed || []), ...(device !== 'desktop' ? [device] : [])].filter((value, index, self) => self.indexOf(value) === index)\n }) : scalarValue);\n };\n /**\n * Handle transparent components\n */\n\n\n if (!OptionComponent) {\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", null, \"Unimplemented option: \", option.type);\n }\n\n let renderingConfig = {\n design: true,\n label: true,\n wrapperAttr: {}\n };\n\n let LabelToolbar = () => null;\n\n let OptionMetaWrapper = null;\n\n let ControlEnd = () => null;\n\n let sectionClassName = () => ({});\n\n renderingConfig = _objectSpread(_objectSpread({}, renderingConfig), OptionComponent.renderingConfig || {});\n\n if (option.design) {\n renderingConfig.design = option.design;\n }\n\n if (typeof renderingConfig.design === 'function') {\n renderingConfig.design = renderingConfig.design({\n option,\n value: valueWithResponsive\n });\n }\n\n if (OptionComponent.LabelToolbar) {\n LabelToolbar = OptionComponent.LabelToolbar;\n }\n\n if (OptionComponent.ControlEnd) {\n ControlEnd = OptionComponent.ControlEnd;\n }\n\n if (OptionComponent.MetaWrapper) {\n OptionMetaWrapper = OptionComponent.MetaWrapper;\n }\n\n if (OptionComponent.sectionClassName) {\n sectionClassName = OptionComponent.sectionClassName;\n }\n\n let OptionComponentWithoutDesign = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, BeforeOptionContent && BeforeOptionContent.content, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(OptionComponent, {\n key: id,\n option: _objectSpread(_objectSpread({}, option), {}, {\n value: (0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .isOptionResponsiveFor */ .W)(option, {\n ignoreHidden: true\n }) ? (0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .getValueForDevice */ .Oi)({\n device,\n option,\n value: (0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .maybePromoteScalarValueIntoResponsive */ .T)(option.value || '')\n }) : (0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .maybePromoteScalarValueIntoResponsive */ .T)(option.value || '', (0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .isOptionResponsiveFor */ .W)(option))\n }),\n value: valueWithResponsive,\n id,\n values,\n onChangeFor,\n device,\n onChange: onChangeWithResponsiveBridge\n }));\n\n if (!renderingConfig.design || renderingConfig.design === 'none') {\n return OptionComponentWithoutDesign;\n }\n\n let maybeLabel = (0,_helpers_get_label__WEBPACK_IMPORTED_MODULE_6__/* .getOptionLabelFor */ .m)({\n id,\n option,\n values,\n renderingConfig\n });\n let maybeDesc = Object.keys(option).indexOf('desc') === -1 ? false : option.desc;\n let maybeLink = Object.keys(option).indexOf('link') === -1 ? false : option.link || ' ';\n const actualDesignType = typeof renderingConfig.design === 'boolean' ? 'block' : renderingConfig.design;\n\n if (renderingConfig.design === 'compact') {\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"section\", option.sectionAttr || {}, maybeLabel && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"label\", null, maybeLabel), ((0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .isOptionResponsiveFor */ .W)(option) && (0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .isOptionEnabledFor */ .S0)(device, option.responsive) || !(0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .isOptionResponsiveFor */ .W)(option)) && OptionComponentWithoutDesign, maybeLink && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"a\", _extends({\n dangerouslySetInnerHTML: {\n __html: maybeLink\n }\n }, option.linkAttr || {})));\n }\n\n const getActualOption = function () {\n let _ref4 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n let {\n wrapperAttr: {\n className\n } = {}\n } = _ref4,\n additionalWrapperAttr = _objectWithoutProperties(_ref4.wrapperAttr, _excluded),\n props = _objectWithoutProperties(_ref4, _excluded2);\n\n const _ref5 = option.wrapperAttr || {},\n {\n className: optionClassName\n } = _ref5,\n optionAdditionalWrapperAttr = _objectWithoutProperties(_ref5, _excluded3);\n\n let computeOptionValue = renderingConfig.computeOptionValue;\n\n if (!computeOptionValue) {\n computeOptionValue = o => o;\n }\n\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", _extends({\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()('ct-control', className, optionClassName, {}),\n \"data-design\": actualDesignType\n }, option.divider ? {\n 'data-divider': option.divider\n } : {}, _objectSpread({}, (0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .isOptionResponsiveFor */ .W)(option) && !(0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .isOptionEnabledFor */ .S0)(device, option.responsive) || option.state === 'disabled' ? {\n 'data-state': 'disabled'\n } : {}), _objectSpread(_objectSpread({}, optionAdditionalWrapperAttr), additionalWrapperAttr)), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"header\", null, maybeLabel && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"label\", null, maybeLabel), option.type !== 'ct-image-picker' && option.type !== 'ct-layers' && option.type !== 'ct-image-uploader' && option.type !== 'ct-panel' && hasRevertButton && !option.disableRevertButton && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"button\", {\n type: \"button\",\n disabled: deep_equal__WEBPACK_IMPORTED_MODULE_3___default()(computeOptionValue(option.value), renderingConfig.getValueForRevert ? renderingConfig.getValueForRevert({\n value,\n option,\n values,\n device\n }) : optionWithDefault({\n value,\n option\n })),\n className: \"ct-revert\",\n onClick: () => {\n if (renderingConfig.performRevert) {\n renderingConfig.performRevert({\n onChangeFor\n });\n }\n\n onChangeWithMobileBridge(option.value);\n }\n }), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(LabelToolbar, {\n option,\n value: valueWithResponsive,\n id,\n onChange: onChangeWithResponsiveBridge\n }), (0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .isOptionResponsiveFor */ .W)(option, {\n ignoreHidden: true\n }) && actualDesignType.indexOf('block') > -1 && !option.skipResponsiveControls && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* [\"default\"] */ .ZP, {\n device: device,\n responsiveDescriptor: option.responsive,\n setDevice: setDevice\n })), (0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .isOptionResponsiveFor */ .W)(option) && !(0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .isOptionEnabledFor */ .S0)(device, option.responsive) && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", {\n className: \"ct-disabled-notification\"\n }, option.disabledDeviceMessage || (0,ct_i18n__WEBPACK_IMPORTED_MODULE_5__.__)(\"Option can't be edited for current device\", 'blocksy')), ((0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .isOptionResponsiveFor */ .W)(option) && (0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .isOptionEnabledFor */ .S0)(device, option.responsive) || !(0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .isOptionResponsiveFor */ .W)(option)) && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"section\", _extends({}, option.sectionAttr || {}, {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()({\n 'ct-responsive-container': (0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .isOptionResponsiveFor */ .W)(option, {\n ignoreHidden: true\n }) && actualDesignType === 'inline'\n }, sectionClassName({\n design: actualDesignType,\n option\n }), (option.sectionAttr || {}).class || '')\n }), (0,_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* .isOptionResponsiveFor */ .W)(option, {\n ignoreHidden: true\n }) && actualDesignType === 'inline' && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_customizer_components_responsive_controls__WEBPACK_IMPORTED_MODULE_2__/* [\"default\"] */ .ZP, {\n device: device,\n responsiveDescriptor: option.responsive,\n setDevice: setDevice\n }), OptionComponentWithoutDesign, maybeLink && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"a\", _extends({\n dangerouslySetInnerHTML: {\n __html: maybeLink\n }\n }, option.linkAttr || {}))), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(ControlEnd, null), maybeDesc && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", {\n dangerouslySetInnerHTML: {\n __html: maybeDesc\n },\n className: \"ct-option-description\"\n }))));\n };\n\n return OptionMetaWrapper ? (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(OptionMetaWrapper, {\n id: id,\n option: option,\n value: valueWithResponsive,\n onChangeFor: onChangeFor,\n values: values,\n getActualOption: getActualOption\n }) : getActualOption();\n};\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (GenericOptionType);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"6095.js","mappings":";;;;;;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./static/js/options/GenericOptionType.js?d600"],"sourcesContent":["const _excluded = [\"className\"],\n      _excluded2 = [\"wrapperAttr\"],\n      _excluded3 = [\"className\"];\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, Fragment, Component, useState, useEffect } from '@wordpress/element';\nimport classnames from 'classnames';\nimport ResponsiveControls, { maybePromoteScalarValueIntoResponsive, isOptionEnabledFor, getValueForDevice, isOptionResponsiveFor } from '../customizer/components/responsive-controls';\nimport deepEqual from 'deep-equal';\nimport { normalizeCondition, matchValuesWithCondition } from 'match-conditions';\nimport { __ } from 'ct-i18n';\nimport { getOptionLabelFor } from './helpers/get-label';\nimport ctEvents from 'ct-events';\n\nconst CORE_OPTIONS_CONTEXT = require.context('./options/', false, /\\.js$/);\n\nCORE_OPTIONS_CONTEXT.keys().forEach(CORE_OPTIONS_CONTEXT);\n\nconst hasCoreOptionModifier = type => {\n  let index = CORE_OPTIONS_CONTEXT.keys().map(module => module.replace(/^\\.\\//, '').replace(/\\.js$/, '')).indexOf(type);\n  return index > -1 && CORE_OPTIONS_CONTEXT.keys()[index];\n};\n\nexport const capitalizeFirstLetter = str => {\n  str = str == null ? '' : String(str);\n  return str.charAt(0).toUpperCase() + str.slice(1);\n};\nexport const getOptionFor = option => {\n  const dynamicOptionTypes = {};\n  ctEvents.trigger('blocksy:options:register', dynamicOptionTypes);\n\n  if (hasCoreOptionModifier(option.type)) {\n    return CORE_OPTIONS_CONTEXT(hasCoreOptionModifier(option.type)).default;\n  }\n\n  if (dynamicOptionTypes[option.type]) {\n    return dynamicOptionTypes[option.type];\n  }\n\n  return null;\n};\nexport const optionWithDefault = _ref => {\n  let {\n    option,\n    value\n  } = _ref;\n  return value === undefined ? option.value : value;\n};\n\nconst GenericOptionType = _ref2 => {\n  let {\n    option,\n    value,\n    values,\n    onChange,\n    onChangeFor,\n    hasRevertButton,\n    id,\n    purpose\n  } = _ref2;\n  let maybeGutenbergDevice = null;\n\n  if (wp.data && wp.data.useSelect) {\n    maybeGutenbergDevice = wp.data.useSelect(select => {\n      if (!select('core/edit-post')) {\n        return null;\n      }\n\n      return select('core/edit-post').__experimentalGetPreviewDeviceType();\n    });\n  }\n\n  const getInitialDevice = () => {\n    if (wp.customize && wp.customize.previewedDevice) {\n      return wp.customize.previewedDevice();\n    }\n\n    if (wp.data && wp.data.select && wp.data.select('core/edit-post') && wp.data.select('core/edit-post').__experimentalGetPreviewDeviceType) {\n      return wp.data.select('core/edit-post').__experimentalGetPreviewDeviceType().toLowerCase();\n    }\n\n    return 'desktop';\n  };\n\n  const [device, setInnerDevice] = useState(getInitialDevice());\n\n  const listener = () => {\n    setInnerDevice(getInitialDevice());\n  };\n\n  const ctEventsListener = _ref3 => {\n    let {\n      device\n    } = _ref3;\n    setInnerDevice(device);\n  };\n\n  const setDevice = device => {\n    ctEvents.trigger('ct:options:device:update', {\n      device\n    });\n    setInnerDevice(device);\n    wp.customize && wp.customize.previewedDevice.set(device);\n\n    if (wp.data && wp.data.dispatch && wp.data.dispatch('core/edit-post') && wp.data.dispatch('core/edit-post').__experimentalSetPreviewDeviceType) {\n      wp.data.dispatch('core/edit-post').__experimentalSetPreviewDeviceType(device.replace(/\\w/, c => c.toUpperCase()));\n    }\n  };\n\n  useEffect(() => {\n    if (maybeGutenbergDevice) {\n      setInnerDevice(maybeGutenbergDevice.toLowerCase());\n    }\n  }, [maybeGutenbergDevice]);\n  useEffect(() => {\n    if (option.type !== 'ct-typography') {\n      if (!isOptionResponsiveFor(option) && !option.markAsAutoFor) {\n        return;\n      }\n    }\n\n    if (wp.customize) {\n      setTimeout(() => wp.customize.previewedDevice.bind(listener), 1000);\n    }\n\n    ctEvents.on('ct:options:device:update', ctEventsListener);\n    setInnerDevice(getInitialDevice());\n    return () => {\n      if (option.type !== 'ct-typography') {\n        if (!isOptionResponsiveFor(option)) {\n          return;\n        }\n      }\n\n      if (wp.customize) {\n        wp.customize.previewedDevice.unbind(listener);\n      }\n\n      ctEvents.off('ct:options:device:update', ctEventsListener);\n    };\n  }, []);\n  let OptionComponent = getOptionFor(option);\n  let BeforeOptionContent = {\n    content: null,\n    option\n  };\n  ctEvents.trigger('blocksy:options:before-option', BeforeOptionContent);\n  const globalResponsiveValue = maybePromoteScalarValueIntoResponsive(optionWithDefault({\n    value,\n    option\n  }), isOptionResponsiveFor(option));\n  const valueWithResponsive = isOptionResponsiveFor(option, {\n    ignoreHidden: true\n  }) ? getValueForDevice({\n    option,\n    value: globalResponsiveValue,\n    device\n  }) : globalResponsiveValue;\n\n  const onChangeWithMobileBridge = value => {\n    if (option.triggerRefreshOnChange) {\n      wp.customize && wp.customize.previewer && wp.customize.previewer.refresh();\n    }\n\n    if (option.switchDeviceOnChange && wp.customize && wp.customize.previewedDevice() !== option.switchDeviceOnChange) {\n      wp.customize.previewedDevice.set(option.switchDeviceOnChange);\n    }\n\n    if (option.sync && (Object.keys(option.sync).length > 0 || Array.isArray(option.sync)) && wp.customize && wp.customize.previewer) {\n      wp.customize.previewer.send('ct:sync:refresh_partial', {\n        id: option.sync.id || option.id,\n        option\n      });\n    }\n\n    onChange(value);\n  };\n\n  const onChangeWithResponsiveBridge = scalarValue => {\n    const responsiveValue = maybePromoteScalarValueIntoResponsive(optionWithDefault({\n      value,\n      option\n    }), isOptionResponsiveFor(option));\n    onChangeWithMobileBridge(isOptionResponsiveFor(option, {\n      ignoreHidden: true\n    }) ? _objectSpread(_objectSpread(_objectSpread(_objectSpread({}, responsiveValue), {}, {\n      [device === 'tablet' && isOptionEnabledFor('tablet', option.responsive) === 'skip' ? 'mobile' : device]: scalarValue\n    }, device === 'desktop' ? Object.keys(responsiveValue).reduce((currentValue, key) => _objectSpread(_objectSpread({}, currentValue), key !== 'desktop' && key !== '__changed' && Object.keys(maybePromoteScalarValueIntoResponsive(option.value)).reduce((result, key) => result ? maybePromoteScalarValueIntoResponsive(option.value)[key] === maybePromoteScalarValueIntoResponsive(option.value).desktop : false, true) && (responsiveValue.__changed || []).indexOf('tablet') === -1 ? {\n      [key]: scalarValue\n    } : {}), {}) : {}), device === 'tablet' && isOptionEnabledFor('tablet', option.responsive) !== 'skip' ? Object.keys(responsiveValue).reduce((currentValue, key) => _objectSpread(_objectSpread({}, currentValue), key !== 'desktop' && key !== 'tablet' && key !== '__changed' && Object.keys(maybePromoteScalarValueIntoResponsive(option.value)).reduce((result, key) => result ? maybePromoteScalarValueIntoResponsive(option.value)[key] === maybePromoteScalarValueIntoResponsive(option.value).desktop : false, true) && (responsiveValue.__changed || []).indexOf(key) === -1 ? {\n      [key]: scalarValue\n    } : {}), {}) : {}), {}, {\n      __changed: [...(responsiveValue.__changed || []), ...(device !== 'desktop' ? [device] : [])].filter((value, index, self) => self.indexOf(value) === index)\n    }) : scalarValue);\n  };\n  /**\n   * Handle transparent components\n   */\n\n\n  if (!OptionComponent) {\n    return createElement(\"div\", null, \"Unimplemented option: \", option.type);\n  }\n\n  let renderingConfig = {\n    design: true,\n    label: true,\n    wrapperAttr: {}\n  };\n\n  let LabelToolbar = () => null;\n\n  let OptionMetaWrapper = null;\n\n  let ControlEnd = () => null;\n\n  let sectionClassName = () => ({});\n\n  renderingConfig = _objectSpread(_objectSpread({}, renderingConfig), OptionComponent.renderingConfig || {});\n\n  if (option.design) {\n    renderingConfig.design = option.design;\n  }\n\n  if (typeof renderingConfig.design === 'function') {\n    renderingConfig.design = renderingConfig.design({\n      option,\n      value: valueWithResponsive\n    });\n  }\n\n  if (OptionComponent.LabelToolbar) {\n    LabelToolbar = OptionComponent.LabelToolbar;\n  }\n\n  if (OptionComponent.ControlEnd) {\n    ControlEnd = OptionComponent.ControlEnd;\n  }\n\n  if (OptionComponent.MetaWrapper) {\n    OptionMetaWrapper = OptionComponent.MetaWrapper;\n  }\n\n  if (OptionComponent.sectionClassName) {\n    sectionClassName = OptionComponent.sectionClassName;\n  }\n\n  let OptionComponentWithoutDesign = createElement(Fragment, null, BeforeOptionContent && BeforeOptionContent.content, createElement(OptionComponent, {\n    key: id,\n    option: _objectSpread(_objectSpread({}, option), {}, {\n      value: isOptionResponsiveFor(option, {\n        ignoreHidden: true\n      }) ? getValueForDevice({\n        device,\n        option,\n        value: maybePromoteScalarValueIntoResponsive(option.value || '')\n      }) : maybePromoteScalarValueIntoResponsive(option.value || '', isOptionResponsiveFor(option))\n    }),\n    value: valueWithResponsive,\n    id,\n    values,\n    onChangeFor,\n    device,\n    onChange: onChangeWithResponsiveBridge\n  }));\n\n  if (!renderingConfig.design || renderingConfig.design === 'none') {\n    return OptionComponentWithoutDesign;\n  }\n\n  let maybeLabel = getOptionLabelFor({\n    id,\n    option,\n    values,\n    renderingConfig\n  });\n  let maybeDesc = Object.keys(option).indexOf('desc') === -1 ? false : option.desc;\n  let maybeLink = Object.keys(option).indexOf('link') === -1 ? false : option.link || ' ';\n  const actualDesignType = typeof renderingConfig.design === 'boolean' ? 'block' : renderingConfig.design;\n\n  if (renderingConfig.design === 'compact') {\n    return createElement(\"section\", option.sectionAttr || {}, maybeLabel && createElement(\"label\", null, maybeLabel), (isOptionResponsiveFor(option) && isOptionEnabledFor(device, option.responsive) || !isOptionResponsiveFor(option)) && OptionComponentWithoutDesign, maybeLink && createElement(\"a\", _extends({\n      dangerouslySetInnerHTML: {\n        __html: maybeLink\n      }\n    }, option.linkAttr || {})));\n  }\n\n  const getActualOption = function () {\n    let _ref4 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n    let {\n      wrapperAttr: {\n        className\n      } = {}\n    } = _ref4,\n        additionalWrapperAttr = _objectWithoutProperties(_ref4.wrapperAttr, _excluded),\n        props = _objectWithoutProperties(_ref4, _excluded2);\n\n    const _ref5 = option.wrapperAttr || {},\n          {\n      className: optionClassName\n    } = _ref5,\n          optionAdditionalWrapperAttr = _objectWithoutProperties(_ref5, _excluded3);\n\n    let computeOptionValue = renderingConfig.computeOptionValue;\n\n    if (!computeOptionValue) {\n      computeOptionValue = o => o;\n    }\n\n    return createElement(Fragment, null, createElement(\"div\", _extends({\n      className: classnames('ct-control', className, optionClassName, {}),\n      \"data-design\": actualDesignType\n    }, option.divider ? {\n      'data-divider': option.divider\n    } : {}, _objectSpread({}, isOptionResponsiveFor(option) && !isOptionEnabledFor(device, option.responsive) || option.state === 'disabled' ? {\n      'data-state': 'disabled'\n    } : {}), _objectSpread(_objectSpread({}, optionAdditionalWrapperAttr), additionalWrapperAttr)), createElement(\"header\", null, maybeLabel && createElement(\"label\", null, maybeLabel), option.type !== 'ct-image-picker' && option.type !== 'ct-layers' && option.type !== 'ct-image-uploader' && option.type !== 'ct-panel' && hasRevertButton && !option.disableRevertButton && createElement(\"button\", {\n      type: \"button\",\n      disabled: deepEqual(computeOptionValue(option.value), renderingConfig.getValueForRevert ? renderingConfig.getValueForRevert({\n        value,\n        option,\n        values,\n        device\n      }) : optionWithDefault({\n        value,\n        option\n      })),\n      className: \"ct-revert\",\n      onClick: () => {\n        if (renderingConfig.performRevert) {\n          renderingConfig.performRevert({\n            onChangeFor\n          });\n        }\n\n        onChangeWithMobileBridge(option.value);\n      }\n    }), createElement(LabelToolbar, {\n      option,\n      value: valueWithResponsive,\n      id,\n      onChange: onChangeWithResponsiveBridge\n    }), isOptionResponsiveFor(option, {\n      ignoreHidden: true\n    }) && actualDesignType.indexOf('block') > -1 && !option.skipResponsiveControls && createElement(ResponsiveControls, {\n      device: device,\n      responsiveDescriptor: option.responsive,\n      setDevice: setDevice\n    })), isOptionResponsiveFor(option) && !isOptionEnabledFor(device, option.responsive) && createElement(\"div\", {\n      className: \"ct-disabled-notification\"\n    }, option.disabledDeviceMessage || __(\"Option can't be edited for current device\", 'blocksy')), (isOptionResponsiveFor(option) && isOptionEnabledFor(device, option.responsive) || !isOptionResponsiveFor(option)) && createElement(Fragment, null, createElement(\"section\", _extends({}, option.sectionAttr || {}, {\n      className: classnames({\n        'ct-responsive-container': isOptionResponsiveFor(option, {\n          ignoreHidden: true\n        }) && actualDesignType === 'inline'\n      }, sectionClassName({\n        design: actualDesignType,\n        option\n      }), (option.sectionAttr || {}).class || '')\n    }), isOptionResponsiveFor(option, {\n      ignoreHidden: true\n    }) && actualDesignType === 'inline' && createElement(ResponsiveControls, {\n      device: device,\n      responsiveDescriptor: option.responsive,\n      setDevice: setDevice\n    }), OptionComponentWithoutDesign, maybeLink && createElement(\"a\", _extends({\n      dangerouslySetInnerHTML: {\n        __html: maybeLink\n      }\n    }, option.linkAttr || {}))), createElement(ControlEnd, null), maybeDesc && createElement(\"div\", {\n      dangerouslySetInnerHTML: {\n        __html: maybeDesc\n      },\n      className: \"ct-option-description\"\n    }))));\n  };\n\n  return OptionMetaWrapper ? createElement(OptionMetaWrapper, {\n    id: id,\n    option: option,\n    value: valueWithResponsive,\n    onChangeFor: onChangeFor,\n    values: values,\n    getActualOption: getActualOption\n  }) : getActualOption();\n};\n\nexport default GenericOptionType;"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///6095\n")},7429:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n "Z": () => (/* binding */ options_OptionsPanel)\n});\n\n// EXTERNAL MODULE: external "window.wp.element"\nvar external_window_wp_element_ = __webpack_require__(1381);\n// EXTERNAL MODULE: ./static/js/options/GenericOptionType.js\nvar GenericOptionType = __webpack_require__(6095);\n// EXTERNAL MODULE: ./node_modules/match-conditions/dist/index.es.js\nvar index_es = __webpack_require__(7465);\n// EXTERNAL MODULE: ./static/js/customizer/components/useDeviceManager.js\nvar useDeviceManager = __webpack_require__(5458);\n;// CONCATENATED MODULE: ./static/js/options/containers/use-force-update.js\n\n\nconst reducer = (state, _) => !state;\n\nconst useForceUpdate = () => {\n const [, dispatch] = (0,external_window_wp_element_.useReducer)(reducer, true);\n const memoizedDispatch = (0,external_window_wp_element_.useMemo)(() => () => {\n dispatch(null);\n }, [dispatch]);\n return memoizedDispatch;\n};\n\n/* harmony default export */ const use_force_update = (useForceUpdate);\n;// CONCATENATED MODULE: ./static/js/options/containers/Condition.js\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\nconst Condition = _ref => {\n let {\n renderingChunk,\n value,\n onChange,\n purpose,\n parentValue,\n hasRevertButton\n } = _ref;\n const forceUpdate = use_force_update();\n const {\n currentView\n } = (0,useDeviceManager/* useDeviceManagerState */.$M)();\n (0,external_window_wp_element_.useEffect)(() => {\n renderingChunk.map(conditionOption => conditionOption.global && Object.keys(conditionOption.condition).map(key => wp.customize(key, val => val.bind(to => setTimeout(() => forceUpdate())))));\n }, []);\n return renderingChunk.map(conditionOption => {\n let valueForCondition = null;\n\n if (conditionOption.values_source === \'global\') {\n let allReplaces = Array.isArray(conditionOption.perform_replace) ? conditionOption.perform_replace : [conditionOption.perform_replace];\n\n let conditionToWatch = _objectSpread(_objectSpread({}, conditionOption.condition), conditionOption.perform_replace ? (Array.isArray(conditionOption.perform_replace) ? conditionOption.perform_replace : [conditionOption.perform_replace]).reduce((res, singleReplace) => {\n return _objectSpread(_objectSpread({}, res), conditionOption.perform_replace.condition);\n }, {}) : {});\n\n valueForCondition = Object.keys(conditionToWatch).reduce((current, key) => _objectSpread(_objectSpread({}, current), {}, {\n [key]: wp.customize(key)()\n }), {});\n }\n\n if (conditionOption.values_source === \'parent\') {\n valueForCondition = parentValue;\n }\n\n if (!valueForCondition) {\n valueForCondition = _objectSpread(_objectSpread({}, value), {}, {\n wp_customizer_current_view: currentView\n });\n }\n\n if (conditionOption.perform_replace) {\n let allReplaces = Array.isArray(conditionOption.perform_replace) ? conditionOption.perform_replace : [conditionOption.perform_replace];\n allReplaces.map(singleReplace => {\n let conditionReplaceMatches = (0,index_es/* matchValuesWithCondition */.Nj)((0,index_es/* normalizeCondition */.KY)(singleReplace.condition), valueForCondition);\n\n if (conditionReplaceMatches && valueForCondition[singleReplace.key] && valueForCondition[singleReplace.key] === singleReplace.from) {\n valueForCondition[singleReplace.key] = singleReplace.to;\n }\n });\n }\n\n let conditionMatches = (0,index_es/* matchValuesWithCondition */.Nj)((0,index_es/* normalizeCondition */.KY)(conditionOption.condition), valueForCondition);\n return conditionMatches ? (0,external_window_wp_element_.createElement)(options_OptionsPanel, {\n purpose: purpose,\n key: conditionOption.id,\n onChange: onChange,\n options: conditionOption.options,\n value: value,\n hasRevertButton: hasRevertButton,\n parentValue: parentValue\n }) : [];\n });\n};\n\n/* harmony default export */ const containers_Condition = (Condition);\n// EXTERNAL MODULE: ./node_modules/classnames/index.js\nvar classnames = __webpack_require__(4184);\nvar classnames_default = /*#__PURE__*/__webpack_require__.n(classnames);\n;// CONCATENATED MODULE: ./static/js/options/containers/Tabs.js\nfunction Tabs_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\nclass Tabs extends external_window_wp_element_.Component {\n constructor() {\n super(...arguments);\n\n Tabs_defineProperty(this, "state", {\n currentTab: 0\n });\n }\n\n render() {\n const filteredTabs = this.props.renderingChunk.filter(singleTab => !singleTab.condition || (0,index_es/* matchValuesWithCondition */.Nj)((0,index_es/* normalizeCondition */.KY)(singleTab.condition), this.props.value));\n const currentTab = filteredTabs[this.state.currentTab];\n return (0,external_window_wp_element_.createElement)("div", {\n className: "ct-tabs"\n }, (0,external_window_wp_element_.createElement)("ul", null, filteredTabs.map((singleTab, index) => ({\n singleTab,\n index\n })).map(_ref => {\n let {\n singleTab,\n index\n } = _ref;\n return (0,external_window_wp_element_.createElement)("li", {\n key: singleTab.id,\n onClick: () => this.setState({\n currentTab: index\n }),\n className: classnames_default()({\n active: index === this.state.currentTab\n })\n }, singleTab.title ? singleTab.title : singleTab.id);\n })), (0,external_window_wp_element_.createElement)("div", {\n className: "ct-current-tab"\n }, (0,external_window_wp_element_.createElement)(options_OptionsPanel, {\n purpose: this.props.purpose,\n key: currentTab.id,\n onChange: (key, val) => this.props.onChange(key, val),\n options: currentTab.options,\n value: this.props.value\n })));\n }\n\n}\n/*\nconst Condition = ({ renderingChunk, value, onChange }) =>\n\trenderingChunk.map(\n\t\tconditionOption =>\n\t\t\tmatchValuesWithCondition(\n\t\t\t\tnormalizeCondition(conditionOption.condition),\n\t\t\t\tvalue\n\t\t\t) ? (\n\t\t\t\t onChange({ ...value, ...val })}\n\t\t\t\t\toptions={conditionOption.options}\n\t\t\t\t\tvalue={value}\n\t\t\t\t/>\n\t\t\t) : (\n\t\t\t\t[]\n\t\t\t)\n\t)\n\nexport default Condition\n\n*/\n// EXTERNAL MODULE: ./static/js/customizer/components/responsive-controls.js\nvar responsive_controls = __webpack_require__(4616);\n;// CONCATENATED MODULE: ./static/js/options/containers/Group.js\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\n\n\n\n\n\n\nconst Group = _ref => {\n let {\n renderingChunk,\n value,\n onChange,\n purpose,\n hasRevertButton\n } = _ref;\n return renderingChunk.map(groupOption => {\n const {\n label,\n options,\n id,\n attr = {},\n wrapperAttr = {},\n responsive = false\n } = groupOption;\n const {\n currentView\n } = (0,useDeviceManager/* useDeviceManagerState */.$M)();\n const {\n setDevice\n } = (0,useDeviceManager/* useDeviceManagerActions */.Id)();\n const groupContents = (0,external_window_wp_element_.createElement)(options_OptionsPanel, {\n purpose: purpose,\n onChange: onChange,\n options: options,\n value: value,\n hasRevertButton: hasRevertButton\n });\n return (0,external_window_wp_element_.createElement)("div", _extends({\n key: id,\n className: "ct-controls-group"\n }, wrapperAttr), label && (0,external_window_wp_element_.createElement)("header", null, (0,external_window_wp_element_.createElement)("label", null, label), responsive && (0,external_window_wp_element_.createElement)(responsive_controls/* default */.ZP, {\n device: currentView,\n responsiveDescriptor: responsive,\n setDevice: setDevice\n })), (0,external_window_wp_element_.createElement)("section", _extends({}, attr, currentView !== \'desktop\' ? {\n \'data-disabled-last\': \'\'\n } : {}), groupContents));\n });\n};\n\n/* harmony default export */ const containers_Group = (Group);\n// EXTERNAL MODULE: ./node_modules/deep-equal/index.js\nvar deep_equal = __webpack_require__(251);\nvar deep_equal_default = /*#__PURE__*/__webpack_require__.n(deep_equal);\n// EXTERNAL MODULE: ./static/js/options/helpers/get-label.js\nvar get_label = __webpack_require__(7493);\n;// CONCATENATED MODULE: ./static/js/options/containers/LabeledGroup.js\nfunction LabeledGroup_extends() { LabeledGroup_extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return LabeledGroup_extends.apply(this, arguments); }\n\nfunction LabeledGroup_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction LabeledGroup_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? LabeledGroup_ownKeys(Object(source), !0).forEach(function (key) { LabeledGroup_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : LabeledGroup_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction LabeledGroup_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\n\n\n\nconst SingleChoice = _ref => {\n let {\n singleChoice,\n groupOption,\n purpose,\n onChange,\n value,\n hasRevertButton,\n parentValue\n } = _ref;\n return (0,external_window_wp_element_.createElement)("div", {\n key: singleChoice.id,\n className: "ct-labeled-group-item"\n }, singleChoice.label && (0,external_window_wp_element_.createElement)("label", null, singleChoice.label), (0,external_window_wp_element_.createElement)(options_OptionsPanel, {\n purpose: purpose,\n key: groupOption.id,\n onChange: onChange,\n options: {\n [singleChoice.id]: LabeledGroup_objectSpread(LabeledGroup_objectSpread({}, groupOption.options[singleChoice.id]), {}, {\n design: \'none\'\n })\n },\n value: value,\n hasRevertButton: hasRevertButton,\n parentValue: parentValue\n }));\n};\n\nconst LabeledGroup = _ref2 => {\n let {\n renderingChunk,\n value,\n onChange,\n purpose,\n parentValue,\n hasRevertButton\n } = _ref2;\n const {\n currentView\n } = (0,useDeviceManager/* useDeviceManagerState */.$M)();\n const {\n setDevice\n } = (0,useDeviceManager/* useDeviceManagerActions */.Id)();\n return renderingChunk.map(groupOption => {\n let valueForCondition = null;\n\n if (!valueForCondition) {\n valueForCondition = LabeledGroup_objectSpread(LabeledGroup_objectSpread({}, value), {}, {\n wp_customizer_current_view: currentView\n });\n }\n\n const totalAmountofMatched = groupOption.choices.filter(singleChoice => singleChoice.condition ? (0,index_es/* matchValuesWithCondition */.Nj)((0,index_es/* normalizeCondition */.KY)(singleChoice.condition), valueForCondition) : true);\n let maybeLabel = (0,get_label/* getOptionLabelFor */.m)({\n id: groupOption.id,\n option: groupOption,\n values: value\n });\n\n if (totalAmountofMatched.length === 0) {\n return null;\n }\n\n if (totalAmountofMatched.length === 1) {\n return (0,external_window_wp_element_.createElement)(options_OptionsPanel, {\n purpose: purpose,\n onChange: onChange,\n key: groupOption.id,\n options: {\n [groupOption.choices[0].id]: LabeledGroup_objectSpread(LabeledGroup_objectSpread({}, groupOption.options[groupOption.choices[0].id]), groupOption.divider ? {\n divider: groupOption.divider\n } : {})\n },\n value: value,\n hasRevertButton: hasRevertButton,\n parentValue: parentValue\n });\n }\n\n return (0,external_window_wp_element_.createElement)("div", LabeledGroup_extends({\n className: "ct-control",\n "data-design": "block"\n }, groupOption.divider ? {\n \'data-divider\': groupOption.divider\n } : {}), (0,external_window_wp_element_.createElement)("header", null, maybeLabel && (0,external_window_wp_element_.createElement)("label", null, maybeLabel), (0,external_window_wp_element_.createElement)("button", {\n type: "button",\n disabled: groupOption.choices.every(_ref3 => {\n let {\n id\n } = _ref3;\n return deep_equal_default()(groupOption.options[id].value, (0,GenericOptionType/* optionWithDefault */.y1)({\n value: value[id],\n option: groupOption.options[id]\n }));\n }),\n className: "ct-revert",\n onClick: () => {\n groupOption.choices.reduce((previousPromise, nextChoice) => {\n return previousPromise.then(() => {\n return new Promise(r => {\n setTimeout(() => {\n onChange(nextChoice.id, groupOption.options[nextChoice.id].value);\n r();\n });\n });\n });\n }, Promise.resolve());\n }\n }), groupOption.responsive && (0,external_window_wp_element_.createElement)(responsive_controls/* default */.ZP, {\n device: currentView,\n responsiveDescriptor: groupOption.responsive,\n setDevice: setDevice\n })), (0,external_window_wp_element_.createElement)("section", {\n className: "ct-labeled-group"\n }, totalAmountofMatched.map(singleChoice => (0,external_window_wp_element_.createElement)(SingleChoice, {\n key: singleChoice.id,\n singleChoice: singleChoice,\n groupOption: groupOption,\n purpose: purpose,\n onChange: onChange,\n value: value,\n hasRevertButton: hasRevertButton,\n parentValue: parentValue\n }))));\n });\n};\n\n/* harmony default export */ const containers_LabeledGroup = (LabeledGroup);\n;// CONCATENATED MODULE: ./static/js/options/containers/ct-has-meta-category-button.js\n\n\n\nconst ct_has_meta_category_button_Group = _ref => {\n let {\n renderingChunk,\n value,\n onChange,\n purpose,\n hasRevertButton\n } = _ref;\n return renderingChunk.map(conditionOption => {\n const {\n label,\n options,\n id,\n attr = {},\n responsive = false,\n optionId\n } = conditionOption;\n\n if (value[optionId].find(_ref2 => {\n let {\n id,\n enabled,\n meta_elements\n } = _ref2;\n return enabled && (id === \'post_meta\' || id === \'custom_meta\') && (meta_elements || []).find(_ref3 => {\n let {\n id,\n style\n } = _ref3;\n return (id === \'categories\' || id === \'tags\') && style === \'pill\';\n });\n })) {\n return (0,external_window_wp_element_.createElement)(options_OptionsPanel, {\n purpose: purpose,\n onChange: onChange,\n options: options,\n value: value,\n hasRevertButton: hasRevertButton\n });\n }\n\n return null;\n });\n};\n\n/* harmony default export */ const ct_has_meta_category_button = (ct_has_meta_category_button_Group);\n;// CONCATENATED MODULE: ./static/js/options/GenericContainerType.js\n\n\n\n\n\n\n\nconst GenericContainerType = _ref => {\n let {\n value,\n renderingChunk,\n onChange,\n parentValue,\n purpose,\n hasRevertButton\n } = _ref;\n let Container = null;\n\n if (renderingChunk[0].type === \'ct-has-meta-category-button\') {\n Container = ct_has_meta_category_button;\n }\n\n if (renderingChunk[0].type === \'ct-condition\') {\n Container = containers_Condition;\n }\n\n if (renderingChunk[0].type === \'tab\') {\n Container = Tabs;\n }\n\n if (renderingChunk[0].type === \'ct-group\') {\n Container = containers_Group;\n }\n\n if (renderingChunk[0].type === \'ct-labeled-group\') {\n Container = containers_LabeledGroup;\n }\n\n if (Container) {\n return (0,external_window_wp_element_.createElement)(Container, {\n purpose: purpose,\n onChange: onChange,\n value: value,\n renderingChunk: renderingChunk,\n hasRevertButton: hasRevertButton,\n parentValue: parentValue\n });\n }\n\n return (0,external_window_wp_element_.createElement)("div", null, "Unknown container type.");\n};\n\n/* harmony default export */ const options_GenericContainerType = (GenericContainerType);\n// EXTERNAL MODULE: ./static/js/options/helpers/get-value-from-input.js\nvar get_value_from_input = __webpack_require__(7069);\n;// CONCATENATED MODULE: ./static/js/options/OptionsPanel.js\nfunction OptionsPanel_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction OptionsPanel_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? OptionsPanel_ownKeys(Object(source), !0).forEach(function (key) { OptionsPanel_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : OptionsPanel_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction OptionsPanel_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\nconst OptionsPanel = props => {\n let {\n options,\n value,\n onChange,\n // default | customizer\n purpose = \'default\',\n hasRevertButton = true,\n renderOptions = null,\n parentValue\n } = props;\n\n if (renderOptions) {\n return renderOptions({\n value,\n onChange\n });\n }\n\n let SlotFillProvider = null;\n\n if (window.wp.components) {\n SlotFillProvider = window.wp.components.SlotFillProvider;\n }\n\n const renderingChunks = (0,external_window_wp_element_.useMemo)(() => {\n const localOptions = (0,get_value_from_input/* flattenOptions */.UO)(options);\n return [...(localOptions.__CT_KEYS_ORDER__ ? Object.keys(localOptions.__CT_KEYS_ORDER__).map(orderKey => parseInt(orderKey, 10)).sort((a, b) => a - b).map(orderKey => localOptions.__CT_KEYS_ORDER__[orderKey]) : Object.keys(localOptions))].filter(id => id !== \'__CT_KEYS_ORDER__\').map(id => OptionsPanel_objectSpread(OptionsPanel_objectSpread({}, localOptions[id]), {}, {\n id\n })).reduce((chunksHolder, currentOptionDescriptor, index) => {\n if (chunksHolder.length === 0) {\n return [[currentOptionDescriptor]];\n }\n\n let lastChunk = chunksHolder[chunksHolder.length - 1];\n\n if ((lastChunk[0].options && lastChunk[0].type === currentOptionDescriptor.type || currentOptionDescriptor.type === \'ct-tab-group\' || currentOptionDescriptor.type === \'ct-tab-group-sync\') &&\n /**\n * Do not group rendering chunks for boxes\n */\n currentOptionDescriptor.type !== \'box\' &&\n /**\n * Do not group rendering chunks for ct-popup\'s\n */\n currentOptionDescriptor.type !== \'ct-popup\') {\n return [...chunksHolder.slice(0, -1), [...lastChunk, currentOptionDescriptor]];\n }\n\n return [...chunksHolder, [currentOptionDescriptor]];\n }, []);\n }, [options]);\n let finalResult = renderingChunks.map(renderingChunk => {\n /**\n * We are dealing with a container\n */\n if (renderingChunk[0].options || renderingChunk[0].type === \'ct-tab-group-sync\') {\n return (0,external_window_wp_element_.createElement)(options_GenericContainerType, {\n key: renderingChunk[0].id,\n value: value,\n parentValue: parentValue,\n renderingChunk: renderingChunk,\n onChange: onChange,\n purpose: purpose,\n hasRevertButton: hasRevertButton\n });\n }\n /**\n * We have a regular option type here\n */\n\n\n return (0,external_window_wp_element_.createElement)(GenericOptionType/* default */.ZP, {\n hasRevertButton: hasRevertButton,\n purpose: purpose,\n key: renderingChunk[0].id,\n id: renderingChunk[0].id,\n value: value[renderingChunk[0].id],\n values: value,\n option: renderingChunk[0],\n onChangeFor: (id, newValue) => onChange(id, newValue),\n onChange: newValue => onChange(renderingChunk[0].id, newValue)\n });\n });\n return window.wp.components ? (0,external_window_wp_element_.createElement)(SlotFillProvider, null, finalResult) : finalResult;\n};\n\n/* harmony default export */ const options_OptionsPanel = (OptionsPanel);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"7429.js","mappings":";;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC7EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACtEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;ACnDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACpDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./static/js/options/containers/use-force-update.js?39cb","webpack://blocksyOptions/./static/js/options/containers/Condition.js?c052","webpack://blocksyOptions/./static/js/options/containers/Tabs.js?dafc","webpack://blocksyOptions/./static/js/options/containers/Group.js?a87a","webpack://blocksyOptions/./static/js/options/containers/LabeledGroup.js?b019","webpack://blocksyOptions/./static/js/options/containers/ct-has-meta-category-button.js?d30e","webpack://blocksyOptions/./static/js/options/GenericContainerType.js?5cc7","webpack://blocksyOptions/./static/js/options/OptionsPanel.js?1ef0"],"sourcesContent":["import { useMemo, useReducer } from '@wordpress/element';\n\nconst reducer = (state, _) => !state;\n\nconst useForceUpdate = () => {\n  const [, dispatch] = useReducer(reducer, true);\n  const memoizedDispatch = useMemo(() => () => {\n    dispatch(null);\n  }, [dispatch]);\n  return memoizedDispatch;\n};\n\nexport default useForceUpdate;","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, useMemo, useEffect } from '@wordpress/element';\nimport OptionsPanel from '../OptionsPanel';\nimport { normalizeCondition, matchValuesWithCondition } from 'match-conditions';\nimport { useDeviceManagerState } from '../../customizer/components/useDeviceManager';\nimport useForceUpdate from './use-force-update';\n\nconst Condition = _ref => {\n  let {\n    renderingChunk,\n    value,\n    onChange,\n    purpose,\n    parentValue,\n    hasRevertButton\n  } = _ref;\n  const forceUpdate = useForceUpdate();\n  const {\n    currentView\n  } = useDeviceManagerState();\n  useEffect(() => {\n    renderingChunk.map(conditionOption => conditionOption.global && Object.keys(conditionOption.condition).map(key => wp.customize(key, val => val.bind(to => setTimeout(() => forceUpdate())))));\n  }, []);\n  return renderingChunk.map(conditionOption => {\n    let valueForCondition = null;\n\n    if (conditionOption.values_source === 'global') {\n      let allReplaces = Array.isArray(conditionOption.perform_replace) ? conditionOption.perform_replace : [conditionOption.perform_replace];\n\n      let conditionToWatch = _objectSpread(_objectSpread({}, conditionOption.condition), conditionOption.perform_replace ? (Array.isArray(conditionOption.perform_replace) ? conditionOption.perform_replace : [conditionOption.perform_replace]).reduce((res, singleReplace) => {\n        return _objectSpread(_objectSpread({}, res), conditionOption.perform_replace.condition);\n      }, {}) : {});\n\n      valueForCondition = Object.keys(conditionToWatch).reduce((current, key) => _objectSpread(_objectSpread({}, current), {}, {\n        [key]: wp.customize(key)()\n      }), {});\n    }\n\n    if (conditionOption.values_source === 'parent') {\n      valueForCondition = parentValue;\n    }\n\n    if (!valueForCondition) {\n      valueForCondition = _objectSpread(_objectSpread({}, value), {}, {\n        wp_customizer_current_view: currentView\n      });\n    }\n\n    if (conditionOption.perform_replace) {\n      let allReplaces = Array.isArray(conditionOption.perform_replace) ? conditionOption.perform_replace : [conditionOption.perform_replace];\n      allReplaces.map(singleReplace => {\n        let conditionReplaceMatches = matchValuesWithCondition(normalizeCondition(singleReplace.condition), valueForCondition);\n\n        if (conditionReplaceMatches && valueForCondition[singleReplace.key] && valueForCondition[singleReplace.key] === singleReplace.from) {\n          valueForCondition[singleReplace.key] = singleReplace.to;\n        }\n      });\n    }\n\n    let conditionMatches = matchValuesWithCondition(normalizeCondition(conditionOption.condition), valueForCondition);\n    return conditionMatches ? createElement(OptionsPanel, {\n      purpose: purpose,\n      key: conditionOption.id,\n      onChange: onChange,\n      options: conditionOption.options,\n      value: value,\n      hasRevertButton: hasRevertButton,\n      parentValue: parentValue\n    }) : [];\n  });\n};\n\nexport default Condition;","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, Fragment, Component } from '@wordpress/element';\nimport OptionsPanel from '../OptionsPanel';\nimport classnames from 'classnames';\nimport { normalizeCondition, matchValuesWithCondition } from 'match-conditions';\nexport default class Tabs extends Component {\n  constructor() {\n    super(...arguments);\n\n    _defineProperty(this, \"state\", {\n      currentTab: 0\n    });\n  }\n\n  render() {\n    const filteredTabs = this.props.renderingChunk.filter(singleTab => !singleTab.condition || matchValuesWithCondition(normalizeCondition(singleTab.condition), this.props.value));\n    const currentTab = filteredTabs[this.state.currentTab];\n    return createElement(\"div\", {\n      className: \"ct-tabs\"\n    }, createElement(\"ul\", null, filteredTabs.map((singleTab, index) => ({\n      singleTab,\n      index\n    })).map(_ref => {\n      let {\n        singleTab,\n        index\n      } = _ref;\n      return createElement(\"li\", {\n        key: singleTab.id,\n        onClick: () => this.setState({\n          currentTab: index\n        }),\n        className: classnames({\n          active: index === this.state.currentTab\n        })\n      }, singleTab.title ? singleTab.title : singleTab.id);\n    })), createElement(\"div\", {\n      className: \"ct-current-tab\"\n    }, createElement(OptionsPanel, {\n      purpose: this.props.purpose,\n      key: currentTab.id,\n      onChange: (key, val) => this.props.onChange(key, val),\n      options: currentTab.options,\n      value: this.props.value\n    })));\n  }\n\n}\n/*\nconst Condition = ({ renderingChunk, value, onChange }) =>\n\trenderingChunk.map(\n\t\tconditionOption =>\n\t\t\tmatchValuesWithCondition(\n\t\t\t\tnormalizeCondition(conditionOption.condition),\n\t\t\t\tvalue\n\t\t\t) ? (\n\t\t\t\t<OptionsPanel\n\t\t\t\t\tkey={conditionOption.id}\n\t\t\t\t\tonChange={val => onChange({ ...value, ...val })}\n\t\t\t\t\toptions={conditionOption.options}\n\t\t\t\t\tvalue={value}\n\t\t\t\t/>\n\t\t\t) : (\n\t\t\t\t[]\n\t\t\t)\n\t)\n\nexport default Condition\n\n*/","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport { createElement, Fragment } from '@wordpress/element';\nimport OptionsPanel from '../OptionsPanel';\nimport { capitalizeFirstLetter } from '../GenericOptionType';\nimport { useDeviceManagerState, useDeviceManagerActions } from '../../customizer/components/useDeviceManager';\nimport ResponsiveControls from '../../customizer/components/responsive-controls';\n\nconst Group = _ref => {\n  let {\n    renderingChunk,\n    value,\n    onChange,\n    purpose,\n    hasRevertButton\n  } = _ref;\n  return renderingChunk.map(groupOption => {\n    const {\n      label,\n      options,\n      id,\n      attr = {},\n      wrapperAttr = {},\n      responsive = false\n    } = groupOption;\n    const {\n      currentView\n    } = useDeviceManagerState();\n    const {\n      setDevice\n    } = useDeviceManagerActions();\n    const groupContents = createElement(OptionsPanel, {\n      purpose: purpose,\n      onChange: onChange,\n      options: options,\n      value: value,\n      hasRevertButton: hasRevertButton\n    });\n    return createElement(\"div\", _extends({\n      key: id,\n      className: \"ct-controls-group\"\n    }, wrapperAttr), label && createElement(\"header\", null, createElement(\"label\", null, label), responsive && createElement(ResponsiveControls, {\n      device: currentView,\n      responsiveDescriptor: responsive,\n      setDevice: setDevice\n    })), createElement(\"section\", _extends({}, attr, currentView !== 'desktop' ? {\n      'data-disabled-last': ''\n    } : {}), groupContents));\n  });\n};\n\nexport default Group;","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, useMemo, useRef, useEffect, useContext } from '@wordpress/element';\nimport OptionsPanel from '../OptionsPanel';\nimport { normalizeCondition, matchValuesWithCondition } from 'match-conditions';\nimport { useDeviceManagerState, useDeviceManagerActions } from '../../customizer/components/useDeviceManager';\nimport { capitalizeFirstLetter, optionWithDefault } from '../GenericOptionType';\nimport deepEqual from 'deep-equal';\nimport ResponsiveControls from '../../customizer/components/responsive-controls';\nimport { getOptionLabelFor } from '../helpers/get-label';\n\nconst SingleChoice = _ref => {\n  let {\n    singleChoice,\n    groupOption,\n    purpose,\n    onChange,\n    value,\n    hasRevertButton,\n    parentValue\n  } = _ref;\n  return createElement(\"div\", {\n    key: singleChoice.id,\n    className: \"ct-labeled-group-item\"\n  }, singleChoice.label && createElement(\"label\", null, singleChoice.label), createElement(OptionsPanel, {\n    purpose: purpose,\n    key: groupOption.id,\n    onChange: onChange,\n    options: {\n      [singleChoice.id]: _objectSpread(_objectSpread({}, groupOption.options[singleChoice.id]), {}, {\n        design: 'none'\n      })\n    },\n    value: value,\n    hasRevertButton: hasRevertButton,\n    parentValue: parentValue\n  }));\n};\n\nconst LabeledGroup = _ref2 => {\n  let {\n    renderingChunk,\n    value,\n    onChange,\n    purpose,\n    parentValue,\n    hasRevertButton\n  } = _ref2;\n  const {\n    currentView\n  } = useDeviceManagerState();\n  const {\n    setDevice\n  } = useDeviceManagerActions();\n  return renderingChunk.map(groupOption => {\n    let valueForCondition = null;\n\n    if (!valueForCondition) {\n      valueForCondition = _objectSpread(_objectSpread({}, value), {}, {\n        wp_customizer_current_view: currentView\n      });\n    }\n\n    const totalAmountofMatched = groupOption.choices.filter(singleChoice => singleChoice.condition ? matchValuesWithCondition(normalizeCondition(singleChoice.condition), valueForCondition) : true);\n    let maybeLabel = getOptionLabelFor({\n      id: groupOption.id,\n      option: groupOption,\n      values: value\n    });\n\n    if (totalAmountofMatched.length === 0) {\n      return null;\n    }\n\n    if (totalAmountofMatched.length === 1) {\n      return createElement(OptionsPanel, {\n        purpose: purpose,\n        onChange: onChange,\n        key: groupOption.id,\n        options: {\n          [groupOption.choices[0].id]: _objectSpread(_objectSpread({}, groupOption.options[groupOption.choices[0].id]), groupOption.divider ? {\n            divider: groupOption.divider\n          } : {})\n        },\n        value: value,\n        hasRevertButton: hasRevertButton,\n        parentValue: parentValue\n      });\n    }\n\n    return createElement(\"div\", _extends({\n      className: \"ct-control\",\n      \"data-design\": \"block\"\n    }, groupOption.divider ? {\n      'data-divider': groupOption.divider\n    } : {}), createElement(\"header\", null, maybeLabel && createElement(\"label\", null, maybeLabel), createElement(\"button\", {\n      type: \"button\",\n      disabled: groupOption.choices.every(_ref3 => {\n        let {\n          id\n        } = _ref3;\n        return deepEqual(groupOption.options[id].value, optionWithDefault({\n          value: value[id],\n          option: groupOption.options[id]\n        }));\n      }),\n      className: \"ct-revert\",\n      onClick: () => {\n        groupOption.choices.reduce((previousPromise, nextChoice) => {\n          return previousPromise.then(() => {\n            return new Promise(r => {\n              setTimeout(() => {\n                onChange(nextChoice.id, groupOption.options[nextChoice.id].value);\n                r();\n              });\n            });\n          });\n        }, Promise.resolve());\n      }\n    }), groupOption.responsive && createElement(ResponsiveControls, {\n      device: currentView,\n      responsiveDescriptor: groupOption.responsive,\n      setDevice: setDevice\n    })), createElement(\"section\", {\n      className: \"ct-labeled-group\"\n    }, totalAmountofMatched.map(singleChoice => createElement(SingleChoice, {\n      key: singleChoice.id,\n      singleChoice: singleChoice,\n      groupOption: groupOption,\n      purpose: purpose,\n      onChange: onChange,\n      value: value,\n      hasRevertButton: hasRevertButton,\n      parentValue: parentValue\n    }))));\n  });\n};\n\nexport default LabeledGroup;","import { createElement, Fragment } from '@wordpress/element';\nimport OptionsPanel from '../OptionsPanel';\n\nconst Group = _ref => {\n  let {\n    renderingChunk,\n    value,\n    onChange,\n    purpose,\n    hasRevertButton\n  } = _ref;\n  return renderingChunk.map(conditionOption => {\n    const {\n      label,\n      options,\n      id,\n      attr = {},\n      responsive = false,\n      optionId\n    } = conditionOption;\n\n    if (value[optionId].find(_ref2 => {\n      let {\n        id,\n        enabled,\n        meta_elements\n      } = _ref2;\n      return enabled && (id === 'post_meta' || id === 'custom_meta') && (meta_elements || []).find(_ref3 => {\n        let {\n          id,\n          style\n        } = _ref3;\n        return (id === 'categories' || id === 'tags') && style === 'pill';\n      });\n    })) {\n      return createElement(OptionsPanel, {\n        purpose: purpose,\n        onChange: onChange,\n        options: options,\n        value: value,\n        hasRevertButton: hasRevertButton\n      });\n    }\n\n    return null;\n  });\n};\n\nexport default Group;","import { createElement, Fragment } from '@wordpress/element';\nimport Condition from './containers/Condition';\nimport Tabs from './containers/Tabs';\nimport Group from './containers/Group';\nimport LabeledGroup from './containers/LabeledGroup';\nimport HasMetaCategoryButton from './containers/ct-has-meta-category-button';\n\nconst GenericContainerType = _ref => {\n  let {\n    value,\n    renderingChunk,\n    onChange,\n    parentValue,\n    purpose,\n    hasRevertButton\n  } = _ref;\n  let Container = null;\n\n  if (renderingChunk[0].type === 'ct-has-meta-category-button') {\n    Container = HasMetaCategoryButton;\n  }\n\n  if (renderingChunk[0].type === 'ct-condition') {\n    Container = Condition;\n  }\n\n  if (renderingChunk[0].type === 'tab') {\n    Container = Tabs;\n  }\n\n  if (renderingChunk[0].type === 'ct-group') {\n    Container = Group;\n  }\n\n  if (renderingChunk[0].type === 'ct-labeled-group') {\n    Container = LabeledGroup;\n  }\n\n  if (Container) {\n    return createElement(Container, {\n      purpose: purpose,\n      onChange: onChange,\n      value: value,\n      renderingChunk: renderingChunk,\n      hasRevertButton: hasRevertButton,\n      parentValue: parentValue\n    });\n  }\n\n  return createElement(\"div\", null, \"Unknown container type.\");\n};\n\nexport default GenericContainerType;","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, Component, Fragment, memo, useMemo } from '@wordpress/element';\nimport GenericOptionType from './GenericOptionType';\nimport GenericContainerType from './GenericContainerType';\nimport { flattenOptions } from './helpers/get-value-from-input';\n\nconst OptionsPanel = props => {\n  let {\n    options,\n    value,\n    onChange,\n    // default | customizer\n    purpose = 'default',\n    hasRevertButton = true,\n    renderOptions = null,\n    parentValue\n  } = props;\n\n  if (renderOptions) {\n    return renderOptions({\n      value,\n      onChange\n    });\n  }\n\n  let SlotFillProvider = null;\n\n  if (window.wp.components) {\n    SlotFillProvider = window.wp.components.SlotFillProvider;\n  }\n\n  const renderingChunks = useMemo(() => {\n    const localOptions = flattenOptions(options);\n    return [...(localOptions.__CT_KEYS_ORDER__ ? Object.keys(localOptions.__CT_KEYS_ORDER__).map(orderKey => parseInt(orderKey, 10)).sort((a, b) => a - b).map(orderKey => localOptions.__CT_KEYS_ORDER__[orderKey]) : Object.keys(localOptions))].filter(id => id !== '__CT_KEYS_ORDER__').map(id => _objectSpread(_objectSpread({}, localOptions[id]), {}, {\n      id\n    })).reduce((chunksHolder, currentOptionDescriptor, index) => {\n      if (chunksHolder.length === 0) {\n        return [[currentOptionDescriptor]];\n      }\n\n      let lastChunk = chunksHolder[chunksHolder.length - 1];\n\n      if ((lastChunk[0].options && lastChunk[0].type === currentOptionDescriptor.type || currentOptionDescriptor.type === 'ct-tab-group' || currentOptionDescriptor.type === 'ct-tab-group-sync') &&\n      /**\n       * Do not group rendering chunks for boxes\n       */\n      currentOptionDescriptor.type !== 'box' &&\n      /**\n       * Do not group rendering chunks for ct-popup's\n       */\n      currentOptionDescriptor.type !== 'ct-popup') {\n        return [...chunksHolder.slice(0, -1), [...lastChunk, currentOptionDescriptor]];\n      }\n\n      return [...chunksHolder, [currentOptionDescriptor]];\n    }, []);\n  }, [options]);\n  let finalResult = renderingChunks.map(renderingChunk => {\n    /**\n     * We are dealing with a container\n     */\n    if (renderingChunk[0].options || renderingChunk[0].type === 'ct-tab-group-sync') {\n      return createElement(GenericContainerType, {\n        key: renderingChunk[0].id,\n        value: value,\n        parentValue: parentValue,\n        renderingChunk: renderingChunk,\n        onChange: onChange,\n        purpose: purpose,\n        hasRevertButton: hasRevertButton\n      });\n    }\n    /**\n     * We have a regular option type here\n     */\n\n\n    return createElement(GenericOptionType, {\n      hasRevertButton: hasRevertButton,\n      purpose: purpose,\n      key: renderingChunk[0].id,\n      id: renderingChunk[0].id,\n      value: value[renderingChunk[0].id],\n      values: value,\n      option: renderingChunk[0],\n      onChangeFor: (id, newValue) => onChange(id, newValue),\n      onChange: newValue => onChange(renderingChunk[0].id, newValue)\n    });\n  });\n  return window.wp.components ? createElement(SlotFillProvider, null, finalResult) : finalResult;\n};\n\nexport default OptionsPanel;"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///7429\n')},6086:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"Z\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(6715);\n/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var ct_i18n__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(5652);\n/* harmony import */ var ct_i18n__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(ct_i18n__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(4184);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_3__);\n\n\n\n\n\nconst InputWithOnlyNumbers = _ref => {\n let {\n disabled,\n className = '',\n value,\n onBlur,\n onChange,\n step = 1,\n placeholder = (0,ct_i18n__WEBPACK_IMPORTED_MODULE_2__.__)('Default', 'blocksy')\n } = _ref;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"input\", {\n type: \"text\",\n value: value,\n onKeyDown: e => {\n // Allow: backspace, delete, tab, escape, enter and.\n if ( // Allow Esc\n [46, 8, 9, 27, 13, 110, 190, 27].indexOf(e.keyCode) > -1 || // Allow: Ctrl+A.\n e.keyCode == 65 && e.ctrlKey === true || // Allow -.\n e.keyCode == 109 || e.keyCode == 189 || e.keyCode == 173 || // Allow: Ctrl+C.\n e.keyCode == 67 && e.ctrlKey === true || // Allow: Ctrl+X.\n e.keyCode == 88 && e.ctrlKey === true || // Allow: home, end, left, right.\n e.keyCode >= 35 && e.keyCode <= 39 && e.keyCode !== 38 && e.keyCode !== 40) {\n // Let it happen, don't do anything.\n return;\n }\n\n let valueForComputation = '__unset__';\n\n if (value.toString().trim().length === 0) {\n valueForComputation = 0;\n } else {\n let maybeValue = parseFloat(value);\n\n if (maybeValue || maybeValue === 0) {\n valueForComputation = maybeValue;\n }\n }\n\n let actualStep = e.shiftKey ? step * 10 : step;\n /**\n * Arrow up\n */\n\n if (e.keyCode === 38 && value !== '__unset__') {\n onChange(valueForComputation + actualStep, true);\n }\n /**\n * Arrow down\n */\n\n\n if (e.keyCode === 40 && value !== '__unset__') {\n onChange(valueForComputation - actualStep, true);\n } // Ensure that it is a number and stop the keypress.\n\n\n if ((e.shiftKey || e.keyCode < 48 || e.keyCode > 57) && (e.keyCode < 96 || e.keyCode > 105)) {\n e.preventDefault();\n }\n },\n onChange: _ref2 => {\n let {\n target: {\n value\n }\n } = _ref2;\n return onChange(value);\n },\n placeholder: placeholder,\n onBlur: () => onBlur && onBlur,\n className: classnames__WEBPACK_IMPORTED_MODULE_3___default()({\n inactive: value === 'auto'\n })\n });\n};\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (InputWithOnlyNumbers);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNjA4Ni5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9zdGF0aWMvanMvb3B0aW9ucy9jb21wb25lbnRzL0lucHV0V2l0aE9ubHlOdW1iZXJzLmpzPzliY2MiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3JlYXRlRWxlbWVudCwgQ29tcG9uZW50IH0gZnJvbSAnQHdvcmRwcmVzcy9lbGVtZW50JztcbmltcG9ydCBfIGZyb20gJ3VuZGVyc2NvcmUnO1xuaW1wb3J0IHsgX18gfSBmcm9tICdjdC1pMThuJztcbmltcG9ydCBjbHMgZnJvbSAnY2xhc3NuYW1lcyc7XG5cbmNvbnN0IElucHV0V2l0aE9ubHlOdW1iZXJzID0gX3JlZiA9PiB7XG4gIGxldCB7XG4gICAgZGlzYWJsZWQsXG4gICAgY2xhc3NOYW1lID0gJycsXG4gICAgdmFsdWUsXG4gICAgb25CbHVyLFxuICAgIG9uQ2hhbmdlLFxuICAgIHN0ZXAgPSAxLFxuICAgIHBsYWNlaG9sZGVyID0gX18oJ0RlZmF1bHQnLCAnYmxvY2tzeScpXG4gIH0gPSBfcmVmO1xuICByZXR1cm4gY3JlYXRlRWxlbWVudChcImlucHV0XCIsIHtcbiAgICB0eXBlOiBcInRleHRcIixcbiAgICB2YWx1ZTogdmFsdWUsXG4gICAgb25LZXlEb3duOiBlID0+IHtcbiAgICAgIC8vIEFsbG93OiBiYWNrc3BhY2UsIGRlbGV0ZSwgdGFiLCBlc2NhcGUsIGVudGVyIGFuZC5cbiAgICAgIGlmICggLy8gQWxsb3cgRXNjXG4gICAgICBbNDYsIDgsIDksIDI3LCAxMywgMTEwLCAxOTAsIDI3XS5pbmRleE9mKGUua2V5Q29kZSkgPiAtMSB8fCAvLyBBbGxvdzogQ3RybCtBLlxuICAgICAgZS5rZXlDb2RlID09IDY1ICYmIGUuY3RybEtleSA9PT0gdHJ1ZSB8fCAvLyBBbGxvdyAtLlxuICAgICAgZS5rZXlDb2RlID09IDEwOSB8fCBlLmtleUNvZGUgPT0gMTg5IHx8IGUua2V5Q29kZSA9PSAxNzMgfHwgLy8gQWxsb3c6IEN0cmwrQy5cbiAgICAgIGUua2V5Q29kZSA9PSA2NyAmJiBlLmN0cmxLZXkgPT09IHRydWUgfHwgLy8gQWxsb3c6IEN0cmwrWC5cbiAgICAgIGUua2V5Q29kZSA9PSA4OCAmJiBlLmN0cmxLZXkgPT09IHRydWUgfHwgLy8gQWxsb3c6IGhvbWUsIGVuZCwgbGVmdCwgcmlnaHQuXG4gICAgICBlLmtleUNvZGUgPj0gMzUgJiYgZS5rZXlDb2RlIDw9IDM5ICYmIGUua2V5Q29kZSAhPT0gMzggJiYgZS5rZXlDb2RlICE9PSA0MCkge1xuICAgICAgICAvLyBMZXQgaXQgaGFwcGVuLCBkb24ndCBkbyBhbnl0aGluZy5cbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuXG4gICAgICBsZXQgdmFsdWVGb3JDb21wdXRhdGlvbiA9ICdfX3Vuc2V0X18nO1xuXG4gICAgICBpZiAodmFsdWUudG9TdHJpbmcoKS50cmltKCkubGVuZ3RoID09PSAwKSB7XG4gICAgICAgIHZhbHVlRm9yQ29tcHV0YXRpb24gPSAwO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgbGV0IG1heWJlVmFsdWUgPSBwYXJzZUZsb2F0KHZhbHVlKTtcblxuICAgICAgICBpZiAobWF5YmVWYWx1ZSB8fCBtYXliZVZhbHVlID09PSAwKSB7XG4gICAgICAgICAgdmFsdWVGb3JDb21wdXRhdGlvbiA9IG1heWJlVmFsdWU7XG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgbGV0IGFjdHVhbFN0ZXAgPSBlLnNoaWZ0S2V5ID8gc3RlcCAqIDEwIDogc3RlcDtcbiAgICAgIC8qKlxuICAgICAgICogQXJyb3cgdXBcbiAgICAgICAqL1xuXG4gICAgICBpZiAoZS5rZXlDb2RlID09PSAzOCAmJiB2YWx1ZSAhPT0gJ19fdW5zZXRfXycpIHtcbiAgICAgICAgb25DaGFuZ2UodmFsdWVGb3JDb21wdXRhdGlvbiArIGFjdHVhbFN0ZXAsIHRydWUpO1xuICAgICAgfVxuICAgICAgLyoqXG4gICAgICAgKiBBcnJvdyBkb3duXG4gICAgICAgKi9cblxuXG4gICAgICBpZiAoZS5rZXlDb2RlID09PSA0MCAmJiB2YWx1ZSAhPT0gJ19fdW5zZXRfXycpIHtcbiAgICAgICAgb25DaGFuZ2UodmFsdWVGb3JDb21wdXRhdGlvbiAtIGFjdHVhbFN0ZXAsIHRydWUpO1xuICAgICAgfSAvLyBFbnN1cmUgdGhhdCBpdCBpcyBhIG51bWJlciBhbmQgc3RvcCB0aGUga2V5cHJlc3MuXG5cblxuICAgICAgaWYgKChlLnNoaWZ0S2V5IHx8IGUua2V5Q29kZSA8IDQ4IHx8IGUua2V5Q29kZSA+IDU3KSAmJiAoZS5rZXlDb2RlIDwgOTYgfHwgZS5rZXlDb2RlID4gMTA1KSkge1xuICAgICAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgICB9XG4gICAgfSxcbiAgICBvbkNoYW5nZTogX3JlZjIgPT4ge1xuICAgICAgbGV0IHtcbiAgICAgICAgdGFyZ2V0OiB7XG4gICAgICAgICAgdmFsdWVcbiAgICAgICAgfVxuICAgICAgfSA9IF9yZWYyO1xuICAgICAgcmV0dXJuIG9uQ2hhbmdlKHZhbHVlKTtcbiAgICB9LFxuICAgIHBsYWNlaG9sZGVyOiBwbGFjZWhvbGRlcixcbiAgICBvbkJsdXI6ICgpID0+IG9uQmx1ciAmJiBvbkJsdXIsXG4gICAgY2xhc3NOYW1lOiBjbHMoe1xuICAgICAgaW5hY3RpdmU6IHZhbHVlID09PSAnYXV0bydcbiAgICB9KVxuICB9KTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IElucHV0V2l0aE9ubHlOdW1iZXJzOyJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///6086\n")},956:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n \"Q\": () => (/* binding */ PanelContext),\n \"Z\": () => (/* binding */ components_PanelLevel)\n});\n\n// EXTERNAL MODULE: external \"window.wp.element\"\nvar external_window_wp_element_ = __webpack_require__(1381);\n// EXTERNAL MODULE: external \"ctEvents\"\nvar external_ctEvents_ = __webpack_require__(2243);\nvar external_ctEvents_default = /*#__PURE__*/__webpack_require__.n(external_ctEvents_);\n;// CONCATENATED MODULE: ./static/js/customizer/preview-events.js\n\nlet deepLinkLocation = null;\nconst getDeepLinkPanel = () => deepLinkLocation ? deepLinkLocation.split(':')[1] : false;\nconst removeDeepLink = () => deepLinkLocation = null;\n\nif (wp.customize) {\n wp.customize.bind('ready', () => {\n wp.customize.previewer.bind('ct-initiate-deep-link', location => {\n const [section, panel] = location.split(':');\n const expanded = Object.values(wp.customize.section._value).find(e => e.expanded());\n\n if (!expanded || expanded.id !== section) {\n deepLinkLocation = location;\n wp.customize.section(section).expand();\n return;\n }\n\n external_ctEvents_default().trigger('ct-deep-link-start', location);\n });\n });\n}\n;// CONCATENATED MODULE: ./static/js/options/components/PanelLevel.js\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\nconst PanelContext = (0,external_window_wp_element_.createContext)({\n titlePrefix: '',\n isOpen: false,\n isTransitioning: false,\n previousPanel: false,\n currentLevel: 1,\n secondLevelTitlePrefix: '',\n secondLevelTitleLabel: ''\n});\n\nconst panelsReducer = (state, action) => {\n if (action.type === 'PANEL_OPEN') {\n const {\n panelId\n } = action.payload;\n\n if (state.isOpen && state.isOpen === panelId) {\n return state;\n }\n\n if (state.isTransitioning) {\n return state;\n }\n\n return _objectSpread(_objectSpread({}, state), {}, {\n isOpen: panelId,\n isTransitioning: panelId,\n currentLevel: 1\n }, state.isOpen ? {\n previousPanel: state.isOpen\n } : {});\n }\n\n if (action.type === 'PANEL_RECEIVE_TITLE') {\n const {\n titlePrefix\n } = action.payload;\n return _objectSpread(_objectSpread({}, state), {}, {\n titlePrefix\n });\n }\n\n if (action.type === 'PANEL_RECEIVE_META') {\n return _objectSpread(_objectSpread({}, state), action.payload);\n }\n\n if (action.type === 'PANEL_OPEN_SECOND_LEVEL') {\n // const { titlePrefix } = action.payload\n return _objectSpread(_objectSpread({}, state), {}, {\n currentLevel: 2\n });\n }\n\n if (action.type === 'PANEL_CLOSE') {\n return _objectSpread(_objectSpread({}, state), state.currentLevel === 2 ? {\n currentLevel: 1\n } : {\n isTransitioning: state.isOpen,\n isOpen: false,\n currentLevel: 1\n });\n }\n\n if (action.type === 'PANEL_FINISH_TRANSITIONING') {\n return _objectSpread(_objectSpread({}, state), {}, {\n isTransitioning: false\n }, state.isOpen && state.isOpen !== state.previousPanel ? {\n previousPanel: false\n } : {});\n }\n\n return state;\n};\n\nconst PanelLevel = _ref => {\n let {\n id,\n children,\n containerRef,\n parentContainerRef,\n useRefsAsWrappers\n } = _ref;\n const [panelsState, panelsDispatch] = (0,external_window_wp_element_.useReducer)(panelsReducer, {\n isOpen: false,\n isTransitioning: false\n });\n (0,external_window_wp_element_.useEffect)(() => {\n external_ctEvents_default().on('ct-deep-link-start', location => {\n const [_, panelId] = location.split(':');\n\n if (!panelId) {\n panelsDispatch({\n type: 'PANEL_CLOSE'\n });\n return;\n }\n\n panelsDispatch({\n type: 'PANEL_OPEN',\n payload: {\n panelId\n }\n });\n });\n\n if (getDeepLinkPanel()) {\n setTimeout(() => {\n panelsDispatch({\n type: 'PANEL_OPEN',\n payload: {\n panelId: getDeepLinkPanel()\n }\n });\n removeDeepLink();\n }, 300);\n }\n }, []);\n return (0,external_window_wp_element_.createElement)(PanelContext.Provider, {\n value: {\n id,\n containerRef,\n panelsState,\n panelsDispatch,\n panelsHelpers: {\n isOpenFor: panelId => panelsState.isOpen && panelId === panelsState.isOpen,\n isTransitioningFor: panelId => panelsState.previousPanel && panelId === panelsState.previousPanel || panelsState.isTransitioning && panelId === panelsState.isTransitioning,\n open: panelId => panelsDispatch({\n type: 'PANEL_OPEN',\n payload: {\n panelId\n }\n }),\n close: () => {\n panelsDispatch({\n type: 'PANEL_CLOSE'\n });\n },\n stopTransitioning: () => {\n panelsDispatch({\n type: 'PANEL_FINISH_TRANSITIONING'\n });\n },\n getWrapperParent: () => useRefsAsWrappers ? parentContainerRef.current : containerRef.current.closest('[id=\"customize-theme-controls\"]'),\n openSecondLevel: () => {\n panelsDispatch({\n type: 'PANEL_OPEN_SECOND_LEVEL'\n });\n },\n getParentOptionsWrapper: () => useRefsAsWrappers ? containerRef.current : containerRef.current.closest('.accordion-section-content')\n }\n }\n }, children);\n};\n\n/* harmony default export */ const components_PanelLevel = (PanelLevel);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"956.js","mappings":";;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./static/js/customizer/preview-events.js?4277","webpack://blocksyOptions/./static/js/options/components/PanelLevel.js?5527"],"sourcesContent":["import ctEvents from 'ct-events';\nlet deepLinkLocation = null;\nexport const getDeepLinkPanel = () => deepLinkLocation ? deepLinkLocation.split(':')[1] : false;\nexport const removeDeepLink = () => deepLinkLocation = null;\n\nif (wp.customize) {\n  wp.customize.bind('ready', () => {\n    wp.customize.previewer.bind('ct-initiate-deep-link', location => {\n      const [section, panel] = location.split(':');\n      const expanded = Object.values(wp.customize.section._value).find(e => e.expanded());\n\n      if (!expanded || expanded.id !== section) {\n        deepLinkLocation = location;\n        wp.customize.section(section).expand();\n        return;\n      }\n\n      ctEvents.trigger('ct-deep-link-start', location);\n    });\n  });\n}","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { Fragment, createElement, createContext, useEffect, createPortal, useMemo, useRef, useState, useReducer, useCallback } from '@wordpress/element';\nimport { getDeepLinkPanel, removeDeepLink } from '../../customizer/preview-events';\nimport ctEvents from 'ct-events';\nexport const PanelContext = createContext({\n  titlePrefix: '',\n  isOpen: false,\n  isTransitioning: false,\n  previousPanel: false,\n  currentLevel: 1,\n  secondLevelTitlePrefix: '',\n  secondLevelTitleLabel: ''\n});\n\nconst panelsReducer = (state, action) => {\n  if (action.type === 'PANEL_OPEN') {\n    const {\n      panelId\n    } = action.payload;\n\n    if (state.isOpen && state.isOpen === panelId) {\n      return state;\n    }\n\n    if (state.isTransitioning) {\n      return state;\n    }\n\n    return _objectSpread(_objectSpread({}, state), {}, {\n      isOpen: panelId,\n      isTransitioning: panelId,\n      currentLevel: 1\n    }, state.isOpen ? {\n      previousPanel: state.isOpen\n    } : {});\n  }\n\n  if (action.type === 'PANEL_RECEIVE_TITLE') {\n    const {\n      titlePrefix\n    } = action.payload;\n    return _objectSpread(_objectSpread({}, state), {}, {\n      titlePrefix\n    });\n  }\n\n  if (action.type === 'PANEL_RECEIVE_META') {\n    return _objectSpread(_objectSpread({}, state), action.payload);\n  }\n\n  if (action.type === 'PANEL_OPEN_SECOND_LEVEL') {\n    // const { titlePrefix } = action.payload\n    return _objectSpread(_objectSpread({}, state), {}, {\n      currentLevel: 2\n    });\n  }\n\n  if (action.type === 'PANEL_CLOSE') {\n    return _objectSpread(_objectSpread({}, state), state.currentLevel === 2 ? {\n      currentLevel: 1\n    } : {\n      isTransitioning: state.isOpen,\n      isOpen: false,\n      currentLevel: 1\n    });\n  }\n\n  if (action.type === 'PANEL_FINISH_TRANSITIONING') {\n    return _objectSpread(_objectSpread({}, state), {}, {\n      isTransitioning: false\n    }, state.isOpen && state.isOpen !== state.previousPanel ? {\n      previousPanel: false\n    } : {});\n  }\n\n  return state;\n};\n\nconst PanelLevel = _ref => {\n  let {\n    id,\n    children,\n    containerRef,\n    parentContainerRef,\n    useRefsAsWrappers\n  } = _ref;\n  const [panelsState, panelsDispatch] = useReducer(panelsReducer, {\n    isOpen: false,\n    isTransitioning: false\n  });\n  useEffect(() => {\n    ctEvents.on('ct-deep-link-start', location => {\n      const [_, panelId] = location.split(':');\n\n      if (!panelId) {\n        panelsDispatch({\n          type: 'PANEL_CLOSE'\n        });\n        return;\n      }\n\n      panelsDispatch({\n        type: 'PANEL_OPEN',\n        payload: {\n          panelId\n        }\n      });\n    });\n\n    if (getDeepLinkPanel()) {\n      setTimeout(() => {\n        panelsDispatch({\n          type: 'PANEL_OPEN',\n          payload: {\n            panelId: getDeepLinkPanel()\n          }\n        });\n        removeDeepLink();\n      }, 300);\n    }\n  }, []);\n  return createElement(PanelContext.Provider, {\n    value: {\n      id,\n      containerRef,\n      panelsState,\n      panelsDispatch,\n      panelsHelpers: {\n        isOpenFor: panelId => panelsState.isOpen && panelId === panelsState.isOpen,\n        isTransitioningFor: panelId => panelsState.previousPanel && panelId === panelsState.previousPanel || panelsState.isTransitioning && panelId === panelsState.isTransitioning,\n        open: panelId => panelsDispatch({\n          type: 'PANEL_OPEN',\n          payload: {\n            panelId\n          }\n        }),\n        close: () => {\n          panelsDispatch({\n            type: 'PANEL_CLOSE'\n          });\n        },\n        stopTransitioning: () => {\n          panelsDispatch({\n            type: 'PANEL_FINISH_TRANSITIONING'\n          });\n        },\n        getWrapperParent: () => useRefsAsWrappers ? parentContainerRef.current : containerRef.current.closest('[id=\"customize-theme-controls\"]'),\n        openSecondLevel: () => {\n          panelsDispatch({\n            type: 'PANEL_OPEN_SECOND_LEVEL'\n          });\n        },\n        getParentOptionsWrapper: () => useRefsAsWrappers ? containerRef.current : containerRef.current.closest('.accordion-section-content')\n      }\n    }\n  }, children);\n};\n\nexport default PanelLevel;"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///956\n")},7493:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"f\": () => (/* binding */ capitalizeFirstLetter),\n/* harmony export */ \"m\": () => (/* binding */ getOptionLabelFor)\n/* harmony export */ });\n/* harmony import */ var match_conditions__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7465);\n\nconst capitalizeFirstLetter = str => {\n str = str == null ? '' : String(str);\n return str.charAt(0).toUpperCase() + str.slice(1);\n};\nconst getOptionLabelFor = _ref => {\n let {\n id,\n option,\n values,\n renderingConfig\n } = _ref;\n let maybeLabel = Object.keys(option).indexOf('label') === -1 ? capitalizeFirstLetter(id).replace(/\\_|\\-/g, ' ') : option.label;\n\n if (maybeLabel !== maybeLabel.toString()) {\n maybeLabel = Object.keys(maybeLabel).reduce((approvedLabel, currentLabel) => {\n if (approvedLabel) {\n return approvedLabel;\n }\n\n if ((0,match_conditions__WEBPACK_IMPORTED_MODULE_0__/* .matchValuesWithCondition */ .Nj)((0,match_conditions__WEBPACK_IMPORTED_MODULE_0__/* .normalizeCondition */ .KY)(maybeLabel[currentLabel]), values)) {\n return currentLabel;\n }\n\n return approvedLabel;\n }, null) || Object.keys(maybeLabel)[0];\n }\n /**\n * Fuck JS\n */\n\n\n if (maybeLabel === '') {\n maybeLabel = true;\n }\n\n if (renderingConfig && !renderingConfig.label) {\n maybeLabel = false;\n }\n\n return maybeLabel;\n};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNzQ5My5qcyIsIm1hcHBpbmdzIjoiOzs7OztBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vc3RhdGljL2pzL29wdGlvbnMvaGVscGVycy9nZXQtbGFiZWwuanM/YTc2OCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBub3JtYWxpemVDb25kaXRpb24sIG1hdGNoVmFsdWVzV2l0aENvbmRpdGlvbiB9IGZyb20gJ21hdGNoLWNvbmRpdGlvbnMnO1xuZXhwb3J0IGNvbnN0IGNhcGl0YWxpemVGaXJzdExldHRlciA9IHN0ciA9PiB7XG4gIHN0ciA9IHN0ciA9PSBudWxsID8gJycgOiBTdHJpbmcoc3RyKTtcbiAgcmV0dXJuIHN0ci5jaGFyQXQoMCkudG9VcHBlckNhc2UoKSArIHN0ci5zbGljZSgxKTtcbn07XG5leHBvcnQgY29uc3QgZ2V0T3B0aW9uTGFiZWxGb3IgPSBfcmVmID0+IHtcbiAgbGV0IHtcbiAgICBpZCxcbiAgICBvcHRpb24sXG4gICAgdmFsdWVzLFxuICAgIHJlbmRlcmluZ0NvbmZpZ1xuICB9ID0gX3JlZjtcbiAgbGV0IG1heWJlTGFiZWwgPSBPYmplY3Qua2V5cyhvcHRpb24pLmluZGV4T2YoJ2xhYmVsJykgPT09IC0xID8gY2FwaXRhbGl6ZUZpcnN0TGV0dGVyKGlkKS5yZXBsYWNlKC9cXF98XFwtL2csICcgJykgOiBvcHRpb24ubGFiZWw7XG5cbiAgaWYgKG1heWJlTGFiZWwgIT09IG1heWJlTGFiZWwudG9TdHJpbmcoKSkge1xuICAgIG1heWJlTGFiZWwgPSBPYmplY3Qua2V5cyhtYXliZUxhYmVsKS5yZWR1Y2UoKGFwcHJvdmVkTGFiZWwsIGN1cnJlbnRMYWJlbCkgPT4ge1xuICAgICAgaWYgKGFwcHJvdmVkTGFiZWwpIHtcbiAgICAgICAgcmV0dXJuIGFwcHJvdmVkTGFiZWw7XG4gICAgICB9XG5cbiAgICAgIGlmIChtYXRjaFZhbHVlc1dpdGhDb25kaXRpb24obm9ybWFsaXplQ29uZGl0aW9uKG1heWJlTGFiZWxbY3VycmVudExhYmVsXSksIHZhbHVlcykpIHtcbiAgICAgICAgcmV0dXJuIGN1cnJlbnRMYWJlbDtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIGFwcHJvdmVkTGFiZWw7XG4gICAgfSwgbnVsbCkgfHwgT2JqZWN0LmtleXMobWF5YmVMYWJlbClbMF07XG4gIH1cbiAgLyoqXG4gICAqIEZ1Y2sgSlNcbiAgICovXG5cblxuICBpZiAobWF5YmVMYWJlbCA9PT0gJycpIHtcbiAgICBtYXliZUxhYmVsID0gdHJ1ZTtcbiAgfVxuXG4gIGlmIChyZW5kZXJpbmdDb25maWcgJiYgIXJlbmRlcmluZ0NvbmZpZy5sYWJlbCkge1xuICAgIG1heWJlTGFiZWwgPSBmYWxzZTtcbiAgfVxuXG4gIHJldHVybiBtYXliZUxhYmVsO1xufTsiXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///7493\n")},7069:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"UO\": () => (/* binding */ flattenOptions),\n/* harmony export */ \"n6\": () => (/* binding */ getValueFromInput)\n/* harmony export */ });\n/* unused harmony export getFirstLevelOptions */\n/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(6715);\n/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_0__);\nconst _excluded = [\"__CT_KEYS_ORDER__\"];\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\n\nconst getFirstLevelOptions = function (options) {\n let hasInnerOptions = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n\n const {\n __CT_KEYS_ORDER__\n } = options,\n rest = _objectWithoutProperties(options, _excluded);\n\n return Object.keys(rest).reduce((currentOptions, currentOptionId) => {\n if (!options[currentOptionId].type) {\n return _objectSpread(_objectSpread({}, currentOptions), getFirstLevelOptions(options[currentOptionId], hasInnerOptions));\n }\n\n if (options[currentOptionId].options) {\n return _objectSpread(_objectSpread({}, currentOptions), getFirstLevelOptions(options[currentOptionId].options, hasInnerOptions));\n }\n\n if (options[currentOptionId]['inner-options'] && hasInnerOptions) {\n return _objectSpread(_objectSpread({}, currentOptions), {}, {\n [currentOptionId]: options[currentOptionId]\n }, getFirstLevelOptions(options[currentOptionId]['inner-options'], hasInnerOptions));\n }\n\n return _objectSpread(_objectSpread({}, currentOptions), {}, {\n [currentOptionId]: options[currentOptionId]\n });\n }, {});\n};\nconst flattenOptions = options => Object.keys(options).reduce((result, currentId) => _objectSpread(_objectSpread({}, result), options[currentId].type ? {\n [currentId]: options[currentId]\n} : currentId === '__CT_KEYS_ORDER__' ? {\n [currentId]: options[currentId]\n} : flattenOptions(options[currentId])), {});\nconst getValueFromInput = function (options, values) {\n let valueGetter = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null;\n let hasInnerOptions = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : true;\n let firstLevelOptions = getFirstLevelOptions(options, hasInnerOptions);\n return _objectSpread(_objectSpread({}, values), Object.keys(firstLevelOptions).reduce((currentValues, currentOptionId) => {\n let actualValue = null;\n\n if (Object.keys(values).indexOf(currentOptionId) > -1) {\n if (underscore__WEBPACK_IMPORTED_MODULE_0___default().isString(values[currentOptionId]) || underscore__WEBPACK_IMPORTED_MODULE_0___default().isNumber(values[currentOptionId])) {\n actualValue = values[currentOptionId];\n }\n\n if (underscore__WEBPACK_IMPORTED_MODULE_0___default().isObject(values[currentOptionId])) {\n actualValue = _objectSpread(_objectSpread({}, firstLevelOptions[currentOptionId].value || {}), values[currentOptionId]);\n }\n\n if (underscore__WEBPACK_IMPORTED_MODULE_0___default().isArray(values[currentOptionId])) {\n actualValue = values[currentOptionId] ? values[currentOptionId] : [...(firstLevelOptions[currentOptionId].value || []) // ...values[currentOptionId],\n ];\n }\n } else if (valueGetter) {\n return _objectSpread(_objectSpread({}, currentValues), valueGetter(currentOptionId, firstLevelOptions[currentOptionId]));\n } else {\n if (Object.keys(firstLevelOptions[currentOptionId]).indexOf('value') > -1) {\n actualValue = firstLevelOptions[currentOptionId].value;\n } else {\n actualValue = '';\n }\n }\n\n return _objectSpread(_objectSpread({}, currentValues), {}, {\n [currentOptionId]: actualValue\n });\n }, {}));\n};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNzA2OS5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9zdGF0aWMvanMvb3B0aW9ucy9oZWxwZXJzL2dldC12YWx1ZS1mcm9tLWlucHV0LmpzPzBjZTgiXSwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgX2V4Y2x1ZGVkID0gW1wiX19DVF9LRVlTX09SREVSX19cIl07XG5cbmZ1bmN0aW9uIG93bktleXMob2JqZWN0LCBlbnVtZXJhYmxlT25seSkgeyB2YXIga2V5cyA9IE9iamVjdC5rZXlzKG9iamVjdCk7IGlmIChPYmplY3QuZ2V0T3duUHJvcGVydHlTeW1ib2xzKSB7IHZhciBzeW1ib2xzID0gT2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9scyhvYmplY3QpOyBlbnVtZXJhYmxlT25seSAmJiAoc3ltYm9scyA9IHN5bWJvbHMuZmlsdGVyKGZ1bmN0aW9uIChzeW0pIHsgcmV0dXJuIE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3Iob2JqZWN0LCBzeW0pLmVudW1lcmFibGU7IH0pKSwga2V5cy5wdXNoLmFwcGx5KGtleXMsIHN5bWJvbHMpOyB9IHJldHVybiBrZXlzOyB9XG5cbmZ1bmN0aW9uIF9vYmplY3RTcHJlYWQodGFyZ2V0KSB7IGZvciAodmFyIGkgPSAxOyBpIDwgYXJndW1lbnRzLmxlbmd0aDsgaSsrKSB7IHZhciBzb3VyY2UgPSBudWxsICE9IGFyZ3VtZW50c1tpXSA/IGFyZ3VtZW50c1tpXSA6IHt9OyBpICUgMiA/IG93bktleXMoT2JqZWN0KHNvdXJjZSksICEwKS5mb3JFYWNoKGZ1bmN0aW9uIChrZXkpIHsgX2RlZmluZVByb3BlcnR5KHRhcmdldCwga2V5LCBzb3VyY2Vba2V5XSk7IH0pIDogT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcnMgPyBPYmplY3QuZGVmaW5lUHJvcGVydGllcyh0YXJnZXQsIE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3JzKHNvdXJjZSkpIDogb3duS2V5cyhPYmplY3Qoc291cmNlKSkuZm9yRWFjaChmdW5jdGlvbiAoa2V5KSB7IE9iamVjdC5kZWZpbmVQcm9wZXJ0eSh0YXJnZXQsIGtleSwgT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcihzb3VyY2UsIGtleSkpOyB9KTsgfSByZXR1cm4gdGFyZ2V0OyB9XG5cbmZ1bmN0aW9uIF9kZWZpbmVQcm9wZXJ0eShvYmosIGtleSwgdmFsdWUpIHsgaWYgKGtleSBpbiBvYmopIHsgT2JqZWN0LmRlZmluZVByb3BlcnR5KG9iaiwga2V5LCB7IHZhbHVlOiB2YWx1ZSwgZW51bWVyYWJsZTogdHJ1ZSwgY29uZmlndXJhYmxlOiB0cnVlLCB3cml0YWJsZTogdHJ1ZSB9KTsgfSBlbHNlIHsgb2JqW2tleV0gPSB2YWx1ZTsgfSByZXR1cm4gb2JqOyB9XG5cbmZ1bmN0aW9uIF9vYmplY3RXaXRob3V0UHJvcGVydGllcyhzb3VyY2UsIGV4Y2x1ZGVkKSB7IGlmIChzb3VyY2UgPT0gbnVsbCkgcmV0dXJuIHt9OyB2YXIgdGFyZ2V0ID0gX29iamVjdFdpdGhvdXRQcm9wZXJ0aWVzTG9vc2Uoc291cmNlLCBleGNsdWRlZCk7IHZhciBrZXksIGk7IGlmIChPYmplY3QuZ2V0T3duUHJvcGVydHlTeW1ib2xzKSB7IHZhciBzb3VyY2VTeW1ib2xLZXlzID0gT2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9scyhzb3VyY2UpOyBmb3IgKGkgPSAwOyBpIDwgc291cmNlU3ltYm9sS2V5cy5sZW5ndGg7IGkrKykgeyBrZXkgPSBzb3VyY2VTeW1ib2xLZXlzW2ldOyBpZiAoZXhjbHVkZWQuaW5kZXhPZihrZXkpID49IDApIGNvbnRpbnVlOyBpZiAoIU9iamVjdC5wcm90b3R5cGUucHJvcGVydHlJc0VudW1lcmFibGUuY2FsbChzb3VyY2UsIGtleSkpIGNvbnRpbnVlOyB0YXJnZXRba2V5XSA9IHNvdXJjZVtrZXldOyB9IH0gcmV0dXJuIHRhcmdldDsgfVxuXG5mdW5jdGlvbiBfb2JqZWN0V2l0aG91dFByb3BlcnRpZXNMb29zZShzb3VyY2UsIGV4Y2x1ZGVkKSB7IGlmIChzb3VyY2UgPT0gbnVsbCkgcmV0dXJuIHt9OyB2YXIgdGFyZ2V0ID0ge307IHZhciBzb3VyY2VLZXlzID0gT2JqZWN0LmtleXMoc291cmNlKTsgdmFyIGtleSwgaTsgZm9yIChpID0gMDsgaSA8IHNvdXJjZUtleXMubGVuZ3RoOyBpKyspIHsga2V5ID0gc291cmNlS2V5c1tpXTsgaWYgKGV4Y2x1ZGVkLmluZGV4T2Yoa2V5KSA+PSAwKSBjb250aW51ZTsgdGFyZ2V0W2tleV0gPSBzb3VyY2Vba2V5XTsgfSByZXR1cm4gdGFyZ2V0OyB9XG5cbmltcG9ydCBfIGZyb20gJ3VuZGVyc2NvcmUnO1xuZXhwb3J0IGNvbnN0IGdldEZpcnN0TGV2ZWxPcHRpb25zID0gZnVuY3Rpb24gKG9wdGlvbnMpIHtcbiAgbGV0IGhhc0lubmVyT3B0aW9ucyA9IGFyZ3VtZW50cy5sZW5ndGggPiAxICYmIGFyZ3VtZW50c1sxXSAhPT0gdW5kZWZpbmVkID8gYXJndW1lbnRzWzFdIDogdHJ1ZTtcblxuICBjb25zdCB7XG4gICAgX19DVF9LRVlTX09SREVSX19cbiAgfSA9IG9wdGlvbnMsXG4gICAgICAgIHJlc3QgPSBfb2JqZWN0V2l0aG91dFByb3BlcnRpZXMob3B0aW9ucywgX2V4Y2x1ZGVkKTtcblxuICByZXR1cm4gT2JqZWN0LmtleXMocmVzdCkucmVkdWNlKChjdXJyZW50T3B0aW9ucywgY3VycmVudE9wdGlvbklkKSA9PiB7XG4gICAgaWYgKCFvcHRpb25zW2N1cnJlbnRPcHRpb25JZF0udHlwZSkge1xuICAgICAgcmV0dXJuIF9vYmplY3RTcHJlYWQoX29iamVjdFNwcmVhZCh7fSwgY3VycmVudE9wdGlvbnMpLCBnZXRGaXJzdExldmVsT3B0aW9ucyhvcHRpb25zW2N1cnJlbnRPcHRpb25JZF0sIGhhc0lubmVyT3B0aW9ucykpO1xuICAgIH1cblxuICAgIGlmIChvcHRpb25zW2N1cnJlbnRPcHRpb25JZF0ub3B0aW9ucykge1xuICAgICAgcmV0dXJuIF9vYmplY3RTcHJlYWQoX29iamVjdFNwcmVhZCh7fSwgY3VycmVudE9wdGlvbnMpLCBnZXRGaXJzdExldmVsT3B0aW9ucyhvcHRpb25zW2N1cnJlbnRPcHRpb25JZF0ub3B0aW9ucywgaGFzSW5uZXJPcHRpb25zKSk7XG4gICAgfVxuXG4gICAgaWYgKG9wdGlvbnNbY3VycmVudE9wdGlvbklkXVsnaW5uZXItb3B0aW9ucyddICYmIGhhc0lubmVyT3B0aW9ucykge1xuICAgICAgcmV0dXJuIF9vYmplY3RTcHJlYWQoX29iamVjdFNwcmVhZCh7fSwgY3VycmVudE9wdGlvbnMpLCB7fSwge1xuICAgICAgICBbY3VycmVudE9wdGlvbklkXTogb3B0aW9uc1tjdXJyZW50T3B0aW9uSWRdXG4gICAgICB9LCBnZXRGaXJzdExldmVsT3B0aW9ucyhvcHRpb25zW2N1cnJlbnRPcHRpb25JZF1bJ2lubmVyLW9wdGlvbnMnXSwgaGFzSW5uZXJPcHRpb25zKSk7XG4gICAgfVxuXG4gICAgcmV0dXJuIF9vYmplY3RTcHJlYWQoX29iamVjdFNwcmVhZCh7fSwgY3VycmVudE9wdGlvbnMpLCB7fSwge1xuICAgICAgW2N1cnJlbnRPcHRpb25JZF06IG9wdGlvbnNbY3VycmVudE9wdGlvbklkXVxuICAgIH0pO1xuICB9LCB7fSk7XG59O1xuZXhwb3J0IGNvbnN0IGZsYXR0ZW5PcHRpb25zID0gb3B0aW9ucyA9PiBPYmplY3Qua2V5cyhvcHRpb25zKS5yZWR1Y2UoKHJlc3VsdCwgY3VycmVudElkKSA9PiBfb2JqZWN0U3ByZWFkKF9vYmplY3RTcHJlYWQoe30sIHJlc3VsdCksIG9wdGlvbnNbY3VycmVudElkXS50eXBlID8ge1xuICBbY3VycmVudElkXTogb3B0aW9uc1tjdXJyZW50SWRdXG59IDogY3VycmVudElkID09PSAnX19DVF9LRVlTX09SREVSX18nID8ge1xuICBbY3VycmVudElkXTogb3B0aW9uc1tjdXJyZW50SWRdXG59IDogZmxhdHRlbk9wdGlvbnMob3B0aW9uc1tjdXJyZW50SWRdKSksIHt9KTtcbmV4cG9ydCBjb25zdCBnZXRWYWx1ZUZyb21JbnB1dCA9IGZ1bmN0aW9uIChvcHRpb25zLCB2YWx1ZXMpIHtcbiAgbGV0IHZhbHVlR2V0dGVyID0gYXJndW1lbnRzLmxlbmd0aCA+IDIgJiYgYXJndW1lbnRzWzJdICE9PSB1bmRlZmluZWQgPyBhcmd1bWVudHNbMl0gOiBudWxsO1xuICBsZXQgaGFzSW5uZXJPcHRpb25zID0gYXJndW1lbnRzLmxlbmd0aCA+IDMgJiYgYXJndW1lbnRzWzNdICE9PSB1bmRlZmluZWQgPyBhcmd1bWVudHNbM10gOiB0cnVlO1xuICBsZXQgZmlyc3RMZXZlbE9wdGlvbnMgPSBnZXRGaXJzdExldmVsT3B0aW9ucyhvcHRpb25zLCBoYXNJbm5lck9wdGlvbnMpO1xuICByZXR1cm4gX29iamVjdFNwcmVhZChfb2JqZWN0U3ByZWFkKHt9LCB2YWx1ZXMpLCBPYmplY3Qua2V5cyhmaXJzdExldmVsT3B0aW9ucykucmVkdWNlKChjdXJyZW50VmFsdWVzLCBjdXJyZW50T3B0aW9uSWQpID0+IHtcbiAgICBsZXQgYWN0dWFsVmFsdWUgPSBudWxsO1xuXG4gICAgaWYgKE9iamVjdC5rZXlzKHZhbHVlcykuaW5kZXhPZihjdXJyZW50T3B0aW9uSWQpID4gLTEpIHtcbiAgICAgIGlmIChfLmlzU3RyaW5nKHZhbHVlc1tjdXJyZW50T3B0aW9uSWRdKSB8fCBfLmlzTnVtYmVyKHZhbHVlc1tjdXJyZW50T3B0aW9uSWRdKSkge1xuICAgICAgICBhY3R1YWxWYWx1ZSA9IHZhbHVlc1tjdXJyZW50T3B0aW9uSWRdO1xuICAgICAgfVxuXG4gICAgICBpZiAoXy5pc09iamVjdCh2YWx1ZXNbY3VycmVudE9wdGlvbklkXSkpIHtcbiAgICAgICAgYWN0dWFsVmFsdWUgPSBfb2JqZWN0U3ByZWFkKF9vYmplY3RTcHJlYWQoe30sIGZpcnN0TGV2ZWxPcHRpb25zW2N1cnJlbnRPcHRpb25JZF0udmFsdWUgfHwge30pLCB2YWx1ZXNbY3VycmVudE9wdGlvbklkXSk7XG4gICAgICB9XG5cbiAgICAgIGlmIChfLmlzQXJyYXkodmFsdWVzW2N1cnJlbnRPcHRpb25JZF0pKSB7XG4gICAgICAgIGFjdHVhbFZhbHVlID0gdmFsdWVzW2N1cnJlbnRPcHRpb25JZF0gPyB2YWx1ZXNbY3VycmVudE9wdGlvbklkXSA6IFsuLi4oZmlyc3RMZXZlbE9wdGlvbnNbY3VycmVudE9wdGlvbklkXS52YWx1ZSB8fCBbXSkgLy8gLi4udmFsdWVzW2N1cnJlbnRPcHRpb25JZF0sXG4gICAgICAgIF07XG4gICAgICB9XG4gICAgfSBlbHNlIGlmICh2YWx1ZUdldHRlcikge1xuICAgICAgcmV0dXJuIF9vYmplY3RTcHJlYWQoX29iamVjdFNwcmVhZCh7fSwgY3VycmVudFZhbHVlcyksIHZhbHVlR2V0dGVyKGN1cnJlbnRPcHRpb25JZCwgZmlyc3RMZXZlbE9wdGlvbnNbY3VycmVudE9wdGlvbklkXSkpO1xuICAgIH0gZWxzZSB7XG4gICAgICBpZiAoT2JqZWN0LmtleXMoZmlyc3RMZXZlbE9wdGlvbnNbY3VycmVudE9wdGlvbklkXSkuaW5kZXhPZigndmFsdWUnKSA+IC0xKSB7XG4gICAgICAgIGFjdHVhbFZhbHVlID0gZmlyc3RMZXZlbE9wdGlvbnNbY3VycmVudE9wdGlvbklkXS52YWx1ZTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGFjdHVhbFZhbHVlID0gJyc7XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIF9vYmplY3RTcHJlYWQoX29iamVjdFNwcmVhZCh7fSwgY3VycmVudFZhbHVlcyksIHt9LCB7XG4gICAgICBbY3VycmVudE9wdGlvbklkXTogYWN0dWFsVmFsdWVcbiAgICB9KTtcbiAgfSwge30pKTtcbn07Il0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///7069\n")},9287:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"u\": () => (/* binding */ normalizeColor)\n/* harmony export */ });\n/* harmony import */ var colord__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(6765);\n\nconst normalizeColor = color => {\n const parsedColor = (0,colord__WEBPACK_IMPORTED_MODULE_0__/* .colord */ .Vi)(color);\n\n if (!parsedColor.parsed) {\n return color;\n }\n\n if (color[0] === '#' && color.length <= 7) {\n return color;\n }\n\n if (parsedColor.rgba.a === 1) {\n return color;\n }\n\n return parsedColor.toRgbString();\n};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiOTI4Ny5qcyIsIm1hcHBpbmdzIjoiOzs7O0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9zdGF0aWMvanMvb3B0aW9ucy9oZWxwZXJzL25vcm1hbGl6ZS1jb2xvci5qcz83YThkIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNvbG9yZCB9IGZyb20gJ2NvbG9yZCc7XG5leHBvcnQgY29uc3Qgbm9ybWFsaXplQ29sb3IgPSBjb2xvciA9PiB7XG4gIGNvbnN0IHBhcnNlZENvbG9yID0gY29sb3JkKGNvbG9yKTtcblxuICBpZiAoIXBhcnNlZENvbG9yLnBhcnNlZCkge1xuICAgIHJldHVybiBjb2xvcjtcbiAgfVxuXG4gIGlmIChjb2xvclswXSA9PT0gJyMnICYmIGNvbG9yLmxlbmd0aCA8PSA3KSB7XG4gICAgcmV0dXJuIGNvbG9yO1xuICB9XG5cbiAgaWYgKHBhcnNlZENvbG9yLnJnYmEuYSA9PT0gMSkge1xuICAgIHJldHVybiBjb2xvcjtcbiAgfVxuXG4gIHJldHVybiBwYXJzZWRDb2xvci50b1JnYlN0cmluZygpO1xufTsiXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///9287\n")},4592:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "N": () => (/* binding */ maybeTransformUnorderedChoices)\n/* harmony export */ });\nconst maybeTransformUnorderedChoices = choices => Array.isArray(choices) ? choices : Object.keys(choices).reduce((current, choice) => [...current, {\n key: choice,\n value: choices[choice]\n}], []);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNDU5Mi5qcyIsIm1hcHBpbmdzIjoiOzs7QUFBQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vc3RhdGljL2pzL29wdGlvbnMvaGVscGVycy9wYXJzZS1jaG9pY2VzLmpzP2RmMTYiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IG1heWJlVHJhbnNmb3JtVW5vcmRlcmVkQ2hvaWNlcyA9IGNob2ljZXMgPT4gQXJyYXkuaXNBcnJheShjaG9pY2VzKSA/IGNob2ljZXMgOiBPYmplY3Qua2V5cyhjaG9pY2VzKS5yZWR1Y2UoKGN1cnJlbnQsIGNob2ljZSkgPT4gWy4uLmN1cnJlbnQsIHtcbiAga2V5OiBjaG9pY2UsXG4gIHZhbHVlOiBjaG9pY2VzW2Nob2ljZV1cbn1dLCBbXSk7Il0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///4592\n')},9144:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"Z\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* unused harmony export nullifyTransforms */\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(4184);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var ct_i18n__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(5652);\n/* harmony import */ var ct_i18n__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(ct_i18n__WEBPACK_IMPORTED_MODULE_2__);\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\nfunction nullifyTransforms(el) {\n const parseTransform = el => window.getComputedStyle(el).transform.split(/\\(|,|\\)/).slice(1, -1).map(v => parseFloat(v)); // 1\n\n\n let {\n top,\n left,\n width,\n height\n } = el.getBoundingClientRect();\n let transformArr = parseTransform(el);\n\n if (transformArr.length == 6) {\n // 2D matrix\n const t = transformArr; // 2\n\n let det = t[0] * t[3] - t[1] * t[2]; // 3\n\n return {\n width: width / t[0],\n height: height / t[3],\n left: (left * t[3] - top * t[2] + t[2] * t[5] - t[4] * t[3]) / det,\n top: (-left * t[1] + top * t[0] + t[4] * t[1] - t[0] * t[5]) / det\n };\n } else {\n // This case is not handled because it's very rarely needed anyway.\n // We just return the tranformed metrics, as they are, for consistency.\n return {\n top,\n left,\n width,\n height\n };\n }\n}\n\nconst usePopoverMaker = function () {\n let {\n contentRef: contentRefProp,\n shouldCalculate = true,\n ref,\n defaultHeight = 0\n } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n const contentRef = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useRef)();\n const [s, setState] = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useState)(null);\n\n const refresh = () => {\n if (!shouldCalculate) {\n return;\n }\n\n setState(Math.random());\n };\n\n const refreshOnScroll = e => {\n let modalRef = contentRefProp || contentRef;\n\n if (modalRef && modalRef.current && !modalRef.current.contains(e.target)) {\n refresh();\n }\n };\n\n (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useEffect)(() => {\n setTimeout(() => {\n refresh();\n }, 500);\n window.addEventListener('resize', refresh);\n window.addEventListener('scroll', refreshOnScroll, true);\n let observer;\n\n if (ref.current) {\n observer = new window.ResizeObserver(refresh);\n observer.observe(ref.current, {\n attributes: true\n });\n\n if (ref.current.closest('.ct-tabs-scroll')) {\n observer.observe(ref.current.closest('.ct-tabs-scroll'), {\n attributes: true\n });\n }\n\n if (ref.current.closest('.ct-modal-scroll')) {\n observer.observe(ref.current.closest('.ct-modal-scroll'), {\n attributes: true\n });\n }\n\n if (ref.current.closest('.customize-pane-child')) {\n observer.observe(ref.current.closest('.customize-pane-child'), {\n attributes: true\n });\n }\n }\n\n if (contentRefProp ? contentRefProp.current : contentRef.current) {\n if (!observer) {\n observer = new window.ResizeObserver(refresh);\n }\n\n observer.observe(contentRefProp ? contentRefProp.current : contentRef.current, {\n attributes: true\n });\n }\n\n return () => {\n window.removeEventListener('resize', refresh);\n window.removeEventListener('scroll', refreshOnScroll, true);\n\n if (observer) {\n observer.disconnect();\n }\n };\n }, [shouldCalculate, contentRef.current, contentRefProp, ref.current]);\n let {\n right,\n yOffset,\n position,\n otherStyles\n } = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useMemo)(() => {\n let right = 0;\n let yOffset = 0;\n let position = 'bottom';\n let otherStyles = {};\n\n if (!shouldCalculate) {\n return {\n yOffset,\n right,\n position\n };\n }\n\n if (ref.current) {\n let rect = ref.current.getBoundingClientRect();\n let el = ref.current.closest('.ct-select-input') ? ref.current.closest('.ct-select-input') : ref.current;\n let maybeWidthFlag = getComputedStyle(el, ':before').content;\n yOffset = rect.top + rect.height;\n right = window.innerWidth - rect.right;\n\n if (document.body.classList.contains('rtl')) {\n right = rect.left;\n }\n\n if (maybeWidthFlag.indexOf('ref-width') > -1) {\n let width = rect.width;\n\n if (maybeWidthFlag.indexOf('left') > -1 && el.previousElementSibling) {\n if (document.body.classList.contains('rtl')) {\n width = el.previousElementSibling.getBoundingClientRect().right - rect.left;\n } else {\n width = rect.right - el.previousElementSibling.getBoundingClientRect().left;\n }\n }\n\n if (maybeWidthFlag.indexOf('right') > -1) {\n let nextRect = el.parentNode // el.nextElementSibling || el.parentNode\n .getBoundingClientRect();\n\n if (document.body.classList.contains('rtl')) {\n right = nextRect.left;\n width = rect.right - nextRect.left;\n } else {\n right = window.innerWidth - nextRect.right;\n width = nextRect.right - rect.left;\n }\n }\n\n otherStyles['--x-select-dropdown-width'] = `${width}px`;\n }\n\n let popoverRect = contentRefProp && contentRefProp.current || contentRef.current ? nullifyTransforms(contentRefProp ? contentRefProp.current : contentRef.current) : {\n height: defaultHeight\n };\n\n if (yOffset + popoverRect.height > window.innerHeight && rect.top - 15 > popoverRect.height) {\n position = 'top';\n yOffset = window.innerHeight - rect.bottom + rect.height;\n }\n\n if (yOffset + popoverRect.height > window.innerHeight && position === 'bottom') {\n position = 'top';\n yOffset = 0;\n }\n }\n\n return {\n yOffset,\n right,\n position,\n otherStyles\n };\n }, [s, shouldCalculate, ref, ref.current, contentRefProp, contentRef.current, defaultHeight]);\n return {\n refreshPopover: refresh,\n styles: _objectSpread({\n '--modal-y-offset': `${yOffset}px`,\n '--modal-x-offset': `${right}px`\n }, otherStyles),\n position,\n popoverProps: _objectSpread({\n ref: contentRefProp || contentRef\n }, position ? {\n 'data-position': position\n } : {})\n };\n};\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (usePopoverMaker);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"9144.js","mappings":";;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./static/js/options/helpers/usePopoverMaker.js?755c"],"sourcesContent":["function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { useMemo, useRef, useState, useEffect } from '@wordpress/element';\nimport classnames from 'classnames';\nimport { __ } from 'ct-i18n';\nexport function nullifyTransforms(el) {\n  const parseTransform = el => window.getComputedStyle(el).transform.split(/\\(|,|\\)/).slice(1, -1).map(v => parseFloat(v)); // 1\n\n\n  let {\n    top,\n    left,\n    width,\n    height\n  } = el.getBoundingClientRect();\n  let transformArr = parseTransform(el);\n\n  if (transformArr.length == 6) {\n    // 2D matrix\n    const t = transformArr; // 2\n\n    let det = t[0] * t[3] - t[1] * t[2]; // 3\n\n    return {\n      width: width / t[0],\n      height: height / t[3],\n      left: (left * t[3] - top * t[2] + t[2] * t[5] - t[4] * t[3]) / det,\n      top: (-left * t[1] + top * t[0] + t[4] * t[1] - t[0] * t[5]) / det\n    };\n  } else {\n    // This case is not handled because it's very rarely needed anyway.\n    // We just return the tranformed metrics, as they are, for consistency.\n    return {\n      top,\n      left,\n      width,\n      height\n    };\n  }\n}\n\nconst usePopoverMaker = function () {\n  let {\n    contentRef: contentRefProp,\n    shouldCalculate = true,\n    ref,\n    defaultHeight = 0\n  } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n  const contentRef = useRef();\n  const [s, setState] = useState(null);\n\n  const refresh = () => {\n    if (!shouldCalculate) {\n      return;\n    }\n\n    setState(Math.random());\n  };\n\n  const refreshOnScroll = e => {\n    let modalRef = contentRefProp || contentRef;\n\n    if (modalRef && modalRef.current && !modalRef.current.contains(e.target)) {\n      refresh();\n    }\n  };\n\n  useEffect(() => {\n    setTimeout(() => {\n      refresh();\n    }, 500);\n    window.addEventListener('resize', refresh);\n    window.addEventListener('scroll', refreshOnScroll, true);\n    let observer;\n\n    if (ref.current) {\n      observer = new window.ResizeObserver(refresh);\n      observer.observe(ref.current, {\n        attributes: true\n      });\n\n      if (ref.current.closest('.ct-tabs-scroll')) {\n        observer.observe(ref.current.closest('.ct-tabs-scroll'), {\n          attributes: true\n        });\n      }\n\n      if (ref.current.closest('.ct-modal-scroll')) {\n        observer.observe(ref.current.closest('.ct-modal-scroll'), {\n          attributes: true\n        });\n      }\n\n      if (ref.current.closest('.customize-pane-child')) {\n        observer.observe(ref.current.closest('.customize-pane-child'), {\n          attributes: true\n        });\n      }\n    }\n\n    if (contentRefProp ? contentRefProp.current : contentRef.current) {\n      if (!observer) {\n        observer = new window.ResizeObserver(refresh);\n      }\n\n      observer.observe(contentRefProp ? contentRefProp.current : contentRef.current, {\n        attributes: true\n      });\n    }\n\n    return () => {\n      window.removeEventListener('resize', refresh);\n      window.removeEventListener('scroll', refreshOnScroll, true);\n\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [shouldCalculate, contentRef.current, contentRefProp, ref.current]);\n  let {\n    right,\n    yOffset,\n    position,\n    otherStyles\n  } = useMemo(() => {\n    let right = 0;\n    let yOffset = 0;\n    let position = 'bottom';\n    let otherStyles = {};\n\n    if (!shouldCalculate) {\n      return {\n        yOffset,\n        right,\n        position\n      };\n    }\n\n    if (ref.current) {\n      let rect = ref.current.getBoundingClientRect();\n      let el = ref.current.closest('.ct-select-input') ? ref.current.closest('.ct-select-input') : ref.current;\n      let maybeWidthFlag = getComputedStyle(el, ':before').content;\n      yOffset = rect.top + rect.height;\n      right = window.innerWidth - rect.right;\n\n      if (document.body.classList.contains('rtl')) {\n        right = rect.left;\n      }\n\n      if (maybeWidthFlag.indexOf('ref-width') > -1) {\n        let width = rect.width;\n\n        if (maybeWidthFlag.indexOf('left') > -1 && el.previousElementSibling) {\n          if (document.body.classList.contains('rtl')) {\n            width = el.previousElementSibling.getBoundingClientRect().right - rect.left;\n          } else {\n            width = rect.right - el.previousElementSibling.getBoundingClientRect().left;\n          }\n        }\n\n        if (maybeWidthFlag.indexOf('right') > -1) {\n          let nextRect = el.parentNode // el.nextElementSibling || el.parentNode\n          .getBoundingClientRect();\n\n          if (document.body.classList.contains('rtl')) {\n            right = nextRect.left;\n            width = rect.right - nextRect.left;\n          } else {\n            right = window.innerWidth - nextRect.right;\n            width = nextRect.right - rect.left;\n          }\n        }\n\n        otherStyles['--x-select-dropdown-width'] = `${width}px`;\n      }\n\n      let popoverRect = contentRefProp && contentRefProp.current || contentRef.current ? nullifyTransforms(contentRefProp ? contentRefProp.current : contentRef.current) : {\n        height: defaultHeight\n      };\n\n      if (yOffset + popoverRect.height > window.innerHeight && rect.top - 15 > popoverRect.height) {\n        position = 'top';\n        yOffset = window.innerHeight - rect.bottom + rect.height;\n      }\n\n      if (yOffset + popoverRect.height > window.innerHeight && position === 'bottom') {\n        position = 'top';\n        yOffset = 0;\n      }\n    }\n\n    return {\n      yOffset,\n      right,\n      position,\n      otherStyles\n    };\n  }, [s, shouldCalculate, ref, ref.current, contentRefProp, contentRef.current, defaultHeight]);\n  return {\n    refreshPopover: refresh,\n    styles: _objectSpread({\n      '--modal-y-offset': `${yOffset}px`,\n      '--modal-x-offset': `${right}px`\n    }, otherStyles),\n    position,\n    popoverProps: _objectSpread({\n      ref: contentRefProp || contentRef\n    }, position ? {\n      'data-position': position\n    } : {})\n  };\n};\n\nexport default usePopoverMaker;"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///9144\n")},694:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n \"Z\": () => (/* binding */ single_picker)\n});\n\n// EXTERNAL MODULE: external \"window.wp.element\"\nvar external_window_wp_element_ = __webpack_require__(1381);\n// EXTERNAL MODULE: external \"window.wp.components\"\nvar external_window_wp_components_ = __webpack_require__(8441);\n// EXTERNAL MODULE: external \"window._\"\nvar external_window_ = __webpack_require__(6715);\n// EXTERNAL MODULE: external \"jQuery\"\nvar external_jQuery_ = __webpack_require__(5311);\n// EXTERNAL MODULE: external \"window.wp.i18n\"\nvar external_window_wp_i18n_ = __webpack_require__(5652);\n// EXTERNAL MODULE: ./static/js/options/helpers/normalize-color.js\nvar normalize_color = __webpack_require__(9287);\n;// CONCATENATED MODULE: ./static/js/options/options/color-picker/color-picker-iris.js\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\n\nconst ColorPickerIris = _ref => {\n let {\n onChange,\n value,\n value: {\n color\n }\n } = _ref;\n const isNew = wp.components.GradientPicker;\n return (0,external_window_wp_element_.createElement)(\"div\", {\n className: isNew ? 'ct-gutenberg-color-picker-new' : 'ct-gutenberg-color-picker'\n }, (0,external_window_wp_element_.createElement)(external_window_wp_components_.ColorPicker, _extends({\n color: color,\n enableAlpha: true\n }, isNew ? {\n onChange: color => {\n onChange(_objectSpread(_objectSpread({}, value), {}, {\n color: (0,normalize_color/* normalizeColor */.u)(color)\n }));\n }\n } : {\n onChangeComplete: result => {\n onChange(_objectSpread(_objectSpread({}, value), {}, {\n color: result.rgb.a === 1 ? result.hex : `rgba(${result.rgb.r}, ${result.rgb.g}, ${result.rgb.b}, ${result.rgb.a})`\n }));\n }\n })), (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-color-picker-value\"\n }, (0,external_window_wp_element_.createElement)(\"input\", {\n onChange: _ref2 => {\n let {\n target: {\n value: color\n }\n } = _ref2;\n onChange(_objectSpread(_objectSpread({}, value), {}, {\n color: (0,normalize_color/* normalizeColor */.u)(color)\n }));\n },\n value: (0,normalize_color/* normalizeColor */.u)(color),\n type: \"text\"\n })));\n};\n\n/* harmony default export */ const color_picker_iris = (ColorPickerIris);\n// EXTERNAL MODULE: ./node_modules/classnames/index.js\nvar classnames = __webpack_require__(4184);\nvar classnames_default = /*#__PURE__*/__webpack_require__.n(classnames);\n// EXTERNAL MODULE: ./static/js/options/helpers/usePopoverMaker.js\nvar usePopoverMaker = __webpack_require__(9144);\n;// CONCATENATED MODULE: ./static/js/options/options/color-picker/picker-modal.js\nfunction picker_modal_extends() { picker_modal_extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return picker_modal_extends.apply(this, arguments); }\n\nfunction picker_modal_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction picker_modal_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? picker_modal_ownKeys(Object(source), !0).forEach(function (key) { picker_modal_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : picker_modal_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction picker_modal_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\nconst getNoColorPropFor = option => option.noColorTransparent ? 'transparent' : `CT_CSS_SKIP_RULE`;\n\nconst focusOrOpenCustomizerSectionProps = section => picker_modal_objectSpread({\n target: '_blank',\n href: `${window.ct_localizations ? window.ct_localizations.customizer_url : ''}${encodeURIComponent(`[section]=${section}`)}`\n}, wp && wp.customize && wp.customize.section ? {\n onClick: e => {\n e.preventDefault();\n wp.customize.section(section).expand();\n }\n} : {});\n\nconst getLeftForEl = (modal, el) => {\n if (!modal) return;\n if (!el) return;\n let style = getComputedStyle(modal);\n let wrapperLeft = parseFloat(style.left);\n el = el.firstElementChild.getBoundingClientRect();\n return {\n '--option-modal-arrow-position': `${el.left + el.width / 2 - wrapperLeft - 6}px`\n };\n};\n\nconst PickerModal = _ref => {\n let {\n containerRef,\n el,\n value,\n picker,\n onChange,\n option,\n style,\n wrapperProps = {},\n inline_modal,\n appendToBody,\n inheritValue\n } = _ref;\n const getValueForPicker = (0,external_window_wp_element_.useMemo)(() => {\n if (value.color === getNoColorPropFor(option)) {\n return {\n color: '',\n key: 'empty'\n };\n }\n\n if ((value.color || '').indexOf(getNoColorPropFor(option)) > -1) {\n return {\n key: '',\n color: ''\n };\n }\n\n if ((value.color || '').indexOf(getNoColorPropFor(option)) > -1 && picker.inherit) {\n return {\n key: 'picker' + inheritValue,\n color: getComputedStyle(document.documentElement).getPropertyValue(inheritValue.replace(/var\\(/, '').replace(/\\)/, '')).trim().replace(/\\s/g, '')\n };\n }\n\n if ((value.color || '').indexOf('var') > -1) {\n return {\n key: 'var' + value.color,\n color: getComputedStyle(document.documentElement).getPropertyValue(value.color.replace(/var\\(/, '').replace(/\\)/, '')).trim().replace(/\\s/g, '')\n };\n }\n\n return {\n key: 'color',\n color: value.color\n };\n }, [value, option, picker, inheritValue]);\n let valueToCheck = value.color;\n\n if ((value.color || '').indexOf(getNoColorPropFor(option)) > -1 && picker.inherit) {\n valueToCheck = inheritValue;\n }\n\n const arrowLeft = (0,external_window_wp_element_.useMemo)(() => wrapperProps.ref && wrapperProps.ref.current && el && getLeftForEl(wrapperProps.ref.current, el.current), [wrapperProps.ref && wrapperProps.ref.current, el && el.current]);\n return (0,external_window_wp_element_.createElement)(external_window_wp_element_.Fragment, null, (0,external_window_wp_element_.createElement)(\"div\", picker_modal_extends({\n tabIndex: \"0\",\n className: classnames_default()(`ct-color-picker-modal`, {\n 'ct-option-modal': !inline_modal && appendToBody\n }, option.modalClassName),\n style: picker_modal_objectSpread(picker_modal_objectSpread({}, arrowLeft), style ? style : {})\n }, wrapperProps), !option.predefined && (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-color-picker-top\"\n }, (0,external_window_wp_element_.createElement)(\"ul\", {\n className: \"ct-color-picker-skins\"\n }, ['paletteColor1', 'paletteColor2', 'paletteColor3', 'paletteColor4', 'paletteColor5', 'paletteColor6', 'paletteColor7', 'paletteColor8'].map(color => (0,external_window_wp_element_.createElement)(\"li\", {\n key: color,\n style: {\n background: `var(--${color})`\n },\n className: classnames_default()({\n active: valueToCheck === `var(--${color})`\n }),\n onClick: () => onChange(picker_modal_objectSpread(picker_modal_objectSpread({}, value), {}, {\n color: `var(--${color})`\n }))\n }, (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-tooltip-top\"\n }, {\n paletteColor1: (0,external_window_wp_i18n_.__)('Color 1', 'blocksy'),\n paletteColor2: (0,external_window_wp_i18n_.__)('Color 2', 'blocksy'),\n paletteColor3: (0,external_window_wp_i18n_.__)('Color 3', 'blocksy'),\n paletteColor4: (0,external_window_wp_i18n_.__)('Color 4', 'blocksy'),\n paletteColor5: (0,external_window_wp_i18n_.__)('Color 5', 'blocksy'),\n paletteColor6: (0,external_window_wp_i18n_.__)('Color 6', 'blocksy'),\n paletteColor7: (0,external_window_wp_i18n_.__)('Color 7', 'blocksy'),\n paletteColor8: (0,external_window_wp_i18n_.__)('Color 8', 'blocksy')\n }[color]))), !option.skipNoColorPill && false && 0)), (0,external_window_wp_element_.createElement)(color_picker_iris, {\n onChange: v => onChange(v),\n value: picker_modal_objectSpread(picker_modal_objectSpread({}, value), {}, {\n color: getValueForPicker.color\n })\n })));\n};\n\n/* harmony default export */ const picker_modal = (PickerModal);\n// EXTERNAL MODULE: ./node_modules/react-spring/renderprops.js\nvar renderprops = __webpack_require__(4823);\n// EXTERNAL MODULE: ./node_modules/bezier-easing/src/index.js\nvar src = __webpack_require__(3431);\nvar src_default = /*#__PURE__*/__webpack_require__.n(src);\n// EXTERNAL MODULE: ./node_modules/match-conditions/dist/index.es.js\nvar index_es = __webpack_require__(7465);\n;// CONCATENATED MODULE: ./static/js/options/options/color-picker/single-picker.js\nfunction single_picker_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction single_picker_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? single_picker_ownKeys(Object(source), !0).forEach(function (key) { single_picker_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : single_picker_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction single_picker_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\n\n\n\nconst resolveInherit = (picker, option, values) => {\n if (typeof picker.inherit === 'string') {\n if (picker.inherit.indexOf('self') > -1) {\n const currentValue = values[option.id] || option.value;\n const pickerToInheritFrom = picker.inherit.split(':')[1];\n let maybeNextValue = currentValue[pickerToInheritFrom].color;\n\n if (maybeNextValue.indexOf('CT_CSS_SKIP_RULE') > -1) {\n maybeNextValue = option.pickers.find(_ref => {\n let {\n id\n } = _ref;\n return id === pickerToInheritFrom;\n }).inherit;\n }\n\n return {\n background: maybeNextValue || ''\n };\n }\n\n return {\n background: picker.inherit\n };\n }\n\n let background = Object.keys(picker.inherit).reduce((maybeResult, currentVar) => {\n if (maybeResult) {\n return maybeResult;\n }\n\n if ((0,index_es/* matchValuesWithCondition */.Nj)((0,index_es/* normalizeCondition */.KY)(picker.inherit[currentVar]), picker.inherit_source === 'global' ? Object.keys(picker.inherit[currentVar]).reduce((current, key) => single_picker_objectSpread(single_picker_objectSpread({}, current), {}, {\n [key]: wp.customize(key)()\n }), {}) : values)) {\n return currentVar;\n }\n\n return maybeResult;\n }, null);\n\n if (!background) {\n return {};\n }\n\n return {\n background\n };\n};\n\nconst SinglePicker = _ref2 => {\n let {\n option,\n value,\n onChange,\n picker,\n onPickingChange,\n stopTransitioning,\n innerRef,\n containerRef,\n modalRef,\n isTransitioning,\n isPicking,\n values\n } = _ref2;\n const el = (0,external_window_wp_element_.useRef)();\n const {\n appendToBody = true\n } = option;\n const {\n refreshPopover,\n styles,\n popoverProps\n } = (0,usePopoverMaker/* default */.Z)({\n contentRef: modalRef,\n ref: containerRef || {},\n defaultHeight: 379,\n shouldCalculate: !option.inline_modal || appendToBody\n });\n\n if (option.inline_modal) {\n return (0,external_window_wp_element_.createElement)(picker_modal, {\n containerRef: containerRef,\n option: option,\n onChange: onChange,\n picker: picker,\n value: value,\n inline_modal: !!option.inline_modal\n });\n }\n\n let modal = null;\n\n if (isTransitioning === picker.id || (isPicking || '').split(':')[0] === picker.id) {\n modal = (0,external_window_wp_element_.createPortal)((0,external_window_wp_element_.createElement)(renderprops/* Transition */.uT, {\n items: isPicking,\n onRest: () => stopTransitioning(),\n config: {\n duration: 100,\n easing: src_default()(0.25, 0.1, 0.25, 1.0)\n },\n from: (isPicking || '').indexOf(':') === -1 ? {\n transform: 'scale3d(0.95, 0.95, 1)',\n opacity: 0\n } : {\n opacity: 1\n },\n enter: (isPicking || '').indexOf(':') === -1 ? {\n transform: 'scale3d(1, 1, 1)',\n opacity: 1\n } : {\n opacity: 1\n },\n leave: (isPicking || '').indexOf(':') === -1 ? {\n transform: 'scale3d(0.95, 0.95, 1)',\n opacity: 0\n } : {\n opacity: 1\n }\n }, isPicking => (isPicking || '').split(':')[0] === picker.id && (props => (0,external_window_wp_element_.createElement)(picker_modal, {\n style: single_picker_objectSpread(single_picker_objectSpread({}, props), appendToBody ? styles : {}),\n option: option,\n onChange: onChange,\n picker: picker,\n value: value,\n el: el,\n inheritValue: picker.inherit ? resolveInherit(picker, option, values).background : '',\n wrapperProps: appendToBody ? popoverProps : {\n ref: modalRef\n },\n appendToBody: appendToBody\n }))), appendToBody ? document.body : el.current.closest('section').parentNode);\n }\n\n return (0,external_window_wp_element_.createElement)(\"div\", {\n ref: instance => {\n el.current = instance;\n\n if (innerRef) {\n innerRef.current = instance;\n }\n },\n className: classnames_default()('ct-color-picker-single', {})\n }, (0,external_window_wp_element_.createElement)(\"span\", {\n tabIndex: \"0\"\n }, (0,external_window_wp_element_.createElement)(\"span\", {\n tabIndex: \"0\",\n className: classnames_default()({\n [`ct-no-color`]: (value || {}).color === getNoColorPropFor(option),\n [`ct-color-inherit`]: (value || {\n color: ''\n }).color.indexOf('INHERIT') > -1\n }),\n onClick: e => {\n if (option.skipModal) {\n return;\n }\n\n e.stopPropagation();\n refreshPopover();\n let futureIsPicking = isPicking ? isPicking.split(':')[0] === picker.id ? null : `${picker.id}:${isPicking.split(':')[0]}` : picker.id;\n onPickingChange(futureIsPicking);\n },\n style: ((value || {}).color || '').indexOf(getNoColorPropFor(option)) === -1 ? {\n background: (value || {}).color\n } : single_picker_objectSpread({}, picker.inherit && (value || {}).color !== getNoColorPropFor(option) ? resolveInherit(picker, option, values) : {})\n }, (0,external_window_wp_element_.createElement)(\"i\", {\n className: \"ct-tooltip-top\"\n }, (value || {\n color: ''\n }).color.indexOf('INHERIT') > -1 ? (0,external_window_wp_i18n_.__)('Inherited', 'blocksy') : picker.title), (value || {\n color: ''\n }).color.indexOf('INHERIT') > -1 && (0,external_window_wp_element_.createElement)(\"svg\", {\n width: \"25\",\n height: \"25\",\n viewBox: \"0 0 30 30\"\n }, (0,external_window_wp_element_.createElement)(\"path\", {\n d: \"M15 3c-3 0-5.7 1.1-7.8 2.9-.4.3-.5.9-.2 1.4.3.4 1 .5 1.4.2h.1C10.3 5.9 12.5 5 15 5c5.2 0 9.5 3.9 10 9h-3l4 6 4-6h-3.1C26.4 7.9 21.3 3 15 3zM4 10l-4 6h3.1c.5 6.1 5.6 11 11.9 11 3 0 5.7-1.1 7.8-2.9.4-.3.5-1 .2-1.4-.3-.4-1-.5-1.4-.2h-.1c-1.7 1.5-4 2.4-6.5 2.4-5.2 0-9.5-3.9-10-9h3L4 10z\"\n })))), modal);\n};\n\n/* harmony default export */ const single_picker = (SinglePicker);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"694.js","mappings":";;;;;;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;AC3DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAUA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC5IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./static/js/options/options/color-picker/color-picker-iris.js?250c","webpack://blocksyOptions/./static/js/options/options/color-picker/picker-modal.js?8c84","webpack://blocksyOptions/./static/js/options/options/color-picker/single-picker.js?d3fd"],"sourcesContent":["function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, Component, createRef } from '@wordpress/element';\nimport { ColorPicker } from '@wordpress/components';\nimport _ from '_';\nimport $ from 'jquery';\nimport { __ } from 'ct-i18n';\nimport { normalizeColor } from '../../helpers/normalize-color';\n\nconst ColorPickerIris = _ref => {\n  let {\n    onChange,\n    value,\n    value: {\n      color\n    }\n  } = _ref;\n  const isNew = wp.components.GradientPicker;\n  return createElement(\"div\", {\n    className: isNew ? 'ct-gutenberg-color-picker-new' : 'ct-gutenberg-color-picker'\n  }, createElement(ColorPicker, _extends({\n    color: color,\n    enableAlpha: true\n  }, isNew ? {\n    onChange: color => {\n      onChange(_objectSpread(_objectSpread({}, value), {}, {\n        color: normalizeColor(color)\n      }));\n    }\n  } : {\n    onChangeComplete: result => {\n      onChange(_objectSpread(_objectSpread({}, value), {}, {\n        color: result.rgb.a === 1 ? result.hex : `rgba(${result.rgb.r}, ${result.rgb.g}, ${result.rgb.b}, ${result.rgb.a})`\n      }));\n    }\n  })), createElement(\"div\", {\n    className: \"ct-color-picker-value\"\n  }, createElement(\"input\", {\n    onChange: _ref2 => {\n      let {\n        target: {\n          value: color\n        }\n      } = _ref2;\n      onChange(_objectSpread(_objectSpread({}, value), {}, {\n        color: normalizeColor(color)\n      }));\n    },\n    value: normalizeColor(color),\n    type: \"text\"\n  })));\n};\n\nexport default ColorPickerIris;","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, Component, useRef, useCallback, useMemo, createRef, Fragment } from '@wordpress/element';\nimport ColorPickerIris from './color-picker-iris.js';\nimport classnames from 'classnames';\nimport { __ } from 'ct-i18n';\nimport { nullifyTransforms } from '../../helpers/usePopoverMaker';\nexport const getNoColorPropFor = option => option.noColorTransparent ? 'transparent' : `CT_CSS_SKIP_RULE`;\n\nconst focusOrOpenCustomizerSectionProps = section => _objectSpread({\n  target: '_blank',\n  href: `${window.ct_localizations ? window.ct_localizations.customizer_url : ''}${encodeURIComponent(`[section]=${section}`)}`\n}, wp && wp.customize && wp.customize.section ? {\n  onClick: e => {\n    e.preventDefault();\n    wp.customize.section(section).expand();\n  }\n} : {});\n\nconst getLeftForEl = (modal, el) => {\n  if (!modal) return;\n  if (!el) return;\n  let style = getComputedStyle(modal);\n  let wrapperLeft = parseFloat(style.left);\n  el = el.firstElementChild.getBoundingClientRect();\n  return {\n    '--option-modal-arrow-position': `${el.left + el.width / 2 - wrapperLeft - 6}px`\n  };\n};\n\nconst PickerModal = _ref => {\n  let {\n    containerRef,\n    el,\n    value,\n    picker,\n    onChange,\n    option,\n    style,\n    wrapperProps = {},\n    inline_modal,\n    appendToBody,\n    inheritValue\n  } = _ref;\n  const getValueForPicker = useMemo(() => {\n    if (value.color === getNoColorPropFor(option)) {\n      return {\n        color: '',\n        key: 'empty'\n      };\n    }\n\n    if ((value.color || '').indexOf(getNoColorPropFor(option)) > -1) {\n      return {\n        key: '',\n        color: ''\n      };\n    }\n\n    if ((value.color || '').indexOf(getNoColorPropFor(option)) > -1 && picker.inherit) {\n      return {\n        key: 'picker' + inheritValue,\n        color: getComputedStyle(document.documentElement).getPropertyValue(inheritValue.replace(/var\\(/, '').replace(/\\)/, '')).trim().replace(/\\s/g, '')\n      };\n    }\n\n    if ((value.color || '').indexOf('var') > -1) {\n      return {\n        key: 'var' + value.color,\n        color: getComputedStyle(document.documentElement).getPropertyValue(value.color.replace(/var\\(/, '').replace(/\\)/, '')).trim().replace(/\\s/g, '')\n      };\n    }\n\n    return {\n      key: 'color',\n      color: value.color\n    };\n  }, [value, option, picker, inheritValue]);\n  let valueToCheck = value.color;\n\n  if ((value.color || '').indexOf(getNoColorPropFor(option)) > -1 && picker.inherit) {\n    valueToCheck = inheritValue;\n  }\n\n  const arrowLeft = useMemo(() => wrapperProps.ref && wrapperProps.ref.current && el && getLeftForEl(wrapperProps.ref.current, el.current), [wrapperProps.ref && wrapperProps.ref.current, el && el.current]);\n  return createElement(Fragment, null, createElement(\"div\", _extends({\n    tabIndex: \"0\",\n    className: classnames(`ct-color-picker-modal`, {\n      'ct-option-modal': !inline_modal && appendToBody\n    }, option.modalClassName),\n    style: _objectSpread(_objectSpread({}, arrowLeft), style ? style : {})\n  }, wrapperProps), !option.predefined && createElement(\"div\", {\n    className: \"ct-color-picker-top\"\n  }, createElement(\"ul\", {\n    className: \"ct-color-picker-skins\"\n  }, ['paletteColor1', 'paletteColor2', 'paletteColor3', 'paletteColor4', 'paletteColor5', 'paletteColor6', 'paletteColor7', 'paletteColor8'].map(color => createElement(\"li\", {\n    key: color,\n    style: {\n      background: `var(--${color})`\n    },\n    className: classnames({\n      active: valueToCheck === `var(--${color})`\n    }),\n    onClick: () => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      color: `var(--${color})`\n    }))\n  }, createElement(\"div\", {\n    className: \"ct-tooltip-top\"\n  }, {\n    paletteColor1: __('Color 1', 'blocksy'),\n    paletteColor2: __('Color 2', 'blocksy'),\n    paletteColor3: __('Color 3', 'blocksy'),\n    paletteColor4: __('Color 4', 'blocksy'),\n    paletteColor5: __('Color 5', 'blocksy'),\n    paletteColor6: __('Color 6', 'blocksy'),\n    paletteColor7: __('Color 7', 'blocksy'),\n    paletteColor8: __('Color 8', 'blocksy')\n  }[color]))), !option.skipNoColorPill && false && createElement(\"li\", {\n    onClick: () => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      color: getNoColorPropFor(option)\n    })),\n    className: classnames('ct-no-color-pill', {\n      active: value.color === getNoColorPropFor(option)\n    })\n  }, createElement(\"i\", {\n    className: \"ct-tooltip-top\"\n  }, __('No Color', 'blocksy'))))), createElement(ColorPickerIris, {\n    onChange: v => onChange(v),\n    value: _objectSpread(_objectSpread({}, value), {}, {\n      color: getValueForPicker.color\n    })\n  })));\n};\n\nexport default PickerModal;","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, Component, createPortal, useRef, createRef } from '@wordpress/element';\nimport PickerModal, { getNoColorPropFor } from './picker-modal';\nimport { Transition } from 'react-spring/renderprops';\nimport bezierEasing from 'bezier-easing';\nimport classnames from 'classnames';\nimport { __ } from 'ct-i18n';\nimport { normalizeCondition, matchValuesWithCondition } from 'match-conditions';\nimport usePopoverMaker from '../../helpers/usePopoverMaker';\n\nconst resolveInherit = (picker, option, values) => {\n  if (typeof picker.inherit === 'string') {\n    if (picker.inherit.indexOf('self') > -1) {\n      const currentValue = values[option.id] || option.value;\n      const pickerToInheritFrom = picker.inherit.split(':')[1];\n      let maybeNextValue = currentValue[pickerToInheritFrom].color;\n\n      if (maybeNextValue.indexOf('CT_CSS_SKIP_RULE') > -1) {\n        maybeNextValue = option.pickers.find(_ref => {\n          let {\n            id\n          } = _ref;\n          return id === pickerToInheritFrom;\n        }).inherit;\n      }\n\n      return {\n        background: maybeNextValue || ''\n      };\n    }\n\n    return {\n      background: picker.inherit\n    };\n  }\n\n  let background = Object.keys(picker.inherit).reduce((maybeResult, currentVar) => {\n    if (maybeResult) {\n      return maybeResult;\n    }\n\n    if (matchValuesWithCondition(normalizeCondition(picker.inherit[currentVar]), picker.inherit_source === 'global' ? Object.keys(picker.inherit[currentVar]).reduce((current, key) => _objectSpread(_objectSpread({}, current), {}, {\n      [key]: wp.customize(key)()\n    }), {}) : values)) {\n      return currentVar;\n    }\n\n    return maybeResult;\n  }, null);\n\n  if (!background) {\n    return {};\n  }\n\n  return {\n    background\n  };\n};\n\nconst SinglePicker = _ref2 => {\n  let {\n    option,\n    value,\n    onChange,\n    picker,\n    onPickingChange,\n    stopTransitioning,\n    innerRef,\n    containerRef,\n    modalRef,\n    isTransitioning,\n    isPicking,\n    values\n  } = _ref2;\n  const el = useRef();\n  const {\n    appendToBody = true\n  } = option;\n  const {\n    refreshPopover,\n    styles,\n    popoverProps\n  } = usePopoverMaker({\n    contentRef: modalRef,\n    ref: containerRef || {},\n    defaultHeight: 379,\n    shouldCalculate: !option.inline_modal || appendToBody\n  });\n\n  if (option.inline_modal) {\n    return createElement(PickerModal, {\n      containerRef: containerRef,\n      option: option,\n      onChange: onChange,\n      picker: picker,\n      value: value,\n      inline_modal: !!option.inline_modal\n    });\n  }\n\n  let modal = null;\n\n  if (isTransitioning === picker.id || (isPicking || '').split(':')[0] === picker.id) {\n    modal = createPortal(createElement(Transition, {\n      items: isPicking,\n      onRest: () => stopTransitioning(),\n      config: {\n        duration: 100,\n        easing: bezierEasing(0.25, 0.1, 0.25, 1.0)\n      },\n      from: (isPicking || '').indexOf(':') === -1 ? {\n        transform: 'scale3d(0.95, 0.95, 1)',\n        opacity: 0\n      } : {\n        opacity: 1\n      },\n      enter: (isPicking || '').indexOf(':') === -1 ? {\n        transform: 'scale3d(1, 1, 1)',\n        opacity: 1\n      } : {\n        opacity: 1\n      },\n      leave: (isPicking || '').indexOf(':') === -1 ? {\n        transform: 'scale3d(0.95, 0.95, 1)',\n        opacity: 0\n      } : {\n        opacity: 1\n      }\n    }, isPicking => (isPicking || '').split(':')[0] === picker.id && (props => createElement(PickerModal, {\n      style: _objectSpread(_objectSpread({}, props), appendToBody ? styles : {}),\n      option: option,\n      onChange: onChange,\n      picker: picker,\n      value: value,\n      el: el,\n      inheritValue: picker.inherit ? resolveInherit(picker, option, values).background : '',\n      wrapperProps: appendToBody ? popoverProps : {\n        ref: modalRef\n      },\n      appendToBody: appendToBody\n    }))), appendToBody ? document.body : el.current.closest('section').parentNode);\n  }\n\n  return createElement(\"div\", {\n    ref: instance => {\n      el.current = instance;\n\n      if (innerRef) {\n        innerRef.current = instance;\n      }\n    },\n    className: classnames('ct-color-picker-single', {})\n  }, createElement(\"span\", {\n    tabIndex: \"0\"\n  }, createElement(\"span\", {\n    tabIndex: \"0\",\n    className: classnames({\n      [`ct-no-color`]: (value || {}).color === getNoColorPropFor(option),\n      [`ct-color-inherit`]: (value || {\n        color: ''\n      }).color.indexOf('INHERIT') > -1\n    }),\n    onClick: e => {\n      if (option.skipModal) {\n        return;\n      }\n\n      e.stopPropagation();\n      refreshPopover();\n      let futureIsPicking = isPicking ? isPicking.split(':')[0] === picker.id ? null : `${picker.id}:${isPicking.split(':')[0]}` : picker.id;\n      onPickingChange(futureIsPicking);\n    },\n    style: ((value || {}).color || '').indexOf(getNoColorPropFor(option)) === -1 ? {\n      background: (value || {}).color\n    } : _objectSpread({}, picker.inherit && (value || {}).color !== getNoColorPropFor(option) ? resolveInherit(picker, option, values) : {})\n  }, createElement(\"i\", {\n    className: \"ct-tooltip-top\"\n  }, (value || {\n    color: ''\n  }).color.indexOf('INHERIT') > -1 ? __('Inherited', 'blocksy') : picker.title), (value || {\n    color: ''\n  }).color.indexOf('INHERIT') > -1 && createElement(\"svg\", {\n    width: \"25\",\n    height: \"25\",\n    viewBox: \"0 0 30 30\"\n  }, createElement(\"path\", {\n    d: \"M15 3c-3 0-5.7 1.1-7.8 2.9-.4.3-.5.9-.2 1.4.3.4 1 .5 1.4.2h.1C10.3 5.9 12.5 5 15 5c5.2 0 9.5 3.9 10 9h-3l4 6 4-6h-3.1C26.4 7.9 21.3 3 15 3zM4 10l-4 6h3.1c.5 6.1 5.6 11 11.9 11 3 0 5.7-1.1 7.8-2.9.4-.3.5-1 .2-1.4-.3-.4-1-.5-1.4-.2h-.1c-1.7 1.5-4 2.4-6.5 2.4-5.2 0-9.5-3.9-10-9h3L4 10z\"\n  })))), modal);\n};\n\nexport default SinglePicker;"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///694\n")},9285:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "LayersContext": () => (/* binding */ LayersContext),\n/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(4184);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var react_sortable_hoc__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(6362);\n/* harmony import */ var array_move__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(454);\n/* harmony import */ var array_move__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(array_move__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var ct_i18n__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(5652);\n/* harmony import */ var ct_i18n__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(ct_i18n__WEBPACK_IMPORTED_MODULE_4__);\n/* harmony import */ var _OptionsPanel__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7429);\n/* harmony import */ var _helpers_get_value_from_input__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(7069);\n/* harmony import */ var nanoid__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(1496);\n/* harmony import */ var nanoid__WEBPACK_IMPORTED_MODULE_7___default = /*#__PURE__*/__webpack_require__.n(nanoid__WEBPACK_IMPORTED_MODULE_7__);\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\n\n\nconst LayerControls = (0,react_sortable_hoc__WEBPACK_IMPORTED_MODULE_2__/* .SortableHandle */ .W6)(_ref => {\n let {\n items,\n onChange,\n value\n } = _ref;\n const {\n removeForId,\n addForId,\n option,\n toggleOptionsPanel\n } = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useContext)(LayersContext);\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", {\n className: "ct-layer-controls"\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("button", {\n type: "button",\n className: "ct-visibility",\n onClick: e => {\n e.stopPropagation();\n onChange(items.map(l => l.__id === value.__id ? _objectSpread(_objectSpread({}, l), {}, {\n enabled: !_objectSpread({\n enabled: true\n }, l).enabled\n }) : l));\n }\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("svg", {\n width: "13px",\n height: "13px",\n viewBox: "0 0 24 24"\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("path", {\n d: "M12,4C4.1,4,0,12,0,12s3.1,8,12,8c8.1,0,12-8,12-8S20.1,4,12,4z M12,17c-2.9,0-5-2.2-5-5c0-2.8,2.1-5,5-5s5,2.2,5,5C17,14.8,14.9,17,12,17z M12,9c-1.7,0-3,1.4-3,3c0,1.6,1.3,3,3,3s3-1.4,3-3C15,10.4,13.7,9,12,9z"\n }))), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", {\n className: "ct-layer-label"\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("span", null, window._.template(option[\'preview-template\'])(value))), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("button", {\n type: "button",\n className: "ct-clone",\n onClick: () => addForId(value)\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("svg", {\n width: "11px",\n height: "11px",\n viewBox: "0 0 24 24"\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("path", {\n d: "M23,24H7.7c-0.6,0-1-0.4-1-1V7.7c0-0.6,0.4-1,1-1H23c0.6,0,1,0.4,1,1V23C24,23.6,23.6,24,23,24z M8.7,22H22V8.7 H8.7V22z"\n }), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("path", {\n d: "M17.3,16.3c0,0.6-0.4,1-1,1H1c-0.6,0-1-0.4-1-1V1c0-0.6,0.4-1,1-1h15.3c0.6,0,1,0.4,1,1V16.3z"\n })), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("i", {\n className: "ct-tooltip-top"\n }, (0,ct_i18n__WEBPACK_IMPORTED_MODULE_4__.__)(\'Clone Item\', \'blocksy\'))), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("button", {\n type: "button",\n className: "ct-remove",\n onClick: () => removeForId(value.__id)\n }), option[\'inner-options\'] && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("button", {\n type: "button",\n className: "ct-toggle",\n onMouseDown: e => {\n e.stopPropagation();\n },\n onClick: e => {\n e.stopPropagation();\n toggleOptionsPanel(value.__id);\n }\n }));\n});\n\nconst valueWithUniqueIds = value => value.map(singleItem => _objectSpread(_objectSpread({}, singleItem), singleItem.__id ? {} : {\n __id: nanoid__WEBPACK_IMPORTED_MODULE_7___default()()\n}));\n\nconst getDefaultState = () => ({\n currentlyPickedItem: null,\n isDragging: false,\n isOpen: false\n});\n\nconst LayersContext = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createContext)(getDefaultState());\nconst {\n Provider,\n Consumer\n} = LayersContext;\n\nclass SingleItem extends _wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Component {\n constructor() {\n super(...arguments);\n\n _defineProperty(this, "state", {\n isOpen: false\n });\n }\n\n render() {\n const {\n value,\n items,\n onChange\n } = this.props;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(Consumer, null, _ref2 => {\n let {\n option,\n isDragging,\n isOpen,\n parentValue\n } = _ref2;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("li", {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()(\'ct-layer\', option.itemClass, {\n [`ct-disabled`]: !_objectSpread({\n enabled: true\n }, value).enabled\n })\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(LayerControls, {\n items: items,\n onChange: onChange,\n value: value\n }), isOpen === value.__id && (!isDragging || isDragging && isDragging !== isOpen) && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", {\n className: "ct-layer-content"\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_OptionsPanel__WEBPACK_IMPORTED_MODULE_5__/* ["default"] */ .Z, {\n hasRevertButton: false,\n parentValue: parentValue,\n onChange: (key, newValue) => {\n onChange(items.map(l => l.__id === value.__id ? _objectSpread(_objectSpread({}, l), {}, {\n [key]: newValue\n }) : l));\n },\n value: (0,_helpers_get_value_from_input__WEBPACK_IMPORTED_MODULE_6__/* .getValueFromInput */ .n6)(option[\'inner-options\'], _objectSpread(_objectSpread({}, option.value.filter(_ref3 => {\n let {\n id\n } = _ref3;\n return id === value.id;\n }).length > 1 ? option.value.filter(_ref4 => {\n let {\n id\n } = _ref4;\n return value.id === id;\n })[items.filter(_ref5 => {\n let {\n id\n } = _ref5;\n return id === value.id;\n }).map(_ref6 => {\n let {\n __id\n } = _ref6;\n return __id;\n }).indexOf(value.__id)] : {}), value)),\n options: option[\'inner-options\']\n })));\n });\n }\n\n}\n\nconst SortableItem = (0,react_sortable_hoc__WEBPACK_IMPORTED_MODULE_2__/* .SortableElement */ .W8)(SingleItem);\nconst SortableList = (0,react_sortable_hoc__WEBPACK_IMPORTED_MODULE_2__/* .SortableContainer */ .JN)(_ref7 => {\n let {\n items,\n onChange\n } = _ref7;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(Consumer, null, _ref8 => {\n let {\n option\n } = _ref8;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("ul", {\n className: "ct-layers"\n }, items.map((value, index) => (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(SortableItem, {\n key: value.__id,\n index: index,\n onChange: onChange,\n value: value,\n items: items,\n disabled: !!option.disableDrag\n })));\n });\n});\n\nconst Layers = _ref9 => {\n let {\n value,\n option,\n onChange,\n values\n } = _ref9;\n const [state, setState] = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useState)(getDefaultState());\n\n const localOnChange = v => {\n onChange(v);\n };\n\n const addForId = function () {\n let val = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n localOnChange([...(value || []), _objectSpread(_objectSpread(_objectSpread({\n enabled: true\n }, (0,_helpers_get_value_from_input__WEBPACK_IMPORTED_MODULE_6__/* .getValueFromInput */ .n6)(option[\'inner-options\'] || {}, {})), val), {}, {\n __id: nanoid__WEBPACK_IMPORTED_MODULE_7___default()()\n })]);\n };\n\n const computedValue = valueWithUniqueIds(value);\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(Provider, {\n value: _objectSpread(_objectSpread({}, state), {}, {\n parentValue: values,\n addForId,\n option,\n removeForId: idToRemove => localOnChange(valueWithUniqueIds(value).filter(_ref10 => {\n let {\n __id: id\n } = _ref10;\n return id !== idToRemove;\n })),\n toggleOptionsPanel: idToAdd => {\n if (value.length > 0 && !value[0].__id) {\n localOnChange(computedValue);\n }\n\n setState(state => _objectSpread(_objectSpread({}, state), {}, {\n isOpen: state.isOpen === idToAdd ? false : idToAdd\n }));\n }\n })\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(SortableList, {\n useDragHandle: true,\n distance: 3,\n lockAxis: "y",\n items: computedValue,\n onChange: v => {\n localOnChange(v);\n },\n helperContainer: () => document.querySelector(\'#customize-theme-controls\') || document.body,\n onSortEnd: _ref11 => {\n let {\n oldIndex,\n newIndex\n } = _ref11;\n localOnChange(array_move__WEBPACK_IMPORTED_MODULE_3___default()(computedValue, oldIndex, newIndex));\n setState(state => _objectSpread(_objectSpread({}, state), {}, {\n isDragging: false\n }));\n },\n updateBeforeSortStart: _ref12 => {\n let {\n index\n } = _ref12;\n new Promise(resolve => {\n if (value.length > 0 && !value[0].__id) {\n wp.customize && wp.customize.previewer && wp.customize.previewer.send(\'ct:sync:refresh_partial\', {\n shouldSkip: true\n });\n localOnChange(computedValue);\n }\n\n setState(state => _objectSpread(_objectSpread({}, state), {}, {\n isDragging: computedValue[index].__id\n }));\n resolve();\n });\n }\n }), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("button", {\n className: "button",\n onClick: e => {\n e.preventDefault();\n addForId();\n }\n }, (0,ct_i18n__WEBPACK_IMPORTED_MODULE_4__.__)(\'Add New Item\', \'blocksy\')));\n};\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Layers);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"9285.js","mappings":";;;;;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./static/js/options/options/ct-addable-box.js?891d"],"sourcesContent":["function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, Component, useContext, createContext, useState, Fragment } from '@wordpress/element';\nimport classnames from 'classnames';\nimport { SortableContainer, SortableElement, SortableHandle } from 'react-sortable-hoc';\nimport arrayMove from 'array-move';\nimport { __ } from 'ct-i18n';\nimport OptionsPanel from '../OptionsPanel';\nimport { getValueFromInput } from '../helpers/get-value-from-input';\nimport nanoid from 'nanoid';\nconst LayerControls = SortableHandle(_ref => {\n  let {\n    items,\n    onChange,\n    value\n  } = _ref;\n  const {\n    removeForId,\n    addForId,\n    option,\n    toggleOptionsPanel\n  } = useContext(LayersContext);\n  return createElement(\"div\", {\n    className: \"ct-layer-controls\"\n  }, createElement(\"button\", {\n    type: \"button\",\n    className: \"ct-visibility\",\n    onClick: e => {\n      e.stopPropagation();\n      onChange(items.map(l => l.__id === value.__id ? _objectSpread(_objectSpread({}, l), {}, {\n        enabled: !_objectSpread({\n          enabled: true\n        }, l).enabled\n      }) : l));\n    }\n  }, createElement(\"svg\", {\n    width: \"13px\",\n    height: \"13px\",\n    viewBox: \"0 0 24 24\"\n  }, createElement(\"path\", {\n    d: \"M12,4C4.1,4,0,12,0,12s3.1,8,12,8c8.1,0,12-8,12-8S20.1,4,12,4z M12,17c-2.9,0-5-2.2-5-5c0-2.8,2.1-5,5-5s5,2.2,5,5C17,14.8,14.9,17,12,17z M12,9c-1.7,0-3,1.4-3,3c0,1.6,1.3,3,3,3s3-1.4,3-3C15,10.4,13.7,9,12,9z\"\n  }))), createElement(\"div\", {\n    className: \"ct-layer-label\"\n  }, createElement(\"span\", null, window._.template(option['preview-template'])(value))), createElement(\"button\", {\n    type: \"button\",\n    className: \"ct-clone\",\n    onClick: () => addForId(value)\n  }, createElement(\"svg\", {\n    width: \"11px\",\n    height: \"11px\",\n    viewBox: \"0 0 24 24\"\n  }, createElement(\"path\", {\n    d: \"M23,24H7.7c-0.6,0-1-0.4-1-1V7.7c0-0.6,0.4-1,1-1H23c0.6,0,1,0.4,1,1V23C24,23.6,23.6,24,23,24z M8.7,22H22V8.7 H8.7V22z\"\n  }), createElement(\"path\", {\n    d: \"M17.3,16.3c0,0.6-0.4,1-1,1H1c-0.6,0-1-0.4-1-1V1c0-0.6,0.4-1,1-1h15.3c0.6,0,1,0.4,1,1V16.3z\"\n  })), createElement(\"i\", {\n    className: \"ct-tooltip-top\"\n  }, __('Clone Item', 'blocksy'))), createElement(\"button\", {\n    type: \"button\",\n    className: \"ct-remove\",\n    onClick: () => removeForId(value.__id)\n  }), option['inner-options'] && createElement(\"button\", {\n    type: \"button\",\n    className: \"ct-toggle\",\n    onMouseDown: e => {\n      e.stopPropagation();\n    },\n    onClick: e => {\n      e.stopPropagation();\n      toggleOptionsPanel(value.__id);\n    }\n  }));\n});\n\nconst valueWithUniqueIds = value => value.map(singleItem => _objectSpread(_objectSpread({}, singleItem), singleItem.__id ? {} : {\n  __id: nanoid()\n}));\n\nconst getDefaultState = () => ({\n  currentlyPickedItem: null,\n  isDragging: false,\n  isOpen: false\n});\n\nexport const LayersContext = createContext(getDefaultState());\nconst {\n  Provider,\n  Consumer\n} = LayersContext;\n\nclass SingleItem extends Component {\n  constructor() {\n    super(...arguments);\n\n    _defineProperty(this, \"state\", {\n      isOpen: false\n    });\n  }\n\n  render() {\n    const {\n      value,\n      items,\n      onChange\n    } = this.props;\n    return createElement(Consumer, null, _ref2 => {\n      let {\n        option,\n        isDragging,\n        isOpen,\n        parentValue\n      } = _ref2;\n      return createElement(\"li\", {\n        className: classnames('ct-layer', option.itemClass, {\n          [`ct-disabled`]: !_objectSpread({\n            enabled: true\n          }, value).enabled\n        })\n      }, createElement(LayerControls, {\n        items: items,\n        onChange: onChange,\n        value: value\n      }), isOpen === value.__id && (!isDragging || isDragging && isDragging !== isOpen) && createElement(\"div\", {\n        className: \"ct-layer-content\"\n      }, createElement(OptionsPanel, {\n        hasRevertButton: false,\n        parentValue: parentValue,\n        onChange: (key, newValue) => {\n          onChange(items.map(l => l.__id === value.__id ? _objectSpread(_objectSpread({}, l), {}, {\n            [key]: newValue\n          }) : l));\n        },\n        value: getValueFromInput(option['inner-options'], _objectSpread(_objectSpread({}, option.value.filter(_ref3 => {\n          let {\n            id\n          } = _ref3;\n          return id === value.id;\n        }).length > 1 ? option.value.filter(_ref4 => {\n          let {\n            id\n          } = _ref4;\n          return value.id === id;\n        })[items.filter(_ref5 => {\n          let {\n            id\n          } = _ref5;\n          return id === value.id;\n        }).map(_ref6 => {\n          let {\n            __id\n          } = _ref6;\n          return __id;\n        }).indexOf(value.__id)] : {}), value)),\n        options: option['inner-options']\n      })));\n    });\n  }\n\n}\n\nconst SortableItem = SortableElement(SingleItem);\nconst SortableList = SortableContainer(_ref7 => {\n  let {\n    items,\n    onChange\n  } = _ref7;\n  return createElement(Consumer, null, _ref8 => {\n    let {\n      option\n    } = _ref8;\n    return createElement(\"ul\", {\n      className: \"ct-layers\"\n    }, items.map((value, index) => createElement(SortableItem, {\n      key: value.__id,\n      index: index,\n      onChange: onChange,\n      value: value,\n      items: items,\n      disabled: !!option.disableDrag\n    })));\n  });\n});\n\nconst Layers = _ref9 => {\n  let {\n    value,\n    option,\n    onChange,\n    values\n  } = _ref9;\n  const [state, setState] = useState(getDefaultState());\n\n  const localOnChange = v => {\n    onChange(v);\n  };\n\n  const addForId = function () {\n    let val = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n    localOnChange([...(value || []), _objectSpread(_objectSpread(_objectSpread({\n      enabled: true\n    }, getValueFromInput(option['inner-options'] || {}, {})), val), {}, {\n      __id: nanoid()\n    })]);\n  };\n\n  const computedValue = valueWithUniqueIds(value);\n  return createElement(Provider, {\n    value: _objectSpread(_objectSpread({}, state), {}, {\n      parentValue: values,\n      addForId,\n      option,\n      removeForId: idToRemove => localOnChange(valueWithUniqueIds(value).filter(_ref10 => {\n        let {\n          __id: id\n        } = _ref10;\n        return id !== idToRemove;\n      })),\n      toggleOptionsPanel: idToAdd => {\n        if (value.length > 0 && !value[0].__id) {\n          localOnChange(computedValue);\n        }\n\n        setState(state => _objectSpread(_objectSpread({}, state), {}, {\n          isOpen: state.isOpen === idToAdd ? false : idToAdd\n        }));\n      }\n    })\n  }, createElement(SortableList, {\n    useDragHandle: true,\n    distance: 3,\n    lockAxis: \"y\",\n    items: computedValue,\n    onChange: v => {\n      localOnChange(v);\n    },\n    helperContainer: () => document.querySelector('#customize-theme-controls') || document.body,\n    onSortEnd: _ref11 => {\n      let {\n        oldIndex,\n        newIndex\n      } = _ref11;\n      localOnChange(arrayMove(computedValue, oldIndex, newIndex));\n      setState(state => _objectSpread(_objectSpread({}, state), {}, {\n        isDragging: false\n      }));\n    },\n    updateBeforeSortStart: _ref12 => {\n      let {\n        index\n      } = _ref12;\n      new Promise(resolve => {\n        if (value.length > 0 && !value[0].__id) {\n          wp.customize && wp.customize.previewer && wp.customize.previewer.send('ct:sync:refresh_partial', {\n            shouldSkip: true\n          });\n          localOnChange(computedValue);\n        }\n\n        setState(state => _objectSpread(_objectSpread({}, state), {}, {\n          isDragging: computedValue[index].__id\n        }));\n        resolve();\n      });\n    }\n  }), createElement(\"button\", {\n    className: \"button\",\n    onClick: e => {\n      e.preventDefault();\n      addForId();\n    }\n  }, __('Add New Item', 'blocksy')));\n};\n\nexport default Layers;"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///9285\n')},8601:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("// ESM COMPAT FLAG\n__webpack_require__.r(__webpack_exports__);\n\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n \"default\": () => (/* binding */ ct_background)\n});\n\n// EXTERNAL MODULE: external \"window.wp.element\"\nvar external_window_wp_element_ = __webpack_require__(1381);\n// EXTERNAL MODULE: ./node_modules/classnames/index.js\nvar classnames = __webpack_require__(4184);\nvar classnames_default = /*#__PURE__*/__webpack_require__.n(classnames);\n// EXTERNAL MODULE: external \"window.wp.i18n\"\nvar external_window_wp_i18n_ = __webpack_require__(5652);\n// EXTERNAL MODULE: ./static/js/options/GenericOptionType.js\nvar GenericOptionType = __webpack_require__(6095);\n;// CONCATENATED MODULE: ./static/js/options/options/background/PatternPicker.js\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\nconst patternsList = [{\n id: 'type-1',\n title: (0,external_window_wp_i18n_.__)('Hideout', 'blocksy'),\n src: 'patterns/hideout.svg'\n}, {\n id: 'type-2',\n title: (0,external_window_wp_i18n_.__)('Triangles', 'blocksy'),\n src: 'patterns/triangles.svg'\n}, {\n id: 'type-3',\n title: (0,external_window_wp_i18n_.__)('Bubbles', 'blocksy'),\n src: 'patterns/bubbles.svg'\n}, {\n id: 'type-4',\n title: (0,external_window_wp_i18n_.__)('Wiggle', 'blocksy'),\n src: 'patterns/wiggle.svg'\n}, {\n id: 'type-5',\n title: (0,external_window_wp_i18n_.__)('Polka Dots', 'blocksy'),\n src: 'patterns/polka-dots.svg'\n}, {\n id: 'type-6',\n title: (0,external_window_wp_i18n_.__)('Overlaping Circles', 'blocksy'),\n src: 'patterns/overlaping-circles.svg'\n}, {\n id: 'type-7',\n title: (0,external_window_wp_i18n_.__)('Texture', 'blocksy'),\n src: 'patterns/texture.svg'\n}, {\n id: 'type-8',\n title: (0,external_window_wp_i18n_.__)('Diagonal Lines', 'blocksy'),\n src: 'patterns/diagonal-lines.svg'\n}, {\n id: 'type-9',\n title: (0,external_window_wp_i18n_.__)('Rain', 'blocksy'),\n src: 'patterns/rain.svg'\n}, {\n id: 'type-10',\n title: (0,external_window_wp_i18n_.__)('Stripes', 'blocksy'),\n src: 'patterns/stripes.svg'\n}, {\n id: 'type-11',\n title: (0,external_window_wp_i18n_.__)('Diagonal Stripes', 'blocksy'),\n src: 'patterns/diagonal-stripes.svg'\n}, {\n id: 'type-12',\n title: (0,external_window_wp_i18n_.__)('Intersecting Circles', 'blocksy'),\n src: 'patterns/intersecting-circles.svg'\n}, {\n id: 'type-13',\n title: (0,external_window_wp_i18n_.__)('Bank Note', 'blocksy'),\n src: 'patterns/bank-note.svg'\n}, {\n id: 'type-14',\n title: (0,external_window_wp_i18n_.__)('Zig Zag', 'blocksy'),\n src: 'patterns/zig-zag.svg'\n}, {\n id: 'type-15',\n title: (0,external_window_wp_i18n_.__)('Endless Clouds', 'blocksy'),\n src: 'patterns/endless-clouds.svg'\n}, {\n id: 'type-16',\n title: (0,external_window_wp_i18n_.__)('Honey Comb', 'blocksy'),\n src: 'patterns/honey-comb.svg'\n}, {\n id: 'type-17',\n title: (0,external_window_wp_i18n_.__)('Cross Stripes', 'blocksy'),\n src: 'patterns/cross-stripes.svg'\n}, {\n id: 'type-18',\n title: (0,external_window_wp_i18n_.__)('Autumn', 'blocksy'),\n src: 'patterns/autumn.svg'\n}];\nconst getUrlForPattern = id => (window.ct_localizations || ct_customizer_localizations).static_public_url + `images/${patternsList.find(p => p.id === id).src}`;\n\nconst PatternPicker = _ref => {\n let {\n option,\n value,\n onChange\n } = _ref;\n return (0,external_window_wp_element_.createElement)(external_window_wp_element_.Fragment, null, (0,external_window_wp_element_.createElement)(\"ul\", {\n className: \"ct-patterns-list\"\n }, patternsList.map(singlePattern => (0,external_window_wp_element_.createElement)(\"li\", {\n onClick: () => onChange(_objectSpread(_objectSpread({}, value), {}, {\n background_pattern: singlePattern.id\n })),\n className: classnames_default()({\n active: singlePattern.id === value.background_pattern\n }),\n key: singlePattern.id,\n title: singlePattern.title\n }, (0,external_window_wp_element_.createElement)(\"img\", {\n src: (window.ct_localizations || ct_customizer_localizations).static_public_url + `images/${singlePattern.src}`\n })))), (0,external_window_wp_element_.createElement)(GenericOptionType/* default */.ZP, {\n value: value['patternColor'],\n values: value,\n option: {\n id: 'patternColor',\n label: (0,external_window_wp_i18n_.__)('Pattern Color', 'blocksy'),\n type: 'ct-color-picker',\n design: 'inline',\n value: option.value['patternColor'],\n pickers: [{\n title: (0,external_window_wp_i18n_.__)('Initial', 'blocksy'),\n id: 'default'\n }],\n skipNoColorPill: true,\n skipArrow: true,\n appendToBody: false\n },\n hasRevertButton: false,\n onChange: newValue => onChange(_objectSpread(_objectSpread({}, value), {}, {\n patternColor: newValue\n }))\n }));\n};\n\n/* harmony default export */ const background_PatternPicker = (PatternPicker);\n;// CONCATENATED MODULE: ./static/js/options/options/background/ImagePicker.js\nfunction ImagePicker_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction ImagePicker_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ImagePicker_ownKeys(Object(source), !0).forEach(function (key) { ImagePicker_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ImagePicker_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction ImagePicker_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\nconst ImagePicker = _ref => {\n let {\n option,\n value,\n onChange,\n setOutsideClickFreezed\n } = _ref;\n return (0,external_window_wp_element_.createElement)(external_window_wp_element_.Fragment, null, (0,external_window_wp_element_.createElement)(GenericOptionType/* default */.ZP, {\n value: value['background_image'],\n values: value,\n option: {\n id: 'background_image',\n label: false,\n type: 'ct-image-uploader',\n value: option.value['background_image'],\n has_position_picker: true,\n emptyLabel: (0,external_window_wp_i18n_.__)('Select Image', 'blocksy'),\n filledLabel: (0,external_window_wp_i18n_.__)('Change Image', 'blocksy'),\n onFrameOpen: () => {\n setOutsideClickFreezed(true);\n },\n onFrameClose: () => {\n setOutsideClickFreezed(false);\n }\n },\n hasRevertButton: false,\n onChange: newValue => onChange(ImagePicker_objectSpread(ImagePicker_objectSpread({}, value), {}, {\n background_image: newValue\n }))\n }), (0,external_window_wp_element_.createElement)(GenericOptionType/* default */.ZP, {\n value: value['background_repeat'],\n values: value,\n option: {\n id: 'background_repeat',\n label: (0,external_window_wp_i18n_.__)('Background Repeat', 'blocksy'),\n attr: {\n 'data-type': 'repeat'\n },\n type: 'ct-radio',\n view: 'text',\n design: 'block',\n value: option.value['background_repeat'],\n choices: {\n repeat: `\n\t\t\t\t\t\t\t${(0,external_window_wp_i18n_.__)('Repeat', 'blocksy')}`,\n 'repeat-y': `\n\t\t\t\t\t\t\t${(0,external_window_wp_i18n_.__)('Repeat Y', 'blocksy')}`,\n 'repeat-x': `\n\t\t\t\t\t\t\t${(0,external_window_wp_i18n_.__)('Repeat X', 'blocksy')}`,\n 'no-repeat': `\n\t\t\t\t\t\t\t${(0,external_window_wp_i18n_.__)('No Repeat', 'blocksy')}`\n }\n },\n hasRevertButton: false,\n onChange: newValue => onChange(ImagePicker_objectSpread(ImagePicker_objectSpread({}, value), {}, {\n background_repeat: newValue\n }))\n }), (0,external_window_wp_element_.createElement)(GenericOptionType/* default */.ZP, {\n value: value['background_size'],\n values: value,\n option: {\n id: 'background_size',\n label: (0,external_window_wp_i18n_.__)('Background Size', 'blocksy'),\n type: 'ct-radio',\n view: 'text',\n design: 'block',\n value: option.value['background_size'],\n choices: {\n auto: (0,external_window_wp_i18n_.__)('Auto', 'blocksy'),\n cover: (0,external_window_wp_i18n_.__)('Cover', 'blocksy'),\n contain: (0,external_window_wp_i18n_.__)('Contain', 'blocksy')\n }\n },\n hasRevertButton: false,\n onChange: newValue => onChange(ImagePicker_objectSpread(ImagePicker_objectSpread({}, value), {}, {\n background_size: newValue\n }))\n }), (0,external_window_wp_element_.createElement)(GenericOptionType/* default */.ZP, {\n value: value['background_attachment'],\n values: value,\n option: {\n id: 'background_size',\n label: (0,external_window_wp_i18n_.__)('Background Attachment', 'blocksy'),\n type: 'ct-radio',\n view: 'text',\n design: 'block',\n value: option.value['background_attachment'],\n choices: {\n scroll: (0,external_window_wp_i18n_.__)('Scroll', 'blocksy'),\n fixed: (0,external_window_wp_i18n_.__)('Fixed', 'blocksy'),\n inherit: (0,external_window_wp_i18n_.__)('Inherit', 'blocksy')\n }\n },\n hasRevertButton: false,\n onChange: newValue => onChange(ImagePicker_objectSpread(ImagePicker_objectSpread({}, value), {}, {\n background_attachment: newValue\n }))\n }), value.background_image.url && (0,external_window_wp_element_.createElement)(external_window_wp_element_.Fragment, null, (0,external_window_wp_element_.createElement)(GenericOptionType/* default */.ZP, {\n value: value.overlayColor && value.overlayColor.default.color.indexOf('CT_CSS_SKIP_RULE') === -1 ? 'yes' : 'no',\n values: {},\n option: {\n id: 'has_overlay',\n label: (0,external_window_wp_i18n_.__)('Image Overlay', 'blocksy'),\n type: 'ct-radio',\n view: 'text',\n design: 'block',\n value: 'no',\n choices: {\n no: (0,external_window_wp_i18n_.__)('Disabled', 'blocksy'),\n yes: (0,external_window_wp_i18n_.__)('Enabled', 'blocksy')\n }\n },\n hasRevertButton: false,\n onChange: newValue => {\n let hasOverlay = value.overlayColor.default.color.indexOf('CT_CSS_SKIP_RULE') === -1;\n onChange(ImagePicker_objectSpread(ImagePicker_objectSpread({}, value), {}, {\n overlayColor: {\n default: {\n color: hasOverlay ? 'CT_CSS_SKIP_RULE' : 'rgba(0, 0, 0, 0.2)'\n }\n }\n }));\n }\n }), value.overlayColor && value.overlayColor.default.color.indexOf('CT_CSS_SKIP_RULE') === -1 && (0,external_window_wp_element_.createElement)(GenericOptionType/* default */.ZP, {\n value: value['overlayColor'],\n values: value,\n option: {\n id: 'overlayColor',\n label: (0,external_window_wp_i18n_.__)('Image Overlay Color', 'blocksy'),\n type: 'ct-color-picker',\n design: 'inline',\n value: option.value['overlayColor'],\n pickers: [{\n title: (0,external_window_wp_i18n_.__)('Initial', 'blocksy'),\n id: 'default'\n }],\n skipArrow: true,\n appendToBody: false\n },\n hasRevertButton: false,\n onChange: newValue => onChange(ImagePicker_objectSpread(ImagePicker_objectSpread({}, value), {}, {\n overlayColor: newValue\n }))\n })));\n};\n\n/* harmony default export */ const background_ImagePicker = (ImagePicker);\n;// CONCATENATED MODULE: ./static/js/options/options/background/GradientPicker.js\nfunction GradientPicker_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction GradientPicker_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? GradientPicker_ownKeys(Object(source), !0).forEach(function (key) { GradientPicker_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : GradientPicker_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction GradientPicker_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\nlet GradientPickerComponent = () => null;\n\nsetTimeout(() => {\n if (window.wp.components) {\n Promise.all(/* import() */[__webpack_require__.e(904), __webpack_require__.e(188)]).then(__webpack_require__.bind(__webpack_require__, 1188)).then(res => {\n GradientPickerComponent = res.default;\n });\n }\n}, 1000);\n\nconst GradientPicker = _ref => {\n let {\n value,\n onChange\n } = _ref;\n const allGradients = (window.ct_customizer_localizations || window.ct_localizations)['gradients']; // let GradientPickerComponent =\n // StableGradientPicker || ExperimentalGradientPicker\n\n return (0,external_window_wp_element_.createElement)(external_window_wp_element_.Fragment, null, (0,external_window_wp_element_.createElement)(GradientPickerComponent, {\n value: value.gradient || '',\n onChange: val => {\n onChange(GradientPicker_objectSpread(GradientPicker_objectSpread({}, value), {}, {\n gradient: val\n }));\n }\n }), (0,external_window_wp_element_.createElement)(\"ul\", {\n className: 'ct-gradient-swatches'\n }, allGradients.map(_ref2 => {\n let {\n gradient,\n slug\n } = _ref2;\n return (0,external_window_wp_element_.createElement)(\"li\", {\n onClick: () => {\n onChange(GradientPicker_objectSpread(GradientPicker_objectSpread({}, value), {}, {\n gradient: value.gradient === gradient ? '' : gradient\n }));\n },\n className: classnames_default()({\n active: gradient === value.gradient\n }),\n style: {\n '--background-image': gradient\n },\n key: slug\n });\n })));\n};\n\n/* harmony default export */ const background_GradientPicker = (GradientPicker);\n;// CONCATENATED MODULE: ./static/js/options/options/background/BackgroundModal.js\nfunction BackgroundModal_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction BackgroundModal_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? BackgroundModal_ownKeys(Object(source), !0).forEach(function (key) { BackgroundModal_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : BackgroundModal_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction BackgroundModal_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\n\n\nconst BackgroundModal = _ref => {\n let {\n option,\n option: {\n activeTabs = ['color', 'gradient', 'image']\n },\n value,\n isOpen,\n onChange,\n setOutsideClickFreezed\n } = _ref;\n return (0,external_window_wp_element_.createElement)(external_window_wp_element_.Fragment, null, (0,external_window_wp_element_.createElement)(\"ul\", {\n className: \"ct-modal-tabs\",\n onMouseUp: e => {\n e.preventDefault();\n }\n }, activeTabs.map(type => (0,external_window_wp_element_.createElement)(\"li\", {\n \"data-type\": type,\n key: type,\n className: classnames_default()({\n active: type === value.background_type || type === 'image' && (value.background_type === 'pattern' || value.background_type === 'image')\n }),\n onClick: () => onChange(BackgroundModal_objectSpread(BackgroundModal_objectSpread({}, value), {}, {\n background_type: type\n }, type === 'gradient' ? {\n gradient: 'linear-gradient(135deg,rgba(6,147,227,1) 0%,rgb(155,81,224) 100%)'\n } : {}))\n }, {\n color: (0,external_window_wp_i18n_.__)('Color', 'blocksy'),\n gradient: (0,external_window_wp_i18n_.__)('Gradient', 'blocksy'),\n // pattern: __('Pattern', 'blocksy'),\n image: (0,external_window_wp_i18n_.__)('Image', 'blocksy')\n }[type]))), (0,external_window_wp_element_.createElement)(\"div\", {\n className: classnames_default()({\n 'ct-image-tab ct-options-container': value.background_type === 'image' || value.background_type === 'pattern',\n 'ct-color-picker-modal': value.background_type === 'gradient',\n 'ct-gradient-tab': value.background_type === 'gradient' && window.wp.components.__experimentalGradientPicker,\n 'ct-gradient-tab-new': value.background_type === 'gradient' && !window.wp.components.__experimentalGradientPicker,\n 'ct-color-tab': value.background_type === 'color'\n }, 'ct-modal-tabs-content')\n }, (value.background_type === 'image' || value.background_type === 'pattern') && (0,external_window_wp_element_.createElement)(\"ul\", {\n className: \"ct-radio-option ct-buttons-group\",\n onMouseUp: e => {\n e.preventDefault();\n }\n }, ['image', 'pattern'].map(type => (0,external_window_wp_element_.createElement)(\"li\", {\n \"data-type\": type,\n key: type,\n className: classnames_default()({\n active: type === value.background_type\n }),\n onClick: () => onChange(BackgroundModal_objectSpread(BackgroundModal_objectSpread({}, value), {}, {\n background_type: type\n }))\n }, {\n pattern: (0,external_window_wp_i18n_.__)('Pattern', 'blocksy'),\n image: (0,external_window_wp_i18n_.__)('Image', 'blocksy')\n }[type]))), value.background_type === 'pattern' && (0,external_window_wp_element_.createElement)(background_PatternPicker, {\n option: option,\n onChange: onChange,\n value: value\n }), value.background_type === 'image' && (0,external_window_wp_element_.createElement)(background_ImagePicker, {\n setOutsideClickFreezed: setOutsideClickFreezed,\n option: option,\n onChange: onChange,\n value: value\n }), value.background_type === 'gradient' && (0,external_window_wp_element_.createElement)(background_GradientPicker, {\n value: value,\n onChange: onChange\n }), value.background_type !== 'gradient' && (0,external_window_wp_element_.createElement)(GenericOptionType/* default */.ZP, {\n value: value['backgroundColor'],\n values: value,\n option: {\n id: 'backgroundColor',\n label: value.background_type === 'color' ? false : (0,external_window_wp_i18n_.__)('Background Color', 'blocksy'),\n type: 'ct-color-picker',\n skipNoColorPill: true,\n design: value.background_type === 'color' ? 'none' : 'inline',\n value: option.value['backgroundColor'],\n pickers: [{\n title: (0,external_window_wp_i18n_.__)('Initial', 'blocksy'),\n id: 'default'\n }],\n inline_modal: value.background_type === 'color',\n skipArrow: true,\n appendToBody: false\n },\n hasRevertButton: false,\n onChange: newValue => onChange(BackgroundModal_objectSpread(BackgroundModal_objectSpread({}, value), {}, {\n backgroundColor: newValue\n }))\n })));\n};\n\n/* harmony default export */ const background_BackgroundModal = (BackgroundModal);\n// EXTERNAL MODULE: ./static/js/options/options/react-outside-click-handler.js\nvar react_outside_click_handler = __webpack_require__(8204);\n// EXTERNAL MODULE: ./static/js/options/helpers/usePopoverMaker.js\nvar usePopoverMaker = __webpack_require__(9144);\n;// CONCATENATED MODULE: ./static/js/options/options/ct-background.js\nfunction ct_background_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction ct_background_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ct_background_ownKeys(Object(source), !0).forEach(function (key) { ct_background_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ct_background_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction ct_background_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\n\n/**\n * Support color picker values inside the background picker.\n * Which means transitions from ct-color-picker are made possible thanks to\n * this logic.\n */\n\nconst maybeConvertFromColorPickerTo = value => {\n if (!value.background_type) {\n if (value[Object.keys(value)[0]].color) {\n return {\n background_type: 'color',\n background_pattern: 'type-1',\n background_image: {\n attachment_id: null,\n x: 0,\n y: 0\n },\n background_repeat: 'no-repeat',\n background_size: 'auto',\n background_attachment: 'scroll',\n patternColor: {\n default: {\n color: '#e5e7ea'\n }\n },\n backgroundColor: {\n default: value[Object.keys(value)[0]]\n }\n };\n }\n }\n\n return value;\n};\n\nconst Background = _ref => {\n let {\n option,\n value,\n onChange\n } = _ref;\n const [isOpen, setIsOpen] = (0,external_window_wp_element_.useState)(false);\n const [outsideClickFreezed, setOutsideClickFreezed] = (0,external_window_wp_element_.useState)(false);\n const backgroundWrapper = (0,external_window_wp_element_.useRef)();\n value = maybeConvertFromColorPickerTo(value);\n const isInherit = !option.has_no_color && value.background_type === 'color' && (value.backgroundColor.default.color === 'CT_CSS_SKIP_RULE' || value.backgroundColor.default.color === 'transparent');\n const isNoColor = option.has_no_color && value.background_type === 'color' && (value.backgroundColor.default.color === 'CT_CSS_SKIP_RULE' || value.backgroundColor.default.color === 'transparent');\n const {\n styles,\n popoverProps\n } = (0,usePopoverMaker/* default */.Z)({\n ref: backgroundWrapper,\n defaultHeight: 434,\n shouldCalculate: backgroundWrapper && backgroundWrapper.current\n });\n return (0,external_window_wp_element_.createElement)(\"div\", {\n ref: backgroundWrapper,\n className: classnames_default()('ct-background', {\n active: isOpen\n })\n }, (0,external_window_wp_element_.createElement)(\"div\", {\n className: classnames_default()('ct-background-preview', {\n 'ct-color-inherit': isInherit,\n 'ct-no-color': isNoColor\n }),\n onClick: e => {\n e.preventDefault();\n setIsOpen(!isOpen);\n\n if (value.background_type === 'color') {\n if (value.backgroundColor.default.color === 'CT_CSS_SKIP_RULE' || value.backgroundColor.default.color === 'transparent') {\n onChange(ct_background_objectSpread(ct_background_objectSpread({}, value), {}, {\n backgroundColor: {\n default: {\n color: option.default_inherit_color || '#ffffff'\n }\n }\n }));\n }\n }\n },\n \"data-background-type\": value.background_type,\n style: ct_background_objectSpread(ct_background_objectSpread({}, value.backgroundColor.default.color.indexOf('CT_CSS_SKIP_RULE') > -1 ? {} : {\n backgroundColor: value.backgroundColor.default.color\n }), {}, {\n '--background-position': `${Math.round(parseFloat(value.background_image.x) * 100)}% ${Math.round(parseFloat(value.background_image.y) * 100)}%`,\n '--pattern-mask': value.background_type === 'pattern' ? `url(${getUrlForPattern(value.background_pattern)})` : '',\n '--background-image': value.background_type === 'gradient' ? value.gradient : value.background_image.url ? `${value.overlayColor && value.overlayColor.default.color.indexOf('CT_CSS_SKIP_RULE') === -1 ? `linear-gradient(${value.overlayColor.default.color}, ${value.overlayColor.default.color}), ` : ''}url(${value.background_image.url})` : 'none',\n '--pattern-color': value.patternColor.default.color\n })\n }, (0,external_window_wp_element_.createElement)(\"i\", {\n className: \"ct-tooltip-top\"\n }, {\n inherit: (0,external_window_wp_i18n_.__)('Inherited', 'blocksy'),\n no_color: (0,external_window_wp_i18n_.__)('No Color', 'blocksy'),\n pattern: (0,external_window_wp_i18n_.__)('Pattern', 'blocksy'),\n gradient: (0,external_window_wp_i18n_.__)('Gradient', 'blocksy'),\n color: (0,external_window_wp_i18n_.__)('Color', 'blocksy'),\n image: (0,external_window_wp_i18n_.__)('Image', 'blocksy')\n }[isNoColor ? 'no_color' : isInherit ? 'inherit' : value.background_type]), isInherit && (0,external_window_wp_element_.createElement)(\"svg\", {\n width: \"25\",\n height: \"25\",\n viewBox: \"0 0 30 30\"\n }, (0,external_window_wp_element_.createElement)(\"path\", {\n d: \"M15 3c-3 0-5.7 1.1-7.8 2.9-.4.3-.5.9-.2 1.4.3.4 1 .5 1.4.2h.1C10.3 5.9 12.5 5 15 5c5.2 0 9.5 3.9 10 9h-3l4 6 4-6h-3.1C26.4 7.9 21.3 3 15 3zM4 10l-4 6h3.1c.5 6.1 5.6 11 11.9 11 3 0 5.7-1.1 7.8-2.9.4-.3.5-1 .2-1.4-.3-.4-1-.5-1.4-.2h-.1c-1.7 1.5-4 2.4-6.5 2.4-5.2 0-9.5-3.9-10-9h3L4 10z\"\n }))), backgroundWrapper && backgroundWrapper.current && (0,external_window_wp_element_.createPortal)((0,external_window_wp_element_.createElement)(react_outside_click_handler[\"default\"], {\n useCapture: false,\n display: \"block\",\n disabled: !isOpen || outsideClickFreezed,\n onOutsideClick: () => {\n setTimeout(() => setIsOpen(false));\n },\n wrapperProps: ct_background_objectSpread(ct_background_objectSpread({\n style: styles\n }, popoverProps), {}, {\n className: classnames_default()('ct-option-modal ct-background-modal', {\n active: isOpen\n })\n })\n }, (0,external_window_wp_element_.createElement)(background_BackgroundModal, {\n onChange: onChange,\n value: value,\n option: option,\n isOpen: isOpen,\n setOutsideClickFreezed: setOutsideClickFreezed\n })), document.body));\n};\n\n/* harmony default export */ const ct_background = (Background);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"8601.js","mappings":";;;;;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;AC5GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./static/js/options/options/background/PatternPicker.js?5e2e","webpack://blocksyOptions/./static/js/options/options/background/ImagePicker.js?a931","webpack://blocksyOptions/./static/js/options/options/background/GradientPicker.js?ca04","webpack://blocksyOptions/./static/js/options/options/background/BackgroundModal.js?7eed","webpack://blocksyOptions/./static/js/options/options/ct-background.js?386c"],"sourcesContent":["function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { Fragment, createElement, Component, useRef, useEffect, useMemo, useCallback, useState } from '@wordpress/element';\nimport classnames from 'classnames';\nimport { __ } from 'ct-i18n';\nimport GenericOptionType from '../../GenericOptionType';\nexport const patternsList = [{\n  id: 'type-1',\n  title: __('Hideout', 'blocksy'),\n  src: 'patterns/hideout.svg'\n}, {\n  id: 'type-2',\n  title: __('Triangles', 'blocksy'),\n  src: 'patterns/triangles.svg'\n}, {\n  id: 'type-3',\n  title: __('Bubbles', 'blocksy'),\n  src: 'patterns/bubbles.svg'\n}, {\n  id: 'type-4',\n  title: __('Wiggle', 'blocksy'),\n  src: 'patterns/wiggle.svg'\n}, {\n  id: 'type-5',\n  title: __('Polka Dots', 'blocksy'),\n  src: 'patterns/polka-dots.svg'\n}, {\n  id: 'type-6',\n  title: __('Overlaping Circles', 'blocksy'),\n  src: 'patterns/overlaping-circles.svg'\n}, {\n  id: 'type-7',\n  title: __('Texture', 'blocksy'),\n  src: 'patterns/texture.svg'\n}, {\n  id: 'type-8',\n  title: __('Diagonal Lines', 'blocksy'),\n  src: 'patterns/diagonal-lines.svg'\n}, {\n  id: 'type-9',\n  title: __('Rain', 'blocksy'),\n  src: 'patterns/rain.svg'\n}, {\n  id: 'type-10',\n  title: __('Stripes', 'blocksy'),\n  src: 'patterns/stripes.svg'\n}, {\n  id: 'type-11',\n  title: __('Diagonal Stripes', 'blocksy'),\n  src: 'patterns/diagonal-stripes.svg'\n}, {\n  id: 'type-12',\n  title: __('Intersecting Circles', 'blocksy'),\n  src: 'patterns/intersecting-circles.svg'\n}, {\n  id: 'type-13',\n  title: __('Bank Note', 'blocksy'),\n  src: 'patterns/bank-note.svg'\n}, {\n  id: 'type-14',\n  title: __('Zig Zag', 'blocksy'),\n  src: 'patterns/zig-zag.svg'\n}, {\n  id: 'type-15',\n  title: __('Endless Clouds', 'blocksy'),\n  src: 'patterns/endless-clouds.svg'\n}, {\n  id: 'type-16',\n  title: __('Honey Comb', 'blocksy'),\n  src: 'patterns/honey-comb.svg'\n}, {\n  id: 'type-17',\n  title: __('Cross Stripes', 'blocksy'),\n  src: 'patterns/cross-stripes.svg'\n}, {\n  id: 'type-18',\n  title: __('Autumn', 'blocksy'),\n  src: 'patterns/autumn.svg'\n}];\nexport const getUrlForPattern = id => (window.ct_localizations || ct_customizer_localizations).static_public_url + `images/${patternsList.find(p => p.id === id).src}`;\n\nconst PatternPicker = _ref => {\n  let {\n    option,\n    value,\n    onChange\n  } = _ref;\n  return createElement(Fragment, null, createElement(\"ul\", {\n    className: \"ct-patterns-list\"\n  }, patternsList.map(singlePattern => createElement(\"li\", {\n    onClick: () => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      background_pattern: singlePattern.id\n    })),\n    className: classnames({\n      active: singlePattern.id === value.background_pattern\n    }),\n    key: singlePattern.id,\n    title: singlePattern.title\n  }, createElement(\"img\", {\n    src: (window.ct_localizations || ct_customizer_localizations).static_public_url + `images/${singlePattern.src}`\n  })))), createElement(GenericOptionType, {\n    value: value['patternColor'],\n    values: value,\n    option: {\n      id: 'patternColor',\n      label: __('Pattern Color', 'blocksy'),\n      type: 'ct-color-picker',\n      design: 'inline',\n      value: option.value['patternColor'],\n      pickers: [{\n        title: __('Initial', 'blocksy'),\n        id: 'default'\n      }],\n      skipNoColorPill: true,\n      skipArrow: true,\n      appendToBody: false\n    },\n    hasRevertButton: false,\n    onChange: newValue => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      patternColor: newValue\n    }))\n  }));\n};\n\nexport default PatternPicker;","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { Fragment, createElement, Component, useRef, useEffect, useMemo, useCallback, useState } from '@wordpress/element';\nimport classnames from 'classnames';\nimport { __ } from 'ct-i18n';\nimport GenericOptionType from '../../GenericOptionType';\n\nconst ImagePicker = _ref => {\n  let {\n    option,\n    value,\n    onChange,\n    setOutsideClickFreezed\n  } = _ref;\n  return createElement(Fragment, null, createElement(GenericOptionType, {\n    value: value['background_image'],\n    values: value,\n    option: {\n      id: 'background_image',\n      label: false,\n      type: 'ct-image-uploader',\n      value: option.value['background_image'],\n      has_position_picker: true,\n      emptyLabel: __('Select Image', 'blocksy'),\n      filledLabel: __('Change Image', 'blocksy'),\n      onFrameOpen: () => {\n        setOutsideClickFreezed(true);\n      },\n      onFrameClose: () => {\n        setOutsideClickFreezed(false);\n      }\n    },\n    hasRevertButton: false,\n    onChange: newValue => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      background_image: newValue\n    }))\n  }), createElement(GenericOptionType, {\n    value: value['background_repeat'],\n    values: value,\n    option: {\n      id: 'background_repeat',\n      label: __('Background Repeat', 'blocksy'),\n      attr: {\n        'data-type': 'repeat'\n      },\n      type: 'ct-radio',\n      view: 'text',\n      design: 'block',\n      value: option.value['background_repeat'],\n      choices: {\n        repeat: `<svg viewBox=\"0 0 16 16\"><path d=\"M0,0h4v4H0V0z M6,0h4v4H6V0z M12,0h4v4h-4V0z M0,6h4v4H0V6z M6,6h4v4H6V6z M12,6h4v4h-4V6z M0,12h4v4H0V12z M6,12h4v4H6V12zM12,12h4v4h-4V12z\"/></svg>\n\t\t\t\t\t\t\t<span class=\"ct-tooltip-top\">${__('Repeat', 'blocksy')}</span>`,\n        'repeat-y': `<svg viewBox=\"0 0 16 16\"><rect x=\"6\" width=\"4\" height=\"4\"/><rect x=\"6\" y=\"6\" width=\"4\" height=\"4\"/><rect x=\"6\" y=\"12\" width=\"4\" height=\"4\"/></svg>\n\t\t\t\t\t\t\t<span class=\"ct-tooltip-top\">${__('Repeat Y', 'blocksy')}</span>`,\n        'repeat-x': `<svg viewBox=\"0 0 16 16\"><rect y=\"6\" width=\"4\" height=\"4\"/><rect x=\"6\" y=\"6\" width=\"4\" height=\"4\"/><rect x=\"12\" y=\"6\" width=\"4\" height=\"4\"/></svg>\n\t\t\t\t\t\t\t<span class=\"ct-tooltip-top\">${__('Repeat X', 'blocksy')}</span>`,\n        'no-repeat': `<svg viewBox=\"0 0 16 16\"><rect x=\"6\" y=\"6\" width=\"4\" height=\"4\"/></svg>\n\t\t\t\t\t\t\t<span class=\"ct-tooltip-top\">${__('No Repeat', 'blocksy')}</span>`\n      }\n    },\n    hasRevertButton: false,\n    onChange: newValue => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      background_repeat: newValue\n    }))\n  }), createElement(GenericOptionType, {\n    value: value['background_size'],\n    values: value,\n    option: {\n      id: 'background_size',\n      label: __('Background Size', 'blocksy'),\n      type: 'ct-radio',\n      view: 'text',\n      design: 'block',\n      value: option.value['background_size'],\n      choices: {\n        auto: __('Auto', 'blocksy'),\n        cover: __('Cover', 'blocksy'),\n        contain: __('Contain', 'blocksy')\n      }\n    },\n    hasRevertButton: false,\n    onChange: newValue => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      background_size: newValue\n    }))\n  }), createElement(GenericOptionType, {\n    value: value['background_attachment'],\n    values: value,\n    option: {\n      id: 'background_size',\n      label: __('Background Attachment', 'blocksy'),\n      type: 'ct-radio',\n      view: 'text',\n      design: 'block',\n      value: option.value['background_attachment'],\n      choices: {\n        scroll: __('Scroll', 'blocksy'),\n        fixed: __('Fixed', 'blocksy'),\n        inherit: __('Inherit', 'blocksy')\n      }\n    },\n    hasRevertButton: false,\n    onChange: newValue => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      background_attachment: newValue\n    }))\n  }), value.background_image.url && createElement(Fragment, null, createElement(GenericOptionType, {\n    value: value.overlayColor && value.overlayColor.default.color.indexOf('CT_CSS_SKIP_RULE') === -1 ? 'yes' : 'no',\n    values: {},\n    option: {\n      id: 'has_overlay',\n      label: __('Image Overlay', 'blocksy'),\n      type: 'ct-radio',\n      view: 'text',\n      design: 'block',\n      value: 'no',\n      choices: {\n        no: __('Disabled', 'blocksy'),\n        yes: __('Enabled', 'blocksy')\n      }\n    },\n    hasRevertButton: false,\n    onChange: newValue => {\n      let hasOverlay = value.overlayColor.default.color.indexOf('CT_CSS_SKIP_RULE') === -1;\n      onChange(_objectSpread(_objectSpread({}, value), {}, {\n        overlayColor: {\n          default: {\n            color: hasOverlay ? 'CT_CSS_SKIP_RULE' : 'rgba(0, 0, 0, 0.2)'\n          }\n        }\n      }));\n    }\n  }), value.overlayColor && value.overlayColor.default.color.indexOf('CT_CSS_SKIP_RULE') === -1 && createElement(GenericOptionType, {\n    value: value['overlayColor'],\n    values: value,\n    option: {\n      id: 'overlayColor',\n      label: __('Image Overlay Color', 'blocksy'),\n      type: 'ct-color-picker',\n      design: 'inline',\n      value: option.value['overlayColor'],\n      pickers: [{\n        title: __('Initial', 'blocksy'),\n        id: 'default'\n      }],\n      skipArrow: true,\n      appendToBody: false\n    },\n    hasRevertButton: false,\n    onChange: newValue => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      overlayColor: newValue\n    }))\n  })));\n};\n\nexport default ImagePicker;","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { Fragment, createElement, useRef, useEffect, useMemo, useCallback, useState } from '@wordpress/element';\nimport classnames from 'classnames';\n\nlet GradientPickerComponent = () => null;\n\nsetTimeout(() => {\n  if (window.wp.components) {\n    import('./gradient/index').then(res => {\n      GradientPickerComponent = res.default;\n    });\n  }\n}, 1000);\n\nconst GradientPicker = _ref => {\n  let {\n    value,\n    onChange\n  } = _ref;\n  const allGradients = (window.ct_customizer_localizations || window.ct_localizations)['gradients']; // let GradientPickerComponent =\n  // StableGradientPicker || ExperimentalGradientPicker\n\n  return createElement(Fragment, null, createElement(GradientPickerComponent, {\n    value: value.gradient || '',\n    onChange: val => {\n      onChange(_objectSpread(_objectSpread({}, value), {}, {\n        gradient: val\n      }));\n    }\n  }), createElement(\"ul\", {\n    className: 'ct-gradient-swatches'\n  }, allGradients.map(_ref2 => {\n    let {\n      gradient,\n      slug\n    } = _ref2;\n    return createElement(\"li\", {\n      onClick: () => {\n        onChange(_objectSpread(_objectSpread({}, value), {}, {\n          gradient: value.gradient === gradient ? '' : gradient\n        }));\n      },\n      className: classnames({\n        active: gradient === value.gradient\n      }),\n      style: {\n        '--background-image': gradient\n      },\n      key: slug\n    });\n  })));\n};\n\nexport default GradientPicker;","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { Fragment, createElement, Component, useRef, useEffect, useMemo, useCallback, useState } from '@wordpress/element';\nimport classnames from 'classnames';\nimport { __ } from 'ct-i18n';\nimport GenericOptionType from '../../GenericOptionType';\nimport PatternPicker from './PatternPicker';\nimport ImagePicker from './ImagePicker';\nimport GradientPicker from './GradientPicker';\n\nconst BackgroundModal = _ref => {\n  let {\n    option,\n    option: {\n      activeTabs = ['color', 'gradient', 'image']\n    },\n    value,\n    isOpen,\n    onChange,\n    setOutsideClickFreezed\n  } = _ref;\n  return createElement(Fragment, null, createElement(\"ul\", {\n    className: \"ct-modal-tabs\",\n    onMouseUp: e => {\n      e.preventDefault();\n    }\n  }, activeTabs.map(type => createElement(\"li\", {\n    \"data-type\": type,\n    key: type,\n    className: classnames({\n      active: type === value.background_type || type === 'image' && (value.background_type === 'pattern' || value.background_type === 'image')\n    }),\n    onClick: () => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      background_type: type\n    }, type === 'gradient' ? {\n      gradient: 'linear-gradient(135deg,rgba(6,147,227,1) 0%,rgb(155,81,224) 100%)'\n    } : {}))\n  }, {\n    color: __('Color', 'blocksy'),\n    gradient: __('Gradient', 'blocksy'),\n    // pattern: __('Pattern', 'blocksy'),\n    image: __('Image', 'blocksy')\n  }[type]))), createElement(\"div\", {\n    className: classnames({\n      'ct-image-tab ct-options-container': value.background_type === 'image' || value.background_type === 'pattern',\n      'ct-color-picker-modal': value.background_type === 'gradient',\n      'ct-gradient-tab': value.background_type === 'gradient' && window.wp.components.__experimentalGradientPicker,\n      'ct-gradient-tab-new': value.background_type === 'gradient' && !window.wp.components.__experimentalGradientPicker,\n      'ct-color-tab': value.background_type === 'color'\n    }, 'ct-modal-tabs-content')\n  }, (value.background_type === 'image' || value.background_type === 'pattern') && createElement(\"ul\", {\n    className: \"ct-radio-option ct-buttons-group\",\n    onMouseUp: e => {\n      e.preventDefault();\n    }\n  }, ['image', 'pattern'].map(type => createElement(\"li\", {\n    \"data-type\": type,\n    key: type,\n    className: classnames({\n      active: type === value.background_type\n    }),\n    onClick: () => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      background_type: type\n    }))\n  }, {\n    pattern: __('Pattern', 'blocksy'),\n    image: __('Image', 'blocksy')\n  }[type]))), value.background_type === 'pattern' && createElement(PatternPicker, {\n    option: option,\n    onChange: onChange,\n    value: value\n  }), value.background_type === 'image' && createElement(ImagePicker, {\n    setOutsideClickFreezed: setOutsideClickFreezed,\n    option: option,\n    onChange: onChange,\n    value: value\n  }), value.background_type === 'gradient' && createElement(GradientPicker, {\n    value: value,\n    onChange: onChange\n  }), value.background_type !== 'gradient' && createElement(GenericOptionType, {\n    value: value['backgroundColor'],\n    values: value,\n    option: {\n      id: 'backgroundColor',\n      label: value.background_type === 'color' ? false : __('Background Color', 'blocksy'),\n      type: 'ct-color-picker',\n      skipNoColorPill: true,\n      design: value.background_type === 'color' ? 'none' : 'inline',\n      value: option.value['backgroundColor'],\n      pickers: [{\n        title: __('Initial', 'blocksy'),\n        id: 'default'\n      }],\n      inline_modal: value.background_type === 'color',\n      skipArrow: true,\n      appendToBody: false\n    },\n    hasRevertButton: false,\n    onChange: newValue => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      backgroundColor: newValue\n    }))\n  })));\n};\n\nexport default BackgroundModal;","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { Fragment, createElement, Component, useRef, useEffect, useMemo, useCallback, createPortal, useState } from '@wordpress/element';\nimport cls from 'classnames';\nimport BackgroundModal from './background/BackgroundModal';\nimport OutsideClickHandler from './react-outside-click-handler';\nimport { getUrlForPattern } from './background/PatternPicker';\nimport { __ } from 'ct-i18n';\nimport usePopoverMaker from '../helpers/usePopoverMaker';\n/**\n * Support color picker values inside the background picker.\n * Which means transitions from ct-color-picker are made possible thanks to\n * this logic.\n */\n\nconst maybeConvertFromColorPickerTo = value => {\n  if (!value.background_type) {\n    if (value[Object.keys(value)[0]].color) {\n      return {\n        background_type: 'color',\n        background_pattern: 'type-1',\n        background_image: {\n          attachment_id: null,\n          x: 0,\n          y: 0\n        },\n        background_repeat: 'no-repeat',\n        background_size: 'auto',\n        background_attachment: 'scroll',\n        patternColor: {\n          default: {\n            color: '#e5e7ea'\n          }\n        },\n        backgroundColor: {\n          default: value[Object.keys(value)[0]]\n        }\n      };\n    }\n  }\n\n  return value;\n};\n\nconst Background = _ref => {\n  let {\n    option,\n    value,\n    onChange\n  } = _ref;\n  const [isOpen, setIsOpen] = useState(false);\n  const [outsideClickFreezed, setOutsideClickFreezed] = useState(false);\n  const backgroundWrapper = useRef();\n  value = maybeConvertFromColorPickerTo(value);\n  const isInherit = !option.has_no_color && value.background_type === 'color' && (value.backgroundColor.default.color === 'CT_CSS_SKIP_RULE' || value.backgroundColor.default.color === 'transparent');\n  const isNoColor = option.has_no_color && value.background_type === 'color' && (value.backgroundColor.default.color === 'CT_CSS_SKIP_RULE' || value.backgroundColor.default.color === 'transparent');\n  const {\n    styles,\n    popoverProps\n  } = usePopoverMaker({\n    ref: backgroundWrapper,\n    defaultHeight: 434,\n    shouldCalculate: backgroundWrapper && backgroundWrapper.current\n  });\n  return createElement(\"div\", {\n    ref: backgroundWrapper,\n    className: cls('ct-background', {\n      active: isOpen\n    })\n  }, createElement(\"div\", {\n    className: cls('ct-background-preview', {\n      'ct-color-inherit': isInherit,\n      'ct-no-color': isNoColor\n    }),\n    onClick: e => {\n      e.preventDefault();\n      setIsOpen(!isOpen);\n\n      if (value.background_type === 'color') {\n        if (value.backgroundColor.default.color === 'CT_CSS_SKIP_RULE' || value.backgroundColor.default.color === 'transparent') {\n          onChange(_objectSpread(_objectSpread({}, value), {}, {\n            backgroundColor: {\n              default: {\n                color: option.default_inherit_color || '#ffffff'\n              }\n            }\n          }));\n        }\n      }\n    },\n    \"data-background-type\": value.background_type,\n    style: _objectSpread(_objectSpread({}, value.backgroundColor.default.color.indexOf('CT_CSS_SKIP_RULE') > -1 ? {} : {\n      backgroundColor: value.backgroundColor.default.color\n    }), {}, {\n      '--background-position': `${Math.round(parseFloat(value.background_image.x) * 100)}% ${Math.round(parseFloat(value.background_image.y) * 100)}%`,\n      '--pattern-mask': value.background_type === 'pattern' ? `url(${getUrlForPattern(value.background_pattern)})` : '',\n      '--background-image': value.background_type === 'gradient' ? value.gradient : value.background_image.url ? `${value.overlayColor && value.overlayColor.default.color.indexOf('CT_CSS_SKIP_RULE') === -1 ? `linear-gradient(${value.overlayColor.default.color}, ${value.overlayColor.default.color}), ` : ''}url(${value.background_image.url})` : 'none',\n      '--pattern-color': value.patternColor.default.color\n    })\n  }, createElement(\"i\", {\n    className: \"ct-tooltip-top\"\n  }, {\n    inherit: __('Inherited', 'blocksy'),\n    no_color: __('No Color', 'blocksy'),\n    pattern: __('Pattern', 'blocksy'),\n    gradient: __('Gradient', 'blocksy'),\n    color: __('Color', 'blocksy'),\n    image: __('Image', 'blocksy')\n  }[isNoColor ? 'no_color' : isInherit ? 'inherit' : value.background_type]), isInherit && createElement(\"svg\", {\n    width: \"25\",\n    height: \"25\",\n    viewBox: \"0 0 30 30\"\n  }, createElement(\"path\", {\n    d: \"M15 3c-3 0-5.7 1.1-7.8 2.9-.4.3-.5.9-.2 1.4.3.4 1 .5 1.4.2h.1C10.3 5.9 12.5 5 15 5c5.2 0 9.5 3.9 10 9h-3l4 6 4-6h-3.1C26.4 7.9 21.3 3 15 3zM4 10l-4 6h3.1c.5 6.1 5.6 11 11.9 11 3 0 5.7-1.1 7.8-2.9.4-.3.5-1 .2-1.4-.3-.4-1-.5-1.4-.2h-.1c-1.7 1.5-4 2.4-6.5 2.4-5.2 0-9.5-3.9-10-9h3L4 10z\"\n  }))), backgroundWrapper && backgroundWrapper.current && createPortal(createElement(OutsideClickHandler, {\n    useCapture: false,\n    display: \"block\",\n    disabled: !isOpen || outsideClickFreezed,\n    onOutsideClick: () => {\n      setTimeout(() => setIsOpen(false));\n    },\n    wrapperProps: _objectSpread(_objectSpread({\n      style: styles\n    }, popoverProps), {}, {\n      className: cls('ct-option-modal ct-background-modal', {\n        active: isOpen\n      })\n    })\n  }, createElement(BackgroundModal, {\n    onChange: onChange,\n    value: value,\n    option: option,\n    isOpen: isOpen,\n    setOutsideClickFreezed: setOutsideClickFreezed\n  })), document.body));\n};\n\nexport default Background;"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///8601\n")},9218:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _react_outside_click_handler__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(8204);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(4184);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _ct_color_picker__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(2495);\n/* harmony import */ var ct_i18n__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(5652);\n/* harmony import */ var ct_i18n__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(ct_i18n__WEBPACK_IMPORTED_MODULE_4__);\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\nconst clamp = (min, max, value) => Math.max(min, Math.min(max, value));\n\nconst Border = _ref => {\n let {\n value,\n option,\n onChange\n } = _ref;\n const [isOpen, setIsOpen] = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useState)(false);\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_2___default()('ct-option-border')\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_2___default()('ct-value-changer', {\n ['active']: isOpen,\n ['ct-disabled']: value.style === 'none' || value.inherit\n })\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"input\", {\n type: \"number\",\n value: value.width // disabled={value.style === 'none'}\n ,\n onChange: _ref2 => {\n let {\n target: {\n value: width\n }\n } = _ref2;\n return onChange(_objectSpread(_objectSpread({}, value), {}, {\n width: clamp(1, 5, parseInt(width, 10) || 1)\n }));\n }\n }), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"span\", {\n className: \"ct-value-divider\"\n }), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"span\", {\n className: \"ct-current-value\",\n \"data-style\": value.inherit ? 'none' : value.style,\n onClick: () => setIsOpen(!isOpen)\n }, value.inherit ? (0,ct_i18n__WEBPACK_IMPORTED_MODULE_4__.__)('Inherit', 'blocksy') : value.style === 'none' ? (0,ct_i18n__WEBPACK_IMPORTED_MODULE_4__.__)('none', 'blocksy') : null), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_react_outside_click_handler__WEBPACK_IMPORTED_MODULE_1__[\"default\"], {\n disabled: !isOpen,\n onOutsideClick: () => {\n if (!isOpen) return;\n setIsOpen(false);\n }\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"ul\", {\n className: \"ct-styles-list\"\n }, ['solid', 'dashed', 'dotted', 'none'].reduce((current, el, index) => [...current.slice(0, index % 2 === 0 ? undefined : -1), ...(index % 2 === 0 ? [[el]] : [[current[current.length - 1][0], el]])], []).map(group => (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"li\", {\n key: group[0]\n }, group.map(style => (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"span\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_2___default()({\n active: style === value.style\n }),\n \"data-style\": style,\n key: style,\n onClick: () => {\n onChange(_objectSpread(_objectSpread({}, value), {}, {\n style\n }, Object.keys(option.value).indexOf('inherit') > -1 ? {\n inherit: false\n } : {}));\n setIsOpen(false);\n },\n \"data-style\": style\n }, style === 'none' ? (0,ct_i18n__WEBPACK_IMPORTED_MODULE_4__.__)('None', 'blocksy') : null))))))), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_ct_color_picker__WEBPACK_IMPORTED_MODULE_3__[\"default\"], {\n onChange: colorValue => onChange(_objectSpread(_objectSpread({}, value), {}, {\n color: colorValue.default\n })),\n option: {\n pickers: [{\n id: 'default',\n title: (0,ct_i18n__WEBPACK_IMPORTED_MODULE_4__.__)('Initial', 'blocksy')\n }]\n },\n value: {\n default: value.color\n }\n }), option.secondColor && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_ct_color_picker__WEBPACK_IMPORTED_MODULE_3__[\"default\"], {\n onChange: colorValue => onChange(_objectSpread(_objectSpread({}, value), {}, {\n secondColor: colorValue.default\n })),\n option: {\n pickers: [{\n id: 'default',\n title: (0,ct_i18n__WEBPACK_IMPORTED_MODULE_4__.__)('Hover', 'blocksy')\n }]\n },\n value: {\n default: value.secondColor || option.value.secondColor\n }\n }));\n};\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Border);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiOTIxOC5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vc3RhdGljL2pzL29wdGlvbnMvb3B0aW9ucy9jdC1ib3JkZXIuanM/MGNjMCJdLCJzb3VyY2VzQ29udGVudCI6WyJmdW5jdGlvbiBvd25LZXlzKG9iamVjdCwgZW51bWVyYWJsZU9ubHkpIHsgdmFyIGtleXMgPSBPYmplY3Qua2V5cyhvYmplY3QpOyBpZiAoT2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9scykgeyB2YXIgc3ltYm9scyA9IE9iamVjdC5nZXRPd25Qcm9wZXJ0eVN5bWJvbHMob2JqZWN0KTsgZW51bWVyYWJsZU9ubHkgJiYgKHN5bWJvbHMgPSBzeW1ib2xzLmZpbHRlcihmdW5jdGlvbiAoc3ltKSB7IHJldHVybiBPYmplY3QuZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9yKG9iamVjdCwgc3ltKS5lbnVtZXJhYmxlOyB9KSksIGtleXMucHVzaC5hcHBseShrZXlzLCBzeW1ib2xzKTsgfSByZXR1cm4ga2V5czsgfVxuXG5mdW5jdGlvbiBfb2JqZWN0U3ByZWFkKHRhcmdldCkgeyBmb3IgKHZhciBpID0gMTsgaSA8IGFyZ3VtZW50cy5sZW5ndGg7IGkrKykgeyB2YXIgc291cmNlID0gbnVsbCAhPSBhcmd1bWVudHNbaV0gPyBhcmd1bWVudHNbaV0gOiB7fTsgaSAlIDIgPyBvd25LZXlzKE9iamVjdChzb3VyY2UpLCAhMCkuZm9yRWFjaChmdW5jdGlvbiAoa2V5KSB7IF9kZWZpbmVQcm9wZXJ0eSh0YXJnZXQsIGtleSwgc291cmNlW2tleV0pOyB9KSA6IE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3JzID8gT2JqZWN0LmRlZmluZVByb3BlcnRpZXModGFyZ2V0LCBPYmplY3QuZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9ycyhzb3VyY2UpKSA6IG93bktleXMoT2JqZWN0KHNvdXJjZSkpLmZvckVhY2goZnVuY3Rpb24gKGtleSkgeyBPYmplY3QuZGVmaW5lUHJvcGVydHkodGFyZ2V0LCBrZXksIE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3Ioc291cmNlLCBrZXkpKTsgfSk7IH0gcmV0dXJuIHRhcmdldDsgfVxuXG5mdW5jdGlvbiBfZGVmaW5lUHJvcGVydHkob2JqLCBrZXksIHZhbHVlKSB7IGlmIChrZXkgaW4gb2JqKSB7IE9iamVjdC5kZWZpbmVQcm9wZXJ0eShvYmosIGtleSwgeyB2YWx1ZTogdmFsdWUsIGVudW1lcmFibGU6IHRydWUsIGNvbmZpZ3VyYWJsZTogdHJ1ZSwgd3JpdGFibGU6IHRydWUgfSk7IH0gZWxzZSB7IG9ialtrZXldID0gdmFsdWU7IH0gcmV0dXJuIG9iajsgfVxuXG5pbXBvcnQgeyBjcmVhdGVFbGVtZW50LCBDb21wb25lbnQsIHVzZVN0YXRlLCB1c2VSZWYsIHVzZUNvbnRleHQgfSBmcm9tICdAd29yZHByZXNzL2VsZW1lbnQnO1xuaW1wb3J0IE91dHNpZGVDbGlja0hhbmRsZXIgZnJvbSAnLi9yZWFjdC1vdXRzaWRlLWNsaWNrLWhhbmRsZXInO1xuaW1wb3J0IGNsYXNzbmFtZXMgZnJvbSAnY2xhc3NuYW1lcyc7XG5pbXBvcnQgQ29sb3JQaWNrZXIgZnJvbSAnLi9jdC1jb2xvci1waWNrZXInO1xuaW1wb3J0IHsgX18gfSBmcm9tICdjdC1pMThuJztcblxuY29uc3QgY2xhbXAgPSAobWluLCBtYXgsIHZhbHVlKSA9PiBNYXRoLm1heChtaW4sIE1hdGgubWluKG1heCwgdmFsdWUpKTtcblxuY29uc3QgQm9yZGVyID0gX3JlZiA9PiB7XG4gIGxldCB7XG4gICAgdmFsdWUsXG4gICAgb3B0aW9uLFxuICAgIG9uQ2hhbmdlXG4gIH0gPSBfcmVmO1xuICBjb25zdCBbaXNPcGVuLCBzZXRJc09wZW5dID0gdXNlU3RhdGUoZmFsc2UpO1xuICByZXR1cm4gY3JlYXRlRWxlbWVudChcImRpdlwiLCB7XG4gICAgY2xhc3NOYW1lOiBjbGFzc25hbWVzKCdjdC1vcHRpb24tYm9yZGVyJylcbiAgfSwgY3JlYXRlRWxlbWVudChcImRpdlwiLCB7XG4gICAgY2xhc3NOYW1lOiBjbGFzc25hbWVzKCdjdC12YWx1ZS1jaGFuZ2VyJywge1xuICAgICAgWydhY3RpdmUnXTogaXNPcGVuLFxuICAgICAgWydjdC1kaXNhYmxlZCddOiB2YWx1ZS5zdHlsZSA9PT0gJ25vbmUnIHx8IHZhbHVlLmluaGVyaXRcbiAgICB9KVxuICB9LCBjcmVhdGVFbGVtZW50KFwiaW5wdXRcIiwge1xuICAgIHR5cGU6IFwibnVtYmVyXCIsXG4gICAgdmFsdWU6IHZhbHVlLndpZHRoIC8vIGRpc2FibGVkPXt2YWx1ZS5zdHlsZSA9PT0gJ25vbmUnfVxuICAgICxcbiAgICBvbkNoYW5nZTogX3JlZjIgPT4ge1xuICAgICAgbGV0IHtcbiAgICAgICAgdGFyZ2V0OiB7XG4gICAgICAgICAgdmFsdWU6IHdpZHRoXG4gICAgICAgIH1cbiAgICAgIH0gPSBfcmVmMjtcbiAgICAgIHJldHVybiBvbkNoYW5nZShfb2JqZWN0U3ByZWFkKF9vYmplY3RTcHJlYWQoe30sIHZhbHVlKSwge30sIHtcbiAgICAgICAgd2lkdGg6IGNsYW1wKDEsIDUsIHBhcnNlSW50KHdpZHRoLCAxMCkgfHwgMSlcbiAgICAgIH0pKTtcbiAgICB9XG4gIH0pLCBjcmVhdGVFbGVtZW50KFwic3BhblwiLCB7XG4gICAgY2xhc3NOYW1lOiBcImN0LXZhbHVlLWRpdmlkZXJcIlxuICB9KSwgY3JlYXRlRWxlbWVudChcInNwYW5cIiwge1xuICAgIGNsYXNzTmFtZTogXCJjdC1jdXJyZW50LXZhbHVlXCIsXG4gICAgXCJkYXRhLXN0eWxlXCI6IHZhbHVlLmluaGVyaXQgPyAnbm9uZScgOiB2YWx1ZS5zdHlsZSxcbiAgICBvbkNsaWNrOiAoKSA9PiBzZXRJc09wZW4oIWlzT3BlbilcbiAgfSwgdmFsdWUuaW5oZXJpdCA/IF9fKCdJbmhlcml0JywgJ2Jsb2Nrc3knKSA6IHZhbHVlLnN0eWxlID09PSAnbm9uZScgPyBfXygnbm9uZScsICdibG9ja3N5JykgOiBudWxsKSwgY3JlYXRlRWxlbWVudChPdXRzaWRlQ2xpY2tIYW5kbGVyLCB7XG4gICAgZGlzYWJsZWQ6ICFpc09wZW4sXG4gICAgb25PdXRzaWRlQ2xpY2s6ICgpID0+IHtcbiAgICAgIGlmICghaXNPcGVuKSByZXR1cm47XG4gICAgICBzZXRJc09wZW4oZmFsc2UpO1xuICAgIH1cbiAgfSwgY3JlYXRlRWxlbWVudChcInVsXCIsIHtcbiAgICBjbGFzc05hbWU6IFwiY3Qtc3R5bGVzLWxpc3RcIlxuICB9LCBbJ3NvbGlkJywgJ2Rhc2hlZCcsICdkb3R0ZWQnLCAnbm9uZSddLnJlZHVjZSgoY3VycmVudCwgZWwsIGluZGV4KSA9PiBbLi4uY3VycmVudC5zbGljZSgwLCBpbmRleCAlIDIgPT09IDAgPyB1bmRlZmluZWQgOiAtMSksIC4uLihpbmRleCAlIDIgPT09IDAgPyBbW2VsXV0gOiBbW2N1cnJlbnRbY3VycmVudC5sZW5ndGggLSAxXVswXSwgZWxdXSldLCBbXSkubWFwKGdyb3VwID0+IGNyZWF0ZUVsZW1lbnQoXCJsaVwiLCB7XG4gICAga2V5OiBncm91cFswXVxuICB9LCBncm91cC5tYXAoc3R5bGUgPT4gY3JlYXRlRWxlbWVudChcInNwYW5cIiwge1xuICAgIGNsYXNzTmFtZTogY2xhc3NuYW1lcyh7XG4gICAgICBhY3RpdmU6IHN0eWxlID09PSB2YWx1ZS5zdHlsZVxuICAgIH0pLFxuICAgIFwiZGF0YS1zdHlsZVwiOiBzdHlsZSxcbiAgICBrZXk6IHN0eWxlLFxuICAgIG9uQ2xpY2s6ICgpID0+IHtcbiAgICAgIG9uQ2hhbmdlKF9vYmplY3RTcHJlYWQoX29iamVjdFNwcmVhZCh7fSwgdmFsdWUpLCB7fSwge1xuICAgICAgICBzdHlsZVxuICAgICAgfSwgT2JqZWN0LmtleXMob3B0aW9uLnZhbHVlKS5pbmRleE9mKCdpbmhlcml0JykgPiAtMSA/IHtcbiAgICAgICAgaW5oZXJpdDogZmFsc2VcbiAgICAgIH0gOiB7fSkpO1xuICAgICAgc2V0SXNPcGVuKGZhbHNlKTtcbiAgICB9LFxuICAgIFwiZGF0YS1zdHlsZVwiOiBzdHlsZVxuICB9LCBzdHlsZSA9PT0gJ25vbmUnID8gX18oJ05vbmUnLCAnYmxvY2tzeScpIDogbnVsbCkpKSkpKSksIGNyZWF0ZUVsZW1lbnQoQ29sb3JQaWNrZXIsIHtcbiAgICBvbkNoYW5nZTogY29sb3JWYWx1ZSA9PiBvbkNoYW5nZShfb2JqZWN0U3ByZWFkKF9vYmplY3RTcHJlYWQoe30sIHZhbHVlKSwge30sIHtcbiAgICAgIGNvbG9yOiBjb2xvclZhbHVlLmRlZmF1bHRcbiAgICB9KSksXG4gICAgb3B0aW9uOiB7XG4gICAgICBwaWNrZXJzOiBbe1xuICAgICAgICBpZDogJ2RlZmF1bHQnLFxuICAgICAgICB0aXRsZTogX18oJ0luaXRpYWwnLCAnYmxvY2tzeScpXG4gICAgICB9XVxuICAgIH0sXG4gICAgdmFsdWU6IHtcbiAgICAgIGRlZmF1bHQ6IHZhbHVlLmNvbG9yXG4gICAgfVxuICB9KSwgb3B0aW9uLnNlY29uZENvbG9yICYmIGNyZWF0ZUVsZW1lbnQoQ29sb3JQaWNrZXIsIHtcbiAgICBvbkNoYW5nZTogY29sb3JWYWx1ZSA9PiBvbkNoYW5nZShfb2JqZWN0U3ByZWFkKF9vYmplY3RTcHJlYWQoe30sIHZhbHVlKSwge30sIHtcbiAgICAgIHNlY29uZENvbG9yOiBjb2xvclZhbHVlLmRlZmF1bHRcbiAgICB9KSksXG4gICAgb3B0aW9uOiB7XG4gICAgICBwaWNrZXJzOiBbe1xuICAgICAgICBpZDogJ2RlZmF1bHQnLFxuICAgICAgICB0aXRsZTogX18oJ0hvdmVyJywgJ2Jsb2Nrc3knKVxuICAgICAgfV1cbiAgICB9LFxuICAgIHZhbHVlOiB7XG4gICAgICBkZWZhdWx0OiB2YWx1ZS5zZWNvbmRDb2xvciB8fCBvcHRpb24udmFsdWUuc2Vjb25kQ29sb3JcbiAgICB9XG4gIH0pKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IEJvcmRlcjsiXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///9218\n")},9795:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("// ESM COMPAT FLAG\n__webpack_require__.r(__webpack_exports__);\n\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n \"default\": () => (/* binding */ ct_box_shadow)\n});\n\n// EXTERNAL MODULE: external \"window.wp.element\"\nvar external_window_wp_element_ = __webpack_require__(1381);\n// EXTERNAL MODULE: ./static/js/options/options/react-outside-click-handler.js\nvar react_outside_click_handler = __webpack_require__(8204);\n// EXTERNAL MODULE: ./node_modules/classnames/index.js\nvar classnames = __webpack_require__(4184);\nvar classnames_default = /*#__PURE__*/__webpack_require__.n(classnames);\n// EXTERNAL MODULE: ./static/js/options/options/color-picker/single-picker.js + 2 modules\nvar single_picker = __webpack_require__(694);\n// EXTERNAL MODULE: external \"window.wp.i18n\"\nvar external_window_wp_i18n_ = __webpack_require__(5652);\n// EXTERNAL MODULE: ./node_modules/react-spring/renderprops.js\nvar renderprops = __webpack_require__(4823);\n// EXTERNAL MODULE: ./node_modules/bezier-easing/src/index.js\nvar src = __webpack_require__(3431);\nvar src_default = /*#__PURE__*/__webpack_require__.n(src);\n// EXTERNAL MODULE: ./static/js/options/GenericOptionType.js\nvar GenericOptionType = __webpack_require__(6095);\n// EXTERNAL MODULE: ./static/js/options/options/ct-switch.js\nvar ct_switch = __webpack_require__(9497);\n// EXTERNAL MODULE: ./static/js/options/helpers/usePopoverMaker.js\nvar usePopoverMaker = __webpack_require__(9144);\n;// CONCATENATED MODULE: ./static/js/options/options/box-shadow/box-shadow-modal.js\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\n\n\n\nconst BoxShadowModal = _ref => {\n let {\n option,\n value,\n onChange,\n picker,\n onPickingChange,\n stopTransitioning,\n el,\n hOffsetRef,\n vOffsetRef,\n blurRef,\n spreadRef,\n isTransitioning,\n isPicking\n } = _ref;\n const {\n styles,\n popoverProps\n } = (0,usePopoverMaker/* default */.Z)({\n ref: el,\n defaultHeight: !option.hide_shadow_placement ? 507 : 437,\n shouldCalculate: isTransitioning === picker.id || (isPicking || '').split(':')[0] === picker.id\n });\n return (isTransitioning === picker.id || (isPicking || '').split(':')[0] === picker.id) && (0,external_window_wp_element_.createPortal)((0,external_window_wp_element_.createElement)(renderprops/* Transition */.uT, {\n items: isPicking,\n onRest: isOpen => {\n stopTransitioning();\n },\n config: {\n duration: 100,\n easing: src_default()(0.25, 0.1, 0.25, 1.0)\n },\n from: (isPicking || '').indexOf(':') === -1 ? {\n transform: 'scale3d(0.95, 0.95, 1)',\n opacity: 0\n } : {\n opacity: 1\n },\n enter: (isPicking || '').indexOf(':') === -1 ? {\n transform: 'scale3d(1, 1, 1)',\n opacity: 1\n } : {\n opacity: 1\n },\n leave: (isPicking || '').indexOf(':') === -1 ? {\n transform: 'scale3d(0.95, 0.95, 1)',\n opacity: 0\n } : {\n opacity: 1\n }\n }, isPicking => (isPicking || '').split(':')[0] === picker.id && (props => (0,external_window_wp_element_.createElement)(\"div\", _extends({\n style: _objectSpread(_objectSpread({}, props), styles)\n }, popoverProps, {\n className: \"ct-option-modal ct-box-shadow-modal\",\n onClick: e => {\n e.preventDefault();\n e.stopPropagation();\n },\n onMouseDownCapture: e => {\n e.nativeEvent.stopImmediatePropagation();\n e.nativeEvent.stopPropagation();\n },\n onMouseUpCapture: e => {\n e.nativeEvent.stopImmediatePropagation();\n e.nativeEvent.stopPropagation();\n }\n }), (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-shadow-trigger\"\n }, (0,external_window_wp_element_.createElement)(\"label\", null, (0,external_window_wp_i18n_.__)('Enable/Disable', 'blocksy')), (0,external_window_wp_element_.createElement)(ct_switch[\"default\"], {\n value: value.enable ? 'yes' : 'no',\n onChange: () => {\n onChange(_objectSpread(_objectSpread({}, value), {}, {\n enable: !value.enable\n }));\n }\n })), (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"shadow-sliders\"\n }, (0,external_window_wp_element_.createElement)(GenericOptionType/* default */.ZP, {\n value: value.h_offset,\n values: value,\n id: \"h_offset\",\n option: {\n id: 'h_offset',\n label: (0,external_window_wp_i18n_.__)('Horizontal Offset', 'blocksy'),\n type: 'ct-slider',\n steps: 'half',\n value: option.value.h_offset,\n min: -100,\n max: 100,\n design: 'compact',\n ref: hOffsetRef // skipInput: true\n\n },\n hasRevertButton: false,\n onChange: newValue => onChange(_objectSpread(_objectSpread({}, value), {}, {\n h_offset: newValue\n }))\n }), (0,external_window_wp_element_.createElement)(GenericOptionType/* default */.ZP, {\n value: value.v_offset,\n values: value,\n id: \"v_offset\",\n option: {\n steps: 'half',\n id: 'v_offset',\n label: (0,external_window_wp_i18n_.__)('Vertical Offset', 'blocksy'),\n type: 'ct-slider',\n value: option.value.v_offset,\n min: -100,\n max: 100,\n design: 'compact',\n ref: vOffsetRef // skipInput: true\n\n },\n hasRevertButton: false,\n onChange: newValue => onChange(_objectSpread(_objectSpread({}, value), {}, {\n v_offset: newValue\n }))\n }), (0,external_window_wp_element_.createElement)(GenericOptionType/* default */.ZP, {\n value: value.blur,\n values: value,\n id: \"blur\",\n option: {\n steps: 'positive',\n id: 'blur',\n label: (0,external_window_wp_i18n_.__)('Blur', 'blocksy'),\n type: 'ct-slider',\n value: option.value.blur,\n min: 0,\n max: 100,\n design: 'compact',\n ref: blurRef // skipInput: true\n\n },\n hasRevertButton: false,\n onChange: newValue => {\n onChange(_objectSpread(_objectSpread({}, value), {}, {\n blur: newValue\n }));\n }\n }), (0,external_window_wp_element_.createElement)(GenericOptionType/* default */.ZP, {\n value: value.spread,\n values: value,\n id: \"spread\",\n option: {\n steps: 'half',\n id: 'spread',\n label: (0,external_window_wp_i18n_.__)('Spread', 'blocksy'),\n type: 'ct-slider',\n value: option.value.spread,\n min: -100,\n max: 100,\n design: 'compact',\n ref: spreadRef // skipInput: true\n\n },\n hasRevertButton: false,\n onChange: newValue => onChange(_objectSpread(_objectSpread({}, value), {}, {\n spread: newValue\n }))\n })), !option.hide_shadow_placement && (0,external_window_wp_element_.createElement)(\"ul\", {\n className: \"ct-shadow-style\"\n }, (0,external_window_wp_element_.createElement)(\"li\", {\n onClick: () => onChange(_objectSpread(_objectSpread({}, value), {}, {\n inset: false\n })),\n className: classnames_default()({\n active: !value.inset\n })\n }, (0,external_window_wp_i18n_.__)('Outline', 'blocksy')), (0,external_window_wp_element_.createElement)(\"li\", {\n onClick: () => onChange(_objectSpread(_objectSpread({}, value), {}, {\n inset: true\n })),\n className: classnames_default()({\n active: value.inset\n })\n }, (0,external_window_wp_i18n_.__)('Inset', 'blocksy')))))), document.body);\n};\n\n/* harmony default export */ const box_shadow_modal = (BoxShadowModal);\n;// CONCATENATED MODULE: ./static/js/options/options/ct-box-shadow.js\nfunction ct_box_shadow_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction ct_box_shadow_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ct_box_shadow_ownKeys(Object(source), !0).forEach(function (key) { ct_box_shadow_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ct_box_shadow_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction ct_box_shadow_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\n\nconst clamp = (min, max, value) => Math.max(min, Math.min(max, value));\n\nconst BoxShadow = _ref => {\n let {\n value,\n option,\n onChange\n } = _ref;\n const [{\n isPicking,\n isTransitioning\n }, setAnimationState] = (0,external_window_wp_element_.useState)({\n isPicking: null,\n isTransitioning: null\n });\n const [focusedComponent, setFocusedComponent] = (0,external_window_wp_element_.useState)(null);\n const el = (0,external_window_wp_element_.useRef)();\n const colorPicker = (0,external_window_wp_element_.useRef)();\n const hOffsetRef = (0,external_window_wp_element_.useRef)();\n const vOffsetRef = (0,external_window_wp_element_.useRef)();\n const blurRef = (0,external_window_wp_element_.useRef)();\n const spreadRef = (0,external_window_wp_element_.useRef)();\n const containerRef = (0,external_window_wp_element_.useRef)();\n const modalRef = (0,external_window_wp_element_.useRef)();\n return (0,external_window_wp_element_.createElement)(\"div\", {\n ref: el,\n className: classnames_default()('ct-box-shadow', {\n 'ct-disabled': !value.enable || value.inherit\n })\n }, (0,external_window_wp_element_.createElement)(single_picker/* default */.Z, {\n innerRef: colorPicker,\n picker: {\n id: 'default',\n title: 'Initial'\n },\n option: {\n pickers: [{\n id: 'default',\n title: 'Initial'\n }]\n },\n isPicking: isPicking,\n isTransitioning: isTransitioning,\n modalRef: modalRef,\n containerRef: containerRef,\n onPickingChange: isPicking => {\n if (!value.enable) {\n return;\n }\n\n setAnimationState({\n isTransitioning: 'default',\n isPicking\n });\n },\n stopTransitioning: () => setAnimationState({\n isPicking,\n isTransitioning: false\n }),\n onChange: colorValue => onChange(ct_box_shadow_objectSpread(ct_box_shadow_objectSpread({}, value), {}, {\n color: colorValue\n })),\n value: value.color\n }), (0,external_window_wp_element_.createElement)(react_outside_click_handler[\"default\"], {\n useCapture: false,\n disabled: !isPicking,\n className: \"ct-box-shadow-values\",\n additionalRefs: [colorPicker, modalRef],\n onOutsideClick: () => {\n if (!isPicking) {\n return;\n }\n\n setAnimationState({\n isTransitioning: isPicking.split(':')[0],\n isPicking: null\n });\n },\n wrapperProps: {\n ref: containerRef,\n onClick: e => {\n e.preventDefault();\n let futureIsPicking = isPicking ? isPicking.split(':')[0] === 'opts' ? null : `opts:${isPicking.split(':')[0]}` : 'opts';\n setAnimationState({\n isTransitioning: 'opts',\n isPicking: futureIsPicking\n });\n }\n }\n }, (0,external_window_wp_element_.createElement)(\"span\", null, value.inherit ? (0,external_window_wp_i18n_.__)('Inherit', 'blocksy') : value.enable ? (0,external_window_wp_i18n_.__)('Adjust', 'blocksy') : (0,external_window_wp_i18n_.__)('None', 'blocksy'))), (0,external_window_wp_element_.createElement)(box_shadow_modal, {\n el: el,\n value: value,\n onChange: value => onChange(ct_box_shadow_objectSpread(ct_box_shadow_objectSpread({}, value), {}, {\n inherit: false\n })),\n option: option,\n isPicking: isPicking,\n isTransitioning: isTransitioning,\n hOffsetRef: hOffsetRef,\n vOffsetRef: vOffsetRef,\n blurRef: blurRef,\n spreadRef: spreadRef,\n picker: {\n id: 'opts'\n },\n onPickingChange: isPicking => {\n if (!value.enable) {\n return;\n }\n\n setAnimationState({\n isTransitioning: 'opts',\n isPicking\n });\n },\n stopTransitioning: () => setAnimationState({\n isPicking,\n isTransitioning: false\n })\n }));\n};\n\n/* harmony default export */ const ct_box_shadow = (BoxShadow);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"9795.js","mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./static/js/options/options/box-shadow/box-shadow-modal.js?ff4b","webpack://blocksyOptions/./static/js/options/options/ct-box-shadow.js?8f42"],"sourcesContent":["function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, createPortal } from '@wordpress/element';\nimport { Transition } from 'react-spring/renderprops';\nimport bezierEasing from 'bezier-easing';\nimport classnames from 'classnames';\nimport GenericOptionType from '../../GenericOptionType';\nimport { __ } from 'ct-i18n';\nimport Switch from '../ct-switch';\nimport usePopoverMaker from '../../helpers/usePopoverMaker';\n\nconst BoxShadowModal = _ref => {\n  let {\n    option,\n    value,\n    onChange,\n    picker,\n    onPickingChange,\n    stopTransitioning,\n    el,\n    hOffsetRef,\n    vOffsetRef,\n    blurRef,\n    spreadRef,\n    isTransitioning,\n    isPicking\n  } = _ref;\n  const {\n    styles,\n    popoverProps\n  } = usePopoverMaker({\n    ref: el,\n    defaultHeight: !option.hide_shadow_placement ? 507 : 437,\n    shouldCalculate: isTransitioning === picker.id || (isPicking || '').split(':')[0] === picker.id\n  });\n  return (isTransitioning === picker.id || (isPicking || '').split(':')[0] === picker.id) && createPortal(createElement(Transition, {\n    items: isPicking,\n    onRest: isOpen => {\n      stopTransitioning();\n    },\n    config: {\n      duration: 100,\n      easing: bezierEasing(0.25, 0.1, 0.25, 1.0)\n    },\n    from: (isPicking || '').indexOf(':') === -1 ? {\n      transform: 'scale3d(0.95, 0.95, 1)',\n      opacity: 0\n    } : {\n      opacity: 1\n    },\n    enter: (isPicking || '').indexOf(':') === -1 ? {\n      transform: 'scale3d(1, 1, 1)',\n      opacity: 1\n    } : {\n      opacity: 1\n    },\n    leave: (isPicking || '').indexOf(':') === -1 ? {\n      transform: 'scale3d(0.95, 0.95, 1)',\n      opacity: 0\n    } : {\n      opacity: 1\n    }\n  }, isPicking => (isPicking || '').split(':')[0] === picker.id && (props => createElement(\"div\", _extends({\n    style: _objectSpread(_objectSpread({}, props), styles)\n  }, popoverProps, {\n    className: \"ct-option-modal ct-box-shadow-modal\",\n    onClick: e => {\n      e.preventDefault();\n      e.stopPropagation();\n    },\n    onMouseDownCapture: e => {\n      e.nativeEvent.stopImmediatePropagation();\n      e.nativeEvent.stopPropagation();\n    },\n    onMouseUpCapture: e => {\n      e.nativeEvent.stopImmediatePropagation();\n      e.nativeEvent.stopPropagation();\n    }\n  }), createElement(\"div\", {\n    className: \"ct-shadow-trigger\"\n  }, createElement(\"label\", null, __('Enable/Disable', 'blocksy')), createElement(Switch, {\n    value: value.enable ? 'yes' : 'no',\n    onChange: () => {\n      onChange(_objectSpread(_objectSpread({}, value), {}, {\n        enable: !value.enable\n      }));\n    }\n  })), createElement(\"div\", {\n    className: \"shadow-sliders\"\n  }, createElement(GenericOptionType, {\n    value: value.h_offset,\n    values: value,\n    id: \"h_offset\",\n    option: {\n      id: 'h_offset',\n      label: __('Horizontal Offset', 'blocksy'),\n      type: 'ct-slider',\n      steps: 'half',\n      value: option.value.h_offset,\n      min: -100,\n      max: 100,\n      design: 'compact',\n      ref: hOffsetRef // skipInput: true\n\n    },\n    hasRevertButton: false,\n    onChange: newValue => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      h_offset: newValue\n    }))\n  }), createElement(GenericOptionType, {\n    value: value.v_offset,\n    values: value,\n    id: \"v_offset\",\n    option: {\n      steps: 'half',\n      id: 'v_offset',\n      label: __('Vertical Offset', 'blocksy'),\n      type: 'ct-slider',\n      value: option.value.v_offset,\n      min: -100,\n      max: 100,\n      design: 'compact',\n      ref: vOffsetRef // skipInput: true\n\n    },\n    hasRevertButton: false,\n    onChange: newValue => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      v_offset: newValue\n    }))\n  }), createElement(GenericOptionType, {\n    value: value.blur,\n    values: value,\n    id: \"blur\",\n    option: {\n      steps: 'positive',\n      id: 'blur',\n      label: __('Blur', 'blocksy'),\n      type: 'ct-slider',\n      value: option.value.blur,\n      min: 0,\n      max: 100,\n      design: 'compact',\n      ref: blurRef // skipInput: true\n\n    },\n    hasRevertButton: false,\n    onChange: newValue => {\n      onChange(_objectSpread(_objectSpread({}, value), {}, {\n        blur: newValue\n      }));\n    }\n  }), createElement(GenericOptionType, {\n    value: value.spread,\n    values: value,\n    id: \"spread\",\n    option: {\n      steps: 'half',\n      id: 'spread',\n      label: __('Spread', 'blocksy'),\n      type: 'ct-slider',\n      value: option.value.spread,\n      min: -100,\n      max: 100,\n      design: 'compact',\n      ref: spreadRef // skipInput: true\n\n    },\n    hasRevertButton: false,\n    onChange: newValue => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      spread: newValue\n    }))\n  })), !option.hide_shadow_placement && createElement(\"ul\", {\n    className: \"ct-shadow-style\"\n  }, createElement(\"li\", {\n    onClick: () => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      inset: false\n    })),\n    className: classnames({\n      active: !value.inset\n    })\n  }, __('Outline', 'blocksy')), createElement(\"li\", {\n    onClick: () => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      inset: true\n    })),\n    className: classnames({\n      active: value.inset\n    })\n  }, __('Inset', 'blocksy')))))), document.body);\n};\n\nexport default BoxShadowModal;","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, useState, useRef, useContext } from '@wordpress/element';\nimport OutsideClickHandler from './react-outside-click-handler';\nimport classnames from 'classnames';\nimport SingleColorPicker from './color-picker/single-picker';\nimport { __ } from 'ct-i18n';\nimport BoxShadowModal from './box-shadow/box-shadow-modal';\n\nconst clamp = (min, max, value) => Math.max(min, Math.min(max, value));\n\nconst BoxShadow = _ref => {\n  let {\n    value,\n    option,\n    onChange\n  } = _ref;\n  const [{\n    isPicking,\n    isTransitioning\n  }, setAnimationState] = useState({\n    isPicking: null,\n    isTransitioning: null\n  });\n  const [focusedComponent, setFocusedComponent] = useState(null);\n  const el = useRef();\n  const colorPicker = useRef();\n  const hOffsetRef = useRef();\n  const vOffsetRef = useRef();\n  const blurRef = useRef();\n  const spreadRef = useRef();\n  const containerRef = useRef();\n  const modalRef = useRef();\n  return createElement(\"div\", {\n    ref: el,\n    className: classnames('ct-box-shadow', {\n      'ct-disabled': !value.enable || value.inherit\n    })\n  }, createElement(SingleColorPicker, {\n    innerRef: colorPicker,\n    picker: {\n      id: 'default',\n      title: 'Initial'\n    },\n    option: {\n      pickers: [{\n        id: 'default',\n        title: 'Initial'\n      }]\n    },\n    isPicking: isPicking,\n    isTransitioning: isTransitioning,\n    modalRef: modalRef,\n    containerRef: containerRef,\n    onPickingChange: isPicking => {\n      if (!value.enable) {\n        return;\n      }\n\n      setAnimationState({\n        isTransitioning: 'default',\n        isPicking\n      });\n    },\n    stopTransitioning: () => setAnimationState({\n      isPicking,\n      isTransitioning: false\n    }),\n    onChange: colorValue => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      color: colorValue\n    })),\n    value: value.color\n  }), createElement(OutsideClickHandler, {\n    useCapture: false,\n    disabled: !isPicking,\n    className: \"ct-box-shadow-values\",\n    additionalRefs: [colorPicker, modalRef],\n    onOutsideClick: () => {\n      if (!isPicking) {\n        return;\n      }\n\n      setAnimationState({\n        isTransitioning: isPicking.split(':')[0],\n        isPicking: null\n      });\n    },\n    wrapperProps: {\n      ref: containerRef,\n      onClick: e => {\n        e.preventDefault();\n        let futureIsPicking = isPicking ? isPicking.split(':')[0] === 'opts' ? null : `opts:${isPicking.split(':')[0]}` : 'opts';\n        setAnimationState({\n          isTransitioning: 'opts',\n          isPicking: futureIsPicking\n        });\n      }\n    }\n  }, createElement(\"span\", null, value.inherit ? __('Inherit', 'blocksy') : value.enable ? __('Adjust', 'blocksy') : __('None', 'blocksy'))), createElement(BoxShadowModal, {\n    el: el,\n    value: value,\n    onChange: value => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      inherit: false\n    })),\n    option: option,\n    isPicking: isPicking,\n    isTransitioning: isTransitioning,\n    hOffsetRef: hOffsetRef,\n    vOffsetRef: vOffsetRef,\n    blurRef: blurRef,\n    spreadRef: spreadRef,\n    picker: {\n      id: 'opts'\n    },\n    onPickingChange: isPicking => {\n      if (!value.enable) {\n        return;\n      }\n\n      setAnimationState({\n        isTransitioning: 'opts',\n        isPicking\n      });\n    },\n    stopTransitioning: () => setAnimationState({\n      isPicking,\n      isTransitioning: false\n    })\n  }));\n};\n\nexport default BoxShadow;"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///9795\n")},9838:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\nconst Button = _ref => {\n let {\n option: {\n text = \'\',\n attr = {},\n panel,\n url\n }\n } = _ref;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("a", _extends({}, _objectSpread({}, attr || {}), {\n href: url,\n target: "_blank",\n onClick: e => {\n return;\n e.preventDefault();\n\n if (panel && wp.customize && wp.customize.panel(panel)) {\n wp.customize.panel(panel).expand();\n return;\n }\n\n url && location.assign(url);\n }\n }), text);\n};\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Button);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiOTgzOC5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vc3RhdGljL2pzL29wdGlvbnMvb3B0aW9ucy9jdC1idXR0b24uanM/MTg4ZSJdLCJzb3VyY2VzQ29udGVudCI6WyJmdW5jdGlvbiBfZXh0ZW5kcygpIHsgX2V4dGVuZHMgPSBPYmplY3QuYXNzaWduID8gT2JqZWN0LmFzc2lnbi5iaW5kKCkgOiBmdW5jdGlvbiAodGFyZ2V0KSB7IGZvciAodmFyIGkgPSAxOyBpIDwgYXJndW1lbnRzLmxlbmd0aDsgaSsrKSB7IHZhciBzb3VyY2UgPSBhcmd1bWVudHNbaV07IGZvciAodmFyIGtleSBpbiBzb3VyY2UpIHsgaWYgKE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChzb3VyY2UsIGtleSkpIHsgdGFyZ2V0W2tleV0gPSBzb3VyY2Vba2V5XTsgfSB9IH0gcmV0dXJuIHRhcmdldDsgfTsgcmV0dXJuIF9leHRlbmRzLmFwcGx5KHRoaXMsIGFyZ3VtZW50cyk7IH1cblxuZnVuY3Rpb24gb3duS2V5cyhvYmplY3QsIGVudW1lcmFibGVPbmx5KSB7IHZhciBrZXlzID0gT2JqZWN0LmtleXMob2JqZWN0KTsgaWYgKE9iamVjdC5nZXRPd25Qcm9wZXJ0eVN5bWJvbHMpIHsgdmFyIHN5bWJvbHMgPSBPYmplY3QuZ2V0T3duUHJvcGVydHlTeW1ib2xzKG9iamVjdCk7IGVudW1lcmFibGVPbmx5ICYmIChzeW1ib2xzID0gc3ltYm9scy5maWx0ZXIoZnVuY3Rpb24gKHN5bSkgeyByZXR1cm4gT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcihvYmplY3QsIHN5bSkuZW51bWVyYWJsZTsgfSkpLCBrZXlzLnB1c2guYXBwbHkoa2V5cywgc3ltYm9scyk7IH0gcmV0dXJuIGtleXM7IH1cblxuZnVuY3Rpb24gX29iamVjdFNwcmVhZCh0YXJnZXQpIHsgZm9yICh2YXIgaSA9IDE7IGkgPCBhcmd1bWVudHMubGVuZ3RoOyBpKyspIHsgdmFyIHNvdXJjZSA9IG51bGwgIT0gYXJndW1lbnRzW2ldID8gYXJndW1lbnRzW2ldIDoge307IGkgJSAyID8gb3duS2V5cyhPYmplY3Qoc291cmNlKSwgITApLmZvckVhY2goZnVuY3Rpb24gKGtleSkgeyBfZGVmaW5lUHJvcGVydHkodGFyZ2V0LCBrZXksIHNvdXJjZVtrZXldKTsgfSkgOiBPYmplY3QuZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9ycyA/IE9iamVjdC5kZWZpbmVQcm9wZXJ0aWVzKHRhcmdldCwgT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcnMoc291cmNlKSkgOiBvd25LZXlzKE9iamVjdChzb3VyY2UpKS5mb3JFYWNoKGZ1bmN0aW9uIChrZXkpIHsgT2JqZWN0LmRlZmluZVByb3BlcnR5KHRhcmdldCwga2V5LCBPYmplY3QuZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9yKHNvdXJjZSwga2V5KSk7IH0pOyB9IHJldHVybiB0YXJnZXQ7IH1cblxuZnVuY3Rpb24gX2RlZmluZVByb3BlcnR5KG9iaiwga2V5LCB2YWx1ZSkgeyBpZiAoa2V5IGluIG9iaikgeyBPYmplY3QuZGVmaW5lUHJvcGVydHkob2JqLCBrZXksIHsgdmFsdWU6IHZhbHVlLCBlbnVtZXJhYmxlOiB0cnVlLCBjb25maWd1cmFibGU6IHRydWUsIHdyaXRhYmxlOiB0cnVlIH0pOyB9IGVsc2UgeyBvYmpba2V5XSA9IHZhbHVlOyB9IHJldHVybiBvYmo7IH1cblxuaW1wb3J0IHsgRnJhZ21lbnQsIGNyZWF0ZUVsZW1lbnQsIENvbXBvbmVudCB9IGZyb20gJ0B3b3JkcHJlc3MvZWxlbWVudCc7XG5cbmNvbnN0IEJ1dHRvbiA9IF9yZWYgPT4ge1xuICBsZXQge1xuICAgIG9wdGlvbjoge1xuICAgICAgdGV4dCA9ICcnLFxuICAgICAgYXR0ciA9IHt9LFxuICAgICAgcGFuZWwsXG4gICAgICB1cmxcbiAgICB9XG4gIH0gPSBfcmVmO1xuICByZXR1cm4gY3JlYXRlRWxlbWVudChcImFcIiwgX2V4dGVuZHMoe30sIF9vYmplY3RTcHJlYWQoe30sIGF0dHIgfHwge30pLCB7XG4gICAgaHJlZjogdXJsLFxuICAgIHRhcmdldDogXCJfYmxhbmtcIixcbiAgICBvbkNsaWNrOiBlID0+IHtcbiAgICAgIHJldHVybjtcbiAgICAgIGUucHJldmVudERlZmF1bHQoKTtcblxuICAgICAgaWYgKHBhbmVsICYmIHdwLmN1c3RvbWl6ZSAmJiB3cC5jdXN0b21pemUucGFuZWwocGFuZWwpKSB7XG4gICAgICAgIHdwLmN1c3RvbWl6ZS5wYW5lbChwYW5lbCkuZXhwYW5kKCk7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgdXJsICYmIGxvY2F0aW9uLmFzc2lnbih1cmwpO1xuICAgIH1cbiAgfSksIHRleHQpO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgQnV0dG9uOyJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///9838\n')},3413:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _helpers_parse_choices_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(4592);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(4184);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(6715);\n/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_2__);\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\nconst Checkboxes = _ref => {\n let {\n option,\n value,\n onChange,\n option: {\n view = \'checkboxes\'\n }\n } = _ref;\n const orderedChoices = (0,_helpers_parse_choices_js__WEBPACK_IMPORTED_MODULE_3__/* .maybeTransformUnorderedChoices */ .N)(option.choices);\n const {\n inline = false\n } = option;\n\n if (view === \'checkboxes\') {\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", _extends({\n className: "ct-option-checkbox"\n }, inline ? {\n [\'data-inline\']: \'\'\n } : {}, option.attr || {}), orderedChoices.map(_ref2 => {\n let {\n key,\n value: choiceValue\n } = _ref2;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("label", {\n key: key\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("input", {\n type: "checkbox",\n checked: typeof value[key] === \'boolean\' ? value[key] : value[key] === \'true\',\n "data-id": key,\n onChange: _ref3 => {\n let {\n target: {\n checked\n }\n } = _ref3;\n return onChange(_objectSpread(_objectSpread({}, value), {}, {\n [key]: value[key] ? Object.values(value).filter(v => v).length === 1 && !option.allow_empty ? true : false : true\n }));\n }\n }), choiceValue);\n }));\n }\n\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("ul", _extends({\n className: "ct-option-checkbox ct-buttons-group"\n }, inline ? {\n [\'data-inline\']: \'\'\n } : {}, option.attr || {}), orderedChoices.map(_ref4 => {\n let {\n key,\n value: choiceValue\n } = _ref4;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("li", {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()({\n active: typeof value[key] === \'boolean\' ? value[key] : value[key] === \'true\'\n }),\n "data-id": key,\n key: key,\n onClick: _ref5 => {\n let {\n target: {\n checked\n }\n } = _ref5;\n return onChange(_objectSpread(_objectSpread({}, value), {}, {\n [key]: value[key] ? Object.values(value).filter(v => v).length === 1 && !option.allow_empty ? true : false : true\n }));\n }\n }, choiceValue);\n }));\n};\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Checkboxes);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMzQxMy5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vc3RhdGljL2pzL29wdGlvbnMvb3B0aW9ucy9jdC1jaGVja2JveGVzLmpzP2NlYzgiXSwic291cmNlc0NvbnRlbnQiOlsiZnVuY3Rpb24gX2V4dGVuZHMoKSB7IF9leHRlbmRzID0gT2JqZWN0LmFzc2lnbiA/IE9iamVjdC5hc3NpZ24uYmluZCgpIDogZnVuY3Rpb24gKHRhcmdldCkgeyBmb3IgKHZhciBpID0gMTsgaSA8IGFyZ3VtZW50cy5sZW5ndGg7IGkrKykgeyB2YXIgc291cmNlID0gYXJndW1lbnRzW2ldOyBmb3IgKHZhciBrZXkgaW4gc291cmNlKSB7IGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwoc291cmNlLCBrZXkpKSB7IHRhcmdldFtrZXldID0gc291cmNlW2tleV07IH0gfSB9IHJldHVybiB0YXJnZXQ7IH07IHJldHVybiBfZXh0ZW5kcy5hcHBseSh0aGlzLCBhcmd1bWVudHMpOyB9XG5cbmZ1bmN0aW9uIG93bktleXMob2JqZWN0LCBlbnVtZXJhYmxlT25seSkgeyB2YXIga2V5cyA9IE9iamVjdC5rZXlzKG9iamVjdCk7IGlmIChPYmplY3QuZ2V0T3duUHJvcGVydHlTeW1ib2xzKSB7IHZhciBzeW1ib2xzID0gT2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9scyhvYmplY3QpOyBlbnVtZXJhYmxlT25seSAmJiAoc3ltYm9scyA9IHN5bWJvbHMuZmlsdGVyKGZ1bmN0aW9uIChzeW0pIHsgcmV0dXJuIE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3Iob2JqZWN0LCBzeW0pLmVudW1lcmFibGU7IH0pKSwga2V5cy5wdXNoLmFwcGx5KGtleXMsIHN5bWJvbHMpOyB9IHJldHVybiBrZXlzOyB9XG5cbmZ1bmN0aW9uIF9vYmplY3RTcHJlYWQodGFyZ2V0KSB7IGZvciAodmFyIGkgPSAxOyBpIDwgYXJndW1lbnRzLmxlbmd0aDsgaSsrKSB7IHZhciBzb3VyY2UgPSBudWxsICE9IGFyZ3VtZW50c1tpXSA/IGFyZ3VtZW50c1tpXSA6IHt9OyBpICUgMiA/IG93bktleXMoT2JqZWN0KHNvdXJjZSksICEwKS5mb3JFYWNoKGZ1bmN0aW9uIChrZXkpIHsgX2RlZmluZVByb3BlcnR5KHRhcmdldCwga2V5LCBzb3VyY2Vba2V5XSk7IH0pIDogT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcnMgPyBPYmplY3QuZGVmaW5lUHJvcGVydGllcyh0YXJnZXQsIE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3JzKHNvdXJjZSkpIDogb3duS2V5cyhPYmplY3Qoc291cmNlKSkuZm9yRWFjaChmdW5jdGlvbiAoa2V5KSB7IE9iamVjdC5kZWZpbmVQcm9wZXJ0eSh0YXJnZXQsIGtleSwgT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcihzb3VyY2UsIGtleSkpOyB9KTsgfSByZXR1cm4gdGFyZ2V0OyB9XG5cbmZ1bmN0aW9uIF9kZWZpbmVQcm9wZXJ0eShvYmosIGtleSwgdmFsdWUpIHsgaWYgKGtleSBpbiBvYmopIHsgT2JqZWN0LmRlZmluZVByb3BlcnR5KG9iaiwga2V5LCB7IHZhbHVlOiB2YWx1ZSwgZW51bWVyYWJsZTogdHJ1ZSwgY29uZmlndXJhYmxlOiB0cnVlLCB3cml0YWJsZTogdHJ1ZSB9KTsgfSBlbHNlIHsgb2JqW2tleV0gPSB2YWx1ZTsgfSByZXR1cm4gb2JqOyB9XG5cbmltcG9ydCB7IGNyZWF0ZUVsZW1lbnQsIENvbXBvbmVudCwgY3JlYXRlQ29udGV4dCwgRnJhZ21lbnQgfSBmcm9tICdAd29yZHByZXNzL2VsZW1lbnQnO1xuaW1wb3J0IHsgbWF5YmVUcmFuc2Zvcm1Vbm9yZGVyZWRDaG9pY2VzIH0gZnJvbSAnLi4vaGVscGVycy9wYXJzZS1jaG9pY2VzLmpzJztcbmltcG9ydCBjbGFzc25hbWVzIGZyb20gJ2NsYXNzbmFtZXMnO1xuaW1wb3J0IF8gZnJvbSAndW5kZXJzY29yZSc7XG5cbmNvbnN0IENoZWNrYm94ZXMgPSBfcmVmID0+IHtcbiAgbGV0IHtcbiAgICBvcHRpb24sXG4gICAgdmFsdWUsXG4gICAgb25DaGFuZ2UsXG4gICAgb3B0aW9uOiB7XG4gICAgICB2aWV3ID0gJ2NoZWNrYm94ZXMnXG4gICAgfVxuICB9ID0gX3JlZjtcbiAgY29uc3Qgb3JkZXJlZENob2ljZXMgPSBtYXliZVRyYW5zZm9ybVVub3JkZXJlZENob2ljZXMob3B0aW9uLmNob2ljZXMpO1xuICBjb25zdCB7XG4gICAgaW5saW5lID0gZmFsc2VcbiAgfSA9IG9wdGlvbjtcblxuICBpZiAodmlldyA9PT0gJ2NoZWNrYm94ZXMnKSB7XG4gICAgcmV0dXJuIGNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwgX2V4dGVuZHMoe1xuICAgICAgY2xhc3NOYW1lOiBcImN0LW9wdGlvbi1jaGVja2JveFwiXG4gICAgfSwgaW5saW5lID8ge1xuICAgICAgWydkYXRhLWlubGluZSddOiAnJ1xuICAgIH0gOiB7fSwgb3B0aW9uLmF0dHIgfHwge30pLCBvcmRlcmVkQ2hvaWNlcy5tYXAoX3JlZjIgPT4ge1xuICAgICAgbGV0IHtcbiAgICAgICAga2V5LFxuICAgICAgICB2YWx1ZTogY2hvaWNlVmFsdWVcbiAgICAgIH0gPSBfcmVmMjtcbiAgICAgIHJldHVybiBjcmVhdGVFbGVtZW50KFwibGFiZWxcIiwge1xuICAgICAgICBrZXk6IGtleVxuICAgICAgfSwgY3JlYXRlRWxlbWVudChcImlucHV0XCIsIHtcbiAgICAgICAgdHlwZTogXCJjaGVja2JveFwiLFxuICAgICAgICBjaGVja2VkOiB0eXBlb2YgdmFsdWVba2V5XSA9PT0gJ2Jvb2xlYW4nID8gdmFsdWVba2V5XSA6IHZhbHVlW2tleV0gPT09ICd0cnVlJyxcbiAgICAgICAgXCJkYXRhLWlkXCI6IGtleSxcbiAgICAgICAgb25DaGFuZ2U6IF9yZWYzID0+IHtcbiAgICAgICAgICBsZXQge1xuICAgICAgICAgICAgdGFyZ2V0OiB7XG4gICAgICAgICAgICAgIGNoZWNrZWRcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9ID0gX3JlZjM7XG4gICAgICAgICAgcmV0dXJuIG9uQ2hhbmdlKF9vYmplY3RTcHJlYWQoX29iamVjdFNwcmVhZCh7fSwgdmFsdWUpLCB7fSwge1xuICAgICAgICAgICAgW2tleV06IHZhbHVlW2tleV0gPyBPYmplY3QudmFsdWVzKHZhbHVlKS5maWx0ZXIodiA9PiB2KS5sZW5ndGggPT09IDEgJiYgIW9wdGlvbi5hbGxvd19lbXB0eSA/IHRydWUgOiBmYWxzZSA6IHRydWVcbiAgICAgICAgICB9KSk7XG4gICAgICAgIH1cbiAgICAgIH0pLCBjaG9pY2VWYWx1ZSk7XG4gICAgfSkpO1xuICB9XG5cbiAgcmV0dXJuIGNyZWF0ZUVsZW1lbnQoXCJ1bFwiLCBfZXh0ZW5kcyh7XG4gICAgY2xhc3NOYW1lOiBcImN0LW9wdGlvbi1jaGVja2JveCBjdC1idXR0b25zLWdyb3VwXCJcbiAgfSwgaW5saW5lID8ge1xuICAgIFsnZGF0YS1pbmxpbmUnXTogJydcbiAgfSA6IHt9LCBvcHRpb24uYXR0ciB8fCB7fSksIG9yZGVyZWRDaG9pY2VzLm1hcChfcmVmNCA9PiB7XG4gICAgbGV0IHtcbiAgICAgIGtleSxcbiAgICAgIHZhbHVlOiBjaG9pY2VWYWx1ZVxuICAgIH0gPSBfcmVmNDtcbiAgICByZXR1cm4gY3JlYXRlRWxlbWVudChcImxpXCIsIHtcbiAgICAgIGNsYXNzTmFtZTogY2xhc3NuYW1lcyh7XG4gICAgICAgIGFjdGl2ZTogdHlwZW9mIHZhbHVlW2tleV0gPT09ICdib29sZWFuJyA/IHZhbHVlW2tleV0gOiB2YWx1ZVtrZXldID09PSAndHJ1ZSdcbiAgICAgIH0pLFxuICAgICAgXCJkYXRhLWlkXCI6IGtleSxcbiAgICAgIGtleToga2V5LFxuICAgICAgb25DbGljazogX3JlZjUgPT4ge1xuICAgICAgICBsZXQge1xuICAgICAgICAgIHRhcmdldDoge1xuICAgICAgICAgICAgY2hlY2tlZFxuICAgICAgICAgIH1cbiAgICAgICAgfSA9IF9yZWY1O1xuICAgICAgICByZXR1cm4gb25DaGFuZ2UoX29iamVjdFNwcmVhZChfb2JqZWN0U3ByZWFkKHt9LCB2YWx1ZSksIHt9LCB7XG4gICAgICAgICAgW2tleV06IHZhbHVlW2tleV0gPyBPYmplY3QudmFsdWVzKHZhbHVlKS5maWx0ZXIodiA9PiB2KS5sZW5ndGggPT09IDEgJiYgIW9wdGlvbi5hbGxvd19lbXB0eSA/IHRydWUgOiBmYWxzZSA6IHRydWVcbiAgICAgICAgfSkpO1xuICAgICAgfVxuICAgIH0sIGNob2ljZVZhbHVlKTtcbiAgfSkpO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgQ2hlY2tib3hlczsiXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///3413\n')},2757:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("// ESM COMPAT FLAG\n__webpack_require__.r(__webpack_exports__);\n\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n \"default\": () => (/* binding */ ct_color_palettes_picker)\n});\n\n// EXTERNAL MODULE: external \"window.wp.element\"\nvar external_window_wp_element_ = __webpack_require__(1381);\n// EXTERNAL MODULE: ./static/js/options/OptionsPanel.js + 7 modules\nvar OptionsPanel = __webpack_require__(7429);\n// EXTERNAL MODULE: external \"window.wp.i18n\"\nvar external_window_wp_i18n_ = __webpack_require__(5652);\n// EXTERNAL MODULE: ./node_modules/classnames/index.js\nvar classnames = __webpack_require__(4184);\nvar classnames_default = /*#__PURE__*/__webpack_require__.n(classnames);\n;// CONCATENATED MODULE: ./static/js/options/options/color-palettes/PalettePreview.js\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\nconst PalettePreview = _ref => {\n let {\n renderBefore = () => null,\n value,\n onChange,\n onClick,\n currentPalette = null,\n className\n } = _ref;\n\n if (!currentPalette) {\n currentPalette = value;\n\n if (value.palettes) {\n currentPalette = value.palettes.find(_ref2 => {\n let {\n id\n } = _ref2;\n return id === value.current_palette;\n });\n }\n }\n\n return (0,external_window_wp_element_.createElement)(\"div\", {\n className: classnames_default()('ct-single-palette', className),\n onClick: e => {\n if (e.target.closest('.ct-color-picker-modal') || e.target.classList.contains('ct-color-picker-modal')) {\n return;\n }\n\n onClick();\n }\n }, renderBefore(), (0,external_window_wp_element_.createElement)(OptionsPanel/* default */.Z, {\n hasRevertButton: false,\n onChange: (optionId, optionValue) => {\n if (optionId !== 'color') {\n return;\n }\n\n onChange(optionId, Object.keys(optionValue).reduce((finalValue, currentId) => _objectSpread(_objectSpread({}, finalValue), currentId.indexOf('color') === 0 ? {\n [currentId]: optionValue[currentId]\n } : {}), {}));\n },\n value: {\n color: currentPalette\n },\n options: {\n color: _objectSpread(_objectSpread({\n type: 'ct-color-picker',\n predefined: true,\n design: 'none',\n label: false,\n modalClassName: 'ct-color-palette-modal',\n value: currentPalette\n }, onChange ? {} : {\n skipModal: true\n }), {}, {\n pickers: Object.keys(currentPalette).filter(k => k.indexOf('color') === 0).map((key, index) => ({\n title: (0,external_window_wp_i18n_.sprintf)((0,external_window_wp_i18n_.__)('Color %s', 'blocksy'), index + 1),\n id: key\n }))\n })\n }\n }));\n};\n\n/* harmony default export */ const color_palettes_PalettePreview = (PalettePreview);\n// EXTERNAL MODULE: ./node_modules/@react-spring/web/dist/react-spring-web.esm.js\nvar react_spring_web_esm = __webpack_require__(1472);\n;// CONCATENATED MODULE: ./static/js/options/options/color-palettes/ColorPalettesModal.js\nconst _excluded = [\"id\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ColorPalettesModal_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction ColorPalettesModal_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ColorPalettesModal_ownKeys(Object(source), !0).forEach(function (key) { ColorPalettesModal_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ColorPalettesModal_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction ColorPalettesModal_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\n\n\n\n\n\n\nconst ColorPalettesModal = _ref => {\n let {\n option,\n value,\n onChange,\n wrapperProps = {}\n } = _ref;\n return (0,external_window_wp_element_.createElement)(react_spring_web_esm.animated.div, _extends({\n className: \"ct-option-modal ct-palettes-modal\"\n }, wrapperProps), value.palettes.map((palette, index) => (0,external_window_wp_element_.createElement)(color_palettes_PalettePreview, {\n currentPalette: palette,\n className: value.current_palette === palette.id ? 'ct-active' : '',\n renderBefore: () => (0,external_window_wp_element_.createElement)(\"label\", null, (0,external_window_wp_i18n_.sprintf)((0,external_window_wp_i18n_.__)('Palette #%s', 'blocksy'), index + 1)),\n onClick: () => {\n const {\n id\n } = palette,\n colors = _objectWithoutProperties(palette, _excluded);\n\n onChange(ColorPalettesModal_objectSpread(ColorPalettesModal_objectSpread({}, value), {}, {\n current_palette: id\n }, colors));\n }\n })));\n};\n\n/* harmony default export */ const color_palettes_ColorPalettesModal = (ColorPalettesModal);\n// EXTERNAL MODULE: ./static/js/options/helpers/usePopoverMaker.js\nvar usePopoverMaker = __webpack_require__(9144);\n// EXTERNAL MODULE: ./static/js/options/options/react-outside-click-handler.js\nvar react_outside_click_handler = __webpack_require__(8204);\n// EXTERNAL MODULE: ./node_modules/bezier-easing/src/index.js\nvar src = __webpack_require__(3431);\nvar src_default = /*#__PURE__*/__webpack_require__.n(src);\n;// CONCATENATED MODULE: ./static/js/options/options/ct-color-palettes-picker.js\nfunction ct_color_palettes_picker_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction ct_color_palettes_picker_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ct_color_palettes_picker_ownKeys(Object(source), !0).forEach(function (key) { ct_color_palettes_picker_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ct_color_palettes_picker_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction ct_color_palettes_picker_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\n\n\n\n\n\nconst ColorPalettes = _ref => {\n let {\n option,\n value,\n onChange\n } = _ref;\n const colorPalettesWrapper = (0,external_window_wp_element_.useRef)();\n const [{\n isOpen,\n isTransitioning\n }, setModalState] = (0,external_window_wp_element_.useState)({\n isOpen: false,\n isTransitioning: false\n });\n const {\n styles,\n popoverProps\n } = (0,usePopoverMaker/* default */.Z)({\n ref: colorPalettesWrapper,\n defaultHeight: 430,\n shouldCalculate: isTransitioning || isOpen\n });\n\n const setIsOpen = isOpen => {\n setModalState(state => ct_color_palettes_picker_objectSpread(ct_color_palettes_picker_objectSpread({}, state), {}, {\n isOpen,\n isTransitioning: true\n }));\n };\n\n const stopTransitioning = () => setModalState(state => ct_color_palettes_picker_objectSpread(ct_color_palettes_picker_objectSpread({}, state), {}, {\n isTransitioning: false\n }));\n\n const properValue = ct_color_palettes_picker_objectSpread(ct_color_palettes_picker_objectSpread(ct_color_palettes_picker_objectSpread({}, option.value), Object.keys(value).reduce((all, currentKey) => ct_color_palettes_picker_objectSpread(ct_color_palettes_picker_objectSpread({}, all), value[currentKey] ? {\n [currentKey]: value[currentKey]\n } : {}), {})), option.value.palettes ? {\n palettes: option.value.palettes.map((p, index) => {\n let maybeCurrentlyInValue = value.palettes.find(_ref2 => {\n let {\n id\n } = _ref2;\n return p.id === id;\n });\n let maybeCurrentValue = {};\n\n if (p.id === value.current_palette) {\n Object.keys(p).map(maybeColor => {\n if (maybeColor.indexOf('color') === 0 && value[maybeColor]) {\n maybeCurrentValue[maybeColor] = value[maybeColor];\n }\n });\n }\n\n const result = ct_color_palettes_picker_objectSpread(ct_color_palettes_picker_objectSpread(ct_color_palettes_picker_objectSpread({}, Object.keys(p).reduce((all, currentKey) => ct_color_palettes_picker_objectSpread(ct_color_palettes_picker_objectSpread({}, all), p[currentKey] ? {\n [currentKey]: p[currentKey]\n } : {}), {})), Object.keys(maybeCurrentlyInValue || {}).reduce((all, currentKey) => ct_color_palettes_picker_objectSpread(ct_color_palettes_picker_objectSpread({}, all), maybeCurrentlyInValue[currentKey] ? {\n [currentKey]: maybeCurrentlyInValue[currentKey]\n } : {}), {})), maybeCurrentValue);\n\n return result;\n })\n } : {});\n\n return (0,external_window_wp_element_.createElement)(\"div\", null, (0,external_window_wp_element_.createElement)(react_outside_click_handler[\"default\"], {\n disabled: !isOpen,\n useCapture: false,\n className: \"ct-palettes-preview\",\n additionalRefs: [popoverProps.ref],\n onOutsideClick: () => {\n setIsOpen(false);\n },\n wrapperProps: {\n ref: colorPalettesWrapper,\n onClick: e => {\n e.preventDefault();\n\n if (e.target.closest('.ct-color-picker-modal') || e.target.classList.contains('ct-color-picker-modal')) {\n return;\n }\n\n if (!properValue.palettes) {\n return;\n }\n\n setIsOpen(true);\n }\n }\n }, (0,external_window_wp_element_.createElement)(color_palettes_PalettePreview, {\n onClick: () => {\n if (!properValue.palettes) {\n return;\n }\n\n setIsOpen(true);\n },\n value: properValue,\n onChange: (optionId, optionValue) => {\n onChange(ct_color_palettes_picker_objectSpread(ct_color_palettes_picker_objectSpread(ct_color_palettes_picker_objectSpread({}, properValue), optionValue), properValue.palettes ? {\n palettes: properValue.palettes.map(p => p.id === properValue.current_palette ? ct_color_palettes_picker_objectSpread(ct_color_palettes_picker_objectSpread({}, p), optionValue) : p)\n } : {}));\n }\n })), (isTransitioning || isOpen) && (0,external_window_wp_element_.createPortal)((0,external_window_wp_element_.createElement)(react_spring_web_esm.Transition, {\n items: isOpen,\n onRest: isOpen => {\n stopTransitioning();\n },\n config: {\n duration: 100,\n easing: src_default()(0.25, 0.1, 0.25, 1.0)\n },\n from: isOpen ? {\n transform: 'scale3d(0.95, 0.95, 1)',\n opacity: 0\n } : {\n opacity: 1\n },\n enter: isOpen ? {\n transform: 'scale3d(1, 1, 1)',\n opacity: 1\n } : {\n opacity: 1\n },\n leave: !isOpen ? {\n transform: 'scale3d(0.95, 0.95, 1)',\n opacity: 0\n } : {\n opacity: 1\n }\n }, (style, item) => {\n if (!item) {\n return null;\n }\n\n return (0,external_window_wp_element_.createElement)(color_palettes_ColorPalettesModal, {\n wrapperProps: ct_color_palettes_picker_objectSpread({\n style: ct_color_palettes_picker_objectSpread(ct_color_palettes_picker_objectSpread({}, style), styles)\n }, popoverProps),\n onChange: value => {\n setIsOpen(false);\n onChange(value);\n },\n value: properValue,\n option: option\n });\n }), document.body));\n};\n\n/* harmony default export */ const ct_color_palettes_picker = (ColorPalettes);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"2757.js","mappings":";;;;;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC7EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC9CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./static/js/options/options/color-palettes/PalettePreview.js?83c8","webpack://blocksyOptions/./static/js/options/options/color-palettes/ColorPalettesModal.js?035c","webpack://blocksyOptions/./static/js/options/options/ct-color-palettes-picker.js?ecdf"],"sourcesContent":["function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, useRef, Fragment } from '@wordpress/element';\nimport OptionsPanel from '../../OptionsPanel';\nimport { __, sprintf } from 'ct-i18n';\nimport classnames from 'classnames';\n\nconst PalettePreview = _ref => {\n  let {\n    renderBefore = () => null,\n    value,\n    onChange,\n    onClick,\n    currentPalette = null,\n    className\n  } = _ref;\n\n  if (!currentPalette) {\n    currentPalette = value;\n\n    if (value.palettes) {\n      currentPalette = value.palettes.find(_ref2 => {\n        let {\n          id\n        } = _ref2;\n        return id === value.current_palette;\n      });\n    }\n  }\n\n  return createElement(\"div\", {\n    className: classnames('ct-single-palette', className),\n    onClick: e => {\n      if (e.target.closest('.ct-color-picker-modal') || e.target.classList.contains('ct-color-picker-modal')) {\n        return;\n      }\n\n      onClick();\n    }\n  }, renderBefore(), createElement(OptionsPanel, {\n    hasRevertButton: false,\n    onChange: (optionId, optionValue) => {\n      if (optionId !== 'color') {\n        return;\n      }\n\n      onChange(optionId, Object.keys(optionValue).reduce((finalValue, currentId) => _objectSpread(_objectSpread({}, finalValue), currentId.indexOf('color') === 0 ? {\n        [currentId]: optionValue[currentId]\n      } : {}), {}));\n    },\n    value: {\n      color: currentPalette\n    },\n    options: {\n      color: _objectSpread(_objectSpread({\n        type: 'ct-color-picker',\n        predefined: true,\n        design: 'none',\n        label: false,\n        modalClassName: 'ct-color-palette-modal',\n        value: currentPalette\n      }, onChange ? {} : {\n        skipModal: true\n      }), {}, {\n        pickers: Object.keys(currentPalette).filter(k => k.indexOf('color') === 0).map((key, index) => ({\n          title: sprintf(__('Color %s', 'blocksy'), index + 1),\n          id: key\n        }))\n      })\n    }\n  }));\n};\n\nexport default PalettePreview;","const _excluded = [\"id\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport { Fragment, createElement, Component, useRef, useEffect, useMemo, useCallback, useState } from '@wordpress/element';\nimport classnames from 'classnames';\nimport { __, sprintf } from 'ct-i18n';\nimport { Transition, animated } from '@react-spring/web';\nimport PalettePreview from './PalettePreview';\n\nconst ColorPalettesModal = _ref => {\n  let {\n    option,\n    value,\n    onChange,\n    wrapperProps = {}\n  } = _ref;\n  return createElement(animated.div, _extends({\n    className: \"ct-option-modal ct-palettes-modal\"\n  }, wrapperProps), value.palettes.map((palette, index) => createElement(PalettePreview, {\n    currentPalette: palette,\n    className: value.current_palette === palette.id ? 'ct-active' : '',\n    renderBefore: () => createElement(\"label\", null, sprintf(__('Palette #%s', 'blocksy'), index + 1)),\n    onClick: () => {\n      const {\n        id\n      } = palette,\n            colors = _objectWithoutProperties(palette, _excluded);\n\n      onChange(_objectSpread(_objectSpread({}, value), {}, {\n        current_palette: id\n      }, colors));\n    }\n  })));\n};\n\nexport default ColorPalettesModal;","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, createPortal, useRef, Fragment, useState } from '@wordpress/element';\nimport OptionsPanel from '../OptionsPanel';\nimport { __ } from 'ct-i18n';\nimport cls from 'classnames';\nimport PalettePreview from './color-palettes/PalettePreview';\nimport ColorPalettesModal from './color-palettes/ColorPalettesModal';\nimport usePopoverMaker from '../helpers/usePopoverMaker';\nimport OutsideClickHandler from './react-outside-click-handler';\nimport { Transition } from '@react-spring/web';\nimport bezierEasing from 'bezier-easing';\n\nconst ColorPalettes = _ref => {\n  let {\n    option,\n    value,\n    onChange\n  } = _ref;\n  const colorPalettesWrapper = useRef();\n  const [{\n    isOpen,\n    isTransitioning\n  }, setModalState] = useState({\n    isOpen: false,\n    isTransitioning: false\n  });\n  const {\n    styles,\n    popoverProps\n  } = usePopoverMaker({\n    ref: colorPalettesWrapper,\n    defaultHeight: 430,\n    shouldCalculate: isTransitioning || isOpen\n  });\n\n  const setIsOpen = isOpen => {\n    setModalState(state => _objectSpread(_objectSpread({}, state), {}, {\n      isOpen,\n      isTransitioning: true\n    }));\n  };\n\n  const stopTransitioning = () => setModalState(state => _objectSpread(_objectSpread({}, state), {}, {\n    isTransitioning: false\n  }));\n\n  const properValue = _objectSpread(_objectSpread(_objectSpread({}, option.value), Object.keys(value).reduce((all, currentKey) => _objectSpread(_objectSpread({}, all), value[currentKey] ? {\n    [currentKey]: value[currentKey]\n  } : {}), {})), option.value.palettes ? {\n    palettes: option.value.palettes.map((p, index) => {\n      let maybeCurrentlyInValue = value.palettes.find(_ref2 => {\n        let {\n          id\n        } = _ref2;\n        return p.id === id;\n      });\n      let maybeCurrentValue = {};\n\n      if (p.id === value.current_palette) {\n        Object.keys(p).map(maybeColor => {\n          if (maybeColor.indexOf('color') === 0 && value[maybeColor]) {\n            maybeCurrentValue[maybeColor] = value[maybeColor];\n          }\n        });\n      }\n\n      const result = _objectSpread(_objectSpread(_objectSpread({}, Object.keys(p).reduce((all, currentKey) => _objectSpread(_objectSpread({}, all), p[currentKey] ? {\n        [currentKey]: p[currentKey]\n      } : {}), {})), Object.keys(maybeCurrentlyInValue || {}).reduce((all, currentKey) => _objectSpread(_objectSpread({}, all), maybeCurrentlyInValue[currentKey] ? {\n        [currentKey]: maybeCurrentlyInValue[currentKey]\n      } : {}), {})), maybeCurrentValue);\n\n      return result;\n    })\n  } : {});\n\n  return createElement(\"div\", null, createElement(OutsideClickHandler, {\n    disabled: !isOpen,\n    useCapture: false,\n    className: \"ct-palettes-preview\",\n    additionalRefs: [popoverProps.ref],\n    onOutsideClick: () => {\n      setIsOpen(false);\n    },\n    wrapperProps: {\n      ref: colorPalettesWrapper,\n      onClick: e => {\n        e.preventDefault();\n\n        if (e.target.closest('.ct-color-picker-modal') || e.target.classList.contains('ct-color-picker-modal')) {\n          return;\n        }\n\n        if (!properValue.palettes) {\n          return;\n        }\n\n        setIsOpen(true);\n      }\n    }\n  }, createElement(PalettePreview, {\n    onClick: () => {\n      if (!properValue.palettes) {\n        return;\n      }\n\n      setIsOpen(true);\n    },\n    value: properValue,\n    onChange: (optionId, optionValue) => {\n      onChange(_objectSpread(_objectSpread(_objectSpread({}, properValue), optionValue), properValue.palettes ? {\n        palettes: properValue.palettes.map(p => p.id === properValue.current_palette ? _objectSpread(_objectSpread({}, p), optionValue) : p)\n      } : {}));\n    }\n  })), (isTransitioning || isOpen) && createPortal(createElement(Transition, {\n    items: isOpen,\n    onRest: isOpen => {\n      stopTransitioning();\n    },\n    config: {\n      duration: 100,\n      easing: bezierEasing(0.25, 0.1, 0.25, 1.0)\n    },\n    from: isOpen ? {\n      transform: 'scale3d(0.95, 0.95, 1)',\n      opacity: 0\n    } : {\n      opacity: 1\n    },\n    enter: isOpen ? {\n      transform: 'scale3d(1, 1, 1)',\n      opacity: 1\n    } : {\n      opacity: 1\n    },\n    leave: !isOpen ? {\n      transform: 'scale3d(0.95, 0.95, 1)',\n      opacity: 0\n    } : {\n      opacity: 1\n    }\n  }, (style, item) => {\n    if (!item) {\n      return null;\n    }\n\n    return createElement(ColorPalettesModal, {\n      wrapperProps: _objectSpread({\n        style: _objectSpread(_objectSpread({}, style), styles)\n      }, popoverProps),\n      onChange: value => {\n        setIsOpen(false);\n        onChange(value);\n      },\n      value: properValue,\n      option: option\n    });\n  }), document.body));\n};\n\nexport default ColorPalettes;"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///2757\n")},2495:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _color_picker_single_picker__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(694);\n/* harmony import */ var _react_outside_click_handler__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(8204);\n/* harmony import */ var match_conditions__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7465);\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\nconst ColorPicker = _ref => {\n let {\n option,\n values,\n value,\n onChange\n } = _ref;\n const [{\n isPicking,\n isTransitioning\n }, setState] = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useState)({\n isPicking: null,\n isTransitioning: null\n });\n const containerRef = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useRef)();\n const modalRef = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useRef)();\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_react_outside_click_handler__WEBPACK_IMPORTED_MODULE_2__["default"], {\n useCapture: false,\n display: "inline-block",\n disabled: !isPicking,\n wrapperProps: {\n ref: containerRef\n },\n className: "ct-color-picker-container",\n additionalRefs: [modalRef],\n onOutsideClick: () => {\n setState(_ref2 => {\n let {\n isPicking\n } = _ref2;\n return {\n isPicking: null,\n isTransitioning: isPicking\n };\n });\n }\n }, option.pickers.filter(picker => !picker.condition || (0,match_conditions__WEBPACK_IMPORTED_MODULE_3__/* .matchValuesWithCondition */ .Nj)((0,match_conditions__WEBPACK_IMPORTED_MODULE_3__/* .normalizeCondition */ .KY)(picker.condition), picker.condition_source === \'global\' ? Object.keys(picker.condition).reduce((current, key) => _objectSpread(_objectSpread({}, current), {}, {\n [key]: wp.customize(key)()\n }), {}) : values)).map(picker => (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_color_picker_single_picker__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z, {\n containerRef: containerRef,\n picker: picker,\n key: picker.id,\n option: option,\n isPicking: isPicking,\n modalRef: modalRef,\n isTransitioning: isTransitioning,\n values: values,\n onPickingChange: isPicking => setState({\n isTransitioning: picker.id,\n isPicking\n }),\n stopTransitioning: () => setState(state => _objectSpread(_objectSpread({}, state), {}, {\n isTransitioning: false\n })),\n onChange: newPicker => onChange(_objectSpread(_objectSpread({}, value), {}, {\n [picker.id]: newPicker\n })),\n value: value[picker.id] || option.value[picker.id]\n })));\n};\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (ColorPicker);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMjQ5NS5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vc3RhdGljL2pzL29wdGlvbnMvb3B0aW9ucy9jdC1jb2xvci1waWNrZXIuanM/NDIwYiJdLCJzb3VyY2VzQ29udGVudCI6WyJmdW5jdGlvbiBvd25LZXlzKG9iamVjdCwgZW51bWVyYWJsZU9ubHkpIHsgdmFyIGtleXMgPSBPYmplY3Qua2V5cyhvYmplY3QpOyBpZiAoT2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9scykgeyB2YXIgc3ltYm9scyA9IE9iamVjdC5nZXRPd25Qcm9wZXJ0eVN5bWJvbHMob2JqZWN0KTsgZW51bWVyYWJsZU9ubHkgJiYgKHN5bWJvbHMgPSBzeW1ib2xzLmZpbHRlcihmdW5jdGlvbiAoc3ltKSB7IHJldHVybiBPYmplY3QuZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9yKG9iamVjdCwgc3ltKS5lbnVtZXJhYmxlOyB9KSksIGtleXMucHVzaC5hcHBseShrZXlzLCBzeW1ib2xzKTsgfSByZXR1cm4ga2V5czsgfVxuXG5mdW5jdGlvbiBfb2JqZWN0U3ByZWFkKHRhcmdldCkgeyBmb3IgKHZhciBpID0gMTsgaSA8IGFyZ3VtZW50cy5sZW5ndGg7IGkrKykgeyB2YXIgc291cmNlID0gbnVsbCAhPSBhcmd1bWVudHNbaV0gPyBhcmd1bWVudHNbaV0gOiB7fTsgaSAlIDIgPyBvd25LZXlzKE9iamVjdChzb3VyY2UpLCAhMCkuZm9yRWFjaChmdW5jdGlvbiAoa2V5KSB7IF9kZWZpbmVQcm9wZXJ0eSh0YXJnZXQsIGtleSwgc291cmNlW2tleV0pOyB9KSA6IE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3JzID8gT2JqZWN0LmRlZmluZVByb3BlcnRpZXModGFyZ2V0LCBPYmplY3QuZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9ycyhzb3VyY2UpKSA6IG93bktleXMoT2JqZWN0KHNvdXJjZSkpLmZvckVhY2goZnVuY3Rpb24gKGtleSkgeyBPYmplY3QuZGVmaW5lUHJvcGVydHkodGFyZ2V0LCBrZXksIE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3Ioc291cmNlLCBrZXkpKTsgfSk7IH0gcmV0dXJuIHRhcmdldDsgfVxuXG5mdW5jdGlvbiBfZGVmaW5lUHJvcGVydHkob2JqLCBrZXksIHZhbHVlKSB7IGlmIChrZXkgaW4gb2JqKSB7IE9iamVjdC5kZWZpbmVQcm9wZXJ0eShvYmosIGtleSwgeyB2YWx1ZTogdmFsdWUsIGVudW1lcmFibGU6IHRydWUsIGNvbmZpZ3VyYWJsZTogdHJ1ZSwgd3JpdGFibGU6IHRydWUgfSk7IH0gZWxzZSB7IG9ialtrZXldID0gdmFsdWU7IH0gcmV0dXJuIG9iajsgfVxuXG5pbXBvcnQgeyBjcmVhdGVFbGVtZW50LCBDb21wb25lbnQsIEZyYWdtZW50LCBjcmVhdGVDb250ZXh0LCB1c2VSZWYsIHVzZUNvbnRleHQsIHVzZVN0YXRlIH0gZnJvbSAnQHdvcmRwcmVzcy9lbGVtZW50JztcbmltcG9ydCBTaW5nbGVQaWNrZXIgZnJvbSAnLi9jb2xvci1waWNrZXIvc2luZ2xlLXBpY2tlcic7XG5pbXBvcnQgT3V0c2lkZUNsaWNrSGFuZGxlciBmcm9tICcuL3JlYWN0LW91dHNpZGUtY2xpY2staGFuZGxlcic7XG5pbXBvcnQgeyBub3JtYWxpemVDb25kaXRpb24sIG1hdGNoVmFsdWVzV2l0aENvbmRpdGlvbiB9IGZyb20gJ21hdGNoLWNvbmRpdGlvbnMnO1xuXG5jb25zdCBDb2xvclBpY2tlciA9IF9yZWYgPT4ge1xuICBsZXQge1xuICAgIG9wdGlvbixcbiAgICB2YWx1ZXMsXG4gICAgdmFsdWUsXG4gICAgb25DaGFuZ2VcbiAgfSA9IF9yZWY7XG4gIGNvbnN0IFt7XG4gICAgaXNQaWNraW5nLFxuICAgIGlzVHJhbnNpdGlvbmluZ1xuICB9LCBzZXRTdGF0ZV0gPSB1c2VTdGF0ZSh7XG4gICAgaXNQaWNraW5nOiBudWxsLFxuICAgIGlzVHJhbnNpdGlvbmluZzogbnVsbFxuICB9KTtcbiAgY29uc3QgY29udGFpbmVyUmVmID0gdXNlUmVmKCk7XG4gIGNvbnN0IG1vZGFsUmVmID0gdXNlUmVmKCk7XG4gIHJldHVybiBjcmVhdGVFbGVtZW50KE91dHNpZGVDbGlja0hhbmRsZXIsIHtcbiAgICB1c2VDYXB0dXJlOiBmYWxzZSxcbiAgICBkaXNwbGF5OiBcImlubGluZS1ibG9ja1wiLFxuICAgIGRpc2FibGVkOiAhaXNQaWNraW5nLFxuICAgIHdyYXBwZXJQcm9wczoge1xuICAgICAgcmVmOiBjb250YWluZXJSZWZcbiAgICB9LFxuICAgIGNsYXNzTmFtZTogXCJjdC1jb2xvci1waWNrZXItY29udGFpbmVyXCIsXG4gICAgYWRkaXRpb25hbFJlZnM6IFttb2RhbFJlZl0sXG4gICAgb25PdXRzaWRlQ2xpY2s6ICgpID0+IHtcbiAgICAgIHNldFN0YXRlKF9yZWYyID0+IHtcbiAgICAgICAgbGV0IHtcbiAgICAgICAgICBpc1BpY2tpbmdcbiAgICAgICAgfSA9IF9yZWYyO1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIGlzUGlja2luZzogbnVsbCxcbiAgICAgICAgICBpc1RyYW5zaXRpb25pbmc6IGlzUGlja2luZ1xuICAgICAgICB9O1xuICAgICAgfSk7XG4gICAgfVxuICB9LCBvcHRpb24ucGlja2Vycy5maWx0ZXIocGlja2VyID0+ICFwaWNrZXIuY29uZGl0aW9uIHx8IG1hdGNoVmFsdWVzV2l0aENvbmRpdGlvbihub3JtYWxpemVDb25kaXRpb24ocGlja2VyLmNvbmRpdGlvbiksIHBpY2tlci5jb25kaXRpb25fc291cmNlID09PSAnZ2xvYmFsJyA/IE9iamVjdC5rZXlzKHBpY2tlci5jb25kaXRpb24pLnJlZHVjZSgoY3VycmVudCwga2V5KSA9PiBfb2JqZWN0U3ByZWFkKF9vYmplY3RTcHJlYWQoe30sIGN1cnJlbnQpLCB7fSwge1xuICAgIFtrZXldOiB3cC5jdXN0b21pemUoa2V5KSgpXG4gIH0pLCB7fSkgOiB2YWx1ZXMpKS5tYXAocGlja2VyID0+IGNyZWF0ZUVsZW1lbnQoU2luZ2xlUGlja2VyLCB7XG4gICAgY29udGFpbmVyUmVmOiBjb250YWluZXJSZWYsXG4gICAgcGlja2VyOiBwaWNrZXIsXG4gICAga2V5OiBwaWNrZXIuaWQsXG4gICAgb3B0aW9uOiBvcHRpb24sXG4gICAgaXNQaWNraW5nOiBpc1BpY2tpbmcsXG4gICAgbW9kYWxSZWY6IG1vZGFsUmVmLFxuICAgIGlzVHJhbnNpdGlvbmluZzogaXNUcmFuc2l0aW9uaW5nLFxuICAgIHZhbHVlczogdmFsdWVzLFxuICAgIG9uUGlja2luZ0NoYW5nZTogaXNQaWNraW5nID0+IHNldFN0YXRlKHtcbiAgICAgIGlzVHJhbnNpdGlvbmluZzogcGlja2VyLmlkLFxuICAgICAgaXNQaWNraW5nXG4gICAgfSksXG4gICAgc3RvcFRyYW5zaXRpb25pbmc6ICgpID0+IHNldFN0YXRlKHN0YXRlID0+IF9vYmplY3RTcHJlYWQoX29iamVjdFNwcmVhZCh7fSwgc3RhdGUpLCB7fSwge1xuICAgICAgaXNUcmFuc2l0aW9uaW5nOiBmYWxzZVxuICAgIH0pKSxcbiAgICBvbkNoYW5nZTogbmV3UGlja2VyID0+IG9uQ2hhbmdlKF9vYmplY3RTcHJlYWQoX29iamVjdFNwcmVhZCh7fSwgdmFsdWUpLCB7fSwge1xuICAgICAgW3BpY2tlci5pZF06IG5ld1BpY2tlclxuICAgIH0pKSxcbiAgICB2YWx1ZTogdmFsdWVbcGlja2VyLmlkXSB8fCBvcHRpb24udmFsdWVbcGlja2VyLmlkXVxuICB9KSkpO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgQ29sb3JQaWNrZXI7Il0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///2495\n')},9158:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _customizer_components_Overlay__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7136);\n/* harmony import */ var ct_i18n__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(5652);\n/* harmony import */ var ct_i18n__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(ct_i18n__WEBPACK_IMPORTED_MODULE_2__);\n\n\n\n\nconst CustomizerResetOptions = _ref => {\n let {\n value,\n option,\n onChange\n } = _ref;\n const [isShowing, setIsShowing] = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useState)(false);\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("button", {\n className: "button",\n style: {\n width: \'100%\'\n },\n onClick: e => {\n e.preventDefault();\n setIsShowing(true);\n }\n }, (0,ct_i18n__WEBPACK_IMPORTED_MODULE_2__.__)(\'Reset Options\', \'blocksy\')), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_customizer_components_Overlay__WEBPACK_IMPORTED_MODULE_1__/* ["default"] */ .Z, {\n items: isShowing,\n className: "ct-admin-modal ct-reset-options",\n onDismiss: () => setIsShowing(false),\n render: () => (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", {\n className: "ct-modal-content"\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("h2", {\n className: "ct-modal-title"\n }, (0,ct_i18n__WEBPACK_IMPORTED_MODULE_2__.__)(\'Reset Settings\', \'blocksy\')), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("p", null, (0,ct_i18n__WEBPACK_IMPORTED_MODULE_2__.__)(\'You are about to reset all settings to their default values, are you sure you want to continue?\', \'blocksy\')), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", {\n className: "ct-modal-actions has-divider",\n "data-buttons": "2"\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("button", {\n onClick: e => {\n e.preventDefault();\n e.stopPropagation();\n setIsShowing(false);\n },\n className: "button"\n }, (0,ct_i18n__WEBPACK_IMPORTED_MODULE_2__.__)(\'Cancel\', \'blocksy\')), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("button", {\n className: "button button-primary",\n onClick: e => {\n e.preventDefault();\n jQuery.post(ajaxurl, {\n wp_customize: \'on\',\n action: \'ct_customizer_reset\',\n nonce: ct_customizer_localizations.customizer_reset_none\n }, () => {\n wp.customize.state(\'saved\').set(true);\n location.reload();\n });\n }\n }, (0,ct_i18n__WEBPACK_IMPORTED_MODULE_2__.__)(\'Confirm\', \'blocksy\'))))\n }));\n};\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (CustomizerResetOptions);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiOTE1OC5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9zdGF0aWMvanMvb3B0aW9ucy9vcHRpb25zL2N0LWN1c3RvbWl6ZXItcmVzZXQtb3B0aW9ucy5qcz9kN2IyIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEZyYWdtZW50LCBjcmVhdGVFbGVtZW50LCB1c2VTdGF0ZSB9IGZyb20gJ0B3b3JkcHJlc3MvZWxlbWVudCc7XG5pbXBvcnQgT3ZlcmxheSBmcm9tICcuLi8uLi9jdXN0b21pemVyL2NvbXBvbmVudHMvT3ZlcmxheSc7XG5pbXBvcnQgeyBfXyB9IGZyb20gJ2N0LWkxOG4nO1xuXG5jb25zdCBDdXN0b21pemVyUmVzZXRPcHRpb25zID0gX3JlZiA9PiB7XG4gIGxldCB7XG4gICAgdmFsdWUsXG4gICAgb3B0aW9uLFxuICAgIG9uQ2hhbmdlXG4gIH0gPSBfcmVmO1xuICBjb25zdCBbaXNTaG93aW5nLCBzZXRJc1Nob3dpbmddID0gdXNlU3RhdGUoZmFsc2UpO1xuICByZXR1cm4gY3JlYXRlRWxlbWVudChGcmFnbWVudCwgbnVsbCwgY3JlYXRlRWxlbWVudChcImJ1dHRvblwiLCB7XG4gICAgY2xhc3NOYW1lOiBcImJ1dHRvblwiLFxuICAgIHN0eWxlOiB7XG4gICAgICB3aWR0aDogJzEwMCUnXG4gICAgfSxcbiAgICBvbkNsaWNrOiBlID0+IHtcbiAgICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICAgIHNldElzU2hvd2luZyh0cnVlKTtcbiAgICB9XG4gIH0sIF9fKCdSZXNldCBPcHRpb25zJywgJ2Jsb2Nrc3knKSksIGNyZWF0ZUVsZW1lbnQoT3ZlcmxheSwge1xuICAgIGl0ZW1zOiBpc1Nob3dpbmcsXG4gICAgY2xhc3NOYW1lOiBcImN0LWFkbWluLW1vZGFsIGN0LXJlc2V0LW9wdGlvbnNcIixcbiAgICBvbkRpc21pc3M6ICgpID0+IHNldElzU2hvd2luZyhmYWxzZSksXG4gICAgcmVuZGVyOiAoKSA9PiBjcmVhdGVFbGVtZW50KFwiZGl2XCIsIHtcbiAgICAgIGNsYXNzTmFtZTogXCJjdC1tb2RhbC1jb250ZW50XCJcbiAgICB9LCBjcmVhdGVFbGVtZW50KFwiaDJcIiwge1xuICAgICAgY2xhc3NOYW1lOiBcImN0LW1vZGFsLXRpdGxlXCJcbiAgICB9LCBfXygnUmVzZXQgU2V0dGluZ3MnLCAnYmxvY2tzeScpKSwgY3JlYXRlRWxlbWVudChcInBcIiwgbnVsbCwgX18oJ1lvdSBhcmUgYWJvdXQgdG8gcmVzZXQgYWxsIHNldHRpbmdzIHRvIHRoZWlyIGRlZmF1bHQgdmFsdWVzLCBhcmUgeW91IHN1cmUgeW91IHdhbnQgdG8gY29udGludWU/JywgJ2Jsb2Nrc3knKSksIGNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwge1xuICAgICAgY2xhc3NOYW1lOiBcImN0LW1vZGFsLWFjdGlvbnMgaGFzLWRpdmlkZXJcIixcbiAgICAgIFwiZGF0YS1idXR0b25zXCI6IFwiMlwiXG4gICAgfSwgY3JlYXRlRWxlbWVudChcImJ1dHRvblwiLCB7XG4gICAgICBvbkNsaWNrOiBlID0+IHtcbiAgICAgICAgZS5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICBlLnN0b3BQcm9wYWdhdGlvbigpO1xuICAgICAgICBzZXRJc1Nob3dpbmcoZmFsc2UpO1xuICAgICAgfSxcbiAgICAgIGNsYXNzTmFtZTogXCJidXR0b25cIlxuICAgIH0sIF9fKCdDYW5jZWwnLCAnYmxvY2tzeScpKSwgY3JlYXRlRWxlbWVudChcImJ1dHRvblwiLCB7XG4gICAgICBjbGFzc05hbWU6IFwiYnV0dG9uIGJ1dHRvbi1wcmltYXJ5XCIsXG4gICAgICBvbkNsaWNrOiBlID0+IHtcbiAgICAgICAgZS5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICBqUXVlcnkucG9zdChhamF4dXJsLCB7XG4gICAgICAgICAgd3BfY3VzdG9taXplOiAnb24nLFxuICAgICAgICAgIGFjdGlvbjogJ2N0X2N1c3RvbWl6ZXJfcmVzZXQnLFxuICAgICAgICAgIG5vbmNlOiBjdF9jdXN0b21pemVyX2xvY2FsaXphdGlvbnMuY3VzdG9taXplcl9yZXNldF9ub25lXG4gICAgICAgIH0sICgpID0+IHtcbiAgICAgICAgICB3cC5jdXN0b21pemUuc3RhdGUoJ3NhdmVkJykuc2V0KHRydWUpO1xuICAgICAgICAgIGxvY2F0aW9uLnJlbG9hZCgpO1xuICAgICAgICB9KTtcbiAgICAgIH1cbiAgICB9LCBfXygnQ29uZmlybScsICdibG9ja3N5JykpKSlcbiAgfSkpO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgQ3VzdG9taXplclJlc2V0T3B0aW9uczsiXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///9158\n')},8163:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(4184);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\nconst _excluded = ["class"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\n\n\n\nconst Divider = _ref => {\n let {\n option: {\n attr: {\n class: className\n } = {}\n }\n } = _ref,\n attr = _objectWithoutProperties(_ref.option.attr, _excluded);\n\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", _extends({\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()(\'ct-divider\', className)\n }, attr));\n};\n\nDivider.renderingConfig = {\n design: \'none\'\n};\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Divider);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiODE2My5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vc3RhdGljL2pzL29wdGlvbnMvb3B0aW9ucy9jdC1kaXZpZGVyLmpzPzk1MDAiXSwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgX2V4Y2x1ZGVkID0gW1wiY2xhc3NcIl07XG5cbmZ1bmN0aW9uIF9leHRlbmRzKCkgeyBfZXh0ZW5kcyA9IE9iamVjdC5hc3NpZ24gPyBPYmplY3QuYXNzaWduLmJpbmQoKSA6IGZ1bmN0aW9uICh0YXJnZXQpIHsgZm9yICh2YXIgaSA9IDE7IGkgPCBhcmd1bWVudHMubGVuZ3RoOyBpKyspIHsgdmFyIHNvdXJjZSA9IGFyZ3VtZW50c1tpXTsgZm9yICh2YXIga2V5IGluIHNvdXJjZSkgeyBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKHNvdXJjZSwga2V5KSkgeyB0YXJnZXRba2V5XSA9IHNvdXJjZVtrZXldOyB9IH0gfSByZXR1cm4gdGFyZ2V0OyB9OyByZXR1cm4gX2V4dGVuZHMuYXBwbHkodGhpcywgYXJndW1lbnRzKTsgfVxuXG5mdW5jdGlvbiBfb2JqZWN0V2l0aG91dFByb3BlcnRpZXMoc291cmNlLCBleGNsdWRlZCkgeyBpZiAoc291cmNlID09IG51bGwpIHJldHVybiB7fTsgdmFyIHRhcmdldCA9IF9vYmplY3RXaXRob3V0UHJvcGVydGllc0xvb3NlKHNvdXJjZSwgZXhjbHVkZWQpOyB2YXIga2V5LCBpOyBpZiAoT2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9scykgeyB2YXIgc291cmNlU3ltYm9sS2V5cyA9IE9iamVjdC5nZXRPd25Qcm9wZXJ0eVN5bWJvbHMoc291cmNlKTsgZm9yIChpID0gMDsgaSA8IHNvdXJjZVN5bWJvbEtleXMubGVuZ3RoOyBpKyspIHsga2V5ID0gc291cmNlU3ltYm9sS2V5c1tpXTsgaWYgKGV4Y2x1ZGVkLmluZGV4T2Yoa2V5KSA+PSAwKSBjb250aW51ZTsgaWYgKCFPYmplY3QucHJvdG90eXBlLnByb3BlcnR5SXNFbnVtZXJhYmxlLmNhbGwoc291cmNlLCBrZXkpKSBjb250aW51ZTsgdGFyZ2V0W2tleV0gPSBzb3VyY2Vba2V5XTsgfSB9IHJldHVybiB0YXJnZXQ7IH1cblxuZnVuY3Rpb24gX29iamVjdFdpdGhvdXRQcm9wZXJ0aWVzTG9vc2Uoc291cmNlLCBleGNsdWRlZCkgeyBpZiAoc291cmNlID09IG51bGwpIHJldHVybiB7fTsgdmFyIHRhcmdldCA9IHt9OyB2YXIgc291cmNlS2V5cyA9IE9iamVjdC5rZXlzKHNvdXJjZSk7IHZhciBrZXksIGk7IGZvciAoaSA9IDA7IGkgPCBzb3VyY2VLZXlzLmxlbmd0aDsgaSsrKSB7IGtleSA9IHNvdXJjZUtleXNbaV07IGlmIChleGNsdWRlZC5pbmRleE9mKGtleSkgPj0gMCkgY29udGludWU7IHRhcmdldFtrZXldID0gc291cmNlW2tleV07IH0gcmV0dXJuIHRhcmdldDsgfVxuXG5pbXBvcnQgeyBGcmFnbWVudCwgY3JlYXRlRWxlbWVudCwgQ29tcG9uZW50IH0gZnJvbSAnQHdvcmRwcmVzcy9lbGVtZW50JztcbmltcG9ydCBjbGFzc25hbWVzIGZyb20gJ2NsYXNzbmFtZXMnO1xuXG5jb25zdCBEaXZpZGVyID0gX3JlZiA9PiB7XG4gIGxldCB7XG4gICAgb3B0aW9uOiB7XG4gICAgICBhdHRyOiB7XG4gICAgICAgIGNsYXNzOiBjbGFzc05hbWVcbiAgICAgIH0gPSB7fVxuICAgIH1cbiAgfSA9IF9yZWYsXG4gICAgICBhdHRyID0gX29iamVjdFdpdGhvdXRQcm9wZXJ0aWVzKF9yZWYub3B0aW9uLmF0dHIsIF9leGNsdWRlZCk7XG5cbiAgcmV0dXJuIGNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwgX2V4dGVuZHMoe1xuICAgIGNsYXNzTmFtZTogY2xhc3NuYW1lcygnY3QtZGl2aWRlcicsIGNsYXNzTmFtZSlcbiAgfSwgYXR0cikpO1xufTtcblxuRGl2aWRlci5yZW5kZXJpbmdDb25maWcgPSB7XG4gIGRlc2lnbjogJ25vbmUnXG59O1xuZXhwb3J0IGRlZmF1bHQgRGl2aWRlcjsiXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///8163\n')},5821:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("// ESM COMPAT FLAG\n__webpack_require__.r(__webpack_exports__);\n\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n \"DragDropContext\": () => (/* binding */ DragDropContext),\n \"default\": () => (/* binding */ ct_footer_builder),\n \"fetchCurrentFooter\": () => (/* binding */ fetchCurrentFooter)\n});\n\n// EXTERNAL MODULE: external \"window.wp.element\"\nvar external_window_wp_element_ = __webpack_require__(1381);\n// EXTERNAL MODULE: external \"window.wp.i18n\"\nvar external_window_wp_i18n_ = __webpack_require__(5652);\n// EXTERNAL MODULE: ./node_modules/classnames/index.js\nvar classnames = __webpack_require__(4184);\nvar classnames_default = /*#__PURE__*/__webpack_require__.n(classnames);\n// EXTERNAL MODULE: ./static/js/customizer/panels-builder/placements/Sortable.js\nvar Sortable = __webpack_require__(7229);\n// EXTERNAL MODULE: ./static/js/options/components/PanelLevel.js + 1 modules\nvar PanelLevel = __webpack_require__(956);\n// EXTERNAL MODULE: ./static/js/customizer/panels-builder/placements/helpers.js\nvar helpers = __webpack_require__(8382);\n;// CONCATENATED MODULE: ./static/js/customizer/panels-builder/columns/DraggableItems.js\nconst _excluded = [\"items\", \"draggableId\", \"hasPointers\", \"className\", \"tagName\", \"direction\", \"group\", \"options\", \"propsForItem\", \"panelType\", \"displayWrapper\"];\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\n\n\n\n\n\n\n\nconst shallowCompare = (prev, next) => {\n for (let key in next) {\n if (next[key] !== prev[key]) return false;\n }\n\n return true;\n};\n\nfunction memo(Component) {\n let areEqual = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : shallowCompare;\n let prevProps = {};\n let prevResult;\n return nextProps => {\n if (prevResult !== undefined && areEqual(prevProps, nextProps)) {\n return prevResult;\n }\n\n prevProps = nextProps;\n prevResult = createElement(Component, Object.assign({}, nextProps));\n return prevResult;\n };\n}\n\nconst DraggableItem = _ref => {\n let {\n item,\n index,\n panelType,\n onRemove,\n renderItem,\n onClick,\n className\n } = _ref;\n const itemData = ct_customizer_localizations.header_builder_data[panelType].find(_ref2 => {\n let {\n id\n } = _ref2;\n return id === (0,helpers/* getOriginalId */.t_)(item);\n });\n const {\n builderValue\n } = (0,external_window_wp_element_.useContext)(DragDropContext);\n\n if (renderItem) {\n return renderItem({\n item,\n itemData,\n index\n });\n }\n /**\n * Dynamic items have a : in their ID\n */\n\n\n const allDynamicItems = Object.keys(builderValue.items).filter(id => id.indexOf((0,helpers/* customItemsSeparator */.SU)()) > -1);\n const allClonesAndOriginal = [(0,helpers/* getOriginalId */.t_)(item), ...allDynamicItems.filter(id => (0,helpers/* getOriginalId */.t_)(id) === (0,helpers/* getOriginalId */.t_)(item))];\n return (0,external_window_wp_element_.createElement)(\"div\", {\n \"data-id\": item,\n className: classnames_default()('ct-builder-item', className, {// 'ct-is-dragging': snapshot.isDragging\n }),\n onClick: onClick\n }, itemData && itemData.config ? allClonesAndOriginal.length > 1 ? `${itemData.config.name} ${allClonesAndOriginal.indexOf(item) + 1}` : itemData.config.name : item, (0,external_window_wp_element_.createElement)(\"button\", {\n className: \"ct-btn-remove\",\n onClick: e => {\n e.preventDefault();\n e.stopPropagation();\n onRemove();\n }\n }));\n};\n\nconst DraggableItems = _ref3 => {\n let {\n items,\n draggableId,\n hasPointers = true,\n className,\n tagName = 'div',\n direction = 'horizontal',\n group = 'header_sortables',\n options = {},\n propsForItem = item => ({}),\n panelType = 'footer',\n displayWrapper = true\n } = _ref3,\n props = _objectWithoutProperties(_ref3, _excluded);\n\n const {\n isDragging,\n setIsDragging,\n onChange,\n setList\n } = (0,external_window_wp_element_.useContext)(DragDropContext);\n const {\n panelsHelpers\n } = (0,external_window_wp_element_.useContext)(PanelLevel/* PanelContext */.Q);\n const itemsOutput = items.map((item, index) => (0,external_window_wp_element_.createElement)(DraggableItem, _extends({\n key: item,\n index: index,\n panelType: panelType,\n item: item,\n className: panelsHelpers.isOpenFor(`builder_panel_${item}`) ? 'ct-customizing' : '',\n onClick: e => {\n e.stopPropagation();\n e.preventDefault();\n panelsHelpers.open(`builder_panel_${item}`);\n },\n onRemove: () => {\n panelsHelpers.close();\n setList({\n [draggableId]: items.filter(id => id !== item)\n });\n }\n }, propsForItem(item))));\n\n if (!displayWrapper) {\n return itemsOutput;\n }\n\n return (0,external_window_wp_element_.createElement)(Sortable/* default */.Z, _extends({\n options: _objectSpread({\n delay: 0,\n group,\n fallbackOnBody: true,\n forceFallback: true,\n fallbackTolerance: 5,\n filter: '.ct-pointer',\n direction: direction,\n touchStartThreshold: 5,\n onStart: event => {\n setIsDragging(event.item.dataset.id);\n document.body.classList.add('ct-builder-dragging');\n\n if (event.from && group && group.pull !== 'clone') {\n event.to.classList.add('ct-is-over');\n }\n },\n onEnd: () => {\n setIsDragging(false);\n document.body.classList.remove('ct-builder-dragging');\n [...document.querySelectorAll('.ct-panel-builder .ct-is-over')].map(el => el.classList.remove('ct-is-over'));\n },\n onMove: (event, originalEvent) => {\n if (event.from.closest('#ct-option-header-builder-items')) {\n Promise.resolve().then(() => [...event.from.querySelectorAll(`[data-id=\"${event.dragged.dataset.id}\"]`)].map(el => {\n el.classList.remove('ct-builder-item');\n el.classList.add('ct-item-in-builder');\n }));\n }\n\n if (event.to) {\n if (event.to.children && Array.from(event.to.children).filter(e => e.dataset.id !== '__pointer__' && e.dataset.id !== '__filler__').length > 0) {\n return false;\n }\n\n ;\n [...document.querySelectorAll('.ct-panel-builder .ct-is-over')].map(el => el.classList.remove('ct-is-over'));\n event.to.classList.add('ct-is-over');\n }\n }\n }, options),\n onChange: (order, sortable, evt) => {\n if (draggableId === 'available-items') {\n return;\n }\n\n onChange({\n id: draggableId,\n value: order.filter(i => i !== '__pointer__' && i !== '__filler__')\n });\n },\n tag: tagName,\n className: classnames_default()('ct-builder-items', className)\n }, props, {\n \"data-id\": draggableId\n }), draggableId !== 'available-items' && isDragging && (0,external_window_wp_element_.createElement)(\"div\", {\n \"data-id\": \"__filler__\",\n className: \"ct-filler\"\n }), hasPointers && isDragging && (0,external_window_wp_element_.createElement)(\"div\", {\n \"data-id\": \"__pointer__\",\n className: \"ct-pointer\"\n }), itemsOutput);\n};\n\n/* harmony default export */ const columns_DraggableItems = (DraggableItems);\n;// CONCATENATED MODULE: ./static/js/customizer/panels-builder/columns/ColumnsBuilder.js\n\n\n\n\n\n\nconst Bar = _ref => {\n let {\n bar,\n builderValue,\n direction = 'horizontal'\n } = _ref;\n const {\n panelsHelpers\n } = (0,external_window_wp_element_.useContext)(PanelLevel/* PanelContext */.Q);\n const maybeValues = builderValue.items[bar.id];\n const allItems = ct_customizer_localizations.header_builder_data.footer;\n const primaryItem = allItems.find(_ref2 => {\n let {\n id\n } = _ref2;\n return id === bar.id;\n });\n const values = maybeValues ? maybeValues.values : {};\n let columns = 'initial';\n\n if (bar.columns.length === 2) {\n columns = values['2_columns_layout'] || {\n desktop: 'repeat(2, 1fr)',\n tablet: 'initial',\n mobile: 'initial'\n };\n }\n\n if (bar.columns.length === 3) {\n columns = values['3_columns_layout'] || {\n desktop: 'repeat(3, 1fr)',\n tablet: 'initial',\n mobile: 'initial'\n };\n }\n\n if (bar.columns.length === 4) {\n columns = values['4_columns_layout'] || {\n desktop: 'repeat(4, 1fr)',\n tablet: 'initial',\n mobile: 'initial'\n };\n }\n\n if (bar.columns.length === 5) {\n columns = values['5_columns_layout'] || {\n desktop: 'repeat(5, 1fr)',\n tablet: 'initial',\n mobile: 'initial'\n };\n }\n\n if (bar.columns.length === 6) {\n columns = values['6_columns_layout'] || {\n desktop: 'repeat(6, 1fr)',\n tablet: 'initial',\n mobile: 'initial'\n };\n }\n\n if (columns && columns.desktop) {\n columns = columns.desktop;\n }\n\n return (0,external_window_wp_element_.createElement)(\"li\", {\n className: \"builder-row\"\n }, (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-row-actions\",\n onClick: () => panelsHelpers.open(`builder_panel_${bar.id}`)\n }, {\n 'top-row': (0,external_window_wp_i18n_.__)('Top Row', 'blocksy'),\n 'middle-row': (0,external_window_wp_i18n_.__)('Middle Row', 'blocksy'),\n 'bottom-row': (0,external_window_wp_i18n_.__)('Bottom Row', 'blocksy')\n }[bar.id]), (0,external_window_wp_element_.createElement)(\"ul\", {\n className: \"row-inner\",\n style: {\n '--gridTemplateColummns': columns\n }\n }, bar.columns.map((column, index) => (0,external_window_wp_element_.createElement)(\"li\", {\n className: \"builder-column\",\n key: index\n }, (0,external_window_wp_element_.createElement)(columns_DraggableItems, {\n draggableId: `${bar.id}:${index}`,\n items: column\n })))));\n};\n\nconst ColumnsBuilder_shallowCompare = (prev, next) => {\n for (let key in next) {\n if (next[key] !== prev[key]) return false;\n }\n\n return true;\n};\n\nfunction ColumnsBuilder_memo(Component) {\n let areEqual = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ColumnsBuilder_shallowCompare;\n let prevProps = {};\n let prevResult;\n return nextProps => {\n if (prevResult !== undefined && areEqual(prevProps, nextProps)) {\n return prevResult;\n }\n\n prevProps = nextProps;\n prevResult = (0,external_window_wp_element_.createElement)(Component, Object.assign({}, nextProps));\n return prevResult;\n };\n}\nconst ColumnsBuilder = ColumnsBuilder_memo(_ref3 => {\n let {\n builderValue\n } = _ref3;\n return (0,external_window_wp_element_.createElement)(\"div\", {\n className: classnames_default()('placements-builder')\n }, (0,external_window_wp_element_.createElement)(\"ul\", {\n className: \"horizontal-rows\"\n }, ['top-row', 'middle-row', 'bottom-row'].map(bar => (0,external_window_wp_element_.createElement)(Bar, {\n builderValue: builderValue,\n bar: builderValue.rows.find(_ref4 => {\n let {\n id\n } = _ref4;\n return id === bar;\n }),\n key: bar\n }))));\n}); // const ColumnsBuilder = () => null\n\n/* harmony default export */ const columns_ColumnsBuilder = (ColumnsBuilder);\n// EXTERNAL MODULE: ./static/js/options/options/ct-panel.js\nvar ct_panel = __webpack_require__(3731);\n// EXTERNAL MODULE: ./static/js/options/helpers/get-value-from-input.js\nvar get_value_from_input = __webpack_require__(7069);\n// EXTERNAL MODULE: ./static/js/options/OptionsPanel.js + 7 modules\nvar OptionsPanel = __webpack_require__(7429);\n// EXTERNAL MODULE: external \"window.wp.components\"\nvar external_window_wp_components_ = __webpack_require__(8441);\n;// CONCATENATED MODULE: ./static/js/customizer/panels-builder/columns/builder-sidebar/SecondaryItems.js\nfunction SecondaryItems_extends() { SecondaryItems_extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return SecondaryItems_extends.apply(this, arguments); }\n\n\n\n\n\n\n\n\n\n\nconst SecondaryItems = _ref => {\n let {\n builderValue,\n builderValueDispatch,\n inlinedItemsFromBuilder,\n displayList = true\n } = _ref;\n const {\n panelsState,\n panelsActions,\n currentView,\n isDragging\n } = (0,external_window_wp_element_.useContext)(DragDropContext);\n const inlinedItemsFromAllViewsBuilder = builderValue.rows.reduce((currentItems, _ref2) => {\n let {\n columns\n } = _ref2;\n return [...currentItems, ...(columns || []).reduce((c, items) => [...c, ...items], [])];\n }, []);\n const secondaryItems = ct_customizer_localizations.header_builder_data.secondary_items.footer.filter(_ref3 => {\n let {\n config\n } = _ref3;\n return (// config.devices.indexOf(currentView) > -1 &&\n config.enabled\n );\n });\n const allItems = ct_customizer_localizations.header_builder_data.footer;\n /**\n * Dynamic items have a : in their ID\n */\n\n const allDynamicItems = Object.keys(builderValue.items).filter(id => id.indexOf((0,helpers/* customItemsSeparator */.SU)()) > -1);\n return (0,external_window_wp_element_.createElement)(columns_DraggableItems, {\n options: {\n sort: false,\n filter: '.ct-item-in-builder'\n },\n group: {\n name: 'header_sortables',\n put: false,\n pull: 'clone'\n },\n draggableId: 'available-items',\n items: [...secondaryItems.map(_ref4 => {\n let {\n id\n } = _ref4;\n return id;\n }), ...allDynamicItems].sort((a, b) => {\n const aItemData = ct_customizer_localizations.header_builder_data['footer'].find(_ref5 => {\n let {\n id\n } = _ref5;\n return id === (0,helpers/* getOriginalId */.t_)(a);\n });\n const bItemData = ct_customizer_localizations.header_builder_data['footer'].find(_ref6 => {\n let {\n id\n } = _ref6;\n return id === (0,helpers/* getOriginalId */.t_)(b);\n });\n return aItemData.config.name.localeCompare(bItemData.config.name);\n }),\n hasPointers: false,\n panelType: \"footer\",\n displayWrapper: displayList,\n propsForItem: item => ({\n renderItem: _ref7 => {\n let {\n item,\n itemData,\n index\n } = _ref7;\n const itemOptions = allItems.find(_ref8 => {\n let {\n id\n } = _ref8;\n return id === (0,helpers/* getOriginalId */.t_)(item);\n }).options;\n const allClonesAndOriginal = [(0,helpers/* getOriginalId */.t_)(item), ...allDynamicItems.filter(id => (0,helpers/* getOriginalId */.t_)(id) === (0,helpers/* getOriginalId */.t_)(item))];\n const itemName = allClonesAndOriginal.length > 1 ? `${itemData.config.name} ${allClonesAndOriginal.indexOf(item) + 1}` : itemData.config.name;\n const option = {\n label: itemName,\n 'inner-options': itemOptions\n };\n const itemInBuilder = inlinedItemsFromBuilder.indexOf(item) > -1;\n const id = `builder_panel_${item}`;\n return (0,external_window_wp_element_.createElement)(ct_panel.PanelMetaWrapper, SecondaryItems_extends({\n id: id,\n option: option\n }, panelsActions, {\n getActualOption: _ref9 => {\n let {\n open,\n container\n } = _ref9;\n return (0,external_window_wp_element_.createElement)(external_window_wp_element_.Fragment, null, inlinedItemsFromAllViewsBuilder.indexOf(item) > -1 && (0,external_window_wp_element_.createElement)(ct_panel[\"default\"], {\n id: id,\n getValues: () => {\n let itemValue = builderValue.items[item];\n\n if (itemValue && Object.keys(itemValue.values) > 5) {\n return itemValue.values;\n }\n\n return (0,get_value_from_input/* getValueFromInput */.n6)(itemOptions, itemValue ? itemValue.values : {});\n },\n option: option,\n onChangeFor: (optionId, optionValue) => {\n const currentValue = builderValue.items[item];\n builderValueDispatch({\n type: 'ITEM_VALUE_ON_CHANGE',\n payload: {\n id: item,\n optionId,\n optionValue,\n values: !currentValue || currentValue && Object.keys(currentValue.values).length === 0 ? (0,get_value_from_input/* getValueFromInput */.n6)(itemOptions, {}) : {}\n }\n });\n },\n view: \"simple\"\n }), displayList && (0,external_window_wp_element_.createElement)(\"div\", {\n ref: container,\n \"data-id\": item,\n className: classnames_default()({\n 'ct-item-in-builder': itemInBuilder,\n 'ct-builder-item': !itemInBuilder\n }),\n onClick: () => {\n if (isDragging) {\n return;\n }\n\n itemInBuilder && open();\n }\n }, itemName, (0,external_window_wp_element_.createElement)(external_window_wp_components_.Slot, {\n name: `ColumnsBuilderSidebarItem_${index}`,\n fillProps: {\n item,\n itemInBuilder,\n itemData\n }\n })));\n }\n }));\n }\n }),\n direction: \"vertical\"\n });\n};\n\n/* harmony default export */ const builder_sidebar_SecondaryItems = (SecondaryItems);\n;// CONCATENATED MODULE: ./static/js/customizer/panels-builder/columns/builder-sidebar/InvisiblePanels.js\nfunction InvisiblePanels_extends() { InvisiblePanels_extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return InvisiblePanels_extends.apply(this, arguments); }\n\nfunction InvisiblePanels_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction InvisiblePanels_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? InvisiblePanels_ownKeys(Object(source), !0).forEach(function (key) { InvisiblePanels_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : InvisiblePanels_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction InvisiblePanels_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\nconst InvisiblePanels = _ref => {\n let {\n builderValue,\n builderValueDispatch\n } = _ref;\n const secondaryItems = ct_customizer_localizations.header_builder_data.secondary_items.footer;\n const allItems = ct_customizer_localizations.header_builder_data.footer;\n const {\n panelsState,\n panelsActions\n } = (0,external_window_wp_element_.useContext)(DragDropContext);\n const primaryItems = allItems.filter(_ref2 => {\n let {\n id\n } = _ref2;\n return !secondaryItems.find(item => item.id === id);\n });\n return (0,external_window_wp_element_.createElement)(external_window_wp_element_.Fragment, null, primaryItems.map(primaryItem => {\n const option = {\n label: primaryItem.config.name,\n 'inner-options': primaryItem.options\n };\n const id = `builder_panel_${primaryItem.id}`;\n return (0,external_window_wp_element_.createElement)(ct_panel.PanelMetaWrapper, InvisiblePanels_extends({\n id: id,\n key: primaryItem.id,\n option: option\n }, panelsActions, {\n getActualOption: _ref3 => {\n let {\n container\n } = _ref3;\n return (0,external_window_wp_element_.createElement)(external_window_wp_element_.Fragment, null, (0,external_window_wp_element_.createElement)(ct_panel[\"default\"], {\n id: id,\n getValues: () => {\n let itemValue = builderValue.items[primaryItem.id];\n const maybeRow = builderValue.rows.find(_ref4 => {\n let {\n id\n } = _ref4;\n return id === primaryItem.id;\n });\n let hasWidgetAreas = false;\n\n if (maybeRow) {\n if (maybeRow.columns.reduce((allItems, current) => [...allItems, current], []).join('').indexOf('widget-area') > -1) {\n hasWidgetAreas = true;\n }\n }\n\n if (itemValue && Object.keys(itemValue.values) > 5) {\n return InvisiblePanels_objectSpread(InvisiblePanels_objectSpread({}, itemValue.values), maybeRow ? {\n items_per_row: maybeRow.columns.length.toString(),\n has_widget_areas: hasWidgetAreas ? 'yes' : 'no'\n } : {});\n }\n\n return InvisiblePanels_objectSpread(InvisiblePanels_objectSpread({}, (0,get_value_from_input/* getValueFromInput */.n6)(primaryItem.options, itemValue ? itemValue.values : {})), maybeRow ? {\n items_per_row: maybeRow.columns.length.toString(),\n has_widget_areas: hasWidgetAreas ? 'yes' : 'no'\n } : {});\n },\n option: option,\n onChangeFor: (optionId, optionValue) => {\n const currentValue = builderValue.items[primaryItem.id];\n builderValueDispatch({\n type: 'ITEM_VALUE_ON_CHANGE',\n payload: {\n id: primaryItem.id,\n optionId,\n optionValue,\n values: !currentValue || currentValue && Object.keys(currentValue.values).length === 0 ? (0,get_value_from_input/* getValueFromInput */.n6)(primaryItem.options, {}) : {}\n }\n });\n },\n view: \"simple\"\n }));\n }\n }));\n }));\n};\n\n/* harmony default export */ const builder_sidebar_InvisiblePanels = (InvisiblePanels);\n;// CONCATENATED MODULE: ./static/js/customizer/panels-builder/columns/builder-sidebar/PanelsManager.js\nfunction PanelsManager_extends() { PanelsManager_extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return PanelsManager_extends.apply(this, arguments); }\n\n\n\n\n\n\n\n\nconst PanelsManager = () => {\n const secondaryItems = ct_customizer_localizations.header_builder_data.secondary_items.footer;\n const allItems = ct_customizer_localizations.header_builder_data.footer;\n const {\n builderValueCollection,\n builderValue,\n builderValueDispatch,\n panelsActions\n } = (0,external_window_wp_element_.useContext)(DragDropContext);\n const allSections = builderValueCollection.sections.filter(_ref => {\n let {\n id\n } = _ref;\n return id !== 'type-2' && id !== 'type-3' && id.indexOf('ct-custom') === -1;\n });\n return (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-panels-manager\"\n }, allSections.map(_ref2 => {\n let {\n name,\n id\n } = _ref2;\n return (0,external_window_wp_element_.createElement)(\"div\", null, name);\n }), (0,external_window_wp_element_.createElement)(\"ul\", {\n className: classnames_default()('ct-panels-list')\n }, allSections.map(_ref3 => {\n let {\n name,\n id\n } = _ref3;\n let panelLabel = name || {\n 'type-1': (0,external_window_wp_i18n_.__)('Global Footer', 'blocksy')\n }[id] || id;\n const panelId = `builder_footer_panel_${id}`;\n const footerOptions = ct_customizer_localizations.header_builder_data.footer_data.footer_options;\n const option = {\n label: panelLabel,\n 'inner-options': footerOptions\n };\n return (0,external_window_wp_element_.createElement)(ct_panel.PanelMetaWrapper, PanelsManager_extends({\n id: panelId,\n key: id,\n option: option\n }, panelsActions, {\n getActualOption: _ref4 => {\n let {\n open\n } = _ref4;\n return (0,external_window_wp_element_.createElement)(external_window_wp_element_.Fragment, null, id === builderValue.id && (0,external_window_wp_element_.createElement)(ct_panel[\"default\"], {\n id: panelId,\n getValues: () => (0,get_value_from_input/* getValueFromInput */.n6)(footerOptions, Array.isArray(builderValue.settings) ? {} : builderValue.settings),\n option: option,\n onChangeFor: (optionId, optionValue) => {\n builderValueDispatch({\n type: 'BUILDER_GLOBAL_SETTING_ON_CHANGE',\n payload: {\n optionId,\n optionValue\n }\n });\n },\n view: \"simple\"\n }), id === builderValue.id && (0,external_window_wp_element_.createElement)(\"li\", {\n className: classnames_default()({\n active: id === builderValue.id,\n 'ct-global': id === 'type-1'\n }),\n onClick: () => {\n open();\n }\n }, (0,external_window_wp_element_.createElement)(\"span\", {\n className: \"ct-panel-name\"\n }, panelLabel)));\n }\n }));\n })));\n};\n\n/* harmony default export */ const builder_sidebar_PanelsManager = (PanelsManager);\n;// CONCATENATED MODULE: ./static/js/customizer/panels-builder/columns/AvailableItems.js\n\n\n\n\n\n\n\n\n\n\n\n\nconst AvailableItems = _ref => {\n let {\n builderValue,\n builderValueCollection,\n builderValueDispatch,\n inlinedItemsFromBuilder\n } = _ref;\n // panels | items | options\n const [currentTab, setCurrentTab] = (0,external_window_wp_element_.useState)('items');\n const secondaryItems = ct_customizer_localizations.header_builder_data.secondary_items.footer;\n const allItems = ct_customizer_localizations.header_builder_data.footer;\n const footerOptions = ct_customizer_localizations.header_builder_data.footer_data.footer_options;\n return (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-available-items ct-footer-builder-options\"\n }, (0,external_window_wp_element_.createElement)(\"h3\", {\n className: \"ct-title\",\n dangerouslySetInnerHTML: {\n __html: sprintf((0,external_window_wp_i18n_.__)('Customizing: %s', 'blocksy'), `${(builderValueCollection.sections.find(_ref2 => {\n let {\n id\n } = _ref2;\n return id === builderValue.id;\n }) || {}).name || {\n 'type-1': (0,external_window_wp_i18n_.__)('Global Footer', 'blocksy')\n }[builderValue.id] || builderValue.id}`)\n }\n }), (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-tabs\"\n }, (0,external_window_wp_element_.createElement)(\"ul\", null, ['items', 'panels'].map(tab => (0,external_window_wp_element_.createElement)(\"li\", {\n key: tab,\n onClick: e => {\n e.preventDefault();\n setCurrentTab(tab);\n },\n className: classnames_default()({\n active: tab === currentTab\n })\n }, {\n panels: (0,external_window_wp_i18n_.__)('Footers', 'blocksy'),\n items: (0,external_window_wp_i18n_.__)('Elements', 'blocksy')\n }[tab]))), (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-current-tab\"\n }, currentTab === 'panels' && (0,external_window_wp_element_.createElement)(external_window_wp_components_.Slot, {\n name: \"ColumnsBuilderPanelsManager\"\n }, fills => fills.length === 0 ? (0,external_window_wp_element_.createElement)(builder_sidebar_PanelsManager, null) : fills), (0,external_window_wp_element_.createElement)(builder_sidebar_SecondaryItems, {\n builderValue: builderValue,\n builderValueDispatch: builderValueDispatch,\n inlinedItemsFromBuilder: inlinedItemsFromBuilder,\n displayList: currentTab === 'items'\n }))), (0,external_window_wp_element_.createElement)(builder_sidebar_InvisiblePanels, {\n builderValue: builderValue,\n builderValueDispatch: builderValueDispatch\n }));\n};\n\n/* harmony default export */ const columns_AvailableItems = (AvailableItems);\n// EXTERNAL MODULE: ./node_modules/nanoid/index.browser.js\nvar index_browser = __webpack_require__(1496);\nvar index_browser_default = /*#__PURE__*/__webpack_require__.n(index_browser);\n;// CONCATENATED MODULE: ./static/js/customizer/panels-builder/columns/builderReducer.js\nfunction builderReducer_objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = builderReducer_objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction builderReducer_objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return typeof key === \"symbol\" ? key : String(key); }\n\nfunction _toPrimitive(input, hint) { if (typeof input !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (typeof res !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\n\nfunction builderReducer_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction builderReducer_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? builderReducer_ownKeys(Object(source), !0).forEach(function (key) { builderReducer_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : builderReducer_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction builderReducer_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\nconst transformColumns = (columns, futureLength) => {\n columns = columns.filter(c => c.length > 0);\n return Array.from(Array(futureLength)).map((_, index) => {\n if (Array.isArray(columns[index])) {\n return columns[index];\n }\n\n return [];\n });\n};\n\nconst builderReducer = (builderValue, action) => {\n let updatedGlobalState = {};\n let newSections = [];\n let futureBuilderValue = builderValue.sections.find(_ref => {\n let {\n id\n } = _ref;\n return id.indexOf(builderValue.__forced_static_footer__ || fetchCurrentFooter() || builderValue.sections[0].id) > -1;\n });\n let shouldUpdate = false;\n let updateItemId = false;\n let removeSectionIds = [];\n\n if (action.type === 'BUILDER_GLOBAL_SETTING_ON_CHANGE') {\n const {\n optionId,\n optionValue,\n values = {}\n } = action.payload;\n futureBuilderValue = builderReducer_objectSpread(builderReducer_objectSpread({}, futureBuilderValue), {}, {\n settings: builderReducer_objectSpread(builderReducer_objectSpread({}, futureBuilderValue.settings), {}, {\n [optionId]: optionValue\n })\n });\n }\n\n if (action.type === 'ITEM_VALUE_ON_CHANGE') {\n const {\n id,\n optionId,\n optionValue,\n values = {}\n } = action.payload;\n updateItemId = `${id}:${optionId}`;\n let items = futureBuilderValue.items;\n\n if ((id === 'top-row' || id === 'middle-row' || id === 'bottom-row') && optionId === 'items_per_row') {\n futureBuilderValue = builderReducer_objectSpread(builderReducer_objectSpread({}, futureBuilderValue), {}, {\n rows: futureBuilderValue.rows.map(row => row.id === id ? builderReducer_objectSpread(builderReducer_objectSpread({}, row), {}, {\n columns: transformColumns(row.columns, parseInt(optionValue, 10))\n }) : row)\n });\n } else {\n if (!items[id]) {\n items[id] = {\n id,\n values: {}\n };\n }\n\n futureBuilderValue = builderReducer_objectSpread(builderReducer_objectSpread({}, futureBuilderValue), {}, {\n items: builderReducer_objectSpread(builderReducer_objectSpread({}, Array.isArray(items) ? {} : items), {}, {\n [id]: {\n id,\n values: builderReducer_objectSpread(builderReducer_objectSpread({}, items[id].values), {}, {\n [optionId]: optionValue\n })\n }\n })\n });\n }\n }\n\n if (action.type === 'REMOVE_CLONED_ITEM') {\n let _futureBuilderValue$i = futureBuilderValue.items,\n _action$payload$id = action.payload.id,\n {\n [_action$payload$id]: removedItem\n } = _futureBuilderValue$i,\n localItems = builderReducer_objectWithoutProperties(_futureBuilderValue$i, [_action$payload$id].map(_toPropertyKey));\n\n futureBuilderValue = builderReducer_objectSpread(builderReducer_objectSpread({}, futureBuilderValue), {}, {\n items: localItems\n });\n }\n\n if (action.type === 'CLONE_ITEM') {\n const futureId = (0,helpers/* getOriginalId */.t_)(action.payload.id);\n let completeFutureId = `${futureId}${(0,helpers/* customItemsSeparator */.SU)()}${index_browser_default()()}`;\n futureBuilderValue = builderReducer_objectSpread(builderReducer_objectSpread({}, futureBuilderValue), {}, {\n items: builderReducer_objectSpread(builderReducer_objectSpread({}, futureBuilderValue.items), {}, {\n [completeFutureId]: {\n id: completeFutureId,\n values: futureBuilderValue.items[futureId] ? futureBuilderValue.items[futureId].values || {} : {}\n }\n })\n });\n }\n\n if (action.type === 'PICK_BUILDER_SECTION') {\n shouldUpdate = true;\n updatedGlobalState = {\n __forced_static_footer__: action.payload.id\n };\n }\n\n if (action.type === 'MARK_FOOTER_AS_GLOBAL') {\n shouldUpdate = true;\n updatedGlobalState = {\n __forced_static_footer__: action.payload.id,\n current_section: action.payload.id\n };\n }\n\n if (action.type === 'MARK_SPECIFIC_FOOTER_AS_GLOBAL') {\n updatedGlobalState = {\n current_section: action.payload.id\n };\n }\n\n if (action.type === 'SET_LIST') {\n shouldUpdate = true;\n const {\n lists\n } = action.payload;\n futureBuilderValue = builderReducer_objectSpread(builderReducer_objectSpread({}, futureBuilderValue), {}, {\n rows: futureBuilderValue.rows.map(_ref2 => {\n let {\n id: barId,\n columns\n } = _ref2;\n const keys = Object.keys(lists);\n\n if (keys.map(k => k.split(':')[0]).indexOf(barId) > -1) {\n return {\n id: barId,\n columns: columns.map((column, index) => {\n if (lists[`${barId}:${index}`]) {\n return lists[`${barId}:${index}`];\n }\n\n return column;\n })\n };\n }\n\n return {\n id: barId,\n columns\n };\n })\n });\n }\n\n if (action.type === 'CREATE_NEW_SECTION') {\n const {\n name,\n copy\n } = action.payload;\n newSections = [copy ? builderReducer_objectSpread(builderReducer_objectSpread({}, builderValue.sections.find(_ref3 => {\n let {\n id\n } = _ref3;\n return id === copy;\n }) || {}), {}, {\n name,\n id: `ct-custom-${index_browser_default()()}`\n }) : {\n name,\n id: `ct-custom-${index_browser_default()()}`,\n mode: 'columns',\n rows: [{\n id: 'top-row',\n columns: [[], []]\n }, {\n id: 'middle-row',\n columns: [[], [], []]\n }, {\n id: 'bottom-row',\n columns: [['copyright']]\n }],\n items: [],\n settings: []\n }];\n }\n\n if (action.type === 'REMOVE_BUILDER_SECTION') {\n removeSectionIds.push(action.payload.id);\n }\n\n const actualBuilderValue = builderReducer_objectSpread(builderReducer_objectSpread(builderReducer_objectSpread({}, builderValue), updatedGlobalState), {}, {\n __should_refresh__: shouldUpdate,\n __should_refresh_item__: updateItemId,\n sections: [...builderValue.sections.map(builder => builder.id === futureBuilderValue.id ? futureBuilderValue : builder), ...newSections].filter(_ref4 => {\n let {\n id\n } = _ref4;\n return removeSectionIds.indexOf(id) === -1;\n })\n });\n\n return actualBuilderValue;\n};\n;// CONCATENATED MODULE: ./static/js/options/options/ct-footer-builder.js\nconst ct_footer_builder_excluded = [\"__forced_static_footer__\", \"__should_refresh__\"],\n _excluded2 = [\"__forced_static_footer__\"];\n\nfunction ct_footer_builder_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction ct_footer_builder_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ct_footer_builder_ownKeys(Object(source), !0).forEach(function (key) { ct_footer_builder_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ct_footer_builder_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction ct_footer_builder_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction ct_footer_builder_objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = ct_footer_builder_objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction ct_footer_builder_objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\n\n\n\n\n\nconst DragDropContext = (0,external_window_wp_element_.createContext)({});\n\nconst getDocument = x => x.document || x.contentDocument || x.contentWindow.document;\n\nconst fetchCurrentFooter = () => {\n const document = getDocument(wp.customize.previewer.container.find('iframe')[0]);\n\n if (wp.customize.previewer.container.find('iframe')[0].contentDocument.querySelector('footer.ct-footer')) {\n return wp.customize.previewer.container.find('iframe')[0].contentDocument.querySelector('footer.ct-footer').dataset.id;\n }\n\n return null;\n};\n\nconst FooterBuilder = _ref => {\n let {\n value: allBuilderSections,\n option,\n onChange: onBuilderValueChange\n } = _ref;\n const currentFooter = (0,external_window_wp_element_.useRef)(null);\n\n if (currentFooter.current === null) {\n currentFooter.current = (allBuilderSections.sections.find(_ref2 => {\n let {\n id\n } = _ref2;\n return id.indexOf(fetchCurrentFooter()) > -1;\n }) || allBuilderSections.sections[0]).id;\n }\n\n (0,external_window_wp_element_.useEffect)(() => {\n let _wp$customize = wp.customize('footer_placements')(),\n {\n __forced_static_footer__,\n __should_refresh__\n } = _wp$customize,\n old = ct_footer_builder_objectWithoutProperties(_wp$customize, ct_footer_builder_excluded);\n\n Object.keys(old).map(key => {\n if (parseFloat(key)) {\n delete old[key];\n }\n });\n\n try {\n wp.customize('footer_placements')(ct_footer_builder_objectSpread(ct_footer_builder_objectSpread({}, old), {}, {\n __forced_static_footer__: (allBuilderSections.sections.find(_ref3 => {\n let {\n id\n } = _ref3;\n return id.indexOf(fetchCurrentFooter()) > -1;\n }) || allBuilderSections.sections[0]).id\n }));\n } catch (e) {\n console.error(e);\n }\n\n return () => {\n const _wp$customize2 = wp.customize('footer_placements')(),\n {\n __forced_static_footer__\n } = _wp$customize2,\n old = ct_footer_builder_objectWithoutProperties(_wp$customize2, _excluded2);\n\n wp.customize('footer_placements')(ct_footer_builder_objectSpread({\n __should_refresh__: true,\n [Math.random()]: 'update'\n }, old));\n };\n }, []);\n const [builderValueCollection, builderValueDispatchInternal] = (0,external_window_wp_element_.useReducer)(builderReducer, ct_footer_builder_objectSpread(ct_footer_builder_objectSpread({}, allBuilderSections), currentFooter.current ? {\n __forced_static_footer__: currentFooter.current\n } : {}));\n const [builderCollapsed, setBuilderCollapsed] = (0,external_window_wp_element_.useState)(false);\n const builderValue = (0,external_window_wp_element_.useMemo)(() => builderValueCollection.sections.find(_ref4 => {\n let {\n id\n } = _ref4;\n return id === builderValueCollection.__forced_static_footer__;\n }) || builderValueCollection.sections[0], [builderValueCollection]);\n const [isDragging, setIsDragging] = (0,external_window_wp_element_.useState)(false);\n const inlinedItemsFromBuilder = builderValue.rows.reduce((currentItems, _ref5) => {\n let {\n columns\n } = _ref5;\n return [...currentItems, ...(columns || []).reduce((c, items) => [...c, ...items], [])];\n }, []);\n const builderValueDispatch = (0,external_window_wp_element_.useCallback)(action => {\n let newState = builderReducer(builderValueCollection, action);\n\n if (action.type === 'BUILDER_GLOBAL_SETTING_ON_CHANGE' && wp.customize.previewer) {\n const builderValue = newState.sections.find(_ref6 => {\n let {\n id\n } = _ref6;\n return id === newState.__forced_static_footer__;\n }) || newState.sections[0];\n const {\n optionId,\n optionValue,\n values = {}\n } = action.payload;\n wp.customize.previewer.send('ct:footer:receive-value-update', {\n itemId: 'global',\n optionId,\n optionValue,\n values: ct_footer_builder_objectSpread(ct_footer_builder_objectSpread({}, builderValue.settings), {}, {\n [optionId]: optionValue\n })\n });\n }\n\n if (action.type === 'ITEM_VALUE_ON_CHANGE' && wp.customize.previewer) {\n const {\n id,\n optionId,\n optionValue,\n values = {}\n } = action.payload;\n const builderValue = newState.sections.find(_ref7 => {\n let {\n id\n } = _ref7;\n return id === newState.__forced_static_footer__;\n }) || newState.sections[0];\n let items = builderValue.items;\n const currentItem = items[id] || {\n values: {}\n };\n wp.customize.previewer.send('ct:footer:receive-value-update', {\n itemId: id,\n optionId,\n optionValue,\n values: ct_footer_builder_objectSpread(ct_footer_builder_objectSpread(ct_footer_builder_objectSpread(ct_footer_builder_objectSpread(ct_footer_builder_objectSpread({}, currentItem.values), values), id === 'top-row' || id === 'middle-row' || id === 'bottom-row' ? {\n items_per_row: builderValue.rows.find(_ref8 => {\n let {\n id: _id\n } = _ref8;\n return id === _id;\n }).columns.length\n } : {}), (id === 'top-row' || id === 'middle-row' || id === 'bottom-row') && optionId === 'items_per_row' ? {\n items_per_row: parseInt(optionValue, 10)\n } : {}), {}, {\n [optionId]: optionValue\n })\n });\n }\n\n onBuilderValueChange(newState);\n builderValueDispatchInternal(action);\n }, [builderValueDispatchInternal, onBuilderValueChange, builderValueCollection]);\n\n const setList = lists => builderValueDispatch({\n type: 'SET_LIST',\n onBuilderValueChange,\n payload: {\n lists\n }\n });\n\n (0,external_window_wp_element_.useEffect)(() => {\n return () => {\n document.querySelector('.wp-full-overlay').classList.remove('ct-builder-collapsed');\n };\n }, []);\n return (0,external_window_wp_element_.createElement)(external_window_wp_element_.Fragment, null, (0,external_window_wp_element_.createElement)(DragDropContext.Provider, {\n value: {\n isDragging,\n setIsDragging,\n setList,\n builderValueDispatch,\n builderValueCollection,\n builderValue,\n onChange: _ref9 => {\n let {\n id,\n value\n } = _ref9;\n return setList({\n [id]: value\n });\n }\n }\n }, (0,external_window_wp_element_.createElement)(columns_AvailableItems, {\n builderValue: builderValue,\n inlinedItemsFromBuilder: inlinedItemsFromBuilder,\n builderValueDispatch: builderValueDispatch,\n builderValueCollection: builderValueCollection\n }), (0,external_window_wp_element_.createPortal)((0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-builder-footer\"\n }, (0,external_window_wp_element_.createElement)(\"ul\", {\n className: \"ct-view-switch\"\n }, (0,external_window_wp_element_.createElement)(\"li\", {\n className: \"ct-builder-toggle\",\n onClick: () => {\n setBuilderCollapsed(!builderCollapsed);\n\n if (builderCollapsed) {\n document.querySelector('.wp-full-overlay').classList.remove('ct-builder-collapsed');\n } else {\n document.querySelector('.wp-full-overlay').classList.add('ct-builder-collapsed');\n }\n }\n }, builderCollapsed ? (0,external_window_wp_i18n_.__)('Show Builder', 'blocksy') : (0,external_window_wp_i18n_.__)('Hide Builder', 'blocksy'))), (0,external_window_wp_element_.createElement)(columns_ColumnsBuilder, {\n builderValue: builderValue\n })), document.querySelector('.ct-panel-builder'))));\n};\n\nFooterBuilder.renderingConfig = {\n design: 'none'\n};\n/* harmony default export */ const ct_footer_builder = (FooterBuilder);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"5821.js","mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9MA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;ACvIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACnEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7NA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./static/js/customizer/panels-builder/columns/DraggableItems.js?1975","webpack://blocksyOptions/./static/js/customizer/panels-builder/columns/ColumnsBuilder.js?5aa4","webpack://blocksyOptions/./static/js/customizer/panels-builder/columns/builder-sidebar/SecondaryItems.js?9506","webpack://blocksyOptions/./static/js/customizer/panels-builder/columns/builder-sidebar/InvisiblePanels.js?3802","webpack://blocksyOptions/./static/js/customizer/panels-builder/columns/builder-sidebar/PanelsManager.js?57be","webpack://blocksyOptions/./static/js/customizer/panels-builder/columns/AvailableItems.js?26e3","webpack://blocksyOptions/./static/js/customizer/panels-builder/columns/builderReducer.js?562b","webpack://blocksyOptions/./static/js/options/options/ct-footer-builder.js?e80e"],"sourcesContent":["const _excluded = [\"items\", \"draggableId\", \"hasPointers\", \"className\", \"tagName\", \"direction\", \"group\", \"options\", \"propsForItem\", \"panelType\", \"displayWrapper\"];\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport { createElement, useContext } from '@wordpress/element';\nimport cls from 'classnames';\nimport Sortable from '../placements/Sortable';\nimport { DragDropContext } from '../../../options/options/ct-footer-builder';\nimport { PanelContext } from '../../../options/components/PanelLevel';\nimport { customItemsSeparator, getOriginalId } from '../placements/helpers';\n\nconst shallowCompare = (prev, next) => {\n  for (let key in next) {\n    if (next[key] !== prev[key]) return false;\n  }\n\n  return true;\n};\n\nfunction memo(Component) {\n  let areEqual = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : shallowCompare;\n  let prevProps = {};\n  let prevResult;\n  return nextProps => {\n    if (prevResult !== undefined && areEqual(prevProps, nextProps)) {\n      return prevResult;\n    }\n\n    prevProps = nextProps;\n    prevResult = createElement(Component, Object.assign({}, nextProps));\n    return prevResult;\n  };\n}\n\nexport const DraggableItem = _ref => {\n  let {\n    item,\n    index,\n    panelType,\n    onRemove,\n    renderItem,\n    onClick,\n    className\n  } = _ref;\n  const itemData = ct_customizer_localizations.header_builder_data[panelType].find(_ref2 => {\n    let {\n      id\n    } = _ref2;\n    return id === getOriginalId(item);\n  });\n  const {\n    builderValue\n  } = useContext(DragDropContext);\n\n  if (renderItem) {\n    return renderItem({\n      item,\n      itemData,\n      index\n    });\n  }\n  /**\n   * Dynamic items have a : in their ID\n   */\n\n\n  const allDynamicItems = Object.keys(builderValue.items).filter(id => id.indexOf(customItemsSeparator()) > -1);\n  const allClonesAndOriginal = [getOriginalId(item), ...allDynamicItems.filter(id => getOriginalId(id) === getOriginalId(item))];\n  return createElement(\"div\", {\n    \"data-id\": item,\n    className: cls('ct-builder-item', className, {// 'ct-is-dragging': snapshot.isDragging\n    }),\n    onClick: onClick\n  }, itemData && itemData.config ? allClonesAndOriginal.length > 1 ? `${itemData.config.name} ${allClonesAndOriginal.indexOf(item) + 1}` : itemData.config.name : item, createElement(\"button\", {\n    className: \"ct-btn-remove\",\n    onClick: e => {\n      e.preventDefault();\n      e.stopPropagation();\n      onRemove();\n    }\n  }));\n};\n\nconst DraggableItems = _ref3 => {\n  let {\n    items,\n    draggableId,\n    hasPointers = true,\n    className,\n    tagName = 'div',\n    direction = 'horizontal',\n    group = 'header_sortables',\n    options = {},\n    propsForItem = item => ({}),\n    panelType = 'footer',\n    displayWrapper = true\n  } = _ref3,\n      props = _objectWithoutProperties(_ref3, _excluded);\n\n  const {\n    isDragging,\n    setIsDragging,\n    onChange,\n    setList\n  } = useContext(DragDropContext);\n  const {\n    panelsHelpers\n  } = useContext(PanelContext);\n  const itemsOutput = items.map((item, index) => createElement(DraggableItem, _extends({\n    key: item,\n    index: index,\n    panelType: panelType,\n    item: item,\n    className: panelsHelpers.isOpenFor(`builder_panel_${item}`) ? 'ct-customizing' : '',\n    onClick: e => {\n      e.stopPropagation();\n      e.preventDefault();\n      panelsHelpers.open(`builder_panel_${item}`);\n    },\n    onRemove: () => {\n      panelsHelpers.close();\n      setList({\n        [draggableId]: items.filter(id => id !== item)\n      });\n    }\n  }, propsForItem(item))));\n\n  if (!displayWrapper) {\n    return itemsOutput;\n  }\n\n  return createElement(Sortable, _extends({\n    options: _objectSpread({\n      delay: 0,\n      group,\n      fallbackOnBody: true,\n      forceFallback: true,\n      fallbackTolerance: 5,\n      filter: '.ct-pointer',\n      direction: direction,\n      touchStartThreshold: 5,\n      onStart: event => {\n        setIsDragging(event.item.dataset.id);\n        document.body.classList.add('ct-builder-dragging');\n\n        if (event.from && group && group.pull !== 'clone') {\n          event.to.classList.add('ct-is-over');\n        }\n      },\n      onEnd: () => {\n        setIsDragging(false);\n        document.body.classList.remove('ct-builder-dragging');\n        [...document.querySelectorAll('.ct-panel-builder .ct-is-over')].map(el => el.classList.remove('ct-is-over'));\n      },\n      onMove: (event, originalEvent) => {\n        if (event.from.closest('#ct-option-header-builder-items')) {\n          Promise.resolve().then(() => [...event.from.querySelectorAll(`[data-id=\"${event.dragged.dataset.id}\"]`)].map(el => {\n            el.classList.remove('ct-builder-item');\n            el.classList.add('ct-item-in-builder');\n          }));\n        }\n\n        if (event.to) {\n          if (event.to.children && Array.from(event.to.children).filter(e => e.dataset.id !== '__pointer__' && e.dataset.id !== '__filler__').length > 0) {\n            return false;\n          }\n\n          ;\n          [...document.querySelectorAll('.ct-panel-builder .ct-is-over')].map(el => el.classList.remove('ct-is-over'));\n          event.to.classList.add('ct-is-over');\n        }\n      }\n    }, options),\n    onChange: (order, sortable, evt) => {\n      if (draggableId === 'available-items') {\n        return;\n      }\n\n      onChange({\n        id: draggableId,\n        value: order.filter(i => i !== '__pointer__' && i !== '__filler__')\n      });\n    },\n    tag: tagName,\n    className: cls('ct-builder-items', className)\n  }, props, {\n    \"data-id\": draggableId\n  }), draggableId !== 'available-items' && isDragging && createElement(\"div\", {\n    \"data-id\": \"__filler__\",\n    className: \"ct-filler\"\n  }), hasPointers && isDragging && createElement(\"div\", {\n    \"data-id\": \"__pointer__\",\n    className: \"ct-pointer\"\n  }), itemsOutput);\n};\n\nexport default DraggableItems;","import { createElement, useContext } from '@wordpress/element';\nimport { __ } from 'ct-i18n';\nimport cls from 'classnames';\nimport DraggableItems from './DraggableItems';\nimport { PanelContext } from '../../../options/components/PanelLevel';\n\nconst Bar = _ref => {\n  let {\n    bar,\n    builderValue,\n    direction = 'horizontal'\n  } = _ref;\n  const {\n    panelsHelpers\n  } = useContext(PanelContext);\n  const maybeValues = builderValue.items[bar.id];\n  const allItems = ct_customizer_localizations.header_builder_data.footer;\n  const primaryItem = allItems.find(_ref2 => {\n    let {\n      id\n    } = _ref2;\n    return id === bar.id;\n  });\n  const values = maybeValues ? maybeValues.values : {};\n  let columns = 'initial';\n\n  if (bar.columns.length === 2) {\n    columns = values['2_columns_layout'] || {\n      desktop: 'repeat(2, 1fr)',\n      tablet: 'initial',\n      mobile: 'initial'\n    };\n  }\n\n  if (bar.columns.length === 3) {\n    columns = values['3_columns_layout'] || {\n      desktop: 'repeat(3, 1fr)',\n      tablet: 'initial',\n      mobile: 'initial'\n    };\n  }\n\n  if (bar.columns.length === 4) {\n    columns = values['4_columns_layout'] || {\n      desktop: 'repeat(4, 1fr)',\n      tablet: 'initial',\n      mobile: 'initial'\n    };\n  }\n\n  if (bar.columns.length === 5) {\n    columns = values['5_columns_layout'] || {\n      desktop: 'repeat(5, 1fr)',\n      tablet: 'initial',\n      mobile: 'initial'\n    };\n  }\n\n  if (bar.columns.length === 6) {\n    columns = values['6_columns_layout'] || {\n      desktop: 'repeat(6, 1fr)',\n      tablet: 'initial',\n      mobile: 'initial'\n    };\n  }\n\n  if (columns && columns.desktop) {\n    columns = columns.desktop;\n  }\n\n  return createElement(\"li\", {\n    className: \"builder-row\"\n  }, createElement(\"div\", {\n    className: \"ct-row-actions\",\n    onClick: () => panelsHelpers.open(`builder_panel_${bar.id}`)\n  }, {\n    'top-row': __('Top Row', 'blocksy'),\n    'middle-row': __('Middle Row', 'blocksy'),\n    'bottom-row': __('Bottom Row', 'blocksy')\n  }[bar.id]), createElement(\"ul\", {\n    className: \"row-inner\",\n    style: {\n      '--gridTemplateColummns': columns\n    }\n  }, bar.columns.map((column, index) => createElement(\"li\", {\n    className: \"builder-column\",\n    key: index\n  }, createElement(DraggableItems, {\n    draggableId: `${bar.id}:${index}`,\n    items: column\n  })))));\n};\n\nconst shallowCompare = (prev, next) => {\n  for (let key in next) {\n    if (next[key] !== prev[key]) return false;\n  }\n\n  return true;\n};\n\nexport function memo(Component) {\n  let areEqual = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : shallowCompare;\n  let prevProps = {};\n  let prevResult;\n  return nextProps => {\n    if (prevResult !== undefined && areEqual(prevProps, nextProps)) {\n      return prevResult;\n    }\n\n    prevProps = nextProps;\n    prevResult = createElement(Component, Object.assign({}, nextProps));\n    return prevResult;\n  };\n}\nconst ColumnsBuilder = memo(_ref3 => {\n  let {\n    builderValue\n  } = _ref3;\n  return createElement(\"div\", {\n    className: cls('placements-builder')\n  }, createElement(\"ul\", {\n    className: \"horizontal-rows\"\n  }, ['top-row', 'middle-row', 'bottom-row'].map(bar => createElement(Bar, {\n    builderValue: builderValue,\n    bar: builderValue.rows.find(_ref4 => {\n      let {\n        id\n      } = _ref4;\n      return id === bar;\n    }),\n    key: bar\n  }))));\n}); // const ColumnsBuilder = () => null\n\nexport default ColumnsBuilder;","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport { createElement, Component, useState, useContext, Fragment } from '@wordpress/element';\nimport DraggableItems from '../DraggableItems';\nimport { DragDropContext } from '../../../../options/options/ct-footer-builder';\nimport cls from 'classnames';\nimport Panel, { PanelMetaWrapper } from '../../../../options/options/ct-panel';\nimport { getValueFromInput } from '../../../../options/helpers/get-value-from-input';\nimport { getOriginalId, customItemsSeparator } from '../../placements/helpers';\nimport { Slot } from '@wordpress/components';\n\nconst SecondaryItems = _ref => {\n  let {\n    builderValue,\n    builderValueDispatch,\n    inlinedItemsFromBuilder,\n    displayList = true\n  } = _ref;\n  const {\n    panelsState,\n    panelsActions,\n    currentView,\n    isDragging\n  } = useContext(DragDropContext);\n  const inlinedItemsFromAllViewsBuilder = builderValue.rows.reduce((currentItems, _ref2) => {\n    let {\n      columns\n    } = _ref2;\n    return [...currentItems, ...(columns || []).reduce((c, items) => [...c, ...items], [])];\n  }, []);\n  const secondaryItems = ct_customizer_localizations.header_builder_data.secondary_items.footer.filter(_ref3 => {\n    let {\n      config\n    } = _ref3;\n    return (// config.devices.indexOf(currentView) > -1 &&\n      config.enabled\n    );\n  });\n  const allItems = ct_customizer_localizations.header_builder_data.footer;\n  /**\n   * Dynamic items have a : in their ID\n   */\n\n  const allDynamicItems = Object.keys(builderValue.items).filter(id => id.indexOf(customItemsSeparator()) > -1);\n  return createElement(DraggableItems, {\n    options: {\n      sort: false,\n      filter: '.ct-item-in-builder'\n    },\n    group: {\n      name: 'header_sortables',\n      put: false,\n      pull: 'clone'\n    },\n    draggableId: 'available-items',\n    items: [...secondaryItems.map(_ref4 => {\n      let {\n        id\n      } = _ref4;\n      return id;\n    }), ...allDynamicItems].sort((a, b) => {\n      const aItemData = ct_customizer_localizations.header_builder_data['footer'].find(_ref5 => {\n        let {\n          id\n        } = _ref5;\n        return id === getOriginalId(a);\n      });\n      const bItemData = ct_customizer_localizations.header_builder_data['footer'].find(_ref6 => {\n        let {\n          id\n        } = _ref6;\n        return id === getOriginalId(b);\n      });\n      return aItemData.config.name.localeCompare(bItemData.config.name);\n    }),\n    hasPointers: false,\n    panelType: \"footer\",\n    displayWrapper: displayList,\n    propsForItem: item => ({\n      renderItem: _ref7 => {\n        let {\n          item,\n          itemData,\n          index\n        } = _ref7;\n        const itemOptions = allItems.find(_ref8 => {\n          let {\n            id\n          } = _ref8;\n          return id === getOriginalId(item);\n        }).options;\n        const allClonesAndOriginal = [getOriginalId(item), ...allDynamicItems.filter(id => getOriginalId(id) === getOriginalId(item))];\n        const itemName = allClonesAndOriginal.length > 1 ? `${itemData.config.name} ${allClonesAndOriginal.indexOf(item) + 1}` : itemData.config.name;\n        const option = {\n          label: itemName,\n          'inner-options': itemOptions\n        };\n        const itemInBuilder = inlinedItemsFromBuilder.indexOf(item) > -1;\n        const id = `builder_panel_${item}`;\n        return createElement(PanelMetaWrapper, _extends({\n          id: id,\n          option: option\n        }, panelsActions, {\n          getActualOption: _ref9 => {\n            let {\n              open,\n              container\n            } = _ref9;\n            return createElement(Fragment, null, inlinedItemsFromAllViewsBuilder.indexOf(item) > -1 && createElement(Panel, {\n              id: id,\n              getValues: () => {\n                let itemValue = builderValue.items[item];\n\n                if (itemValue && Object.keys(itemValue.values) > 5) {\n                  return itemValue.values;\n                }\n\n                return getValueFromInput(itemOptions, itemValue ? itemValue.values : {});\n              },\n              option: option,\n              onChangeFor: (optionId, optionValue) => {\n                const currentValue = builderValue.items[item];\n                builderValueDispatch({\n                  type: 'ITEM_VALUE_ON_CHANGE',\n                  payload: {\n                    id: item,\n                    optionId,\n                    optionValue,\n                    values: !currentValue || currentValue && Object.keys(currentValue.values).length === 0 ? getValueFromInput(itemOptions, {}) : {}\n                  }\n                });\n              },\n              view: \"simple\"\n            }), displayList && createElement(\"div\", {\n              ref: container,\n              \"data-id\": item,\n              className: cls({\n                'ct-item-in-builder': itemInBuilder,\n                'ct-builder-item': !itemInBuilder\n              }),\n              onClick: () => {\n                if (isDragging) {\n                  return;\n                }\n\n                itemInBuilder && open();\n              }\n            }, itemName, createElement(Slot, {\n              name: `ColumnsBuilderSidebarItem_${index}`,\n              fillProps: {\n                item,\n                itemInBuilder,\n                itemData\n              }\n            })));\n          }\n        }));\n      }\n    }),\n    direction: \"vertical\"\n  });\n};\n\nexport default SecondaryItems;","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, Component, useState, useContext, Fragment } from '@wordpress/element';\nimport cls from 'classnames';\nimport Panel, { PanelMetaWrapper } from '../../../../options/options/ct-panel';\nimport { getValueFromInput } from '../../../../options/helpers/get-value-from-input';\nimport { DragDropContext } from '../../../../options/options/ct-footer-builder';\n\nconst InvisiblePanels = _ref => {\n  let {\n    builderValue,\n    builderValueDispatch\n  } = _ref;\n  const secondaryItems = ct_customizer_localizations.header_builder_data.secondary_items.footer;\n  const allItems = ct_customizer_localizations.header_builder_data.footer;\n  const {\n    panelsState,\n    panelsActions\n  } = useContext(DragDropContext);\n  const primaryItems = allItems.filter(_ref2 => {\n    let {\n      id\n    } = _ref2;\n    return !secondaryItems.find(item => item.id === id);\n  });\n  return createElement(Fragment, null, primaryItems.map(primaryItem => {\n    const option = {\n      label: primaryItem.config.name,\n      'inner-options': primaryItem.options\n    };\n    const id = `builder_panel_${primaryItem.id}`;\n    return createElement(PanelMetaWrapper, _extends({\n      id: id,\n      key: primaryItem.id,\n      option: option\n    }, panelsActions, {\n      getActualOption: _ref3 => {\n        let {\n          container\n        } = _ref3;\n        return createElement(Fragment, null, createElement(Panel, {\n          id: id,\n          getValues: () => {\n            let itemValue = builderValue.items[primaryItem.id];\n            const maybeRow = builderValue.rows.find(_ref4 => {\n              let {\n                id\n              } = _ref4;\n              return id === primaryItem.id;\n            });\n            let hasWidgetAreas = false;\n\n            if (maybeRow) {\n              if (maybeRow.columns.reduce((allItems, current) => [...allItems, current], []).join('').indexOf('widget-area') > -1) {\n                hasWidgetAreas = true;\n              }\n            }\n\n            if (itemValue && Object.keys(itemValue.values) > 5) {\n              return _objectSpread(_objectSpread({}, itemValue.values), maybeRow ? {\n                items_per_row: maybeRow.columns.length.toString(),\n                has_widget_areas: hasWidgetAreas ? 'yes' : 'no'\n              } : {});\n            }\n\n            return _objectSpread(_objectSpread({}, getValueFromInput(primaryItem.options, itemValue ? itemValue.values : {})), maybeRow ? {\n              items_per_row: maybeRow.columns.length.toString(),\n              has_widget_areas: hasWidgetAreas ? 'yes' : 'no'\n            } : {});\n          },\n          option: option,\n          onChangeFor: (optionId, optionValue) => {\n            const currentValue = builderValue.items[primaryItem.id];\n            builderValueDispatch({\n              type: 'ITEM_VALUE_ON_CHANGE',\n              payload: {\n                id: primaryItem.id,\n                optionId,\n                optionValue,\n                values: !currentValue || currentValue && Object.keys(currentValue.values).length === 0 ? getValueFromInput(primaryItem.options, {}) : {}\n              }\n            });\n          },\n          view: \"simple\"\n        }));\n      }\n    }));\n  }));\n};\n\nexport default InvisiblePanels;","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport { createElement, Component, useState, useContext, Fragment } from '@wordpress/element';\nimport cls from 'classnames';\nimport { DragDropContext } from '../../../../options/options/ct-footer-builder';\nimport Panel, { PanelMetaWrapper } from '../../../../options/options/ct-panel';\nimport { getValueFromInput } from '../../../../options/helpers/get-value-from-input';\nimport { __ } from 'ct-i18n';\n\nconst PanelsManager = () => {\n  const secondaryItems = ct_customizer_localizations.header_builder_data.secondary_items.footer;\n  const allItems = ct_customizer_localizations.header_builder_data.footer;\n  const {\n    builderValueCollection,\n    builderValue,\n    builderValueDispatch,\n    panelsActions\n  } = useContext(DragDropContext);\n  const allSections = builderValueCollection.sections.filter(_ref => {\n    let {\n      id\n    } = _ref;\n    return id !== 'type-2' && id !== 'type-3' && id.indexOf('ct-custom') === -1;\n  });\n  return createElement(\"div\", {\n    className: \"ct-panels-manager\"\n  }, allSections.map(_ref2 => {\n    let {\n      name,\n      id\n    } = _ref2;\n    return createElement(\"div\", null, name);\n  }), createElement(\"ul\", {\n    className: cls('ct-panels-list')\n  }, allSections.map(_ref3 => {\n    let {\n      name,\n      id\n    } = _ref3;\n    let panelLabel = name || {\n      'type-1': __('Global Footer', 'blocksy')\n    }[id] || id;\n    const panelId = `builder_footer_panel_${id}`;\n    const footerOptions = ct_customizer_localizations.header_builder_data.footer_data.footer_options;\n    const option = {\n      label: panelLabel,\n      'inner-options': footerOptions\n    };\n    return createElement(PanelMetaWrapper, _extends({\n      id: panelId,\n      key: id,\n      option: option\n    }, panelsActions, {\n      getActualOption: _ref4 => {\n        let {\n          open\n        } = _ref4;\n        return createElement(Fragment, null, id === builderValue.id && createElement(Panel, {\n          id: panelId,\n          getValues: () => getValueFromInput(footerOptions, Array.isArray(builderValue.settings) ? {} : builderValue.settings),\n          option: option,\n          onChangeFor: (optionId, optionValue) => {\n            builderValueDispatch({\n              type: 'BUILDER_GLOBAL_SETTING_ON_CHANGE',\n              payload: {\n                optionId,\n                optionValue\n              }\n            });\n          },\n          view: \"simple\"\n        }), id === builderValue.id && createElement(\"li\", {\n          className: cls({\n            active: id === builderValue.id,\n            'ct-global': id === 'type-1'\n          }),\n          onClick: () => {\n            open();\n          }\n        }, createElement(\"span\", {\n          className: \"ct-panel-name\"\n        }, panelLabel)));\n      }\n    }));\n  })));\n};\n\nexport default PanelsManager;","import { createElement, Component, useState, Fragment } from '@wordpress/element';\nimport DraggableItems from './DraggableItems';\nimport cls from 'classnames';\nimport Panel, { PanelMetaWrapper } from '../../../options/options/ct-panel';\nimport { getValueFromInput } from '../../../options/helpers/get-value-from-input';\nimport { __ } from 'ct-i18n';\nimport OptionsPanel from '../../../options/OptionsPanel';\nimport { Slot } from '@wordpress/components';\nimport SecondaryItems from './builder-sidebar/SecondaryItems';\nimport InvisiblePanels from './builder-sidebar/InvisiblePanels';\nimport PanelsManager from './builder-sidebar/PanelsManager';\n\nconst AvailableItems = _ref => {\n  let {\n    builderValue,\n    builderValueCollection,\n    builderValueDispatch,\n    inlinedItemsFromBuilder\n  } = _ref;\n  // panels | items | options\n  const [currentTab, setCurrentTab] = useState('items');\n  const secondaryItems = ct_customizer_localizations.header_builder_data.secondary_items.footer;\n  const allItems = ct_customizer_localizations.header_builder_data.footer;\n  const footerOptions = ct_customizer_localizations.header_builder_data.footer_data.footer_options;\n  return createElement(\"div\", {\n    className: \"ct-available-items ct-footer-builder-options\"\n  }, createElement(\"h3\", {\n    className: \"ct-title\",\n    dangerouslySetInnerHTML: {\n      __html: sprintf(__('Customizing: %s', 'blocksy'), `<span>${(builderValueCollection.sections.find(_ref2 => {\n        let {\n          id\n        } = _ref2;\n        return id === builderValue.id;\n      }) || {}).name || {\n        'type-1': __('Global Footer', 'blocksy')\n      }[builderValue.id] || builderValue.id}</span>`)\n    }\n  }), createElement(\"div\", {\n    className: \"ct-tabs\"\n  }, createElement(\"ul\", null, ['items', 'panels'].map(tab => createElement(\"li\", {\n    key: tab,\n    onClick: e => {\n      e.preventDefault();\n      setCurrentTab(tab);\n    },\n    className: cls({\n      active: tab === currentTab\n    })\n  }, {\n    panels: __('Footers', 'blocksy'),\n    items: __('Elements', 'blocksy')\n  }[tab]))), createElement(\"div\", {\n    className: \"ct-current-tab\"\n  }, currentTab === 'panels' && createElement(Slot, {\n    name: \"ColumnsBuilderPanelsManager\"\n  }, fills => fills.length === 0 ? createElement(PanelsManager, null) : fills), createElement(SecondaryItems, {\n    builderValue: builderValue,\n    builderValueDispatch: builderValueDispatch,\n    inlinedItemsFromBuilder: inlinedItemsFromBuilder,\n    displayList: currentTab === 'items'\n  }))), createElement(InvisiblePanels, {\n    builderValue: builderValue,\n    builderValueDispatch: builderValueDispatch\n  }));\n};\n\nexport default AvailableItems;","function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return typeof key === \"symbol\" ? key : String(key); }\n\nfunction _toPrimitive(input, hint) { if (typeof input !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (typeof res !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport nanoid from 'nanoid';\nimport { fetchCurrentFooter } from '../../../options/options/ct-footer-builder';\nimport { getOriginalId, customItemsSeparator } from '../placements/helpers';\n\nconst transformColumns = (columns, futureLength) => {\n  columns = columns.filter(c => c.length > 0);\n  return Array.from(Array(futureLength)).map((_, index) => {\n    if (Array.isArray(columns[index])) {\n      return columns[index];\n    }\n\n    return [];\n  });\n};\n\nexport const builderReducer = (builderValue, action) => {\n  let updatedGlobalState = {};\n  let newSections = [];\n  let futureBuilderValue = builderValue.sections.find(_ref => {\n    let {\n      id\n    } = _ref;\n    return id.indexOf(builderValue.__forced_static_footer__ || fetchCurrentFooter() || builderValue.sections[0].id) > -1;\n  });\n  let shouldUpdate = false;\n  let updateItemId = false;\n  let removeSectionIds = [];\n\n  if (action.type === 'BUILDER_GLOBAL_SETTING_ON_CHANGE') {\n    const {\n      optionId,\n      optionValue,\n      values = {}\n    } = action.payload;\n    futureBuilderValue = _objectSpread(_objectSpread({}, futureBuilderValue), {}, {\n      settings: _objectSpread(_objectSpread({}, futureBuilderValue.settings), {}, {\n        [optionId]: optionValue\n      })\n    });\n  }\n\n  if (action.type === 'ITEM_VALUE_ON_CHANGE') {\n    const {\n      id,\n      optionId,\n      optionValue,\n      values = {}\n    } = action.payload;\n    updateItemId = `${id}:${optionId}`;\n    let items = futureBuilderValue.items;\n\n    if ((id === 'top-row' || id === 'middle-row' || id === 'bottom-row') && optionId === 'items_per_row') {\n      futureBuilderValue = _objectSpread(_objectSpread({}, futureBuilderValue), {}, {\n        rows: futureBuilderValue.rows.map(row => row.id === id ? _objectSpread(_objectSpread({}, row), {}, {\n          columns: transformColumns(row.columns, parseInt(optionValue, 10))\n        }) : row)\n      });\n    } else {\n      if (!items[id]) {\n        items[id] = {\n          id,\n          values: {}\n        };\n      }\n\n      futureBuilderValue = _objectSpread(_objectSpread({}, futureBuilderValue), {}, {\n        items: _objectSpread(_objectSpread({}, Array.isArray(items) ? {} : items), {}, {\n          [id]: {\n            id,\n            values: _objectSpread(_objectSpread({}, items[id].values), {}, {\n              [optionId]: optionValue\n            })\n          }\n        })\n      });\n    }\n  }\n\n  if (action.type === 'REMOVE_CLONED_ITEM') {\n    let _futureBuilderValue$i = futureBuilderValue.items,\n        _action$payload$id = action.payload.id,\n        {\n      [_action$payload$id]: removedItem\n    } = _futureBuilderValue$i,\n        localItems = _objectWithoutProperties(_futureBuilderValue$i, [_action$payload$id].map(_toPropertyKey));\n\n    futureBuilderValue = _objectSpread(_objectSpread({}, futureBuilderValue), {}, {\n      items: localItems\n    });\n  }\n\n  if (action.type === 'CLONE_ITEM') {\n    const futureId = getOriginalId(action.payload.id);\n    let completeFutureId = `${futureId}${customItemsSeparator()}${nanoid()}`;\n    futureBuilderValue = _objectSpread(_objectSpread({}, futureBuilderValue), {}, {\n      items: _objectSpread(_objectSpread({}, futureBuilderValue.items), {}, {\n        [completeFutureId]: {\n          id: completeFutureId,\n          values: futureBuilderValue.items[futureId] ? futureBuilderValue.items[futureId].values || {} : {}\n        }\n      })\n    });\n  }\n\n  if (action.type === 'PICK_BUILDER_SECTION') {\n    shouldUpdate = true;\n    updatedGlobalState = {\n      __forced_static_footer__: action.payload.id\n    };\n  }\n\n  if (action.type === 'MARK_FOOTER_AS_GLOBAL') {\n    shouldUpdate = true;\n    updatedGlobalState = {\n      __forced_static_footer__: action.payload.id,\n      current_section: action.payload.id\n    };\n  }\n\n  if (action.type === 'MARK_SPECIFIC_FOOTER_AS_GLOBAL') {\n    updatedGlobalState = {\n      current_section: action.payload.id\n    };\n  }\n\n  if (action.type === 'SET_LIST') {\n    shouldUpdate = true;\n    const {\n      lists\n    } = action.payload;\n    futureBuilderValue = _objectSpread(_objectSpread({}, futureBuilderValue), {}, {\n      rows: futureBuilderValue.rows.map(_ref2 => {\n        let {\n          id: barId,\n          columns\n        } = _ref2;\n        const keys = Object.keys(lists);\n\n        if (keys.map(k => k.split(':')[0]).indexOf(barId) > -1) {\n          return {\n            id: barId,\n            columns: columns.map((column, index) => {\n              if (lists[`${barId}:${index}`]) {\n                return lists[`${barId}:${index}`];\n              }\n\n              return column;\n            })\n          };\n        }\n\n        return {\n          id: barId,\n          columns\n        };\n      })\n    });\n  }\n\n  if (action.type === 'CREATE_NEW_SECTION') {\n    const {\n      name,\n      copy\n    } = action.payload;\n    newSections = [copy ? _objectSpread(_objectSpread({}, builderValue.sections.find(_ref3 => {\n      let {\n        id\n      } = _ref3;\n      return id === copy;\n    }) || {}), {}, {\n      name,\n      id: `ct-custom-${nanoid()}`\n    }) : {\n      name,\n      id: `ct-custom-${nanoid()}`,\n      mode: 'columns',\n      rows: [{\n        id: 'top-row',\n        columns: [[], []]\n      }, {\n        id: 'middle-row',\n        columns: [[], [], []]\n      }, {\n        id: 'bottom-row',\n        columns: [['copyright']]\n      }],\n      items: [],\n      settings: []\n    }];\n  }\n\n  if (action.type === 'REMOVE_BUILDER_SECTION') {\n    removeSectionIds.push(action.payload.id);\n  }\n\n  const actualBuilderValue = _objectSpread(_objectSpread(_objectSpread({}, builderValue), updatedGlobalState), {}, {\n    __should_refresh__: shouldUpdate,\n    __should_refresh_item__: updateItemId,\n    sections: [...builderValue.sections.map(builder => builder.id === futureBuilderValue.id ? futureBuilderValue : builder), ...newSections].filter(_ref4 => {\n      let {\n        id\n      } = _ref4;\n      return removeSectionIds.indexOf(id) === -1;\n    })\n  });\n\n  return actualBuilderValue;\n};","const _excluded = [\"__forced_static_footer__\", \"__should_refresh__\"],\n      _excluded2 = [\"__forced_static_footer__\"];\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport { createElement, Fragment, useRef, Component, useEffect, useMemo, createPortal, useState, useCallback, createContext, useReducer } from '@wordpress/element';\nimport { __ } from 'ct-i18n';\nimport ColumnsBuilder from '../../customizer/panels-builder/columns/ColumnsBuilder';\nimport AvailableItems from '../../customizer/panels-builder/columns/AvailableItems';\nimport { builderReducer } from '../../customizer/panels-builder/columns/builderReducer';\nexport const DragDropContext = createContext({});\n\nconst getDocument = x => x.document || x.contentDocument || x.contentWindow.document;\n\nexport const fetchCurrentFooter = () => {\n  const document = getDocument(wp.customize.previewer.container.find('iframe')[0]);\n\n  if (wp.customize.previewer.container.find('iframe')[0].contentDocument.querySelector('footer.ct-footer')) {\n    return wp.customize.previewer.container.find('iframe')[0].contentDocument.querySelector('footer.ct-footer').dataset.id;\n  }\n\n  return null;\n};\n\nconst FooterBuilder = _ref => {\n  let {\n    value: allBuilderSections,\n    option,\n    onChange: onBuilderValueChange\n  } = _ref;\n  const currentFooter = useRef(null);\n\n  if (currentFooter.current === null) {\n    currentFooter.current = (allBuilderSections.sections.find(_ref2 => {\n      let {\n        id\n      } = _ref2;\n      return id.indexOf(fetchCurrentFooter()) > -1;\n    }) || allBuilderSections.sections[0]).id;\n  }\n\n  useEffect(() => {\n    let _wp$customize = wp.customize('footer_placements')(),\n        {\n      __forced_static_footer__,\n      __should_refresh__\n    } = _wp$customize,\n        old = _objectWithoutProperties(_wp$customize, _excluded);\n\n    Object.keys(old).map(key => {\n      if (parseFloat(key)) {\n        delete old[key];\n      }\n    });\n\n    try {\n      wp.customize('footer_placements')(_objectSpread(_objectSpread({}, old), {}, {\n        __forced_static_footer__: (allBuilderSections.sections.find(_ref3 => {\n          let {\n            id\n          } = _ref3;\n          return id.indexOf(fetchCurrentFooter()) > -1;\n        }) || allBuilderSections.sections[0]).id\n      }));\n    } catch (e) {\n      console.error(e);\n    }\n\n    return () => {\n      const _wp$customize2 = wp.customize('footer_placements')(),\n            {\n        __forced_static_footer__\n      } = _wp$customize2,\n            old = _objectWithoutProperties(_wp$customize2, _excluded2);\n\n      wp.customize('footer_placements')(_objectSpread({\n        __should_refresh__: true,\n        [Math.random()]: 'update'\n      }, old));\n    };\n  }, []);\n  const [builderValueCollection, builderValueDispatchInternal] = useReducer(builderReducer, _objectSpread(_objectSpread({}, allBuilderSections), currentFooter.current ? {\n    __forced_static_footer__: currentFooter.current\n  } : {}));\n  const [builderCollapsed, setBuilderCollapsed] = useState(false);\n  const builderValue = useMemo(() => builderValueCollection.sections.find(_ref4 => {\n    let {\n      id\n    } = _ref4;\n    return id === builderValueCollection.__forced_static_footer__;\n  }) || builderValueCollection.sections[0], [builderValueCollection]);\n  const [isDragging, setIsDragging] = useState(false);\n  const inlinedItemsFromBuilder = builderValue.rows.reduce((currentItems, _ref5) => {\n    let {\n      columns\n    } = _ref5;\n    return [...currentItems, ...(columns || []).reduce((c, items) => [...c, ...items], [])];\n  }, []);\n  const builderValueDispatch = useCallback(action => {\n    let newState = builderReducer(builderValueCollection, action);\n\n    if (action.type === 'BUILDER_GLOBAL_SETTING_ON_CHANGE' && wp.customize.previewer) {\n      const builderValue = newState.sections.find(_ref6 => {\n        let {\n          id\n        } = _ref6;\n        return id === newState.__forced_static_footer__;\n      }) || newState.sections[0];\n      const {\n        optionId,\n        optionValue,\n        values = {}\n      } = action.payload;\n      wp.customize.previewer.send('ct:footer:receive-value-update', {\n        itemId: 'global',\n        optionId,\n        optionValue,\n        values: _objectSpread(_objectSpread({}, builderValue.settings), {}, {\n          [optionId]: optionValue\n        })\n      });\n    }\n\n    if (action.type === 'ITEM_VALUE_ON_CHANGE' && wp.customize.previewer) {\n      const {\n        id,\n        optionId,\n        optionValue,\n        values = {}\n      } = action.payload;\n      const builderValue = newState.sections.find(_ref7 => {\n        let {\n          id\n        } = _ref7;\n        return id === newState.__forced_static_footer__;\n      }) || newState.sections[0];\n      let items = builderValue.items;\n      const currentItem = items[id] || {\n        values: {}\n      };\n      wp.customize.previewer.send('ct:footer:receive-value-update', {\n        itemId: id,\n        optionId,\n        optionValue,\n        values: _objectSpread(_objectSpread(_objectSpread(_objectSpread(_objectSpread({}, currentItem.values), values), id === 'top-row' || id === 'middle-row' || id === 'bottom-row' ? {\n          items_per_row: builderValue.rows.find(_ref8 => {\n            let {\n              id: _id\n            } = _ref8;\n            return id === _id;\n          }).columns.length\n        } : {}), (id === 'top-row' || id === 'middle-row' || id === 'bottom-row') && optionId === 'items_per_row' ? {\n          items_per_row: parseInt(optionValue, 10)\n        } : {}), {}, {\n          [optionId]: optionValue\n        })\n      });\n    }\n\n    onBuilderValueChange(newState);\n    builderValueDispatchInternal(action);\n  }, [builderValueDispatchInternal, onBuilderValueChange, builderValueCollection]);\n\n  const setList = lists => builderValueDispatch({\n    type: 'SET_LIST',\n    onBuilderValueChange,\n    payload: {\n      lists\n    }\n  });\n\n  useEffect(() => {\n    return () => {\n      document.querySelector('.wp-full-overlay').classList.remove('ct-builder-collapsed');\n    };\n  }, []);\n  return createElement(Fragment, null, createElement(DragDropContext.Provider, {\n    value: {\n      isDragging,\n      setIsDragging,\n      setList,\n      builderValueDispatch,\n      builderValueCollection,\n      builderValue,\n      onChange: _ref9 => {\n        let {\n          id,\n          value\n        } = _ref9;\n        return setList({\n          [id]: value\n        });\n      }\n    }\n  }, createElement(AvailableItems, {\n    builderValue: builderValue,\n    inlinedItemsFromBuilder: inlinedItemsFromBuilder,\n    builderValueDispatch: builderValueDispatch,\n    builderValueCollection: builderValueCollection\n  }), createPortal(createElement(\"div\", {\n    className: \"ct-builder-footer\"\n  }, createElement(\"ul\", {\n    className: \"ct-view-switch\"\n  }, createElement(\"li\", {\n    className: \"ct-builder-toggle\",\n    onClick: () => {\n      setBuilderCollapsed(!builderCollapsed);\n\n      if (builderCollapsed) {\n        document.querySelector('.wp-full-overlay').classList.remove('ct-builder-collapsed');\n      } else {\n        document.querySelector('.wp-full-overlay').classList.add('ct-builder-collapsed');\n      }\n    }\n  }, builderCollapsed ? __('Show Builder', 'blocksy') : __('Hide Builder', 'blocksy'))), createElement(ColumnsBuilder, {\n    builderValue: builderValue\n  })), document.querySelector('.ct-panel-builder'))));\n};\n\nFooterBuilder.renderingConfig = {\n  design: 'none'\n};\nexport default FooterBuilder;"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///5821\n")},5565:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("// ESM COMPAT FLAG\n__webpack_require__.r(__webpack_exports__);\n\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n \"default\": () => (/* binding */ ct_header_builder)\n});\n\n// EXTERNAL MODULE: external \"window.wp.element\"\nvar external_window_wp_element_ = __webpack_require__(1381);\n// EXTERNAL MODULE: external \"window.wp.i18n\"\nvar external_window_wp_i18n_ = __webpack_require__(5652);\n// EXTERNAL MODULE: ./node_modules/classnames/index.js\nvar classnames = __webpack_require__(4184);\nvar classnames_default = /*#__PURE__*/__webpack_require__.n(classnames);\n// EXTERNAL MODULE: ./static/js/customizer/panels-builder/placements/Sortable.js\nvar Sortable = __webpack_require__(7229);\n// EXTERNAL MODULE: ./static/js/options/components/PanelLevel.js + 1 modules\nvar PanelLevel = __webpack_require__(956);\n// EXTERNAL MODULE: ./static/js/customizer/panels-builder/placements/helpers.js\nvar helpers = __webpack_require__(8382);\n// EXTERNAL MODULE: ./static/js/options/helpers/get-label.js\nvar get_label = __webpack_require__(7493);\n;// CONCATENATED MODULE: ./static/js/customizer/panels-builder/placements/DraggableItems.js\nconst _excluded = [\"items\", \"draggableId\", \"hasPointers\", \"className\", \"tagName\", \"direction\", \"group\", \"options\", \"propsForItem\", \"displayWrapper\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\n\n\n\n\n\n\n\n\nconst isItemAllowedIn = (itemId, barId, currentView) => {\n const item = ct_customizer_localizations.header_builder_data.header.find(_ref => {\n let {\n id\n } = _ref;\n return id === (0,helpers/* getOriginalId */.t_)(itemId);\n });\n\n if (!item) {\n return true;\n }\n\n let allowed_in = [];\n\n if (Array.isArray(item.config.allowed_in)) {\n allowed_in = item.config.allowed_in;\n } else {\n if (item.config.allowed_in[currentView]) {\n allowed_in = item.config.allowed_in[currentView];\n }\n }\n\n const allowedRespected = allowed_in.length > 0 ? allowed_in.indexOf(barId) > -1 : true;\n const exclusionRespected = item.config.excluded_from.length > 0 ? item.config.excluded_from.indexOf(barId) === -1 : true;\n return allowedRespected && exclusionRespected;\n};\n\nconst DraggableItem = _ref2 => {\n var _itemData$config$name, _itemData$config, _itemData$config$name2, _itemData$config2;\n\n let {\n item,\n index,\n panelType,\n onRemove,\n renderItem,\n onClick,\n className\n } = _ref2;\n const itemData = ct_customizer_localizations.header_builder_data[panelType].find(_ref3 => {\n let {\n id\n } = _ref3;\n return id === (0,helpers/* getOriginalId */.t_)(item);\n });\n const {\n builderValue\n } = (0,external_window_wp_element_.useContext)(DragDropContext);\n\n if (renderItem) {\n return renderItem({\n item,\n itemData,\n index\n });\n }\n /**\n * Dynamic items have a : in their ID\n */\n\n\n const allDynamicItems = builderValue.items.filter(_ref4 => {\n let {\n id\n } = _ref4;\n return id.indexOf((0,helpers/* customItemsSeparator */.SU)()) > -1;\n }).map(_ref5 => {\n let {\n id\n } = _ref5;\n return id;\n });\n const allClonesAndOriginal = [(0,helpers/* getOriginalId */.t_)(item), ...allDynamicItems.filter(id => (0,helpers/* getOriginalId */.t_)(id) === (0,helpers/* getOriginalId */.t_)(item))];\n const beautyItem = (0,get_label/* capitalizeFirstLetter */.f)((0,helpers/* getOriginalId */.t_)(item));\n return (0,external_window_wp_element_.createElement)(\"div\", {\n \"data-id\": item,\n className: classnames_default()('ct-builder-item', className, {// 'ct-is-dragging': snapshot.isDragging\n }),\n onClick: onClick\n }, allClonesAndOriginal.length > 1 ? `${(_itemData$config$name = itemData === null || itemData === void 0 ? void 0 : (_itemData$config = itemData.config) === null || _itemData$config === void 0 ? void 0 : _itemData$config.name) !== null && _itemData$config$name !== void 0 ? _itemData$config$name : beautyItem} ${allClonesAndOriginal.indexOf(item) + 1}` : (_itemData$config$name2 = itemData === null || itemData === void 0 ? void 0 : (_itemData$config2 = itemData.config) === null || _itemData$config2 === void 0 ? void 0 : _itemData$config2.name) !== null && _itemData$config$name2 !== void 0 ? _itemData$config$name2 : beautyItem, (0,external_window_wp_element_.createElement)(\"button\", {\n className: \"ct-btn-remove\",\n onClick: e => {\n e.preventDefault();\n e.stopPropagation();\n onRemove();\n }\n }));\n};\n\nconst DraggableItems = _ref6 => {\n let {\n items,\n draggableId,\n hasPointers = true,\n className,\n tagName = 'div',\n direction = 'horizontal',\n group = 'header_sortables',\n options = {},\n propsForItem = item => ({}),\n displayWrapper = true\n } = _ref6,\n props = _objectWithoutProperties(_ref6, _excluded);\n\n const {\n currentView,\n isDragging,\n setIsDragging,\n onChange,\n setList\n } = (0,external_window_wp_element_.useContext)(DragDropContext);\n const {\n panelsHelpers\n } = (0,external_window_wp_element_.useContext)(PanelLevel/* PanelContext */.Q);\n const itemsOutput = items.map((item, index) => (0,external_window_wp_element_.createElement)(DraggableItem, _extends({\n key: item,\n index: index,\n panelType: 'header',\n item: item,\n className: panelsHelpers.isOpenFor(`builder_panel_${item}`) ? 'ct-customizing' : '',\n onClick: e => {\n e.stopPropagation();\n e.preventDefault();\n\n if (isDragging) {\n return;\n }\n\n panelsHelpers.open(`builder_panel_${item}`);\n },\n onRemove: () => {\n panelsHelpers.close();\n setList(_objectSpread({\n [draggableId]: items.filter(id => id !== item)\n }, currentView === 'desktop' && item === 'trigger' ? {\n ['offcanvas:start']: []\n } : {}));\n }\n }, propsForItem(item))));\n\n if (!displayWrapper) {\n return (0,external_window_wp_element_.createElement)(external_window_wp_element_.Fragment, null, itemsOutput);\n }\n\n return (0,external_window_wp_element_.createElement)(Sortable/* default */.Z, _extends({\n options: _objectSpread({\n delay: 0,\n group,\n fallbackOnBody: true,\n forceFallback: true,\n fallbackTolerance: 5,\n filter: '.ct-pointer',\n direction,\n touchStartThreshold: 5,\n onStart: event => {\n setIsDragging(event.item.dataset.id);\n let currentView = wp.customize.previewedDevice();\n\n if (currentView === 'tablet') {\n currentView = 'mobile';\n }\n\n if (isItemAllowedIn(event.item.dataset.id, 'middle-row', currentView)) {\n document.body.classList.add('ct-builder-dragging');\n }\n\n if (event.from && group && group.pull !== 'clone') {\n event.to.classList.add('ct-is-over');\n }\n },\n onEnd: () => {\n setIsDragging(false);\n document.body.classList.remove('ct-builder-dragging');\n [...document.querySelectorAll('.ct-panel-builder .ct-is-over')].map(el => el.classList.remove('ct-is-over'));\n },\n onMove: (event, originalEvent) => {\n let currentView = wp.customize.previewedDevice();\n\n if (currentView === 'tablet') {\n currentView = 'mobile';\n }\n\n if (event.from.closest('#ct-option-header-builder-items')) {\n Promise.resolve().then(() => [...event.from.querySelectorAll(`[data-id=\"${event.dragged.dataset.id}\"]`)].map(el => {\n el.classList.remove('ct-builder-item');\n el.classList.add('ct-item-in-builder');\n }));\n }\n\n ;\n [...document.querySelectorAll('.ct-panel-builder .ct-is-over')].map(el => el.classList.remove('ct-is-over'));\n\n if (event.to) {\n event.to.classList.add('ct-is-over');\n }\n\n if (!isItemAllowedIn(event.dragged.dataset.id, event.to.dataset.id.split(':')[0], currentView)) {\n return false;\n }\n }\n }, options),\n onChange: (order, sortable, evt) => {\n // console.log('here is change', order, draggableId)\n if (draggableId === 'available-items') {\n return;\n }\n\n onChange({\n id: draggableId,\n value: order.filter(i => i !== '__pointer__' && i !== '__filler__')\n });\n },\n tag: tagName,\n className: classnames_default()('ct-builder-items', className)\n }, props, {\n \"data-id\": draggableId\n }), ['end', 'start-middle'].indexOf(draggableId.split(':')[1]) > -1 && (0,external_window_wp_element_.createElement)(\"div\", {\n \"data-id\": \"__filler__\",\n className: \"ct-filler\"\n }), hasPointers && isDragging && isItemAllowedIn(isDragging, draggableId.split(':')[0], currentView) && (0,external_window_wp_element_.createElement)(\"div\", {\n \"data-id\": \"__pointer__\",\n className: \"ct-pointer\"\n }), itemsOutput);\n};\n\n/* harmony default export */ const placements_DraggableItems = (DraggableItems);\n;// CONCATENATED MODULE: ./static/js/customizer/panels-builder/placements/PlacementsBuilder/PrimaryPlacement.js\nfunction PrimaryPlacement_extends() { PrimaryPlacement_extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return PrimaryPlacement_extends.apply(this, arguments); }\n\n\n\n\nconst PrimaryPlacement = _ref => {\n let {\n placementName,\n bar,\n direction\n } = _ref;\n const placement = bar.placements.find(_ref2 => {\n let {\n id\n } = _ref2;\n return id === placementName;\n });\n let placementsToRender = [placement];\n\n if (placementName !== 'middle') {\n const middle = bar.placements.find(_ref3 => {\n let {\n id\n } = _ref3;\n return id === 'middle';\n });\n\n if (middle && middle.items.length > 0) {\n if (placementName === 'start') {\n const startMiddle = bar.placements.find(_ref4 => {\n let {\n id\n } = _ref4;\n return id === 'start-middle';\n });\n placementsToRender = [placement, startMiddle];\n }\n\n if (placementName === 'end') {\n const endMiddle = bar.placements.find(_ref5 => {\n let {\n id\n } = _ref5;\n return id === 'end-middle';\n });\n placementsToRender = [endMiddle, placement];\n }\n }\n }\n\n return (0,external_window_wp_element_.createElement)(\"li\", PrimaryPlacement_extends({\n className: [`ct-builder-column-${placement.id}`]\n }, placement.id === 'middle' ? {\n 'data-count': placement.items.length\n } : {}), placementsToRender.map(placement => (0,external_window_wp_element_.createElement)(placements_DraggableItems, {\n key: placement.id,\n direction: direction,\n className: placement.id === 'middle' ? '' : `ct-${placement.id.indexOf('-') > -1 ? 'secondary' : 'primary'}-column`,\n draggableId: `${bar.id}:${placement.id}`,\n items: placement.items\n })));\n};\n\n/* harmony default export */ const PlacementsBuilder_PrimaryPlacement = (PrimaryPlacement);\n;// CONCATENATED MODULE: ./static/js/customizer/panels-builder/placements/PlacementsBuilder/Row.js\n\n\n\n\n\nconst Row = _ref => {\n let {\n bar,\n direction = 'horizontal'\n } = _ref;\n const {\n panelsHelpers\n } = (0,external_window_wp_element_.useContext)(PanelLevel/* PanelContext */.Q);\n return (0,external_window_wp_element_.createElement)(\"li\", {\n className: \"builder-row\"\n }, (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-row-actions\",\n onClick: () => panelsHelpers.open(`builder_panel_${bar.id}`)\n }, {\n 'top-row': (0,external_window_wp_i18n_.__)('Top Row', 'blocksy'),\n 'middle-row': (0,external_window_wp_i18n_.__)('Main Row', 'blocksy'),\n 'bottom-row': (0,external_window_wp_i18n_.__)('Bottom Row', 'blocksy'),\n offcanvas: (0,external_window_wp_i18n_.__)('Off Canvas Area', 'blocksy')\n }[bar.id]), (0,external_window_wp_element_.createElement)(\"ul\", {\n className: \"row-inner\"\n }, ['start', 'middle', 'end'].filter(placementName => !!bar.placements.find(_ref2 => {\n let {\n id\n } = _ref2;\n return id === placementName;\n })).map(placementName => (0,external_window_wp_element_.createElement)(PlacementsBuilder_PrimaryPlacement, {\n key: placementName,\n bar: bar,\n placementName: placementName,\n direction: direction\n }))));\n};\n\n/* harmony default export */ const PlacementsBuilder_Row = (Row);\n;// CONCATENATED MODULE: ./static/js/customizer/panels-builder/placements/PlacementsBuilder.js\n\n\n\n\n\n\nconst PlacementsBuilder = _ref => {\n let {\n inlinedItemsFromBuilder,\n view,\n builderValueWithView\n } = _ref;\n let hasOffcanvas = view === 'mobile' || inlinedItemsFromBuilder.indexOf('trigger') > -1 && builderValueWithView.find(_ref2 => {\n let {\n id\n } = _ref2;\n return id === 'offcanvas';\n });\n return (0,external_window_wp_element_.createElement)(\"div\", {\n className: classnames_default()('placements-builder', {\n 'ct-mobile': hasOffcanvas\n })\n }, hasOffcanvas && (0,external_window_wp_element_.createElement)(\"ul\", {\n className: \"offcanvas-container\"\n }, (0,external_window_wp_element_.createElement)(PlacementsBuilder_Row, {\n direction: \"vertical\",\n bar: builderValueWithView.find(_ref3 => {\n let {\n id\n } = _ref3;\n return id === 'offcanvas';\n })\n })), (0,external_window_wp_element_.createElement)(\"ul\", {\n className: \"horizontal-rows\"\n }, ['top-row', 'middle-row', 'bottom-row'].map(bar => {\n const maybeBar = builderValueWithView.find(_ref4 => {\n let {\n id\n } = _ref4;\n return id === bar;\n });\n\n if (!maybeBar) {\n return null;\n }\n\n return (0,external_window_wp_element_.createElement)(PlacementsBuilder_Row, {\n bar: maybeBar,\n key: bar\n });\n })));\n};\n\n/* harmony default export */ const placements_PlacementsBuilder = (PlacementsBuilder);\n;// CONCATENATED MODULE: ./static/js/customizer/panels-builder/placements/ViewSwitch.js\n\n\n\n\nconst ViewSwitch = _ref => {\n let {\n currentView,\n setCurrentView\n } = _ref;\n const [builderCollapsed, setBuilderCollapsed] = (0,external_window_wp_element_.useState)(false);\n (0,external_window_wp_element_.useEffect)(() => {\n return () => {\n document.querySelector('.wp-full-overlay').classList.remove('ct-builder-collapsed');\n };\n }, []);\n return (0,external_window_wp_element_.createElement)(\"ul\", {\n className: \"ct-view-switch\"\n }, ['desktop', 'mobile'].map(view => (0,external_window_wp_element_.createElement)(\"li\", {\n key: view,\n onClick: () => setCurrentView(view === 'mobile' ? 'tablet' : view),\n className: classnames_default()({\n active: currentView === view\n })\n }, {\n desktop: (0,external_window_wp_i18n_.__)('Desktop Header', 'blocksy'),\n mobile: (0,external_window_wp_i18n_.__)('Tablet / Mobile Header', 'blocksy')\n }[view])), (0,external_window_wp_element_.createElement)(\"li\", {\n className: \"ct-builder-toggle\",\n onClick: () => {\n setBuilderCollapsed(!builderCollapsed);\n\n if (builderCollapsed) {\n document.querySelector('.wp-full-overlay').classList.remove('ct-builder-collapsed');\n } else {\n document.querySelector('.wp-full-overlay').classList.add('ct-builder-collapsed');\n }\n }\n }, builderCollapsed ? (0,external_window_wp_i18n_.__)('Show Builder', 'blocksy') : (0,external_window_wp_i18n_.__)('Hide Builder', 'blocksy')));\n};\n\n/* harmony default export */ const placements_ViewSwitch = (ViewSwitch);\n// EXTERNAL MODULE: external \"window.wp.components\"\nvar external_window_wp_components_ = __webpack_require__(8441);\n// EXTERNAL MODULE: ./static/js/options/options/ct-panel.js\nvar ct_panel = __webpack_require__(3731);\n// EXTERNAL MODULE: ./static/js/options/helpers/get-value-from-input.js\nvar get_value_from_input = __webpack_require__(7069);\n;// CONCATENATED MODULE: ./static/js/customizer/panels-builder/placements/builder-sidebar/SecondaryItems.js\nfunction SecondaryItems_extends() { SecondaryItems_extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return SecondaryItems_extends.apply(this, arguments); }\n\nfunction SecondaryItems_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction SecondaryItems_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? SecondaryItems_ownKeys(Object(source), !0).forEach(function (key) { SecondaryItems_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : SecondaryItems_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction SecondaryItems_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\n\n\n\nconst SecondaryItems = _ref => {\n let {\n builderValue,\n builderValueDispatch,\n inlinedItemsFromBuilder,\n displayList = true\n } = _ref;\n const {\n panelsState,\n panelsActions,\n currentView,\n isDragging\n } = (0,external_window_wp_element_.useContext)(DragDropContext);\n const inlinedItemsFromAllViewsBuilder = [...builderValue.desktop.reduce((currentItems, _ref2) => {\n let {\n id,\n placements\n } = _ref2;\n return [...currentItems, ...(placements || []).reduce((c, _ref3) => {\n let {\n id,\n items\n } = _ref3;\n return [...c, ...items];\n }, [])];\n }, []), ...builderValue.mobile.reduce((currentItems, _ref4) => {\n let {\n id,\n placements\n } = _ref4;\n return [...currentItems, ...(placements || []).reduce((c, _ref5) => {\n let {\n id,\n items\n } = _ref5;\n return [...c, ...items];\n }, [])];\n }, [])];\n const secondaryItems = ct_customizer_localizations.header_builder_data.secondary_items.header.filter(_ref6 => {\n let {\n config\n } = _ref6;\n return (// config.devices.indexOf(currentView) > -1 &&\n config.enabled\n );\n });\n const allItems = ct_customizer_localizations.header_builder_data.header;\n /**\n * Dynamic items have a : in their ID\n */\n\n const allDynamicItems = builderValue.items.filter(_ref7 => {\n let {\n id\n } = _ref7;\n return id.indexOf((0,helpers/* customItemsSeparator */.SU)()) > -1;\n }).map(_ref8 => {\n let {\n id\n } = _ref8;\n return id;\n });\n return (0,external_window_wp_element_.createElement)(placements_DraggableItems, {\n options: {\n sort: false,\n filter: '.ct-item-in-builder'\n },\n group: {\n name: 'header_sortables',\n put: false,\n pull: 'clone'\n },\n draggableId: 'available-items',\n items: [...secondaryItems.map(_ref9 => {\n let {\n id\n } = _ref9;\n return id;\n }), ...allDynamicItems].filter(el => allItems.some(_ref10 => {\n let {\n id\n } = _ref10;\n return id === (0,helpers/* getOriginalId */.t_)(el);\n })).sort((a, b) => {\n const aItemData = allItems.find(_ref11 => {\n let {\n id\n } = _ref11;\n return id === (0,helpers/* getOriginalId */.t_)(a);\n });\n const bItemData = allItems.find(_ref12 => {\n let {\n id\n } = _ref12;\n return id === (0,helpers/* getOriginalId */.t_)(b);\n });\n return aItemData.config.name.localeCompare(bItemData.config.name);\n }),\n hasPointers: false,\n displayWrapper: displayList,\n propsForItem: item => ({\n renderItem: _ref13 => {\n let {\n item,\n itemData,\n index\n } = _ref13;\n const itemOptions = allItems.find(_ref14 => {\n let {\n id\n } = _ref14;\n return id === (0,helpers/* getOriginalId */.t_)(item);\n }).options;\n const allClonesAndOriginal = [(0,helpers/* getOriginalId */.t_)(item), ...allDynamicItems.filter(id => (0,helpers/* getOriginalId */.t_)(id) === (0,helpers/* getOriginalId */.t_)(item))];\n const itemName = allClonesAndOriginal.length > 1 ? `${itemData.config.name} ${allClonesAndOriginal.indexOf(item) + 1}` : itemData.config.name;\n const option = {\n label: itemName,\n 'inner-options': itemOptions\n };\n const itemInBuilder = inlinedItemsFromBuilder.indexOf(item) > -1;\n let row = '__none__';\n\n if (itemInBuilder) {\n row = builderValue[currentView].find(_ref15 => {\n let {\n id,\n placements\n } = _ref15;\n const rowItems = (placements || []).reduce((c, _ref16) => {\n let {\n id,\n items\n } = _ref16;\n return [...c, ...items];\n }, []);\n return rowItems.find(i => i === item);\n }).id;\n }\n\n const id = `builder_panel_${item}`;\n const itemsOnlyWithTrigger = ['mobile-menu', 'mobile-menu-secondary', 'offcanvas-logo'];\n const isSidebarRepresentationPresent = displayList && itemData.config.devices.includes(currentView) && (!itemsOnlyWithTrigger.includes(item) || itemsOnlyWithTrigger.includes(item) && (currentView !== 'desktop' || inlinedItemsFromBuilder.indexOf('trigger') > -1));\n let itemTitle = itemData.config.name;\n return (0,external_window_wp_element_.createElement)(ct_panel.PanelMetaWrapper, SecondaryItems_extends({\n id: id,\n option: option\n }, panelsActions, {\n getActualOption: _ref17 => {\n let {\n open\n } = _ref17;\n return (0,external_window_wp_element_.createElement)(external_window_wp_element_.Fragment, null, inlinedItemsFromAllViewsBuilder.indexOf(item) > -1 && (0,external_window_wp_element_.createElement)(ct_panel[\"default\"], {\n id: id,\n getValues: () => {\n let itemValue = builderValue.items.find(_ref18 => {\n let {\n id\n } = _ref18;\n return id === item;\n });\n\n if (itemValue && Object.keys(itemValue.values) > 5) {\n return SecondaryItems_objectSpread({\n builderSettings: builderValue.settings || {},\n row\n }, itemValue.values);\n }\n\n return SecondaryItems_objectSpread(SecondaryItems_objectSpread({}, (0,get_value_from_input/* getValueFromInput */.n6)(itemOptions, itemValue ? itemValue.values : {})), {}, {\n row,\n builderSettings: builderValue.settings || {}\n });\n },\n option: option,\n onChangeFor: (optionId, optionValue) => {\n const currentValue = builderValue.items.find(_ref19 => {\n let {\n id\n } = _ref19;\n return id === item;\n });\n builderValueDispatch({\n type: 'ITEM_VALUE_ON_CHANGE',\n payload: {\n id: item,\n optionId,\n optionValue,\n values: !currentValue || currentValue && Object.keys(currentValue.values).length === 0 ? (0,get_value_from_input/* getValueFromInput */.n6)(itemOptions, {}) : {}\n }\n });\n },\n view: \"simple\"\n }), isSidebarRepresentationPresent && (0,external_window_wp_element_.createElement)(\"div\", {\n \"data-id\": item,\n className: classnames_default()({\n 'ct-item-in-builder': itemInBuilder,\n 'ct-builder-item': !itemInBuilder\n }),\n onClick: e => {\n if (isDragging) {\n return;\n }\n\n itemInBuilder && open();\n }\n }, itemName, (0,external_window_wp_element_.createElement)(external_window_wp_components_.Slot, {\n name: `PlacementsBuilderSidebarItem_${index}`,\n fillProps: {\n item,\n itemInBuilder,\n itemData\n }\n })));\n }\n }));\n }\n }),\n direction: \"vertical\"\n });\n};\n\n/* harmony default export */ const builder_sidebar_SecondaryItems = (SecondaryItems);\n;// CONCATENATED MODULE: ./static/js/customizer/panels-builder/placements/builder-sidebar/InvisiblePanels.js\nfunction InvisiblePanels_extends() { InvisiblePanels_extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return InvisiblePanels_extends.apply(this, arguments); }\n\nfunction InvisiblePanels_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction InvisiblePanels_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? InvisiblePanels_ownKeys(Object(source), !0).forEach(function (key) { InvisiblePanels_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : InvisiblePanels_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction InvisiblePanels_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\nconst InvisiblePanels = _ref => {\n let {\n builderValue,\n builderValueDispatch\n } = _ref;\n const secondaryItems = ct_customizer_localizations.header_builder_data.secondary_items.header;\n const allItems = ct_customizer_localizations.header_builder_data.header;\n const {\n panelsState,\n panelsActions\n } = (0,external_window_wp_element_.useContext)(DragDropContext);\n const primaryItems = allItems.filter(_ref2 => {\n let {\n id\n } = _ref2;\n return !secondaryItems.find(item => item.id === id);\n });\n return (0,external_window_wp_element_.createElement)(external_window_wp_element_.Fragment, null, primaryItems.map(primaryItem => {\n const option = {\n label: primaryItem.config.name,\n 'inner-options': primaryItem.options\n };\n const id = `builder_panel_${primaryItem.id}`;\n return (0,external_window_wp_element_.createElement)(ct_panel.PanelMetaWrapper, InvisiblePanels_extends({\n id: id,\n key: primaryItem.id,\n option: option\n }, panelsActions, {\n getActualOption: () => (0,external_window_wp_element_.createElement)(external_window_wp_element_.Fragment, null, (0,external_window_wp_element_.createElement)(ct_panel[\"default\"], {\n id: id,\n getValues: () => {\n let itemValue = builderValue.items.find(_ref3 => {\n let {\n id\n } = _ref3;\n return id === primaryItem.id;\n });\n let itemsCount = '0';\n\n if (primaryItem.id === 'top-row' || primaryItem.id === 'middle-row' || primaryItem.id === 'bottom-row') {\n itemsCount = (builderValue.desktop.find(_ref4 => {\n let {\n id\n } = _ref4;\n return id === primaryItem.id;\n }).placements.reduce((r, p) => {\n return [...r, ...p.items];\n }, []).length + builderValue.mobile.find(_ref5 => {\n let {\n id\n } = _ref5;\n return id === primaryItem.id;\n }).placements.reduce((r, p) => {\n return [...r, ...p.items];\n }, []).length).toString();\n }\n\n if (itemValue && Object.keys(itemValue.values) > 5) {\n return InvisiblePanels_objectSpread({\n itemsCount,\n builderSettings: builderValue.settings || {}\n }, itemValue.values);\n }\n\n return InvisiblePanels_objectSpread(InvisiblePanels_objectSpread({}, (0,get_value_from_input/* getValueFromInput */.n6)(primaryItem.options, itemValue ? itemValue.values : {})), {}, {\n itemsCount,\n builderSettings: builderValue.settings || {}\n });\n },\n option: option,\n onChangeFor: (optionId, optionValue) => {\n const currentValue = builderValue.items.find(_ref6 => {\n let {\n id\n } = _ref6;\n return id === primaryItem.id;\n });\n builderValueDispatch({\n type: 'ITEM_VALUE_ON_CHANGE',\n payload: {\n id: primaryItem.id,\n optionId,\n optionValue,\n values: !currentValue || currentValue && Object.keys(currentValue.values).length === 0 ? (0,get_value_from_input/* getValueFromInput */.n6)(primaryItem.options, {}) : {}\n }\n });\n },\n view: \"simple\"\n }))\n }));\n }));\n};\n\n/* harmony default export */ const builder_sidebar_InvisiblePanels = (InvisiblePanels);\n;// CONCATENATED MODULE: ./static/js/customizer/panels-builder/placements/builder-sidebar/PanelsManager.js\nfunction PanelsManager_extends() { PanelsManager_extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return PanelsManager_extends.apply(this, arguments); }\n\n\n\n\n\n\n\n\nconst PanelsManager = () => {\n const secondaryItems = ct_customizer_localizations.header_builder_data.secondary_items.header;\n const allItems = ct_customizer_localizations.header_builder_data.header;\n const {\n builderValue,\n option,\n builderValueCollection,\n builderValueDispatch,\n panelsActions\n } = (0,external_window_wp_element_.useContext)(DragDropContext);\n const allSections = builderValueCollection.sections.filter(_ref => {\n let {\n id\n } = _ref;\n return id !== 'type-2' && id !== 'type-3' && id.indexOf('ct-custom') === -1;\n });\n return (0,external_window_wp_element_.createElement)(\"ul\", {\n className: classnames_default()('ct-panels-manager')\n }, allSections.map(_ref2 => {\n let {\n name,\n id\n } = _ref2;\n let panelLabel = name || {\n 'type-1': (0,external_window_wp_i18n_.__)('Global Header', 'blocksy')\n }[id] || id;\n const panelId = `builder_header_panel_${id}`;\n const headerOptions = ct_customizer_localizations.header_builder_data.header_data.header_options;\n const option = {\n label: panelLabel,\n 'inner-options': headerOptions\n };\n return (0,external_window_wp_element_.createElement)(ct_panel.PanelMetaWrapper, PanelsManager_extends({\n id: panelId,\n key: id,\n option: option\n }, panelsActions, {\n getActualOption: _ref3 => {\n let {\n open\n } = _ref3;\n return (0,external_window_wp_element_.createElement)(external_window_wp_element_.Fragment, null, Object.keys(headerOptions).length > 0 && id === builderValue.id && (0,external_window_wp_element_.createElement)(ct_panel[\"default\"], {\n id: panelId,\n getValues: () => builderValue.settings || {},\n option: option,\n onChangeFor: (optionId, optionValue) => {\n builderValueDispatch({\n type: 'BUILDER_GLOBAL_SETTING_ON_CHANGE',\n payload: {\n optionId,\n optionValue,\n values: (0,get_value_from_input/* getValueFromInput */.n6)(headerOptions, Array.isArray(builderValue.settings) ? {} : builderValue.settings || {})\n }\n });\n },\n view: \"simple\"\n }), id === builderValue.id && (0,external_window_wp_element_.createElement)(\"li\", {\n className: classnames_default()({\n active: id === builderValue.id,\n 'ct-global': id === 'type-1'\n }),\n onClick: () => {\n if (Object.keys(headerOptions).length > 0) {\n open();\n }\n }\n }, (0,external_window_wp_element_.createElement)(\"span\", {\n className: \"ct-panel-name\"\n }, panelLabel)));\n }\n }));\n }));\n};\n\n/* harmony default export */ const builder_sidebar_PanelsManager = (PanelsManager);\n;// CONCATENATED MODULE: ./static/js/customizer/panels-builder/placements/AvailableItems.js\n\n\n\n\n\n\n\n\n\n\nconst AvailableItems = _ref => {\n let {\n allBuilderSections,\n builderValue,\n builderValueDispatch,\n inlinedItemsFromBuilder\n } = _ref;\n // panels | items | options\n const [currentTab, setCurrentTab] = (0,external_window_wp_element_.useState)('items');\n const {\n builderValueCollection\n } = (0,external_window_wp_element_.useContext)(DragDropContext);\n const secondaryItems = ct_customizer_localizations.header_builder_data.secondary_items.header;\n const allItems = ct_customizer_localizations.header_builder_data.header;\n const headerOptions = ct_customizer_localizations.header_builder_data.header_data.header_options;\n return (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-available-items\"\n }, (0,external_window_wp_element_.createElement)(\"h3\", {\n className: \"ct-title\",\n dangerouslySetInnerHTML: {\n __html: (0,external_window_wp_i18n_.sprintf)((0,external_window_wp_i18n_.__)('Customizing: %s', 'blocksy'), `${(builderValueCollection.sections.find(_ref2 => {\n let {\n id\n } = _ref2;\n return id === builderValue.id;\n }) || {}).name || {\n 'type-1': (0,external_window_wp_i18n_.__)('Global Header', 'blocksy')\n }[builderValue.id] || builderValue.id}`)\n }\n }), (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-tabs\"\n }, (0,external_window_wp_element_.createElement)(\"ul\", null, ['items', 'panels'].map(tab => (0,external_window_wp_element_.createElement)(\"li\", {\n key: tab,\n onClick: e => {\n e.preventDefault();\n setCurrentTab(tab);\n },\n className: classnames_default()({\n active: tab === currentTab\n })\n }, {\n panels: (0,external_window_wp_i18n_.__)('Headers', 'blocksy'),\n items: (0,external_window_wp_i18n_.__)('Elements', 'blocksy')\n }[tab]))), (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-current-tab\"\n }, currentTab === 'panels' && (0,external_window_wp_element_.createElement)(external_window_wp_components_.Slot, {\n name: \"PlacementsBuilderPanelsManager\"\n }, fills => fills.length === 0 ? (0,external_window_wp_element_.createElement)(builder_sidebar_PanelsManager, null) : fills), (0,external_window_wp_element_.createElement)(builder_sidebar_SecondaryItems, {\n builderValue: builderValue,\n builderValueDispatch: builderValueDispatch,\n inlinedItemsFromBuilder: inlinedItemsFromBuilder,\n displayList: currentTab === 'items'\n }))), (0,external_window_wp_element_.createElement)(builder_sidebar_InvisiblePanels, {\n builderValue: builderValue,\n builderValueDispatch: builderValueDispatch\n }));\n};\n\n/* harmony default export */ const placements_AvailableItems = (AvailableItems);\n// EXTERNAL MODULE: ./node_modules/nanoid/index.browser.js\nvar index_browser = __webpack_require__(1496);\nvar index_browser_default = /*#__PURE__*/__webpack_require__.n(index_browser);\n;// CONCATENATED MODULE: ./static/js/customizer/panels-builder/placements/builderReducer.js\nfunction builderReducer_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction builderReducer_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? builderReducer_ownKeys(Object(source), !0).forEach(function (key) { builderReducer_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : builderReducer_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction builderReducer_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\nconst builderReducer = (builderValue, action) => {\n let updatedGlobalState = {};\n let newSections = [];\n let futureBuilderValue = builderValue.sections.find(_ref => {\n let {\n id\n } = _ref;\n return id.indexOf(builderValue.__forced_static_header__ || fetchCurrentHeader() || builderValue.sections[0].id) > -1;\n });\n let shouldUpdate = false;\n let updateItemId = false;\n let removeSectionIds = [];\n\n if (action.type === 'ITEM_VALUE_ON_CHANGE') {\n const {\n id,\n optionId,\n optionValue,\n values = {}\n } = action.payload;\n updateItemId = `${id}:${optionId}`;\n let items = futureBuilderValue.items;\n\n if (!items.find(_ref2 => {\n let {\n id: _id\n } = _ref2;\n return _id === id;\n })) {\n items = [...items, {\n id,\n values: {}\n }];\n }\n\n futureBuilderValue = builderReducer_objectSpread(builderReducer_objectSpread({}, futureBuilderValue), {}, {\n items: items.map(item => item.id === id ? builderReducer_objectSpread(builderReducer_objectSpread({}, item), {}, {\n values: builderReducer_objectSpread(builderReducer_objectSpread(builderReducer_objectSpread({}, item.values), values), {}, {\n [optionId]: optionValue\n })\n }) : item)\n });\n }\n\n if (action.type === 'PICK_BUILDER_SECTION') {\n shouldUpdate = true;\n updatedGlobalState = {\n __forced_static_header__: action.payload.id\n };\n }\n\n if (action.type === 'MARK_HEADER_AS_GLOBAL') {\n shouldUpdate = true;\n updatedGlobalState = {\n current_section: builderValue.__forced_static_header__\n };\n }\n\n if (action.type === 'MARK_SPECIFIC_HEADER_AS_GLOBAL') {\n updatedGlobalState = {\n current_section: action.payload.id\n };\n }\n\n if (action.type === 'CLONE_ITEM') {\n const futureId = (0,helpers/* getOriginalId */.t_)(action.payload.id);\n futureBuilderValue = builderReducer_objectSpread(builderReducer_objectSpread({}, futureBuilderValue), {}, {\n items: [...futureBuilderValue.items, {\n id: `${futureId}${(0,helpers/* customItemsSeparator */.SU)()}${index_browser_default()()}`,\n values: futureBuilderValue.items.find(_ref3 => {\n let {\n id\n } = _ref3;\n return id === futureId;\n }) ? futureBuilderValue.items.find(_ref4 => {\n let {\n id\n } = _ref4;\n return id === futureId;\n }).values : {}\n }]\n });\n }\n\n if (action.type === 'REMOVE_CLONED_ITEM') {\n futureBuilderValue = builderReducer_objectSpread(builderReducer_objectSpread({}, futureBuilderValue), {}, {\n items: futureBuilderValue.items.filter(_ref5 => {\n let {\n id\n } = _ref5;\n return id !== action.payload.id;\n })\n });\n }\n\n if (action.type === 'SET_LIST') {\n shouldUpdate = true;\n const {\n currentView,\n lists\n } = action.payload;\n\n if (\n /**\n * If we just inserted offcanvas trigger on desktop\n */\n currentView === 'desktop' && Object.values(lists).reduce((all, current) => [...all, ...current], []).indexOf('trigger') > -1 && !futureBuilderValue.desktop.find(_ref6 => {\n let {\n id\n } = _ref6;\n return id === 'offcanvas';\n })) {\n futureBuilderValue = builderReducer_objectSpread(builderReducer_objectSpread({}, futureBuilderValue), {}, {\n desktop: [...futureBuilderValue.desktop, {\n id: 'offcanvas',\n placements: [{\n id: 'start',\n items: []\n }]\n }]\n });\n }\n\n futureBuilderValue = builderReducer_objectSpread(builderReducer_objectSpread({}, futureBuilderValue), {}, {\n [currentView]: futureBuilderValue[currentView].map(_ref7 => {\n let {\n id: barId,\n placements\n } = _ref7;\n const keys = Object.keys(lists);\n\n if (keys.map(k => k.split(':')[0]).indexOf(barId) > -1) {\n let futureBar = {\n id: barId,\n placements: placements.map(_ref8 => {\n let {\n id,\n items\n } = _ref8;\n\n if (lists[`${barId}:${id}`]) {\n return {\n id,\n items: lists[`${barId}:${id}`]\n };\n }\n\n return {\n id,\n items\n };\n })\n };\n\n if (futureBar.placements.find(_ref9 => {\n let {\n id\n } = _ref9;\n return id === 'middle';\n }) && futureBar.placements.find(_ref10 => {\n let {\n id\n } = _ref10;\n return id === 'middle';\n }).items.length === 0 && futureBar.placements.find(_ref11 => {\n let {\n id\n } = _ref11;\n return id === 'start-middle';\n }) && (futureBar.placements.find(_ref12 => {\n let {\n id\n } = _ref12;\n return id === 'start-middle';\n }).items.length > 0 || futureBar.placements.find(_ref13 => {\n let {\n id\n } = _ref13;\n return id === 'end-middle';\n }).items.length > 0)) {\n let updater = {};\n updater[`${barId}:start`] = [...futureBar.placements.find(_ref14 => {\n let {\n id\n } = _ref14;\n return id === 'start';\n }).items, ...futureBar.placements.find(_ref15 => {\n let {\n id\n } = _ref15;\n return id === 'start-middle';\n }).items];\n updater[`${barId}:end`] = [...futureBar.placements.find(_ref16 => {\n let {\n id\n } = _ref16;\n return id === 'end-middle';\n }).items, ...futureBar.placements.find(_ref17 => {\n let {\n id\n } = _ref17;\n return id === 'end';\n }).items];\n updater[`${barId}:start-middle`] = [];\n updater[`${barId}:end-middle`] = [];\n futureBar = {\n id: barId,\n placements: futureBar.placements.map(_ref18 => {\n let {\n id,\n items\n } = _ref18;\n\n if (updater[`${barId}:${id}`]) {\n return {\n id,\n items: updater[`${barId}:${id}`]\n };\n }\n\n return {\n id,\n items\n };\n })\n };\n }\n\n return futureBar;\n }\n\n return {\n id: barId,\n placements\n };\n })\n });\n }\n\n if (action.type === 'BUILDER_GLOBAL_SETTING_ON_CHANGE') {\n const {\n optionId,\n optionValue,\n values = {}\n } = action.payload;\n futureBuilderValue = builderReducer_objectSpread(builderReducer_objectSpread({}, futureBuilderValue), {}, {\n settings: builderReducer_objectSpread(builderReducer_objectSpread(builderReducer_objectSpread({}, futureBuilderValue.settings), values), {}, {\n [optionId]: optionValue\n })\n });\n }\n\n if (action.type === 'CREATE_NEW_SECTION') {\n const {\n name,\n copy\n } = action.payload;\n newSections = [copy ? builderReducer_objectSpread(builderReducer_objectSpread({}, builderValue.sections.find(_ref19 => {\n let {\n id\n } = _ref19;\n return id === copy;\n }) || {}), {}, {\n name,\n id: `ct-custom-${index_browser_default()()}`\n }) : {\n name,\n id: `ct-custom-${index_browser_default()()}`,\n mode: 'placements',\n items: [],\n settings: [],\n desktop: [{\n id: 'top-row',\n placements: [{\n id: 'start',\n items: []\n }, {\n id: 'middle',\n items: []\n }, {\n id: 'end',\n items: []\n }, {\n id: 'start-middle',\n items: []\n }, {\n id: 'end-middle',\n items: []\n }]\n }, {\n id: 'middle-row',\n placements: [{\n id: 'start',\n items: ['logo']\n }, {\n id: 'middle',\n items: []\n }, {\n id: 'end',\n items: ['menu']\n }, {\n id: 'start-middle',\n items: []\n }, {\n id: 'end-middle',\n items: []\n }]\n }, {\n id: 'bottom-row',\n placements: [{\n id: 'start',\n items: []\n }, {\n id: 'middle',\n items: []\n }, {\n id: 'end',\n items: []\n }, {\n id: 'start-middle',\n items: []\n }, {\n id: 'end-middle',\n items: []\n }]\n }],\n mobile: [{\n id: 'top-row',\n placements: [{\n id: 'start',\n items: []\n }, {\n id: 'middle',\n items: []\n }, {\n id: 'end',\n items: []\n }, {\n id: 'start-middle',\n items: []\n }, {\n id: 'end-middle',\n items: []\n }]\n }, {\n id: 'middle-row',\n placements: [{\n id: 'start',\n items: ['logo']\n }, {\n id: 'middle',\n items: []\n }, {\n id: 'end',\n items: ['trigger']\n }, {\n id: 'start-middle',\n items: []\n }, {\n id: 'end-middle',\n items: []\n }]\n }, {\n id: 'bottom-row',\n placements: [{\n id: 'start',\n items: []\n }, {\n id: 'middle',\n items: []\n }, {\n id: 'end',\n items: []\n }, {\n id: 'start-middle',\n items: []\n }, {\n id: 'end-middle',\n items: []\n }]\n }, {\n id: 'offcanvas',\n placements: [{\n id: 'start',\n items: ['mobile-menu']\n }]\n }]\n }];\n }\n\n if (action.type === 'REMOVE_BUILDER_SECTION') {\n removeSectionIds.push(action.payload.id);\n }\n\n const actualBuilderValue = builderReducer_objectSpread(builderReducer_objectSpread(builderReducer_objectSpread({}, builderValue), updatedGlobalState), {}, {\n __should_refresh__: shouldUpdate,\n __should_refresh_item__: updateItemId,\n sections: [...builderValue.sections.map(builder => builder.id === futureBuilderValue.id ? futureBuilderValue : builder), ...newSections].filter(_ref20 => {\n let {\n id\n } = _ref20;\n return removeSectionIds.indexOf(id) === -1;\n })\n });\n\n return actualBuilderValue;\n};\n// EXTERNAL MODULE: ./static/js/customizer/components/useDeviceManager.js\nvar useDeviceManager = __webpack_require__(5458);\n// EXTERNAL MODULE: external \"ctEvents\"\nvar external_ctEvents_ = __webpack_require__(2243);\n;// CONCATENATED MODULE: ./static/js/customizer/panels-builder/placements/BuilderRoot.js\nconst BuilderRoot_excluded = [\"__forced_dynamic_header__\", \"__forced_static_header__\", \"__should_refresh__\"],\n _excluded2 = [\"__forced_dynamic_header__\", \"__forced_static_header__\", \"__should_refresh__\"];\n\nfunction BuilderRoot_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction BuilderRoot_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? BuilderRoot_ownKeys(Object(source), !0).forEach(function (key) { BuilderRoot_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : BuilderRoot_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction BuilderRoot_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction BuilderRoot_objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = BuilderRoot_objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction BuilderRoot_objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\n\n\n\n\n\n\n\n\nconst DragDropContext = (0,external_window_wp_element_.createContext)({});\n\nconst getDocument = x => x.document || x.contentDocument || x.contentWindow.document;\n\nconst fetchCurrentHeader = () => {\n const document = getDocument(wp.customize.previewer.container.find('iframe')[0]);\n\n if (wp.customize.previewer.container.find('iframe')[0].contentDocument.querySelector('header#header')) {\n return wp.customize.previewer.container.find('iframe')[0].contentDocument.querySelector('header#header').dataset.id;\n }\n\n return null;\n};\n\nconst BuilderRoot = _ref => {\n let {\n value: allBuilderSections,\n option,\n onChange: onBuilderValueChange\n } = _ref;\n const currentHeader = (0,external_window_wp_element_.useRef)(null);\n\n if (currentHeader.current === null) {\n currentHeader.current = (allBuilderSections.sections.find(_ref2 => {\n let {\n id\n } = _ref2;\n return id.indexOf(fetchCurrentHeader()) > -1;\n }) || allBuilderSections.sections[0]).id;\n }\n\n (0,external_window_wp_element_.useEffect)(() => {\n let _wp$customize = wp.customize('header_placements')(),\n {\n __forced_dynamic_header__,\n __forced_static_header__,\n __should_refresh__\n } = _wp$customize,\n old = BuilderRoot_objectWithoutProperties(_wp$customize, BuilderRoot_excluded);\n\n Object.keys(old).map(key => {\n if (parseFloat(key)) {\n delete old[key];\n }\n });\n\n try {\n wp.customize('header_placements')(BuilderRoot_objectSpread(BuilderRoot_objectSpread({}, old), {}, {\n __forced_static_header__: (allBuilderSections.sections.find(_ref3 => {\n let {\n id\n } = _ref3;\n return id.indexOf(fetchCurrentHeader()) > -1;\n }) || allBuilderSections.sections[0]).id\n }));\n } catch (e) {\n console.error(e);\n }\n\n return () => {\n const _wp$customize2 = wp.customize('header_placements')(),\n {\n __forced_dynamic_header__,\n __forced_static_header__,\n __should_refresh__\n } = _wp$customize2,\n old = BuilderRoot_objectWithoutProperties(_wp$customize2, _excluded2);\n\n wp.customize('header_placements')(BuilderRoot_objectSpread({\n __should_refresh__: true,\n [Math.random()]: 'update'\n }, old));\n };\n }, []);\n const [isDragging, setIsDragging] = (0,external_window_wp_element_.useState)(false);\n const [builderValueCollection, builderValueDispatchInternal] = (0,external_window_wp_element_.useReducer)(builderReducer, BuilderRoot_objectSpread(BuilderRoot_objectSpread({}, allBuilderSections), currentHeader.current ? {\n __forced_static_header__: currentHeader.current\n } : {}));\n const builderValue = (0,external_window_wp_element_.useMemo)(() => builderValueCollection.sections.find(_ref4 => {\n let {\n id\n } = _ref4;\n return id === builderValueCollection.__forced_static_header__;\n }) || builderValueCollection.sections[0], [builderValueCollection]); // desktop | mobile\n\n const [currentView, setCurrentView] = (0,useDeviceManager/* useDeviceManager */.Or)({\n withTablet: false\n });\n const inlinedItemsFromBuilder = (0,external_window_wp_element_.useMemo)(() => builderValue[currentView].reduce((currentItems, _ref5) => {\n let {\n id,\n placements\n } = _ref5;\n return [...currentItems, ...(placements || []).reduce((c, _ref6) => {\n let {\n id,\n items\n } = _ref6;\n return [...c, ...items];\n }, [])];\n }, []), [builderValue, currentView]);\n const builderValueDispatch = (0,external_window_wp_element_.useCallback)(action => {\n let newState = builderReducer(builderValueCollection, action);\n\n if (action.type === 'ITEM_VALUE_ON_CHANGE') {\n const {\n id,\n optionId,\n optionValue,\n values = {}\n } = action.payload;\n const builderValue = newState.sections.find(_ref7 => {\n let {\n id\n } = _ref7;\n return id === newState.__forced_static_header__;\n }) || newState.sections[0];\n let items = builderValue.items;\n\n if (id === 'logo' && optionId === 'custom_logo' && builderValue.id === 'type-1') {\n wp.customize && wp.customize('custom_logo')(optionValue ? optionValue.desktop ? optionValue.desktop : optionValue : '');\n }\n\n wp.customize.previewer && wp.customize.previewer.send('ct:header:receive-value-update', {\n itemId: id,\n optionId,\n optionValue,\n futureItems: builderValue.items,\n values: BuilderRoot_objectSpread(BuilderRoot_objectSpread(BuilderRoot_objectSpread({}, (items.find(_ref8 => {\n let {\n id: _id\n } = _ref8;\n return id === _id;\n }) || {\n values: {}\n }).values), values), {}, {\n [optionId]: optionValue\n })\n });\n }\n\n if (action.type === 'BUILDER_GLOBAL_SETTING_ON_CHANGE') {\n const {\n optionId,\n optionValue,\n values = {}\n } = action.payload;\n const builderValue = newState.sections.find(_ref9 => {\n let {\n id\n } = _ref9;\n return id === newState.__forced_static_header__;\n }) || newState.sections[0];\n wp.customize.previewer && wp.customize.previewer.send('ct:header:receive-value-update', {\n itemId: 'global',\n optionId,\n optionValue,\n values: BuilderRoot_objectSpread(BuilderRoot_objectSpread(BuilderRoot_objectSpread({}, builderValue.settings), values), {}, {\n [optionId]: optionValue\n })\n });\n }\n\n onBuilderValueChange(newState);\n builderValueDispatchInternal(action);\n }, [builderValueDispatchInternal, onBuilderValueChange, builderValueCollection]);\n const setList = (0,external_window_wp_element_.useCallback)(lists => builderValueDispatch({\n type: 'SET_LIST',\n payload: {\n currentView,\n lists\n }\n }), [builderValueDispatch, currentView]);\n return (0,external_window_wp_element_.createElement)(external_window_wp_element_.Fragment, null, (0,external_window_wp_element_.createElement)(DragDropContext.Provider, {\n value: {\n option,\n currentView,\n isDragging,\n setIsDragging,\n setList,\n builderValueDispatch,\n builderValue,\n onChange: _ref10 => {\n let {\n id,\n value\n } = _ref10;\n return setList({\n [id]: value\n });\n },\n builderValueCollection\n }\n }, (0,external_window_wp_element_.createElement)(placements_AvailableItems, {\n allBuilderSections: allBuilderSections,\n builderValue: builderValue,\n inlinedItemsFromBuilder: inlinedItemsFromBuilder,\n builderValueDispatch: builderValueDispatch\n }), (0,external_window_wp_element_.createPortal)((0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-builder-header\"\n }, (0,external_window_wp_element_.createElement)(placements_ViewSwitch, {\n currentView: currentView,\n setCurrentView: setCurrentView\n }), (0,external_window_wp_element_.createElement)(placements_PlacementsBuilder, {\n inlinedItemsFromBuilder: inlinedItemsFromBuilder,\n builderValueWithView: builderValue[currentView],\n view: currentView\n })), document.querySelector('.ct-panel-builder'))));\n};\n\n/* harmony default export */ const placements_BuilderRoot = (BuilderRoot);\n;// CONCATENATED MODULE: ./static/js/options/options/ct-header-builder.js\n\n\n\nconst HeaderBuilder = props => (0,external_window_wp_element_.createElement)(placements_BuilderRoot, props);\n\nHeaderBuilder.renderingConfig = {\n design: 'none'\n};\n/* harmony default export */ const ct_header_builder = (HeaderBuilder);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"5565.js","mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACxCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9OA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACpEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;AC/ZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./static/js/customizer/panels-builder/placements/DraggableItems.js?4475","webpack://blocksyOptions/./static/js/customizer/panels-builder/placements/PlacementsBuilder/PrimaryPlacement.js?1198","webpack://blocksyOptions/./static/js/customizer/panels-builder/placements/PlacementsBuilder/Row.js?a24f","webpack://blocksyOptions/./static/js/customizer/panels-builder/placements/PlacementsBuilder.js?f163","webpack://blocksyOptions/./static/js/customizer/panels-builder/placements/ViewSwitch.js?6170","webpack://blocksyOptions/./static/js/customizer/panels-builder/placements/builder-sidebar/SecondaryItems.js?0c71","webpack://blocksyOptions/./static/js/customizer/panels-builder/placements/builder-sidebar/InvisiblePanels.js?770c","webpack://blocksyOptions/./static/js/customizer/panels-builder/placements/builder-sidebar/PanelsManager.js?22f2","webpack://blocksyOptions/./static/js/customizer/panels-builder/placements/AvailableItems.js?c3e5","webpack://blocksyOptions/./static/js/customizer/panels-builder/placements/builderReducer.js?49af","webpack://blocksyOptions/./static/js/customizer/panels-builder/placements/BuilderRoot.js?3e7c","webpack://blocksyOptions/./static/js/options/options/ct-header-builder.js?aa29"],"sourcesContent":["const _excluded = [\"items\", \"draggableId\", \"hasPointers\", \"className\", \"tagName\", \"direction\", \"group\", \"options\", \"propsForItem\", \"displayWrapper\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport { createElement, useContext, Fragment } from '@wordpress/element';\nimport cls from 'classnames';\nimport Sortable from './Sortable';\nimport { DragDropContext } from './BuilderRoot';\nimport { PanelContext } from '../../../options/components/PanelLevel';\nimport { customItemsSeparator, getOriginalId } from './helpers';\nimport { capitalizeFirstLetter } from '../../../options/helpers/get-label';\n\nconst isItemAllowedIn = (itemId, barId, currentView) => {\n  const item = ct_customizer_localizations.header_builder_data.header.find(_ref => {\n    let {\n      id\n    } = _ref;\n    return id === getOriginalId(itemId);\n  });\n\n  if (!item) {\n    return true;\n  }\n\n  let allowed_in = [];\n\n  if (Array.isArray(item.config.allowed_in)) {\n    allowed_in = item.config.allowed_in;\n  } else {\n    if (item.config.allowed_in[currentView]) {\n      allowed_in = item.config.allowed_in[currentView];\n    }\n  }\n\n  const allowedRespected = allowed_in.length > 0 ? allowed_in.indexOf(barId) > -1 : true;\n  const exclusionRespected = item.config.excluded_from.length > 0 ? item.config.excluded_from.indexOf(barId) === -1 : true;\n  return allowedRespected && exclusionRespected;\n};\n\nexport const DraggableItem = _ref2 => {\n  var _itemData$config$name, _itemData$config, _itemData$config$name2, _itemData$config2;\n\n  let {\n    item,\n    index,\n    panelType,\n    onRemove,\n    renderItem,\n    onClick,\n    className\n  } = _ref2;\n  const itemData = ct_customizer_localizations.header_builder_data[panelType].find(_ref3 => {\n    let {\n      id\n    } = _ref3;\n    return id === getOriginalId(item);\n  });\n  const {\n    builderValue\n  } = useContext(DragDropContext);\n\n  if (renderItem) {\n    return renderItem({\n      item,\n      itemData,\n      index\n    });\n  }\n  /**\n   * Dynamic items have a : in their ID\n   */\n\n\n  const allDynamicItems = builderValue.items.filter(_ref4 => {\n    let {\n      id\n    } = _ref4;\n    return id.indexOf(customItemsSeparator()) > -1;\n  }).map(_ref5 => {\n    let {\n      id\n    } = _ref5;\n    return id;\n  });\n  const allClonesAndOriginal = [getOriginalId(item), ...allDynamicItems.filter(id => getOriginalId(id) === getOriginalId(item))];\n  const beautyItem = capitalizeFirstLetter(getOriginalId(item));\n  return createElement(\"div\", {\n    \"data-id\": item,\n    className: cls('ct-builder-item', className, {// 'ct-is-dragging': snapshot.isDragging\n    }),\n    onClick: onClick\n  }, allClonesAndOriginal.length > 1 ? `${(_itemData$config$name = itemData === null || itemData === void 0 ? void 0 : (_itemData$config = itemData.config) === null || _itemData$config === void 0 ? void 0 : _itemData$config.name) !== null && _itemData$config$name !== void 0 ? _itemData$config$name : beautyItem} ${allClonesAndOriginal.indexOf(item) + 1}` : (_itemData$config$name2 = itemData === null || itemData === void 0 ? void 0 : (_itemData$config2 = itemData.config) === null || _itemData$config2 === void 0 ? void 0 : _itemData$config2.name) !== null && _itemData$config$name2 !== void 0 ? _itemData$config$name2 : beautyItem, createElement(\"button\", {\n    className: \"ct-btn-remove\",\n    onClick: e => {\n      e.preventDefault();\n      e.stopPropagation();\n      onRemove();\n    }\n  }));\n};\n\nconst DraggableItems = _ref6 => {\n  let {\n    items,\n    draggableId,\n    hasPointers = true,\n    className,\n    tagName = 'div',\n    direction = 'horizontal',\n    group = 'header_sortables',\n    options = {},\n    propsForItem = item => ({}),\n    displayWrapper = true\n  } = _ref6,\n      props = _objectWithoutProperties(_ref6, _excluded);\n\n  const {\n    currentView,\n    isDragging,\n    setIsDragging,\n    onChange,\n    setList\n  } = useContext(DragDropContext);\n  const {\n    panelsHelpers\n  } = useContext(PanelContext);\n  const itemsOutput = items.map((item, index) => createElement(DraggableItem, _extends({\n    key: item,\n    index: index,\n    panelType: 'header',\n    item: item,\n    className: panelsHelpers.isOpenFor(`builder_panel_${item}`) ? 'ct-customizing' : '',\n    onClick: e => {\n      e.stopPropagation();\n      e.preventDefault();\n\n      if (isDragging) {\n        return;\n      }\n\n      panelsHelpers.open(`builder_panel_${item}`);\n    },\n    onRemove: () => {\n      panelsHelpers.close();\n      setList(_objectSpread({\n        [draggableId]: items.filter(id => id !== item)\n      }, currentView === 'desktop' && item === 'trigger' ? {\n        ['offcanvas:start']: []\n      } : {}));\n    }\n  }, propsForItem(item))));\n\n  if (!displayWrapper) {\n    return createElement(Fragment, null, itemsOutput);\n  }\n\n  return createElement(Sortable, _extends({\n    options: _objectSpread({\n      delay: 0,\n      group,\n      fallbackOnBody: true,\n      forceFallback: true,\n      fallbackTolerance: 5,\n      filter: '.ct-pointer',\n      direction,\n      touchStartThreshold: 5,\n      onStart: event => {\n        setIsDragging(event.item.dataset.id);\n        let currentView = wp.customize.previewedDevice();\n\n        if (currentView === 'tablet') {\n          currentView = 'mobile';\n        }\n\n        if (isItemAllowedIn(event.item.dataset.id, 'middle-row', currentView)) {\n          document.body.classList.add('ct-builder-dragging');\n        }\n\n        if (event.from && group && group.pull !== 'clone') {\n          event.to.classList.add('ct-is-over');\n        }\n      },\n      onEnd: () => {\n        setIsDragging(false);\n        document.body.classList.remove('ct-builder-dragging');\n        [...document.querySelectorAll('.ct-panel-builder .ct-is-over')].map(el => el.classList.remove('ct-is-over'));\n      },\n      onMove: (event, originalEvent) => {\n        let currentView = wp.customize.previewedDevice();\n\n        if (currentView === 'tablet') {\n          currentView = 'mobile';\n        }\n\n        if (event.from.closest('#ct-option-header-builder-items')) {\n          Promise.resolve().then(() => [...event.from.querySelectorAll(`[data-id=\"${event.dragged.dataset.id}\"]`)].map(el => {\n            el.classList.remove('ct-builder-item');\n            el.classList.add('ct-item-in-builder');\n          }));\n        }\n\n        ;\n        [...document.querySelectorAll('.ct-panel-builder .ct-is-over')].map(el => el.classList.remove('ct-is-over'));\n\n        if (event.to) {\n          event.to.classList.add('ct-is-over');\n        }\n\n        if (!isItemAllowedIn(event.dragged.dataset.id, event.to.dataset.id.split(':')[0], currentView)) {\n          return false;\n        }\n      }\n    }, options),\n    onChange: (order, sortable, evt) => {\n      // console.log('here is change', order, draggableId)\n      if (draggableId === 'available-items') {\n        return;\n      }\n\n      onChange({\n        id: draggableId,\n        value: order.filter(i => i !== '__pointer__' && i !== '__filler__')\n      });\n    },\n    tag: tagName,\n    className: cls('ct-builder-items', className)\n  }, props, {\n    \"data-id\": draggableId\n  }), ['end', 'start-middle'].indexOf(draggableId.split(':')[1]) > -1 && createElement(\"div\", {\n    \"data-id\": \"__filler__\",\n    className: \"ct-filler\"\n  }), hasPointers && isDragging && isItemAllowedIn(isDragging, draggableId.split(':')[0], currentView) && createElement(\"div\", {\n    \"data-id\": \"__pointer__\",\n    className: \"ct-pointer\"\n  }), itemsOutput);\n};\n\nexport default DraggableItems;","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport { createElement } from '@wordpress/element';\nimport DraggableItems from '../DraggableItems';\n\nconst PrimaryPlacement = _ref => {\n  let {\n    placementName,\n    bar,\n    direction\n  } = _ref;\n  const placement = bar.placements.find(_ref2 => {\n    let {\n      id\n    } = _ref2;\n    return id === placementName;\n  });\n  let placementsToRender = [placement];\n\n  if (placementName !== 'middle') {\n    const middle = bar.placements.find(_ref3 => {\n      let {\n        id\n      } = _ref3;\n      return id === 'middle';\n    });\n\n    if (middle && middle.items.length > 0) {\n      if (placementName === 'start') {\n        const startMiddle = bar.placements.find(_ref4 => {\n          let {\n            id\n          } = _ref4;\n          return id === 'start-middle';\n        });\n        placementsToRender = [placement, startMiddle];\n      }\n\n      if (placementName === 'end') {\n        const endMiddle = bar.placements.find(_ref5 => {\n          let {\n            id\n          } = _ref5;\n          return id === 'end-middle';\n        });\n        placementsToRender = [endMiddle, placement];\n      }\n    }\n  }\n\n  return createElement(\"li\", _extends({\n    className: [`ct-builder-column-${placement.id}`]\n  }, placement.id === 'middle' ? {\n    'data-count': placement.items.length\n  } : {}), placementsToRender.map(placement => createElement(DraggableItems, {\n    key: placement.id,\n    direction: direction,\n    className: placement.id === 'middle' ? '' : `ct-${placement.id.indexOf('-') > -1 ? 'secondary' : 'primary'}-column`,\n    draggableId: `${bar.id}:${placement.id}`,\n    items: placement.items\n  })));\n};\n\nexport default PrimaryPlacement;","import { createElement, useContext } from '@wordpress/element';\nimport { __ } from 'ct-i18n';\nimport { PanelContext } from '../../../../options/components/PanelLevel';\nimport PrimaryPlacement from './PrimaryPlacement';\n\nconst Row = _ref => {\n  let {\n    bar,\n    direction = 'horizontal'\n  } = _ref;\n  const {\n    panelsHelpers\n  } = useContext(PanelContext);\n  return createElement(\"li\", {\n    className: \"builder-row\"\n  }, createElement(\"div\", {\n    className: \"ct-row-actions\",\n    onClick: () => panelsHelpers.open(`builder_panel_${bar.id}`)\n  }, {\n    'top-row': __('Top Row', 'blocksy'),\n    'middle-row': __('Main Row', 'blocksy'),\n    'bottom-row': __('Bottom Row', 'blocksy'),\n    offcanvas: __('Off Canvas Area', 'blocksy')\n  }[bar.id]), createElement(\"ul\", {\n    className: \"row-inner\"\n  }, ['start', 'middle', 'end'].filter(placementName => !!bar.placements.find(_ref2 => {\n    let {\n      id\n    } = _ref2;\n    return id === placementName;\n  })).map(placementName => createElement(PrimaryPlacement, {\n    key: placementName,\n    bar: bar,\n    placementName: placementName,\n    direction: direction\n  }))));\n};\n\nexport default Row;","import { createElement, useContext } from '@wordpress/element';\nimport { __ } from 'ct-i18n';\nimport cls from 'classnames';\nimport DraggableItems from './DraggableItems';\nimport Row from './PlacementsBuilder/Row';\n\nconst PlacementsBuilder = _ref => {\n  let {\n    inlinedItemsFromBuilder,\n    view,\n    builderValueWithView\n  } = _ref;\n  let hasOffcanvas = view === 'mobile' || inlinedItemsFromBuilder.indexOf('trigger') > -1 && builderValueWithView.find(_ref2 => {\n    let {\n      id\n    } = _ref2;\n    return id === 'offcanvas';\n  });\n  return createElement(\"div\", {\n    className: cls('placements-builder', {\n      'ct-mobile': hasOffcanvas\n    })\n  }, hasOffcanvas && createElement(\"ul\", {\n    className: \"offcanvas-container\"\n  }, createElement(Row, {\n    direction: \"vertical\",\n    bar: builderValueWithView.find(_ref3 => {\n      let {\n        id\n      } = _ref3;\n      return id === 'offcanvas';\n    })\n  })), createElement(\"ul\", {\n    className: \"horizontal-rows\"\n  }, ['top-row', 'middle-row', 'bottom-row'].map(bar => {\n    const maybeBar = builderValueWithView.find(_ref4 => {\n      let {\n        id\n      } = _ref4;\n      return id === bar;\n    });\n\n    if (!maybeBar) {\n      return null;\n    }\n\n    return createElement(Row, {\n      bar: maybeBar,\n      key: bar\n    });\n  })));\n};\n\nexport default PlacementsBuilder;","import { createElement, useState, useEffect } from '@wordpress/element';\nimport cls from 'classnames';\nimport { __ } from 'ct-i18n';\n\nconst ViewSwitch = _ref => {\n  let {\n    currentView,\n    setCurrentView\n  } = _ref;\n  const [builderCollapsed, setBuilderCollapsed] = useState(false);\n  useEffect(() => {\n    return () => {\n      document.querySelector('.wp-full-overlay').classList.remove('ct-builder-collapsed');\n    };\n  }, []);\n  return createElement(\"ul\", {\n    className: \"ct-view-switch\"\n  }, ['desktop', 'mobile'].map(view => createElement(\"li\", {\n    key: view,\n    onClick: () => setCurrentView(view === 'mobile' ? 'tablet' : view),\n    className: cls({\n      active: currentView === view\n    })\n  }, {\n    desktop: __('Desktop Header', 'blocksy'),\n    mobile: __('Tablet / Mobile Header', 'blocksy')\n  }[view])), createElement(\"li\", {\n    className: \"ct-builder-toggle\",\n    onClick: () => {\n      setBuilderCollapsed(!builderCollapsed);\n\n      if (builderCollapsed) {\n        document.querySelector('.wp-full-overlay').classList.remove('ct-builder-collapsed');\n      } else {\n        document.querySelector('.wp-full-overlay').classList.add('ct-builder-collapsed');\n      }\n    }\n  }, builderCollapsed ? __('Show Builder', 'blocksy') : __('Hide Builder', 'blocksy')));\n};\n\nexport default ViewSwitch;","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, Component, useState, useContext, Fragment } from '@wordpress/element';\nimport DraggableItems from '../DraggableItems';\nimport { DragDropContext } from '../BuilderRoot';\nimport cls from 'classnames';\nimport Panel, { PanelMetaWrapper } from '../../../../options/options/ct-panel';\nimport { getValueFromInput } from '../../../../options/helpers/get-value-from-input';\nimport { getOriginalId, customItemsSeparator } from '../helpers';\nimport { Slot } from '@wordpress/components';\n\nconst SecondaryItems = _ref => {\n  let {\n    builderValue,\n    builderValueDispatch,\n    inlinedItemsFromBuilder,\n    displayList = true\n  } = _ref;\n  const {\n    panelsState,\n    panelsActions,\n    currentView,\n    isDragging\n  } = useContext(DragDropContext);\n  const inlinedItemsFromAllViewsBuilder = [...builderValue.desktop.reduce((currentItems, _ref2) => {\n    let {\n      id,\n      placements\n    } = _ref2;\n    return [...currentItems, ...(placements || []).reduce((c, _ref3) => {\n      let {\n        id,\n        items\n      } = _ref3;\n      return [...c, ...items];\n    }, [])];\n  }, []), ...builderValue.mobile.reduce((currentItems, _ref4) => {\n    let {\n      id,\n      placements\n    } = _ref4;\n    return [...currentItems, ...(placements || []).reduce((c, _ref5) => {\n      let {\n        id,\n        items\n      } = _ref5;\n      return [...c, ...items];\n    }, [])];\n  }, [])];\n  const secondaryItems = ct_customizer_localizations.header_builder_data.secondary_items.header.filter(_ref6 => {\n    let {\n      config\n    } = _ref6;\n    return (// config.devices.indexOf(currentView) > -1 &&\n      config.enabled\n    );\n  });\n  const allItems = ct_customizer_localizations.header_builder_data.header;\n  /**\n   * Dynamic items have a : in their ID\n   */\n\n  const allDynamicItems = builderValue.items.filter(_ref7 => {\n    let {\n      id\n    } = _ref7;\n    return id.indexOf(customItemsSeparator()) > -1;\n  }).map(_ref8 => {\n    let {\n      id\n    } = _ref8;\n    return id;\n  });\n  return createElement(DraggableItems, {\n    options: {\n      sort: false,\n      filter: '.ct-item-in-builder'\n    },\n    group: {\n      name: 'header_sortables',\n      put: false,\n      pull: 'clone'\n    },\n    draggableId: 'available-items',\n    items: [...secondaryItems.map(_ref9 => {\n      let {\n        id\n      } = _ref9;\n      return id;\n    }), ...allDynamicItems].filter(el => allItems.some(_ref10 => {\n      let {\n        id\n      } = _ref10;\n      return id === getOriginalId(el);\n    })).sort((a, b) => {\n      const aItemData = allItems.find(_ref11 => {\n        let {\n          id\n        } = _ref11;\n        return id === getOriginalId(a);\n      });\n      const bItemData = allItems.find(_ref12 => {\n        let {\n          id\n        } = _ref12;\n        return id === getOriginalId(b);\n      });\n      return aItemData.config.name.localeCompare(bItemData.config.name);\n    }),\n    hasPointers: false,\n    displayWrapper: displayList,\n    propsForItem: item => ({\n      renderItem: _ref13 => {\n        let {\n          item,\n          itemData,\n          index\n        } = _ref13;\n        const itemOptions = allItems.find(_ref14 => {\n          let {\n            id\n          } = _ref14;\n          return id === getOriginalId(item);\n        }).options;\n        const allClonesAndOriginal = [getOriginalId(item), ...allDynamicItems.filter(id => getOriginalId(id) === getOriginalId(item))];\n        const itemName = allClonesAndOriginal.length > 1 ? `${itemData.config.name} ${allClonesAndOriginal.indexOf(item) + 1}` : itemData.config.name;\n        const option = {\n          label: itemName,\n          'inner-options': itemOptions\n        };\n        const itemInBuilder = inlinedItemsFromBuilder.indexOf(item) > -1;\n        let row = '__none__';\n\n        if (itemInBuilder) {\n          row = builderValue[currentView].find(_ref15 => {\n            let {\n              id,\n              placements\n            } = _ref15;\n            const rowItems = (placements || []).reduce((c, _ref16) => {\n              let {\n                id,\n                items\n              } = _ref16;\n              return [...c, ...items];\n            }, []);\n            return rowItems.find(i => i === item);\n          }).id;\n        }\n\n        const id = `builder_panel_${item}`;\n        const itemsOnlyWithTrigger = ['mobile-menu', 'mobile-menu-secondary', 'offcanvas-logo'];\n        const isSidebarRepresentationPresent = displayList && itemData.config.devices.includes(currentView) && (!itemsOnlyWithTrigger.includes(item) || itemsOnlyWithTrigger.includes(item) && (currentView !== 'desktop' || inlinedItemsFromBuilder.indexOf('trigger') > -1));\n        let itemTitle = itemData.config.name;\n        return createElement(PanelMetaWrapper, _extends({\n          id: id,\n          option: option\n        }, panelsActions, {\n          getActualOption: _ref17 => {\n            let {\n              open\n            } = _ref17;\n            return createElement(Fragment, null, inlinedItemsFromAllViewsBuilder.indexOf(item) > -1 && createElement(Panel, {\n              id: id,\n              getValues: () => {\n                let itemValue = builderValue.items.find(_ref18 => {\n                  let {\n                    id\n                  } = _ref18;\n                  return id === item;\n                });\n\n                if (itemValue && Object.keys(itemValue.values) > 5) {\n                  return _objectSpread({\n                    builderSettings: builderValue.settings || {},\n                    row\n                  }, itemValue.values);\n                }\n\n                return _objectSpread(_objectSpread({}, getValueFromInput(itemOptions, itemValue ? itemValue.values : {})), {}, {\n                  row,\n                  builderSettings: builderValue.settings || {}\n                });\n              },\n              option: option,\n              onChangeFor: (optionId, optionValue) => {\n                const currentValue = builderValue.items.find(_ref19 => {\n                  let {\n                    id\n                  } = _ref19;\n                  return id === item;\n                });\n                builderValueDispatch({\n                  type: 'ITEM_VALUE_ON_CHANGE',\n                  payload: {\n                    id: item,\n                    optionId,\n                    optionValue,\n                    values: !currentValue || currentValue && Object.keys(currentValue.values).length === 0 ? getValueFromInput(itemOptions, {}) : {}\n                  }\n                });\n              },\n              view: \"simple\"\n            }), isSidebarRepresentationPresent && createElement(\"div\", {\n              \"data-id\": item,\n              className: cls({\n                'ct-item-in-builder': itemInBuilder,\n                'ct-builder-item': !itemInBuilder\n              }),\n              onClick: e => {\n                if (isDragging) {\n                  return;\n                }\n\n                itemInBuilder && open();\n              }\n            }, itemName, createElement(Slot, {\n              name: `PlacementsBuilderSidebarItem_${index}`,\n              fillProps: {\n                item,\n                itemInBuilder,\n                itemData\n              }\n            })));\n          }\n        }));\n      }\n    }),\n    direction: \"vertical\"\n  });\n};\n\nexport default SecondaryItems;","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, Component, useState, useContext, Fragment } from '@wordpress/element';\nimport cls from 'classnames';\nimport Panel, { PanelMetaWrapper } from '../../../../options/options/ct-panel';\nimport { getValueFromInput } from '../../../../options/helpers/get-value-from-input';\nimport { DragDropContext } from '../BuilderRoot';\n\nconst InvisiblePanels = _ref => {\n  let {\n    builderValue,\n    builderValueDispatch\n  } = _ref;\n  const secondaryItems = ct_customizer_localizations.header_builder_data.secondary_items.header;\n  const allItems = ct_customizer_localizations.header_builder_data.header;\n  const {\n    panelsState,\n    panelsActions\n  } = useContext(DragDropContext);\n  const primaryItems = allItems.filter(_ref2 => {\n    let {\n      id\n    } = _ref2;\n    return !secondaryItems.find(item => item.id === id);\n  });\n  return createElement(Fragment, null, primaryItems.map(primaryItem => {\n    const option = {\n      label: primaryItem.config.name,\n      'inner-options': primaryItem.options\n    };\n    const id = `builder_panel_${primaryItem.id}`;\n    return createElement(PanelMetaWrapper, _extends({\n      id: id,\n      key: primaryItem.id,\n      option: option\n    }, panelsActions, {\n      getActualOption: () => createElement(Fragment, null, createElement(Panel, {\n        id: id,\n        getValues: () => {\n          let itemValue = builderValue.items.find(_ref3 => {\n            let {\n              id\n            } = _ref3;\n            return id === primaryItem.id;\n          });\n          let itemsCount = '0';\n\n          if (primaryItem.id === 'top-row' || primaryItem.id === 'middle-row' || primaryItem.id === 'bottom-row') {\n            itemsCount = (builderValue.desktop.find(_ref4 => {\n              let {\n                id\n              } = _ref4;\n              return id === primaryItem.id;\n            }).placements.reduce((r, p) => {\n              return [...r, ...p.items];\n            }, []).length + builderValue.mobile.find(_ref5 => {\n              let {\n                id\n              } = _ref5;\n              return id === primaryItem.id;\n            }).placements.reduce((r, p) => {\n              return [...r, ...p.items];\n            }, []).length).toString();\n          }\n\n          if (itemValue && Object.keys(itemValue.values) > 5) {\n            return _objectSpread({\n              itemsCount,\n              builderSettings: builderValue.settings || {}\n            }, itemValue.values);\n          }\n\n          return _objectSpread(_objectSpread({}, getValueFromInput(primaryItem.options, itemValue ? itemValue.values : {})), {}, {\n            itemsCount,\n            builderSettings: builderValue.settings || {}\n          });\n        },\n        option: option,\n        onChangeFor: (optionId, optionValue) => {\n          const currentValue = builderValue.items.find(_ref6 => {\n            let {\n              id\n            } = _ref6;\n            return id === primaryItem.id;\n          });\n          builderValueDispatch({\n            type: 'ITEM_VALUE_ON_CHANGE',\n            payload: {\n              id: primaryItem.id,\n              optionId,\n              optionValue,\n              values: !currentValue || currentValue && Object.keys(currentValue.values).length === 0 ? getValueFromInput(primaryItem.options, {}) : {}\n            }\n          });\n        },\n        view: \"simple\"\n      }))\n    }));\n  }));\n};\n\nexport default InvisiblePanels;","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport { createElement, Component, useState, useContext, Fragment } from '@wordpress/element';\nimport { DragDropContext } from '../BuilderRoot';\nimport cls from 'classnames';\nimport Panel, { PanelMetaWrapper } from '../../../../options/options/ct-panel';\nimport { getValueFromInput } from '../../../../options/helpers/get-value-from-input';\nimport { __ } from 'ct-i18n';\n\nconst PanelsManager = () => {\n  const secondaryItems = ct_customizer_localizations.header_builder_data.secondary_items.header;\n  const allItems = ct_customizer_localizations.header_builder_data.header;\n  const {\n    builderValue,\n    option,\n    builderValueCollection,\n    builderValueDispatch,\n    panelsActions\n  } = useContext(DragDropContext);\n  const allSections = builderValueCollection.sections.filter(_ref => {\n    let {\n      id\n    } = _ref;\n    return id !== 'type-2' && id !== 'type-3' && id.indexOf('ct-custom') === -1;\n  });\n  return createElement(\"ul\", {\n    className: cls('ct-panels-manager')\n  }, allSections.map(_ref2 => {\n    let {\n      name,\n      id\n    } = _ref2;\n    let panelLabel = name || {\n      'type-1': __('Global Header', 'blocksy')\n    }[id] || id;\n    const panelId = `builder_header_panel_${id}`;\n    const headerOptions = ct_customizer_localizations.header_builder_data.header_data.header_options;\n    const option = {\n      label: panelLabel,\n      'inner-options': headerOptions\n    };\n    return createElement(PanelMetaWrapper, _extends({\n      id: panelId,\n      key: id,\n      option: option\n    }, panelsActions, {\n      getActualOption: _ref3 => {\n        let {\n          open\n        } = _ref3;\n        return createElement(Fragment, null, Object.keys(headerOptions).length > 0 && id === builderValue.id && createElement(Panel, {\n          id: panelId,\n          getValues: () => builderValue.settings || {},\n          option: option,\n          onChangeFor: (optionId, optionValue) => {\n            builderValueDispatch({\n              type: 'BUILDER_GLOBAL_SETTING_ON_CHANGE',\n              payload: {\n                optionId,\n                optionValue,\n                values: getValueFromInput(headerOptions, Array.isArray(builderValue.settings) ? {} : builderValue.settings || {})\n              }\n            });\n          },\n          view: \"simple\"\n        }), id === builderValue.id && createElement(\"li\", {\n          className: cls({\n            active: id === builderValue.id,\n            'ct-global': id === 'type-1'\n          }),\n          onClick: () => {\n            if (Object.keys(headerOptions).length > 0) {\n              open();\n            }\n          }\n        }, createElement(\"span\", {\n          className: \"ct-panel-name\"\n        }, panelLabel)));\n      }\n    }));\n  }));\n};\n\nexport default PanelsManager;","import { createElement, Component, useState, useContext, Fragment } from '@wordpress/element';\nimport cls from 'classnames';\nimport { __, sprintf } from 'ct-i18n';\nimport { Slot } from '@wordpress/components';\nimport SecondaryItems from './builder-sidebar/SecondaryItems';\nimport InvisiblePanels from './builder-sidebar/InvisiblePanels';\nimport PanelsManager from './builder-sidebar/PanelsManager';\nimport { DragDropContext } from './BuilderRoot';\nimport classnames from 'classnames';\n\nconst AvailableItems = _ref => {\n  let {\n    allBuilderSections,\n    builderValue,\n    builderValueDispatch,\n    inlinedItemsFromBuilder\n  } = _ref;\n  // panels | items | options\n  const [currentTab, setCurrentTab] = useState('items');\n  const {\n    builderValueCollection\n  } = useContext(DragDropContext);\n  const secondaryItems = ct_customizer_localizations.header_builder_data.secondary_items.header;\n  const allItems = ct_customizer_localizations.header_builder_data.header;\n  const headerOptions = ct_customizer_localizations.header_builder_data.header_data.header_options;\n  return createElement(\"div\", {\n    className: \"ct-available-items\"\n  }, createElement(\"h3\", {\n    className: \"ct-title\",\n    dangerouslySetInnerHTML: {\n      __html: sprintf(__('Customizing: %s', 'blocksy'), `<span>${(builderValueCollection.sections.find(_ref2 => {\n        let {\n          id\n        } = _ref2;\n        return id === builderValue.id;\n      }) || {}).name || {\n        'type-1': __('Global Header', 'blocksy')\n      }[builderValue.id] || builderValue.id}</span>`)\n    }\n  }), createElement(\"div\", {\n    className: \"ct-tabs\"\n  }, createElement(\"ul\", null, ['items', 'panels'].map(tab => createElement(\"li\", {\n    key: tab,\n    onClick: e => {\n      e.preventDefault();\n      setCurrentTab(tab);\n    },\n    className: cls({\n      active: tab === currentTab\n    })\n  }, {\n    panels: __('Headers', 'blocksy'),\n    items: __('Elements', 'blocksy')\n  }[tab]))), createElement(\"div\", {\n    className: \"ct-current-tab\"\n  }, currentTab === 'panels' && createElement(Slot, {\n    name: \"PlacementsBuilderPanelsManager\"\n  }, fills => fills.length === 0 ? createElement(PanelsManager, null) : fills), createElement(SecondaryItems, {\n    builderValue: builderValue,\n    builderValueDispatch: builderValueDispatch,\n    inlinedItemsFromBuilder: inlinedItemsFromBuilder,\n    displayList: currentTab === 'items'\n  }))), createElement(InvisiblePanels, {\n    builderValue: builderValue,\n    builderValueDispatch: builderValueDispatch\n  }));\n};\n\nexport default AvailableItems;","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { fetchCurrentHeader } from './BuilderRoot';\nimport { getOriginalId, customItemsSeparator } from './helpers';\nimport nanoid from 'nanoid';\nexport const builderReducer = (builderValue, action) => {\n  let updatedGlobalState = {};\n  let newSections = [];\n  let futureBuilderValue = builderValue.sections.find(_ref => {\n    let {\n      id\n    } = _ref;\n    return id.indexOf(builderValue.__forced_static_header__ || fetchCurrentHeader() || builderValue.sections[0].id) > -1;\n  });\n  let shouldUpdate = false;\n  let updateItemId = false;\n  let removeSectionIds = [];\n\n  if (action.type === 'ITEM_VALUE_ON_CHANGE') {\n    const {\n      id,\n      optionId,\n      optionValue,\n      values = {}\n    } = action.payload;\n    updateItemId = `${id}:${optionId}`;\n    let items = futureBuilderValue.items;\n\n    if (!items.find(_ref2 => {\n      let {\n        id: _id\n      } = _ref2;\n      return _id === id;\n    })) {\n      items = [...items, {\n        id,\n        values: {}\n      }];\n    }\n\n    futureBuilderValue = _objectSpread(_objectSpread({}, futureBuilderValue), {}, {\n      items: items.map(item => item.id === id ? _objectSpread(_objectSpread({}, item), {}, {\n        values: _objectSpread(_objectSpread(_objectSpread({}, item.values), values), {}, {\n          [optionId]: optionValue\n        })\n      }) : item)\n    });\n  }\n\n  if (action.type === 'PICK_BUILDER_SECTION') {\n    shouldUpdate = true;\n    updatedGlobalState = {\n      __forced_static_header__: action.payload.id\n    };\n  }\n\n  if (action.type === 'MARK_HEADER_AS_GLOBAL') {\n    shouldUpdate = true;\n    updatedGlobalState = {\n      current_section: builderValue.__forced_static_header__\n    };\n  }\n\n  if (action.type === 'MARK_SPECIFIC_HEADER_AS_GLOBAL') {\n    updatedGlobalState = {\n      current_section: action.payload.id\n    };\n  }\n\n  if (action.type === 'CLONE_ITEM') {\n    const futureId = getOriginalId(action.payload.id);\n    futureBuilderValue = _objectSpread(_objectSpread({}, futureBuilderValue), {}, {\n      items: [...futureBuilderValue.items, {\n        id: `${futureId}${customItemsSeparator()}${nanoid()}`,\n        values: futureBuilderValue.items.find(_ref3 => {\n          let {\n            id\n          } = _ref3;\n          return id === futureId;\n        }) ? futureBuilderValue.items.find(_ref4 => {\n          let {\n            id\n          } = _ref4;\n          return id === futureId;\n        }).values : {}\n      }]\n    });\n  }\n\n  if (action.type === 'REMOVE_CLONED_ITEM') {\n    futureBuilderValue = _objectSpread(_objectSpread({}, futureBuilderValue), {}, {\n      items: futureBuilderValue.items.filter(_ref5 => {\n        let {\n          id\n        } = _ref5;\n        return id !== action.payload.id;\n      })\n    });\n  }\n\n  if (action.type === 'SET_LIST') {\n    shouldUpdate = true;\n    const {\n      currentView,\n      lists\n    } = action.payload;\n\n    if (\n    /**\n     * If we just inserted offcanvas trigger on desktop\n     */\n    currentView === 'desktop' && Object.values(lists).reduce((all, current) => [...all, ...current], []).indexOf('trigger') > -1 && !futureBuilderValue.desktop.find(_ref6 => {\n      let {\n        id\n      } = _ref6;\n      return id === 'offcanvas';\n    })) {\n      futureBuilderValue = _objectSpread(_objectSpread({}, futureBuilderValue), {}, {\n        desktop: [...futureBuilderValue.desktop, {\n          id: 'offcanvas',\n          placements: [{\n            id: 'start',\n            items: []\n          }]\n        }]\n      });\n    }\n\n    futureBuilderValue = _objectSpread(_objectSpread({}, futureBuilderValue), {}, {\n      [currentView]: futureBuilderValue[currentView].map(_ref7 => {\n        let {\n          id: barId,\n          placements\n        } = _ref7;\n        const keys = Object.keys(lists);\n\n        if (keys.map(k => k.split(':')[0]).indexOf(barId) > -1) {\n          let futureBar = {\n            id: barId,\n            placements: placements.map(_ref8 => {\n              let {\n                id,\n                items\n              } = _ref8;\n\n              if (lists[`${barId}:${id}`]) {\n                return {\n                  id,\n                  items: lists[`${barId}:${id}`]\n                };\n              }\n\n              return {\n                id,\n                items\n              };\n            })\n          };\n\n          if (futureBar.placements.find(_ref9 => {\n            let {\n              id\n            } = _ref9;\n            return id === 'middle';\n          }) && futureBar.placements.find(_ref10 => {\n            let {\n              id\n            } = _ref10;\n            return id === 'middle';\n          }).items.length === 0 && futureBar.placements.find(_ref11 => {\n            let {\n              id\n            } = _ref11;\n            return id === 'start-middle';\n          }) && (futureBar.placements.find(_ref12 => {\n            let {\n              id\n            } = _ref12;\n            return id === 'start-middle';\n          }).items.length > 0 || futureBar.placements.find(_ref13 => {\n            let {\n              id\n            } = _ref13;\n            return id === 'end-middle';\n          }).items.length > 0)) {\n            let updater = {};\n            updater[`${barId}:start`] = [...futureBar.placements.find(_ref14 => {\n              let {\n                id\n              } = _ref14;\n              return id === 'start';\n            }).items, ...futureBar.placements.find(_ref15 => {\n              let {\n                id\n              } = _ref15;\n              return id === 'start-middle';\n            }).items];\n            updater[`${barId}:end`] = [...futureBar.placements.find(_ref16 => {\n              let {\n                id\n              } = _ref16;\n              return id === 'end-middle';\n            }).items, ...futureBar.placements.find(_ref17 => {\n              let {\n                id\n              } = _ref17;\n              return id === 'end';\n            }).items];\n            updater[`${barId}:start-middle`] = [];\n            updater[`${barId}:end-middle`] = [];\n            futureBar = {\n              id: barId,\n              placements: futureBar.placements.map(_ref18 => {\n                let {\n                  id,\n                  items\n                } = _ref18;\n\n                if (updater[`${barId}:${id}`]) {\n                  return {\n                    id,\n                    items: updater[`${barId}:${id}`]\n                  };\n                }\n\n                return {\n                  id,\n                  items\n                };\n              })\n            };\n          }\n\n          return futureBar;\n        }\n\n        return {\n          id: barId,\n          placements\n        };\n      })\n    });\n  }\n\n  if (action.type === 'BUILDER_GLOBAL_SETTING_ON_CHANGE') {\n    const {\n      optionId,\n      optionValue,\n      values = {}\n    } = action.payload;\n    futureBuilderValue = _objectSpread(_objectSpread({}, futureBuilderValue), {}, {\n      settings: _objectSpread(_objectSpread(_objectSpread({}, futureBuilderValue.settings), values), {}, {\n        [optionId]: optionValue\n      })\n    });\n  }\n\n  if (action.type === 'CREATE_NEW_SECTION') {\n    const {\n      name,\n      copy\n    } = action.payload;\n    newSections = [copy ? _objectSpread(_objectSpread({}, builderValue.sections.find(_ref19 => {\n      let {\n        id\n      } = _ref19;\n      return id === copy;\n    }) || {}), {}, {\n      name,\n      id: `ct-custom-${nanoid()}`\n    }) : {\n      name,\n      id: `ct-custom-${nanoid()}`,\n      mode: 'placements',\n      items: [],\n      settings: [],\n      desktop: [{\n        id: 'top-row',\n        placements: [{\n          id: 'start',\n          items: []\n        }, {\n          id: 'middle',\n          items: []\n        }, {\n          id: 'end',\n          items: []\n        }, {\n          id: 'start-middle',\n          items: []\n        }, {\n          id: 'end-middle',\n          items: []\n        }]\n      }, {\n        id: 'middle-row',\n        placements: [{\n          id: 'start',\n          items: ['logo']\n        }, {\n          id: 'middle',\n          items: []\n        }, {\n          id: 'end',\n          items: ['menu']\n        }, {\n          id: 'start-middle',\n          items: []\n        }, {\n          id: 'end-middle',\n          items: []\n        }]\n      }, {\n        id: 'bottom-row',\n        placements: [{\n          id: 'start',\n          items: []\n        }, {\n          id: 'middle',\n          items: []\n        }, {\n          id: 'end',\n          items: []\n        }, {\n          id: 'start-middle',\n          items: []\n        }, {\n          id: 'end-middle',\n          items: []\n        }]\n      }],\n      mobile: [{\n        id: 'top-row',\n        placements: [{\n          id: 'start',\n          items: []\n        }, {\n          id: 'middle',\n          items: []\n        }, {\n          id: 'end',\n          items: []\n        }, {\n          id: 'start-middle',\n          items: []\n        }, {\n          id: 'end-middle',\n          items: []\n        }]\n      }, {\n        id: 'middle-row',\n        placements: [{\n          id: 'start',\n          items: ['logo']\n        }, {\n          id: 'middle',\n          items: []\n        }, {\n          id: 'end',\n          items: ['trigger']\n        }, {\n          id: 'start-middle',\n          items: []\n        }, {\n          id: 'end-middle',\n          items: []\n        }]\n      }, {\n        id: 'bottom-row',\n        placements: [{\n          id: 'start',\n          items: []\n        }, {\n          id: 'middle',\n          items: []\n        }, {\n          id: 'end',\n          items: []\n        }, {\n          id: 'start-middle',\n          items: []\n        }, {\n          id: 'end-middle',\n          items: []\n        }]\n      }, {\n        id: 'offcanvas',\n        placements: [{\n          id: 'start',\n          items: ['mobile-menu']\n        }]\n      }]\n    }];\n  }\n\n  if (action.type === 'REMOVE_BUILDER_SECTION') {\n    removeSectionIds.push(action.payload.id);\n  }\n\n  const actualBuilderValue = _objectSpread(_objectSpread(_objectSpread({}, builderValue), updatedGlobalState), {}, {\n    __should_refresh__: shouldUpdate,\n    __should_refresh_item__: updateItemId,\n    sections: [...builderValue.sections.map(builder => builder.id === futureBuilderValue.id ? futureBuilderValue : builder), ...newSections].filter(_ref20 => {\n      let {\n        id\n      } = _ref20;\n      return removeSectionIds.indexOf(id) === -1;\n    })\n  });\n\n  return actualBuilderValue;\n};","const _excluded = [\"__forced_dynamic_header__\", \"__forced_static_header__\", \"__should_refresh__\"],\n      _excluded2 = [\"__forced_dynamic_header__\", \"__forced_static_header__\", \"__should_refresh__\"];\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport { createElement, Fragment, Component, useEffect, useRef, useMemo, createPortal, useState, useCallback, createContext, useReducer } from '@wordpress/element';\nimport PlacementsBuilder from './PlacementsBuilder';\nimport DraggableItems from './DraggableItems';\nimport ViewSwitch from './ViewSwitch';\nimport AvailableItems from './AvailableItems';\nimport { builderReducer } from './builderReducer';\nimport { useDeviceManager } from '../../components/useDeviceManager';\nimport ctEvents from 'ct-events';\nexport const DragDropContext = createContext({});\n\nconst getDocument = x => x.document || x.contentDocument || x.contentWindow.document;\n\nexport const fetchCurrentHeader = () => {\n  const document = getDocument(wp.customize.previewer.container.find('iframe')[0]);\n\n  if (wp.customize.previewer.container.find('iframe')[0].contentDocument.querySelector('header#header')) {\n    return wp.customize.previewer.container.find('iframe')[0].contentDocument.querySelector('header#header').dataset.id;\n  }\n\n  return null;\n};\n\nconst BuilderRoot = _ref => {\n  let {\n    value: allBuilderSections,\n    option,\n    onChange: onBuilderValueChange\n  } = _ref;\n  const currentHeader = useRef(null);\n\n  if (currentHeader.current === null) {\n    currentHeader.current = (allBuilderSections.sections.find(_ref2 => {\n      let {\n        id\n      } = _ref2;\n      return id.indexOf(fetchCurrentHeader()) > -1;\n    }) || allBuilderSections.sections[0]).id;\n  }\n\n  useEffect(() => {\n    let _wp$customize = wp.customize('header_placements')(),\n        {\n      __forced_dynamic_header__,\n      __forced_static_header__,\n      __should_refresh__\n    } = _wp$customize,\n        old = _objectWithoutProperties(_wp$customize, _excluded);\n\n    Object.keys(old).map(key => {\n      if (parseFloat(key)) {\n        delete old[key];\n      }\n    });\n\n    try {\n      wp.customize('header_placements')(_objectSpread(_objectSpread({}, old), {}, {\n        __forced_static_header__: (allBuilderSections.sections.find(_ref3 => {\n          let {\n            id\n          } = _ref3;\n          return id.indexOf(fetchCurrentHeader()) > -1;\n        }) || allBuilderSections.sections[0]).id\n      }));\n    } catch (e) {\n      console.error(e);\n    }\n\n    return () => {\n      const _wp$customize2 = wp.customize('header_placements')(),\n            {\n        __forced_dynamic_header__,\n        __forced_static_header__,\n        __should_refresh__\n      } = _wp$customize2,\n            old = _objectWithoutProperties(_wp$customize2, _excluded2);\n\n      wp.customize('header_placements')(_objectSpread({\n        __should_refresh__: true,\n        [Math.random()]: 'update'\n      }, old));\n    };\n  }, []);\n  const [isDragging, setIsDragging] = useState(false);\n  const [builderValueCollection, builderValueDispatchInternal] = useReducer(builderReducer, _objectSpread(_objectSpread({}, allBuilderSections), currentHeader.current ? {\n    __forced_static_header__: currentHeader.current\n  } : {}));\n  const builderValue = useMemo(() => builderValueCollection.sections.find(_ref4 => {\n    let {\n      id\n    } = _ref4;\n    return id === builderValueCollection.__forced_static_header__;\n  }) || builderValueCollection.sections[0], [builderValueCollection]); // desktop | mobile\n\n  const [currentView, setCurrentView] = useDeviceManager({\n    withTablet: false\n  });\n  const inlinedItemsFromBuilder = useMemo(() => builderValue[currentView].reduce((currentItems, _ref5) => {\n    let {\n      id,\n      placements\n    } = _ref5;\n    return [...currentItems, ...(placements || []).reduce((c, _ref6) => {\n      let {\n        id,\n        items\n      } = _ref6;\n      return [...c, ...items];\n    }, [])];\n  }, []), [builderValue, currentView]);\n  const builderValueDispatch = useCallback(action => {\n    let newState = builderReducer(builderValueCollection, action);\n\n    if (action.type === 'ITEM_VALUE_ON_CHANGE') {\n      const {\n        id,\n        optionId,\n        optionValue,\n        values = {}\n      } = action.payload;\n      const builderValue = newState.sections.find(_ref7 => {\n        let {\n          id\n        } = _ref7;\n        return id === newState.__forced_static_header__;\n      }) || newState.sections[0];\n      let items = builderValue.items;\n\n      if (id === 'logo' && optionId === 'custom_logo' && builderValue.id === 'type-1') {\n        wp.customize && wp.customize('custom_logo')(optionValue ? optionValue.desktop ? optionValue.desktop : optionValue : '');\n      }\n\n      wp.customize.previewer && wp.customize.previewer.send('ct:header:receive-value-update', {\n        itemId: id,\n        optionId,\n        optionValue,\n        futureItems: builderValue.items,\n        values: _objectSpread(_objectSpread(_objectSpread({}, (items.find(_ref8 => {\n          let {\n            id: _id\n          } = _ref8;\n          return id === _id;\n        }) || {\n          values: {}\n        }).values), values), {}, {\n          [optionId]: optionValue\n        })\n      });\n    }\n\n    if (action.type === 'BUILDER_GLOBAL_SETTING_ON_CHANGE') {\n      const {\n        optionId,\n        optionValue,\n        values = {}\n      } = action.payload;\n      const builderValue = newState.sections.find(_ref9 => {\n        let {\n          id\n        } = _ref9;\n        return id === newState.__forced_static_header__;\n      }) || newState.sections[0];\n      wp.customize.previewer && wp.customize.previewer.send('ct:header:receive-value-update', {\n        itemId: 'global',\n        optionId,\n        optionValue,\n        values: _objectSpread(_objectSpread(_objectSpread({}, builderValue.settings), values), {}, {\n          [optionId]: optionValue\n        })\n      });\n    }\n\n    onBuilderValueChange(newState);\n    builderValueDispatchInternal(action);\n  }, [builderValueDispatchInternal, onBuilderValueChange, builderValueCollection]);\n  const setList = useCallback(lists => builderValueDispatch({\n    type: 'SET_LIST',\n    payload: {\n      currentView,\n      lists\n    }\n  }), [builderValueDispatch, currentView]);\n  return createElement(Fragment, null, createElement(DragDropContext.Provider, {\n    value: {\n      option,\n      currentView,\n      isDragging,\n      setIsDragging,\n      setList,\n      builderValueDispatch,\n      builderValue,\n      onChange: _ref10 => {\n        let {\n          id,\n          value\n        } = _ref10;\n        return setList({\n          [id]: value\n        });\n      },\n      builderValueCollection\n    }\n  }, createElement(AvailableItems, {\n    allBuilderSections: allBuilderSections,\n    builderValue: builderValue,\n    inlinedItemsFromBuilder: inlinedItemsFromBuilder,\n    builderValueDispatch: builderValueDispatch\n  }), createPortal(createElement(\"div\", {\n    className: \"ct-builder-header\"\n  }, createElement(ViewSwitch, {\n    currentView: currentView,\n    setCurrentView: setCurrentView\n  }), createElement(PlacementsBuilder, {\n    inlinedItemsFromBuilder: inlinedItemsFromBuilder,\n    builderValueWithView: builderValue[currentView],\n    view: currentView\n  })), document.querySelector('.ct-panel-builder'))));\n};\n\nexport default BuilderRoot;","import { createElement } from '@wordpress/element';\nimport BuilderRoot from '../../customizer/panels-builder/placements/BuilderRoot';\n\nconst HeaderBuilder = props => createElement(BuilderRoot, props);\n\nHeaderBuilder.renderingConfig = {\n  design: 'none'\n};\nexport default HeaderBuilder;"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///5565\n")},6962:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(4184);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var match_conditions__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7465);\nconst _excluded = ["className"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\n\n\n\n\nconst ImagePicker = _ref => {\n let {\n option: {\n choices,\n tabletChoices,\n mobileChoices\n },\n option,\n device,\n value,\n values,\n onChange\n } = _ref;\n\n const _ref2 = _objectSpread({}, option.attr || {}),\n {\n className\n } = _ref2,\n attr = _objectWithoutProperties(_ref2, _excluded);\n\n let deviceChoices = option.choices;\n\n if (device === \'tablet\' && tabletChoices) {\n deviceChoices = tabletChoices;\n }\n\n if (device === \'mobile\' && mobileChoices) {\n deviceChoices = mobileChoices;\n }\n\n let matchingChoices = (Array.isArray(deviceChoices) ? deviceChoices : Object.keys(deviceChoices).map(choice => _objectSpread({\n key: choice\n }, deviceChoices[choice]))).filter(_ref3 => {\n let {\n key\n } = _ref3;\n\n if (!option.conditions) {\n return true;\n }\n\n if (!option.conditions[key]) {\n return true;\n }\n\n return (0,match_conditions__WEBPACK_IMPORTED_MODULE_2__/* .matchValuesWithCondition */ .Nj)((0,match_conditions__WEBPACK_IMPORTED_MODULE_2__/* .normalizeCondition */ .KY)(option.conditions[key]), values);\n });\n let normalizedValue = matchingChoices.map(_ref4 => {\n let {\n key\n } = _ref4;\n return key;\n }).includes(value) ? value : option.value;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("ul", _extends({}, attr, {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()(\'ct-image-picker\', className)\n }, option.title && null ? 0 : {}), matchingChoices.map(choice => (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("li", {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()({\n active: choice.key === normalizedValue\n }),\n onClick: () => onChange(choice.key),\n key: choice.key\n }, choice.src.indexOf(\'{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ ImageUploader)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _wordpress_components__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(8441);\n/* harmony import */ var _wordpress_components__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_wordpress_components__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(4184);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var ct_i18n__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(5652);\n/* harmony import */ var ct_i18n__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(ct_i18n__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(6715);\n/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_4__);\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\nclass ImageUploader extends _wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Component {\n constructor() {\n var _this;\n\n super(...arguments);\n _this = this;\n\n _defineProperty(this, \"params\", {\n height: 250,\n width: 250,\n flex_width: true,\n flex_height: true\n });\n\n _defineProperty(this, \"state\", {\n attachment_info: null\n });\n\n _defineProperty(this, \"getUrlFor\", attachmentInfo => attachmentInfo ? (attachmentInfo.width < 700 ? attachmentInfo.sizes.full : underscore__WEBPACK_IMPORTED_MODULE_4___default().max(underscore__WEBPACK_IMPORTED_MODULE_4___default().values(underscore__WEBPACK_IMPORTED_MODULE_4___default().keys(attachmentInfo.sizes).length === 1 ? attachmentInfo.sizes : underscore__WEBPACK_IMPORTED_MODULE_4___default().omit(attachmentInfo.sizes, 'full')), _ref => {\n let {\n width\n } = _ref;\n return width;\n })).url || attachmentInfo.url : null);\n\n _defineProperty(this, \"onChange\", function (value) {\n let attachment_info = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;\n return _this.props.onChange(_this.props.option.inline_value ? value || '' : _objectSpread(_objectSpread({}, _this.props.value), {}, {\n url: _this.getUrlFor(attachment_info),\n attachment_id: value\n }));\n });\n\n _defineProperty(this, \"getAttachmentId\", function () {\n let props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : _this.props;\n return props.option.inline_value ? props.value : props.value.attachment_id;\n });\n\n _defineProperty(this, \"onSelect\", () => {\n var attachment = this.frame.state().get('selection').first().toJSON();\n\n if ((this.props.option.logo || {}).width === attachment.width && (this.props.option.logo || {}).height === attachment.height && !(this.props.option.logo || {}).flex_width && !(this.props.option.logo || {}).flex_height || this.props.option.skipCrop || true) {\n this.setImageFromAttachment(attachment);\n this.frame.close();\n } else {}\n });\n\n _defineProperty(this, \"onCropped\", croppedImage => {\n this.setImageFromAttachment(croppedImage);\n });\n\n _defineProperty(this, \"onSkippedCrop\", () => {\n var attachment = this.frame.state().get('selection').first().toJSON();\n this.setImageFromAttachment(attachment);\n });\n\n _defineProperty(this, \"updateAttachmentInfo\", function () {\n let force = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;\n\n let id = _this.getAttachmentId();\n\n if (!id) return;\n\n if (!wp.media.attachment(id).get('url') || force) {\n wp.media.attachment(id).fetch().then(() => _this.setState({\n attachment_info: JSON.parse(JSON.stringify(wp.media.attachment(id).toJSON()))\n }));\n } else {\n _this.setState({\n attachment_info: JSON.parse(JSON.stringify(wp.media.attachment(id).toJSON()))\n });\n }\n\n _this.detachListener();\n\n wp.media.attachment(id).on('change', _this.updateAttachmentInfo);\n });\n }\n\n /**\n * Create a media modal select frame, and store it so the instance can be reused when needed.\n */\n initFrame() {\n this.frame = wp.media({\n button: {\n text: 'Select',\n close: false\n },\n states: [new wp.media.controller.Library({\n title: (0,ct_i18n__WEBPACK_IMPORTED_MODULE_3__.__)('Select logo', 'blocksy'),\n library: wp.media.query({\n type: this.props.option.mediaType || 'image'\n }),\n multiple: false,\n date: false,\n priority: 20,\n suggestedWidth: (this.props.option.logo || {}).width,\n suggestedHeight: (this.props.option.logo || {}).height\n }), ...(this.props.option.skipCrop || true ? [] : 0)]\n });\n this.frame.on('select', this.onSelect, this);\n this.frame.on('close', () => {\n this.props.option.onFrameClose && this.props.option.onFrameClose();\n });\n this.frame.on('cropped', this.onCropped, this);\n this.frame.on('skippedcrop', this.onSkippedCrop, this);\n }\n /**\n * Open the media modal to the library state.\n */\n\n\n openFrame() {\n this.initFrame();\n this.frame.setState('library').open();\n this.props.option.onFrameOpen && this.props.option.onFrameOpen();\n }\n /**\n * After an image is selected in the media modal, switch to the cropper\n * state if the image isn't the right size.\n */\n\n\n /**\n * Returns a set of options, computed from the attached image data and\n * control-specific data, to be fed to the imgAreaSelect plugin in\n * wp.media.view.Cropper.\n *\n * @param {wp.media.model.Attachment} attachment\n * @param {wp.media.controller.Cropper} controller\n * @returns {Object} Options\n */\n calculateImageSelectOptions(attachment, controller) {\n var control = controller.get('control');\n var flexWidth = !!parseInt((control.props.option.logo || {}).flex_width, 10);\n var flexHeight = !!parseInt((control.props.option.logo || {}).flex_height, 10);\n var realWidth = attachment.get('width');\n var realHeight = attachment.get('height');\n var xInit = parseInt((control.props.option.logo || {}).width, 10);\n var yInit = parseInt((control.props.option.logo || {}).height, 10);\n var ratio = xInit / yInit;\n var xImg = xInit;\n var yImg = yInit;\n var x1;\n var y1;\n var imgSelectOptions;\n\n if (realWidth / realHeight > ratio) {\n yInit = realHeight;\n xInit = yInit * ratio;\n } else {\n xInit = realWidth;\n yInit = xInit / ratio;\n }\n\n x1 = (realWidth - xInit) / 2;\n y1 = (realHeight - yInit) / 2;\n imgSelectOptions = {\n handles: true,\n keys: true,\n instance: true,\n persistent: true,\n imageWidth: realWidth,\n imageHeight: realHeight,\n minWidth: xImg > xInit ? xInit : xImg,\n minHeight: yImg > yInit ? yInit : yImg,\n x1: x1,\n y1: y1,\n x2: xInit + x1,\n y2: yInit + y1\n };\n\n if (flexHeight === false && flexWidth === false) {\n imgSelectOptions.aspectRatio = xInit + ':' + yInit;\n }\n\n if (true === flexHeight) {\n delete imgSelectOptions.minHeight;\n imgSelectOptions.maxWidth = realWidth;\n }\n\n if (true === flexWidth) {\n delete imgSelectOptions.minWidth;\n imgSelectOptions.maxHeight = realHeight;\n }\n\n return imgSelectOptions;\n }\n /**\n * Return whether the image must be cropped, based on required dimensions.\n *\n * @param {bool} flexW\n * @param {bool} flexH\n * @param {int} dstW\n * @param {int} dstH\n * @param {int} imgW\n * @param {int} imgH\n * @return {bool}\n */\n\n\n mustBeCropped(flexW, flexH, dstW, dstH, imgW, imgH) {\n if (true === flexW && true === flexH) {\n return false;\n }\n\n if (true === flexW && dstH === imgH) {\n return false;\n }\n\n if (true === flexH && dstW === imgW) {\n return false;\n }\n\n if (dstW === imgW && dstH === imgH) {\n return false;\n }\n\n if (imgW <= dstW) {\n return false;\n }\n\n return true;\n }\n /**\n * If cropping was skipped, apply the image data directly to the setting.\n */\n\n\n /**\n * Updates the setting and re-renders the control UI.\n *\n * @param {object} attachment\n */\n setImageFromAttachment(attachment) {\n this.onChange(attachment.id, JSON.parse(JSON.stringify(wp.media.attachment(attachment.id).toJSON())));\n this.updateAttachmentInfo();\n }\n\n detachListener() {\n if (!this.getAttachmentId()) return;\n wp.media.attachment(this.getAttachmentId()).off('change', this.updateAttachmentInfo);\n }\n\n componentDidUpdate(prevProps) {\n if (this.getAttachmentId() !== this.getAttachmentId(prevProps)) {\n wp.media.attachment(this.getAttachmentId(prevProps)).off('change', this.updateAttachmentInfo);\n this.updateAttachmentInfo();\n }\n }\n\n componentDidMount() {\n this.updateAttachmentInfo();\n }\n\n componentWillUnmount() {\n this.detachListener();\n }\n\n render() {\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", _extends({\n className: classnames__WEBPACK_IMPORTED_MODULE_2___default()('attachment-media-view ct-attachment', {\n ['landscape']: this.getAttachmentId() && this.state.attachment_info,\n ['attachment-media-view-image']: this.getAttachmentId() && this.state.attachment_info\n })\n }, this.props.option.attr || {}), this.getAttachmentId() && this.state.attachment_info ? (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", {\n className: \"thumbnail thumbnail-image\",\n onClick: () => !this.props.option.has_position_picker && this.openFrame()\n }, !this.props.option.has_position_picker && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"img\", {\n className: \"attachment-thumb\",\n src: this.getUrlFor(this.state.attachment_info),\n draggable: \"false\",\n alt: \"\"\n }), this.props.option.has_position_picker && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_wordpress_components__WEBPACK_IMPORTED_MODULE_1__.FocalPointPicker, {\n url: this.getUrlFor(this.state.attachment_info),\n dimensions: {\n width: 400,\n height: 100\n },\n value: this.props.value,\n onChange: drag_position => {\n this.props.onChange(_objectSpread(_objectSpread({}, this.props.value), drag_position));\n }\n }), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", {\n className: \"actions\"\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"button\", {\n type: \"button\",\n className: \"button edit-button control-focus\",\n title: (0,ct_i18n__WEBPACK_IMPORTED_MODULE_3__.__)('Edit', 'blocksy'),\n onClick: e => {\n e.stopPropagation();\n this.openFrame();\n },\n id: \"customize-media-control-button-35\"\n }), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"button\", {\n onClick: e => {\n e.stopPropagation();\n this.setState({\n attachment_info: null\n });\n this.onChange(null);\n },\n title: (0,ct_i18n__WEBPACK_IMPORTED_MODULE_3__.__)('Remove', 'blocksy'),\n type: \"button\",\n className: \"button remove-button\"\n })))) : (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"button\", {\n type: \"button\",\n onClick: () => this.openFrame(),\n className: \"button ct-upload-button\",\n id: \"customize-media-control-button-50\"\n }, this.props.option.emptyLabel || (0,ct_i18n__WEBPACK_IMPORTED_MODULE_3__.__)('Select logo', 'blocksy'))));\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"3048.js","mappings":";;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./static/js/options/options/ct-image-uploader.js?c0d6"],"sourcesContent":["function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, Component, Fragment } from '@wordpress/element';\nimport { FocalPointPicker } from '@wordpress/components';\nimport classnames from 'classnames';\nimport { __ } from 'ct-i18n';\nimport _ from 'underscore';\nexport default class ImageUploader extends Component {\n  constructor() {\n    var _this;\n\n    super(...arguments);\n    _this = this;\n\n    _defineProperty(this, \"params\", {\n      height: 250,\n      width: 250,\n      flex_width: true,\n      flex_height: true\n    });\n\n    _defineProperty(this, \"state\", {\n      attachment_info: null\n    });\n\n    _defineProperty(this, \"getUrlFor\", attachmentInfo => attachmentInfo ? (attachmentInfo.width < 700 ? attachmentInfo.sizes.full : _.max(_.values(_.keys(attachmentInfo.sizes).length === 1 ? attachmentInfo.sizes : _.omit(attachmentInfo.sizes, 'full')), _ref => {\n      let {\n        width\n      } = _ref;\n      return width;\n    })).url || attachmentInfo.url : null);\n\n    _defineProperty(this, \"onChange\", function (value) {\n      let attachment_info = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;\n      return _this.props.onChange(_this.props.option.inline_value ? value || '' : _objectSpread(_objectSpread({}, _this.props.value), {}, {\n        url: _this.getUrlFor(attachment_info),\n        attachment_id: value\n      }));\n    });\n\n    _defineProperty(this, \"getAttachmentId\", function () {\n      let props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : _this.props;\n      return props.option.inline_value ? props.value : props.value.attachment_id;\n    });\n\n    _defineProperty(this, \"onSelect\", () => {\n      var attachment = this.frame.state().get('selection').first().toJSON();\n\n      if ((this.props.option.logo || {}).width === attachment.width && (this.props.option.logo || {}).height === attachment.height && !(this.props.option.logo || {}).flex_width && !(this.props.option.logo || {}).flex_height || this.props.option.skipCrop || true) {\n        this.setImageFromAttachment(attachment);\n        this.frame.close();\n      } else {\n        this.frame.setState('cropper');\n      }\n    });\n\n    _defineProperty(this, \"onCropped\", croppedImage => {\n      this.setImageFromAttachment(croppedImage);\n    });\n\n    _defineProperty(this, \"onSkippedCrop\", () => {\n      var attachment = this.frame.state().get('selection').first().toJSON();\n      this.setImageFromAttachment(attachment);\n    });\n\n    _defineProperty(this, \"updateAttachmentInfo\", function () {\n      let force = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;\n\n      let id = _this.getAttachmentId();\n\n      if (!id) return;\n\n      if (!wp.media.attachment(id).get('url') || force) {\n        wp.media.attachment(id).fetch().then(() => _this.setState({\n          attachment_info: JSON.parse(JSON.stringify(wp.media.attachment(id).toJSON()))\n        }));\n      } else {\n        _this.setState({\n          attachment_info: JSON.parse(JSON.stringify(wp.media.attachment(id).toJSON()))\n        });\n      }\n\n      _this.detachListener();\n\n      wp.media.attachment(id).on('change', _this.updateAttachmentInfo);\n    });\n  }\n\n  /**\n   * Create a media modal select frame, and store it so the instance can be reused when needed.\n   */\n  initFrame() {\n    this.frame = wp.media({\n      button: {\n        text: 'Select',\n        close: false\n      },\n      states: [new wp.media.controller.Library({\n        title: __('Select logo', 'blocksy'),\n        library: wp.media.query({\n          type: this.props.option.mediaType || 'image'\n        }),\n        multiple: false,\n        date: false,\n        priority: 20,\n        suggestedWidth: (this.props.option.logo || {}).width,\n        suggestedHeight: (this.props.option.logo || {}).height\n      }), ...(this.props.option.skipCrop || true ? [] : [new wp.media.controller.CustomizeImageCropper({\n        imgSelectOptions: this.calculateImageSelectOptions,\n        control: this\n      })])]\n    });\n    this.frame.on('select', this.onSelect, this);\n    this.frame.on('close', () => {\n      this.props.option.onFrameClose && this.props.option.onFrameClose();\n    });\n    this.frame.on('cropped', this.onCropped, this);\n    this.frame.on('skippedcrop', this.onSkippedCrop, this);\n  }\n  /**\n   * Open the media modal to the library state.\n   */\n\n\n  openFrame() {\n    this.initFrame();\n    this.frame.setState('library').open();\n    this.props.option.onFrameOpen && this.props.option.onFrameOpen();\n  }\n  /**\n   * After an image is selected in the media modal, switch to the cropper\n   * state if the image isn't the right size.\n   */\n\n\n  /**\n   * Returns a set of options, computed from the attached image data and\n   * control-specific data, to be fed to the imgAreaSelect plugin in\n   * wp.media.view.Cropper.\n   *\n   * @param {wp.media.model.Attachment} attachment\n   * @param {wp.media.controller.Cropper} controller\n   * @returns {Object} Options\n   */\n  calculateImageSelectOptions(attachment, controller) {\n    var control = controller.get('control');\n    var flexWidth = !!parseInt((control.props.option.logo || {}).flex_width, 10);\n    var flexHeight = !!parseInt((control.props.option.logo || {}).flex_height, 10);\n    var realWidth = attachment.get('width');\n    var realHeight = attachment.get('height');\n    var xInit = parseInt((control.props.option.logo || {}).width, 10);\n    var yInit = parseInt((control.props.option.logo || {}).height, 10);\n    var ratio = xInit / yInit;\n    var xImg = xInit;\n    var yImg = yInit;\n    var x1;\n    var y1;\n    var imgSelectOptions;\n\n    if (realWidth / realHeight > ratio) {\n      yInit = realHeight;\n      xInit = yInit * ratio;\n    } else {\n      xInit = realWidth;\n      yInit = xInit / ratio;\n    }\n\n    x1 = (realWidth - xInit) / 2;\n    y1 = (realHeight - yInit) / 2;\n    imgSelectOptions = {\n      handles: true,\n      keys: true,\n      instance: true,\n      persistent: true,\n      imageWidth: realWidth,\n      imageHeight: realHeight,\n      minWidth: xImg > xInit ? xInit : xImg,\n      minHeight: yImg > yInit ? yInit : yImg,\n      x1: x1,\n      y1: y1,\n      x2: xInit + x1,\n      y2: yInit + y1\n    };\n\n    if (flexHeight === false && flexWidth === false) {\n      imgSelectOptions.aspectRatio = xInit + ':' + yInit;\n    }\n\n    if (true === flexHeight) {\n      delete imgSelectOptions.minHeight;\n      imgSelectOptions.maxWidth = realWidth;\n    }\n\n    if (true === flexWidth) {\n      delete imgSelectOptions.minWidth;\n      imgSelectOptions.maxHeight = realHeight;\n    }\n\n    return imgSelectOptions;\n  }\n  /**\n   * Return whether the image must be cropped, based on required dimensions.\n   *\n   * @param {bool} flexW\n   * @param {bool} flexH\n   * @param {int}  dstW\n   * @param {int}  dstH\n   * @param {int}  imgW\n   * @param {int}  imgH\n   * @return {bool}\n   */\n\n\n  mustBeCropped(flexW, flexH, dstW, dstH, imgW, imgH) {\n    if (true === flexW && true === flexH) {\n      return false;\n    }\n\n    if (true === flexW && dstH === imgH) {\n      return false;\n    }\n\n    if (true === flexH && dstW === imgW) {\n      return false;\n    }\n\n    if (dstW === imgW && dstH === imgH) {\n      return false;\n    }\n\n    if (imgW <= dstW) {\n      return false;\n    }\n\n    return true;\n  }\n  /**\n   * If cropping was skipped, apply the image data directly to the setting.\n   */\n\n\n  /**\n   * Updates the setting and re-renders the control UI.\n   *\n   * @param {object} attachment\n   */\n  setImageFromAttachment(attachment) {\n    this.onChange(attachment.id, JSON.parse(JSON.stringify(wp.media.attachment(attachment.id).toJSON())));\n    this.updateAttachmentInfo();\n  }\n\n  detachListener() {\n    if (!this.getAttachmentId()) return;\n    wp.media.attachment(this.getAttachmentId()).off('change', this.updateAttachmentInfo);\n  }\n\n  componentDidUpdate(prevProps) {\n    if (this.getAttachmentId() !== this.getAttachmentId(prevProps)) {\n      wp.media.attachment(this.getAttachmentId(prevProps)).off('change', this.updateAttachmentInfo);\n      this.updateAttachmentInfo();\n    }\n  }\n\n  componentDidMount() {\n    this.updateAttachmentInfo();\n  }\n\n  componentWillUnmount() {\n    this.detachListener();\n  }\n\n  render() {\n    return createElement(\"div\", _extends({\n      className: classnames('attachment-media-view ct-attachment', {\n        ['landscape']: this.getAttachmentId() && this.state.attachment_info,\n        ['attachment-media-view-image']: this.getAttachmentId() && this.state.attachment_info\n      })\n    }, this.props.option.attr || {}), this.getAttachmentId() && this.state.attachment_info ? createElement(Fragment, null, createElement(\"div\", {\n      className: \"thumbnail thumbnail-image\",\n      onClick: () => !this.props.option.has_position_picker && this.openFrame()\n    }, !this.props.option.has_position_picker && createElement(\"img\", {\n      className: \"attachment-thumb\",\n      src: this.getUrlFor(this.state.attachment_info),\n      draggable: \"false\",\n      alt: \"\"\n    }), this.props.option.has_position_picker && createElement(FocalPointPicker, {\n      url: this.getUrlFor(this.state.attachment_info),\n      dimensions: {\n        width: 400,\n        height: 100\n      },\n      value: this.props.value,\n      onChange: drag_position => {\n        this.props.onChange(_objectSpread(_objectSpread({}, this.props.value), drag_position));\n      }\n    }), createElement(\"div\", {\n      className: \"actions\"\n    }, createElement(\"button\", {\n      type: \"button\",\n      className: \"button edit-button control-focus\",\n      title: __('Edit', 'blocksy'),\n      onClick: e => {\n        e.stopPropagation();\n        this.openFrame();\n      },\n      id: \"customize-media-control-button-35\"\n    }), createElement(\"button\", {\n      onClick: e => {\n        e.stopPropagation();\n        this.setState({\n          attachment_info: null\n        });\n        this.onChange(null);\n      },\n      title: __('Remove', 'blocksy'),\n      type: \"button\",\n      className: \"button remove-button\"\n    })))) : createElement(Fragment, null, createElement(\"button\", {\n      type: \"button\",\n      onClick: () => this.openFrame(),\n      className: \"button ct-upload-button\",\n      id: \"customize-media-control-button-50\"\n    }, this.props.option.emptyLabel || __('Select logo', 'blocksy'))));\n  }\n\n}"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///3048\n")},379:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _OptionsPanel__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7429);\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\nconst LayersMirror = _ref => {\n let {\n values,\n onChangeFor,\n value,\n option,\n onChange\n } = _ref;\n const wholeLayers = values[option.layers] || [];\n const ourLayers = wholeLayers.filter(_ref2 => {\n let {\n id,\n enabled\n } = _ref2;\n return enabled && id === option.field;\n });\n\n if (ourLayers.length === 0) {\n return null;\n }\n\n return ourLayers.map((layer, index) => {\n let computedOptions = Object.keys(option['inner-options']).reduce((all, optionId) => _objectSpread(_objectSpread({}, all), {}, {\n [optionId]: _objectSpread(_objectSpread({}, option['inner-options'][optionId]), {}, {\n label: option['inner-options'][optionId].label.replace('INDEX ', ourLayers.length === 1 ? '' : `${index + 1} `)\n })\n }), {});\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_OptionsPanel__WEBPACK_IMPORTED_MODULE_1__/* [\"default\"] */ .Z, {\n key: layer.__id || layer.id,\n onChange: (id, value) => {\n onChangeFor(option.layers, wholeLayers.map(l => l.__id !== layer.__id ? l : _objectSpread(_objectSpread({}, l), {}, {\n [id]: value\n })));\n },\n options: computedOptions,\n value: layer\n });\n });\n};\n\nLayersMirror.renderingConfig = {\n design: 'none'\n};\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (LayersMirror);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMzc5LmpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9zdGF0aWMvanMvb3B0aW9ucy9vcHRpb25zL2N0LWxheWVycy1taXJyb3IuanM/NWZmMCJdLCJzb3VyY2VzQ29udGVudCI6WyJmdW5jdGlvbiBvd25LZXlzKG9iamVjdCwgZW51bWVyYWJsZU9ubHkpIHsgdmFyIGtleXMgPSBPYmplY3Qua2V5cyhvYmplY3QpOyBpZiAoT2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9scykgeyB2YXIgc3ltYm9scyA9IE9iamVjdC5nZXRPd25Qcm9wZXJ0eVN5bWJvbHMob2JqZWN0KTsgZW51bWVyYWJsZU9ubHkgJiYgKHN5bWJvbHMgPSBzeW1ib2xzLmZpbHRlcihmdW5jdGlvbiAoc3ltKSB7IHJldHVybiBPYmplY3QuZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9yKG9iamVjdCwgc3ltKS5lbnVtZXJhYmxlOyB9KSksIGtleXMucHVzaC5hcHBseShrZXlzLCBzeW1ib2xzKTsgfSByZXR1cm4ga2V5czsgfVxuXG5mdW5jdGlvbiBfb2JqZWN0U3ByZWFkKHRhcmdldCkgeyBmb3IgKHZhciBpID0gMTsgaSA8IGFyZ3VtZW50cy5sZW5ndGg7IGkrKykgeyB2YXIgc291cmNlID0gbnVsbCAhPSBhcmd1bWVudHNbaV0gPyBhcmd1bWVudHNbaV0gOiB7fTsgaSAlIDIgPyBvd25LZXlzKE9iamVjdChzb3VyY2UpLCAhMCkuZm9yRWFjaChmdW5jdGlvbiAoa2V5KSB7IF9kZWZpbmVQcm9wZXJ0eSh0YXJnZXQsIGtleSwgc291cmNlW2tleV0pOyB9KSA6IE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3JzID8gT2JqZWN0LmRlZmluZVByb3BlcnRpZXModGFyZ2V0LCBPYmplY3QuZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9ycyhzb3VyY2UpKSA6IG93bktleXMoT2JqZWN0KHNvdXJjZSkpLmZvckVhY2goZnVuY3Rpb24gKGtleSkgeyBPYmplY3QuZGVmaW5lUHJvcGVydHkodGFyZ2V0LCBrZXksIE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3Ioc291cmNlLCBrZXkpKTsgfSk7IH0gcmV0dXJuIHRhcmdldDsgfVxuXG5mdW5jdGlvbiBfZGVmaW5lUHJvcGVydHkob2JqLCBrZXksIHZhbHVlKSB7IGlmIChrZXkgaW4gb2JqKSB7IE9iamVjdC5kZWZpbmVQcm9wZXJ0eShvYmosIGtleSwgeyB2YWx1ZTogdmFsdWUsIGVudW1lcmFibGU6IHRydWUsIGNvbmZpZ3VyYWJsZTogdHJ1ZSwgd3JpdGFibGU6IHRydWUgfSk7IH0gZWxzZSB7IG9ialtrZXldID0gdmFsdWU7IH0gcmV0dXJuIG9iajsgfVxuXG5pbXBvcnQgeyBGcmFnbWVudCwgY3JlYXRlRWxlbWVudCB9IGZyb20gJ0B3b3JkcHJlc3MvZWxlbWVudCc7XG5pbXBvcnQgT3B0aW9uc1BhbmVsIGZyb20gJy4uL09wdGlvbnNQYW5lbCc7XG5cbmNvbnN0IExheWVyc01pcnJvciA9IF9yZWYgPT4ge1xuICBsZXQge1xuICAgIHZhbHVlcyxcbiAgICBvbkNoYW5nZUZvcixcbiAgICB2YWx1ZSxcbiAgICBvcHRpb24sXG4gICAgb25DaGFuZ2VcbiAgfSA9IF9yZWY7XG4gIGNvbnN0IHdob2xlTGF5ZXJzID0gdmFsdWVzW29wdGlvbi5sYXllcnNdIHx8IFtdO1xuICBjb25zdCBvdXJMYXllcnMgPSB3aG9sZUxheWVycy5maWx0ZXIoX3JlZjIgPT4ge1xuICAgIGxldCB7XG4gICAgICBpZCxcbiAgICAgIGVuYWJsZWRcbiAgICB9ID0gX3JlZjI7XG4gICAgcmV0dXJuIGVuYWJsZWQgJiYgaWQgPT09IG9wdGlvbi5maWVsZDtcbiAgfSk7XG5cbiAgaWYgKG91ckxheWVycy5sZW5ndGggPT09IDApIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuXG4gIHJldHVybiBvdXJMYXllcnMubWFwKChsYXllciwgaW5kZXgpID0+IHtcbiAgICBsZXQgY29tcHV0ZWRPcHRpb25zID0gT2JqZWN0LmtleXMob3B0aW9uWydpbm5lci1vcHRpb25zJ10pLnJlZHVjZSgoYWxsLCBvcHRpb25JZCkgPT4gX29iamVjdFNwcmVhZChfb2JqZWN0U3ByZWFkKHt9LCBhbGwpLCB7fSwge1xuICAgICAgW29wdGlvbklkXTogX29iamVjdFNwcmVhZChfb2JqZWN0U3ByZWFkKHt9LCBvcHRpb25bJ2lubmVyLW9wdGlvbnMnXVtvcHRpb25JZF0pLCB7fSwge1xuICAgICAgICBsYWJlbDogb3B0aW9uWydpbm5lci1vcHRpb25zJ11bb3B0aW9uSWRdLmxhYmVsLnJlcGxhY2UoJ0lOREVYICcsIG91ckxheWVycy5sZW5ndGggPT09IDEgPyAnJyA6IGAke2luZGV4ICsgMX0gYClcbiAgICAgIH0pXG4gICAgfSksIHt9KTtcbiAgICByZXR1cm4gY3JlYXRlRWxlbWVudChPcHRpb25zUGFuZWwsIHtcbiAgICAgIGtleTogbGF5ZXIuX19pZCB8fCBsYXllci5pZCxcbiAgICAgIG9uQ2hhbmdlOiAoaWQsIHZhbHVlKSA9PiB7XG4gICAgICAgIG9uQ2hhbmdlRm9yKG9wdGlvbi5sYXllcnMsIHdob2xlTGF5ZXJzLm1hcChsID0+IGwuX19pZCAhPT0gbGF5ZXIuX19pZCA/IGwgOiBfb2JqZWN0U3ByZWFkKF9vYmplY3RTcHJlYWQoe30sIGwpLCB7fSwge1xuICAgICAgICAgIFtpZF06IHZhbHVlXG4gICAgICAgIH0pKSk7XG4gICAgICB9LFxuICAgICAgb3B0aW9uczogY29tcHV0ZWRPcHRpb25zLFxuICAgICAgdmFsdWU6IGxheWVyXG4gICAgfSk7XG4gIH0pO1xufTtcblxuTGF5ZXJzTWlycm9yLnJlbmRlcmluZ0NvbmZpZyA9IHtcbiAgZGVzaWduOiAnbm9uZSdcbn07XG5leHBvcnQgZGVmYXVsdCBMYXllcnNNaXJyb3I7Il0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///379\n")},6780:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('// ESM COMPAT FLAG\n__webpack_require__.r(__webpack_exports__);\n\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n "LayersContext": () => (/* binding */ LayersContext),\n "default": () => (/* binding */ ct_layers),\n "itemsThatAreNotAdded": () => (/* binding */ itemsThatAreNotAdded)\n});\n\n// EXTERNAL MODULE: external "window.wp.element"\nvar external_window_wp_element_ = __webpack_require__(1381);\n// EXTERNAL MODULE: ./node_modules/classnames/index.js\nvar classnames = __webpack_require__(4184);\nvar classnames_default = /*#__PURE__*/__webpack_require__.n(classnames);\n// EXTERNAL MODULE: ./node_modules/react-sortable-hoc/dist/react-sortable-hoc.esm.js + 18 modules\nvar react_sortable_hoc_esm = __webpack_require__(6362);\n// EXTERNAL MODULE: ./node_modules/array-move/index.js\nvar array_move = __webpack_require__(454);\nvar array_move_default = /*#__PURE__*/__webpack_require__.n(array_move);\n// EXTERNAL MODULE: ./static/js/options/OptionsPanel.js + 7 modules\nvar OptionsPanel = __webpack_require__(7429);\n// EXTERNAL MODULE: ./static/js/options/helpers/get-value-from-input.js\nvar get_value_from_input = __webpack_require__(7069);\n// EXTERNAL MODULE: ./static/js/options/options/ct-select.js + 3 modules\nvar ct_select = __webpack_require__(1404);\n// EXTERNAL MODULE: ./node_modules/nanoid/index.browser.js\nvar index_browser = __webpack_require__(1496);\nvar index_browser_default = /*#__PURE__*/__webpack_require__.n(index_browser);\n;// CONCATENATED MODULE: ./static/js/options/options/ct-layers/SelectThatAddsItems.js\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\nconst SelectThatAddsItems = _ref => {\n let {\n value,\n option\n } = _ref;\n const notAddedItems = itemsThatAreNotAdded(value, option);\n const {\n currentlyPickedItem,\n setCurrentItem,\n addCurrentlySelectedItem\n } = (0,external_window_wp_element_.useContext)(LayersContext);\n\n if (notAddedItems.length <= 0) {\n return null;\n }\n\n return (0,external_window_wp_element_.createElement)("div", {\n className: "ct-add-layer-controls"\n }, (0,external_window_wp_element_.createElement)(ct_select["default"], {\n onChange: currentlyPickedItem => setCurrentItem(currentlyPickedItem),\n option: _objectSpread({\n search: true,\n choices: notAddedItems.map(key => ({\n key,\n value: window._.template((option.settings[key] || {\n label: key\n }).label)({\n label: \'\'\n })\n }))\n }, option.selectOption || {}),\n value: currentlyPickedItem || notAddedItems[0]\n }), (0,external_window_wp_element_.createElement)("button", {\n type: "button",\n className: "button button-primary",\n onClick: () => addCurrentlySelectedItem()\n }, (0,external_window_wp_element_.createElement)("svg", {\n width: "10",\n height: "10",\n viewBox: "0 0 17 17"\n }, (0,external_window_wp_element_.createElement)("path", {\n d: "M17,10h-7v7H7v-7H0V7h7V0h3v7h7V10z"\n }))));\n};\n\n/* harmony default export */ const ct_layers_SelectThatAddsItems = (SelectThatAddsItems);\n// EXTERNAL MODULE: external "window.wp.i18n"\nvar external_window_wp_i18n_ = __webpack_require__(5652);\n// EXTERNAL MODULE: ./node_modules/match-conditions/dist/index.es.js\nvar index_es = __webpack_require__(7465);\n;// CONCATENATED MODULE: ./static/js/options/options/ct-layers/LayerControls.js\nfunction LayerControls_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction LayerControls_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? LayerControls_ownKeys(Object(source), !0).forEach(function (key) { LayerControls_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : LayerControls_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction LayerControls_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\nconst LayerControls = _ref => {\n let {\n itemIndex,\n items,\n onChange,\n value\n } = _ref;\n const {\n removeForId,\n addForId,\n option,\n toggleOptionsPanel\n } = (0,external_window_wp_element_.useContext)(LayersContext);\n const hasOptions = option.settings[value.id] && option.settings[value.id].options && (!option.settings[value.id].options_condition || option.settings[value.id].options_condition && (0,index_es/* matchValuesWithCondition */.Nj)((0,index_es/* normalizeCondition */.KY)(option.settings[value.id].options_condition), LayerControls_objectSpread(LayerControls_objectSpread({}, value), {}, {\n itemIndex\n })));\n let itemsOfType = items.filter(_ref2 => {\n let {\n id\n } = _ref2;\n return id === value.id;\n });\n let relativeIndex = itemsOfType.map(_ref3 => {\n let {\n __id\n } = _ref3;\n return __id;\n }).indexOf(value.__id);\n return (0,external_window_wp_element_.createElement)("div", {\n className: "ct-layer-controls"\n }, !option.disableHiding && (0,external_window_wp_element_.createElement)("button", {\n type: "button",\n className: "ct-visibility",\n onClick: e => {\n e.stopPropagation();\n onChange(items.map(l => l.__id === value.__id ? LayerControls_objectSpread(LayerControls_objectSpread({}, l), {}, {\n enabled: !LayerControls_objectSpread({\n enabled: true\n }, l).enabled\n }) : l));\n }\n }, (0,external_window_wp_element_.createElement)("svg", {\n width: "13px",\n height: "13px",\n viewBox: "0 0 24 24"\n }, (0,external_window_wp_element_.createElement)("path", {\n d: "M12,4C4.1,4,0,12,0,12s3.1,8,12,8c8.1,0,12-8,12-8S20.1,4,12,4z M12,17c-2.9,0-5-2.2-5-5c0-2.8,2.1-5,5-5s5,2.2,5,5C17,14.8,14.9,17,12,17z M12,9c-1.7,0-3,1.4-3,3c0,1.6,1.3,3,3,3s3-1.4,3-3C15,10.4,13.7,9,12,9z"\n }))), (0,external_window_wp_element_.createElement)("div", {\n className: "ct-layer-label"\n }, (0,external_window_wp_element_.createElement)("span", null, window._.template((option.settings[value.id] || {\n label: value.id\n }).label)(value).replace(\' INDEX\', itemsOfType.length === 1 ? \'\' : ` ${relativeIndex + 1}`))), option.settings[value.id] && option.settings[value.id].clone && items.filter(_ref4 => {\n let {\n id\n } = _ref4;\n return id === value.id;\n }).length < (parseInt(option.settings[value.id].clone) || 1) + 1 && (0,external_window_wp_element_.createElement)("button", {\n type: "button",\n className: "ct-clone",\n onClick: () => addForId(value.id, value)\n }, (0,external_window_wp_element_.createElement)("svg", {\n width: "11px",\n height: "11px",\n viewBox: "0 0 24 24"\n }, (0,external_window_wp_element_.createElement)("path", {\n d: "M23,24H7.7c-0.6,0-1-0.4-1-1V7.7c0-0.6,0.4-1,1-1H23c0.6,0,1,0.4,1,1V23C24,23.6,23.6,24,23,24z M8.7,22H22V8.7 H8.7V22z"\n }), (0,external_window_wp_element_.createElement)("path", {\n d: "M17.3,16.3c0,0.6-0.4,1-1,1H1c-0.6,0-1-0.4-1-1V1c0-0.6,0.4-1,1-1h15.3c0.6,0,1,0.4,1,1V16.3z"\n })), (0,external_window_wp_element_.createElement)("i", {\n className: "ct-tooltip-top"\n }, (0,external_window_wp_i18n_.__)(\'Clone Item\', \'blocksy\'))), (option.manageable || option.settings[value.id] && option.settings[value.id].clone && items.filter(_ref5 => {\n let {\n id\n } = _ref5;\n return id === value.id;\n }).length > 1 || !option.settings[value.id]) && (0,external_window_wp_element_.createElement)("button", {\n type: "button",\n className: "ct-remove",\n onClick: () => removeForId(value.__id)\n }), hasOptions && (0,external_window_wp_element_.createElement)("button", {\n type: "button",\n className: "ct-toggle",\n onMouseDown: e => {\n e.stopPropagation();\n },\n onClick: e => {\n e.stopPropagation();\n toggleOptionsPanel(value.__id);\n }\n }));\n};\n\n/* harmony default export */ const ct_layers_LayerControls = ((0,react_sortable_hoc_esm/* SortableHandle */.W6)(LayerControls));\n;// CONCATENATED MODULE: ./static/js/options/options/ct-layers.js\nfunction ct_layers_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction ct_layers_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ct_layers_ownKeys(Object(source), !0).forEach(function (key) { ct_layers_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ct_layers_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction ct_layers_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\n\n\n\n\n\nconst valueWithUniqueIds = value => value.map(singleItem => ct_layers_objectSpread(ct_layers_objectSpread({}, singleItem), singleItem.__id ? {} : {\n __id: index_browser_default()()\n}));\n\nconst itemsThatAreNotAdded = (value, option) => Object.keys(option.settings).filter(optionId => !value.find(_ref => {\n let {\n id\n } = _ref;\n return id === optionId;\n}));\n\nconst getDefaultState = () => ({\n currentlyPickedItem: null,\n isDragging: false,\n isOpen: false\n});\n\nconst LayersContext = (0,external_window_wp_element_.createContext)(getDefaultState());\nconst {\n Provider,\n Consumer\n} = LayersContext;\n\nclass SingleItem extends external_window_wp_element_.Component {\n constructor() {\n super(...arguments);\n\n ct_layers_defineProperty(this, "state", {\n isOpen: false\n });\n }\n\n render() {\n const {\n value,\n items,\n onChange,\n index\n } = this.props;\n const itemIndex = items.map(_ref2 => {\n let {\n __id\n } = _ref2;\n return __id;\n }).indexOf(value.__id).toString();\n return (0,external_window_wp_element_.createElement)(Consumer, null, _ref3 => {\n let {\n option,\n isDragging,\n isOpen,\n parentValue\n } = _ref3;\n return (0,external_window_wp_element_.createElement)("li", {\n className: classnames_default()(\'ct-layer\', option.itemClass, {\n [`ct-disabled`]: !ct_layers_objectSpread({\n enabled: true\n }, value).enabled\n })\n }, (0,external_window_wp_element_.createElement)(ct_layers_LayerControls, {\n items: items,\n onChange: onChange,\n value: value,\n itemIndex: itemIndex\n }), option.settings[value.id] && option.settings[value.id].options && isOpen === value.__id && (!isDragging || isDragging && isDragging !== isOpen) && (0,external_window_wp_element_.createElement)("div", {\n className: "ct-layer-content"\n }, (0,external_window_wp_element_.createElement)(OptionsPanel/* default */.Z, {\n hasRevertButton: false,\n parentValue: parentValue,\n onChange: (key, newValue) => {\n if (option.settings[value.id].sync && option.settings[value.id].clone) {\n let totalItems = items.filter(_ref4 => {\n let {\n id\n } = _ref4;\n return id === value.id;\n }).length;\n let idForSync = `${option.settings[value.id].sync.id}_first`;\n\n if (totalItems > 1 && items.filter(_ref5 => {\n let {\n id\n } = _ref5;\n return id === value.id;\n }).map(_ref6 => {\n let {\n __id\n } = _ref6;\n return __id;\n }).indexOf(value.__id) > 0) {\n idForSync = `${option.settings[value.id].sync.id}_second`;\n }\n\n wp.customize && wp.customize.previewer && wp.customize.previewer.send(\'ct:sync:refresh_partial\', {\n id: idForSync\n });\n }\n\n onChange(items.map(l => l.__id === value.__id ? ct_layers_objectSpread(ct_layers_objectSpread({}, l), {}, {\n [key]: newValue\n }) : l));\n },\n value: (0,get_value_from_input/* getValueFromInput */.n6)(option.settings[value.id].options, ct_layers_objectSpread(ct_layers_objectSpread(ct_layers_objectSpread({}, option.value.filter(_ref7 => {\n let {\n id\n } = _ref7;\n return id === value.id;\n }).length > 1 ? option.value.filter(_ref8 => {\n let {\n id\n } = _ref8;\n return value.id === id;\n })[items.filter(_ref9 => {\n let {\n id\n } = _ref9;\n return id === value.id;\n }).map(_ref10 => {\n let {\n __id\n } = _ref10;\n return __id;\n }).indexOf(value.__id)] : {}), value), {}, {\n itemIndex\n })),\n options: option.settings[value.id].options\n })));\n });\n }\n\n}\n\nconst SortableItem = (0,react_sortable_hoc_esm/* SortableElement */.W8)(SingleItem);\nconst SortableList = (0,react_sortable_hoc_esm/* SortableContainer */.JN)(_ref11 => {\n let {\n items,\n onChange\n } = _ref11;\n return (0,external_window_wp_element_.createElement)(Consumer, null, _ref12 => {\n let {\n option\n } = _ref12;\n return (0,external_window_wp_element_.createElement)("ul", {\n className: "ct-layers"\n }, items.map((value, index) => (0,external_window_wp_element_.createElement)(SortableItem, {\n key: value.__id,\n index: index,\n onChange: onChange,\n value: value,\n items: items,\n disabled: !!option.disableDrag\n })));\n });\n});\n\nconst Layers = _ref13 => {\n let {\n value,\n option,\n onChange,\n values\n } = _ref13;\n const [state, setState] = (0,external_window_wp_element_.useState)(getDefaultState());\n\n const addForId = function (idToAdd) {\n let val = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n onChange([...(value || []), ct_layers_objectSpread(ct_layers_objectSpread(ct_layers_objectSpread({\n id: idToAdd,\n enabled: true\n }, (0,get_value_from_input/* getValueFromInput */.n6)(option.settings[idToAdd].options || {}, {})), val), {}, {\n __id: index_browser_default()()\n })]);\n };\n\n const computedValue = (option.manageable ? valueWithUniqueIds(value) : [...valueWithUniqueIds(value), ...option.value.filter(_ref14 => {\n let {\n id\n } = _ref14;\n return value.map(_ref15 => {\n let {\n id\n } = _ref15;\n return id;\n }).indexOf(id) === -1;\n }).map(item => ct_layers_objectSpread(ct_layers_objectSpread({}, item), {}, {\n __id: index_browser_default()(),\n enabled: false\n }))]).filter(item => !!option.settings[item.id]);\n return (0,external_window_wp_element_.createElement)(Provider, {\n value: ct_layers_objectSpread(ct_layers_objectSpread({}, state), {}, {\n parentValue: values,\n addCurrentlySelectedItem: () => {\n const idToAdd = state.currentlyPickedItem || itemsThatAreNotAdded(valueWithUniqueIds(value), option)[0];\n setState(state => ct_layers_objectSpread(ct_layers_objectSpread({}, state), {}, {\n currentlyPickedItem: null\n }));\n addForId(idToAdd);\n },\n addForId: (id, value) => addForId(id, value),\n option: option,\n setCurrentItem: currentlyPickedItem => setState(state => ct_layers_objectSpread(ct_layers_objectSpread({}, state), {}, {\n currentlyPickedItem\n })),\n removeForId: idToRemove => onChange(valueWithUniqueIds(value).filter(_ref16 => {\n let {\n __id: id\n } = _ref16;\n return id !== idToRemove;\n })),\n toggleOptionsPanel: idToAdd => {\n if (value.length > 0 && !value[0].__id) {\n wp.customize && wp.customize.previewer && wp.customize.previewer.send(\'ct:sync:refresh_partial\', {\n shouldSkip: true\n });\n onChange(computedValue);\n }\n\n setState(state => ct_layers_objectSpread(ct_layers_objectSpread({}, state), {}, {\n isOpen: state.isOpen === idToAdd ? false : idToAdd\n }));\n }\n })\n }, option.manageable && (0,external_window_wp_element_.createElement)(ct_layers_SelectThatAddsItems, {\n value: computedValue,\n option\n }), (0,external_window_wp_element_.createElement)(SortableList, {\n useDragHandle: true,\n distance: 3,\n lockAxis: "y",\n items: computedValue,\n onChange: v => onChange(v),\n helperContainer: () => document.querySelector(\'#customize-theme-controls\') || document.body,\n onSortEnd: _ref17 => {\n let {\n oldIndex,\n newIndex\n } = _ref17;\n onChange(array_move_default()(computedValue, oldIndex, newIndex));\n setState(state => ct_layers_objectSpread(ct_layers_objectSpread({}, state), {}, {\n isDragging: false\n }));\n },\n updateBeforeSortStart: _ref18 => {\n let {\n index\n } = _ref18;\n new Promise(resolve => {\n if (value.length > 0 && !value[0].__id) {\n wp.customize && wp.customize.previewer && wp.customize.previewer.send(\'ct:sync:refresh_partial\', {\n shouldSkip: true\n });\n onChange(computedValue);\n }\n\n setState(state => ct_layers_objectSpread(ct_layers_objectSpread({}, state), {}, {\n isDragging: computedValue[index].__id\n }));\n resolve();\n });\n }\n }));\n};\n\n/* harmony default export */ const ct_layers = (Layers);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"6780.js","mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;ACvDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./static/js/options/options/ct-layers/SelectThatAddsItems.js?8e23","webpack://blocksyOptions/./static/js/options/options/ct-layers/LayerControls.js?2c36","webpack://blocksyOptions/./static/js/options/options/ct-layers.js?0085"],"sourcesContent":["function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, Fragment, useContext } from '@wordpress/element';\nimport { itemsThatAreNotAdded, LayersContext } from '../ct-layers';\nimport Select from '../ct-select';\n\nconst SelectThatAddsItems = _ref => {\n  let {\n    value,\n    option\n  } = _ref;\n  const notAddedItems = itemsThatAreNotAdded(value, option);\n  const {\n    currentlyPickedItem,\n    setCurrentItem,\n    addCurrentlySelectedItem\n  } = useContext(LayersContext);\n\n  if (notAddedItems.length <= 0) {\n    return null;\n  }\n\n  return createElement(\"div\", {\n    className: \"ct-add-layer-controls\"\n  }, createElement(Select, {\n    onChange: currentlyPickedItem => setCurrentItem(currentlyPickedItem),\n    option: _objectSpread({\n      search: true,\n      choices: notAddedItems.map(key => ({\n        key,\n        value: window._.template((option.settings[key] || {\n          label: key\n        }).label)({\n          label: ''\n        })\n      }))\n    }, option.selectOption || {}),\n    value: currentlyPickedItem || notAddedItems[0]\n  }), createElement(\"button\", {\n    type: \"button\",\n    className: \"button button-primary\",\n    onClick: () => addCurrentlySelectedItem()\n  }, createElement(\"svg\", {\n    width: \"10\",\n    height: \"10\",\n    viewBox: \"0 0 17 17\"\n  }, createElement(\"path\", {\n    d: \"M17,10h-7v7H7v-7H0V7h7V0h3v7h7V10z\"\n  }))));\n};\n\nexport default SelectThatAddsItems;","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, useContext, useState, Fragment } from '@wordpress/element';\nimport { SortableHandle } from 'react-sortable-hoc';\nimport { LayersContext } from '../ct-layers';\nimport { __ } from 'ct-i18n';\nimport { normalizeCondition, matchValuesWithCondition } from 'match-conditions';\n\nconst LayerControls = _ref => {\n  let {\n    itemIndex,\n    items,\n    onChange,\n    value\n  } = _ref;\n  const {\n    removeForId,\n    addForId,\n    option,\n    toggleOptionsPanel\n  } = useContext(LayersContext);\n  const hasOptions = option.settings[value.id] && option.settings[value.id].options && (!option.settings[value.id].options_condition || option.settings[value.id].options_condition && matchValuesWithCondition(normalizeCondition(option.settings[value.id].options_condition), _objectSpread(_objectSpread({}, value), {}, {\n    itemIndex\n  })));\n  let itemsOfType = items.filter(_ref2 => {\n    let {\n      id\n    } = _ref2;\n    return id === value.id;\n  });\n  let relativeIndex = itemsOfType.map(_ref3 => {\n    let {\n      __id\n    } = _ref3;\n    return __id;\n  }).indexOf(value.__id);\n  return createElement(\"div\", {\n    className: \"ct-layer-controls\"\n  }, !option.disableHiding && createElement(\"button\", {\n    type: \"button\",\n    className: \"ct-visibility\",\n    onClick: e => {\n      e.stopPropagation();\n      onChange(items.map(l => l.__id === value.__id ? _objectSpread(_objectSpread({}, l), {}, {\n        enabled: !_objectSpread({\n          enabled: true\n        }, l).enabled\n      }) : l));\n    }\n  }, createElement(\"svg\", {\n    width: \"13px\",\n    height: \"13px\",\n    viewBox: \"0 0 24 24\"\n  }, createElement(\"path\", {\n    d: \"M12,4C4.1,4,0,12,0,12s3.1,8,12,8c8.1,0,12-8,12-8S20.1,4,12,4z M12,17c-2.9,0-5-2.2-5-5c0-2.8,2.1-5,5-5s5,2.2,5,5C17,14.8,14.9,17,12,17z M12,9c-1.7,0-3,1.4-3,3c0,1.6,1.3,3,3,3s3-1.4,3-3C15,10.4,13.7,9,12,9z\"\n  }))), createElement(\"div\", {\n    className: \"ct-layer-label\"\n  }, createElement(\"span\", null, window._.template((option.settings[value.id] || {\n    label: value.id\n  }).label)(value).replace(' INDEX', itemsOfType.length === 1 ? '' : ` ${relativeIndex + 1}`))), option.settings[value.id] && option.settings[value.id].clone && items.filter(_ref4 => {\n    let {\n      id\n    } = _ref4;\n    return id === value.id;\n  }).length < (parseInt(option.settings[value.id].clone) || 1) + 1 && createElement(\"button\", {\n    type: \"button\",\n    className: \"ct-clone\",\n    onClick: () => addForId(value.id, value)\n  }, createElement(\"svg\", {\n    width: \"11px\",\n    height: \"11px\",\n    viewBox: \"0 0 24 24\"\n  }, createElement(\"path\", {\n    d: \"M23,24H7.7c-0.6,0-1-0.4-1-1V7.7c0-0.6,0.4-1,1-1H23c0.6,0,1,0.4,1,1V23C24,23.6,23.6,24,23,24z M8.7,22H22V8.7 H8.7V22z\"\n  }), createElement(\"path\", {\n    d: \"M17.3,16.3c0,0.6-0.4,1-1,1H1c-0.6,0-1-0.4-1-1V1c0-0.6,0.4-1,1-1h15.3c0.6,0,1,0.4,1,1V16.3z\"\n  })), createElement(\"i\", {\n    className: \"ct-tooltip-top\"\n  }, __('Clone Item', 'blocksy'))), (option.manageable || option.settings[value.id] && option.settings[value.id].clone && items.filter(_ref5 => {\n    let {\n      id\n    } = _ref5;\n    return id === value.id;\n  }).length > 1 || !option.settings[value.id]) && createElement(\"button\", {\n    type: \"button\",\n    className: \"ct-remove\",\n    onClick: () => removeForId(value.__id)\n  }), hasOptions && createElement(\"button\", {\n    type: \"button\",\n    className: \"ct-toggle\",\n    onMouseDown: e => {\n      e.stopPropagation();\n    },\n    onClick: e => {\n      e.stopPropagation();\n      toggleOptionsPanel(value.__id);\n    }\n  }));\n};\n\nexport default SortableHandle(LayerControls);","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, Component, createContext, useState, Fragment } from '@wordpress/element';\nimport classnames from 'classnames';\nimport { SortableContainer, SortableElement, SortableHandle } from 'react-sortable-hoc';\nimport arrayMove from 'array-move';\nimport OptionsPanel from '../OptionsPanel';\nimport { getValueFromInput } from '../helpers/get-value-from-input';\nimport Select from './ct-select';\nimport nanoid from 'nanoid';\nimport SelectThatAddsItems from './ct-layers/SelectThatAddsItems';\nimport LayerControls from './ct-layers/LayerControls';\n\nconst valueWithUniqueIds = value => value.map(singleItem => _objectSpread(_objectSpread({}, singleItem), singleItem.__id ? {} : {\n  __id: nanoid()\n}));\n\nexport const itemsThatAreNotAdded = (value, option) => Object.keys(option.settings).filter(optionId => !value.find(_ref => {\n  let {\n    id\n  } = _ref;\n  return id === optionId;\n}));\n\nconst getDefaultState = () => ({\n  currentlyPickedItem: null,\n  isDragging: false,\n  isOpen: false\n});\n\nexport const LayersContext = createContext(getDefaultState());\nconst {\n  Provider,\n  Consumer\n} = LayersContext;\n\nclass SingleItem extends Component {\n  constructor() {\n    super(...arguments);\n\n    _defineProperty(this, \"state\", {\n      isOpen: false\n    });\n  }\n\n  render() {\n    const {\n      value,\n      items,\n      onChange,\n      index\n    } = this.props;\n    const itemIndex = items.map(_ref2 => {\n      let {\n        __id\n      } = _ref2;\n      return __id;\n    }).indexOf(value.__id).toString();\n    return createElement(Consumer, null, _ref3 => {\n      let {\n        option,\n        isDragging,\n        isOpen,\n        parentValue\n      } = _ref3;\n      return createElement(\"li\", {\n        className: classnames('ct-layer', option.itemClass, {\n          [`ct-disabled`]: !_objectSpread({\n            enabled: true\n          }, value).enabled\n        })\n      }, createElement(LayerControls, {\n        items: items,\n        onChange: onChange,\n        value: value,\n        itemIndex: itemIndex\n      }), option.settings[value.id] && option.settings[value.id].options && isOpen === value.__id && (!isDragging || isDragging && isDragging !== isOpen) && createElement(\"div\", {\n        className: \"ct-layer-content\"\n      }, createElement(OptionsPanel, {\n        hasRevertButton: false,\n        parentValue: parentValue,\n        onChange: (key, newValue) => {\n          if (option.settings[value.id].sync && option.settings[value.id].clone) {\n            let totalItems = items.filter(_ref4 => {\n              let {\n                id\n              } = _ref4;\n              return id === value.id;\n            }).length;\n            let idForSync = `${option.settings[value.id].sync.id}_first`;\n\n            if (totalItems > 1 && items.filter(_ref5 => {\n              let {\n                id\n              } = _ref5;\n              return id === value.id;\n            }).map(_ref6 => {\n              let {\n                __id\n              } = _ref6;\n              return __id;\n            }).indexOf(value.__id) > 0) {\n              idForSync = `${option.settings[value.id].sync.id}_second`;\n            }\n\n            wp.customize && wp.customize.previewer && wp.customize.previewer.send('ct:sync:refresh_partial', {\n              id: idForSync\n            });\n          }\n\n          onChange(items.map(l => l.__id === value.__id ? _objectSpread(_objectSpread({}, l), {}, {\n            [key]: newValue\n          }) : l));\n        },\n        value: getValueFromInput(option.settings[value.id].options, _objectSpread(_objectSpread(_objectSpread({}, option.value.filter(_ref7 => {\n          let {\n            id\n          } = _ref7;\n          return id === value.id;\n        }).length > 1 ? option.value.filter(_ref8 => {\n          let {\n            id\n          } = _ref8;\n          return value.id === id;\n        })[items.filter(_ref9 => {\n          let {\n            id\n          } = _ref9;\n          return id === value.id;\n        }).map(_ref10 => {\n          let {\n            __id\n          } = _ref10;\n          return __id;\n        }).indexOf(value.__id)] : {}), value), {}, {\n          itemIndex\n        })),\n        options: option.settings[value.id].options\n      })));\n    });\n  }\n\n}\n\nconst SortableItem = SortableElement(SingleItem);\nconst SortableList = SortableContainer(_ref11 => {\n  let {\n    items,\n    onChange\n  } = _ref11;\n  return createElement(Consumer, null, _ref12 => {\n    let {\n      option\n    } = _ref12;\n    return createElement(\"ul\", {\n      className: \"ct-layers\"\n    }, items.map((value, index) => createElement(SortableItem, {\n      key: value.__id,\n      index: index,\n      onChange: onChange,\n      value: value,\n      items: items,\n      disabled: !!option.disableDrag\n    })));\n  });\n});\n\nconst Layers = _ref13 => {\n  let {\n    value,\n    option,\n    onChange,\n    values\n  } = _ref13;\n  const [state, setState] = useState(getDefaultState());\n\n  const addForId = function (idToAdd) {\n    let val = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n    onChange([...(value || []), _objectSpread(_objectSpread(_objectSpread({\n      id: idToAdd,\n      enabled: true\n    }, getValueFromInput(option.settings[idToAdd].options || {}, {})), val), {}, {\n      __id: nanoid()\n    })]);\n  };\n\n  const computedValue = (option.manageable ? valueWithUniqueIds(value) : [...valueWithUniqueIds(value), ...option.value.filter(_ref14 => {\n    let {\n      id\n    } = _ref14;\n    return value.map(_ref15 => {\n      let {\n        id\n      } = _ref15;\n      return id;\n    }).indexOf(id) === -1;\n  }).map(item => _objectSpread(_objectSpread({}, item), {}, {\n    __id: nanoid(),\n    enabled: false\n  }))]).filter(item => !!option.settings[item.id]);\n  return createElement(Provider, {\n    value: _objectSpread(_objectSpread({}, state), {}, {\n      parentValue: values,\n      addCurrentlySelectedItem: () => {\n        const idToAdd = state.currentlyPickedItem || itemsThatAreNotAdded(valueWithUniqueIds(value), option)[0];\n        setState(state => _objectSpread(_objectSpread({}, state), {}, {\n          currentlyPickedItem: null\n        }));\n        addForId(idToAdd);\n      },\n      addForId: (id, value) => addForId(id, value),\n      option: option,\n      setCurrentItem: currentlyPickedItem => setState(state => _objectSpread(_objectSpread({}, state), {}, {\n        currentlyPickedItem\n      })),\n      removeForId: idToRemove => onChange(valueWithUniqueIds(value).filter(_ref16 => {\n        let {\n          __id: id\n        } = _ref16;\n        return id !== idToRemove;\n      })),\n      toggleOptionsPanel: idToAdd => {\n        if (value.length > 0 && !value[0].__id) {\n          wp.customize && wp.customize.previewer && wp.customize.previewer.send('ct:sync:refresh_partial', {\n            shouldSkip: true\n          });\n          onChange(computedValue);\n        }\n\n        setState(state => _objectSpread(_objectSpread({}, state), {}, {\n          isOpen: state.isOpen === idToAdd ? false : idToAdd\n        }));\n      }\n    })\n  }, option.manageable && createElement(SelectThatAddsItems, {\n    value: computedValue,\n    option\n  }), createElement(SortableList, {\n    useDragHandle: true,\n    distance: 3,\n    lockAxis: \"y\",\n    items: computedValue,\n    onChange: v => onChange(v),\n    helperContainer: () => document.querySelector('#customize-theme-controls') || document.body,\n    onSortEnd: _ref17 => {\n      let {\n        oldIndex,\n        newIndex\n      } = _ref17;\n      onChange(arrayMove(computedValue, oldIndex, newIndex));\n      setState(state => _objectSpread(_objectSpread({}, state), {}, {\n        isDragging: false\n      }));\n    },\n    updateBeforeSortStart: _ref18 => {\n      let {\n        index\n      } = _ref18;\n      new Promise(resolve => {\n        if (value.length > 0 && !value[0].__id) {\n          wp.customize && wp.customize.previewer && wp.customize.previewer.send('ct:sync:refresh_partial', {\n            shouldSkip: true\n          });\n          onChange(computedValue);\n        }\n\n        setState(state => _objectSpread(_objectSpread({}, state), {}, {\n          isDragging: computedValue[index].__id\n        }));\n        resolve();\n      });\n    }\n  }));\n};\n\nexport default Layers;"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///6780\n')},546:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (/* binding */ MultiImageUploader)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(4184);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var ct_i18n__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(5652);\n/* harmony import */ var ct_i18n__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(ct_i18n__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(6715);\n/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_3__);\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\nconst ALLOWED_MEDIA_TYPES = [\'image\'];\nclass MultiImageUploader extends _wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Component {\n constructor() {\n super(...arguments);\n\n _defineProperty(this, "params", {\n height: 250,\n width: 250,\n flex_width: true,\n flex_height: true\n });\n\n _defineProperty(this, "state", {\n attachment_info: []\n });\n\n _defineProperty(this, "getUrlFor", attachmentInfo => attachmentInfo ? (attachmentInfo.width < 700 ? attachmentInfo.sizes.full : underscore__WEBPACK_IMPORTED_MODULE_3___default().max(underscore__WEBPACK_IMPORTED_MODULE_3___default().values(underscore__WEBPACK_IMPORTED_MODULE_3___default().keys(attachmentInfo.sizes).length === 1 ? attachmentInfo.sizes : underscore__WEBPACK_IMPORTED_MODULE_3___default().omit(attachmentInfo.sizes, \'full\')), _ref => {\n let {\n width\n } = _ref;\n return width;\n })).url || attachmentInfo.url : null);\n }\n\n render() {\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", _extends({\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()(\'ct-attachment-multi\', {})\n }, this.props.option.attr || {}), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(wp.mediaUtils.MediaUpload, {\n onSelect: media => {\n const result = media.map(attachment => ({\n url: this.getUrlFor(attachment),\n attachment_id: attachment.id\n }));\n this.props.onChange(result);\n },\n gallery: true,\n allowedTypes: ALLOWED_MEDIA_TYPES,\n value: this.props.value.map(_ref2 => {\n let {\n attachment_id\n } = _ref2;\n return attachment_id;\n }),\n multiple: true,\n render: _ref3 => {\n let {\n open\n } = _ref3;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, Array.isArray(this.props.value) && this.props.value.length > 0 && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", {\n className: "ct-thumbnails-list"\n }, this.props.value.map(_ref4 => {\n let {\n url,\n attachment_id\n } = _ref4;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", {\n key: attachment_id,\n className: "thumbnail thumbnail-image",\n onClick: () => {\n open();\n }\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("img", {\n className: "attachment-thumb",\n src: url,\n draggable: "false",\n alt: ""\n }), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", {\n className: "actions"\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("button", {\n type: "button",\n className: "button edit-button control-focus",\n title: "Edit"\n }), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("button", {\n title: "Remove",\n type: "button",\n className: "button remove-button",\n onClick: e => {\n e.stopPropagation();\n this.props.onChange(this.props.value.filter(a => a.attachment_id !== attachment_id));\n }\n })));\n })), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("button", {\n type: "button",\n className: "button edit-button control-focus",\n title: "Edit",\n onClick: () => open()\n }, (0,ct_i18n__WEBPACK_IMPORTED_MODULE_2__.__)(\'Add/Edit Gallery\', \'blocksy\')));\n }\n }));\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNTQ2LmpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9zdGF0aWMvanMvb3B0aW9ucy9vcHRpb25zL2N0LW11bHRpLWltYWdlLXVwbG9hZGVyLmpzPzVmNmMiXSwic291cmNlc0NvbnRlbnQiOlsiZnVuY3Rpb24gX2V4dGVuZHMoKSB7IF9leHRlbmRzID0gT2JqZWN0LmFzc2lnbiA/IE9iamVjdC5hc3NpZ24uYmluZCgpIDogZnVuY3Rpb24gKHRhcmdldCkgeyBmb3IgKHZhciBpID0gMTsgaSA8IGFyZ3VtZW50cy5sZW5ndGg7IGkrKykgeyB2YXIgc291cmNlID0gYXJndW1lbnRzW2ldOyBmb3IgKHZhciBrZXkgaW4gc291cmNlKSB7IGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwoc291cmNlLCBrZXkpKSB7IHRhcmdldFtrZXldID0gc291cmNlW2tleV07IH0gfSB9IHJldHVybiB0YXJnZXQ7IH07IHJldHVybiBfZXh0ZW5kcy5hcHBseSh0aGlzLCBhcmd1bWVudHMpOyB9XG5cbmZ1bmN0aW9uIF9kZWZpbmVQcm9wZXJ0eShvYmosIGtleSwgdmFsdWUpIHsgaWYgKGtleSBpbiBvYmopIHsgT2JqZWN0LmRlZmluZVByb3BlcnR5KG9iaiwga2V5LCB7IHZhbHVlOiB2YWx1ZSwgZW51bWVyYWJsZTogdHJ1ZSwgY29uZmlndXJhYmxlOiB0cnVlLCB3cml0YWJsZTogdHJ1ZSB9KTsgfSBlbHNlIHsgb2JqW2tleV0gPSB2YWx1ZTsgfSByZXR1cm4gb2JqOyB9XG5cbmltcG9ydCB7IGNyZWF0ZUVsZW1lbnQsIENvbXBvbmVudCwgRnJhZ21lbnQgfSBmcm9tICdAd29yZHByZXNzL2VsZW1lbnQnO1xuaW1wb3J0IGNsYXNzbmFtZXMgZnJvbSAnY2xhc3NuYW1lcyc7XG5pbXBvcnQgeyBfXyB9IGZyb20gJ2N0LWkxOG4nO1xuaW1wb3J0IF8gZnJvbSAndW5kZXJzY29yZSc7XG5jb25zdCBBTExPV0VEX01FRElBX1RZUEVTID0gWydpbWFnZSddO1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgTXVsdGlJbWFnZVVwbG9hZGVyIGV4dGVuZHMgQ29tcG9uZW50IHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoLi4uYXJndW1lbnRzKTtcblxuICAgIF9kZWZpbmVQcm9wZXJ0eSh0aGlzLCBcInBhcmFtc1wiLCB7XG4gICAgICBoZWlnaHQ6IDI1MCxcbiAgICAgIHdpZHRoOiAyNTAsXG4gICAgICBmbGV4X3dpZHRoOiB0cnVlLFxuICAgICAgZmxleF9oZWlnaHQ6IHRydWVcbiAgICB9KTtcblxuICAgIF9kZWZpbmVQcm9wZXJ0eSh0aGlzLCBcInN0YXRlXCIsIHtcbiAgICAgIGF0dGFjaG1lbnRfaW5mbzogW11cbiAgICB9KTtcblxuICAgIF9kZWZpbmVQcm9wZXJ0eSh0aGlzLCBcImdldFVybEZvclwiLCBhdHRhY2htZW50SW5mbyA9PiBhdHRhY2htZW50SW5mbyA/IChhdHRhY2htZW50SW5mby53aWR0aCA8IDcwMCA/IGF0dGFjaG1lbnRJbmZvLnNpemVzLmZ1bGwgOiBfLm1heChfLnZhbHVlcyhfLmtleXMoYXR0YWNobWVudEluZm8uc2l6ZXMpLmxlbmd0aCA9PT0gMSA/IGF0dGFjaG1lbnRJbmZvLnNpemVzIDogXy5vbWl0KGF0dGFjaG1lbnRJbmZvLnNpemVzLCAnZnVsbCcpKSwgX3JlZiA9PiB7XG4gICAgICBsZXQge1xuICAgICAgICB3aWR0aFxuICAgICAgfSA9IF9yZWY7XG4gICAgICByZXR1cm4gd2lkdGg7XG4gICAgfSkpLnVybCB8fCBhdHRhY2htZW50SW5mby51cmwgOiBudWxsKTtcbiAgfVxuXG4gIHJlbmRlcigpIHtcbiAgICByZXR1cm4gY3JlYXRlRWxlbWVudChcImRpdlwiLCBfZXh0ZW5kcyh7XG4gICAgICBjbGFzc05hbWU6IGNsYXNzbmFtZXMoJ2N0LWF0dGFjaG1lbnQtbXVsdGknLCB7fSlcbiAgICB9LCB0aGlzLnByb3BzLm9wdGlvbi5hdHRyIHx8IHt9KSwgY3JlYXRlRWxlbWVudCh3cC5tZWRpYVV0aWxzLk1lZGlhVXBsb2FkLCB7XG4gICAgICBvblNlbGVjdDogbWVkaWEgPT4ge1xuICAgICAgICBjb25zdCByZXN1bHQgPSBtZWRpYS5tYXAoYXR0YWNobWVudCA9PiAoe1xuICAgICAgICAgIHVybDogdGhpcy5nZXRVcmxGb3IoYXR0YWNobWVudCksXG4gICAgICAgICAgYXR0YWNobWVudF9pZDogYXR0YWNobWVudC5pZFxuICAgICAgICB9KSk7XG4gICAgICAgIHRoaXMucHJvcHMub25DaGFuZ2UocmVzdWx0KTtcbiAgICAgIH0sXG4gICAgICBnYWxsZXJ5OiB0cnVlLFxuICAgICAgYWxsb3dlZFR5cGVzOiBBTExPV0VEX01FRElBX1RZUEVTLFxuICAgICAgdmFsdWU6IHRoaXMucHJvcHMudmFsdWUubWFwKF9yZWYyID0+IHtcbiAgICAgICAgbGV0IHtcbiAgICAgICAgICBhdHRhY2htZW50X2lkXG4gICAgICAgIH0gPSBfcmVmMjtcbiAgICAgICAgcmV0dXJuIGF0dGFjaG1lbnRfaWQ7XG4gICAgICB9KSxcbiAgICAgIG11bHRpcGxlOiB0cnVlLFxuICAgICAgcmVuZGVyOiBfcmVmMyA9PiB7XG4gICAgICAgIGxldCB7XG4gICAgICAgICAgb3BlblxuICAgICAgICB9ID0gX3JlZjM7XG4gICAgICAgIHJldHVybiBjcmVhdGVFbGVtZW50KEZyYWdtZW50LCBudWxsLCBBcnJheS5pc0FycmF5KHRoaXMucHJvcHMudmFsdWUpICYmIHRoaXMucHJvcHMudmFsdWUubGVuZ3RoID4gMCAmJiBjcmVhdGVFbGVtZW50KFwiZGl2XCIsIHtcbiAgICAgICAgICBjbGFzc05hbWU6IFwiY3QtdGh1bWJuYWlscy1saXN0XCJcbiAgICAgICAgfSwgdGhpcy5wcm9wcy52YWx1ZS5tYXAoX3JlZjQgPT4ge1xuICAgICAgICAgIGxldCB7XG4gICAgICAgICAgICB1cmwsXG4gICAgICAgICAgICBhdHRhY2htZW50X2lkXG4gICAgICAgICAgfSA9IF9yZWY0O1xuICAgICAgICAgIHJldHVybiBjcmVhdGVFbGVtZW50KFwiZGl2XCIsIHtcbiAgICAgICAgICAgIGtleTogYXR0YWNobWVudF9pZCxcbiAgICAgICAgICAgIGNsYXNzTmFtZTogXCJ0aHVtYm5haWwgdGh1bWJuYWlsLWltYWdlXCIsXG4gICAgICAgICAgICBvbkNsaWNrOiAoKSA9PiB7XG4gICAgICAgICAgICAgIG9wZW4oKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9LCBjcmVhdGVFbGVtZW50KFwiaW1nXCIsIHtcbiAgICAgICAgICAgIGNsYXNzTmFtZTogXCJhdHRhY2htZW50LXRodW1iXCIsXG4gICAgICAgICAgICBzcmM6IHVybCxcbiAgICAgICAgICAgIGRyYWdnYWJsZTogXCJmYWxzZVwiLFxuICAgICAgICAgICAgYWx0OiBcIlwiXG4gICAgICAgICAgfSksIGNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwge1xuICAgICAgICAgICAgY2xhc3NOYW1lOiBcImFjdGlvbnNcIlxuICAgICAgICAgIH0sIGNyZWF0ZUVsZW1lbnQoXCJidXR0b25cIiwge1xuICAgICAgICAgICAgdHlwZTogXCJidXR0b25cIixcbiAgICAgICAgICAgIGNsYXNzTmFtZTogXCJidXR0b24gZWRpdC1idXR0b24gY29udHJvbC1mb2N1c1wiLFxuICAgICAgICAgICAgdGl0bGU6IFwiRWRpdFwiXG4gICAgICAgICAgfSksIGNyZWF0ZUVsZW1lbnQoXCJidXR0b25cIiwge1xuICAgICAgICAgICAgdGl0bGU6IFwiUmVtb3ZlXCIsXG4gICAgICAgICAgICB0eXBlOiBcImJ1dHRvblwiLFxuICAgICAgICAgICAgY2xhc3NOYW1lOiBcImJ1dHRvbiByZW1vdmUtYnV0dG9uXCIsXG4gICAgICAgICAgICBvbkNsaWNrOiBlID0+IHtcbiAgICAgICAgICAgICAgZS5zdG9wUHJvcGFnYXRpb24oKTtcbiAgICAgICAgICAgICAgdGhpcy5wcm9wcy5vbkNoYW5nZSh0aGlzLnByb3BzLnZhbHVlLmZpbHRlcihhID0+IGEuYXR0YWNobWVudF9pZCAhPT0gYXR0YWNobWVudF9pZCkpO1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH0pKSk7XG4gICAgICAgIH0pKSwgY3JlYXRlRWxlbWVudChcImJ1dHRvblwiLCB7XG4gICAgICAgICAgdHlwZTogXCJidXR0b25cIixcbiAgICAgICAgICBjbGFzc05hbWU6IFwiYnV0dG9uIGVkaXQtYnV0dG9uIGNvbnRyb2wtZm9jdXNcIixcbiAgICAgICAgICB0aXRsZTogXCJFZGl0XCIsXG4gICAgICAgICAgb25DbGljazogKCkgPT4gb3BlbigpXG4gICAgICAgIH0sIF9fKCdBZGQvRWRpdCBHYWxsZXJ5JywgJ2Jsb2Nrc3knKSkpO1xuICAgICAgfVxuICAgIH0pKTtcbiAgfVxuXG59Il0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///546\n')},9875:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\nconst Notification = _ref => {\n let {\n option: {\n text = \'\',\n attr = {}\n }\n } = _ref;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", _extends({\n className: "ct-notification"\n }, _objectSpread({}, attr || {}), {\n dangerouslySetInnerHTML: {\n __html: text\n }\n })));\n};\n\nNotification.renderingConfig = {\n design: \'none\'\n};\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Notification);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiOTg3NS5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9ibG9ja3N5T3B0aW9ucy8uL3N0YXRpYy9qcy9vcHRpb25zL29wdGlvbnMvY3Qtbm90aWZpY2F0aW9uLmpzPzkxMTYiXSwic291cmNlc0NvbnRlbnQiOlsiZnVuY3Rpb24gX2V4dGVuZHMoKSB7IF9leHRlbmRzID0gT2JqZWN0LmFzc2lnbiA/IE9iamVjdC5hc3NpZ24uYmluZCgpIDogZnVuY3Rpb24gKHRhcmdldCkgeyBmb3IgKHZhciBpID0gMTsgaSA8IGFyZ3VtZW50cy5sZW5ndGg7IGkrKykgeyB2YXIgc291cmNlID0gYXJndW1lbnRzW2ldOyBmb3IgKHZhciBrZXkgaW4gc291cmNlKSB7IGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwoc291cmNlLCBrZXkpKSB7IHRhcmdldFtrZXldID0gc291cmNlW2tleV07IH0gfSB9IHJldHVybiB0YXJnZXQ7IH07IHJldHVybiBfZXh0ZW5kcy5hcHBseSh0aGlzLCBhcmd1bWVudHMpOyB9XG5cbmZ1bmN0aW9uIG93bktleXMob2JqZWN0LCBlbnVtZXJhYmxlT25seSkgeyB2YXIga2V5cyA9IE9iamVjdC5rZXlzKG9iamVjdCk7IGlmIChPYmplY3QuZ2V0T3duUHJvcGVydHlTeW1ib2xzKSB7IHZhciBzeW1ib2xzID0gT2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9scyhvYmplY3QpOyBlbnVtZXJhYmxlT25seSAmJiAoc3ltYm9scyA9IHN5bWJvbHMuZmlsdGVyKGZ1bmN0aW9uIChzeW0pIHsgcmV0dXJuIE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3Iob2JqZWN0LCBzeW0pLmVudW1lcmFibGU7IH0pKSwga2V5cy5wdXNoLmFwcGx5KGtleXMsIHN5bWJvbHMpOyB9IHJldHVybiBrZXlzOyB9XG5cbmZ1bmN0aW9uIF9vYmplY3RTcHJlYWQodGFyZ2V0KSB7IGZvciAodmFyIGkgPSAxOyBpIDwgYXJndW1lbnRzLmxlbmd0aDsgaSsrKSB7IHZhciBzb3VyY2UgPSBudWxsICE9IGFyZ3VtZW50c1tpXSA/IGFyZ3VtZW50c1tpXSA6IHt9OyBpICUgMiA/IG93bktleXMoT2JqZWN0KHNvdXJjZSksICEwKS5mb3JFYWNoKGZ1bmN0aW9uIChrZXkpIHsgX2RlZmluZVByb3BlcnR5KHRhcmdldCwga2V5LCBzb3VyY2Vba2V5XSk7IH0pIDogT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcnMgPyBPYmplY3QuZGVmaW5lUHJvcGVydGllcyh0YXJnZXQsIE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3JzKHNvdXJjZSkpIDogb3duS2V5cyhPYmplY3Qoc291cmNlKSkuZm9yRWFjaChmdW5jdGlvbiAoa2V5KSB7IE9iamVjdC5kZWZpbmVQcm9wZXJ0eSh0YXJnZXQsIGtleSwgT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcihzb3VyY2UsIGtleSkpOyB9KTsgfSByZXR1cm4gdGFyZ2V0OyB9XG5cbmZ1bmN0aW9uIF9kZWZpbmVQcm9wZXJ0eShvYmosIGtleSwgdmFsdWUpIHsgaWYgKGtleSBpbiBvYmopIHsgT2JqZWN0LmRlZmluZVByb3BlcnR5KG9iaiwga2V5LCB7IHZhbHVlOiB2YWx1ZSwgZW51bWVyYWJsZTogdHJ1ZSwgY29uZmlndXJhYmxlOiB0cnVlLCB3cml0YWJsZTogdHJ1ZSB9KTsgfSBlbHNlIHsgb2JqW2tleV0gPSB2YWx1ZTsgfSByZXR1cm4gb2JqOyB9XG5cbmltcG9ydCB7IEZyYWdtZW50LCBjcmVhdGVFbGVtZW50LCBDb21wb25lbnQgfSBmcm9tICdAd29yZHByZXNzL2VsZW1lbnQnO1xuXG5jb25zdCBOb3RpZmljYXRpb24gPSBfcmVmID0+IHtcbiAgbGV0IHtcbiAgICBvcHRpb246IHtcbiAgICAgIHRleHQgPSAnJyxcbiAgICAgIGF0dHIgPSB7fVxuICAgIH1cbiAgfSA9IF9yZWY7XG4gIHJldHVybiBjcmVhdGVFbGVtZW50KEZyYWdtZW50LCBudWxsLCBjcmVhdGVFbGVtZW50KFwiZGl2XCIsIF9leHRlbmRzKHtcbiAgICBjbGFzc05hbWU6IFwiY3Qtbm90aWZpY2F0aW9uXCJcbiAgfSwgX29iamVjdFNwcmVhZCh7fSwgYXR0ciB8fCB7fSksIHtcbiAgICBkYW5nZXJvdXNseVNldElubmVySFRNTDoge1xuICAgICAgX19odG1sOiB0ZXh0XG4gICAgfVxuICB9KSkpO1xufTtcblxuTm90aWZpY2F0aW9uLnJlbmRlcmluZ0NvbmZpZyA9IHtcbiAgZGVzaWduOiAnbm9uZSdcbn07XG5leHBvcnQgZGVmYXVsdCBOb3RpZmljYXRpb247Il0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///9875\n')},4949:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(6715);\n/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(4184);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _components_InputWithOnlyNumbers__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(6086);\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\n\n\n\n\n\nconst round = value => Math.round(value * 10) / 10;\n\nconst NumberOption = _ref => {\n let {\n value,\n option,\n option: {\n attr,\n step = 1,\n markAsAutoFor\n },\n device,\n onChange\n } = _ref;\n const parsedValue = markAsAutoFor && markAsAutoFor.indexOf(device) > -1 ? 'auto' : value;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", _extends({\n className: classnames__WEBPACK_IMPORTED_MODULE_2___default()('ct-option-number', {\n [`ct-reached-limits`]: parseFloat(parsedValue) === parseInt(option.min) || parseFloat(parsedValue) === parseInt(option.max)\n })\n }, attr || {}), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"a\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_2___default()('ct-minus', {\n ['ct-disabled']: parseFloat(parsedValue) === parseInt(option.min)\n }),\n onClick: () => onChange(round(Math.min(Math.max(parseFloat(parsedValue) - parseFloat(step), option.min || -Infinity), option.max || Infinity)))\n }), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"a\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_2___default()('ct-plus', {\n ['ct-disabled']: parseFloat(parsedValue) === parseInt(option.max)\n }),\n onClick: () => onChange(round(Math.min(Math.max(parseFloat(parsedValue) + parseFloat(step), option.min || -Infinity), option.max || Infinity)))\n }), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_components_InputWithOnlyNumbers__WEBPACK_IMPORTED_MODULE_3__/* [\"default\"] */ .Z, {\n value: parsedValue,\n step: step,\n onBlur: () => parseFloat(parsedValue) ? onChange(round(Math.min(Math.max(parsedValue, option.min || -Infinity), option.max || Infinity))) : [],\n onChange: (value, can_safely_parse) => can_safely_parse && underscore__WEBPACK_IMPORTED_MODULE_1___default().isNumber(parseFloat(value)) ? onChange(round(Math.min(Math.max(value, option.min || -Infinity), option.max || Infinity))) : parseFloat(value) ? onChange(round(Math.min(parseFloat(value), option.max || Infinity))) : onChange(round(value))\n }));\n};\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (NumberOption);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNDk0OS5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vc3RhdGljL2pzL29wdGlvbnMvb3B0aW9ucy9jdC1udW1iZXIuanM/NDY5MiJdLCJzb3VyY2VzQ29udGVudCI6WyJmdW5jdGlvbiBfZXh0ZW5kcygpIHsgX2V4dGVuZHMgPSBPYmplY3QuYXNzaWduID8gT2JqZWN0LmFzc2lnbi5iaW5kKCkgOiBmdW5jdGlvbiAodGFyZ2V0KSB7IGZvciAodmFyIGkgPSAxOyBpIDwgYXJndW1lbnRzLmxlbmd0aDsgaSsrKSB7IHZhciBzb3VyY2UgPSBhcmd1bWVudHNbaV07IGZvciAodmFyIGtleSBpbiBzb3VyY2UpIHsgaWYgKE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChzb3VyY2UsIGtleSkpIHsgdGFyZ2V0W2tleV0gPSBzb3VyY2Vba2V5XTsgfSB9IH0gcmV0dXJuIHRhcmdldDsgfTsgcmV0dXJuIF9leHRlbmRzLmFwcGx5KHRoaXMsIGFyZ3VtZW50cyk7IH1cblxuaW1wb3J0IHsgY3JlYXRlRWxlbWVudCwgQ29tcG9uZW50IH0gZnJvbSAnQHdvcmRwcmVzcy9lbGVtZW50JztcbmltcG9ydCBfIGZyb20gJ3VuZGVyc2NvcmUnO1xuaW1wb3J0IGNsYXNzbmFtZXMgZnJvbSAnY2xhc3NuYW1lcyc7XG5pbXBvcnQgSW5wdXRXaXRoT25seU51bWJlcnMgZnJvbSAnLi4vY29tcG9uZW50cy9JbnB1dFdpdGhPbmx5TnVtYmVycyc7XG5cbmNvbnN0IHJvdW5kID0gdmFsdWUgPT4gTWF0aC5yb3VuZCh2YWx1ZSAqIDEwKSAvIDEwO1xuXG5jb25zdCBOdW1iZXJPcHRpb24gPSBfcmVmID0+IHtcbiAgbGV0IHtcbiAgICB2YWx1ZSxcbiAgICBvcHRpb24sXG4gICAgb3B0aW9uOiB7XG4gICAgICBhdHRyLFxuICAgICAgc3RlcCA9IDEsXG4gICAgICBtYXJrQXNBdXRvRm9yXG4gICAgfSxcbiAgICBkZXZpY2UsXG4gICAgb25DaGFuZ2VcbiAgfSA9IF9yZWY7XG4gIGNvbnN0IHBhcnNlZFZhbHVlID0gbWFya0FzQXV0b0ZvciAmJiBtYXJrQXNBdXRvRm9yLmluZGV4T2YoZGV2aWNlKSA+IC0xID8gJ2F1dG8nIDogdmFsdWU7XG4gIHJldHVybiBjcmVhdGVFbGVtZW50KFwiZGl2XCIsIF9leHRlbmRzKHtcbiAgICBjbGFzc05hbWU6IGNsYXNzbmFtZXMoJ2N0LW9wdGlvbi1udW1iZXInLCB7XG4gICAgICBbYGN0LXJlYWNoZWQtbGltaXRzYF06IHBhcnNlRmxvYXQocGFyc2VkVmFsdWUpID09PSBwYXJzZUludChvcHRpb24ubWluKSB8fCBwYXJzZUZsb2F0KHBhcnNlZFZhbHVlKSA9PT0gcGFyc2VJbnQob3B0aW9uLm1heClcbiAgICB9KVxuICB9LCBhdHRyIHx8IHt9KSwgY3JlYXRlRWxlbWVudChcImFcIiwge1xuICAgIGNsYXNzTmFtZTogY2xhc3NuYW1lcygnY3QtbWludXMnLCB7XG4gICAgICBbJ2N0LWRpc2FibGVkJ106IHBhcnNlRmxvYXQocGFyc2VkVmFsdWUpID09PSBwYXJzZUludChvcHRpb24ubWluKVxuICAgIH0pLFxuICAgIG9uQ2xpY2s6ICgpID0+IG9uQ2hhbmdlKHJvdW5kKE1hdGgubWluKE1hdGgubWF4KHBhcnNlRmxvYXQocGFyc2VkVmFsdWUpIC0gcGFyc2VGbG9hdChzdGVwKSwgb3B0aW9uLm1pbiB8fCAtSW5maW5pdHkpLCBvcHRpb24ubWF4IHx8IEluZmluaXR5KSkpXG4gIH0pLCBjcmVhdGVFbGVtZW50KFwiYVwiLCB7XG4gICAgY2xhc3NOYW1lOiBjbGFzc25hbWVzKCdjdC1wbHVzJywge1xuICAgICAgWydjdC1kaXNhYmxlZCddOiBwYXJzZUZsb2F0KHBhcnNlZFZhbHVlKSA9PT0gcGFyc2VJbnQob3B0aW9uLm1heClcbiAgICB9KSxcbiAgICBvbkNsaWNrOiAoKSA9PiBvbkNoYW5nZShyb3VuZChNYXRoLm1pbihNYXRoLm1heChwYXJzZUZsb2F0KHBhcnNlZFZhbHVlKSArIHBhcnNlRmxvYXQoc3RlcCksIG9wdGlvbi5taW4gfHwgLUluZmluaXR5KSwgb3B0aW9uLm1heCB8fCBJbmZpbml0eSkpKVxuICB9KSwgY3JlYXRlRWxlbWVudChJbnB1dFdpdGhPbmx5TnVtYmVycywge1xuICAgIHZhbHVlOiBwYXJzZWRWYWx1ZSxcbiAgICBzdGVwOiBzdGVwLFxuICAgIG9uQmx1cjogKCkgPT4gcGFyc2VGbG9hdChwYXJzZWRWYWx1ZSkgPyBvbkNoYW5nZShyb3VuZChNYXRoLm1pbihNYXRoLm1heChwYXJzZWRWYWx1ZSwgb3B0aW9uLm1pbiB8fCAtSW5maW5pdHkpLCBvcHRpb24ubWF4IHx8IEluZmluaXR5KSkpIDogW10sXG4gICAgb25DaGFuZ2U6ICh2YWx1ZSwgY2FuX3NhZmVseV9wYXJzZSkgPT4gY2FuX3NhZmVseV9wYXJzZSAmJiBfLmlzTnVtYmVyKHBhcnNlRmxvYXQodmFsdWUpKSA/IG9uQ2hhbmdlKHJvdW5kKE1hdGgubWluKE1hdGgubWF4KHZhbHVlLCBvcHRpb24ubWluIHx8IC1JbmZpbml0eSksIG9wdGlvbi5tYXggfHwgSW5maW5pdHkpKSkgOiBwYXJzZUZsb2F0KHZhbHVlKSA/IG9uQ2hhbmdlKHJvdW5kKE1hdGgubWluKHBhcnNlRmxvYXQodmFsdWUpLCBvcHRpb24ubWF4IHx8IEluZmluaXR5KSkpIDogb25DaGFuZ2Uocm91bmQodmFsdWUpKVxuICB9KSk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBOdW1iZXJPcHRpb247Il0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///4949\n")},3731:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"PanelMetaWrapper\": () => (/* binding */ PanelMetaWrapper),\n/* harmony export */ \"default\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(4184);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var bezier_easing__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(3431);\n/* harmony import */ var bezier_easing__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(bezier_easing__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _options_OptionsPanel__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7429);\n/* harmony import */ var _ct_switch__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(9497);\n/* harmony import */ var _components_PanelLevel__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(956);\n/* harmony import */ var _react_spring_web__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(1472);\n\n\n\n\n\n\n\nconst PanelMetaWrapper = _ref => {\n let {\n id,\n option,\n getActualOption,\n value\n } = _ref;\n const {\n panelsState,\n panelsHelpers,\n panelsDispatch,\n containerRef\n } = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useContext)(_components_PanelLevel__WEBPACK_IMPORTED_MODULE_5__/* .PanelContext */ .Q);\n const selfPanelId = id;\n (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useEffect)(() => {\n if (panelsState.previousPanel) {\n return;\n }\n\n if (!panelsHelpers.isTransitioningFor(id)) {\n return;\n }\n\n if (panelsHelpers.isOpenFor(id)) {\n if (!panelsHelpers.getWrapperParent().querySelector('.ct-tmp-panel-wrapper')) {\n const wrapper = document.createElement('div');\n wrapper.classList.add('ct-tmp-panel-wrapper');\n panelsHelpers.getWrapperParent().appendChild(wrapper);\n }\n\n if (panelsHelpers.getParentOptionsWrapper()) {\n panelsHelpers.getParentOptionsWrapper().classList.add('ct-panel-open');\n }\n\n const h3 = containerRef.current.closest('ul') && containerRef.current.closest('ul').querySelector('.customize-section-description-container h3');\n panelsDispatch({\n type: 'PANEL_RECEIVE_TITLE',\n payload: {\n titlePrefix: h3 ? `${h3.querySelector('span').innerText} ▸ ${h3.innerText.split('\\n')[h3.innerText.split('\\n').length - 1]}` : ''\n }\n });\n } else {\n if (!containerRef.current.closest('.accordion-section-content') || !containerRef.current.closest('.accordion-section-content').classList.contains('ct-panel-open')) {// return\n }\n\n if (panelsHelpers.getParentOptionsWrapper()) {\n panelsHelpers.getParentOptionsWrapper().classList.remove('ct-panel-open');\n }\n /*\n setTimeout(() =>\n \t(containerRef.current.querySelector('button')\n \t\t? containerRef.current.querySelector('button')\n \t\t: containerRef.current\n \t).focus()\n )\n */\n\n }\n }, [panelsState.previousPanel, id, panelsHelpers.isOpenFor(id)]);\n (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useEffect)(() => {\n return () => {\n ;\n [...document.querySelectorAll('.ct-panel-open:not(.open)')].map(el => el.classList.remove('ct-panel-open'));\n };\n }, []);\n const isEnabled = value === 'yes' || value === true;\n return getActualOption({\n open: () => panelsHelpers.open(id),\n wrapperAttr: {\n className: `${option.switch ? isEnabled ? 'ct-click-allowed' : '' : 'ct-click-allowed'} ct-panel`,\n onClick: _ref2 => {\n let {\n target\n } = _ref2;\n\n if (option.switch && !isEnabled) {\n return;\n }\n\n if (target.closest('.ct-tmp-panel-wrapper')) {\n return;\n }\n\n panelsHelpers.open(selfPanelId);\n }\n }\n });\n};\n\nconst PanelContainer = _ref3 => {\n let {\n option,\n id,\n onChange,\n getValues,\n onChangeFor\n } = _ref3;\n let maybeLabel = Object.keys(option).indexOf('label') === -1 ? (id || '').replace(/./, s => s.toUpperCase()).replace(/\\_|\\-/g, ' ') : option.label;\n const {\n panelsState: {\n titlePrefix,\n previousPanel\n },\n panelsState,\n panelsHelpers,\n containerRef\n } = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useContext)(_components_PanelLevel__WEBPACK_IMPORTED_MODULE_5__/* .PanelContext */ .Q);\n return containerRef.current && panelsHelpers.getWrapperParent().querySelector('.ct-tmp-panel-wrapper') ? (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createPortal)((0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_react_spring_web__WEBPACK_IMPORTED_MODULE_6__.Transition, {\n items: panelsHelpers.isOpenFor(id),\n from: {\n transform: 'translateX(100%)'\n },\n enter: {\n transform: 'translateX(0%)'\n },\n leave: previousPanel === id ? {\n transform: 'translateX(-100%)'\n } : {\n transform: 'translateX(100%)'\n },\n config: (item, type) => ({\n // delay: type === 'enter' ? 180 * 10 : 0,\n // duration: 2000,\n duration: 180,\n easing: bezier_easing__WEBPACK_IMPORTED_MODULE_2___default()(0.645, 0.045, 0.355, 1)\n }),\n onRest: isOpen => {\n panelsHelpers.stopTransitioning();\n\n if (isOpen) {\n ;\n [...panelsHelpers.getWrapperParent().querySelectorAll('.ct-tmp-panel-wrapper')].map(el => {\n setTimeout(() => {\n if (!el.firstElementChild) {\n return;\n }\n\n el.firstElementChild.removeAttribute('style');\n });\n });\n return;\n }\n\n if (!previousPanel) {\n ;\n [...panelsHelpers.getWrapperParent().querySelectorAll('.ct-tmp-panel-wrapper')].map(el => el.parentNode.removeChild(el));\n }\n }\n }, (props, isOpen) => isOpen && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_react_spring_web__WEBPACK_IMPORTED_MODULE_6__.animated.div, {\n style: props,\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()('ct-customizer-panel ct-options-container', {\n 'ct-panel-second-level': panelsState.currentLevel === 2\n })\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", {\n className: \"customize-panel-actions\"\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"button\", {\n onClick: e => {\n e.stopPropagation();\n panelsHelpers.close();\n },\n type: \"button\",\n className: \"customize-section-back\"\n }), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"h3\", null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"span\", null, titlePrefix), maybeLabel)), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", {\n className: \"customizer-panel-content\"\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_options_OptionsPanel__WEBPACK_IMPORTED_MODULE_3__/* [\"default\"] */ .Z, {\n purpose: \"customizer\",\n onChange: (key, val) => onChangeFor(key, val),\n options: option['inner-options'],\n value: getValues()\n }))), (panelsState.currentLevel === 2 || panelsState.secondLevelTitleLabel) && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", {\n className: \"customize-panel-actions\"\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"button\", {\n onClick: e => {\n e.stopPropagation();\n panelsHelpers.close();\n },\n type: \"button\",\n className: \"customize-section-back\"\n }), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"h3\", null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"span\", null, panelsState.titlePrefix + ' ▸ ' + maybeLabel), panelsState.secondLevelTitleLabel)), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", {\n className: \"customizer-panel-content\"\n })))), panelsHelpers.getWrapperParent().querySelector('.ct-tmp-panel-wrapper')) : null;\n};\n\nconst Panel = _ref4 => {\n let {\n id,\n getValues,\n values,\n onChangeFor,\n option,\n value,\n view = 'normal',\n onChange\n } = _ref4;\n const {\n panelsState: {\n isOpen,\n isTransitioning\n },\n panelsHelpers\n } = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useContext)(_components_PanelLevel__WEBPACK_IMPORTED_MODULE_5__/* .PanelContext */ .Q);\n\n if (view === 'simple') {\n return panelsHelpers.isTransitioningFor(id) || panelsHelpers.isOpenFor(id) ? (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(PanelContainer, {\n id: id,\n getValues: () => getValues ? getValues() : values,\n onChangeFor: onChangeFor,\n option: option\n }) : null;\n }\n\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", {\n className: \"ct-customizer-panel-container\"\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()('ct-customizer-panel-option')\n }, option.switch && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_ct_switch__WEBPACK_IMPORTED_MODULE_4__[\"default\"], {\n value: value,\n onChange: onChange,\n onClick: e => e.stopPropagation(),\n option: {\n behavior: option.switchBehavior || 'words'\n }\n }), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"button\", {\n type: \"button\"\n })), (panelsHelpers.isTransitioningFor(id) || panelsHelpers.isOpenFor(id)) && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(PanelContainer, {\n id: id,\n getValues: () => getValues ? getValues() : values,\n onChangeFor: onChangeFor,\n option: option\n }));\n};\n\nPanel.renderingConfig = {\n design: 'inline'\n};\nPanel.MetaWrapper = PanelMetaWrapper;\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Panel);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"3731.js","mappings":";;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./static/js/options/options/ct-panel.js?ea70"],"sourcesContent":["import { createElement, useContext, useEffect, createPortal } from '@wordpress/element';\nimport classnames from 'classnames';\nimport bezierEasing from 'bezier-easing';\nimport OptionsPanel from '../../options/OptionsPanel';\nimport Switch from './ct-switch';\nimport { PanelContext } from '../components/PanelLevel';\nimport { Transition, animated } from '@react-spring/web';\nexport const PanelMetaWrapper = _ref => {\n  let {\n    id,\n    option,\n    getActualOption,\n    value\n  } = _ref;\n  const {\n    panelsState,\n    panelsHelpers,\n    panelsDispatch,\n    containerRef\n  } = useContext(PanelContext);\n  const selfPanelId = id;\n  useEffect(() => {\n    if (panelsState.previousPanel) {\n      return;\n    }\n\n    if (!panelsHelpers.isTransitioningFor(id)) {\n      return;\n    }\n\n    if (panelsHelpers.isOpenFor(id)) {\n      if (!panelsHelpers.getWrapperParent().querySelector('.ct-tmp-panel-wrapper')) {\n        const wrapper = document.createElement('div');\n        wrapper.classList.add('ct-tmp-panel-wrapper');\n        panelsHelpers.getWrapperParent().appendChild(wrapper);\n      }\n\n      if (panelsHelpers.getParentOptionsWrapper()) {\n        panelsHelpers.getParentOptionsWrapper().classList.add('ct-panel-open');\n      }\n\n      const h3 = containerRef.current.closest('ul') && containerRef.current.closest('ul').querySelector('.customize-section-description-container h3');\n      panelsDispatch({\n        type: 'PANEL_RECEIVE_TITLE',\n        payload: {\n          titlePrefix: h3 ? `${h3.querySelector('span').innerText} ▸ ${h3.innerText.split('\\n')[h3.innerText.split('\\n').length - 1]}` : ''\n        }\n      });\n    } else {\n      if (!containerRef.current.closest('.accordion-section-content') || !containerRef.current.closest('.accordion-section-content').classList.contains('ct-panel-open')) {// return\n      }\n\n      if (panelsHelpers.getParentOptionsWrapper()) {\n        panelsHelpers.getParentOptionsWrapper().classList.remove('ct-panel-open');\n      }\n      /*\n      setTimeout(() =>\n      \t(containerRef.current.querySelector('button')\n      \t\t? containerRef.current.querySelector('button')\n      \t\t: containerRef.current\n      \t).focus()\n      )\n               */\n\n    }\n  }, [panelsState.previousPanel, id, panelsHelpers.isOpenFor(id)]);\n  useEffect(() => {\n    return () => {\n      ;\n      [...document.querySelectorAll('.ct-panel-open:not(.open)')].map(el => el.classList.remove('ct-panel-open'));\n    };\n  }, []);\n  const isEnabled = value === 'yes' || value === true;\n  return getActualOption({\n    open: () => panelsHelpers.open(id),\n    wrapperAttr: {\n      className: `${option.switch ? isEnabled ? 'ct-click-allowed' : '' : 'ct-click-allowed'} ct-panel`,\n      onClick: _ref2 => {\n        let {\n          target\n        } = _ref2;\n\n        if (option.switch && !isEnabled) {\n          return;\n        }\n\n        if (target.closest('.ct-tmp-panel-wrapper')) {\n          return;\n        }\n\n        panelsHelpers.open(selfPanelId);\n      }\n    }\n  });\n};\n\nconst PanelContainer = _ref3 => {\n  let {\n    option,\n    id,\n    onChange,\n    getValues,\n    onChangeFor\n  } = _ref3;\n  let maybeLabel = Object.keys(option).indexOf('label') === -1 ? (id || '').replace(/./, s => s.toUpperCase()).replace(/\\_|\\-/g, ' ') : option.label;\n  const {\n    panelsState: {\n      titlePrefix,\n      previousPanel\n    },\n    panelsState,\n    panelsHelpers,\n    containerRef\n  } = useContext(PanelContext);\n  return containerRef.current && panelsHelpers.getWrapperParent().querySelector('.ct-tmp-panel-wrapper') ? createPortal(createElement(Transition, {\n    items: panelsHelpers.isOpenFor(id),\n    from: {\n      transform: 'translateX(100%)'\n    },\n    enter: {\n      transform: 'translateX(0%)'\n    },\n    leave: previousPanel === id ? {\n      transform: 'translateX(-100%)'\n    } : {\n      transform: 'translateX(100%)'\n    },\n    config: (item, type) => ({\n      // delay: type === 'enter' ? 180 * 10 : 0,\n      // duration: 2000,\n      duration: 180,\n      easing: bezierEasing(0.645, 0.045, 0.355, 1)\n    }),\n    onRest: isOpen => {\n      panelsHelpers.stopTransitioning();\n\n      if (isOpen) {\n        ;\n        [...panelsHelpers.getWrapperParent().querySelectorAll('.ct-tmp-panel-wrapper')].map(el => {\n          setTimeout(() => {\n            if (!el.firstElementChild) {\n              return;\n            }\n\n            el.firstElementChild.removeAttribute('style');\n          });\n        });\n        return;\n      }\n\n      if (!previousPanel) {\n        ;\n        [...panelsHelpers.getWrapperParent().querySelectorAll('.ct-tmp-panel-wrapper')].map(el => el.parentNode.removeChild(el));\n      }\n    }\n  }, (props, isOpen) => isOpen && createElement(animated.div, {\n    style: props,\n    className: classnames('ct-customizer-panel ct-options-container', {\n      'ct-panel-second-level': panelsState.currentLevel === 2\n    })\n  }, createElement(\"div\", null, createElement(\"div\", {\n    className: \"customize-panel-actions\"\n  }, createElement(\"button\", {\n    onClick: e => {\n      e.stopPropagation();\n      panelsHelpers.close();\n    },\n    type: \"button\",\n    className: \"customize-section-back\"\n  }), createElement(\"h3\", null, createElement(\"span\", null, titlePrefix), maybeLabel)), createElement(\"div\", {\n    className: \"customizer-panel-content\"\n  }, createElement(OptionsPanel, {\n    purpose: \"customizer\",\n    onChange: (key, val) => onChangeFor(key, val),\n    options: option['inner-options'],\n    value: getValues()\n  }))), (panelsState.currentLevel === 2 || panelsState.secondLevelTitleLabel) && createElement(\"div\", null, createElement(\"div\", {\n    className: \"customize-panel-actions\"\n  }, createElement(\"button\", {\n    onClick: e => {\n      e.stopPropagation();\n      panelsHelpers.close();\n    },\n    type: \"button\",\n    className: \"customize-section-back\"\n  }), createElement(\"h3\", null, createElement(\"span\", null, panelsState.titlePrefix + ' ▸ ' + maybeLabel), panelsState.secondLevelTitleLabel)), createElement(\"div\", {\n    className: \"customizer-panel-content\"\n  })))), panelsHelpers.getWrapperParent().querySelector('.ct-tmp-panel-wrapper')) : null;\n};\n\nconst Panel = _ref4 => {\n  let {\n    id,\n    getValues,\n    values,\n    onChangeFor,\n    option,\n    value,\n    view = 'normal',\n    onChange\n  } = _ref4;\n  const {\n    panelsState: {\n      isOpen,\n      isTransitioning\n    },\n    panelsHelpers\n  } = useContext(PanelContext);\n\n  if (view === 'simple') {\n    return panelsHelpers.isTransitioningFor(id) || panelsHelpers.isOpenFor(id) ? createElement(PanelContainer, {\n      id: id,\n      getValues: () => getValues ? getValues() : values,\n      onChangeFor: onChangeFor,\n      option: option\n    }) : null;\n  }\n\n  return createElement(\"div\", {\n    className: \"ct-customizer-panel-container\"\n  }, createElement(\"div\", {\n    className: classnames('ct-customizer-panel-option')\n  }, option.switch && createElement(Switch, {\n    value: value,\n    onChange: onChange,\n    onClick: e => e.stopPropagation(),\n    option: {\n      behavior: option.switchBehavior || 'words'\n    }\n  }), createElement(\"button\", {\n    type: \"button\"\n  })), (panelsHelpers.isTransitioningFor(id) || panelsHelpers.isOpenFor(id)) && createElement(PanelContainer, {\n    id: id,\n    getValues: () => getValues ? getValues() : values,\n    onChangeFor: onChangeFor,\n    option: option\n  }));\n};\n\nPanel.renderingConfig = {\n  design: 'inline'\n};\nPanel.MetaWrapper = PanelMetaWrapper;\nexport default Panel;"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///3731\n")},7636:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(4184);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var match_conditions__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7465);\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\n\n\n\n\nconst RadioInput = props => {\n const {\n inline = false\n } = props.option;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", _extends({\n className: "ct-radio-option"\n }, inline ? {\n [\'data-inline\']: \'\'\n } : {}, props.option.attr || {}), Object.keys(props.option.choices).map(choice => (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("label", {\n key: choice\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("input", {\n type: "radio",\n checked: choice === props.value,\n onChange: () => props.onChange(choice)\n }), props.option.choices[choice])));\n};\n\nconst DefaultRadio = _ref => {\n let {\n option,\n values,\n value,\n onChange,\n singleChoiceProps\n } = _ref;\n const {\n inline = false\n } = option;\n let matchingChoices = Object.keys(option.choices).filter(choice => {\n if (!option.conditions) {\n return true;\n }\n\n if (!option.conditions[choice]) {\n return true;\n }\n\n return (0,match_conditions__WEBPACK_IMPORTED_MODULE_2__/* .matchValuesWithCondition */ .Nj)((0,match_conditions__WEBPACK_IMPORTED_MODULE_2__/* .normalizeCondition */ .KY)(option.conditions[choice]), values);\n });\n let normalizedValue = matchingChoices.includes(value) ? value : option.value;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("ul", _extends({\n className: "ct-radio-option ct-buttons-group"\n }, inline ? {\n [\'data-inline\']: \'\'\n } : {}, option.attr || {}), matchingChoices.map((choice, index) => (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("li", _extends({\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()({\n active: choice === normalizedValue\n }),\n onClick: () => onChange(choice),\n key: choice,\n dangerouslySetInnerHTML: {\n __html: option.choices[choice]\n }\n }, singleChoiceProps ? singleChoiceProps(choice) : {}))));\n};\n\nconst Radio = props => {\n const {\n option: {\n view\n }\n } = props;\n\n if (view === \'radio\') {\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(RadioInput, props);\n }\n\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(DefaultRadio, props);\n};\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Radio);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNzYzNi5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9zdGF0aWMvanMvb3B0aW9ucy9vcHRpb25zL2N0LXJhZGlvLmpzP2I0ZTIiXSwic291cmNlc0NvbnRlbnQiOlsiZnVuY3Rpb24gX2V4dGVuZHMoKSB7IF9leHRlbmRzID0gT2JqZWN0LmFzc2lnbiA/IE9iamVjdC5hc3NpZ24uYmluZCgpIDogZnVuY3Rpb24gKHRhcmdldCkgeyBmb3IgKHZhciBpID0gMTsgaSA8IGFyZ3VtZW50cy5sZW5ndGg7IGkrKykgeyB2YXIgc291cmNlID0gYXJndW1lbnRzW2ldOyBmb3IgKHZhciBrZXkgaW4gc291cmNlKSB7IGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwoc291cmNlLCBrZXkpKSB7IHRhcmdldFtrZXldID0gc291cmNlW2tleV07IH0gfSB9IHJldHVybiB0YXJnZXQ7IH07IHJldHVybiBfZXh0ZW5kcy5hcHBseSh0aGlzLCBhcmd1bWVudHMpOyB9XG5cbmltcG9ydCB7IGNyZWF0ZUVsZW1lbnQsIENvbXBvbmVudCB9IGZyb20gJ0B3b3JkcHJlc3MvZWxlbWVudCc7XG5pbXBvcnQgY2xhc3NuYW1lcyBmcm9tICdjbGFzc25hbWVzJztcbmltcG9ydCB7IG5vcm1hbGl6ZUNvbmRpdGlvbiwgbWF0Y2hWYWx1ZXNXaXRoQ29uZGl0aW9uIH0gZnJvbSAnbWF0Y2gtY29uZGl0aW9ucyc7XG5cbmNvbnN0IFJhZGlvSW5wdXQgPSBwcm9wcyA9PiB7XG4gIGNvbnN0IHtcbiAgICBpbmxpbmUgPSBmYWxzZVxuICB9ID0gcHJvcHMub3B0aW9uO1xuICByZXR1cm4gY3JlYXRlRWxlbWVudChcImRpdlwiLCBfZXh0ZW5kcyh7XG4gICAgY2xhc3NOYW1lOiBcImN0LXJhZGlvLW9wdGlvblwiXG4gIH0sIGlubGluZSA/IHtcbiAgICBbJ2RhdGEtaW5saW5lJ106ICcnXG4gIH0gOiB7fSwgcHJvcHMub3B0aW9uLmF0dHIgfHwge30pLCBPYmplY3Qua2V5cyhwcm9wcy5vcHRpb24uY2hvaWNlcykubWFwKGNob2ljZSA9PiBjcmVhdGVFbGVtZW50KFwibGFiZWxcIiwge1xuICAgIGtleTogY2hvaWNlXG4gIH0sIGNyZWF0ZUVsZW1lbnQoXCJpbnB1dFwiLCB7XG4gICAgdHlwZTogXCJyYWRpb1wiLFxuICAgIGNoZWNrZWQ6IGNob2ljZSA9PT0gcHJvcHMudmFsdWUsXG4gICAgb25DaGFuZ2U6ICgpID0+IHByb3BzLm9uQ2hhbmdlKGNob2ljZSlcbiAgfSksIHByb3BzLm9wdGlvbi5jaG9pY2VzW2Nob2ljZV0pKSk7XG59O1xuXG5jb25zdCBEZWZhdWx0UmFkaW8gPSBfcmVmID0+IHtcbiAgbGV0IHtcbiAgICBvcHRpb24sXG4gICAgdmFsdWVzLFxuICAgIHZhbHVlLFxuICAgIG9uQ2hhbmdlLFxuICAgIHNpbmdsZUNob2ljZVByb3BzXG4gIH0gPSBfcmVmO1xuICBjb25zdCB7XG4gICAgaW5saW5lID0gZmFsc2VcbiAgfSA9IG9wdGlvbjtcbiAgbGV0IG1hdGNoaW5nQ2hvaWNlcyA9IE9iamVjdC5rZXlzKG9wdGlvbi5jaG9pY2VzKS5maWx0ZXIoY2hvaWNlID0+IHtcbiAgICBpZiAoIW9wdGlvbi5jb25kaXRpb25zKSB7XG4gICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG5cbiAgICBpZiAoIW9wdGlvbi5jb25kaXRpb25zW2Nob2ljZV0pIHtcbiAgICAgIHJldHVybiB0cnVlO1xuICAgIH1cblxuICAgIHJldHVybiBtYXRjaFZhbHVlc1dpdGhDb25kaXRpb24obm9ybWFsaXplQ29uZGl0aW9uKG9wdGlvbi5jb25kaXRpb25zW2Nob2ljZV0pLCB2YWx1ZXMpO1xuICB9KTtcbiAgbGV0IG5vcm1hbGl6ZWRWYWx1ZSA9IG1hdGNoaW5nQ2hvaWNlcy5pbmNsdWRlcyh2YWx1ZSkgPyB2YWx1ZSA6IG9wdGlvbi52YWx1ZTtcbiAgcmV0dXJuIGNyZWF0ZUVsZW1lbnQoXCJ1bFwiLCBfZXh0ZW5kcyh7XG4gICAgY2xhc3NOYW1lOiBcImN0LXJhZGlvLW9wdGlvbiBjdC1idXR0b25zLWdyb3VwXCJcbiAgfSwgaW5saW5lID8ge1xuICAgIFsnZGF0YS1pbmxpbmUnXTogJydcbiAgfSA6IHt9LCBvcHRpb24uYXR0ciB8fCB7fSksIG1hdGNoaW5nQ2hvaWNlcy5tYXAoKGNob2ljZSwgaW5kZXgpID0+IGNyZWF0ZUVsZW1lbnQoXCJsaVwiLCBfZXh0ZW5kcyh7XG4gICAgY2xhc3NOYW1lOiBjbGFzc25hbWVzKHtcbiAgICAgIGFjdGl2ZTogY2hvaWNlID09PSBub3JtYWxpemVkVmFsdWVcbiAgICB9KSxcbiAgICBvbkNsaWNrOiAoKSA9PiBvbkNoYW5nZShjaG9pY2UpLFxuICAgIGtleTogY2hvaWNlLFxuICAgIGRhbmdlcm91c2x5U2V0SW5uZXJIVE1MOiB7XG4gICAgICBfX2h0bWw6IG9wdGlvbi5jaG9pY2VzW2Nob2ljZV1cbiAgICB9XG4gIH0sIHNpbmdsZUNob2ljZVByb3BzID8gc2luZ2xlQ2hvaWNlUHJvcHMoY2hvaWNlKSA6IHt9KSkpKTtcbn07XG5cbmNvbnN0IFJhZGlvID0gcHJvcHMgPT4ge1xuICBjb25zdCB7XG4gICAgb3B0aW9uOiB7XG4gICAgICB2aWV3XG4gICAgfVxuICB9ID0gcHJvcHM7XG5cbiAgaWYgKHZpZXcgPT09ICdyYWRpbycpIHtcbiAgICByZXR1cm4gY3JlYXRlRWxlbWVudChSYWRpb0lucHV0LCBwcm9wcyk7XG4gIH1cblxuICByZXR1cm4gY3JlYXRlRWxlbWVudChEZWZhdWx0UmFkaW8sIHByb3BzKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IFJhZGlvOyJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///7636\n')},9735:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("// ESM COMPAT FLAG\n__webpack_require__.r(__webpack_exports__);\n\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n \"default\": () => (/* binding */ ct_ratio)\n});\n\n// EXTERNAL MODULE: external \"window.wp.element\"\nvar external_window_wp_element_ = __webpack_require__(1381);\n// EXTERNAL MODULE: ./node_modules/classnames/index.js\nvar classnames = __webpack_require__(4184);\nvar classnames_default = /*#__PURE__*/__webpack_require__.n(classnames);\n// EXTERNAL MODULE: external \"window.wp.i18n\"\nvar external_window_wp_i18n_ = __webpack_require__(5652);\n// EXTERNAL MODULE: ./static/js/options/options/react-outside-click-handler.js\nvar react_outside_click_handler = __webpack_require__(8204);\n// EXTERNAL MODULE: ./node_modules/react-spring/renderprops.js\nvar renderprops = __webpack_require__(4823);\n// EXTERNAL MODULE: ./node_modules/bezier-easing/src/index.js\nvar src = __webpack_require__(3431);\nvar src_default = /*#__PURE__*/__webpack_require__.n(src);\n// EXTERNAL MODULE: ./static/js/options/GenericOptionType.js\nvar GenericOptionType = __webpack_require__(6095);\n;// CONCATENATED MODULE: ./static/js/options/options/ratio/RatioModal.js\n\n\n\n\n\n\n\nconst RatioModal = _ref => {\n let {\n renderContent,\n stopTransitioning,\n el,\n isTransitioning,\n isPicking\n } = _ref;\n return (isTransitioning || isPicking) && (0,external_window_wp_element_.createPortal)((0,external_window_wp_element_.createElement)(renderprops/* Transition */.uT, {\n items: isPicking,\n onRest: isOpen => stopTransitioning(),\n config: {\n duration: 100,\n easing: src_default()(0.25, 0.1, 0.25, 1.0)\n },\n from: {\n transform: 'scale3d(0.95, 0.95, 1)',\n opacity: 0\n },\n enter: {\n transform: 'scale3d(1, 1, 1)',\n opacity: 1\n },\n leave: {\n transform: 'scale3d(0.95, 0.95, 1)',\n opacity: 0\n }\n }, isPicking => isPicking && (props => (0,external_window_wp_element_.createElement)(\"div\", {\n style: props,\n className: \"ct-ratio-modal\",\n onClick: e => {\n e.preventDefault();\n e.stopPropagation();\n },\n onMouseDownCapture: e => {\n e.nativeEvent.stopImmediatePropagation();\n e.nativeEvent.stopPropagation();\n },\n onMouseUpCapture: e => {\n e.nativeEvent.stopImmediatePropagation();\n e.nativeEvent.stopPropagation();\n }\n }, renderContent && renderContent()))), el.current.closest('.ct-single-palette') ? el.current.closest('.ct-single-palette').querySelector('.ct-color-modal-wrapper') : el.current.closest('.ct-color-modal-wrapper') ? el.current.closest('.ct-color-modal-wrapper') : el.current.closest('.ct-control').querySelector('.ct-color-modal-wrapper'));\n};\n\n/* harmony default export */ const ratio_RatioModal = (RatioModal);\n// EXTERNAL MODULE: ./static/js/options/OptionsPanel.js + 7 modules\nvar OptionsPanel = __webpack_require__(7429);\n// EXTERNAL MODULE: ./static/js/options/helpers/get-value-from-input.js\nvar get_value_from_input = __webpack_require__(7069);\n;// CONCATENATED MODULE: ./static/js/options/options/ct-ratio.js\n\n\n\n\n\n\n\n\nconst Ratio = _ref => {\n let {\n option,\n value,\n onChange,\n onChangeFor,\n values\n } = _ref;\n const [isForcedReversed, setIsReversed] = (0,external_window_wp_element_.useState)(false);\n let {\n hasOriginalRatio = true,\n // popup | inline\n view = 'popup',\n preview_width_key = null\n } = option || {};\n const [currentModalTab, setCurrentTab] = (0,external_window_wp_element_.useState)('ratio');\n let normal_ratios = ['4/3', '16/9', '2/1'];\n let reversed_ratios = ['3/4', '9/16', '1/2'];\n const el = (0,external_window_wp_element_.useRef)();\n const [{\n isPicking,\n isTransitioning\n }, setAnimationState] = (0,external_window_wp_element_.useState)({\n isPicking: false,\n isTransitioning: false\n });\n const isReversed = normal_ratios.indexOf(value) > -1 ? false : reversed_ratios.indexOf(value) > -1 ? true : isForcedReversed;\n let currentTab = value === 'original' ? 'original' : value.indexOf('/') === -1 ? 'custom' : 'predefined';\n let isCustom = value.indexOf('/') === -1;\n const inlineRatioView = (0,external_window_wp_element_.createElement)(external_window_wp_element_.Fragment, null, option && option['inner-options'] && (0,external_window_wp_element_.createElement)(\"ul\", {\n className: \"ct-modal-tabs\"\n }, (0,external_window_wp_element_.createElement)(\"li\", {\n onClick: () => setCurrentTab('ratio'),\n className: classnames_default()({\n active: currentModalTab === 'ratio'\n })\n }, (0,external_window_wp_i18n_.__)('Image Ratio', 'blocksy')), (0,external_window_wp_element_.createElement)(\"li\", {\n onClick: () => setCurrentTab('size'),\n className: classnames_default()({\n active: currentModalTab === 'size'\n })\n }, (0,external_window_wp_i18n_.__)('Image Size', 'blocksy'))), (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-ratio-content\"\n }, currentModalTab === 'ratio' && (0,external_window_wp_element_.createElement)(\"div\", {\n className: classnames_default()('ct-ratio-picker', {\n reversed: isReversed\n })\n }, (0,external_window_wp_element_.createElement)(\"ul\", {\n className: \"ct-radio-option ct-buttons-group\"\n }, hasOriginalRatio && (0,external_window_wp_element_.createElement)(\"li\", {\n className: classnames_default()({\n active: currentTab === 'original'\n }),\n onClick: () => {\n if (value !== 'original') {\n onChange('original');\n }\n }\n }, (0,external_window_wp_i18n_.__)('Original', 'blocksy')), (0,external_window_wp_element_.createElement)(\"li\", {\n className: classnames_default()({\n active: currentTab === 'predefined'\n }),\n onClick: () => {\n if (value.indexOf('/') === -1 || value === 'original') {\n onChange(option.value === 'original' ? '1/1' : option.value);\n }\n }\n }, (0,external_window_wp_i18n_.__)('Predefined', 'blocksy')), (0,external_window_wp_element_.createElement)(\"li\", {\n className: classnames_default()({\n active: currentTab === 'custom'\n }),\n onClick: () => {\n if (value.indexOf('/') !== -1 || value === 'original') {\n let [first, second] = (value === 'original' ? option.value === 'original' ? '1/1' : option.value : value).split('/');\n onChange(`${first}:${second}`);\n }\n }\n }, (0,external_window_wp_i18n_.__)('Custom', 'blocksy'))), currentTab === 'predefined' && (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-ratio-predefined\"\n }, (0,external_window_wp_element_.createElement)(\"ul\", {\n className: \"ct-buttons-group\"\n }, ['1/1', ...(isReversed ? reversed_ratios : normal_ratios)].map(ratio => (0,external_window_wp_element_.createElement)(\"li\", {\n key: ratio,\n className: classnames_default()({\n active: ratio === value\n }),\n onClick: () => onChange(ratio)\n }, ratio))), (0,external_window_wp_element_.createElement)(\"button\", {\n onClick: e => {\n e.preventDefault();\n\n if (value === '1/1') {\n setIsReversed(!isReversed);\n return;\n }\n\n let [first_component, second_component] = value.split('/');\n setIsReversed(+first_component < +second_component);\n onChange(value.split('/').reverse().join('/'));\n }\n }, (0,external_window_wp_element_.createElement)(\"span\", null), (0,external_window_wp_element_.createElement)(\"i\", {\n className: \"ct-tooltip-top\"\n }, \"Reverse\"))), currentTab === 'custom' && (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-ratio-custom\"\n }, (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-option-input\"\n }, (0,external_window_wp_element_.createElement)(\"input\", {\n type: \"text\",\n value: value.split(':')[0],\n onChange: _ref2 => {\n let {\n target: {\n value: val\n }\n } = _ref2;\n onChange(`${val}:${value.split(':')[1]}`);\n }\n })), (0,external_window_wp_element_.createElement)(\"span\", null, \":\"), (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-option-input\"\n }, (0,external_window_wp_element_.createElement)(\"input\", {\n type: \"text\",\n value: value.split(':')[1],\n onChange: _ref3 => {\n let {\n target: {\n value: val\n }\n } = _ref3;\n onChange(`${value.split(':')[0]}:${val}`);\n }\n })), (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-notification\",\n dangerouslySetInnerHTML: {\n __html: (0,external_window_wp_i18n_.sprintf)((0,external_window_wp_i18n_.__)('Use this online %stool%s for calculating a custom image ratio based on your image size.', 'blocksy'), '', '')\n }\n })), currentTab === 'original' && (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-ratio-original\"\n }, (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-notification\"\n }, (0,external_window_wp_i18n_.__)('Images will be displayed using the aspect ratio in which they were uploaded.', 'blocksy')))), currentModalTab === 'size' && option['inner-options'] && (0,external_window_wp_element_.createElement)(OptionsPanel/* default */.Z, {\n onChange: (key, val) => onChangeFor(key, val),\n options: option['inner-options'],\n value: values\n })));\n\n if (view === 'inline') {\n return inlineRatioView;\n }\n\n return (0,external_window_wp_element_.createElement)(\"div\", {\n ref: el,\n className: classnames_default()('ct-ratio-picker-container', {})\n }, (0,external_window_wp_element_.createElement)(react_outside_click_handler[\"default\"], {\n useCapture: false,\n disabled: !isPicking,\n className: \"ct-ratio-preview\",\n onOutsideClick: () => {\n if (!isPicking) {\n return;\n }\n\n setAnimationState({\n isTransitioning: false,\n isPicking: false\n });\n },\n wrapperProps: {\n onClick: e => {\n e.preventDefault();\n setAnimationState({\n isTransitioning: true,\n isPicking: !isPicking\n });\n }\n }\n }, value.indexOf(':') > -1 && (0,external_window_wp_element_.createElement)(\"span\", {\n className: \"ct-ratio-key\"\n }, (0,external_window_wp_i18n_.__)('Custom', 'blocksy')), value.indexOf('/') > -1 && (0,external_window_wp_element_.createElement)(\"span\", {\n className: \"ct-ratio-key\"\n }, (0,external_window_wp_i18n_.__)('Predefined', 'blocksy')), value === 'original' ? (0,external_window_wp_i18n_.__)('Original Ratio', 'blocksy') : value.replace('/', ':'), preview_width_key && (0,external_window_wp_element_.createElement)(\"span\", {\n className: \"ct-width-key\"\n }, values[preview_width_key])), (0,external_window_wp_element_.createElement)(ratio_RatioModal, {\n el: el,\n value: value,\n onChange: onChange,\n option: option,\n isPicking: isPicking,\n isTransitioning: isTransitioning,\n onPickingChange: isPicking => {\n setAnimationState({\n isTransitioning: true,\n isPicking\n });\n },\n stopTransitioning: () => setAnimationState({\n isPicking,\n isTransitioning: false\n }),\n renderContent: () => inlineRatioView\n }));\n};\n\nRatio.ControlEnd = () => (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-color-modal-wrapper\",\n onMouseDown: e => e.stopPropagation(),\n onMouseUp: e => e.stopPropagation()\n});\n\n/* harmony default export */ const ct_ratio = (Ratio);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"9735.js","mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;ACpDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./static/js/options/options/ratio/RatioModal.js?53b2","webpack://blocksyOptions/./static/js/options/options/ct-ratio.js?2222"],"sourcesContent":["import { createElement, Component, createPortal, useRef, createRef } from '@wordpress/element';\nimport { Transition } from 'react-spring/renderprops';\nimport bezierEasing from 'bezier-easing';\nimport classnames from 'classnames';\nimport GenericOptionType from '../../GenericOptionType';\nimport { __ } from 'ct-i18n';\n\nconst RatioModal = _ref => {\n  let {\n    renderContent,\n    stopTransitioning,\n    el,\n    isTransitioning,\n    isPicking\n  } = _ref;\n  return (isTransitioning || isPicking) && createPortal(createElement(Transition, {\n    items: isPicking,\n    onRest: isOpen => stopTransitioning(),\n    config: {\n      duration: 100,\n      easing: bezierEasing(0.25, 0.1, 0.25, 1.0)\n    },\n    from: {\n      transform: 'scale3d(0.95, 0.95, 1)',\n      opacity: 0\n    },\n    enter: {\n      transform: 'scale3d(1, 1, 1)',\n      opacity: 1\n    },\n    leave: {\n      transform: 'scale3d(0.95, 0.95, 1)',\n      opacity: 0\n    }\n  }, isPicking => isPicking && (props => createElement(\"div\", {\n    style: props,\n    className: \"ct-ratio-modal\",\n    onClick: e => {\n      e.preventDefault();\n      e.stopPropagation();\n    },\n    onMouseDownCapture: e => {\n      e.nativeEvent.stopImmediatePropagation();\n      e.nativeEvent.stopPropagation();\n    },\n    onMouseUpCapture: e => {\n      e.nativeEvent.stopImmediatePropagation();\n      e.nativeEvent.stopPropagation();\n    }\n  }, renderContent && renderContent()))), el.current.closest('.ct-single-palette') ? el.current.closest('.ct-single-palette').querySelector('.ct-color-modal-wrapper') : el.current.closest('.ct-color-modal-wrapper') ? el.current.closest('.ct-color-modal-wrapper') : el.current.closest('.ct-control').querySelector('.ct-color-modal-wrapper'));\n};\n\nexport default RatioModal;","import { createElement, Component, useState, useRef, Fragment } from '@wordpress/element';\nimport cls from 'classnames';\nimport { __, sprintf } from 'ct-i18n';\nimport OutsideClickHandler from './react-outside-click-handler';\nimport RatioModal from './ratio/RatioModal';\nimport OptionsPanel from '../OptionsPanel';\nimport { getValueFromInput } from '../helpers/get-value-from-input';\n\nconst Ratio = _ref => {\n  let {\n    option,\n    value,\n    onChange,\n    onChangeFor,\n    values\n  } = _ref;\n  const [isForcedReversed, setIsReversed] = useState(false);\n  let {\n    hasOriginalRatio = true,\n    // popup | inline\n    view = 'popup',\n    preview_width_key = null\n  } = option || {};\n  const [currentModalTab, setCurrentTab] = useState('ratio');\n  let normal_ratios = ['4/3', '16/9', '2/1'];\n  let reversed_ratios = ['3/4', '9/16', '1/2'];\n  const el = useRef();\n  const [{\n    isPicking,\n    isTransitioning\n  }, setAnimationState] = useState({\n    isPicking: false,\n    isTransitioning: false\n  });\n  const isReversed = normal_ratios.indexOf(value) > -1 ? false : reversed_ratios.indexOf(value) > -1 ? true : isForcedReversed;\n  let currentTab = value === 'original' ? 'original' : value.indexOf('/') === -1 ? 'custom' : 'predefined';\n  let isCustom = value.indexOf('/') === -1;\n  const inlineRatioView = createElement(Fragment, null, option && option['inner-options'] && createElement(\"ul\", {\n    className: \"ct-modal-tabs\"\n  }, createElement(\"li\", {\n    onClick: () => setCurrentTab('ratio'),\n    className: cls({\n      active: currentModalTab === 'ratio'\n    })\n  }, __('Image Ratio', 'blocksy')), createElement(\"li\", {\n    onClick: () => setCurrentTab('size'),\n    className: cls({\n      active: currentModalTab === 'size'\n    })\n  }, __('Image Size', 'blocksy'))), createElement(\"div\", {\n    className: \"ct-ratio-content\"\n  }, currentModalTab === 'ratio' && createElement(\"div\", {\n    className: cls('ct-ratio-picker', {\n      reversed: isReversed\n    })\n  }, createElement(\"ul\", {\n    className: \"ct-radio-option ct-buttons-group\"\n  }, hasOriginalRatio && createElement(\"li\", {\n    className: cls({\n      active: currentTab === 'original'\n    }),\n    onClick: () => {\n      if (value !== 'original') {\n        onChange('original');\n      }\n    }\n  }, __('Original', 'blocksy')), createElement(\"li\", {\n    className: cls({\n      active: currentTab === 'predefined'\n    }),\n    onClick: () => {\n      if (value.indexOf('/') === -1 || value === 'original') {\n        onChange(option.value === 'original' ? '1/1' : option.value);\n      }\n    }\n  }, __('Predefined', 'blocksy')), createElement(\"li\", {\n    className: cls({\n      active: currentTab === 'custom'\n    }),\n    onClick: () => {\n      if (value.indexOf('/') !== -1 || value === 'original') {\n        let [first, second] = (value === 'original' ? option.value === 'original' ? '1/1' : option.value : value).split('/');\n        onChange(`${first}:${second}`);\n      }\n    }\n  }, __('Custom', 'blocksy'))), currentTab === 'predefined' && createElement(\"div\", {\n    className: \"ct-ratio-predefined\"\n  }, createElement(\"ul\", {\n    className: \"ct-buttons-group\"\n  }, ['1/1', ...(isReversed ? reversed_ratios : normal_ratios)].map(ratio => createElement(\"li\", {\n    key: ratio,\n    className: cls({\n      active: ratio === value\n    }),\n    onClick: () => onChange(ratio)\n  }, ratio))), createElement(\"button\", {\n    onClick: e => {\n      e.preventDefault();\n\n      if (value === '1/1') {\n        setIsReversed(!isReversed);\n        return;\n      }\n\n      let [first_component, second_component] = value.split('/');\n      setIsReversed(+first_component < +second_component);\n      onChange(value.split('/').reverse().join('/'));\n    }\n  }, createElement(\"span\", null), createElement(\"i\", {\n    className: \"ct-tooltip-top\"\n  }, \"Reverse\"))), currentTab === 'custom' && createElement(\"div\", {\n    className: \"ct-ratio-custom\"\n  }, createElement(\"div\", {\n    className: \"ct-option-input\"\n  }, createElement(\"input\", {\n    type: \"text\",\n    value: value.split(':')[0],\n    onChange: _ref2 => {\n      let {\n        target: {\n          value: val\n        }\n      } = _ref2;\n      onChange(`${val}:${value.split(':')[1]}`);\n    }\n  })), createElement(\"span\", null, \":\"), createElement(\"div\", {\n    className: \"ct-option-input\"\n  }, createElement(\"input\", {\n    type: \"text\",\n    value: value.split(':')[1],\n    onChange: _ref3 => {\n      let {\n        target: {\n          value: val\n        }\n      } = _ref3;\n      onChange(`${value.split(':')[0]}:${val}`);\n    }\n  })), createElement(\"div\", {\n    className: \"ct-notification\",\n    dangerouslySetInnerHTML: {\n      __html: sprintf(__('Use this online %stool%s for calculating a custom image ratio based on your image size.', 'blocksy'), '<a href=\"https://www.digitalrebellion.com/webapps/aspectcalc\" target=\"_blank\">', '</a>')\n    }\n  })), currentTab === 'original' && createElement(\"div\", {\n    className: \"ct-ratio-original\"\n  }, createElement(\"div\", {\n    className: \"ct-notification\"\n  }, __('Images will be displayed using the aspect ratio in which they were uploaded.', 'blocksy')))), currentModalTab === 'size' && option['inner-options'] && createElement(OptionsPanel, {\n    onChange: (key, val) => onChangeFor(key, val),\n    options: option['inner-options'],\n    value: values\n  })));\n\n  if (view === 'inline') {\n    return inlineRatioView;\n  }\n\n  return createElement(\"div\", {\n    ref: el,\n    className: cls('ct-ratio-picker-container', {})\n  }, createElement(OutsideClickHandler, {\n    useCapture: false,\n    disabled: !isPicking,\n    className: \"ct-ratio-preview\",\n    onOutsideClick: () => {\n      if (!isPicking) {\n        return;\n      }\n\n      setAnimationState({\n        isTransitioning: false,\n        isPicking: false\n      });\n    },\n    wrapperProps: {\n      onClick: e => {\n        e.preventDefault();\n        setAnimationState({\n          isTransitioning: true,\n          isPicking: !isPicking\n        });\n      }\n    }\n  }, value.indexOf(':') > -1 && createElement(\"span\", {\n    className: \"ct-ratio-key\"\n  }, __('Custom', 'blocksy')), value.indexOf('/') > -1 && createElement(\"span\", {\n    className: \"ct-ratio-key\"\n  }, __('Predefined', 'blocksy')), value === 'original' ? __('Original Ratio', 'blocksy') : value.replace('/', ':'), preview_width_key && createElement(\"span\", {\n    className: \"ct-width-key\"\n  }, values[preview_width_key])), createElement(RatioModal, {\n    el: el,\n    value: value,\n    onChange: onChange,\n    option: option,\n    isPicking: isPicking,\n    isTransitioning: isTransitioning,\n    onPickingChange: isPicking => {\n      setAnimationState({\n        isTransitioning: true,\n        isPicking\n      });\n    },\n    stopTransitioning: () => setAnimationState({\n      isPicking,\n      isTransitioning: false\n    }),\n    renderContent: () => inlineRatioView\n  }));\n};\n\nRatio.ControlEnd = () => createElement(\"div\", {\n  className: \"ct-color-modal-wrapper\",\n  onMouseDown: e => e.stopPropagation(),\n  onMouseUp: e => e.stopPropagation()\n});\n\nexport default Ratio;"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///9735\n")},1404:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('// ESM COMPAT FLAG\n__webpack_require__.r(__webpack_exports__);\n\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n "default": () => (/* binding */ ct_select)\n});\n\n// EXTERNAL MODULE: external "window.wp.element"\nvar external_window_wp_element_ = __webpack_require__(1381);\n// EXTERNAL MODULE: ./static/js/options/helpers/parse-choices.js\nvar parse_choices = __webpack_require__(4592);\n// EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js\nvar objectWithoutPropertiesLoose = __webpack_require__(3366);\n// EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/esm/extends.js\nvar esm_extends = __webpack_require__(7462);\n// EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js\nvar assertThisInitialized = __webpack_require__(7326);\n// EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/esm/inheritsLoose.js\nvar inheritsLoose = __webpack_require__(4578);\n// EXTERNAL MODULE: ./node_modules/prop-types/index.js\nvar prop_types = __webpack_require__(5697);\nvar prop_types_default = /*#__PURE__*/__webpack_require__.n(prop_types);\n// EXTERNAL MODULE: external "React"\nvar external_React_ = __webpack_require__(7363);\n// EXTERNAL MODULE: ./node_modules/downshift/node_modules/react-is/index.js\nvar react_is = __webpack_require__(1726);\n;// CONCATENATED MODULE: ./node_modules/compute-scroll-into-view/dist/index.module.js\nfunction t(t){return"object"==typeof t&&null!=t&&1===t.nodeType}function e(t,e){return(!e||"hidden"!==t)&&"visible"!==t&&"clip"!==t}function n(t,n){if(t.clientHeighte||o>t&&l=e&&d>=n?o-t-r:l>e&&dn?l-e+i:0}/* harmony default export */ function index_module(e,i){var o=window,l=i.scrollMode,d=i.block,u=i.inline,h=i.boundary,a=i.skipOverflowHiddenElements,c="function"==typeof h?h:function(t){return t!==h};if(!t(e))throw new TypeError("Invalid target");for(var f=document.scrollingElement||document.documentElement,s=[],p=e;t(p)&&c(p);){if((p=p.parentElement)===f){s.push(p);break}null!=p&&p===document.body&&n(p)&&!n(document.documentElement)||null!=p&&n(p,a)&&s.push(p)}for(var m=o.visualViewport?o.visualViewport.width:innerWidth,g=o.visualViewport?o.visualViewport.height:innerHeight,w=window.scrollX||pageXOffset,v=window.scrollY||pageYOffset,W=e.getBoundingClientRect(),b=W.height,H=W.width,y=W.top,E=W.right,M=W.bottom,V=W.left,x="start"===d||"nearest"===d?y:"end"===d?M:y+b/2,I="center"===u?V+H/2:"end"===u?E:V,C=[],T=0;T=0&&V>=0&&M<=g&&E<=m&&y>=R&&M<=Y&&V>=L&&E<=X)return C;var S=getComputedStyle(k),j=parseInt(S.borderLeftWidth,10),q=parseInt(S.borderTopWidth,10),z=parseInt(S.borderRightWidth,10),A=parseInt(S.borderBottomWidth,10),F=0,G=0,J="offsetWidth"in k?k.offsetWidth-k.clientWidth-j-z:0,K="offsetHeight"in k?k.offsetHeight-k.clientHeight-q-A:0;if(f===k)F="start"===d?x:"end"===d?x-g:"nearest"===d?r(v,v+g,g,q,A,v+x,v+x+b,b):x-g/2,G="start"===u?I:"center"===u?I-m/2:"end"===u?I-m:r(w,w+m,m,j,z,w+I,w+I+H,H),F=Math.max(0,F+v),G=Math.max(0,G+w);else{F="start"===d?x-R-q:"end"===d?x-Y+A+K:"nearest"===d?r(R,Y,D,q,A+K,x,x+b,b):x-(R+D/2)+K/2,G="start"===u?I-L-j:"center"===u?I-(L+O/2)+J/2:"end"===u?I-X+z+J:r(L,X,O,j,z+J,I,I+H,H);var N=k.scrollLeft,P=k.scrollTop;x+=P-(F=Math.max(0,Math.min(P+F,k.scrollHeight-D+K))),I+=N-(G=Math.max(0,Math.min(N+G,k.scrollWidth-O+J)))}C.push({el:k,top:F,left:G})}return C}\n//# sourceMappingURL=index.module.js.map\n\n;// CONCATENATED MODULE: ./node_modules/tslib/tslib.es6.js\n/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nfunction __extends(d, b) {\r\n if (typeof b !== "function" && b !== null)\r\n throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nvar __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nfunction __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === "function")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nfunction __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nfunction __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nfunction __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nfunction __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nfunction __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError("Generator is already executing.");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nvar __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nfunction __exportStar(m, o) {\r\n for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nfunction __values(o) {\r\n var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === "number") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");\r\n}\r\n\r\nfunction __read(o, n) {\r\n var m = typeof Symbol === "function" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i["return"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nfunction __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nfunction __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nfunction __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nfunction __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nfunction __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume("next", value); }\r\n function reject(value) { resume("throw", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nfunction __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === "return" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nfunction __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nfunction __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, "default", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o["default"] = v;\r\n};\r\n\r\nfunction __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nfunction __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nfunction __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");\r\n if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");\r\n return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nfunction __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === "m") throw new TypeError("Private method is not writable");\r\n if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");\r\n if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");\r\n return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nfunction __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== "object" && typeof receiver !== "function")) throw new TypeError("Cannot use \'in\' operator on non-object");\r\n return typeof state === "function" ? receiver === state : state.has(receiver);\r\n}\r\n\n;// CONCATENATED MODULE: ./node_modules/downshift/dist/downshift.esm.js\n\n\n\n\n\n\n\n\n\n\nvar idCounter = 0;\n/**\n * Accepts a parameter and returns it if it\'s a function\n * or a noop function if it\'s not. This allows us to\n * accept a callback, but not worry about it if it\'s not\n * passed.\n * @param {Function} cb the callback\n * @return {Function} a function\n */\n\nfunction cbToCb(cb) {\n return typeof cb === \'function\' ? cb : noop;\n}\n\nfunction noop() {}\n/**\n * Scroll node into view if necessary\n * @param {HTMLElement} node the element that should scroll into view\n * @param {HTMLElement} menuNode the menu element of the component\n */\n\n\nfunction scrollIntoView(node, menuNode) {\n if (!node) {\n return;\n }\n\n var actions = index_module(node, {\n boundary: menuNode,\n block: \'nearest\',\n scrollMode: \'if-needed\'\n });\n actions.forEach(function (_ref) {\n var el = _ref.el,\n top = _ref.top,\n left = _ref.left;\n el.scrollTop = top;\n el.scrollLeft = left;\n });\n}\n/**\n * @param {HTMLElement} parent the parent node\n * @param {HTMLElement} child the child node\n * @param {Window} environment The window context where downshift renders.\n * @return {Boolean} whether the parent is the child or the child is in the parent\n */\n\n\nfunction isOrContainsNode(parent, child, environment) {\n var result = parent === child || child instanceof environment.Node && parent.contains && parent.contains(child);\n return result;\n}\n/**\n * Simple debounce implementation. Will call the given\n * function once after the time given has passed since\n * it was last called.\n * @param {Function} fn the function to call after the time\n * @param {Number} time the time to wait\n * @return {Function} the debounced function\n */\n\n\nfunction debounce(fn, time) {\n var timeoutId;\n\n function cancel() {\n if (timeoutId) {\n clearTimeout(timeoutId);\n }\n }\n\n function wrapper() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n cancel();\n timeoutId = setTimeout(function () {\n timeoutId = null;\n fn.apply(void 0, args);\n }, time);\n }\n\n wrapper.cancel = cancel;\n return wrapper;\n}\n/**\n * This is intended to be used to compose event handlers.\n * They are executed in order until one of them sets\n * `event.preventDownshiftDefault = true`.\n * @param {...Function} fns the event handler functions\n * @return {Function} the event handler to add to an element\n */\n\n\nfunction callAllEventHandlers() {\n for (var _len2 = arguments.length, fns = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n fns[_key2] = arguments[_key2];\n }\n\n return function (event) {\n for (var _len3 = arguments.length, args = new Array(_len3 > 1 ? _len3 - 1 : 0), _key3 = 1; _key3 < _len3; _key3++) {\n args[_key3 - 1] = arguments[_key3];\n }\n\n return fns.some(function (fn) {\n if (fn) {\n fn.apply(void 0, [event].concat(args));\n }\n\n return event.preventDownshiftDefault || event.hasOwnProperty(\'nativeEvent\') && event.nativeEvent.preventDownshiftDefault;\n });\n };\n}\n\nfunction handleRefs() {\n for (var _len4 = arguments.length, refs = new Array(_len4), _key4 = 0; _key4 < _len4; _key4++) {\n refs[_key4] = arguments[_key4];\n }\n\n return function (node) {\n refs.forEach(function (ref) {\n if (typeof ref === \'function\') {\n ref(node);\n } else if (ref) {\n ref.current = node;\n }\n });\n };\n}\n/**\n * This generates a unique ID for an instance of Downshift\n * @return {String} the unique ID\n */\n\n\nfunction generateId() {\n return String(idCounter++);\n}\n/**\n * Resets idCounter to 0. Used for SSR.\n */\n\n\nfunction resetIdCounter() {\n idCounter = 0;\n}\n/**\n * Default implementation for status message. Only added when menu is open.\n * Will specify if there are results in the list, and if so, how many,\n * and what keys are relevant.\n *\n * @param {Object} param the downshift state and other relevant properties\n * @return {String} the a11y status message\n */\n\n\nfunction getA11yStatusMessage$1(_ref2) {\n var isOpen = _ref2.isOpen,\n resultCount = _ref2.resultCount,\n previousResultCount = _ref2.previousResultCount;\n\n if (!isOpen) {\n return \'\';\n }\n\n if (!resultCount) {\n return \'No results are available.\';\n }\n\n if (resultCount !== previousResultCount) {\n return resultCount + " result" + (resultCount === 1 ? \' is\' : \'s are\') + " available, use up and down arrow keys to navigate. Press Enter key to select.";\n }\n\n return \'\';\n}\n/**\n * Takes an argument and if it\'s an array, returns the first item in the array\n * otherwise returns the argument\n * @param {*} arg the maybe-array\n * @param {*} defaultValue the value if arg is falsey not defined\n * @return {*} the arg or it\'s first item\n */\n\n\nfunction unwrapArray(arg, defaultValue) {\n arg = Array.isArray(arg) ?\n /* istanbul ignore next (preact) */\n arg[0] : arg;\n\n if (!arg && defaultValue) {\n return defaultValue;\n } else {\n return arg;\n }\n}\n/**\n * @param {Object} element (P)react element\n * @return {Boolean} whether it\'s a DOM element\n */\n\n\nfunction isDOMElement(element) {\n\n\n return typeof element.type === \'string\';\n}\n/**\n * @param {Object} element (P)react element\n * @return {Object} the props\n */\n\n\nfunction getElementProps(element) {\n\n return element.props;\n}\n/**\n * Throws a helpful error message for required properties. Useful\n * to be used as a default in destructuring or object params.\n * @param {String} fnName the function name\n * @param {String} propName the prop name\n */\n\n\nfunction requiredProp(fnName, propName) {\n // eslint-disable-next-line no-console\n console.error("The property \\"" + propName + "\\" is required in \\"" + fnName + "\\"");\n}\n\nvar stateKeys = [\'highlightedIndex\', \'inputValue\', \'isOpen\', \'selectedItem\', \'type\'];\n/**\n * @param {Object} state the state object\n * @return {Object} state that is relevant to downshift\n */\n\nfunction pickState(state) {\n if (state === void 0) {\n state = {};\n }\n\n var result = {};\n stateKeys.forEach(function (k) {\n if (state.hasOwnProperty(k)) {\n result[k] = state[k];\n }\n });\n return result;\n}\n/**\n * This will perform a shallow merge of the given state object\n * with the state coming from props\n * (for the controlled component scenario)\n * This is used in state updater functions so they\'re referencing\n * the right state regardless of where it comes from.\n *\n * @param {Object} state The state of the component/hook.\n * @param {Object} props The props that may contain controlled values.\n * @returns {Object} The merged controlled state.\n */\n\n\nfunction getState(state, props) {\n return Object.keys(state).reduce(function (prevState, key) {\n prevState[key] = isControlledProp(props, key) ? props[key] : state[key];\n return prevState;\n }, {});\n}\n/**\n * This determines whether a prop is a "controlled prop" meaning it is\n * state which is controlled by the outside of this component rather\n * than within this component.\n *\n * @param {Object} props The props that may contain controlled values.\n * @param {String} key the key to check\n * @return {Boolean} whether it is a controlled controlled prop\n */\n\n\nfunction isControlledProp(props, key) {\n return props[key] !== undefined;\n}\n/**\n * Normalizes the \'key\' property of a KeyboardEvent in IE/Edge\n * @param {Object} event a keyboardEvent object\n * @return {String} keyboard key\n */\n\n\nfunction normalizeArrowKey(event) {\n var key = event.key,\n keyCode = event.keyCode;\n /* istanbul ignore next (ie) */\n\n if (keyCode >= 37 && keyCode <= 40 && key.indexOf(\'Arrow\') !== 0) {\n return "Arrow" + key;\n }\n\n return key;\n}\n/**\n * Simple check if the value passed is object literal\n * @param {*} obj any things\n * @return {Boolean} whether it\'s object literal\n */\n\n\nfunction isPlainObject(obj) {\n return Object.prototype.toString.call(obj) === \'[object Object]\';\n}\n/**\n * Returns the new index in the list, in a circular way. If next value is out of bonds from the total,\n * it will wrap to either 0 or itemCount - 1.\n *\n * @param {number} moveAmount Number of positions to move. Negative to move backwards, positive forwards.\n * @param {number} baseIndex The initial position to move from.\n * @param {number} itemCount The total number of items.\n * @param {Function} getItemNodeFromIndex Used to check if item is disabled.\n * @param {boolean} circular Specify if navigation is circular. Default is true.\n * @returns {number} The new index after the move.\n */\n\n\nfunction getNextWrappingIndex(moveAmount, baseIndex, itemCount, getItemNodeFromIndex, circular) {\n if (circular === void 0) {\n circular = true;\n }\n\n if (itemCount === 0) {\n return -1;\n }\n\n var itemsLastIndex = itemCount - 1;\n\n if (typeof baseIndex !== \'number\' || baseIndex < 0 || baseIndex >= itemCount) {\n baseIndex = moveAmount > 0 ? -1 : itemsLastIndex + 1;\n }\n\n var newIndex = baseIndex + moveAmount;\n\n if (newIndex < 0) {\n newIndex = circular ? itemsLastIndex : 0;\n } else if (newIndex > itemsLastIndex) {\n newIndex = circular ? 0 : itemsLastIndex;\n }\n\n var nonDisabledNewIndex = getNextNonDisabledIndex(moveAmount, newIndex, itemCount, getItemNodeFromIndex, circular);\n\n if (nonDisabledNewIndex === -1) {\n return baseIndex >= itemCount ? -1 : baseIndex;\n }\n\n return nonDisabledNewIndex;\n}\n/**\n * Returns the next index in the list of an item that is not disabled.\n *\n * @param {number} moveAmount Number of positions to move. Negative to move backwards, positive forwards.\n * @param {number} baseIndex The initial position to move from.\n * @param {number} itemCount The total number of items.\n * @param {Function} getItemNodeFromIndex Used to check if item is disabled.\n * @param {boolean} circular Specify if navigation is circular. Default is true.\n * @returns {number} The new index. Returns baseIndex if item is not disabled. Returns next non-disabled item otherwise. If no non-disabled found it will return -1.\n */\n\n\nfunction getNextNonDisabledIndex(moveAmount, baseIndex, itemCount, getItemNodeFromIndex, circular) {\n var currentElementNode = getItemNodeFromIndex(baseIndex);\n\n if (!currentElementNode || !currentElementNode.hasAttribute(\'disabled\')) {\n return baseIndex;\n }\n\n if (moveAmount > 0) {\n for (var index = baseIndex + 1; index < itemCount; index++) {\n if (!getItemNodeFromIndex(index).hasAttribute(\'disabled\')) {\n return index;\n }\n }\n } else {\n for (var _index = baseIndex - 1; _index >= 0; _index--) {\n if (!getItemNodeFromIndex(_index).hasAttribute(\'disabled\')) {\n return _index;\n }\n }\n }\n\n if (circular) {\n return moveAmount > 0 ? getNextNonDisabledIndex(1, 0, itemCount, getItemNodeFromIndex, false) : getNextNonDisabledIndex(-1, itemCount - 1, itemCount, getItemNodeFromIndex, false);\n }\n\n return -1;\n}\n/**\n * Checks if event target is within the downshift elements.\n *\n * @param {EventTarget} target Target to check.\n * @param {HTMLElement[]} downshiftElements The elements that form downshift (list, toggle button etc).\n * @param {Window} environment The window context where downshift renders.\n * @param {boolean} checkActiveElement Whether to also check activeElement.\n *\n * @returns {boolean} Whether or not the target is within downshift elements.\n */\n\n\nfunction targetWithinDownshift(target, downshiftElements, environment, checkActiveElement) {\n if (checkActiveElement === void 0) {\n checkActiveElement = true;\n }\n\n return downshiftElements.some(function (contextNode) {\n return contextNode && (isOrContainsNode(contextNode, target, environment) || checkActiveElement && isOrContainsNode(contextNode, environment.document.activeElement, environment));\n });\n} // eslint-disable-next-line import/no-mutable-exports\n\n\nvar validateControlledUnchanged = (/* unused pure expression or super */ null && (noop));\n/* istanbul ignore next */\n\nif (false) {}\n\nvar cleanupStatus = debounce(function (documentProp) {\n getStatusDiv(documentProp).textContent = \'\';\n}, 500);\n/**\n * @param {String} status the status message\n * @param {Object} documentProp document passed by the user.\n */\n\nfunction setStatus(status, documentProp) {\n var div = getStatusDiv(documentProp);\n\n if (!status) {\n return;\n }\n\n div.textContent = status;\n cleanupStatus(documentProp);\n}\n/**\n * Get the status node or create it if it does not already exist.\n * @param {Object} documentProp document passed by the user.\n * @return {HTMLElement} the status node.\n */\n\n\nfunction getStatusDiv(documentProp) {\n if (documentProp === void 0) {\n documentProp = document;\n }\n\n var statusDiv = documentProp.getElementById(\'a11y-status-message\');\n\n if (statusDiv) {\n return statusDiv;\n }\n\n statusDiv = documentProp.createElement(\'div\');\n statusDiv.setAttribute(\'id\', \'a11y-status-message\');\n statusDiv.setAttribute(\'role\', \'status\');\n statusDiv.setAttribute(\'aria-live\', \'polite\');\n statusDiv.setAttribute(\'aria-relevant\', \'additions text\');\n Object.assign(statusDiv.style, {\n border: \'0\',\n clip: \'rect(0 0 0 0)\',\n height: \'1px\',\n margin: \'-1px\',\n overflow: \'hidden\',\n padding: \'0\',\n position: \'absolute\',\n width: \'1px\'\n });\n documentProp.body.appendChild(statusDiv);\n return statusDiv;\n}\n\nvar unknown = false ? 0 : 0;\nvar mouseUp = false ? 0 : 1;\nvar itemMouseEnter = false ? 0 : 2;\nvar keyDownArrowUp = false ? 0 : 3;\nvar keyDownArrowDown = false ? 0 : 4;\nvar keyDownEscape = false ? 0 : 5;\nvar keyDownEnter = false ? 0 : 6;\nvar keyDownHome = false ? 0 : 7;\nvar keyDownEnd = false ? 0 : 8;\nvar clickItem = false ? 0 : 9;\nvar blurInput = false ? 0 : 10;\nvar changeInput = false ? 0 : 11;\nvar keyDownSpaceButton = false ? 0 : 12;\nvar clickButton = false ? 0 : 13;\nvar blurButton = false ? 0 : 14;\nvar controlledPropUpdatedSelectedItem = false ? 0 : 15;\nvar touchEnd = false ? 0 : 16;\n\nvar stateChangeTypes$3 = /*#__PURE__*/Object.freeze({\n __proto__: null,\n unknown: unknown,\n mouseUp: mouseUp,\n itemMouseEnter: itemMouseEnter,\n keyDownArrowUp: keyDownArrowUp,\n keyDownArrowDown: keyDownArrowDown,\n keyDownEscape: keyDownEscape,\n keyDownEnter: keyDownEnter,\n keyDownHome: keyDownHome,\n keyDownEnd: keyDownEnd,\n clickItem: clickItem,\n blurInput: blurInput,\n changeInput: changeInput,\n keyDownSpaceButton: keyDownSpaceButton,\n clickButton: clickButton,\n blurButton: blurButton,\n controlledPropUpdatedSelectedItem: controlledPropUpdatedSelectedItem,\n touchEnd: touchEnd\n});\n\nvar _excluded$4 = ["refKey", "ref"],\n _excluded2$3 = ["onClick", "onPress", "onKeyDown", "onKeyUp", "onBlur"],\n _excluded3$2 = ["onKeyDown", "onBlur", "onChange", "onInput", "onChangeText"],\n _excluded4$1 = ["refKey", "ref"],\n _excluded5$1 = ["onMouseMove", "onMouseDown", "onClick", "onPress", "index", "item"];\n\nvar Downshift = /*#__PURE__*/function () {\n var Downshift = /*#__PURE__*/function (_Component) {\n (0,inheritsLoose/* default */.Z)(Downshift, _Component);\n\n function Downshift(_props) {\n var _this;\n\n _this = _Component.call(this, _props) || this; // fancy destructuring + defaults + aliases\n // this basically says each value of state should either be set to\n // the initial value or the default value if the initial value is not provided\n\n _this.id = _this.props.id || "downshift-" + generateId();\n _this.menuId = _this.props.menuId || _this.id + "-menu";\n _this.labelId = _this.props.labelId || _this.id + "-label";\n _this.inputId = _this.props.inputId || _this.id + "-input";\n\n _this.getItemId = _this.props.getItemId || function (index) {\n return _this.id + "-item-" + index;\n };\n\n _this.input = null;\n _this.items = [];\n _this.itemCount = null;\n _this.previousResultCount = 0;\n _this.timeoutIds = [];\n\n _this.internalSetTimeout = function (fn, time) {\n var id = setTimeout(function () {\n _this.timeoutIds = _this.timeoutIds.filter(function (i) {\n return i !== id;\n });\n fn();\n }, time);\n\n _this.timeoutIds.push(id);\n };\n\n _this.setItemCount = function (count) {\n _this.itemCount = count;\n };\n\n _this.unsetItemCount = function () {\n _this.itemCount = null;\n };\n\n _this.setHighlightedIndex = function (highlightedIndex, otherStateToSet) {\n if (highlightedIndex === void 0) {\n highlightedIndex = _this.props.defaultHighlightedIndex;\n }\n\n if (otherStateToSet === void 0) {\n otherStateToSet = {};\n }\n\n otherStateToSet = pickState(otherStateToSet);\n\n _this.internalSetState((0,esm_extends["default"])({\n highlightedIndex: highlightedIndex\n }, otherStateToSet));\n };\n\n _this.clearSelection = function (cb) {\n _this.internalSetState({\n selectedItem: null,\n inputValue: \'\',\n highlightedIndex: _this.props.defaultHighlightedIndex,\n isOpen: _this.props.defaultIsOpen\n }, cb);\n };\n\n _this.selectItem = function (item, otherStateToSet, cb) {\n otherStateToSet = pickState(otherStateToSet);\n\n _this.internalSetState((0,esm_extends["default"])({\n isOpen: _this.props.defaultIsOpen,\n highlightedIndex: _this.props.defaultHighlightedIndex,\n selectedItem: item,\n inputValue: _this.props.itemToString(item)\n }, otherStateToSet), cb);\n };\n\n _this.selectItemAtIndex = function (itemIndex, otherStateToSet, cb) {\n var item = _this.items[itemIndex];\n\n if (item == null) {\n return;\n }\n\n _this.selectItem(item, otherStateToSet, cb);\n };\n\n _this.selectHighlightedItem = function (otherStateToSet, cb) {\n return _this.selectItemAtIndex(_this.getState().highlightedIndex, otherStateToSet, cb);\n };\n\n _this.internalSetState = function (stateToSet, cb) {\n var isItemSelected, onChangeArg;\n var onStateChangeArg = {};\n var isStateToSetFunction = typeof stateToSet === \'function\'; // we want to call `onInputValueChange` before the `setState` call\n // so someone controlling the `inputValue` state gets notified of\n // the input change as soon as possible. This avoids issues with\n // preserving the cursor position.\n // See https://github.com/downshift-js/downshift/issues/217 for more info.\n\n if (!isStateToSetFunction && stateToSet.hasOwnProperty(\'inputValue\')) {\n _this.props.onInputValueChange(stateToSet.inputValue, (0,esm_extends["default"])({}, _this.getStateAndHelpers(), stateToSet));\n }\n\n return _this.setState(function (state) {\n state = _this.getState(state);\n var newStateToSet = isStateToSetFunction ? stateToSet(state) : stateToSet; // Your own function that could modify the state that will be set.\n\n newStateToSet = _this.props.stateReducer(state, newStateToSet); // checks if an item is selected, regardless of if it\'s different from\n // what was selected before\n // used to determine if onSelect and onChange callbacks should be called\n\n isItemSelected = newStateToSet.hasOwnProperty(\'selectedItem\'); // this keeps track of the object we want to call with setState\n\n var nextState = {}; // this is just used to tell whether the state changed\n\n var nextFullState = {}; // we need to call on change if the outside world is controlling any of our state\n // and we\'re trying to update that state. OR if the selection has changed and we\'re\n // trying to update the selection\n\n if (isItemSelected && newStateToSet.selectedItem !== state.selectedItem) {\n onChangeArg = newStateToSet.selectedItem;\n }\n\n newStateToSet.type = newStateToSet.type || unknown;\n Object.keys(newStateToSet).forEach(function (key) {\n // onStateChangeArg should only have the state that is\n // actually changing\n if (state[key] !== newStateToSet[key]) {\n onStateChangeArg[key] = newStateToSet[key];\n } // the type is useful for the onStateChangeArg\n // but we don\'t actually want to set it in internal state.\n // this is an undocumented feature for now... Not all internalSetState\n // calls support it and I\'m not certain we want them to yet.\n // But it enables users controlling the isOpen state to know when\n // the isOpen state changes due to mouseup events which is quite handy.\n\n\n if (key === \'type\') {\n return;\n }\n\n nextFullState[key] = newStateToSet[key]; // if it\'s coming from props, then we don\'t care to set it internally\n\n if (!isControlledProp(_this.props, key)) {\n nextState[key] = newStateToSet[key];\n }\n }); // if stateToSet is a function, then we weren\'t able to call onInputValueChange\n // earlier, so we\'ll call it now that we know what the inputValue state will be.\n\n if (isStateToSetFunction && newStateToSet.hasOwnProperty(\'inputValue\')) {\n _this.props.onInputValueChange(newStateToSet.inputValue, (0,esm_extends["default"])({}, _this.getStateAndHelpers(), newStateToSet));\n }\n\n return nextState;\n }, function () {\n // call the provided callback if it\'s a function\n cbToCb(cb)(); // only call the onStateChange and onChange callbacks if\n // we have relevant information to pass them.\n\n var hasMoreStateThanType = Object.keys(onStateChangeArg).length > 1;\n\n if (hasMoreStateThanType) {\n _this.props.onStateChange(onStateChangeArg, _this.getStateAndHelpers());\n }\n\n if (isItemSelected) {\n _this.props.onSelect(stateToSet.selectedItem, _this.getStateAndHelpers());\n }\n\n if (onChangeArg !== undefined) {\n _this.props.onChange(onChangeArg, _this.getStateAndHelpers());\n } // this is currently undocumented and therefore subject to change\n // We\'ll try to not break it, but just be warned.\n\n\n _this.props.onUserAction(onStateChangeArg, _this.getStateAndHelpers());\n });\n };\n\n _this.rootRef = function (node) {\n return _this._rootNode = node;\n };\n\n _this.getRootProps = function (_temp, _temp2) {\n var _extends2;\n\n var _ref = _temp === void 0 ? {} : _temp,\n _ref$refKey = _ref.refKey,\n refKey = _ref$refKey === void 0 ? \'ref\' : _ref$refKey,\n ref = _ref.ref,\n rest = (0,objectWithoutPropertiesLoose["default"])(_ref, _excluded$4);\n\n var _ref2 = _temp2 === void 0 ? {} : _temp2,\n _ref2$suppressRefErro = _ref2.suppressRefError,\n suppressRefError = _ref2$suppressRefErro === void 0 ? false : _ref2$suppressRefErro;\n\n // this is used in the render to know whether the user has called getRootProps.\n // It uses that to know whether to apply the props automatically\n _this.getRootProps.called = true;\n _this.getRootProps.refKey = refKey;\n _this.getRootProps.suppressRefError = suppressRefError;\n\n var _this$getState = _this.getState(),\n isOpen = _this$getState.isOpen;\n\n return (0,esm_extends["default"])((_extends2 = {}, _extends2[refKey] = handleRefs(ref, _this.rootRef), _extends2.role = \'combobox\', _extends2[\'aria-expanded\'] = isOpen, _extends2[\'aria-haspopup\'] = \'listbox\', _extends2[\'aria-owns\'] = isOpen ? _this.menuId : null, _extends2[\'aria-labelledby\'] = _this.labelId, _extends2), rest);\n };\n\n _this.keyDownHandlers = {\n ArrowDown: function ArrowDown(event) {\n var _this2 = this;\n\n event.preventDefault();\n\n if (this.getState().isOpen) {\n var amount = event.shiftKey ? 5 : 1;\n this.moveHighlightedIndex(amount, {\n type: keyDownArrowDown\n });\n } else {\n this.internalSetState({\n isOpen: true,\n type: keyDownArrowDown\n }, function () {\n var itemCount = _this2.getItemCount();\n\n if (itemCount > 0) {\n var _this2$getState = _this2.getState(),\n highlightedIndex = _this2$getState.highlightedIndex;\n\n var nextHighlightedIndex = getNextWrappingIndex(1, highlightedIndex, itemCount, function (index) {\n return _this2.getItemNodeFromIndex(index);\n });\n\n _this2.setHighlightedIndex(nextHighlightedIndex, {\n type: keyDownArrowDown\n });\n }\n });\n }\n },\n ArrowUp: function ArrowUp(event) {\n var _this3 = this;\n\n event.preventDefault();\n\n if (this.getState().isOpen) {\n var amount = event.shiftKey ? -5 : -1;\n this.moveHighlightedIndex(amount, {\n type: keyDownArrowUp\n });\n } else {\n this.internalSetState({\n isOpen: true,\n type: keyDownArrowUp\n }, function () {\n var itemCount = _this3.getItemCount();\n\n if (itemCount > 0) {\n var _this3$getState = _this3.getState(),\n highlightedIndex = _this3$getState.highlightedIndex;\n\n var nextHighlightedIndex = getNextWrappingIndex(-1, highlightedIndex, itemCount, function (index) {\n return _this3.getItemNodeFromIndex(index);\n });\n\n _this3.setHighlightedIndex(nextHighlightedIndex, {\n type: keyDownArrowUp\n });\n }\n });\n }\n },\n Enter: function Enter(event) {\n if (event.which === 229) {\n return;\n }\n\n var _this$getState2 = this.getState(),\n isOpen = _this$getState2.isOpen,\n highlightedIndex = _this$getState2.highlightedIndex;\n\n if (isOpen && highlightedIndex != null) {\n event.preventDefault();\n var item = this.items[highlightedIndex];\n var itemNode = this.getItemNodeFromIndex(highlightedIndex);\n\n if (item == null || itemNode && itemNode.hasAttribute(\'disabled\')) {\n return;\n }\n\n this.selectHighlightedItem({\n type: keyDownEnter\n });\n }\n },\n Escape: function Escape(event) {\n event.preventDefault();\n this.reset((0,esm_extends["default"])({\n type: keyDownEscape\n }, !this.state.isOpen && {\n selectedItem: null,\n inputValue: \'\'\n }));\n }\n };\n _this.buttonKeyDownHandlers = (0,esm_extends["default"])({}, _this.keyDownHandlers, {\n \' \': function _(event) {\n event.preventDefault();\n this.toggleMenu({\n type: keyDownSpaceButton\n });\n }\n });\n _this.inputKeyDownHandlers = (0,esm_extends["default"])({}, _this.keyDownHandlers, {\n Home: function Home(event) {\n var _this4 = this;\n\n var _this$getState3 = this.getState(),\n isOpen = _this$getState3.isOpen;\n\n if (!isOpen) {\n return;\n }\n\n event.preventDefault();\n var itemCount = this.getItemCount();\n\n if (itemCount <= 0 || !isOpen) {\n return;\n } // get next non-disabled starting downwards from 0 if that\'s disabled.\n\n\n var newHighlightedIndex = getNextNonDisabledIndex(1, 0, itemCount, function (index) {\n return _this4.getItemNodeFromIndex(index);\n }, false);\n this.setHighlightedIndex(newHighlightedIndex, {\n type: keyDownHome\n });\n },\n End: function End(event) {\n var _this5 = this;\n\n var _this$getState4 = this.getState(),\n isOpen = _this$getState4.isOpen;\n\n if (!isOpen) {\n return;\n }\n\n event.preventDefault();\n var itemCount = this.getItemCount();\n\n if (itemCount <= 0 || !isOpen) {\n return;\n } // get next non-disabled starting upwards from last index if that\'s disabled.\n\n\n var newHighlightedIndex = getNextNonDisabledIndex(-1, itemCount - 1, itemCount, function (index) {\n return _this5.getItemNodeFromIndex(index);\n }, false);\n this.setHighlightedIndex(newHighlightedIndex, {\n type: keyDownEnd\n });\n }\n });\n\n _this.getToggleButtonProps = function (_temp3) {\n var _ref3 = _temp3 === void 0 ? {} : _temp3,\n onClick = _ref3.onClick;\n _ref3.onPress;\n var onKeyDown = _ref3.onKeyDown,\n onKeyUp = _ref3.onKeyUp,\n onBlur = _ref3.onBlur,\n rest = (0,objectWithoutPropertiesLoose["default"])(_ref3, _excluded2$3);\n\n var _this$getState5 = _this.getState(),\n isOpen = _this$getState5.isOpen;\n\n var enabledEventHandlers = {\n onClick: callAllEventHandlers(onClick, _this.buttonHandleClick),\n onKeyDown: callAllEventHandlers(onKeyDown, _this.buttonHandleKeyDown),\n onKeyUp: callAllEventHandlers(onKeyUp, _this.buttonHandleKeyUp),\n onBlur: callAllEventHandlers(onBlur, _this.buttonHandleBlur)\n };\n var eventHandlers = rest.disabled ? {} : enabledEventHandlers;\n return (0,esm_extends["default"])({\n type: \'button\',\n role: \'button\',\n \'aria-label\': isOpen ? \'close menu\' : \'open menu\',\n \'aria-haspopup\': true,\n \'data-toggle\': true\n }, eventHandlers, rest);\n };\n\n _this.buttonHandleKeyUp = function (event) {\n // Prevent click event from emitting in Firefox\n event.preventDefault();\n };\n\n _this.buttonHandleKeyDown = function (event) {\n var key = normalizeArrowKey(event);\n\n if (_this.buttonKeyDownHandlers[key]) {\n _this.buttonKeyDownHandlers[key].call((0,assertThisInitialized/* default */.Z)(_this), event);\n }\n };\n\n _this.buttonHandleClick = function (event) {\n event.preventDefault(); // handle odd case for Safari and Firefox which\n // don\'t give the button the focus properly.\n\n /* istanbul ignore if (can\'t reasonably test this) */\n\n if (_this.props.environment.document.activeElement === _this.props.environment.document.body) {\n event.target.focus();\n } // to simplify testing components that use downshift, we\'ll not wrap this in a setTimeout\n // if the NODE_ENV is test. With the proper build system, this should be dead code eliminated\n // when building for production and should therefore have no impact on production code.\n\n\n if (false) {} else {\n // Ensure that toggle of menu occurs after the potential blur event in iOS\n _this.internalSetTimeout(function () {\n return _this.toggleMenu({\n type: clickButton\n });\n });\n }\n };\n\n _this.buttonHandleBlur = function (event) {\n var blurTarget = event.target; // Save blur target for comparison with activeElement later\n // Need setTimeout, so that when the user presses Tab, the activeElement is the next focused element, not body element\n\n _this.internalSetTimeout(function () {\n if (!_this.isMouseDown && (_this.props.environment.document.activeElement == null || _this.props.environment.document.activeElement.id !== _this.inputId) && _this.props.environment.document.activeElement !== blurTarget // Do nothing if we refocus the same element again (to solve issue in Safari on iOS)\n ) {\n _this.reset({\n type: blurButton\n });\n }\n });\n };\n\n _this.getLabelProps = function (props) {\n return (0,esm_extends["default"])({\n htmlFor: _this.inputId,\n id: _this.labelId\n }, props);\n };\n\n _this.getInputProps = function (_temp4) {\n var _ref4 = _temp4 === void 0 ? {} : _temp4,\n onKeyDown = _ref4.onKeyDown,\n onBlur = _ref4.onBlur,\n onChange = _ref4.onChange,\n onInput = _ref4.onInput;\n _ref4.onChangeText;\n var rest = (0,objectWithoutPropertiesLoose["default"])(_ref4, _excluded3$2);\n\n var onChangeKey;\n var eventHandlers = {};\n /* istanbul ignore next (preact) */\n\n {\n onChangeKey = \'onChange\';\n }\n\n var _this$getState6 = _this.getState(),\n inputValue = _this$getState6.inputValue,\n isOpen = _this$getState6.isOpen,\n highlightedIndex = _this$getState6.highlightedIndex;\n\n if (!rest.disabled) {\n var _eventHandlers;\n\n eventHandlers = (_eventHandlers = {}, _eventHandlers[onChangeKey] = callAllEventHandlers(onChange, onInput, _this.inputHandleChange), _eventHandlers.onKeyDown = callAllEventHandlers(onKeyDown, _this.inputHandleKeyDown), _eventHandlers.onBlur = callAllEventHandlers(onBlur, _this.inputHandleBlur), _eventHandlers);\n }\n\n return (0,esm_extends["default"])({\n \'aria-autocomplete\': \'list\',\n \'aria-activedescendant\': isOpen && typeof highlightedIndex === \'number\' && highlightedIndex >= 0 ? _this.getItemId(highlightedIndex) : null,\n \'aria-controls\': isOpen ? _this.menuId : null,\n \'aria-labelledby\': _this.labelId,\n // https://developer.mozilla.org/en-US/docs/Web/Security/Securing_your_site/Turning_off_form_autocompletion\n // revert back since autocomplete="nope" is ignored on latest Chrome and Opera\n autoComplete: \'off\',\n value: inputValue,\n id: _this.inputId\n }, eventHandlers, rest);\n };\n\n _this.inputHandleKeyDown = function (event) {\n var key = normalizeArrowKey(event);\n\n if (key && _this.inputKeyDownHandlers[key]) {\n _this.inputKeyDownHandlers[key].call((0,assertThisInitialized/* default */.Z)(_this), event);\n }\n };\n\n _this.inputHandleChange = function (event) {\n _this.internalSetState({\n type: changeInput,\n isOpen: true,\n inputValue: event.target.value,\n highlightedIndex: _this.props.defaultHighlightedIndex\n });\n };\n\n _this.inputHandleBlur = function () {\n // Need setTimeout, so that when the user presses Tab, the activeElement is the next focused element, not the body element\n _this.internalSetTimeout(function () {\n var downshiftButtonIsActive = _this.props.environment.document && !!_this.props.environment.document.activeElement && !!_this.props.environment.document.activeElement.dataset && _this.props.environment.document.activeElement.dataset.toggle && _this._rootNode && _this._rootNode.contains(_this.props.environment.document.activeElement);\n\n if (!_this.isMouseDown && !downshiftButtonIsActive) {\n _this.reset({\n type: blurInput\n });\n }\n });\n };\n\n _this.menuRef = function (node) {\n _this._menuNode = node;\n };\n\n _this.getMenuProps = function (_temp5, _temp6) {\n var _extends3;\n\n var _ref5 = _temp5 === void 0 ? {} : _temp5,\n _ref5$refKey = _ref5.refKey,\n refKey = _ref5$refKey === void 0 ? \'ref\' : _ref5$refKey,\n ref = _ref5.ref,\n props = (0,objectWithoutPropertiesLoose["default"])(_ref5, _excluded4$1);\n\n var _ref6 = _temp6 === void 0 ? {} : _temp6,\n _ref6$suppressRefErro = _ref6.suppressRefError,\n suppressRefError = _ref6$suppressRefErro === void 0 ? false : _ref6$suppressRefErro;\n\n _this.getMenuProps.called = true;\n _this.getMenuProps.refKey = refKey;\n _this.getMenuProps.suppressRefError = suppressRefError;\n return (0,esm_extends["default"])((_extends3 = {}, _extends3[refKey] = handleRefs(ref, _this.menuRef), _extends3.role = \'listbox\', _extends3[\'aria-labelledby\'] = props && props[\'aria-label\'] ? null : _this.labelId, _extends3.id = _this.menuId, _extends3), props);\n };\n\n _this.getItemProps = function (_temp7) {\n var _enabledEventHandlers;\n\n var _ref7 = _temp7 === void 0 ? {} : _temp7,\n onMouseMove = _ref7.onMouseMove,\n onMouseDown = _ref7.onMouseDown,\n onClick = _ref7.onClick;\n _ref7.onPress;\n var index = _ref7.index,\n _ref7$item = _ref7.item,\n item = _ref7$item === void 0 ? true ?\n /* istanbul ignore next */\n undefined : 0 : _ref7$item,\n rest = (0,objectWithoutPropertiesLoose["default"])(_ref7, _excluded5$1);\n\n if (index === undefined) {\n _this.items.push(item);\n\n index = _this.items.indexOf(item);\n } else {\n _this.items[index] = item;\n }\n\n var onSelectKey = \'onClick\';\n var customClickHandler = onClick;\n var enabledEventHandlers = (_enabledEventHandlers = {\n // onMouseMove is used over onMouseEnter here. onMouseMove\n // is only triggered on actual mouse movement while onMouseEnter\n // can fire on DOM changes, interrupting keyboard navigation\n onMouseMove: callAllEventHandlers(onMouseMove, function () {\n if (index === _this.getState().highlightedIndex) {\n return;\n }\n\n _this.setHighlightedIndex(index, {\n type: itemMouseEnter\n }); // We never want to manually scroll when changing state based\n // on `onMouseMove` because we will be moving the element out\n // from under the user which is currently scrolling/moving the\n // cursor\n\n\n _this.avoidScrolling = true;\n\n _this.internalSetTimeout(function () {\n return _this.avoidScrolling = false;\n }, 250);\n }),\n onMouseDown: callAllEventHandlers(onMouseDown, function (event) {\n // This prevents the activeElement from being changed\n // to the item so it can remain with the current activeElement\n // which is a more common use case.\n event.preventDefault();\n })\n }, _enabledEventHandlers[onSelectKey] = callAllEventHandlers(customClickHandler, function () {\n _this.selectItemAtIndex(index, {\n type: clickItem\n });\n }), _enabledEventHandlers); // Passing down the onMouseDown handler to prevent redirect\n // of the activeElement if clicking on disabled items\n\n var eventHandlers = rest.disabled ? {\n onMouseDown: enabledEventHandlers.onMouseDown\n } : enabledEventHandlers;\n return (0,esm_extends["default"])({\n id: _this.getItemId(index),\n role: \'option\',\n \'aria-selected\': _this.getState().highlightedIndex === index\n }, eventHandlers, rest);\n };\n\n _this.clearItems = function () {\n _this.items = [];\n };\n\n _this.reset = function (otherStateToSet, cb) {\n if (otherStateToSet === void 0) {\n otherStateToSet = {};\n }\n\n otherStateToSet = pickState(otherStateToSet);\n\n _this.internalSetState(function (_ref8) {\n var selectedItem = _ref8.selectedItem;\n return (0,esm_extends["default"])({\n isOpen: _this.props.defaultIsOpen,\n highlightedIndex: _this.props.defaultHighlightedIndex,\n inputValue: _this.props.itemToString(selectedItem)\n }, otherStateToSet);\n }, cb);\n };\n\n _this.toggleMenu = function (otherStateToSet, cb) {\n if (otherStateToSet === void 0) {\n otherStateToSet = {};\n }\n\n otherStateToSet = pickState(otherStateToSet);\n\n _this.internalSetState(function (_ref9) {\n var isOpen = _ref9.isOpen;\n return (0,esm_extends["default"])({\n isOpen: !isOpen\n }, isOpen && {\n highlightedIndex: _this.props.defaultHighlightedIndex\n }, otherStateToSet);\n }, function () {\n var _this$getState7 = _this.getState(),\n isOpen = _this$getState7.isOpen,\n highlightedIndex = _this$getState7.highlightedIndex;\n\n if (isOpen) {\n if (_this.getItemCount() > 0 && typeof highlightedIndex === \'number\') {\n _this.setHighlightedIndex(highlightedIndex, otherStateToSet);\n }\n }\n\n cbToCb(cb)();\n });\n };\n\n _this.openMenu = function (cb) {\n _this.internalSetState({\n isOpen: true\n }, cb);\n };\n\n _this.closeMenu = function (cb) {\n _this.internalSetState({\n isOpen: false\n }, cb);\n };\n\n _this.updateStatus = debounce(function () {\n var state = _this.getState();\n\n var item = _this.items[state.highlightedIndex];\n\n var resultCount = _this.getItemCount();\n\n var status = _this.props.getA11yStatusMessage((0,esm_extends["default"])({\n itemToString: _this.props.itemToString,\n previousResultCount: _this.previousResultCount,\n resultCount: resultCount,\n highlightedItem: item\n }, state));\n\n _this.previousResultCount = resultCount;\n setStatus(status, _this.props.environment.document);\n }, 200);\n\n var _this$props = _this.props,\n defaultHighlightedIndex = _this$props.defaultHighlightedIndex,\n _this$props$initialHi = _this$props.initialHighlightedIndex,\n _highlightedIndex = _this$props$initialHi === void 0 ? defaultHighlightedIndex : _this$props$initialHi,\n defaultIsOpen = _this$props.defaultIsOpen,\n _this$props$initialIs = _this$props.initialIsOpen,\n _isOpen = _this$props$initialIs === void 0 ? defaultIsOpen : _this$props$initialIs,\n _this$props$initialIn = _this$props.initialInputValue,\n _inputValue = _this$props$initialIn === void 0 ? \'\' : _this$props$initialIn,\n _this$props$initialSe = _this$props.initialSelectedItem,\n _selectedItem = _this$props$initialSe === void 0 ? null : _this$props$initialSe;\n\n var _state = _this.getState({\n highlightedIndex: _highlightedIndex,\n isOpen: _isOpen,\n inputValue: _inputValue,\n selectedItem: _selectedItem\n });\n\n if (_state.selectedItem != null && _this.props.initialInputValue === undefined) {\n _state.inputValue = _this.props.itemToString(_state.selectedItem);\n }\n\n _this.state = _state;\n return _this;\n }\n\n var _proto = Downshift.prototype;\n\n /**\n * Clear all running timeouts\n */\n _proto.internalClearTimeouts = function internalClearTimeouts() {\n this.timeoutIds.forEach(function (id) {\n clearTimeout(id);\n });\n this.timeoutIds = [];\n }\n /**\n * Gets the state based on internal state or props\n * If a state value is passed via props, then that\n * is the value given, otherwise it\'s retrieved from\n * stateToMerge\n *\n * @param {Object} stateToMerge defaults to this.state\n * @return {Object} the state\n */\n ;\n\n _proto.getState = function getState$1(stateToMerge) {\n if (stateToMerge === void 0) {\n stateToMerge = this.state;\n }\n\n return getState(stateToMerge, this.props);\n };\n\n _proto.getItemCount = function getItemCount() {\n // things read better this way. They\'re in priority order:\n // 1. `this.itemCount`\n // 2. `this.props.itemCount`\n // 3. `this.items.length`\n var itemCount = this.items.length;\n\n if (this.itemCount != null) {\n itemCount = this.itemCount;\n } else if (this.props.itemCount !== undefined) {\n itemCount = this.props.itemCount;\n }\n\n return itemCount;\n };\n\n _proto.getItemNodeFromIndex = function getItemNodeFromIndex(index) {\n return this.props.environment.document.getElementById(this.getItemId(index));\n };\n\n _proto.scrollHighlightedItemIntoView = function scrollHighlightedItemIntoView() {\n /* istanbul ignore else (react-native) */\n {\n var node = this.getItemNodeFromIndex(this.getState().highlightedIndex);\n this.props.scrollIntoView(node, this._menuNode);\n }\n };\n\n _proto.moveHighlightedIndex = function moveHighlightedIndex(amount, otherStateToSet) {\n var _this6 = this;\n\n var itemCount = this.getItemCount();\n\n var _this$getState8 = this.getState(),\n highlightedIndex = _this$getState8.highlightedIndex;\n\n if (itemCount > 0) {\n var nextHighlightedIndex = getNextWrappingIndex(amount, highlightedIndex, itemCount, function (index) {\n return _this6.getItemNodeFromIndex(index);\n });\n this.setHighlightedIndex(nextHighlightedIndex, otherStateToSet);\n }\n };\n\n _proto.getStateAndHelpers = function getStateAndHelpers() {\n var _this$getState9 = this.getState(),\n highlightedIndex = _this$getState9.highlightedIndex,\n inputValue = _this$getState9.inputValue,\n selectedItem = _this$getState9.selectedItem,\n isOpen = _this$getState9.isOpen;\n\n var itemToString = this.props.itemToString;\n var id = this.id;\n var getRootProps = this.getRootProps,\n getToggleButtonProps = this.getToggleButtonProps,\n getLabelProps = this.getLabelProps,\n getMenuProps = this.getMenuProps,\n getInputProps = this.getInputProps,\n getItemProps = this.getItemProps,\n openMenu = this.openMenu,\n closeMenu = this.closeMenu,\n toggleMenu = this.toggleMenu,\n selectItem = this.selectItem,\n selectItemAtIndex = this.selectItemAtIndex,\n selectHighlightedItem = this.selectHighlightedItem,\n setHighlightedIndex = this.setHighlightedIndex,\n clearSelection = this.clearSelection,\n clearItems = this.clearItems,\n reset = this.reset,\n setItemCount = this.setItemCount,\n unsetItemCount = this.unsetItemCount,\n setState = this.internalSetState;\n return {\n // prop getters\n getRootProps: getRootProps,\n getToggleButtonProps: getToggleButtonProps,\n getLabelProps: getLabelProps,\n getMenuProps: getMenuProps,\n getInputProps: getInputProps,\n getItemProps: getItemProps,\n // actions\n reset: reset,\n openMenu: openMenu,\n closeMenu: closeMenu,\n toggleMenu: toggleMenu,\n selectItem: selectItem,\n selectItemAtIndex: selectItemAtIndex,\n selectHighlightedItem: selectHighlightedItem,\n setHighlightedIndex: setHighlightedIndex,\n clearSelection: clearSelection,\n clearItems: clearItems,\n setItemCount: setItemCount,\n unsetItemCount: unsetItemCount,\n setState: setState,\n // props\n itemToString: itemToString,\n // derived\n id: id,\n // state\n highlightedIndex: highlightedIndex,\n inputValue: inputValue,\n isOpen: isOpen,\n selectedItem: selectedItem\n };\n } //////////////////////////// ROOT\n ;\n\n _proto.componentDidMount = function componentDidMount() {\n var _this7 = this;\n\n /* istanbul ignore if (react-native) */\n if (false) {}\n /* istanbul ignore if (react-native) */\n\n\n {\n // this.isMouseDown helps us track whether the mouse is currently held down.\n // This is useful when the user clicks on an item in the list, but holds the mouse\n // down long enough for the list to disappear (because the blur event fires on the input)\n // this.isMouseDown is used in the blur handler on the input to determine whether the blur event should\n // trigger hiding the menu.\n var onMouseDown = function onMouseDown() {\n _this7.isMouseDown = true;\n };\n\n var onMouseUp = function onMouseUp(event) {\n _this7.isMouseDown = false; // if the target element or the activeElement is within a downshift node\n // then we don\'t want to reset downshift\n\n var contextWithinDownshift = targetWithinDownshift(event.target, [_this7._rootNode, _this7._menuNode], _this7.props.environment);\n\n if (!contextWithinDownshift && _this7.getState().isOpen) {\n _this7.reset({\n type: mouseUp\n }, function () {\n return _this7.props.onOuterClick(_this7.getStateAndHelpers());\n });\n }\n }; // Touching an element in iOS gives focus and hover states, but touching out of\n // the element will remove hover, and persist the focus state, resulting in the\n // blur event not being triggered.\n // this.isTouchMove helps us track whether the user is tapping or swiping on a touch screen.\n // If the user taps outside of Downshift, the component should be reset,\n // but not if the user is swiping\n\n\n var onTouchStart = function onTouchStart() {\n _this7.isTouchMove = false;\n };\n\n var onTouchMove = function onTouchMove() {\n _this7.isTouchMove = true;\n };\n\n var onTouchEnd = function onTouchEnd(event) {\n var contextWithinDownshift = targetWithinDownshift(event.target, [_this7._rootNode, _this7._menuNode], _this7.props.environment, false);\n\n if (!_this7.isTouchMove && !contextWithinDownshift && _this7.getState().isOpen) {\n _this7.reset({\n type: touchEnd\n }, function () {\n return _this7.props.onOuterClick(_this7.getStateAndHelpers());\n });\n }\n };\n\n var environment = this.props.environment;\n environment.addEventListener(\'mousedown\', onMouseDown);\n environment.addEventListener(\'mouseup\', onMouseUp);\n environment.addEventListener(\'touchstart\', onTouchStart);\n environment.addEventListener(\'touchmove\', onTouchMove);\n environment.addEventListener(\'touchend\', onTouchEnd);\n\n this.cleanup = function () {\n _this7.internalClearTimeouts();\n\n _this7.updateStatus.cancel();\n\n environment.removeEventListener(\'mousedown\', onMouseDown);\n environment.removeEventListener(\'mouseup\', onMouseUp);\n environment.removeEventListener(\'touchstart\', onTouchStart);\n environment.removeEventListener(\'touchmove\', onTouchMove);\n environment.removeEventListener(\'touchend\', onTouchEnd);\n };\n }\n };\n\n _proto.shouldScroll = function shouldScroll(prevState, prevProps) {\n var _ref10 = this.props.highlightedIndex === undefined ? this.getState() : this.props,\n currentHighlightedIndex = _ref10.highlightedIndex;\n\n var _ref11 = prevProps.highlightedIndex === undefined ? prevState : prevProps,\n prevHighlightedIndex = _ref11.highlightedIndex;\n\n var scrollWhenOpen = currentHighlightedIndex && this.getState().isOpen && !prevState.isOpen;\n var scrollWhenNavigating = currentHighlightedIndex !== prevHighlightedIndex;\n return scrollWhenOpen || scrollWhenNavigating;\n };\n\n _proto.componentDidUpdate = function componentDidUpdate(prevProps, prevState) {\n if (false) {}\n\n if (isControlledProp(this.props, \'selectedItem\') && this.props.selectedItemChanged(prevProps.selectedItem, this.props.selectedItem)) {\n this.internalSetState({\n type: controlledPropUpdatedSelectedItem,\n inputValue: this.props.itemToString(this.props.selectedItem)\n });\n }\n\n if (!this.avoidScrolling && this.shouldScroll(prevState, prevProps)) {\n this.scrollHighlightedItemIntoView();\n }\n /* istanbul ignore else (react-native) */\n\n\n {\n this.updateStatus();\n }\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n this.cleanup(); // avoids memory leak\n };\n\n _proto.render = function render() {\n var children = unwrapArray(this.props.children, noop); // because the items are rerendered every time we call the children\n // we clear this out each render and it will be populated again as\n // getItemProps is called.\n\n this.clearItems(); // we reset this so we know whether the user calls getRootProps during\n // this render. If they do then we don\'t need to do anything,\n // if they don\'t then we need to clone the element they return and\n // apply the props for them.\n\n this.getRootProps.called = false;\n this.getRootProps.refKey = undefined;\n this.getRootProps.suppressRefError = undefined; // we do something similar for getMenuProps\n\n this.getMenuProps.called = false;\n this.getMenuProps.refKey = undefined;\n this.getMenuProps.suppressRefError = undefined; // we do something similar for getLabelProps\n\n this.getLabelProps.called = false; // and something similar for getInputProps\n\n this.getInputProps.called = false;\n var element = unwrapArray(children(this.getStateAndHelpers()));\n\n if (!element) {\n return null;\n }\n\n if (this.getRootProps.called || this.props.suppressRefError) {\n if (false) {}\n\n return element;\n } else if (isDOMElement(element)) {\n // they didn\'t apply the root props, but we can clone\n // this and apply the props ourselves\n return /*#__PURE__*/(0,external_React_.cloneElement)(element, this.getRootProps(getElementProps(element)));\n }\n /* istanbul ignore else */\n\n\n if (false) {}\n /* istanbul ignore next */\n\n\n return undefined;\n };\n\n return Downshift;\n }(external_React_.Component);\n\n Downshift.defaultProps = {\n defaultHighlightedIndex: null,\n defaultIsOpen: false,\n getA11yStatusMessage: getA11yStatusMessage$1,\n itemToString: function itemToString(i) {\n if (i == null) {\n return \'\';\n }\n\n if (false) {}\n\n return String(i);\n },\n onStateChange: noop,\n onInputValueChange: noop,\n onUserAction: noop,\n onChange: noop,\n onSelect: noop,\n onOuterClick: noop,\n selectedItemChanged: function selectedItemChanged(prevItem, item) {\n return prevItem !== item;\n },\n environment:\n /* istanbul ignore next (ssr) */\n typeof window === \'undefined\' ? {} : window,\n stateReducer: function stateReducer(state, stateToSet) {\n return stateToSet;\n },\n suppressRefError: false,\n scrollIntoView: scrollIntoView\n };\n Downshift.stateChangeTypes = stateChangeTypes$3;\n return Downshift;\n}();\n\n false ? 0 : void 0;\nvar Downshift$1 = Downshift;\n\nfunction validateGetMenuPropsCalledCorrectly(node, _ref12) {\n var refKey = _ref12.refKey;\n\n if (!node) {\n // eslint-disable-next-line no-console\n console.error("downshift: The ref prop \\"" + refKey + "\\" from getMenuProps was not applied correctly on your menu element.");\n }\n}\n\nfunction validateGetRootPropsCalledCorrectly(element, _ref13) {\n var refKey = _ref13.refKey;\n var refKeySpecified = refKey !== \'ref\';\n var isComposite = !isDOMElement(element);\n\n if (isComposite && !refKeySpecified && !isForwardRef(element)) {\n // eslint-disable-next-line no-console\n console.error(\'downshift: You returned a non-DOM element. You must specify a refKey in getRootProps\');\n } else if (!isComposite && refKeySpecified) {\n // eslint-disable-next-line no-console\n console.error("downshift: You returned a DOM element. You should not specify a refKey in getRootProps. You specified \\"" + refKey + "\\"");\n }\n\n if (!isForwardRef(element) && !getElementProps(element)[refKey]) {\n // eslint-disable-next-line no-console\n console.error("downshift: You must apply the ref prop \\"" + refKey + "\\" from getRootProps onto your root element.");\n }\n}\n\nvar _excluded$3 = ["isInitialMount", "highlightedIndex", "items", "environment"];\nvar dropdownDefaultStateValues = {\n highlightedIndex: -1,\n isOpen: false,\n selectedItem: null,\n inputValue: \'\'\n};\n\nfunction callOnChangeProps(action, state, newState) {\n var props = action.props,\n type = action.type;\n var changes = {};\n Object.keys(state).forEach(function (key) {\n invokeOnChangeHandler(key, action, state, newState);\n\n if (newState[key] !== state[key]) {\n changes[key] = newState[key];\n }\n });\n\n if (props.onStateChange && Object.keys(changes).length) {\n props.onStateChange((0,esm_extends["default"])({\n type: type\n }, changes));\n }\n}\n\nfunction invokeOnChangeHandler(key, action, state, newState) {\n var props = action.props,\n type = action.type;\n var handler = "on" + capitalizeString(key) + "Change";\n\n if (props[handler] && newState[key] !== undefined && newState[key] !== state[key]) {\n props[handler]((0,esm_extends["default"])({\n type: type\n }, newState));\n }\n}\n/**\n * Default state reducer that returns the changes.\n *\n * @param {Object} s state.\n * @param {Object} a action with changes.\n * @returns {Object} changes.\n */\n\n\nfunction stateReducer(s, a) {\n return a.changes;\n}\n/**\n * Returns a message to be added to aria-live region when item is selected.\n *\n * @param {Object} selectionParameters Parameters required to build the message.\n * @returns {string} The a11y message.\n */\n\n\nfunction getA11ySelectionMessage(selectionParameters) {\n var selectedItem = selectionParameters.selectedItem,\n itemToStringLocal = selectionParameters.itemToString;\n return selectedItem ? itemToStringLocal(selectedItem) + " has been selected." : \'\';\n}\n/**\n * Debounced call for updating the a11y message.\n */\n\n\nvar updateA11yStatus = debounce(function (getA11yMessage, document) {\n setStatus(getA11yMessage(), document);\n}, 200); // istanbul ignore next\n\nvar useIsomorphicLayoutEffect = typeof window !== \'undefined\' && typeof window.document !== \'undefined\' && typeof window.document.createElement !== \'undefined\' ? external_React_.useLayoutEffect : external_React_.useEffect;\n\nfunction useElementIds(_ref) {\n var _ref$id = _ref.id,\n id = _ref$id === void 0 ? "downshift-" + generateId() : _ref$id,\n labelId = _ref.labelId,\n menuId = _ref.menuId,\n getItemId = _ref.getItemId,\n toggleButtonId = _ref.toggleButtonId,\n inputId = _ref.inputId;\n var elementIdsRef = (0,external_React_.useRef)({\n labelId: labelId || id + "-label",\n menuId: menuId || id + "-menu",\n getItemId: getItemId || function (index) {\n return id + "-item-" + index;\n },\n toggleButtonId: toggleButtonId || id + "-toggle-button",\n inputId: inputId || id + "-input"\n });\n return elementIdsRef.current;\n}\n\nfunction getItemIndex(index, item, items) {\n if (index !== undefined) {\n return index;\n }\n\n if (items.length === 0) {\n return -1;\n }\n\n return items.indexOf(item);\n}\n\nfunction itemToString(item) {\n return item ? String(item) : \'\';\n}\n\nfunction isAcceptedCharacterKey(key) {\n return /^\\S{1}$/.test(key);\n}\n\nfunction capitalizeString(string) {\n return "" + string.slice(0, 1).toUpperCase() + string.slice(1);\n}\n\nfunction useLatestRef(val) {\n var ref = (0,external_React_.useRef)(val); // technically this is not "concurrent mode safe" because we\'re manipulating\n // the value during render (so it\'s not idempotent). However, the places this\n // hook is used is to support memoizing callbacks which will be called\n // *during* render, so we need the latest values *during* render.\n // If not for this, then we\'d probably want to use useLayoutEffect instead.\n\n ref.current = val;\n return ref;\n}\n/**\n * Computes the controlled state using a the previous state, props,\n * two reducers, one from downshift and an optional one from the user.\n * Also calls the onChange handlers for state values that have changed.\n *\n * @param {Function} reducer Reducer function from downshift.\n * @param {Object} initialState Initial state of the hook.\n * @param {Object} props The hook props.\n * @returns {Array} An array with the state and an action dispatcher.\n */\n\n\nfunction useEnhancedReducer(reducer, initialState, props) {\n var prevStateRef = (0,external_React_.useRef)();\n var actionRef = (0,external_React_.useRef)();\n var enhancedReducer = (0,external_React_.useCallback)(function (state, action) {\n actionRef.current = action;\n state = getState(state, action.props);\n var changes = reducer(state, action);\n var newState = action.props.stateReducer(state, (0,esm_extends["default"])({}, action, {\n changes: changes\n }));\n return newState;\n }, [reducer]);\n\n var _useReducer = (0,external_React_.useReducer)(enhancedReducer, initialState),\n state = _useReducer[0],\n dispatch = _useReducer[1];\n\n var propsRef = useLatestRef(props);\n var dispatchWithProps = (0,external_React_.useCallback)(function (action) {\n return dispatch((0,esm_extends["default"])({\n props: propsRef.current\n }, action));\n }, [propsRef]);\n var action = actionRef.current;\n (0,external_React_.useEffect)(function () {\n if (action && prevStateRef.current && prevStateRef.current !== state) {\n callOnChangeProps(action, getState(prevStateRef.current, action.props), state);\n }\n\n prevStateRef.current = state;\n }, [state, props, action]);\n return [state, dispatchWithProps];\n}\n/**\n * Wraps the useEnhancedReducer and applies the controlled prop values before\n * returning the new state.\n *\n * @param {Function} reducer Reducer function from downshift.\n * @param {Object} initialState Initial state of the hook.\n * @param {Object} props The hook props.\n * @returns {Array} An array with the state and an action dispatcher.\n */\n\n\nfunction useControlledReducer$1(reducer, initialState, props) {\n var _useEnhancedReducer = useEnhancedReducer(reducer, initialState, props),\n state = _useEnhancedReducer[0],\n dispatch = _useEnhancedReducer[1];\n\n return [getState(state, props), dispatch];\n}\n\nvar defaultProps$3 = {\n itemToString: itemToString,\n stateReducer: stateReducer,\n getA11ySelectionMessage: getA11ySelectionMessage,\n scrollIntoView: scrollIntoView,\n circularNavigation: false,\n environment:\n /* istanbul ignore next (ssr) */\n typeof window === \'undefined\' ? {} : window\n};\n\nfunction getDefaultValue$1(props, propKey, defaultStateValues) {\n if (defaultStateValues === void 0) {\n defaultStateValues = dropdownDefaultStateValues;\n }\n\n var defaultPropKey = "default" + capitalizeString(propKey);\n\n if (defaultPropKey in props) {\n return props[defaultPropKey];\n }\n\n return defaultStateValues[propKey];\n}\n\nfunction getInitialValue$1(props, propKey, defaultStateValues) {\n if (defaultStateValues === void 0) {\n defaultStateValues = dropdownDefaultStateValues;\n }\n\n if (propKey in props) {\n return props[propKey];\n }\n\n var initialPropKey = "initial" + capitalizeString(propKey);\n\n if (initialPropKey in props) {\n return props[initialPropKey];\n }\n\n return getDefaultValue$1(props, propKey, defaultStateValues);\n}\n\nfunction getInitialState$2(props) {\n var selectedItem = getInitialValue$1(props, \'selectedItem\');\n var isOpen = getInitialValue$1(props, \'isOpen\');\n var highlightedIndex = getInitialValue$1(props, \'highlightedIndex\');\n var inputValue = getInitialValue$1(props, \'inputValue\');\n return {\n highlightedIndex: highlightedIndex < 0 && selectedItem && isOpen ? props.items.indexOf(selectedItem) : highlightedIndex,\n isOpen: isOpen,\n selectedItem: selectedItem,\n inputValue: inputValue\n };\n}\n\nfunction getHighlightedIndexOnOpen(props, state, offset, getItemNodeFromIndex) {\n var items = props.items,\n initialHighlightedIndex = props.initialHighlightedIndex,\n defaultHighlightedIndex = props.defaultHighlightedIndex;\n var selectedItem = state.selectedItem,\n highlightedIndex = state.highlightedIndex;\n\n if (items.length === 0) {\n return -1;\n } // initialHighlightedIndex will give value to highlightedIndex on initial state only.\n\n\n if (initialHighlightedIndex !== undefined && highlightedIndex === initialHighlightedIndex) {\n return initialHighlightedIndex;\n }\n\n if (defaultHighlightedIndex !== undefined) {\n return defaultHighlightedIndex;\n }\n\n if (selectedItem) {\n if (offset === 0) {\n return items.indexOf(selectedItem);\n }\n\n return getNextWrappingIndex(offset, items.indexOf(selectedItem), items.length, getItemNodeFromIndex, false);\n }\n\n if (offset === 0) {\n return -1;\n }\n\n return offset < 0 ? items.length - 1 : 0;\n}\n/**\n * Reuse the movement tracking of mouse and touch events.\n *\n * @param {boolean} isOpen Whether the dropdown is open or not.\n * @param {Array} downshiftElementRefs Downshift element refs to track movement (toggleButton, menu etc.)\n * @param {Object} environment Environment where component/hook exists.\n * @param {Function} handleBlur Handler on blur from mouse or touch.\n * @returns {Object} Ref containing whether mouseDown or touchMove event is happening\n */\n\n\nfunction useMouseAndTouchTracker(isOpen, downshiftElementRefs, environment, handleBlur) {\n var mouseAndTouchTrackersRef = (0,external_React_.useRef)({\n isMouseDown: false,\n isTouchMove: false\n });\n (0,external_React_.useEffect)(function () {\n // The same strategy for checking if a click occurred inside or outside downsift\n // as in downshift.js.\n var onMouseDown = function onMouseDown() {\n mouseAndTouchTrackersRef.current.isMouseDown = true;\n };\n\n var onMouseUp = function onMouseUp(event) {\n mouseAndTouchTrackersRef.current.isMouseDown = false;\n\n if (isOpen && !targetWithinDownshift(event.target, downshiftElementRefs.map(function (ref) {\n return ref.current;\n }), environment)) {\n handleBlur();\n }\n };\n\n var onTouchStart = function onTouchStart() {\n mouseAndTouchTrackersRef.current.isTouchMove = false;\n };\n\n var onTouchMove = function onTouchMove() {\n mouseAndTouchTrackersRef.current.isTouchMove = true;\n };\n\n var onTouchEnd = function onTouchEnd(event) {\n if (isOpen && !mouseAndTouchTrackersRef.current.isTouchMove && !targetWithinDownshift(event.target, downshiftElementRefs.map(function (ref) {\n return ref.current;\n }), environment, false)) {\n handleBlur();\n }\n };\n\n environment.addEventListener(\'mousedown\', onMouseDown);\n environment.addEventListener(\'mouseup\', onMouseUp);\n environment.addEventListener(\'touchstart\', onTouchStart);\n environment.addEventListener(\'touchmove\', onTouchMove);\n environment.addEventListener(\'touchend\', onTouchEnd);\n return function cleanup() {\n environment.removeEventListener(\'mousedown\', onMouseDown);\n environment.removeEventListener(\'mouseup\', onMouseUp);\n environment.removeEventListener(\'touchstart\', onTouchStart);\n environment.removeEventListener(\'touchmove\', onTouchMove);\n environment.removeEventListener(\'touchend\', onTouchEnd);\n }; // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [isOpen, environment]);\n return mouseAndTouchTrackersRef;\n}\n/* istanbul ignore next */\n// eslint-disable-next-line import/no-mutable-exports\n\n\nvar useGetterPropsCalledChecker = function useGetterPropsCalledChecker() {\n return noop;\n};\n/**\n * Custom hook that checks if getter props are called correctly.\n *\n * @param {...any} propKeys Getter prop names to be handled.\n * @returns {Function} Setter function called inside getter props to set call information.\n */\n\n/* istanbul ignore next */\n\n\nif (false) {}\n\nfunction useA11yMessageSetter(getA11yMessage, dependencyArray, _ref2) {\n var isInitialMount = _ref2.isInitialMount,\n highlightedIndex = _ref2.highlightedIndex,\n items = _ref2.items,\n environment = _ref2.environment,\n rest = (0,objectWithoutPropertiesLoose["default"])(_ref2, _excluded$3);\n\n // Sets a11y status message on changes in state.\n (0,external_React_.useEffect)(function () {\n if (isInitialMount || false) {\n return;\n }\n\n updateA11yStatus(function () {\n return getA11yMessage((0,esm_extends["default"])({\n highlightedIndex: highlightedIndex,\n highlightedItem: items[highlightedIndex],\n resultCount: items.length\n }, rest));\n }, environment.document); // eslint-disable-next-line react-hooks/exhaustive-deps\n }, dependencyArray);\n}\n\nfunction useScrollIntoView(_ref3) {\n var highlightedIndex = _ref3.highlightedIndex,\n isOpen = _ref3.isOpen,\n itemRefs = _ref3.itemRefs,\n getItemNodeFromIndex = _ref3.getItemNodeFromIndex,\n menuElement = _ref3.menuElement,\n scrollIntoViewProp = _ref3.scrollIntoView;\n // used not to scroll on highlight by mouse.\n var shouldScrollRef = (0,external_React_.useRef)(true); // Scroll on highlighted item if change comes from keyboard.\n\n useIsomorphicLayoutEffect(function () {\n if (highlightedIndex < 0 || !isOpen || !Object.keys(itemRefs.current).length) {\n return;\n }\n\n if (shouldScrollRef.current === false) {\n shouldScrollRef.current = true;\n } else {\n scrollIntoViewProp(getItemNodeFromIndex(highlightedIndex), menuElement);\n } // eslint-disable-next-line react-hooks/exhaustive-deps\n\n }, [highlightedIndex]);\n return shouldScrollRef;\n} // eslint-disable-next-line import/no-mutable-exports\n\n\nvar useControlPropsValidator = noop;\n/* istanbul ignore next */\n\nif (false) {}\n\n/* eslint-disable complexity */\n\nfunction downshiftCommonReducer(state, action, stateChangeTypes) {\n var type = action.type,\n props = action.props;\n var changes;\n\n switch (type) {\n case stateChangeTypes.ItemMouseMove:\n changes = {\n highlightedIndex: action.index\n };\n break;\n\n case stateChangeTypes.MenuMouseLeave:\n changes = {\n highlightedIndex: -1\n };\n break;\n\n case stateChangeTypes.ToggleButtonClick:\n case stateChangeTypes.FunctionToggleMenu:\n changes = {\n isOpen: !state.isOpen,\n highlightedIndex: state.isOpen ? -1 : getHighlightedIndexOnOpen(props, state, 0)\n };\n break;\n\n case stateChangeTypes.FunctionOpenMenu:\n changes = {\n isOpen: true,\n highlightedIndex: getHighlightedIndexOnOpen(props, state, 0)\n };\n break;\n\n case stateChangeTypes.FunctionCloseMenu:\n changes = {\n isOpen: false\n };\n break;\n\n case stateChangeTypes.FunctionSetHighlightedIndex:\n changes = {\n highlightedIndex: action.highlightedIndex\n };\n break;\n\n case stateChangeTypes.FunctionSetInputValue:\n changes = {\n inputValue: action.inputValue\n };\n break;\n\n case stateChangeTypes.FunctionReset:\n changes = {\n highlightedIndex: getDefaultValue$1(props, \'highlightedIndex\'),\n isOpen: getDefaultValue$1(props, \'isOpen\'),\n selectedItem: getDefaultValue$1(props, \'selectedItem\'),\n inputValue: getDefaultValue$1(props, \'inputValue\')\n };\n break;\n\n default:\n throw new Error(\'Reducer called without proper action type.\');\n }\n\n return (0,esm_extends["default"])({}, state, changes);\n}\n/* eslint-enable complexity */\n\nfunction getItemIndexByCharacterKey(_a) {\n var keysSoFar = _a.keysSoFar, highlightedIndex = _a.highlightedIndex, items = _a.items, itemToString = _a.itemToString, getItemNodeFromIndex = _a.getItemNodeFromIndex;\n var lowerCasedKeysSoFar = keysSoFar.toLowerCase();\n for (var index = 0; index < items.length; index++) {\n var offsetIndex = (index + highlightedIndex + 1) % items.length;\n var item = items[offsetIndex];\n if (item !== undefined &&\n itemToString(item)\n .toLowerCase()\n .startsWith(lowerCasedKeysSoFar)) {\n var element = getItemNodeFromIndex(offsetIndex);\n if (!(element === null || element === void 0 ? void 0 : element.hasAttribute(\'disabled\'))) {\n return offsetIndex;\n }\n }\n }\n return highlightedIndex;\n}\nvar propTypes$2 = {\n items: (prop_types_default()).array.isRequired,\n itemToString: (prop_types_default()).func,\n getA11yStatusMessage: (prop_types_default()).func,\n getA11ySelectionMessage: (prop_types_default()).func,\n circularNavigation: (prop_types_default()).bool,\n highlightedIndex: (prop_types_default()).number,\n defaultHighlightedIndex: (prop_types_default()).number,\n initialHighlightedIndex: (prop_types_default()).number,\n isOpen: (prop_types_default()).bool,\n defaultIsOpen: (prop_types_default()).bool,\n initialIsOpen: (prop_types_default()).bool,\n selectedItem: (prop_types_default()).any,\n initialSelectedItem: (prop_types_default()).any,\n defaultSelectedItem: (prop_types_default()).any,\n id: (prop_types_default()).string,\n labelId: (prop_types_default()).string,\n menuId: (prop_types_default()).string,\n getItemId: (prop_types_default()).func,\n toggleButtonId: (prop_types_default()).string,\n stateReducer: (prop_types_default()).func,\n onSelectedItemChange: (prop_types_default()).func,\n onHighlightedIndexChange: (prop_types_default()).func,\n onStateChange: (prop_types_default()).func,\n onIsOpenChange: (prop_types_default()).func,\n environment: prop_types_default().shape({\n addEventListener: (prop_types_default()).func,\n removeEventListener: (prop_types_default()).func,\n document: prop_types_default().shape({\n getElementById: (prop_types_default()).func,\n activeElement: (prop_types_default()).any,\n body: (prop_types_default()).any\n })\n })\n};\n/**\n * Default implementation for status message. Only added when menu is open.\n * Will specift if there are results in the list, and if so, how many,\n * and what keys are relevant.\n *\n * @param {Object} param the downshift state and other relevant properties\n * @return {String} the a11y status message\n */\nfunction getA11yStatusMessage(_a) {\n var isOpen = _a.isOpen, resultCount = _a.resultCount, previousResultCount = _a.previousResultCount;\n if (!isOpen) {\n return \'\';\n }\n if (!resultCount) {\n return \'No results are available.\';\n }\n if (resultCount !== previousResultCount) {\n return resultCount + " result" + (resultCount === 1 ? \' is\' : \'s are\') + " available, use up and down arrow keys to navigate. Press Enter or Space Bar keys to select.";\n }\n return \'\';\n}\nvar defaultProps$2 = __assign(__assign({}, defaultProps$3), { getA11yStatusMessage: getA11yStatusMessage });\n// eslint-disable-next-line import/no-mutable-exports\nvar validatePropTypes$2 = noop;\n/* istanbul ignore next */\nif (false) {}\n\nvar MenuKeyDownArrowDown = false ? 0 : 0;\nvar MenuKeyDownArrowUp = false ? 0 : 1;\nvar MenuKeyDownEscape = false ? 0 : 2;\nvar MenuKeyDownHome = false ? 0 : 3;\nvar MenuKeyDownEnd = false ? 0 : 4;\nvar MenuKeyDownEnter = false ? 0 : 5;\nvar MenuKeyDownSpaceButton = false ? 0 : 6;\nvar MenuKeyDownCharacter = false ? 0 : 7;\nvar MenuBlur = false ? 0 : 8;\nvar MenuMouseLeave$1 = false ? 0 : 9;\nvar ItemMouseMove$1 = false ? 0 : 10;\nvar ItemClick$1 = false ? 0 : 11;\nvar ToggleButtonClick$1 = false ? 0 : 12;\nvar ToggleButtonKeyDownArrowDown = false ? 0 : 13;\nvar ToggleButtonKeyDownArrowUp = false ? 0 : 14;\nvar ToggleButtonKeyDownCharacter = false ? 0 : 15;\nvar FunctionToggleMenu$1 = false ? 0 : 16;\nvar FunctionOpenMenu$1 = false ? 0 : 17;\nvar FunctionCloseMenu$1 = false ? 0 : 18;\nvar FunctionSetHighlightedIndex$1 = false ? 0 : 19;\nvar FunctionSelectItem$1 = false ? 0 : 20;\nvar FunctionSetInputValue$1 = false ? 0 : 21;\nvar FunctionReset$2 = false ? 0 : 22;\n\nvar stateChangeTypes$2 = /*#__PURE__*/Object.freeze({\n __proto__: null,\n MenuKeyDownArrowDown: MenuKeyDownArrowDown,\n MenuKeyDownArrowUp: MenuKeyDownArrowUp,\n MenuKeyDownEscape: MenuKeyDownEscape,\n MenuKeyDownHome: MenuKeyDownHome,\n MenuKeyDownEnd: MenuKeyDownEnd,\n MenuKeyDownEnter: MenuKeyDownEnter,\n MenuKeyDownSpaceButton: MenuKeyDownSpaceButton,\n MenuKeyDownCharacter: MenuKeyDownCharacter,\n MenuBlur: MenuBlur,\n MenuMouseLeave: MenuMouseLeave$1,\n ItemMouseMove: ItemMouseMove$1,\n ItemClick: ItemClick$1,\n ToggleButtonClick: ToggleButtonClick$1,\n ToggleButtonKeyDownArrowDown: ToggleButtonKeyDownArrowDown,\n ToggleButtonKeyDownArrowUp: ToggleButtonKeyDownArrowUp,\n ToggleButtonKeyDownCharacter: ToggleButtonKeyDownCharacter,\n FunctionToggleMenu: FunctionToggleMenu$1,\n FunctionOpenMenu: FunctionOpenMenu$1,\n FunctionCloseMenu: FunctionCloseMenu$1,\n FunctionSetHighlightedIndex: FunctionSetHighlightedIndex$1,\n FunctionSelectItem: FunctionSelectItem$1,\n FunctionSetInputValue: FunctionSetInputValue$1,\n FunctionReset: FunctionReset$2\n});\n\n/* eslint-disable complexity */\n\nfunction downshiftSelectReducer(state, action) {\n var type = action.type,\n props = action.props,\n shiftKey = action.shiftKey;\n var changes;\n\n switch (type) {\n case ItemClick$1:\n changes = {\n isOpen: getDefaultValue$1(props, \'isOpen\'),\n highlightedIndex: getDefaultValue$1(props, \'highlightedIndex\'),\n selectedItem: props.items[action.index]\n };\n break;\n\n case ToggleButtonKeyDownCharacter:\n {\n var lowercasedKey = action.key;\n var inputValue = "" + state.inputValue + lowercasedKey;\n var itemIndex = getItemIndexByCharacterKey({\n keysSoFar: inputValue,\n highlightedIndex: state.selectedItem ? props.items.indexOf(state.selectedItem) : -1,\n items: props.items,\n itemToString: props.itemToString,\n getItemNodeFromIndex: action.getItemNodeFromIndex\n });\n changes = (0,esm_extends["default"])({\n inputValue: inputValue\n }, itemIndex >= 0 && {\n selectedItem: props.items[itemIndex]\n });\n }\n break;\n\n case ToggleButtonKeyDownArrowDown:\n changes = {\n highlightedIndex: getHighlightedIndexOnOpen(props, state, 1, action.getItemNodeFromIndex),\n isOpen: true\n };\n break;\n\n case ToggleButtonKeyDownArrowUp:\n changes = {\n highlightedIndex: getHighlightedIndexOnOpen(props, state, -1, action.getItemNodeFromIndex),\n isOpen: true\n };\n break;\n\n case MenuKeyDownEnter:\n case MenuKeyDownSpaceButton:\n changes = (0,esm_extends["default"])({\n isOpen: getDefaultValue$1(props, \'isOpen\'),\n highlightedIndex: getDefaultValue$1(props, \'highlightedIndex\')\n }, state.highlightedIndex >= 0 && {\n selectedItem: props.items[state.highlightedIndex]\n });\n break;\n\n case MenuKeyDownHome:\n changes = {\n highlightedIndex: getNextNonDisabledIndex(1, 0, props.items.length, action.getItemNodeFromIndex, false)\n };\n break;\n\n case MenuKeyDownEnd:\n changes = {\n highlightedIndex: getNextNonDisabledIndex(-1, props.items.length - 1, props.items.length, action.getItemNodeFromIndex, false)\n };\n break;\n\n case MenuKeyDownEscape:\n changes = {\n isOpen: false,\n highlightedIndex: -1\n };\n break;\n\n case MenuBlur:\n changes = {\n isOpen: false,\n highlightedIndex: -1\n };\n break;\n\n case MenuKeyDownCharacter:\n {\n var _lowercasedKey = action.key;\n\n var _inputValue = "" + state.inputValue + _lowercasedKey;\n\n var highlightedIndex = getItemIndexByCharacterKey({\n keysSoFar: _inputValue,\n highlightedIndex: state.highlightedIndex,\n items: props.items,\n itemToString: props.itemToString,\n getItemNodeFromIndex: action.getItemNodeFromIndex\n });\n changes = (0,esm_extends["default"])({\n inputValue: _inputValue\n }, highlightedIndex >= 0 && {\n highlightedIndex: highlightedIndex\n });\n }\n break;\n\n case MenuKeyDownArrowDown:\n changes = {\n highlightedIndex: getNextWrappingIndex(shiftKey ? 5 : 1, state.highlightedIndex, props.items.length, action.getItemNodeFromIndex, props.circularNavigation)\n };\n break;\n\n case MenuKeyDownArrowUp:\n changes = {\n highlightedIndex: getNextWrappingIndex(shiftKey ? -5 : -1, state.highlightedIndex, props.items.length, action.getItemNodeFromIndex, props.circularNavigation)\n };\n break;\n\n case FunctionSelectItem$1:\n changes = {\n selectedItem: action.selectedItem\n };\n break;\n\n default:\n return downshiftCommonReducer(state, action, stateChangeTypes$2);\n }\n\n return (0,esm_extends["default"])({}, state, changes);\n}\n/* eslint-enable complexity */\n\nvar _excluded$2 = ["onMouseLeave", "refKey", "onKeyDown", "onBlur", "ref"],\n _excluded2$2 = ["onClick", "onKeyDown", "refKey", "ref"],\n _excluded3$1 = ["item", "index", "onMouseMove", "onClick", "refKey", "ref"];\nuseSelect.stateChangeTypes = stateChangeTypes$2;\n\nfunction useSelect(userProps) {\n if (userProps === void 0) {\n userProps = {};\n }\n\n validatePropTypes$2(userProps, useSelect); // Props defaults and destructuring.\n\n var props = (0,esm_extends["default"])({}, defaultProps$2, userProps);\n\n var items = props.items,\n scrollIntoView = props.scrollIntoView,\n environment = props.environment,\n initialIsOpen = props.initialIsOpen,\n defaultIsOpen = props.defaultIsOpen,\n itemToString = props.itemToString,\n getA11ySelectionMessage = props.getA11ySelectionMessage,\n getA11yStatusMessage = props.getA11yStatusMessage; // Initial state depending on controlled props.\n\n var initialState = getInitialState$2(props);\n\n var _useControlledReducer = useControlledReducer$1(downshiftSelectReducer, initialState, props),\n state = _useControlledReducer[0],\n dispatch = _useControlledReducer[1];\n\n var isOpen = state.isOpen,\n highlightedIndex = state.highlightedIndex,\n selectedItem = state.selectedItem,\n inputValue = state.inputValue; // Element efs.\n\n var toggleButtonRef = (0,external_React_.useRef)(null);\n var menuRef = (0,external_React_.useRef)(null);\n var itemRefs = (0,external_React_.useRef)({}); // used not to trigger menu blur action in some scenarios.\n\n var shouldBlurRef = (0,external_React_.useRef)(true); // used to keep the inputValue clearTimeout object between renders.\n\n var clearTimeoutRef = (0,external_React_.useRef)(null); // prevent id re-generation between renders.\n\n var elementIds = useElementIds(props); // used to keep track of how many items we had on previous cycle.\n\n var previousResultCountRef = (0,external_React_.useRef)();\n var isInitialMountRef = (0,external_React_.useRef)(true); // utility callback to get item element.\n\n var latest = useLatestRef({\n state: state,\n props: props\n }); // Some utils.\n\n var getItemNodeFromIndex = (0,external_React_.useCallback)(function (index) {\n return itemRefs.current[elementIds.getItemId(index)];\n }, [elementIds]); // Effects.\n // Sets a11y status message on changes in state.\n\n useA11yMessageSetter(getA11yStatusMessage, [isOpen, highlightedIndex, inputValue, items], (0,esm_extends["default"])({\n isInitialMount: isInitialMountRef.current,\n previousResultCount: previousResultCountRef.current,\n items: items,\n environment: environment,\n itemToString: itemToString\n }, state)); // Sets a11y status message on changes in selectedItem.\n\n useA11yMessageSetter(getA11ySelectionMessage, [selectedItem], (0,esm_extends["default"])({\n isInitialMount: isInitialMountRef.current,\n previousResultCount: previousResultCountRef.current,\n items: items,\n environment: environment,\n itemToString: itemToString\n }, state)); // Scroll on highlighted item if change comes from keyboard.\n\n var shouldScrollRef = useScrollIntoView({\n menuElement: menuRef.current,\n highlightedIndex: highlightedIndex,\n isOpen: isOpen,\n itemRefs: itemRefs,\n scrollIntoView: scrollIntoView,\n getItemNodeFromIndex: getItemNodeFromIndex\n }); // Sets cleanup for the keysSoFar callback, debounded after 500ms.\n\n (0,external_React_.useEffect)(function () {\n // init the clean function here as we need access to dispatch.\n clearTimeoutRef.current = debounce(function (outerDispatch) {\n outerDispatch({\n type: FunctionSetInputValue$1,\n inputValue: \'\'\n });\n }, 500); // Cancel any pending debounced calls on mount\n\n return function () {\n clearTimeoutRef.current.cancel();\n };\n }, []); // Invokes the keysSoFar callback set up above.\n\n (0,external_React_.useEffect)(function () {\n if (!inputValue) {\n return;\n }\n\n clearTimeoutRef.current(dispatch);\n }, [dispatch, inputValue]);\n useControlPropsValidator({\n isInitialMount: isInitialMountRef.current,\n props: props,\n state: state\n });\n /* Controls the focus on the menu or the toggle button. */\n\n (0,external_React_.useEffect)(function () {\n // Don\'t focus menu on first render.\n if (isInitialMountRef.current) {\n // Unless it was initialised as open.\n if ((initialIsOpen || defaultIsOpen || isOpen) && menuRef.current) {\n menuRef.current.focus();\n }\n\n return;\n } // Focus menu on open.\n\n\n if (isOpen) {\n // istanbul ignore else\n if (menuRef.current) {\n menuRef.current.focus();\n }\n\n return;\n } // Focus toggleButton on close, but not if it was closed with (Shift+)Tab.\n\n\n if (environment.document.activeElement === menuRef.current) {\n // istanbul ignore else\n if (toggleButtonRef.current) {\n shouldBlurRef.current = false;\n toggleButtonRef.current.focus();\n }\n } // eslint-disable-next-line react-hooks/exhaustive-deps\n\n }, [isOpen]);\n (0,external_React_.useEffect)(function () {\n if (isInitialMountRef.current) {\n return;\n }\n\n previousResultCountRef.current = items.length;\n }); // Add mouse/touch events to document.\n\n var mouseAndTouchTrackersRef = useMouseAndTouchTracker(isOpen, [menuRef, toggleButtonRef], environment, function () {\n dispatch({\n type: MenuBlur\n });\n });\n var setGetterPropCallInfo = useGetterPropsCalledChecker(\'getMenuProps\', \'getToggleButtonProps\'); // Make initial ref false.\n\n (0,external_React_.useEffect)(function () {\n isInitialMountRef.current = false;\n }, []); // Reset itemRefs on close.\n\n (0,external_React_.useEffect)(function () {\n if (!isOpen) {\n itemRefs.current = {};\n }\n }, [isOpen]); // Event handler functions.\n\n var toggleButtonKeyDownHandlers = (0,external_React_.useMemo)(function () {\n return {\n ArrowDown: function ArrowDown(event) {\n event.preventDefault();\n dispatch({\n type: ToggleButtonKeyDownArrowDown,\n getItemNodeFromIndex: getItemNodeFromIndex,\n shiftKey: event.shiftKey\n });\n },\n ArrowUp: function ArrowUp(event) {\n event.preventDefault();\n dispatch({\n type: ToggleButtonKeyDownArrowUp,\n getItemNodeFromIndex: getItemNodeFromIndex,\n shiftKey: event.shiftKey\n });\n }\n };\n }, [dispatch, getItemNodeFromIndex]);\n var menuKeyDownHandlers = (0,external_React_.useMemo)(function () {\n return {\n ArrowDown: function ArrowDown(event) {\n event.preventDefault();\n dispatch({\n type: MenuKeyDownArrowDown,\n getItemNodeFromIndex: getItemNodeFromIndex,\n shiftKey: event.shiftKey\n });\n },\n ArrowUp: function ArrowUp(event) {\n event.preventDefault();\n dispatch({\n type: MenuKeyDownArrowUp,\n getItemNodeFromIndex: getItemNodeFromIndex,\n shiftKey: event.shiftKey\n });\n },\n Home: function Home(event) {\n event.preventDefault();\n dispatch({\n type: MenuKeyDownHome,\n getItemNodeFromIndex: getItemNodeFromIndex\n });\n },\n End: function End(event) {\n event.preventDefault();\n dispatch({\n type: MenuKeyDownEnd,\n getItemNodeFromIndex: getItemNodeFromIndex\n });\n },\n Escape: function Escape() {\n dispatch({\n type: MenuKeyDownEscape\n });\n },\n Enter: function Enter(event) {\n event.preventDefault();\n dispatch({\n type: MenuKeyDownEnter\n });\n },\n \' \': function _(event) {\n event.preventDefault();\n dispatch({\n type: MenuKeyDownSpaceButton\n });\n }\n };\n }, [dispatch, getItemNodeFromIndex]); // Action functions.\n\n var toggleMenu = (0,external_React_.useCallback)(function () {\n dispatch({\n type: FunctionToggleMenu$1\n });\n }, [dispatch]);\n var closeMenu = (0,external_React_.useCallback)(function () {\n dispatch({\n type: FunctionCloseMenu$1\n });\n }, [dispatch]);\n var openMenu = (0,external_React_.useCallback)(function () {\n dispatch({\n type: FunctionOpenMenu$1\n });\n }, [dispatch]);\n var setHighlightedIndex = (0,external_React_.useCallback)(function (newHighlightedIndex) {\n dispatch({\n type: FunctionSetHighlightedIndex$1,\n highlightedIndex: newHighlightedIndex\n });\n }, [dispatch]);\n var selectItem = (0,external_React_.useCallback)(function (newSelectedItem) {\n dispatch({\n type: FunctionSelectItem$1,\n selectedItem: newSelectedItem\n });\n }, [dispatch]);\n var reset = (0,external_React_.useCallback)(function () {\n dispatch({\n type: FunctionReset$2\n });\n }, [dispatch]);\n var setInputValue = (0,external_React_.useCallback)(function (newInputValue) {\n dispatch({\n type: FunctionSetInputValue$1,\n inputValue: newInputValue\n });\n }, [dispatch]); // Getter functions.\n\n var getLabelProps = (0,external_React_.useCallback)(function (labelProps) {\n return (0,esm_extends["default"])({\n id: elementIds.labelId,\n htmlFor: elementIds.toggleButtonId\n }, labelProps);\n }, [elementIds]);\n var getMenuProps = (0,external_React_.useCallback)(function (_temp, _temp2) {\n var _extends2;\n\n var _ref = _temp === void 0 ? {} : _temp,\n onMouseLeave = _ref.onMouseLeave,\n _ref$refKey = _ref.refKey,\n refKey = _ref$refKey === void 0 ? \'ref\' : _ref$refKey,\n onKeyDown = _ref.onKeyDown,\n onBlur = _ref.onBlur,\n ref = _ref.ref,\n rest = (0,objectWithoutPropertiesLoose["default"])(_ref, _excluded$2);\n\n var _ref2 = _temp2 === void 0 ? {} : _temp2,\n _ref2$suppressRefErro = _ref2.suppressRefError,\n suppressRefError = _ref2$suppressRefErro === void 0 ? false : _ref2$suppressRefErro;\n\n var latestState = latest.current.state;\n\n var menuHandleKeyDown = function menuHandleKeyDown(event) {\n var key = normalizeArrowKey(event);\n\n if (key && menuKeyDownHandlers[key]) {\n menuKeyDownHandlers[key](event);\n } else if (isAcceptedCharacterKey(key)) {\n dispatch({\n type: MenuKeyDownCharacter,\n key: key,\n getItemNodeFromIndex: getItemNodeFromIndex\n });\n }\n };\n\n var menuHandleBlur = function menuHandleBlur() {\n // if the blur was a result of selection, we don\'t trigger this action.\n if (shouldBlurRef.current === false) {\n shouldBlurRef.current = true;\n return;\n }\n\n var shouldBlur = !mouseAndTouchTrackersRef.current.isMouseDown;\n /* istanbul ignore else */\n\n if (shouldBlur) {\n dispatch({\n type: MenuBlur\n });\n }\n };\n\n var menuHandleMouseLeave = function menuHandleMouseLeave() {\n dispatch({\n type: MenuMouseLeave$1\n });\n };\n\n setGetterPropCallInfo(\'getMenuProps\', suppressRefError, refKey, menuRef);\n return (0,esm_extends["default"])((_extends2 = {}, _extends2[refKey] = handleRefs(ref, function (menuNode) {\n menuRef.current = menuNode;\n }), _extends2.id = elementIds.menuId, _extends2.role = \'listbox\', _extends2[\'aria-labelledby\'] = elementIds.labelId, _extends2.tabIndex = -1, _extends2), latestState.isOpen && latestState.highlightedIndex > -1 && {\n \'aria-activedescendant\': elementIds.getItemId(latestState.highlightedIndex)\n }, {\n onMouseLeave: callAllEventHandlers(onMouseLeave, menuHandleMouseLeave),\n onKeyDown: callAllEventHandlers(onKeyDown, menuHandleKeyDown),\n onBlur: callAllEventHandlers(onBlur, menuHandleBlur)\n }, rest);\n }, [dispatch, latest, menuKeyDownHandlers, mouseAndTouchTrackersRef, setGetterPropCallInfo, elementIds, getItemNodeFromIndex]);\n var getToggleButtonProps = (0,external_React_.useCallback)(function (_temp3, _temp4) {\n var _extends3;\n\n var _ref3 = _temp3 === void 0 ? {} : _temp3,\n onClick = _ref3.onClick,\n onKeyDown = _ref3.onKeyDown,\n _ref3$refKey = _ref3.refKey,\n refKey = _ref3$refKey === void 0 ? \'ref\' : _ref3$refKey,\n ref = _ref3.ref,\n rest = (0,objectWithoutPropertiesLoose["default"])(_ref3, _excluded2$2);\n\n var _ref4 = _temp4 === void 0 ? {} : _temp4,\n _ref4$suppressRefErro = _ref4.suppressRefError,\n suppressRefError = _ref4$suppressRefErro === void 0 ? false : _ref4$suppressRefErro;\n\n var toggleButtonHandleClick = function toggleButtonHandleClick() {\n dispatch({\n type: ToggleButtonClick$1\n });\n };\n\n var toggleButtonHandleKeyDown = function toggleButtonHandleKeyDown(event) {\n var key = normalizeArrowKey(event);\n\n if (key && toggleButtonKeyDownHandlers[key]) {\n toggleButtonKeyDownHandlers[key](event);\n } else if (isAcceptedCharacterKey(key)) {\n dispatch({\n type: ToggleButtonKeyDownCharacter,\n key: key,\n getItemNodeFromIndex: getItemNodeFromIndex\n });\n }\n };\n\n var toggleProps = (0,esm_extends["default"])((_extends3 = {}, _extends3[refKey] = handleRefs(ref, function (toggleButtonNode) {\n toggleButtonRef.current = toggleButtonNode;\n }), _extends3.id = elementIds.toggleButtonId, _extends3[\'aria-haspopup\'] = \'listbox\', _extends3[\'aria-expanded\'] = latest.current.state.isOpen, _extends3[\'aria-labelledby\'] = elementIds.labelId + " " + elementIds.toggleButtonId, _extends3), rest);\n\n if (!rest.disabled) {\n toggleProps.onClick = callAllEventHandlers(onClick, toggleButtonHandleClick);\n toggleProps.onKeyDown = callAllEventHandlers(onKeyDown, toggleButtonHandleKeyDown);\n }\n\n setGetterPropCallInfo(\'getToggleButtonProps\', suppressRefError, refKey, toggleButtonRef);\n return toggleProps;\n }, [dispatch, latest, toggleButtonKeyDownHandlers, setGetterPropCallInfo, elementIds, getItemNodeFromIndex]);\n var getItemProps = (0,external_React_.useCallback)(function (_temp5) {\n var _extends4;\n\n var _ref5 = _temp5 === void 0 ? {} : _temp5,\n item = _ref5.item,\n index = _ref5.index,\n onMouseMove = _ref5.onMouseMove,\n onClick = _ref5.onClick,\n _ref5$refKey = _ref5.refKey,\n refKey = _ref5$refKey === void 0 ? \'ref\' : _ref5$refKey,\n ref = _ref5.ref,\n rest = (0,objectWithoutPropertiesLoose["default"])(_ref5, _excluded3$1);\n\n var _latest$current = latest.current,\n latestState = _latest$current.state,\n latestProps = _latest$current.props;\n\n var itemHandleMouseMove = function itemHandleMouseMove() {\n if (index === latestState.highlightedIndex) {\n return;\n }\n\n shouldScrollRef.current = false;\n dispatch({\n type: ItemMouseMove$1,\n index: index\n });\n };\n\n var itemHandleClick = function itemHandleClick() {\n dispatch({\n type: ItemClick$1,\n index: index\n });\n };\n\n var itemIndex = getItemIndex(index, item, latestProps.items);\n\n if (itemIndex < 0) {\n throw new Error(\'Pass either item or item index in getItemProps!\');\n }\n\n var itemProps = (0,esm_extends["default"])((_extends4 = {\n role: \'option\',\n \'aria-selected\': "" + (itemIndex === latestState.highlightedIndex),\n id: elementIds.getItemId(itemIndex)\n }, _extends4[refKey] = handleRefs(ref, function (itemNode) {\n if (itemNode) {\n itemRefs.current[elementIds.getItemId(itemIndex)] = itemNode;\n }\n }), _extends4), rest);\n\n if (!rest.disabled) {\n itemProps.onMouseMove = callAllEventHandlers(onMouseMove, itemHandleMouseMove);\n itemProps.onClick = callAllEventHandlers(onClick, itemHandleClick);\n }\n\n return itemProps;\n }, [dispatch, latest, shouldScrollRef, elementIds]);\n return {\n // prop getters.\n getToggleButtonProps: getToggleButtonProps,\n getLabelProps: getLabelProps,\n getMenuProps: getMenuProps,\n getItemProps: getItemProps,\n // actions.\n toggleMenu: toggleMenu,\n openMenu: openMenu,\n closeMenu: closeMenu,\n setHighlightedIndex: setHighlightedIndex,\n selectItem: selectItem,\n reset: reset,\n setInputValue: setInputValue,\n // state.\n highlightedIndex: highlightedIndex,\n isOpen: isOpen,\n selectedItem: selectedItem,\n inputValue: inputValue\n };\n}\n\nvar InputKeyDownArrowDown = false ? 0 : 0;\nvar InputKeyDownArrowUp = false ? 0 : 1;\nvar InputKeyDownEscape = false ? 0 : 2;\nvar InputKeyDownHome = false ? 0 : 3;\nvar InputKeyDownEnd = false ? 0 : 4;\nvar InputKeyDownEnter = false ? 0 : 5;\nvar InputChange = false ? 0 : 6;\nvar InputBlur = false ? 0 : 7;\nvar MenuMouseLeave = false ? 0 : 8;\nvar ItemMouseMove = false ? 0 : 9;\nvar ItemClick = false ? 0 : 10;\nvar ToggleButtonClick = false ? 0 : 11;\nvar FunctionToggleMenu = false ? 0 : 12;\nvar FunctionOpenMenu = false ? 0 : 13;\nvar FunctionCloseMenu = false ? 0 : 14;\nvar FunctionSetHighlightedIndex = false ? 0 : 15;\nvar FunctionSelectItem = false ? 0 : 16;\nvar FunctionSetInputValue = false ? 0 : 17;\nvar FunctionReset$1 = false ? 0 : 18;\nvar ControlledPropUpdatedSelectedItem = false ? 0 : 19;\n\nvar stateChangeTypes$1 = /*#__PURE__*/Object.freeze({\n __proto__: null,\n InputKeyDownArrowDown: InputKeyDownArrowDown,\n InputKeyDownArrowUp: InputKeyDownArrowUp,\n InputKeyDownEscape: InputKeyDownEscape,\n InputKeyDownHome: InputKeyDownHome,\n InputKeyDownEnd: InputKeyDownEnd,\n InputKeyDownEnter: InputKeyDownEnter,\n InputChange: InputChange,\n InputBlur: InputBlur,\n MenuMouseLeave: MenuMouseLeave,\n ItemMouseMove: ItemMouseMove,\n ItemClick: ItemClick,\n ToggleButtonClick: ToggleButtonClick,\n FunctionToggleMenu: FunctionToggleMenu,\n FunctionOpenMenu: FunctionOpenMenu,\n FunctionCloseMenu: FunctionCloseMenu,\n FunctionSetHighlightedIndex: FunctionSetHighlightedIndex,\n FunctionSelectItem: FunctionSelectItem,\n FunctionSetInputValue: FunctionSetInputValue,\n FunctionReset: FunctionReset$1,\n ControlledPropUpdatedSelectedItem: ControlledPropUpdatedSelectedItem\n});\n\nfunction getInitialState$1(props) {\n var initialState = getInitialState$2(props);\n var selectedItem = initialState.selectedItem;\n var inputValue = initialState.inputValue;\n\n if (inputValue === \'\' && selectedItem && props.defaultInputValue === undefined && props.initialInputValue === undefined && props.inputValue === undefined) {\n inputValue = props.itemToString(selectedItem);\n }\n\n return (0,esm_extends["default"])({}, initialState, {\n inputValue: inputValue\n });\n}\n\nvar propTypes$1 = {\n items: (prop_types_default()).array.isRequired,\n itemToString: (prop_types_default()).func,\n getA11yStatusMessage: (prop_types_default()).func,\n getA11ySelectionMessage: (prop_types_default()).func,\n circularNavigation: (prop_types_default()).bool,\n highlightedIndex: (prop_types_default()).number,\n defaultHighlightedIndex: (prop_types_default()).number,\n initialHighlightedIndex: (prop_types_default()).number,\n isOpen: (prop_types_default()).bool,\n defaultIsOpen: (prop_types_default()).bool,\n initialIsOpen: (prop_types_default()).bool,\n selectedItem: (prop_types_default()).any,\n initialSelectedItem: (prop_types_default()).any,\n defaultSelectedItem: (prop_types_default()).any,\n inputValue: (prop_types_default()).string,\n defaultInputValue: (prop_types_default()).string,\n initialInputValue: (prop_types_default()).string,\n id: (prop_types_default()).string,\n labelId: (prop_types_default()).string,\n menuId: (prop_types_default()).string,\n getItemId: (prop_types_default()).func,\n inputId: (prop_types_default()).string,\n toggleButtonId: (prop_types_default()).string,\n stateReducer: (prop_types_default()).func,\n onSelectedItemChange: (prop_types_default()).func,\n onHighlightedIndexChange: (prop_types_default()).func,\n onStateChange: (prop_types_default()).func,\n onIsOpenChange: (prop_types_default()).func,\n onInputValueChange: (prop_types_default()).func,\n environment: prop_types_default().shape({\n addEventListener: (prop_types_default()).func,\n removeEventListener: (prop_types_default()).func,\n document: prop_types_default().shape({\n getElementById: (prop_types_default()).func,\n activeElement: (prop_types_default()).any,\n body: (prop_types_default()).any\n })\n })\n};\n/**\n * The useCombobox version of useControlledReducer, which also\n * checks if the controlled prop selectedItem changed between\n * renders. If so, it will also update inputValue with its\n * string equivalent. It uses the common useEnhancedReducer to\n * compute the rest of the state.\n *\n * @param {Function} reducer Reducer function from downshift.\n * @param {Object} initialState Initial state of the hook.\n * @param {Object} props The hook props.\n * @returns {Array} An array with the state and an action dispatcher.\n */\n\nfunction useControlledReducer(reducer, initialState, props) {\n var previousSelectedItemRef = (0,external_React_.useRef)();\n\n var _useEnhancedReducer = useEnhancedReducer(reducer, initialState, props),\n state = _useEnhancedReducer[0],\n dispatch = _useEnhancedReducer[1]; // ToDo: if needed, make same approach as selectedItemChanged from Downshift.\n\n\n (0,external_React_.useEffect)(function () {\n if (isControlledProp(props, \'selectedItem\')) {\n if (previousSelectedItemRef.current !== props.selectedItem) {\n dispatch({\n type: ControlledPropUpdatedSelectedItem,\n inputValue: props.itemToString(props.selectedItem)\n });\n }\n\n previousSelectedItemRef.current = state.selectedItem === previousSelectedItemRef.current ? props.selectedItem : state.selectedItem;\n }\n });\n return [getState(state, props), dispatch];\n} // eslint-disable-next-line import/no-mutable-exports\n\n\nvar validatePropTypes$1 = noop;\n/* istanbul ignore next */\n\nif (false) {}\n\nvar defaultProps$1 = (0,esm_extends["default"])({}, defaultProps$3, {\n getA11yStatusMessage: getA11yStatusMessage$1,\n circularNavigation: true\n});\n\n/* eslint-disable complexity */\n\nfunction downshiftUseComboboxReducer(state, action) {\n var type = action.type,\n props = action.props,\n shiftKey = action.shiftKey;\n var changes;\n\n switch (type) {\n case ItemClick:\n changes = {\n isOpen: getDefaultValue$1(props, \'isOpen\'),\n highlightedIndex: getDefaultValue$1(props, \'highlightedIndex\'),\n selectedItem: props.items[action.index],\n inputValue: props.itemToString(props.items[action.index])\n };\n break;\n\n case InputKeyDownArrowDown:\n if (state.isOpen) {\n changes = {\n highlightedIndex: getNextWrappingIndex(shiftKey ? 5 : 1, state.highlightedIndex, props.items.length, action.getItemNodeFromIndex, props.circularNavigation)\n };\n } else {\n changes = {\n highlightedIndex: getHighlightedIndexOnOpen(props, state, 1, action.getItemNodeFromIndex),\n isOpen: props.items.length >= 0\n };\n }\n\n break;\n\n case InputKeyDownArrowUp:\n if (state.isOpen) {\n changes = {\n highlightedIndex: getNextWrappingIndex(shiftKey ? -5 : -1, state.highlightedIndex, props.items.length, action.getItemNodeFromIndex, props.circularNavigation)\n };\n } else {\n changes = {\n highlightedIndex: getHighlightedIndexOnOpen(props, state, -1, action.getItemNodeFromIndex),\n isOpen: props.items.length >= 0\n };\n }\n\n break;\n\n case InputKeyDownEnter:\n changes = (0,esm_extends["default"])({}, state.isOpen && state.highlightedIndex >= 0 && {\n selectedItem: props.items[state.highlightedIndex],\n isOpen: getDefaultValue$1(props, \'isOpen\'),\n highlightedIndex: getDefaultValue$1(props, \'highlightedIndex\'),\n inputValue: props.itemToString(props.items[state.highlightedIndex])\n });\n break;\n\n case InputKeyDownEscape:\n changes = (0,esm_extends["default"])({\n isOpen: false,\n highlightedIndex: -1\n }, !state.isOpen && {\n selectedItem: null,\n inputValue: \'\'\n });\n break;\n\n case InputKeyDownHome:\n changes = {\n highlightedIndex: getNextNonDisabledIndex(1, 0, props.items.length, action.getItemNodeFromIndex, false)\n };\n break;\n\n case InputKeyDownEnd:\n changes = {\n highlightedIndex: getNextNonDisabledIndex(-1, props.items.length - 1, props.items.length, action.getItemNodeFromIndex, false)\n };\n break;\n\n case InputBlur:\n changes = (0,esm_extends["default"])({\n isOpen: false,\n highlightedIndex: -1\n }, state.highlightedIndex >= 0 && action.selectItem && {\n selectedItem: props.items[state.highlightedIndex],\n inputValue: props.itemToString(props.items[state.highlightedIndex])\n });\n break;\n\n case InputChange:\n changes = {\n isOpen: true,\n highlightedIndex: getDefaultValue$1(props, \'highlightedIndex\'),\n inputValue: action.inputValue\n };\n break;\n\n case FunctionSelectItem:\n changes = {\n selectedItem: action.selectedItem,\n inputValue: props.itemToString(action.selectedItem)\n };\n break;\n\n case ControlledPropUpdatedSelectedItem:\n changes = {\n inputValue: action.inputValue\n };\n break;\n\n default:\n return downshiftCommonReducer(state, action, stateChangeTypes$1);\n }\n\n return (0,esm_extends["default"])({}, state, changes);\n}\n/* eslint-enable complexity */\n\nvar _excluded$1 = ["onMouseLeave", "refKey", "ref"],\n _excluded2$1 = ["item", "index", "refKey", "ref", "onMouseMove", "onClick", "onPress"],\n _excluded3 = ["onClick", "onPress", "refKey", "ref"],\n _excluded4 = ["onKeyDown", "onChange", "onInput", "onBlur", "onChangeText", "refKey", "ref"],\n _excluded5 = ["refKey", "ref"];\nuseCombobox.stateChangeTypes = stateChangeTypes$1;\n\nfunction useCombobox(userProps) {\n if (userProps === void 0) {\n userProps = {};\n }\n\n validatePropTypes$1(userProps, useCombobox); // Props defaults and destructuring.\n\n var props = (0,esm_extends["default"])({}, defaultProps$1, userProps);\n\n var initialIsOpen = props.initialIsOpen,\n defaultIsOpen = props.defaultIsOpen,\n items = props.items,\n scrollIntoView = props.scrollIntoView,\n environment = props.environment,\n getA11yStatusMessage = props.getA11yStatusMessage,\n getA11ySelectionMessage = props.getA11ySelectionMessage,\n itemToString = props.itemToString; // Initial state depending on controlled props.\n\n var initialState = getInitialState$1(props);\n\n var _useControlledReducer = useControlledReducer(downshiftUseComboboxReducer, initialState, props),\n state = _useControlledReducer[0],\n dispatch = _useControlledReducer[1];\n\n var isOpen = state.isOpen,\n highlightedIndex = state.highlightedIndex,\n selectedItem = state.selectedItem,\n inputValue = state.inputValue; // Element refs.\n\n var menuRef = (0,external_React_.useRef)(null);\n var itemRefs = (0,external_React_.useRef)({});\n var inputRef = (0,external_React_.useRef)(null);\n var toggleButtonRef = (0,external_React_.useRef)(null);\n var comboboxRef = (0,external_React_.useRef)(null);\n var isInitialMountRef = (0,external_React_.useRef)(true); // prevent id re-generation between renders.\n\n var elementIds = useElementIds(props); // used to keep track of how many items we had on previous cycle.\n\n var previousResultCountRef = (0,external_React_.useRef)(); // utility callback to get item element.\n\n var latest = useLatestRef({\n state: state,\n props: props\n });\n var getItemNodeFromIndex = (0,external_React_.useCallback)(function (index) {\n return itemRefs.current[elementIds.getItemId(index)];\n }, [elementIds]); // Effects.\n // Sets a11y status message on changes in state.\n\n useA11yMessageSetter(getA11yStatusMessage, [isOpen, highlightedIndex, inputValue, items], (0,esm_extends["default"])({\n isInitialMount: isInitialMountRef.current,\n previousResultCount: previousResultCountRef.current,\n items: items,\n environment: environment,\n itemToString: itemToString\n }, state)); // Sets a11y status message on changes in selectedItem.\n\n useA11yMessageSetter(getA11ySelectionMessage, [selectedItem], (0,esm_extends["default"])({\n isInitialMount: isInitialMountRef.current,\n previousResultCount: previousResultCountRef.current,\n items: items,\n environment: environment,\n itemToString: itemToString\n }, state)); // Scroll on highlighted item if change comes from keyboard.\n\n var shouldScrollRef = useScrollIntoView({\n menuElement: menuRef.current,\n highlightedIndex: highlightedIndex,\n isOpen: isOpen,\n itemRefs: itemRefs,\n scrollIntoView: scrollIntoView,\n getItemNodeFromIndex: getItemNodeFromIndex\n });\n useControlPropsValidator({\n isInitialMount: isInitialMountRef.current,\n props: props,\n state: state\n }); // Focus the input on first render if required.\n\n (0,external_React_.useEffect)(function () {\n var focusOnOpen = initialIsOpen || defaultIsOpen || isOpen;\n\n if (focusOnOpen && inputRef.current) {\n inputRef.current.focus();\n } // eslint-disable-next-line react-hooks/exhaustive-deps\n\n }, []);\n (0,external_React_.useEffect)(function () {\n if (isInitialMountRef.current) {\n return;\n }\n\n previousResultCountRef.current = items.length;\n }); // Add mouse/touch events to document.\n\n var mouseAndTouchTrackersRef = useMouseAndTouchTracker(isOpen, [comboboxRef, menuRef, toggleButtonRef], environment, function () {\n dispatch({\n type: InputBlur,\n selectItem: false\n });\n });\n var setGetterPropCallInfo = useGetterPropsCalledChecker(\'getInputProps\', \'getComboboxProps\', \'getMenuProps\'); // Make initial ref false.\n\n (0,external_React_.useEffect)(function () {\n isInitialMountRef.current = false;\n }, []); // Reset itemRefs on close.\n\n (0,external_React_.useEffect)(function () {\n if (!isOpen) {\n itemRefs.current = {};\n }\n }, [isOpen]);\n /* Event handler functions */\n\n var inputKeyDownHandlers = (0,external_React_.useMemo)(function () {\n return {\n ArrowDown: function ArrowDown(event) {\n event.preventDefault();\n dispatch({\n type: InputKeyDownArrowDown,\n shiftKey: event.shiftKey,\n getItemNodeFromIndex: getItemNodeFromIndex\n });\n },\n ArrowUp: function ArrowUp(event) {\n event.preventDefault();\n dispatch({\n type: InputKeyDownArrowUp,\n shiftKey: event.shiftKey,\n getItemNodeFromIndex: getItemNodeFromIndex\n });\n },\n Home: function Home(event) {\n if (!latest.current.state.isOpen) {\n return;\n }\n\n event.preventDefault();\n dispatch({\n type: InputKeyDownHome,\n getItemNodeFromIndex: getItemNodeFromIndex\n });\n },\n End: function End(event) {\n if (!latest.current.state.isOpen) {\n return;\n }\n\n event.preventDefault();\n dispatch({\n type: InputKeyDownEnd,\n getItemNodeFromIndex: getItemNodeFromIndex\n });\n },\n Escape: function Escape() {\n var latestState = latest.current.state;\n\n if (latestState.isOpen || latestState.inputValue || latestState.selectedItem || latestState.highlightedIndex > -1) {\n dispatch({\n type: InputKeyDownEscape\n });\n }\n },\n Enter: function Enter(event) {\n var latestState = latest.current.state; // if closed or no highlighted index, do nothing.\n\n if (!latestState.isOpen || latestState.highlightedIndex < 0 || event.which === 229 // if IME composing, wait for next Enter keydown event.\n ) {\n return;\n }\n\n event.preventDefault();\n dispatch({\n type: InputKeyDownEnter,\n getItemNodeFromIndex: getItemNodeFromIndex\n });\n }\n };\n }, [dispatch, latest, getItemNodeFromIndex]); // Getter props.\n\n var getLabelProps = (0,external_React_.useCallback)(function (labelProps) {\n return (0,esm_extends["default"])({\n id: elementIds.labelId,\n htmlFor: elementIds.inputId\n }, labelProps);\n }, [elementIds]);\n var getMenuProps = (0,external_React_.useCallback)(function (_temp, _temp2) {\n var _extends2;\n\n var _ref = _temp === void 0 ? {} : _temp,\n onMouseLeave = _ref.onMouseLeave,\n _ref$refKey = _ref.refKey,\n refKey = _ref$refKey === void 0 ? \'ref\' : _ref$refKey,\n ref = _ref.ref,\n rest = (0,objectWithoutPropertiesLoose["default"])(_ref, _excluded$1);\n\n var _ref2 = _temp2 === void 0 ? {} : _temp2,\n _ref2$suppressRefErro = _ref2.suppressRefError,\n suppressRefError = _ref2$suppressRefErro === void 0 ? false : _ref2$suppressRefErro;\n\n setGetterPropCallInfo(\'getMenuProps\', suppressRefError, refKey, menuRef);\n return (0,esm_extends["default"])((_extends2 = {}, _extends2[refKey] = handleRefs(ref, function (menuNode) {\n menuRef.current = menuNode;\n }), _extends2.id = elementIds.menuId, _extends2.role = \'listbox\', _extends2[\'aria-labelledby\'] = elementIds.labelId, _extends2.onMouseLeave = callAllEventHandlers(onMouseLeave, function () {\n dispatch({\n type: MenuMouseLeave\n });\n }), _extends2), rest);\n }, [dispatch, setGetterPropCallInfo, elementIds]);\n var getItemProps = (0,external_React_.useCallback)(function (_temp3) {\n var _extends3, _ref4;\n\n var _ref3 = _temp3 === void 0 ? {} : _temp3,\n item = _ref3.item,\n index = _ref3.index,\n _ref3$refKey = _ref3.refKey,\n refKey = _ref3$refKey === void 0 ? \'ref\' : _ref3$refKey,\n ref = _ref3.ref,\n onMouseMove = _ref3.onMouseMove,\n onClick = _ref3.onClick;\n _ref3.onPress;\n var rest = (0,objectWithoutPropertiesLoose["default"])(_ref3, _excluded2$1);\n\n var _latest$current = latest.current,\n latestProps = _latest$current.props,\n latestState = _latest$current.state;\n var itemIndex = getItemIndex(index, item, latestProps.items);\n\n if (itemIndex < 0) {\n throw new Error(\'Pass either item or item index in getItemProps!\');\n }\n\n var onSelectKey = \'onClick\';\n var customClickHandler = onClick;\n\n var itemHandleMouseMove = function itemHandleMouseMove() {\n if (index === latestState.highlightedIndex) {\n return;\n }\n\n shouldScrollRef.current = false;\n dispatch({\n type: ItemMouseMove,\n index: index\n });\n };\n\n var itemHandleClick = function itemHandleClick() {\n dispatch({\n type: ItemClick,\n index: index\n });\n\n if (inputRef.current) {\n inputRef.current.focus();\n }\n };\n\n return (0,esm_extends["default"])((_extends3 = {}, _extends3[refKey] = handleRefs(ref, function (itemNode) {\n if (itemNode) {\n itemRefs.current[elementIds.getItemId(itemIndex)] = itemNode;\n }\n }), _extends3.role = \'option\', _extends3[\'aria-selected\'] = "" + (itemIndex === latestState.highlightedIndex), _extends3.id = elementIds.getItemId(itemIndex), _extends3), !rest.disabled && (_ref4 = {\n onMouseMove: callAllEventHandlers(onMouseMove, itemHandleMouseMove)\n }, _ref4[onSelectKey] = callAllEventHandlers(customClickHandler, itemHandleClick), _ref4), rest);\n }, [dispatch, latest, shouldScrollRef, elementIds]);\n var getToggleButtonProps = (0,external_React_.useCallback)(function (_temp4) {\n var _extends4;\n\n var _ref5 = _temp4 === void 0 ? {} : _temp4,\n onClick = _ref5.onClick;\n _ref5.onPress;\n var _ref5$refKey = _ref5.refKey,\n refKey = _ref5$refKey === void 0 ? \'ref\' : _ref5$refKey,\n ref = _ref5.ref,\n rest = (0,objectWithoutPropertiesLoose["default"])(_ref5, _excluded3);\n\n var toggleButtonHandleClick = function toggleButtonHandleClick() {\n dispatch({\n type: ToggleButtonClick\n });\n\n if (!latest.current.state.isOpen && inputRef.current) {\n inputRef.current.focus();\n }\n };\n\n return (0,esm_extends["default"])((_extends4 = {}, _extends4[refKey] = handleRefs(ref, function (toggleButtonNode) {\n toggleButtonRef.current = toggleButtonNode;\n }), _extends4.id = elementIds.toggleButtonId, _extends4.tabIndex = -1, _extends4), !rest.disabled && (0,esm_extends["default"])({}, {\n onClick: callAllEventHandlers(onClick, toggleButtonHandleClick)\n }), rest);\n }, [dispatch, latest, elementIds]);\n var getInputProps = (0,external_React_.useCallback)(function (_temp5, _temp6) {\n var _extends5;\n\n var _ref6 = _temp5 === void 0 ? {} : _temp5,\n onKeyDown = _ref6.onKeyDown,\n onChange = _ref6.onChange,\n onInput = _ref6.onInput,\n onBlur = _ref6.onBlur;\n _ref6.onChangeText;\n var _ref6$refKey = _ref6.refKey,\n refKey = _ref6$refKey === void 0 ? \'ref\' : _ref6$refKey,\n ref = _ref6.ref,\n rest = (0,objectWithoutPropertiesLoose["default"])(_ref6, _excluded4);\n\n var _ref7 = _temp6 === void 0 ? {} : _temp6,\n _ref7$suppressRefErro = _ref7.suppressRefError,\n suppressRefError = _ref7$suppressRefErro === void 0 ? false : _ref7$suppressRefErro;\n\n setGetterPropCallInfo(\'getInputProps\', suppressRefError, refKey, inputRef);\n var latestState = latest.current.state;\n\n var inputHandleKeyDown = function inputHandleKeyDown(event) {\n var key = normalizeArrowKey(event);\n\n if (key && inputKeyDownHandlers[key]) {\n inputKeyDownHandlers[key](event);\n }\n };\n\n var inputHandleChange = function inputHandleChange(event) {\n dispatch({\n type: InputChange,\n inputValue: event.target.value\n });\n };\n\n var inputHandleBlur = function inputHandleBlur() {\n /* istanbul ignore else */\n if (latestState.isOpen && !mouseAndTouchTrackersRef.current.isMouseDown) {\n dispatch({\n type: InputBlur,\n selectItem: true\n });\n }\n };\n /* istanbul ignore next (preact) */\n\n\n var onChangeKey = \'onChange\';\n var eventHandlers = {};\n\n if (!rest.disabled) {\n var _eventHandlers;\n\n eventHandlers = (_eventHandlers = {}, _eventHandlers[onChangeKey] = callAllEventHandlers(onChange, onInput, inputHandleChange), _eventHandlers.onKeyDown = callAllEventHandlers(onKeyDown, inputHandleKeyDown), _eventHandlers.onBlur = callAllEventHandlers(onBlur, inputHandleBlur), _eventHandlers);\n }\n\n return (0,esm_extends["default"])((_extends5 = {}, _extends5[refKey] = handleRefs(ref, function (inputNode) {\n inputRef.current = inputNode;\n }), _extends5.id = elementIds.inputId, _extends5[\'aria-autocomplete\'] = \'list\', _extends5[\'aria-controls\'] = elementIds.menuId, _extends5), latestState.isOpen && latestState.highlightedIndex > -1 && {\n \'aria-activedescendant\': elementIds.getItemId(latestState.highlightedIndex)\n }, {\n \'aria-labelledby\': elementIds.labelId,\n // https://developer.mozilla.org/en-US/docs/Web/Security/Securing_your_site/Turning_off_form_autocompletion\n // revert back since autocomplete="nope" is ignored on latest Chrome and Opera\n autoComplete: \'off\',\n value: latestState.inputValue\n }, eventHandlers, rest);\n }, [dispatch, inputKeyDownHandlers, latest, mouseAndTouchTrackersRef, setGetterPropCallInfo, elementIds]);\n var getComboboxProps = (0,external_React_.useCallback)(function (_temp7, _temp8) {\n var _extends6;\n\n var _ref8 = _temp7 === void 0 ? {} : _temp7,\n _ref8$refKey = _ref8.refKey,\n refKey = _ref8$refKey === void 0 ? \'ref\' : _ref8$refKey,\n ref = _ref8.ref,\n rest = (0,objectWithoutPropertiesLoose["default"])(_ref8, _excluded5);\n\n var _ref9 = _temp8 === void 0 ? {} : _temp8,\n _ref9$suppressRefErro = _ref9.suppressRefError,\n suppressRefError = _ref9$suppressRefErro === void 0 ? false : _ref9$suppressRefErro;\n\n setGetterPropCallInfo(\'getComboboxProps\', suppressRefError, refKey, comboboxRef);\n return (0,esm_extends["default"])((_extends6 = {}, _extends6[refKey] = handleRefs(ref, function (comboboxNode) {\n comboboxRef.current = comboboxNode;\n }), _extends6.role = \'combobox\', _extends6[\'aria-haspopup\'] = \'listbox\', _extends6[\'aria-owns\'] = elementIds.menuId, _extends6[\'aria-expanded\'] = latest.current.state.isOpen, _extends6), rest);\n }, [latest, setGetterPropCallInfo, elementIds]); // returns\n\n var toggleMenu = (0,external_React_.useCallback)(function () {\n dispatch({\n type: FunctionToggleMenu\n });\n }, [dispatch]);\n var closeMenu = (0,external_React_.useCallback)(function () {\n dispatch({\n type: FunctionCloseMenu\n });\n }, [dispatch]);\n var openMenu = (0,external_React_.useCallback)(function () {\n dispatch({\n type: FunctionOpenMenu\n });\n }, [dispatch]);\n var setHighlightedIndex = (0,external_React_.useCallback)(function (newHighlightedIndex) {\n dispatch({\n type: FunctionSetHighlightedIndex,\n highlightedIndex: newHighlightedIndex\n });\n }, [dispatch]);\n var selectItem = (0,external_React_.useCallback)(function (newSelectedItem) {\n dispatch({\n type: FunctionSelectItem,\n selectedItem: newSelectedItem\n });\n }, [dispatch]);\n var setInputValue = (0,external_React_.useCallback)(function (newInputValue) {\n dispatch({\n type: FunctionSetInputValue,\n inputValue: newInputValue\n });\n }, [dispatch]);\n var reset = (0,external_React_.useCallback)(function () {\n dispatch({\n type: FunctionReset$1\n });\n }, [dispatch]);\n return {\n // prop getters.\n getItemProps: getItemProps,\n getLabelProps: getLabelProps,\n getMenuProps: getMenuProps,\n getInputProps: getInputProps,\n getComboboxProps: getComboboxProps,\n getToggleButtonProps: getToggleButtonProps,\n // actions.\n toggleMenu: toggleMenu,\n openMenu: openMenu,\n closeMenu: closeMenu,\n setHighlightedIndex: setHighlightedIndex,\n setInputValue: setInputValue,\n selectItem: selectItem,\n reset: reset,\n // state.\n highlightedIndex: highlightedIndex,\n isOpen: isOpen,\n selectedItem: selectedItem,\n inputValue: inputValue\n };\n}\n\nvar defaultStateValues = {\n activeIndex: -1,\n selectedItems: []\n};\n/**\n * Returns the initial value for a state key in the following order:\n * 1. controlled prop, 2. initial prop, 3. default prop, 4. default\n * value from Downshift.\n *\n * @param {Object} props Props passed to the hook.\n * @param {string} propKey Props key to generate the value for.\n * @returns {any} The initial value for that prop.\n */\n\nfunction getInitialValue(props, propKey) {\n return getInitialValue$1(props, propKey, defaultStateValues);\n}\n/**\n * Returns the default value for a state key in the following order:\n * 1. controlled prop, 2. default prop, 3. default value from Downshift.\n *\n * @param {Object} props Props passed to the hook.\n * @param {string} propKey Props key to generate the value for.\n * @returns {any} The initial value for that prop.\n */\n\n\nfunction getDefaultValue(props, propKey) {\n return getDefaultValue$1(props, propKey, defaultStateValues);\n}\n/**\n * Gets the initial state based on the provided props. It uses initial, default\n * and controlled props related to state in order to compute the initial value.\n *\n * @param {Object} props Props passed to the hook.\n * @returns {Object} The initial state.\n */\n\n\nfunction getInitialState(props) {\n var activeIndex = getInitialValue(props, \'activeIndex\');\n var selectedItems = getInitialValue(props, \'selectedItems\');\n return {\n activeIndex: activeIndex,\n selectedItems: selectedItems\n };\n}\n/**\n * Returns true if dropdown keydown operation is permitted. Should not be\n * allowed on keydown with modifier keys (ctrl, alt, shift, meta), on\n * input element with text content that is either highlighted or selection\n * cursor is not at the starting position.\n *\n * @param {KeyboardEvent} event The event from keydown.\n * @returns {boolean} Whether the operation is allowed.\n */\n\n\nfunction isKeyDownOperationPermitted(event) {\n if (event.shiftKey || event.metaKey || event.ctrlKey || event.altKey) {\n return false;\n }\n\n var element = event.target;\n\n if (element instanceof HTMLInputElement && // if element is a text input\n element.value !== \'\' && (element.selectionStart !== 0 || element.selectionEnd !== 0)) {\n return false;\n }\n\n return true;\n}\n/**\n * Returns a message to be added to aria-live region when item is removed.\n *\n * @param {Object} selectionParameters Parameters required to build the message.\n * @returns {string} The a11y message.\n */\n\n\nfunction getA11yRemovalMessage(selectionParameters) {\n var removedSelectedItem = selectionParameters.removedSelectedItem,\n itemToStringLocal = selectionParameters.itemToString;\n return itemToStringLocal(removedSelectedItem) + " has been removed.";\n}\n\nvar propTypes = {\n selectedItems: (prop_types_default()).array,\n initialSelectedItems: (prop_types_default()).array,\n defaultSelectedItems: (prop_types_default()).array,\n itemToString: (prop_types_default()).func,\n getA11yRemovalMessage: (prop_types_default()).func,\n stateReducer: (prop_types_default()).func,\n activeIndex: (prop_types_default()).number,\n initialActiveIndex: (prop_types_default()).number,\n defaultActiveIndex: (prop_types_default()).number,\n onActiveIndexChange: (prop_types_default()).func,\n onSelectedItemsChange: (prop_types_default()).func,\n keyNavigationNext: (prop_types_default()).string,\n keyNavigationPrevious: (prop_types_default()).string,\n environment: prop_types_default().shape({\n addEventListener: (prop_types_default()).func,\n removeEventListener: (prop_types_default()).func,\n document: prop_types_default().shape({\n getElementById: (prop_types_default()).func,\n activeElement: (prop_types_default()).any,\n body: (prop_types_default()).any\n })\n })\n};\nvar defaultProps = {\n itemToString: defaultProps$3.itemToString,\n stateReducer: defaultProps$3.stateReducer,\n environment: defaultProps$3.environment,\n getA11yRemovalMessage: getA11yRemovalMessage,\n keyNavigationNext: \'ArrowRight\',\n keyNavigationPrevious: \'ArrowLeft\'\n}; // eslint-disable-next-line import/no-mutable-exports\n\nvar validatePropTypes = noop;\n/* istanbul ignore next */\n\nif (false) {}\n\nvar SelectedItemClick = false ? 0 : 0;\nvar SelectedItemKeyDownDelete = false ? 0 : 1;\nvar SelectedItemKeyDownBackspace = false ? 0 : 2;\nvar SelectedItemKeyDownNavigationNext = false ? 0 : 3;\nvar SelectedItemKeyDownNavigationPrevious = false ? 0 : 4;\nvar DropdownKeyDownNavigationPrevious = false ? 0 : 5;\nvar DropdownKeyDownBackspace = false ? 0 : 6;\nvar DropdownClick = false ? 0 : 7;\nvar FunctionAddSelectedItem = false ? 0 : 8;\nvar FunctionRemoveSelectedItem = false ? 0 : 9;\nvar FunctionSetSelectedItems = false ? 0 : 10;\nvar FunctionSetActiveIndex = false ? 0 : 11;\nvar FunctionReset = false ? 0 : 12;\n\nvar stateChangeTypes = /*#__PURE__*/Object.freeze({\n __proto__: null,\n SelectedItemClick: SelectedItemClick,\n SelectedItemKeyDownDelete: SelectedItemKeyDownDelete,\n SelectedItemKeyDownBackspace: SelectedItemKeyDownBackspace,\n SelectedItemKeyDownNavigationNext: SelectedItemKeyDownNavigationNext,\n SelectedItemKeyDownNavigationPrevious: SelectedItemKeyDownNavigationPrevious,\n DropdownKeyDownNavigationPrevious: DropdownKeyDownNavigationPrevious,\n DropdownKeyDownBackspace: DropdownKeyDownBackspace,\n DropdownClick: DropdownClick,\n FunctionAddSelectedItem: FunctionAddSelectedItem,\n FunctionRemoveSelectedItem: FunctionRemoveSelectedItem,\n FunctionSetSelectedItems: FunctionSetSelectedItems,\n FunctionSetActiveIndex: FunctionSetActiveIndex,\n FunctionReset: FunctionReset\n});\n\n/* eslint-disable complexity */\n\nfunction downshiftMultipleSelectionReducer(state, action) {\n var type = action.type,\n index = action.index,\n props = action.props,\n selectedItem = action.selectedItem;\n var activeIndex = state.activeIndex,\n selectedItems = state.selectedItems;\n var changes;\n\n switch (type) {\n case SelectedItemClick:\n changes = {\n activeIndex: index\n };\n break;\n\n case SelectedItemKeyDownNavigationPrevious:\n changes = {\n activeIndex: activeIndex - 1 < 0 ? 0 : activeIndex - 1\n };\n break;\n\n case SelectedItemKeyDownNavigationNext:\n changes = {\n activeIndex: activeIndex + 1 >= selectedItems.length ? -1 : activeIndex + 1\n };\n break;\n\n case SelectedItemKeyDownBackspace:\n case SelectedItemKeyDownDelete:\n {\n var newActiveIndex = activeIndex;\n\n if (selectedItems.length === 1) {\n newActiveIndex = -1;\n } else if (activeIndex === selectedItems.length - 1) {\n newActiveIndex = selectedItems.length - 2;\n }\n\n changes = (0,esm_extends["default"])({\n selectedItems: [].concat(selectedItems.slice(0, activeIndex), selectedItems.slice(activeIndex + 1))\n }, {\n activeIndex: newActiveIndex\n });\n break;\n }\n\n case DropdownKeyDownNavigationPrevious:\n changes = {\n activeIndex: selectedItems.length - 1\n };\n break;\n\n case DropdownKeyDownBackspace:\n changes = {\n selectedItems: selectedItems.slice(0, selectedItems.length - 1)\n };\n break;\n\n case FunctionAddSelectedItem:\n changes = {\n selectedItems: [].concat(selectedItems, [selectedItem])\n };\n break;\n\n case DropdownClick:\n changes = {\n activeIndex: -1\n };\n break;\n\n case FunctionRemoveSelectedItem:\n {\n var _newActiveIndex = activeIndex;\n var selectedItemIndex = selectedItems.indexOf(selectedItem);\n\n if (selectedItems.length === 1) {\n _newActiveIndex = -1;\n } else if (selectedItemIndex === selectedItems.length - 1) {\n _newActiveIndex = selectedItems.length - 2;\n }\n\n changes = (0,esm_extends["default"])({\n selectedItems: [].concat(selectedItems.slice(0, selectedItemIndex), selectedItems.slice(selectedItemIndex + 1))\n }, {\n activeIndex: _newActiveIndex\n });\n break;\n }\n\n case FunctionSetSelectedItems:\n {\n var newSelectedItems = action.selectedItems;\n changes = {\n selectedItems: newSelectedItems\n };\n break;\n }\n\n case FunctionSetActiveIndex:\n {\n var _newActiveIndex2 = action.activeIndex;\n changes = {\n activeIndex: _newActiveIndex2\n };\n break;\n }\n\n case FunctionReset:\n changes = {\n activeIndex: getDefaultValue(props, \'activeIndex\'),\n selectedItems: getDefaultValue(props, \'selectedItems\')\n };\n break;\n\n default:\n throw new Error(\'Reducer called without proper action type.\');\n }\n\n return (0,esm_extends["default"])({}, state, changes);\n}\n\nvar _excluded = ["refKey", "ref", "onClick", "onKeyDown", "selectedItem", "index"],\n _excluded2 = ["refKey", "ref", "onKeyDown", "onClick", "preventKeyAction"];\nuseMultipleSelection.stateChangeTypes = stateChangeTypes;\n\nfunction useMultipleSelection(userProps) {\n if (userProps === void 0) {\n userProps = {};\n }\n\n validatePropTypes(userProps, useMultipleSelection); // Props defaults and destructuring.\n\n var props = (0,esm_extends["default"])({}, defaultProps, userProps);\n\n var getA11yRemovalMessage = props.getA11yRemovalMessage,\n itemToString = props.itemToString,\n environment = props.environment,\n keyNavigationNext = props.keyNavigationNext,\n keyNavigationPrevious = props.keyNavigationPrevious; // Reducer init.\n\n var _useControlledReducer = useControlledReducer$1(downshiftMultipleSelectionReducer, getInitialState(props), props),\n state = _useControlledReducer[0],\n dispatch = _useControlledReducer[1];\n\n var activeIndex = state.activeIndex,\n selectedItems = state.selectedItems; // Refs.\n\n var isInitialMountRef = (0,external_React_.useRef)(true);\n var dropdownRef = (0,external_React_.useRef)(null);\n var previousSelectedItemsRef = (0,external_React_.useRef)(selectedItems);\n var selectedItemRefs = (0,external_React_.useRef)();\n selectedItemRefs.current = [];\n var latest = useLatestRef({\n state: state,\n props: props\n }); // Effects.\n\n /* Sets a11y status message on changes in selectedItem. */\n\n (0,external_React_.useEffect)(function () {\n if (isInitialMountRef.current) {\n return;\n }\n\n if (selectedItems.length < previousSelectedItemsRef.current.length) {\n var removedSelectedItem = previousSelectedItemsRef.current.find(function (item) {\n return selectedItems.indexOf(item) < 0;\n });\n setStatus(getA11yRemovalMessage({\n itemToString: itemToString,\n resultCount: selectedItems.length,\n removedSelectedItem: removedSelectedItem,\n activeIndex: activeIndex,\n activeSelectedItem: selectedItems[activeIndex]\n }), environment.document);\n }\n\n previousSelectedItemsRef.current = selectedItems; // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [selectedItems.length]); // Sets focus on active item.\n\n (0,external_React_.useEffect)(function () {\n if (isInitialMountRef.current) {\n return;\n }\n\n if (activeIndex === -1 && dropdownRef.current) {\n dropdownRef.current.focus();\n } else if (selectedItemRefs.current[activeIndex]) {\n selectedItemRefs.current[activeIndex].focus();\n }\n }, [activeIndex]);\n useControlPropsValidator({\n isInitialMount: isInitialMountRef.current,\n props: props,\n state: state\n });\n var setGetterPropCallInfo = useGetterPropsCalledChecker(\'getDropdownProps\'); // Make initial ref false.\n\n (0,external_React_.useEffect)(function () {\n isInitialMountRef.current = false;\n }, []); // Event handler functions.\n\n var selectedItemKeyDownHandlers = (0,external_React_.useMemo)(function () {\n var _ref;\n\n return _ref = {}, _ref[keyNavigationPrevious] = function () {\n dispatch({\n type: SelectedItemKeyDownNavigationPrevious\n });\n }, _ref[keyNavigationNext] = function () {\n dispatch({\n type: SelectedItemKeyDownNavigationNext\n });\n }, _ref.Delete = function Delete() {\n dispatch({\n type: SelectedItemKeyDownDelete\n });\n }, _ref.Backspace = function Backspace() {\n dispatch({\n type: SelectedItemKeyDownBackspace\n });\n }, _ref;\n }, [dispatch, keyNavigationNext, keyNavigationPrevious]);\n var dropdownKeyDownHandlers = (0,external_React_.useMemo)(function () {\n var _ref2;\n\n return _ref2 = {}, _ref2[keyNavigationPrevious] = function (event) {\n if (isKeyDownOperationPermitted(event)) {\n dispatch({\n type: DropdownKeyDownNavigationPrevious\n });\n }\n }, _ref2.Backspace = function Backspace(event) {\n if (isKeyDownOperationPermitted(event)) {\n dispatch({\n type: DropdownKeyDownBackspace\n });\n }\n }, _ref2;\n }, [dispatch, keyNavigationPrevious]); // Getter props.\n\n var getSelectedItemProps = (0,external_React_.useCallback)(function (_temp) {\n var _extends2;\n\n var _ref3 = _temp === void 0 ? {} : _temp,\n _ref3$refKey = _ref3.refKey,\n refKey = _ref3$refKey === void 0 ? \'ref\' : _ref3$refKey,\n ref = _ref3.ref,\n onClick = _ref3.onClick,\n onKeyDown = _ref3.onKeyDown,\n selectedItem = _ref3.selectedItem,\n index = _ref3.index,\n rest = (0,objectWithoutPropertiesLoose["default"])(_ref3, _excluded);\n\n var latestState = latest.current.state;\n var itemIndex = getItemIndex(index, selectedItem, latestState.selectedItems);\n\n if (itemIndex < 0) {\n throw new Error(\'Pass either selectedItem or index in getSelectedItemProps!\');\n }\n\n var selectedItemHandleClick = function selectedItemHandleClick() {\n dispatch({\n type: SelectedItemClick,\n index: index\n });\n };\n\n var selectedItemHandleKeyDown = function selectedItemHandleKeyDown(event) {\n var key = normalizeArrowKey(event);\n\n if (key && selectedItemKeyDownHandlers[key]) {\n selectedItemKeyDownHandlers[key](event);\n }\n };\n\n return (0,esm_extends["default"])((_extends2 = {}, _extends2[refKey] = handleRefs(ref, function (selectedItemNode) {\n if (selectedItemNode) {\n selectedItemRefs.current.push(selectedItemNode);\n }\n }), _extends2.tabIndex = index === latestState.activeIndex ? 0 : -1, _extends2.onClick = callAllEventHandlers(onClick, selectedItemHandleClick), _extends2.onKeyDown = callAllEventHandlers(onKeyDown, selectedItemHandleKeyDown), _extends2), rest);\n }, [dispatch, latest, selectedItemKeyDownHandlers]);\n var getDropdownProps = (0,external_React_.useCallback)(function (_temp2, _temp3) {\n var _extends3;\n\n var _ref4 = _temp2 === void 0 ? {} : _temp2,\n _ref4$refKey = _ref4.refKey,\n refKey = _ref4$refKey === void 0 ? \'ref\' : _ref4$refKey,\n ref = _ref4.ref,\n onKeyDown = _ref4.onKeyDown,\n onClick = _ref4.onClick,\n _ref4$preventKeyActio = _ref4.preventKeyAction,\n preventKeyAction = _ref4$preventKeyActio === void 0 ? false : _ref4$preventKeyActio,\n rest = (0,objectWithoutPropertiesLoose["default"])(_ref4, _excluded2);\n\n var _ref5 = _temp3 === void 0 ? {} : _temp3,\n _ref5$suppressRefErro = _ref5.suppressRefError,\n suppressRefError = _ref5$suppressRefErro === void 0 ? false : _ref5$suppressRefErro;\n\n setGetterPropCallInfo(\'getDropdownProps\', suppressRefError, refKey, dropdownRef);\n\n var dropdownHandleKeyDown = function dropdownHandleKeyDown(event) {\n var key = normalizeArrowKey(event);\n\n if (key && dropdownKeyDownHandlers[key]) {\n dropdownKeyDownHandlers[key](event);\n }\n };\n\n var dropdownHandleClick = function dropdownHandleClick() {\n dispatch({\n type: DropdownClick\n });\n };\n\n return (0,esm_extends["default"])((_extends3 = {}, _extends3[refKey] = handleRefs(ref, function (dropdownNode) {\n if (dropdownNode) {\n dropdownRef.current = dropdownNode;\n }\n }), _extends3), !preventKeyAction && {\n onKeyDown: callAllEventHandlers(onKeyDown, dropdownHandleKeyDown),\n onClick: callAllEventHandlers(onClick, dropdownHandleClick)\n }, rest);\n }, [dispatch, dropdownKeyDownHandlers, setGetterPropCallInfo]); // returns\n\n var addSelectedItem = (0,external_React_.useCallback)(function (selectedItem) {\n dispatch({\n type: FunctionAddSelectedItem,\n selectedItem: selectedItem\n });\n }, [dispatch]);\n var removeSelectedItem = (0,external_React_.useCallback)(function (selectedItem) {\n dispatch({\n type: FunctionRemoveSelectedItem,\n selectedItem: selectedItem\n });\n }, [dispatch]);\n var setSelectedItems = (0,external_React_.useCallback)(function (newSelectedItems) {\n dispatch({\n type: FunctionSetSelectedItems,\n selectedItems: newSelectedItems\n });\n }, [dispatch]);\n var setActiveIndex = (0,external_React_.useCallback)(function (newActiveIndex) {\n dispatch({\n type: FunctionSetActiveIndex,\n activeIndex: newActiveIndex\n });\n }, [dispatch]);\n var reset = (0,external_React_.useCallback)(function () {\n dispatch({\n type: FunctionReset\n });\n }, [dispatch]);\n return {\n getSelectedItemProps: getSelectedItemProps,\n getDropdownProps: getDropdownProps,\n addSelectedItem: addSelectedItem,\n removeSelectedItem: removeSelectedItem,\n setSelectedItems: setSelectedItems,\n setActiveIndex: setActiveIndex,\n reset: reset,\n selectedItems: selectedItems,\n activeIndex: activeIndex\n };\n}\n\n\n\n// EXTERNAL MODULE: ./node_modules/classnames/index.js\nvar classnames = __webpack_require__(4184);\nvar classnames_default = /*#__PURE__*/__webpack_require__.n(classnames);\n// EXTERNAL MODULE: external "window.wp.i18n"\nvar external_window_wp_i18n_ = __webpack_require__(5652);\n// EXTERNAL MODULE: ./static/js/options/helpers/usePopoverMaker.js\nvar usePopoverMaker = __webpack_require__(9144);\n;// CONCATENATED MODULE: ./static/js/options/options/ct-select.js\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\n\nconst Select = _ref => {\n var _maybeSelectedItem;\n\n let {\n value,\n option,\n option: {\n choices,\n tabletChoices,\n mobileChoices,\n placeholder,\n searchPlaceholder,\n defaultToFirstItem = true,\n search = false,\n inputClassName = \'\',\n selectInputStart,\n appendToBody = false\n },\n onInputValueChange = () => {},\n renderItemFor = item => item.value,\n onChange,\n device = \'desktop\'\n } = _ref;\n const inputRef = (0,external_window_wp_element_.useRef)(null);\n const [tempState, setTempState] = (0,external_window_wp_element_.useState)(null);\n let deviceChoices = choices;\n\n if (device === \'tablet\' && tabletChoices) {\n deviceChoices = tabletChoices;\n }\n\n if (device === \'mobile\' && mobileChoices) {\n deviceChoices = mobileChoices;\n }\n\n const orderedChoices = (0,parse_choices/* maybeTransformUnorderedChoices */.N)(deviceChoices);\n let potentialValue = value || !defaultToFirstItem ? value : parseInt(value, 10) === 0 ? value : (orderedChoices[0] || {}).key;\n const {\n styles,\n popoverProps\n } = (0,usePopoverMaker/* default */.Z)({\n ref: inputRef,\n defaultHeight: 228,\n shouldCalculate: appendToBody\n });\n (0,external_window_wp_element_.useEffect)(() => {\n if (!appendToBody) {\n return;\n }\n\n setTimeout(() => {\n setTempState(Math.round());\n }, 50);\n }, []);\n let maybeSelectedItem = orderedChoices.find(_ref2 => {\n let {\n key\n } = _ref2;\n return key === potentialValue;\n });\n\n if (!maybeSelectedItem) {\n maybeSelectedItem = orderedChoices.find(_ref3 => {\n let {\n key\n } = _ref3;\n return parseInt(key) === parseInt(potentialValue);\n });\n }\n\n return (0,external_window_wp_element_.createElement)(Downshift$1, {\n key: ((_maybeSelectedItem = maybeSelectedItem) === null || _maybeSelectedItem === void 0 ? void 0 : _maybeSelectedItem.key) || \'downshift\',\n onInputValueChange: value => {\n onInputValueChange(value);\n },\n selectedItem: maybeSelectedItem || !defaultToFirstItem ? potentialValue : (orderedChoices[0] || {}).key,\n onChange: selection => {\n onChange(selection);\n },\n itemToString: item => {\n let maybeSelectedItem = orderedChoices.find(_ref4 => {\n let {\n key\n } = _ref4;\n return key === item;\n });\n\n if (!maybeSelectedItem) {\n maybeSelectedItem = orderedChoices.find(_ref5 => {\n let {\n key\n } = _ref5;\n return parseInt(key) === parseInt(item);\n });\n }\n\n return item && maybeSelectedItem ? maybeSelectedItem.value : \'\';\n }\n }, _ref6 => {\n let {\n getInputProps,\n getItemProps,\n getLabelProps,\n getMenuProps,\n isOpen,\n inputValue,\n highlightedIndex,\n selectedItem,\n openMenu,\n toggleMenu,\n setState\n } = _ref6;\n let dropdown = null;\n\n if (isOpen) {\n dropdown = (0,external_window_wp_element_.createElement)("div", _extends({}, getMenuProps(_objectSpread({\n className: classnames_default()(\'ct-select-dropdown\', {\n \'ct-fixed\': appendToBody\n })\n }, appendToBody ? popoverProps : {})), {\n style: appendToBody ? styles : {}\n }), orderedChoices.filter(item => !inputValue || orderedChoices.find(_ref7 => {\n let {\n key\n } = _ref7;\n return key.toString() === selectedItem.toString();\n }) && orderedChoices.find(_ref8 => {\n let {\n key\n } = _ref8;\n return key.toString() === selectedItem.toString();\n }).value === inputValue || item.value.toLowerCase().includes(inputValue.toLowerCase()) || item.key.toString().toLowerCase().includes(inputValue.toString().toLowerCase())).map((item, index) => (0,external_window_wp_element_.createElement)(external_window_wp_element_.Fragment, {\n key: index\n }, item.group && (index === 0 || orderedChoices[index - 1].group !== orderedChoices[index].group) && (0,external_window_wp_element_.createElement)("div", {\n className: "ct-select-dropdown-group",\n key: `${index}-group`\n }, item.group), (0,external_window_wp_element_.createElement)("div", getItemProps({\n key: item.key,\n index,\n item: item.key,\n className: classnames_default()(\'ct-select-dropdown-item\', {\n active: highlightedIndex === index,\n selected: selectedItem === item.key\n })\n }), renderItemFor(item)))));\n\n if (appendToBody) {\n dropdown = (0,external_window_wp_element_.createPortal)(dropdown, document.body);\n }\n }\n\n return (0,external_window_wp_element_.createElement)("div", {\n className: classnames_default()(\'ct-select-input 1\', inputClassName)\n }, selectInputStart && selectInputStart(), (0,external_window_wp_element_.createElement)("input", _extends({}, getInputProps({\n onKeyDown: e => {\n if (e.key === \'ArrowDown\' && search && !isOpen) {\n setState({\n inputValue: \'\'\n });\n }\n },\n onClick: () => {\n toggleMenu();\n setTimeout(() => {\n let popover;\n\n if (appendToBody) {\n popover = document.querySelector(\'body > .ct-select-dropdown.ct-fixed .ct-select-dropdown-item.selected\');\n } else {\n popover = inputRef.current.closest(\'.ct-select-input\').querySelector(\'.ct-select-dropdown .ct-select-dropdown-item.selected\');\n }\n\n if (popover) {\n let popoverTop = popover.parentNode.getBoundingClientRect().top;\n let itemTop = popover.getBoundingClientRect().top;\n popover.parentNode.scrollTop = itemTop - popoverTop;\n }\n });\n setTimeout(() => {\n setTempState(Math.round());\n }, 50);\n\n if (search) {\n setState({\n inputValue: \'\'\n });\n }\n },\n ref: inputRef\n }), {\n placeholder: search && isOpen ? searchPlaceholder || (0,external_window_wp_i18n_.__)(\'Type to search...\', \'blocksy\') : placeholder || (0,external_window_wp_i18n_.__)(\'Select value...\', \'blocksy\'),\n readOnly: search ? !isOpen : true\n })), dropdown);\n });\n};\n\n/* harmony default export */ const ct_select = (Select);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"1404.js","mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AACA;;;ACDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACvPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAcA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAQA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AA8CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AA6CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAiBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;ACxpIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./node_modules/compute-scroll-into-view/dist/index.module.js?06b6","webpack://blocksyOptions/./node_modules/tslib/tslib.es6.js?9ab4","webpack://blocksyOptions/./node_modules/downshift/dist/downshift.esm.js?33ce","webpack://blocksyOptions/./static/js/options/options/ct-select.js?8e7d"],"sourcesContent":["function t(t){return\"object\"==typeof t&&null!=t&&1===t.nodeType}function e(t,e){return(!e||\"hidden\"!==t)&&\"visible\"!==t&&\"clip\"!==t}function n(t,n){if(t.clientHeight<t.scrollHeight||t.clientWidth<t.scrollWidth){var r=getComputedStyle(t,null);return e(r.overflowY,n)||e(r.overflowX,n)||function(t){var e=function(t){if(!t.ownerDocument||!t.ownerDocument.defaultView)return null;try{return t.ownerDocument.defaultView.frameElement}catch(t){return null}}(t);return!!e&&(e.clientHeight<t.scrollHeight||e.clientWidth<t.scrollWidth)}(t)}return!1}function r(t,e,n,r,i,o,l,d){return o<t&&l>e||o>t&&l<e?0:o<=t&&d<=n||l>=e&&d>=n?o-t-r:l>e&&d<n||o<t&&d>n?l-e+i:0}export default function(e,i){var o=window,l=i.scrollMode,d=i.block,u=i.inline,h=i.boundary,a=i.skipOverflowHiddenElements,c=\"function\"==typeof h?h:function(t){return t!==h};if(!t(e))throw new TypeError(\"Invalid target\");for(var f=document.scrollingElement||document.documentElement,s=[],p=e;t(p)&&c(p);){if((p=p.parentElement)===f){s.push(p);break}null!=p&&p===document.body&&n(p)&&!n(document.documentElement)||null!=p&&n(p,a)&&s.push(p)}for(var m=o.visualViewport?o.visualViewport.width:innerWidth,g=o.visualViewport?o.visualViewport.height:innerHeight,w=window.scrollX||pageXOffset,v=window.scrollY||pageYOffset,W=e.getBoundingClientRect(),b=W.height,H=W.width,y=W.top,E=W.right,M=W.bottom,V=W.left,x=\"start\"===d||\"nearest\"===d?y:\"end\"===d?M:y+b/2,I=\"center\"===u?V+H/2:\"end\"===u?E:V,C=[],T=0;T<s.length;T++){var k=s[T],B=k.getBoundingClientRect(),D=B.height,O=B.width,R=B.top,X=B.right,Y=B.bottom,L=B.left;if(\"if-needed\"===l&&y>=0&&V>=0&&M<=g&&E<=m&&y>=R&&M<=Y&&V>=L&&E<=X)return C;var S=getComputedStyle(k),j=parseInt(S.borderLeftWidth,10),q=parseInt(S.borderTopWidth,10),z=parseInt(S.borderRightWidth,10),A=parseInt(S.borderBottomWidth,10),F=0,G=0,J=\"offsetWidth\"in k?k.offsetWidth-k.clientWidth-j-z:0,K=\"offsetHeight\"in k?k.offsetHeight-k.clientHeight-q-A:0;if(f===k)F=\"start\"===d?x:\"end\"===d?x-g:\"nearest\"===d?r(v,v+g,g,q,A,v+x,v+x+b,b):x-g/2,G=\"start\"===u?I:\"center\"===u?I-m/2:\"end\"===u?I-m:r(w,w+m,m,j,z,w+I,w+I+H,H),F=Math.max(0,F+v),G=Math.max(0,G+w);else{F=\"start\"===d?x-R-q:\"end\"===d?x-Y+A+K:\"nearest\"===d?r(R,Y,D,q,A+K,x,x+b,b):x-(R+D/2)+K/2,G=\"start\"===u?I-L-j:\"center\"===u?I-(L+O/2)+J/2:\"end\"===u?I-X+z+J:r(L,X,O,j,z+J,I,I+H,H);var N=k.scrollLeft,P=k.scrollTop;x+=P-(F=Math.max(0,Math.min(P+F,k.scrollHeight-D+K))),I+=N-(G=Math.max(0,Math.min(N+G,k.scrollWidth-O+J)))}C.push({el:k,top:F,left:G})}return C}\n//# sourceMappingURL=index.module.js.map\n","/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n    extendStatics = Object.setPrototypeOf ||\r\n        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n        function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n    return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n    if (typeof b !== \"function\" && b !== null)\r\n        throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n    extendStatics(d, b);\r\n    function __() { this.constructor = d; }\r\n    d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n    __assign = Object.assign || function __assign(t) {\r\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n            s = arguments[i];\r\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n        }\r\n        return t;\r\n    }\r\n    return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n    var t = {};\r\n    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n        t[p] = s[p];\r\n    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n            if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n                t[p[i]] = s[p[i]];\r\n        }\r\n    return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n    var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n    if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n    else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n    return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n    return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n    if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n    return new (P || (P = Promise))(function (resolve, reject) {\r\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n    });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n    var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n    return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n    function verb(n) { return function (v) { return step([n, v]); }; }\r\n    function step(op) {\r\n        if (f) throw new TypeError(\"Generator is already executing.\");\r\n        while (_) try {\r\n            if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n            if (y = 0, t) op = [op[0] & 2, t.value];\r\n            switch (op[0]) {\r\n                case 0: case 1: t = op; break;\r\n                case 4: _.label++; return { value: op[1], done: false };\r\n                case 5: _.label++; y = op[1]; op = [0]; continue;\r\n                case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n                default:\r\n                    if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n                    if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n                    if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n                    if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n                    if (t[2]) _.ops.pop();\r\n                    _.trys.pop(); continue;\r\n            }\r\n            op = body.call(thisArg, _);\r\n        } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n        if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n    }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n    if (k2 === undefined) k2 = k;\r\n    var desc = Object.getOwnPropertyDescriptor(m, k);\r\n    if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n        desc = { enumerable: true, get: function() { return m[k]; } };\r\n    }\r\n    Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n    if (k2 === undefined) k2 = k;\r\n    o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n    for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n    var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n    if (m) return m.call(o);\r\n    if (o && typeof o.length === \"number\") return {\r\n        next: function () {\r\n            if (o && i >= o.length) o = void 0;\r\n            return { value: o && o[i++], done: !o };\r\n        }\r\n    };\r\n    throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n    if (!m) return o;\r\n    var i = m.call(o), r, ar = [], e;\r\n    try {\r\n        while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n    }\r\n    catch (error) { e = { error: error }; }\r\n    finally {\r\n        try {\r\n            if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n        }\r\n        finally { if (e) throw e.error; }\r\n    }\r\n    return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n    for (var ar = [], i = 0; i < arguments.length; i++)\r\n        ar = ar.concat(__read(arguments[i]));\r\n    return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n    for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n    for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n        for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n            r[k] = a[j];\r\n    return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n    if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n        if (ar || !(i in from)) {\r\n            if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n            ar[i] = from[i];\r\n        }\r\n    }\r\n    return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n    return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n    return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n    function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n    function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n    function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n    function fulfill(value) { resume(\"next\", value); }\r\n    function reject(value) { resume(\"throw\", value); }\r\n    function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n    var i, p;\r\n    return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n    function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var m = o[Symbol.asyncIterator], i;\r\n    return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n    function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n    function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n    if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n    return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n    Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n    o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n    if (mod && mod.__esModule) return mod;\r\n    var result = {};\r\n    if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n    __setModuleDefault(result, mod);\r\n    return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n    return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n    if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n    if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n    return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n    if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n    if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n    if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n    return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n    if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n    return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n","import _objectWithoutPropertiesLoose from '@babel/runtime/helpers/esm/objectWithoutPropertiesLoose';\nimport _extends from '@babel/runtime/helpers/esm/extends';\nimport _assertThisInitialized from '@babel/runtime/helpers/esm/assertThisInitialized';\nimport _inheritsLoose from '@babel/runtime/helpers/esm/inheritsLoose';\nimport PropTypes from 'prop-types';\nimport { cloneElement, Component, useRef, useEffect, useCallback, useLayoutEffect, useReducer, useMemo } from 'react';\nimport { isForwardRef } from 'react-is';\nimport computeScrollIntoView from 'compute-scroll-into-view';\nimport { __assign } from 'tslib';\n\nvar idCounter = 0;\n/**\n * Accepts a parameter and returns it if it's a function\n * or a noop function if it's not. This allows us to\n * accept a callback, but not worry about it if it's not\n * passed.\n * @param {Function} cb the callback\n * @return {Function} a function\n */\n\nfunction cbToCb(cb) {\n  return typeof cb === 'function' ? cb : noop;\n}\n\nfunction noop() {}\n/**\n * Scroll node into view if necessary\n * @param {HTMLElement} node the element that should scroll into view\n * @param {HTMLElement} menuNode the menu element of the component\n */\n\n\nfunction scrollIntoView(node, menuNode) {\n  if (!node) {\n    return;\n  }\n\n  var actions = computeScrollIntoView(node, {\n    boundary: menuNode,\n    block: 'nearest',\n    scrollMode: 'if-needed'\n  });\n  actions.forEach(function (_ref) {\n    var el = _ref.el,\n        top = _ref.top,\n        left = _ref.left;\n    el.scrollTop = top;\n    el.scrollLeft = left;\n  });\n}\n/**\n * @param {HTMLElement} parent the parent node\n * @param {HTMLElement} child the child node\n * @param {Window} environment The window context where downshift renders.\n * @return {Boolean} whether the parent is the child or the child is in the parent\n */\n\n\nfunction isOrContainsNode(parent, child, environment) {\n  var result = parent === child || child instanceof environment.Node && parent.contains && parent.contains(child);\n  return result;\n}\n/**\n * Simple debounce implementation. Will call the given\n * function once after the time given has passed since\n * it was last called.\n * @param {Function} fn the function to call after the time\n * @param {Number} time the time to wait\n * @return {Function} the debounced function\n */\n\n\nfunction debounce(fn, time) {\n  var timeoutId;\n\n  function cancel() {\n    if (timeoutId) {\n      clearTimeout(timeoutId);\n    }\n  }\n\n  function wrapper() {\n    for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    cancel();\n    timeoutId = setTimeout(function () {\n      timeoutId = null;\n      fn.apply(void 0, args);\n    }, time);\n  }\n\n  wrapper.cancel = cancel;\n  return wrapper;\n}\n/**\n * This is intended to be used to compose event handlers.\n * They are executed in order until one of them sets\n * `event.preventDownshiftDefault = true`.\n * @param {...Function} fns the event handler functions\n * @return {Function} the event handler to add to an element\n */\n\n\nfunction callAllEventHandlers() {\n  for (var _len2 = arguments.length, fns = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n    fns[_key2] = arguments[_key2];\n  }\n\n  return function (event) {\n    for (var _len3 = arguments.length, args = new Array(_len3 > 1 ? _len3 - 1 : 0), _key3 = 1; _key3 < _len3; _key3++) {\n      args[_key3 - 1] = arguments[_key3];\n    }\n\n    return fns.some(function (fn) {\n      if (fn) {\n        fn.apply(void 0, [event].concat(args));\n      }\n\n      return event.preventDownshiftDefault || event.hasOwnProperty('nativeEvent') && event.nativeEvent.preventDownshiftDefault;\n    });\n  };\n}\n\nfunction handleRefs() {\n  for (var _len4 = arguments.length, refs = new Array(_len4), _key4 = 0; _key4 < _len4; _key4++) {\n    refs[_key4] = arguments[_key4];\n  }\n\n  return function (node) {\n    refs.forEach(function (ref) {\n      if (typeof ref === 'function') {\n        ref(node);\n      } else if (ref) {\n        ref.current = node;\n      }\n    });\n  };\n}\n/**\n * This generates a unique ID for an instance of Downshift\n * @return {String} the unique ID\n */\n\n\nfunction generateId() {\n  return String(idCounter++);\n}\n/**\n * Resets idCounter to 0. Used for SSR.\n */\n\n\nfunction resetIdCounter() {\n  idCounter = 0;\n}\n/**\n * Default implementation for status message. Only added when menu is open.\n * Will specify if there are results in the list, and if so, how many,\n * and what keys are relevant.\n *\n * @param {Object} param the downshift state and other relevant properties\n * @return {String} the a11y status message\n */\n\n\nfunction getA11yStatusMessage$1(_ref2) {\n  var isOpen = _ref2.isOpen,\n      resultCount = _ref2.resultCount,\n      previousResultCount = _ref2.previousResultCount;\n\n  if (!isOpen) {\n    return '';\n  }\n\n  if (!resultCount) {\n    return 'No results are available.';\n  }\n\n  if (resultCount !== previousResultCount) {\n    return resultCount + \" result\" + (resultCount === 1 ? ' is' : 's are') + \" available, use up and down arrow keys to navigate. Press Enter key to select.\";\n  }\n\n  return '';\n}\n/**\n * Takes an argument and if it's an array, returns the first item in the array\n * otherwise returns the argument\n * @param {*} arg the maybe-array\n * @param {*} defaultValue the value if arg is falsey not defined\n * @return {*} the arg or it's first item\n */\n\n\nfunction unwrapArray(arg, defaultValue) {\n  arg = Array.isArray(arg) ?\n  /* istanbul ignore next (preact) */\n  arg[0] : arg;\n\n  if (!arg && defaultValue) {\n    return defaultValue;\n  } else {\n    return arg;\n  }\n}\n/**\n * @param {Object} element (P)react element\n * @return {Boolean} whether it's a DOM element\n */\n\n\nfunction isDOMElement(element) {\n\n\n  return typeof element.type === 'string';\n}\n/**\n * @param {Object} element (P)react element\n * @return {Object} the props\n */\n\n\nfunction getElementProps(element) {\n\n  return element.props;\n}\n/**\n * Throws a helpful error message for required properties. Useful\n * to be used as a default in destructuring or object params.\n * @param {String} fnName the function name\n * @param {String} propName the prop name\n */\n\n\nfunction requiredProp(fnName, propName) {\n  // eslint-disable-next-line no-console\n  console.error(\"The property \\\"\" + propName + \"\\\" is required in \\\"\" + fnName + \"\\\"\");\n}\n\nvar stateKeys = ['highlightedIndex', 'inputValue', 'isOpen', 'selectedItem', 'type'];\n/**\n * @param {Object} state the state object\n * @return {Object} state that is relevant to downshift\n */\n\nfunction pickState(state) {\n  if (state === void 0) {\n    state = {};\n  }\n\n  var result = {};\n  stateKeys.forEach(function (k) {\n    if (state.hasOwnProperty(k)) {\n      result[k] = state[k];\n    }\n  });\n  return result;\n}\n/**\n * This will perform a shallow merge of the given state object\n * with the state coming from props\n * (for the controlled component scenario)\n * This is used in state updater functions so they're referencing\n * the right state regardless of where it comes from.\n *\n * @param {Object} state The state of the component/hook.\n * @param {Object} props The props that may contain controlled values.\n * @returns {Object} The merged controlled state.\n */\n\n\nfunction getState(state, props) {\n  return Object.keys(state).reduce(function (prevState, key) {\n    prevState[key] = isControlledProp(props, key) ? props[key] : state[key];\n    return prevState;\n  }, {});\n}\n/**\n * This determines whether a prop is a \"controlled prop\" meaning it is\n * state which is controlled by the outside of this component rather\n * than within this component.\n *\n * @param {Object} props The props that may contain controlled values.\n * @param {String} key the key to check\n * @return {Boolean} whether it is a controlled controlled prop\n */\n\n\nfunction isControlledProp(props, key) {\n  return props[key] !== undefined;\n}\n/**\n * Normalizes the 'key' property of a KeyboardEvent in IE/Edge\n * @param {Object} event a keyboardEvent object\n * @return {String} keyboard key\n */\n\n\nfunction normalizeArrowKey(event) {\n  var key = event.key,\n      keyCode = event.keyCode;\n  /* istanbul ignore next (ie) */\n\n  if (keyCode >= 37 && keyCode <= 40 && key.indexOf('Arrow') !== 0) {\n    return \"Arrow\" + key;\n  }\n\n  return key;\n}\n/**\n * Simple check if the value passed is object literal\n * @param {*} obj any things\n * @return {Boolean} whether it's object literal\n */\n\n\nfunction isPlainObject(obj) {\n  return Object.prototype.toString.call(obj) === '[object Object]';\n}\n/**\n * Returns the new index in the list, in a circular way. If next value is out of bonds from the total,\n * it will wrap to either 0 or itemCount - 1.\n *\n * @param {number} moveAmount Number of positions to move. Negative to move backwards, positive forwards.\n * @param {number} baseIndex The initial position to move from.\n * @param {number} itemCount The total number of items.\n * @param {Function} getItemNodeFromIndex Used to check if item is disabled.\n * @param {boolean} circular Specify if navigation is circular. Default is true.\n * @returns {number} The new index after the move.\n */\n\n\nfunction getNextWrappingIndex(moveAmount, baseIndex, itemCount, getItemNodeFromIndex, circular) {\n  if (circular === void 0) {\n    circular = true;\n  }\n\n  if (itemCount === 0) {\n    return -1;\n  }\n\n  var itemsLastIndex = itemCount - 1;\n\n  if (typeof baseIndex !== 'number' || baseIndex < 0 || baseIndex >= itemCount) {\n    baseIndex = moveAmount > 0 ? -1 : itemsLastIndex + 1;\n  }\n\n  var newIndex = baseIndex + moveAmount;\n\n  if (newIndex < 0) {\n    newIndex = circular ? itemsLastIndex : 0;\n  } else if (newIndex > itemsLastIndex) {\n    newIndex = circular ? 0 : itemsLastIndex;\n  }\n\n  var nonDisabledNewIndex = getNextNonDisabledIndex(moveAmount, newIndex, itemCount, getItemNodeFromIndex, circular);\n\n  if (nonDisabledNewIndex === -1) {\n    return baseIndex >= itemCount ? -1 : baseIndex;\n  }\n\n  return nonDisabledNewIndex;\n}\n/**\n * Returns the next index in the list of an item that is not disabled.\n *\n * @param {number} moveAmount Number of positions to move. Negative to move backwards, positive forwards.\n * @param {number} baseIndex The initial position to move from.\n * @param {number} itemCount The total number of items.\n * @param {Function} getItemNodeFromIndex Used to check if item is disabled.\n * @param {boolean} circular Specify if navigation is circular. Default is true.\n * @returns {number} The new index. Returns baseIndex if item is not disabled. Returns next non-disabled item otherwise. If no non-disabled found it will return -1.\n */\n\n\nfunction getNextNonDisabledIndex(moveAmount, baseIndex, itemCount, getItemNodeFromIndex, circular) {\n  var currentElementNode = getItemNodeFromIndex(baseIndex);\n\n  if (!currentElementNode || !currentElementNode.hasAttribute('disabled')) {\n    return baseIndex;\n  }\n\n  if (moveAmount > 0) {\n    for (var index = baseIndex + 1; index < itemCount; index++) {\n      if (!getItemNodeFromIndex(index).hasAttribute('disabled')) {\n        return index;\n      }\n    }\n  } else {\n    for (var _index = baseIndex - 1; _index >= 0; _index--) {\n      if (!getItemNodeFromIndex(_index).hasAttribute('disabled')) {\n        return _index;\n      }\n    }\n  }\n\n  if (circular) {\n    return moveAmount > 0 ? getNextNonDisabledIndex(1, 0, itemCount, getItemNodeFromIndex, false) : getNextNonDisabledIndex(-1, itemCount - 1, itemCount, getItemNodeFromIndex, false);\n  }\n\n  return -1;\n}\n/**\n * Checks if event target is within the downshift elements.\n *\n * @param {EventTarget} target Target to check.\n * @param {HTMLElement[]} downshiftElements The elements that form downshift (list, toggle button etc).\n * @param {Window} environment The window context where downshift renders.\n * @param {boolean} checkActiveElement Whether to also check activeElement.\n *\n * @returns {boolean} Whether or not the target is within downshift elements.\n */\n\n\nfunction targetWithinDownshift(target, downshiftElements, environment, checkActiveElement) {\n  if (checkActiveElement === void 0) {\n    checkActiveElement = true;\n  }\n\n  return downshiftElements.some(function (contextNode) {\n    return contextNode && (isOrContainsNode(contextNode, target, environment) || checkActiveElement && isOrContainsNode(contextNode, environment.document.activeElement, environment));\n  });\n} // eslint-disable-next-line import/no-mutable-exports\n\n\nvar validateControlledUnchanged = noop;\n/* istanbul ignore next */\n\nif (process.env.NODE_ENV !== 'production') {\n  validateControlledUnchanged = function validateControlledUnchanged(state, prevProps, nextProps) {\n    var warningDescription = \"This prop should not switch from controlled to uncontrolled (or vice versa). Decide between using a controlled or uncontrolled Downshift element for the lifetime of the component. More info: https://github.com/downshift-js/downshift#control-props\";\n    Object.keys(state).forEach(function (propKey) {\n      if (prevProps[propKey] !== undefined && nextProps[propKey] === undefined) {\n        // eslint-disable-next-line no-console\n        console.error(\"downshift: A component has changed the controlled prop \\\"\" + propKey + \"\\\" to be uncontrolled. \" + warningDescription);\n      } else if (prevProps[propKey] === undefined && nextProps[propKey] !== undefined) {\n        // eslint-disable-next-line no-console\n        console.error(\"downshift: A component has changed the uncontrolled prop \\\"\" + propKey + \"\\\" to be controlled. \" + warningDescription);\n      }\n    });\n  };\n}\n\nvar cleanupStatus = debounce(function (documentProp) {\n  getStatusDiv(documentProp).textContent = '';\n}, 500);\n/**\n * @param {String} status the status message\n * @param {Object} documentProp document passed by the user.\n */\n\nfunction setStatus(status, documentProp) {\n  var div = getStatusDiv(documentProp);\n\n  if (!status) {\n    return;\n  }\n\n  div.textContent = status;\n  cleanupStatus(documentProp);\n}\n/**\n * Get the status node or create it if it does not already exist.\n * @param {Object} documentProp document passed by the user.\n * @return {HTMLElement} the status node.\n */\n\n\nfunction getStatusDiv(documentProp) {\n  if (documentProp === void 0) {\n    documentProp = document;\n  }\n\n  var statusDiv = documentProp.getElementById('a11y-status-message');\n\n  if (statusDiv) {\n    return statusDiv;\n  }\n\n  statusDiv = documentProp.createElement('div');\n  statusDiv.setAttribute('id', 'a11y-status-message');\n  statusDiv.setAttribute('role', 'status');\n  statusDiv.setAttribute('aria-live', 'polite');\n  statusDiv.setAttribute('aria-relevant', 'additions text');\n  Object.assign(statusDiv.style, {\n    border: '0',\n    clip: 'rect(0 0 0 0)',\n    height: '1px',\n    margin: '-1px',\n    overflow: 'hidden',\n    padding: '0',\n    position: 'absolute',\n    width: '1px'\n  });\n  documentProp.body.appendChild(statusDiv);\n  return statusDiv;\n}\n\nvar unknown = process.env.NODE_ENV !== \"production\" ? '__autocomplete_unknown__' : 0;\nvar mouseUp = process.env.NODE_ENV !== \"production\" ? '__autocomplete_mouseup__' : 1;\nvar itemMouseEnter = process.env.NODE_ENV !== \"production\" ? '__autocomplete_item_mouseenter__' : 2;\nvar keyDownArrowUp = process.env.NODE_ENV !== \"production\" ? '__autocomplete_keydown_arrow_up__' : 3;\nvar keyDownArrowDown = process.env.NODE_ENV !== \"production\" ? '__autocomplete_keydown_arrow_down__' : 4;\nvar keyDownEscape = process.env.NODE_ENV !== \"production\" ? '__autocomplete_keydown_escape__' : 5;\nvar keyDownEnter = process.env.NODE_ENV !== \"production\" ? '__autocomplete_keydown_enter__' : 6;\nvar keyDownHome = process.env.NODE_ENV !== \"production\" ? '__autocomplete_keydown_home__' : 7;\nvar keyDownEnd = process.env.NODE_ENV !== \"production\" ? '__autocomplete_keydown_end__' : 8;\nvar clickItem = process.env.NODE_ENV !== \"production\" ? '__autocomplete_click_item__' : 9;\nvar blurInput = process.env.NODE_ENV !== \"production\" ? '__autocomplete_blur_input__' : 10;\nvar changeInput = process.env.NODE_ENV !== \"production\" ? '__autocomplete_change_input__' : 11;\nvar keyDownSpaceButton = process.env.NODE_ENV !== \"production\" ? '__autocomplete_keydown_space_button__' : 12;\nvar clickButton = process.env.NODE_ENV !== \"production\" ? '__autocomplete_click_button__' : 13;\nvar blurButton = process.env.NODE_ENV !== \"production\" ? '__autocomplete_blur_button__' : 14;\nvar controlledPropUpdatedSelectedItem = process.env.NODE_ENV !== \"production\" ? '__autocomplete_controlled_prop_updated_selected_item__' : 15;\nvar touchEnd = process.env.NODE_ENV !== \"production\" ? '__autocomplete_touchend__' : 16;\n\nvar stateChangeTypes$3 = /*#__PURE__*/Object.freeze({\n  __proto__: null,\n  unknown: unknown,\n  mouseUp: mouseUp,\n  itemMouseEnter: itemMouseEnter,\n  keyDownArrowUp: keyDownArrowUp,\n  keyDownArrowDown: keyDownArrowDown,\n  keyDownEscape: keyDownEscape,\n  keyDownEnter: keyDownEnter,\n  keyDownHome: keyDownHome,\n  keyDownEnd: keyDownEnd,\n  clickItem: clickItem,\n  blurInput: blurInput,\n  changeInput: changeInput,\n  keyDownSpaceButton: keyDownSpaceButton,\n  clickButton: clickButton,\n  blurButton: blurButton,\n  controlledPropUpdatedSelectedItem: controlledPropUpdatedSelectedItem,\n  touchEnd: touchEnd\n});\n\nvar _excluded$4 = [\"refKey\", \"ref\"],\n    _excluded2$3 = [\"onClick\", \"onPress\", \"onKeyDown\", \"onKeyUp\", \"onBlur\"],\n    _excluded3$2 = [\"onKeyDown\", \"onBlur\", \"onChange\", \"onInput\", \"onChangeText\"],\n    _excluded4$1 = [\"refKey\", \"ref\"],\n    _excluded5$1 = [\"onMouseMove\", \"onMouseDown\", \"onClick\", \"onPress\", \"index\", \"item\"];\n\nvar Downshift = /*#__PURE__*/function () {\n  var Downshift = /*#__PURE__*/function (_Component) {\n    _inheritsLoose(Downshift, _Component);\n\n    function Downshift(_props) {\n      var _this;\n\n      _this = _Component.call(this, _props) || this; // fancy destructuring + defaults + aliases\n      // this basically says each value of state should either be set to\n      // the initial value or the default value if the initial value is not provided\n\n      _this.id = _this.props.id || \"downshift-\" + generateId();\n      _this.menuId = _this.props.menuId || _this.id + \"-menu\";\n      _this.labelId = _this.props.labelId || _this.id + \"-label\";\n      _this.inputId = _this.props.inputId || _this.id + \"-input\";\n\n      _this.getItemId = _this.props.getItemId || function (index) {\n        return _this.id + \"-item-\" + index;\n      };\n\n      _this.input = null;\n      _this.items = [];\n      _this.itemCount = null;\n      _this.previousResultCount = 0;\n      _this.timeoutIds = [];\n\n      _this.internalSetTimeout = function (fn, time) {\n        var id = setTimeout(function () {\n          _this.timeoutIds = _this.timeoutIds.filter(function (i) {\n            return i !== id;\n          });\n          fn();\n        }, time);\n\n        _this.timeoutIds.push(id);\n      };\n\n      _this.setItemCount = function (count) {\n        _this.itemCount = count;\n      };\n\n      _this.unsetItemCount = function () {\n        _this.itemCount = null;\n      };\n\n      _this.setHighlightedIndex = function (highlightedIndex, otherStateToSet) {\n        if (highlightedIndex === void 0) {\n          highlightedIndex = _this.props.defaultHighlightedIndex;\n        }\n\n        if (otherStateToSet === void 0) {\n          otherStateToSet = {};\n        }\n\n        otherStateToSet = pickState(otherStateToSet);\n\n        _this.internalSetState(_extends({\n          highlightedIndex: highlightedIndex\n        }, otherStateToSet));\n      };\n\n      _this.clearSelection = function (cb) {\n        _this.internalSetState({\n          selectedItem: null,\n          inputValue: '',\n          highlightedIndex: _this.props.defaultHighlightedIndex,\n          isOpen: _this.props.defaultIsOpen\n        }, cb);\n      };\n\n      _this.selectItem = function (item, otherStateToSet, cb) {\n        otherStateToSet = pickState(otherStateToSet);\n\n        _this.internalSetState(_extends({\n          isOpen: _this.props.defaultIsOpen,\n          highlightedIndex: _this.props.defaultHighlightedIndex,\n          selectedItem: item,\n          inputValue: _this.props.itemToString(item)\n        }, otherStateToSet), cb);\n      };\n\n      _this.selectItemAtIndex = function (itemIndex, otherStateToSet, cb) {\n        var item = _this.items[itemIndex];\n\n        if (item == null) {\n          return;\n        }\n\n        _this.selectItem(item, otherStateToSet, cb);\n      };\n\n      _this.selectHighlightedItem = function (otherStateToSet, cb) {\n        return _this.selectItemAtIndex(_this.getState().highlightedIndex, otherStateToSet, cb);\n      };\n\n      _this.internalSetState = function (stateToSet, cb) {\n        var isItemSelected, onChangeArg;\n        var onStateChangeArg = {};\n        var isStateToSetFunction = typeof stateToSet === 'function'; // we want to call `onInputValueChange` before the `setState` call\n        // so someone controlling the `inputValue` state gets notified of\n        // the input change as soon as possible. This avoids issues with\n        // preserving the cursor position.\n        // See https://github.com/downshift-js/downshift/issues/217 for more info.\n\n        if (!isStateToSetFunction && stateToSet.hasOwnProperty('inputValue')) {\n          _this.props.onInputValueChange(stateToSet.inputValue, _extends({}, _this.getStateAndHelpers(), stateToSet));\n        }\n\n        return _this.setState(function (state) {\n          state = _this.getState(state);\n          var newStateToSet = isStateToSetFunction ? stateToSet(state) : stateToSet; // Your own function that could modify the state that will be set.\n\n          newStateToSet = _this.props.stateReducer(state, newStateToSet); // checks if an item is selected, regardless of if it's different from\n          // what was selected before\n          // used to determine if onSelect and onChange callbacks should be called\n\n          isItemSelected = newStateToSet.hasOwnProperty('selectedItem'); // this keeps track of the object we want to call with setState\n\n          var nextState = {}; // this is just used to tell whether the state changed\n\n          var nextFullState = {}; // we need to call on change if the outside world is controlling any of our state\n          // and we're trying to update that state. OR if the selection has changed and we're\n          // trying to update the selection\n\n          if (isItemSelected && newStateToSet.selectedItem !== state.selectedItem) {\n            onChangeArg = newStateToSet.selectedItem;\n          }\n\n          newStateToSet.type = newStateToSet.type || unknown;\n          Object.keys(newStateToSet).forEach(function (key) {\n            // onStateChangeArg should only have the state that is\n            // actually changing\n            if (state[key] !== newStateToSet[key]) {\n              onStateChangeArg[key] = newStateToSet[key];\n            } // the type is useful for the onStateChangeArg\n            // but we don't actually want to set it in internal state.\n            // this is an undocumented feature for now... Not all internalSetState\n            // calls support it and I'm not certain we want them to yet.\n            // But it enables users controlling the isOpen state to know when\n            // the isOpen state changes due to mouseup events which is quite handy.\n\n\n            if (key === 'type') {\n              return;\n            }\n\n            nextFullState[key] = newStateToSet[key]; // if it's coming from props, then we don't care to set it internally\n\n            if (!isControlledProp(_this.props, key)) {\n              nextState[key] = newStateToSet[key];\n            }\n          }); // if stateToSet is a function, then we weren't able to call onInputValueChange\n          // earlier, so we'll call it now that we know what the inputValue state will be.\n\n          if (isStateToSetFunction && newStateToSet.hasOwnProperty('inputValue')) {\n            _this.props.onInputValueChange(newStateToSet.inputValue, _extends({}, _this.getStateAndHelpers(), newStateToSet));\n          }\n\n          return nextState;\n        }, function () {\n          // call the provided callback if it's a function\n          cbToCb(cb)(); // only call the onStateChange and onChange callbacks if\n          // we have relevant information to pass them.\n\n          var hasMoreStateThanType = Object.keys(onStateChangeArg).length > 1;\n\n          if (hasMoreStateThanType) {\n            _this.props.onStateChange(onStateChangeArg, _this.getStateAndHelpers());\n          }\n\n          if (isItemSelected) {\n            _this.props.onSelect(stateToSet.selectedItem, _this.getStateAndHelpers());\n          }\n\n          if (onChangeArg !== undefined) {\n            _this.props.onChange(onChangeArg, _this.getStateAndHelpers());\n          } // this is currently undocumented and therefore subject to change\n          // We'll try to not break it, but just be warned.\n\n\n          _this.props.onUserAction(onStateChangeArg, _this.getStateAndHelpers());\n        });\n      };\n\n      _this.rootRef = function (node) {\n        return _this._rootNode = node;\n      };\n\n      _this.getRootProps = function (_temp, _temp2) {\n        var _extends2;\n\n        var _ref = _temp === void 0 ? {} : _temp,\n            _ref$refKey = _ref.refKey,\n            refKey = _ref$refKey === void 0 ? 'ref' : _ref$refKey,\n            ref = _ref.ref,\n            rest = _objectWithoutPropertiesLoose(_ref, _excluded$4);\n\n        var _ref2 = _temp2 === void 0 ? {} : _temp2,\n            _ref2$suppressRefErro = _ref2.suppressRefError,\n            suppressRefError = _ref2$suppressRefErro === void 0 ? false : _ref2$suppressRefErro;\n\n        // this is used in the render to know whether the user has called getRootProps.\n        // It uses that to know whether to apply the props automatically\n        _this.getRootProps.called = true;\n        _this.getRootProps.refKey = refKey;\n        _this.getRootProps.suppressRefError = suppressRefError;\n\n        var _this$getState = _this.getState(),\n            isOpen = _this$getState.isOpen;\n\n        return _extends((_extends2 = {}, _extends2[refKey] = handleRefs(ref, _this.rootRef), _extends2.role = 'combobox', _extends2['aria-expanded'] = isOpen, _extends2['aria-haspopup'] = 'listbox', _extends2['aria-owns'] = isOpen ? _this.menuId : null, _extends2['aria-labelledby'] = _this.labelId, _extends2), rest);\n      };\n\n      _this.keyDownHandlers = {\n        ArrowDown: function ArrowDown(event) {\n          var _this2 = this;\n\n          event.preventDefault();\n\n          if (this.getState().isOpen) {\n            var amount = event.shiftKey ? 5 : 1;\n            this.moveHighlightedIndex(amount, {\n              type: keyDownArrowDown\n            });\n          } else {\n            this.internalSetState({\n              isOpen: true,\n              type: keyDownArrowDown\n            }, function () {\n              var itemCount = _this2.getItemCount();\n\n              if (itemCount > 0) {\n                var _this2$getState = _this2.getState(),\n                    highlightedIndex = _this2$getState.highlightedIndex;\n\n                var nextHighlightedIndex = getNextWrappingIndex(1, highlightedIndex, itemCount, function (index) {\n                  return _this2.getItemNodeFromIndex(index);\n                });\n\n                _this2.setHighlightedIndex(nextHighlightedIndex, {\n                  type: keyDownArrowDown\n                });\n              }\n            });\n          }\n        },\n        ArrowUp: function ArrowUp(event) {\n          var _this3 = this;\n\n          event.preventDefault();\n\n          if (this.getState().isOpen) {\n            var amount = event.shiftKey ? -5 : -1;\n            this.moveHighlightedIndex(amount, {\n              type: keyDownArrowUp\n            });\n          } else {\n            this.internalSetState({\n              isOpen: true,\n              type: keyDownArrowUp\n            }, function () {\n              var itemCount = _this3.getItemCount();\n\n              if (itemCount > 0) {\n                var _this3$getState = _this3.getState(),\n                    highlightedIndex = _this3$getState.highlightedIndex;\n\n                var nextHighlightedIndex = getNextWrappingIndex(-1, highlightedIndex, itemCount, function (index) {\n                  return _this3.getItemNodeFromIndex(index);\n                });\n\n                _this3.setHighlightedIndex(nextHighlightedIndex, {\n                  type: keyDownArrowUp\n                });\n              }\n            });\n          }\n        },\n        Enter: function Enter(event) {\n          if (event.which === 229) {\n            return;\n          }\n\n          var _this$getState2 = this.getState(),\n              isOpen = _this$getState2.isOpen,\n              highlightedIndex = _this$getState2.highlightedIndex;\n\n          if (isOpen && highlightedIndex != null) {\n            event.preventDefault();\n            var item = this.items[highlightedIndex];\n            var itemNode = this.getItemNodeFromIndex(highlightedIndex);\n\n            if (item == null || itemNode && itemNode.hasAttribute('disabled')) {\n              return;\n            }\n\n            this.selectHighlightedItem({\n              type: keyDownEnter\n            });\n          }\n        },\n        Escape: function Escape(event) {\n          event.preventDefault();\n          this.reset(_extends({\n            type: keyDownEscape\n          }, !this.state.isOpen && {\n            selectedItem: null,\n            inputValue: ''\n          }));\n        }\n      };\n      _this.buttonKeyDownHandlers = _extends({}, _this.keyDownHandlers, {\n        ' ': function _(event) {\n          event.preventDefault();\n          this.toggleMenu({\n            type: keyDownSpaceButton\n          });\n        }\n      });\n      _this.inputKeyDownHandlers = _extends({}, _this.keyDownHandlers, {\n        Home: function Home(event) {\n          var _this4 = this;\n\n          var _this$getState3 = this.getState(),\n              isOpen = _this$getState3.isOpen;\n\n          if (!isOpen) {\n            return;\n          }\n\n          event.preventDefault();\n          var itemCount = this.getItemCount();\n\n          if (itemCount <= 0 || !isOpen) {\n            return;\n          } // get next non-disabled starting downwards from 0 if that's disabled.\n\n\n          var newHighlightedIndex = getNextNonDisabledIndex(1, 0, itemCount, function (index) {\n            return _this4.getItemNodeFromIndex(index);\n          }, false);\n          this.setHighlightedIndex(newHighlightedIndex, {\n            type: keyDownHome\n          });\n        },\n        End: function End(event) {\n          var _this5 = this;\n\n          var _this$getState4 = this.getState(),\n              isOpen = _this$getState4.isOpen;\n\n          if (!isOpen) {\n            return;\n          }\n\n          event.preventDefault();\n          var itemCount = this.getItemCount();\n\n          if (itemCount <= 0 || !isOpen) {\n            return;\n          } // get next non-disabled starting upwards from last index if that's disabled.\n\n\n          var newHighlightedIndex = getNextNonDisabledIndex(-1, itemCount - 1, itemCount, function (index) {\n            return _this5.getItemNodeFromIndex(index);\n          }, false);\n          this.setHighlightedIndex(newHighlightedIndex, {\n            type: keyDownEnd\n          });\n        }\n      });\n\n      _this.getToggleButtonProps = function (_temp3) {\n        var _ref3 = _temp3 === void 0 ? {} : _temp3,\n            onClick = _ref3.onClick;\n            _ref3.onPress;\n            var onKeyDown = _ref3.onKeyDown,\n            onKeyUp = _ref3.onKeyUp,\n            onBlur = _ref3.onBlur,\n            rest = _objectWithoutPropertiesLoose(_ref3, _excluded2$3);\n\n        var _this$getState5 = _this.getState(),\n            isOpen = _this$getState5.isOpen;\n\n        var enabledEventHandlers = {\n          onClick: callAllEventHandlers(onClick, _this.buttonHandleClick),\n          onKeyDown: callAllEventHandlers(onKeyDown, _this.buttonHandleKeyDown),\n          onKeyUp: callAllEventHandlers(onKeyUp, _this.buttonHandleKeyUp),\n          onBlur: callAllEventHandlers(onBlur, _this.buttonHandleBlur)\n        };\n        var eventHandlers = rest.disabled ? {} : enabledEventHandlers;\n        return _extends({\n          type: 'button',\n          role: 'button',\n          'aria-label': isOpen ? 'close menu' : 'open menu',\n          'aria-haspopup': true,\n          'data-toggle': true\n        }, eventHandlers, rest);\n      };\n\n      _this.buttonHandleKeyUp = function (event) {\n        // Prevent click event from emitting in Firefox\n        event.preventDefault();\n      };\n\n      _this.buttonHandleKeyDown = function (event) {\n        var key = normalizeArrowKey(event);\n\n        if (_this.buttonKeyDownHandlers[key]) {\n          _this.buttonKeyDownHandlers[key].call(_assertThisInitialized(_this), event);\n        }\n      };\n\n      _this.buttonHandleClick = function (event) {\n        event.preventDefault(); // handle odd case for Safari and Firefox which\n        // don't give the button the focus properly.\n\n        /* istanbul ignore if (can't reasonably test this) */\n\n        if (_this.props.environment.document.activeElement === _this.props.environment.document.body) {\n          event.target.focus();\n        } // to simplify testing components that use downshift, we'll not wrap this in a setTimeout\n        // if the NODE_ENV is test. With the proper build system, this should be dead code eliminated\n        // when building for production and should therefore have no impact on production code.\n\n\n        if (process.env.NODE_ENV === 'test') {\n          _this.toggleMenu({\n            type: clickButton\n          });\n        } else {\n          // Ensure that toggle of menu occurs after the potential blur event in iOS\n          _this.internalSetTimeout(function () {\n            return _this.toggleMenu({\n              type: clickButton\n            });\n          });\n        }\n      };\n\n      _this.buttonHandleBlur = function (event) {\n        var blurTarget = event.target; // Save blur target for comparison with activeElement later\n        // Need setTimeout, so that when the user presses Tab, the activeElement is the next focused element, not body element\n\n        _this.internalSetTimeout(function () {\n          if (!_this.isMouseDown && (_this.props.environment.document.activeElement == null || _this.props.environment.document.activeElement.id !== _this.inputId) && _this.props.environment.document.activeElement !== blurTarget // Do nothing if we refocus the same element again (to solve issue in Safari on iOS)\n          ) {\n            _this.reset({\n              type: blurButton\n            });\n          }\n        });\n      };\n\n      _this.getLabelProps = function (props) {\n        return _extends({\n          htmlFor: _this.inputId,\n          id: _this.labelId\n        }, props);\n      };\n\n      _this.getInputProps = function (_temp4) {\n        var _ref4 = _temp4 === void 0 ? {} : _temp4,\n            onKeyDown = _ref4.onKeyDown,\n            onBlur = _ref4.onBlur,\n            onChange = _ref4.onChange,\n            onInput = _ref4.onInput;\n            _ref4.onChangeText;\n            var rest = _objectWithoutPropertiesLoose(_ref4, _excluded3$2);\n\n        var onChangeKey;\n        var eventHandlers = {};\n        /* istanbul ignore next (preact) */\n\n        {\n          onChangeKey = 'onChange';\n        }\n\n        var _this$getState6 = _this.getState(),\n            inputValue = _this$getState6.inputValue,\n            isOpen = _this$getState6.isOpen,\n            highlightedIndex = _this$getState6.highlightedIndex;\n\n        if (!rest.disabled) {\n          var _eventHandlers;\n\n          eventHandlers = (_eventHandlers = {}, _eventHandlers[onChangeKey] = callAllEventHandlers(onChange, onInput, _this.inputHandleChange), _eventHandlers.onKeyDown = callAllEventHandlers(onKeyDown, _this.inputHandleKeyDown), _eventHandlers.onBlur = callAllEventHandlers(onBlur, _this.inputHandleBlur), _eventHandlers);\n        }\n\n        return _extends({\n          'aria-autocomplete': 'list',\n          'aria-activedescendant': isOpen && typeof highlightedIndex === 'number' && highlightedIndex >= 0 ? _this.getItemId(highlightedIndex) : null,\n          'aria-controls': isOpen ? _this.menuId : null,\n          'aria-labelledby': _this.labelId,\n          // https://developer.mozilla.org/en-US/docs/Web/Security/Securing_your_site/Turning_off_form_autocompletion\n          // revert back since autocomplete=\"nope\" is ignored on latest Chrome and Opera\n          autoComplete: 'off',\n          value: inputValue,\n          id: _this.inputId\n        }, eventHandlers, rest);\n      };\n\n      _this.inputHandleKeyDown = function (event) {\n        var key = normalizeArrowKey(event);\n\n        if (key && _this.inputKeyDownHandlers[key]) {\n          _this.inputKeyDownHandlers[key].call(_assertThisInitialized(_this), event);\n        }\n      };\n\n      _this.inputHandleChange = function (event) {\n        _this.internalSetState({\n          type: changeInput,\n          isOpen: true,\n          inputValue: event.target.value,\n          highlightedIndex: _this.props.defaultHighlightedIndex\n        });\n      };\n\n      _this.inputHandleBlur = function () {\n        // Need setTimeout, so that when the user presses Tab, the activeElement is the next focused element, not the body element\n        _this.internalSetTimeout(function () {\n          var downshiftButtonIsActive = _this.props.environment.document && !!_this.props.environment.document.activeElement && !!_this.props.environment.document.activeElement.dataset && _this.props.environment.document.activeElement.dataset.toggle && _this._rootNode && _this._rootNode.contains(_this.props.environment.document.activeElement);\n\n          if (!_this.isMouseDown && !downshiftButtonIsActive) {\n            _this.reset({\n              type: blurInput\n            });\n          }\n        });\n      };\n\n      _this.menuRef = function (node) {\n        _this._menuNode = node;\n      };\n\n      _this.getMenuProps = function (_temp5, _temp6) {\n        var _extends3;\n\n        var _ref5 = _temp5 === void 0 ? {} : _temp5,\n            _ref5$refKey = _ref5.refKey,\n            refKey = _ref5$refKey === void 0 ? 'ref' : _ref5$refKey,\n            ref = _ref5.ref,\n            props = _objectWithoutPropertiesLoose(_ref5, _excluded4$1);\n\n        var _ref6 = _temp6 === void 0 ? {} : _temp6,\n            _ref6$suppressRefErro = _ref6.suppressRefError,\n            suppressRefError = _ref6$suppressRefErro === void 0 ? false : _ref6$suppressRefErro;\n\n        _this.getMenuProps.called = true;\n        _this.getMenuProps.refKey = refKey;\n        _this.getMenuProps.suppressRefError = suppressRefError;\n        return _extends((_extends3 = {}, _extends3[refKey] = handleRefs(ref, _this.menuRef), _extends3.role = 'listbox', _extends3['aria-labelledby'] = props && props['aria-label'] ? null : _this.labelId, _extends3.id = _this.menuId, _extends3), props);\n      };\n\n      _this.getItemProps = function (_temp7) {\n        var _enabledEventHandlers;\n\n        var _ref7 = _temp7 === void 0 ? {} : _temp7,\n            onMouseMove = _ref7.onMouseMove,\n            onMouseDown = _ref7.onMouseDown,\n            onClick = _ref7.onClick;\n            _ref7.onPress;\n            var index = _ref7.index,\n            _ref7$item = _ref7.item,\n            item = _ref7$item === void 0 ? process.env.NODE_ENV === 'production' ?\n        /* istanbul ignore next */\n        undefined : requiredProp('getItemProps', 'item') : _ref7$item,\n            rest = _objectWithoutPropertiesLoose(_ref7, _excluded5$1);\n\n        if (index === undefined) {\n          _this.items.push(item);\n\n          index = _this.items.indexOf(item);\n        } else {\n          _this.items[index] = item;\n        }\n\n        var onSelectKey = 'onClick';\n        var customClickHandler = onClick;\n        var enabledEventHandlers = (_enabledEventHandlers = {\n          // onMouseMove is used over onMouseEnter here. onMouseMove\n          // is only triggered on actual mouse movement while onMouseEnter\n          // can fire on DOM changes, interrupting keyboard navigation\n          onMouseMove: callAllEventHandlers(onMouseMove, function () {\n            if (index === _this.getState().highlightedIndex) {\n              return;\n            }\n\n            _this.setHighlightedIndex(index, {\n              type: itemMouseEnter\n            }); // We never want to manually scroll when changing state based\n            // on `onMouseMove` because we will be moving the element out\n            // from under the user which is currently scrolling/moving the\n            // cursor\n\n\n            _this.avoidScrolling = true;\n\n            _this.internalSetTimeout(function () {\n              return _this.avoidScrolling = false;\n            }, 250);\n          }),\n          onMouseDown: callAllEventHandlers(onMouseDown, function (event) {\n            // This prevents the activeElement from being changed\n            // to the item so it can remain with the current activeElement\n            // which is a more common use case.\n            event.preventDefault();\n          })\n        }, _enabledEventHandlers[onSelectKey] = callAllEventHandlers(customClickHandler, function () {\n          _this.selectItemAtIndex(index, {\n            type: clickItem\n          });\n        }), _enabledEventHandlers); // Passing down the onMouseDown handler to prevent redirect\n        // of the activeElement if clicking on disabled items\n\n        var eventHandlers = rest.disabled ? {\n          onMouseDown: enabledEventHandlers.onMouseDown\n        } : enabledEventHandlers;\n        return _extends({\n          id: _this.getItemId(index),\n          role: 'option',\n          'aria-selected': _this.getState().highlightedIndex === index\n        }, eventHandlers, rest);\n      };\n\n      _this.clearItems = function () {\n        _this.items = [];\n      };\n\n      _this.reset = function (otherStateToSet, cb) {\n        if (otherStateToSet === void 0) {\n          otherStateToSet = {};\n        }\n\n        otherStateToSet = pickState(otherStateToSet);\n\n        _this.internalSetState(function (_ref8) {\n          var selectedItem = _ref8.selectedItem;\n          return _extends({\n            isOpen: _this.props.defaultIsOpen,\n            highlightedIndex: _this.props.defaultHighlightedIndex,\n            inputValue: _this.props.itemToString(selectedItem)\n          }, otherStateToSet);\n        }, cb);\n      };\n\n      _this.toggleMenu = function (otherStateToSet, cb) {\n        if (otherStateToSet === void 0) {\n          otherStateToSet = {};\n        }\n\n        otherStateToSet = pickState(otherStateToSet);\n\n        _this.internalSetState(function (_ref9) {\n          var isOpen = _ref9.isOpen;\n          return _extends({\n            isOpen: !isOpen\n          }, isOpen && {\n            highlightedIndex: _this.props.defaultHighlightedIndex\n          }, otherStateToSet);\n        }, function () {\n          var _this$getState7 = _this.getState(),\n              isOpen = _this$getState7.isOpen,\n              highlightedIndex = _this$getState7.highlightedIndex;\n\n          if (isOpen) {\n            if (_this.getItemCount() > 0 && typeof highlightedIndex === 'number') {\n              _this.setHighlightedIndex(highlightedIndex, otherStateToSet);\n            }\n          }\n\n          cbToCb(cb)();\n        });\n      };\n\n      _this.openMenu = function (cb) {\n        _this.internalSetState({\n          isOpen: true\n        }, cb);\n      };\n\n      _this.closeMenu = function (cb) {\n        _this.internalSetState({\n          isOpen: false\n        }, cb);\n      };\n\n      _this.updateStatus = debounce(function () {\n        var state = _this.getState();\n\n        var item = _this.items[state.highlightedIndex];\n\n        var resultCount = _this.getItemCount();\n\n        var status = _this.props.getA11yStatusMessage(_extends({\n          itemToString: _this.props.itemToString,\n          previousResultCount: _this.previousResultCount,\n          resultCount: resultCount,\n          highlightedItem: item\n        }, state));\n\n        _this.previousResultCount = resultCount;\n        setStatus(status, _this.props.environment.document);\n      }, 200);\n\n      var _this$props = _this.props,\n          defaultHighlightedIndex = _this$props.defaultHighlightedIndex,\n          _this$props$initialHi = _this$props.initialHighlightedIndex,\n          _highlightedIndex = _this$props$initialHi === void 0 ? defaultHighlightedIndex : _this$props$initialHi,\n          defaultIsOpen = _this$props.defaultIsOpen,\n          _this$props$initialIs = _this$props.initialIsOpen,\n          _isOpen = _this$props$initialIs === void 0 ? defaultIsOpen : _this$props$initialIs,\n          _this$props$initialIn = _this$props.initialInputValue,\n          _inputValue = _this$props$initialIn === void 0 ? '' : _this$props$initialIn,\n          _this$props$initialSe = _this$props.initialSelectedItem,\n          _selectedItem = _this$props$initialSe === void 0 ? null : _this$props$initialSe;\n\n      var _state = _this.getState({\n        highlightedIndex: _highlightedIndex,\n        isOpen: _isOpen,\n        inputValue: _inputValue,\n        selectedItem: _selectedItem\n      });\n\n      if (_state.selectedItem != null && _this.props.initialInputValue === undefined) {\n        _state.inputValue = _this.props.itemToString(_state.selectedItem);\n      }\n\n      _this.state = _state;\n      return _this;\n    }\n\n    var _proto = Downshift.prototype;\n\n    /**\n     * Clear all running timeouts\n     */\n    _proto.internalClearTimeouts = function internalClearTimeouts() {\n      this.timeoutIds.forEach(function (id) {\n        clearTimeout(id);\n      });\n      this.timeoutIds = [];\n    }\n    /**\n     * Gets the state based on internal state or props\n     * If a state value is passed via props, then that\n     * is the value given, otherwise it's retrieved from\n     * stateToMerge\n     *\n     * @param {Object} stateToMerge defaults to this.state\n     * @return {Object} the state\n     */\n    ;\n\n    _proto.getState = function getState$1(stateToMerge) {\n      if (stateToMerge === void 0) {\n        stateToMerge = this.state;\n      }\n\n      return getState(stateToMerge, this.props);\n    };\n\n    _proto.getItemCount = function getItemCount() {\n      // things read better this way. They're in priority order:\n      // 1. `this.itemCount`\n      // 2. `this.props.itemCount`\n      // 3. `this.items.length`\n      var itemCount = this.items.length;\n\n      if (this.itemCount != null) {\n        itemCount = this.itemCount;\n      } else if (this.props.itemCount !== undefined) {\n        itemCount = this.props.itemCount;\n      }\n\n      return itemCount;\n    };\n\n    _proto.getItemNodeFromIndex = function getItemNodeFromIndex(index) {\n      return this.props.environment.document.getElementById(this.getItemId(index));\n    };\n\n    _proto.scrollHighlightedItemIntoView = function scrollHighlightedItemIntoView() {\n      /* istanbul ignore else (react-native) */\n      {\n        var node = this.getItemNodeFromIndex(this.getState().highlightedIndex);\n        this.props.scrollIntoView(node, this._menuNode);\n      }\n    };\n\n    _proto.moveHighlightedIndex = function moveHighlightedIndex(amount, otherStateToSet) {\n      var _this6 = this;\n\n      var itemCount = this.getItemCount();\n\n      var _this$getState8 = this.getState(),\n          highlightedIndex = _this$getState8.highlightedIndex;\n\n      if (itemCount > 0) {\n        var nextHighlightedIndex = getNextWrappingIndex(amount, highlightedIndex, itemCount, function (index) {\n          return _this6.getItemNodeFromIndex(index);\n        });\n        this.setHighlightedIndex(nextHighlightedIndex, otherStateToSet);\n      }\n    };\n\n    _proto.getStateAndHelpers = function getStateAndHelpers() {\n      var _this$getState9 = this.getState(),\n          highlightedIndex = _this$getState9.highlightedIndex,\n          inputValue = _this$getState9.inputValue,\n          selectedItem = _this$getState9.selectedItem,\n          isOpen = _this$getState9.isOpen;\n\n      var itemToString = this.props.itemToString;\n      var id = this.id;\n      var getRootProps = this.getRootProps,\n          getToggleButtonProps = this.getToggleButtonProps,\n          getLabelProps = this.getLabelProps,\n          getMenuProps = this.getMenuProps,\n          getInputProps = this.getInputProps,\n          getItemProps = this.getItemProps,\n          openMenu = this.openMenu,\n          closeMenu = this.closeMenu,\n          toggleMenu = this.toggleMenu,\n          selectItem = this.selectItem,\n          selectItemAtIndex = this.selectItemAtIndex,\n          selectHighlightedItem = this.selectHighlightedItem,\n          setHighlightedIndex = this.setHighlightedIndex,\n          clearSelection = this.clearSelection,\n          clearItems = this.clearItems,\n          reset = this.reset,\n          setItemCount = this.setItemCount,\n          unsetItemCount = this.unsetItemCount,\n          setState = this.internalSetState;\n      return {\n        // prop getters\n        getRootProps: getRootProps,\n        getToggleButtonProps: getToggleButtonProps,\n        getLabelProps: getLabelProps,\n        getMenuProps: getMenuProps,\n        getInputProps: getInputProps,\n        getItemProps: getItemProps,\n        // actions\n        reset: reset,\n        openMenu: openMenu,\n        closeMenu: closeMenu,\n        toggleMenu: toggleMenu,\n        selectItem: selectItem,\n        selectItemAtIndex: selectItemAtIndex,\n        selectHighlightedItem: selectHighlightedItem,\n        setHighlightedIndex: setHighlightedIndex,\n        clearSelection: clearSelection,\n        clearItems: clearItems,\n        setItemCount: setItemCount,\n        unsetItemCount: unsetItemCount,\n        setState: setState,\n        // props\n        itemToString: itemToString,\n        // derived\n        id: id,\n        // state\n        highlightedIndex: highlightedIndex,\n        inputValue: inputValue,\n        isOpen: isOpen,\n        selectedItem: selectedItem\n      };\n    } //////////////////////////// ROOT\n    ;\n\n    _proto.componentDidMount = function componentDidMount() {\n      var _this7 = this;\n\n      /* istanbul ignore if (react-native) */\n      if (process.env.NODE_ENV !== 'production' && !false && this.getMenuProps.called && !this.getMenuProps.suppressRefError) {\n        validateGetMenuPropsCalledCorrectly(this._menuNode, this.getMenuProps);\n      }\n      /* istanbul ignore if (react-native) */\n\n\n      {\n        // this.isMouseDown helps us track whether the mouse is currently held down.\n        // This is useful when the user clicks on an item in the list, but holds the mouse\n        // down long enough for the list to disappear (because the blur event fires on the input)\n        // this.isMouseDown is used in the blur handler on the input to determine whether the blur event should\n        // trigger hiding the menu.\n        var onMouseDown = function onMouseDown() {\n          _this7.isMouseDown = true;\n        };\n\n        var onMouseUp = function onMouseUp(event) {\n          _this7.isMouseDown = false; // if the target element or the activeElement is within a downshift node\n          // then we don't want to reset downshift\n\n          var contextWithinDownshift = targetWithinDownshift(event.target, [_this7._rootNode, _this7._menuNode], _this7.props.environment);\n\n          if (!contextWithinDownshift && _this7.getState().isOpen) {\n            _this7.reset({\n              type: mouseUp\n            }, function () {\n              return _this7.props.onOuterClick(_this7.getStateAndHelpers());\n            });\n          }\n        }; // Touching an element in iOS gives focus and hover states, but touching out of\n        // the element will remove hover, and persist the focus state, resulting in the\n        // blur event not being triggered.\n        // this.isTouchMove helps us track whether the user is tapping or swiping on a touch screen.\n        // If the user taps outside of Downshift, the component should be reset,\n        // but not if the user is swiping\n\n\n        var onTouchStart = function onTouchStart() {\n          _this7.isTouchMove = false;\n        };\n\n        var onTouchMove = function onTouchMove() {\n          _this7.isTouchMove = true;\n        };\n\n        var onTouchEnd = function onTouchEnd(event) {\n          var contextWithinDownshift = targetWithinDownshift(event.target, [_this7._rootNode, _this7._menuNode], _this7.props.environment, false);\n\n          if (!_this7.isTouchMove && !contextWithinDownshift && _this7.getState().isOpen) {\n            _this7.reset({\n              type: touchEnd\n            }, function () {\n              return _this7.props.onOuterClick(_this7.getStateAndHelpers());\n            });\n          }\n        };\n\n        var environment = this.props.environment;\n        environment.addEventListener('mousedown', onMouseDown);\n        environment.addEventListener('mouseup', onMouseUp);\n        environment.addEventListener('touchstart', onTouchStart);\n        environment.addEventListener('touchmove', onTouchMove);\n        environment.addEventListener('touchend', onTouchEnd);\n\n        this.cleanup = function () {\n          _this7.internalClearTimeouts();\n\n          _this7.updateStatus.cancel();\n\n          environment.removeEventListener('mousedown', onMouseDown);\n          environment.removeEventListener('mouseup', onMouseUp);\n          environment.removeEventListener('touchstart', onTouchStart);\n          environment.removeEventListener('touchmove', onTouchMove);\n          environment.removeEventListener('touchend', onTouchEnd);\n        };\n      }\n    };\n\n    _proto.shouldScroll = function shouldScroll(prevState, prevProps) {\n      var _ref10 = this.props.highlightedIndex === undefined ? this.getState() : this.props,\n          currentHighlightedIndex = _ref10.highlightedIndex;\n\n      var _ref11 = prevProps.highlightedIndex === undefined ? prevState : prevProps,\n          prevHighlightedIndex = _ref11.highlightedIndex;\n\n      var scrollWhenOpen = currentHighlightedIndex && this.getState().isOpen && !prevState.isOpen;\n      var scrollWhenNavigating = currentHighlightedIndex !== prevHighlightedIndex;\n      return scrollWhenOpen || scrollWhenNavigating;\n    };\n\n    _proto.componentDidUpdate = function componentDidUpdate(prevProps, prevState) {\n      if (process.env.NODE_ENV !== 'production') {\n        validateControlledUnchanged(this.state, prevProps, this.props);\n        /* istanbul ignore if (react-native) */\n\n        if (this.getMenuProps.called && !this.getMenuProps.suppressRefError) {\n          validateGetMenuPropsCalledCorrectly(this._menuNode, this.getMenuProps);\n        }\n      }\n\n      if (isControlledProp(this.props, 'selectedItem') && this.props.selectedItemChanged(prevProps.selectedItem, this.props.selectedItem)) {\n        this.internalSetState({\n          type: controlledPropUpdatedSelectedItem,\n          inputValue: this.props.itemToString(this.props.selectedItem)\n        });\n      }\n\n      if (!this.avoidScrolling && this.shouldScroll(prevState, prevProps)) {\n        this.scrollHighlightedItemIntoView();\n      }\n      /* istanbul ignore else (react-native) */\n\n\n      {\n        this.updateStatus();\n      }\n    };\n\n    _proto.componentWillUnmount = function componentWillUnmount() {\n      this.cleanup(); // avoids memory leak\n    };\n\n    _proto.render = function render() {\n      var children = unwrapArray(this.props.children, noop); // because the items are rerendered every time we call the children\n      // we clear this out each render and it will be populated again as\n      // getItemProps is called.\n\n      this.clearItems(); // we reset this so we know whether the user calls getRootProps during\n      // this render. If they do then we don't need to do anything,\n      // if they don't then we need to clone the element they return and\n      // apply the props for them.\n\n      this.getRootProps.called = false;\n      this.getRootProps.refKey = undefined;\n      this.getRootProps.suppressRefError = undefined; // we do something similar for getMenuProps\n\n      this.getMenuProps.called = false;\n      this.getMenuProps.refKey = undefined;\n      this.getMenuProps.suppressRefError = undefined; // we do something similar for getLabelProps\n\n      this.getLabelProps.called = false; // and something similar for getInputProps\n\n      this.getInputProps.called = false;\n      var element = unwrapArray(children(this.getStateAndHelpers()));\n\n      if (!element) {\n        return null;\n      }\n\n      if (this.getRootProps.called || this.props.suppressRefError) {\n        if (process.env.NODE_ENV !== 'production' && !this.getRootProps.suppressRefError && !this.props.suppressRefError) {\n          validateGetRootPropsCalledCorrectly(element, this.getRootProps);\n        }\n\n        return element;\n      } else if (isDOMElement(element)) {\n        // they didn't apply the root props, but we can clone\n        // this and apply the props ourselves\n        return /*#__PURE__*/cloneElement(element, this.getRootProps(getElementProps(element)));\n      }\n      /* istanbul ignore else */\n\n\n      if (process.env.NODE_ENV !== 'production') {\n        // they didn't apply the root props, but they need to\n        // otherwise we can't query around the autocomplete\n        throw new Error('downshift: If you return a non-DOM element, you must apply the getRootProps function');\n      }\n      /* istanbul ignore next */\n\n\n      return undefined;\n    };\n\n    return Downshift;\n  }(Component);\n\n  Downshift.defaultProps = {\n    defaultHighlightedIndex: null,\n    defaultIsOpen: false,\n    getA11yStatusMessage: getA11yStatusMessage$1,\n    itemToString: function itemToString(i) {\n      if (i == null) {\n        return '';\n      }\n\n      if (process.env.NODE_ENV !== 'production' && isPlainObject(i) && !i.hasOwnProperty('toString')) {\n        // eslint-disable-next-line no-console\n        console.warn('downshift: An object was passed to the default implementation of `itemToString`. You should probably provide your own `itemToString` implementation. Please refer to the `itemToString` API documentation.', 'The object that was passed:', i);\n      }\n\n      return String(i);\n    },\n    onStateChange: noop,\n    onInputValueChange: noop,\n    onUserAction: noop,\n    onChange: noop,\n    onSelect: noop,\n    onOuterClick: noop,\n    selectedItemChanged: function selectedItemChanged(prevItem, item) {\n      return prevItem !== item;\n    },\n    environment:\n    /* istanbul ignore next (ssr) */\n    typeof window === 'undefined' ? {} : window,\n    stateReducer: function stateReducer(state, stateToSet) {\n      return stateToSet;\n    },\n    suppressRefError: false,\n    scrollIntoView: scrollIntoView\n  };\n  Downshift.stateChangeTypes = stateChangeTypes$3;\n  return Downshift;\n}();\n\nprocess.env.NODE_ENV !== \"production\" ? Downshift.propTypes = {\n  children: PropTypes.func,\n  defaultHighlightedIndex: PropTypes.number,\n  defaultIsOpen: PropTypes.bool,\n  initialHighlightedIndex: PropTypes.number,\n  initialSelectedItem: PropTypes.any,\n  initialInputValue: PropTypes.string,\n  initialIsOpen: PropTypes.bool,\n  getA11yStatusMessage: PropTypes.func,\n  itemToString: PropTypes.func,\n  onChange: PropTypes.func,\n  onSelect: PropTypes.func,\n  onStateChange: PropTypes.func,\n  onInputValueChange: PropTypes.func,\n  onUserAction: PropTypes.func,\n  onOuterClick: PropTypes.func,\n  selectedItemChanged: PropTypes.func,\n  stateReducer: PropTypes.func,\n  itemCount: PropTypes.number,\n  id: PropTypes.string,\n  environment: PropTypes.shape({\n    addEventListener: PropTypes.func,\n    removeEventListener: PropTypes.func,\n    document: PropTypes.shape({\n      getElementById: PropTypes.func,\n      activeElement: PropTypes.any,\n      body: PropTypes.any\n    })\n  }),\n  suppressRefError: PropTypes.bool,\n  scrollIntoView: PropTypes.func,\n  // things we keep in state for uncontrolled components\n  // but can accept as props for controlled components\n\n  /* eslint-disable react/no-unused-prop-types */\n  selectedItem: PropTypes.any,\n  isOpen: PropTypes.bool,\n  inputValue: PropTypes.string,\n  highlightedIndex: PropTypes.number,\n  labelId: PropTypes.string,\n  inputId: PropTypes.string,\n  menuId: PropTypes.string,\n  getItemId: PropTypes.func\n  /* eslint-enable react/no-unused-prop-types */\n\n} : void 0;\nvar Downshift$1 = Downshift;\n\nfunction validateGetMenuPropsCalledCorrectly(node, _ref12) {\n  var refKey = _ref12.refKey;\n\n  if (!node) {\n    // eslint-disable-next-line no-console\n    console.error(\"downshift: The ref prop \\\"\" + refKey + \"\\\" from getMenuProps was not applied correctly on your menu element.\");\n  }\n}\n\nfunction validateGetRootPropsCalledCorrectly(element, _ref13) {\n  var refKey = _ref13.refKey;\n  var refKeySpecified = refKey !== 'ref';\n  var isComposite = !isDOMElement(element);\n\n  if (isComposite && !refKeySpecified && !isForwardRef(element)) {\n    // eslint-disable-next-line no-console\n    console.error('downshift: You returned a non-DOM element. You must specify a refKey in getRootProps');\n  } else if (!isComposite && refKeySpecified) {\n    // eslint-disable-next-line no-console\n    console.error(\"downshift: You returned a DOM element. You should not specify a refKey in getRootProps. You specified \\\"\" + refKey + \"\\\"\");\n  }\n\n  if (!isForwardRef(element) && !getElementProps(element)[refKey]) {\n    // eslint-disable-next-line no-console\n    console.error(\"downshift: You must apply the ref prop \\\"\" + refKey + \"\\\" from getRootProps onto your root element.\");\n  }\n}\n\nvar _excluded$3 = [\"isInitialMount\", \"highlightedIndex\", \"items\", \"environment\"];\nvar dropdownDefaultStateValues = {\n  highlightedIndex: -1,\n  isOpen: false,\n  selectedItem: null,\n  inputValue: ''\n};\n\nfunction callOnChangeProps(action, state, newState) {\n  var props = action.props,\n      type = action.type;\n  var changes = {};\n  Object.keys(state).forEach(function (key) {\n    invokeOnChangeHandler(key, action, state, newState);\n\n    if (newState[key] !== state[key]) {\n      changes[key] = newState[key];\n    }\n  });\n\n  if (props.onStateChange && Object.keys(changes).length) {\n    props.onStateChange(_extends({\n      type: type\n    }, changes));\n  }\n}\n\nfunction invokeOnChangeHandler(key, action, state, newState) {\n  var props = action.props,\n      type = action.type;\n  var handler = \"on\" + capitalizeString(key) + \"Change\";\n\n  if (props[handler] && newState[key] !== undefined && newState[key] !== state[key]) {\n    props[handler](_extends({\n      type: type\n    }, newState));\n  }\n}\n/**\n * Default state reducer that returns the changes.\n *\n * @param {Object} s state.\n * @param {Object} a action with changes.\n * @returns {Object} changes.\n */\n\n\nfunction stateReducer(s, a) {\n  return a.changes;\n}\n/**\n * Returns a message to be added to aria-live region when item is selected.\n *\n * @param {Object} selectionParameters Parameters required to build the message.\n * @returns {string} The a11y message.\n */\n\n\nfunction getA11ySelectionMessage(selectionParameters) {\n  var selectedItem = selectionParameters.selectedItem,\n      itemToStringLocal = selectionParameters.itemToString;\n  return selectedItem ? itemToStringLocal(selectedItem) + \" has been selected.\" : '';\n}\n/**\n * Debounced call for updating the a11y message.\n */\n\n\nvar updateA11yStatus = debounce(function (getA11yMessage, document) {\n  setStatus(getA11yMessage(), document);\n}, 200); // istanbul ignore next\n\nvar useIsomorphicLayoutEffect = typeof window !== 'undefined' && typeof window.document !== 'undefined' && typeof window.document.createElement !== 'undefined' ? useLayoutEffect : useEffect;\n\nfunction useElementIds(_ref) {\n  var _ref$id = _ref.id,\n      id = _ref$id === void 0 ? \"downshift-\" + generateId() : _ref$id,\n      labelId = _ref.labelId,\n      menuId = _ref.menuId,\n      getItemId = _ref.getItemId,\n      toggleButtonId = _ref.toggleButtonId,\n      inputId = _ref.inputId;\n  var elementIdsRef = useRef({\n    labelId: labelId || id + \"-label\",\n    menuId: menuId || id + \"-menu\",\n    getItemId: getItemId || function (index) {\n      return id + \"-item-\" + index;\n    },\n    toggleButtonId: toggleButtonId || id + \"-toggle-button\",\n    inputId: inputId || id + \"-input\"\n  });\n  return elementIdsRef.current;\n}\n\nfunction getItemIndex(index, item, items) {\n  if (index !== undefined) {\n    return index;\n  }\n\n  if (items.length === 0) {\n    return -1;\n  }\n\n  return items.indexOf(item);\n}\n\nfunction itemToString(item) {\n  return item ? String(item) : '';\n}\n\nfunction isAcceptedCharacterKey(key) {\n  return /^\\S{1}$/.test(key);\n}\n\nfunction capitalizeString(string) {\n  return \"\" + string.slice(0, 1).toUpperCase() + string.slice(1);\n}\n\nfunction useLatestRef(val) {\n  var ref = useRef(val); // technically this is not \"concurrent mode safe\" because we're manipulating\n  // the value during render (so it's not idempotent). However, the places this\n  // hook is used is to support memoizing callbacks which will be called\n  // *during* render, so we need the latest values *during* render.\n  // If not for this, then we'd probably want to use useLayoutEffect instead.\n\n  ref.current = val;\n  return ref;\n}\n/**\n * Computes the controlled state using a the previous state, props,\n * two reducers, one from downshift and an optional one from the user.\n * Also calls the onChange handlers for state values that have changed.\n *\n * @param {Function} reducer Reducer function from downshift.\n * @param {Object} initialState Initial state of the hook.\n * @param {Object} props The hook props.\n * @returns {Array} An array with the state and an action dispatcher.\n */\n\n\nfunction useEnhancedReducer(reducer, initialState, props) {\n  var prevStateRef = useRef();\n  var actionRef = useRef();\n  var enhancedReducer = useCallback(function (state, action) {\n    actionRef.current = action;\n    state = getState(state, action.props);\n    var changes = reducer(state, action);\n    var newState = action.props.stateReducer(state, _extends({}, action, {\n      changes: changes\n    }));\n    return newState;\n  }, [reducer]);\n\n  var _useReducer = useReducer(enhancedReducer, initialState),\n      state = _useReducer[0],\n      dispatch = _useReducer[1];\n\n  var propsRef = useLatestRef(props);\n  var dispatchWithProps = useCallback(function (action) {\n    return dispatch(_extends({\n      props: propsRef.current\n    }, action));\n  }, [propsRef]);\n  var action = actionRef.current;\n  useEffect(function () {\n    if (action && prevStateRef.current && prevStateRef.current !== state) {\n      callOnChangeProps(action, getState(prevStateRef.current, action.props), state);\n    }\n\n    prevStateRef.current = state;\n  }, [state, props, action]);\n  return [state, dispatchWithProps];\n}\n/**\n * Wraps the useEnhancedReducer and applies the controlled prop values before\n * returning the new state.\n *\n * @param {Function} reducer Reducer function from downshift.\n * @param {Object} initialState Initial state of the hook.\n * @param {Object} props The hook props.\n * @returns {Array} An array with the state and an action dispatcher.\n */\n\n\nfunction useControlledReducer$1(reducer, initialState, props) {\n  var _useEnhancedReducer = useEnhancedReducer(reducer, initialState, props),\n      state = _useEnhancedReducer[0],\n      dispatch = _useEnhancedReducer[1];\n\n  return [getState(state, props), dispatch];\n}\n\nvar defaultProps$3 = {\n  itemToString: itemToString,\n  stateReducer: stateReducer,\n  getA11ySelectionMessage: getA11ySelectionMessage,\n  scrollIntoView: scrollIntoView,\n  circularNavigation: false,\n  environment:\n  /* istanbul ignore next (ssr) */\n  typeof window === 'undefined' ? {} : window\n};\n\nfunction getDefaultValue$1(props, propKey, defaultStateValues) {\n  if (defaultStateValues === void 0) {\n    defaultStateValues = dropdownDefaultStateValues;\n  }\n\n  var defaultPropKey = \"default\" + capitalizeString(propKey);\n\n  if (defaultPropKey in props) {\n    return props[defaultPropKey];\n  }\n\n  return defaultStateValues[propKey];\n}\n\nfunction getInitialValue$1(props, propKey, defaultStateValues) {\n  if (defaultStateValues === void 0) {\n    defaultStateValues = dropdownDefaultStateValues;\n  }\n\n  if (propKey in props) {\n    return props[propKey];\n  }\n\n  var initialPropKey = \"initial\" + capitalizeString(propKey);\n\n  if (initialPropKey in props) {\n    return props[initialPropKey];\n  }\n\n  return getDefaultValue$1(props, propKey, defaultStateValues);\n}\n\nfunction getInitialState$2(props) {\n  var selectedItem = getInitialValue$1(props, 'selectedItem');\n  var isOpen = getInitialValue$1(props, 'isOpen');\n  var highlightedIndex = getInitialValue$1(props, 'highlightedIndex');\n  var inputValue = getInitialValue$1(props, 'inputValue');\n  return {\n    highlightedIndex: highlightedIndex < 0 && selectedItem && isOpen ? props.items.indexOf(selectedItem) : highlightedIndex,\n    isOpen: isOpen,\n    selectedItem: selectedItem,\n    inputValue: inputValue\n  };\n}\n\nfunction getHighlightedIndexOnOpen(props, state, offset, getItemNodeFromIndex) {\n  var items = props.items,\n      initialHighlightedIndex = props.initialHighlightedIndex,\n      defaultHighlightedIndex = props.defaultHighlightedIndex;\n  var selectedItem = state.selectedItem,\n      highlightedIndex = state.highlightedIndex;\n\n  if (items.length === 0) {\n    return -1;\n  } // initialHighlightedIndex will give value to highlightedIndex on initial state only.\n\n\n  if (initialHighlightedIndex !== undefined && highlightedIndex === initialHighlightedIndex) {\n    return initialHighlightedIndex;\n  }\n\n  if (defaultHighlightedIndex !== undefined) {\n    return defaultHighlightedIndex;\n  }\n\n  if (selectedItem) {\n    if (offset === 0) {\n      return items.indexOf(selectedItem);\n    }\n\n    return getNextWrappingIndex(offset, items.indexOf(selectedItem), items.length, getItemNodeFromIndex, false);\n  }\n\n  if (offset === 0) {\n    return -1;\n  }\n\n  return offset < 0 ? items.length - 1 : 0;\n}\n/**\n * Reuse the movement tracking of mouse and touch events.\n *\n * @param {boolean} isOpen Whether the dropdown is open or not.\n * @param {Array<Object>} downshiftElementRefs Downshift element refs to track movement (toggleButton, menu etc.)\n * @param {Object} environment Environment where component/hook exists.\n * @param {Function} handleBlur Handler on blur from mouse or touch.\n * @returns {Object} Ref containing whether mouseDown or touchMove event is happening\n */\n\n\nfunction useMouseAndTouchTracker(isOpen, downshiftElementRefs, environment, handleBlur) {\n  var mouseAndTouchTrackersRef = useRef({\n    isMouseDown: false,\n    isTouchMove: false\n  });\n  useEffect(function () {\n    // The same strategy for checking if a click occurred inside or outside downsift\n    // as in downshift.js.\n    var onMouseDown = function onMouseDown() {\n      mouseAndTouchTrackersRef.current.isMouseDown = true;\n    };\n\n    var onMouseUp = function onMouseUp(event) {\n      mouseAndTouchTrackersRef.current.isMouseDown = false;\n\n      if (isOpen && !targetWithinDownshift(event.target, downshiftElementRefs.map(function (ref) {\n        return ref.current;\n      }), environment)) {\n        handleBlur();\n      }\n    };\n\n    var onTouchStart = function onTouchStart() {\n      mouseAndTouchTrackersRef.current.isTouchMove = false;\n    };\n\n    var onTouchMove = function onTouchMove() {\n      mouseAndTouchTrackersRef.current.isTouchMove = true;\n    };\n\n    var onTouchEnd = function onTouchEnd(event) {\n      if (isOpen && !mouseAndTouchTrackersRef.current.isTouchMove && !targetWithinDownshift(event.target, downshiftElementRefs.map(function (ref) {\n        return ref.current;\n      }), environment, false)) {\n        handleBlur();\n      }\n    };\n\n    environment.addEventListener('mousedown', onMouseDown);\n    environment.addEventListener('mouseup', onMouseUp);\n    environment.addEventListener('touchstart', onTouchStart);\n    environment.addEventListener('touchmove', onTouchMove);\n    environment.addEventListener('touchend', onTouchEnd);\n    return function cleanup() {\n      environment.removeEventListener('mousedown', onMouseDown);\n      environment.removeEventListener('mouseup', onMouseUp);\n      environment.removeEventListener('touchstart', onTouchStart);\n      environment.removeEventListener('touchmove', onTouchMove);\n      environment.removeEventListener('touchend', onTouchEnd);\n    }; // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [isOpen, environment]);\n  return mouseAndTouchTrackersRef;\n}\n/* istanbul ignore next */\n// eslint-disable-next-line import/no-mutable-exports\n\n\nvar useGetterPropsCalledChecker = function useGetterPropsCalledChecker() {\n  return noop;\n};\n/**\n * Custom hook that checks if getter props are called correctly.\n *\n * @param  {...any} propKeys Getter prop names to be handled.\n * @returns {Function} Setter function called inside getter props to set call information.\n */\n\n/* istanbul ignore next */\n\n\nif (process.env.NODE_ENV !== 'production') {\n  useGetterPropsCalledChecker = function useGetterPropsCalledChecker() {\n    var isInitialMountRef = useRef(true);\n\n    for (var _len = arguments.length, propKeys = new Array(_len), _key = 0; _key < _len; _key++) {\n      propKeys[_key] = arguments[_key];\n    }\n\n    var getterPropsCalledRef = useRef(propKeys.reduce(function (acc, propKey) {\n      acc[propKey] = {};\n      return acc;\n    }, {}));\n    useEffect(function () {\n      Object.keys(getterPropsCalledRef.current).forEach(function (propKey) {\n        var propCallInfo = getterPropsCalledRef.current[propKey];\n\n        if (isInitialMountRef.current) {\n          if (!Object.keys(propCallInfo).length) {\n            // eslint-disable-next-line no-console\n            console.error(\"downshift: You forgot to call the \" + propKey + \" getter function on your component / element.\");\n            return;\n          }\n        }\n\n        var suppressRefError = propCallInfo.suppressRefError,\n            refKey = propCallInfo.refKey,\n            elementRef = propCallInfo.elementRef;\n\n        if ((!elementRef || !elementRef.current) && !suppressRefError) {\n          // eslint-disable-next-line no-console\n          console.error(\"downshift: The ref prop \\\"\" + refKey + \"\\\" from \" + propKey + \" was not applied correctly on your element.\");\n        }\n      });\n      isInitialMountRef.current = false;\n    });\n    var setGetterPropCallInfo = useCallback(function (propKey, suppressRefError, refKey, elementRef) {\n      getterPropsCalledRef.current[propKey] = {\n        suppressRefError: suppressRefError,\n        refKey: refKey,\n        elementRef: elementRef\n      };\n    }, []);\n    return setGetterPropCallInfo;\n  };\n}\n\nfunction useA11yMessageSetter(getA11yMessage, dependencyArray, _ref2) {\n  var isInitialMount = _ref2.isInitialMount,\n      highlightedIndex = _ref2.highlightedIndex,\n      items = _ref2.items,\n      environment = _ref2.environment,\n      rest = _objectWithoutPropertiesLoose(_ref2, _excluded$3);\n\n  // Sets a11y status message on changes in state.\n  useEffect(function () {\n    if (isInitialMount || false) {\n      return;\n    }\n\n    updateA11yStatus(function () {\n      return getA11yMessage(_extends({\n        highlightedIndex: highlightedIndex,\n        highlightedItem: items[highlightedIndex],\n        resultCount: items.length\n      }, rest));\n    }, environment.document); // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, dependencyArray);\n}\n\nfunction useScrollIntoView(_ref3) {\n  var highlightedIndex = _ref3.highlightedIndex,\n      isOpen = _ref3.isOpen,\n      itemRefs = _ref3.itemRefs,\n      getItemNodeFromIndex = _ref3.getItemNodeFromIndex,\n      menuElement = _ref3.menuElement,\n      scrollIntoViewProp = _ref3.scrollIntoView;\n  // used not to scroll on highlight by mouse.\n  var shouldScrollRef = useRef(true); // Scroll on highlighted item if change comes from keyboard.\n\n  useIsomorphicLayoutEffect(function () {\n    if (highlightedIndex < 0 || !isOpen || !Object.keys(itemRefs.current).length) {\n      return;\n    }\n\n    if (shouldScrollRef.current === false) {\n      shouldScrollRef.current = true;\n    } else {\n      scrollIntoViewProp(getItemNodeFromIndex(highlightedIndex), menuElement);\n    } // eslint-disable-next-line react-hooks/exhaustive-deps\n\n  }, [highlightedIndex]);\n  return shouldScrollRef;\n} // eslint-disable-next-line import/no-mutable-exports\n\n\nvar useControlPropsValidator = noop;\n/* istanbul ignore next */\n\nif (process.env.NODE_ENV !== 'production') {\n  useControlPropsValidator = function useControlPropsValidator(_ref4) {\n    var isInitialMount = _ref4.isInitialMount,\n        props = _ref4.props,\n        state = _ref4.state;\n    // used for checking when props are moving from controlled to uncontrolled.\n    var prevPropsRef = useRef(props);\n    useEffect(function () {\n      if (isInitialMount) {\n        return;\n      }\n\n      validateControlledUnchanged(state, prevPropsRef.current, props);\n      prevPropsRef.current = props;\n    }, [state, props, isInitialMount]);\n  };\n}\n\n/* eslint-disable complexity */\n\nfunction downshiftCommonReducer(state, action, stateChangeTypes) {\n  var type = action.type,\n      props = action.props;\n  var changes;\n\n  switch (type) {\n    case stateChangeTypes.ItemMouseMove:\n      changes = {\n        highlightedIndex: action.index\n      };\n      break;\n\n    case stateChangeTypes.MenuMouseLeave:\n      changes = {\n        highlightedIndex: -1\n      };\n      break;\n\n    case stateChangeTypes.ToggleButtonClick:\n    case stateChangeTypes.FunctionToggleMenu:\n      changes = {\n        isOpen: !state.isOpen,\n        highlightedIndex: state.isOpen ? -1 : getHighlightedIndexOnOpen(props, state, 0)\n      };\n      break;\n\n    case stateChangeTypes.FunctionOpenMenu:\n      changes = {\n        isOpen: true,\n        highlightedIndex: getHighlightedIndexOnOpen(props, state, 0)\n      };\n      break;\n\n    case stateChangeTypes.FunctionCloseMenu:\n      changes = {\n        isOpen: false\n      };\n      break;\n\n    case stateChangeTypes.FunctionSetHighlightedIndex:\n      changes = {\n        highlightedIndex: action.highlightedIndex\n      };\n      break;\n\n    case stateChangeTypes.FunctionSetInputValue:\n      changes = {\n        inputValue: action.inputValue\n      };\n      break;\n\n    case stateChangeTypes.FunctionReset:\n      changes = {\n        highlightedIndex: getDefaultValue$1(props, 'highlightedIndex'),\n        isOpen: getDefaultValue$1(props, 'isOpen'),\n        selectedItem: getDefaultValue$1(props, 'selectedItem'),\n        inputValue: getDefaultValue$1(props, 'inputValue')\n      };\n      break;\n\n    default:\n      throw new Error('Reducer called without proper action type.');\n  }\n\n  return _extends({}, state, changes);\n}\n/* eslint-enable complexity */\n\nfunction getItemIndexByCharacterKey(_a) {\n    var keysSoFar = _a.keysSoFar, highlightedIndex = _a.highlightedIndex, items = _a.items, itemToString = _a.itemToString, getItemNodeFromIndex = _a.getItemNodeFromIndex;\n    var lowerCasedKeysSoFar = keysSoFar.toLowerCase();\n    for (var index = 0; index < items.length; index++) {\n        var offsetIndex = (index + highlightedIndex + 1) % items.length;\n        var item = items[offsetIndex];\n        if (item !== undefined &&\n            itemToString(item)\n                .toLowerCase()\n                .startsWith(lowerCasedKeysSoFar)) {\n            var element = getItemNodeFromIndex(offsetIndex);\n            if (!(element === null || element === void 0 ? void 0 : element.hasAttribute('disabled'))) {\n                return offsetIndex;\n            }\n        }\n    }\n    return highlightedIndex;\n}\nvar propTypes$2 = {\n    items: PropTypes.array.isRequired,\n    itemToString: PropTypes.func,\n    getA11yStatusMessage: PropTypes.func,\n    getA11ySelectionMessage: PropTypes.func,\n    circularNavigation: PropTypes.bool,\n    highlightedIndex: PropTypes.number,\n    defaultHighlightedIndex: PropTypes.number,\n    initialHighlightedIndex: PropTypes.number,\n    isOpen: PropTypes.bool,\n    defaultIsOpen: PropTypes.bool,\n    initialIsOpen: PropTypes.bool,\n    selectedItem: PropTypes.any,\n    initialSelectedItem: PropTypes.any,\n    defaultSelectedItem: PropTypes.any,\n    id: PropTypes.string,\n    labelId: PropTypes.string,\n    menuId: PropTypes.string,\n    getItemId: PropTypes.func,\n    toggleButtonId: PropTypes.string,\n    stateReducer: PropTypes.func,\n    onSelectedItemChange: PropTypes.func,\n    onHighlightedIndexChange: PropTypes.func,\n    onStateChange: PropTypes.func,\n    onIsOpenChange: PropTypes.func,\n    environment: PropTypes.shape({\n        addEventListener: PropTypes.func,\n        removeEventListener: PropTypes.func,\n        document: PropTypes.shape({\n            getElementById: PropTypes.func,\n            activeElement: PropTypes.any,\n            body: PropTypes.any\n        })\n    })\n};\n/**\n * Default implementation for status message. Only added when menu is open.\n * Will specift if there are results in the list, and if so, how many,\n * and what keys are relevant.\n *\n * @param {Object} param the downshift state and other relevant properties\n * @return {String} the a11y status message\n */\nfunction getA11yStatusMessage(_a) {\n    var isOpen = _a.isOpen, resultCount = _a.resultCount, previousResultCount = _a.previousResultCount;\n    if (!isOpen) {\n        return '';\n    }\n    if (!resultCount) {\n        return 'No results are available.';\n    }\n    if (resultCount !== previousResultCount) {\n        return resultCount + \" result\" + (resultCount === 1 ? ' is' : 's are') + \" available, use up and down arrow keys to navigate. Press Enter or Space Bar keys to select.\";\n    }\n    return '';\n}\nvar defaultProps$2 = __assign(__assign({}, defaultProps$3), { getA11yStatusMessage: getA11yStatusMessage });\n// eslint-disable-next-line import/no-mutable-exports\nvar validatePropTypes$2 = noop;\n/* istanbul ignore next */\nif (process.env.NODE_ENV !== 'production') {\n    validatePropTypes$2 = function (options, caller) {\n        PropTypes.checkPropTypes(propTypes$2, options, 'prop', caller.name);\n    };\n}\n\nvar MenuKeyDownArrowDown = process.env.NODE_ENV !== \"production\" ? '__menu_keydown_arrow_down__' : 0;\nvar MenuKeyDownArrowUp = process.env.NODE_ENV !== \"production\" ? '__menu_keydown_arrow_up__' : 1;\nvar MenuKeyDownEscape = process.env.NODE_ENV !== \"production\" ? '__menu_keydown_escape__' : 2;\nvar MenuKeyDownHome = process.env.NODE_ENV !== \"production\" ? '__menu_keydown_home__' : 3;\nvar MenuKeyDownEnd = process.env.NODE_ENV !== \"production\" ? '__menu_keydown_end__' : 4;\nvar MenuKeyDownEnter = process.env.NODE_ENV !== \"production\" ? '__menu_keydown_enter__' : 5;\nvar MenuKeyDownSpaceButton = process.env.NODE_ENV !== \"production\" ? '__menu_keydown_space_button__' : 6;\nvar MenuKeyDownCharacter = process.env.NODE_ENV !== \"production\" ? '__menu_keydown_character__' : 7;\nvar MenuBlur = process.env.NODE_ENV !== \"production\" ? '__menu_blur__' : 8;\nvar MenuMouseLeave$1 = process.env.NODE_ENV !== \"production\" ? '__menu_mouse_leave__' : 9;\nvar ItemMouseMove$1 = process.env.NODE_ENV !== \"production\" ? '__item_mouse_move__' : 10;\nvar ItemClick$1 = process.env.NODE_ENV !== \"production\" ? '__item_click__' : 11;\nvar ToggleButtonClick$1 = process.env.NODE_ENV !== \"production\" ? '__togglebutton_click__' : 12;\nvar ToggleButtonKeyDownArrowDown = process.env.NODE_ENV !== \"production\" ? '__togglebutton_keydown_arrow_down__' : 13;\nvar ToggleButtonKeyDownArrowUp = process.env.NODE_ENV !== \"production\" ? '__togglebutton_keydown_arrow_up__' : 14;\nvar ToggleButtonKeyDownCharacter = process.env.NODE_ENV !== \"production\" ? '__togglebutton_keydown_character__' : 15;\nvar FunctionToggleMenu$1 = process.env.NODE_ENV !== \"production\" ? '__function_toggle_menu__' : 16;\nvar FunctionOpenMenu$1 = process.env.NODE_ENV !== \"production\" ? '__function_open_menu__' : 17;\nvar FunctionCloseMenu$1 = process.env.NODE_ENV !== \"production\" ? '__function_close_menu__' : 18;\nvar FunctionSetHighlightedIndex$1 = process.env.NODE_ENV !== \"production\" ? '__function_set_highlighted_index__' : 19;\nvar FunctionSelectItem$1 = process.env.NODE_ENV !== \"production\" ? '__function_select_item__' : 20;\nvar FunctionSetInputValue$1 = process.env.NODE_ENV !== \"production\" ? '__function_set_input_value__' : 21;\nvar FunctionReset$2 = process.env.NODE_ENV !== \"production\" ? '__function_reset__' : 22;\n\nvar stateChangeTypes$2 = /*#__PURE__*/Object.freeze({\n  __proto__: null,\n  MenuKeyDownArrowDown: MenuKeyDownArrowDown,\n  MenuKeyDownArrowUp: MenuKeyDownArrowUp,\n  MenuKeyDownEscape: MenuKeyDownEscape,\n  MenuKeyDownHome: MenuKeyDownHome,\n  MenuKeyDownEnd: MenuKeyDownEnd,\n  MenuKeyDownEnter: MenuKeyDownEnter,\n  MenuKeyDownSpaceButton: MenuKeyDownSpaceButton,\n  MenuKeyDownCharacter: MenuKeyDownCharacter,\n  MenuBlur: MenuBlur,\n  MenuMouseLeave: MenuMouseLeave$1,\n  ItemMouseMove: ItemMouseMove$1,\n  ItemClick: ItemClick$1,\n  ToggleButtonClick: ToggleButtonClick$1,\n  ToggleButtonKeyDownArrowDown: ToggleButtonKeyDownArrowDown,\n  ToggleButtonKeyDownArrowUp: ToggleButtonKeyDownArrowUp,\n  ToggleButtonKeyDownCharacter: ToggleButtonKeyDownCharacter,\n  FunctionToggleMenu: FunctionToggleMenu$1,\n  FunctionOpenMenu: FunctionOpenMenu$1,\n  FunctionCloseMenu: FunctionCloseMenu$1,\n  FunctionSetHighlightedIndex: FunctionSetHighlightedIndex$1,\n  FunctionSelectItem: FunctionSelectItem$1,\n  FunctionSetInputValue: FunctionSetInputValue$1,\n  FunctionReset: FunctionReset$2\n});\n\n/* eslint-disable complexity */\n\nfunction downshiftSelectReducer(state, action) {\n  var type = action.type,\n      props = action.props,\n      shiftKey = action.shiftKey;\n  var changes;\n\n  switch (type) {\n    case ItemClick$1:\n      changes = {\n        isOpen: getDefaultValue$1(props, 'isOpen'),\n        highlightedIndex: getDefaultValue$1(props, 'highlightedIndex'),\n        selectedItem: props.items[action.index]\n      };\n      break;\n\n    case ToggleButtonKeyDownCharacter:\n      {\n        var lowercasedKey = action.key;\n        var inputValue = \"\" + state.inputValue + lowercasedKey;\n        var itemIndex = getItemIndexByCharacterKey({\n          keysSoFar: inputValue,\n          highlightedIndex: state.selectedItem ? props.items.indexOf(state.selectedItem) : -1,\n          items: props.items,\n          itemToString: props.itemToString,\n          getItemNodeFromIndex: action.getItemNodeFromIndex\n        });\n        changes = _extends({\n          inputValue: inputValue\n        }, itemIndex >= 0 && {\n          selectedItem: props.items[itemIndex]\n        });\n      }\n      break;\n\n    case ToggleButtonKeyDownArrowDown:\n      changes = {\n        highlightedIndex: getHighlightedIndexOnOpen(props, state, 1, action.getItemNodeFromIndex),\n        isOpen: true\n      };\n      break;\n\n    case ToggleButtonKeyDownArrowUp:\n      changes = {\n        highlightedIndex: getHighlightedIndexOnOpen(props, state, -1, action.getItemNodeFromIndex),\n        isOpen: true\n      };\n      break;\n\n    case MenuKeyDownEnter:\n    case MenuKeyDownSpaceButton:\n      changes = _extends({\n        isOpen: getDefaultValue$1(props, 'isOpen'),\n        highlightedIndex: getDefaultValue$1(props, 'highlightedIndex')\n      }, state.highlightedIndex >= 0 && {\n        selectedItem: props.items[state.highlightedIndex]\n      });\n      break;\n\n    case MenuKeyDownHome:\n      changes = {\n        highlightedIndex: getNextNonDisabledIndex(1, 0, props.items.length, action.getItemNodeFromIndex, false)\n      };\n      break;\n\n    case MenuKeyDownEnd:\n      changes = {\n        highlightedIndex: getNextNonDisabledIndex(-1, props.items.length - 1, props.items.length, action.getItemNodeFromIndex, false)\n      };\n      break;\n\n    case MenuKeyDownEscape:\n      changes = {\n        isOpen: false,\n        highlightedIndex: -1\n      };\n      break;\n\n    case MenuBlur:\n      changes = {\n        isOpen: false,\n        highlightedIndex: -1\n      };\n      break;\n\n    case MenuKeyDownCharacter:\n      {\n        var _lowercasedKey = action.key;\n\n        var _inputValue = \"\" + state.inputValue + _lowercasedKey;\n\n        var highlightedIndex = getItemIndexByCharacterKey({\n          keysSoFar: _inputValue,\n          highlightedIndex: state.highlightedIndex,\n          items: props.items,\n          itemToString: props.itemToString,\n          getItemNodeFromIndex: action.getItemNodeFromIndex\n        });\n        changes = _extends({\n          inputValue: _inputValue\n        }, highlightedIndex >= 0 && {\n          highlightedIndex: highlightedIndex\n        });\n      }\n      break;\n\n    case MenuKeyDownArrowDown:\n      changes = {\n        highlightedIndex: getNextWrappingIndex(shiftKey ? 5 : 1, state.highlightedIndex, props.items.length, action.getItemNodeFromIndex, props.circularNavigation)\n      };\n      break;\n\n    case MenuKeyDownArrowUp:\n      changes = {\n        highlightedIndex: getNextWrappingIndex(shiftKey ? -5 : -1, state.highlightedIndex, props.items.length, action.getItemNodeFromIndex, props.circularNavigation)\n      };\n      break;\n\n    case FunctionSelectItem$1:\n      changes = {\n        selectedItem: action.selectedItem\n      };\n      break;\n\n    default:\n      return downshiftCommonReducer(state, action, stateChangeTypes$2);\n  }\n\n  return _extends({}, state, changes);\n}\n/* eslint-enable complexity */\n\nvar _excluded$2 = [\"onMouseLeave\", \"refKey\", \"onKeyDown\", \"onBlur\", \"ref\"],\n    _excluded2$2 = [\"onClick\", \"onKeyDown\", \"refKey\", \"ref\"],\n    _excluded3$1 = [\"item\", \"index\", \"onMouseMove\", \"onClick\", \"refKey\", \"ref\"];\nuseSelect.stateChangeTypes = stateChangeTypes$2;\n\nfunction useSelect(userProps) {\n  if (userProps === void 0) {\n    userProps = {};\n  }\n\n  validatePropTypes$2(userProps, useSelect); // Props defaults and destructuring.\n\n  var props = _extends({}, defaultProps$2, userProps);\n\n  var items = props.items,\n      scrollIntoView = props.scrollIntoView,\n      environment = props.environment,\n      initialIsOpen = props.initialIsOpen,\n      defaultIsOpen = props.defaultIsOpen,\n      itemToString = props.itemToString,\n      getA11ySelectionMessage = props.getA11ySelectionMessage,\n      getA11yStatusMessage = props.getA11yStatusMessage; // Initial state depending on controlled props.\n\n  var initialState = getInitialState$2(props);\n\n  var _useControlledReducer = useControlledReducer$1(downshiftSelectReducer, initialState, props),\n      state = _useControlledReducer[0],\n      dispatch = _useControlledReducer[1];\n\n  var isOpen = state.isOpen,\n      highlightedIndex = state.highlightedIndex,\n      selectedItem = state.selectedItem,\n      inputValue = state.inputValue; // Element efs.\n\n  var toggleButtonRef = useRef(null);\n  var menuRef = useRef(null);\n  var itemRefs = useRef({}); // used not to trigger menu blur action in some scenarios.\n\n  var shouldBlurRef = useRef(true); // used to keep the inputValue clearTimeout object between renders.\n\n  var clearTimeoutRef = useRef(null); // prevent id re-generation between renders.\n\n  var elementIds = useElementIds(props); // used to keep track of how many items we had on previous cycle.\n\n  var previousResultCountRef = useRef();\n  var isInitialMountRef = useRef(true); // utility callback to get item element.\n\n  var latest = useLatestRef({\n    state: state,\n    props: props\n  }); // Some utils.\n\n  var getItemNodeFromIndex = useCallback(function (index) {\n    return itemRefs.current[elementIds.getItemId(index)];\n  }, [elementIds]); // Effects.\n  // Sets a11y status message on changes in state.\n\n  useA11yMessageSetter(getA11yStatusMessage, [isOpen, highlightedIndex, inputValue, items], _extends({\n    isInitialMount: isInitialMountRef.current,\n    previousResultCount: previousResultCountRef.current,\n    items: items,\n    environment: environment,\n    itemToString: itemToString\n  }, state)); // Sets a11y status message on changes in selectedItem.\n\n  useA11yMessageSetter(getA11ySelectionMessage, [selectedItem], _extends({\n    isInitialMount: isInitialMountRef.current,\n    previousResultCount: previousResultCountRef.current,\n    items: items,\n    environment: environment,\n    itemToString: itemToString\n  }, state)); // Scroll on highlighted item if change comes from keyboard.\n\n  var shouldScrollRef = useScrollIntoView({\n    menuElement: menuRef.current,\n    highlightedIndex: highlightedIndex,\n    isOpen: isOpen,\n    itemRefs: itemRefs,\n    scrollIntoView: scrollIntoView,\n    getItemNodeFromIndex: getItemNodeFromIndex\n  }); // Sets cleanup for the keysSoFar callback, debounded after 500ms.\n\n  useEffect(function () {\n    // init the clean function here as we need access to dispatch.\n    clearTimeoutRef.current = debounce(function (outerDispatch) {\n      outerDispatch({\n        type: FunctionSetInputValue$1,\n        inputValue: ''\n      });\n    }, 500); // Cancel any pending debounced calls on mount\n\n    return function () {\n      clearTimeoutRef.current.cancel();\n    };\n  }, []); // Invokes the keysSoFar callback set up above.\n\n  useEffect(function () {\n    if (!inputValue) {\n      return;\n    }\n\n    clearTimeoutRef.current(dispatch);\n  }, [dispatch, inputValue]);\n  useControlPropsValidator({\n    isInitialMount: isInitialMountRef.current,\n    props: props,\n    state: state\n  });\n  /* Controls the focus on the menu or the toggle button. */\n\n  useEffect(function () {\n    // Don't focus menu on first render.\n    if (isInitialMountRef.current) {\n      // Unless it was initialised as open.\n      if ((initialIsOpen || defaultIsOpen || isOpen) && menuRef.current) {\n        menuRef.current.focus();\n      }\n\n      return;\n    } // Focus menu on open.\n\n\n    if (isOpen) {\n      // istanbul ignore else\n      if (menuRef.current) {\n        menuRef.current.focus();\n      }\n\n      return;\n    } // Focus toggleButton on close, but not if it was closed with (Shift+)Tab.\n\n\n    if (environment.document.activeElement === menuRef.current) {\n      // istanbul ignore else\n      if (toggleButtonRef.current) {\n        shouldBlurRef.current = false;\n        toggleButtonRef.current.focus();\n      }\n    } // eslint-disable-next-line react-hooks/exhaustive-deps\n\n  }, [isOpen]);\n  useEffect(function () {\n    if (isInitialMountRef.current) {\n      return;\n    }\n\n    previousResultCountRef.current = items.length;\n  }); // Add mouse/touch events to document.\n\n  var mouseAndTouchTrackersRef = useMouseAndTouchTracker(isOpen, [menuRef, toggleButtonRef], environment, function () {\n    dispatch({\n      type: MenuBlur\n    });\n  });\n  var setGetterPropCallInfo = useGetterPropsCalledChecker('getMenuProps', 'getToggleButtonProps'); // Make initial ref false.\n\n  useEffect(function () {\n    isInitialMountRef.current = false;\n  }, []); // Reset itemRefs on close.\n\n  useEffect(function () {\n    if (!isOpen) {\n      itemRefs.current = {};\n    }\n  }, [isOpen]); // Event handler functions.\n\n  var toggleButtonKeyDownHandlers = useMemo(function () {\n    return {\n      ArrowDown: function ArrowDown(event) {\n        event.preventDefault();\n        dispatch({\n          type: ToggleButtonKeyDownArrowDown,\n          getItemNodeFromIndex: getItemNodeFromIndex,\n          shiftKey: event.shiftKey\n        });\n      },\n      ArrowUp: function ArrowUp(event) {\n        event.preventDefault();\n        dispatch({\n          type: ToggleButtonKeyDownArrowUp,\n          getItemNodeFromIndex: getItemNodeFromIndex,\n          shiftKey: event.shiftKey\n        });\n      }\n    };\n  }, [dispatch, getItemNodeFromIndex]);\n  var menuKeyDownHandlers = useMemo(function () {\n    return {\n      ArrowDown: function ArrowDown(event) {\n        event.preventDefault();\n        dispatch({\n          type: MenuKeyDownArrowDown,\n          getItemNodeFromIndex: getItemNodeFromIndex,\n          shiftKey: event.shiftKey\n        });\n      },\n      ArrowUp: function ArrowUp(event) {\n        event.preventDefault();\n        dispatch({\n          type: MenuKeyDownArrowUp,\n          getItemNodeFromIndex: getItemNodeFromIndex,\n          shiftKey: event.shiftKey\n        });\n      },\n      Home: function Home(event) {\n        event.preventDefault();\n        dispatch({\n          type: MenuKeyDownHome,\n          getItemNodeFromIndex: getItemNodeFromIndex\n        });\n      },\n      End: function End(event) {\n        event.preventDefault();\n        dispatch({\n          type: MenuKeyDownEnd,\n          getItemNodeFromIndex: getItemNodeFromIndex\n        });\n      },\n      Escape: function Escape() {\n        dispatch({\n          type: MenuKeyDownEscape\n        });\n      },\n      Enter: function Enter(event) {\n        event.preventDefault();\n        dispatch({\n          type: MenuKeyDownEnter\n        });\n      },\n      ' ': function _(event) {\n        event.preventDefault();\n        dispatch({\n          type: MenuKeyDownSpaceButton\n        });\n      }\n    };\n  }, [dispatch, getItemNodeFromIndex]); // Action functions.\n\n  var toggleMenu = useCallback(function () {\n    dispatch({\n      type: FunctionToggleMenu$1\n    });\n  }, [dispatch]);\n  var closeMenu = useCallback(function () {\n    dispatch({\n      type: FunctionCloseMenu$1\n    });\n  }, [dispatch]);\n  var openMenu = useCallback(function () {\n    dispatch({\n      type: FunctionOpenMenu$1\n    });\n  }, [dispatch]);\n  var setHighlightedIndex = useCallback(function (newHighlightedIndex) {\n    dispatch({\n      type: FunctionSetHighlightedIndex$1,\n      highlightedIndex: newHighlightedIndex\n    });\n  }, [dispatch]);\n  var selectItem = useCallback(function (newSelectedItem) {\n    dispatch({\n      type: FunctionSelectItem$1,\n      selectedItem: newSelectedItem\n    });\n  }, [dispatch]);\n  var reset = useCallback(function () {\n    dispatch({\n      type: FunctionReset$2\n    });\n  }, [dispatch]);\n  var setInputValue = useCallback(function (newInputValue) {\n    dispatch({\n      type: FunctionSetInputValue$1,\n      inputValue: newInputValue\n    });\n  }, [dispatch]); // Getter functions.\n\n  var getLabelProps = useCallback(function (labelProps) {\n    return _extends({\n      id: elementIds.labelId,\n      htmlFor: elementIds.toggleButtonId\n    }, labelProps);\n  }, [elementIds]);\n  var getMenuProps = useCallback(function (_temp, _temp2) {\n    var _extends2;\n\n    var _ref = _temp === void 0 ? {} : _temp,\n        onMouseLeave = _ref.onMouseLeave,\n        _ref$refKey = _ref.refKey,\n        refKey = _ref$refKey === void 0 ? 'ref' : _ref$refKey,\n        onKeyDown = _ref.onKeyDown,\n        onBlur = _ref.onBlur,\n        ref = _ref.ref,\n        rest = _objectWithoutPropertiesLoose(_ref, _excluded$2);\n\n    var _ref2 = _temp2 === void 0 ? {} : _temp2,\n        _ref2$suppressRefErro = _ref2.suppressRefError,\n        suppressRefError = _ref2$suppressRefErro === void 0 ? false : _ref2$suppressRefErro;\n\n    var latestState = latest.current.state;\n\n    var menuHandleKeyDown = function menuHandleKeyDown(event) {\n      var key = normalizeArrowKey(event);\n\n      if (key && menuKeyDownHandlers[key]) {\n        menuKeyDownHandlers[key](event);\n      } else if (isAcceptedCharacterKey(key)) {\n        dispatch({\n          type: MenuKeyDownCharacter,\n          key: key,\n          getItemNodeFromIndex: getItemNodeFromIndex\n        });\n      }\n    };\n\n    var menuHandleBlur = function menuHandleBlur() {\n      // if the blur was a result of selection, we don't trigger this action.\n      if (shouldBlurRef.current === false) {\n        shouldBlurRef.current = true;\n        return;\n      }\n\n      var shouldBlur = !mouseAndTouchTrackersRef.current.isMouseDown;\n      /* istanbul ignore else */\n\n      if (shouldBlur) {\n        dispatch({\n          type: MenuBlur\n        });\n      }\n    };\n\n    var menuHandleMouseLeave = function menuHandleMouseLeave() {\n      dispatch({\n        type: MenuMouseLeave$1\n      });\n    };\n\n    setGetterPropCallInfo('getMenuProps', suppressRefError, refKey, menuRef);\n    return _extends((_extends2 = {}, _extends2[refKey] = handleRefs(ref, function (menuNode) {\n      menuRef.current = menuNode;\n    }), _extends2.id = elementIds.menuId, _extends2.role = 'listbox', _extends2['aria-labelledby'] = elementIds.labelId, _extends2.tabIndex = -1, _extends2), latestState.isOpen && latestState.highlightedIndex > -1 && {\n      'aria-activedescendant': elementIds.getItemId(latestState.highlightedIndex)\n    }, {\n      onMouseLeave: callAllEventHandlers(onMouseLeave, menuHandleMouseLeave),\n      onKeyDown: callAllEventHandlers(onKeyDown, menuHandleKeyDown),\n      onBlur: callAllEventHandlers(onBlur, menuHandleBlur)\n    }, rest);\n  }, [dispatch, latest, menuKeyDownHandlers, mouseAndTouchTrackersRef, setGetterPropCallInfo, elementIds, getItemNodeFromIndex]);\n  var getToggleButtonProps = useCallback(function (_temp3, _temp4) {\n    var _extends3;\n\n    var _ref3 = _temp3 === void 0 ? {} : _temp3,\n        onClick = _ref3.onClick,\n        onKeyDown = _ref3.onKeyDown,\n        _ref3$refKey = _ref3.refKey,\n        refKey = _ref3$refKey === void 0 ? 'ref' : _ref3$refKey,\n        ref = _ref3.ref,\n        rest = _objectWithoutPropertiesLoose(_ref3, _excluded2$2);\n\n    var _ref4 = _temp4 === void 0 ? {} : _temp4,\n        _ref4$suppressRefErro = _ref4.suppressRefError,\n        suppressRefError = _ref4$suppressRefErro === void 0 ? false : _ref4$suppressRefErro;\n\n    var toggleButtonHandleClick = function toggleButtonHandleClick() {\n      dispatch({\n        type: ToggleButtonClick$1\n      });\n    };\n\n    var toggleButtonHandleKeyDown = function toggleButtonHandleKeyDown(event) {\n      var key = normalizeArrowKey(event);\n\n      if (key && toggleButtonKeyDownHandlers[key]) {\n        toggleButtonKeyDownHandlers[key](event);\n      } else if (isAcceptedCharacterKey(key)) {\n        dispatch({\n          type: ToggleButtonKeyDownCharacter,\n          key: key,\n          getItemNodeFromIndex: getItemNodeFromIndex\n        });\n      }\n    };\n\n    var toggleProps = _extends((_extends3 = {}, _extends3[refKey] = handleRefs(ref, function (toggleButtonNode) {\n      toggleButtonRef.current = toggleButtonNode;\n    }), _extends3.id = elementIds.toggleButtonId, _extends3['aria-haspopup'] = 'listbox', _extends3['aria-expanded'] = latest.current.state.isOpen, _extends3['aria-labelledby'] = elementIds.labelId + \" \" + elementIds.toggleButtonId, _extends3), rest);\n\n    if (!rest.disabled) {\n      toggleProps.onClick = callAllEventHandlers(onClick, toggleButtonHandleClick);\n      toggleProps.onKeyDown = callAllEventHandlers(onKeyDown, toggleButtonHandleKeyDown);\n    }\n\n    setGetterPropCallInfo('getToggleButtonProps', suppressRefError, refKey, toggleButtonRef);\n    return toggleProps;\n  }, [dispatch, latest, toggleButtonKeyDownHandlers, setGetterPropCallInfo, elementIds, getItemNodeFromIndex]);\n  var getItemProps = useCallback(function (_temp5) {\n    var _extends4;\n\n    var _ref5 = _temp5 === void 0 ? {} : _temp5,\n        item = _ref5.item,\n        index = _ref5.index,\n        onMouseMove = _ref5.onMouseMove,\n        onClick = _ref5.onClick,\n        _ref5$refKey = _ref5.refKey,\n        refKey = _ref5$refKey === void 0 ? 'ref' : _ref5$refKey,\n        ref = _ref5.ref,\n        rest = _objectWithoutPropertiesLoose(_ref5, _excluded3$1);\n\n    var _latest$current = latest.current,\n        latestState = _latest$current.state,\n        latestProps = _latest$current.props;\n\n    var itemHandleMouseMove = function itemHandleMouseMove() {\n      if (index === latestState.highlightedIndex) {\n        return;\n      }\n\n      shouldScrollRef.current = false;\n      dispatch({\n        type: ItemMouseMove$1,\n        index: index\n      });\n    };\n\n    var itemHandleClick = function itemHandleClick() {\n      dispatch({\n        type: ItemClick$1,\n        index: index\n      });\n    };\n\n    var itemIndex = getItemIndex(index, item, latestProps.items);\n\n    if (itemIndex < 0) {\n      throw new Error('Pass either item or item index in getItemProps!');\n    }\n\n    var itemProps = _extends((_extends4 = {\n      role: 'option',\n      'aria-selected': \"\" + (itemIndex === latestState.highlightedIndex),\n      id: elementIds.getItemId(itemIndex)\n    }, _extends4[refKey] = handleRefs(ref, function (itemNode) {\n      if (itemNode) {\n        itemRefs.current[elementIds.getItemId(itemIndex)] = itemNode;\n      }\n    }), _extends4), rest);\n\n    if (!rest.disabled) {\n      itemProps.onMouseMove = callAllEventHandlers(onMouseMove, itemHandleMouseMove);\n      itemProps.onClick = callAllEventHandlers(onClick, itemHandleClick);\n    }\n\n    return itemProps;\n  }, [dispatch, latest, shouldScrollRef, elementIds]);\n  return {\n    // prop getters.\n    getToggleButtonProps: getToggleButtonProps,\n    getLabelProps: getLabelProps,\n    getMenuProps: getMenuProps,\n    getItemProps: getItemProps,\n    // actions.\n    toggleMenu: toggleMenu,\n    openMenu: openMenu,\n    closeMenu: closeMenu,\n    setHighlightedIndex: setHighlightedIndex,\n    selectItem: selectItem,\n    reset: reset,\n    setInputValue: setInputValue,\n    // state.\n    highlightedIndex: highlightedIndex,\n    isOpen: isOpen,\n    selectedItem: selectedItem,\n    inputValue: inputValue\n  };\n}\n\nvar InputKeyDownArrowDown = process.env.NODE_ENV !== \"production\" ? '__input_keydown_arrow_down__' : 0;\nvar InputKeyDownArrowUp = process.env.NODE_ENV !== \"production\" ? '__input_keydown_arrow_up__' : 1;\nvar InputKeyDownEscape = process.env.NODE_ENV !== \"production\" ? '__input_keydown_escape__' : 2;\nvar InputKeyDownHome = process.env.NODE_ENV !== \"production\" ? '__input_keydown_home__' : 3;\nvar InputKeyDownEnd = process.env.NODE_ENV !== \"production\" ? '__input_keydown_end__' : 4;\nvar InputKeyDownEnter = process.env.NODE_ENV !== \"production\" ? '__input_keydown_enter__' : 5;\nvar InputChange = process.env.NODE_ENV !== \"production\" ? '__input_change__' : 6;\nvar InputBlur = process.env.NODE_ENV !== \"production\" ? '__input_blur__' : 7;\nvar MenuMouseLeave = process.env.NODE_ENV !== \"production\" ? '__menu_mouse_leave__' : 8;\nvar ItemMouseMove = process.env.NODE_ENV !== \"production\" ? '__item_mouse_move__' : 9;\nvar ItemClick = process.env.NODE_ENV !== \"production\" ? '__item_click__' : 10;\nvar ToggleButtonClick = process.env.NODE_ENV !== \"production\" ? '__togglebutton_click__' : 11;\nvar FunctionToggleMenu = process.env.NODE_ENV !== \"production\" ? '__function_toggle_menu__' : 12;\nvar FunctionOpenMenu = process.env.NODE_ENV !== \"production\" ? '__function_open_menu__' : 13;\nvar FunctionCloseMenu = process.env.NODE_ENV !== \"production\" ? '__function_close_menu__' : 14;\nvar FunctionSetHighlightedIndex = process.env.NODE_ENV !== \"production\" ? '__function_set_highlighted_index__' : 15;\nvar FunctionSelectItem = process.env.NODE_ENV !== \"production\" ? '__function_select_item__' : 16;\nvar FunctionSetInputValue = process.env.NODE_ENV !== \"production\" ? '__function_set_input_value__' : 17;\nvar FunctionReset$1 = process.env.NODE_ENV !== \"production\" ? '__function_reset__' : 18;\nvar ControlledPropUpdatedSelectedItem = process.env.NODE_ENV !== \"production\" ? '__controlled_prop_updated_selected_item__' : 19;\n\nvar stateChangeTypes$1 = /*#__PURE__*/Object.freeze({\n  __proto__: null,\n  InputKeyDownArrowDown: InputKeyDownArrowDown,\n  InputKeyDownArrowUp: InputKeyDownArrowUp,\n  InputKeyDownEscape: InputKeyDownEscape,\n  InputKeyDownHome: InputKeyDownHome,\n  InputKeyDownEnd: InputKeyDownEnd,\n  InputKeyDownEnter: InputKeyDownEnter,\n  InputChange: InputChange,\n  InputBlur: InputBlur,\n  MenuMouseLeave: MenuMouseLeave,\n  ItemMouseMove: ItemMouseMove,\n  ItemClick: ItemClick,\n  ToggleButtonClick: ToggleButtonClick,\n  FunctionToggleMenu: FunctionToggleMenu,\n  FunctionOpenMenu: FunctionOpenMenu,\n  FunctionCloseMenu: FunctionCloseMenu,\n  FunctionSetHighlightedIndex: FunctionSetHighlightedIndex,\n  FunctionSelectItem: FunctionSelectItem,\n  FunctionSetInputValue: FunctionSetInputValue,\n  FunctionReset: FunctionReset$1,\n  ControlledPropUpdatedSelectedItem: ControlledPropUpdatedSelectedItem\n});\n\nfunction getInitialState$1(props) {\n  var initialState = getInitialState$2(props);\n  var selectedItem = initialState.selectedItem;\n  var inputValue = initialState.inputValue;\n\n  if (inputValue === '' && selectedItem && props.defaultInputValue === undefined && props.initialInputValue === undefined && props.inputValue === undefined) {\n    inputValue = props.itemToString(selectedItem);\n  }\n\n  return _extends({}, initialState, {\n    inputValue: inputValue\n  });\n}\n\nvar propTypes$1 = {\n  items: PropTypes.array.isRequired,\n  itemToString: PropTypes.func,\n  getA11yStatusMessage: PropTypes.func,\n  getA11ySelectionMessage: PropTypes.func,\n  circularNavigation: PropTypes.bool,\n  highlightedIndex: PropTypes.number,\n  defaultHighlightedIndex: PropTypes.number,\n  initialHighlightedIndex: PropTypes.number,\n  isOpen: PropTypes.bool,\n  defaultIsOpen: PropTypes.bool,\n  initialIsOpen: PropTypes.bool,\n  selectedItem: PropTypes.any,\n  initialSelectedItem: PropTypes.any,\n  defaultSelectedItem: PropTypes.any,\n  inputValue: PropTypes.string,\n  defaultInputValue: PropTypes.string,\n  initialInputValue: PropTypes.string,\n  id: PropTypes.string,\n  labelId: PropTypes.string,\n  menuId: PropTypes.string,\n  getItemId: PropTypes.func,\n  inputId: PropTypes.string,\n  toggleButtonId: PropTypes.string,\n  stateReducer: PropTypes.func,\n  onSelectedItemChange: PropTypes.func,\n  onHighlightedIndexChange: PropTypes.func,\n  onStateChange: PropTypes.func,\n  onIsOpenChange: PropTypes.func,\n  onInputValueChange: PropTypes.func,\n  environment: PropTypes.shape({\n    addEventListener: PropTypes.func,\n    removeEventListener: PropTypes.func,\n    document: PropTypes.shape({\n      getElementById: PropTypes.func,\n      activeElement: PropTypes.any,\n      body: PropTypes.any\n    })\n  })\n};\n/**\n * The useCombobox version of useControlledReducer, which also\n * checks if the controlled prop selectedItem changed between\n * renders. If so, it will also update inputValue with its\n * string equivalent. It uses the common useEnhancedReducer to\n * compute the rest of the state.\n *\n * @param {Function} reducer Reducer function from downshift.\n * @param {Object} initialState Initial state of the hook.\n * @param {Object} props The hook props.\n * @returns {Array} An array with the state and an action dispatcher.\n */\n\nfunction useControlledReducer(reducer, initialState, props) {\n  var previousSelectedItemRef = useRef();\n\n  var _useEnhancedReducer = useEnhancedReducer(reducer, initialState, props),\n      state = _useEnhancedReducer[0],\n      dispatch = _useEnhancedReducer[1]; // ToDo: if needed, make same approach as selectedItemChanged from Downshift.\n\n\n  useEffect(function () {\n    if (isControlledProp(props, 'selectedItem')) {\n      if (previousSelectedItemRef.current !== props.selectedItem) {\n        dispatch({\n          type: ControlledPropUpdatedSelectedItem,\n          inputValue: props.itemToString(props.selectedItem)\n        });\n      }\n\n      previousSelectedItemRef.current = state.selectedItem === previousSelectedItemRef.current ? props.selectedItem : state.selectedItem;\n    }\n  });\n  return [getState(state, props), dispatch];\n} // eslint-disable-next-line import/no-mutable-exports\n\n\nvar validatePropTypes$1 = noop;\n/* istanbul ignore next */\n\nif (process.env.NODE_ENV !== 'production') {\n  validatePropTypes$1 = function validatePropTypes(options, caller) {\n    PropTypes.checkPropTypes(propTypes$1, options, 'prop', caller.name);\n  };\n}\n\nvar defaultProps$1 = _extends({}, defaultProps$3, {\n  getA11yStatusMessage: getA11yStatusMessage$1,\n  circularNavigation: true\n});\n\n/* eslint-disable complexity */\n\nfunction downshiftUseComboboxReducer(state, action) {\n  var type = action.type,\n      props = action.props,\n      shiftKey = action.shiftKey;\n  var changes;\n\n  switch (type) {\n    case ItemClick:\n      changes = {\n        isOpen: getDefaultValue$1(props, 'isOpen'),\n        highlightedIndex: getDefaultValue$1(props, 'highlightedIndex'),\n        selectedItem: props.items[action.index],\n        inputValue: props.itemToString(props.items[action.index])\n      };\n      break;\n\n    case InputKeyDownArrowDown:\n      if (state.isOpen) {\n        changes = {\n          highlightedIndex: getNextWrappingIndex(shiftKey ? 5 : 1, state.highlightedIndex, props.items.length, action.getItemNodeFromIndex, props.circularNavigation)\n        };\n      } else {\n        changes = {\n          highlightedIndex: getHighlightedIndexOnOpen(props, state, 1, action.getItemNodeFromIndex),\n          isOpen: props.items.length >= 0\n        };\n      }\n\n      break;\n\n    case InputKeyDownArrowUp:\n      if (state.isOpen) {\n        changes = {\n          highlightedIndex: getNextWrappingIndex(shiftKey ? -5 : -1, state.highlightedIndex, props.items.length, action.getItemNodeFromIndex, props.circularNavigation)\n        };\n      } else {\n        changes = {\n          highlightedIndex: getHighlightedIndexOnOpen(props, state, -1, action.getItemNodeFromIndex),\n          isOpen: props.items.length >= 0\n        };\n      }\n\n      break;\n\n    case InputKeyDownEnter:\n      changes = _extends({}, state.isOpen && state.highlightedIndex >= 0 && {\n        selectedItem: props.items[state.highlightedIndex],\n        isOpen: getDefaultValue$1(props, 'isOpen'),\n        highlightedIndex: getDefaultValue$1(props, 'highlightedIndex'),\n        inputValue: props.itemToString(props.items[state.highlightedIndex])\n      });\n      break;\n\n    case InputKeyDownEscape:\n      changes = _extends({\n        isOpen: false,\n        highlightedIndex: -1\n      }, !state.isOpen && {\n        selectedItem: null,\n        inputValue: ''\n      });\n      break;\n\n    case InputKeyDownHome:\n      changes = {\n        highlightedIndex: getNextNonDisabledIndex(1, 0, props.items.length, action.getItemNodeFromIndex, false)\n      };\n      break;\n\n    case InputKeyDownEnd:\n      changes = {\n        highlightedIndex: getNextNonDisabledIndex(-1, props.items.length - 1, props.items.length, action.getItemNodeFromIndex, false)\n      };\n      break;\n\n    case InputBlur:\n      changes = _extends({\n        isOpen: false,\n        highlightedIndex: -1\n      }, state.highlightedIndex >= 0 && action.selectItem && {\n        selectedItem: props.items[state.highlightedIndex],\n        inputValue: props.itemToString(props.items[state.highlightedIndex])\n      });\n      break;\n\n    case InputChange:\n      changes = {\n        isOpen: true,\n        highlightedIndex: getDefaultValue$1(props, 'highlightedIndex'),\n        inputValue: action.inputValue\n      };\n      break;\n\n    case FunctionSelectItem:\n      changes = {\n        selectedItem: action.selectedItem,\n        inputValue: props.itemToString(action.selectedItem)\n      };\n      break;\n\n    case ControlledPropUpdatedSelectedItem:\n      changes = {\n        inputValue: action.inputValue\n      };\n      break;\n\n    default:\n      return downshiftCommonReducer(state, action, stateChangeTypes$1);\n  }\n\n  return _extends({}, state, changes);\n}\n/* eslint-enable complexity */\n\nvar _excluded$1 = [\"onMouseLeave\", \"refKey\", \"ref\"],\n    _excluded2$1 = [\"item\", \"index\", \"refKey\", \"ref\", \"onMouseMove\", \"onClick\", \"onPress\"],\n    _excluded3 = [\"onClick\", \"onPress\", \"refKey\", \"ref\"],\n    _excluded4 = [\"onKeyDown\", \"onChange\", \"onInput\", \"onBlur\", \"onChangeText\", \"refKey\", \"ref\"],\n    _excluded5 = [\"refKey\", \"ref\"];\nuseCombobox.stateChangeTypes = stateChangeTypes$1;\n\nfunction useCombobox(userProps) {\n  if (userProps === void 0) {\n    userProps = {};\n  }\n\n  validatePropTypes$1(userProps, useCombobox); // Props defaults and destructuring.\n\n  var props = _extends({}, defaultProps$1, userProps);\n\n  var initialIsOpen = props.initialIsOpen,\n      defaultIsOpen = props.defaultIsOpen,\n      items = props.items,\n      scrollIntoView = props.scrollIntoView,\n      environment = props.environment,\n      getA11yStatusMessage = props.getA11yStatusMessage,\n      getA11ySelectionMessage = props.getA11ySelectionMessage,\n      itemToString = props.itemToString; // Initial state depending on controlled props.\n\n  var initialState = getInitialState$1(props);\n\n  var _useControlledReducer = useControlledReducer(downshiftUseComboboxReducer, initialState, props),\n      state = _useControlledReducer[0],\n      dispatch = _useControlledReducer[1];\n\n  var isOpen = state.isOpen,\n      highlightedIndex = state.highlightedIndex,\n      selectedItem = state.selectedItem,\n      inputValue = state.inputValue; // Element refs.\n\n  var menuRef = useRef(null);\n  var itemRefs = useRef({});\n  var inputRef = useRef(null);\n  var toggleButtonRef = useRef(null);\n  var comboboxRef = useRef(null);\n  var isInitialMountRef = useRef(true); // prevent id re-generation between renders.\n\n  var elementIds = useElementIds(props); // used to keep track of how many items we had on previous cycle.\n\n  var previousResultCountRef = useRef(); // utility callback to get item element.\n\n  var latest = useLatestRef({\n    state: state,\n    props: props\n  });\n  var getItemNodeFromIndex = useCallback(function (index) {\n    return itemRefs.current[elementIds.getItemId(index)];\n  }, [elementIds]); // Effects.\n  // Sets a11y status message on changes in state.\n\n  useA11yMessageSetter(getA11yStatusMessage, [isOpen, highlightedIndex, inputValue, items], _extends({\n    isInitialMount: isInitialMountRef.current,\n    previousResultCount: previousResultCountRef.current,\n    items: items,\n    environment: environment,\n    itemToString: itemToString\n  }, state)); // Sets a11y status message on changes in selectedItem.\n\n  useA11yMessageSetter(getA11ySelectionMessage, [selectedItem], _extends({\n    isInitialMount: isInitialMountRef.current,\n    previousResultCount: previousResultCountRef.current,\n    items: items,\n    environment: environment,\n    itemToString: itemToString\n  }, state)); // Scroll on highlighted item if change comes from keyboard.\n\n  var shouldScrollRef = useScrollIntoView({\n    menuElement: menuRef.current,\n    highlightedIndex: highlightedIndex,\n    isOpen: isOpen,\n    itemRefs: itemRefs,\n    scrollIntoView: scrollIntoView,\n    getItemNodeFromIndex: getItemNodeFromIndex\n  });\n  useControlPropsValidator({\n    isInitialMount: isInitialMountRef.current,\n    props: props,\n    state: state\n  }); // Focus the input on first render if required.\n\n  useEffect(function () {\n    var focusOnOpen = initialIsOpen || defaultIsOpen || isOpen;\n\n    if (focusOnOpen && inputRef.current) {\n      inputRef.current.focus();\n    } // eslint-disable-next-line react-hooks/exhaustive-deps\n\n  }, []);\n  useEffect(function () {\n    if (isInitialMountRef.current) {\n      return;\n    }\n\n    previousResultCountRef.current = items.length;\n  }); // Add mouse/touch events to document.\n\n  var mouseAndTouchTrackersRef = useMouseAndTouchTracker(isOpen, [comboboxRef, menuRef, toggleButtonRef], environment, function () {\n    dispatch({\n      type: InputBlur,\n      selectItem: false\n    });\n  });\n  var setGetterPropCallInfo = useGetterPropsCalledChecker('getInputProps', 'getComboboxProps', 'getMenuProps'); // Make initial ref false.\n\n  useEffect(function () {\n    isInitialMountRef.current = false;\n  }, []); // Reset itemRefs on close.\n\n  useEffect(function () {\n    if (!isOpen) {\n      itemRefs.current = {};\n    }\n  }, [isOpen]);\n  /* Event handler functions */\n\n  var inputKeyDownHandlers = useMemo(function () {\n    return {\n      ArrowDown: function ArrowDown(event) {\n        event.preventDefault();\n        dispatch({\n          type: InputKeyDownArrowDown,\n          shiftKey: event.shiftKey,\n          getItemNodeFromIndex: getItemNodeFromIndex\n        });\n      },\n      ArrowUp: function ArrowUp(event) {\n        event.preventDefault();\n        dispatch({\n          type: InputKeyDownArrowUp,\n          shiftKey: event.shiftKey,\n          getItemNodeFromIndex: getItemNodeFromIndex\n        });\n      },\n      Home: function Home(event) {\n        if (!latest.current.state.isOpen) {\n          return;\n        }\n\n        event.preventDefault();\n        dispatch({\n          type: InputKeyDownHome,\n          getItemNodeFromIndex: getItemNodeFromIndex\n        });\n      },\n      End: function End(event) {\n        if (!latest.current.state.isOpen) {\n          return;\n        }\n\n        event.preventDefault();\n        dispatch({\n          type: InputKeyDownEnd,\n          getItemNodeFromIndex: getItemNodeFromIndex\n        });\n      },\n      Escape: function Escape() {\n        var latestState = latest.current.state;\n\n        if (latestState.isOpen || latestState.inputValue || latestState.selectedItem || latestState.highlightedIndex > -1) {\n          dispatch({\n            type: InputKeyDownEscape\n          });\n        }\n      },\n      Enter: function Enter(event) {\n        var latestState = latest.current.state; // if closed or no highlighted index, do nothing.\n\n        if (!latestState.isOpen || latestState.highlightedIndex < 0 || event.which === 229 // if IME composing, wait for next Enter keydown event.\n        ) {\n          return;\n        }\n\n        event.preventDefault();\n        dispatch({\n          type: InputKeyDownEnter,\n          getItemNodeFromIndex: getItemNodeFromIndex\n        });\n      }\n    };\n  }, [dispatch, latest, getItemNodeFromIndex]); // Getter props.\n\n  var getLabelProps = useCallback(function (labelProps) {\n    return _extends({\n      id: elementIds.labelId,\n      htmlFor: elementIds.inputId\n    }, labelProps);\n  }, [elementIds]);\n  var getMenuProps = useCallback(function (_temp, _temp2) {\n    var _extends2;\n\n    var _ref = _temp === void 0 ? {} : _temp,\n        onMouseLeave = _ref.onMouseLeave,\n        _ref$refKey = _ref.refKey,\n        refKey = _ref$refKey === void 0 ? 'ref' : _ref$refKey,\n        ref = _ref.ref,\n        rest = _objectWithoutPropertiesLoose(_ref, _excluded$1);\n\n    var _ref2 = _temp2 === void 0 ? {} : _temp2,\n        _ref2$suppressRefErro = _ref2.suppressRefError,\n        suppressRefError = _ref2$suppressRefErro === void 0 ? false : _ref2$suppressRefErro;\n\n    setGetterPropCallInfo('getMenuProps', suppressRefError, refKey, menuRef);\n    return _extends((_extends2 = {}, _extends2[refKey] = handleRefs(ref, function (menuNode) {\n      menuRef.current = menuNode;\n    }), _extends2.id = elementIds.menuId, _extends2.role = 'listbox', _extends2['aria-labelledby'] = elementIds.labelId, _extends2.onMouseLeave = callAllEventHandlers(onMouseLeave, function () {\n      dispatch({\n        type: MenuMouseLeave\n      });\n    }), _extends2), rest);\n  }, [dispatch, setGetterPropCallInfo, elementIds]);\n  var getItemProps = useCallback(function (_temp3) {\n    var _extends3, _ref4;\n\n    var _ref3 = _temp3 === void 0 ? {} : _temp3,\n        item = _ref3.item,\n        index = _ref3.index,\n        _ref3$refKey = _ref3.refKey,\n        refKey = _ref3$refKey === void 0 ? 'ref' : _ref3$refKey,\n        ref = _ref3.ref,\n        onMouseMove = _ref3.onMouseMove,\n        onClick = _ref3.onClick;\n        _ref3.onPress;\n        var rest = _objectWithoutPropertiesLoose(_ref3, _excluded2$1);\n\n    var _latest$current = latest.current,\n        latestProps = _latest$current.props,\n        latestState = _latest$current.state;\n    var itemIndex = getItemIndex(index, item, latestProps.items);\n\n    if (itemIndex < 0) {\n      throw new Error('Pass either item or item index in getItemProps!');\n    }\n\n    var onSelectKey = 'onClick';\n    var customClickHandler = onClick;\n\n    var itemHandleMouseMove = function itemHandleMouseMove() {\n      if (index === latestState.highlightedIndex) {\n        return;\n      }\n\n      shouldScrollRef.current = false;\n      dispatch({\n        type: ItemMouseMove,\n        index: index\n      });\n    };\n\n    var itemHandleClick = function itemHandleClick() {\n      dispatch({\n        type: ItemClick,\n        index: index\n      });\n\n      if (inputRef.current) {\n        inputRef.current.focus();\n      }\n    };\n\n    return _extends((_extends3 = {}, _extends3[refKey] = handleRefs(ref, function (itemNode) {\n      if (itemNode) {\n        itemRefs.current[elementIds.getItemId(itemIndex)] = itemNode;\n      }\n    }), _extends3.role = 'option', _extends3['aria-selected'] = \"\" + (itemIndex === latestState.highlightedIndex), _extends3.id = elementIds.getItemId(itemIndex), _extends3), !rest.disabled && (_ref4 = {\n      onMouseMove: callAllEventHandlers(onMouseMove, itemHandleMouseMove)\n    }, _ref4[onSelectKey] = callAllEventHandlers(customClickHandler, itemHandleClick), _ref4), rest);\n  }, [dispatch, latest, shouldScrollRef, elementIds]);\n  var getToggleButtonProps = useCallback(function (_temp4) {\n    var _extends4;\n\n    var _ref5 = _temp4 === void 0 ? {} : _temp4,\n        onClick = _ref5.onClick;\n        _ref5.onPress;\n        var _ref5$refKey = _ref5.refKey,\n        refKey = _ref5$refKey === void 0 ? 'ref' : _ref5$refKey,\n        ref = _ref5.ref,\n        rest = _objectWithoutPropertiesLoose(_ref5, _excluded3);\n\n    var toggleButtonHandleClick = function toggleButtonHandleClick() {\n      dispatch({\n        type: ToggleButtonClick\n      });\n\n      if (!latest.current.state.isOpen && inputRef.current) {\n        inputRef.current.focus();\n      }\n    };\n\n    return _extends((_extends4 = {}, _extends4[refKey] = handleRefs(ref, function (toggleButtonNode) {\n      toggleButtonRef.current = toggleButtonNode;\n    }), _extends4.id = elementIds.toggleButtonId, _extends4.tabIndex = -1, _extends4), !rest.disabled && _extends({}, {\n      onClick: callAllEventHandlers(onClick, toggleButtonHandleClick)\n    }), rest);\n  }, [dispatch, latest, elementIds]);\n  var getInputProps = useCallback(function (_temp5, _temp6) {\n    var _extends5;\n\n    var _ref6 = _temp5 === void 0 ? {} : _temp5,\n        onKeyDown = _ref6.onKeyDown,\n        onChange = _ref6.onChange,\n        onInput = _ref6.onInput,\n        onBlur = _ref6.onBlur;\n        _ref6.onChangeText;\n        var _ref6$refKey = _ref6.refKey,\n        refKey = _ref6$refKey === void 0 ? 'ref' : _ref6$refKey,\n        ref = _ref6.ref,\n        rest = _objectWithoutPropertiesLoose(_ref6, _excluded4);\n\n    var _ref7 = _temp6 === void 0 ? {} : _temp6,\n        _ref7$suppressRefErro = _ref7.suppressRefError,\n        suppressRefError = _ref7$suppressRefErro === void 0 ? false : _ref7$suppressRefErro;\n\n    setGetterPropCallInfo('getInputProps', suppressRefError, refKey, inputRef);\n    var latestState = latest.current.state;\n\n    var inputHandleKeyDown = function inputHandleKeyDown(event) {\n      var key = normalizeArrowKey(event);\n\n      if (key && inputKeyDownHandlers[key]) {\n        inputKeyDownHandlers[key](event);\n      }\n    };\n\n    var inputHandleChange = function inputHandleChange(event) {\n      dispatch({\n        type: InputChange,\n        inputValue: event.target.value\n      });\n    };\n\n    var inputHandleBlur = function inputHandleBlur() {\n      /* istanbul ignore else */\n      if (latestState.isOpen && !mouseAndTouchTrackersRef.current.isMouseDown) {\n        dispatch({\n          type: InputBlur,\n          selectItem: true\n        });\n      }\n    };\n    /* istanbul ignore next (preact) */\n\n\n    var onChangeKey = 'onChange';\n    var eventHandlers = {};\n\n    if (!rest.disabled) {\n      var _eventHandlers;\n\n      eventHandlers = (_eventHandlers = {}, _eventHandlers[onChangeKey] = callAllEventHandlers(onChange, onInput, inputHandleChange), _eventHandlers.onKeyDown = callAllEventHandlers(onKeyDown, inputHandleKeyDown), _eventHandlers.onBlur = callAllEventHandlers(onBlur, inputHandleBlur), _eventHandlers);\n    }\n\n    return _extends((_extends5 = {}, _extends5[refKey] = handleRefs(ref, function (inputNode) {\n      inputRef.current = inputNode;\n    }), _extends5.id = elementIds.inputId, _extends5['aria-autocomplete'] = 'list', _extends5['aria-controls'] = elementIds.menuId, _extends5), latestState.isOpen && latestState.highlightedIndex > -1 && {\n      'aria-activedescendant': elementIds.getItemId(latestState.highlightedIndex)\n    }, {\n      'aria-labelledby': elementIds.labelId,\n      // https://developer.mozilla.org/en-US/docs/Web/Security/Securing_your_site/Turning_off_form_autocompletion\n      // revert back since autocomplete=\"nope\" is ignored on latest Chrome and Opera\n      autoComplete: 'off',\n      value: latestState.inputValue\n    }, eventHandlers, rest);\n  }, [dispatch, inputKeyDownHandlers, latest, mouseAndTouchTrackersRef, setGetterPropCallInfo, elementIds]);\n  var getComboboxProps = useCallback(function (_temp7, _temp8) {\n    var _extends6;\n\n    var _ref8 = _temp7 === void 0 ? {} : _temp7,\n        _ref8$refKey = _ref8.refKey,\n        refKey = _ref8$refKey === void 0 ? 'ref' : _ref8$refKey,\n        ref = _ref8.ref,\n        rest = _objectWithoutPropertiesLoose(_ref8, _excluded5);\n\n    var _ref9 = _temp8 === void 0 ? {} : _temp8,\n        _ref9$suppressRefErro = _ref9.suppressRefError,\n        suppressRefError = _ref9$suppressRefErro === void 0 ? false : _ref9$suppressRefErro;\n\n    setGetterPropCallInfo('getComboboxProps', suppressRefError, refKey, comboboxRef);\n    return _extends((_extends6 = {}, _extends6[refKey] = handleRefs(ref, function (comboboxNode) {\n      comboboxRef.current = comboboxNode;\n    }), _extends6.role = 'combobox', _extends6['aria-haspopup'] = 'listbox', _extends6['aria-owns'] = elementIds.menuId, _extends6['aria-expanded'] = latest.current.state.isOpen, _extends6), rest);\n  }, [latest, setGetterPropCallInfo, elementIds]); // returns\n\n  var toggleMenu = useCallback(function () {\n    dispatch({\n      type: FunctionToggleMenu\n    });\n  }, [dispatch]);\n  var closeMenu = useCallback(function () {\n    dispatch({\n      type: FunctionCloseMenu\n    });\n  }, [dispatch]);\n  var openMenu = useCallback(function () {\n    dispatch({\n      type: FunctionOpenMenu\n    });\n  }, [dispatch]);\n  var setHighlightedIndex = useCallback(function (newHighlightedIndex) {\n    dispatch({\n      type: FunctionSetHighlightedIndex,\n      highlightedIndex: newHighlightedIndex\n    });\n  }, [dispatch]);\n  var selectItem = useCallback(function (newSelectedItem) {\n    dispatch({\n      type: FunctionSelectItem,\n      selectedItem: newSelectedItem\n    });\n  }, [dispatch]);\n  var setInputValue = useCallback(function (newInputValue) {\n    dispatch({\n      type: FunctionSetInputValue,\n      inputValue: newInputValue\n    });\n  }, [dispatch]);\n  var reset = useCallback(function () {\n    dispatch({\n      type: FunctionReset$1\n    });\n  }, [dispatch]);\n  return {\n    // prop getters.\n    getItemProps: getItemProps,\n    getLabelProps: getLabelProps,\n    getMenuProps: getMenuProps,\n    getInputProps: getInputProps,\n    getComboboxProps: getComboboxProps,\n    getToggleButtonProps: getToggleButtonProps,\n    // actions.\n    toggleMenu: toggleMenu,\n    openMenu: openMenu,\n    closeMenu: closeMenu,\n    setHighlightedIndex: setHighlightedIndex,\n    setInputValue: setInputValue,\n    selectItem: selectItem,\n    reset: reset,\n    // state.\n    highlightedIndex: highlightedIndex,\n    isOpen: isOpen,\n    selectedItem: selectedItem,\n    inputValue: inputValue\n  };\n}\n\nvar defaultStateValues = {\n  activeIndex: -1,\n  selectedItems: []\n};\n/**\n * Returns the initial value for a state key in the following order:\n * 1. controlled prop, 2. initial prop, 3. default prop, 4. default\n * value from Downshift.\n *\n * @param {Object} props Props passed to the hook.\n * @param {string} propKey Props key to generate the value for.\n * @returns {any} The initial value for that prop.\n */\n\nfunction getInitialValue(props, propKey) {\n  return getInitialValue$1(props, propKey, defaultStateValues);\n}\n/**\n * Returns the default value for a state key in the following order:\n * 1. controlled prop, 2. default prop, 3. default value from Downshift.\n *\n * @param {Object} props Props passed to the hook.\n * @param {string} propKey Props key to generate the value for.\n * @returns {any} The initial value for that prop.\n */\n\n\nfunction getDefaultValue(props, propKey) {\n  return getDefaultValue$1(props, propKey, defaultStateValues);\n}\n/**\n * Gets the initial state based on the provided props. It uses initial, default\n * and controlled props related to state in order to compute the initial value.\n *\n * @param {Object} props Props passed to the hook.\n * @returns {Object} The initial state.\n */\n\n\nfunction getInitialState(props) {\n  var activeIndex = getInitialValue(props, 'activeIndex');\n  var selectedItems = getInitialValue(props, 'selectedItems');\n  return {\n    activeIndex: activeIndex,\n    selectedItems: selectedItems\n  };\n}\n/**\n * Returns true if dropdown keydown operation is permitted. Should not be\n * allowed on keydown with modifier keys (ctrl, alt, shift, meta), on\n * input element with text content that is either highlighted or selection\n * cursor is not at the starting position.\n *\n * @param {KeyboardEvent} event The event from keydown.\n * @returns {boolean} Whether the operation is allowed.\n */\n\n\nfunction isKeyDownOperationPermitted(event) {\n  if (event.shiftKey || event.metaKey || event.ctrlKey || event.altKey) {\n    return false;\n  }\n\n  var element = event.target;\n\n  if (element instanceof HTMLInputElement && // if element is a text input\n  element.value !== '' && (element.selectionStart !== 0 || element.selectionEnd !== 0)) {\n    return false;\n  }\n\n  return true;\n}\n/**\n * Returns a message to be added to aria-live region when item is removed.\n *\n * @param {Object} selectionParameters Parameters required to build the message.\n * @returns {string} The a11y message.\n */\n\n\nfunction getA11yRemovalMessage(selectionParameters) {\n  var removedSelectedItem = selectionParameters.removedSelectedItem,\n      itemToStringLocal = selectionParameters.itemToString;\n  return itemToStringLocal(removedSelectedItem) + \" has been removed.\";\n}\n\nvar propTypes = {\n  selectedItems: PropTypes.array,\n  initialSelectedItems: PropTypes.array,\n  defaultSelectedItems: PropTypes.array,\n  itemToString: PropTypes.func,\n  getA11yRemovalMessage: PropTypes.func,\n  stateReducer: PropTypes.func,\n  activeIndex: PropTypes.number,\n  initialActiveIndex: PropTypes.number,\n  defaultActiveIndex: PropTypes.number,\n  onActiveIndexChange: PropTypes.func,\n  onSelectedItemsChange: PropTypes.func,\n  keyNavigationNext: PropTypes.string,\n  keyNavigationPrevious: PropTypes.string,\n  environment: PropTypes.shape({\n    addEventListener: PropTypes.func,\n    removeEventListener: PropTypes.func,\n    document: PropTypes.shape({\n      getElementById: PropTypes.func,\n      activeElement: PropTypes.any,\n      body: PropTypes.any\n    })\n  })\n};\nvar defaultProps = {\n  itemToString: defaultProps$3.itemToString,\n  stateReducer: defaultProps$3.stateReducer,\n  environment: defaultProps$3.environment,\n  getA11yRemovalMessage: getA11yRemovalMessage,\n  keyNavigationNext: 'ArrowRight',\n  keyNavigationPrevious: 'ArrowLeft'\n}; // eslint-disable-next-line import/no-mutable-exports\n\nvar validatePropTypes = noop;\n/* istanbul ignore next */\n\nif (process.env.NODE_ENV !== 'production') {\n  validatePropTypes = function validatePropTypes(options, caller) {\n    PropTypes.checkPropTypes(propTypes, options, 'prop', caller.name);\n  };\n}\n\nvar SelectedItemClick = process.env.NODE_ENV !== \"production\" ? '__selected_item_click__' : 0;\nvar SelectedItemKeyDownDelete = process.env.NODE_ENV !== \"production\" ? '__selected_item_keydown_delete__' : 1;\nvar SelectedItemKeyDownBackspace = process.env.NODE_ENV !== \"production\" ? '__selected_item_keydown_backspace__' : 2;\nvar SelectedItemKeyDownNavigationNext = process.env.NODE_ENV !== \"production\" ? '__selected_item_keydown_navigation_next__' : 3;\nvar SelectedItemKeyDownNavigationPrevious = process.env.NODE_ENV !== \"production\" ? '__selected_item_keydown_navigation_previous__' : 4;\nvar DropdownKeyDownNavigationPrevious = process.env.NODE_ENV !== \"production\" ? '__dropdown_keydown_navigation_previous__' : 5;\nvar DropdownKeyDownBackspace = process.env.NODE_ENV !== \"production\" ? '__dropdown_keydown_backspace__' : 6;\nvar DropdownClick = process.env.NODE_ENV !== \"production\" ? '__dropdown_click__' : 7;\nvar FunctionAddSelectedItem = process.env.NODE_ENV !== \"production\" ? '__function_add_selected_item__' : 8;\nvar FunctionRemoveSelectedItem = process.env.NODE_ENV !== \"production\" ? '__function_remove_selected_item__' : 9;\nvar FunctionSetSelectedItems = process.env.NODE_ENV !== \"production\" ? '__function_set_selected_items__' : 10;\nvar FunctionSetActiveIndex = process.env.NODE_ENV !== \"production\" ? '__function_set_active_index__' : 11;\nvar FunctionReset = process.env.NODE_ENV !== \"production\" ? '__function_reset__' : 12;\n\nvar stateChangeTypes = /*#__PURE__*/Object.freeze({\n  __proto__: null,\n  SelectedItemClick: SelectedItemClick,\n  SelectedItemKeyDownDelete: SelectedItemKeyDownDelete,\n  SelectedItemKeyDownBackspace: SelectedItemKeyDownBackspace,\n  SelectedItemKeyDownNavigationNext: SelectedItemKeyDownNavigationNext,\n  SelectedItemKeyDownNavigationPrevious: SelectedItemKeyDownNavigationPrevious,\n  DropdownKeyDownNavigationPrevious: DropdownKeyDownNavigationPrevious,\n  DropdownKeyDownBackspace: DropdownKeyDownBackspace,\n  DropdownClick: DropdownClick,\n  FunctionAddSelectedItem: FunctionAddSelectedItem,\n  FunctionRemoveSelectedItem: FunctionRemoveSelectedItem,\n  FunctionSetSelectedItems: FunctionSetSelectedItems,\n  FunctionSetActiveIndex: FunctionSetActiveIndex,\n  FunctionReset: FunctionReset\n});\n\n/* eslint-disable complexity */\n\nfunction downshiftMultipleSelectionReducer(state, action) {\n  var type = action.type,\n      index = action.index,\n      props = action.props,\n      selectedItem = action.selectedItem;\n  var activeIndex = state.activeIndex,\n      selectedItems = state.selectedItems;\n  var changes;\n\n  switch (type) {\n    case SelectedItemClick:\n      changes = {\n        activeIndex: index\n      };\n      break;\n\n    case SelectedItemKeyDownNavigationPrevious:\n      changes = {\n        activeIndex: activeIndex - 1 < 0 ? 0 : activeIndex - 1\n      };\n      break;\n\n    case SelectedItemKeyDownNavigationNext:\n      changes = {\n        activeIndex: activeIndex + 1 >= selectedItems.length ? -1 : activeIndex + 1\n      };\n      break;\n\n    case SelectedItemKeyDownBackspace:\n    case SelectedItemKeyDownDelete:\n      {\n        var newActiveIndex = activeIndex;\n\n        if (selectedItems.length === 1) {\n          newActiveIndex = -1;\n        } else if (activeIndex === selectedItems.length - 1) {\n          newActiveIndex = selectedItems.length - 2;\n        }\n\n        changes = _extends({\n          selectedItems: [].concat(selectedItems.slice(0, activeIndex), selectedItems.slice(activeIndex + 1))\n        }, {\n          activeIndex: newActiveIndex\n        });\n        break;\n      }\n\n    case DropdownKeyDownNavigationPrevious:\n      changes = {\n        activeIndex: selectedItems.length - 1\n      };\n      break;\n\n    case DropdownKeyDownBackspace:\n      changes = {\n        selectedItems: selectedItems.slice(0, selectedItems.length - 1)\n      };\n      break;\n\n    case FunctionAddSelectedItem:\n      changes = {\n        selectedItems: [].concat(selectedItems, [selectedItem])\n      };\n      break;\n\n    case DropdownClick:\n      changes = {\n        activeIndex: -1\n      };\n      break;\n\n    case FunctionRemoveSelectedItem:\n      {\n        var _newActiveIndex = activeIndex;\n        var selectedItemIndex = selectedItems.indexOf(selectedItem);\n\n        if (selectedItems.length === 1) {\n          _newActiveIndex = -1;\n        } else if (selectedItemIndex === selectedItems.length - 1) {\n          _newActiveIndex = selectedItems.length - 2;\n        }\n\n        changes = _extends({\n          selectedItems: [].concat(selectedItems.slice(0, selectedItemIndex), selectedItems.slice(selectedItemIndex + 1))\n        }, {\n          activeIndex: _newActiveIndex\n        });\n        break;\n      }\n\n    case FunctionSetSelectedItems:\n      {\n        var newSelectedItems = action.selectedItems;\n        changes = {\n          selectedItems: newSelectedItems\n        };\n        break;\n      }\n\n    case FunctionSetActiveIndex:\n      {\n        var _newActiveIndex2 = action.activeIndex;\n        changes = {\n          activeIndex: _newActiveIndex2\n        };\n        break;\n      }\n\n    case FunctionReset:\n      changes = {\n        activeIndex: getDefaultValue(props, 'activeIndex'),\n        selectedItems: getDefaultValue(props, 'selectedItems')\n      };\n      break;\n\n    default:\n      throw new Error('Reducer called without proper action type.');\n  }\n\n  return _extends({}, state, changes);\n}\n\nvar _excluded = [\"refKey\", \"ref\", \"onClick\", \"onKeyDown\", \"selectedItem\", \"index\"],\n    _excluded2 = [\"refKey\", \"ref\", \"onKeyDown\", \"onClick\", \"preventKeyAction\"];\nuseMultipleSelection.stateChangeTypes = stateChangeTypes;\n\nfunction useMultipleSelection(userProps) {\n  if (userProps === void 0) {\n    userProps = {};\n  }\n\n  validatePropTypes(userProps, useMultipleSelection); // Props defaults and destructuring.\n\n  var props = _extends({}, defaultProps, userProps);\n\n  var getA11yRemovalMessage = props.getA11yRemovalMessage,\n      itemToString = props.itemToString,\n      environment = props.environment,\n      keyNavigationNext = props.keyNavigationNext,\n      keyNavigationPrevious = props.keyNavigationPrevious; // Reducer init.\n\n  var _useControlledReducer = useControlledReducer$1(downshiftMultipleSelectionReducer, getInitialState(props), props),\n      state = _useControlledReducer[0],\n      dispatch = _useControlledReducer[1];\n\n  var activeIndex = state.activeIndex,\n      selectedItems = state.selectedItems; // Refs.\n\n  var isInitialMountRef = useRef(true);\n  var dropdownRef = useRef(null);\n  var previousSelectedItemsRef = useRef(selectedItems);\n  var selectedItemRefs = useRef();\n  selectedItemRefs.current = [];\n  var latest = useLatestRef({\n    state: state,\n    props: props\n  }); // Effects.\n\n  /* Sets a11y status message on changes in selectedItem. */\n\n  useEffect(function () {\n    if (isInitialMountRef.current) {\n      return;\n    }\n\n    if (selectedItems.length < previousSelectedItemsRef.current.length) {\n      var removedSelectedItem = previousSelectedItemsRef.current.find(function (item) {\n        return selectedItems.indexOf(item) < 0;\n      });\n      setStatus(getA11yRemovalMessage({\n        itemToString: itemToString,\n        resultCount: selectedItems.length,\n        removedSelectedItem: removedSelectedItem,\n        activeIndex: activeIndex,\n        activeSelectedItem: selectedItems[activeIndex]\n      }), environment.document);\n    }\n\n    previousSelectedItemsRef.current = selectedItems; // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [selectedItems.length]); // Sets focus on active item.\n\n  useEffect(function () {\n    if (isInitialMountRef.current) {\n      return;\n    }\n\n    if (activeIndex === -1 && dropdownRef.current) {\n      dropdownRef.current.focus();\n    } else if (selectedItemRefs.current[activeIndex]) {\n      selectedItemRefs.current[activeIndex].focus();\n    }\n  }, [activeIndex]);\n  useControlPropsValidator({\n    isInitialMount: isInitialMountRef.current,\n    props: props,\n    state: state\n  });\n  var setGetterPropCallInfo = useGetterPropsCalledChecker('getDropdownProps'); // Make initial ref false.\n\n  useEffect(function () {\n    isInitialMountRef.current = false;\n  }, []); // Event handler functions.\n\n  var selectedItemKeyDownHandlers = useMemo(function () {\n    var _ref;\n\n    return _ref = {}, _ref[keyNavigationPrevious] = function () {\n      dispatch({\n        type: SelectedItemKeyDownNavigationPrevious\n      });\n    }, _ref[keyNavigationNext] = function () {\n      dispatch({\n        type: SelectedItemKeyDownNavigationNext\n      });\n    }, _ref.Delete = function Delete() {\n      dispatch({\n        type: SelectedItemKeyDownDelete\n      });\n    }, _ref.Backspace = function Backspace() {\n      dispatch({\n        type: SelectedItemKeyDownBackspace\n      });\n    }, _ref;\n  }, [dispatch, keyNavigationNext, keyNavigationPrevious]);\n  var dropdownKeyDownHandlers = useMemo(function () {\n    var _ref2;\n\n    return _ref2 = {}, _ref2[keyNavigationPrevious] = function (event) {\n      if (isKeyDownOperationPermitted(event)) {\n        dispatch({\n          type: DropdownKeyDownNavigationPrevious\n        });\n      }\n    }, _ref2.Backspace = function Backspace(event) {\n      if (isKeyDownOperationPermitted(event)) {\n        dispatch({\n          type: DropdownKeyDownBackspace\n        });\n      }\n    }, _ref2;\n  }, [dispatch, keyNavigationPrevious]); // Getter props.\n\n  var getSelectedItemProps = useCallback(function (_temp) {\n    var _extends2;\n\n    var _ref3 = _temp === void 0 ? {} : _temp,\n        _ref3$refKey = _ref3.refKey,\n        refKey = _ref3$refKey === void 0 ? 'ref' : _ref3$refKey,\n        ref = _ref3.ref,\n        onClick = _ref3.onClick,\n        onKeyDown = _ref3.onKeyDown,\n        selectedItem = _ref3.selectedItem,\n        index = _ref3.index,\n        rest = _objectWithoutPropertiesLoose(_ref3, _excluded);\n\n    var latestState = latest.current.state;\n    var itemIndex = getItemIndex(index, selectedItem, latestState.selectedItems);\n\n    if (itemIndex < 0) {\n      throw new Error('Pass either selectedItem or index in getSelectedItemProps!');\n    }\n\n    var selectedItemHandleClick = function selectedItemHandleClick() {\n      dispatch({\n        type: SelectedItemClick,\n        index: index\n      });\n    };\n\n    var selectedItemHandleKeyDown = function selectedItemHandleKeyDown(event) {\n      var key = normalizeArrowKey(event);\n\n      if (key && selectedItemKeyDownHandlers[key]) {\n        selectedItemKeyDownHandlers[key](event);\n      }\n    };\n\n    return _extends((_extends2 = {}, _extends2[refKey] = handleRefs(ref, function (selectedItemNode) {\n      if (selectedItemNode) {\n        selectedItemRefs.current.push(selectedItemNode);\n      }\n    }), _extends2.tabIndex = index === latestState.activeIndex ? 0 : -1, _extends2.onClick = callAllEventHandlers(onClick, selectedItemHandleClick), _extends2.onKeyDown = callAllEventHandlers(onKeyDown, selectedItemHandleKeyDown), _extends2), rest);\n  }, [dispatch, latest, selectedItemKeyDownHandlers]);\n  var getDropdownProps = useCallback(function (_temp2, _temp3) {\n    var _extends3;\n\n    var _ref4 = _temp2 === void 0 ? {} : _temp2,\n        _ref4$refKey = _ref4.refKey,\n        refKey = _ref4$refKey === void 0 ? 'ref' : _ref4$refKey,\n        ref = _ref4.ref,\n        onKeyDown = _ref4.onKeyDown,\n        onClick = _ref4.onClick,\n        _ref4$preventKeyActio = _ref4.preventKeyAction,\n        preventKeyAction = _ref4$preventKeyActio === void 0 ? false : _ref4$preventKeyActio,\n        rest = _objectWithoutPropertiesLoose(_ref4, _excluded2);\n\n    var _ref5 = _temp3 === void 0 ? {} : _temp3,\n        _ref5$suppressRefErro = _ref5.suppressRefError,\n        suppressRefError = _ref5$suppressRefErro === void 0 ? false : _ref5$suppressRefErro;\n\n    setGetterPropCallInfo('getDropdownProps', suppressRefError, refKey, dropdownRef);\n\n    var dropdownHandleKeyDown = function dropdownHandleKeyDown(event) {\n      var key = normalizeArrowKey(event);\n\n      if (key && dropdownKeyDownHandlers[key]) {\n        dropdownKeyDownHandlers[key](event);\n      }\n    };\n\n    var dropdownHandleClick = function dropdownHandleClick() {\n      dispatch({\n        type: DropdownClick\n      });\n    };\n\n    return _extends((_extends3 = {}, _extends3[refKey] = handleRefs(ref, function (dropdownNode) {\n      if (dropdownNode) {\n        dropdownRef.current = dropdownNode;\n      }\n    }), _extends3), !preventKeyAction && {\n      onKeyDown: callAllEventHandlers(onKeyDown, dropdownHandleKeyDown),\n      onClick: callAllEventHandlers(onClick, dropdownHandleClick)\n    }, rest);\n  }, [dispatch, dropdownKeyDownHandlers, setGetterPropCallInfo]); // returns\n\n  var addSelectedItem = useCallback(function (selectedItem) {\n    dispatch({\n      type: FunctionAddSelectedItem,\n      selectedItem: selectedItem\n    });\n  }, [dispatch]);\n  var removeSelectedItem = useCallback(function (selectedItem) {\n    dispatch({\n      type: FunctionRemoveSelectedItem,\n      selectedItem: selectedItem\n    });\n  }, [dispatch]);\n  var setSelectedItems = useCallback(function (newSelectedItems) {\n    dispatch({\n      type: FunctionSetSelectedItems,\n      selectedItems: newSelectedItems\n    });\n  }, [dispatch]);\n  var setActiveIndex = useCallback(function (newActiveIndex) {\n    dispatch({\n      type: FunctionSetActiveIndex,\n      activeIndex: newActiveIndex\n    });\n  }, [dispatch]);\n  var reset = useCallback(function () {\n    dispatch({\n      type: FunctionReset\n    });\n  }, [dispatch]);\n  return {\n    getSelectedItemProps: getSelectedItemProps,\n    getDropdownProps: getDropdownProps,\n    addSelectedItem: addSelectedItem,\n    removeSelectedItem: removeSelectedItem,\n    setSelectedItems: setSelectedItems,\n    setActiveIndex: setActiveIndex,\n    reset: reset,\n    selectedItems: selectedItems,\n    activeIndex: activeIndex\n  };\n}\n\nexport { Downshift$1 as default, resetIdCounter, useCombobox, useMultipleSelection, useSelect };\n","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createPortal, useState, useEffect, useRef, createElement, Component, Fragment } from '@wordpress/element';\nimport { maybeTransformUnorderedChoices } from '../helpers/parse-choices.js';\nimport Downshift from 'downshift';\nimport classnames from 'classnames';\nimport { __ } from 'ct-i18n';\nimport usePopoverMaker from '../helpers/usePopoverMaker';\n\nconst Select = _ref => {\n  var _maybeSelectedItem;\n\n  let {\n    value,\n    option,\n    option: {\n      choices,\n      tabletChoices,\n      mobileChoices,\n      placeholder,\n      searchPlaceholder,\n      defaultToFirstItem = true,\n      search = false,\n      inputClassName = '',\n      selectInputStart,\n      appendToBody = false\n    },\n    onInputValueChange = () => {},\n    renderItemFor = item => item.value,\n    onChange,\n    device = 'desktop'\n  } = _ref;\n  const inputRef = useRef(null);\n  const [tempState, setTempState] = useState(null);\n  let deviceChoices = choices;\n\n  if (device === 'tablet' && tabletChoices) {\n    deviceChoices = tabletChoices;\n  }\n\n  if (device === 'mobile' && mobileChoices) {\n    deviceChoices = mobileChoices;\n  }\n\n  const orderedChoices = maybeTransformUnorderedChoices(deviceChoices);\n  let potentialValue = value || !defaultToFirstItem ? value : parseInt(value, 10) === 0 ? value : (orderedChoices[0] || {}).key;\n  const {\n    styles,\n    popoverProps\n  } = usePopoverMaker({\n    ref: inputRef,\n    defaultHeight: 228,\n    shouldCalculate: appendToBody\n  });\n  useEffect(() => {\n    if (!appendToBody) {\n      return;\n    }\n\n    setTimeout(() => {\n      setTempState(Math.round());\n    }, 50);\n  }, []);\n  let maybeSelectedItem = orderedChoices.find(_ref2 => {\n    let {\n      key\n    } = _ref2;\n    return key === potentialValue;\n  });\n\n  if (!maybeSelectedItem) {\n    maybeSelectedItem = orderedChoices.find(_ref3 => {\n      let {\n        key\n      } = _ref3;\n      return parseInt(key) === parseInt(potentialValue);\n    });\n  }\n\n  return createElement(Downshift, {\n    key: ((_maybeSelectedItem = maybeSelectedItem) === null || _maybeSelectedItem === void 0 ? void 0 : _maybeSelectedItem.key) || 'downshift',\n    onInputValueChange: value => {\n      onInputValueChange(value);\n    },\n    selectedItem: maybeSelectedItem || !defaultToFirstItem ? potentialValue : (orderedChoices[0] || {}).key,\n    onChange: selection => {\n      onChange(selection);\n    },\n    itemToString: item => {\n      let maybeSelectedItem = orderedChoices.find(_ref4 => {\n        let {\n          key\n        } = _ref4;\n        return key === item;\n      });\n\n      if (!maybeSelectedItem) {\n        maybeSelectedItem = orderedChoices.find(_ref5 => {\n          let {\n            key\n          } = _ref5;\n          return parseInt(key) === parseInt(item);\n        });\n      }\n\n      return item && maybeSelectedItem ? maybeSelectedItem.value : '';\n    }\n  }, _ref6 => {\n    let {\n      getInputProps,\n      getItemProps,\n      getLabelProps,\n      getMenuProps,\n      isOpen,\n      inputValue,\n      highlightedIndex,\n      selectedItem,\n      openMenu,\n      toggleMenu,\n      setState\n    } = _ref6;\n    let dropdown = null;\n\n    if (isOpen) {\n      dropdown = createElement(\"div\", _extends({}, getMenuProps(_objectSpread({\n        className: classnames('ct-select-dropdown', {\n          'ct-fixed': appendToBody\n        })\n      }, appendToBody ? popoverProps : {})), {\n        style: appendToBody ? styles : {}\n      }), orderedChoices.filter(item => !inputValue || orderedChoices.find(_ref7 => {\n        let {\n          key\n        } = _ref7;\n        return key.toString() === selectedItem.toString();\n      }) && orderedChoices.find(_ref8 => {\n        let {\n          key\n        } = _ref8;\n        return key.toString() === selectedItem.toString();\n      }).value === inputValue || item.value.toLowerCase().includes(inputValue.toLowerCase()) || item.key.toString().toLowerCase().includes(inputValue.toString().toLowerCase())).map((item, index) => createElement(Fragment, {\n        key: index\n      }, item.group && (index === 0 || orderedChoices[index - 1].group !== orderedChoices[index].group) && createElement(\"div\", {\n        className: \"ct-select-dropdown-group\",\n        key: `${index}-group`\n      }, item.group), createElement(\"div\", getItemProps({\n        key: item.key,\n        index,\n        item: item.key,\n        className: classnames('ct-select-dropdown-item', {\n          active: highlightedIndex === index,\n          selected: selectedItem === item.key\n        })\n      }), renderItemFor(item)))));\n\n      if (appendToBody) {\n        dropdown = createPortal(dropdown, document.body);\n      }\n    }\n\n    return createElement(\"div\", {\n      className: classnames('ct-select-input 1', inputClassName)\n    }, selectInputStart && selectInputStart(), createElement(\"input\", _extends({}, getInputProps({\n      onKeyDown: e => {\n        if (e.key === 'ArrowDown' && search && !isOpen) {\n          setState({\n            inputValue: ''\n          });\n        }\n      },\n      onClick: () => {\n        toggleMenu();\n        setTimeout(() => {\n          let popover;\n\n          if (appendToBody) {\n            popover = document.querySelector('body > .ct-select-dropdown.ct-fixed .ct-select-dropdown-item.selected');\n          } else {\n            popover = inputRef.current.closest('.ct-select-input').querySelector('.ct-select-dropdown .ct-select-dropdown-item.selected');\n          }\n\n          if (popover) {\n            let popoverTop = popover.parentNode.getBoundingClientRect().top;\n            let itemTop = popover.getBoundingClientRect().top;\n            popover.parentNode.scrollTop = itemTop - popoverTop;\n          }\n        });\n        setTimeout(() => {\n          setTempState(Math.round());\n        }, 50);\n\n        if (search) {\n          setState({\n            inputValue: ''\n          });\n        }\n      },\n      ref: inputRef\n    }), {\n      placeholder: search && isOpen ? searchPlaceholder || __('Type to search...', 'blocksy') : placeholder || __('Select value...', 'blocksy'),\n      readOnly: search ? !isOpen : true\n    })), dropdown);\n  });\n};\n\nexport default Select;"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///1404\n')},8252:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (/* binding */ Slider)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(4184);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var simple_linear_scale__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(6399);\n/* harmony import */ var simple_linear_scale__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(simple_linear_scale__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _react_outside_click_handler__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(8204);\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\nconst clamp = (min, max, value) => Math.max(min, Math.min(max, value));\n\nconst clampMax = (max, value) => Math.min(max, value);\n\nconst round = function (value) {\n let decimalPlaces = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;\n // return Math.round(value)\n const multiplier = Math.pow(10, decimalPlaces);\n const rounded = Math.round(value * multiplier + Number.EPSILON) / multiplier;\n return rounded;\n};\n\nvar roundWholeNumbers = function (num, precision) {\n num = parseFloat(num);\n if (!precision) return num;\n return Math.round(num / precision) * precision;\n};\n\nconst UnitsList = _ref => {\n let {\n option,\n onChange,\n is_open,\n toggleOpen,\n currentUnit,\n getNumericValue,\n getAllowedDecimalPlaces\n } = _ref;\n\n const pickUnit = unit => {\n const numericValue = getNumericValue();\n onChange(`${round(clamp(option.units.find(_ref2 => {\n let {\n unit: u\n } = _ref2;\n return u === unit;\n }).min, option.units.find(_ref3 => {\n let {\n unit: u\n } = _ref3;\n return u === unit;\n }).max, numericValue === \'\' ? -Infinity : numericValue), getAllowedDecimalPlaces(unit))}${unit}`);\n };\n\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("span", {\n onClick: () => toggleOpen(),\n className: "ct-current-value"\n }, currentUnit || \'―\'), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_react_outside_click_handler__WEBPACK_IMPORTED_MODULE_3__["default"], {\n onOutsideClick: () => {\n if (!is_open) {\n return;\n }\n\n toggleOpen();\n }\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("ul", {\n className: "ct-units-list"\n }, option.units.filter(_ref4 => {\n let {\n unit\n } = _ref4;\n return unit !== currentUnit;\n }).reduce((current, el, index) => [...current.slice(0, index % 2 === 0 ? undefined : -1), ...(index % 2 === 0 ? [[el]] : [[current[current.length - 1][0], el]])], []).map(group => (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("li", {\n key: group[0].unit\n }, group.map(_ref5 => {\n let {\n unit\n } = _ref5;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("span", {\n key: unit,\n onClick: () => {\n pickUnit(unit);\n toggleOpen();\n }\n }, unit || \'―\');\n }))))));\n};\n\nclass Slider extends _wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Component {\n constructor() {\n var _this;\n\n super(...arguments);\n _this = this;\n\n _defineProperty(this, "state", {\n is_dragging: false,\n is_open: false\n });\n\n _defineProperty(this, "el", (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createRef)());\n\n _defineProperty(this, "hasUnitsList", () => this.props.option.units && this.props.option.units.length > 1);\n\n _defineProperty(this, "getAllowedDecimalPlaces", function () {\n let properUnit = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null;\n const decimals = _this.props.option.units ? _this.props.option.units.find(_ref6 => {\n let {\n unit\n } = _ref6;\n return unit === (properUnit || _this.getCurrentUnit());\n }).decimals : _this.props.option.decimals;\n return decimals !== 0 && !decimals ? 0 : decimals;\n });\n\n _defineProperty(this, "withDefault", (currentUnit, defaultUnit) => this.props.option.units ? this.props.option.units.find(_ref7 => {\n let {\n unit\n } = _ref7;\n return unit === currentUnit;\n }) ? currentUnit : currentUnit || defaultUnit : currentUnit || defaultUnit);\n\n _defineProperty(this, "getCurrentUnit", () => {\n let defaultUnit = this.props.option.units ? this.props.option.units[0].unit : \'\';\n\n if (this.props.value === \'NaN\' || this.props.value === \'\') {\n return defaultUnit;\n }\n\n return this.props.option.units ? this.withDefault(this.props.value.toString().replace(/[0-9]/g, \'\').replace(/\\-/g, \'\').replace(/\\./g, \'\').replace(\'CT_CSS_SKIP_RULE\', \'\'), this.props.option.units[0].unit) : \'\';\n });\n\n _defineProperty(this, "getMax", () => this.props.option.units ? this.props.option.units.find(_ref8 => {\n let {\n unit\n } = _ref8;\n return unit === this.getCurrentUnit();\n }).max : this.props.option.max);\n\n _defineProperty(this, "getMin", () => {\n return this.props.option.units ? this.props.option.units.find(_ref9 => {\n let {\n unit\n } = _ref9;\n return unit === this.getCurrentUnit();\n }).min : this.props.option.min;\n });\n\n _defineProperty(this, "getNumericValue", function () {\n let {\n forPosition = false\n } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n const maybeValue = parseFloat(_this.props.value, 10);\n\n if (maybeValue === 0) {\n return maybeValue;\n }\n\n if (!maybeValue) {\n if (_this.props.option.defaultPosition && _this.props.option.defaultPosition === \'center\' && forPosition) {\n let min = parseFloat(_this.getMin(), 10);\n let max = parseFloat(_this.getMax(), 10);\n return (max - min) / 2 + min;\n }\n\n return \'\';\n }\n\n return maybeValue;\n });\n\n _defineProperty(this, "handleMove", event => {\n if (!this.state.is_dragging) return;\n this.computeAndSendNewValue(event);\n });\n\n _defineProperty(this, "handleUp", () => {\n this.setState({\n is_dragging: false\n });\n this.detachEvents();\n });\n\n _defineProperty(this, "handleBlur", () => {\n if (this.props.option.value === \'CT_CSS_SKIP_RULE\') {\n if (this.props.value === \'CT_CSS_SKIP_RULE\') {\n return;\n }\n\n if (this.getNumericValue() === \'\') {\n this.props.onChange(\'CT_CSS_SKIP_RULE\');\n return;\n }\n }\n\n if (this.props.value.toString().trim() === \'\') {\n this.props.onChange(this.props.option.value);\n return;\n }\n\n this.props.onChange(`${clamp(parseFloat(this.getMin(), 10), parseFloat(this.getMax(), 10), parseFloat(this.getNumericValue(), 10))}${this.getCurrentUnit()}`);\n });\n\n _defineProperty(this, "handleChange", value => {\n if (this.props.option.value === \'CT_CSS_SKIP_RULE\') {\n if (value.toString().trim() === \'\') {\n this.props.onChange(\'CT_CSS_SKIP_RULE\');\n return;\n }\n }\n\n if (value.toString().trim() === \'\') {\n this.props.onChange(\'\');\n return;\n }\n\n this.props.onChange(`${clampMax(parseFloat(this.getMax(), 10), parseFloat(value || this.getMin()))}${this.getCurrentUnit()}`);\n });\n }\n\n computeAndSendNewValue(_ref10) {\n let {\n pageX,\n shiftKey\n } = _ref10;\n let {\n top,\n left,\n right,\n width\n } = this.el.current.getBoundingClientRect();\n let elLeftOffset = pageX - left - pageXOffset;\n this.props.onChange(`${roundWholeNumbers(round(simple_linear_scale__WEBPACK_IMPORTED_MODULE_2___default()([0, width], [parseFloat(this.getMin(), 10), parseFloat(this.getMax(), 10)], true)(document.body.classList.contains(\'rtl\') ? width - elLeftOffset : elLeftOffset), this.getAllowedDecimalPlaces()), shiftKey ? 10 : 1)}${this.getCurrentUnit()}`);\n }\n\n attachEvents() {\n document.documentElement.addEventListener(\'mousemove\', this.handleMove, true);\n document.documentElement.addEventListener(\'mouseup\', this.handleUp, true);\n }\n\n detachEvents() {\n document.documentElement.removeEventListener(\'mousemove\', this.handleMove, true);\n document.documentElement.removeEventListener(\'mouseup\', this.handleUp, true);\n }\n\n render() {\n const leftValue = `${simple_linear_scale__WEBPACK_IMPORTED_MODULE_2___default()([parseFloat(this.getMin(), 10), parseFloat(this.getMax(), 10)], [0, 100])(clamp(parseFloat(this.getMin(), 10), parseFloat(this.getMax(), 10), parseFloat(this.getNumericValue({\n forPosition: true\n }), 10) === 0 ? 0 : parseFloat(this.getNumericValue({\n forPosition: true\n }), 10) ? parseFloat(this.getNumericValue({\n forPosition: true\n }), 10) : parseFloat(this.getMin(), 10)))}`;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", {\n className: "ct-option-slider"\n }, this.props.beforeOption && this.props.beforeOption(), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", _extends({\n onMouseDown: _ref11 => {\n let {\n pageX,\n pageY\n } = _ref11;\n this.attachEvents();\n this.setState({\n is_dragging: true\n });\n },\n onClick: e => this.computeAndSendNewValue(e),\n ref: this.el,\n className: "ct-slider"\n }, this.props.option.steps ? {\n [\'data-steps\']: \'\'\n } : {}), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", {\n style: {\n width: `${leftValue}%`\n }\n }), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("span", {\n tabIndex: "0",\n onKeyDown: e => {\n const valueForComputation = this.getNumericValue();\n let step = 1 / Math.pow(10, this.getAllowedDecimalPlaces());\n let actualStep = e.shiftKey ? step * 10 : step;\n /**\n * Arrow up or left\n */\n\n if (e.keyCode === 38 || e.keyCode === 39) {\n e.preventDefault();\n this.props.onChange(`${clamp(parseFloat(this.getMin(), 10), parseFloat(this.getMax(), 10), valueForComputation + actualStep)}${this.getCurrentUnit()}`);\n }\n /**\n * Arrow down or right\n */\n\n\n if (e.keyCode === 40 || e.keyCode === 37) {\n e.preventDefault();\n this.props.onChange(`${clamp(parseFloat(this.getMin(), 10), parseFloat(this.getMax(), 10), valueForComputation - actualStep)}${this.getCurrentUnit()}`);\n }\n },\n style: {\n \'--position\': `${leftValue}%`\n }\n }), this.props.option.steps && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("section", {\n className: this.props.option.steps\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("i", {\n className: "minus"\n }), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("i", {\n className: "zero"\n }), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("i", {\n className: "plus"\n }))), !this.props.option.skipInput && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()(\'ct-slider-input\', {\n // [\'ct-unit-changer\']: !!this.props.option.units,\n [\'ct-value-changer\']: true,\n \'no-unit-list\': !this.hasUnitsList(),\n active: this.state.is_open\n })\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("input", _extends({\n type: "number"\n }, this.props.option.ref ? {\n ref: this.props.option.ref\n } : {}, {\n step: 1 / Math.pow(10, this.getAllowedDecimalPlaces()),\n value: this.getNumericValue(),\n onBlur: () => this.handleBlur(),\n onChange: _ref12 => {\n let {\n target: {\n value\n }\n } = _ref12;\n return this.handleChange(value);\n }\n })), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("span", {\n className: "ct-value-divider"\n }), !this.hasUnitsList() && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("span", {\n className: "ct-current-value"\n }, this.withDefault(this.getCurrentUnit(), this.props.option.defaultUnit || \'px\')), this.hasUnitsList() && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(UnitsList, {\n option: this.props.option,\n onChange: this.props.onChange,\n is_open: this.state.is_open,\n toggleOpen: () => this.setState({\n is_open: !this.state.is_open\n }),\n currentUnit: this.getCurrentUnit(),\n getNumericValue: this.getNumericValue,\n getAllowedDecimalPlaces: this.getAllowedDecimalPlaces\n })));\n }\n\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"8252.js","mappings":";;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./static/js/options/options/ct-slider.js?37c9"],"sourcesContent":["function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, Component, createRef, Fragment } from '@wordpress/element';\nimport classnames from 'classnames';\nimport linearScale from 'simple-linear-scale';\nimport OutsideClickHandler from './react-outside-click-handler';\n\nconst clamp = (min, max, value) => Math.max(min, Math.min(max, value));\n\nconst clampMax = (max, value) => Math.min(max, value);\n\nconst round = function (value) {\n  let decimalPlaces = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;\n  // return Math.round(value)\n  const multiplier = Math.pow(10, decimalPlaces);\n  const rounded = Math.round(value * multiplier + Number.EPSILON) / multiplier;\n  return rounded;\n};\n\nvar roundWholeNumbers = function (num, precision) {\n  num = parseFloat(num);\n  if (!precision) return num;\n  return Math.round(num / precision) * precision;\n};\n\nconst UnitsList = _ref => {\n  let {\n    option,\n    onChange,\n    is_open,\n    toggleOpen,\n    currentUnit,\n    getNumericValue,\n    getAllowedDecimalPlaces\n  } = _ref;\n\n  const pickUnit = unit => {\n    const numericValue = getNumericValue();\n    onChange(`${round(clamp(option.units.find(_ref2 => {\n      let {\n        unit: u\n      } = _ref2;\n      return u === unit;\n    }).min, option.units.find(_ref3 => {\n      let {\n        unit: u\n      } = _ref3;\n      return u === unit;\n    }).max, numericValue === '' ? -Infinity : numericValue), getAllowedDecimalPlaces(unit))}${unit}`);\n  };\n\n  return createElement(Fragment, null, createElement(\"span\", {\n    onClick: () => toggleOpen(),\n    className: \"ct-current-value\"\n  }, currentUnit || '―'), createElement(OutsideClickHandler, {\n    onOutsideClick: () => {\n      if (!is_open) {\n        return;\n      }\n\n      toggleOpen();\n    }\n  }, createElement(\"ul\", {\n    className: \"ct-units-list\"\n  }, option.units.filter(_ref4 => {\n    let {\n      unit\n    } = _ref4;\n    return unit !== currentUnit;\n  }).reduce((current, el, index) => [...current.slice(0, index % 2 === 0 ? undefined : -1), ...(index % 2 === 0 ? [[el]] : [[current[current.length - 1][0], el]])], []).map(group => createElement(\"li\", {\n    key: group[0].unit\n  }, group.map(_ref5 => {\n    let {\n      unit\n    } = _ref5;\n    return createElement(\"span\", {\n      key: unit,\n      onClick: () => {\n        pickUnit(unit);\n        toggleOpen();\n      }\n    }, unit || '―');\n  }))))));\n};\n\nexport default class Slider extends Component {\n  constructor() {\n    var _this;\n\n    super(...arguments);\n    _this = this;\n\n    _defineProperty(this, \"state\", {\n      is_dragging: false,\n      is_open: false\n    });\n\n    _defineProperty(this, \"el\", createRef());\n\n    _defineProperty(this, \"hasUnitsList\", () => this.props.option.units && this.props.option.units.length > 1);\n\n    _defineProperty(this, \"getAllowedDecimalPlaces\", function () {\n      let properUnit = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null;\n      const decimals = _this.props.option.units ? _this.props.option.units.find(_ref6 => {\n        let {\n          unit\n        } = _ref6;\n        return unit === (properUnit || _this.getCurrentUnit());\n      }).decimals : _this.props.option.decimals;\n      return decimals !== 0 && !decimals ? 0 : decimals;\n    });\n\n    _defineProperty(this, \"withDefault\", (currentUnit, defaultUnit) => this.props.option.units ? this.props.option.units.find(_ref7 => {\n      let {\n        unit\n      } = _ref7;\n      return unit === currentUnit;\n    }) ? currentUnit : currentUnit || defaultUnit : currentUnit || defaultUnit);\n\n    _defineProperty(this, \"getCurrentUnit\", () => {\n      let defaultUnit = this.props.option.units ? this.props.option.units[0].unit : '';\n\n      if (this.props.value === 'NaN' || this.props.value === '') {\n        return defaultUnit;\n      }\n\n      return this.props.option.units ? this.withDefault(this.props.value.toString().replace(/[0-9]/g, '').replace(/\\-/g, '').replace(/\\./g, '').replace('CT_CSS_SKIP_RULE', ''), this.props.option.units[0].unit) : '';\n    });\n\n    _defineProperty(this, \"getMax\", () => this.props.option.units ? this.props.option.units.find(_ref8 => {\n      let {\n        unit\n      } = _ref8;\n      return unit === this.getCurrentUnit();\n    }).max : this.props.option.max);\n\n    _defineProperty(this, \"getMin\", () => {\n      return this.props.option.units ? this.props.option.units.find(_ref9 => {\n        let {\n          unit\n        } = _ref9;\n        return unit === this.getCurrentUnit();\n      }).min : this.props.option.min;\n    });\n\n    _defineProperty(this, \"getNumericValue\", function () {\n      let {\n        forPosition = false\n      } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n      const maybeValue = parseFloat(_this.props.value, 10);\n\n      if (maybeValue === 0) {\n        return maybeValue;\n      }\n\n      if (!maybeValue) {\n        if (_this.props.option.defaultPosition && _this.props.option.defaultPosition === 'center' && forPosition) {\n          let min = parseFloat(_this.getMin(), 10);\n          let max = parseFloat(_this.getMax(), 10);\n          return (max - min) / 2 + min;\n        }\n\n        return '';\n      }\n\n      return maybeValue;\n    });\n\n    _defineProperty(this, \"handleMove\", event => {\n      if (!this.state.is_dragging) return;\n      this.computeAndSendNewValue(event);\n    });\n\n    _defineProperty(this, \"handleUp\", () => {\n      this.setState({\n        is_dragging: false\n      });\n      this.detachEvents();\n    });\n\n    _defineProperty(this, \"handleBlur\", () => {\n      if (this.props.option.value === 'CT_CSS_SKIP_RULE') {\n        if (this.props.value === 'CT_CSS_SKIP_RULE') {\n          return;\n        }\n\n        if (this.getNumericValue() === '') {\n          this.props.onChange('CT_CSS_SKIP_RULE');\n          return;\n        }\n      }\n\n      if (this.props.value.toString().trim() === '') {\n        this.props.onChange(this.props.option.value);\n        return;\n      }\n\n      this.props.onChange(`${clamp(parseFloat(this.getMin(), 10), parseFloat(this.getMax(), 10), parseFloat(this.getNumericValue(), 10))}${this.getCurrentUnit()}`);\n    });\n\n    _defineProperty(this, \"handleChange\", value => {\n      if (this.props.option.value === 'CT_CSS_SKIP_RULE') {\n        if (value.toString().trim() === '') {\n          this.props.onChange('CT_CSS_SKIP_RULE');\n          return;\n        }\n      }\n\n      if (value.toString().trim() === '') {\n        this.props.onChange('');\n        return;\n      }\n\n      this.props.onChange(`${clampMax(parseFloat(this.getMax(), 10), parseFloat(value || this.getMin()))}${this.getCurrentUnit()}`);\n    });\n  }\n\n  computeAndSendNewValue(_ref10) {\n    let {\n      pageX,\n      shiftKey\n    } = _ref10;\n    let {\n      top,\n      left,\n      right,\n      width\n    } = this.el.current.getBoundingClientRect();\n    let elLeftOffset = pageX - left - pageXOffset;\n    this.props.onChange(`${roundWholeNumbers(round(linearScale([0, width], [parseFloat(this.getMin(), 10), parseFloat(this.getMax(), 10)], true)(document.body.classList.contains('rtl') ? width - elLeftOffset : elLeftOffset), this.getAllowedDecimalPlaces()), shiftKey ? 10 : 1)}${this.getCurrentUnit()}`);\n  }\n\n  attachEvents() {\n    document.documentElement.addEventListener('mousemove', this.handleMove, true);\n    document.documentElement.addEventListener('mouseup', this.handleUp, true);\n  }\n\n  detachEvents() {\n    document.documentElement.removeEventListener('mousemove', this.handleMove, true);\n    document.documentElement.removeEventListener('mouseup', this.handleUp, true);\n  }\n\n  render() {\n    const leftValue = `${linearScale([parseFloat(this.getMin(), 10), parseFloat(this.getMax(), 10)], [0, 100])(clamp(parseFloat(this.getMin(), 10), parseFloat(this.getMax(), 10), parseFloat(this.getNumericValue({\n      forPosition: true\n    }), 10) === 0 ? 0 : parseFloat(this.getNumericValue({\n      forPosition: true\n    }), 10) ? parseFloat(this.getNumericValue({\n      forPosition: true\n    }), 10) : parseFloat(this.getMin(), 10)))}`;\n    return createElement(\"div\", {\n      className: \"ct-option-slider\"\n    }, this.props.beforeOption && this.props.beforeOption(), createElement(\"div\", _extends({\n      onMouseDown: _ref11 => {\n        let {\n          pageX,\n          pageY\n        } = _ref11;\n        this.attachEvents();\n        this.setState({\n          is_dragging: true\n        });\n      },\n      onClick: e => this.computeAndSendNewValue(e),\n      ref: this.el,\n      className: \"ct-slider\"\n    }, this.props.option.steps ? {\n      ['data-steps']: ''\n    } : {}), createElement(\"div\", {\n      style: {\n        width: `${leftValue}%`\n      }\n    }), createElement(\"span\", {\n      tabIndex: \"0\",\n      onKeyDown: e => {\n        const valueForComputation = this.getNumericValue();\n        let step = 1 / Math.pow(10, this.getAllowedDecimalPlaces());\n        let actualStep = e.shiftKey ? step * 10 : step;\n        /**\n         * Arrow up or left\n         */\n\n        if (e.keyCode === 38 || e.keyCode === 39) {\n          e.preventDefault();\n          this.props.onChange(`${clamp(parseFloat(this.getMin(), 10), parseFloat(this.getMax(), 10), valueForComputation + actualStep)}${this.getCurrentUnit()}`);\n        }\n        /**\n         * Arrow down or right\n         */\n\n\n        if (e.keyCode === 40 || e.keyCode === 37) {\n          e.preventDefault();\n          this.props.onChange(`${clamp(parseFloat(this.getMin(), 10), parseFloat(this.getMax(), 10), valueForComputation - actualStep)}${this.getCurrentUnit()}`);\n        }\n      },\n      style: {\n        '--position': `${leftValue}%`\n      }\n    }), this.props.option.steps && createElement(\"section\", {\n      className: this.props.option.steps\n    }, createElement(\"i\", {\n      className: \"minus\"\n    }), createElement(\"i\", {\n      className: \"zero\"\n    }), createElement(\"i\", {\n      className: \"plus\"\n    }))), !this.props.option.skipInput && createElement(\"div\", {\n      className: classnames('ct-slider-input', {\n        // ['ct-unit-changer']: !!this.props.option.units,\n        ['ct-value-changer']: true,\n        'no-unit-list': !this.hasUnitsList(),\n        active: this.state.is_open\n      })\n    }, createElement(\"input\", _extends({\n      type: \"number\"\n    }, this.props.option.ref ? {\n      ref: this.props.option.ref\n    } : {}, {\n      step: 1 / Math.pow(10, this.getAllowedDecimalPlaces()),\n      value: this.getNumericValue(),\n      onBlur: () => this.handleBlur(),\n      onChange: _ref12 => {\n        let {\n          target: {\n            value\n          }\n        } = _ref12;\n        return this.handleChange(value);\n      }\n    })), createElement(\"span\", {\n      className: \"ct-value-divider\"\n    }), !this.hasUnitsList() && createElement(\"span\", {\n      className: \"ct-current-value\"\n    }, this.withDefault(this.getCurrentUnit(), this.props.option.defaultUnit || 'px')), this.hasUnitsList() && createElement(UnitsList, {\n      option: this.props.option,\n      onChange: this.props.onChange,\n      is_open: this.state.is_open,\n      toggleOpen: () => this.setState({\n        is_open: !this.state.is_open\n      }),\n      currentUnit: this.getCurrentUnit(),\n      getNumericValue: this.getNumericValue,\n      getAllowedDecimalPlaces: this.getAllowedDecimalPlaces\n    })));\n  }\n\n}"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///8252\n')},1282:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(4184);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\nconst _excluded = ["class"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\n\n\n\nconst Spacer = _ref => {\n let {\n option: {\n height = 10,\n attr: {\n class: className\n } = {}\n }\n } = _ref,\n attr = _objectWithoutProperties(_ref.option.attr, _excluded);\n\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", _extends({\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()(\'ct-spacer\', className)\n }, attr, {\n style: {\n height: `${height}px`\n }\n }));\n};\n\nSpacer.renderingConfig = {\n design: \'none\'\n};\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Spacer);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTI4Mi5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9ibG9ja3N5T3B0aW9ucy8uL3N0YXRpYy9qcy9vcHRpb25zL29wdGlvbnMvY3Qtc3BhY2VyLmpzPzE4MGIiXSwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgX2V4Y2x1ZGVkID0gW1wiY2xhc3NcIl07XG5cbmZ1bmN0aW9uIF9leHRlbmRzKCkgeyBfZXh0ZW5kcyA9IE9iamVjdC5hc3NpZ24gPyBPYmplY3QuYXNzaWduLmJpbmQoKSA6IGZ1bmN0aW9uICh0YXJnZXQpIHsgZm9yICh2YXIgaSA9IDE7IGkgPCBhcmd1bWVudHMubGVuZ3RoOyBpKyspIHsgdmFyIHNvdXJjZSA9IGFyZ3VtZW50c1tpXTsgZm9yICh2YXIga2V5IGluIHNvdXJjZSkgeyBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKHNvdXJjZSwga2V5KSkgeyB0YXJnZXRba2V5XSA9IHNvdXJjZVtrZXldOyB9IH0gfSByZXR1cm4gdGFyZ2V0OyB9OyByZXR1cm4gX2V4dGVuZHMuYXBwbHkodGhpcywgYXJndW1lbnRzKTsgfVxuXG5mdW5jdGlvbiBfb2JqZWN0V2l0aG91dFByb3BlcnRpZXMoc291cmNlLCBleGNsdWRlZCkgeyBpZiAoc291cmNlID09IG51bGwpIHJldHVybiB7fTsgdmFyIHRhcmdldCA9IF9vYmplY3RXaXRob3V0UHJvcGVydGllc0xvb3NlKHNvdXJjZSwgZXhjbHVkZWQpOyB2YXIga2V5LCBpOyBpZiAoT2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9scykgeyB2YXIgc291cmNlU3ltYm9sS2V5cyA9IE9iamVjdC5nZXRPd25Qcm9wZXJ0eVN5bWJvbHMoc291cmNlKTsgZm9yIChpID0gMDsgaSA8IHNvdXJjZVN5bWJvbEtleXMubGVuZ3RoOyBpKyspIHsga2V5ID0gc291cmNlU3ltYm9sS2V5c1tpXTsgaWYgKGV4Y2x1ZGVkLmluZGV4T2Yoa2V5KSA+PSAwKSBjb250aW51ZTsgaWYgKCFPYmplY3QucHJvdG90eXBlLnByb3BlcnR5SXNFbnVtZXJhYmxlLmNhbGwoc291cmNlLCBrZXkpKSBjb250aW51ZTsgdGFyZ2V0W2tleV0gPSBzb3VyY2Vba2V5XTsgfSB9IHJldHVybiB0YXJnZXQ7IH1cblxuZnVuY3Rpb24gX29iamVjdFdpdGhvdXRQcm9wZXJ0aWVzTG9vc2Uoc291cmNlLCBleGNsdWRlZCkgeyBpZiAoc291cmNlID09IG51bGwpIHJldHVybiB7fTsgdmFyIHRhcmdldCA9IHt9OyB2YXIgc291cmNlS2V5cyA9IE9iamVjdC5rZXlzKHNvdXJjZSk7IHZhciBrZXksIGk7IGZvciAoaSA9IDA7IGkgPCBzb3VyY2VLZXlzLmxlbmd0aDsgaSsrKSB7IGtleSA9IHNvdXJjZUtleXNbaV07IGlmIChleGNsdWRlZC5pbmRleE9mKGtleSkgPj0gMCkgY29udGludWU7IHRhcmdldFtrZXldID0gc291cmNlW2tleV07IH0gcmV0dXJuIHRhcmdldDsgfVxuXG5pbXBvcnQgeyBGcmFnbWVudCwgY3JlYXRlRWxlbWVudCwgQ29tcG9uZW50IH0gZnJvbSAnQHdvcmRwcmVzcy9lbGVtZW50JztcbmltcG9ydCBjbGFzc25hbWVzIGZyb20gJ2NsYXNzbmFtZXMnO1xuXG5jb25zdCBTcGFjZXIgPSBfcmVmID0+IHtcbiAgbGV0IHtcbiAgICBvcHRpb246IHtcbiAgICAgIGhlaWdodCA9IDEwLFxuICAgICAgYXR0cjoge1xuICAgICAgICBjbGFzczogY2xhc3NOYW1lXG4gICAgICB9ID0ge31cbiAgICB9XG4gIH0gPSBfcmVmLFxuICAgICAgYXR0ciA9IF9vYmplY3RXaXRob3V0UHJvcGVydGllcyhfcmVmLm9wdGlvbi5hdHRyLCBfZXhjbHVkZWQpO1xuXG4gIHJldHVybiBjcmVhdGVFbGVtZW50KFwiZGl2XCIsIF9leHRlbmRzKHtcbiAgICBjbGFzc05hbWU6IGNsYXNzbmFtZXMoJ2N0LXNwYWNlcicsIGNsYXNzTmFtZSlcbiAgfSwgYXR0ciwge1xuICAgIHN0eWxlOiB7XG4gICAgICBoZWlnaHQ6IGAke2hlaWdodH1weGBcbiAgICB9XG4gIH0pKTtcbn07XG5cblNwYWNlci5yZW5kZXJpbmdDb25maWcgPSB7XG4gIGRlc2lnbjogJ25vbmUnXG59O1xuZXhwb3J0IGRlZmF1bHQgU3BhY2VyOyJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///1282\n')},5286:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var ct_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(5652);\n/* harmony import */ var ct_i18n__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(ct_i18n__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _components_InputWithOnlyNumbers__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(6086);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(4184);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var _react_outside_click_handler__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(8204);\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\nconst Spacing = _ref => {\n let {\n value,\n option,\n onChange\n } = _ref;\n const [isOpen, setIsOpen] = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useState)(false);\n const units = [{\n unit: 'px'\n }, {\n unit: '%'\n }, {\n unit: 'em'\n }, {\n unit: 'rem'\n }, {\n unit: 'pt'\n }];\n\n const withDefault = (currentUnit, defaultUnit) => units.find(_ref2 => {\n let {\n unit\n } = _ref2;\n return unit === currentUnit;\n }) ? currentUnit : currentUnit || units[0].unit;\n\n const getLinkedLeader = () => ['top', 'right', 'bottom', 'left'].find(v => value[v] !== 'auto');\n\n const getCurrentUnit = () => withDefault(value[getLinkedLeader()].toString().replace(/[0-9]/g, '').replace('-', '').replace(/\\./g, ''));\n\n const getNumericValue = function (value) {\n let unit = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';\n\n if (value === 'auto') {\n return value;\n }\n\n return `${parseFloat(value) === 0 ? 0 : parseFloat(value) || ''}${unit}`;\n };\n\n const handleChange = (futureValue, position) => {\n if (value.linked) {\n onChange(_objectSpread(_objectSpread({}, value), {}, {\n top: value.top === 'auto' ? value.top : getNumericValue(futureValue, getCurrentUnit()),\n left: value.left === 'auto' ? value.left : getNumericValue(futureValue, getCurrentUnit()),\n right: value.right === 'auto' ? value.right : getNumericValue(futureValue, getCurrentUnit()),\n bottom: value.bottom === 'auto' ? value.bottom : getNumericValue(futureValue, getCurrentUnit())\n }));\n return;\n }\n\n onChange(_objectSpread(_objectSpread({}, value), {}, {\n [position]: getNumericValue(futureValue, getCurrentUnit())\n }));\n };\n\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_3___default()('ct-option-spacing', {\n linked: value.linked\n })\n }, ['top', 'right', 'bottom', 'left'].map(side => (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"span\", {\n key: side\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_components_InputWithOnlyNumbers__WEBPACK_IMPORTED_MODULE_2__/* [\"default\"] */ .Z, _extends({\n placeholder: \"\",\n value: getNumericValue(value[side]),\n onChange: v => handleChange(v, side)\n }, _objectSpread({\n placeholder: ''\n }, option.inputAttr))), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"small\", null, {\n top: (0,ct_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Top', 'blocksy'),\n bottom: (0,ct_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Bottom', 'blocksy'),\n left: (0,ct_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Left', 'blocksy'),\n right: (0,ct_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Right', 'blocksy')\n }[side]))), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_3___default()('ct-spacing-controls ct-value-changer', {\n active: isOpen\n })\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"a\", {\n onClick: e => {\n e.preventDefault();\n\n if (value.linked) {\n onChange(_objectSpread(_objectSpread({}, value), {}, {\n linked: false\n }));\n return;\n }\n\n const futureValue = value[getLinkedLeader()];\n onChange(_objectSpread(_objectSpread({}, value), {}, {\n top: value.top !== 'auto' ? futureValue : value.top,\n left: value.left !== 'auto' ? futureValue : value.left,\n bottom: value.bottom !== 'auto' ? futureValue : value.bottom,\n right: value.right !== 'auto' ? futureValue : value.right,\n linked: true\n }));\n }\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"svg\", {\n width: \"10\",\n height: \"10\",\n viewBox: \"0 0 15 15\"\n }, value.linked ? (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"path\", {\n d: \"M12.2,5.5V4.7c0-2.6-2.1-4.7-4.7-4.7S2.8,2.1,2.8,4.7v0.8c-0.9,0-1.6,0.7-1.6,1.6v6.3c0,0.9,0.7,1.6,1.6,1.6h9.5c0.9,0,1.6-0.7,1.6-1.6V7.1C13.8,6.2,13.1,5.5,12.2,5.5z M10.7,5.5H4.3V4.7c0-1.8,1.4-3.2,3.2-3.2s3.2,1.4,3.2,3.2V5.5z\"\n }) : (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"path\", {\n d: \"M12.2,5.5h-1.6H9.9h-5H4.7l0-0.2C4.4,3.5,5.5,1.9,7.3,1.5c1.1-0.2,2.2,0.1,2.8,0.9l1.3-0.9c-1-1.1-2.6-1.8-4.3-1.5C4.5,0.5,2.8,2.9,3.2,5.5H2.8c-0.9,0-1.6,0.7-1.6,1.6v6.3c0,0.9,0.7,1.6,1.6,1.6h9.5c0.9,0,1.6-0.7,1.6-1.6V7.1C13.8,6.2,13.1,5.5,12.2,5.5z\"\n }))), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"span\", {\n className: \"ct-value-divider\"\n }), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", {\n onClick: () => setIsOpen(!isOpen),\n className: \"ct-current-value\"\n }, getCurrentUnit() || '―'), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_react_outside_click_handler__WEBPACK_IMPORTED_MODULE_4__[\"default\"], {\n onOutsideClick: () => {\n if (!isOpen) {\n return;\n }\n\n setIsOpen(false);\n }\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"ul\", {\n className: \"ct-units-list\"\n }, units.filter(_ref3 => {\n let {\n unit\n } = _ref3;\n return unit !== getCurrentUnit();\n }).reduce((current, el, index) => [...current.slice(0, index % 2 === 0 ? undefined : -1), ...(index % 2 === 0 ? [[el]] : [[current[current.length - 1][0], el]])], []).map(group => (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"li\", {\n key: group[0].unit\n }, group.map(_ref4 => {\n let {\n unit\n } = _ref4;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"span\", {\n key: unit,\n onClick: () => {\n onChange(_objectSpread(_objectSpread({}, value), {}, {\n top: getNumericValue(value.top, unit),\n left: getNumericValue(value.left, unit),\n right: getNumericValue(value.right, unit),\n bottom: getNumericValue(value.bottom, unit)\n }));\n setIsOpen(false);\n }\n }, unit || '―');\n })))))));\n};\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Spacing);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"5286.js","mappings":";;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./static/js/options/options/ct-spacing.js?77a4"],"sourcesContent":["function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, Component, useState } from '@wordpress/element';\nimport { __ } from 'ct-i18n';\nimport InputWithOnlyNumbers from '../components/InputWithOnlyNumbers';\nimport cls from 'classnames';\nimport OutsideClickHandler from './react-outside-click-handler';\n\nconst Spacing = _ref => {\n  let {\n    value,\n    option,\n    onChange\n  } = _ref;\n  const [isOpen, setIsOpen] = useState(false);\n  const units = [{\n    unit: 'px'\n  }, {\n    unit: '%'\n  }, {\n    unit: 'em'\n  }, {\n    unit: 'rem'\n  }, {\n    unit: 'pt'\n  }];\n\n  const withDefault = (currentUnit, defaultUnit) => units.find(_ref2 => {\n    let {\n      unit\n    } = _ref2;\n    return unit === currentUnit;\n  }) ? currentUnit : currentUnit || units[0].unit;\n\n  const getLinkedLeader = () => ['top', 'right', 'bottom', 'left'].find(v => value[v] !== 'auto');\n\n  const getCurrentUnit = () => withDefault(value[getLinkedLeader()].toString().replace(/[0-9]/g, '').replace('-', '').replace(/\\./g, ''));\n\n  const getNumericValue = function (value) {\n    let unit = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';\n\n    if (value === 'auto') {\n      return value;\n    }\n\n    return `${parseFloat(value) === 0 ? 0 : parseFloat(value) || ''}${unit}`;\n  };\n\n  const handleChange = (futureValue, position) => {\n    if (value.linked) {\n      onChange(_objectSpread(_objectSpread({}, value), {}, {\n        top: value.top === 'auto' ? value.top : getNumericValue(futureValue, getCurrentUnit()),\n        left: value.left === 'auto' ? value.left : getNumericValue(futureValue, getCurrentUnit()),\n        right: value.right === 'auto' ? value.right : getNumericValue(futureValue, getCurrentUnit()),\n        bottom: value.bottom === 'auto' ? value.bottom : getNumericValue(futureValue, getCurrentUnit())\n      }));\n      return;\n    }\n\n    onChange(_objectSpread(_objectSpread({}, value), {}, {\n      [position]: getNumericValue(futureValue, getCurrentUnit())\n    }));\n  };\n\n  return createElement(\"div\", {\n    className: cls('ct-option-spacing', {\n      linked: value.linked\n    })\n  }, ['top', 'right', 'bottom', 'left'].map(side => createElement(\"span\", {\n    key: side\n  }, createElement(InputWithOnlyNumbers, _extends({\n    placeholder: \"\",\n    value: getNumericValue(value[side]),\n    onChange: v => handleChange(v, side)\n  }, _objectSpread({\n    placeholder: ''\n  }, option.inputAttr))), createElement(\"small\", null, {\n    top: __('Top', 'blocksy'),\n    bottom: __('Bottom', 'blocksy'),\n    left: __('Left', 'blocksy'),\n    right: __('Right', 'blocksy')\n  }[side]))), createElement(\"div\", {\n    className: cls('ct-spacing-controls ct-value-changer', {\n      active: isOpen\n    })\n  }, createElement(\"a\", {\n    onClick: e => {\n      e.preventDefault();\n\n      if (value.linked) {\n        onChange(_objectSpread(_objectSpread({}, value), {}, {\n          linked: false\n        }));\n        return;\n      }\n\n      const futureValue = value[getLinkedLeader()];\n      onChange(_objectSpread(_objectSpread({}, value), {}, {\n        top: value.top !== 'auto' ? futureValue : value.top,\n        left: value.left !== 'auto' ? futureValue : value.left,\n        bottom: value.bottom !== 'auto' ? futureValue : value.bottom,\n        right: value.right !== 'auto' ? futureValue : value.right,\n        linked: true\n      }));\n    }\n  }, createElement(\"svg\", {\n    width: \"10\",\n    height: \"10\",\n    viewBox: \"0 0 15 15\"\n  }, value.linked ? createElement(\"path\", {\n    d: \"M12.2,5.5V4.7c0-2.6-2.1-4.7-4.7-4.7S2.8,2.1,2.8,4.7v0.8c-0.9,0-1.6,0.7-1.6,1.6v6.3c0,0.9,0.7,1.6,1.6,1.6h9.5c0.9,0,1.6-0.7,1.6-1.6V7.1C13.8,6.2,13.1,5.5,12.2,5.5z M10.7,5.5H4.3V4.7c0-1.8,1.4-3.2,3.2-3.2s3.2,1.4,3.2,3.2V5.5z\"\n  }) : createElement(\"path\", {\n    d: \"M12.2,5.5h-1.6H9.9h-5H4.7l0-0.2C4.4,3.5,5.5,1.9,7.3,1.5c1.1-0.2,2.2,0.1,2.8,0.9l1.3-0.9c-1-1.1-2.6-1.8-4.3-1.5C4.5,0.5,2.8,2.9,3.2,5.5H2.8c-0.9,0-1.6,0.7-1.6,1.6v6.3c0,0.9,0.7,1.6,1.6,1.6h9.5c0.9,0,1.6-0.7,1.6-1.6V7.1C13.8,6.2,13.1,5.5,12.2,5.5z\"\n  }))), createElement(\"span\", {\n    className: \"ct-value-divider\"\n  }), createElement(\"div\", {\n    onClick: () => setIsOpen(!isOpen),\n    className: \"ct-current-value\"\n  }, getCurrentUnit() || '―'), createElement(OutsideClickHandler, {\n    onOutsideClick: () => {\n      if (!isOpen) {\n        return;\n      }\n\n      setIsOpen(false);\n    }\n  }, createElement(\"ul\", {\n    className: \"ct-units-list\"\n  }, units.filter(_ref3 => {\n    let {\n      unit\n    } = _ref3;\n    return unit !== getCurrentUnit();\n  }).reduce((current, el, index) => [...current.slice(0, index % 2 === 0 ? undefined : -1), ...(index % 2 === 0 ? [[el]] : [[current[current.length - 1][0], el]])], []).map(group => createElement(\"li\", {\n    key: group[0].unit\n  }, group.map(_ref4 => {\n    let {\n      unit\n    } = _ref4;\n    return createElement(\"span\", {\n      key: unit,\n      onClick: () => {\n        onChange(_objectSpread(_objectSpread({}, value), {}, {\n          top: getNumericValue(value.top, unit),\n          left: getNumericValue(value.left, unit),\n          right: getNumericValue(value.right, unit),\n          bottom: getNumericValue(value.bottom, unit)\n        }));\n        setIsOpen(false);\n      }\n    }, unit || '―');\n  })))))));\n};\n\nexport default Spacing;"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///5286\n")},9497:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(4184);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\n\n\n\nconst isActive = _ref => {\n let {\n option: {\n behavior = 'words'\n },\n value\n } = _ref;\n return behavior === 'words' ? value === 'yes' : !!value;\n};\n\nconst alternateValueFor = _ref2 => {\n let {\n option = {},\n option: {\n behavior = 'words'\n },\n value\n } = _ref2;\n return isActive({\n option,\n value\n }) ? behavior === 'words' ? 'no' : false : behavior === 'words' ? 'yes' : true;\n};\n\nconst Switch = _ref3 => {\n let {\n value,\n option = {},\n onChange,\n onClick\n } = _ref3;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()({\n [`ct-option-switch`]: true,\n [`ct-active`]: isActive({\n option,\n value\n })\n }),\n onClick: e => {\n onClick && onClick(e);\n onChange(alternateValueFor({\n option,\n value\n }));\n }\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"span\", null));\n};\n\nSwitch.renderingConfig = {\n design: 'inline'\n};\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Switch);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiOTQ5Ny5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9ibG9ja3N5T3B0aW9ucy8uL3N0YXRpYy9qcy9vcHRpb25zL29wdGlvbnMvY3Qtc3dpdGNoLmpzPzM1ZTAiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3JlYXRlRWxlbWVudCwgQ29tcG9uZW50IH0gZnJvbSAnQHdvcmRwcmVzcy9lbGVtZW50JztcbmltcG9ydCBjbGFzc25hbWVzIGZyb20gJ2NsYXNzbmFtZXMnO1xuXG5jb25zdCBpc0FjdGl2ZSA9IF9yZWYgPT4ge1xuICBsZXQge1xuICAgIG9wdGlvbjoge1xuICAgICAgYmVoYXZpb3IgPSAnd29yZHMnXG4gICAgfSxcbiAgICB2YWx1ZVxuICB9ID0gX3JlZjtcbiAgcmV0dXJuIGJlaGF2aW9yID09PSAnd29yZHMnID8gdmFsdWUgPT09ICd5ZXMnIDogISF2YWx1ZTtcbn07XG5cbmNvbnN0IGFsdGVybmF0ZVZhbHVlRm9yID0gX3JlZjIgPT4ge1xuICBsZXQge1xuICAgIG9wdGlvbiA9IHt9LFxuICAgIG9wdGlvbjoge1xuICAgICAgYmVoYXZpb3IgPSAnd29yZHMnXG4gICAgfSxcbiAgICB2YWx1ZVxuICB9ID0gX3JlZjI7XG4gIHJldHVybiBpc0FjdGl2ZSh7XG4gICAgb3B0aW9uLFxuICAgIHZhbHVlXG4gIH0pID8gYmVoYXZpb3IgPT09ICd3b3JkcycgPyAnbm8nIDogZmFsc2UgOiBiZWhhdmlvciA9PT0gJ3dvcmRzJyA/ICd5ZXMnIDogdHJ1ZTtcbn07XG5cbmNvbnN0IFN3aXRjaCA9IF9yZWYzID0+IHtcbiAgbGV0IHtcbiAgICB2YWx1ZSxcbiAgICBvcHRpb24gPSB7fSxcbiAgICBvbkNoYW5nZSxcbiAgICBvbkNsaWNrXG4gIH0gPSBfcmVmMztcbiAgcmV0dXJuIGNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwge1xuICAgIGNsYXNzTmFtZTogY2xhc3NuYW1lcyh7XG4gICAgICBbYGN0LW9wdGlvbi1zd2l0Y2hgXTogdHJ1ZSxcbiAgICAgIFtgY3QtYWN0aXZlYF06IGlzQWN0aXZlKHtcbiAgICAgICAgb3B0aW9uLFxuICAgICAgICB2YWx1ZVxuICAgICAgfSlcbiAgICB9KSxcbiAgICBvbkNsaWNrOiBlID0+IHtcbiAgICAgIG9uQ2xpY2sgJiYgb25DbGljayhlKTtcbiAgICAgIG9uQ2hhbmdlKGFsdGVybmF0ZVZhbHVlRm9yKHtcbiAgICAgICAgb3B0aW9uLFxuICAgICAgICB2YWx1ZVxuICAgICAgfSkpO1xuICAgIH1cbiAgfSwgY3JlYXRlRWxlbWVudChcInNwYW5cIiwgbnVsbCkpO1xufTtcblxuU3dpdGNoLnJlbmRlcmluZ0NvbmZpZyA9IHtcbiAgZGVzaWduOiAnaW5saW5lJ1xufTtcbmV4cG9ydCBkZWZhdWx0IFN3aXRjaDsiXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///9497\n")},7896:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\nconst Title = _ref => {\n let {\n option: {\n label = \'\',\n desc = \'\',\n attr = {},\n variation = \'simple\'\n }\n } = _ref;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", _extends({\n className: "ct-title"\n }, _objectSpread({\n \'data-type\': variation\n }, attr || {})), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("h3", null, label), desc && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", {\n className: "ct-option-description",\n dangerouslySetInnerHTML: {\n __html: desc\n }\n })));\n};\n\nTitle.renderingConfig = {\n design: \'none\'\n};\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Title);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNzg5Ni5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9zdGF0aWMvanMvb3B0aW9ucy9vcHRpb25zL2N0LXRpdGxlLmpzPzA3ZjUiXSwic291cmNlc0NvbnRlbnQiOlsiZnVuY3Rpb24gX2V4dGVuZHMoKSB7IF9leHRlbmRzID0gT2JqZWN0LmFzc2lnbiA/IE9iamVjdC5hc3NpZ24uYmluZCgpIDogZnVuY3Rpb24gKHRhcmdldCkgeyBmb3IgKHZhciBpID0gMTsgaSA8IGFyZ3VtZW50cy5sZW5ndGg7IGkrKykgeyB2YXIgc291cmNlID0gYXJndW1lbnRzW2ldOyBmb3IgKHZhciBrZXkgaW4gc291cmNlKSB7IGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwoc291cmNlLCBrZXkpKSB7IHRhcmdldFtrZXldID0gc291cmNlW2tleV07IH0gfSB9IHJldHVybiB0YXJnZXQ7IH07IHJldHVybiBfZXh0ZW5kcy5hcHBseSh0aGlzLCBhcmd1bWVudHMpOyB9XG5cbmZ1bmN0aW9uIG93bktleXMob2JqZWN0LCBlbnVtZXJhYmxlT25seSkgeyB2YXIga2V5cyA9IE9iamVjdC5rZXlzKG9iamVjdCk7IGlmIChPYmplY3QuZ2V0T3duUHJvcGVydHlTeW1ib2xzKSB7IHZhciBzeW1ib2xzID0gT2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9scyhvYmplY3QpOyBlbnVtZXJhYmxlT25seSAmJiAoc3ltYm9scyA9IHN5bWJvbHMuZmlsdGVyKGZ1bmN0aW9uIChzeW0pIHsgcmV0dXJuIE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3Iob2JqZWN0LCBzeW0pLmVudW1lcmFibGU7IH0pKSwga2V5cy5wdXNoLmFwcGx5KGtleXMsIHN5bWJvbHMpOyB9IHJldHVybiBrZXlzOyB9XG5cbmZ1bmN0aW9uIF9vYmplY3RTcHJlYWQodGFyZ2V0KSB7IGZvciAodmFyIGkgPSAxOyBpIDwgYXJndW1lbnRzLmxlbmd0aDsgaSsrKSB7IHZhciBzb3VyY2UgPSBudWxsICE9IGFyZ3VtZW50c1tpXSA/IGFyZ3VtZW50c1tpXSA6IHt9OyBpICUgMiA/IG93bktleXMoT2JqZWN0KHNvdXJjZSksICEwKS5mb3JFYWNoKGZ1bmN0aW9uIChrZXkpIHsgX2RlZmluZVByb3BlcnR5KHRhcmdldCwga2V5LCBzb3VyY2Vba2V5XSk7IH0pIDogT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcnMgPyBPYmplY3QuZGVmaW5lUHJvcGVydGllcyh0YXJnZXQsIE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3JzKHNvdXJjZSkpIDogb3duS2V5cyhPYmplY3Qoc291cmNlKSkuZm9yRWFjaChmdW5jdGlvbiAoa2V5KSB7IE9iamVjdC5kZWZpbmVQcm9wZXJ0eSh0YXJnZXQsIGtleSwgT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcihzb3VyY2UsIGtleSkpOyB9KTsgfSByZXR1cm4gdGFyZ2V0OyB9XG5cbmZ1bmN0aW9uIF9kZWZpbmVQcm9wZXJ0eShvYmosIGtleSwgdmFsdWUpIHsgaWYgKGtleSBpbiBvYmopIHsgT2JqZWN0LmRlZmluZVByb3BlcnR5KG9iaiwga2V5LCB7IHZhbHVlOiB2YWx1ZSwgZW51bWVyYWJsZTogdHJ1ZSwgY29uZmlndXJhYmxlOiB0cnVlLCB3cml0YWJsZTogdHJ1ZSB9KTsgfSBlbHNlIHsgb2JqW2tleV0gPSB2YWx1ZTsgfSByZXR1cm4gb2JqOyB9XG5cbmltcG9ydCB7IEZyYWdtZW50LCBjcmVhdGVFbGVtZW50LCBDb21wb25lbnQgfSBmcm9tICdAd29yZHByZXNzL2VsZW1lbnQnO1xuXG5jb25zdCBUaXRsZSA9IF9yZWYgPT4ge1xuICBsZXQge1xuICAgIG9wdGlvbjoge1xuICAgICAgbGFiZWwgPSAnJyxcbiAgICAgIGRlc2MgPSAnJyxcbiAgICAgIGF0dHIgPSB7fSxcbiAgICAgIHZhcmlhdGlvbiA9ICdzaW1wbGUnXG4gICAgfVxuICB9ID0gX3JlZjtcbiAgcmV0dXJuIGNyZWF0ZUVsZW1lbnQoRnJhZ21lbnQsIG51bGwsIGNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwgX2V4dGVuZHMoe1xuICAgIGNsYXNzTmFtZTogXCJjdC10aXRsZVwiXG4gIH0sIF9vYmplY3RTcHJlYWQoe1xuICAgICdkYXRhLXR5cGUnOiB2YXJpYXRpb25cbiAgfSwgYXR0ciB8fCB7fSkpLCBjcmVhdGVFbGVtZW50KFwiaDNcIiwgbnVsbCwgbGFiZWwpLCBkZXNjICYmIGNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwge1xuICAgIGNsYXNzTmFtZTogXCJjdC1vcHRpb24tZGVzY3JpcHRpb25cIixcbiAgICBkYW5nZXJvdXNseVNldElubmVySFRNTDoge1xuICAgICAgX19odG1sOiBkZXNjXG4gICAgfVxuICB9KSkpO1xufTtcblxuVGl0bGUucmVuZGVyaW5nQ29uZmlnID0ge1xuICBkZXNpZ246ICdub25lJ1xufTtcbmV4cG9ydCBkZWZhdWx0IFRpdGxlOyJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///7896\n')},5183:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("// ESM COMPAT FLAG\n__webpack_require__.r(__webpack_exports__);\n\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n \"default\": () => (/* binding */ ct_typography)\n});\n\n// EXTERNAL MODULE: external \"window.wp.element\"\nvar external_window_wp_element_ = __webpack_require__(1381);\n// EXTERNAL MODULE: ./node_modules/classnames/index.js\nvar classnames = __webpack_require__(4184);\nvar classnames_default = /*#__PURE__*/__webpack_require__.n(classnames);\n// EXTERNAL MODULE: external \"window.wp.i18n\"\nvar external_window_wp_i18n_ = __webpack_require__(5652);\n;// CONCATENATED MODULE: ./static/js/options/options/typography/default-data.js\n\nconst getDefaultFonts = _ref => {\n let {\n isDefault\n } = _ref;\n return {\n system: {\n type: 'system',\n families: [...(!isDefault ? ['Default'] : []), 'System Default', 'Arial', 'Verdana', 'Trebuchet', 'Georgia', 'Times New Roman', 'Palatino', 'Helvetica', 'Myriad Pro', 'Lucida', 'Gill Sans', 'Impact', 'Serif', 'monospace'].map(family => ({\n source: 'system',\n family,\n display: family === 'System Default' ? (0,external_window_wp_i18n_.__)('System Default', 'blocksy') : family,\n variations: [],\n all_variations: [...(family === 'Default' ? ['Default'] : []), 'n1', 'i1', 'n2', 'i2', 'n3', 'i3', 'n4', 'i4', 'n5', 'i5', 'n6', 'i6', 'n7', 'i7', 'n8', 'i8', 'n9', 'i9']\n }))\n }\n };\n};\n;// CONCATENATED MODULE: ./static/js/options/options/typography/helpers.js\n\nconst fontFamilyToCSSFamily = family => {\n if (family === 'System Default') {\n return \"-apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol'\";\n }\n\n return family.replace('ct_typekit_', '');\n};\n\nconst findSourceTypeSettingsFor = (font_family, fonts_list) => Object.values(fonts_list).find(single_font_source => single_font_source.families.map(_ref => {\n let {\n family\n } = _ref;\n return family;\n}).indexOf(font_family) > -1);\n\nconst findSourceTypeFor = (font_family, fonts_list) => {\n let source = findSourceTypeSettingsFor(font_family, fonts_list);\n if (!source) return false;\n return source.type;\n};\nconst findSelectedFontFamily = (font_family, fonts_list) => {\n let source = findSourceTypeSettingsFor(font_family, fonts_list);\n\n if (!source) {\n return null;\n }\n\n return source.families.find(_ref2 => {\n let {\n family\n } = _ref2;\n return family === font_family;\n });\n};\nconst decideVariationToSelect = (newValue, oldValue) => {\n if (newValue.all_variations.indexOf(oldValue.variation) > -1) {\n return oldValue.variation;\n }\n\n if (newValue.all_variations.indexOf('n4') > -1) {\n return 'n4';\n }\n\n return newValue.all_variations[0];\n};\nconst humanizeVariationsShort = variation => {\n var all = {\n n1: '100',\n i1: '100',\n n2: '200',\n i2: '200',\n n3: '300',\n i3: '300',\n n4: '400',\n i4: '400',\n n5: '500',\n i5: '500',\n n6: '600',\n i6: '600',\n n7: '700',\n i7: '700',\n n8: '800',\n i8: '800',\n n9: '900',\n i9: '900',\n Default: (0,external_window_wp_i18n_.__)('Default', 'blocksy')\n };\n return all[variation];\n};\nconst humanizeVariations = variation => {\n var all = {\n n1: (0,external_window_wp_i18n_.__)('Thin 100', 'blocksy'),\n i1: (0,external_window_wp_i18n_.__)('Thin 100 Italic', 'blocksy'),\n n2: (0,external_window_wp_i18n_.__)('Extra-Light 200', 'blocksy'),\n i2: (0,external_window_wp_i18n_.__)('Extra-Light 200 Italic', 'blocksy'),\n n3: (0,external_window_wp_i18n_.__)('Light 300', 'blocksy'),\n i3: (0,external_window_wp_i18n_.__)('Light 300 Italic', 'blocksy'),\n n4: (0,external_window_wp_i18n_.__)('Regular', 'blocksy'),\n i4: (0,external_window_wp_i18n_.__)('Regular 400 Italic', 'blocksy'),\n n5: (0,external_window_wp_i18n_.__)('Medium 500', 'blocksy'),\n i5: (0,external_window_wp_i18n_.__)('Medium 500 Italic', 'blocksy'),\n n6: (0,external_window_wp_i18n_.__)('Semi-Bold 600', 'blocksy'),\n i6: (0,external_window_wp_i18n_.__)('Semi-Bold 600 Italic', 'blocksy'),\n n7: (0,external_window_wp_i18n_.__)('Bold 700', 'blocksy'),\n i7: (0,external_window_wp_i18n_.__)('Bold 700 Italic', 'blocksy'),\n n8: (0,external_window_wp_i18n_.__)('Extra-Bold 800', 'blocksy'),\n i8: (0,external_window_wp_i18n_.__)('Extra-Bold 800 Italic', 'blocksy'),\n n9: (0,external_window_wp_i18n_.__)('Ultra-Bold 900', 'blocksy'),\n i9: (0,external_window_wp_i18n_.__)('Ultra-Bold 900 Italic', 'blocksy'),\n Default: (0,external_window_wp_i18n_.__)('Default Weight', 'blocksy')\n };\n return all[variation];\n};\nconst familyForDisplay = family => {\n if (family.indexOf('ct_font') === 0) {\n return family.replace('ct_font_', '').replace(/([-_][a-z])/gi, $1 => $1.toUpperCase().replace('-', '').replace('_', ''));\n }\n\n if (family.indexOf('ct_typekit') === 0) {\n return family.replace('ct_typekit_', '').replace(/([-_][a-z])/gi, $1 => $1.toUpperCase().replace('-', ' ').replace('_', ' '));\n }\n\n if (family === 'System Default') {\n return (0,external_window_wp_i18n_.__)('System Default', 'blocksy');\n }\n\n if (family === 'Default') {\n return (0,external_window_wp_i18n_.__)('Default', 'blocksy');\n }\n\n return family;\n};\n// EXTERNAL MODULE: ./node_modules/bezier-easing/src/index.js\nvar src = __webpack_require__(3431);\nvar src_default = /*#__PURE__*/__webpack_require__.n(src);\n// EXTERNAL MODULE: ./node_modules/@react-spring/web/dist/react-spring-web.esm.js\nvar react_spring_web_esm = __webpack_require__(1472);\n// EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/esm/extends.js\nvar esm_extends = __webpack_require__(7462);\n// EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js\nvar assertThisInitialized = __webpack_require__(7326);\n// EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/esm/inheritsLoose.js\nvar inheritsLoose = __webpack_require__(4578);\n;// CONCATENATED MODULE: ./node_modules/memoize-one/dist/memoize-one.esm.js\nvar safeIsNaN = Number.isNaN ||\n function ponyfill(value) {\n return typeof value === 'number' && value !== value;\n };\nfunction isEqual(first, second) {\n if (first === second) {\n return true;\n }\n if (safeIsNaN(first) && safeIsNaN(second)) {\n return true;\n }\n return false;\n}\nfunction areInputsEqual(newInputs, lastInputs) {\n if (newInputs.length !== lastInputs.length) {\n return false;\n }\n for (var i = 0; i < newInputs.length; i++) {\n if (!isEqual(newInputs[i], lastInputs[i])) {\n return false;\n }\n }\n return true;\n}\n\nfunction memoizeOne(resultFn, isEqual) {\n if (isEqual === void 0) { isEqual = areInputsEqual; }\n var lastThis;\n var lastArgs = [];\n var lastResult;\n var calledOnce = false;\n function memoized() {\n var newArgs = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n newArgs[_i] = arguments[_i];\n }\n if (calledOnce && lastThis === this && isEqual(newArgs, lastArgs)) {\n return lastResult;\n }\n lastResult = resultFn.apply(this, newArgs);\n calledOnce = true;\n lastThis = this;\n lastArgs = newArgs;\n return lastResult;\n }\n return memoized;\n}\n\n/* harmony default export */ const memoize_one_esm = (memoizeOne);\n\n// EXTERNAL MODULE: external \"React\"\nvar external_React_ = __webpack_require__(7363);\n;// CONCATENATED MODULE: ./node_modules/react-window/dist/index.esm.js\n\n\n\n\n\n\n\n// Animation frame based implementation of setTimeout.\n// Inspired by Joe Lambert, https://gist.github.com/joelambert/1002116#file-requesttimeout-js\nvar hasNativePerformanceNow = typeof performance === 'object' && typeof performance.now === 'function';\nvar now = hasNativePerformanceNow ? function () {\n return performance.now();\n} : function () {\n return Date.now();\n};\nfunction cancelTimeout(timeoutID) {\n cancelAnimationFrame(timeoutID.id);\n}\nfunction requestTimeout(callback, delay) {\n var start = now();\n\n function tick() {\n if (now() - start >= delay) {\n callback.call(null);\n } else {\n timeoutID.id = requestAnimationFrame(tick);\n }\n }\n\n var timeoutID = {\n id: requestAnimationFrame(tick)\n };\n return timeoutID;\n}\n\nvar size = -1; // This utility copied from \"dom-helpers\" package.\n\nfunction getScrollbarSize(recalculate) {\n if (recalculate === void 0) {\n recalculate = false;\n }\n\n if (size === -1 || recalculate) {\n var div = document.createElement('div');\n var style = div.style;\n style.width = '50px';\n style.height = '50px';\n style.overflow = 'scroll';\n document.body.appendChild(div);\n size = div.offsetWidth - div.clientWidth;\n document.body.removeChild(div);\n }\n\n return size;\n}\nvar cachedRTLResult = null; // TRICKY According to the spec, scrollLeft should be negative for RTL aligned elements.\n// Chrome does not seem to adhere; its scrollLeft values are positive (measured relative to the left).\n// Safari's elastic bounce makes detecting this even more complicated wrt potential false positives.\n// The safest way to check this is to intentionally set a negative offset,\n// and then verify that the subsequent \"scroll\" event matches the negative offset.\n// If it does not match, then we can assume a non-standard RTL scroll implementation.\n\nfunction getRTLOffsetType(recalculate) {\n if (recalculate === void 0) {\n recalculate = false;\n }\n\n if (cachedRTLResult === null || recalculate) {\n var outerDiv = document.createElement('div');\n var outerStyle = outerDiv.style;\n outerStyle.width = '50px';\n outerStyle.height = '50px';\n outerStyle.overflow = 'scroll';\n outerStyle.direction = 'rtl';\n var innerDiv = document.createElement('div');\n var innerStyle = innerDiv.style;\n innerStyle.width = '100px';\n innerStyle.height = '100px';\n outerDiv.appendChild(innerDiv);\n document.body.appendChild(outerDiv);\n\n if (outerDiv.scrollLeft > 0) {\n cachedRTLResult = 'positive-descending';\n } else {\n outerDiv.scrollLeft = 1;\n\n if (outerDiv.scrollLeft === 0) {\n cachedRTLResult = 'negative';\n } else {\n cachedRTLResult = 'positive-ascending';\n }\n }\n\n document.body.removeChild(outerDiv);\n return cachedRTLResult;\n }\n\n return cachedRTLResult;\n}\n\nvar IS_SCROLLING_DEBOUNCE_INTERVAL = 150;\n\nvar defaultItemKey = function defaultItemKey(_ref) {\n var columnIndex = _ref.columnIndex,\n data = _ref.data,\n rowIndex = _ref.rowIndex;\n return rowIndex + \":\" + columnIndex;\n}; // In DEV mode, this Set helps us only log a warning once per component instance.\n// This avoids spamming the console every time a render happens.\n\n\nvar devWarningsOverscanCount = null;\nvar devWarningsOverscanRowsColumnsCount = null;\nvar devWarningsTagName = null;\n\nif (false) {}\n\nfunction createGridComponent(_ref2) {\n var _class;\n\n var getColumnOffset = _ref2.getColumnOffset,\n getColumnStartIndexForOffset = _ref2.getColumnStartIndexForOffset,\n getColumnStopIndexForStartIndex = _ref2.getColumnStopIndexForStartIndex,\n getColumnWidth = _ref2.getColumnWidth,\n getEstimatedTotalHeight = _ref2.getEstimatedTotalHeight,\n getEstimatedTotalWidth = _ref2.getEstimatedTotalWidth,\n getOffsetForColumnAndAlignment = _ref2.getOffsetForColumnAndAlignment,\n getOffsetForRowAndAlignment = _ref2.getOffsetForRowAndAlignment,\n getRowHeight = _ref2.getRowHeight,\n getRowOffset = _ref2.getRowOffset,\n getRowStartIndexForOffset = _ref2.getRowStartIndexForOffset,\n getRowStopIndexForStartIndex = _ref2.getRowStopIndexForStartIndex,\n initInstanceProps = _ref2.initInstanceProps,\n shouldResetStyleCacheOnItemSizeChange = _ref2.shouldResetStyleCacheOnItemSizeChange,\n validateProps = _ref2.validateProps;\n return _class = /*#__PURE__*/function (_PureComponent) {\n (0,inheritsLoose/* default */.Z)(Grid, _PureComponent);\n\n // Always use explicit constructor for React components.\n // It produces less code after transpilation. (#26)\n // eslint-disable-next-line no-useless-constructor\n function Grid(props) {\n var _this;\n\n _this = _PureComponent.call(this, props) || this;\n _this._instanceProps = initInstanceProps(_this.props, (0,assertThisInitialized/* default */.Z)(_this));\n _this._resetIsScrollingTimeoutId = null;\n _this._outerRef = void 0;\n _this.state = {\n instance: (0,assertThisInitialized/* default */.Z)(_this),\n isScrolling: false,\n horizontalScrollDirection: 'forward',\n scrollLeft: typeof _this.props.initialScrollLeft === 'number' ? _this.props.initialScrollLeft : 0,\n scrollTop: typeof _this.props.initialScrollTop === 'number' ? _this.props.initialScrollTop : 0,\n scrollUpdateWasRequested: false,\n verticalScrollDirection: 'forward'\n };\n _this._callOnItemsRendered = void 0;\n _this._callOnItemsRendered = memoize_one_esm(function (overscanColumnStartIndex, overscanColumnStopIndex, overscanRowStartIndex, overscanRowStopIndex, visibleColumnStartIndex, visibleColumnStopIndex, visibleRowStartIndex, visibleRowStopIndex) {\n return _this.props.onItemsRendered({\n overscanColumnStartIndex: overscanColumnStartIndex,\n overscanColumnStopIndex: overscanColumnStopIndex,\n overscanRowStartIndex: overscanRowStartIndex,\n overscanRowStopIndex: overscanRowStopIndex,\n visibleColumnStartIndex: visibleColumnStartIndex,\n visibleColumnStopIndex: visibleColumnStopIndex,\n visibleRowStartIndex: visibleRowStartIndex,\n visibleRowStopIndex: visibleRowStopIndex\n });\n });\n _this._callOnScroll = void 0;\n _this._callOnScroll = memoize_one_esm(function (scrollLeft, scrollTop, horizontalScrollDirection, verticalScrollDirection, scrollUpdateWasRequested) {\n return _this.props.onScroll({\n horizontalScrollDirection: horizontalScrollDirection,\n scrollLeft: scrollLeft,\n scrollTop: scrollTop,\n verticalScrollDirection: verticalScrollDirection,\n scrollUpdateWasRequested: scrollUpdateWasRequested\n });\n });\n _this._getItemStyle = void 0;\n\n _this._getItemStyle = function (rowIndex, columnIndex) {\n var _this$props = _this.props,\n columnWidth = _this$props.columnWidth,\n direction = _this$props.direction,\n rowHeight = _this$props.rowHeight;\n\n var itemStyleCache = _this._getItemStyleCache(shouldResetStyleCacheOnItemSizeChange && columnWidth, shouldResetStyleCacheOnItemSizeChange && direction, shouldResetStyleCacheOnItemSizeChange && rowHeight);\n\n var key = rowIndex + \":\" + columnIndex;\n var style;\n\n if (itemStyleCache.hasOwnProperty(key)) {\n style = itemStyleCache[key];\n } else {\n var _offset = getColumnOffset(_this.props, columnIndex, _this._instanceProps);\n\n var isRtl = direction === 'rtl';\n itemStyleCache[key] = style = {\n position: 'absolute',\n left: isRtl ? undefined : _offset,\n right: isRtl ? _offset : undefined,\n top: getRowOffset(_this.props, rowIndex, _this._instanceProps),\n height: getRowHeight(_this.props, rowIndex, _this._instanceProps),\n width: getColumnWidth(_this.props, columnIndex, _this._instanceProps)\n };\n }\n\n return style;\n };\n\n _this._getItemStyleCache = void 0;\n _this._getItemStyleCache = memoize_one_esm(function (_, __, ___) {\n return {};\n });\n\n _this._onScroll = function (event) {\n var _event$currentTarget = event.currentTarget,\n clientHeight = _event$currentTarget.clientHeight,\n clientWidth = _event$currentTarget.clientWidth,\n scrollLeft = _event$currentTarget.scrollLeft,\n scrollTop = _event$currentTarget.scrollTop,\n scrollHeight = _event$currentTarget.scrollHeight,\n scrollWidth = _event$currentTarget.scrollWidth;\n\n _this.setState(function (prevState) {\n if (prevState.scrollLeft === scrollLeft && prevState.scrollTop === scrollTop) {\n // Scroll position may have been updated by cDM/cDU,\n // In which case we don't need to trigger another render,\n // And we don't want to update state.isScrolling.\n return null;\n }\n\n var direction = _this.props.direction; // TRICKY According to the spec, scrollLeft should be negative for RTL aligned elements.\n // This is not the case for all browsers though (e.g. Chrome reports values as positive, measured relative to the left).\n // It's also easier for this component if we convert offsets to the same format as they would be in for ltr.\n // So the simplest solution is to determine which browser behavior we're dealing with, and convert based on it.\n\n var calculatedScrollLeft = scrollLeft;\n\n if (direction === 'rtl') {\n switch (getRTLOffsetType()) {\n case 'negative':\n calculatedScrollLeft = -scrollLeft;\n break;\n\n case 'positive-descending':\n calculatedScrollLeft = scrollWidth - clientWidth - scrollLeft;\n break;\n }\n } // Prevent Safari's elastic scrolling from causing visual shaking when scrolling past bounds.\n\n\n calculatedScrollLeft = Math.max(0, Math.min(calculatedScrollLeft, scrollWidth - clientWidth));\n var calculatedScrollTop = Math.max(0, Math.min(scrollTop, scrollHeight - clientHeight));\n return {\n isScrolling: true,\n horizontalScrollDirection: prevState.scrollLeft < scrollLeft ? 'forward' : 'backward',\n scrollLeft: calculatedScrollLeft,\n scrollTop: calculatedScrollTop,\n verticalScrollDirection: prevState.scrollTop < scrollTop ? 'forward' : 'backward',\n scrollUpdateWasRequested: false\n };\n }, _this._resetIsScrollingDebounced);\n };\n\n _this._outerRefSetter = function (ref) {\n var outerRef = _this.props.outerRef;\n _this._outerRef = ref;\n\n if (typeof outerRef === 'function') {\n outerRef(ref);\n } else if (outerRef != null && typeof outerRef === 'object' && outerRef.hasOwnProperty('current')) {\n outerRef.current = ref;\n }\n };\n\n _this._resetIsScrollingDebounced = function () {\n if (_this._resetIsScrollingTimeoutId !== null) {\n cancelTimeout(_this._resetIsScrollingTimeoutId);\n }\n\n _this._resetIsScrollingTimeoutId = requestTimeout(_this._resetIsScrolling, IS_SCROLLING_DEBOUNCE_INTERVAL);\n };\n\n _this._resetIsScrolling = function () {\n _this._resetIsScrollingTimeoutId = null;\n\n _this.setState({\n isScrolling: false\n }, function () {\n // Clear style cache after state update has been committed.\n // This way we don't break pure sCU for items that don't use isScrolling param.\n _this._getItemStyleCache(-1);\n });\n };\n\n return _this;\n }\n\n Grid.getDerivedStateFromProps = function getDerivedStateFromProps(nextProps, prevState) {\n validateSharedProps(nextProps, prevState);\n validateProps(nextProps);\n return null;\n };\n\n var _proto = Grid.prototype;\n\n _proto.scrollTo = function scrollTo(_ref3) {\n var scrollLeft = _ref3.scrollLeft,\n scrollTop = _ref3.scrollTop;\n\n if (scrollLeft !== undefined) {\n scrollLeft = Math.max(0, scrollLeft);\n }\n\n if (scrollTop !== undefined) {\n scrollTop = Math.max(0, scrollTop);\n }\n\n this.setState(function (prevState) {\n if (scrollLeft === undefined) {\n scrollLeft = prevState.scrollLeft;\n }\n\n if (scrollTop === undefined) {\n scrollTop = prevState.scrollTop;\n }\n\n if (prevState.scrollLeft === scrollLeft && prevState.scrollTop === scrollTop) {\n return null;\n }\n\n return {\n horizontalScrollDirection: prevState.scrollLeft < scrollLeft ? 'forward' : 'backward',\n scrollLeft: scrollLeft,\n scrollTop: scrollTop,\n scrollUpdateWasRequested: true,\n verticalScrollDirection: prevState.scrollTop < scrollTop ? 'forward' : 'backward'\n };\n }, this._resetIsScrollingDebounced);\n };\n\n _proto.scrollToItem = function scrollToItem(_ref4) {\n var _ref4$align = _ref4.align,\n align = _ref4$align === void 0 ? 'auto' : _ref4$align,\n columnIndex = _ref4.columnIndex,\n rowIndex = _ref4.rowIndex;\n var _this$props2 = this.props,\n columnCount = _this$props2.columnCount,\n height = _this$props2.height,\n rowCount = _this$props2.rowCount,\n width = _this$props2.width;\n var _this$state = this.state,\n scrollLeft = _this$state.scrollLeft,\n scrollTop = _this$state.scrollTop;\n var scrollbarSize = getScrollbarSize();\n\n if (columnIndex !== undefined) {\n columnIndex = Math.max(0, Math.min(columnIndex, columnCount - 1));\n }\n\n if (rowIndex !== undefined) {\n rowIndex = Math.max(0, Math.min(rowIndex, rowCount - 1));\n }\n\n var estimatedTotalHeight = getEstimatedTotalHeight(this.props, this._instanceProps);\n var estimatedTotalWidth = getEstimatedTotalWidth(this.props, this._instanceProps); // The scrollbar size should be considered when scrolling an item into view,\n // to ensure it's fully visible.\n // But we only need to account for its size when it's actually visible.\n\n var horizontalScrollbarSize = estimatedTotalWidth > width ? scrollbarSize : 0;\n var verticalScrollbarSize = estimatedTotalHeight > height ? scrollbarSize : 0;\n this.scrollTo({\n scrollLeft: columnIndex !== undefined ? getOffsetForColumnAndAlignment(this.props, columnIndex, align, scrollLeft, this._instanceProps, verticalScrollbarSize) : scrollLeft,\n scrollTop: rowIndex !== undefined ? getOffsetForRowAndAlignment(this.props, rowIndex, align, scrollTop, this._instanceProps, horizontalScrollbarSize) : scrollTop\n });\n };\n\n _proto.componentDidMount = function componentDidMount() {\n var _this$props3 = this.props,\n initialScrollLeft = _this$props3.initialScrollLeft,\n initialScrollTop = _this$props3.initialScrollTop;\n\n if (this._outerRef != null) {\n var outerRef = this._outerRef;\n\n if (typeof initialScrollLeft === 'number') {\n outerRef.scrollLeft = initialScrollLeft;\n }\n\n if (typeof initialScrollTop === 'number') {\n outerRef.scrollTop = initialScrollTop;\n }\n }\n\n this._callPropsCallbacks();\n };\n\n _proto.componentDidUpdate = function componentDidUpdate() {\n var direction = this.props.direction;\n var _this$state2 = this.state,\n scrollLeft = _this$state2.scrollLeft,\n scrollTop = _this$state2.scrollTop,\n scrollUpdateWasRequested = _this$state2.scrollUpdateWasRequested;\n\n if (scrollUpdateWasRequested && this._outerRef != null) {\n // TRICKY According to the spec, scrollLeft should be negative for RTL aligned elements.\n // This is not the case for all browsers though (e.g. Chrome reports values as positive, measured relative to the left).\n // So we need to determine which browser behavior we're dealing with, and mimic it.\n var outerRef = this._outerRef;\n\n if (direction === 'rtl') {\n switch (getRTLOffsetType()) {\n case 'negative':\n outerRef.scrollLeft = -scrollLeft;\n break;\n\n case 'positive-ascending':\n outerRef.scrollLeft = scrollLeft;\n break;\n\n default:\n var clientWidth = outerRef.clientWidth,\n scrollWidth = outerRef.scrollWidth;\n outerRef.scrollLeft = scrollWidth - clientWidth - scrollLeft;\n break;\n }\n } else {\n outerRef.scrollLeft = Math.max(0, scrollLeft);\n }\n\n outerRef.scrollTop = Math.max(0, scrollTop);\n }\n\n this._callPropsCallbacks();\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n if (this._resetIsScrollingTimeoutId !== null) {\n cancelTimeout(this._resetIsScrollingTimeoutId);\n }\n };\n\n _proto.render = function render() {\n var _this$props4 = this.props,\n children = _this$props4.children,\n className = _this$props4.className,\n columnCount = _this$props4.columnCount,\n direction = _this$props4.direction,\n height = _this$props4.height,\n innerRef = _this$props4.innerRef,\n innerElementType = _this$props4.innerElementType,\n innerTagName = _this$props4.innerTagName,\n itemData = _this$props4.itemData,\n _this$props4$itemKey = _this$props4.itemKey,\n itemKey = _this$props4$itemKey === void 0 ? defaultItemKey : _this$props4$itemKey,\n outerElementType = _this$props4.outerElementType,\n outerTagName = _this$props4.outerTagName,\n rowCount = _this$props4.rowCount,\n style = _this$props4.style,\n useIsScrolling = _this$props4.useIsScrolling,\n width = _this$props4.width;\n var isScrolling = this.state.isScrolling;\n\n var _this$_getHorizontalR = this._getHorizontalRangeToRender(),\n columnStartIndex = _this$_getHorizontalR[0],\n columnStopIndex = _this$_getHorizontalR[1];\n\n var _this$_getVerticalRan = this._getVerticalRangeToRender(),\n rowStartIndex = _this$_getVerticalRan[0],\n rowStopIndex = _this$_getVerticalRan[1];\n\n var items = [];\n\n if (columnCount > 0 && rowCount) {\n for (var _rowIndex = rowStartIndex; _rowIndex <= rowStopIndex; _rowIndex++) {\n for (var _columnIndex = columnStartIndex; _columnIndex <= columnStopIndex; _columnIndex++) {\n items.push((0,external_React_.createElement)(children, {\n columnIndex: _columnIndex,\n data: itemData,\n isScrolling: useIsScrolling ? isScrolling : undefined,\n key: itemKey({\n columnIndex: _columnIndex,\n data: itemData,\n rowIndex: _rowIndex\n }),\n rowIndex: _rowIndex,\n style: this._getItemStyle(_rowIndex, _columnIndex)\n }));\n }\n }\n } // Read this value AFTER items have been created,\n // So their actual sizes (if variable) are taken into consideration.\n\n\n var estimatedTotalHeight = getEstimatedTotalHeight(this.props, this._instanceProps);\n var estimatedTotalWidth = getEstimatedTotalWidth(this.props, this._instanceProps);\n return (0,external_React_.createElement)(outerElementType || outerTagName || 'div', {\n className: className,\n onScroll: this._onScroll,\n ref: this._outerRefSetter,\n style: (0,esm_extends[\"default\"])({\n position: 'relative',\n height: height,\n width: width,\n overflow: 'auto',\n WebkitOverflowScrolling: 'touch',\n willChange: 'transform',\n direction: direction\n }, style)\n }, (0,external_React_.createElement)(innerElementType || innerTagName || 'div', {\n children: items,\n ref: innerRef,\n style: {\n height: estimatedTotalHeight,\n pointerEvents: isScrolling ? 'none' : undefined,\n width: estimatedTotalWidth\n }\n }));\n };\n\n _proto._callPropsCallbacks = function _callPropsCallbacks() {\n var _this$props5 = this.props,\n columnCount = _this$props5.columnCount,\n onItemsRendered = _this$props5.onItemsRendered,\n onScroll = _this$props5.onScroll,\n rowCount = _this$props5.rowCount;\n\n if (typeof onItemsRendered === 'function') {\n if (columnCount > 0 && rowCount > 0) {\n var _this$_getHorizontalR2 = this._getHorizontalRangeToRender(),\n _overscanColumnStartIndex = _this$_getHorizontalR2[0],\n _overscanColumnStopIndex = _this$_getHorizontalR2[1],\n _visibleColumnStartIndex = _this$_getHorizontalR2[2],\n _visibleColumnStopIndex = _this$_getHorizontalR2[3];\n\n var _this$_getVerticalRan2 = this._getVerticalRangeToRender(),\n _overscanRowStartIndex = _this$_getVerticalRan2[0],\n _overscanRowStopIndex = _this$_getVerticalRan2[1],\n _visibleRowStartIndex = _this$_getVerticalRan2[2],\n _visibleRowStopIndex = _this$_getVerticalRan2[3];\n\n this._callOnItemsRendered(_overscanColumnStartIndex, _overscanColumnStopIndex, _overscanRowStartIndex, _overscanRowStopIndex, _visibleColumnStartIndex, _visibleColumnStopIndex, _visibleRowStartIndex, _visibleRowStopIndex);\n }\n }\n\n if (typeof onScroll === 'function') {\n var _this$state3 = this.state,\n _horizontalScrollDirection = _this$state3.horizontalScrollDirection,\n _scrollLeft = _this$state3.scrollLeft,\n _scrollTop = _this$state3.scrollTop,\n _scrollUpdateWasRequested = _this$state3.scrollUpdateWasRequested,\n _verticalScrollDirection = _this$state3.verticalScrollDirection;\n\n this._callOnScroll(_scrollLeft, _scrollTop, _horizontalScrollDirection, _verticalScrollDirection, _scrollUpdateWasRequested);\n }\n } // Lazily create and cache item styles while scrolling,\n // So that pure component sCU will prevent re-renders.\n // We maintain this cache, and pass a style prop rather than index,\n // So that List can clear cached styles and force item re-render if necessary.\n ;\n\n _proto._getHorizontalRangeToRender = function _getHorizontalRangeToRender() {\n var _this$props6 = this.props,\n columnCount = _this$props6.columnCount,\n overscanColumnCount = _this$props6.overscanColumnCount,\n overscanColumnsCount = _this$props6.overscanColumnsCount,\n overscanCount = _this$props6.overscanCount,\n rowCount = _this$props6.rowCount;\n var _this$state4 = this.state,\n horizontalScrollDirection = _this$state4.horizontalScrollDirection,\n isScrolling = _this$state4.isScrolling,\n scrollLeft = _this$state4.scrollLeft;\n var overscanCountResolved = overscanColumnCount || overscanColumnsCount || overscanCount || 1;\n\n if (columnCount === 0 || rowCount === 0) {\n return [0, 0, 0, 0];\n }\n\n var startIndex = getColumnStartIndexForOffset(this.props, scrollLeft, this._instanceProps);\n var stopIndex = getColumnStopIndexForStartIndex(this.props, startIndex, scrollLeft, this._instanceProps); // Overscan by one item in each direction so that tab/focus works.\n // If there isn't at least one extra item, tab loops back around.\n\n var overscanBackward = !isScrolling || horizontalScrollDirection === 'backward' ? Math.max(1, overscanCountResolved) : 1;\n var overscanForward = !isScrolling || horizontalScrollDirection === 'forward' ? Math.max(1, overscanCountResolved) : 1;\n return [Math.max(0, startIndex - overscanBackward), Math.max(0, Math.min(columnCount - 1, stopIndex + overscanForward)), startIndex, stopIndex];\n };\n\n _proto._getVerticalRangeToRender = function _getVerticalRangeToRender() {\n var _this$props7 = this.props,\n columnCount = _this$props7.columnCount,\n overscanCount = _this$props7.overscanCount,\n overscanRowCount = _this$props7.overscanRowCount,\n overscanRowsCount = _this$props7.overscanRowsCount,\n rowCount = _this$props7.rowCount;\n var _this$state5 = this.state,\n isScrolling = _this$state5.isScrolling,\n verticalScrollDirection = _this$state5.verticalScrollDirection,\n scrollTop = _this$state5.scrollTop;\n var overscanCountResolved = overscanRowCount || overscanRowsCount || overscanCount || 1;\n\n if (columnCount === 0 || rowCount === 0) {\n return [0, 0, 0, 0];\n }\n\n var startIndex = getRowStartIndexForOffset(this.props, scrollTop, this._instanceProps);\n var stopIndex = getRowStopIndexForStartIndex(this.props, startIndex, scrollTop, this._instanceProps); // Overscan by one item in each direction so that tab/focus works.\n // If there isn't at least one extra item, tab loops back around.\n\n var overscanBackward = !isScrolling || verticalScrollDirection === 'backward' ? Math.max(1, overscanCountResolved) : 1;\n var overscanForward = !isScrolling || verticalScrollDirection === 'forward' ? Math.max(1, overscanCountResolved) : 1;\n return [Math.max(0, startIndex - overscanBackward), Math.max(0, Math.min(rowCount - 1, stopIndex + overscanForward)), startIndex, stopIndex];\n };\n\n return Grid;\n }(external_React_.PureComponent), _class.defaultProps = {\n direction: 'ltr',\n itemData: undefined,\n useIsScrolling: false\n }, _class;\n}\n\nvar validateSharedProps = function validateSharedProps(_ref5, _ref6) {\n var children = _ref5.children,\n direction = _ref5.direction,\n height = _ref5.height,\n innerTagName = _ref5.innerTagName,\n outerTagName = _ref5.outerTagName,\n overscanColumnsCount = _ref5.overscanColumnsCount,\n overscanCount = _ref5.overscanCount,\n overscanRowsCount = _ref5.overscanRowsCount,\n width = _ref5.width;\n var instance = _ref6.instance;\n\n if (false) {}\n};\n\nvar DEFAULT_ESTIMATED_ITEM_SIZE = 50;\n\nvar getEstimatedTotalHeight = function getEstimatedTotalHeight(_ref, _ref2) {\n var rowCount = _ref.rowCount;\n var rowMetadataMap = _ref2.rowMetadataMap,\n estimatedRowHeight = _ref2.estimatedRowHeight,\n lastMeasuredRowIndex = _ref2.lastMeasuredRowIndex;\n var totalSizeOfMeasuredRows = 0; // Edge case check for when the number of items decreases while a scroll is in progress.\n // https://github.com/bvaughn/react-window/pull/138\n\n if (lastMeasuredRowIndex >= rowCount) {\n lastMeasuredRowIndex = rowCount - 1;\n }\n\n if (lastMeasuredRowIndex >= 0) {\n var itemMetadata = rowMetadataMap[lastMeasuredRowIndex];\n totalSizeOfMeasuredRows = itemMetadata.offset + itemMetadata.size;\n }\n\n var numUnmeasuredItems = rowCount - lastMeasuredRowIndex - 1;\n var totalSizeOfUnmeasuredItems = numUnmeasuredItems * estimatedRowHeight;\n return totalSizeOfMeasuredRows + totalSizeOfUnmeasuredItems;\n};\n\nvar getEstimatedTotalWidth = function getEstimatedTotalWidth(_ref3, _ref4) {\n var columnCount = _ref3.columnCount;\n var columnMetadataMap = _ref4.columnMetadataMap,\n estimatedColumnWidth = _ref4.estimatedColumnWidth,\n lastMeasuredColumnIndex = _ref4.lastMeasuredColumnIndex;\n var totalSizeOfMeasuredRows = 0; // Edge case check for when the number of items decreases while a scroll is in progress.\n // https://github.com/bvaughn/react-window/pull/138\n\n if (lastMeasuredColumnIndex >= columnCount) {\n lastMeasuredColumnIndex = columnCount - 1;\n }\n\n if (lastMeasuredColumnIndex >= 0) {\n var itemMetadata = columnMetadataMap[lastMeasuredColumnIndex];\n totalSizeOfMeasuredRows = itemMetadata.offset + itemMetadata.size;\n }\n\n var numUnmeasuredItems = columnCount - lastMeasuredColumnIndex - 1;\n var totalSizeOfUnmeasuredItems = numUnmeasuredItems * estimatedColumnWidth;\n return totalSizeOfMeasuredRows + totalSizeOfUnmeasuredItems;\n};\n\nvar getItemMetadata = function getItemMetadata(itemType, props, index, instanceProps) {\n var itemMetadataMap, itemSize, lastMeasuredIndex;\n\n if (itemType === 'column') {\n itemMetadataMap = instanceProps.columnMetadataMap;\n itemSize = props.columnWidth;\n lastMeasuredIndex = instanceProps.lastMeasuredColumnIndex;\n } else {\n itemMetadataMap = instanceProps.rowMetadataMap;\n itemSize = props.rowHeight;\n lastMeasuredIndex = instanceProps.lastMeasuredRowIndex;\n }\n\n if (index > lastMeasuredIndex) {\n var offset = 0;\n\n if (lastMeasuredIndex >= 0) {\n var itemMetadata = itemMetadataMap[lastMeasuredIndex];\n offset = itemMetadata.offset + itemMetadata.size;\n }\n\n for (var i = lastMeasuredIndex + 1; i <= index; i++) {\n var size = itemSize(i);\n itemMetadataMap[i] = {\n offset: offset,\n size: size\n };\n offset += size;\n }\n\n if (itemType === 'column') {\n instanceProps.lastMeasuredColumnIndex = index;\n } else {\n instanceProps.lastMeasuredRowIndex = index;\n }\n }\n\n return itemMetadataMap[index];\n};\n\nvar findNearestItem = function findNearestItem(itemType, props, instanceProps, offset) {\n var itemMetadataMap, lastMeasuredIndex;\n\n if (itemType === 'column') {\n itemMetadataMap = instanceProps.columnMetadataMap;\n lastMeasuredIndex = instanceProps.lastMeasuredColumnIndex;\n } else {\n itemMetadataMap = instanceProps.rowMetadataMap;\n lastMeasuredIndex = instanceProps.lastMeasuredRowIndex;\n }\n\n var lastMeasuredItemOffset = lastMeasuredIndex > 0 ? itemMetadataMap[lastMeasuredIndex].offset : 0;\n\n if (lastMeasuredItemOffset >= offset) {\n // If we've already measured items within this range just use a binary search as it's faster.\n return findNearestItemBinarySearch(itemType, props, instanceProps, lastMeasuredIndex, 0, offset);\n } else {\n // If we haven't yet measured this high, fallback to an exponential search with an inner binary search.\n // The exponential search avoids pre-computing sizes for the full set of items as a binary search would.\n // The overall complexity for this approach is O(log n).\n return findNearestItemExponentialSearch(itemType, props, instanceProps, Math.max(0, lastMeasuredIndex), offset);\n }\n};\n\nvar findNearestItemBinarySearch = function findNearestItemBinarySearch(itemType, props, instanceProps, high, low, offset) {\n while (low <= high) {\n var middle = low + Math.floor((high - low) / 2);\n var currentOffset = getItemMetadata(itemType, props, middle, instanceProps).offset;\n\n if (currentOffset === offset) {\n return middle;\n } else if (currentOffset < offset) {\n low = middle + 1;\n } else if (currentOffset > offset) {\n high = middle - 1;\n }\n }\n\n if (low > 0) {\n return low - 1;\n } else {\n return 0;\n }\n};\n\nvar findNearestItemExponentialSearch = function findNearestItemExponentialSearch(itemType, props, instanceProps, index, offset) {\n var itemCount = itemType === 'column' ? props.columnCount : props.rowCount;\n var interval = 1;\n\n while (index < itemCount && getItemMetadata(itemType, props, index, instanceProps).offset < offset) {\n index += interval;\n interval *= 2;\n }\n\n return findNearestItemBinarySearch(itemType, props, instanceProps, Math.min(index, itemCount - 1), Math.floor(index / 2), offset);\n};\n\nvar getOffsetForIndexAndAlignment = function getOffsetForIndexAndAlignment(itemType, props, index, align, scrollOffset, instanceProps, scrollbarSize) {\n var size = itemType === 'column' ? props.width : props.height;\n var itemMetadata = getItemMetadata(itemType, props, index, instanceProps); // Get estimated total size after ItemMetadata is computed,\n // To ensure it reflects actual measurements instead of just estimates.\n\n var estimatedTotalSize = itemType === 'column' ? getEstimatedTotalWidth(props, instanceProps) : getEstimatedTotalHeight(props, instanceProps);\n var maxOffset = Math.max(0, Math.min(estimatedTotalSize - size, itemMetadata.offset));\n var minOffset = Math.max(0, itemMetadata.offset - size + scrollbarSize + itemMetadata.size);\n\n if (align === 'smart') {\n if (scrollOffset >= minOffset - size && scrollOffset <= maxOffset + size) {\n align = 'auto';\n } else {\n align = 'center';\n }\n }\n\n switch (align) {\n case 'start':\n return maxOffset;\n\n case 'end':\n return minOffset;\n\n case 'center':\n return Math.round(minOffset + (maxOffset - minOffset) / 2);\n\n case 'auto':\n default:\n if (scrollOffset >= minOffset && scrollOffset <= maxOffset) {\n return scrollOffset;\n } else if (minOffset > maxOffset) {\n // Because we only take into account the scrollbar size when calculating minOffset\n // this value can be larger than maxOffset when at the end of the list\n return minOffset;\n } else if (scrollOffset < minOffset) {\n return minOffset;\n } else {\n return maxOffset;\n }\n\n }\n};\n\nvar VariableSizeGrid = /*#__PURE__*/createGridComponent({\n getColumnOffset: function getColumnOffset(props, index, instanceProps) {\n return getItemMetadata('column', props, index, instanceProps).offset;\n },\n getColumnStartIndexForOffset: function getColumnStartIndexForOffset(props, scrollLeft, instanceProps) {\n return findNearestItem('column', props, instanceProps, scrollLeft);\n },\n getColumnStopIndexForStartIndex: function getColumnStopIndexForStartIndex(props, startIndex, scrollLeft, instanceProps) {\n var columnCount = props.columnCount,\n width = props.width;\n var itemMetadata = getItemMetadata('column', props, startIndex, instanceProps);\n var maxOffset = scrollLeft + width;\n var offset = itemMetadata.offset + itemMetadata.size;\n var stopIndex = startIndex;\n\n while (stopIndex < columnCount - 1 && offset < maxOffset) {\n stopIndex++;\n offset += getItemMetadata('column', props, stopIndex, instanceProps).size;\n }\n\n return stopIndex;\n },\n getColumnWidth: function getColumnWidth(props, index, instanceProps) {\n return instanceProps.columnMetadataMap[index].size;\n },\n getEstimatedTotalHeight: getEstimatedTotalHeight,\n getEstimatedTotalWidth: getEstimatedTotalWidth,\n getOffsetForColumnAndAlignment: function getOffsetForColumnAndAlignment(props, index, align, scrollOffset, instanceProps, scrollbarSize) {\n return getOffsetForIndexAndAlignment('column', props, index, align, scrollOffset, instanceProps, scrollbarSize);\n },\n getOffsetForRowAndAlignment: function getOffsetForRowAndAlignment(props, index, align, scrollOffset, instanceProps, scrollbarSize) {\n return getOffsetForIndexAndAlignment('row', props, index, align, scrollOffset, instanceProps, scrollbarSize);\n },\n getRowOffset: function getRowOffset(props, index, instanceProps) {\n return getItemMetadata('row', props, index, instanceProps).offset;\n },\n getRowHeight: function getRowHeight(props, index, instanceProps) {\n return instanceProps.rowMetadataMap[index].size;\n },\n getRowStartIndexForOffset: function getRowStartIndexForOffset(props, scrollTop, instanceProps) {\n return findNearestItem('row', props, instanceProps, scrollTop);\n },\n getRowStopIndexForStartIndex: function getRowStopIndexForStartIndex(props, startIndex, scrollTop, instanceProps) {\n var rowCount = props.rowCount,\n height = props.height;\n var itemMetadata = getItemMetadata('row', props, startIndex, instanceProps);\n var maxOffset = scrollTop + height;\n var offset = itemMetadata.offset + itemMetadata.size;\n var stopIndex = startIndex;\n\n while (stopIndex < rowCount - 1 && offset < maxOffset) {\n stopIndex++;\n offset += getItemMetadata('row', props, stopIndex, instanceProps).size;\n }\n\n return stopIndex;\n },\n initInstanceProps: function initInstanceProps(props, instance) {\n var _ref5 = props,\n estimatedColumnWidth = _ref5.estimatedColumnWidth,\n estimatedRowHeight = _ref5.estimatedRowHeight;\n var instanceProps = {\n columnMetadataMap: {},\n estimatedColumnWidth: estimatedColumnWidth || DEFAULT_ESTIMATED_ITEM_SIZE,\n estimatedRowHeight: estimatedRowHeight || DEFAULT_ESTIMATED_ITEM_SIZE,\n lastMeasuredColumnIndex: -1,\n lastMeasuredRowIndex: -1,\n rowMetadataMap: {}\n };\n\n instance.resetAfterColumnIndex = function (columnIndex, shouldForceUpdate) {\n if (shouldForceUpdate === void 0) {\n shouldForceUpdate = true;\n }\n\n instance.resetAfterIndices({\n columnIndex: columnIndex,\n shouldForceUpdate: shouldForceUpdate\n });\n };\n\n instance.resetAfterRowIndex = function (rowIndex, shouldForceUpdate) {\n if (shouldForceUpdate === void 0) {\n shouldForceUpdate = true;\n }\n\n instance.resetAfterIndices({\n rowIndex: rowIndex,\n shouldForceUpdate: shouldForceUpdate\n });\n };\n\n instance.resetAfterIndices = function (_ref6) {\n var columnIndex = _ref6.columnIndex,\n rowIndex = _ref6.rowIndex,\n _ref6$shouldForceUpda = _ref6.shouldForceUpdate,\n shouldForceUpdate = _ref6$shouldForceUpda === void 0 ? true : _ref6$shouldForceUpda;\n\n if (typeof columnIndex === 'number') {\n instanceProps.lastMeasuredColumnIndex = Math.min(instanceProps.lastMeasuredColumnIndex, columnIndex - 1);\n }\n\n if (typeof rowIndex === 'number') {\n instanceProps.lastMeasuredRowIndex = Math.min(instanceProps.lastMeasuredRowIndex, rowIndex - 1);\n } // We could potentially optimize further by only evicting styles after this index,\n // But since styles are only cached while scrolling is in progress-\n // It seems an unnecessary optimization.\n // It's unlikely that resetAfterIndex() will be called while a user is scrolling.\n\n\n instance._getItemStyleCache(-1);\n\n if (shouldForceUpdate) {\n instance.forceUpdate();\n }\n };\n\n return instanceProps;\n },\n shouldResetStyleCacheOnItemSizeChange: false,\n validateProps: function validateProps(_ref7) {\n var columnWidth = _ref7.columnWidth,\n rowHeight = _ref7.rowHeight;\n\n if (false) {}\n }\n});\n\nvar IS_SCROLLING_DEBOUNCE_INTERVAL$1 = 150;\n\nvar defaultItemKey$1 = function defaultItemKey(index, data) {\n return index;\n}; // In DEV mode, this Set helps us only log a warning once per component instance.\n// This avoids spamming the console every time a render happens.\n\n\nvar devWarningsDirection = null;\nvar devWarningsTagName$1 = null;\n\nif (false) {}\n\nfunction createListComponent(_ref) {\n var _class;\n\n var getItemOffset = _ref.getItemOffset,\n getEstimatedTotalSize = _ref.getEstimatedTotalSize,\n getItemSize = _ref.getItemSize,\n getOffsetForIndexAndAlignment = _ref.getOffsetForIndexAndAlignment,\n getStartIndexForOffset = _ref.getStartIndexForOffset,\n getStopIndexForStartIndex = _ref.getStopIndexForStartIndex,\n initInstanceProps = _ref.initInstanceProps,\n shouldResetStyleCacheOnItemSizeChange = _ref.shouldResetStyleCacheOnItemSizeChange,\n validateProps = _ref.validateProps;\n return _class = /*#__PURE__*/function (_PureComponent) {\n (0,inheritsLoose/* default */.Z)(List, _PureComponent);\n\n // Always use explicit constructor for React components.\n // It produces less code after transpilation. (#26)\n // eslint-disable-next-line no-useless-constructor\n function List(props) {\n var _this;\n\n _this = _PureComponent.call(this, props) || this;\n _this._instanceProps = initInstanceProps(_this.props, (0,assertThisInitialized/* default */.Z)(_this));\n _this._outerRef = void 0;\n _this._resetIsScrollingTimeoutId = null;\n _this.state = {\n instance: (0,assertThisInitialized/* default */.Z)(_this),\n isScrolling: false,\n scrollDirection: 'forward',\n scrollOffset: typeof _this.props.initialScrollOffset === 'number' ? _this.props.initialScrollOffset : 0,\n scrollUpdateWasRequested: false\n };\n _this._callOnItemsRendered = void 0;\n _this._callOnItemsRendered = memoize_one_esm(function (overscanStartIndex, overscanStopIndex, visibleStartIndex, visibleStopIndex) {\n return _this.props.onItemsRendered({\n overscanStartIndex: overscanStartIndex,\n overscanStopIndex: overscanStopIndex,\n visibleStartIndex: visibleStartIndex,\n visibleStopIndex: visibleStopIndex\n });\n });\n _this._callOnScroll = void 0;\n _this._callOnScroll = memoize_one_esm(function (scrollDirection, scrollOffset, scrollUpdateWasRequested) {\n return _this.props.onScroll({\n scrollDirection: scrollDirection,\n scrollOffset: scrollOffset,\n scrollUpdateWasRequested: scrollUpdateWasRequested\n });\n });\n _this._getItemStyle = void 0;\n\n _this._getItemStyle = function (index) {\n var _this$props = _this.props,\n direction = _this$props.direction,\n itemSize = _this$props.itemSize,\n layout = _this$props.layout;\n\n var itemStyleCache = _this._getItemStyleCache(shouldResetStyleCacheOnItemSizeChange && itemSize, shouldResetStyleCacheOnItemSizeChange && layout, shouldResetStyleCacheOnItemSizeChange && direction);\n\n var style;\n\n if (itemStyleCache.hasOwnProperty(index)) {\n style = itemStyleCache[index];\n } else {\n var _offset = getItemOffset(_this.props, index, _this._instanceProps);\n\n var size = getItemSize(_this.props, index, _this._instanceProps); // TODO Deprecate direction \"horizontal\"\n\n var isHorizontal = direction === 'horizontal' || layout === 'horizontal';\n var isRtl = direction === 'rtl';\n var offsetHorizontal = isHorizontal ? _offset : 0;\n itemStyleCache[index] = style = {\n position: 'absolute',\n left: isRtl ? undefined : offsetHorizontal,\n right: isRtl ? offsetHorizontal : undefined,\n top: !isHorizontal ? _offset : 0,\n height: !isHorizontal ? size : '100%',\n width: isHorizontal ? size : '100%'\n };\n }\n\n return style;\n };\n\n _this._getItemStyleCache = void 0;\n _this._getItemStyleCache = memoize_one_esm(function (_, __, ___) {\n return {};\n });\n\n _this._onScrollHorizontal = function (event) {\n var _event$currentTarget = event.currentTarget,\n clientWidth = _event$currentTarget.clientWidth,\n scrollLeft = _event$currentTarget.scrollLeft,\n scrollWidth = _event$currentTarget.scrollWidth;\n\n _this.setState(function (prevState) {\n if (prevState.scrollOffset === scrollLeft) {\n // Scroll position may have been updated by cDM/cDU,\n // In which case we don't need to trigger another render,\n // And we don't want to update state.isScrolling.\n return null;\n }\n\n var direction = _this.props.direction;\n var scrollOffset = scrollLeft;\n\n if (direction === 'rtl') {\n // TRICKY According to the spec, scrollLeft should be negative for RTL aligned elements.\n // This is not the case for all browsers though (e.g. Chrome reports values as positive, measured relative to the left).\n // It's also easier for this component if we convert offsets to the same format as they would be in for ltr.\n // So the simplest solution is to determine which browser behavior we're dealing with, and convert based on it.\n switch (getRTLOffsetType()) {\n case 'negative':\n scrollOffset = -scrollLeft;\n break;\n\n case 'positive-descending':\n scrollOffset = scrollWidth - clientWidth - scrollLeft;\n break;\n }\n } // Prevent Safari's elastic scrolling from causing visual shaking when scrolling past bounds.\n\n\n scrollOffset = Math.max(0, Math.min(scrollOffset, scrollWidth - clientWidth));\n return {\n isScrolling: true,\n scrollDirection: prevState.scrollOffset < scrollLeft ? 'forward' : 'backward',\n scrollOffset: scrollOffset,\n scrollUpdateWasRequested: false\n };\n }, _this._resetIsScrollingDebounced);\n };\n\n _this._onScrollVertical = function (event) {\n var _event$currentTarget2 = event.currentTarget,\n clientHeight = _event$currentTarget2.clientHeight,\n scrollHeight = _event$currentTarget2.scrollHeight,\n scrollTop = _event$currentTarget2.scrollTop;\n\n _this.setState(function (prevState) {\n if (prevState.scrollOffset === scrollTop) {\n // Scroll position may have been updated by cDM/cDU,\n // In which case we don't need to trigger another render,\n // And we don't want to update state.isScrolling.\n return null;\n } // Prevent Safari's elastic scrolling from causing visual shaking when scrolling past bounds.\n\n\n var scrollOffset = Math.max(0, Math.min(scrollTop, scrollHeight - clientHeight));\n return {\n isScrolling: true,\n scrollDirection: prevState.scrollOffset < scrollOffset ? 'forward' : 'backward',\n scrollOffset: scrollOffset,\n scrollUpdateWasRequested: false\n };\n }, _this._resetIsScrollingDebounced);\n };\n\n _this._outerRefSetter = function (ref) {\n var outerRef = _this.props.outerRef;\n _this._outerRef = ref;\n\n if (typeof outerRef === 'function') {\n outerRef(ref);\n } else if (outerRef != null && typeof outerRef === 'object' && outerRef.hasOwnProperty('current')) {\n outerRef.current = ref;\n }\n };\n\n _this._resetIsScrollingDebounced = function () {\n if (_this._resetIsScrollingTimeoutId !== null) {\n cancelTimeout(_this._resetIsScrollingTimeoutId);\n }\n\n _this._resetIsScrollingTimeoutId = requestTimeout(_this._resetIsScrolling, IS_SCROLLING_DEBOUNCE_INTERVAL$1);\n };\n\n _this._resetIsScrolling = function () {\n _this._resetIsScrollingTimeoutId = null;\n\n _this.setState({\n isScrolling: false\n }, function () {\n // Clear style cache after state update has been committed.\n // This way we don't break pure sCU for items that don't use isScrolling param.\n _this._getItemStyleCache(-1, null);\n });\n };\n\n return _this;\n }\n\n List.getDerivedStateFromProps = function getDerivedStateFromProps(nextProps, prevState) {\n validateSharedProps$1(nextProps, prevState);\n validateProps(nextProps);\n return null;\n };\n\n var _proto = List.prototype;\n\n _proto.scrollTo = function scrollTo(scrollOffset) {\n scrollOffset = Math.max(0, scrollOffset);\n this.setState(function (prevState) {\n if (prevState.scrollOffset === scrollOffset) {\n return null;\n }\n\n return {\n scrollDirection: prevState.scrollOffset < scrollOffset ? 'forward' : 'backward',\n scrollOffset: scrollOffset,\n scrollUpdateWasRequested: true\n };\n }, this._resetIsScrollingDebounced);\n };\n\n _proto.scrollToItem = function scrollToItem(index, align) {\n if (align === void 0) {\n align = 'auto';\n }\n\n var itemCount = this.props.itemCount;\n var scrollOffset = this.state.scrollOffset;\n index = Math.max(0, Math.min(index, itemCount - 1));\n this.scrollTo(getOffsetForIndexAndAlignment(this.props, index, align, scrollOffset, this._instanceProps));\n };\n\n _proto.componentDidMount = function componentDidMount() {\n var _this$props2 = this.props,\n direction = _this$props2.direction,\n initialScrollOffset = _this$props2.initialScrollOffset,\n layout = _this$props2.layout;\n\n if (typeof initialScrollOffset === 'number' && this._outerRef != null) {\n var outerRef = this._outerRef; // TODO Deprecate direction \"horizontal\"\n\n if (direction === 'horizontal' || layout === 'horizontal') {\n outerRef.scrollLeft = initialScrollOffset;\n } else {\n outerRef.scrollTop = initialScrollOffset;\n }\n }\n\n this._callPropsCallbacks();\n };\n\n _proto.componentDidUpdate = function componentDidUpdate() {\n var _this$props3 = this.props,\n direction = _this$props3.direction,\n layout = _this$props3.layout;\n var _this$state = this.state,\n scrollOffset = _this$state.scrollOffset,\n scrollUpdateWasRequested = _this$state.scrollUpdateWasRequested;\n\n if (scrollUpdateWasRequested && this._outerRef != null) {\n var outerRef = this._outerRef; // TODO Deprecate direction \"horizontal\"\n\n if (direction === 'horizontal' || layout === 'horizontal') {\n if (direction === 'rtl') {\n // TRICKY According to the spec, scrollLeft should be negative for RTL aligned elements.\n // This is not the case for all browsers though (e.g. Chrome reports values as positive, measured relative to the left).\n // So we need to determine which browser behavior we're dealing with, and mimic it.\n switch (getRTLOffsetType()) {\n case 'negative':\n outerRef.scrollLeft = -scrollOffset;\n break;\n\n case 'positive-ascending':\n outerRef.scrollLeft = scrollOffset;\n break;\n\n default:\n var clientWidth = outerRef.clientWidth,\n scrollWidth = outerRef.scrollWidth;\n outerRef.scrollLeft = scrollWidth - clientWidth - scrollOffset;\n break;\n }\n } else {\n outerRef.scrollLeft = scrollOffset;\n }\n } else {\n outerRef.scrollTop = scrollOffset;\n }\n }\n\n this._callPropsCallbacks();\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n if (this._resetIsScrollingTimeoutId !== null) {\n cancelTimeout(this._resetIsScrollingTimeoutId);\n }\n };\n\n _proto.render = function render() {\n var _this$props4 = this.props,\n children = _this$props4.children,\n className = _this$props4.className,\n direction = _this$props4.direction,\n height = _this$props4.height,\n innerRef = _this$props4.innerRef,\n innerElementType = _this$props4.innerElementType,\n innerTagName = _this$props4.innerTagName,\n itemCount = _this$props4.itemCount,\n itemData = _this$props4.itemData,\n _this$props4$itemKey = _this$props4.itemKey,\n itemKey = _this$props4$itemKey === void 0 ? defaultItemKey$1 : _this$props4$itemKey,\n layout = _this$props4.layout,\n outerElementType = _this$props4.outerElementType,\n outerTagName = _this$props4.outerTagName,\n style = _this$props4.style,\n useIsScrolling = _this$props4.useIsScrolling,\n width = _this$props4.width;\n var isScrolling = this.state.isScrolling; // TODO Deprecate direction \"horizontal\"\n\n var isHorizontal = direction === 'horizontal' || layout === 'horizontal';\n var onScroll = isHorizontal ? this._onScrollHorizontal : this._onScrollVertical;\n\n var _this$_getRangeToRend = this._getRangeToRender(),\n startIndex = _this$_getRangeToRend[0],\n stopIndex = _this$_getRangeToRend[1];\n\n var items = [];\n\n if (itemCount > 0) {\n for (var _index = startIndex; _index <= stopIndex; _index++) {\n items.push((0,external_React_.createElement)(children, {\n data: itemData,\n key: itemKey(_index, itemData),\n index: _index,\n isScrolling: useIsScrolling ? isScrolling : undefined,\n style: this._getItemStyle(_index)\n }));\n }\n } // Read this value AFTER items have been created,\n // So their actual sizes (if variable) are taken into consideration.\n\n\n var estimatedTotalSize = getEstimatedTotalSize(this.props, this._instanceProps);\n return (0,external_React_.createElement)(outerElementType || outerTagName || 'div', {\n className: className,\n onScroll: onScroll,\n ref: this._outerRefSetter,\n style: (0,esm_extends[\"default\"])({\n position: 'relative',\n height: height,\n width: width,\n overflow: 'auto',\n WebkitOverflowScrolling: 'touch',\n willChange: 'transform',\n direction: direction\n }, style)\n }, (0,external_React_.createElement)(innerElementType || innerTagName || 'div', {\n children: items,\n ref: innerRef,\n style: {\n height: isHorizontal ? '100%' : estimatedTotalSize,\n pointerEvents: isScrolling ? 'none' : undefined,\n width: isHorizontal ? estimatedTotalSize : '100%'\n }\n }));\n };\n\n _proto._callPropsCallbacks = function _callPropsCallbacks() {\n if (typeof this.props.onItemsRendered === 'function') {\n var itemCount = this.props.itemCount;\n\n if (itemCount > 0) {\n var _this$_getRangeToRend2 = this._getRangeToRender(),\n _overscanStartIndex = _this$_getRangeToRend2[0],\n _overscanStopIndex = _this$_getRangeToRend2[1],\n _visibleStartIndex = _this$_getRangeToRend2[2],\n _visibleStopIndex = _this$_getRangeToRend2[3];\n\n this._callOnItemsRendered(_overscanStartIndex, _overscanStopIndex, _visibleStartIndex, _visibleStopIndex);\n }\n }\n\n if (typeof this.props.onScroll === 'function') {\n var _this$state2 = this.state,\n _scrollDirection = _this$state2.scrollDirection,\n _scrollOffset = _this$state2.scrollOffset,\n _scrollUpdateWasRequested = _this$state2.scrollUpdateWasRequested;\n\n this._callOnScroll(_scrollDirection, _scrollOffset, _scrollUpdateWasRequested);\n }\n } // Lazily create and cache item styles while scrolling,\n // So that pure component sCU will prevent re-renders.\n // We maintain this cache, and pass a style prop rather than index,\n // So that List can clear cached styles and force item re-render if necessary.\n ;\n\n _proto._getRangeToRender = function _getRangeToRender() {\n var _this$props5 = this.props,\n itemCount = _this$props5.itemCount,\n overscanCount = _this$props5.overscanCount;\n var _this$state3 = this.state,\n isScrolling = _this$state3.isScrolling,\n scrollDirection = _this$state3.scrollDirection,\n scrollOffset = _this$state3.scrollOffset;\n\n if (itemCount === 0) {\n return [0, 0, 0, 0];\n }\n\n var startIndex = getStartIndexForOffset(this.props, scrollOffset, this._instanceProps);\n var stopIndex = getStopIndexForStartIndex(this.props, startIndex, scrollOffset, this._instanceProps); // Overscan by one item in each direction so that tab/focus works.\n // If there isn't at least one extra item, tab loops back around.\n\n var overscanBackward = !isScrolling || scrollDirection === 'backward' ? Math.max(1, overscanCount) : 1;\n var overscanForward = !isScrolling || scrollDirection === 'forward' ? Math.max(1, overscanCount) : 1;\n return [Math.max(0, startIndex - overscanBackward), Math.max(0, Math.min(itemCount - 1, stopIndex + overscanForward)), startIndex, stopIndex];\n };\n\n return List;\n }(external_React_.PureComponent), _class.defaultProps = {\n direction: 'ltr',\n itemData: undefined,\n layout: 'vertical',\n overscanCount: 2,\n useIsScrolling: false\n }, _class;\n} // NOTE: I considered further wrapping individual items with a pure ListItem component.\n// This would avoid ever calling the render function for the same index more than once,\n// But it would also add the overhead of a lot of components/fibers.\n// I assume people already do this (render function returning a class component),\n// So my doing it would just unnecessarily double the wrappers.\n\nvar validateSharedProps$1 = function validateSharedProps(_ref2, _ref3) {\n var children = _ref2.children,\n direction = _ref2.direction,\n height = _ref2.height,\n layout = _ref2.layout,\n innerTagName = _ref2.innerTagName,\n outerTagName = _ref2.outerTagName,\n width = _ref2.width;\n var instance = _ref3.instance;\n\n if (false) { var isHorizontal; }\n};\n\nvar DEFAULT_ESTIMATED_ITEM_SIZE$1 = 50;\n\nvar getItemMetadata$1 = function getItemMetadata(props, index, instanceProps) {\n var _ref = props,\n itemSize = _ref.itemSize;\n var itemMetadataMap = instanceProps.itemMetadataMap,\n lastMeasuredIndex = instanceProps.lastMeasuredIndex;\n\n if (index > lastMeasuredIndex) {\n var offset = 0;\n\n if (lastMeasuredIndex >= 0) {\n var itemMetadata = itemMetadataMap[lastMeasuredIndex];\n offset = itemMetadata.offset + itemMetadata.size;\n }\n\n for (var i = lastMeasuredIndex + 1; i <= index; i++) {\n var size = itemSize(i);\n itemMetadataMap[i] = {\n offset: offset,\n size: size\n };\n offset += size;\n }\n\n instanceProps.lastMeasuredIndex = index;\n }\n\n return itemMetadataMap[index];\n};\n\nvar findNearestItem$1 = function findNearestItem(props, instanceProps, offset) {\n var itemMetadataMap = instanceProps.itemMetadataMap,\n lastMeasuredIndex = instanceProps.lastMeasuredIndex;\n var lastMeasuredItemOffset = lastMeasuredIndex > 0 ? itemMetadataMap[lastMeasuredIndex].offset : 0;\n\n if (lastMeasuredItemOffset >= offset) {\n // If we've already measured items within this range just use a binary search as it's faster.\n return findNearestItemBinarySearch$1(props, instanceProps, lastMeasuredIndex, 0, offset);\n } else {\n // If we haven't yet measured this high, fallback to an exponential search with an inner binary search.\n // The exponential search avoids pre-computing sizes for the full set of items as a binary search would.\n // The overall complexity for this approach is O(log n).\n return findNearestItemExponentialSearch$1(props, instanceProps, Math.max(0, lastMeasuredIndex), offset);\n }\n};\n\nvar findNearestItemBinarySearch$1 = function findNearestItemBinarySearch(props, instanceProps, high, low, offset) {\n while (low <= high) {\n var middle = low + Math.floor((high - low) / 2);\n var currentOffset = getItemMetadata$1(props, middle, instanceProps).offset;\n\n if (currentOffset === offset) {\n return middle;\n } else if (currentOffset < offset) {\n low = middle + 1;\n } else if (currentOffset > offset) {\n high = middle - 1;\n }\n }\n\n if (low > 0) {\n return low - 1;\n } else {\n return 0;\n }\n};\n\nvar findNearestItemExponentialSearch$1 = function findNearestItemExponentialSearch(props, instanceProps, index, offset) {\n var itemCount = props.itemCount;\n var interval = 1;\n\n while (index < itemCount && getItemMetadata$1(props, index, instanceProps).offset < offset) {\n index += interval;\n interval *= 2;\n }\n\n return findNearestItemBinarySearch$1(props, instanceProps, Math.min(index, itemCount - 1), Math.floor(index / 2), offset);\n};\n\nvar getEstimatedTotalSize = function getEstimatedTotalSize(_ref2, _ref3) {\n var itemCount = _ref2.itemCount;\n var itemMetadataMap = _ref3.itemMetadataMap,\n estimatedItemSize = _ref3.estimatedItemSize,\n lastMeasuredIndex = _ref3.lastMeasuredIndex;\n var totalSizeOfMeasuredItems = 0; // Edge case check for when the number of items decreases while a scroll is in progress.\n // https://github.com/bvaughn/react-window/pull/138\n\n if (lastMeasuredIndex >= itemCount) {\n lastMeasuredIndex = itemCount - 1;\n }\n\n if (lastMeasuredIndex >= 0) {\n var itemMetadata = itemMetadataMap[lastMeasuredIndex];\n totalSizeOfMeasuredItems = itemMetadata.offset + itemMetadata.size;\n }\n\n var numUnmeasuredItems = itemCount - lastMeasuredIndex - 1;\n var totalSizeOfUnmeasuredItems = numUnmeasuredItems * estimatedItemSize;\n return totalSizeOfMeasuredItems + totalSizeOfUnmeasuredItems;\n};\n\nvar VariableSizeList = /*#__PURE__*/createListComponent({\n getItemOffset: function getItemOffset(props, index, instanceProps) {\n return getItemMetadata$1(props, index, instanceProps).offset;\n },\n getItemSize: function getItemSize(props, index, instanceProps) {\n return instanceProps.itemMetadataMap[index].size;\n },\n getEstimatedTotalSize: getEstimatedTotalSize,\n getOffsetForIndexAndAlignment: function getOffsetForIndexAndAlignment(props, index, align, scrollOffset, instanceProps) {\n var direction = props.direction,\n height = props.height,\n layout = props.layout,\n width = props.width; // TODO Deprecate direction \"horizontal\"\n\n var isHorizontal = direction === 'horizontal' || layout === 'horizontal';\n var size = isHorizontal ? width : height;\n var itemMetadata = getItemMetadata$1(props, index, instanceProps); // Get estimated total size after ItemMetadata is computed,\n // To ensure it reflects actual measurements instead of just estimates.\n\n var estimatedTotalSize = getEstimatedTotalSize(props, instanceProps);\n var maxOffset = Math.max(0, Math.min(estimatedTotalSize - size, itemMetadata.offset));\n var minOffset = Math.max(0, itemMetadata.offset - size + itemMetadata.size);\n\n if (align === 'smart') {\n if (scrollOffset >= minOffset - size && scrollOffset <= maxOffset + size) {\n align = 'auto';\n } else {\n align = 'center';\n }\n }\n\n switch (align) {\n case 'start':\n return maxOffset;\n\n case 'end':\n return minOffset;\n\n case 'center':\n return Math.round(minOffset + (maxOffset - minOffset) / 2);\n\n case 'auto':\n default:\n if (scrollOffset >= minOffset && scrollOffset <= maxOffset) {\n return scrollOffset;\n } else if (scrollOffset < minOffset) {\n return minOffset;\n } else {\n return maxOffset;\n }\n\n }\n },\n getStartIndexForOffset: function getStartIndexForOffset(props, offset, instanceProps) {\n return findNearestItem$1(props, instanceProps, offset);\n },\n getStopIndexForStartIndex: function getStopIndexForStartIndex(props, startIndex, scrollOffset, instanceProps) {\n var direction = props.direction,\n height = props.height,\n itemCount = props.itemCount,\n layout = props.layout,\n width = props.width; // TODO Deprecate direction \"horizontal\"\n\n var isHorizontal = direction === 'horizontal' || layout === 'horizontal';\n var size = isHorizontal ? width : height;\n var itemMetadata = getItemMetadata$1(props, startIndex, instanceProps);\n var maxOffset = scrollOffset + size;\n var offset = itemMetadata.offset + itemMetadata.size;\n var stopIndex = startIndex;\n\n while (stopIndex < itemCount - 1 && offset < maxOffset) {\n stopIndex++;\n offset += getItemMetadata$1(props, stopIndex, instanceProps).size;\n }\n\n return stopIndex;\n },\n initInstanceProps: function initInstanceProps(props, instance) {\n var _ref4 = props,\n estimatedItemSize = _ref4.estimatedItemSize;\n var instanceProps = {\n itemMetadataMap: {},\n estimatedItemSize: estimatedItemSize || DEFAULT_ESTIMATED_ITEM_SIZE$1,\n lastMeasuredIndex: -1\n };\n\n instance.resetAfterIndex = function (index, shouldForceUpdate) {\n if (shouldForceUpdate === void 0) {\n shouldForceUpdate = true;\n }\n\n instanceProps.lastMeasuredIndex = Math.min(instanceProps.lastMeasuredIndex, index - 1); // We could potentially optimize further by only evicting styles after this index,\n // But since styles are only cached while scrolling is in progress-\n // It seems an unnecessary optimization.\n // It's unlikely that resetAfterIndex() will be called while a user is scrolling.\n\n instance._getItemStyleCache(-1);\n\n if (shouldForceUpdate) {\n instance.forceUpdate();\n }\n };\n\n return instanceProps;\n },\n shouldResetStyleCacheOnItemSizeChange: false,\n validateProps: function validateProps(_ref5) {\n var itemSize = _ref5.itemSize;\n\n if (false) {}\n }\n});\n\nvar FixedSizeGrid = /*#__PURE__*/createGridComponent({\n getColumnOffset: function getColumnOffset(_ref, index) {\n var columnWidth = _ref.columnWidth;\n return index * columnWidth;\n },\n getColumnWidth: function getColumnWidth(_ref2, index) {\n var columnWidth = _ref2.columnWidth;\n return columnWidth;\n },\n getRowOffset: function getRowOffset(_ref3, index) {\n var rowHeight = _ref3.rowHeight;\n return index * rowHeight;\n },\n getRowHeight: function getRowHeight(_ref4, index) {\n var rowHeight = _ref4.rowHeight;\n return rowHeight;\n },\n getEstimatedTotalHeight: function getEstimatedTotalHeight(_ref5) {\n var rowCount = _ref5.rowCount,\n rowHeight = _ref5.rowHeight;\n return rowHeight * rowCount;\n },\n getEstimatedTotalWidth: function getEstimatedTotalWidth(_ref6) {\n var columnCount = _ref6.columnCount,\n columnWidth = _ref6.columnWidth;\n return columnWidth * columnCount;\n },\n getOffsetForColumnAndAlignment: function getOffsetForColumnAndAlignment(_ref7, columnIndex, align, scrollLeft, instanceProps, scrollbarSize) {\n var columnCount = _ref7.columnCount,\n columnWidth = _ref7.columnWidth,\n width = _ref7.width;\n var lastColumnOffset = Math.max(0, columnCount * columnWidth - width);\n var maxOffset = Math.min(lastColumnOffset, columnIndex * columnWidth);\n var minOffset = Math.max(0, columnIndex * columnWidth - width + scrollbarSize + columnWidth);\n\n if (align === 'smart') {\n if (scrollLeft >= minOffset - width && scrollLeft <= maxOffset + width) {\n align = 'auto';\n } else {\n align = 'center';\n }\n }\n\n switch (align) {\n case 'start':\n return maxOffset;\n\n case 'end':\n return minOffset;\n\n case 'center':\n // \"Centered\" offset is usually the average of the min and max.\n // But near the edges of the list, this doesn't hold true.\n var middleOffset = Math.round(minOffset + (maxOffset - minOffset) / 2);\n\n if (middleOffset < Math.ceil(width / 2)) {\n return 0; // near the beginning\n } else if (middleOffset > lastColumnOffset + Math.floor(width / 2)) {\n return lastColumnOffset; // near the end\n } else {\n return middleOffset;\n }\n\n case 'auto':\n default:\n if (scrollLeft >= minOffset && scrollLeft <= maxOffset) {\n return scrollLeft;\n } else if (minOffset > maxOffset) {\n // Because we only take into account the scrollbar size when calculating minOffset\n // this value can be larger than maxOffset when at the end of the list\n return minOffset;\n } else if (scrollLeft < minOffset) {\n return minOffset;\n } else {\n return maxOffset;\n }\n\n }\n },\n getOffsetForRowAndAlignment: function getOffsetForRowAndAlignment(_ref8, rowIndex, align, scrollTop, instanceProps, scrollbarSize) {\n var rowHeight = _ref8.rowHeight,\n height = _ref8.height,\n rowCount = _ref8.rowCount;\n var lastRowOffset = Math.max(0, rowCount * rowHeight - height);\n var maxOffset = Math.min(lastRowOffset, rowIndex * rowHeight);\n var minOffset = Math.max(0, rowIndex * rowHeight - height + scrollbarSize + rowHeight);\n\n if (align === 'smart') {\n if (scrollTop >= minOffset - height && scrollTop <= maxOffset + height) {\n align = 'auto';\n } else {\n align = 'center';\n }\n }\n\n switch (align) {\n case 'start':\n return maxOffset;\n\n case 'end':\n return minOffset;\n\n case 'center':\n // \"Centered\" offset is usually the average of the min and max.\n // But near the edges of the list, this doesn't hold true.\n var middleOffset = Math.round(minOffset + (maxOffset - minOffset) / 2);\n\n if (middleOffset < Math.ceil(height / 2)) {\n return 0; // near the beginning\n } else if (middleOffset > lastRowOffset + Math.floor(height / 2)) {\n return lastRowOffset; // near the end\n } else {\n return middleOffset;\n }\n\n case 'auto':\n default:\n if (scrollTop >= minOffset && scrollTop <= maxOffset) {\n return scrollTop;\n } else if (minOffset > maxOffset) {\n // Because we only take into account the scrollbar size when calculating minOffset\n // this value can be larger than maxOffset when at the end of the list\n return minOffset;\n } else if (scrollTop < minOffset) {\n return minOffset;\n } else {\n return maxOffset;\n }\n\n }\n },\n getColumnStartIndexForOffset: function getColumnStartIndexForOffset(_ref9, scrollLeft) {\n var columnWidth = _ref9.columnWidth,\n columnCount = _ref9.columnCount;\n return Math.max(0, Math.min(columnCount - 1, Math.floor(scrollLeft / columnWidth)));\n },\n getColumnStopIndexForStartIndex: function getColumnStopIndexForStartIndex(_ref10, startIndex, scrollLeft) {\n var columnWidth = _ref10.columnWidth,\n columnCount = _ref10.columnCount,\n width = _ref10.width;\n var left = startIndex * columnWidth;\n var numVisibleColumns = Math.ceil((width + scrollLeft - left) / columnWidth);\n return Math.max(0, Math.min(columnCount - 1, startIndex + numVisibleColumns - 1 // -1 is because stop index is inclusive\n ));\n },\n getRowStartIndexForOffset: function getRowStartIndexForOffset(_ref11, scrollTop) {\n var rowHeight = _ref11.rowHeight,\n rowCount = _ref11.rowCount;\n return Math.max(0, Math.min(rowCount - 1, Math.floor(scrollTop / rowHeight)));\n },\n getRowStopIndexForStartIndex: function getRowStopIndexForStartIndex(_ref12, startIndex, scrollTop) {\n var rowHeight = _ref12.rowHeight,\n rowCount = _ref12.rowCount,\n height = _ref12.height;\n var top = startIndex * rowHeight;\n var numVisibleRows = Math.ceil((height + scrollTop - top) / rowHeight);\n return Math.max(0, Math.min(rowCount - 1, startIndex + numVisibleRows - 1 // -1 is because stop index is inclusive\n ));\n },\n initInstanceProps: function initInstanceProps(props) {// Noop\n },\n shouldResetStyleCacheOnItemSizeChange: true,\n validateProps: function validateProps(_ref13) {\n var columnWidth = _ref13.columnWidth,\n rowHeight = _ref13.rowHeight;\n\n if (false) {}\n }\n});\n\nvar FixedSizeList = /*#__PURE__*/createListComponent({\n getItemOffset: function getItemOffset(_ref, index) {\n var itemSize = _ref.itemSize;\n return index * itemSize;\n },\n getItemSize: function getItemSize(_ref2, index) {\n var itemSize = _ref2.itemSize;\n return itemSize;\n },\n getEstimatedTotalSize: function getEstimatedTotalSize(_ref3) {\n var itemCount = _ref3.itemCount,\n itemSize = _ref3.itemSize;\n return itemSize * itemCount;\n },\n getOffsetForIndexAndAlignment: function getOffsetForIndexAndAlignment(_ref4, index, align, scrollOffset) {\n var direction = _ref4.direction,\n height = _ref4.height,\n itemCount = _ref4.itemCount,\n itemSize = _ref4.itemSize,\n layout = _ref4.layout,\n width = _ref4.width;\n // TODO Deprecate direction \"horizontal\"\n var isHorizontal = direction === 'horizontal' || layout === 'horizontal';\n var size = isHorizontal ? width : height;\n var lastItemOffset = Math.max(0, itemCount * itemSize - size);\n var maxOffset = Math.min(lastItemOffset, index * itemSize);\n var minOffset = Math.max(0, index * itemSize - size + itemSize);\n\n if (align === 'smart') {\n if (scrollOffset >= minOffset - size && scrollOffset <= maxOffset + size) {\n align = 'auto';\n } else {\n align = 'center';\n }\n }\n\n switch (align) {\n case 'start':\n return maxOffset;\n\n case 'end':\n return minOffset;\n\n case 'center':\n {\n // \"Centered\" offset is usually the average of the min and max.\n // But near the edges of the list, this doesn't hold true.\n var middleOffset = Math.round(minOffset + (maxOffset - minOffset) / 2);\n\n if (middleOffset < Math.ceil(size / 2)) {\n return 0; // near the beginning\n } else if (middleOffset > lastItemOffset + Math.floor(size / 2)) {\n return lastItemOffset; // near the end\n } else {\n return middleOffset;\n }\n }\n\n case 'auto':\n default:\n if (scrollOffset >= minOffset && scrollOffset <= maxOffset) {\n return scrollOffset;\n } else if (scrollOffset < minOffset) {\n return minOffset;\n } else {\n return maxOffset;\n }\n\n }\n },\n getStartIndexForOffset: function getStartIndexForOffset(_ref5, offset) {\n var itemCount = _ref5.itemCount,\n itemSize = _ref5.itemSize;\n return Math.max(0, Math.min(itemCount - 1, Math.floor(offset / itemSize)));\n },\n getStopIndexForStartIndex: function getStopIndexForStartIndex(_ref6, startIndex, scrollOffset) {\n var direction = _ref6.direction,\n height = _ref6.height,\n itemCount = _ref6.itemCount,\n itemSize = _ref6.itemSize,\n layout = _ref6.layout,\n width = _ref6.width;\n // TODO Deprecate direction \"horizontal\"\n var isHorizontal = direction === 'horizontal' || layout === 'horizontal';\n var offset = startIndex * itemSize;\n var size = isHorizontal ? width : height;\n var numVisibleItems = Math.ceil((size + scrollOffset - offset) / itemSize);\n return Math.max(0, Math.min(itemCount - 1, startIndex + numVisibleItems - 1 // -1 is because stop index is inclusive\n ));\n },\n initInstanceProps: function initInstanceProps(props) {// Noop\n },\n shouldResetStyleCacheOnItemSizeChange: true,\n validateProps: function validateProps(_ref7) {\n var itemSize = _ref7.itemSize;\n\n if (false) {}\n }\n});\n\n// Pulled from react-compat\n// https://github.com/developit/preact-compat/blob/7c5de00e7c85e2ffd011bf3af02899b63f699d3a/src/index.js#L349\nfunction shallowDiffers(prev, next) {\n for (var attribute in prev) {\n if (!(attribute in next)) {\n return true;\n }\n }\n\n for (var _attribute in next) {\n if (prev[_attribute] !== next[_attribute]) {\n return true;\n }\n }\n\n return false;\n}\n\nvar _excluded = (/* unused pure expression or super */ null && ([\"style\"])),\n _excluded2 = (/* unused pure expression or super */ null && ([\"style\"]));\n// It knows to compare individual style props and ignore the wrapper object.\n// See https://reactjs.org/docs/react-api.html#reactmemo\n\nfunction areEqual(prevProps, nextProps) {\n var prevStyle = prevProps.style,\n prevRest = _objectWithoutPropertiesLoose(prevProps, _excluded);\n\n var nextStyle = nextProps.style,\n nextRest = _objectWithoutPropertiesLoose(nextProps, _excluded2);\n\n return !shallowDiffers(prevStyle, nextStyle) && !shallowDiffers(prevRest, nextRest);\n}\n\n// It knows to compare individual style props and ignore the wrapper object.\n// See https://reactjs.org/docs/react-component.html#shouldcomponentupdate\n\nfunction shouldComponentUpdate(nextProps, nextState) {\n return !areEqual(this.props, nextProps) || shallowDiffers(this.state, nextState);\n}\n\n\n//# sourceMappingURL=index.esm.js.map\n\n// EXTERNAL MODULE: ./node_modules/webfontloader/webfontloader.js\nvar webfontloader = __webpack_require__(5933);\nvar webfontloader_default = /*#__PURE__*/__webpack_require__.n(webfontloader);\n;// CONCATENATED MODULE: ./node_modules/react-virtualized-auto-sizer/dist/index.esm.js\n\n\nvar classCallCheck = function (instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n};\n\nvar createClass = function () {\n function defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n }\n\n return function (Constructor, protoProps, staticProps) {\n if (protoProps) defineProperties(Constructor.prototype, protoProps);\n if (staticProps) defineProperties(Constructor, staticProps);\n return Constructor;\n };\n}();\n\nvar _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n};\n\nvar inherits = function (subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass);\n }\n\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass;\n};\n\nvar possibleConstructorReturn = function (self, call) {\n if (!self) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self;\n};\n\nvar slicedToArray = function () {\n function sliceIterator(arr, i) {\n var _arr = [];\n var _n = true;\n var _d = false;\n var _e = undefined;\n\n try {\n for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"]) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n\n return _arr;\n }\n\n return function (arr, i) {\n if (Array.isArray(arr)) {\n return arr;\n } else if (Symbol.iterator in Object(arr)) {\n return sliceIterator(arr, i);\n } else {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance\");\n }\n };\n}();\n\n/**\n * Detect Element Resize.\n * https://github.com/sdecima/javascript-detect-element-resize\n * Sebastian Decima\n *\n * Forked from version 0.5.3; includes the following modifications:\n * 1) Guard against unsafe 'window' and 'document' references (to support SSR).\n * 2) Defer initialization code via a top-level function wrapper (to support SSR).\n * 3) Avoid unnecessary reflows by not measuring size for scroll events bubbling from children.\n * 4) Add nonce for style element.\n **/\n\n// Check `document` and `window` in case of server-side rendering\nvar windowObject = void 0;\nif (typeof window !== 'undefined') {\n windowObject = window;\n\n // eslint-disable-next-line no-restricted-globals\n} else if (typeof self !== 'undefined') {\n // eslint-disable-next-line no-restricted-globals\n windowObject = self;\n} else {\n windowObject = __webpack_require__.g;\n}\n\nvar cancelFrame = null;\nvar requestFrame = null;\n\nvar TIMEOUT_DURATION = 20;\n\nvar clearTimeoutFn = windowObject.clearTimeout;\nvar setTimeoutFn = windowObject.setTimeout;\n\nvar cancelAnimationFrameFn = windowObject.cancelAnimationFrame || windowObject.mozCancelAnimationFrame || windowObject.webkitCancelAnimationFrame;\n\nvar requestAnimationFrameFn = windowObject.requestAnimationFrame || windowObject.mozRequestAnimationFrame || windowObject.webkitRequestAnimationFrame;\n\nif (cancelAnimationFrameFn == null || requestAnimationFrameFn == null) {\n // For environments that don't support animation frame,\n // fallback to a setTimeout based approach.\n cancelFrame = clearTimeoutFn;\n requestFrame = function requestAnimationFrameViaSetTimeout(callback) {\n return setTimeoutFn(callback, TIMEOUT_DURATION);\n };\n} else {\n // Counter intuitively, environments that support animation frames can be trickier.\n // Chrome's \"Throttle non-visible cross-origin iframes\" flag can prevent rAFs from being called.\n // In this case, we should fallback to a setTimeout() implementation.\n cancelFrame = function cancelFrame(_ref) {\n var _ref2 = slicedToArray(_ref, 2),\n animationFrameID = _ref2[0],\n timeoutID = _ref2[1];\n\n cancelAnimationFrameFn(animationFrameID);\n clearTimeoutFn(timeoutID);\n };\n requestFrame = function requestAnimationFrameWithSetTimeoutFallback(callback) {\n var animationFrameID = requestAnimationFrameFn(function animationFrameCallback() {\n clearTimeoutFn(timeoutID);\n callback();\n });\n\n var timeoutID = setTimeoutFn(function timeoutCallback() {\n cancelAnimationFrameFn(animationFrameID);\n callback();\n }, TIMEOUT_DURATION);\n\n return [animationFrameID, timeoutID];\n };\n}\n\nfunction createDetectElementResize(nonce) {\n var animationKeyframes = void 0;\n var animationName = void 0;\n var animationStartEvent = void 0;\n var animationStyle = void 0;\n var checkTriggers = void 0;\n var resetTriggers = void 0;\n var scrollListener = void 0;\n\n var attachEvent = typeof document !== 'undefined' && document.attachEvent;\n if (!attachEvent) {\n resetTriggers = function resetTriggers(element) {\n var triggers = element.__resizeTriggers__,\n expand = triggers.firstElementChild,\n contract = triggers.lastElementChild,\n expandChild = expand.firstElementChild;\n contract.scrollLeft = contract.scrollWidth;\n contract.scrollTop = contract.scrollHeight;\n expandChild.style.width = expand.offsetWidth + 1 + 'px';\n expandChild.style.height = expand.offsetHeight + 1 + 'px';\n expand.scrollLeft = expand.scrollWidth;\n expand.scrollTop = expand.scrollHeight;\n };\n\n checkTriggers = function checkTriggers(element) {\n return element.offsetWidth !== element.__resizeLast__.width || element.offsetHeight !== element.__resizeLast__.height;\n };\n\n scrollListener = function scrollListener(e) {\n // Don't measure (which forces) reflow for scrolls that happen inside of children!\n if (e.target.className && typeof e.target.className.indexOf === 'function' && e.target.className.indexOf('contract-trigger') < 0 && e.target.className.indexOf('expand-trigger') < 0) {\n return;\n }\n\n var element = this;\n resetTriggers(this);\n if (this.__resizeRAF__) {\n cancelFrame(this.__resizeRAF__);\n }\n this.__resizeRAF__ = requestFrame(function animationFrame() {\n if (checkTriggers(element)) {\n element.__resizeLast__.width = element.offsetWidth;\n element.__resizeLast__.height = element.offsetHeight;\n element.__resizeListeners__.forEach(function forEachResizeListener(fn) {\n fn.call(element, e);\n });\n }\n });\n };\n\n /* Detect CSS Animations support to detect element display/re-attach */\n var animation = false;\n var keyframeprefix = '';\n animationStartEvent = 'animationstart';\n var domPrefixes = 'Webkit Moz O ms'.split(' ');\n var startEvents = 'webkitAnimationStart animationstart oAnimationStart MSAnimationStart'.split(' ');\n var pfx = '';\n {\n var elm = document.createElement('fakeelement');\n if (elm.style.animationName !== undefined) {\n animation = true;\n }\n\n if (animation === false) {\n for (var i = 0; i < domPrefixes.length; i++) {\n if (elm.style[domPrefixes[i] + 'AnimationName'] !== undefined) {\n pfx = domPrefixes[i];\n keyframeprefix = '-' + pfx.toLowerCase() + '-';\n animationStartEvent = startEvents[i];\n animation = true;\n break;\n }\n }\n }\n }\n\n animationName = 'resizeanim';\n animationKeyframes = '@' + keyframeprefix + 'keyframes ' + animationName + ' { from { opacity: 0; } to { opacity: 0; } } ';\n animationStyle = keyframeprefix + 'animation: 1ms ' + animationName + '; ';\n }\n\n var createStyles = function createStyles(doc) {\n if (!doc.getElementById('detectElementResize')) {\n //opacity:0 works around a chrome bug https://code.google.com/p/chromium/issues/detail?id=286360\n var css = (animationKeyframes ? animationKeyframes : '') + '.resize-triggers { ' + (animationStyle ? animationStyle : '') + 'visibility: hidden; opacity: 0; } ' + '.resize-triggers, .resize-triggers > div, .contract-trigger:before { content: \" \"; display: block; position: absolute; top: 0; left: 0; height: 100%; width: 100%; overflow: hidden; z-index: -1; } .resize-triggers > div { background: #eee; overflow: auto; } .contract-trigger:before { width: 200%; height: 200%; }',\n head = doc.head || doc.getElementsByTagName('head')[0],\n style = doc.createElement('style');\n\n style.id = 'detectElementResize';\n style.type = 'text/css';\n\n if (nonce != null) {\n style.setAttribute('nonce', nonce);\n }\n\n if (style.styleSheet) {\n style.styleSheet.cssText = css;\n } else {\n style.appendChild(doc.createTextNode(css));\n }\n\n head.appendChild(style);\n }\n };\n\n var addResizeListener = function addResizeListener(element, fn) {\n if (attachEvent) {\n element.attachEvent('onresize', fn);\n } else {\n if (!element.__resizeTriggers__) {\n var doc = element.ownerDocument;\n var elementStyle = windowObject.getComputedStyle(element);\n if (elementStyle && elementStyle.position === 'static') {\n element.style.position = 'relative';\n }\n createStyles(doc);\n element.__resizeLast__ = {};\n element.__resizeListeners__ = [];\n (element.__resizeTriggers__ = doc.createElement('div')).className = 'resize-triggers';\n var expandTrigger = doc.createElement('div');\n expandTrigger.className = 'expand-trigger';\n expandTrigger.appendChild(doc.createElement('div'));\n var contractTrigger = doc.createElement('div');\n contractTrigger.className = 'contract-trigger';\n element.__resizeTriggers__.appendChild(expandTrigger);\n element.__resizeTriggers__.appendChild(contractTrigger);\n element.appendChild(element.__resizeTriggers__);\n resetTriggers(element);\n element.addEventListener('scroll', scrollListener, true);\n\n /* Listen for a css animation to detect element display/re-attach */\n if (animationStartEvent) {\n element.__resizeTriggers__.__animationListener__ = function animationListener(e) {\n if (e.animationName === animationName) {\n resetTriggers(element);\n }\n };\n element.__resizeTriggers__.addEventListener(animationStartEvent, element.__resizeTriggers__.__animationListener__);\n }\n }\n element.__resizeListeners__.push(fn);\n }\n };\n\n var removeResizeListener = function removeResizeListener(element, fn) {\n if (attachEvent) {\n element.detachEvent('onresize', fn);\n } else {\n element.__resizeListeners__.splice(element.__resizeListeners__.indexOf(fn), 1);\n if (!element.__resizeListeners__.length) {\n element.removeEventListener('scroll', scrollListener, true);\n if (element.__resizeTriggers__.__animationListener__) {\n element.__resizeTriggers__.removeEventListener(animationStartEvent, element.__resizeTriggers__.__animationListener__);\n element.__resizeTriggers__.__animationListener__ = null;\n }\n try {\n element.__resizeTriggers__ = !element.removeChild(element.__resizeTriggers__);\n } catch (e) {\n // Preact compat; see developit/preact-compat/issues/228\n }\n }\n }\n };\n\n return {\n addResizeListener: addResizeListener,\n removeResizeListener: removeResizeListener\n };\n}\n\nvar AutoSizer = function (_React$PureComponent) {\n inherits(AutoSizer, _React$PureComponent);\n\n function AutoSizer() {\n var _ref;\n\n var _temp, _this, _ret;\n\n classCallCheck(this, AutoSizer);\n\n for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return _ret = (_temp = (_this = possibleConstructorReturn(this, (_ref = AutoSizer.__proto__ || Object.getPrototypeOf(AutoSizer)).call.apply(_ref, [this].concat(args))), _this), _this.state = {\n height: _this.props.defaultHeight || 0,\n width: _this.props.defaultWidth || 0\n }, _this._onResize = function () {\n var _this$props = _this.props,\n disableHeight = _this$props.disableHeight,\n disableWidth = _this$props.disableWidth,\n onResize = _this$props.onResize;\n\n\n if (_this._parentNode) {\n // Guard against AutoSizer component being removed from the DOM immediately after being added.\n // This can result in invalid style values which can result in NaN values if we don't handle them.\n // See issue #150 for more context.\n\n var _height = _this._parentNode.offsetHeight || 0;\n var _width = _this._parentNode.offsetWidth || 0;\n\n var _style = window.getComputedStyle(_this._parentNode) || {};\n var paddingLeft = parseInt(_style.paddingLeft, 10) || 0;\n var paddingRight = parseInt(_style.paddingRight, 10) || 0;\n var paddingTop = parseInt(_style.paddingTop, 10) || 0;\n var paddingBottom = parseInt(_style.paddingBottom, 10) || 0;\n\n var newHeight = _height - paddingTop - paddingBottom;\n var newWidth = _width - paddingLeft - paddingRight;\n\n if (!disableHeight && _this.state.height !== newHeight || !disableWidth && _this.state.width !== newWidth) {\n _this.setState({\n height: _height - paddingTop - paddingBottom,\n width: _width - paddingLeft - paddingRight\n });\n\n onResize({ height: _height, width: _width });\n }\n }\n }, _this._setRef = function (autoSizer) {\n _this._autoSizer = autoSizer;\n }, _temp), possibleConstructorReturn(_this, _ret);\n }\n\n createClass(AutoSizer, [{\n key: 'componentDidMount',\n value: function componentDidMount() {\n var nonce = this.props.nonce;\n\n if (this._autoSizer && this._autoSizer.parentNode && this._autoSizer.parentNode.ownerDocument && this._autoSizer.parentNode.ownerDocument.defaultView && this._autoSizer.parentNode instanceof this._autoSizer.parentNode.ownerDocument.defaultView.HTMLElement) {\n // Delay access of parentNode until mount.\n // This handles edge-cases where the component has already been unmounted before its ref has been set,\n // As well as libraries like react-lite which have a slightly different lifecycle.\n this._parentNode = this._autoSizer.parentNode;\n\n // Defer requiring resize handler in order to support server-side rendering.\n // See issue #41\n this._detectElementResize = createDetectElementResize(nonce);\n this._detectElementResize.addResizeListener(this._parentNode, this._onResize);\n\n this._onResize();\n }\n }\n }, {\n key: 'componentWillUnmount',\n value: function componentWillUnmount() {\n if (this._detectElementResize && this._parentNode) {\n this._detectElementResize.removeResizeListener(this._parentNode, this._onResize);\n }\n }\n }, {\n key: 'render',\n value: function render() {\n var _props = this.props,\n children = _props.children,\n className = _props.className,\n disableHeight = _props.disableHeight,\n disableWidth = _props.disableWidth,\n style = _props.style;\n var _state = this.state,\n height = _state.height,\n width = _state.width;\n\n // Outer div should not force width/height since that may prevent containers from shrinking.\n // Inner component should overflow and use calculated width/height.\n // See issue #68 for more information.\n\n var outerStyle = { overflow: 'visible' };\n var childParams = {};\n\n // Avoid rendering children before the initial measurements have been collected.\n // At best this would just be wasting cycles.\n var bailoutOnChildren = false;\n\n if (!disableHeight) {\n if (height === 0) {\n bailoutOnChildren = true;\n }\n outerStyle.height = 0;\n childParams.height = height;\n }\n\n if (!disableWidth) {\n if (width === 0) {\n bailoutOnChildren = true;\n }\n outerStyle.width = 0;\n childParams.width = width;\n }\n\n return (0,external_React_.createElement)(\n 'div',\n {\n className: className,\n ref: this._setRef,\n style: _extends({}, outerStyle, style)\n },\n !bailoutOnChildren && children(childParams)\n );\n }\n }]);\n return AutoSizer;\n}(external_React_.PureComponent);\n\nAutoSizer.defaultProps = {\n onResize: function onResize() {},\n disableHeight: false,\n disableWidth: false,\n style: {}\n};\n\n/* harmony default export */ const index_esm = ((/* unused pure expression or super */ null && (AutoSizer)));\n\n;// CONCATENATED MODULE: ./static/js/options/options/typography/FontsList.js\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\n\nlet loadedFonts = [];\n\nconst loadGoogleFonts = font_families => {\n if (font_families.length === 0) return;\n loadedFonts = [...loadedFonts, ...font_families.map(_ref => {\n let {\n family\n } = _ref;\n return family;\n })];\n const googleFonts = font_families.map(_ref2 => {\n let {\n family\n } = _ref2;\n return family;\n }).filter(family => family.indexOf('ct_typekit') === -1);\n const typekitFonts = font_families.filter(_ref3 => {\n let {\n family\n } = _ref3;\n return family.indexOf('ct_typekit') > -1;\n });\n\n if (googleFonts.length > 0 || typekitFonts.length > 0) {\n webfontloader_default().load(_objectSpread(_objectSpread(_objectSpread({}, googleFonts.length > 0 ? {\n google: {\n families: googleFonts\n }\n } : {}), typekitFonts.length > 0 ? {\n typekit: {\n id: typekitFonts[0].kit\n }\n } : {}), {}, {\n classes: false,\n text: 'abcdefghijklmnopqrstuvwxyz'\n }));\n }\n};\n\nconst SingleFont = _ref4 => {\n let {\n data: {\n linearFontsList,\n onPickFamily,\n value\n },\n index,\n style\n } = _ref4;\n const family = linearFontsList[index];\n return (0,external_window_wp_element_.createElement)(\"div\", {\n style: style,\n onClick: () => onPickFamily(family),\n className: classnames_default()('ct-typography-single-font', `ct-${family.source}`, {\n active: family.family === value.family\n }),\n key: family.family\n }, (0,external_window_wp_element_.createElement)(\"span\", {\n className: \"ct-font-name\"\n }, familyForDisplay(family.display || family.family)), (0,external_window_wp_element_.createElement)(\"span\", {\n style: {\n fontFamily: fontFamilyToCSSFamily(family.family)\n },\n className: \"ct-font-preview\"\n }, \"Simply dummy text\"));\n};\n\nconst FontsList = _ref5 => {\n let {\n option,\n value,\n onPickFamily,\n typographyList,\n linearFontsList,\n currentView,\n searchTerm\n } = _ref5;\n const listRef = (0,external_window_wp_element_.useRef)(null);\n const timerRef = (0,external_window_wp_element_.useRef)(null);\n const [scrollTimer, setScrollTimer] = (0,external_window_wp_element_.useState)(null);\n (0,external_window_wp_element_.useEffect)(() => {\n if (value.family) {\n listRef.current.scrollToItem(linearFontsList.map(_ref6 => {\n let {\n family\n } = _ref6;\n return family;\n }).indexOf(value.family), 'start');\n }\n }, []);\n\n const onScroll = () => {\n scrollTimer && clearTimeout(scrollTimer);\n setScrollTimer(setTimeout(() => {\n if (!listRef.current) {\n return;\n }\n\n const [overscanStartIndex] = listRef.current._getRangeToRender();\n\n const perPage = 25;\n const totalPages = Math.ceil(linearFontsList.length / perPage);\n const startingPage = Math.ceil((overscanStartIndex + 1) / perPage); // const stopPage = Math.ceil((overscanStopIndex + 1) / perPage)\n\n const pageItems = [...Array(perPage)].map((_, i) => (startingPage - 1) * perPage + i).map(index => linearFontsList[index]).filter(s => !!s).filter(_ref7 => {\n let {\n source,\n family\n } = _ref7;\n return loadedFonts.indexOf(family) === -1 && (source === 'google' || source === 'typekit');\n });\n loadGoogleFonts(pageItems);\n }, 100));\n };\n\n (0,external_window_wp_element_.useEffect)(() => {\n onScroll();\n }, [linearFontsList]);\n return (0,external_window_wp_element_.createElement)(FixedSizeList, {\n height: 360,\n itemCount: linearFontsList.length,\n itemSize: 85,\n ref: listRef,\n onScroll: e => {\n onScroll();\n },\n itemData: {\n linearFontsList,\n onPickFamily,\n value\n },\n onItemsRendered: _ref8 => {\n let {\n overscanStartIndex,\n overscanStopIndex\n } = _ref8;\n },\n className: \"ct-typography-fonts\"\n }, SingleFont);\n};\n\n/* harmony default export */ const typography_FontsList = (FontsList);\n;// CONCATENATED MODULE: ./static/js/options/options/typography/VariationsList.js\nfunction VariationsList_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction VariationsList_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? VariationsList_ownKeys(Object(source), !0).forEach(function (key) { VariationsList_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : VariationsList_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction VariationsList_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\nconst VariationsList = _ref => {\n let {\n option,\n value,\n onChange,\n typographyList,\n props\n } = _ref;\n const selectedFontFamily = findSelectedFontFamily(value.family, typographyList);\n const parentEl = (0,external_window_wp_element_.useRef)(null);\n (0,external_window_wp_element_.useEffect)(() => {\n if (!selectedFontFamily) {\n return;\n }\n\n parentEl.current.scrollTop = (parentEl.current.children[selectedFontFamily.all_variations.indexOf(value.variation)] || parentEl.current.children[0]).offsetTop - parentEl.current.offsetTop;\n }, [selectedFontFamily]);\n return (0,external_window_wp_element_.createElement)(react_spring_web_esm.animated.ul, {\n style: props,\n className: \"ct-typography-variations\",\n ref: parentEl\n }, selectedFontFamily && selectedFontFamily.all_variations.map(variation => (0,external_window_wp_element_.createElement)(\"li\", {\n onClick: () => onChange(VariationsList_objectSpread(VariationsList_objectSpread({}, value), {}, {\n variation\n })),\n className: classnames_default()({\n active: variation === value.variation\n }),\n key: variation\n }, (0,external_window_wp_element_.createElement)(\"span\", {\n className: \"ct-variation-name\",\n \"data-variation\": variation\n }, humanizeVariations(variation)))));\n};\n\n/* harmony default export */ const typography_VariationsList = (VariationsList);\n// EXTERNAL MODULE: ./static/js/options/GenericOptionType.js\nvar GenericOptionType = __webpack_require__(6095);\n;// CONCATENATED MODULE: ./static/js/options/options/typography/FontOptions.js\nfunction FontOptions_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction FontOptions_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? FontOptions_ownKeys(Object(source), !0).forEach(function (key) { FontOptions_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : FontOptions_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction FontOptions_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\nconst FontOptions = _ref => {\n let {\n option,\n value,\n sizeRef,\n onChange,\n props\n } = _ref;\n return (0,external_window_wp_element_.createElement)(react_spring_web_esm.animated.ul, {\n style: props,\n className: \"ct-typography-options\",\n key: \"options\"\n }, (0,external_window_wp_element_.createElement)(\"li\", {\n key: \"size\"\n }, (0,external_window_wp_element_.createElement)(GenericOptionType/* default */.ZP, {\n value: value.size,\n values: value,\n id: \"size\",\n option: {\n id: 'size',\n label: (0,external_window_wp_i18n_.__)('Font Size', 'blocksy'),\n type: 'ct-slider',\n value: option.value.size,\n ref: sizeRef,\n responsive: option.typography_responsive || true,\n units: [{\n unit: 'px',\n min: 0,\n max: 200\n }, {\n unit: 'em',\n min: 0,\n max: 50\n }, {\n unit: 'rem',\n min: 0,\n max: 50\n }, {\n unit: 'pt',\n min: 0,\n max: 50\n }, {\n unit: 'vw',\n min: 0,\n max: 100\n }]\n },\n hasRevertButton: true,\n onChange: newValue => onChange(FontOptions_objectSpread(FontOptions_objectSpread({}, value), {}, {\n size: newValue\n }))\n })), (0,external_window_wp_element_.createElement)(\"li\", {\n key: \"line-height\"\n }, (0,external_window_wp_element_.createElement)(GenericOptionType/* default */.ZP, {\n value: value['line-height'],\n values: value,\n id: \"line-height\",\n option: {\n id: 'line-height',\n label: (0,external_window_wp_i18n_.__)('Line Height', 'blocksy'),\n type: 'ct-slider',\n value: option.value['line-height'],\n responsive: option.typography_responsive || true,\n units: [{\n unit: '',\n min: 0,\n max: 10,\n decimals: 1\n }, {\n unit: 'px',\n min: 0,\n max: 100\n }, {\n unit: 'em',\n min: 0,\n max: 100\n }, {\n unit: 'pt',\n min: 0,\n max: 100\n }, {\n unit: '%',\n min: 0,\n max: 100\n }]\n },\n hasRevertButton: true,\n onChange: newValue => onChange(FontOptions_objectSpread(FontOptions_objectSpread({}, value), {}, {\n 'line-height': newValue\n }))\n })), (0,external_window_wp_element_.createElement)(\"li\", {\n key: \"letter-spacing\"\n }, (0,external_window_wp_element_.createElement)(GenericOptionType/* default */.ZP, {\n value: value['letter-spacing'],\n values: value,\n id: \"letter-spacing\",\n option: {\n id: 'letter-spacing',\n label: (0,external_window_wp_i18n_.__)('Letter Spacing', 'blocksy'),\n type: 'ct-slider',\n value: option.value['letter-spacing'],\n responsive: option.typography_responsive || true,\n defaultPosition: 'center',\n units: [{\n unit: 'em',\n min: -5,\n max: 5,\n decimals: 1\n }, {\n unit: 'px',\n min: -20,\n max: 20,\n decimals: 1\n }, {\n unit: 'rem',\n min: -5,\n max: 5,\n decimals: 1\n }]\n },\n hasRevertButton: true,\n onChange: newValue => onChange(FontOptions_objectSpread(FontOptions_objectSpread({}, value), {}, {\n 'letter-spacing': newValue\n }))\n })), (0,external_window_wp_element_.createElement)(\"li\", {\n key: \"variant\",\n className: \"ct-typography-variant\"\n }, (0,external_window_wp_element_.createElement)(\"ul\", {\n className: classnames_default()('ct-text-transform')\n }, ['capitalize', 'uppercase'].map(variant => (0,external_window_wp_element_.createElement)(\"li\", {\n key: variant,\n onClick: () => onChange(FontOptions_objectSpread(FontOptions_objectSpread({}, value), {}, {\n 'text-transform': value['text-transform'] === variant ? 'none' : variant\n })),\n className: classnames_default()({\n active: variant === value['text-transform']\n }),\n \"data-variant\": variant\n }, (0,external_window_wp_element_.createElement)(\"i\", {\n className: \"ct-tooltip-top\"\n }, {\n capitalize: (0,external_window_wp_i18n_.__)('Capitalize', 'blocksy'),\n uppercase: (0,external_window_wp_i18n_.__)('Uppercase', 'blocksy')\n }[variant])))), (0,external_window_wp_element_.createElement)(\"ul\", {\n className: classnames_default()('ct-text-decoration')\n }, ['line-through', 'underline'].map(variant => (0,external_window_wp_element_.createElement)(\"li\", {\n key: variant,\n onClick: () => onChange(FontOptions_objectSpread(FontOptions_objectSpread({}, value), {}, {\n 'text-decoration': value['text-decoration'] === variant ? 'none' : variant\n })),\n className: classnames_default()({\n active: variant === value['text-decoration']\n }),\n \"data-variant\": variant\n }, (0,external_window_wp_element_.createElement)(\"i\", {\n className: \"ct-tooltip-top\"\n }, {\n 'line-through': (0,external_window_wp_i18n_.__)('Line Through', 'blocksy'),\n underline: (0,external_window_wp_i18n_.__)('Underline', 'blocksy')\n }[variant]))))));\n};\n\n/* harmony default export */ const typography_FontOptions = (FontOptions);\n;// CONCATENATED MODULE: ./static/js/options/options/typography/TypographyModal.js\nfunction TypographyModal_extends() { TypographyModal_extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return TypographyModal_extends.apply(this, arguments); }\n\nfunction TypographyModal_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction TypographyModal_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? TypographyModal_ownKeys(Object(source), !0).forEach(function (key) { TypographyModal_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : TypographyModal_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction TypographyModal_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\n\n\n\n\n\n\nconst combineRefs = function () {\n for (var _len = arguments.length, refs = new Array(_len), _key = 0; _key < _len; _key++) {\n refs[_key] = arguments[_key];\n }\n\n return el => {\n refs.map(ref => {\n if (typeof ref === 'function') {\n ref(el);\n } else if (typeof ref === 'object' && ref !== null && ref.hasOwnProperty('current')) {\n ref.current = el;\n } else if (ref === null) {// No-op\n }\n });\n };\n};\n\nfunction fuzzysearch(needle, haystack) {\n var hlen = haystack.length;\n var nlen = needle.length;\n\n if (nlen > hlen) {\n return false;\n }\n\n if (nlen === hlen) {\n return needle === haystack;\n }\n\n outer: for (var i = 0, j = 0; i < nlen; i++) {\n var nch = needle.charCodeAt(i);\n\n while (j < hlen) {\n if (haystack.charCodeAt(j++) === nch) {\n continue outer;\n }\n }\n\n return false;\n }\n\n return true;\n}\n\nconst TypographyModal = _ref => {\n let {\n option,\n value,\n initialView,\n currentView,\n previousView,\n setCurrentView,\n setInititialView,\n onChange,\n wrapperProps = {}\n } = _ref;\n const [typographyList, setTypographyList] = (0,external_window_wp_element_.useState)(getDefaultFonts(option));\n const [isSearch, setIsSearch] = (0,external_window_wp_element_.useState)(false);\n const [searchTerm, setSearchTerm] = (0,external_window_wp_element_.useState)('');\n const direction = (0,external_window_wp_element_.useMemo)(() => {\n if (previousView === '_') {\n return 'static';\n }\n\n if (currentView === 'search' && previousView === 'fonts' || previousView === 'search' && currentView === 'fonts') {\n return 'static';\n }\n\n if (previousView === 'options') {\n return 'right';\n }\n\n if (previousView === 'fonts' && currentView === 'variations') {\n return 'right';\n }\n\n return 'left';\n }, [currentView, previousView]);\n const inputEl = (0,external_window_wp_element_.useRef)(null);\n const sizeEl = (0,external_window_wp_element_.useRef)(null);\n const linearFontsList = Object.keys(typographyList).reduce((currentList, currentSource) => [...currentList, ...(typographyList[currentSource].families || []).filter(_ref2 => {\n let {\n family\n } = _ref2;\n return fuzzysearch(searchTerm.toLowerCase(), family.toLowerCase());\n })], []);\n\n const fetchFontsList = async () => {\n const body = new FormData();\n body.append('action', 'blocksy_get_fonts_list');\n\n try {\n const response = await fetch(ajaxurl, {\n method: 'POST',\n body\n });\n\n if (response.status === 200) {\n const {\n success,\n data\n } = await response.json();\n\n if (success) {\n setTypographyList(TypographyModal_objectSpread(TypographyModal_objectSpread({}, data.fonts), {}, {\n system: TypographyModal_objectSpread(TypographyModal_objectSpread({}, data.fonts.system), {}, {\n families: [...(option.isDefault ? [] : [{\n source: 'system',\n family: 'Default',\n variations: [],\n all_variations: ['Default', 'n1', 'i1', 'n2', 'i2', 'n3', 'i3', 'n4', 'i4', 'n5', 'i5', 'n6', 'i6', 'n7', 'i7', 'n8', 'i8', 'n9', 'i9']\n }]), ...data.fonts.system.families]\n })\n }));\n }\n }\n } catch (e) {}\n };\n\n (0,external_window_wp_element_.useEffect)(() => {\n if (initialView && initialView !== 'done') {\n setSearchTerm('');\n setTimeout(() => {// setInititialView('done')\n });\n }\n\n if (initialView === 'font_size') {\n setTimeout(() => sizeEl.current && sizeEl.current.focus(), 100);\n }\n }, [initialView]);\n (0,external_window_wp_element_.useEffect)(() => {\n fetchFontsList();\n }, []);\n (0,external_window_wp_element_.useEffect)(() => {\n if (currentView === 'search') {\n inputEl.current.focus();\n }\n }, [currentView]);\n\n const pickFontFamily = family => {\n onChange(TypographyModal_objectSpread(TypographyModal_objectSpread({}, value), {}, {\n family: family.family,\n variation: decideVariationToSelect(family, value)\n }));\n };\n\n return (0,external_window_wp_element_.createElement)(react_spring_web_esm.animated.div, TypographyModal_extends({\n className: \"ct-option-modal ct-typography-modal\"\n }, wrapperProps), (0,external_window_wp_element_.createElement)(\"div\", {\n className: \"ct-typography-container\"\n }, (0,external_window_wp_element_.createElement)(\"ul\", {\n className: classnames_default()('ct-typography-top', {\n 'ct-switch-panel': currentView !== 'options',\n 'ct-static': previousView === '_'\n })\n }, (0,external_window_wp_element_.createElement)(\"li\", {\n className: \"ct-back\",\n onClick: () => setCurrentView('options')\n }, (0,external_window_wp_element_.createElement)(\"svg\", {\n width: \"10\",\n height: \"10\",\n viewBox: \"0 0 15 15\"\n }, (0,external_window_wp_element_.createElement)(\"path\", {\n d: \"M14.2,6.8H2.6l4-4c0.3-0.3,0.3-0.8,0-1.1c-0.3-0.3-0.8-0.3-1.1,0L0.2,7l0,0c0,0-0.1,0.1-0.1,0.1c0,0,0,0,0,0.1c0,0,0,0,0,0.1c0,0,0,0.1,0,0.1c0,0,0,0,0,0.1c0,0,0,0.1,0,0.1l0,0c0,0,0,0,0,0c0,0,0,0.1,0,0.1c0,0,0,0,0,0.1c0,0,0,0.1,0,0.1c0,0,0,0,0,0.1c0,0,0,0,0,0.1C0.2,8,0.2,8,0.2,8l5.3,5.3c0.3,0.3,0.8,0.3,1.1,0c0.3-0.3,0.3-0.8,0-1.1l-4-4h11.7c0.4,0,0.8-0.3,0.8-0.8S14.7,6.8,14.2,6.8z\"\n }))), (0,external_window_wp_element_.createElement)(\"li\", {\n className: classnames_default()('ct-font', {\n active: currentView === 'search' || currentView === 'fonts'\n }),\n onClick: () => {\n setCurrentView(currentView === 'fonts' ? 'search' : 'fonts');\n setSearchTerm('');\n }\n }, currentView !== 'search' && (0,external_window_wp_element_.createElement)(\"span\", null, familyForDisplay(value.family)), currentView === 'search' && (0,external_window_wp_element_.createElement)(\"input\", {\n onClick: e => e.stopPropagation(),\n ref: inputEl,\n autoFocus: true,\n value: searchTerm,\n onKeyUp: e => {\n if (e.keyCode == 13) {\n if (linearFontsList.length > 0) {\n pickFontFamily(linearFontsList[0]);\n setCurrentView('options');\n setSearchTerm('');\n }\n }\n },\n onChange: _ref3 => {\n let {\n target: {\n value\n }\n } = _ref3;\n return setSearchTerm(value);\n }\n }), (0,external_window_wp_element_.createElement)(\"svg\", {\n width: \"8\",\n height: \"8\",\n viewBox: \"0 0 15 15\"\n }, currentView === 'search' && (0,external_window_wp_element_.createElement)(\"path\", {\n d: \"M8.9,7.5l4.6-4.6c0.4-0.4,0.4-1,0-1.4c-0.4-0.4-1-0.4-1.4,0L7.5,6.1L2.9,1.5c-0.4-0.4-1-0.4-1.4,0c-0.4,0.4-0.4,1,0,1.4l4.6,4.6l-4.6,4.6c-0.4,0.4-0.4,1,0,1.4c0.4,0.4,1,0.4,1.4,0l4.6-4.6l4.6,4.6c0.4,0.4,1,0.4,1.4,0c0.4-0.4,0.4-1,0-1.4L8.9,7.5z\"\n }), currentView !== 'search' && (0,external_window_wp_element_.createElement)(\"path\", {\n d: \"M14.6,14.6c-0.6,0.6-1.4,0.6-2,0l-2.5-2.5c-1,0.7-2.2,1-3.5,1C2.9,13.1,0,10.2,0,6.6S2.9,0,6.6,0c3.6,0,6.6,2.9,6.6,6.6c0,1.3-0.4,2.5-1,3.5l2.5,2.5C15.1,13.1,15.1,14,14.6,14.6z M6.6,1.9C4,1.9,1.9,4,1.9,6.6s2.1,4.7,4.7,4.7c2.6,0,4.7-2.1,4.7-4.7C11.3,4,9.2,1.9,6.6,1.9z\"\n }))), (0,external_window_wp_element_.createElement)(\"li\", {\n className: classnames_default()('ct-weight', {\n active: currentView === 'variations'\n }),\n onClick: () => setCurrentView('variations')\n }, (0,external_window_wp_element_.createElement)(\"span\", {\n \"data-variation\": value.variation\n }, humanizeVariationsShort(value.variation)))), (0,external_window_wp_element_.createElement)(react_spring_web_esm.Transition, {\n items: currentView,\n immediate: direction === 'static',\n config: (item, type) => ({\n duration: 210,\n easing: src_default()(0.455, 0.03, 0.515, 0.955)\n }),\n from: {\n transform: direction === 'left' ? 'translateX(100%)' : 'translateX(-100%)',\n position: 'absolute'\n },\n enter: {\n transform: 'translateX(0%)',\n position: 'absolute'\n },\n leave: {\n position: 'absolute',\n transform: direction === 'left' ? 'translateX(-100%)' : 'translateX(100%)'\n }\n }, (props, currentView, transition, key) => {\n if (currentView === 'options') {\n return (0,external_window_wp_element_.createElement)(typography_FontOptions, {\n sizeRef: sizeEl,\n value: value,\n option: option,\n onChange: onChange,\n props: props,\n currentView: currentView\n });\n }\n\n if (currentView === 'fonts' || currentView === 'search') {\n return (0,external_window_wp_element_.createElement)(react_spring_web_esm.animated.div, {\n style: props,\n key: currentView\n }, (0,external_window_wp_element_.createElement)(typography_FontsList, {\n typographyList: typographyList,\n searchTerm: searchTerm,\n linearFontsList: linearFontsList,\n currentView: `${currentView}:${previousView}`,\n onPickFamily: family => {\n pickFontFamily(family); // setCurrentView('options')\n // setSearchTerm('')\n },\n value: value\n }));\n }\n\n if (currentView === 'variations') {\n return (0,external_window_wp_element_.createElement)(typography_VariationsList, {\n currentView: currentView,\n props: props,\n typographyList: typographyList,\n onChange: value => {\n onChange(value); // setCurrentView('options')\n },\n value: value\n });\n }\n })));\n};\n\n/* harmony default export */ const typography_TypographyModal = (TypographyModal);\n// EXTERNAL MODULE: ./static/js/options/options/react-outside-click-handler.js\nvar react_outside_click_handler = __webpack_require__(8204);\n// EXTERNAL MODULE: ./static/js/customizer/components/responsive-controls.js\nvar responsive_controls = __webpack_require__(4616);\n// EXTERNAL MODULE: ./static/js/options/helpers/usePopoverMaker.js\nvar usePopoverMaker = __webpack_require__(9144);\n;// CONCATENATED MODULE: ./static/js/options/options/ct-typography.js\nfunction ct_typography_ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction ct_typography_objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ct_typography_ownKeys(Object(source), !0).forEach(function (key) { ct_typography_defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ct_typography_ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction ct_typography_defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\n\n\n\n\n\nconst getLeftForEl = (modal, el) => {\n if (!modal) return;\n if (!el) return;\n let style = getComputedStyle(modal);\n let wrapperLeft = parseFloat(style.left);\n el = el.getBoundingClientRect();\n return {\n '--option-modal-arrow-position': `${el.left + el.width / 2 - wrapperLeft - 6}px`\n };\n};\n\nconst Typography = _ref => {\n let {\n option: {\n label = '',\n desc = '',\n attr = {}\n },\n option,\n value,\n device,\n onChange\n } = _ref;\n // const [isOpen, setIsOpen] = useState(false)\n // options | fonts | variations | search\n const [currentViewCache, setCurrentViewCache] = (0,external_window_wp_element_.useState)('_:_');\n const typographyWrapper = (0,external_window_wp_element_.useRef)();\n let [currentView, previousView] = (0,external_window_wp_element_.useMemo)(() => currentViewCache.split(':'), [currentViewCache]);\n const setCurrentView = (0,external_window_wp_element_.useCallback)(newView => setCurrentViewCache(`${newView}:${currentView}`), [currentView]);\n const [{\n isOpen,\n isTransitioning\n }, setModalState] = (0,external_window_wp_element_.useState)({\n isOpen: false,\n isTransitioning: false\n });\n const {\n styles,\n popoverProps\n } = (0,usePopoverMaker/* default */.Z)({\n ref: typographyWrapper,\n defaultHeight: 430,\n shouldCalculate: isTransitioning || isOpen\n });\n\n const setIsOpen = isOpen => {\n setModalState(state => ct_typography_objectSpread(ct_typography_objectSpread({}, state), {}, {\n isOpen,\n isTransitioning: true\n }));\n };\n\n const stopTransitioning = () => setModalState(state => ct_typography_objectSpread(ct_typography_objectSpread({}, state), {}, {\n isTransitioning: false\n }));\n\n const fontFamilyRef = (0,external_window_wp_element_.useRef)();\n const fontSizeRef = (0,external_window_wp_element_.useRef)();\n const fontWeightRef = (0,external_window_wp_element_.useRef)();\n const dotsRef = (0,external_window_wp_element_.useRef)();\n const arrowLeft = (0,external_window_wp_element_.useMemo)(() => {\n const view = currentView;\n const futureRef = view === 'options' ? fontSizeRef.current : view === 'fonts' ? fontFamilyRef.current : view === 'variations' ? fontWeightRef.current : fontSizeRef.current;\n return popoverProps.ref && popoverProps.ref.current && getLeftForEl(popoverProps.ref.current, futureRef);\n }, [isOpen, currentView, popoverProps.ref, popoverProps.ref && popoverProps.ref.current, fontFamilyRef && fontFamilyRef.current, fontWeightRef && fontWeightRef.current, fontSizeRef && fontSizeRef.current, dotsRef && dotsRef.current]);\n return (0,external_window_wp_element_.createElement)(\"div\", {\n className: classnames_default()('ct-typography', {})\n }, (0,external_window_wp_element_.createElement)(react_outside_click_handler[\"default\"], {\n disabled: !isOpen,\n useCapture: false,\n className: \"ct-typohraphy-value\",\n additionalRefs: [popoverProps.ref],\n onOutsideClick: () => {\n setIsOpen(false);\n },\n wrapperProps: {\n ref: typographyWrapper,\n onClick: e => {\n e.preventDefault();\n\n if (isOpen) {\n setCurrentView('options');\n return;\n }\n\n setCurrentViewCache('options:_');\n setIsOpen('options');\n }\n }\n }, (0,external_window_wp_element_.createElement)(\"div\", null, (0,external_window_wp_element_.createElement)(\"span\", {\n onClick: e => {\n e.stopPropagation();\n\n if (isOpen) {\n setCurrentView('fonts');\n return;\n }\n\n setCurrentViewCache('fonts:_');\n setIsOpen('fonts');\n },\n className: \"ct-font\",\n ref: fontFamilyRef\n }, (0,external_window_wp_element_.createElement)(\"span\", null, value.family === 'Default' ? (0,external_window_wp_i18n_.__)('Default Family', 'blocksy') : familyForDisplay(value.family))), (0,external_window_wp_element_.createElement)(\"i\", null, \"/\"), (0,external_window_wp_element_.createElement)(\"span\", {\n onClick: e => {\n e.stopPropagation();\n\n if (isOpen) {\n setCurrentView('options');\n return;\n }\n\n setCurrentViewCache('options:_');\n setIsOpen('font_size');\n },\n ref: fontSizeRef,\n className: \"ct-size\"\n }, (0,external_window_wp_element_.createElement)(\"span\", null, (0,responsive_controls/* maybePromoteScalarValueIntoResponsive */.T)(value['size'])[device] === 'CT_CSS_SKIP_RULE' ? (0,external_window_wp_i18n_.__)('Default Size', 'blocksy') : (0,responsive_controls/* maybePromoteScalarValueIntoResponsive */.T)(value['size'])[device])), (0,external_window_wp_element_.createElement)(\"i\", null, \"/\"), (0,external_window_wp_element_.createElement)(\"span\", {\n ref: fontWeightRef,\n onClick: e => {\n e.stopPropagation();\n\n if (isOpen) {\n setCurrentView('variations');\n return;\n }\n\n setCurrentViewCache('variations:_');\n setIsOpen('variations');\n },\n className: \"ct-weight\"\n }, (0,external_window_wp_element_.createElement)(\"span\", null, humanizeVariations(value.variation)))), (0,external_window_wp_element_.createElement)(\"a\", {\n ref: dotsRef\n })), (isTransitioning || isOpen) && (0,external_window_wp_element_.createPortal)((0,external_window_wp_element_.createElement)(react_spring_web_esm.Transition, {\n items: isOpen,\n onRest: isOpen => {\n stopTransitioning();\n },\n config: {\n duration: 100,\n easing: src_default()(0.25, 0.1, 0.25, 1.0)\n },\n from: isOpen ? {\n transform: 'scale3d(0.95, 0.95, 1)',\n opacity: 0\n } : {\n opacity: 1\n },\n enter: isOpen ? {\n transform: 'scale3d(1, 1, 1)',\n opacity: 1\n } : {\n opacity: 1\n },\n leave: !isOpen ? {\n transform: 'scale3d(0.95, 0.95, 1)',\n opacity: 0\n } : {\n opacity: 1\n }\n }, (style, item) => {\n if (!item) {\n return null;\n }\n\n return (0,external_window_wp_element_.createElement)(typography_TypographyModal, {\n wrapperProps: ct_typography_objectSpread({\n style: ct_typography_objectSpread(ct_typography_objectSpread(ct_typography_objectSpread({}, style), styles), arrowLeft)\n }, popoverProps),\n onChange: onChange,\n value: value,\n option: option,\n initialView: item,\n setInititialView: initialView => setIsOpen(initialView),\n currentView: currentView,\n previousView: previousView,\n setCurrentView: setCurrentView\n });\n /*\n isOpen &&\n ((props) => (\n \t\n \t\t\tsetIsOpen(initialView)\n \t\t}\n \t\tcurrentView={currentView}\n \t\tpreviousView={previousView}\n \t\tsetCurrentView={setCurrentView}\n \t/>\n ))\n */\n }), document.body));\n};\n\n/* harmony default export */ const ct_typography = (Typography);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"5183.js","mappings":";;;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;AChHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AChDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AA4CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAkDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AASA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;AC1gEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACreA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC/CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9KA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACnSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./static/js/options/options/typography/default-data.js?86ec","webpack://blocksyOptions/./static/js/options/options/typography/helpers.js?e08f","webpack://blocksyOptions/./node_modules/memoize-one/dist/memoize-one.esm.js?5b0a","webpack://blocksyOptions/./node_modules/react-window/dist/index.esm.js?891d","webpack://blocksyOptions/./node_modules/react-virtualized-auto-sizer/dist/index.esm.js?8d8c","webpack://blocksyOptions/./static/js/options/options/typography/FontsList.js?1a1b","webpack://blocksyOptions/./static/js/options/options/typography/VariationsList.js?f686","webpack://blocksyOptions/./static/js/options/options/typography/FontOptions.js?7209","webpack://blocksyOptions/./static/js/options/options/typography/TypographyModal.js?6afb","webpack://blocksyOptions/./static/js/options/options/ct-typography.js?7ce4"],"sourcesContent":["import { __ } from 'ct-i18n';\nexport const getDefaultFonts = _ref => {\n  let {\n    isDefault\n  } = _ref;\n  return {\n    system: {\n      type: 'system',\n      families: [...(!isDefault ? ['Default'] : []), 'System Default', 'Arial', 'Verdana', 'Trebuchet', 'Georgia', 'Times New Roman', 'Palatino', 'Helvetica', 'Myriad Pro', 'Lucida', 'Gill Sans', 'Impact', 'Serif', 'monospace'].map(family => ({\n        source: 'system',\n        family,\n        display: family === 'System Default' ? __('System Default', 'blocksy') : family,\n        variations: [],\n        all_variations: [...(family === 'Default' ? ['Default'] : []), 'n1', 'i1', 'n2', 'i2', 'n3', 'i3', 'n4', 'i4', 'n5', 'i5', 'n6', 'i6', 'n7', 'i7', 'n8', 'i8', 'n9', 'i9']\n      }))\n    }\n  };\n};","import { __ } from 'ct-i18n';\nexport const fontFamilyToCSSFamily = family => {\n  if (family === 'System Default') {\n    return \"-apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol'\";\n  }\n\n  return family.replace('ct_typekit_', '');\n};\n\nconst findSourceTypeSettingsFor = (font_family, fonts_list) => Object.values(fonts_list).find(single_font_source => single_font_source.families.map(_ref => {\n  let {\n    family\n  } = _ref;\n  return family;\n}).indexOf(font_family) > -1);\n\nexport const findSourceTypeFor = (font_family, fonts_list) => {\n  let source = findSourceTypeSettingsFor(font_family, fonts_list);\n  if (!source) return false;\n  return source.type;\n};\nexport const findSelectedFontFamily = (font_family, fonts_list) => {\n  let source = findSourceTypeSettingsFor(font_family, fonts_list);\n\n  if (!source) {\n    return null;\n  }\n\n  return source.families.find(_ref2 => {\n    let {\n      family\n    } = _ref2;\n    return family === font_family;\n  });\n};\nexport const decideVariationToSelect = (newValue, oldValue) => {\n  if (newValue.all_variations.indexOf(oldValue.variation) > -1) {\n    return oldValue.variation;\n  }\n\n  if (newValue.all_variations.indexOf('n4') > -1) {\n    return 'n4';\n  }\n\n  return newValue.all_variations[0];\n};\nexport const humanizeVariationsShort = variation => {\n  var all = {\n    n1: '100',\n    i1: '100',\n    n2: '200',\n    i2: '200',\n    n3: '300',\n    i3: '300',\n    n4: '400',\n    i4: '400',\n    n5: '500',\n    i5: '500',\n    n6: '600',\n    i6: '600',\n    n7: '700',\n    i7: '700',\n    n8: '800',\n    i8: '800',\n    n9: '900',\n    i9: '900',\n    Default: __('Default', 'blocksy')\n  };\n  return all[variation];\n};\nexport const humanizeVariations = variation => {\n  var all = {\n    n1: __('Thin 100', 'blocksy'),\n    i1: __('Thin 100 Italic', 'blocksy'),\n    n2: __('Extra-Light 200', 'blocksy'),\n    i2: __('Extra-Light 200 Italic', 'blocksy'),\n    n3: __('Light 300', 'blocksy'),\n    i3: __('Light 300 Italic', 'blocksy'),\n    n4: __('Regular', 'blocksy'),\n    i4: __('Regular 400 Italic', 'blocksy'),\n    n5: __('Medium 500', 'blocksy'),\n    i5: __('Medium 500 Italic', 'blocksy'),\n    n6: __('Semi-Bold 600', 'blocksy'),\n    i6: __('Semi-Bold 600 Italic', 'blocksy'),\n    n7: __('Bold 700', 'blocksy'),\n    i7: __('Bold 700 Italic', 'blocksy'),\n    n8: __('Extra-Bold 800', 'blocksy'),\n    i8: __('Extra-Bold 800 Italic', 'blocksy'),\n    n9: __('Ultra-Bold 900', 'blocksy'),\n    i9: __('Ultra-Bold 900 Italic', 'blocksy'),\n    Default: __('Default Weight', 'blocksy')\n  };\n  return all[variation];\n};\nexport const familyForDisplay = family => {\n  if (family.indexOf('ct_font') === 0) {\n    return family.replace('ct_font_', '').replace(/([-_][a-z])/gi, $1 => $1.toUpperCase().replace('-', '').replace('_', ''));\n  }\n\n  if (family.indexOf('ct_typekit') === 0) {\n    return family.replace('ct_typekit_', '').replace(/([-_][a-z])/gi, $1 => $1.toUpperCase().replace('-', ' ').replace('_', ' '));\n  }\n\n  if (family === 'System Default') {\n    return __('System Default', 'blocksy');\n  }\n\n  if (family === 'Default') {\n    return __('Default', 'blocksy');\n  }\n\n  return family;\n};","var safeIsNaN = Number.isNaN ||\n    function ponyfill(value) {\n        return typeof value === 'number' && value !== value;\n    };\nfunction isEqual(first, second) {\n    if (first === second) {\n        return true;\n    }\n    if (safeIsNaN(first) && safeIsNaN(second)) {\n        return true;\n    }\n    return false;\n}\nfunction areInputsEqual(newInputs, lastInputs) {\n    if (newInputs.length !== lastInputs.length) {\n        return false;\n    }\n    for (var i = 0; i < newInputs.length; i++) {\n        if (!isEqual(newInputs[i], lastInputs[i])) {\n            return false;\n        }\n    }\n    return true;\n}\n\nfunction memoizeOne(resultFn, isEqual) {\n    if (isEqual === void 0) { isEqual = areInputsEqual; }\n    var lastThis;\n    var lastArgs = [];\n    var lastResult;\n    var calledOnce = false;\n    function memoized() {\n        var newArgs = [];\n        for (var _i = 0; _i < arguments.length; _i++) {\n            newArgs[_i] = arguments[_i];\n        }\n        if (calledOnce && lastThis === this && isEqual(newArgs, lastArgs)) {\n            return lastResult;\n        }\n        lastResult = resultFn.apply(this, newArgs);\n        calledOnce = true;\n        lastThis = this;\n        lastArgs = newArgs;\n        return lastResult;\n    }\n    return memoized;\n}\n\nexport default memoizeOne;\n","import _extends from '@babel/runtime/helpers/esm/extends';\nimport _assertThisInitialized from '@babel/runtime/helpers/esm/assertThisInitialized';\nimport _inheritsLoose from '@babel/runtime/helpers/esm/inheritsLoose';\nimport memoizeOne from 'memoize-one';\nimport { createElement, PureComponent } from 'react';\nimport _objectWithoutPropertiesLoose from '@babel/runtime/helpers/esm/objectWithoutPropertiesLoose';\n\n// Animation frame based implementation of setTimeout.\n// Inspired by Joe Lambert, https://gist.github.com/joelambert/1002116#file-requesttimeout-js\nvar hasNativePerformanceNow = typeof performance === 'object' && typeof performance.now === 'function';\nvar now = hasNativePerformanceNow ? function () {\n  return performance.now();\n} : function () {\n  return Date.now();\n};\nfunction cancelTimeout(timeoutID) {\n  cancelAnimationFrame(timeoutID.id);\n}\nfunction requestTimeout(callback, delay) {\n  var start = now();\n\n  function tick() {\n    if (now() - start >= delay) {\n      callback.call(null);\n    } else {\n      timeoutID.id = requestAnimationFrame(tick);\n    }\n  }\n\n  var timeoutID = {\n    id: requestAnimationFrame(tick)\n  };\n  return timeoutID;\n}\n\nvar size = -1; // This utility copied from \"dom-helpers\" package.\n\nfunction getScrollbarSize(recalculate) {\n  if (recalculate === void 0) {\n    recalculate = false;\n  }\n\n  if (size === -1 || recalculate) {\n    var div = document.createElement('div');\n    var style = div.style;\n    style.width = '50px';\n    style.height = '50px';\n    style.overflow = 'scroll';\n    document.body.appendChild(div);\n    size = div.offsetWidth - div.clientWidth;\n    document.body.removeChild(div);\n  }\n\n  return size;\n}\nvar cachedRTLResult = null; // TRICKY According to the spec, scrollLeft should be negative for RTL aligned elements.\n// Chrome does not seem to adhere; its scrollLeft values are positive (measured relative to the left).\n// Safari's elastic bounce makes detecting this even more complicated wrt potential false positives.\n// The safest way to check this is to intentionally set a negative offset,\n// and then verify that the subsequent \"scroll\" event matches the negative offset.\n// If it does not match, then we can assume a non-standard RTL scroll implementation.\n\nfunction getRTLOffsetType(recalculate) {\n  if (recalculate === void 0) {\n    recalculate = false;\n  }\n\n  if (cachedRTLResult === null || recalculate) {\n    var outerDiv = document.createElement('div');\n    var outerStyle = outerDiv.style;\n    outerStyle.width = '50px';\n    outerStyle.height = '50px';\n    outerStyle.overflow = 'scroll';\n    outerStyle.direction = 'rtl';\n    var innerDiv = document.createElement('div');\n    var innerStyle = innerDiv.style;\n    innerStyle.width = '100px';\n    innerStyle.height = '100px';\n    outerDiv.appendChild(innerDiv);\n    document.body.appendChild(outerDiv);\n\n    if (outerDiv.scrollLeft > 0) {\n      cachedRTLResult = 'positive-descending';\n    } else {\n      outerDiv.scrollLeft = 1;\n\n      if (outerDiv.scrollLeft === 0) {\n        cachedRTLResult = 'negative';\n      } else {\n        cachedRTLResult = 'positive-ascending';\n      }\n    }\n\n    document.body.removeChild(outerDiv);\n    return cachedRTLResult;\n  }\n\n  return cachedRTLResult;\n}\n\nvar IS_SCROLLING_DEBOUNCE_INTERVAL = 150;\n\nvar defaultItemKey = function defaultItemKey(_ref) {\n  var columnIndex = _ref.columnIndex,\n      data = _ref.data,\n      rowIndex = _ref.rowIndex;\n  return rowIndex + \":\" + columnIndex;\n}; // In DEV mode, this Set helps us only log a warning once per component instance.\n// This avoids spamming the console every time a render happens.\n\n\nvar devWarningsOverscanCount = null;\nvar devWarningsOverscanRowsColumnsCount = null;\nvar devWarningsTagName = null;\n\nif (process.env.NODE_ENV !== 'production') {\n  if (typeof window !== 'undefined' && typeof window.WeakSet !== 'undefined') {\n    devWarningsOverscanCount = /*#__PURE__*/new WeakSet();\n    devWarningsOverscanRowsColumnsCount = /*#__PURE__*/new WeakSet();\n    devWarningsTagName = /*#__PURE__*/new WeakSet();\n  }\n}\n\nfunction createGridComponent(_ref2) {\n  var _class;\n\n  var getColumnOffset = _ref2.getColumnOffset,\n      getColumnStartIndexForOffset = _ref2.getColumnStartIndexForOffset,\n      getColumnStopIndexForStartIndex = _ref2.getColumnStopIndexForStartIndex,\n      getColumnWidth = _ref2.getColumnWidth,\n      getEstimatedTotalHeight = _ref2.getEstimatedTotalHeight,\n      getEstimatedTotalWidth = _ref2.getEstimatedTotalWidth,\n      getOffsetForColumnAndAlignment = _ref2.getOffsetForColumnAndAlignment,\n      getOffsetForRowAndAlignment = _ref2.getOffsetForRowAndAlignment,\n      getRowHeight = _ref2.getRowHeight,\n      getRowOffset = _ref2.getRowOffset,\n      getRowStartIndexForOffset = _ref2.getRowStartIndexForOffset,\n      getRowStopIndexForStartIndex = _ref2.getRowStopIndexForStartIndex,\n      initInstanceProps = _ref2.initInstanceProps,\n      shouldResetStyleCacheOnItemSizeChange = _ref2.shouldResetStyleCacheOnItemSizeChange,\n      validateProps = _ref2.validateProps;\n  return _class = /*#__PURE__*/function (_PureComponent) {\n    _inheritsLoose(Grid, _PureComponent);\n\n    // Always use explicit constructor for React components.\n    // It produces less code after transpilation. (#26)\n    // eslint-disable-next-line no-useless-constructor\n    function Grid(props) {\n      var _this;\n\n      _this = _PureComponent.call(this, props) || this;\n      _this._instanceProps = initInstanceProps(_this.props, _assertThisInitialized(_this));\n      _this._resetIsScrollingTimeoutId = null;\n      _this._outerRef = void 0;\n      _this.state = {\n        instance: _assertThisInitialized(_this),\n        isScrolling: false,\n        horizontalScrollDirection: 'forward',\n        scrollLeft: typeof _this.props.initialScrollLeft === 'number' ? _this.props.initialScrollLeft : 0,\n        scrollTop: typeof _this.props.initialScrollTop === 'number' ? _this.props.initialScrollTop : 0,\n        scrollUpdateWasRequested: false,\n        verticalScrollDirection: 'forward'\n      };\n      _this._callOnItemsRendered = void 0;\n      _this._callOnItemsRendered = memoizeOne(function (overscanColumnStartIndex, overscanColumnStopIndex, overscanRowStartIndex, overscanRowStopIndex, visibleColumnStartIndex, visibleColumnStopIndex, visibleRowStartIndex, visibleRowStopIndex) {\n        return _this.props.onItemsRendered({\n          overscanColumnStartIndex: overscanColumnStartIndex,\n          overscanColumnStopIndex: overscanColumnStopIndex,\n          overscanRowStartIndex: overscanRowStartIndex,\n          overscanRowStopIndex: overscanRowStopIndex,\n          visibleColumnStartIndex: visibleColumnStartIndex,\n          visibleColumnStopIndex: visibleColumnStopIndex,\n          visibleRowStartIndex: visibleRowStartIndex,\n          visibleRowStopIndex: visibleRowStopIndex\n        });\n      });\n      _this._callOnScroll = void 0;\n      _this._callOnScroll = memoizeOne(function (scrollLeft, scrollTop, horizontalScrollDirection, verticalScrollDirection, scrollUpdateWasRequested) {\n        return _this.props.onScroll({\n          horizontalScrollDirection: horizontalScrollDirection,\n          scrollLeft: scrollLeft,\n          scrollTop: scrollTop,\n          verticalScrollDirection: verticalScrollDirection,\n          scrollUpdateWasRequested: scrollUpdateWasRequested\n        });\n      });\n      _this._getItemStyle = void 0;\n\n      _this._getItemStyle = function (rowIndex, columnIndex) {\n        var _this$props = _this.props,\n            columnWidth = _this$props.columnWidth,\n            direction = _this$props.direction,\n            rowHeight = _this$props.rowHeight;\n\n        var itemStyleCache = _this._getItemStyleCache(shouldResetStyleCacheOnItemSizeChange && columnWidth, shouldResetStyleCacheOnItemSizeChange && direction, shouldResetStyleCacheOnItemSizeChange && rowHeight);\n\n        var key = rowIndex + \":\" + columnIndex;\n        var style;\n\n        if (itemStyleCache.hasOwnProperty(key)) {\n          style = itemStyleCache[key];\n        } else {\n          var _offset = getColumnOffset(_this.props, columnIndex, _this._instanceProps);\n\n          var isRtl = direction === 'rtl';\n          itemStyleCache[key] = style = {\n            position: 'absolute',\n            left: isRtl ? undefined : _offset,\n            right: isRtl ? _offset : undefined,\n            top: getRowOffset(_this.props, rowIndex, _this._instanceProps),\n            height: getRowHeight(_this.props, rowIndex, _this._instanceProps),\n            width: getColumnWidth(_this.props, columnIndex, _this._instanceProps)\n          };\n        }\n\n        return style;\n      };\n\n      _this._getItemStyleCache = void 0;\n      _this._getItemStyleCache = memoizeOne(function (_, __, ___) {\n        return {};\n      });\n\n      _this._onScroll = function (event) {\n        var _event$currentTarget = event.currentTarget,\n            clientHeight = _event$currentTarget.clientHeight,\n            clientWidth = _event$currentTarget.clientWidth,\n            scrollLeft = _event$currentTarget.scrollLeft,\n            scrollTop = _event$currentTarget.scrollTop,\n            scrollHeight = _event$currentTarget.scrollHeight,\n            scrollWidth = _event$currentTarget.scrollWidth;\n\n        _this.setState(function (prevState) {\n          if (prevState.scrollLeft === scrollLeft && prevState.scrollTop === scrollTop) {\n            // Scroll position may have been updated by cDM/cDU,\n            // In which case we don't need to trigger another render,\n            // And we don't want to update state.isScrolling.\n            return null;\n          }\n\n          var direction = _this.props.direction; // TRICKY According to the spec, scrollLeft should be negative for RTL aligned elements.\n          // This is not the case for all browsers though (e.g. Chrome reports values as positive, measured relative to the left).\n          // It's also easier for this component if we convert offsets to the same format as they would be in for ltr.\n          // So the simplest solution is to determine which browser behavior we're dealing with, and convert based on it.\n\n          var calculatedScrollLeft = scrollLeft;\n\n          if (direction === 'rtl') {\n            switch (getRTLOffsetType()) {\n              case 'negative':\n                calculatedScrollLeft = -scrollLeft;\n                break;\n\n              case 'positive-descending':\n                calculatedScrollLeft = scrollWidth - clientWidth - scrollLeft;\n                break;\n            }\n          } // Prevent Safari's elastic scrolling from causing visual shaking when scrolling past bounds.\n\n\n          calculatedScrollLeft = Math.max(0, Math.min(calculatedScrollLeft, scrollWidth - clientWidth));\n          var calculatedScrollTop = Math.max(0, Math.min(scrollTop, scrollHeight - clientHeight));\n          return {\n            isScrolling: true,\n            horizontalScrollDirection: prevState.scrollLeft < scrollLeft ? 'forward' : 'backward',\n            scrollLeft: calculatedScrollLeft,\n            scrollTop: calculatedScrollTop,\n            verticalScrollDirection: prevState.scrollTop < scrollTop ? 'forward' : 'backward',\n            scrollUpdateWasRequested: false\n          };\n        }, _this._resetIsScrollingDebounced);\n      };\n\n      _this._outerRefSetter = function (ref) {\n        var outerRef = _this.props.outerRef;\n        _this._outerRef = ref;\n\n        if (typeof outerRef === 'function') {\n          outerRef(ref);\n        } else if (outerRef != null && typeof outerRef === 'object' && outerRef.hasOwnProperty('current')) {\n          outerRef.current = ref;\n        }\n      };\n\n      _this._resetIsScrollingDebounced = function () {\n        if (_this._resetIsScrollingTimeoutId !== null) {\n          cancelTimeout(_this._resetIsScrollingTimeoutId);\n        }\n\n        _this._resetIsScrollingTimeoutId = requestTimeout(_this._resetIsScrolling, IS_SCROLLING_DEBOUNCE_INTERVAL);\n      };\n\n      _this._resetIsScrolling = function () {\n        _this._resetIsScrollingTimeoutId = null;\n\n        _this.setState({\n          isScrolling: false\n        }, function () {\n          // Clear style cache after state update has been committed.\n          // This way we don't break pure sCU for items that don't use isScrolling param.\n          _this._getItemStyleCache(-1);\n        });\n      };\n\n      return _this;\n    }\n\n    Grid.getDerivedStateFromProps = function getDerivedStateFromProps(nextProps, prevState) {\n      validateSharedProps(nextProps, prevState);\n      validateProps(nextProps);\n      return null;\n    };\n\n    var _proto = Grid.prototype;\n\n    _proto.scrollTo = function scrollTo(_ref3) {\n      var scrollLeft = _ref3.scrollLeft,\n          scrollTop = _ref3.scrollTop;\n\n      if (scrollLeft !== undefined) {\n        scrollLeft = Math.max(0, scrollLeft);\n      }\n\n      if (scrollTop !== undefined) {\n        scrollTop = Math.max(0, scrollTop);\n      }\n\n      this.setState(function (prevState) {\n        if (scrollLeft === undefined) {\n          scrollLeft = prevState.scrollLeft;\n        }\n\n        if (scrollTop === undefined) {\n          scrollTop = prevState.scrollTop;\n        }\n\n        if (prevState.scrollLeft === scrollLeft && prevState.scrollTop === scrollTop) {\n          return null;\n        }\n\n        return {\n          horizontalScrollDirection: prevState.scrollLeft < scrollLeft ? 'forward' : 'backward',\n          scrollLeft: scrollLeft,\n          scrollTop: scrollTop,\n          scrollUpdateWasRequested: true,\n          verticalScrollDirection: prevState.scrollTop < scrollTop ? 'forward' : 'backward'\n        };\n      }, this._resetIsScrollingDebounced);\n    };\n\n    _proto.scrollToItem = function scrollToItem(_ref4) {\n      var _ref4$align = _ref4.align,\n          align = _ref4$align === void 0 ? 'auto' : _ref4$align,\n          columnIndex = _ref4.columnIndex,\n          rowIndex = _ref4.rowIndex;\n      var _this$props2 = this.props,\n          columnCount = _this$props2.columnCount,\n          height = _this$props2.height,\n          rowCount = _this$props2.rowCount,\n          width = _this$props2.width;\n      var _this$state = this.state,\n          scrollLeft = _this$state.scrollLeft,\n          scrollTop = _this$state.scrollTop;\n      var scrollbarSize = getScrollbarSize();\n\n      if (columnIndex !== undefined) {\n        columnIndex = Math.max(0, Math.min(columnIndex, columnCount - 1));\n      }\n\n      if (rowIndex !== undefined) {\n        rowIndex = Math.max(0, Math.min(rowIndex, rowCount - 1));\n      }\n\n      var estimatedTotalHeight = getEstimatedTotalHeight(this.props, this._instanceProps);\n      var estimatedTotalWidth = getEstimatedTotalWidth(this.props, this._instanceProps); // The scrollbar size should be considered when scrolling an item into view,\n      // to ensure it's fully visible.\n      // But we only need to account for its size when it's actually visible.\n\n      var horizontalScrollbarSize = estimatedTotalWidth > width ? scrollbarSize : 0;\n      var verticalScrollbarSize = estimatedTotalHeight > height ? scrollbarSize : 0;\n      this.scrollTo({\n        scrollLeft: columnIndex !== undefined ? getOffsetForColumnAndAlignment(this.props, columnIndex, align, scrollLeft, this._instanceProps, verticalScrollbarSize) : scrollLeft,\n        scrollTop: rowIndex !== undefined ? getOffsetForRowAndAlignment(this.props, rowIndex, align, scrollTop, this._instanceProps, horizontalScrollbarSize) : scrollTop\n      });\n    };\n\n    _proto.componentDidMount = function componentDidMount() {\n      var _this$props3 = this.props,\n          initialScrollLeft = _this$props3.initialScrollLeft,\n          initialScrollTop = _this$props3.initialScrollTop;\n\n      if (this._outerRef != null) {\n        var outerRef = this._outerRef;\n\n        if (typeof initialScrollLeft === 'number') {\n          outerRef.scrollLeft = initialScrollLeft;\n        }\n\n        if (typeof initialScrollTop === 'number') {\n          outerRef.scrollTop = initialScrollTop;\n        }\n      }\n\n      this._callPropsCallbacks();\n    };\n\n    _proto.componentDidUpdate = function componentDidUpdate() {\n      var direction = this.props.direction;\n      var _this$state2 = this.state,\n          scrollLeft = _this$state2.scrollLeft,\n          scrollTop = _this$state2.scrollTop,\n          scrollUpdateWasRequested = _this$state2.scrollUpdateWasRequested;\n\n      if (scrollUpdateWasRequested && this._outerRef != null) {\n        // TRICKY According to the spec, scrollLeft should be negative for RTL aligned elements.\n        // This is not the case for all browsers though (e.g. Chrome reports values as positive, measured relative to the left).\n        // So we need to determine which browser behavior we're dealing with, and mimic it.\n        var outerRef = this._outerRef;\n\n        if (direction === 'rtl') {\n          switch (getRTLOffsetType()) {\n            case 'negative':\n              outerRef.scrollLeft = -scrollLeft;\n              break;\n\n            case 'positive-ascending':\n              outerRef.scrollLeft = scrollLeft;\n              break;\n\n            default:\n              var clientWidth = outerRef.clientWidth,\n                  scrollWidth = outerRef.scrollWidth;\n              outerRef.scrollLeft = scrollWidth - clientWidth - scrollLeft;\n              break;\n          }\n        } else {\n          outerRef.scrollLeft = Math.max(0, scrollLeft);\n        }\n\n        outerRef.scrollTop = Math.max(0, scrollTop);\n      }\n\n      this._callPropsCallbacks();\n    };\n\n    _proto.componentWillUnmount = function componentWillUnmount() {\n      if (this._resetIsScrollingTimeoutId !== null) {\n        cancelTimeout(this._resetIsScrollingTimeoutId);\n      }\n    };\n\n    _proto.render = function render() {\n      var _this$props4 = this.props,\n          children = _this$props4.children,\n          className = _this$props4.className,\n          columnCount = _this$props4.columnCount,\n          direction = _this$props4.direction,\n          height = _this$props4.height,\n          innerRef = _this$props4.innerRef,\n          innerElementType = _this$props4.innerElementType,\n          innerTagName = _this$props4.innerTagName,\n          itemData = _this$props4.itemData,\n          _this$props4$itemKey = _this$props4.itemKey,\n          itemKey = _this$props4$itemKey === void 0 ? defaultItemKey : _this$props4$itemKey,\n          outerElementType = _this$props4.outerElementType,\n          outerTagName = _this$props4.outerTagName,\n          rowCount = _this$props4.rowCount,\n          style = _this$props4.style,\n          useIsScrolling = _this$props4.useIsScrolling,\n          width = _this$props4.width;\n      var isScrolling = this.state.isScrolling;\n\n      var _this$_getHorizontalR = this._getHorizontalRangeToRender(),\n          columnStartIndex = _this$_getHorizontalR[0],\n          columnStopIndex = _this$_getHorizontalR[1];\n\n      var _this$_getVerticalRan = this._getVerticalRangeToRender(),\n          rowStartIndex = _this$_getVerticalRan[0],\n          rowStopIndex = _this$_getVerticalRan[1];\n\n      var items = [];\n\n      if (columnCount > 0 && rowCount) {\n        for (var _rowIndex = rowStartIndex; _rowIndex <= rowStopIndex; _rowIndex++) {\n          for (var _columnIndex = columnStartIndex; _columnIndex <= columnStopIndex; _columnIndex++) {\n            items.push(createElement(children, {\n              columnIndex: _columnIndex,\n              data: itemData,\n              isScrolling: useIsScrolling ? isScrolling : undefined,\n              key: itemKey({\n                columnIndex: _columnIndex,\n                data: itemData,\n                rowIndex: _rowIndex\n              }),\n              rowIndex: _rowIndex,\n              style: this._getItemStyle(_rowIndex, _columnIndex)\n            }));\n          }\n        }\n      } // Read this value AFTER items have been created,\n      // So their actual sizes (if variable) are taken into consideration.\n\n\n      var estimatedTotalHeight = getEstimatedTotalHeight(this.props, this._instanceProps);\n      var estimatedTotalWidth = getEstimatedTotalWidth(this.props, this._instanceProps);\n      return createElement(outerElementType || outerTagName || 'div', {\n        className: className,\n        onScroll: this._onScroll,\n        ref: this._outerRefSetter,\n        style: _extends({\n          position: 'relative',\n          height: height,\n          width: width,\n          overflow: 'auto',\n          WebkitOverflowScrolling: 'touch',\n          willChange: 'transform',\n          direction: direction\n        }, style)\n      }, createElement(innerElementType || innerTagName || 'div', {\n        children: items,\n        ref: innerRef,\n        style: {\n          height: estimatedTotalHeight,\n          pointerEvents: isScrolling ? 'none' : undefined,\n          width: estimatedTotalWidth\n        }\n      }));\n    };\n\n    _proto._callPropsCallbacks = function _callPropsCallbacks() {\n      var _this$props5 = this.props,\n          columnCount = _this$props5.columnCount,\n          onItemsRendered = _this$props5.onItemsRendered,\n          onScroll = _this$props5.onScroll,\n          rowCount = _this$props5.rowCount;\n\n      if (typeof onItemsRendered === 'function') {\n        if (columnCount > 0 && rowCount > 0) {\n          var _this$_getHorizontalR2 = this._getHorizontalRangeToRender(),\n              _overscanColumnStartIndex = _this$_getHorizontalR2[0],\n              _overscanColumnStopIndex = _this$_getHorizontalR2[1],\n              _visibleColumnStartIndex = _this$_getHorizontalR2[2],\n              _visibleColumnStopIndex = _this$_getHorizontalR2[3];\n\n          var _this$_getVerticalRan2 = this._getVerticalRangeToRender(),\n              _overscanRowStartIndex = _this$_getVerticalRan2[0],\n              _overscanRowStopIndex = _this$_getVerticalRan2[1],\n              _visibleRowStartIndex = _this$_getVerticalRan2[2],\n              _visibleRowStopIndex = _this$_getVerticalRan2[3];\n\n          this._callOnItemsRendered(_overscanColumnStartIndex, _overscanColumnStopIndex, _overscanRowStartIndex, _overscanRowStopIndex, _visibleColumnStartIndex, _visibleColumnStopIndex, _visibleRowStartIndex, _visibleRowStopIndex);\n        }\n      }\n\n      if (typeof onScroll === 'function') {\n        var _this$state3 = this.state,\n            _horizontalScrollDirection = _this$state3.horizontalScrollDirection,\n            _scrollLeft = _this$state3.scrollLeft,\n            _scrollTop = _this$state3.scrollTop,\n            _scrollUpdateWasRequested = _this$state3.scrollUpdateWasRequested,\n            _verticalScrollDirection = _this$state3.verticalScrollDirection;\n\n        this._callOnScroll(_scrollLeft, _scrollTop, _horizontalScrollDirection, _verticalScrollDirection, _scrollUpdateWasRequested);\n      }\n    } // Lazily create and cache item styles while scrolling,\n    // So that pure component sCU will prevent re-renders.\n    // We maintain this cache, and pass a style prop rather than index,\n    // So that List can clear cached styles and force item re-render if necessary.\n    ;\n\n    _proto._getHorizontalRangeToRender = function _getHorizontalRangeToRender() {\n      var _this$props6 = this.props,\n          columnCount = _this$props6.columnCount,\n          overscanColumnCount = _this$props6.overscanColumnCount,\n          overscanColumnsCount = _this$props6.overscanColumnsCount,\n          overscanCount = _this$props6.overscanCount,\n          rowCount = _this$props6.rowCount;\n      var _this$state4 = this.state,\n          horizontalScrollDirection = _this$state4.horizontalScrollDirection,\n          isScrolling = _this$state4.isScrolling,\n          scrollLeft = _this$state4.scrollLeft;\n      var overscanCountResolved = overscanColumnCount || overscanColumnsCount || overscanCount || 1;\n\n      if (columnCount === 0 || rowCount === 0) {\n        return [0, 0, 0, 0];\n      }\n\n      var startIndex = getColumnStartIndexForOffset(this.props, scrollLeft, this._instanceProps);\n      var stopIndex = getColumnStopIndexForStartIndex(this.props, startIndex, scrollLeft, this._instanceProps); // Overscan by one item in each direction so that tab/focus works.\n      // If there isn't at least one extra item, tab loops back around.\n\n      var overscanBackward = !isScrolling || horizontalScrollDirection === 'backward' ? Math.max(1, overscanCountResolved) : 1;\n      var overscanForward = !isScrolling || horizontalScrollDirection === 'forward' ? Math.max(1, overscanCountResolved) : 1;\n      return [Math.max(0, startIndex - overscanBackward), Math.max(0, Math.min(columnCount - 1, stopIndex + overscanForward)), startIndex, stopIndex];\n    };\n\n    _proto._getVerticalRangeToRender = function _getVerticalRangeToRender() {\n      var _this$props7 = this.props,\n          columnCount = _this$props7.columnCount,\n          overscanCount = _this$props7.overscanCount,\n          overscanRowCount = _this$props7.overscanRowCount,\n          overscanRowsCount = _this$props7.overscanRowsCount,\n          rowCount = _this$props7.rowCount;\n      var _this$state5 = this.state,\n          isScrolling = _this$state5.isScrolling,\n          verticalScrollDirection = _this$state5.verticalScrollDirection,\n          scrollTop = _this$state5.scrollTop;\n      var overscanCountResolved = overscanRowCount || overscanRowsCount || overscanCount || 1;\n\n      if (columnCount === 0 || rowCount === 0) {\n        return [0, 0, 0, 0];\n      }\n\n      var startIndex = getRowStartIndexForOffset(this.props, scrollTop, this._instanceProps);\n      var stopIndex = getRowStopIndexForStartIndex(this.props, startIndex, scrollTop, this._instanceProps); // Overscan by one item in each direction so that tab/focus works.\n      // If there isn't at least one extra item, tab loops back around.\n\n      var overscanBackward = !isScrolling || verticalScrollDirection === 'backward' ? Math.max(1, overscanCountResolved) : 1;\n      var overscanForward = !isScrolling || verticalScrollDirection === 'forward' ? Math.max(1, overscanCountResolved) : 1;\n      return [Math.max(0, startIndex - overscanBackward), Math.max(0, Math.min(rowCount - 1, stopIndex + overscanForward)), startIndex, stopIndex];\n    };\n\n    return Grid;\n  }(PureComponent), _class.defaultProps = {\n    direction: 'ltr',\n    itemData: undefined,\n    useIsScrolling: false\n  }, _class;\n}\n\nvar validateSharedProps = function validateSharedProps(_ref5, _ref6) {\n  var children = _ref5.children,\n      direction = _ref5.direction,\n      height = _ref5.height,\n      innerTagName = _ref5.innerTagName,\n      outerTagName = _ref5.outerTagName,\n      overscanColumnsCount = _ref5.overscanColumnsCount,\n      overscanCount = _ref5.overscanCount,\n      overscanRowsCount = _ref5.overscanRowsCount,\n      width = _ref5.width;\n  var instance = _ref6.instance;\n\n  if (process.env.NODE_ENV !== 'production') {\n    if (typeof overscanCount === 'number') {\n      if (devWarningsOverscanCount && !devWarningsOverscanCount.has(instance)) {\n        devWarningsOverscanCount.add(instance);\n        console.warn('The overscanCount prop has been deprecated. ' + 'Please use the overscanColumnCount and overscanRowCount props instead.');\n      }\n    }\n\n    if (typeof overscanColumnsCount === 'number' || typeof overscanRowsCount === 'number') {\n      if (devWarningsOverscanRowsColumnsCount && !devWarningsOverscanRowsColumnsCount.has(instance)) {\n        devWarningsOverscanRowsColumnsCount.add(instance);\n        console.warn('The overscanColumnsCount and overscanRowsCount props have been deprecated. ' + 'Please use the overscanColumnCount and overscanRowCount props instead.');\n      }\n    }\n\n    if (innerTagName != null || outerTagName != null) {\n      if (devWarningsTagName && !devWarningsTagName.has(instance)) {\n        devWarningsTagName.add(instance);\n        console.warn('The innerTagName and outerTagName props have been deprecated. ' + 'Please use the innerElementType and outerElementType props instead.');\n      }\n    }\n\n    if (children == null) {\n      throw Error('An invalid \"children\" prop has been specified. ' + 'Value should be a React component. ' + (\"\\\"\" + (children === null ? 'null' : typeof children) + \"\\\" was specified.\"));\n    }\n\n    switch (direction) {\n      case 'ltr':\n      case 'rtl':\n        // Valid values\n        break;\n\n      default:\n        throw Error('An invalid \"direction\" prop has been specified. ' + 'Value should be either \"ltr\" or \"rtl\". ' + (\"\\\"\" + direction + \"\\\" was specified.\"));\n    }\n\n    if (typeof width !== 'number') {\n      throw Error('An invalid \"width\" prop has been specified. ' + 'Grids must specify a number for width. ' + (\"\\\"\" + (width === null ? 'null' : typeof width) + \"\\\" was specified.\"));\n    }\n\n    if (typeof height !== 'number') {\n      throw Error('An invalid \"height\" prop has been specified. ' + 'Grids must specify a number for height. ' + (\"\\\"\" + (height === null ? 'null' : typeof height) + \"\\\" was specified.\"));\n    }\n  }\n};\n\nvar DEFAULT_ESTIMATED_ITEM_SIZE = 50;\n\nvar getEstimatedTotalHeight = function getEstimatedTotalHeight(_ref, _ref2) {\n  var rowCount = _ref.rowCount;\n  var rowMetadataMap = _ref2.rowMetadataMap,\n      estimatedRowHeight = _ref2.estimatedRowHeight,\n      lastMeasuredRowIndex = _ref2.lastMeasuredRowIndex;\n  var totalSizeOfMeasuredRows = 0; // Edge case check for when the number of items decreases while a scroll is in progress.\n  // https://github.com/bvaughn/react-window/pull/138\n\n  if (lastMeasuredRowIndex >= rowCount) {\n    lastMeasuredRowIndex = rowCount - 1;\n  }\n\n  if (lastMeasuredRowIndex >= 0) {\n    var itemMetadata = rowMetadataMap[lastMeasuredRowIndex];\n    totalSizeOfMeasuredRows = itemMetadata.offset + itemMetadata.size;\n  }\n\n  var numUnmeasuredItems = rowCount - lastMeasuredRowIndex - 1;\n  var totalSizeOfUnmeasuredItems = numUnmeasuredItems * estimatedRowHeight;\n  return totalSizeOfMeasuredRows + totalSizeOfUnmeasuredItems;\n};\n\nvar getEstimatedTotalWidth = function getEstimatedTotalWidth(_ref3, _ref4) {\n  var columnCount = _ref3.columnCount;\n  var columnMetadataMap = _ref4.columnMetadataMap,\n      estimatedColumnWidth = _ref4.estimatedColumnWidth,\n      lastMeasuredColumnIndex = _ref4.lastMeasuredColumnIndex;\n  var totalSizeOfMeasuredRows = 0; // Edge case check for when the number of items decreases while a scroll is in progress.\n  // https://github.com/bvaughn/react-window/pull/138\n\n  if (lastMeasuredColumnIndex >= columnCount) {\n    lastMeasuredColumnIndex = columnCount - 1;\n  }\n\n  if (lastMeasuredColumnIndex >= 0) {\n    var itemMetadata = columnMetadataMap[lastMeasuredColumnIndex];\n    totalSizeOfMeasuredRows = itemMetadata.offset + itemMetadata.size;\n  }\n\n  var numUnmeasuredItems = columnCount - lastMeasuredColumnIndex - 1;\n  var totalSizeOfUnmeasuredItems = numUnmeasuredItems * estimatedColumnWidth;\n  return totalSizeOfMeasuredRows + totalSizeOfUnmeasuredItems;\n};\n\nvar getItemMetadata = function getItemMetadata(itemType, props, index, instanceProps) {\n  var itemMetadataMap, itemSize, lastMeasuredIndex;\n\n  if (itemType === 'column') {\n    itemMetadataMap = instanceProps.columnMetadataMap;\n    itemSize = props.columnWidth;\n    lastMeasuredIndex = instanceProps.lastMeasuredColumnIndex;\n  } else {\n    itemMetadataMap = instanceProps.rowMetadataMap;\n    itemSize = props.rowHeight;\n    lastMeasuredIndex = instanceProps.lastMeasuredRowIndex;\n  }\n\n  if (index > lastMeasuredIndex) {\n    var offset = 0;\n\n    if (lastMeasuredIndex >= 0) {\n      var itemMetadata = itemMetadataMap[lastMeasuredIndex];\n      offset = itemMetadata.offset + itemMetadata.size;\n    }\n\n    for (var i = lastMeasuredIndex + 1; i <= index; i++) {\n      var size = itemSize(i);\n      itemMetadataMap[i] = {\n        offset: offset,\n        size: size\n      };\n      offset += size;\n    }\n\n    if (itemType === 'column') {\n      instanceProps.lastMeasuredColumnIndex = index;\n    } else {\n      instanceProps.lastMeasuredRowIndex = index;\n    }\n  }\n\n  return itemMetadataMap[index];\n};\n\nvar findNearestItem = function findNearestItem(itemType, props, instanceProps, offset) {\n  var itemMetadataMap, lastMeasuredIndex;\n\n  if (itemType === 'column') {\n    itemMetadataMap = instanceProps.columnMetadataMap;\n    lastMeasuredIndex = instanceProps.lastMeasuredColumnIndex;\n  } else {\n    itemMetadataMap = instanceProps.rowMetadataMap;\n    lastMeasuredIndex = instanceProps.lastMeasuredRowIndex;\n  }\n\n  var lastMeasuredItemOffset = lastMeasuredIndex > 0 ? itemMetadataMap[lastMeasuredIndex].offset : 0;\n\n  if (lastMeasuredItemOffset >= offset) {\n    // If we've already measured items within this range just use a binary search as it's faster.\n    return findNearestItemBinarySearch(itemType, props, instanceProps, lastMeasuredIndex, 0, offset);\n  } else {\n    // If we haven't yet measured this high, fallback to an exponential search with an inner binary search.\n    // The exponential search avoids pre-computing sizes for the full set of items as a binary search would.\n    // The overall complexity for this approach is O(log n).\n    return findNearestItemExponentialSearch(itemType, props, instanceProps, Math.max(0, lastMeasuredIndex), offset);\n  }\n};\n\nvar findNearestItemBinarySearch = function findNearestItemBinarySearch(itemType, props, instanceProps, high, low, offset) {\n  while (low <= high) {\n    var middle = low + Math.floor((high - low) / 2);\n    var currentOffset = getItemMetadata(itemType, props, middle, instanceProps).offset;\n\n    if (currentOffset === offset) {\n      return middle;\n    } else if (currentOffset < offset) {\n      low = middle + 1;\n    } else if (currentOffset > offset) {\n      high = middle - 1;\n    }\n  }\n\n  if (low > 0) {\n    return low - 1;\n  } else {\n    return 0;\n  }\n};\n\nvar findNearestItemExponentialSearch = function findNearestItemExponentialSearch(itemType, props, instanceProps, index, offset) {\n  var itemCount = itemType === 'column' ? props.columnCount : props.rowCount;\n  var interval = 1;\n\n  while (index < itemCount && getItemMetadata(itemType, props, index, instanceProps).offset < offset) {\n    index += interval;\n    interval *= 2;\n  }\n\n  return findNearestItemBinarySearch(itemType, props, instanceProps, Math.min(index, itemCount - 1), Math.floor(index / 2), offset);\n};\n\nvar getOffsetForIndexAndAlignment = function getOffsetForIndexAndAlignment(itemType, props, index, align, scrollOffset, instanceProps, scrollbarSize) {\n  var size = itemType === 'column' ? props.width : props.height;\n  var itemMetadata = getItemMetadata(itemType, props, index, instanceProps); // Get estimated total size after ItemMetadata is computed,\n  // To ensure it reflects actual measurements instead of just estimates.\n\n  var estimatedTotalSize = itemType === 'column' ? getEstimatedTotalWidth(props, instanceProps) : getEstimatedTotalHeight(props, instanceProps);\n  var maxOffset = Math.max(0, Math.min(estimatedTotalSize - size, itemMetadata.offset));\n  var minOffset = Math.max(0, itemMetadata.offset - size + scrollbarSize + itemMetadata.size);\n\n  if (align === 'smart') {\n    if (scrollOffset >= minOffset - size && scrollOffset <= maxOffset + size) {\n      align = 'auto';\n    } else {\n      align = 'center';\n    }\n  }\n\n  switch (align) {\n    case 'start':\n      return maxOffset;\n\n    case 'end':\n      return minOffset;\n\n    case 'center':\n      return Math.round(minOffset + (maxOffset - minOffset) / 2);\n\n    case 'auto':\n    default:\n      if (scrollOffset >= minOffset && scrollOffset <= maxOffset) {\n        return scrollOffset;\n      } else if (minOffset > maxOffset) {\n        // Because we only take into account the scrollbar size when calculating minOffset\n        // this value can be larger than maxOffset when at the end of the list\n        return minOffset;\n      } else if (scrollOffset < minOffset) {\n        return minOffset;\n      } else {\n        return maxOffset;\n      }\n\n  }\n};\n\nvar VariableSizeGrid = /*#__PURE__*/createGridComponent({\n  getColumnOffset: function getColumnOffset(props, index, instanceProps) {\n    return getItemMetadata('column', props, index, instanceProps).offset;\n  },\n  getColumnStartIndexForOffset: function getColumnStartIndexForOffset(props, scrollLeft, instanceProps) {\n    return findNearestItem('column', props, instanceProps, scrollLeft);\n  },\n  getColumnStopIndexForStartIndex: function getColumnStopIndexForStartIndex(props, startIndex, scrollLeft, instanceProps) {\n    var columnCount = props.columnCount,\n        width = props.width;\n    var itemMetadata = getItemMetadata('column', props, startIndex, instanceProps);\n    var maxOffset = scrollLeft + width;\n    var offset = itemMetadata.offset + itemMetadata.size;\n    var stopIndex = startIndex;\n\n    while (stopIndex < columnCount - 1 && offset < maxOffset) {\n      stopIndex++;\n      offset += getItemMetadata('column', props, stopIndex, instanceProps).size;\n    }\n\n    return stopIndex;\n  },\n  getColumnWidth: function getColumnWidth(props, index, instanceProps) {\n    return instanceProps.columnMetadataMap[index].size;\n  },\n  getEstimatedTotalHeight: getEstimatedTotalHeight,\n  getEstimatedTotalWidth: getEstimatedTotalWidth,\n  getOffsetForColumnAndAlignment: function getOffsetForColumnAndAlignment(props, index, align, scrollOffset, instanceProps, scrollbarSize) {\n    return getOffsetForIndexAndAlignment('column', props, index, align, scrollOffset, instanceProps, scrollbarSize);\n  },\n  getOffsetForRowAndAlignment: function getOffsetForRowAndAlignment(props, index, align, scrollOffset, instanceProps, scrollbarSize) {\n    return getOffsetForIndexAndAlignment('row', props, index, align, scrollOffset, instanceProps, scrollbarSize);\n  },\n  getRowOffset: function getRowOffset(props, index, instanceProps) {\n    return getItemMetadata('row', props, index, instanceProps).offset;\n  },\n  getRowHeight: function getRowHeight(props, index, instanceProps) {\n    return instanceProps.rowMetadataMap[index].size;\n  },\n  getRowStartIndexForOffset: function getRowStartIndexForOffset(props, scrollTop, instanceProps) {\n    return findNearestItem('row', props, instanceProps, scrollTop);\n  },\n  getRowStopIndexForStartIndex: function getRowStopIndexForStartIndex(props, startIndex, scrollTop, instanceProps) {\n    var rowCount = props.rowCount,\n        height = props.height;\n    var itemMetadata = getItemMetadata('row', props, startIndex, instanceProps);\n    var maxOffset = scrollTop + height;\n    var offset = itemMetadata.offset + itemMetadata.size;\n    var stopIndex = startIndex;\n\n    while (stopIndex < rowCount - 1 && offset < maxOffset) {\n      stopIndex++;\n      offset += getItemMetadata('row', props, stopIndex, instanceProps).size;\n    }\n\n    return stopIndex;\n  },\n  initInstanceProps: function initInstanceProps(props, instance) {\n    var _ref5 = props,\n        estimatedColumnWidth = _ref5.estimatedColumnWidth,\n        estimatedRowHeight = _ref5.estimatedRowHeight;\n    var instanceProps = {\n      columnMetadataMap: {},\n      estimatedColumnWidth: estimatedColumnWidth || DEFAULT_ESTIMATED_ITEM_SIZE,\n      estimatedRowHeight: estimatedRowHeight || DEFAULT_ESTIMATED_ITEM_SIZE,\n      lastMeasuredColumnIndex: -1,\n      lastMeasuredRowIndex: -1,\n      rowMetadataMap: {}\n    };\n\n    instance.resetAfterColumnIndex = function (columnIndex, shouldForceUpdate) {\n      if (shouldForceUpdate === void 0) {\n        shouldForceUpdate = true;\n      }\n\n      instance.resetAfterIndices({\n        columnIndex: columnIndex,\n        shouldForceUpdate: shouldForceUpdate\n      });\n    };\n\n    instance.resetAfterRowIndex = function (rowIndex, shouldForceUpdate) {\n      if (shouldForceUpdate === void 0) {\n        shouldForceUpdate = true;\n      }\n\n      instance.resetAfterIndices({\n        rowIndex: rowIndex,\n        shouldForceUpdate: shouldForceUpdate\n      });\n    };\n\n    instance.resetAfterIndices = function (_ref6) {\n      var columnIndex = _ref6.columnIndex,\n          rowIndex = _ref6.rowIndex,\n          _ref6$shouldForceUpda = _ref6.shouldForceUpdate,\n          shouldForceUpdate = _ref6$shouldForceUpda === void 0 ? true : _ref6$shouldForceUpda;\n\n      if (typeof columnIndex === 'number') {\n        instanceProps.lastMeasuredColumnIndex = Math.min(instanceProps.lastMeasuredColumnIndex, columnIndex - 1);\n      }\n\n      if (typeof rowIndex === 'number') {\n        instanceProps.lastMeasuredRowIndex = Math.min(instanceProps.lastMeasuredRowIndex, rowIndex - 1);\n      } // We could potentially optimize further by only evicting styles after this index,\n      // But since styles are only cached while scrolling is in progress-\n      // It seems an unnecessary optimization.\n      // It's unlikely that resetAfterIndex() will be called while a user is scrolling.\n\n\n      instance._getItemStyleCache(-1);\n\n      if (shouldForceUpdate) {\n        instance.forceUpdate();\n      }\n    };\n\n    return instanceProps;\n  },\n  shouldResetStyleCacheOnItemSizeChange: false,\n  validateProps: function validateProps(_ref7) {\n    var columnWidth = _ref7.columnWidth,\n        rowHeight = _ref7.rowHeight;\n\n    if (process.env.NODE_ENV !== 'production') {\n      if (typeof columnWidth !== 'function') {\n        throw Error('An invalid \"columnWidth\" prop has been specified. ' + 'Value should be a function. ' + (\"\\\"\" + (columnWidth === null ? 'null' : typeof columnWidth) + \"\\\" was specified.\"));\n      } else if (typeof rowHeight !== 'function') {\n        throw Error('An invalid \"rowHeight\" prop has been specified. ' + 'Value should be a function. ' + (\"\\\"\" + (rowHeight === null ? 'null' : typeof rowHeight) + \"\\\" was specified.\"));\n      }\n    }\n  }\n});\n\nvar IS_SCROLLING_DEBOUNCE_INTERVAL$1 = 150;\n\nvar defaultItemKey$1 = function defaultItemKey(index, data) {\n  return index;\n}; // In DEV mode, this Set helps us only log a warning once per component instance.\n// This avoids spamming the console every time a render happens.\n\n\nvar devWarningsDirection = null;\nvar devWarningsTagName$1 = null;\n\nif (process.env.NODE_ENV !== 'production') {\n  if (typeof window !== 'undefined' && typeof window.WeakSet !== 'undefined') {\n    devWarningsDirection = /*#__PURE__*/new WeakSet();\n    devWarningsTagName$1 = /*#__PURE__*/new WeakSet();\n  }\n}\n\nfunction createListComponent(_ref) {\n  var _class;\n\n  var getItemOffset = _ref.getItemOffset,\n      getEstimatedTotalSize = _ref.getEstimatedTotalSize,\n      getItemSize = _ref.getItemSize,\n      getOffsetForIndexAndAlignment = _ref.getOffsetForIndexAndAlignment,\n      getStartIndexForOffset = _ref.getStartIndexForOffset,\n      getStopIndexForStartIndex = _ref.getStopIndexForStartIndex,\n      initInstanceProps = _ref.initInstanceProps,\n      shouldResetStyleCacheOnItemSizeChange = _ref.shouldResetStyleCacheOnItemSizeChange,\n      validateProps = _ref.validateProps;\n  return _class = /*#__PURE__*/function (_PureComponent) {\n    _inheritsLoose(List, _PureComponent);\n\n    // Always use explicit constructor for React components.\n    // It produces less code after transpilation. (#26)\n    // eslint-disable-next-line no-useless-constructor\n    function List(props) {\n      var _this;\n\n      _this = _PureComponent.call(this, props) || this;\n      _this._instanceProps = initInstanceProps(_this.props, _assertThisInitialized(_this));\n      _this._outerRef = void 0;\n      _this._resetIsScrollingTimeoutId = null;\n      _this.state = {\n        instance: _assertThisInitialized(_this),\n        isScrolling: false,\n        scrollDirection: 'forward',\n        scrollOffset: typeof _this.props.initialScrollOffset === 'number' ? _this.props.initialScrollOffset : 0,\n        scrollUpdateWasRequested: false\n      };\n      _this._callOnItemsRendered = void 0;\n      _this._callOnItemsRendered = memoizeOne(function (overscanStartIndex, overscanStopIndex, visibleStartIndex, visibleStopIndex) {\n        return _this.props.onItemsRendered({\n          overscanStartIndex: overscanStartIndex,\n          overscanStopIndex: overscanStopIndex,\n          visibleStartIndex: visibleStartIndex,\n          visibleStopIndex: visibleStopIndex\n        });\n      });\n      _this._callOnScroll = void 0;\n      _this._callOnScroll = memoizeOne(function (scrollDirection, scrollOffset, scrollUpdateWasRequested) {\n        return _this.props.onScroll({\n          scrollDirection: scrollDirection,\n          scrollOffset: scrollOffset,\n          scrollUpdateWasRequested: scrollUpdateWasRequested\n        });\n      });\n      _this._getItemStyle = void 0;\n\n      _this._getItemStyle = function (index) {\n        var _this$props = _this.props,\n            direction = _this$props.direction,\n            itemSize = _this$props.itemSize,\n            layout = _this$props.layout;\n\n        var itemStyleCache = _this._getItemStyleCache(shouldResetStyleCacheOnItemSizeChange && itemSize, shouldResetStyleCacheOnItemSizeChange && layout, shouldResetStyleCacheOnItemSizeChange && direction);\n\n        var style;\n\n        if (itemStyleCache.hasOwnProperty(index)) {\n          style = itemStyleCache[index];\n        } else {\n          var _offset = getItemOffset(_this.props, index, _this._instanceProps);\n\n          var size = getItemSize(_this.props, index, _this._instanceProps); // TODO Deprecate direction \"horizontal\"\n\n          var isHorizontal = direction === 'horizontal' || layout === 'horizontal';\n          var isRtl = direction === 'rtl';\n          var offsetHorizontal = isHorizontal ? _offset : 0;\n          itemStyleCache[index] = style = {\n            position: 'absolute',\n            left: isRtl ? undefined : offsetHorizontal,\n            right: isRtl ? offsetHorizontal : undefined,\n            top: !isHorizontal ? _offset : 0,\n            height: !isHorizontal ? size : '100%',\n            width: isHorizontal ? size : '100%'\n          };\n        }\n\n        return style;\n      };\n\n      _this._getItemStyleCache = void 0;\n      _this._getItemStyleCache = memoizeOne(function (_, __, ___) {\n        return {};\n      });\n\n      _this._onScrollHorizontal = function (event) {\n        var _event$currentTarget = event.currentTarget,\n            clientWidth = _event$currentTarget.clientWidth,\n            scrollLeft = _event$currentTarget.scrollLeft,\n            scrollWidth = _event$currentTarget.scrollWidth;\n\n        _this.setState(function (prevState) {\n          if (prevState.scrollOffset === scrollLeft) {\n            // Scroll position may have been updated by cDM/cDU,\n            // In which case we don't need to trigger another render,\n            // And we don't want to update state.isScrolling.\n            return null;\n          }\n\n          var direction = _this.props.direction;\n          var scrollOffset = scrollLeft;\n\n          if (direction === 'rtl') {\n            // TRICKY According to the spec, scrollLeft should be negative for RTL aligned elements.\n            // This is not the case for all browsers though (e.g. Chrome reports values as positive, measured relative to the left).\n            // It's also easier for this component if we convert offsets to the same format as they would be in for ltr.\n            // So the simplest solution is to determine which browser behavior we're dealing with, and convert based on it.\n            switch (getRTLOffsetType()) {\n              case 'negative':\n                scrollOffset = -scrollLeft;\n                break;\n\n              case 'positive-descending':\n                scrollOffset = scrollWidth - clientWidth - scrollLeft;\n                break;\n            }\n          } // Prevent Safari's elastic scrolling from causing visual shaking when scrolling past bounds.\n\n\n          scrollOffset = Math.max(0, Math.min(scrollOffset, scrollWidth - clientWidth));\n          return {\n            isScrolling: true,\n            scrollDirection: prevState.scrollOffset < scrollLeft ? 'forward' : 'backward',\n            scrollOffset: scrollOffset,\n            scrollUpdateWasRequested: false\n          };\n        }, _this._resetIsScrollingDebounced);\n      };\n\n      _this._onScrollVertical = function (event) {\n        var _event$currentTarget2 = event.currentTarget,\n            clientHeight = _event$currentTarget2.clientHeight,\n            scrollHeight = _event$currentTarget2.scrollHeight,\n            scrollTop = _event$currentTarget2.scrollTop;\n\n        _this.setState(function (prevState) {\n          if (prevState.scrollOffset === scrollTop) {\n            // Scroll position may have been updated by cDM/cDU,\n            // In which case we don't need to trigger another render,\n            // And we don't want to update state.isScrolling.\n            return null;\n          } // Prevent Safari's elastic scrolling from causing visual shaking when scrolling past bounds.\n\n\n          var scrollOffset = Math.max(0, Math.min(scrollTop, scrollHeight - clientHeight));\n          return {\n            isScrolling: true,\n            scrollDirection: prevState.scrollOffset < scrollOffset ? 'forward' : 'backward',\n            scrollOffset: scrollOffset,\n            scrollUpdateWasRequested: false\n          };\n        }, _this._resetIsScrollingDebounced);\n      };\n\n      _this._outerRefSetter = function (ref) {\n        var outerRef = _this.props.outerRef;\n        _this._outerRef = ref;\n\n        if (typeof outerRef === 'function') {\n          outerRef(ref);\n        } else if (outerRef != null && typeof outerRef === 'object' && outerRef.hasOwnProperty('current')) {\n          outerRef.current = ref;\n        }\n      };\n\n      _this._resetIsScrollingDebounced = function () {\n        if (_this._resetIsScrollingTimeoutId !== null) {\n          cancelTimeout(_this._resetIsScrollingTimeoutId);\n        }\n\n        _this._resetIsScrollingTimeoutId = requestTimeout(_this._resetIsScrolling, IS_SCROLLING_DEBOUNCE_INTERVAL$1);\n      };\n\n      _this._resetIsScrolling = function () {\n        _this._resetIsScrollingTimeoutId = null;\n\n        _this.setState({\n          isScrolling: false\n        }, function () {\n          // Clear style cache after state update has been committed.\n          // This way we don't break pure sCU for items that don't use isScrolling param.\n          _this._getItemStyleCache(-1, null);\n        });\n      };\n\n      return _this;\n    }\n\n    List.getDerivedStateFromProps = function getDerivedStateFromProps(nextProps, prevState) {\n      validateSharedProps$1(nextProps, prevState);\n      validateProps(nextProps);\n      return null;\n    };\n\n    var _proto = List.prototype;\n\n    _proto.scrollTo = function scrollTo(scrollOffset) {\n      scrollOffset = Math.max(0, scrollOffset);\n      this.setState(function (prevState) {\n        if (prevState.scrollOffset === scrollOffset) {\n          return null;\n        }\n\n        return {\n          scrollDirection: prevState.scrollOffset < scrollOffset ? 'forward' : 'backward',\n          scrollOffset: scrollOffset,\n          scrollUpdateWasRequested: true\n        };\n      }, this._resetIsScrollingDebounced);\n    };\n\n    _proto.scrollToItem = function scrollToItem(index, align) {\n      if (align === void 0) {\n        align = 'auto';\n      }\n\n      var itemCount = this.props.itemCount;\n      var scrollOffset = this.state.scrollOffset;\n      index = Math.max(0, Math.min(index, itemCount - 1));\n      this.scrollTo(getOffsetForIndexAndAlignment(this.props, index, align, scrollOffset, this._instanceProps));\n    };\n\n    _proto.componentDidMount = function componentDidMount() {\n      var _this$props2 = this.props,\n          direction = _this$props2.direction,\n          initialScrollOffset = _this$props2.initialScrollOffset,\n          layout = _this$props2.layout;\n\n      if (typeof initialScrollOffset === 'number' && this._outerRef != null) {\n        var outerRef = this._outerRef; // TODO Deprecate direction \"horizontal\"\n\n        if (direction === 'horizontal' || layout === 'horizontal') {\n          outerRef.scrollLeft = initialScrollOffset;\n        } else {\n          outerRef.scrollTop = initialScrollOffset;\n        }\n      }\n\n      this._callPropsCallbacks();\n    };\n\n    _proto.componentDidUpdate = function componentDidUpdate() {\n      var _this$props3 = this.props,\n          direction = _this$props3.direction,\n          layout = _this$props3.layout;\n      var _this$state = this.state,\n          scrollOffset = _this$state.scrollOffset,\n          scrollUpdateWasRequested = _this$state.scrollUpdateWasRequested;\n\n      if (scrollUpdateWasRequested && this._outerRef != null) {\n        var outerRef = this._outerRef; // TODO Deprecate direction \"horizontal\"\n\n        if (direction === 'horizontal' || layout === 'horizontal') {\n          if (direction === 'rtl') {\n            // TRICKY According to the spec, scrollLeft should be negative for RTL aligned elements.\n            // This is not the case for all browsers though (e.g. Chrome reports values as positive, measured relative to the left).\n            // So we need to determine which browser behavior we're dealing with, and mimic it.\n            switch (getRTLOffsetType()) {\n              case 'negative':\n                outerRef.scrollLeft = -scrollOffset;\n                break;\n\n              case 'positive-ascending':\n                outerRef.scrollLeft = scrollOffset;\n                break;\n\n              default:\n                var clientWidth = outerRef.clientWidth,\n                    scrollWidth = outerRef.scrollWidth;\n                outerRef.scrollLeft = scrollWidth - clientWidth - scrollOffset;\n                break;\n            }\n          } else {\n            outerRef.scrollLeft = scrollOffset;\n          }\n        } else {\n          outerRef.scrollTop = scrollOffset;\n        }\n      }\n\n      this._callPropsCallbacks();\n    };\n\n    _proto.componentWillUnmount = function componentWillUnmount() {\n      if (this._resetIsScrollingTimeoutId !== null) {\n        cancelTimeout(this._resetIsScrollingTimeoutId);\n      }\n    };\n\n    _proto.render = function render() {\n      var _this$props4 = this.props,\n          children = _this$props4.children,\n          className = _this$props4.className,\n          direction = _this$props4.direction,\n          height = _this$props4.height,\n          innerRef = _this$props4.innerRef,\n          innerElementType = _this$props4.innerElementType,\n          innerTagName = _this$props4.innerTagName,\n          itemCount = _this$props4.itemCount,\n          itemData = _this$props4.itemData,\n          _this$props4$itemKey = _this$props4.itemKey,\n          itemKey = _this$props4$itemKey === void 0 ? defaultItemKey$1 : _this$props4$itemKey,\n          layout = _this$props4.layout,\n          outerElementType = _this$props4.outerElementType,\n          outerTagName = _this$props4.outerTagName,\n          style = _this$props4.style,\n          useIsScrolling = _this$props4.useIsScrolling,\n          width = _this$props4.width;\n      var isScrolling = this.state.isScrolling; // TODO Deprecate direction \"horizontal\"\n\n      var isHorizontal = direction === 'horizontal' || layout === 'horizontal';\n      var onScroll = isHorizontal ? this._onScrollHorizontal : this._onScrollVertical;\n\n      var _this$_getRangeToRend = this._getRangeToRender(),\n          startIndex = _this$_getRangeToRend[0],\n          stopIndex = _this$_getRangeToRend[1];\n\n      var items = [];\n\n      if (itemCount > 0) {\n        for (var _index = startIndex; _index <= stopIndex; _index++) {\n          items.push(createElement(children, {\n            data: itemData,\n            key: itemKey(_index, itemData),\n            index: _index,\n            isScrolling: useIsScrolling ? isScrolling : undefined,\n            style: this._getItemStyle(_index)\n          }));\n        }\n      } // Read this value AFTER items have been created,\n      // So their actual sizes (if variable) are taken into consideration.\n\n\n      var estimatedTotalSize = getEstimatedTotalSize(this.props, this._instanceProps);\n      return createElement(outerElementType || outerTagName || 'div', {\n        className: className,\n        onScroll: onScroll,\n        ref: this._outerRefSetter,\n        style: _extends({\n          position: 'relative',\n          height: height,\n          width: width,\n          overflow: 'auto',\n          WebkitOverflowScrolling: 'touch',\n          willChange: 'transform',\n          direction: direction\n        }, style)\n      }, createElement(innerElementType || innerTagName || 'div', {\n        children: items,\n        ref: innerRef,\n        style: {\n          height: isHorizontal ? '100%' : estimatedTotalSize,\n          pointerEvents: isScrolling ? 'none' : undefined,\n          width: isHorizontal ? estimatedTotalSize : '100%'\n        }\n      }));\n    };\n\n    _proto._callPropsCallbacks = function _callPropsCallbacks() {\n      if (typeof this.props.onItemsRendered === 'function') {\n        var itemCount = this.props.itemCount;\n\n        if (itemCount > 0) {\n          var _this$_getRangeToRend2 = this._getRangeToRender(),\n              _overscanStartIndex = _this$_getRangeToRend2[0],\n              _overscanStopIndex = _this$_getRangeToRend2[1],\n              _visibleStartIndex = _this$_getRangeToRend2[2],\n              _visibleStopIndex = _this$_getRangeToRend2[3];\n\n          this._callOnItemsRendered(_overscanStartIndex, _overscanStopIndex, _visibleStartIndex, _visibleStopIndex);\n        }\n      }\n\n      if (typeof this.props.onScroll === 'function') {\n        var _this$state2 = this.state,\n            _scrollDirection = _this$state2.scrollDirection,\n            _scrollOffset = _this$state2.scrollOffset,\n            _scrollUpdateWasRequested = _this$state2.scrollUpdateWasRequested;\n\n        this._callOnScroll(_scrollDirection, _scrollOffset, _scrollUpdateWasRequested);\n      }\n    } // Lazily create and cache item styles while scrolling,\n    // So that pure component sCU will prevent re-renders.\n    // We maintain this cache, and pass a style prop rather than index,\n    // So that List can clear cached styles and force item re-render if necessary.\n    ;\n\n    _proto._getRangeToRender = function _getRangeToRender() {\n      var _this$props5 = this.props,\n          itemCount = _this$props5.itemCount,\n          overscanCount = _this$props5.overscanCount;\n      var _this$state3 = this.state,\n          isScrolling = _this$state3.isScrolling,\n          scrollDirection = _this$state3.scrollDirection,\n          scrollOffset = _this$state3.scrollOffset;\n\n      if (itemCount === 0) {\n        return [0, 0, 0, 0];\n      }\n\n      var startIndex = getStartIndexForOffset(this.props, scrollOffset, this._instanceProps);\n      var stopIndex = getStopIndexForStartIndex(this.props, startIndex, scrollOffset, this._instanceProps); // Overscan by one item in each direction so that tab/focus works.\n      // If there isn't at least one extra item, tab loops back around.\n\n      var overscanBackward = !isScrolling || scrollDirection === 'backward' ? Math.max(1, overscanCount) : 1;\n      var overscanForward = !isScrolling || scrollDirection === 'forward' ? Math.max(1, overscanCount) : 1;\n      return [Math.max(0, startIndex - overscanBackward), Math.max(0, Math.min(itemCount - 1, stopIndex + overscanForward)), startIndex, stopIndex];\n    };\n\n    return List;\n  }(PureComponent), _class.defaultProps = {\n    direction: 'ltr',\n    itemData: undefined,\n    layout: 'vertical',\n    overscanCount: 2,\n    useIsScrolling: false\n  }, _class;\n} // NOTE: I considered further wrapping individual items with a pure ListItem component.\n// This would avoid ever calling the render function for the same index more than once,\n// But it would also add the overhead of a lot of components/fibers.\n// I assume people already do this (render function returning a class component),\n// So my doing it would just unnecessarily double the wrappers.\n\nvar validateSharedProps$1 = function validateSharedProps(_ref2, _ref3) {\n  var children = _ref2.children,\n      direction = _ref2.direction,\n      height = _ref2.height,\n      layout = _ref2.layout,\n      innerTagName = _ref2.innerTagName,\n      outerTagName = _ref2.outerTagName,\n      width = _ref2.width;\n  var instance = _ref3.instance;\n\n  if (process.env.NODE_ENV !== 'production') {\n    if (innerTagName != null || outerTagName != null) {\n      if (devWarningsTagName$1 && !devWarningsTagName$1.has(instance)) {\n        devWarningsTagName$1.add(instance);\n        console.warn('The innerTagName and outerTagName props have been deprecated. ' + 'Please use the innerElementType and outerElementType props instead.');\n      }\n    } // TODO Deprecate direction \"horizontal\"\n\n\n    var isHorizontal = direction === 'horizontal' || layout === 'horizontal';\n\n    switch (direction) {\n      case 'horizontal':\n      case 'vertical':\n        if (devWarningsDirection && !devWarningsDirection.has(instance)) {\n          devWarningsDirection.add(instance);\n          console.warn('The direction prop should be either \"ltr\" (default) or \"rtl\". ' + 'Please use the layout prop to specify \"vertical\" (default) or \"horizontal\" orientation.');\n        }\n\n        break;\n\n      case 'ltr':\n      case 'rtl':\n        // Valid values\n        break;\n\n      default:\n        throw Error('An invalid \"direction\" prop has been specified. ' + 'Value should be either \"ltr\" or \"rtl\". ' + (\"\\\"\" + direction + \"\\\" was specified.\"));\n    }\n\n    switch (layout) {\n      case 'horizontal':\n      case 'vertical':\n        // Valid values\n        break;\n\n      default:\n        throw Error('An invalid \"layout\" prop has been specified. ' + 'Value should be either \"horizontal\" or \"vertical\". ' + (\"\\\"\" + layout + \"\\\" was specified.\"));\n    }\n\n    if (children == null) {\n      throw Error('An invalid \"children\" prop has been specified. ' + 'Value should be a React component. ' + (\"\\\"\" + (children === null ? 'null' : typeof children) + \"\\\" was specified.\"));\n    }\n\n    if (isHorizontal && typeof width !== 'number') {\n      throw Error('An invalid \"width\" prop has been specified. ' + 'Horizontal lists must specify a number for width. ' + (\"\\\"\" + (width === null ? 'null' : typeof width) + \"\\\" was specified.\"));\n    } else if (!isHorizontal && typeof height !== 'number') {\n      throw Error('An invalid \"height\" prop has been specified. ' + 'Vertical lists must specify a number for height. ' + (\"\\\"\" + (height === null ? 'null' : typeof height) + \"\\\" was specified.\"));\n    }\n  }\n};\n\nvar DEFAULT_ESTIMATED_ITEM_SIZE$1 = 50;\n\nvar getItemMetadata$1 = function getItemMetadata(props, index, instanceProps) {\n  var _ref = props,\n      itemSize = _ref.itemSize;\n  var itemMetadataMap = instanceProps.itemMetadataMap,\n      lastMeasuredIndex = instanceProps.lastMeasuredIndex;\n\n  if (index > lastMeasuredIndex) {\n    var offset = 0;\n\n    if (lastMeasuredIndex >= 0) {\n      var itemMetadata = itemMetadataMap[lastMeasuredIndex];\n      offset = itemMetadata.offset + itemMetadata.size;\n    }\n\n    for (var i = lastMeasuredIndex + 1; i <= index; i++) {\n      var size = itemSize(i);\n      itemMetadataMap[i] = {\n        offset: offset,\n        size: size\n      };\n      offset += size;\n    }\n\n    instanceProps.lastMeasuredIndex = index;\n  }\n\n  return itemMetadataMap[index];\n};\n\nvar findNearestItem$1 = function findNearestItem(props, instanceProps, offset) {\n  var itemMetadataMap = instanceProps.itemMetadataMap,\n      lastMeasuredIndex = instanceProps.lastMeasuredIndex;\n  var lastMeasuredItemOffset = lastMeasuredIndex > 0 ? itemMetadataMap[lastMeasuredIndex].offset : 0;\n\n  if (lastMeasuredItemOffset >= offset) {\n    // If we've already measured items within this range just use a binary search as it's faster.\n    return findNearestItemBinarySearch$1(props, instanceProps, lastMeasuredIndex, 0, offset);\n  } else {\n    // If we haven't yet measured this high, fallback to an exponential search with an inner binary search.\n    // The exponential search avoids pre-computing sizes for the full set of items as a binary search would.\n    // The overall complexity for this approach is O(log n).\n    return findNearestItemExponentialSearch$1(props, instanceProps, Math.max(0, lastMeasuredIndex), offset);\n  }\n};\n\nvar findNearestItemBinarySearch$1 = function findNearestItemBinarySearch(props, instanceProps, high, low, offset) {\n  while (low <= high) {\n    var middle = low + Math.floor((high - low) / 2);\n    var currentOffset = getItemMetadata$1(props, middle, instanceProps).offset;\n\n    if (currentOffset === offset) {\n      return middle;\n    } else if (currentOffset < offset) {\n      low = middle + 1;\n    } else if (currentOffset > offset) {\n      high = middle - 1;\n    }\n  }\n\n  if (low > 0) {\n    return low - 1;\n  } else {\n    return 0;\n  }\n};\n\nvar findNearestItemExponentialSearch$1 = function findNearestItemExponentialSearch(props, instanceProps, index, offset) {\n  var itemCount = props.itemCount;\n  var interval = 1;\n\n  while (index < itemCount && getItemMetadata$1(props, index, instanceProps).offset < offset) {\n    index += interval;\n    interval *= 2;\n  }\n\n  return findNearestItemBinarySearch$1(props, instanceProps, Math.min(index, itemCount - 1), Math.floor(index / 2), offset);\n};\n\nvar getEstimatedTotalSize = function getEstimatedTotalSize(_ref2, _ref3) {\n  var itemCount = _ref2.itemCount;\n  var itemMetadataMap = _ref3.itemMetadataMap,\n      estimatedItemSize = _ref3.estimatedItemSize,\n      lastMeasuredIndex = _ref3.lastMeasuredIndex;\n  var totalSizeOfMeasuredItems = 0; // Edge case check for when the number of items decreases while a scroll is in progress.\n  // https://github.com/bvaughn/react-window/pull/138\n\n  if (lastMeasuredIndex >= itemCount) {\n    lastMeasuredIndex = itemCount - 1;\n  }\n\n  if (lastMeasuredIndex >= 0) {\n    var itemMetadata = itemMetadataMap[lastMeasuredIndex];\n    totalSizeOfMeasuredItems = itemMetadata.offset + itemMetadata.size;\n  }\n\n  var numUnmeasuredItems = itemCount - lastMeasuredIndex - 1;\n  var totalSizeOfUnmeasuredItems = numUnmeasuredItems * estimatedItemSize;\n  return totalSizeOfMeasuredItems + totalSizeOfUnmeasuredItems;\n};\n\nvar VariableSizeList = /*#__PURE__*/createListComponent({\n  getItemOffset: function getItemOffset(props, index, instanceProps) {\n    return getItemMetadata$1(props, index, instanceProps).offset;\n  },\n  getItemSize: function getItemSize(props, index, instanceProps) {\n    return instanceProps.itemMetadataMap[index].size;\n  },\n  getEstimatedTotalSize: getEstimatedTotalSize,\n  getOffsetForIndexAndAlignment: function getOffsetForIndexAndAlignment(props, index, align, scrollOffset, instanceProps) {\n    var direction = props.direction,\n        height = props.height,\n        layout = props.layout,\n        width = props.width; // TODO Deprecate direction \"horizontal\"\n\n    var isHorizontal = direction === 'horizontal' || layout === 'horizontal';\n    var size = isHorizontal ? width : height;\n    var itemMetadata = getItemMetadata$1(props, index, instanceProps); // Get estimated total size after ItemMetadata is computed,\n    // To ensure it reflects actual measurements instead of just estimates.\n\n    var estimatedTotalSize = getEstimatedTotalSize(props, instanceProps);\n    var maxOffset = Math.max(0, Math.min(estimatedTotalSize - size, itemMetadata.offset));\n    var minOffset = Math.max(0, itemMetadata.offset - size + itemMetadata.size);\n\n    if (align === 'smart') {\n      if (scrollOffset >= minOffset - size && scrollOffset <= maxOffset + size) {\n        align = 'auto';\n      } else {\n        align = 'center';\n      }\n    }\n\n    switch (align) {\n      case 'start':\n        return maxOffset;\n\n      case 'end':\n        return minOffset;\n\n      case 'center':\n        return Math.round(minOffset + (maxOffset - minOffset) / 2);\n\n      case 'auto':\n      default:\n        if (scrollOffset >= minOffset && scrollOffset <= maxOffset) {\n          return scrollOffset;\n        } else if (scrollOffset < minOffset) {\n          return minOffset;\n        } else {\n          return maxOffset;\n        }\n\n    }\n  },\n  getStartIndexForOffset: function getStartIndexForOffset(props, offset, instanceProps) {\n    return findNearestItem$1(props, instanceProps, offset);\n  },\n  getStopIndexForStartIndex: function getStopIndexForStartIndex(props, startIndex, scrollOffset, instanceProps) {\n    var direction = props.direction,\n        height = props.height,\n        itemCount = props.itemCount,\n        layout = props.layout,\n        width = props.width; // TODO Deprecate direction \"horizontal\"\n\n    var isHorizontal = direction === 'horizontal' || layout === 'horizontal';\n    var size = isHorizontal ? width : height;\n    var itemMetadata = getItemMetadata$1(props, startIndex, instanceProps);\n    var maxOffset = scrollOffset + size;\n    var offset = itemMetadata.offset + itemMetadata.size;\n    var stopIndex = startIndex;\n\n    while (stopIndex < itemCount - 1 && offset < maxOffset) {\n      stopIndex++;\n      offset += getItemMetadata$1(props, stopIndex, instanceProps).size;\n    }\n\n    return stopIndex;\n  },\n  initInstanceProps: function initInstanceProps(props, instance) {\n    var _ref4 = props,\n        estimatedItemSize = _ref4.estimatedItemSize;\n    var instanceProps = {\n      itemMetadataMap: {},\n      estimatedItemSize: estimatedItemSize || DEFAULT_ESTIMATED_ITEM_SIZE$1,\n      lastMeasuredIndex: -1\n    };\n\n    instance.resetAfterIndex = function (index, shouldForceUpdate) {\n      if (shouldForceUpdate === void 0) {\n        shouldForceUpdate = true;\n      }\n\n      instanceProps.lastMeasuredIndex = Math.min(instanceProps.lastMeasuredIndex, index - 1); // We could potentially optimize further by only evicting styles after this index,\n      // But since styles are only cached while scrolling is in progress-\n      // It seems an unnecessary optimization.\n      // It's unlikely that resetAfterIndex() will be called while a user is scrolling.\n\n      instance._getItemStyleCache(-1);\n\n      if (shouldForceUpdate) {\n        instance.forceUpdate();\n      }\n    };\n\n    return instanceProps;\n  },\n  shouldResetStyleCacheOnItemSizeChange: false,\n  validateProps: function validateProps(_ref5) {\n    var itemSize = _ref5.itemSize;\n\n    if (process.env.NODE_ENV !== 'production') {\n      if (typeof itemSize !== 'function') {\n        throw Error('An invalid \"itemSize\" prop has been specified. ' + 'Value should be a function. ' + (\"\\\"\" + (itemSize === null ? 'null' : typeof itemSize) + \"\\\" was specified.\"));\n      }\n    }\n  }\n});\n\nvar FixedSizeGrid = /*#__PURE__*/createGridComponent({\n  getColumnOffset: function getColumnOffset(_ref, index) {\n    var columnWidth = _ref.columnWidth;\n    return index * columnWidth;\n  },\n  getColumnWidth: function getColumnWidth(_ref2, index) {\n    var columnWidth = _ref2.columnWidth;\n    return columnWidth;\n  },\n  getRowOffset: function getRowOffset(_ref3, index) {\n    var rowHeight = _ref3.rowHeight;\n    return index * rowHeight;\n  },\n  getRowHeight: function getRowHeight(_ref4, index) {\n    var rowHeight = _ref4.rowHeight;\n    return rowHeight;\n  },\n  getEstimatedTotalHeight: function getEstimatedTotalHeight(_ref5) {\n    var rowCount = _ref5.rowCount,\n        rowHeight = _ref5.rowHeight;\n    return rowHeight * rowCount;\n  },\n  getEstimatedTotalWidth: function getEstimatedTotalWidth(_ref6) {\n    var columnCount = _ref6.columnCount,\n        columnWidth = _ref6.columnWidth;\n    return columnWidth * columnCount;\n  },\n  getOffsetForColumnAndAlignment: function getOffsetForColumnAndAlignment(_ref7, columnIndex, align, scrollLeft, instanceProps, scrollbarSize) {\n    var columnCount = _ref7.columnCount,\n        columnWidth = _ref7.columnWidth,\n        width = _ref7.width;\n    var lastColumnOffset = Math.max(0, columnCount * columnWidth - width);\n    var maxOffset = Math.min(lastColumnOffset, columnIndex * columnWidth);\n    var minOffset = Math.max(0, columnIndex * columnWidth - width + scrollbarSize + columnWidth);\n\n    if (align === 'smart') {\n      if (scrollLeft >= minOffset - width && scrollLeft <= maxOffset + width) {\n        align = 'auto';\n      } else {\n        align = 'center';\n      }\n    }\n\n    switch (align) {\n      case 'start':\n        return maxOffset;\n\n      case 'end':\n        return minOffset;\n\n      case 'center':\n        // \"Centered\" offset is usually the average of the min and max.\n        // But near the edges of the list, this doesn't hold true.\n        var middleOffset = Math.round(minOffset + (maxOffset - minOffset) / 2);\n\n        if (middleOffset < Math.ceil(width / 2)) {\n          return 0; // near the beginning\n        } else if (middleOffset > lastColumnOffset + Math.floor(width / 2)) {\n          return lastColumnOffset; // near the end\n        } else {\n          return middleOffset;\n        }\n\n      case 'auto':\n      default:\n        if (scrollLeft >= minOffset && scrollLeft <= maxOffset) {\n          return scrollLeft;\n        } else if (minOffset > maxOffset) {\n          // Because we only take into account the scrollbar size when calculating minOffset\n          // this value can be larger than maxOffset when at the end of the list\n          return minOffset;\n        } else if (scrollLeft < minOffset) {\n          return minOffset;\n        } else {\n          return maxOffset;\n        }\n\n    }\n  },\n  getOffsetForRowAndAlignment: function getOffsetForRowAndAlignment(_ref8, rowIndex, align, scrollTop, instanceProps, scrollbarSize) {\n    var rowHeight = _ref8.rowHeight,\n        height = _ref8.height,\n        rowCount = _ref8.rowCount;\n    var lastRowOffset = Math.max(0, rowCount * rowHeight - height);\n    var maxOffset = Math.min(lastRowOffset, rowIndex * rowHeight);\n    var minOffset = Math.max(0, rowIndex * rowHeight - height + scrollbarSize + rowHeight);\n\n    if (align === 'smart') {\n      if (scrollTop >= minOffset - height && scrollTop <= maxOffset + height) {\n        align = 'auto';\n      } else {\n        align = 'center';\n      }\n    }\n\n    switch (align) {\n      case 'start':\n        return maxOffset;\n\n      case 'end':\n        return minOffset;\n\n      case 'center':\n        // \"Centered\" offset is usually the average of the min and max.\n        // But near the edges of the list, this doesn't hold true.\n        var middleOffset = Math.round(minOffset + (maxOffset - minOffset) / 2);\n\n        if (middleOffset < Math.ceil(height / 2)) {\n          return 0; // near the beginning\n        } else if (middleOffset > lastRowOffset + Math.floor(height / 2)) {\n          return lastRowOffset; // near the end\n        } else {\n          return middleOffset;\n        }\n\n      case 'auto':\n      default:\n        if (scrollTop >= minOffset && scrollTop <= maxOffset) {\n          return scrollTop;\n        } else if (minOffset > maxOffset) {\n          // Because we only take into account the scrollbar size when calculating minOffset\n          // this value can be larger than maxOffset when at the end of the list\n          return minOffset;\n        } else if (scrollTop < minOffset) {\n          return minOffset;\n        } else {\n          return maxOffset;\n        }\n\n    }\n  },\n  getColumnStartIndexForOffset: function getColumnStartIndexForOffset(_ref9, scrollLeft) {\n    var columnWidth = _ref9.columnWidth,\n        columnCount = _ref9.columnCount;\n    return Math.max(0, Math.min(columnCount - 1, Math.floor(scrollLeft / columnWidth)));\n  },\n  getColumnStopIndexForStartIndex: function getColumnStopIndexForStartIndex(_ref10, startIndex, scrollLeft) {\n    var columnWidth = _ref10.columnWidth,\n        columnCount = _ref10.columnCount,\n        width = _ref10.width;\n    var left = startIndex * columnWidth;\n    var numVisibleColumns = Math.ceil((width + scrollLeft - left) / columnWidth);\n    return Math.max(0, Math.min(columnCount - 1, startIndex + numVisibleColumns - 1 // -1 is because stop index is inclusive\n    ));\n  },\n  getRowStartIndexForOffset: function getRowStartIndexForOffset(_ref11, scrollTop) {\n    var rowHeight = _ref11.rowHeight,\n        rowCount = _ref11.rowCount;\n    return Math.max(0, Math.min(rowCount - 1, Math.floor(scrollTop / rowHeight)));\n  },\n  getRowStopIndexForStartIndex: function getRowStopIndexForStartIndex(_ref12, startIndex, scrollTop) {\n    var rowHeight = _ref12.rowHeight,\n        rowCount = _ref12.rowCount,\n        height = _ref12.height;\n    var top = startIndex * rowHeight;\n    var numVisibleRows = Math.ceil((height + scrollTop - top) / rowHeight);\n    return Math.max(0, Math.min(rowCount - 1, startIndex + numVisibleRows - 1 // -1 is because stop index is inclusive\n    ));\n  },\n  initInstanceProps: function initInstanceProps(props) {// Noop\n  },\n  shouldResetStyleCacheOnItemSizeChange: true,\n  validateProps: function validateProps(_ref13) {\n    var columnWidth = _ref13.columnWidth,\n        rowHeight = _ref13.rowHeight;\n\n    if (process.env.NODE_ENV !== 'production') {\n      if (typeof columnWidth !== 'number') {\n        throw Error('An invalid \"columnWidth\" prop has been specified. ' + 'Value should be a number. ' + (\"\\\"\" + (columnWidth === null ? 'null' : typeof columnWidth) + \"\\\" was specified.\"));\n      }\n\n      if (typeof rowHeight !== 'number') {\n        throw Error('An invalid \"rowHeight\" prop has been specified. ' + 'Value should be a number. ' + (\"\\\"\" + (rowHeight === null ? 'null' : typeof rowHeight) + \"\\\" was specified.\"));\n      }\n    }\n  }\n});\n\nvar FixedSizeList = /*#__PURE__*/createListComponent({\n  getItemOffset: function getItemOffset(_ref, index) {\n    var itemSize = _ref.itemSize;\n    return index * itemSize;\n  },\n  getItemSize: function getItemSize(_ref2, index) {\n    var itemSize = _ref2.itemSize;\n    return itemSize;\n  },\n  getEstimatedTotalSize: function getEstimatedTotalSize(_ref3) {\n    var itemCount = _ref3.itemCount,\n        itemSize = _ref3.itemSize;\n    return itemSize * itemCount;\n  },\n  getOffsetForIndexAndAlignment: function getOffsetForIndexAndAlignment(_ref4, index, align, scrollOffset) {\n    var direction = _ref4.direction,\n        height = _ref4.height,\n        itemCount = _ref4.itemCount,\n        itemSize = _ref4.itemSize,\n        layout = _ref4.layout,\n        width = _ref4.width;\n    // TODO Deprecate direction \"horizontal\"\n    var isHorizontal = direction === 'horizontal' || layout === 'horizontal';\n    var size = isHorizontal ? width : height;\n    var lastItemOffset = Math.max(0, itemCount * itemSize - size);\n    var maxOffset = Math.min(lastItemOffset, index * itemSize);\n    var minOffset = Math.max(0, index * itemSize - size + itemSize);\n\n    if (align === 'smart') {\n      if (scrollOffset >= minOffset - size && scrollOffset <= maxOffset + size) {\n        align = 'auto';\n      } else {\n        align = 'center';\n      }\n    }\n\n    switch (align) {\n      case 'start':\n        return maxOffset;\n\n      case 'end':\n        return minOffset;\n\n      case 'center':\n        {\n          // \"Centered\" offset is usually the average of the min and max.\n          // But near the edges of the list, this doesn't hold true.\n          var middleOffset = Math.round(minOffset + (maxOffset - minOffset) / 2);\n\n          if (middleOffset < Math.ceil(size / 2)) {\n            return 0; // near the beginning\n          } else if (middleOffset > lastItemOffset + Math.floor(size / 2)) {\n            return lastItemOffset; // near the end\n          } else {\n            return middleOffset;\n          }\n        }\n\n      case 'auto':\n      default:\n        if (scrollOffset >= minOffset && scrollOffset <= maxOffset) {\n          return scrollOffset;\n        } else if (scrollOffset < minOffset) {\n          return minOffset;\n        } else {\n          return maxOffset;\n        }\n\n    }\n  },\n  getStartIndexForOffset: function getStartIndexForOffset(_ref5, offset) {\n    var itemCount = _ref5.itemCount,\n        itemSize = _ref5.itemSize;\n    return Math.max(0, Math.min(itemCount - 1, Math.floor(offset / itemSize)));\n  },\n  getStopIndexForStartIndex: function getStopIndexForStartIndex(_ref6, startIndex, scrollOffset) {\n    var direction = _ref6.direction,\n        height = _ref6.height,\n        itemCount = _ref6.itemCount,\n        itemSize = _ref6.itemSize,\n        layout = _ref6.layout,\n        width = _ref6.width;\n    // TODO Deprecate direction \"horizontal\"\n    var isHorizontal = direction === 'horizontal' || layout === 'horizontal';\n    var offset = startIndex * itemSize;\n    var size = isHorizontal ? width : height;\n    var numVisibleItems = Math.ceil((size + scrollOffset - offset) / itemSize);\n    return Math.max(0, Math.min(itemCount - 1, startIndex + numVisibleItems - 1 // -1 is because stop index is inclusive\n    ));\n  },\n  initInstanceProps: function initInstanceProps(props) {// Noop\n  },\n  shouldResetStyleCacheOnItemSizeChange: true,\n  validateProps: function validateProps(_ref7) {\n    var itemSize = _ref7.itemSize;\n\n    if (process.env.NODE_ENV !== 'production') {\n      if (typeof itemSize !== 'number') {\n        throw Error('An invalid \"itemSize\" prop has been specified. ' + 'Value should be a number. ' + (\"\\\"\" + (itemSize === null ? 'null' : typeof itemSize) + \"\\\" was specified.\"));\n      }\n    }\n  }\n});\n\n// Pulled from react-compat\n// https://github.com/developit/preact-compat/blob/7c5de00e7c85e2ffd011bf3af02899b63f699d3a/src/index.js#L349\nfunction shallowDiffers(prev, next) {\n  for (var attribute in prev) {\n    if (!(attribute in next)) {\n      return true;\n    }\n  }\n\n  for (var _attribute in next) {\n    if (prev[_attribute] !== next[_attribute]) {\n      return true;\n    }\n  }\n\n  return false;\n}\n\nvar _excluded = [\"style\"],\n    _excluded2 = [\"style\"];\n// It knows to compare individual style props and ignore the wrapper object.\n// See https://reactjs.org/docs/react-api.html#reactmemo\n\nfunction areEqual(prevProps, nextProps) {\n  var prevStyle = prevProps.style,\n      prevRest = _objectWithoutPropertiesLoose(prevProps, _excluded);\n\n  var nextStyle = nextProps.style,\n      nextRest = _objectWithoutPropertiesLoose(nextProps, _excluded2);\n\n  return !shallowDiffers(prevStyle, nextStyle) && !shallowDiffers(prevRest, nextRest);\n}\n\n// It knows to compare individual style props and ignore the wrapper object.\n// See https://reactjs.org/docs/react-component.html#shouldcomponentupdate\n\nfunction shouldComponentUpdate(nextProps, nextState) {\n  return !areEqual(this.props, nextProps) || shallowDiffers(this.state, nextState);\n}\n\nexport { FixedSizeGrid, FixedSizeList, VariableSizeGrid, VariableSizeList, areEqual, shouldComponentUpdate };\n//# sourceMappingURL=index.esm.js.map\n","import { createElement, PureComponent } from 'react';\n\nvar classCallCheck = function (instance, Constructor) {\n  if (!(instance instanceof Constructor)) {\n    throw new TypeError(\"Cannot call a class as a function\");\n  }\n};\n\nvar createClass = function () {\n  function defineProperties(target, props) {\n    for (var i = 0; i < props.length; i++) {\n      var descriptor = props[i];\n      descriptor.enumerable = descriptor.enumerable || false;\n      descriptor.configurable = true;\n      if (\"value\" in descriptor) descriptor.writable = true;\n      Object.defineProperty(target, descriptor.key, descriptor);\n    }\n  }\n\n  return function (Constructor, protoProps, staticProps) {\n    if (protoProps) defineProperties(Constructor.prototype, protoProps);\n    if (staticProps) defineProperties(Constructor, staticProps);\n    return Constructor;\n  };\n}();\n\nvar _extends = Object.assign || function (target) {\n  for (var i = 1; i < arguments.length; i++) {\n    var source = arguments[i];\n\n    for (var key in source) {\n      if (Object.prototype.hasOwnProperty.call(source, key)) {\n        target[key] = source[key];\n      }\n    }\n  }\n\n  return target;\n};\n\nvar inherits = function (subClass, superClass) {\n  if (typeof superClass !== \"function\" && superClass !== null) {\n    throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass);\n  }\n\n  subClass.prototype = Object.create(superClass && superClass.prototype, {\n    constructor: {\n      value: subClass,\n      enumerable: false,\n      writable: true,\n      configurable: true\n    }\n  });\n  if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass;\n};\n\nvar possibleConstructorReturn = function (self, call) {\n  if (!self) {\n    throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n  }\n\n  return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self;\n};\n\nvar slicedToArray = function () {\n  function sliceIterator(arr, i) {\n    var _arr = [];\n    var _n = true;\n    var _d = false;\n    var _e = undefined;\n\n    try {\n      for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {\n        _arr.push(_s.value);\n\n        if (i && _arr.length === i) break;\n      }\n    } catch (err) {\n      _d = true;\n      _e = err;\n    } finally {\n      try {\n        if (!_n && _i[\"return\"]) _i[\"return\"]();\n      } finally {\n        if (_d) throw _e;\n      }\n    }\n\n    return _arr;\n  }\n\n  return function (arr, i) {\n    if (Array.isArray(arr)) {\n      return arr;\n    } else if (Symbol.iterator in Object(arr)) {\n      return sliceIterator(arr, i);\n    } else {\n      throw new TypeError(\"Invalid attempt to destructure non-iterable instance\");\n    }\n  };\n}();\n\n/**\n * Detect Element Resize.\n * https://github.com/sdecima/javascript-detect-element-resize\n * Sebastian Decima\n *\n * Forked from version 0.5.3; includes the following modifications:\n * 1) Guard against unsafe 'window' and 'document' references (to support SSR).\n * 2) Defer initialization code via a top-level function wrapper (to support SSR).\n * 3) Avoid unnecessary reflows by not measuring size for scroll events bubbling from children.\n * 4) Add nonce for style element.\n **/\n\n// Check `document` and `window` in case of server-side rendering\nvar windowObject = void 0;\nif (typeof window !== 'undefined') {\n  windowObject = window;\n\n  // eslint-disable-next-line no-restricted-globals\n} else if (typeof self !== 'undefined') {\n  // eslint-disable-next-line no-restricted-globals\n  windowObject = self;\n} else {\n  windowObject = global;\n}\n\nvar cancelFrame = null;\nvar requestFrame = null;\n\nvar TIMEOUT_DURATION = 20;\n\nvar clearTimeoutFn = windowObject.clearTimeout;\nvar setTimeoutFn = windowObject.setTimeout;\n\nvar cancelAnimationFrameFn = windowObject.cancelAnimationFrame || windowObject.mozCancelAnimationFrame || windowObject.webkitCancelAnimationFrame;\n\nvar requestAnimationFrameFn = windowObject.requestAnimationFrame || windowObject.mozRequestAnimationFrame || windowObject.webkitRequestAnimationFrame;\n\nif (cancelAnimationFrameFn == null || requestAnimationFrameFn == null) {\n  // For environments that don't support animation frame,\n  // fallback to a setTimeout based approach.\n  cancelFrame = clearTimeoutFn;\n  requestFrame = function requestAnimationFrameViaSetTimeout(callback) {\n    return setTimeoutFn(callback, TIMEOUT_DURATION);\n  };\n} else {\n  // Counter intuitively, environments that support animation frames can be trickier.\n  // Chrome's \"Throttle non-visible cross-origin iframes\" flag can prevent rAFs from being called.\n  // In this case, we should fallback to a setTimeout() implementation.\n  cancelFrame = function cancelFrame(_ref) {\n    var _ref2 = slicedToArray(_ref, 2),\n        animationFrameID = _ref2[0],\n        timeoutID = _ref2[1];\n\n    cancelAnimationFrameFn(animationFrameID);\n    clearTimeoutFn(timeoutID);\n  };\n  requestFrame = function requestAnimationFrameWithSetTimeoutFallback(callback) {\n    var animationFrameID = requestAnimationFrameFn(function animationFrameCallback() {\n      clearTimeoutFn(timeoutID);\n      callback();\n    });\n\n    var timeoutID = setTimeoutFn(function timeoutCallback() {\n      cancelAnimationFrameFn(animationFrameID);\n      callback();\n    }, TIMEOUT_DURATION);\n\n    return [animationFrameID, timeoutID];\n  };\n}\n\nfunction createDetectElementResize(nonce) {\n  var animationKeyframes = void 0;\n  var animationName = void 0;\n  var animationStartEvent = void 0;\n  var animationStyle = void 0;\n  var checkTriggers = void 0;\n  var resetTriggers = void 0;\n  var scrollListener = void 0;\n\n  var attachEvent = typeof document !== 'undefined' && document.attachEvent;\n  if (!attachEvent) {\n    resetTriggers = function resetTriggers(element) {\n      var triggers = element.__resizeTriggers__,\n          expand = triggers.firstElementChild,\n          contract = triggers.lastElementChild,\n          expandChild = expand.firstElementChild;\n      contract.scrollLeft = contract.scrollWidth;\n      contract.scrollTop = contract.scrollHeight;\n      expandChild.style.width = expand.offsetWidth + 1 + 'px';\n      expandChild.style.height = expand.offsetHeight + 1 + 'px';\n      expand.scrollLeft = expand.scrollWidth;\n      expand.scrollTop = expand.scrollHeight;\n    };\n\n    checkTriggers = function checkTriggers(element) {\n      return element.offsetWidth !== element.__resizeLast__.width || element.offsetHeight !== element.__resizeLast__.height;\n    };\n\n    scrollListener = function scrollListener(e) {\n      // Don't measure (which forces) reflow for scrolls that happen inside of children!\n      if (e.target.className && typeof e.target.className.indexOf === 'function' && e.target.className.indexOf('contract-trigger') < 0 && e.target.className.indexOf('expand-trigger') < 0) {\n        return;\n      }\n\n      var element = this;\n      resetTriggers(this);\n      if (this.__resizeRAF__) {\n        cancelFrame(this.__resizeRAF__);\n      }\n      this.__resizeRAF__ = requestFrame(function animationFrame() {\n        if (checkTriggers(element)) {\n          element.__resizeLast__.width = element.offsetWidth;\n          element.__resizeLast__.height = element.offsetHeight;\n          element.__resizeListeners__.forEach(function forEachResizeListener(fn) {\n            fn.call(element, e);\n          });\n        }\n      });\n    };\n\n    /* Detect CSS Animations support to detect element display/re-attach */\n    var animation = false;\n    var keyframeprefix = '';\n    animationStartEvent = 'animationstart';\n    var domPrefixes = 'Webkit Moz O ms'.split(' ');\n    var startEvents = 'webkitAnimationStart animationstart oAnimationStart MSAnimationStart'.split(' ');\n    var pfx = '';\n    {\n      var elm = document.createElement('fakeelement');\n      if (elm.style.animationName !== undefined) {\n        animation = true;\n      }\n\n      if (animation === false) {\n        for (var i = 0; i < domPrefixes.length; i++) {\n          if (elm.style[domPrefixes[i] + 'AnimationName'] !== undefined) {\n            pfx = domPrefixes[i];\n            keyframeprefix = '-' + pfx.toLowerCase() + '-';\n            animationStartEvent = startEvents[i];\n            animation = true;\n            break;\n          }\n        }\n      }\n    }\n\n    animationName = 'resizeanim';\n    animationKeyframes = '@' + keyframeprefix + 'keyframes ' + animationName + ' { from { opacity: 0; } to { opacity: 0; } } ';\n    animationStyle = keyframeprefix + 'animation: 1ms ' + animationName + '; ';\n  }\n\n  var createStyles = function createStyles(doc) {\n    if (!doc.getElementById('detectElementResize')) {\n      //opacity:0 works around a chrome bug https://code.google.com/p/chromium/issues/detail?id=286360\n      var css = (animationKeyframes ? animationKeyframes : '') + '.resize-triggers { ' + (animationStyle ? animationStyle : '') + 'visibility: hidden; opacity: 0; } ' + '.resize-triggers, .resize-triggers > div, .contract-trigger:before { content: \" \"; display: block; position: absolute; top: 0; left: 0; height: 100%; width: 100%; overflow: hidden; z-index: -1; } .resize-triggers > div { background: #eee; overflow: auto; } .contract-trigger:before { width: 200%; height: 200%; }',\n          head = doc.head || doc.getElementsByTagName('head')[0],\n          style = doc.createElement('style');\n\n      style.id = 'detectElementResize';\n      style.type = 'text/css';\n\n      if (nonce != null) {\n        style.setAttribute('nonce', nonce);\n      }\n\n      if (style.styleSheet) {\n        style.styleSheet.cssText = css;\n      } else {\n        style.appendChild(doc.createTextNode(css));\n      }\n\n      head.appendChild(style);\n    }\n  };\n\n  var addResizeListener = function addResizeListener(element, fn) {\n    if (attachEvent) {\n      element.attachEvent('onresize', fn);\n    } else {\n      if (!element.__resizeTriggers__) {\n        var doc = element.ownerDocument;\n        var elementStyle = windowObject.getComputedStyle(element);\n        if (elementStyle && elementStyle.position === 'static') {\n          element.style.position = 'relative';\n        }\n        createStyles(doc);\n        element.__resizeLast__ = {};\n        element.__resizeListeners__ = [];\n        (element.__resizeTriggers__ = doc.createElement('div')).className = 'resize-triggers';\n        var expandTrigger = doc.createElement('div');\n        expandTrigger.className = 'expand-trigger';\n        expandTrigger.appendChild(doc.createElement('div'));\n        var contractTrigger = doc.createElement('div');\n        contractTrigger.className = 'contract-trigger';\n        element.__resizeTriggers__.appendChild(expandTrigger);\n        element.__resizeTriggers__.appendChild(contractTrigger);\n        element.appendChild(element.__resizeTriggers__);\n        resetTriggers(element);\n        element.addEventListener('scroll', scrollListener, true);\n\n        /* Listen for a css animation to detect element display/re-attach */\n        if (animationStartEvent) {\n          element.__resizeTriggers__.__animationListener__ = function animationListener(e) {\n            if (e.animationName === animationName) {\n              resetTriggers(element);\n            }\n          };\n          element.__resizeTriggers__.addEventListener(animationStartEvent, element.__resizeTriggers__.__animationListener__);\n        }\n      }\n      element.__resizeListeners__.push(fn);\n    }\n  };\n\n  var removeResizeListener = function removeResizeListener(element, fn) {\n    if (attachEvent) {\n      element.detachEvent('onresize', fn);\n    } else {\n      element.__resizeListeners__.splice(element.__resizeListeners__.indexOf(fn), 1);\n      if (!element.__resizeListeners__.length) {\n        element.removeEventListener('scroll', scrollListener, true);\n        if (element.__resizeTriggers__.__animationListener__) {\n          element.__resizeTriggers__.removeEventListener(animationStartEvent, element.__resizeTriggers__.__animationListener__);\n          element.__resizeTriggers__.__animationListener__ = null;\n        }\n        try {\n          element.__resizeTriggers__ = !element.removeChild(element.__resizeTriggers__);\n        } catch (e) {\n          // Preact compat; see developit/preact-compat/issues/228\n        }\n      }\n    }\n  };\n\n  return {\n    addResizeListener: addResizeListener,\n    removeResizeListener: removeResizeListener\n  };\n}\n\nvar AutoSizer = function (_React$PureComponent) {\n  inherits(AutoSizer, _React$PureComponent);\n\n  function AutoSizer() {\n    var _ref;\n\n    var _temp, _this, _ret;\n\n    classCallCheck(this, AutoSizer);\n\n    for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    return _ret = (_temp = (_this = possibleConstructorReturn(this, (_ref = AutoSizer.__proto__ || Object.getPrototypeOf(AutoSizer)).call.apply(_ref, [this].concat(args))), _this), _this.state = {\n      height: _this.props.defaultHeight || 0,\n      width: _this.props.defaultWidth || 0\n    }, _this._onResize = function () {\n      var _this$props = _this.props,\n          disableHeight = _this$props.disableHeight,\n          disableWidth = _this$props.disableWidth,\n          onResize = _this$props.onResize;\n\n\n      if (_this._parentNode) {\n        // Guard against AutoSizer component being removed from the DOM immediately after being added.\n        // This can result in invalid style values which can result in NaN values if we don't handle them.\n        // See issue #150 for more context.\n\n        var _height = _this._parentNode.offsetHeight || 0;\n        var _width = _this._parentNode.offsetWidth || 0;\n\n        var _style = window.getComputedStyle(_this._parentNode) || {};\n        var paddingLeft = parseInt(_style.paddingLeft, 10) || 0;\n        var paddingRight = parseInt(_style.paddingRight, 10) || 0;\n        var paddingTop = parseInt(_style.paddingTop, 10) || 0;\n        var paddingBottom = parseInt(_style.paddingBottom, 10) || 0;\n\n        var newHeight = _height - paddingTop - paddingBottom;\n        var newWidth = _width - paddingLeft - paddingRight;\n\n        if (!disableHeight && _this.state.height !== newHeight || !disableWidth && _this.state.width !== newWidth) {\n          _this.setState({\n            height: _height - paddingTop - paddingBottom,\n            width: _width - paddingLeft - paddingRight\n          });\n\n          onResize({ height: _height, width: _width });\n        }\n      }\n    }, _this._setRef = function (autoSizer) {\n      _this._autoSizer = autoSizer;\n    }, _temp), possibleConstructorReturn(_this, _ret);\n  }\n\n  createClass(AutoSizer, [{\n    key: 'componentDidMount',\n    value: function componentDidMount() {\n      var nonce = this.props.nonce;\n\n      if (this._autoSizer && this._autoSizer.parentNode && this._autoSizer.parentNode.ownerDocument && this._autoSizer.parentNode.ownerDocument.defaultView && this._autoSizer.parentNode instanceof this._autoSizer.parentNode.ownerDocument.defaultView.HTMLElement) {\n        // Delay access of parentNode until mount.\n        // This handles edge-cases where the component has already been unmounted before its ref has been set,\n        // As well as libraries like react-lite which have a slightly different lifecycle.\n        this._parentNode = this._autoSizer.parentNode;\n\n        // Defer requiring resize handler in order to support server-side rendering.\n        // See issue #41\n        this._detectElementResize = createDetectElementResize(nonce);\n        this._detectElementResize.addResizeListener(this._parentNode, this._onResize);\n\n        this._onResize();\n      }\n    }\n  }, {\n    key: 'componentWillUnmount',\n    value: function componentWillUnmount() {\n      if (this._detectElementResize && this._parentNode) {\n        this._detectElementResize.removeResizeListener(this._parentNode, this._onResize);\n      }\n    }\n  }, {\n    key: 'render',\n    value: function render() {\n      var _props = this.props,\n          children = _props.children,\n          className = _props.className,\n          disableHeight = _props.disableHeight,\n          disableWidth = _props.disableWidth,\n          style = _props.style;\n      var _state = this.state,\n          height = _state.height,\n          width = _state.width;\n\n      // Outer div should not force width/height since that may prevent containers from shrinking.\n      // Inner component should overflow and use calculated width/height.\n      // See issue #68 for more information.\n\n      var outerStyle = { overflow: 'visible' };\n      var childParams = {};\n\n      // Avoid rendering children before the initial measurements have been collected.\n      // At best this would just be wasting cycles.\n      var bailoutOnChildren = false;\n\n      if (!disableHeight) {\n        if (height === 0) {\n          bailoutOnChildren = true;\n        }\n        outerStyle.height = 0;\n        childParams.height = height;\n      }\n\n      if (!disableWidth) {\n        if (width === 0) {\n          bailoutOnChildren = true;\n        }\n        outerStyle.width = 0;\n        childParams.width = width;\n      }\n\n      return createElement(\n        'div',\n        {\n          className: className,\n          ref: this._setRef,\n          style: _extends({}, outerStyle, style)\n        },\n        !bailoutOnChildren && children(childParams)\n      );\n    }\n  }]);\n  return AutoSizer;\n}(PureComponent);\n\nAutoSizer.defaultProps = {\n  onResize: function onResize() {},\n  disableHeight: false,\n  disableWidth: false,\n  style: {}\n};\n\nexport default AutoSizer;\n","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { Fragment, createElement, Component, useEffect, useRef, useState } from '@wordpress/element';\nimport classnames from 'classnames';\nimport { getDefaultFonts } from './default-data';\nimport { familyForDisplay, humanizeVariations, fontFamilyToCSSFamily } from './helpers';\nimport { FixedSizeList as List } from 'react-window';\nimport WebFontLoader from 'webfontloader';\nimport AutoSizer from 'react-virtualized-auto-sizer';\nlet loadedFonts = [];\n\nconst loadGoogleFonts = font_families => {\n  if (font_families.length === 0) return;\n  loadedFonts = [...loadedFonts, ...font_families.map(_ref => {\n    let {\n      family\n    } = _ref;\n    return family;\n  })];\n  const googleFonts = font_families.map(_ref2 => {\n    let {\n      family\n    } = _ref2;\n    return family;\n  }).filter(family => family.indexOf('ct_typekit') === -1);\n  const typekitFonts = font_families.filter(_ref3 => {\n    let {\n      family\n    } = _ref3;\n    return family.indexOf('ct_typekit') > -1;\n  });\n\n  if (googleFonts.length > 0 || typekitFonts.length > 0) {\n    WebFontLoader.load(_objectSpread(_objectSpread(_objectSpread({}, googleFonts.length > 0 ? {\n      google: {\n        families: googleFonts\n      }\n    } : {}), typekitFonts.length > 0 ? {\n      typekit: {\n        id: typekitFonts[0].kit\n      }\n    } : {}), {}, {\n      classes: false,\n      text: 'abcdefghijklmnopqrstuvwxyz'\n    }));\n  }\n};\n\nconst SingleFont = _ref4 => {\n  let {\n    data: {\n      linearFontsList,\n      onPickFamily,\n      value\n    },\n    index,\n    style\n  } = _ref4;\n  const family = linearFontsList[index];\n  return createElement(\"div\", {\n    style: style,\n    onClick: () => onPickFamily(family),\n    className: classnames('ct-typography-single-font', `ct-${family.source}`, {\n      active: family.family === value.family\n    }),\n    key: family.family\n  }, createElement(\"span\", {\n    className: \"ct-font-name\"\n  }, familyForDisplay(family.display || family.family)), createElement(\"span\", {\n    style: {\n      fontFamily: fontFamilyToCSSFamily(family.family)\n    },\n    className: \"ct-font-preview\"\n  }, \"Simply dummy text\"));\n};\n\nconst FontsList = _ref5 => {\n  let {\n    option,\n    value,\n    onPickFamily,\n    typographyList,\n    linearFontsList,\n    currentView,\n    searchTerm\n  } = _ref5;\n  const listRef = useRef(null);\n  const timerRef = useRef(null);\n  const [scrollTimer, setScrollTimer] = useState(null);\n  useEffect(() => {\n    if (value.family) {\n      listRef.current.scrollToItem(linearFontsList.map(_ref6 => {\n        let {\n          family\n        } = _ref6;\n        return family;\n      }).indexOf(value.family), 'start');\n    }\n  }, []);\n\n  const onScroll = () => {\n    scrollTimer && clearTimeout(scrollTimer);\n    setScrollTimer(setTimeout(() => {\n      if (!listRef.current) {\n        return;\n      }\n\n      const [overscanStartIndex] = listRef.current._getRangeToRender();\n\n      const perPage = 25;\n      const totalPages = Math.ceil(linearFontsList.length / perPage);\n      const startingPage = Math.ceil((overscanStartIndex + 1) / perPage); // const stopPage = Math.ceil((overscanStopIndex + 1) / perPage)\n\n      const pageItems = [...Array(perPage)].map((_, i) => (startingPage - 1) * perPage + i).map(index => linearFontsList[index]).filter(s => !!s).filter(_ref7 => {\n        let {\n          source,\n          family\n        } = _ref7;\n        return loadedFonts.indexOf(family) === -1 && (source === 'google' || source === 'typekit');\n      });\n      loadGoogleFonts(pageItems);\n    }, 100));\n  };\n\n  useEffect(() => {\n    onScroll();\n  }, [linearFontsList]);\n  return createElement(List, {\n    height: 360,\n    itemCount: linearFontsList.length,\n    itemSize: 85,\n    ref: listRef,\n    onScroll: e => {\n      onScroll();\n    },\n    itemData: {\n      linearFontsList,\n      onPickFamily,\n      value\n    },\n    onItemsRendered: _ref8 => {\n      let {\n        overscanStartIndex,\n        overscanStopIndex\n      } = _ref8;\n    },\n    className: \"ct-typography-fonts\"\n  }, SingleFont);\n};\n\nexport default FontsList;","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { Fragment, createElement, Component, useRef, useEffect, useState } from '@wordpress/element';\nimport classnames from 'classnames';\nimport { getDefaultFonts } from './default-data';\nimport { humanizeVariations, findSelectedFontFamily } from './helpers';\nimport { animated } from '@react-spring/web';\n\nconst VariationsList = _ref => {\n  let {\n    option,\n    value,\n    onChange,\n    typographyList,\n    props\n  } = _ref;\n  const selectedFontFamily = findSelectedFontFamily(value.family, typographyList);\n  const parentEl = useRef(null);\n  useEffect(() => {\n    if (!selectedFontFamily) {\n      return;\n    }\n\n    parentEl.current.scrollTop = (parentEl.current.children[selectedFontFamily.all_variations.indexOf(value.variation)] || parentEl.current.children[0]).offsetTop - parentEl.current.offsetTop;\n  }, [selectedFontFamily]);\n  return createElement(animated.ul, {\n    style: props,\n    className: \"ct-typography-variations\",\n    ref: parentEl\n  }, selectedFontFamily && selectedFontFamily.all_variations.map(variation => createElement(\"li\", {\n    onClick: () => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      variation\n    })),\n    className: classnames({\n      active: variation === value.variation\n    }),\n    key: variation\n  }, createElement(\"span\", {\n    className: \"ct-variation-name\",\n    \"data-variation\": variation\n  }, humanizeVariations(variation)))));\n};\n\nexport default VariationsList;","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { Fragment, createElement, Component, useRef, useEffect, useState } from '@wordpress/element';\nimport classnames from 'classnames';\nimport { __ } from 'ct-i18n';\nimport { animated } from '@react-spring/web';\nimport GenericOptionType from '../../GenericOptionType';\n\nconst FontOptions = _ref => {\n  let {\n    option,\n    value,\n    sizeRef,\n    onChange,\n    props\n  } = _ref;\n  return createElement(animated.ul, {\n    style: props,\n    className: \"ct-typography-options\",\n    key: \"options\"\n  }, createElement(\"li\", {\n    key: \"size\"\n  }, createElement(GenericOptionType, {\n    value: value.size,\n    values: value,\n    id: \"size\",\n    option: {\n      id: 'size',\n      label: __('Font Size', 'blocksy'),\n      type: 'ct-slider',\n      value: option.value.size,\n      ref: sizeRef,\n      responsive: option.typography_responsive || true,\n      units: [{\n        unit: 'px',\n        min: 0,\n        max: 200\n      }, {\n        unit: 'em',\n        min: 0,\n        max: 50\n      }, {\n        unit: 'rem',\n        min: 0,\n        max: 50\n      }, {\n        unit: 'pt',\n        min: 0,\n        max: 50\n      }, {\n        unit: 'vw',\n        min: 0,\n        max: 100\n      }]\n    },\n    hasRevertButton: true,\n    onChange: newValue => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      size: newValue\n    }))\n  })), createElement(\"li\", {\n    key: \"line-height\"\n  }, createElement(GenericOptionType, {\n    value: value['line-height'],\n    values: value,\n    id: \"line-height\",\n    option: {\n      id: 'line-height',\n      label: __('Line Height', 'blocksy'),\n      type: 'ct-slider',\n      value: option.value['line-height'],\n      responsive: option.typography_responsive || true,\n      units: [{\n        unit: '',\n        min: 0,\n        max: 10,\n        decimals: 1\n      }, {\n        unit: 'px',\n        min: 0,\n        max: 100\n      }, {\n        unit: 'em',\n        min: 0,\n        max: 100\n      }, {\n        unit: 'pt',\n        min: 0,\n        max: 100\n      }, {\n        unit: '%',\n        min: 0,\n        max: 100\n      }]\n    },\n    hasRevertButton: true,\n    onChange: newValue => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      'line-height': newValue\n    }))\n  })), createElement(\"li\", {\n    key: \"letter-spacing\"\n  }, createElement(GenericOptionType, {\n    value: value['letter-spacing'],\n    values: value,\n    id: \"letter-spacing\",\n    option: {\n      id: 'letter-spacing',\n      label: __('Letter Spacing', 'blocksy'),\n      type: 'ct-slider',\n      value: option.value['letter-spacing'],\n      responsive: option.typography_responsive || true,\n      defaultPosition: 'center',\n      units: [{\n        unit: 'em',\n        min: -5,\n        max: 5,\n        decimals: 1\n      }, {\n        unit: 'px',\n        min: -20,\n        max: 20,\n        decimals: 1\n      }, {\n        unit: 'rem',\n        min: -5,\n        max: 5,\n        decimals: 1\n      }]\n    },\n    hasRevertButton: true,\n    onChange: newValue => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      'letter-spacing': newValue\n    }))\n  })), createElement(\"li\", {\n    key: \"variant\",\n    className: \"ct-typography-variant\"\n  }, createElement(\"ul\", {\n    className: classnames('ct-text-transform')\n  }, ['capitalize', 'uppercase'].map(variant => createElement(\"li\", {\n    key: variant,\n    onClick: () => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      'text-transform': value['text-transform'] === variant ? 'none' : variant\n    })),\n    className: classnames({\n      active: variant === value['text-transform']\n    }),\n    \"data-variant\": variant\n  }, createElement(\"i\", {\n    className: \"ct-tooltip-top\"\n  }, {\n    capitalize: __('Capitalize', 'blocksy'),\n    uppercase: __('Uppercase', 'blocksy')\n  }[variant])))), createElement(\"ul\", {\n    className: classnames('ct-text-decoration')\n  }, ['line-through', 'underline'].map(variant => createElement(\"li\", {\n    key: variant,\n    onClick: () => onChange(_objectSpread(_objectSpread({}, value), {}, {\n      'text-decoration': value['text-decoration'] === variant ? 'none' : variant\n    })),\n    className: classnames({\n      active: variant === value['text-decoration']\n    }),\n    \"data-variant\": variant\n  }, createElement(\"i\", {\n    className: \"ct-tooltip-top\"\n  }, {\n    'line-through': __('Line Through', 'blocksy'),\n    underline: __('Underline', 'blocksy')\n  }[variant]))))));\n};\n\nexport default FontOptions;","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { Fragment, createElement, Component, useRef, useEffect, useMemo, useCallback, useState } from '@wordpress/element';\nimport classnames from 'classnames';\nimport { getDefaultFonts } from './default-data';\nimport { humanizeVariationsShort, decideVariationToSelect, familyForDisplay } from './helpers';\nimport { __ } from 'ct-i18n';\nimport bezierEasing from 'bezier-easing';\nimport { Transition, animated } from '@react-spring/web';\nimport FontsList from './FontsList';\nimport VariationsList from './VariationsList';\nimport FontOptions from './FontOptions';\nimport GenericOptionType from '../../GenericOptionType';\n\nconst combineRefs = function () {\n  for (var _len = arguments.length, refs = new Array(_len), _key = 0; _key < _len; _key++) {\n    refs[_key] = arguments[_key];\n  }\n\n  return el => {\n    refs.map(ref => {\n      if (typeof ref === 'function') {\n        ref(el);\n      } else if (typeof ref === 'object' && ref !== null && ref.hasOwnProperty('current')) {\n        ref.current = el;\n      } else if (ref === null) {// No-op\n      }\n    });\n  };\n};\n\nfunction fuzzysearch(needle, haystack) {\n  var hlen = haystack.length;\n  var nlen = needle.length;\n\n  if (nlen > hlen) {\n    return false;\n  }\n\n  if (nlen === hlen) {\n    return needle === haystack;\n  }\n\n  outer: for (var i = 0, j = 0; i < nlen; i++) {\n    var nch = needle.charCodeAt(i);\n\n    while (j < hlen) {\n      if (haystack.charCodeAt(j++) === nch) {\n        continue outer;\n      }\n    }\n\n    return false;\n  }\n\n  return true;\n}\n\nconst TypographyModal = _ref => {\n  let {\n    option,\n    value,\n    initialView,\n    currentView,\n    previousView,\n    setCurrentView,\n    setInititialView,\n    onChange,\n    wrapperProps = {}\n  } = _ref;\n  const [typographyList, setTypographyList] = useState(getDefaultFonts(option));\n  const [isSearch, setIsSearch] = useState(false);\n  const [searchTerm, setSearchTerm] = useState('');\n  const direction = useMemo(() => {\n    if (previousView === '_') {\n      return 'static';\n    }\n\n    if (currentView === 'search' && previousView === 'fonts' || previousView === 'search' && currentView === 'fonts') {\n      return 'static';\n    }\n\n    if (previousView === 'options') {\n      return 'right';\n    }\n\n    if (previousView === 'fonts' && currentView === 'variations') {\n      return 'right';\n    }\n\n    return 'left';\n  }, [currentView, previousView]);\n  const inputEl = useRef(null);\n  const sizeEl = useRef(null);\n  const linearFontsList = Object.keys(typographyList).reduce((currentList, currentSource) => [...currentList, ...(typographyList[currentSource].families || []).filter(_ref2 => {\n    let {\n      family\n    } = _ref2;\n    return fuzzysearch(searchTerm.toLowerCase(), family.toLowerCase());\n  })], []);\n\n  const fetchFontsList = async () => {\n    const body = new FormData();\n    body.append('action', 'blocksy_get_fonts_list');\n\n    try {\n      const response = await fetch(ajaxurl, {\n        method: 'POST',\n        body\n      });\n\n      if (response.status === 200) {\n        const {\n          success,\n          data\n        } = await response.json();\n\n        if (success) {\n          setTypographyList(_objectSpread(_objectSpread({}, data.fonts), {}, {\n            system: _objectSpread(_objectSpread({}, data.fonts.system), {}, {\n              families: [...(option.isDefault ? [] : [{\n                source: 'system',\n                family: 'Default',\n                variations: [],\n                all_variations: ['Default', 'n1', 'i1', 'n2', 'i2', 'n3', 'i3', 'n4', 'i4', 'n5', 'i5', 'n6', 'i6', 'n7', 'i7', 'n8', 'i8', 'n9', 'i9']\n              }]), ...data.fonts.system.families]\n            })\n          }));\n        }\n      }\n    } catch (e) {}\n  };\n\n  useEffect(() => {\n    if (initialView && initialView !== 'done') {\n      setSearchTerm('');\n      setTimeout(() => {// setInititialView('done')\n      });\n    }\n\n    if (initialView === 'font_size') {\n      setTimeout(() => sizeEl.current && sizeEl.current.focus(), 100);\n    }\n  }, [initialView]);\n  useEffect(() => {\n    fetchFontsList();\n  }, []);\n  useEffect(() => {\n    if (currentView === 'search') {\n      inputEl.current.focus();\n    }\n  }, [currentView]);\n\n  const pickFontFamily = family => {\n    onChange(_objectSpread(_objectSpread({}, value), {}, {\n      family: family.family,\n      variation: decideVariationToSelect(family, value)\n    }));\n  };\n\n  return createElement(animated.div, _extends({\n    className: \"ct-option-modal ct-typography-modal\"\n  }, wrapperProps), createElement(\"div\", {\n    className: \"ct-typography-container\"\n  }, createElement(\"ul\", {\n    className: classnames('ct-typography-top', {\n      'ct-switch-panel': currentView !== 'options',\n      'ct-static': previousView === '_'\n    })\n  }, createElement(\"li\", {\n    className: \"ct-back\",\n    onClick: () => setCurrentView('options')\n  }, createElement(\"svg\", {\n    width: \"10\",\n    height: \"10\",\n    viewBox: \"0 0 15 15\"\n  }, createElement(\"path\", {\n    d: \"M14.2,6.8H2.6l4-4c0.3-0.3,0.3-0.8,0-1.1c-0.3-0.3-0.8-0.3-1.1,0L0.2,7l0,0c0,0-0.1,0.1-0.1,0.1c0,0,0,0,0,0.1c0,0,0,0,0,0.1c0,0,0,0.1,0,0.1c0,0,0,0,0,0.1c0,0,0,0.1,0,0.1l0,0c0,0,0,0,0,0c0,0,0,0.1,0,0.1c0,0,0,0,0,0.1c0,0,0,0.1,0,0.1c0,0,0,0,0,0.1c0,0,0,0,0,0.1C0.2,8,0.2,8,0.2,8l5.3,5.3c0.3,0.3,0.8,0.3,1.1,0c0.3-0.3,0.3-0.8,0-1.1l-4-4h11.7c0.4,0,0.8-0.3,0.8-0.8S14.7,6.8,14.2,6.8z\"\n  }))), createElement(\"li\", {\n    className: classnames('ct-font', {\n      active: currentView === 'search' || currentView === 'fonts'\n    }),\n    onClick: () => {\n      setCurrentView(currentView === 'fonts' ? 'search' : 'fonts');\n      setSearchTerm('');\n    }\n  }, currentView !== 'search' && createElement(\"span\", null, familyForDisplay(value.family)), currentView === 'search' && createElement(\"input\", {\n    onClick: e => e.stopPropagation(),\n    ref: inputEl,\n    autoFocus: true,\n    value: searchTerm,\n    onKeyUp: e => {\n      if (e.keyCode == 13) {\n        if (linearFontsList.length > 0) {\n          pickFontFamily(linearFontsList[0]);\n          setCurrentView('options');\n          setSearchTerm('');\n        }\n      }\n    },\n    onChange: _ref3 => {\n      let {\n        target: {\n          value\n        }\n      } = _ref3;\n      return setSearchTerm(value);\n    }\n  }), createElement(\"svg\", {\n    width: \"8\",\n    height: \"8\",\n    viewBox: \"0 0 15 15\"\n  }, currentView === 'search' && createElement(\"path\", {\n    d: \"M8.9,7.5l4.6-4.6c0.4-0.4,0.4-1,0-1.4c-0.4-0.4-1-0.4-1.4,0L7.5,6.1L2.9,1.5c-0.4-0.4-1-0.4-1.4,0c-0.4,0.4-0.4,1,0,1.4l4.6,4.6l-4.6,4.6c-0.4,0.4-0.4,1,0,1.4c0.4,0.4,1,0.4,1.4,0l4.6-4.6l4.6,4.6c0.4,0.4,1,0.4,1.4,0c0.4-0.4,0.4-1,0-1.4L8.9,7.5z\"\n  }), currentView !== 'search' && createElement(\"path\", {\n    d: \"M14.6,14.6c-0.6,0.6-1.4,0.6-2,0l-2.5-2.5c-1,0.7-2.2,1-3.5,1C2.9,13.1,0,10.2,0,6.6S2.9,0,6.6,0c3.6,0,6.6,2.9,6.6,6.6c0,1.3-0.4,2.5-1,3.5l2.5,2.5C15.1,13.1,15.1,14,14.6,14.6z M6.6,1.9C4,1.9,1.9,4,1.9,6.6s2.1,4.7,4.7,4.7c2.6,0,4.7-2.1,4.7-4.7C11.3,4,9.2,1.9,6.6,1.9z\"\n  }))), createElement(\"li\", {\n    className: classnames('ct-weight', {\n      active: currentView === 'variations'\n    }),\n    onClick: () => setCurrentView('variations')\n  }, createElement(\"span\", {\n    \"data-variation\": value.variation\n  }, humanizeVariationsShort(value.variation)))), createElement(Transition, {\n    items: currentView,\n    immediate: direction === 'static',\n    config: (item, type) => ({\n      duration: 210,\n      easing: bezierEasing(0.455, 0.03, 0.515, 0.955)\n    }),\n    from: {\n      transform: direction === 'left' ? 'translateX(100%)' : 'translateX(-100%)',\n      position: 'absolute'\n    },\n    enter: {\n      transform: 'translateX(0%)',\n      position: 'absolute'\n    },\n    leave: {\n      position: 'absolute',\n      transform: direction === 'left' ? 'translateX(-100%)' : 'translateX(100%)'\n    }\n  }, (props, currentView, transition, key) => {\n    if (currentView === 'options') {\n      return createElement(FontOptions, {\n        sizeRef: sizeEl,\n        value: value,\n        option: option,\n        onChange: onChange,\n        props: props,\n        currentView: currentView\n      });\n    }\n\n    if (currentView === 'fonts' || currentView === 'search') {\n      return createElement(animated.div, {\n        style: props,\n        key: currentView\n      }, createElement(FontsList, {\n        typographyList: typographyList,\n        searchTerm: searchTerm,\n        linearFontsList: linearFontsList,\n        currentView: `${currentView}:${previousView}`,\n        onPickFamily: family => {\n          pickFontFamily(family); // setCurrentView('options')\n          // setSearchTerm('')\n        },\n        value: value\n      }));\n    }\n\n    if (currentView === 'variations') {\n      return createElement(VariationsList, {\n        currentView: currentView,\n        props: props,\n        typographyList: typographyList,\n        onChange: value => {\n          onChange(value); // setCurrentView('options')\n        },\n        value: value\n      });\n    }\n  })));\n};\n\nexport default TypographyModal;","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { Fragment, createElement, createPortal, Component, useRef, useReducer, useEffect, useMemo, useCallback, useState } from '@wordpress/element';\nimport classnames from 'classnames';\nimport TypographyModal from './typography/TypographyModal';\nimport OutsideClickHandler from './react-outside-click-handler';\nimport { humanizeVariations, familyForDisplay } from './typography/helpers';\nimport { maybePromoteScalarValueIntoResponsive } from '../../customizer/components/responsive-controls';\nimport usePopoverMaker from '../helpers/usePopoverMaker';\nimport { Transition } from '@react-spring/web';\nimport bezierEasing from 'bezier-easing';\nimport { __ } from 'ct-i18n';\n\nconst getLeftForEl = (modal, el) => {\n  if (!modal) return;\n  if (!el) return;\n  let style = getComputedStyle(modal);\n  let wrapperLeft = parseFloat(style.left);\n  el = el.getBoundingClientRect();\n  return {\n    '--option-modal-arrow-position': `${el.left + el.width / 2 - wrapperLeft - 6}px`\n  };\n};\n\nconst Typography = _ref => {\n  let {\n    option: {\n      label = '',\n      desc = '',\n      attr = {}\n    },\n    option,\n    value,\n    device,\n    onChange\n  } = _ref;\n  // const [isOpen, setIsOpen] = useState(false)\n  // options | fonts | variations | search\n  const [currentViewCache, setCurrentViewCache] = useState('_:_');\n  const typographyWrapper = useRef();\n  let [currentView, previousView] = useMemo(() => currentViewCache.split(':'), [currentViewCache]);\n  const setCurrentView = useCallback(newView => setCurrentViewCache(`${newView}:${currentView}`), [currentView]);\n  const [{\n    isOpen,\n    isTransitioning\n  }, setModalState] = useState({\n    isOpen: false,\n    isTransitioning: false\n  });\n  const {\n    styles,\n    popoverProps\n  } = usePopoverMaker({\n    ref: typographyWrapper,\n    defaultHeight: 430,\n    shouldCalculate: isTransitioning || isOpen\n  });\n\n  const setIsOpen = isOpen => {\n    setModalState(state => _objectSpread(_objectSpread({}, state), {}, {\n      isOpen,\n      isTransitioning: true\n    }));\n  };\n\n  const stopTransitioning = () => setModalState(state => _objectSpread(_objectSpread({}, state), {}, {\n    isTransitioning: false\n  }));\n\n  const fontFamilyRef = useRef();\n  const fontSizeRef = useRef();\n  const fontWeightRef = useRef();\n  const dotsRef = useRef();\n  const arrowLeft = useMemo(() => {\n    const view = currentView;\n    const futureRef = view === 'options' ? fontSizeRef.current : view === 'fonts' ? fontFamilyRef.current : view === 'variations' ? fontWeightRef.current : fontSizeRef.current;\n    return popoverProps.ref && popoverProps.ref.current && getLeftForEl(popoverProps.ref.current, futureRef);\n  }, [isOpen, currentView, popoverProps.ref, popoverProps.ref && popoverProps.ref.current, fontFamilyRef && fontFamilyRef.current, fontWeightRef && fontWeightRef.current, fontSizeRef && fontSizeRef.current, dotsRef && dotsRef.current]);\n  return createElement(\"div\", {\n    className: classnames('ct-typography', {})\n  }, createElement(OutsideClickHandler, {\n    disabled: !isOpen,\n    useCapture: false,\n    className: \"ct-typohraphy-value\",\n    additionalRefs: [popoverProps.ref],\n    onOutsideClick: () => {\n      setIsOpen(false);\n    },\n    wrapperProps: {\n      ref: typographyWrapper,\n      onClick: e => {\n        e.preventDefault();\n\n        if (isOpen) {\n          setCurrentView('options');\n          return;\n        }\n\n        setCurrentViewCache('options:_');\n        setIsOpen('options');\n      }\n    }\n  }, createElement(\"div\", null, createElement(\"span\", {\n    onClick: e => {\n      e.stopPropagation();\n\n      if (isOpen) {\n        setCurrentView('fonts');\n        return;\n      }\n\n      setCurrentViewCache('fonts:_');\n      setIsOpen('fonts');\n    },\n    className: \"ct-font\",\n    ref: fontFamilyRef\n  }, createElement(\"span\", null, value.family === 'Default' ? __('Default Family', 'blocksy') : familyForDisplay(value.family))), createElement(\"i\", null, \"/\"), createElement(\"span\", {\n    onClick: e => {\n      e.stopPropagation();\n\n      if (isOpen) {\n        setCurrentView('options');\n        return;\n      }\n\n      setCurrentViewCache('options:_');\n      setIsOpen('font_size');\n    },\n    ref: fontSizeRef,\n    className: \"ct-size\"\n  }, createElement(\"span\", null, maybePromoteScalarValueIntoResponsive(value['size'])[device] === 'CT_CSS_SKIP_RULE' ? __('Default Size', 'blocksy') : maybePromoteScalarValueIntoResponsive(value['size'])[device])), createElement(\"i\", null, \"/\"), createElement(\"span\", {\n    ref: fontWeightRef,\n    onClick: e => {\n      e.stopPropagation();\n\n      if (isOpen) {\n        setCurrentView('variations');\n        return;\n      }\n\n      setCurrentViewCache('variations:_');\n      setIsOpen('variations');\n    },\n    className: \"ct-weight\"\n  }, createElement(\"span\", null, humanizeVariations(value.variation)))), createElement(\"a\", {\n    ref: dotsRef\n  })), (isTransitioning || isOpen) && createPortal(createElement(Transition, {\n    items: isOpen,\n    onRest: isOpen => {\n      stopTransitioning();\n    },\n    config: {\n      duration: 100,\n      easing: bezierEasing(0.25, 0.1, 0.25, 1.0)\n    },\n    from: isOpen ? {\n      transform: 'scale3d(0.95, 0.95, 1)',\n      opacity: 0\n    } : {\n      opacity: 1\n    },\n    enter: isOpen ? {\n      transform: 'scale3d(1, 1, 1)',\n      opacity: 1\n    } : {\n      opacity: 1\n    },\n    leave: !isOpen ? {\n      transform: 'scale3d(0.95, 0.95, 1)',\n      opacity: 0\n    } : {\n      opacity: 1\n    }\n  }, (style, item) => {\n    if (!item) {\n      return null;\n    }\n\n    return createElement(TypographyModal, {\n      wrapperProps: _objectSpread({\n        style: _objectSpread(_objectSpread(_objectSpread({}, style), styles), arrowLeft)\n      }, popoverProps),\n      onChange: onChange,\n      value: value,\n      option: option,\n      initialView: item,\n      setInititialView: initialView => setIsOpen(initialView),\n      currentView: currentView,\n      previousView: previousView,\n      setCurrentView: setCurrentView\n    });\n    /*\n    isOpen &&\n    ((props) => (\n    \t<TypographyModal\n    \t\twrapperProps={{\n    \t\t\tstyle: {\n    \t\t\t\t...props,\n    \t\t\t\t...styles,\n    \t\t\t\t...arrowLeft,\n    \t\t\t},\n    \t\t\t...popoverProps,\n    \t\t}}\n    \t\tonChange={onChange}\n    \t\tvalue={value}\n    \t\toption={option}\n    \t\tinitialView={isOpen}\n    \t\tsetInititialView={(initialView) =>\n    \t\t\tsetIsOpen(initialView)\n    \t\t}\n    \t\tcurrentView={currentView}\n    \t\tpreviousView={previousView}\n    \t\tsetCurrentView={setCurrentView}\n    \t/>\n    ))\n                         */\n  }), document.body));\n};\n\nexport default Typography;"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///5183\n")},5138:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _helpers_parse_choices_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(4592);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(4184);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var react_spring_renderprops__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(4823);\n/* harmony import */ var bezier_easing__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(3431);\n/* harmony import */ var bezier_easing__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(bezier_easing__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _react_outside_click_handler__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(8204);\n/* harmony import */ var ct_i18n__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(5652);\n/* harmony import */ var ct_i18n__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(ct_i18n__WEBPACK_IMPORTED_MODULE_4__);\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\n\n\nconst InlineVisibility = _ref => {\n let {\n option,\n value,\n onChange\n } = _ref;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"ul\", _extends({\n className: \"ct-visibility-option ct-devices ct-buttons-group\"\n }, option.attr || {}), (0,_helpers_parse_choices_js__WEBPACK_IMPORTED_MODULE_5__/* .maybeTransformUnorderedChoices */ .N)(option.choices).map(_ref2 => {\n let {\n key,\n value: val\n } = _ref2;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"li\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()({\n active: value[key]\n }, `ct-${key}`),\n onClick: () => onChange(_objectSpread(_objectSpread({}, value), {}, {\n [key]: value[key] ? Object.values(value).filter(v => v).length === 1 && !option.allow_empty ? true : false : true\n })),\n key: key\n });\n }));\n};\n\nconst VisibilityModal = _ref3 => {\n let {\n option,\n value,\n onChange\n } = _ref3;\n const [{\n isPicking,\n isTransitioning\n }, setAnimationState] = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useState)({\n isPicking: null,\n isTransitioning: null\n });\n\n const stopTransitioning = () => setAnimationState({\n isPicking,\n isTransitioning: false\n });\n\n const el = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useRef)();\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_react_outside_click_handler__WEBPACK_IMPORTED_MODULE_3__[\"default\"], {\n useCapture: false,\n disabled: !isPicking,\n className: \"ct-visibility-trigger\",\n additionalRefs: [],\n onOutsideClick: () => {\n if (!isPicking) {\n return;\n }\n\n setAnimationState({\n isTransitioning: true,\n isPicking: null\n });\n },\n wrapperProps: {\n ref: el,\n onClick: e => {\n e.preventDefault();\n setAnimationState({\n isTransitioning: true,\n isPicking: true\n });\n }\n }\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"span\", null, \"open visibility\")), (isTransitioning || isPicking) && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createPortal)((0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(react_spring_renderprops__WEBPACK_IMPORTED_MODULE_6__/* .Transition */ .uT, {\n items: isPicking,\n onRest: isOpen => {\n stopTransitioning();\n },\n config: {\n duration: 100,\n easing: bezier_easing__WEBPACK_IMPORTED_MODULE_2___default()(0.25, 0.1, 0.25, 1.0)\n },\n from: isPicking ? {\n transform: 'scale3d(0.95, 0.95, 1)',\n opacity: 0\n } : {\n opacity: 1\n },\n enter: isPicking ? {\n transform: 'scale3d(1, 1, 1)',\n opacity: 1\n } : {\n opacity: 1\n },\n leave: isPicking ? {\n transform: 'scale3d(0.95, 0.95, 1)',\n opacity: 0\n } : {\n opacity: 1\n }\n }, isPicking => isPicking && (props => (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", {\n style: props,\n className: \"ct-box-shadow-modal\",\n onClick: e => {\n e.preventDefault();\n e.stopPropagation();\n },\n onMouseDownCapture: e => {\n e.nativeEvent.stopImmediatePropagation();\n e.nativeEvent.stopPropagation();\n },\n onMouseUpCapture: e => {\n e.nativeEvent.stopImmediatePropagation();\n e.nativeEvent.stopPropagation();\n }\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(InlineVisibility, {\n option: option,\n value: value,\n onChange: onChange\n })))), el.current.closest('.ct-labeled-group-item') ? el.current.closest('.ct-labeled-group-item').querySelector('.ct-visibility-modal-wrapper') : el.current.closest('.ct-single-palette') ? el.current.closest('.ct-single-palette').querySelector('.ct-visibility-modal-wrapper') : el.current.closest('.ct-visibility-modal-wrapper') ? el.current.closest('.ct-visibility-modal-wrapper') : el.current.closest('.ct-control').querySelector('.ct-visibility-modal-wrapper')));\n};\n\nconst Visibility = _ref4 => {\n let {\n option,\n option: {\n // inline | modal\n view = 'inline'\n },\n value,\n onChange\n } = _ref4;\n\n if (view === 'inline') {\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(InlineVisibility, {\n option: option,\n value: value,\n onChange: onChange\n });\n }\n\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(VisibilityModal, {\n option: option,\n value: value,\n onChange: onChange\n });\n};\n\nVisibility.hiddenResponsive = true;\n\nVisibility.ControlEnd = () => (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", {\n className: \"ct-visibility-modal-wrapper\"\n});\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Visibility);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"5138.js","mappings":";;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./static/js/options/options/ct-visibility.js?3c05"],"sourcesContent":["function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createElement, createPortal, useContext, Fragment, useState, Component, useRef } from '@wordpress/element';\nimport { maybeTransformUnorderedChoices } from '../helpers/parse-choices.js';\nimport classnames from 'classnames';\nimport { Transition } from 'react-spring/renderprops';\nimport bezierEasing from 'bezier-easing';\nimport OutsideClickHandler from './react-outside-click-handler';\nimport { __ } from 'ct-i18n';\n\nconst InlineVisibility = _ref => {\n  let {\n    option,\n    value,\n    onChange\n  } = _ref;\n  return createElement(\"ul\", _extends({\n    className: \"ct-visibility-option ct-devices ct-buttons-group\"\n  }, option.attr || {}), maybeTransformUnorderedChoices(option.choices).map(_ref2 => {\n    let {\n      key,\n      value: val\n    } = _ref2;\n    return createElement(\"li\", {\n      className: classnames({\n        active: value[key]\n      }, `ct-${key}`),\n      onClick: () => onChange(_objectSpread(_objectSpread({}, value), {}, {\n        [key]: value[key] ? Object.values(value).filter(v => v).length === 1 && !option.allow_empty ? true : false : true\n      })),\n      key: key\n    });\n  }));\n};\n\nconst VisibilityModal = _ref3 => {\n  let {\n    option,\n    value,\n    onChange\n  } = _ref3;\n  const [{\n    isPicking,\n    isTransitioning\n  }, setAnimationState] = useState({\n    isPicking: null,\n    isTransitioning: null\n  });\n\n  const stopTransitioning = () => setAnimationState({\n    isPicking,\n    isTransitioning: false\n  });\n\n  const el = useRef();\n  return createElement(Fragment, null, createElement(OutsideClickHandler, {\n    useCapture: false,\n    disabled: !isPicking,\n    className: \"ct-visibility-trigger\",\n    additionalRefs: [],\n    onOutsideClick: () => {\n      if (!isPicking) {\n        return;\n      }\n\n      setAnimationState({\n        isTransitioning: true,\n        isPicking: null\n      });\n    },\n    wrapperProps: {\n      ref: el,\n      onClick: e => {\n        e.preventDefault();\n        setAnimationState({\n          isTransitioning: true,\n          isPicking: true\n        });\n      }\n    }\n  }, createElement(\"span\", null, \"open visibility\")), (isTransitioning || isPicking) && createPortal(createElement(Transition, {\n    items: isPicking,\n    onRest: isOpen => {\n      stopTransitioning();\n    },\n    config: {\n      duration: 100,\n      easing: bezierEasing(0.25, 0.1, 0.25, 1.0)\n    },\n    from: isPicking ? {\n      transform: 'scale3d(0.95, 0.95, 1)',\n      opacity: 0\n    } : {\n      opacity: 1\n    },\n    enter: isPicking ? {\n      transform: 'scale3d(1, 1, 1)',\n      opacity: 1\n    } : {\n      opacity: 1\n    },\n    leave: isPicking ? {\n      transform: 'scale3d(0.95, 0.95, 1)',\n      opacity: 0\n    } : {\n      opacity: 1\n    }\n  }, isPicking => isPicking && (props => createElement(\"div\", {\n    style: props,\n    className: \"ct-box-shadow-modal\",\n    onClick: e => {\n      e.preventDefault();\n      e.stopPropagation();\n    },\n    onMouseDownCapture: e => {\n      e.nativeEvent.stopImmediatePropagation();\n      e.nativeEvent.stopPropagation();\n    },\n    onMouseUpCapture: e => {\n      e.nativeEvent.stopImmediatePropagation();\n      e.nativeEvent.stopPropagation();\n    }\n  }, createElement(InlineVisibility, {\n    option: option,\n    value: value,\n    onChange: onChange\n  })))), el.current.closest('.ct-labeled-group-item') ? el.current.closest('.ct-labeled-group-item').querySelector('.ct-visibility-modal-wrapper') : el.current.closest('.ct-single-palette') ? el.current.closest('.ct-single-palette').querySelector('.ct-visibility-modal-wrapper') : el.current.closest('.ct-visibility-modal-wrapper') ? el.current.closest('.ct-visibility-modal-wrapper') : el.current.closest('.ct-control').querySelector('.ct-visibility-modal-wrapper')));\n};\n\nconst Visibility = _ref4 => {\n  let {\n    option,\n    option: {\n      // inline | modal\n      view = 'inline'\n    },\n    value,\n    onChange\n  } = _ref4;\n\n  if (view === 'inline') {\n    return createElement(InlineVisibility, {\n      option: option,\n      value: value,\n      onChange: onChange\n    });\n  }\n\n  return createElement(VisibilityModal, {\n    option: option,\n    value: value,\n    onChange: onChange\n  });\n};\n\nVisibility.hiddenResponsive = true;\n\nVisibility.ControlEnd = () => createElement(\"div\", {\n  className: \"ct-visibility-modal-wrapper\"\n});\n\nexport default Visibility;"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///5138\n")},6223:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(4184);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var ct_i18n__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(5652);\n/* harmony import */ var ct_i18n__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(ct_i18n__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _ct_number__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(4949);\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\nconst WooColumnsAndRows = _ref => {\n let {\n onChange,\n value,\n option,\n option: {\n columns_id,\n rows_id\n },\n device,\n onChangeFor,\n values,\n values: {\n woocommerce_catalog_columns,\n woocommerce_catalog_rows\n }\n } = _ref;\n const rowsValue = rows_id ? values[rows_id] : woocommerce_catalog_rows;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", _extends({\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()('ct-woo-columns-and-rows', {})\n }, device !== 'desktop' ? {\n 'data-disabled-last': ''\n } : {}), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_ct_number__WEBPACK_IMPORTED_MODULE_3__[\"default\"], {\n option: _objectSpread(_objectSpread({}, option), {}, {\n attr: _objectSpread(_objectSpread({}, option.attr || {}), {}, {\n 'data-width': 'full'\n })\n }),\n value: !columns_id && device === 'desktop' ? woocommerce_catalog_columns : value,\n onChange: val => {\n device === 'desktop' && !columns_id ? onChangeFor('woocommerce_catalog_columns', val) : onChange(val);\n }\n }), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"p\", {\n className: \"ct-option-description\"\n }, (0,ct_i18n__WEBPACK_IMPORTED_MODULE_2__.__)('Number of columns', 'blc'))), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_ct_number__WEBPACK_IMPORTED_MODULE_3__[\"default\"], {\n option: {\n min: 1,\n max: 100,\n responsive: false,\n value: 4,\n attr: {\n 'data-width': 'full'\n }\n },\n value: device === 'desktop' ? rowsValue : 'auto',\n onChange: val => {\n device === 'desktop' && onChangeFor(rows_id || 'woocommerce_catalog_rows', val);\n\n if (wp.customize && wp.customize.previewer) {\n wp.customize.previewer.send('ct:sync:refresh_partial', {\n id: rows_id || 'woocommerce_catalog_rows'\n });\n }\n }\n }), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"p\", {\n className: \"ct-option-description\"\n }, (0,ct_i18n__WEBPACK_IMPORTED_MODULE_2__.__)('Number of rows', 'blc'))));\n};\n\nWooColumnsAndRows.renderingConfig = {\n getValueForRevert: _ref2 => {\n let {\n value,\n values: {\n woocommerce_catalog_columns,\n woocommerce_catalog_rows\n },\n option,\n option: {\n columns_id,\n rows_id\n },\n values,\n device\n } = _ref2;\n const rowsValue = rows_id ? values[rows_id] : woocommerce_catalog_rows;\n\n let myResult = _objectSpread(_objectSpread({}, value), {}, {\n desktop: woocommerce_catalog_columns,\n woocommerce_catalog_columns,\n woocommerce_catalog_rows\n });\n\n return myResult;\n },\n computeOptionValue: v => _objectSpread(_objectSpread({}, v), {}, {\n woocommerce_catalog_columns: 4,\n woocommerce_catalog_rows: 4\n }),\n computeOptionValue: v => {\n const result = _objectSpread(_objectSpread({}, v), {}, {\n woocommerce_catalog_columns: 4,\n woocommerce_catalog_rows: 4\n });\n\n return result;\n },\n performRevert: _ref3 => {\n let {\n onChangeFor\n } = _ref3;\n onChangeFor('woocommerce_catalog_columns', 4);\n onChangeFor('woocommerce_catalog_rows', 4);\n }\n};\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (WooColumnsAndRows);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNjIyMy5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vc3RhdGljL2pzL29wdGlvbnMvb3B0aW9ucy9jdC13b29jb21tZXJjZS1jb2x1bW5zLWFuZC1yb3dzLmpzP2I4ZTQiXSwic291cmNlc0NvbnRlbnQiOlsiZnVuY3Rpb24gX2V4dGVuZHMoKSB7IF9leHRlbmRzID0gT2JqZWN0LmFzc2lnbiA/IE9iamVjdC5hc3NpZ24uYmluZCgpIDogZnVuY3Rpb24gKHRhcmdldCkgeyBmb3IgKHZhciBpID0gMTsgaSA8IGFyZ3VtZW50cy5sZW5ndGg7IGkrKykgeyB2YXIgc291cmNlID0gYXJndW1lbnRzW2ldOyBmb3IgKHZhciBrZXkgaW4gc291cmNlKSB7IGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwoc291cmNlLCBrZXkpKSB7IHRhcmdldFtrZXldID0gc291cmNlW2tleV07IH0gfSB9IHJldHVybiB0YXJnZXQ7IH07IHJldHVybiBfZXh0ZW5kcy5hcHBseSh0aGlzLCBhcmd1bWVudHMpOyB9XG5cbmZ1bmN0aW9uIG93bktleXMob2JqZWN0LCBlbnVtZXJhYmxlT25seSkgeyB2YXIga2V5cyA9IE9iamVjdC5rZXlzKG9iamVjdCk7IGlmIChPYmplY3QuZ2V0T3duUHJvcGVydHlTeW1ib2xzKSB7IHZhciBzeW1ib2xzID0gT2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9scyhvYmplY3QpOyBlbnVtZXJhYmxlT25seSAmJiAoc3ltYm9scyA9IHN5bWJvbHMuZmlsdGVyKGZ1bmN0aW9uIChzeW0pIHsgcmV0dXJuIE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3Iob2JqZWN0LCBzeW0pLmVudW1lcmFibGU7IH0pKSwga2V5cy5wdXNoLmFwcGx5KGtleXMsIHN5bWJvbHMpOyB9IHJldHVybiBrZXlzOyB9XG5cbmZ1bmN0aW9uIF9vYmplY3RTcHJlYWQodGFyZ2V0KSB7IGZvciAodmFyIGkgPSAxOyBpIDwgYXJndW1lbnRzLmxlbmd0aDsgaSsrKSB7IHZhciBzb3VyY2UgPSBudWxsICE9IGFyZ3VtZW50c1tpXSA/IGFyZ3VtZW50c1tpXSA6IHt9OyBpICUgMiA/IG93bktleXMoT2JqZWN0KHNvdXJjZSksICEwKS5mb3JFYWNoKGZ1bmN0aW9uIChrZXkpIHsgX2RlZmluZVByb3BlcnR5KHRhcmdldCwga2V5LCBzb3VyY2Vba2V5XSk7IH0pIDogT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcnMgPyBPYmplY3QuZGVmaW5lUHJvcGVydGllcyh0YXJnZXQsIE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3JzKHNvdXJjZSkpIDogb3duS2V5cyhPYmplY3Qoc291cmNlKSkuZm9yRWFjaChmdW5jdGlvbiAoa2V5KSB7IE9iamVjdC5kZWZpbmVQcm9wZXJ0eSh0YXJnZXQsIGtleSwgT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcihzb3VyY2UsIGtleSkpOyB9KTsgfSByZXR1cm4gdGFyZ2V0OyB9XG5cbmZ1bmN0aW9uIF9kZWZpbmVQcm9wZXJ0eShvYmosIGtleSwgdmFsdWUpIHsgaWYgKGtleSBpbiBvYmopIHsgT2JqZWN0LmRlZmluZVByb3BlcnR5KG9iaiwga2V5LCB7IHZhbHVlOiB2YWx1ZSwgZW51bWVyYWJsZTogdHJ1ZSwgY29uZmlndXJhYmxlOiB0cnVlLCB3cml0YWJsZTogdHJ1ZSB9KTsgfSBlbHNlIHsgb2JqW2tleV0gPSB2YWx1ZTsgfSByZXR1cm4gb2JqOyB9XG5cbmltcG9ydCB7IGNyZWF0ZUVsZW1lbnQsIENvbXBvbmVudCwgdXNlU3RhdGUsIEZyYWdtZW50IH0gZnJvbSAnQHdvcmRwcmVzcy9lbGVtZW50JztcbmltcG9ydCBjbHMgZnJvbSAnY2xhc3NuYW1lcyc7XG5pbXBvcnQgeyBfXywgc3ByaW50ZiB9IGZyb20gJ2N0LWkxOG4nO1xuaW1wb3J0IE51bWJlck9wdGlvbiBmcm9tICcuL2N0LW51bWJlcic7XG5pbXBvcnQgY2xhc3NuYW1lcyBmcm9tICdjbGFzc25hbWVzJztcblxuY29uc3QgV29vQ29sdW1uc0FuZFJvd3MgPSBfcmVmID0+IHtcbiAgbGV0IHtcbiAgICBvbkNoYW5nZSxcbiAgICB2YWx1ZSxcbiAgICBvcHRpb24sXG4gICAgb3B0aW9uOiB7XG4gICAgICBjb2x1bW5zX2lkLFxuICAgICAgcm93c19pZFxuICAgIH0sXG4gICAgZGV2aWNlLFxuICAgIG9uQ2hhbmdlRm9yLFxuICAgIHZhbHVlcyxcbiAgICB2YWx1ZXM6IHtcbiAgICAgIHdvb2NvbW1lcmNlX2NhdGFsb2dfY29sdW1ucyxcbiAgICAgIHdvb2NvbW1lcmNlX2NhdGFsb2dfcm93c1xuICAgIH1cbiAgfSA9IF9yZWY7XG4gIGNvbnN0IHJvd3NWYWx1ZSA9IHJvd3NfaWQgPyB2YWx1ZXNbcm93c19pZF0gOiB3b29jb21tZXJjZV9jYXRhbG9nX3Jvd3M7XG4gIHJldHVybiBjcmVhdGVFbGVtZW50KFwiZGl2XCIsIF9leHRlbmRzKHtcbiAgICBjbGFzc05hbWU6IGNsYXNzbmFtZXMoJ2N0LXdvby1jb2x1bW5zLWFuZC1yb3dzJywge30pXG4gIH0sIGRldmljZSAhPT0gJ2Rlc2t0b3AnID8ge1xuICAgICdkYXRhLWRpc2FibGVkLWxhc3QnOiAnJ1xuICB9IDoge30pLCBjcmVhdGVFbGVtZW50KFwiZGl2XCIsIG51bGwsIGNyZWF0ZUVsZW1lbnQoTnVtYmVyT3B0aW9uLCB7XG4gICAgb3B0aW9uOiBfb2JqZWN0U3ByZWFkKF9vYmplY3RTcHJlYWQoe30sIG9wdGlvbiksIHt9LCB7XG4gICAgICBhdHRyOiBfb2JqZWN0U3ByZWFkKF9vYmplY3RTcHJlYWQoe30sIG9wdGlvbi5hdHRyIHx8IHt9KSwge30sIHtcbiAgICAgICAgJ2RhdGEtd2lkdGgnOiAnZnVsbCdcbiAgICAgIH0pXG4gICAgfSksXG4gICAgdmFsdWU6ICFjb2x1bW5zX2lkICYmIGRldmljZSA9PT0gJ2Rlc2t0b3AnID8gd29vY29tbWVyY2VfY2F0YWxvZ19jb2x1bW5zIDogdmFsdWUsXG4gICAgb25DaGFuZ2U6IHZhbCA9PiB7XG4gICAgICBkZXZpY2UgPT09ICdkZXNrdG9wJyAmJiAhY29sdW1uc19pZCA/IG9uQ2hhbmdlRm9yKCd3b29jb21tZXJjZV9jYXRhbG9nX2NvbHVtbnMnLCB2YWwpIDogb25DaGFuZ2UodmFsKTtcbiAgICB9XG4gIH0pLCBjcmVhdGVFbGVtZW50KFwicFwiLCB7XG4gICAgY2xhc3NOYW1lOiBcImN0LW9wdGlvbi1kZXNjcmlwdGlvblwiXG4gIH0sIF9fKCdOdW1iZXIgb2YgY29sdW1ucycsICdibGMnKSkpLCBjcmVhdGVFbGVtZW50KFwiZGl2XCIsIG51bGwsIGNyZWF0ZUVsZW1lbnQoTnVtYmVyT3B0aW9uLCB7XG4gICAgb3B0aW9uOiB7XG4gICAgICBtaW46IDEsXG4gICAgICBtYXg6IDEwMCxcbiAgICAgIHJlc3BvbnNpdmU6IGZhbHNlLFxuICAgICAgdmFsdWU6IDQsXG4gICAgICBhdHRyOiB7XG4gICAgICAgICdkYXRhLXdpZHRoJzogJ2Z1bGwnXG4gICAgICB9XG4gICAgfSxcbiAgICB2YWx1ZTogZGV2aWNlID09PSAnZGVza3RvcCcgPyByb3dzVmFsdWUgOiAnYXV0bycsXG4gICAgb25DaGFuZ2U6IHZhbCA9PiB7XG4gICAgICBkZXZpY2UgPT09ICdkZXNrdG9wJyAmJiBvbkNoYW5nZUZvcihyb3dzX2lkIHx8ICd3b29jb21tZXJjZV9jYXRhbG9nX3Jvd3MnLCB2YWwpO1xuXG4gICAgICBpZiAod3AuY3VzdG9taXplICYmIHdwLmN1c3RvbWl6ZS5wcmV2aWV3ZXIpIHtcbiAgICAgICAgd3AuY3VzdG9taXplLnByZXZpZXdlci5zZW5kKCdjdDpzeW5jOnJlZnJlc2hfcGFydGlhbCcsIHtcbiAgICAgICAgICBpZDogcm93c19pZCB8fCAnd29vY29tbWVyY2VfY2F0YWxvZ19yb3dzJ1xuICAgICAgICB9KTtcbiAgICAgIH1cbiAgICB9XG4gIH0pLCBjcmVhdGVFbGVtZW50KFwicFwiLCB7XG4gICAgY2xhc3NOYW1lOiBcImN0LW9wdGlvbi1kZXNjcmlwdGlvblwiXG4gIH0sIF9fKCdOdW1iZXIgb2Ygcm93cycsICdibGMnKSkpKTtcbn07XG5cbldvb0NvbHVtbnNBbmRSb3dzLnJlbmRlcmluZ0NvbmZpZyA9IHtcbiAgZ2V0VmFsdWVGb3JSZXZlcnQ6IF9yZWYyID0+IHtcbiAgICBsZXQge1xuICAgICAgdmFsdWUsXG4gICAgICB2YWx1ZXM6IHtcbiAgICAgICAgd29vY29tbWVyY2VfY2F0YWxvZ19jb2x1bW5zLFxuICAgICAgICB3b29jb21tZXJjZV9jYXRhbG9nX3Jvd3NcbiAgICAgIH0sXG4gICAgICBvcHRpb24sXG4gICAgICBvcHRpb246IHtcbiAgICAgICAgY29sdW1uc19pZCxcbiAgICAgICAgcm93c19pZFxuICAgICAgfSxcbiAgICAgIHZhbHVlcyxcbiAgICAgIGRldmljZVxuICAgIH0gPSBfcmVmMjtcbiAgICBjb25zdCByb3dzVmFsdWUgPSByb3dzX2lkID8gdmFsdWVzW3Jvd3NfaWRdIDogd29vY29tbWVyY2VfY2F0YWxvZ19yb3dzO1xuXG4gICAgbGV0IG15UmVzdWx0ID0gX29iamVjdFNwcmVhZChfb2JqZWN0U3ByZWFkKHt9LCB2YWx1ZSksIHt9LCB7XG4gICAgICBkZXNrdG9wOiB3b29jb21tZXJjZV9jYXRhbG9nX2NvbHVtbnMsXG4gICAgICB3b29jb21tZXJjZV9jYXRhbG9nX2NvbHVtbnMsXG4gICAgICB3b29jb21tZXJjZV9jYXRhbG9nX3Jvd3NcbiAgICB9KTtcblxuICAgIHJldHVybiBteVJlc3VsdDtcbiAgfSxcbiAgY29tcHV0ZU9wdGlvblZhbHVlOiB2ID0+IF9vYmplY3RTcHJlYWQoX29iamVjdFNwcmVhZCh7fSwgdiksIHt9LCB7XG4gICAgd29vY29tbWVyY2VfY2F0YWxvZ19jb2x1bW5zOiA0LFxuICAgIHdvb2NvbW1lcmNlX2NhdGFsb2dfcm93czogNFxuICB9KSxcbiAgY29tcHV0ZU9wdGlvblZhbHVlOiB2ID0+IHtcbiAgICBjb25zdCByZXN1bHQgPSBfb2JqZWN0U3ByZWFkKF9vYmplY3RTcHJlYWQoe30sIHYpLCB7fSwge1xuICAgICAgd29vY29tbWVyY2VfY2F0YWxvZ19jb2x1bW5zOiA0LFxuICAgICAgd29vY29tbWVyY2VfY2F0YWxvZ19yb3dzOiA0XG4gICAgfSk7XG5cbiAgICByZXR1cm4gcmVzdWx0O1xuICB9LFxuICBwZXJmb3JtUmV2ZXJ0OiBfcmVmMyA9PiB7XG4gICAgbGV0IHtcbiAgICAgIG9uQ2hhbmdlRm9yXG4gICAgfSA9IF9yZWYzO1xuICAgIG9uQ2hhbmdlRm9yKCd3b29jb21tZXJjZV9jYXRhbG9nX2NvbHVtbnMnLCA0KTtcbiAgICBvbkNoYW5nZUZvcignd29vY29tbWVyY2VfY2F0YWxvZ19yb3dzJywgNCk7XG4gIH1cbn07XG5leHBvcnQgZGVmYXVsdCBXb29Db2x1bW5zQW5kUm93czsiXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///6223\n")},6761:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(4184);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var ct_i18n__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(5652);\n/* harmony import */ var ct_i18n__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(ct_i18n__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _ct_ratio__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(9735);\nconst _excluded = [\"value\", \"onChange\", \"onChangeFor\", \"values\", \"values\", \"option\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\n\n\n\n\n\nconst WooCommerceRatio = _ref => {\n let {\n value,\n onChange,\n onChangeFor,\n values,\n values: {\n woocommerce_thumbnail_cropping_custom_width,\n woocommerce_thumbnail_cropping_custom_height\n },\n option\n } = _ref,\n props = _objectWithoutProperties(_ref, _excluded);\n\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_ct_ratio__WEBPACK_IMPORTED_MODULE_3__[\"default\"], _extends({\n onChange: val => {\n let isCustom = val.indexOf('/') === -1;\n let [width, height] = val.split(isCustom ? ':' : '/');\n\n if (val === 'original') {\n onChangeFor('woocommerce_thumbnail_cropping', 'uncropped');\n onChange('uncropped');\n return;\n }\n\n onChange(isCustom ? 'custom' : 'predefined');\n onChangeFor('woocommerce_thumbnail_cropping', 'custom');\n onChangeFor('woocommerce_thumbnail_cropping_custom_height', parseFloat(height || '0') || 0);\n onChangeFor('woocommerce_thumbnail_cropping_custom_width', parseFloat(width || '0') || 0);\n },\n value: value === 'uncropped' ? 'original' : value === '1:1' ? `1/1` : `${woocommerce_thumbnail_cropping_custom_width}${value === 'custom' ? ':' : '/'}${woocommerce_thumbnail_cropping_custom_height}`,\n option: _objectSpread(_objectSpread({}, option), {}, {\n value: '1/1'\n }),\n onChangeFor: onChangeFor,\n values: values\n }, props));\n};\n\nWooCommerceRatio.ControlEnd = () => (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", {\n className: \"ct-color-modal-wrapper\",\n onMouseDown: e => e.stopPropagation(),\n onMouseUp: e => e.stopPropagation()\n});\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (WooCommerceRatio);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNjc2MS5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9ibG9ja3N5T3B0aW9ucy8uL3N0YXRpYy9qcy9vcHRpb25zL29wdGlvbnMvY3Qtd29vY29tbWVyY2UtcmF0aW8uanM/NWE3MCJdLCJzb3VyY2VzQ29udGVudCI6WyJjb25zdCBfZXhjbHVkZWQgPSBbXCJ2YWx1ZVwiLCBcIm9uQ2hhbmdlXCIsIFwib25DaGFuZ2VGb3JcIiwgXCJ2YWx1ZXNcIiwgXCJ2YWx1ZXNcIiwgXCJvcHRpb25cIl07XG5cbmZ1bmN0aW9uIF9leHRlbmRzKCkgeyBfZXh0ZW5kcyA9IE9iamVjdC5hc3NpZ24gPyBPYmplY3QuYXNzaWduLmJpbmQoKSA6IGZ1bmN0aW9uICh0YXJnZXQpIHsgZm9yICh2YXIgaSA9IDE7IGkgPCBhcmd1bWVudHMubGVuZ3RoOyBpKyspIHsgdmFyIHNvdXJjZSA9IGFyZ3VtZW50c1tpXTsgZm9yICh2YXIga2V5IGluIHNvdXJjZSkgeyBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKHNvdXJjZSwga2V5KSkgeyB0YXJnZXRba2V5XSA9IHNvdXJjZVtrZXldOyB9IH0gfSByZXR1cm4gdGFyZ2V0OyB9OyByZXR1cm4gX2V4dGVuZHMuYXBwbHkodGhpcywgYXJndW1lbnRzKTsgfVxuXG5mdW5jdGlvbiBvd25LZXlzKG9iamVjdCwgZW51bWVyYWJsZU9ubHkpIHsgdmFyIGtleXMgPSBPYmplY3Qua2V5cyhvYmplY3QpOyBpZiAoT2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9scykgeyB2YXIgc3ltYm9scyA9IE9iamVjdC5nZXRPd25Qcm9wZXJ0eVN5bWJvbHMob2JqZWN0KTsgZW51bWVyYWJsZU9ubHkgJiYgKHN5bWJvbHMgPSBzeW1ib2xzLmZpbHRlcihmdW5jdGlvbiAoc3ltKSB7IHJldHVybiBPYmplY3QuZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9yKG9iamVjdCwgc3ltKS5lbnVtZXJhYmxlOyB9KSksIGtleXMucHVzaC5hcHBseShrZXlzLCBzeW1ib2xzKTsgfSByZXR1cm4ga2V5czsgfVxuXG5mdW5jdGlvbiBfb2JqZWN0U3ByZWFkKHRhcmdldCkgeyBmb3IgKHZhciBpID0gMTsgaSA8IGFyZ3VtZW50cy5sZW5ndGg7IGkrKykgeyB2YXIgc291cmNlID0gbnVsbCAhPSBhcmd1bWVudHNbaV0gPyBhcmd1bWVudHNbaV0gOiB7fTsgaSAlIDIgPyBvd25LZXlzKE9iamVjdChzb3VyY2UpLCAhMCkuZm9yRWFjaChmdW5jdGlvbiAoa2V5KSB7IF9kZWZpbmVQcm9wZXJ0eSh0YXJnZXQsIGtleSwgc291cmNlW2tleV0pOyB9KSA6IE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3JzID8gT2JqZWN0LmRlZmluZVByb3BlcnRpZXModGFyZ2V0LCBPYmplY3QuZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9ycyhzb3VyY2UpKSA6IG93bktleXMoT2JqZWN0KHNvdXJjZSkpLmZvckVhY2goZnVuY3Rpb24gKGtleSkgeyBPYmplY3QuZGVmaW5lUHJvcGVydHkodGFyZ2V0LCBrZXksIE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3Ioc291cmNlLCBrZXkpKTsgfSk7IH0gcmV0dXJuIHRhcmdldDsgfVxuXG5mdW5jdGlvbiBfZGVmaW5lUHJvcGVydHkob2JqLCBrZXksIHZhbHVlKSB7IGlmIChrZXkgaW4gb2JqKSB7IE9iamVjdC5kZWZpbmVQcm9wZXJ0eShvYmosIGtleSwgeyB2YWx1ZTogdmFsdWUsIGVudW1lcmFibGU6IHRydWUsIGNvbmZpZ3VyYWJsZTogdHJ1ZSwgd3JpdGFibGU6IHRydWUgfSk7IH0gZWxzZSB7IG9ialtrZXldID0gdmFsdWU7IH0gcmV0dXJuIG9iajsgfVxuXG5mdW5jdGlvbiBfb2JqZWN0V2l0aG91dFByb3BlcnRpZXMoc291cmNlLCBleGNsdWRlZCkgeyBpZiAoc291cmNlID09IG51bGwpIHJldHVybiB7fTsgdmFyIHRhcmdldCA9IF9vYmplY3RXaXRob3V0UHJvcGVydGllc0xvb3NlKHNvdXJjZSwgZXhjbHVkZWQpOyB2YXIga2V5LCBpOyBpZiAoT2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9scykgeyB2YXIgc291cmNlU3ltYm9sS2V5cyA9IE9iamVjdC5nZXRPd25Qcm9wZXJ0eVN5bWJvbHMoc291cmNlKTsgZm9yIChpID0gMDsgaSA8IHNvdXJjZVN5bWJvbEtleXMubGVuZ3RoOyBpKyspIHsga2V5ID0gc291cmNlU3ltYm9sS2V5c1tpXTsgaWYgKGV4Y2x1ZGVkLmluZGV4T2Yoa2V5KSA+PSAwKSBjb250aW51ZTsgaWYgKCFPYmplY3QucHJvdG90eXBlLnByb3BlcnR5SXNFbnVtZXJhYmxlLmNhbGwoc291cmNlLCBrZXkpKSBjb250aW51ZTsgdGFyZ2V0W2tleV0gPSBzb3VyY2Vba2V5XTsgfSB9IHJldHVybiB0YXJnZXQ7IH1cblxuZnVuY3Rpb24gX29iamVjdFdpdGhvdXRQcm9wZXJ0aWVzTG9vc2Uoc291cmNlLCBleGNsdWRlZCkgeyBpZiAoc291cmNlID09IG51bGwpIHJldHVybiB7fTsgdmFyIHRhcmdldCA9IHt9OyB2YXIgc291cmNlS2V5cyA9IE9iamVjdC5rZXlzKHNvdXJjZSk7IHZhciBrZXksIGk7IGZvciAoaSA9IDA7IGkgPCBzb3VyY2VLZXlzLmxlbmd0aDsgaSsrKSB7IGtleSA9IHNvdXJjZUtleXNbaV07IGlmIChleGNsdWRlZC5pbmRleE9mKGtleSkgPj0gMCkgY29udGludWU7IHRhcmdldFtrZXldID0gc291cmNlW2tleV07IH0gcmV0dXJuIHRhcmdldDsgfVxuXG5pbXBvcnQgeyBjcmVhdGVFbGVtZW50LCBDb21wb25lbnQsIHVzZVN0YXRlIH0gZnJvbSAnQHdvcmRwcmVzcy9lbGVtZW50JztcbmltcG9ydCBjbHMgZnJvbSAnY2xhc3NuYW1lcyc7XG5pbXBvcnQgeyBfXywgc3ByaW50ZiB9IGZyb20gJ2N0LWkxOG4nO1xuaW1wb3J0IFJhdGlvIGZyb20gJy4vY3QtcmF0aW8nO1xuXG5jb25zdCBXb29Db21tZXJjZVJhdGlvID0gX3JlZiA9PiB7XG4gIGxldCB7XG4gICAgdmFsdWUsXG4gICAgb25DaGFuZ2UsXG4gICAgb25DaGFuZ2VGb3IsXG4gICAgdmFsdWVzLFxuICAgIHZhbHVlczoge1xuICAgICAgd29vY29tbWVyY2VfdGh1bWJuYWlsX2Nyb3BwaW5nX2N1c3RvbV93aWR0aCxcbiAgICAgIHdvb2NvbW1lcmNlX3RodW1ibmFpbF9jcm9wcGluZ19jdXN0b21faGVpZ2h0XG4gICAgfSxcbiAgICBvcHRpb25cbiAgfSA9IF9yZWYsXG4gICAgICBwcm9wcyA9IF9vYmplY3RXaXRob3V0UHJvcGVydGllcyhfcmVmLCBfZXhjbHVkZWQpO1xuXG4gIHJldHVybiBjcmVhdGVFbGVtZW50KFJhdGlvLCBfZXh0ZW5kcyh7XG4gICAgb25DaGFuZ2U6IHZhbCA9PiB7XG4gICAgICBsZXQgaXNDdXN0b20gPSB2YWwuaW5kZXhPZignLycpID09PSAtMTtcbiAgICAgIGxldCBbd2lkdGgsIGhlaWdodF0gPSB2YWwuc3BsaXQoaXNDdXN0b20gPyAnOicgOiAnLycpO1xuXG4gICAgICBpZiAodmFsID09PSAnb3JpZ2luYWwnKSB7XG4gICAgICAgIG9uQ2hhbmdlRm9yKCd3b29jb21tZXJjZV90aHVtYm5haWxfY3JvcHBpbmcnLCAndW5jcm9wcGVkJyk7XG4gICAgICAgIG9uQ2hhbmdlKCd1bmNyb3BwZWQnKTtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuXG4gICAgICBvbkNoYW5nZShpc0N1c3RvbSA/ICdjdXN0b20nIDogJ3ByZWRlZmluZWQnKTtcbiAgICAgIG9uQ2hhbmdlRm9yKCd3b29jb21tZXJjZV90aHVtYm5haWxfY3JvcHBpbmcnLCAnY3VzdG9tJyk7XG4gICAgICBvbkNoYW5nZUZvcignd29vY29tbWVyY2VfdGh1bWJuYWlsX2Nyb3BwaW5nX2N1c3RvbV9oZWlnaHQnLCBwYXJzZUZsb2F0KGhlaWdodCB8fCAnMCcpIHx8IDApO1xuICAgICAgb25DaGFuZ2VGb3IoJ3dvb2NvbW1lcmNlX3RodW1ibmFpbF9jcm9wcGluZ19jdXN0b21fd2lkdGgnLCBwYXJzZUZsb2F0KHdpZHRoIHx8ICcwJykgfHwgMCk7XG4gICAgfSxcbiAgICB2YWx1ZTogdmFsdWUgPT09ICd1bmNyb3BwZWQnID8gJ29yaWdpbmFsJyA6IHZhbHVlID09PSAnMToxJyA/IGAxLzFgIDogYCR7d29vY29tbWVyY2VfdGh1bWJuYWlsX2Nyb3BwaW5nX2N1c3RvbV93aWR0aH0ke3ZhbHVlID09PSAnY3VzdG9tJyA/ICc6JyA6ICcvJ30ke3dvb2NvbW1lcmNlX3RodW1ibmFpbF9jcm9wcGluZ19jdXN0b21faGVpZ2h0fWAsXG4gICAgb3B0aW9uOiBfb2JqZWN0U3ByZWFkKF9vYmplY3RTcHJlYWQoe30sIG9wdGlvbiksIHt9LCB7XG4gICAgICB2YWx1ZTogJzEvMSdcbiAgICB9KSxcbiAgICBvbkNoYW5nZUZvcjogb25DaGFuZ2VGb3IsXG4gICAgdmFsdWVzOiB2YWx1ZXNcbiAgfSwgcHJvcHMpKTtcbn07XG5cbldvb0NvbW1lcmNlUmF0aW8uQ29udHJvbEVuZCA9ICgpID0+IGNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwge1xuICBjbGFzc05hbWU6IFwiY3QtY29sb3ItbW9kYWwtd3JhcHBlclwiLFxuICBvbk1vdXNlRG93bjogZSA9PiBlLnN0b3BQcm9wYWdhdGlvbigpLFxuICBvbk1vdXNlVXA6IGUgPT4gZS5zdG9wUHJvcGFnYXRpb24oKVxufSk7XG5cbmV4cG9ydCBkZWZhdWx0IFdvb0NvbW1lcmNlUmF0aW87Il0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///6761\n")},7946:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('// ESM COMPAT FLAG\n__webpack_require__.r(__webpack_exports__);\n\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n "default": () => (/* binding */ date_time_picker)\n});\n\n// EXTERNAL MODULE: external "window.wp.element"\nvar external_window_wp_element_ = __webpack_require__(1381);\n// EXTERNAL MODULE: external "window.wp.components"\nvar external_window_wp_components_ = __webpack_require__(8441);\n;// CONCATENATED MODULE: external "window.wp.date"\nconst external_window_wp_date_namespaceObject = window.wp.date;\n;// CONCATENATED MODULE: ./static/js/options/options/date-time-picker.js\n\n\n\n\nconst LocalDateTimePicker = _ref => {\n let {\n value,\n option,\n onChange\n } = _ref;\n\n const settings = (0,external_window_wp_date_namespaceObject.__experimentalGetSettings)();\n\n const is12HourTime = /a(?!\\\\)/i.test(settings.formats.time.toLowerCase() // Test only the lower case a\n .replace(/\\\\\\\\/g, \'\') // Replace "//" with empty strings\n .split(\'\').reverse().join(\'\') // Reverse the string and test for "a" not followed by a slash\n );\n return (0,external_window_wp_element_.createElement)("div", {\n className: "ct-date-time-picker"\n }, (0,external_window_wp_element_.createElement)(external_window_wp_components_.DateTimePicker, {\n currentDate: value ? value : new Date(),\n onChange: date => {\n onChange(date);\n },\n is12Hour: is12HourTime\n }));\n};\n/*\n\t
\n\t\t onChange(value)}\n\t\t/>\n\t
\n)\n*/\n\n\n/* harmony default export */ const date_time_picker = (LocalDateTimePicker);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNzk0Ni5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7O0FBQUE7O0FDQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvZXh0ZXJuYWwgdmFyIFwid2luZG93LndwLmRhdGVcIj9iOTVlIiwid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vc3RhdGljL2pzL29wdGlvbnMvb3B0aW9ucy9kYXRlLXRpbWUtcGlja2VyLmpzP2Q3MTIiXSwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgX19XRUJQQUNLX05BTUVTUEFDRV9PQkpFQ1RfXyA9IHdpbmRvdy53cC5kYXRlOyIsImltcG9ydCB7IGNyZWF0ZUVsZW1lbnQsIENvbXBvbmVudCB9IGZyb20gJ0B3b3JkcHJlc3MvZWxlbWVudCc7XG5pbXBvcnQgeyBEYXRlVGltZVBpY2tlciB9IGZyb20gJ0B3b3JkcHJlc3MvY29tcG9uZW50cyc7XG5pbXBvcnQgeyBfX2V4cGVyaW1lbnRhbEdldFNldHRpbmdzIH0gZnJvbSAnQHdvcmRwcmVzcy9kYXRlJztcblxuY29uc3QgTG9jYWxEYXRlVGltZVBpY2tlciA9IF9yZWYgPT4ge1xuICBsZXQge1xuICAgIHZhbHVlLFxuICAgIG9wdGlvbixcbiAgICBvbkNoYW5nZVxuICB9ID0gX3JlZjtcblxuICBjb25zdCBzZXR0aW5ncyA9IF9fZXhwZXJpbWVudGFsR2V0U2V0dGluZ3MoKTtcblxuICBjb25zdCBpczEySG91clRpbWUgPSAvYSg/IVxcXFwpL2kudGVzdChzZXR0aW5ncy5mb3JtYXRzLnRpbWUudG9Mb3dlckNhc2UoKSAvLyBUZXN0IG9ubHkgdGhlIGxvd2VyIGNhc2UgYVxuICAucmVwbGFjZSgvXFxcXFxcXFwvZywgJycpIC8vIFJlcGxhY2UgXCIvL1wiIHdpdGggZW1wdHkgc3RyaW5nc1xuICAuc3BsaXQoJycpLnJldmVyc2UoKS5qb2luKCcnKSAvLyBSZXZlcnNlIHRoZSBzdHJpbmcgYW5kIHRlc3QgZm9yIFwiYVwiIG5vdCBmb2xsb3dlZCBieSBhIHNsYXNoXG4gICk7XG4gIHJldHVybiBjcmVhdGVFbGVtZW50KFwiZGl2XCIsIHtcbiAgICBjbGFzc05hbWU6IFwiY3QtZGF0ZS10aW1lLXBpY2tlclwiXG4gIH0sIGNyZWF0ZUVsZW1lbnQoRGF0ZVRpbWVQaWNrZXIsIHtcbiAgICBjdXJyZW50RGF0ZTogdmFsdWUgPyB2YWx1ZSA6IG5ldyBEYXRlKCksXG4gICAgb25DaGFuZ2U6IGRhdGUgPT4ge1xuICAgICAgb25DaGFuZ2UoZGF0ZSk7XG4gICAgfSxcbiAgICBpczEySG91cjogaXMxMkhvdXJUaW1lXG4gIH0pKTtcbn07XG4vKlxuXHQ8ZGl2IGNsYXNzTmFtZT1cImN0LW9wdGlvbi1pbnB1dFwiPlxuXHRcdDxpbnB1dFxuXHRcdFx0dHlwZT1cInRleHRcIlxuXHRcdFx0dmFsdWU9e3ZhbHVlfVxuXHRcdFx0ey4uLntcblx0XHRcdFx0Li4uKG9wdGlvbi5maWVsZF9hdHRyID8gb3B0aW9uLmZpZWxkX2F0dHIgOiB7fSksXG5cdFx0XHRcdC4uLihvcHRpb24uYXR0ciAmJiBvcHRpb24uYXR0ci5wbGFjZWhvbGRlclxuXHRcdFx0XHRcdD8ge1xuXHRcdFx0XHRcdFx0XHRwbGFjZWhvbGRlcjogb3B0aW9uLmF0dHIucGxhY2Vob2xkZXIsXG5cdFx0XHRcdFx0ICB9XG5cdFx0XHRcdFx0OiB7fSksXG5cdFx0XHR9fVxuXHRcdFx0b25DaGFuZ2U9eyh7IHRhcmdldDogeyB2YWx1ZSB9IH0pID0+IG9uQ2hhbmdlKHZhbHVlKX1cblx0XHQvPlxuXHQ8L2Rpdj5cbilcbiovXG5cblxuZXhwb3J0IGRlZmF1bHQgTG9jYWxEYXRlVGltZVBpY2tlcjsiXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///7946\n')},6897:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n\n\nconst Hidden = _ref => {\n let {\n option: {\n text = '',\n attr = {}\n }\n } = _ref;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Fragment, null);\n};\n\nHidden.renderingConfig = {\n design: 'none'\n};\n\nHidden.MetaWrapper = () => null;\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Hidden);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNjg5Ny5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vc3RhdGljL2pzL29wdGlvbnMvb3B0aW9ucy9oaWRkZW4uanM/NDFkOSJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGcmFnbWVudCwgY3JlYXRlRWxlbWVudCwgQ29tcG9uZW50IH0gZnJvbSAnQHdvcmRwcmVzcy9lbGVtZW50JztcblxuY29uc3QgSGlkZGVuID0gX3JlZiA9PiB7XG4gIGxldCB7XG4gICAgb3B0aW9uOiB7XG4gICAgICB0ZXh0ID0gJycsXG4gICAgICBhdHRyID0ge31cbiAgICB9XG4gIH0gPSBfcmVmO1xuICByZXR1cm4gY3JlYXRlRWxlbWVudChGcmFnbWVudCwgbnVsbCk7XG59O1xuXG5IaWRkZW4ucmVuZGVyaW5nQ29uZmlnID0ge1xuICBkZXNpZ246ICdub25lJ1xufTtcblxuSGlkZGVuLk1ldGFXcmFwcGVyID0gKCkgPT4gbnVsbDtcblxuZXhwb3J0IGRlZmF1bHQgSGlkZGVuOyJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///6897\n")},6904:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n\n\nconst HTML = props => {\n const {\n option\n } = props;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", {\n dangerouslySetInnerHTML: {\n __html: option.html || \'\'\n }\n });\n};\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (HTML);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNjkwNC5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9zdGF0aWMvanMvb3B0aW9ucy9vcHRpb25zL2h0bWwuanM/ZDliOSJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjcmVhdGVFbGVtZW50LCBDb21wb25lbnQsIEZyYWdtZW50LCBtZW1vLCB1c2VNZW1vIH0gZnJvbSAnQHdvcmRwcmVzcy9lbGVtZW50JztcblxuY29uc3QgSFRNTCA9IHByb3BzID0+IHtcbiAgY29uc3Qge1xuICAgIG9wdGlvblxuICB9ID0gcHJvcHM7XG4gIHJldHVybiBjcmVhdGVFbGVtZW50KFwiZGl2XCIsIHtcbiAgICBkYW5nZXJvdXNseVNldElubmVySFRNTDoge1xuICAgICAgX19odG1sOiBvcHRpb24uaHRtbCB8fCAnJ1xuICAgIH1cbiAgfSk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBIVE1MOyJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///6904\n')},5491:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n\n\nconst Jsx = props => {\n const {\n option\n } = props;\n\n if (option.render) {\n return option.render(props);\n }\n\n return null;\n};\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Jsx);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNTQ5MS5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9ibG9ja3N5T3B0aW9ucy8uL3N0YXRpYy9qcy9vcHRpb25zL29wdGlvbnMvanN4LmpzP2Y0MzciXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3JlYXRlRWxlbWVudCwgQ29tcG9uZW50LCBGcmFnbWVudCwgbWVtbywgdXNlTWVtbyB9IGZyb20gJ0B3b3JkcHJlc3MvZWxlbWVudCc7XG5cbmNvbnN0IEpzeCA9IHByb3BzID0+IHtcbiAgY29uc3Qge1xuICAgIG9wdGlvblxuICB9ID0gcHJvcHM7XG5cbiAgaWYgKG9wdGlvbi5yZW5kZXIpIHtcbiAgICByZXR1cm4gb3B0aW9uLnJlbmRlcihwcm9wcyk7XG4gIH1cblxuICByZXR1cm4gbnVsbDtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IEpzeDsiXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///5491\n')},8204:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ OutsideClickHandler)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(4184);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\nconst DISPLAY = {\n BLOCK: 'block',\n FLEX: 'flex',\n INLINE_BLOCK: 'inline-block'\n};\nconst defaultProps = {\n disabled: false,\n // `useCapture` is set to true by default so that a `stopPropagation` in the\n // children will not prevent all outside click handlers from firing - maja\n useCapture: true,\n display: DISPLAY.BLOCK\n};\n\nconst updateRef = (ref, instance) => {\n if (typeof ref === 'function') {\n ref(instance);\n } else {\n ref.current = instance;\n }\n};\n\nclass OutsideClickHandler extends _wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Component {\n constructor() {\n super(...arguments);\n\n _defineProperty(this, \"childNode\", (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createRef)());\n\n _defineProperty(this, \"checkIsInside\", event => {\n const result = [this.childNode, ...(this.props.additionalRefs || [])].reduce((isInside, currentRef) => {\n if (isInside) {\n return isInside;\n }\n\n if (!currentRef || !currentRef.current) {\n return isInside;\n }\n\n return currentRef.current.contains(event.target);\n }, false);\n return result;\n });\n\n _defineProperty(this, \"onMouseDown\", e => {\n const {\n useCapture\n } = this.props;\n\n if (!this.checkIsInside(e)) {\n if (this.removeMouseUp) {\n this.removeMouseUp();\n this.removeMouseUp = null;\n }\n\n document.addEventListener('mouseup', this.onMouseUp, useCapture);\n\n this.removeMouseUp = () => {\n document.removeEventListener('mouseup', this.onMouseUp, useCapture);\n };\n }\n });\n\n _defineProperty(this, \"onMouseUp\", e => {\n const {\n onOutsideClick\n } = this.props;\n\n if (this.removeMouseUp) {\n this.removeMouseUp();\n this.removeMouseUp = null;\n }\n\n if (!this.checkIsInside(e)) {\n onOutsideClick(e);\n }\n });\n\n _defineProperty(this, \"setChildNodeRef\", ref => {\n if (this.props.wrapperProps && this.props.wrapperProps.ref) {\n updateRef(this.props.wrapperProps.ref, ref);\n }\n\n updateRef(this.childNode, ref);\n });\n }\n\n componentDidMount() {\n const {\n disabled,\n useCapture\n } = this.props;\n if (!disabled) this.addMouseDownEventListener(useCapture);\n }\n\n UNSAFE_componentWillReceiveProps(_ref) {\n let {\n disabled,\n useCapture\n } = _ref;\n const {\n disabled: prevDisabled\n } = this.props;\n\n if (prevDisabled !== disabled) {\n if (disabled) {\n this.removeEventListeners();\n } else {\n this.addMouseDownEventListener(useCapture);\n }\n }\n }\n\n componentWillUnmount() {\n this.removeEventListeners();\n } // Use mousedown/mouseup to enforce that clicks remain outside the root's\n // descendant tree, even when dragged. This should also get triggered on\n // touch devices.\n\n\n addMouseDownEventListener(useCapture) {\n document.addEventListener('mousedown', this.onMouseDown, useCapture);\n\n this.removeMouseDown = () => {\n document.removeEventListener('mousedown', this.onMouseDown, useCapture);\n };\n }\n\n removeEventListeners() {\n if (this.removeMouseDown) this.removeMouseDown();\n if (this.removeMouseUp) this.removeMouseUp();\n }\n\n render() {\n const {\n children,\n display,\n className,\n wrapperProps\n } = this.props;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", _extends({\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()(className)\n }, wrapperProps || {}, {\n ref: this.setChildNodeRef\n }), children);\n }\n\n}\nOutsideClickHandler.defaultProps = defaultProps;//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiODIwNC5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vc3RhdGljL2pzL29wdGlvbnMvb3B0aW9ucy9yZWFjdC1vdXRzaWRlLWNsaWNrLWhhbmRsZXIuanM/YzNkZiJdLCJzb3VyY2VzQ29udGVudCI6WyJmdW5jdGlvbiBfZXh0ZW5kcygpIHsgX2V4dGVuZHMgPSBPYmplY3QuYXNzaWduID8gT2JqZWN0LmFzc2lnbi5iaW5kKCkgOiBmdW5jdGlvbiAodGFyZ2V0KSB7IGZvciAodmFyIGkgPSAxOyBpIDwgYXJndW1lbnRzLmxlbmd0aDsgaSsrKSB7IHZhciBzb3VyY2UgPSBhcmd1bWVudHNbaV07IGZvciAodmFyIGtleSBpbiBzb3VyY2UpIHsgaWYgKE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChzb3VyY2UsIGtleSkpIHsgdGFyZ2V0W2tleV0gPSBzb3VyY2Vba2V5XTsgfSB9IH0gcmV0dXJuIHRhcmdldDsgfTsgcmV0dXJuIF9leHRlbmRzLmFwcGx5KHRoaXMsIGFyZ3VtZW50cyk7IH1cblxuZnVuY3Rpb24gX2RlZmluZVByb3BlcnR5KG9iaiwga2V5LCB2YWx1ZSkgeyBpZiAoa2V5IGluIG9iaikgeyBPYmplY3QuZGVmaW5lUHJvcGVydHkob2JqLCBrZXksIHsgdmFsdWU6IHZhbHVlLCBlbnVtZXJhYmxlOiB0cnVlLCBjb25maWd1cmFibGU6IHRydWUsIHdyaXRhYmxlOiB0cnVlIH0pOyB9IGVsc2UgeyBvYmpba2V5XSA9IHZhbHVlOyB9IHJldHVybiBvYmo7IH1cblxuaW1wb3J0IHsgY3JlYXRlRWxlbWVudCwgQ29tcG9uZW50LCBGcmFnbWVudCwgY3JlYXRlUmVmIH0gZnJvbSAnQHdvcmRwcmVzcy9lbGVtZW50JztcbmltcG9ydCBjbHMgZnJvbSAnY2xhc3NuYW1lcyc7XG5jb25zdCBESVNQTEFZID0ge1xuICBCTE9DSzogJ2Jsb2NrJyxcbiAgRkxFWDogJ2ZsZXgnLFxuICBJTkxJTkVfQkxPQ0s6ICdpbmxpbmUtYmxvY2snXG59O1xuY29uc3QgZGVmYXVsdFByb3BzID0ge1xuICBkaXNhYmxlZDogZmFsc2UsXG4gIC8vIGB1c2VDYXB0dXJlYCBpcyBzZXQgdG8gdHJ1ZSBieSBkZWZhdWx0IHNvIHRoYXQgYSBgc3RvcFByb3BhZ2F0aW9uYCBpbiB0aGVcbiAgLy8gY2hpbGRyZW4gd2lsbCBub3QgcHJldmVudCBhbGwgb3V0c2lkZSBjbGljayBoYW5kbGVycyBmcm9tIGZpcmluZyAtIG1hamFcbiAgdXNlQ2FwdHVyZTogdHJ1ZSxcbiAgZGlzcGxheTogRElTUExBWS5CTE9DS1xufTtcblxuY29uc3QgdXBkYXRlUmVmID0gKHJlZiwgaW5zdGFuY2UpID0+IHtcbiAgaWYgKHR5cGVvZiByZWYgPT09ICdmdW5jdGlvbicpIHtcbiAgICByZWYoaW5zdGFuY2UpO1xuICB9IGVsc2Uge1xuICAgIHJlZi5jdXJyZW50ID0gaW5zdGFuY2U7XG4gIH1cbn07XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIE91dHNpZGVDbGlja0hhbmRsZXIgZXh0ZW5kcyBDb21wb25lbnQge1xuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlciguLi5hcmd1bWVudHMpO1xuXG4gICAgX2RlZmluZVByb3BlcnR5KHRoaXMsIFwiY2hpbGROb2RlXCIsIGNyZWF0ZVJlZigpKTtcblxuICAgIF9kZWZpbmVQcm9wZXJ0eSh0aGlzLCBcImNoZWNrSXNJbnNpZGVcIiwgZXZlbnQgPT4ge1xuICAgICAgY29uc3QgcmVzdWx0ID0gW3RoaXMuY2hpbGROb2RlLCAuLi4odGhpcy5wcm9wcy5hZGRpdGlvbmFsUmVmcyB8fCBbXSldLnJlZHVjZSgoaXNJbnNpZGUsIGN1cnJlbnRSZWYpID0+IHtcbiAgICAgICAgaWYgKGlzSW5zaWRlKSB7XG4gICAgICAgICAgcmV0dXJuIGlzSW5zaWRlO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKCFjdXJyZW50UmVmIHx8ICFjdXJyZW50UmVmLmN1cnJlbnQpIHtcbiAgICAgICAgICByZXR1cm4gaXNJbnNpZGU7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gY3VycmVudFJlZi5jdXJyZW50LmNvbnRhaW5zKGV2ZW50LnRhcmdldCk7XG4gICAgICB9LCBmYWxzZSk7XG4gICAgICByZXR1cm4gcmVzdWx0O1xuICAgIH0pO1xuXG4gICAgX2RlZmluZVByb3BlcnR5KHRoaXMsIFwib25Nb3VzZURvd25cIiwgZSA9PiB7XG4gICAgICBjb25zdCB7XG4gICAgICAgIHVzZUNhcHR1cmVcbiAgICAgIH0gPSB0aGlzLnByb3BzO1xuXG4gICAgICBpZiAoIXRoaXMuY2hlY2tJc0luc2lkZShlKSkge1xuICAgICAgICBpZiAodGhpcy5yZW1vdmVNb3VzZVVwKSB7XG4gICAgICAgICAgdGhpcy5yZW1vdmVNb3VzZVVwKCk7XG4gICAgICAgICAgdGhpcy5yZW1vdmVNb3VzZVVwID0gbnVsbDtcbiAgICAgICAgfVxuXG4gICAgICAgIGRvY3VtZW50LmFkZEV2ZW50TGlzdGVuZXIoJ21vdXNldXAnLCB0aGlzLm9uTW91c2VVcCwgdXNlQ2FwdHVyZSk7XG5cbiAgICAgICAgdGhpcy5yZW1vdmVNb3VzZVVwID0gKCkgPT4ge1xuICAgICAgICAgIGRvY3VtZW50LnJlbW92ZUV2ZW50TGlzdGVuZXIoJ21vdXNldXAnLCB0aGlzLm9uTW91c2VVcCwgdXNlQ2FwdHVyZSk7XG4gICAgICAgIH07XG4gICAgICB9XG4gICAgfSk7XG5cbiAgICBfZGVmaW5lUHJvcGVydHkodGhpcywgXCJvbk1vdXNlVXBcIiwgZSA9PiB7XG4gICAgICBjb25zdCB7XG4gICAgICAgIG9uT3V0c2lkZUNsaWNrXG4gICAgICB9ID0gdGhpcy5wcm9wcztcblxuICAgICAgaWYgKHRoaXMucmVtb3ZlTW91c2VVcCkge1xuICAgICAgICB0aGlzLnJlbW92ZU1vdXNlVXAoKTtcbiAgICAgICAgdGhpcy5yZW1vdmVNb3VzZVVwID0gbnVsbDtcbiAgICAgIH1cblxuICAgICAgaWYgKCF0aGlzLmNoZWNrSXNJbnNpZGUoZSkpIHtcbiAgICAgICAgb25PdXRzaWRlQ2xpY2soZSk7XG4gICAgICB9XG4gICAgfSk7XG5cbiAgICBfZGVmaW5lUHJvcGVydHkodGhpcywgXCJzZXRDaGlsZE5vZGVSZWZcIiwgcmVmID0+IHtcbiAgICAgIGlmICh0aGlzLnByb3BzLndyYXBwZXJQcm9wcyAmJiB0aGlzLnByb3BzLndyYXBwZXJQcm9wcy5yZWYpIHtcbiAgICAgICAgdXBkYXRlUmVmKHRoaXMucHJvcHMud3JhcHBlclByb3BzLnJlZiwgcmVmKTtcbiAgICAgIH1cblxuICAgICAgdXBkYXRlUmVmKHRoaXMuY2hpbGROb2RlLCByZWYpO1xuICAgIH0pO1xuICB9XG5cbiAgY29tcG9uZW50RGlkTW91bnQoKSB7XG4gICAgY29uc3Qge1xuICAgICAgZGlzYWJsZWQsXG4gICAgICB1c2VDYXB0dXJlXG4gICAgfSA9IHRoaXMucHJvcHM7XG4gICAgaWYgKCFkaXNhYmxlZCkgdGhpcy5hZGRNb3VzZURvd25FdmVudExpc3RlbmVyKHVzZUNhcHR1cmUpO1xuICB9XG5cbiAgVU5TQUZFX2NvbXBvbmVudFdpbGxSZWNlaXZlUHJvcHMoX3JlZikge1xuICAgIGxldCB7XG4gICAgICBkaXNhYmxlZCxcbiAgICAgIHVzZUNhcHR1cmVcbiAgICB9ID0gX3JlZjtcbiAgICBjb25zdCB7XG4gICAgICBkaXNhYmxlZDogcHJldkRpc2FibGVkXG4gICAgfSA9IHRoaXMucHJvcHM7XG5cbiAgICBpZiAocHJldkRpc2FibGVkICE9PSBkaXNhYmxlZCkge1xuICAgICAgaWYgKGRpc2FibGVkKSB7XG4gICAgICAgIHRoaXMucmVtb3ZlRXZlbnRMaXN0ZW5lcnMoKTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHRoaXMuYWRkTW91c2VEb3duRXZlbnRMaXN0ZW5lcih1c2VDYXB0dXJlKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBjb21wb25lbnRXaWxsVW5tb3VudCgpIHtcbiAgICB0aGlzLnJlbW92ZUV2ZW50TGlzdGVuZXJzKCk7XG4gIH0gLy8gVXNlIG1vdXNlZG93bi9tb3VzZXVwIHRvIGVuZm9yY2UgdGhhdCBjbGlja3MgcmVtYWluIG91dHNpZGUgdGhlIHJvb3Qnc1xuICAvLyBkZXNjZW5kYW50IHRyZWUsIGV2ZW4gd2hlbiBkcmFnZ2VkLiBUaGlzIHNob3VsZCBhbHNvIGdldCB0cmlnZ2VyZWQgb25cbiAgLy8gdG91Y2ggZGV2aWNlcy5cblxuXG4gIGFkZE1vdXNlRG93bkV2ZW50TGlzdGVuZXIodXNlQ2FwdHVyZSkge1xuICAgIGRvY3VtZW50LmFkZEV2ZW50TGlzdGVuZXIoJ21vdXNlZG93bicsIHRoaXMub25Nb3VzZURvd24sIHVzZUNhcHR1cmUpO1xuXG4gICAgdGhpcy5yZW1vdmVNb3VzZURvd24gPSAoKSA9PiB7XG4gICAgICBkb2N1bWVudC5yZW1vdmVFdmVudExpc3RlbmVyKCdtb3VzZWRvd24nLCB0aGlzLm9uTW91c2VEb3duLCB1c2VDYXB0dXJlKTtcbiAgICB9O1xuICB9XG5cbiAgcmVtb3ZlRXZlbnRMaXN0ZW5lcnMoKSB7XG4gICAgaWYgKHRoaXMucmVtb3ZlTW91c2VEb3duKSB0aGlzLnJlbW92ZU1vdXNlRG93bigpO1xuICAgIGlmICh0aGlzLnJlbW92ZU1vdXNlVXApIHRoaXMucmVtb3ZlTW91c2VVcCgpO1xuICB9XG5cbiAgcmVuZGVyKCkge1xuICAgIGNvbnN0IHtcbiAgICAgIGNoaWxkcmVuLFxuICAgICAgZGlzcGxheSxcbiAgICAgIGNsYXNzTmFtZSxcbiAgICAgIHdyYXBwZXJQcm9wc1xuICAgIH0gPSB0aGlzLnByb3BzO1xuICAgIHJldHVybiBjcmVhdGVFbGVtZW50KFwiZGl2XCIsIF9leHRlbmRzKHtcbiAgICAgIGNsYXNzTmFtZTogY2xzKGNsYXNzTmFtZSlcbiAgICB9LCB3cmFwcGVyUHJvcHMgfHwge30sIHtcbiAgICAgIHJlZjogdGhpcy5zZXRDaGlsZE5vZGVSZWZcbiAgICB9KSwgY2hpbGRyZW4pO1xuICB9XG5cbn1cbk91dHNpZGVDbGlja0hhbmRsZXIuZGVmYXVsdFByb3BzID0gZGVmYXVsdFByb3BzOyJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///8204\n")},977:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\nconst Text = _ref => {\n let {\n value,\n option,\n onChange\n } = _ref;\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", {\n className: "ct-option-input"\n }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("input", _extends({\n type: "text",\n value: value\n }, _objectSpread(_objectSpread({}, option.field_attr ? option.field_attr : {}), option.attr && option.attr.placeholder ? {\n placeholder: option.attr.placeholder\n } : {}), {\n onChange: _ref2 => {\n let {\n target: {\n value\n }\n } = _ref2;\n return onChange(value);\n }\n }, option.select_on_focus ? {\n onFocus: _ref3 => {\n let {\n target\n } = _ref3;\n return target.select();\n }\n } : {})));\n};\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Text);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiOTc3LmpzIiwibWFwcGluZ3MiOiI7Ozs7OztBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9zdGF0aWMvanMvb3B0aW9ucy9vcHRpb25zL3RleHQuanM/Y2Q4ZCJdLCJzb3VyY2VzQ29udGVudCI6WyJmdW5jdGlvbiBfZXh0ZW5kcygpIHsgX2V4dGVuZHMgPSBPYmplY3QuYXNzaWduID8gT2JqZWN0LmFzc2lnbi5iaW5kKCkgOiBmdW5jdGlvbiAodGFyZ2V0KSB7IGZvciAodmFyIGkgPSAxOyBpIDwgYXJndW1lbnRzLmxlbmd0aDsgaSsrKSB7IHZhciBzb3VyY2UgPSBhcmd1bWVudHNbaV07IGZvciAodmFyIGtleSBpbiBzb3VyY2UpIHsgaWYgKE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChzb3VyY2UsIGtleSkpIHsgdGFyZ2V0W2tleV0gPSBzb3VyY2Vba2V5XTsgfSB9IH0gcmV0dXJuIHRhcmdldDsgfTsgcmV0dXJuIF9leHRlbmRzLmFwcGx5KHRoaXMsIGFyZ3VtZW50cyk7IH1cblxuZnVuY3Rpb24gb3duS2V5cyhvYmplY3QsIGVudW1lcmFibGVPbmx5KSB7IHZhciBrZXlzID0gT2JqZWN0LmtleXMob2JqZWN0KTsgaWYgKE9iamVjdC5nZXRPd25Qcm9wZXJ0eVN5bWJvbHMpIHsgdmFyIHN5bWJvbHMgPSBPYmplY3QuZ2V0T3duUHJvcGVydHlTeW1ib2xzKG9iamVjdCk7IGVudW1lcmFibGVPbmx5ICYmIChzeW1ib2xzID0gc3ltYm9scy5maWx0ZXIoZnVuY3Rpb24gKHN5bSkgeyByZXR1cm4gT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcihvYmplY3QsIHN5bSkuZW51bWVyYWJsZTsgfSkpLCBrZXlzLnB1c2guYXBwbHkoa2V5cywgc3ltYm9scyk7IH0gcmV0dXJuIGtleXM7IH1cblxuZnVuY3Rpb24gX29iamVjdFNwcmVhZCh0YXJnZXQpIHsgZm9yICh2YXIgaSA9IDE7IGkgPCBhcmd1bWVudHMubGVuZ3RoOyBpKyspIHsgdmFyIHNvdXJjZSA9IG51bGwgIT0gYXJndW1lbnRzW2ldID8gYXJndW1lbnRzW2ldIDoge307IGkgJSAyID8gb3duS2V5cyhPYmplY3Qoc291cmNlKSwgITApLmZvckVhY2goZnVuY3Rpb24gKGtleSkgeyBfZGVmaW5lUHJvcGVydHkodGFyZ2V0LCBrZXksIHNvdXJjZVtrZXldKTsgfSkgOiBPYmplY3QuZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9ycyA/IE9iamVjdC5kZWZpbmVQcm9wZXJ0aWVzKHRhcmdldCwgT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcnMoc291cmNlKSkgOiBvd25LZXlzKE9iamVjdChzb3VyY2UpKS5mb3JFYWNoKGZ1bmN0aW9uIChrZXkpIHsgT2JqZWN0LmRlZmluZVByb3BlcnR5KHRhcmdldCwga2V5LCBPYmplY3QuZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9yKHNvdXJjZSwga2V5KSk7IH0pOyB9IHJldHVybiB0YXJnZXQ7IH1cblxuZnVuY3Rpb24gX2RlZmluZVByb3BlcnR5KG9iaiwga2V5LCB2YWx1ZSkgeyBpZiAoa2V5IGluIG9iaikgeyBPYmplY3QuZGVmaW5lUHJvcGVydHkob2JqLCBrZXksIHsgdmFsdWU6IHZhbHVlLCBlbnVtZXJhYmxlOiB0cnVlLCBjb25maWd1cmFibGU6IHRydWUsIHdyaXRhYmxlOiB0cnVlIH0pOyB9IGVsc2UgeyBvYmpba2V5XSA9IHZhbHVlOyB9IHJldHVybiBvYmo7IH1cblxuaW1wb3J0IHsgY3JlYXRlRWxlbWVudCB9IGZyb20gJ0B3b3JkcHJlc3MvZWxlbWVudCc7XG5cbmNvbnN0IFRleHQgPSBfcmVmID0+IHtcbiAgbGV0IHtcbiAgICB2YWx1ZSxcbiAgICBvcHRpb24sXG4gICAgb25DaGFuZ2VcbiAgfSA9IF9yZWY7XG4gIHJldHVybiBjcmVhdGVFbGVtZW50KFwiZGl2XCIsIHtcbiAgICBjbGFzc05hbWU6IFwiY3Qtb3B0aW9uLWlucHV0XCJcbiAgfSwgY3JlYXRlRWxlbWVudChcImlucHV0XCIsIF9leHRlbmRzKHtcbiAgICB0eXBlOiBcInRleHRcIixcbiAgICB2YWx1ZTogdmFsdWVcbiAgfSwgX29iamVjdFNwcmVhZChfb2JqZWN0U3ByZWFkKHt9LCBvcHRpb24uZmllbGRfYXR0ciA/IG9wdGlvbi5maWVsZF9hdHRyIDoge30pLCBvcHRpb24uYXR0ciAmJiBvcHRpb24uYXR0ci5wbGFjZWhvbGRlciA/IHtcbiAgICBwbGFjZWhvbGRlcjogb3B0aW9uLmF0dHIucGxhY2Vob2xkZXJcbiAgfSA6IHt9KSwge1xuICAgIG9uQ2hhbmdlOiBfcmVmMiA9PiB7XG4gICAgICBsZXQge1xuICAgICAgICB0YXJnZXQ6IHtcbiAgICAgICAgICB2YWx1ZVxuICAgICAgICB9XG4gICAgICB9ID0gX3JlZjI7XG4gICAgICByZXR1cm4gb25DaGFuZ2UodmFsdWUpO1xuICAgIH1cbiAgfSwgb3B0aW9uLnNlbGVjdF9vbl9mb2N1cyA/IHtcbiAgICBvbkZvY3VzOiBfcmVmMyA9PiB7XG4gICAgICBsZXQge1xuICAgICAgICB0YXJnZXRcbiAgICAgIH0gPSBfcmVmMztcbiAgICAgIHJldHVybiB0YXJnZXQuc2VsZWN0KCk7XG4gICAgfVxuICB9IDoge30pKSk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBUZXh0OyJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///977\n')},1323:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\nconst _excluded = ["placeholder"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\n\n\nconst TextArea = _ref => {\n let {\n value,\n option,\n onChange\n } = _ref;\n\n let _ref2 = _objectSpread({}, option.attr || {}),\n {\n placeholder\n } = _ref2,\n attr = _objectWithoutProperties(_ref2, _excluded);\n\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", _extends({\n className: "ct-option-textarea"\n }, attr), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("textarea", _extends({\n value: value\n }, _objectSpread(_objectSpread({}, option.field_attr ? option.field_attr : {}), placeholder ? {\n placeholder\n } : {}), {\n onChange: _ref3 => {\n let {\n target: {\n value\n }\n } = _ref3;\n return onChange(value);\n }\n })));\n};\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (TextArea);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTMyMy5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9ibG9ja3N5T3B0aW9ucy8uL3N0YXRpYy9qcy9vcHRpb25zL29wdGlvbnMvdGV4dGFyZWEuanM/Y2NhZCJdLCJzb3VyY2VzQ29udGVudCI6WyJjb25zdCBfZXhjbHVkZWQgPSBbXCJwbGFjZWhvbGRlclwiXTtcblxuZnVuY3Rpb24gX2V4dGVuZHMoKSB7IF9leHRlbmRzID0gT2JqZWN0LmFzc2lnbiA/IE9iamVjdC5hc3NpZ24uYmluZCgpIDogZnVuY3Rpb24gKHRhcmdldCkgeyBmb3IgKHZhciBpID0gMTsgaSA8IGFyZ3VtZW50cy5sZW5ndGg7IGkrKykgeyB2YXIgc291cmNlID0gYXJndW1lbnRzW2ldOyBmb3IgKHZhciBrZXkgaW4gc291cmNlKSB7IGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwoc291cmNlLCBrZXkpKSB7IHRhcmdldFtrZXldID0gc291cmNlW2tleV07IH0gfSB9IHJldHVybiB0YXJnZXQ7IH07IHJldHVybiBfZXh0ZW5kcy5hcHBseSh0aGlzLCBhcmd1bWVudHMpOyB9XG5cbmZ1bmN0aW9uIG93bktleXMob2JqZWN0LCBlbnVtZXJhYmxlT25seSkgeyB2YXIga2V5cyA9IE9iamVjdC5rZXlzKG9iamVjdCk7IGlmIChPYmplY3QuZ2V0T3duUHJvcGVydHlTeW1ib2xzKSB7IHZhciBzeW1ib2xzID0gT2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9scyhvYmplY3QpOyBlbnVtZXJhYmxlT25seSAmJiAoc3ltYm9scyA9IHN5bWJvbHMuZmlsdGVyKGZ1bmN0aW9uIChzeW0pIHsgcmV0dXJuIE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3Iob2JqZWN0LCBzeW0pLmVudW1lcmFibGU7IH0pKSwga2V5cy5wdXNoLmFwcGx5KGtleXMsIHN5bWJvbHMpOyB9IHJldHVybiBrZXlzOyB9XG5cbmZ1bmN0aW9uIF9vYmplY3RTcHJlYWQodGFyZ2V0KSB7IGZvciAodmFyIGkgPSAxOyBpIDwgYXJndW1lbnRzLmxlbmd0aDsgaSsrKSB7IHZhciBzb3VyY2UgPSBudWxsICE9IGFyZ3VtZW50c1tpXSA/IGFyZ3VtZW50c1tpXSA6IHt9OyBpICUgMiA/IG93bktleXMoT2JqZWN0KHNvdXJjZSksICEwKS5mb3JFYWNoKGZ1bmN0aW9uIChrZXkpIHsgX2RlZmluZVByb3BlcnR5KHRhcmdldCwga2V5LCBzb3VyY2Vba2V5XSk7IH0pIDogT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcnMgPyBPYmplY3QuZGVmaW5lUHJvcGVydGllcyh0YXJnZXQsIE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3JzKHNvdXJjZSkpIDogb3duS2V5cyhPYmplY3Qoc291cmNlKSkuZm9yRWFjaChmdW5jdGlvbiAoa2V5KSB7IE9iamVjdC5kZWZpbmVQcm9wZXJ0eSh0YXJnZXQsIGtleSwgT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcihzb3VyY2UsIGtleSkpOyB9KTsgfSByZXR1cm4gdGFyZ2V0OyB9XG5cbmZ1bmN0aW9uIF9kZWZpbmVQcm9wZXJ0eShvYmosIGtleSwgdmFsdWUpIHsgaWYgKGtleSBpbiBvYmopIHsgT2JqZWN0LmRlZmluZVByb3BlcnR5KG9iaiwga2V5LCB7IHZhbHVlOiB2YWx1ZSwgZW51bWVyYWJsZTogdHJ1ZSwgY29uZmlndXJhYmxlOiB0cnVlLCB3cml0YWJsZTogdHJ1ZSB9KTsgfSBlbHNlIHsgb2JqW2tleV0gPSB2YWx1ZTsgfSByZXR1cm4gb2JqOyB9XG5cbmZ1bmN0aW9uIF9vYmplY3RXaXRob3V0UHJvcGVydGllcyhzb3VyY2UsIGV4Y2x1ZGVkKSB7IGlmIChzb3VyY2UgPT0gbnVsbCkgcmV0dXJuIHt9OyB2YXIgdGFyZ2V0ID0gX29iamVjdFdpdGhvdXRQcm9wZXJ0aWVzTG9vc2Uoc291cmNlLCBleGNsdWRlZCk7IHZhciBrZXksIGk7IGlmIChPYmplY3QuZ2V0T3duUHJvcGVydHlTeW1ib2xzKSB7IHZhciBzb3VyY2VTeW1ib2xLZXlzID0gT2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9scyhzb3VyY2UpOyBmb3IgKGkgPSAwOyBpIDwgc291cmNlU3ltYm9sS2V5cy5sZW5ndGg7IGkrKykgeyBrZXkgPSBzb3VyY2VTeW1ib2xLZXlzW2ldOyBpZiAoZXhjbHVkZWQuaW5kZXhPZihrZXkpID49IDApIGNvbnRpbnVlOyBpZiAoIU9iamVjdC5wcm90b3R5cGUucHJvcGVydHlJc0VudW1lcmFibGUuY2FsbChzb3VyY2UsIGtleSkpIGNvbnRpbnVlOyB0YXJnZXRba2V5XSA9IHNvdXJjZVtrZXldOyB9IH0gcmV0dXJuIHRhcmdldDsgfVxuXG5mdW5jdGlvbiBfb2JqZWN0V2l0aG91dFByb3BlcnRpZXNMb29zZShzb3VyY2UsIGV4Y2x1ZGVkKSB7IGlmIChzb3VyY2UgPT0gbnVsbCkgcmV0dXJuIHt9OyB2YXIgdGFyZ2V0ID0ge307IHZhciBzb3VyY2VLZXlzID0gT2JqZWN0LmtleXMoc291cmNlKTsgdmFyIGtleSwgaTsgZm9yIChpID0gMDsgaSA8IHNvdXJjZUtleXMubGVuZ3RoOyBpKyspIHsga2V5ID0gc291cmNlS2V5c1tpXTsgaWYgKGV4Y2x1ZGVkLmluZGV4T2Yoa2V5KSA+PSAwKSBjb250aW51ZTsgdGFyZ2V0W2tleV0gPSBzb3VyY2Vba2V5XTsgfSByZXR1cm4gdGFyZ2V0OyB9XG5cbmltcG9ydCB7IGNyZWF0ZUVsZW1lbnQsIENvbXBvbmVudCB9IGZyb20gJ0B3b3JkcHJlc3MvZWxlbWVudCc7XG5cbmNvbnN0IFRleHRBcmVhID0gX3JlZiA9PiB7XG4gIGxldCB7XG4gICAgdmFsdWUsXG4gICAgb3B0aW9uLFxuICAgIG9uQ2hhbmdlXG4gIH0gPSBfcmVmO1xuXG4gIGxldCBfcmVmMiA9IF9vYmplY3RTcHJlYWQoe30sIG9wdGlvbi5hdHRyIHx8IHt9KSxcbiAgICAgIHtcbiAgICBwbGFjZWhvbGRlclxuICB9ID0gX3JlZjIsXG4gICAgICBhdHRyID0gX29iamVjdFdpdGhvdXRQcm9wZXJ0aWVzKF9yZWYyLCBfZXhjbHVkZWQpO1xuXG4gIHJldHVybiBjcmVhdGVFbGVtZW50KFwiZGl2XCIsIF9leHRlbmRzKHtcbiAgICBjbGFzc05hbWU6IFwiY3Qtb3B0aW9uLXRleHRhcmVhXCJcbiAgfSwgYXR0ciksIGNyZWF0ZUVsZW1lbnQoXCJ0ZXh0YXJlYVwiLCBfZXh0ZW5kcyh7XG4gICAgdmFsdWU6IHZhbHVlXG4gIH0sIF9vYmplY3RTcHJlYWQoX29iamVjdFNwcmVhZCh7fSwgb3B0aW9uLmZpZWxkX2F0dHIgPyBvcHRpb24uZmllbGRfYXR0ciA6IHt9KSwgcGxhY2Vob2xkZXIgPyB7XG4gICAgcGxhY2Vob2xkZXJcbiAgfSA6IHt9KSwge1xuICAgIG9uQ2hhbmdlOiBfcmVmMyA9PiB7XG4gICAgICBsZXQge1xuICAgICAgICB0YXJnZXQ6IHtcbiAgICAgICAgICB2YWx1ZVxuICAgICAgICB9XG4gICAgICB9ID0gX3JlZjM7XG4gICAgICByZXR1cm4gb25DaGFuZ2UodmFsdWUpO1xuICAgIH1cbiAgfSkpKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IFRleHRBcmVhOyJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///1323\n')},9313:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1381);\n/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var md5__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(2568);\n/* harmony import */ var md5__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(md5__WEBPACK_IMPORTED_MODULE_1__);\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\nconst TextArea = _ref => {\n let {\n id,\n value,\n option,\n onChange\n } = _ref;\n const el = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useRef)();\n const editor = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useRef)(null);\n const [editorId, _] = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useState)(`${id}-${md5__WEBPACK_IMPORTED_MODULE_1___default()(Math.random() + '-' + Math.random() + '-' + Math.random())}`);\n\n const correctEditor = () => wp.oldEditor || wp.editor;\n\n const listener = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useCallback)(() => onChange(correctEditor().getContent(editorId)), [editorId]);\n (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useEffect)(() => {\n correctEditor().initialize(editorId, _objectSpread(_objectSpread({\n quicktags: true,\n mediaButtons: true\n }, option), {}, {\n tinymce: _objectSpread(_objectSpread({\n toolbar1: 'formatselect,styleselect,bold,italic,bullist,numlist,link,alignleft,aligncenter,alignright,wp_adv',\n toolbar2: 'strikethrough,hr,forecolor,pastetext,removeformat,charmap,outdent,indent,undo,redo,wp_help'\n }, typeof option.tinymce === 'object' ? option.tinymce : {}), {}, {\n style_formats_merge: true,\n style_formats: []\n })\n }));\n setTimeout(() => window.tinymce.editors[editorId] && window.tinymce.editors[editorId].on('change', listener));\n\n if (wp.oldEditor) {\n setTimeout(() => {\n setTimeout(() => {\n window.tinymce.editors[editorId].off('change', listener);\n correctEditor().remove(editorId);\n correctEditor().initialize(editorId, _objectSpread(_objectSpread({\n quicktags: true,\n mediaButtons: true\n }, option), {}, {\n tinymce: _objectSpread(_objectSpread({\n toolbar1: 'formatselect,styleselect,bold,italic,bullist,numlist,link,alignleft,aligncenter,alignright,wp_adv',\n toolbar2: 'strikethrough,hr,forecolor,pastetext,removeformat,charmap,outdent,indent,undo,redo,wp_help'\n }, typeof option.tinymce === 'object' ? option.tinymce : {}), {}, {\n style_formats_merge: true,\n style_formats: []\n })\n }));\n setTimeout(() => window.tinymce.editors[editorId] && window.tinymce.editors[editorId].on('change', listener));\n }, 300);\n }, 1000);\n }\n\n return () => {\n if (!window.tinymce.editors[editorId]) return;\n setTimeout(() => {\n window.tinymce.editors[editorId].off('change', listener);\n correctEditor().remove(editorId);\n }, 300);\n };\n }, []);\n return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"div\", _extends({\n className: \"ct-option-editor\"\n }, option.attr || {}), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(\"textarea\", _extends({\n style: {\n opacity: 0\n },\n id: editorId,\n ref: el,\n value: value,\n className: \"wp-editor-area\"\n }, _objectSpread(_objectSpread({}, option.field_attr ? option.field_attr : {}), option.attr && option.attr.placeholder ? {\n placeholder: option.attr.placeholder\n } : {}), {\n onChange: _ref2 => {\n let {\n target: {\n value\n }\n } = _ref2;\n return onChange(value);\n }\n })));\n};\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (TextArea);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiOTMxMy5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9ibG9ja3N5T3B0aW9ucy8uL3N0YXRpYy9qcy9vcHRpb25zL29wdGlvbnMvd3AtZWRpdG9yLmpzP2Q0Y2YiXSwic291cmNlc0NvbnRlbnQiOlsiZnVuY3Rpb24gX2V4dGVuZHMoKSB7IF9leHRlbmRzID0gT2JqZWN0LmFzc2lnbiA/IE9iamVjdC5hc3NpZ24uYmluZCgpIDogZnVuY3Rpb24gKHRhcmdldCkgeyBmb3IgKHZhciBpID0gMTsgaSA8IGFyZ3VtZW50cy5sZW5ndGg7IGkrKykgeyB2YXIgc291cmNlID0gYXJndW1lbnRzW2ldOyBmb3IgKHZhciBrZXkgaW4gc291cmNlKSB7IGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwoc291cmNlLCBrZXkpKSB7IHRhcmdldFtrZXldID0gc291cmNlW2tleV07IH0gfSB9IHJldHVybiB0YXJnZXQ7IH07IHJldHVybiBfZXh0ZW5kcy5hcHBseSh0aGlzLCBhcmd1bWVudHMpOyB9XG5cbmZ1bmN0aW9uIG93bktleXMob2JqZWN0LCBlbnVtZXJhYmxlT25seSkgeyB2YXIga2V5cyA9IE9iamVjdC5rZXlzKG9iamVjdCk7IGlmIChPYmplY3QuZ2V0T3duUHJvcGVydHlTeW1ib2xzKSB7IHZhciBzeW1ib2xzID0gT2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9scyhvYmplY3QpOyBlbnVtZXJhYmxlT25seSAmJiAoc3ltYm9scyA9IHN5bWJvbHMuZmlsdGVyKGZ1bmN0aW9uIChzeW0pIHsgcmV0dXJuIE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3Iob2JqZWN0LCBzeW0pLmVudW1lcmFibGU7IH0pKSwga2V5cy5wdXNoLmFwcGx5KGtleXMsIHN5bWJvbHMpOyB9IHJldHVybiBrZXlzOyB9XG5cbmZ1bmN0aW9uIF9vYmplY3RTcHJlYWQodGFyZ2V0KSB7IGZvciAodmFyIGkgPSAxOyBpIDwgYXJndW1lbnRzLmxlbmd0aDsgaSsrKSB7IHZhciBzb3VyY2UgPSBudWxsICE9IGFyZ3VtZW50c1tpXSA/IGFyZ3VtZW50c1tpXSA6IHt9OyBpICUgMiA/IG93bktleXMoT2JqZWN0KHNvdXJjZSksICEwKS5mb3JFYWNoKGZ1bmN0aW9uIChrZXkpIHsgX2RlZmluZVByb3BlcnR5KHRhcmdldCwga2V5LCBzb3VyY2Vba2V5XSk7IH0pIDogT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcnMgPyBPYmplY3QuZGVmaW5lUHJvcGVydGllcyh0YXJnZXQsIE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3JzKHNvdXJjZSkpIDogb3duS2V5cyhPYmplY3Qoc291cmNlKSkuZm9yRWFjaChmdW5jdGlvbiAoa2V5KSB7IE9iamVjdC5kZWZpbmVQcm9wZXJ0eSh0YXJnZXQsIGtleSwgT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcihzb3VyY2UsIGtleSkpOyB9KTsgfSByZXR1cm4gdGFyZ2V0OyB9XG5cbmZ1bmN0aW9uIF9kZWZpbmVQcm9wZXJ0eShvYmosIGtleSwgdmFsdWUpIHsgaWYgKGtleSBpbiBvYmopIHsgT2JqZWN0LmRlZmluZVByb3BlcnR5KG9iaiwga2V5LCB7IHZhbHVlOiB2YWx1ZSwgZW51bWVyYWJsZTogdHJ1ZSwgY29uZmlndXJhYmxlOiB0cnVlLCB3cml0YWJsZTogdHJ1ZSB9KTsgfSBlbHNlIHsgb2JqW2tleV0gPSB2YWx1ZTsgfSByZXR1cm4gb2JqOyB9XG5cbmltcG9ydCB7IGNyZWF0ZUVsZW1lbnQsIHVzZVJlZiwgdXNlU3RhdGUsIHVzZUVmZmVjdCwgdXNlQ2FsbGJhY2sgfSBmcm9tICdAd29yZHByZXNzL2VsZW1lbnQnO1xuaW1wb3J0IG1kNSBmcm9tICdtZDUnO1xuXG5jb25zdCBUZXh0QXJlYSA9IF9yZWYgPT4ge1xuICBsZXQge1xuICAgIGlkLFxuICAgIHZhbHVlLFxuICAgIG9wdGlvbixcbiAgICBvbkNoYW5nZVxuICB9ID0gX3JlZjtcbiAgY29uc3QgZWwgPSB1c2VSZWYoKTtcbiAgY29uc3QgZWRpdG9yID0gdXNlUmVmKG51bGwpO1xuICBjb25zdCBbZWRpdG9ySWQsIF9dID0gdXNlU3RhdGUoYCR7aWR9LSR7bWQ1KE1hdGgucmFuZG9tKCkgKyAnLScgKyBNYXRoLnJhbmRvbSgpICsgJy0nICsgTWF0aC5yYW5kb20oKSl9YCk7XG5cbiAgY29uc3QgY29ycmVjdEVkaXRvciA9ICgpID0+IHdwLm9sZEVkaXRvciB8fCB3cC5lZGl0b3I7XG5cbiAgY29uc3QgbGlzdGVuZXIgPSB1c2VDYWxsYmFjaygoKSA9PiBvbkNoYW5nZShjb3JyZWN0RWRpdG9yKCkuZ2V0Q29udGVudChlZGl0b3JJZCkpLCBbZWRpdG9ySWRdKTtcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBjb3JyZWN0RWRpdG9yKCkuaW5pdGlhbGl6ZShlZGl0b3JJZCwgX29iamVjdFNwcmVhZChfb2JqZWN0U3ByZWFkKHtcbiAgICAgIHF1aWNrdGFnczogdHJ1ZSxcbiAgICAgIG1lZGlhQnV0dG9uczogdHJ1ZVxuICAgIH0sIG9wdGlvbiksIHt9LCB7XG4gICAgICB0aW55bWNlOiBfb2JqZWN0U3ByZWFkKF9vYmplY3RTcHJlYWQoe1xuICAgICAgICB0b29sYmFyMTogJ2Zvcm1hdHNlbGVjdCxzdHlsZXNlbGVjdCxib2xkLGl0YWxpYyxidWxsaXN0LG51bWxpc3QsbGluayxhbGlnbmxlZnQsYWxpZ25jZW50ZXIsYWxpZ25yaWdodCx3cF9hZHYnLFxuICAgICAgICB0b29sYmFyMjogJ3N0cmlrZXRocm91Z2gsaHIsZm9yZWNvbG9yLHBhc3RldGV4dCxyZW1vdmVmb3JtYXQsY2hhcm1hcCxvdXRkZW50LGluZGVudCx1bmRvLHJlZG8sd3BfaGVscCdcbiAgICAgIH0sIHR5cGVvZiBvcHRpb24udGlueW1jZSA9PT0gJ29iamVjdCcgPyBvcHRpb24udGlueW1jZSA6IHt9KSwge30sIHtcbiAgICAgICAgc3R5bGVfZm9ybWF0c19tZXJnZTogdHJ1ZSxcbiAgICAgICAgc3R5bGVfZm9ybWF0czogW11cbiAgICAgIH0pXG4gICAgfSkpO1xuICAgIHNldFRpbWVvdXQoKCkgPT4gd2luZG93LnRpbnltY2UuZWRpdG9yc1tlZGl0b3JJZF0gJiYgd2luZG93LnRpbnltY2UuZWRpdG9yc1tlZGl0b3JJZF0ub24oJ2NoYW5nZScsIGxpc3RlbmVyKSk7XG5cbiAgICBpZiAod3Aub2xkRWRpdG9yKSB7XG4gICAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgICAgd2luZG93LnRpbnltY2UuZWRpdG9yc1tlZGl0b3JJZF0ub2ZmKCdjaGFuZ2UnLCBsaXN0ZW5lcik7XG4gICAgICAgICAgY29ycmVjdEVkaXRvcigpLnJlbW92ZShlZGl0b3JJZCk7XG4gICAgICAgICAgY29ycmVjdEVkaXRvcigpLmluaXRpYWxpemUoZWRpdG9ySWQsIF9vYmplY3RTcHJlYWQoX29iamVjdFNwcmVhZCh7XG4gICAgICAgICAgICBxdWlja3RhZ3M6IHRydWUsXG4gICAgICAgICAgICBtZWRpYUJ1dHRvbnM6IHRydWVcbiAgICAgICAgICB9LCBvcHRpb24pLCB7fSwge1xuICAgICAgICAgICAgdGlueW1jZTogX29iamVjdFNwcmVhZChfb2JqZWN0U3ByZWFkKHtcbiAgICAgICAgICAgICAgdG9vbGJhcjE6ICdmb3JtYXRzZWxlY3Qsc3R5bGVzZWxlY3QsYm9sZCxpdGFsaWMsYnVsbGlzdCxudW1saXN0LGxpbmssYWxpZ25sZWZ0LGFsaWduY2VudGVyLGFsaWducmlnaHQsd3BfYWR2JyxcbiAgICAgICAgICAgICAgdG9vbGJhcjI6ICdzdHJpa2V0aHJvdWdoLGhyLGZvcmVjb2xvcixwYXN0ZXRleHQscmVtb3ZlZm9ybWF0LGNoYXJtYXAsb3V0ZGVudCxpbmRlbnQsdW5kbyxyZWRvLHdwX2hlbHAnXG4gICAgICAgICAgICB9LCB0eXBlb2Ygb3B0aW9uLnRpbnltY2UgPT09ICdvYmplY3QnID8gb3B0aW9uLnRpbnltY2UgOiB7fSksIHt9LCB7XG4gICAgICAgICAgICAgIHN0eWxlX2Zvcm1hdHNfbWVyZ2U6IHRydWUsXG4gICAgICAgICAgICAgIHN0eWxlX2Zvcm1hdHM6IFtdXG4gICAgICAgICAgICB9KVxuICAgICAgICAgIH0pKTtcbiAgICAgICAgICBzZXRUaW1lb3V0KCgpID0+IHdpbmRvdy50aW55bWNlLmVkaXRvcnNbZWRpdG9ySWRdICYmIHdpbmRvdy50aW55bWNlLmVkaXRvcnNbZWRpdG9ySWRdLm9uKCdjaGFuZ2UnLCBsaXN0ZW5lcikpO1xuICAgICAgICB9LCAzMDApO1xuICAgICAgfSwgMTAwMCk7XG4gICAgfVxuXG4gICAgcmV0dXJuICgpID0+IHtcbiAgICAgIGlmICghd2luZG93LnRpbnltY2UuZWRpdG9yc1tlZGl0b3JJZF0pIHJldHVybjtcbiAgICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgICB3aW5kb3cudGlueW1jZS5lZGl0b3JzW2VkaXRvcklkXS5vZmYoJ2NoYW5nZScsIGxpc3RlbmVyKTtcbiAgICAgICAgY29ycmVjdEVkaXRvcigpLnJlbW92ZShlZGl0b3JJZCk7XG4gICAgICB9LCAzMDApO1xuICAgIH07XG4gIH0sIFtdKTtcbiAgcmV0dXJuIGNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwgX2V4dGVuZHMoe1xuICAgIGNsYXNzTmFtZTogXCJjdC1vcHRpb24tZWRpdG9yXCJcbiAgfSwgb3B0aW9uLmF0dHIgfHwge30pLCBjcmVhdGVFbGVtZW50KFwidGV4dGFyZWFcIiwgX2V4dGVuZHMoe1xuICAgIHN0eWxlOiB7XG4gICAgICBvcGFjaXR5OiAwXG4gICAgfSxcbiAgICBpZDogZWRpdG9ySWQsXG4gICAgcmVmOiBlbCxcbiAgICB2YWx1ZTogdmFsdWUsXG4gICAgY2xhc3NOYW1lOiBcIndwLWVkaXRvci1hcmVhXCJcbiAgfSwgX29iamVjdFNwcmVhZChfb2JqZWN0U3ByZWFkKHt9LCBvcHRpb24uZmllbGRfYXR0ciA/IG9wdGlvbi5maWVsZF9hdHRyIDoge30pLCBvcHRpb24uYXR0ciAmJiBvcHRpb24uYXR0ci5wbGFjZWhvbGRlciA/IHtcbiAgICBwbGFjZWhvbGRlcjogb3B0aW9uLmF0dHIucGxhY2Vob2xkZXJcbiAgfSA6IHt9KSwge1xuICAgIG9uQ2hhbmdlOiBfcmVmMiA9PiB7XG4gICAgICBsZXQge1xuICAgICAgICB0YXJnZXQ6IHtcbiAgICAgICAgICB2YWx1ZVxuICAgICAgICB9XG4gICAgICB9ID0gX3JlZjI7XG4gICAgICByZXR1cm4gb25DaGFuZ2UodmFsdWUpO1xuICAgIH1cbiAgfSkpKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IFRleHRBcmVhOyJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///9313\n")},8683:(__unused_webpack_module,__unused_webpack_exports,__webpack_require__)=>{eval("__webpack_require__.p = ct_localizations.public_url;//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiODY4My5qcyIsIm1hcHBpbmdzIjoiQUFBQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vc3RhdGljL2pzL3B1YmxpYy1wYXRoLmpzPzAzYjEiXSwic291cmNlc0NvbnRlbnQiOlsiX193ZWJwYWNrX3B1YmxpY19wYXRoX18gPSBjdF9sb2NhbGl6YXRpb25zLnB1YmxpY191cmw7Il0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///8683\n")},3431:module=>{eval("/**\n * https://github.com/gre/bezier-easing\n * BezierEasing - use bezier curve for transition easing function\n * by Gaëtan Renaudeau 2014 - 2015 – MIT License\n */\n\n// These values are established by empiricism with tests (tradeoff: performance VS precision)\nvar NEWTON_ITERATIONS = 4;\nvar NEWTON_MIN_SLOPE = 0.001;\nvar SUBDIVISION_PRECISION = 0.0000001;\nvar SUBDIVISION_MAX_ITERATIONS = 10;\n\nvar kSplineTableSize = 11;\nvar kSampleStepSize = 1.0 / (kSplineTableSize - 1.0);\n\nvar float32ArraySupported = typeof Float32Array === 'function';\n\nfunction A (aA1, aA2) { return 1.0 - 3.0 * aA2 + 3.0 * aA1; }\nfunction B (aA1, aA2) { return 3.0 * aA2 - 6.0 * aA1; }\nfunction C (aA1) { return 3.0 * aA1; }\n\n// Returns x(t) given t, x1, and x2, or y(t) given t, y1, and y2.\nfunction calcBezier (aT, aA1, aA2) { return ((A(aA1, aA2) * aT + B(aA1, aA2)) * aT + C(aA1)) * aT; }\n\n// Returns dx/dt given t, x1, and x2, or dy/dt given t, y1, and y2.\nfunction getSlope (aT, aA1, aA2) { return 3.0 * A(aA1, aA2) * aT * aT + 2.0 * B(aA1, aA2) * aT + C(aA1); }\n\nfunction binarySubdivide (aX, aA, aB, mX1, mX2) {\n var currentX, currentT, i = 0;\n do {\n currentT = aA + (aB - aA) / 2.0;\n currentX = calcBezier(currentT, mX1, mX2) - aX;\n if (currentX > 0.0) {\n aB = currentT;\n } else {\n aA = currentT;\n }\n } while (Math.abs(currentX) > SUBDIVISION_PRECISION && ++i < SUBDIVISION_MAX_ITERATIONS);\n return currentT;\n}\n\nfunction newtonRaphsonIterate (aX, aGuessT, mX1, mX2) {\n for (var i = 0; i < NEWTON_ITERATIONS; ++i) {\n var currentSlope = getSlope(aGuessT, mX1, mX2);\n if (currentSlope === 0.0) {\n return aGuessT;\n }\n var currentX = calcBezier(aGuessT, mX1, mX2) - aX;\n aGuessT -= currentX / currentSlope;\n }\n return aGuessT;\n}\n\nfunction LinearEasing (x) {\n return x;\n}\n\nmodule.exports = function bezier (mX1, mY1, mX2, mY2) {\n if (!(0 <= mX1 && mX1 <= 1 && 0 <= mX2 && mX2 <= 1)) {\n throw new Error('bezier x values must be in [0, 1] range');\n }\n\n if (mX1 === mY1 && mX2 === mY2) {\n return LinearEasing;\n }\n\n // Precompute samples table\n var sampleValues = float32ArraySupported ? new Float32Array(kSplineTableSize) : new Array(kSplineTableSize);\n for (var i = 0; i < kSplineTableSize; ++i) {\n sampleValues[i] = calcBezier(i * kSampleStepSize, mX1, mX2);\n }\n\n function getTForX (aX) {\n var intervalStart = 0.0;\n var currentSample = 1;\n var lastSample = kSplineTableSize - 1;\n\n for (; currentSample !== lastSample && sampleValues[currentSample] <= aX; ++currentSample) {\n intervalStart += kSampleStepSize;\n }\n --currentSample;\n\n // Interpolate to provide an initial guess for t\n var dist = (aX - sampleValues[currentSample]) / (sampleValues[currentSample + 1] - sampleValues[currentSample]);\n var guessForT = intervalStart + dist * kSampleStepSize;\n\n var initialSlope = getSlope(guessForT, mX1, mX2);\n if (initialSlope >= NEWTON_MIN_SLOPE) {\n return newtonRaphsonIterate(aX, guessForT, mX1, mX2);\n } else if (initialSlope === 0.0) {\n return guessForT;\n } else {\n return binarySubdivide(aX, intervalStart, intervalStart + kSampleStepSize, mX1, mX2);\n }\n }\n\n return function BezierEasing (x) {\n // Because JavaScript number are imprecise, we should guarantee the extremes are right.\n if (x === 0) {\n return 0;\n }\n if (x === 1) {\n return 1;\n }\n return calcBezier(getTForX(x), mY1, mY2);\n };\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMzQzMS5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9ub2RlX21vZHVsZXMvYmV6aWVyLWVhc2luZy9zcmMvaW5kZXguanM/ZDEzOCJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIGh0dHBzOi8vZ2l0aHViLmNvbS9ncmUvYmV6aWVyLWVhc2luZ1xuICogQmV6aWVyRWFzaW5nIC0gdXNlIGJlemllciBjdXJ2ZSBmb3IgdHJhbnNpdGlvbiBlYXNpbmcgZnVuY3Rpb25cbiAqIGJ5IEdhw6t0YW4gUmVuYXVkZWF1IDIwMTQgLSAyMDE1IOKAkyBNSVQgTGljZW5zZVxuICovXG5cbi8vIFRoZXNlIHZhbHVlcyBhcmUgZXN0YWJsaXNoZWQgYnkgZW1waXJpY2lzbSB3aXRoIHRlc3RzICh0cmFkZW9mZjogcGVyZm9ybWFuY2UgVlMgcHJlY2lzaW9uKVxudmFyIE5FV1RPTl9JVEVSQVRJT05TID0gNDtcbnZhciBORVdUT05fTUlOX1NMT1BFID0gMC4wMDE7XG52YXIgU1VCRElWSVNJT05fUFJFQ0lTSU9OID0gMC4wMDAwMDAxO1xudmFyIFNVQkRJVklTSU9OX01BWF9JVEVSQVRJT05TID0gMTA7XG5cbnZhciBrU3BsaW5lVGFibGVTaXplID0gMTE7XG52YXIga1NhbXBsZVN0ZXBTaXplID0gMS4wIC8gKGtTcGxpbmVUYWJsZVNpemUgLSAxLjApO1xuXG52YXIgZmxvYXQzMkFycmF5U3VwcG9ydGVkID0gdHlwZW9mIEZsb2F0MzJBcnJheSA9PT0gJ2Z1bmN0aW9uJztcblxuZnVuY3Rpb24gQSAoYUExLCBhQTIpIHsgcmV0dXJuIDEuMCAtIDMuMCAqIGFBMiArIDMuMCAqIGFBMTsgfVxuZnVuY3Rpb24gQiAoYUExLCBhQTIpIHsgcmV0dXJuIDMuMCAqIGFBMiAtIDYuMCAqIGFBMTsgfVxuZnVuY3Rpb24gQyAoYUExKSAgICAgIHsgcmV0dXJuIDMuMCAqIGFBMTsgfVxuXG4vLyBSZXR1cm5zIHgodCkgZ2l2ZW4gdCwgeDEsIGFuZCB4Miwgb3IgeSh0KSBnaXZlbiB0LCB5MSwgYW5kIHkyLlxuZnVuY3Rpb24gY2FsY0JlemllciAoYVQsIGFBMSwgYUEyKSB7IHJldHVybiAoKEEoYUExLCBhQTIpICogYVQgKyBCKGFBMSwgYUEyKSkgKiBhVCArIEMoYUExKSkgKiBhVDsgfVxuXG4vLyBSZXR1cm5zIGR4L2R0IGdpdmVuIHQsIHgxLCBhbmQgeDIsIG9yIGR5L2R0IGdpdmVuIHQsIHkxLCBhbmQgeTIuXG5mdW5jdGlvbiBnZXRTbG9wZSAoYVQsIGFBMSwgYUEyKSB7IHJldHVybiAzLjAgKiBBKGFBMSwgYUEyKSAqIGFUICogYVQgKyAyLjAgKiBCKGFBMSwgYUEyKSAqIGFUICsgQyhhQTEpOyB9XG5cbmZ1bmN0aW9uIGJpbmFyeVN1YmRpdmlkZSAoYVgsIGFBLCBhQiwgbVgxLCBtWDIpIHtcbiAgdmFyIGN1cnJlbnRYLCBjdXJyZW50VCwgaSA9IDA7XG4gIGRvIHtcbiAgICBjdXJyZW50VCA9IGFBICsgKGFCIC0gYUEpIC8gMi4wO1xuICAgIGN1cnJlbnRYID0gY2FsY0JlemllcihjdXJyZW50VCwgbVgxLCBtWDIpIC0gYVg7XG4gICAgaWYgKGN1cnJlbnRYID4gMC4wKSB7XG4gICAgICBhQiA9IGN1cnJlbnRUO1xuICAgIH0gZWxzZSB7XG4gICAgICBhQSA9IGN1cnJlbnRUO1xuICAgIH1cbiAgfSB3aGlsZSAoTWF0aC5hYnMoY3VycmVudFgpID4gU1VCRElWSVNJT05fUFJFQ0lTSU9OICYmICsraSA8IFNVQkRJVklTSU9OX01BWF9JVEVSQVRJT05TKTtcbiAgcmV0dXJuIGN1cnJlbnRUO1xufVxuXG5mdW5jdGlvbiBuZXd0b25SYXBoc29uSXRlcmF0ZSAoYVgsIGFHdWVzc1QsIG1YMSwgbVgyKSB7XG4gZm9yICh2YXIgaSA9IDA7IGkgPCBORVdUT05fSVRFUkFUSU9OUzsgKytpKSB7XG4gICB2YXIgY3VycmVudFNsb3BlID0gZ2V0U2xvcGUoYUd1ZXNzVCwgbVgxLCBtWDIpO1xuICAgaWYgKGN1cnJlbnRTbG9wZSA9PT0gMC4wKSB7XG4gICAgIHJldHVybiBhR3Vlc3NUO1xuICAgfVxuICAgdmFyIGN1cnJlbnRYID0gY2FsY0JlemllcihhR3Vlc3NULCBtWDEsIG1YMikgLSBhWDtcbiAgIGFHdWVzc1QgLT0gY3VycmVudFggLyBjdXJyZW50U2xvcGU7XG4gfVxuIHJldHVybiBhR3Vlc3NUO1xufVxuXG5mdW5jdGlvbiBMaW5lYXJFYXNpbmcgKHgpIHtcbiAgcmV0dXJuIHg7XG59XG5cbm1vZHVsZS5leHBvcnRzID0gZnVuY3Rpb24gYmV6aWVyIChtWDEsIG1ZMSwgbVgyLCBtWTIpIHtcbiAgaWYgKCEoMCA8PSBtWDEgJiYgbVgxIDw9IDEgJiYgMCA8PSBtWDIgJiYgbVgyIDw9IDEpKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdiZXppZXIgeCB2YWx1ZXMgbXVzdCBiZSBpbiBbMCwgMV0gcmFuZ2UnKTtcbiAgfVxuXG4gIGlmIChtWDEgPT09IG1ZMSAmJiBtWDIgPT09IG1ZMikge1xuICAgIHJldHVybiBMaW5lYXJFYXNpbmc7XG4gIH1cblxuICAvLyBQcmVjb21wdXRlIHNhbXBsZXMgdGFibGVcbiAgdmFyIHNhbXBsZVZhbHVlcyA9IGZsb2F0MzJBcnJheVN1cHBvcnRlZCA/IG5ldyBGbG9hdDMyQXJyYXkoa1NwbGluZVRhYmxlU2l6ZSkgOiBuZXcgQXJyYXkoa1NwbGluZVRhYmxlU2l6ZSk7XG4gIGZvciAodmFyIGkgPSAwOyBpIDwga1NwbGluZVRhYmxlU2l6ZTsgKytpKSB7XG4gICAgc2FtcGxlVmFsdWVzW2ldID0gY2FsY0JlemllcihpICoga1NhbXBsZVN0ZXBTaXplLCBtWDEsIG1YMik7XG4gIH1cblxuICBmdW5jdGlvbiBnZXRURm9yWCAoYVgpIHtcbiAgICB2YXIgaW50ZXJ2YWxTdGFydCA9IDAuMDtcbiAgICB2YXIgY3VycmVudFNhbXBsZSA9IDE7XG4gICAgdmFyIGxhc3RTYW1wbGUgPSBrU3BsaW5lVGFibGVTaXplIC0gMTtcblxuICAgIGZvciAoOyBjdXJyZW50U2FtcGxlICE9PSBsYXN0U2FtcGxlICYmIHNhbXBsZVZhbHVlc1tjdXJyZW50U2FtcGxlXSA8PSBhWDsgKytjdXJyZW50U2FtcGxlKSB7XG4gICAgICBpbnRlcnZhbFN0YXJ0ICs9IGtTYW1wbGVTdGVwU2l6ZTtcbiAgICB9XG4gICAgLS1jdXJyZW50U2FtcGxlO1xuXG4gICAgLy8gSW50ZXJwb2xhdGUgdG8gcHJvdmlkZSBhbiBpbml0aWFsIGd1ZXNzIGZvciB0XG4gICAgdmFyIGRpc3QgPSAoYVggLSBzYW1wbGVWYWx1ZXNbY3VycmVudFNhbXBsZV0pIC8gKHNhbXBsZVZhbHVlc1tjdXJyZW50U2FtcGxlICsgMV0gLSBzYW1wbGVWYWx1ZXNbY3VycmVudFNhbXBsZV0pO1xuICAgIHZhciBndWVzc0ZvclQgPSBpbnRlcnZhbFN0YXJ0ICsgZGlzdCAqIGtTYW1wbGVTdGVwU2l6ZTtcblxuICAgIHZhciBpbml0aWFsU2xvcGUgPSBnZXRTbG9wZShndWVzc0ZvclQsIG1YMSwgbVgyKTtcbiAgICBpZiAoaW5pdGlhbFNsb3BlID49IE5FV1RPTl9NSU5fU0xPUEUpIHtcbiAgICAgIHJldHVybiBuZXd0b25SYXBoc29uSXRlcmF0ZShhWCwgZ3Vlc3NGb3JULCBtWDEsIG1YMik7XG4gICAgfSBlbHNlIGlmIChpbml0aWFsU2xvcGUgPT09IDAuMCkge1xuICAgICAgcmV0dXJuIGd1ZXNzRm9yVDtcbiAgICB9IGVsc2Uge1xuICAgICAgcmV0dXJuIGJpbmFyeVN1YmRpdmlkZShhWCwgaW50ZXJ2YWxTdGFydCwgaW50ZXJ2YWxTdGFydCArIGtTYW1wbGVTdGVwU2l6ZSwgbVgxLCBtWDIpO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBmdW5jdGlvbiBCZXppZXJFYXNpbmcgKHgpIHtcbiAgICAvLyBCZWNhdXNlIEphdmFTY3JpcHQgbnVtYmVyIGFyZSBpbXByZWNpc2UsIHdlIHNob3VsZCBndWFyYW50ZWUgdGhlIGV4dHJlbWVzIGFyZSByaWdodC5cbiAgICBpZiAoeCA9PT0gMCkge1xuICAgICAgcmV0dXJuIDA7XG4gICAgfVxuICAgIGlmICh4ID09PSAxKSB7XG4gICAgICByZXR1cm4gMTtcbiAgICB9XG4gICAgcmV0dXJuIGNhbGNCZXppZXIoZ2V0VEZvclgoeCksIG1ZMSwgbVkyKTtcbiAgfTtcbn07XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///3431\n")},1924:(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval("\n\nvar GetIntrinsic = __webpack_require__(210);\n\nvar callBind = __webpack_require__(5559);\n\nvar $indexOf = callBind(GetIntrinsic('String.prototype.indexOf'));\n\nmodule.exports = function callBoundIntrinsic(name, allowMissing) {\n\tvar intrinsic = GetIntrinsic(name, !!allowMissing);\n\tif (typeof intrinsic === 'function' && $indexOf(name, '.prototype.') > -1) {\n\t\treturn callBind(intrinsic);\n\t}\n\treturn intrinsic;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTkyNC5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9ibG9ja3N5T3B0aW9ucy8uL25vZGVfbW9kdWxlcy9jYWxsLWJpbmQvY2FsbEJvdW5kLmpzPzU0NWUiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG52YXIgR2V0SW50cmluc2ljID0gcmVxdWlyZSgnZ2V0LWludHJpbnNpYycpO1xuXG52YXIgY2FsbEJpbmQgPSByZXF1aXJlKCcuLycpO1xuXG52YXIgJGluZGV4T2YgPSBjYWxsQmluZChHZXRJbnRyaW5zaWMoJ1N0cmluZy5wcm90b3R5cGUuaW5kZXhPZicpKTtcblxubW9kdWxlLmV4cG9ydHMgPSBmdW5jdGlvbiBjYWxsQm91bmRJbnRyaW5zaWMobmFtZSwgYWxsb3dNaXNzaW5nKSB7XG5cdHZhciBpbnRyaW5zaWMgPSBHZXRJbnRyaW5zaWMobmFtZSwgISFhbGxvd01pc3NpbmcpO1xuXHRpZiAodHlwZW9mIGludHJpbnNpYyA9PT0gJ2Z1bmN0aW9uJyAmJiAkaW5kZXhPZihuYW1lLCAnLnByb3RvdHlwZS4nKSA+IC0xKSB7XG5cdFx0cmV0dXJuIGNhbGxCaW5kKGludHJpbnNpYyk7XG5cdH1cblx0cmV0dXJuIGludHJpbnNpYztcbn07XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///1924\n")},5559:(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval("\n\nvar bind = __webpack_require__(8612);\nvar GetIntrinsic = __webpack_require__(210);\n\nvar $apply = GetIntrinsic('%Function.prototype.apply%');\nvar $call = GetIntrinsic('%Function.prototype.call%');\nvar $reflectApply = GetIntrinsic('%Reflect.apply%', true) || bind.call($call, $apply);\n\nvar $gOPD = GetIntrinsic('%Object.getOwnPropertyDescriptor%', true);\nvar $defineProperty = GetIntrinsic('%Object.defineProperty%', true);\nvar $max = GetIntrinsic('%Math.max%');\n\nif ($defineProperty) {\n\ttry {\n\t\t$defineProperty({}, 'a', { value: 1 });\n\t} catch (e) {\n\t\t// IE 8 has a broken defineProperty\n\t\t$defineProperty = null;\n\t}\n}\n\nmodule.exports = function callBind(originalFunction) {\n\tvar func = $reflectApply(bind, $call, arguments);\n\tif ($gOPD && $defineProperty) {\n\t\tvar desc = $gOPD(func, 'length');\n\t\tif (desc.configurable) {\n\t\t\t// original length, plus the receiver, minus any additional arguments (after the receiver)\n\t\t\t$defineProperty(\n\t\t\t\tfunc,\n\t\t\t\t'length',\n\t\t\t\t{ value: 1 + $max(0, originalFunction.length - (arguments.length - 1)) }\n\t\t\t);\n\t\t}\n\t}\n\treturn func;\n};\n\nvar applyBind = function applyBind() {\n\treturn $reflectApply(bind, $apply, arguments);\n};\n\nif ($defineProperty) {\n\t$defineProperty(module.exports, 'apply', { value: applyBind });\n} else {\n\tmodule.exports.apply = applyBind;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNTU1OS5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9ub2RlX21vZHVsZXMvY2FsbC1iaW5kL2luZGV4LmpzPzNlYjEiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG52YXIgYmluZCA9IHJlcXVpcmUoJ2Z1bmN0aW9uLWJpbmQnKTtcbnZhciBHZXRJbnRyaW5zaWMgPSByZXF1aXJlKCdnZXQtaW50cmluc2ljJyk7XG5cbnZhciAkYXBwbHkgPSBHZXRJbnRyaW5zaWMoJyVGdW5jdGlvbi5wcm90b3R5cGUuYXBwbHklJyk7XG52YXIgJGNhbGwgPSBHZXRJbnRyaW5zaWMoJyVGdW5jdGlvbi5wcm90b3R5cGUuY2FsbCUnKTtcbnZhciAkcmVmbGVjdEFwcGx5ID0gR2V0SW50cmluc2ljKCclUmVmbGVjdC5hcHBseSUnLCB0cnVlKSB8fCBiaW5kLmNhbGwoJGNhbGwsICRhcHBseSk7XG5cbnZhciAkZ09QRCA9IEdldEludHJpbnNpYygnJU9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3IlJywgdHJ1ZSk7XG52YXIgJGRlZmluZVByb3BlcnR5ID0gR2V0SW50cmluc2ljKCclT2JqZWN0LmRlZmluZVByb3BlcnR5JScsIHRydWUpO1xudmFyICRtYXggPSBHZXRJbnRyaW5zaWMoJyVNYXRoLm1heCUnKTtcblxuaWYgKCRkZWZpbmVQcm9wZXJ0eSkge1xuXHR0cnkge1xuXHRcdCRkZWZpbmVQcm9wZXJ0eSh7fSwgJ2EnLCB7IHZhbHVlOiAxIH0pO1xuXHR9IGNhdGNoIChlKSB7XG5cdFx0Ly8gSUUgOCBoYXMgYSBicm9rZW4gZGVmaW5lUHJvcGVydHlcblx0XHQkZGVmaW5lUHJvcGVydHkgPSBudWxsO1xuXHR9XG59XG5cbm1vZHVsZS5leHBvcnRzID0gZnVuY3Rpb24gY2FsbEJpbmQob3JpZ2luYWxGdW5jdGlvbikge1xuXHR2YXIgZnVuYyA9ICRyZWZsZWN0QXBwbHkoYmluZCwgJGNhbGwsIGFyZ3VtZW50cyk7XG5cdGlmICgkZ09QRCAmJiAkZGVmaW5lUHJvcGVydHkpIHtcblx0XHR2YXIgZGVzYyA9ICRnT1BEKGZ1bmMsICdsZW5ndGgnKTtcblx0XHRpZiAoZGVzYy5jb25maWd1cmFibGUpIHtcblx0XHRcdC8vIG9yaWdpbmFsIGxlbmd0aCwgcGx1cyB0aGUgcmVjZWl2ZXIsIG1pbnVzIGFueSBhZGRpdGlvbmFsIGFyZ3VtZW50cyAoYWZ0ZXIgdGhlIHJlY2VpdmVyKVxuXHRcdFx0JGRlZmluZVByb3BlcnR5KFxuXHRcdFx0XHRmdW5jLFxuXHRcdFx0XHQnbGVuZ3RoJyxcblx0XHRcdFx0eyB2YWx1ZTogMSArICRtYXgoMCwgb3JpZ2luYWxGdW5jdGlvbi5sZW5ndGggLSAoYXJndW1lbnRzLmxlbmd0aCAtIDEpKSB9XG5cdFx0XHQpO1xuXHRcdH1cblx0fVxuXHRyZXR1cm4gZnVuYztcbn07XG5cbnZhciBhcHBseUJpbmQgPSBmdW5jdGlvbiBhcHBseUJpbmQoKSB7XG5cdHJldHVybiAkcmVmbGVjdEFwcGx5KGJpbmQsICRhcHBseSwgYXJndW1lbnRzKTtcbn07XG5cbmlmICgkZGVmaW5lUHJvcGVydHkpIHtcblx0JGRlZmluZVByb3BlcnR5KG1vZHVsZS5leHBvcnRzLCAnYXBwbHknLCB7IHZhbHVlOiBhcHBseUJpbmQgfSk7XG59IGVsc2Uge1xuXHRtb2R1bGUuZXhwb3J0cy5hcHBseSA9IGFwcGx5QmluZDtcbn1cbiJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///5559\n")},487:module=>{eval("var charenc = {\n // UTF-8 encoding\n utf8: {\n // Convert a string to a byte array\n stringToBytes: function(str) {\n return charenc.bin.stringToBytes(unescape(encodeURIComponent(str)));\n },\n\n // Convert a byte array to a string\n bytesToString: function(bytes) {\n return decodeURIComponent(escape(charenc.bin.bytesToString(bytes)));\n }\n },\n\n // Binary encoding\n bin: {\n // Convert a string to a byte array\n stringToBytes: function(str) {\n for (var bytes = [], i = 0; i < str.length; i++)\n bytes.push(str.charCodeAt(i) & 0xFF);\n return bytes;\n },\n\n // Convert a byte array to a string\n bytesToString: function(bytes) {\n for (var str = [], i = 0; i < bytes.length; i++)\n str.push(String.fromCharCode(bytes[i]));\n return str.join('');\n }\n }\n};\n\nmodule.exports = charenc;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNDg3LmpzIiwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vbm9kZV9tb2R1bGVzL2NoYXJlbmMvY2hhcmVuYy5qcz85YTYzIl0sInNvdXJjZXNDb250ZW50IjpbInZhciBjaGFyZW5jID0ge1xuICAvLyBVVEYtOCBlbmNvZGluZ1xuICB1dGY4OiB7XG4gICAgLy8gQ29udmVydCBhIHN0cmluZyB0byBhIGJ5dGUgYXJyYXlcbiAgICBzdHJpbmdUb0J5dGVzOiBmdW5jdGlvbihzdHIpIHtcbiAgICAgIHJldHVybiBjaGFyZW5jLmJpbi5zdHJpbmdUb0J5dGVzKHVuZXNjYXBlKGVuY29kZVVSSUNvbXBvbmVudChzdHIpKSk7XG4gICAgfSxcblxuICAgIC8vIENvbnZlcnQgYSBieXRlIGFycmF5IHRvIGEgc3RyaW5nXG4gICAgYnl0ZXNUb1N0cmluZzogZnVuY3Rpb24oYnl0ZXMpIHtcbiAgICAgIHJldHVybiBkZWNvZGVVUklDb21wb25lbnQoZXNjYXBlKGNoYXJlbmMuYmluLmJ5dGVzVG9TdHJpbmcoYnl0ZXMpKSk7XG4gICAgfVxuICB9LFxuXG4gIC8vIEJpbmFyeSBlbmNvZGluZ1xuICBiaW46IHtcbiAgICAvLyBDb252ZXJ0IGEgc3RyaW5nIHRvIGEgYnl0ZSBhcnJheVxuICAgIHN0cmluZ1RvQnl0ZXM6IGZ1bmN0aW9uKHN0cikge1xuICAgICAgZm9yICh2YXIgYnl0ZXMgPSBbXSwgaSA9IDA7IGkgPCBzdHIubGVuZ3RoOyBpKyspXG4gICAgICAgIGJ5dGVzLnB1c2goc3RyLmNoYXJDb2RlQXQoaSkgJiAweEZGKTtcbiAgICAgIHJldHVybiBieXRlcztcbiAgICB9LFxuXG4gICAgLy8gQ29udmVydCBhIGJ5dGUgYXJyYXkgdG8gYSBzdHJpbmdcbiAgICBieXRlc1RvU3RyaW5nOiBmdW5jdGlvbihieXRlcykge1xuICAgICAgZm9yICh2YXIgc3RyID0gW10sIGkgPSAwOyBpIDwgYnl0ZXMubGVuZ3RoOyBpKyspXG4gICAgICAgIHN0ci5wdXNoKFN0cmluZy5mcm9tQ2hhckNvZGUoYnl0ZXNbaV0pKTtcbiAgICAgIHJldHVybiBzdHIuam9pbignJyk7XG4gICAgfVxuICB9XG59O1xuXG5tb2R1bGUuZXhwb3J0cyA9IGNoYXJlbmM7XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///487\n")},4184:(module,exports)=>{eval("var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;/*!\n Copyright (c) 2018 Jed Watson.\n Licensed under the MIT License (MIT), see\n http://jedwatson.github.io/classnames\n*/\n/* global define */\n\n(function () {\n\t'use strict';\n\n\tvar hasOwn = {}.hasOwnProperty;\n\n\tfunction classNames() {\n\t\tvar classes = [];\n\n\t\tfor (var i = 0; i < arguments.length; i++) {\n\t\t\tvar arg = arguments[i];\n\t\t\tif (!arg) continue;\n\n\t\t\tvar argType = typeof arg;\n\n\t\t\tif (argType === 'string' || argType === 'number') {\n\t\t\t\tclasses.push(arg);\n\t\t\t} else if (Array.isArray(arg)) {\n\t\t\t\tif (arg.length) {\n\t\t\t\t\tvar inner = classNames.apply(null, arg);\n\t\t\t\t\tif (inner) {\n\t\t\t\t\t\tclasses.push(inner);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else if (argType === 'object') {\n\t\t\t\tif (arg.toString === Object.prototype.toString) {\n\t\t\t\t\tfor (var key in arg) {\n\t\t\t\t\t\tif (hasOwn.call(arg, key) && arg[key]) {\n\t\t\t\t\t\t\tclasses.push(key);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tclasses.push(arg.toString());\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn classes.join(' ');\n\t}\n\n\tif ( true && module.exports) {\n\t\tclassNames.default = classNames;\n\t\tmodule.exports = classNames;\n\t} else if (true) {\n\t\t// register as 'classnames', consistent with npm package name\n\t\t!(__WEBPACK_AMD_DEFINE_ARRAY__ = [], __WEBPACK_AMD_DEFINE_RESULT__ = (function () {\n\t\t\treturn classNames;\n\t\t}).apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__),\n\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));\n\t} else {}\n}());\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNDE4NC5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBR0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9ibG9ja3N5T3B0aW9ucy8uL25vZGVfbW9kdWxlcy9jbGFzc25hbWVzL2luZGV4LmpzPzRkMjYiXSwic291cmNlc0NvbnRlbnQiOlsiLyohXG4gIENvcHlyaWdodCAoYykgMjAxOCBKZWQgV2F0c29uLlxuICBMaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UgKE1JVCksIHNlZVxuICBodHRwOi8vamVkd2F0c29uLmdpdGh1Yi5pby9jbGFzc25hbWVzXG4qL1xuLyogZ2xvYmFsIGRlZmluZSAqL1xuXG4oZnVuY3Rpb24gKCkge1xuXHQndXNlIHN0cmljdCc7XG5cblx0dmFyIGhhc093biA9IHt9Lmhhc093blByb3BlcnR5O1xuXG5cdGZ1bmN0aW9uIGNsYXNzTmFtZXMoKSB7XG5cdFx0dmFyIGNsYXNzZXMgPSBbXTtcblxuXHRcdGZvciAodmFyIGkgPSAwOyBpIDwgYXJndW1lbnRzLmxlbmd0aDsgaSsrKSB7XG5cdFx0XHR2YXIgYXJnID0gYXJndW1lbnRzW2ldO1xuXHRcdFx0aWYgKCFhcmcpIGNvbnRpbnVlO1xuXG5cdFx0XHR2YXIgYXJnVHlwZSA9IHR5cGVvZiBhcmc7XG5cblx0XHRcdGlmIChhcmdUeXBlID09PSAnc3RyaW5nJyB8fCBhcmdUeXBlID09PSAnbnVtYmVyJykge1xuXHRcdFx0XHRjbGFzc2VzLnB1c2goYXJnKTtcblx0XHRcdH0gZWxzZSBpZiAoQXJyYXkuaXNBcnJheShhcmcpKSB7XG5cdFx0XHRcdGlmIChhcmcubGVuZ3RoKSB7XG5cdFx0XHRcdFx0dmFyIGlubmVyID0gY2xhc3NOYW1lcy5hcHBseShudWxsLCBhcmcpO1xuXHRcdFx0XHRcdGlmIChpbm5lcikge1xuXHRcdFx0XHRcdFx0Y2xhc3Nlcy5wdXNoKGlubmVyKTtcblx0XHRcdFx0XHR9XG5cdFx0XHRcdH1cblx0XHRcdH0gZWxzZSBpZiAoYXJnVHlwZSA9PT0gJ29iamVjdCcpIHtcblx0XHRcdFx0aWYgKGFyZy50b1N0cmluZyA9PT0gT2JqZWN0LnByb3RvdHlwZS50b1N0cmluZykge1xuXHRcdFx0XHRcdGZvciAodmFyIGtleSBpbiBhcmcpIHtcblx0XHRcdFx0XHRcdGlmIChoYXNPd24uY2FsbChhcmcsIGtleSkgJiYgYXJnW2tleV0pIHtcblx0XHRcdFx0XHRcdFx0Y2xhc3Nlcy5wdXNoKGtleSk7XG5cdFx0XHRcdFx0XHR9XG5cdFx0XHRcdFx0fVxuXHRcdFx0XHR9IGVsc2Uge1xuXHRcdFx0XHRcdGNsYXNzZXMucHVzaChhcmcudG9TdHJpbmcoKSk7XG5cdFx0XHRcdH1cblx0XHRcdH1cblx0XHR9XG5cblx0XHRyZXR1cm4gY2xhc3Nlcy5qb2luKCcgJyk7XG5cdH1cblxuXHRpZiAodHlwZW9mIG1vZHVsZSAhPT0gJ3VuZGVmaW5lZCcgJiYgbW9kdWxlLmV4cG9ydHMpIHtcblx0XHRjbGFzc05hbWVzLmRlZmF1bHQgPSBjbGFzc05hbWVzO1xuXHRcdG1vZHVsZS5leHBvcnRzID0gY2xhc3NOYW1lcztcblx0fSBlbHNlIGlmICh0eXBlb2YgZGVmaW5lID09PSAnZnVuY3Rpb24nICYmIHR5cGVvZiBkZWZpbmUuYW1kID09PSAnb2JqZWN0JyAmJiBkZWZpbmUuYW1kKSB7XG5cdFx0Ly8gcmVnaXN0ZXIgYXMgJ2NsYXNzbmFtZXMnLCBjb25zaXN0ZW50IHdpdGggbnBtIHBhY2thZ2UgbmFtZVxuXHRcdGRlZmluZSgnY2xhc3NuYW1lcycsIFtdLCBmdW5jdGlvbiAoKSB7XG5cdFx0XHRyZXR1cm4gY2xhc3NOYW1lcztcblx0XHR9KTtcblx0fSBlbHNlIHtcblx0XHR3aW5kb3cuY2xhc3NOYW1lcyA9IGNsYXNzTmFtZXM7XG5cdH1cbn0oKSk7XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///4184\n")},1012:module=>{eval("(function() {\n var base64map\n = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/',\n\n crypt = {\n // Bit-wise rotation left\n rotl: function(n, b) {\n return (n << b) | (n >>> (32 - b));\n },\n\n // Bit-wise rotation right\n rotr: function(n, b) {\n return (n << (32 - b)) | (n >>> b);\n },\n\n // Swap big-endian to little-endian and vice versa\n endian: function(n) {\n // If number given, swap endian\n if (n.constructor == Number) {\n return crypt.rotl(n, 8) & 0x00FF00FF | crypt.rotl(n, 24) & 0xFF00FF00;\n }\n\n // Else, assume array and swap all items\n for (var i = 0; i < n.length; i++)\n n[i] = crypt.endian(n[i]);\n return n;\n },\n\n // Generate an array of any length of random bytes\n randomBytes: function(n) {\n for (var bytes = []; n > 0; n--)\n bytes.push(Math.floor(Math.random() * 256));\n return bytes;\n },\n\n // Convert a byte array to big-endian 32-bit words\n bytesToWords: function(bytes) {\n for (var words = [], i = 0, b = 0; i < bytes.length; i++, b += 8)\n words[b >>> 5] |= bytes[i] << (24 - b % 32);\n return words;\n },\n\n // Convert big-endian 32-bit words to a byte array\n wordsToBytes: function(words) {\n for (var bytes = [], b = 0; b < words.length * 32; b += 8)\n bytes.push((words[b >>> 5] >>> (24 - b % 32)) & 0xFF);\n return bytes;\n },\n\n // Convert a byte array to a hex string\n bytesToHex: function(bytes) {\n for (var hex = [], i = 0; i < bytes.length; i++) {\n hex.push((bytes[i] >>> 4).toString(16));\n hex.push((bytes[i] & 0xF).toString(16));\n }\n return hex.join('');\n },\n\n // Convert a hex string to a byte array\n hexToBytes: function(hex) {\n for (var bytes = [], c = 0; c < hex.length; c += 2)\n bytes.push(parseInt(hex.substr(c, 2), 16));\n return bytes;\n },\n\n // Convert a byte array to a base-64 string\n bytesToBase64: function(bytes) {\n for (var base64 = [], i = 0; i < bytes.length; i += 3) {\n var triplet = (bytes[i] << 16) | (bytes[i + 1] << 8) | bytes[i + 2];\n for (var j = 0; j < 4; j++)\n if (i * 8 + j * 6 <= bytes.length * 8)\n base64.push(base64map.charAt((triplet >>> 6 * (3 - j)) & 0x3F));\n else\n base64.push('=');\n }\n return base64.join('');\n },\n\n // Convert a base-64 string to a byte array\n base64ToBytes: function(base64) {\n // Remove non-base-64 characters\n base64 = base64.replace(/[^A-Z0-9+\\/]/ig, '');\n\n for (var bytes = [], i = 0, imod4 = 0; i < base64.length;\n imod4 = ++i % 4) {\n if (imod4 == 0) continue;\n bytes.push(((base64map.indexOf(base64.charAt(i - 1))\n & (Math.pow(2, -2 * imod4 + 8) - 1)) << (imod4 * 2))\n | (base64map.indexOf(base64.charAt(i)) >>> (6 - imod4 * 2)));\n }\n return bytes;\n }\n };\n\n module.exports = crypt;\n})();\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTAxMi5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9ibG9ja3N5T3B0aW9ucy8uL25vZGVfbW9kdWxlcy9jcnlwdC9jcnlwdC5qcz8wMGQ4Il0sInNvdXJjZXNDb250ZW50IjpbIihmdW5jdGlvbigpIHtcbiAgdmFyIGJhc2U2NG1hcFxuICAgICAgPSAnQUJDREVGR0hJSktMTU5PUFFSU1RVVldYWVphYmNkZWZnaGlqa2xtbm9wcXJzdHV2d3h5ejAxMjM0NTY3ODkrLycsXG5cbiAgY3J5cHQgPSB7XG4gICAgLy8gQml0LXdpc2Ugcm90YXRpb24gbGVmdFxuICAgIHJvdGw6IGZ1bmN0aW9uKG4sIGIpIHtcbiAgICAgIHJldHVybiAobiA8PCBiKSB8IChuID4+PiAoMzIgLSBiKSk7XG4gICAgfSxcblxuICAgIC8vIEJpdC13aXNlIHJvdGF0aW9uIHJpZ2h0XG4gICAgcm90cjogZnVuY3Rpb24obiwgYikge1xuICAgICAgcmV0dXJuIChuIDw8ICgzMiAtIGIpKSB8IChuID4+PiBiKTtcbiAgICB9LFxuXG4gICAgLy8gU3dhcCBiaWctZW5kaWFuIHRvIGxpdHRsZS1lbmRpYW4gYW5kIHZpY2UgdmVyc2FcbiAgICBlbmRpYW46IGZ1bmN0aW9uKG4pIHtcbiAgICAgIC8vIElmIG51bWJlciBnaXZlbiwgc3dhcCBlbmRpYW5cbiAgICAgIGlmIChuLmNvbnN0cnVjdG9yID09IE51bWJlcikge1xuICAgICAgICByZXR1cm4gY3J5cHQucm90bChuLCA4KSAmIDB4MDBGRjAwRkYgfCBjcnlwdC5yb3RsKG4sIDI0KSAmIDB4RkYwMEZGMDA7XG4gICAgICB9XG5cbiAgICAgIC8vIEVsc2UsIGFzc3VtZSBhcnJheSBhbmQgc3dhcCBhbGwgaXRlbXNcbiAgICAgIGZvciAodmFyIGkgPSAwOyBpIDwgbi5sZW5ndGg7IGkrKylcbiAgICAgICAgbltpXSA9IGNyeXB0LmVuZGlhbihuW2ldKTtcbiAgICAgIHJldHVybiBuO1xuICAgIH0sXG5cbiAgICAvLyBHZW5lcmF0ZSBhbiBhcnJheSBvZiBhbnkgbGVuZ3RoIG9mIHJhbmRvbSBieXRlc1xuICAgIHJhbmRvbUJ5dGVzOiBmdW5jdGlvbihuKSB7XG4gICAgICBmb3IgKHZhciBieXRlcyA9IFtdOyBuID4gMDsgbi0tKVxuICAgICAgICBieXRlcy5wdXNoKE1hdGguZmxvb3IoTWF0aC5yYW5kb20oKSAqIDI1NikpO1xuICAgICAgcmV0dXJuIGJ5dGVzO1xuICAgIH0sXG5cbiAgICAvLyBDb252ZXJ0IGEgYnl0ZSBhcnJheSB0byBiaWctZW5kaWFuIDMyLWJpdCB3b3Jkc1xuICAgIGJ5dGVzVG9Xb3JkczogZnVuY3Rpb24oYnl0ZXMpIHtcbiAgICAgIGZvciAodmFyIHdvcmRzID0gW10sIGkgPSAwLCBiID0gMDsgaSA8IGJ5dGVzLmxlbmd0aDsgaSsrLCBiICs9IDgpXG4gICAgICAgIHdvcmRzW2IgPj4+IDVdIHw9IGJ5dGVzW2ldIDw8ICgyNCAtIGIgJSAzMik7XG4gICAgICByZXR1cm4gd29yZHM7XG4gICAgfSxcblxuICAgIC8vIENvbnZlcnQgYmlnLWVuZGlhbiAzMi1iaXQgd29yZHMgdG8gYSBieXRlIGFycmF5XG4gICAgd29yZHNUb0J5dGVzOiBmdW5jdGlvbih3b3Jkcykge1xuICAgICAgZm9yICh2YXIgYnl0ZXMgPSBbXSwgYiA9IDA7IGIgPCB3b3Jkcy5sZW5ndGggKiAzMjsgYiArPSA4KVxuICAgICAgICBieXRlcy5wdXNoKCh3b3Jkc1tiID4+PiA1XSA+Pj4gKDI0IC0gYiAlIDMyKSkgJiAweEZGKTtcbiAgICAgIHJldHVybiBieXRlcztcbiAgICB9LFxuXG4gICAgLy8gQ29udmVydCBhIGJ5dGUgYXJyYXkgdG8gYSBoZXggc3RyaW5nXG4gICAgYnl0ZXNUb0hleDogZnVuY3Rpb24oYnl0ZXMpIHtcbiAgICAgIGZvciAodmFyIGhleCA9IFtdLCBpID0gMDsgaSA8IGJ5dGVzLmxlbmd0aDsgaSsrKSB7XG4gICAgICAgIGhleC5wdXNoKChieXRlc1tpXSA+Pj4gNCkudG9TdHJpbmcoMTYpKTtcbiAgICAgICAgaGV4LnB1c2goKGJ5dGVzW2ldICYgMHhGKS50b1N0cmluZygxNikpO1xuICAgICAgfVxuICAgICAgcmV0dXJuIGhleC5qb2luKCcnKTtcbiAgICB9LFxuXG4gICAgLy8gQ29udmVydCBhIGhleCBzdHJpbmcgdG8gYSBieXRlIGFycmF5XG4gICAgaGV4VG9CeXRlczogZnVuY3Rpb24oaGV4KSB7XG4gICAgICBmb3IgKHZhciBieXRlcyA9IFtdLCBjID0gMDsgYyA8IGhleC5sZW5ndGg7IGMgKz0gMilcbiAgICAgICAgYnl0ZXMucHVzaChwYXJzZUludChoZXguc3Vic3RyKGMsIDIpLCAxNikpO1xuICAgICAgcmV0dXJuIGJ5dGVzO1xuICAgIH0sXG5cbiAgICAvLyBDb252ZXJ0IGEgYnl0ZSBhcnJheSB0byBhIGJhc2UtNjQgc3RyaW5nXG4gICAgYnl0ZXNUb0Jhc2U2NDogZnVuY3Rpb24oYnl0ZXMpIHtcbiAgICAgIGZvciAodmFyIGJhc2U2NCA9IFtdLCBpID0gMDsgaSA8IGJ5dGVzLmxlbmd0aDsgaSArPSAzKSB7XG4gICAgICAgIHZhciB0cmlwbGV0ID0gKGJ5dGVzW2ldIDw8IDE2KSB8IChieXRlc1tpICsgMV0gPDwgOCkgfCBieXRlc1tpICsgMl07XG4gICAgICAgIGZvciAodmFyIGogPSAwOyBqIDwgNDsgaisrKVxuICAgICAgICAgIGlmIChpICogOCArIGogKiA2IDw9IGJ5dGVzLmxlbmd0aCAqIDgpXG4gICAgICAgICAgICBiYXNlNjQucHVzaChiYXNlNjRtYXAuY2hhckF0KCh0cmlwbGV0ID4+PiA2ICogKDMgLSBqKSkgJiAweDNGKSk7XG4gICAgICAgICAgZWxzZVxuICAgICAgICAgICAgYmFzZTY0LnB1c2goJz0nKTtcbiAgICAgIH1cbiAgICAgIHJldHVybiBiYXNlNjQuam9pbignJyk7XG4gICAgfSxcblxuICAgIC8vIENvbnZlcnQgYSBiYXNlLTY0IHN0cmluZyB0byBhIGJ5dGUgYXJyYXlcbiAgICBiYXNlNjRUb0J5dGVzOiBmdW5jdGlvbihiYXNlNjQpIHtcbiAgICAgIC8vIFJlbW92ZSBub24tYmFzZS02NCBjaGFyYWN0ZXJzXG4gICAgICBiYXNlNjQgPSBiYXNlNjQucmVwbGFjZSgvW15BLVowLTkrXFwvXS9pZywgJycpO1xuXG4gICAgICBmb3IgKHZhciBieXRlcyA9IFtdLCBpID0gMCwgaW1vZDQgPSAwOyBpIDwgYmFzZTY0Lmxlbmd0aDtcbiAgICAgICAgICBpbW9kNCA9ICsraSAlIDQpIHtcbiAgICAgICAgaWYgKGltb2Q0ID09IDApIGNvbnRpbnVlO1xuICAgICAgICBieXRlcy5wdXNoKCgoYmFzZTY0bWFwLmluZGV4T2YoYmFzZTY0LmNoYXJBdChpIC0gMSkpXG4gICAgICAgICAgICAmIChNYXRoLnBvdygyLCAtMiAqIGltb2Q0ICsgOCkgLSAxKSkgPDwgKGltb2Q0ICogMikpXG4gICAgICAgICAgICB8IChiYXNlNjRtYXAuaW5kZXhPZihiYXNlNjQuY2hhckF0KGkpKSA+Pj4gKDYgLSBpbW9kNCAqIDIpKSk7XG4gICAgICB9XG4gICAgICByZXR1cm4gYnl0ZXM7XG4gICAgfVxuICB9O1xuXG4gIG1vZHVsZS5leHBvcnRzID0gY3J5cHQ7XG59KSgpO1xuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///1012\n")},600:(__unused_webpack_module,exports)=>{"use strict";eval("var __webpack_unused_export__;\n\n\n__webpack_unused_export__ = ({ value: true });\n\nvar maybePromoteScalarValueIntoResponsive = function maybePromoteScalarValueIntoResponsive(value) {\n var isResponsive = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n\n /**\n * Responsive value must necessarily have the desktop key attached to it\n */\n if (value && Object.keys(value).indexOf('desktop') > -1) {\n if (!isResponsive) {\n return value.desktop;\n }\n\n return value;\n }\n\n if (!isResponsive) {\n return value;\n }\n\n return {\n desktop: value,\n tablet: value,\n mobile: value\n };\n};\n\nexports.T = maybePromoteScalarValueIntoResponsive;\n//# sourceMappingURL=promote-into-responsive.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNjAwLmpzIiwibWFwcGluZ3MiOiI7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vbm9kZV9tb2R1bGVzL2N1c3RvbWl6ZXItc3luYy1oZWxwZXJzL2Rpc3QvcHJvbW90ZS1pbnRvLXJlc3BvbnNpdmUuanM/Y2NhYSJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCAnX19lc01vZHVsZScsIHsgdmFsdWU6IHRydWUgfSk7XG5cbnZhciBtYXliZVByb21vdGVTY2FsYXJWYWx1ZUludG9SZXNwb25zaXZlID0gZnVuY3Rpb24gbWF5YmVQcm9tb3RlU2NhbGFyVmFsdWVJbnRvUmVzcG9uc2l2ZSh2YWx1ZSkge1xuICB2YXIgaXNSZXNwb25zaXZlID0gYXJndW1lbnRzLmxlbmd0aCA+IDEgJiYgYXJndW1lbnRzWzFdICE9PSB1bmRlZmluZWQgPyBhcmd1bWVudHNbMV0gOiB0cnVlO1xuXG4gIC8qKlxuICAgKiBSZXNwb25zaXZlIHZhbHVlIG11c3QgbmVjZXNzYXJpbHkgaGF2ZSB0aGUgZGVza3RvcCBrZXkgYXR0YWNoZWQgdG8gaXRcbiAgICovXG4gIGlmICh2YWx1ZSAmJiBPYmplY3Qua2V5cyh2YWx1ZSkuaW5kZXhPZignZGVza3RvcCcpID4gLTEpIHtcbiAgICBpZiAoIWlzUmVzcG9uc2l2ZSkge1xuICAgICAgcmV0dXJuIHZhbHVlLmRlc2t0b3A7XG4gICAgfVxuXG4gICAgcmV0dXJuIHZhbHVlO1xuICB9XG5cbiAgaWYgKCFpc1Jlc3BvbnNpdmUpIHtcbiAgICByZXR1cm4gdmFsdWU7XG4gIH1cblxuICByZXR1cm4ge1xuICAgIGRlc2t0b3A6IHZhbHVlLFxuICAgIHRhYmxldDogdmFsdWUsXG4gICAgbW9iaWxlOiB2YWx1ZVxuICB9O1xufTtcblxuZXhwb3J0cy5tYXliZVByb21vdGVTY2FsYXJWYWx1ZUludG9SZXNwb25zaXZlID0gbWF5YmVQcm9tb3RlU2NhbGFyVmFsdWVJbnRvUmVzcG9uc2l2ZTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXByb21vdGUtaW50by1yZXNwb25zaXZlLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///600\n")},251:(module,__unused_webpack_exports,__webpack_require__)=>{eval("var objectKeys = __webpack_require__(2215);\nvar isArguments = __webpack_require__(2584);\nvar is = __webpack_require__(609);\nvar isRegex = __webpack_require__(8420);\nvar flags = __webpack_require__(2847);\nvar isDate = __webpack_require__(8923);\n\nvar getTime = Date.prototype.getTime;\n\nfunction deepEqual(actual, expected, options) {\n var opts = options || {};\n\n // 7.1. All identical values are equivalent, as determined by ===.\n if (opts.strict ? is(actual, expected) : actual === expected) {\n return true;\n }\n\n // 7.3. Other pairs that do not both pass typeof value == 'object', equivalence is determined by ==.\n if (!actual || !expected || (typeof actual !== 'object' && typeof expected !== 'object')) {\n return opts.strict ? is(actual, expected) : actual == expected;\n }\n\n /*\n * 7.4. For all other Object pairs, including Array objects, equivalence is\n * determined by having the same number of owned properties (as verified\n * with Object.prototype.hasOwnProperty.call), the same set of keys\n * (although not necessarily the same order), equivalent values for every\n * corresponding key, and an identical 'prototype' property. Note: this\n * accounts for both named and indexed properties on Arrays.\n */\n // eslint-disable-next-line no-use-before-define\n return objEquiv(actual, expected, opts);\n}\n\nfunction isUndefinedOrNull(value) {\n return value === null || value === undefined;\n}\n\nfunction isBuffer(x) {\n if (!x || typeof x !== 'object' || typeof x.length !== 'number') {\n return false;\n }\n if (typeof x.copy !== 'function' || typeof x.slice !== 'function') {\n return false;\n }\n if (x.length > 0 && typeof x[0] !== 'number') {\n return false;\n }\n return true;\n}\n\nfunction objEquiv(a, b, opts) {\n /* eslint max-statements: [2, 50] */\n var i, key;\n if (typeof a !== typeof b) { return false; }\n if (isUndefinedOrNull(a) || isUndefinedOrNull(b)) { return false; }\n\n // an identical 'prototype' property.\n if (a.prototype !== b.prototype) { return false; }\n\n if (isArguments(a) !== isArguments(b)) { return false; }\n\n var aIsRegex = isRegex(a);\n var bIsRegex = isRegex(b);\n if (aIsRegex !== bIsRegex) { return false; }\n if (aIsRegex || bIsRegex) {\n return a.source === b.source && flags(a) === flags(b);\n }\n\n if (isDate(a) && isDate(b)) {\n return getTime.call(a) === getTime.call(b);\n }\n\n var aIsBuffer = isBuffer(a);\n var bIsBuffer = isBuffer(b);\n if (aIsBuffer !== bIsBuffer) { return false; }\n if (aIsBuffer || bIsBuffer) { // && would work too, because both are true or both false here\n if (a.length !== b.length) { return false; }\n for (i = 0; i < a.length; i++) {\n if (a[i] !== b[i]) { return false; }\n }\n return true;\n }\n\n if (typeof a !== typeof b) { return false; }\n\n try {\n var ka = objectKeys(a);\n var kb = objectKeys(b);\n } catch (e) { // happens when one is a string literal and the other isn't\n return false;\n }\n // having the same number of owned properties (keys incorporates hasOwnProperty)\n if (ka.length !== kb.length) { return false; }\n\n // the same set of keys (although not necessarily the same order),\n ka.sort();\n kb.sort();\n // ~~~cheap key test\n for (i = ka.length - 1; i >= 0; i--) {\n if (ka[i] != kb[i]) { return false; }\n }\n // equivalent values for every corresponding key, and ~~~possibly expensive deep test\n for (i = ka.length - 1; i >= 0; i--) {\n key = ka[i];\n if (!deepEqual(a[key], b[key], opts)) { return false; }\n }\n\n return true;\n}\n\nmodule.exports = deepEqual;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMjUxLmpzIiwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9ub2RlX21vZHVsZXMvZGVlcC1lcXVhbC9pbmRleC5qcz83ZmFlIl0sInNvdXJjZXNDb250ZW50IjpbInZhciBvYmplY3RLZXlzID0gcmVxdWlyZSgnb2JqZWN0LWtleXMnKTtcbnZhciBpc0FyZ3VtZW50cyA9IHJlcXVpcmUoJ2lzLWFyZ3VtZW50cycpO1xudmFyIGlzID0gcmVxdWlyZSgnb2JqZWN0LWlzJyk7XG52YXIgaXNSZWdleCA9IHJlcXVpcmUoJ2lzLXJlZ2V4Jyk7XG52YXIgZmxhZ3MgPSByZXF1aXJlKCdyZWdleHAucHJvdG90eXBlLmZsYWdzJyk7XG52YXIgaXNEYXRlID0gcmVxdWlyZSgnaXMtZGF0ZS1vYmplY3QnKTtcblxudmFyIGdldFRpbWUgPSBEYXRlLnByb3RvdHlwZS5nZXRUaW1lO1xuXG5mdW5jdGlvbiBkZWVwRXF1YWwoYWN0dWFsLCBleHBlY3RlZCwgb3B0aW9ucykge1xuICB2YXIgb3B0cyA9IG9wdGlvbnMgfHwge307XG5cbiAgLy8gNy4xLiBBbGwgaWRlbnRpY2FsIHZhbHVlcyBhcmUgZXF1aXZhbGVudCwgYXMgZGV0ZXJtaW5lZCBieSA9PT0uXG4gIGlmIChvcHRzLnN0cmljdCA/IGlzKGFjdHVhbCwgZXhwZWN0ZWQpIDogYWN0dWFsID09PSBleHBlY3RlZCkge1xuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgLy8gNy4zLiBPdGhlciBwYWlycyB0aGF0IGRvIG5vdCBib3RoIHBhc3MgdHlwZW9mIHZhbHVlID09ICdvYmplY3QnLCBlcXVpdmFsZW5jZSBpcyBkZXRlcm1pbmVkIGJ5ID09LlxuICBpZiAoIWFjdHVhbCB8fCAhZXhwZWN0ZWQgfHwgKHR5cGVvZiBhY3R1YWwgIT09ICdvYmplY3QnICYmIHR5cGVvZiBleHBlY3RlZCAhPT0gJ29iamVjdCcpKSB7XG4gICAgcmV0dXJuIG9wdHMuc3RyaWN0ID8gaXMoYWN0dWFsLCBleHBlY3RlZCkgOiBhY3R1YWwgPT0gZXhwZWN0ZWQ7XG4gIH1cblxuICAvKlxuICAgKiA3LjQuIEZvciBhbGwgb3RoZXIgT2JqZWN0IHBhaXJzLCBpbmNsdWRpbmcgQXJyYXkgb2JqZWN0cywgZXF1aXZhbGVuY2UgaXNcbiAgICogZGV0ZXJtaW5lZCBieSBoYXZpbmcgdGhlIHNhbWUgbnVtYmVyIG9mIG93bmVkIHByb3BlcnRpZXMgKGFzIHZlcmlmaWVkXG4gICAqIHdpdGggT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKSwgdGhlIHNhbWUgc2V0IG9mIGtleXNcbiAgICogKGFsdGhvdWdoIG5vdCBuZWNlc3NhcmlseSB0aGUgc2FtZSBvcmRlciksIGVxdWl2YWxlbnQgdmFsdWVzIGZvciBldmVyeVxuICAgKiBjb3JyZXNwb25kaW5nIGtleSwgYW5kIGFuIGlkZW50aWNhbCAncHJvdG90eXBlJyBwcm9wZXJ0eS4gTm90ZTogdGhpc1xuICAgKiBhY2NvdW50cyBmb3IgYm90aCBuYW1lZCBhbmQgaW5kZXhlZCBwcm9wZXJ0aWVzIG9uIEFycmF5cy5cbiAgICovXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby11c2UtYmVmb3JlLWRlZmluZVxuICByZXR1cm4gb2JqRXF1aXYoYWN0dWFsLCBleHBlY3RlZCwgb3B0cyk7XG59XG5cbmZ1bmN0aW9uIGlzVW5kZWZpbmVkT3JOdWxsKHZhbHVlKSB7XG4gIHJldHVybiB2YWx1ZSA9PT0gbnVsbCB8fCB2YWx1ZSA9PT0gdW5kZWZpbmVkO1xufVxuXG5mdW5jdGlvbiBpc0J1ZmZlcih4KSB7XG4gIGlmICgheCB8fCB0eXBlb2YgeCAhPT0gJ29iamVjdCcgfHwgdHlwZW9mIHgubGVuZ3RoICE9PSAnbnVtYmVyJykge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuICBpZiAodHlwZW9mIHguY29weSAhPT0gJ2Z1bmN0aW9uJyB8fCB0eXBlb2YgeC5zbGljZSAhPT0gJ2Z1bmN0aW9uJykge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuICBpZiAoeC5sZW5ndGggPiAwICYmIHR5cGVvZiB4WzBdICE9PSAnbnVtYmVyJykge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuICByZXR1cm4gdHJ1ZTtcbn1cblxuZnVuY3Rpb24gb2JqRXF1aXYoYSwgYiwgb3B0cykge1xuICAvKiBlc2xpbnQgbWF4LXN0YXRlbWVudHM6IFsyLCA1MF0gKi9cbiAgdmFyIGksIGtleTtcbiAgaWYgKHR5cGVvZiBhICE9PSB0eXBlb2YgYikgeyByZXR1cm4gZmFsc2U7IH1cbiAgaWYgKGlzVW5kZWZpbmVkT3JOdWxsKGEpIHx8IGlzVW5kZWZpbmVkT3JOdWxsKGIpKSB7IHJldHVybiBmYWxzZTsgfVxuXG4gIC8vIGFuIGlkZW50aWNhbCAncHJvdG90eXBlJyBwcm9wZXJ0eS5cbiAgaWYgKGEucHJvdG90eXBlICE9PSBiLnByb3RvdHlwZSkgeyByZXR1cm4gZmFsc2U7IH1cblxuICBpZiAoaXNBcmd1bWVudHMoYSkgIT09IGlzQXJndW1lbnRzKGIpKSB7IHJldHVybiBmYWxzZTsgfVxuXG4gIHZhciBhSXNSZWdleCA9IGlzUmVnZXgoYSk7XG4gIHZhciBiSXNSZWdleCA9IGlzUmVnZXgoYik7XG4gIGlmIChhSXNSZWdleCAhPT0gYklzUmVnZXgpIHsgcmV0dXJuIGZhbHNlOyB9XG4gIGlmIChhSXNSZWdleCB8fCBiSXNSZWdleCkge1xuICAgIHJldHVybiBhLnNvdXJjZSA9PT0gYi5zb3VyY2UgJiYgZmxhZ3MoYSkgPT09IGZsYWdzKGIpO1xuICB9XG5cbiAgaWYgKGlzRGF0ZShhKSAmJiBpc0RhdGUoYikpIHtcbiAgICByZXR1cm4gZ2V0VGltZS5jYWxsKGEpID09PSBnZXRUaW1lLmNhbGwoYik7XG4gIH1cblxuICB2YXIgYUlzQnVmZmVyID0gaXNCdWZmZXIoYSk7XG4gIHZhciBiSXNCdWZmZXIgPSBpc0J1ZmZlcihiKTtcbiAgaWYgKGFJc0J1ZmZlciAhPT0gYklzQnVmZmVyKSB7IHJldHVybiBmYWxzZTsgfVxuICBpZiAoYUlzQnVmZmVyIHx8IGJJc0J1ZmZlcikgeyAvLyAmJiB3b3VsZCB3b3JrIHRvbywgYmVjYXVzZSBib3RoIGFyZSB0cnVlIG9yIGJvdGggZmFsc2UgaGVyZVxuICAgIGlmIChhLmxlbmd0aCAhPT0gYi5sZW5ndGgpIHsgcmV0dXJuIGZhbHNlOyB9XG4gICAgZm9yIChpID0gMDsgaSA8IGEubGVuZ3RoOyBpKyspIHtcbiAgICAgIGlmIChhW2ldICE9PSBiW2ldKSB7IHJldHVybiBmYWxzZTsgfVxuICAgIH1cbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIGlmICh0eXBlb2YgYSAhPT0gdHlwZW9mIGIpIHsgcmV0dXJuIGZhbHNlOyB9XG5cbiAgdHJ5IHtcbiAgICB2YXIga2EgPSBvYmplY3RLZXlzKGEpO1xuICAgIHZhciBrYiA9IG9iamVjdEtleXMoYik7XG4gIH0gY2F0Y2ggKGUpIHsgLy8gaGFwcGVucyB3aGVuIG9uZSBpcyBhIHN0cmluZyBsaXRlcmFsIGFuZCB0aGUgb3RoZXIgaXNuJ3RcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cbiAgLy8gaGF2aW5nIHRoZSBzYW1lIG51bWJlciBvZiBvd25lZCBwcm9wZXJ0aWVzIChrZXlzIGluY29ycG9yYXRlcyBoYXNPd25Qcm9wZXJ0eSlcbiAgaWYgKGthLmxlbmd0aCAhPT0ga2IubGVuZ3RoKSB7IHJldHVybiBmYWxzZTsgfVxuXG4gIC8vIHRoZSBzYW1lIHNldCBvZiBrZXlzIChhbHRob3VnaCBub3QgbmVjZXNzYXJpbHkgdGhlIHNhbWUgb3JkZXIpLFxuICBrYS5zb3J0KCk7XG4gIGtiLnNvcnQoKTtcbiAgLy8gfn5+Y2hlYXAga2V5IHRlc3RcbiAgZm9yIChpID0ga2EubGVuZ3RoIC0gMTsgaSA+PSAwOyBpLS0pIHtcbiAgICBpZiAoa2FbaV0gIT0ga2JbaV0pIHsgcmV0dXJuIGZhbHNlOyB9XG4gIH1cbiAgLy8gZXF1aXZhbGVudCB2YWx1ZXMgZm9yIGV2ZXJ5IGNvcnJlc3BvbmRpbmcga2V5LCBhbmQgfn5+cG9zc2libHkgZXhwZW5zaXZlIGRlZXAgdGVzdFxuICBmb3IgKGkgPSBrYS5sZW5ndGggLSAxOyBpID49IDA7IGktLSkge1xuICAgIGtleSA9IGthW2ldO1xuICAgIGlmICghZGVlcEVxdWFsKGFba2V5XSwgYltrZXldLCBvcHRzKSkgeyByZXR1cm4gZmFsc2U7IH1cbiAgfVxuXG4gIHJldHVybiB0cnVlO1xufVxuXG5tb2R1bGUuZXhwb3J0cyA9IGRlZXBFcXVhbDtcbiJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///251\n")},4289:(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval("\n\nvar keys = __webpack_require__(2215);\nvar hasSymbols = typeof Symbol === 'function' && typeof Symbol('foo') === 'symbol';\n\nvar toStr = Object.prototype.toString;\nvar concat = Array.prototype.concat;\nvar origDefineProperty = Object.defineProperty;\n\nvar isFunction = function (fn) {\n\treturn typeof fn === 'function' && toStr.call(fn) === '[object Function]';\n};\n\nvar hasPropertyDescriptors = __webpack_require__(1044)();\n\nvar supportsDescriptors = origDefineProperty && hasPropertyDescriptors;\n\nvar defineProperty = function (object, name, value, predicate) {\n\tif (name in object && (!isFunction(predicate) || !predicate())) {\n\t\treturn;\n\t}\n\tif (supportsDescriptors) {\n\t\torigDefineProperty(object, name, {\n\t\t\tconfigurable: true,\n\t\t\tenumerable: false,\n\t\t\tvalue: value,\n\t\t\twritable: true\n\t\t});\n\t} else {\n\t\tobject[name] = value; // eslint-disable-line no-param-reassign\n\t}\n};\n\nvar defineProperties = function (object, map) {\n\tvar predicates = arguments.length > 2 ? arguments[2] : {};\n\tvar props = keys(map);\n\tif (hasSymbols) {\n\t\tprops = concat.call(props, Object.getOwnPropertySymbols(map));\n\t}\n\tfor (var i = 0; i < props.length; i += 1) {\n\t\tdefineProperty(object, props[i], map[props[i]], predicates[props[i]]);\n\t}\n};\n\ndefineProperties.supportsDescriptors = !!supportsDescriptors;\n\nmodule.exports = defineProperties;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNDI4OS5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9ub2RlX21vZHVsZXMvZGVmaW5lLXByb3BlcnRpZXMvaW5kZXguanM/ZjM2NyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbnZhciBrZXlzID0gcmVxdWlyZSgnb2JqZWN0LWtleXMnKTtcbnZhciBoYXNTeW1ib2xzID0gdHlwZW9mIFN5bWJvbCA9PT0gJ2Z1bmN0aW9uJyAmJiB0eXBlb2YgU3ltYm9sKCdmb28nKSA9PT0gJ3N5bWJvbCc7XG5cbnZhciB0b1N0ciA9IE9iamVjdC5wcm90b3R5cGUudG9TdHJpbmc7XG52YXIgY29uY2F0ID0gQXJyYXkucHJvdG90eXBlLmNvbmNhdDtcbnZhciBvcmlnRGVmaW5lUHJvcGVydHkgPSBPYmplY3QuZGVmaW5lUHJvcGVydHk7XG5cbnZhciBpc0Z1bmN0aW9uID0gZnVuY3Rpb24gKGZuKSB7XG5cdHJldHVybiB0eXBlb2YgZm4gPT09ICdmdW5jdGlvbicgJiYgdG9TdHIuY2FsbChmbikgPT09ICdbb2JqZWN0IEZ1bmN0aW9uXSc7XG59O1xuXG52YXIgaGFzUHJvcGVydHlEZXNjcmlwdG9ycyA9IHJlcXVpcmUoJ2hhcy1wcm9wZXJ0eS1kZXNjcmlwdG9ycycpKCk7XG5cbnZhciBzdXBwb3J0c0Rlc2NyaXB0b3JzID0gb3JpZ0RlZmluZVByb3BlcnR5ICYmIGhhc1Byb3BlcnR5RGVzY3JpcHRvcnM7XG5cbnZhciBkZWZpbmVQcm9wZXJ0eSA9IGZ1bmN0aW9uIChvYmplY3QsIG5hbWUsIHZhbHVlLCBwcmVkaWNhdGUpIHtcblx0aWYgKG5hbWUgaW4gb2JqZWN0ICYmICghaXNGdW5jdGlvbihwcmVkaWNhdGUpIHx8ICFwcmVkaWNhdGUoKSkpIHtcblx0XHRyZXR1cm47XG5cdH1cblx0aWYgKHN1cHBvcnRzRGVzY3JpcHRvcnMpIHtcblx0XHRvcmlnRGVmaW5lUHJvcGVydHkob2JqZWN0LCBuYW1lLCB7XG5cdFx0XHRjb25maWd1cmFibGU6IHRydWUsXG5cdFx0XHRlbnVtZXJhYmxlOiBmYWxzZSxcblx0XHRcdHZhbHVlOiB2YWx1ZSxcblx0XHRcdHdyaXRhYmxlOiB0cnVlXG5cdFx0fSk7XG5cdH0gZWxzZSB7XG5cdFx0b2JqZWN0W25hbWVdID0gdmFsdWU7IC8vIGVzbGludC1kaXNhYmxlLWxpbmUgbm8tcGFyYW0tcmVhc3NpZ25cblx0fVxufTtcblxudmFyIGRlZmluZVByb3BlcnRpZXMgPSBmdW5jdGlvbiAob2JqZWN0LCBtYXApIHtcblx0dmFyIHByZWRpY2F0ZXMgPSBhcmd1bWVudHMubGVuZ3RoID4gMiA/IGFyZ3VtZW50c1syXSA6IHt9O1xuXHR2YXIgcHJvcHMgPSBrZXlzKG1hcCk7XG5cdGlmIChoYXNTeW1ib2xzKSB7XG5cdFx0cHJvcHMgPSBjb25jYXQuY2FsbChwcm9wcywgT2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9scyhtYXApKTtcblx0fVxuXHRmb3IgKHZhciBpID0gMDsgaSA8IHByb3BzLmxlbmd0aDsgaSArPSAxKSB7XG5cdFx0ZGVmaW5lUHJvcGVydHkob2JqZWN0LCBwcm9wc1tpXSwgbWFwW3Byb3BzW2ldXSwgcHJlZGljYXRlc1twcm9wc1tpXV0pO1xuXHR9XG59O1xuXG5kZWZpbmVQcm9wZXJ0aWVzLnN1cHBvcnRzRGVzY3JpcHRvcnMgPSAhIXN1cHBvcnRzRGVzY3JpcHRvcnM7XG5cbm1vZHVsZS5leHBvcnRzID0gZGVmaW5lUHJvcGVydGllcztcbiJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///4289\n")},6781:(__unused_webpack_module,exports)=>{"use strict";eval('var __webpack_unused_export__;\n/** @license React v17.0.2\n * react-is.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nvar b=60103,c=60106,d=60107,e=60108,f=60114,g=60109,h=60110,k=60112,l=60113,m=60120,n=60115,p=60116,q=60121,r=60122,u=60117,v=60129,w=60131;\nif("function"===typeof Symbol&&Symbol.for){var x=Symbol.for;b=x("react.element");c=x("react.portal");d=x("react.fragment");e=x("react.strict_mode");f=x("react.profiler");g=x("react.provider");h=x("react.context");k=x("react.forward_ref");l=x("react.suspense");m=x("react.suspense_list");n=x("react.memo");p=x("react.lazy");q=x("react.block");r=x("react.server.block");u=x("react.fundamental");v=x("react.debug_trace_mode");w=x("react.legacy_hidden")}\nfunction y(a){if("object"===typeof a&&null!==a){var t=a.$$typeof;switch(t){case b:switch(a=a.type,a){case d:case f:case e:case l:case m:return a;default:switch(a=a&&a.$$typeof,a){case h:case k:case p:case n:case g:return a;default:return t}}case c:return t}}}var z=g,A=b,B=k,C=d,D=p,E=n,F=c,G=f,H=e,I=l;__webpack_unused_export__=h;__webpack_unused_export__=z;__webpack_unused_export__=A;__webpack_unused_export__=B;__webpack_unused_export__=C;__webpack_unused_export__=D;__webpack_unused_export__=E;__webpack_unused_export__=F;__webpack_unused_export__=G;__webpack_unused_export__=H;\n__webpack_unused_export__=I;__webpack_unused_export__=function(){return!1};__webpack_unused_export__=function(){return!1};__webpack_unused_export__=function(a){return y(a)===h};__webpack_unused_export__=function(a){return y(a)===g};__webpack_unused_export__=function(a){return"object"===typeof a&&null!==a&&a.$$typeof===b};__webpack_unused_export__=function(a){return y(a)===k};__webpack_unused_export__=function(a){return y(a)===d};__webpack_unused_export__=function(a){return y(a)===p};__webpack_unused_export__=function(a){return y(a)===n};\n__webpack_unused_export__=function(a){return y(a)===c};__webpack_unused_export__=function(a){return y(a)===f};__webpack_unused_export__=function(a){return y(a)===e};__webpack_unused_export__=function(a){return y(a)===l};__webpack_unused_export__=function(a){return"string"===typeof a||"function"===typeof a||a===d||a===f||a===v||a===e||a===l||a===m||a===w||"object"===typeof a&&null!==a&&(a.$$typeof===p||a.$$typeof===n||a.$$typeof===g||a.$$typeof===h||a.$$typeof===k||a.$$typeof===u||a.$$typeof===q||a[0]===r)?!0:!1};\n__webpack_unused_export__=y;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNjc4MS5qcyIsIm1hcHBpbmdzIjoiO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vbm9kZV9tb2R1bGVzL2Rvd25zaGlmdC9ub2RlX21vZHVsZXMvcmVhY3QtaXMvY2pzL3JlYWN0LWlzLnByb2R1Y3Rpb24ubWluLmpzP2U1YTAiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBsaWNlbnNlIFJlYWN0IHYxNy4wLjJcbiAqIHJlYWN0LWlzLnByb2R1Y3Rpb24ubWluLmpzXG4gKlxuICogQ29weXJpZ2h0IChjKSBGYWNlYm9vaywgSW5jLiBhbmQgaXRzIGFmZmlsaWF0ZXMuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKi9cbid1c2Ugc3RyaWN0Jzt2YXIgYj02MDEwMyxjPTYwMTA2LGQ9NjAxMDcsZT02MDEwOCxmPTYwMTE0LGc9NjAxMDksaD02MDExMCxrPTYwMTEyLGw9NjAxMTMsbT02MDEyMCxuPTYwMTE1LHA9NjAxMTYscT02MDEyMSxyPTYwMTIyLHU9NjAxMTcsdj02MDEyOSx3PTYwMTMxO1xuaWYoXCJmdW5jdGlvblwiPT09dHlwZW9mIFN5bWJvbCYmU3ltYm9sLmZvcil7dmFyIHg9U3ltYm9sLmZvcjtiPXgoXCJyZWFjdC5lbGVtZW50XCIpO2M9eChcInJlYWN0LnBvcnRhbFwiKTtkPXgoXCJyZWFjdC5mcmFnbWVudFwiKTtlPXgoXCJyZWFjdC5zdHJpY3RfbW9kZVwiKTtmPXgoXCJyZWFjdC5wcm9maWxlclwiKTtnPXgoXCJyZWFjdC5wcm92aWRlclwiKTtoPXgoXCJyZWFjdC5jb250ZXh0XCIpO2s9eChcInJlYWN0LmZvcndhcmRfcmVmXCIpO2w9eChcInJlYWN0LnN1c3BlbnNlXCIpO209eChcInJlYWN0LnN1c3BlbnNlX2xpc3RcIik7bj14KFwicmVhY3QubWVtb1wiKTtwPXgoXCJyZWFjdC5sYXp5XCIpO3E9eChcInJlYWN0LmJsb2NrXCIpO3I9eChcInJlYWN0LnNlcnZlci5ibG9ja1wiKTt1PXgoXCJyZWFjdC5mdW5kYW1lbnRhbFwiKTt2PXgoXCJyZWFjdC5kZWJ1Z190cmFjZV9tb2RlXCIpO3c9eChcInJlYWN0LmxlZ2FjeV9oaWRkZW5cIil9XG5mdW5jdGlvbiB5KGEpe2lmKFwib2JqZWN0XCI9PT10eXBlb2YgYSYmbnVsbCE9PWEpe3ZhciB0PWEuJCR0eXBlb2Y7c3dpdGNoKHQpe2Nhc2UgYjpzd2l0Y2goYT1hLnR5cGUsYSl7Y2FzZSBkOmNhc2UgZjpjYXNlIGU6Y2FzZSBsOmNhc2UgbTpyZXR1cm4gYTtkZWZhdWx0OnN3aXRjaChhPWEmJmEuJCR0eXBlb2YsYSl7Y2FzZSBoOmNhc2UgazpjYXNlIHA6Y2FzZSBuOmNhc2UgZzpyZXR1cm4gYTtkZWZhdWx0OnJldHVybiB0fX1jYXNlIGM6cmV0dXJuIHR9fX12YXIgej1nLEE9YixCPWssQz1kLEQ9cCxFPW4sRj1jLEc9ZixIPWUsST1sO2V4cG9ydHMuQ29udGV4dENvbnN1bWVyPWg7ZXhwb3J0cy5Db250ZXh0UHJvdmlkZXI9ejtleHBvcnRzLkVsZW1lbnQ9QTtleHBvcnRzLkZvcndhcmRSZWY9QjtleHBvcnRzLkZyYWdtZW50PUM7ZXhwb3J0cy5MYXp5PUQ7ZXhwb3J0cy5NZW1vPUU7ZXhwb3J0cy5Qb3J0YWw9RjtleHBvcnRzLlByb2ZpbGVyPUc7ZXhwb3J0cy5TdHJpY3RNb2RlPUg7XG5leHBvcnRzLlN1c3BlbnNlPUk7ZXhwb3J0cy5pc0FzeW5jTW9kZT1mdW5jdGlvbigpe3JldHVybiExfTtleHBvcnRzLmlzQ29uY3VycmVudE1vZGU9ZnVuY3Rpb24oKXtyZXR1cm4hMX07ZXhwb3J0cy5pc0NvbnRleHRDb25zdW1lcj1mdW5jdGlvbihhKXtyZXR1cm4geShhKT09PWh9O2V4cG9ydHMuaXNDb250ZXh0UHJvdmlkZXI9ZnVuY3Rpb24oYSl7cmV0dXJuIHkoYSk9PT1nfTtleHBvcnRzLmlzRWxlbWVudD1mdW5jdGlvbihhKXtyZXR1cm5cIm9iamVjdFwiPT09dHlwZW9mIGEmJm51bGwhPT1hJiZhLiQkdHlwZW9mPT09Yn07ZXhwb3J0cy5pc0ZvcndhcmRSZWY9ZnVuY3Rpb24oYSl7cmV0dXJuIHkoYSk9PT1rfTtleHBvcnRzLmlzRnJhZ21lbnQ9ZnVuY3Rpb24oYSl7cmV0dXJuIHkoYSk9PT1kfTtleHBvcnRzLmlzTGF6eT1mdW5jdGlvbihhKXtyZXR1cm4geShhKT09PXB9O2V4cG9ydHMuaXNNZW1vPWZ1bmN0aW9uKGEpe3JldHVybiB5KGEpPT09bn07XG5leHBvcnRzLmlzUG9ydGFsPWZ1bmN0aW9uKGEpe3JldHVybiB5KGEpPT09Y307ZXhwb3J0cy5pc1Byb2ZpbGVyPWZ1bmN0aW9uKGEpe3JldHVybiB5KGEpPT09Zn07ZXhwb3J0cy5pc1N0cmljdE1vZGU9ZnVuY3Rpb24oYSl7cmV0dXJuIHkoYSk9PT1lfTtleHBvcnRzLmlzU3VzcGVuc2U9ZnVuY3Rpb24oYSl7cmV0dXJuIHkoYSk9PT1sfTtleHBvcnRzLmlzVmFsaWRFbGVtZW50VHlwZT1mdW5jdGlvbihhKXtyZXR1cm5cInN0cmluZ1wiPT09dHlwZW9mIGF8fFwiZnVuY3Rpb25cIj09PXR5cGVvZiBhfHxhPT09ZHx8YT09PWZ8fGE9PT12fHxhPT09ZXx8YT09PWx8fGE9PT1tfHxhPT09d3x8XCJvYmplY3RcIj09PXR5cGVvZiBhJiZudWxsIT09YSYmKGEuJCR0eXBlb2Y9PT1wfHxhLiQkdHlwZW9mPT09bnx8YS4kJHR5cGVvZj09PWd8fGEuJCR0eXBlb2Y9PT1ofHxhLiQkdHlwZW9mPT09a3x8YS4kJHR5cGVvZj09PXV8fGEuJCR0eXBlb2Y9PT1xfHxhWzBdPT09cik/ITA6ITF9O1xuZXhwb3J0cy50eXBlT2Y9eTtcbiJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///6781\n')},1726:(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval("\n\nif (true) {\n /* unused reexport */ __webpack_require__(6781);\n} else {}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTcyNi5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9ub2RlX21vZHVsZXMvZG93bnNoaWZ0L25vZGVfbW9kdWxlcy9yZWFjdC1pcy9pbmRleC5qcz83MDNkIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuaWYgKHByb2Nlc3MuZW52Lk5PREVfRU5WID09PSAncHJvZHVjdGlvbicpIHtcbiAgbW9kdWxlLmV4cG9ydHMgPSByZXF1aXJlKCcuL2Nqcy9yZWFjdC1pcy5wcm9kdWN0aW9uLm1pbi5qcycpO1xufSBlbHNlIHtcbiAgbW9kdWxlLmV4cG9ydHMgPSByZXF1aXJlKCcuL2Nqcy9yZWFjdC1pcy5kZXZlbG9wbWVudC5qcycpO1xufVxuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///1726\n")},3172:(module,__unused_webpack_exports,__webpack_require__)=>{eval("var tabbable = __webpack_require__(4760);\nvar xtend = __webpack_require__(7529);\n\nvar listeningFocusTrap = null;\n\nfunction focusTrap(element, userOptions) {\n var doc = document;\n var container =\n typeof element === 'string' ? doc.querySelector(element) : element;\n\n var config = xtend(\n {\n returnFocusOnDeactivate: true,\n escapeDeactivates: true\n },\n userOptions\n );\n\n var state = {\n firstTabbableNode: null,\n lastTabbableNode: null,\n nodeFocusedBeforeActivation: null,\n mostRecentlyFocusedNode: null,\n active: false,\n paused: false\n };\n\n var trap = {\n activate: activate,\n deactivate: deactivate,\n pause: pause,\n unpause: unpause\n };\n\n return trap;\n\n function activate(activateOptions) {\n if (state.active) return;\n\n updateTabbableNodes();\n\n state.active = true;\n state.paused = false;\n state.nodeFocusedBeforeActivation = doc.activeElement;\n\n var onActivate =\n activateOptions && activateOptions.onActivate\n ? activateOptions.onActivate\n : config.onActivate;\n if (onActivate) {\n onActivate();\n }\n\n addListeners();\n return trap;\n }\n\n function deactivate(deactivateOptions) {\n if (!state.active) return;\n\n removeListeners();\n state.active = false;\n state.paused = false;\n\n var onDeactivate =\n deactivateOptions && deactivateOptions.onDeactivate !== undefined\n ? deactivateOptions.onDeactivate\n : config.onDeactivate;\n if (onDeactivate) {\n onDeactivate();\n }\n\n var returnFocus =\n deactivateOptions && deactivateOptions.returnFocus !== undefined\n ? deactivateOptions.returnFocus\n : config.returnFocusOnDeactivate;\n if (returnFocus) {\n delay(function() {\n tryFocus(state.nodeFocusedBeforeActivation);\n });\n }\n\n return trap;\n }\n\n function pause() {\n if (state.paused || !state.active) return;\n state.paused = true;\n removeListeners();\n }\n\n function unpause() {\n if (!state.paused || !state.active) return;\n state.paused = false;\n addListeners();\n }\n\n function addListeners() {\n if (!state.active) return;\n\n // There can be only one listening focus trap at a time\n if (listeningFocusTrap) {\n listeningFocusTrap.pause();\n }\n listeningFocusTrap = trap;\n\n updateTabbableNodes();\n\n // Delay ensures that the focused element doesn't capture the event\n // that caused the focus trap activation.\n delay(function() {\n tryFocus(getInitialFocusNode());\n });\n doc.addEventListener('focusin', checkFocusIn, true);\n doc.addEventListener('mousedown', checkPointerDown, true);\n doc.addEventListener('touchstart', checkPointerDown, true);\n doc.addEventListener('click', checkClick, true);\n doc.addEventListener('keydown', checkKey, true);\n\n return trap;\n }\n\n function removeListeners() {\n if (!state.active || listeningFocusTrap !== trap) return;\n\n doc.removeEventListener('focusin', checkFocusIn, true);\n doc.removeEventListener('mousedown', checkPointerDown, true);\n doc.removeEventListener('touchstart', checkPointerDown, true);\n doc.removeEventListener('click', checkClick, true);\n doc.removeEventListener('keydown', checkKey, true);\n\n listeningFocusTrap = null;\n\n return trap;\n }\n\n function getNodeForOption(optionName) {\n var optionValue = config[optionName];\n var node = optionValue;\n if (!optionValue) {\n return null;\n }\n if (typeof optionValue === 'string') {\n node = doc.querySelector(optionValue);\n if (!node) {\n throw new Error('`' + optionName + '` refers to no known node');\n }\n }\n if (typeof optionValue === 'function') {\n node = optionValue();\n if (!node) {\n throw new Error('`' + optionName + '` did not return a node');\n }\n }\n return node;\n }\n\n function getInitialFocusNode() {\n var node;\n if (getNodeForOption('initialFocus') !== null) {\n node = getNodeForOption('initialFocus');\n } else if (container.contains(doc.activeElement)) {\n node = doc.activeElement;\n } else {\n node = state.firstTabbableNode || getNodeForOption('fallbackFocus');\n }\n\n if (!node) {\n throw new Error(\n \"You can't have a focus-trap without at least one focusable element\"\n );\n }\n\n return node;\n }\n\n // This needs to be done on mousedown and touchstart instead of click\n // so that it precedes the focus event.\n function checkPointerDown(e) {\n if (container.contains(e.target)) return;\n if (config.clickOutsideDeactivates) {\n deactivate({\n returnFocus: !tabbable.isFocusable(e.target)\n });\n } else {\n e.preventDefault();\n }\n }\n\n // In case focus escapes the trap for some strange reason, pull it back in.\n function checkFocusIn(e) {\n // In Firefox when you Tab out of an iframe the Document is briefly focused.\n if (container.contains(e.target) || e.target instanceof Document) {\n return;\n }\n e.stopImmediatePropagation();\n tryFocus(state.mostRecentlyFocusedNode || getInitialFocusNode());\n }\n\n function checkKey(e) {\n if (config.escapeDeactivates !== false && isEscapeEvent(e)) {\n e.preventDefault();\n deactivate();\n return;\n }\n if (isTabEvent(e)) {\n checkTab(e);\n return;\n }\n }\n\n // Hijack Tab events on the first and last focusable nodes of the trap,\n // in order to prevent focus from escaping. If it escapes for even a\n // moment it can end up scrolling the page and causing confusion so we\n // kind of need to capture the action at the keydown phase.\n function checkTab(e) {\n updateTabbableNodes();\n if (e.shiftKey && e.target === state.firstTabbableNode) {\n e.preventDefault();\n tryFocus(state.lastTabbableNode);\n return;\n }\n if (!e.shiftKey && e.target === state.lastTabbableNode) {\n e.preventDefault();\n tryFocus(state.firstTabbableNode);\n return;\n }\n }\n\n function checkClick(e) {\n if (config.clickOutsideDeactivates) return;\n if (container.contains(e.target)) return;\n e.preventDefault();\n e.stopImmediatePropagation();\n }\n\n function updateTabbableNodes() {\n var tabbableNodes = tabbable(container);\n state.firstTabbableNode = tabbableNodes[0] || getInitialFocusNode();\n state.lastTabbableNode =\n tabbableNodes[tabbableNodes.length - 1] || getInitialFocusNode();\n }\n\n function tryFocus(node) {\n if (node === doc.activeElement) return;\n if (!node || !node.focus) {\n tryFocus(getInitialFocusNode());\n return;\n }\n\n node.focus();\n state.mostRecentlyFocusedNode = node;\n if (isSelectableInput(node)) {\n node.select();\n }\n }\n}\n\nfunction isSelectableInput(node) {\n return (\n node.tagName &&\n node.tagName.toLowerCase() === 'input' &&\n typeof node.select === 'function'\n );\n}\n\nfunction isEscapeEvent(e) {\n return e.key === 'Escape' || e.key === 'Esc' || e.keyCode === 27;\n}\n\nfunction isTabEvent(e) {\n return e.key === 'Tab' || e.keyCode === 9;\n}\n\nfunction delay(fn) {\n return setTimeout(fn, 0);\n}\n\nmodule.exports = focusTrap;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"3172.js","mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./node_modules/focus-trap/index.js?6c92"],"sourcesContent":["var tabbable = require('tabbable');\nvar xtend = require('xtend');\n\nvar listeningFocusTrap = null;\n\nfunction focusTrap(element, userOptions) {\n  var doc = document;\n  var container =\n    typeof element === 'string' ? doc.querySelector(element) : element;\n\n  var config = xtend(\n    {\n      returnFocusOnDeactivate: true,\n      escapeDeactivates: true\n    },\n    userOptions\n  );\n\n  var state = {\n    firstTabbableNode: null,\n    lastTabbableNode: null,\n    nodeFocusedBeforeActivation: null,\n    mostRecentlyFocusedNode: null,\n    active: false,\n    paused: false\n  };\n\n  var trap = {\n    activate: activate,\n    deactivate: deactivate,\n    pause: pause,\n    unpause: unpause\n  };\n\n  return trap;\n\n  function activate(activateOptions) {\n    if (state.active) return;\n\n    updateTabbableNodes();\n\n    state.active = true;\n    state.paused = false;\n    state.nodeFocusedBeforeActivation = doc.activeElement;\n\n    var onActivate =\n      activateOptions && activateOptions.onActivate\n        ? activateOptions.onActivate\n        : config.onActivate;\n    if (onActivate) {\n      onActivate();\n    }\n\n    addListeners();\n    return trap;\n  }\n\n  function deactivate(deactivateOptions) {\n    if (!state.active) return;\n\n    removeListeners();\n    state.active = false;\n    state.paused = false;\n\n    var onDeactivate =\n      deactivateOptions && deactivateOptions.onDeactivate !== undefined\n        ? deactivateOptions.onDeactivate\n        : config.onDeactivate;\n    if (onDeactivate) {\n      onDeactivate();\n    }\n\n    var returnFocus =\n      deactivateOptions && deactivateOptions.returnFocus !== undefined\n        ? deactivateOptions.returnFocus\n        : config.returnFocusOnDeactivate;\n    if (returnFocus) {\n      delay(function() {\n        tryFocus(state.nodeFocusedBeforeActivation);\n      });\n    }\n\n    return trap;\n  }\n\n  function pause() {\n    if (state.paused || !state.active) return;\n    state.paused = true;\n    removeListeners();\n  }\n\n  function unpause() {\n    if (!state.paused || !state.active) return;\n    state.paused = false;\n    addListeners();\n  }\n\n  function addListeners() {\n    if (!state.active) return;\n\n    // There can be only one listening focus trap at a time\n    if (listeningFocusTrap) {\n      listeningFocusTrap.pause();\n    }\n    listeningFocusTrap = trap;\n\n    updateTabbableNodes();\n\n    // Delay ensures that the focused element doesn't capture the event\n    // that caused the focus trap activation.\n    delay(function() {\n      tryFocus(getInitialFocusNode());\n    });\n    doc.addEventListener('focusin', checkFocusIn, true);\n    doc.addEventListener('mousedown', checkPointerDown, true);\n    doc.addEventListener('touchstart', checkPointerDown, true);\n    doc.addEventListener('click', checkClick, true);\n    doc.addEventListener('keydown', checkKey, true);\n\n    return trap;\n  }\n\n  function removeListeners() {\n    if (!state.active || listeningFocusTrap !== trap) return;\n\n    doc.removeEventListener('focusin', checkFocusIn, true);\n    doc.removeEventListener('mousedown', checkPointerDown, true);\n    doc.removeEventListener('touchstart', checkPointerDown, true);\n    doc.removeEventListener('click', checkClick, true);\n    doc.removeEventListener('keydown', checkKey, true);\n\n    listeningFocusTrap = null;\n\n    return trap;\n  }\n\n  function getNodeForOption(optionName) {\n    var optionValue = config[optionName];\n    var node = optionValue;\n    if (!optionValue) {\n      return null;\n    }\n    if (typeof optionValue === 'string') {\n      node = doc.querySelector(optionValue);\n      if (!node) {\n        throw new Error('`' + optionName + '` refers to no known node');\n      }\n    }\n    if (typeof optionValue === 'function') {\n      node = optionValue();\n      if (!node) {\n        throw new Error('`' + optionName + '` did not return a node');\n      }\n    }\n    return node;\n  }\n\n  function getInitialFocusNode() {\n    var node;\n    if (getNodeForOption('initialFocus') !== null) {\n      node = getNodeForOption('initialFocus');\n    } else if (container.contains(doc.activeElement)) {\n      node = doc.activeElement;\n    } else {\n      node = state.firstTabbableNode || getNodeForOption('fallbackFocus');\n    }\n\n    if (!node) {\n      throw new Error(\n        \"You can't have a focus-trap without at least one focusable element\"\n      );\n    }\n\n    return node;\n  }\n\n  // This needs to be done on mousedown and touchstart instead of click\n  // so that it precedes the focus event.\n  function checkPointerDown(e) {\n    if (container.contains(e.target)) return;\n    if (config.clickOutsideDeactivates) {\n      deactivate({\n        returnFocus: !tabbable.isFocusable(e.target)\n      });\n    } else {\n      e.preventDefault();\n    }\n  }\n\n  // In case focus escapes the trap for some strange reason, pull it back in.\n  function checkFocusIn(e) {\n    // In Firefox when you Tab out of an iframe the Document is briefly focused.\n    if (container.contains(e.target) || e.target instanceof Document) {\n      return;\n    }\n    e.stopImmediatePropagation();\n    tryFocus(state.mostRecentlyFocusedNode || getInitialFocusNode());\n  }\n\n  function checkKey(e) {\n    if (config.escapeDeactivates !== false && isEscapeEvent(e)) {\n      e.preventDefault();\n      deactivate();\n      return;\n    }\n    if (isTabEvent(e)) {\n      checkTab(e);\n      return;\n    }\n  }\n\n  // Hijack Tab events on the first and last focusable nodes of the trap,\n  // in order to prevent focus from escaping. If it escapes for even a\n  // moment it can end up scrolling the page and causing confusion so we\n  // kind of need to capture the action at the keydown phase.\n  function checkTab(e) {\n    updateTabbableNodes();\n    if (e.shiftKey && e.target === state.firstTabbableNode) {\n      e.preventDefault();\n      tryFocus(state.lastTabbableNode);\n      return;\n    }\n    if (!e.shiftKey && e.target === state.lastTabbableNode) {\n      e.preventDefault();\n      tryFocus(state.firstTabbableNode);\n      return;\n    }\n  }\n\n  function checkClick(e) {\n    if (config.clickOutsideDeactivates) return;\n    if (container.contains(e.target)) return;\n    e.preventDefault();\n    e.stopImmediatePropagation();\n  }\n\n  function updateTabbableNodes() {\n    var tabbableNodes = tabbable(container);\n    state.firstTabbableNode = tabbableNodes[0] || getInitialFocusNode();\n    state.lastTabbableNode =\n      tabbableNodes[tabbableNodes.length - 1] || getInitialFocusNode();\n  }\n\n  function tryFocus(node) {\n    if (node === doc.activeElement) return;\n    if (!node || !node.focus) {\n      tryFocus(getInitialFocusNode());\n      return;\n    }\n\n    node.focus();\n    state.mostRecentlyFocusedNode = node;\n    if (isSelectableInput(node)) {\n      node.select();\n    }\n  }\n}\n\nfunction isSelectableInput(node) {\n  return (\n    node.tagName &&\n    node.tagName.toLowerCase() === 'input' &&\n    typeof node.select === 'function'\n  );\n}\n\nfunction isEscapeEvent(e) {\n  return e.key === 'Escape' || e.key === 'Esc' || e.keyCode === 27;\n}\n\nfunction isTabEvent(e) {\n  return e.key === 'Tab' || e.keyCode === 9;\n}\n\nfunction delay(fn) {\n  return setTimeout(fn, 0);\n}\n\nmodule.exports = focusTrap;\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///3172\n")},7648:module=>{"use strict";eval("\n\n/* eslint no-invalid-this: 1 */\n\nvar ERROR_MESSAGE = 'Function.prototype.bind called on incompatible ';\nvar slice = Array.prototype.slice;\nvar toStr = Object.prototype.toString;\nvar funcType = '[object Function]';\n\nmodule.exports = function bind(that) {\n var target = this;\n if (typeof target !== 'function' || toStr.call(target) !== funcType) {\n throw new TypeError(ERROR_MESSAGE + target);\n }\n var args = slice.call(arguments, 1);\n\n var bound;\n var binder = function () {\n if (this instanceof bound) {\n var result = target.apply(\n this,\n args.concat(slice.call(arguments))\n );\n if (Object(result) === result) {\n return result;\n }\n return this;\n } else {\n return target.apply(\n that,\n args.concat(slice.call(arguments))\n );\n }\n };\n\n var boundLength = Math.max(0, target.length - args.length);\n var boundArgs = [];\n for (var i = 0; i < boundLength; i++) {\n boundArgs.push('$' + i);\n }\n\n bound = Function('binder', 'return function (' + boundArgs.join(',') + '){ return binder.apply(this,arguments); }')(binder);\n\n if (target.prototype) {\n var Empty = function Empty() {};\n Empty.prototype = target.prototype;\n bound.prototype = new Empty();\n Empty.prototype = null;\n }\n\n return bound;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNzY0OC5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vbm9kZV9tb2R1bGVzL2Z1bmN0aW9uLWJpbmQvaW1wbGVtZW50YXRpb24uanM/Njg4ZSJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbi8qIGVzbGludCBuby1pbnZhbGlkLXRoaXM6IDEgKi9cblxudmFyIEVSUk9SX01FU1NBR0UgPSAnRnVuY3Rpb24ucHJvdG90eXBlLmJpbmQgY2FsbGVkIG9uIGluY29tcGF0aWJsZSAnO1xudmFyIHNsaWNlID0gQXJyYXkucHJvdG90eXBlLnNsaWNlO1xudmFyIHRvU3RyID0gT2JqZWN0LnByb3RvdHlwZS50b1N0cmluZztcbnZhciBmdW5jVHlwZSA9ICdbb2JqZWN0IEZ1bmN0aW9uXSc7XG5cbm1vZHVsZS5leHBvcnRzID0gZnVuY3Rpb24gYmluZCh0aGF0KSB7XG4gICAgdmFyIHRhcmdldCA9IHRoaXM7XG4gICAgaWYgKHR5cGVvZiB0YXJnZXQgIT09ICdmdW5jdGlvbicgfHwgdG9TdHIuY2FsbCh0YXJnZXQpICE9PSBmdW5jVHlwZSkge1xuICAgICAgICB0aHJvdyBuZXcgVHlwZUVycm9yKEVSUk9SX01FU1NBR0UgKyB0YXJnZXQpO1xuICAgIH1cbiAgICB2YXIgYXJncyA9IHNsaWNlLmNhbGwoYXJndW1lbnRzLCAxKTtcblxuICAgIHZhciBib3VuZDtcbiAgICB2YXIgYmluZGVyID0gZnVuY3Rpb24gKCkge1xuICAgICAgICBpZiAodGhpcyBpbnN0YW5jZW9mIGJvdW5kKSB7XG4gICAgICAgICAgICB2YXIgcmVzdWx0ID0gdGFyZ2V0LmFwcGx5KFxuICAgICAgICAgICAgICAgIHRoaXMsXG4gICAgICAgICAgICAgICAgYXJncy5jb25jYXQoc2xpY2UuY2FsbChhcmd1bWVudHMpKVxuICAgICAgICAgICAgKTtcbiAgICAgICAgICAgIGlmIChPYmplY3QocmVzdWx0KSA9PT0gcmVzdWx0KSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIHJlc3VsdDtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHJldHVybiB0aGlzO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgcmV0dXJuIHRhcmdldC5hcHBseShcbiAgICAgICAgICAgICAgICB0aGF0LFxuICAgICAgICAgICAgICAgIGFyZ3MuY29uY2F0KHNsaWNlLmNhbGwoYXJndW1lbnRzKSlcbiAgICAgICAgICAgICk7XG4gICAgICAgIH1cbiAgICB9O1xuXG4gICAgdmFyIGJvdW5kTGVuZ3RoID0gTWF0aC5tYXgoMCwgdGFyZ2V0Lmxlbmd0aCAtIGFyZ3MubGVuZ3RoKTtcbiAgICB2YXIgYm91bmRBcmdzID0gW107XG4gICAgZm9yICh2YXIgaSA9IDA7IGkgPCBib3VuZExlbmd0aDsgaSsrKSB7XG4gICAgICAgIGJvdW5kQXJncy5wdXNoKCckJyArIGkpO1xuICAgIH1cblxuICAgIGJvdW5kID0gRnVuY3Rpb24oJ2JpbmRlcicsICdyZXR1cm4gZnVuY3Rpb24gKCcgKyBib3VuZEFyZ3Muam9pbignLCcpICsgJyl7IHJldHVybiBiaW5kZXIuYXBwbHkodGhpcyxhcmd1bWVudHMpOyB9JykoYmluZGVyKTtcblxuICAgIGlmICh0YXJnZXQucHJvdG90eXBlKSB7XG4gICAgICAgIHZhciBFbXB0eSA9IGZ1bmN0aW9uIEVtcHR5KCkge307XG4gICAgICAgIEVtcHR5LnByb3RvdHlwZSA9IHRhcmdldC5wcm90b3R5cGU7XG4gICAgICAgIGJvdW5kLnByb3RvdHlwZSA9IG5ldyBFbXB0eSgpO1xuICAgICAgICBFbXB0eS5wcm90b3R5cGUgPSBudWxsO1xuICAgIH1cblxuICAgIHJldHVybiBib3VuZDtcbn07XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///7648\n")},8612:(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval("\n\nvar implementation = __webpack_require__(7648);\n\nmodule.exports = Function.prototype.bind || implementation;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiODYxMi5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9ub2RlX21vZHVsZXMvZnVuY3Rpb24tYmluZC9pbmRleC5qcz8wZjdjIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxudmFyIGltcGxlbWVudGF0aW9uID0gcmVxdWlyZSgnLi9pbXBsZW1lbnRhdGlvbicpO1xuXG5tb2R1bGUuZXhwb3J0cyA9IEZ1bmN0aW9uLnByb3RvdHlwZS5iaW5kIHx8IGltcGxlbWVudGF0aW9uO1xuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///8612\n")},5972:module=>{"use strict";eval("\n\nvar functionsHaveNames = function functionsHaveNames() {\n\treturn typeof function f() {}.name === 'string';\n};\n\nvar gOPD = Object.getOwnPropertyDescriptor;\nif (gOPD) {\n\ttry {\n\t\tgOPD([], 'length');\n\t} catch (e) {\n\t\t// IE 8 has a broken gOPD\n\t\tgOPD = null;\n\t}\n}\n\nfunctionsHaveNames.functionsHaveConfigurableNames = function functionsHaveConfigurableNames() {\n\tif (!functionsHaveNames() || !gOPD) {\n\t\treturn false;\n\t}\n\tvar desc = gOPD(function () {}, 'name');\n\treturn !!desc && !!desc.configurable;\n};\n\nvar $bind = Function.prototype.bind;\n\nfunctionsHaveNames.boundFunctionsHaveNames = function boundFunctionsHaveNames() {\n\treturn functionsHaveNames() && typeof $bind === 'function' && function f() {}.bind().name !== '';\n};\n\nmodule.exports = functionsHaveNames;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNTk3Mi5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vbm9kZV9tb2R1bGVzL2Z1bmN0aW9ucy1oYXZlLW5hbWVzL2luZGV4LmpzPzI1MDAiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG52YXIgZnVuY3Rpb25zSGF2ZU5hbWVzID0gZnVuY3Rpb24gZnVuY3Rpb25zSGF2ZU5hbWVzKCkge1xuXHRyZXR1cm4gdHlwZW9mIGZ1bmN0aW9uIGYoKSB7fS5uYW1lID09PSAnc3RyaW5nJztcbn07XG5cbnZhciBnT1BEID0gT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcjtcbmlmIChnT1BEKSB7XG5cdHRyeSB7XG5cdFx0Z09QRChbXSwgJ2xlbmd0aCcpO1xuXHR9IGNhdGNoIChlKSB7XG5cdFx0Ly8gSUUgOCBoYXMgYSBicm9rZW4gZ09QRFxuXHRcdGdPUEQgPSBudWxsO1xuXHR9XG59XG5cbmZ1bmN0aW9uc0hhdmVOYW1lcy5mdW5jdGlvbnNIYXZlQ29uZmlndXJhYmxlTmFtZXMgPSBmdW5jdGlvbiBmdW5jdGlvbnNIYXZlQ29uZmlndXJhYmxlTmFtZXMoKSB7XG5cdGlmICghZnVuY3Rpb25zSGF2ZU5hbWVzKCkgfHwgIWdPUEQpIHtcblx0XHRyZXR1cm4gZmFsc2U7XG5cdH1cblx0dmFyIGRlc2MgPSBnT1BEKGZ1bmN0aW9uICgpIHt9LCAnbmFtZScpO1xuXHRyZXR1cm4gISFkZXNjICYmICEhZGVzYy5jb25maWd1cmFibGU7XG59O1xuXG52YXIgJGJpbmQgPSBGdW5jdGlvbi5wcm90b3R5cGUuYmluZDtcblxuZnVuY3Rpb25zSGF2ZU5hbWVzLmJvdW5kRnVuY3Rpb25zSGF2ZU5hbWVzID0gZnVuY3Rpb24gYm91bmRGdW5jdGlvbnNIYXZlTmFtZXMoKSB7XG5cdHJldHVybiBmdW5jdGlvbnNIYXZlTmFtZXMoKSAmJiB0eXBlb2YgJGJpbmQgPT09ICdmdW5jdGlvbicgJiYgZnVuY3Rpb24gZigpIHt9LmJpbmQoKS5uYW1lICE9PSAnJztcbn07XG5cbm1vZHVsZS5leHBvcnRzID0gZnVuY3Rpb25zSGF2ZU5hbWVzO1xuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///5972\n")},210:(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval("\n\nvar undefined;\n\nvar $SyntaxError = SyntaxError;\nvar $Function = Function;\nvar $TypeError = TypeError;\n\n// eslint-disable-next-line consistent-return\nvar getEvalledConstructor = function (expressionSyntax) {\n\ttry {\n\t\treturn $Function('\"use strict\"; return (' + expressionSyntax + ').constructor;')();\n\t} catch (e) {}\n};\n\nvar $gOPD = Object.getOwnPropertyDescriptor;\nif ($gOPD) {\n\ttry {\n\t\t$gOPD({}, '');\n\t} catch (e) {\n\t\t$gOPD = null; // this is IE 8, which has a broken gOPD\n\t}\n}\n\nvar throwTypeError = function () {\n\tthrow new $TypeError();\n};\nvar ThrowTypeError = $gOPD\n\t? (function () {\n\t\ttry {\n\t\t\t// eslint-disable-next-line no-unused-expressions, no-caller, no-restricted-properties\n\t\t\targuments.callee; // IE 8 does not throw here\n\t\t\treturn throwTypeError;\n\t\t} catch (calleeThrows) {\n\t\t\ttry {\n\t\t\t\t// IE 8 throws on Object.getOwnPropertyDescriptor(arguments, '')\n\t\t\t\treturn $gOPD(arguments, 'callee').get;\n\t\t\t} catch (gOPDthrows) {\n\t\t\t\treturn throwTypeError;\n\t\t\t}\n\t\t}\n\t}())\n\t: throwTypeError;\n\nvar hasSymbols = __webpack_require__(1405)();\n\nvar getProto = Object.getPrototypeOf || function (x) { return x.__proto__; }; // eslint-disable-line no-proto\n\nvar needsEval = {};\n\nvar TypedArray = typeof Uint8Array === 'undefined' ? undefined : getProto(Uint8Array);\n\nvar INTRINSICS = {\n\t'%AggregateError%': typeof AggregateError === 'undefined' ? undefined : AggregateError,\n\t'%Array%': Array,\n\t'%ArrayBuffer%': typeof ArrayBuffer === 'undefined' ? undefined : ArrayBuffer,\n\t'%ArrayIteratorPrototype%': hasSymbols ? getProto([][Symbol.iterator]()) : undefined,\n\t'%AsyncFromSyncIteratorPrototype%': undefined,\n\t'%AsyncFunction%': needsEval,\n\t'%AsyncGenerator%': needsEval,\n\t'%AsyncGeneratorFunction%': needsEval,\n\t'%AsyncIteratorPrototype%': needsEval,\n\t'%Atomics%': typeof Atomics === 'undefined' ? undefined : Atomics,\n\t'%BigInt%': typeof BigInt === 'undefined' ? undefined : BigInt,\n\t'%Boolean%': Boolean,\n\t'%DataView%': typeof DataView === 'undefined' ? undefined : DataView,\n\t'%Date%': Date,\n\t'%decodeURI%': decodeURI,\n\t'%decodeURIComponent%': decodeURIComponent,\n\t'%encodeURI%': encodeURI,\n\t'%encodeURIComponent%': encodeURIComponent,\n\t'%Error%': Error,\n\t'%eval%': eval, // eslint-disable-line no-eval\n\t'%EvalError%': EvalError,\n\t'%Float32Array%': typeof Float32Array === 'undefined' ? undefined : Float32Array,\n\t'%Float64Array%': typeof Float64Array === 'undefined' ? undefined : Float64Array,\n\t'%FinalizationRegistry%': typeof FinalizationRegistry === 'undefined' ? undefined : FinalizationRegistry,\n\t'%Function%': $Function,\n\t'%GeneratorFunction%': needsEval,\n\t'%Int8Array%': typeof Int8Array === 'undefined' ? undefined : Int8Array,\n\t'%Int16Array%': typeof Int16Array === 'undefined' ? undefined : Int16Array,\n\t'%Int32Array%': typeof Int32Array === 'undefined' ? undefined : Int32Array,\n\t'%isFinite%': isFinite,\n\t'%isNaN%': isNaN,\n\t'%IteratorPrototype%': hasSymbols ? getProto(getProto([][Symbol.iterator]())) : undefined,\n\t'%JSON%': typeof JSON === 'object' ? JSON : undefined,\n\t'%Map%': typeof Map === 'undefined' ? undefined : Map,\n\t'%MapIteratorPrototype%': typeof Map === 'undefined' || !hasSymbols ? undefined : getProto(new Map()[Symbol.iterator]()),\n\t'%Math%': Math,\n\t'%Number%': Number,\n\t'%Object%': Object,\n\t'%parseFloat%': parseFloat,\n\t'%parseInt%': parseInt,\n\t'%Promise%': typeof Promise === 'undefined' ? undefined : Promise,\n\t'%Proxy%': typeof Proxy === 'undefined' ? undefined : Proxy,\n\t'%RangeError%': RangeError,\n\t'%ReferenceError%': ReferenceError,\n\t'%Reflect%': typeof Reflect === 'undefined' ? undefined : Reflect,\n\t'%RegExp%': RegExp,\n\t'%Set%': typeof Set === 'undefined' ? undefined : Set,\n\t'%SetIteratorPrototype%': typeof Set === 'undefined' || !hasSymbols ? undefined : getProto(new Set()[Symbol.iterator]()),\n\t'%SharedArrayBuffer%': typeof SharedArrayBuffer === 'undefined' ? undefined : SharedArrayBuffer,\n\t'%String%': String,\n\t'%StringIteratorPrototype%': hasSymbols ? getProto(''[Symbol.iterator]()) : undefined,\n\t'%Symbol%': hasSymbols ? Symbol : undefined,\n\t'%SyntaxError%': $SyntaxError,\n\t'%ThrowTypeError%': ThrowTypeError,\n\t'%TypedArray%': TypedArray,\n\t'%TypeError%': $TypeError,\n\t'%Uint8Array%': typeof Uint8Array === 'undefined' ? undefined : Uint8Array,\n\t'%Uint8ClampedArray%': typeof Uint8ClampedArray === 'undefined' ? undefined : Uint8ClampedArray,\n\t'%Uint16Array%': typeof Uint16Array === 'undefined' ? undefined : Uint16Array,\n\t'%Uint32Array%': typeof Uint32Array === 'undefined' ? undefined : Uint32Array,\n\t'%URIError%': URIError,\n\t'%WeakMap%': typeof WeakMap === 'undefined' ? undefined : WeakMap,\n\t'%WeakRef%': typeof WeakRef === 'undefined' ? undefined : WeakRef,\n\t'%WeakSet%': typeof WeakSet === 'undefined' ? undefined : WeakSet\n};\n\nvar doEval = function doEval(name) {\n\tvar value;\n\tif (name === '%AsyncFunction%') {\n\t\tvalue = getEvalledConstructor('async function () {}');\n\t} else if (name === '%GeneratorFunction%') {\n\t\tvalue = getEvalledConstructor('function* () {}');\n\t} else if (name === '%AsyncGeneratorFunction%') {\n\t\tvalue = getEvalledConstructor('async function* () {}');\n\t} else if (name === '%AsyncGenerator%') {\n\t\tvar fn = doEval('%AsyncGeneratorFunction%');\n\t\tif (fn) {\n\t\t\tvalue = fn.prototype;\n\t\t}\n\t} else if (name === '%AsyncIteratorPrototype%') {\n\t\tvar gen = doEval('%AsyncGenerator%');\n\t\tif (gen) {\n\t\t\tvalue = getProto(gen.prototype);\n\t\t}\n\t}\n\n\tINTRINSICS[name] = value;\n\n\treturn value;\n};\n\nvar LEGACY_ALIASES = {\n\t'%ArrayBufferPrototype%': ['ArrayBuffer', 'prototype'],\n\t'%ArrayPrototype%': ['Array', 'prototype'],\n\t'%ArrayProto_entries%': ['Array', 'prototype', 'entries'],\n\t'%ArrayProto_forEach%': ['Array', 'prototype', 'forEach'],\n\t'%ArrayProto_keys%': ['Array', 'prototype', 'keys'],\n\t'%ArrayProto_values%': ['Array', 'prototype', 'values'],\n\t'%AsyncFunctionPrototype%': ['AsyncFunction', 'prototype'],\n\t'%AsyncGenerator%': ['AsyncGeneratorFunction', 'prototype'],\n\t'%AsyncGeneratorPrototype%': ['AsyncGeneratorFunction', 'prototype', 'prototype'],\n\t'%BooleanPrototype%': ['Boolean', 'prototype'],\n\t'%DataViewPrototype%': ['DataView', 'prototype'],\n\t'%DatePrototype%': ['Date', 'prototype'],\n\t'%ErrorPrototype%': ['Error', 'prototype'],\n\t'%EvalErrorPrototype%': ['EvalError', 'prototype'],\n\t'%Float32ArrayPrototype%': ['Float32Array', 'prototype'],\n\t'%Float64ArrayPrototype%': ['Float64Array', 'prototype'],\n\t'%FunctionPrototype%': ['Function', 'prototype'],\n\t'%Generator%': ['GeneratorFunction', 'prototype'],\n\t'%GeneratorPrototype%': ['GeneratorFunction', 'prototype', 'prototype'],\n\t'%Int8ArrayPrototype%': ['Int8Array', 'prototype'],\n\t'%Int16ArrayPrototype%': ['Int16Array', 'prototype'],\n\t'%Int32ArrayPrototype%': ['Int32Array', 'prototype'],\n\t'%JSONParse%': ['JSON', 'parse'],\n\t'%JSONStringify%': ['JSON', 'stringify'],\n\t'%MapPrototype%': ['Map', 'prototype'],\n\t'%NumberPrototype%': ['Number', 'prototype'],\n\t'%ObjectPrototype%': ['Object', 'prototype'],\n\t'%ObjProto_toString%': ['Object', 'prototype', 'toString'],\n\t'%ObjProto_valueOf%': ['Object', 'prototype', 'valueOf'],\n\t'%PromisePrototype%': ['Promise', 'prototype'],\n\t'%PromiseProto_then%': ['Promise', 'prototype', 'then'],\n\t'%Promise_all%': ['Promise', 'all'],\n\t'%Promise_reject%': ['Promise', 'reject'],\n\t'%Promise_resolve%': ['Promise', 'resolve'],\n\t'%RangeErrorPrototype%': ['RangeError', 'prototype'],\n\t'%ReferenceErrorPrototype%': ['ReferenceError', 'prototype'],\n\t'%RegExpPrototype%': ['RegExp', 'prototype'],\n\t'%SetPrototype%': ['Set', 'prototype'],\n\t'%SharedArrayBufferPrototype%': ['SharedArrayBuffer', 'prototype'],\n\t'%StringPrototype%': ['String', 'prototype'],\n\t'%SymbolPrototype%': ['Symbol', 'prototype'],\n\t'%SyntaxErrorPrototype%': ['SyntaxError', 'prototype'],\n\t'%TypedArrayPrototype%': ['TypedArray', 'prototype'],\n\t'%TypeErrorPrototype%': ['TypeError', 'prototype'],\n\t'%Uint8ArrayPrototype%': ['Uint8Array', 'prototype'],\n\t'%Uint8ClampedArrayPrototype%': ['Uint8ClampedArray', 'prototype'],\n\t'%Uint16ArrayPrototype%': ['Uint16Array', 'prototype'],\n\t'%Uint32ArrayPrototype%': ['Uint32Array', 'prototype'],\n\t'%URIErrorPrototype%': ['URIError', 'prototype'],\n\t'%WeakMapPrototype%': ['WeakMap', 'prototype'],\n\t'%WeakSetPrototype%': ['WeakSet', 'prototype']\n};\n\nvar bind = __webpack_require__(8612);\nvar hasOwn = __webpack_require__(7642);\nvar $concat = bind.call(Function.call, Array.prototype.concat);\nvar $spliceApply = bind.call(Function.apply, Array.prototype.splice);\nvar $replace = bind.call(Function.call, String.prototype.replace);\nvar $strSlice = bind.call(Function.call, String.prototype.slice);\n\n/* adapted from https://github.com/lodash/lodash/blob/4.17.15/dist/lodash.js#L6735-L6744 */\nvar rePropName = /[^%.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|%$))/g;\nvar reEscapeChar = /\\\\(\\\\)?/g; /** Used to match backslashes in property paths. */\nvar stringToPath = function stringToPath(string) {\n\tvar first = $strSlice(string, 0, 1);\n\tvar last = $strSlice(string, -1);\n\tif (first === '%' && last !== '%') {\n\t\tthrow new $SyntaxError('invalid intrinsic syntax, expected closing `%`');\n\t} else if (last === '%' && first !== '%') {\n\t\tthrow new $SyntaxError('invalid intrinsic syntax, expected opening `%`');\n\t}\n\tvar result = [];\n\t$replace(string, rePropName, function (match, number, quote, subString) {\n\t\tresult[result.length] = quote ? $replace(subString, reEscapeChar, '$1') : number || match;\n\t});\n\treturn result;\n};\n/* end adaptation */\n\nvar getBaseIntrinsic = function getBaseIntrinsic(name, allowMissing) {\n\tvar intrinsicName = name;\n\tvar alias;\n\tif (hasOwn(LEGACY_ALIASES, intrinsicName)) {\n\t\talias = LEGACY_ALIASES[intrinsicName];\n\t\tintrinsicName = '%' + alias[0] + '%';\n\t}\n\n\tif (hasOwn(INTRINSICS, intrinsicName)) {\n\t\tvar value = INTRINSICS[intrinsicName];\n\t\tif (value === needsEval) {\n\t\t\tvalue = doEval(intrinsicName);\n\t\t}\n\t\tif (typeof value === 'undefined' && !allowMissing) {\n\t\t\tthrow new $TypeError('intrinsic ' + name + ' exists, but is not available. Please file an issue!');\n\t\t}\n\n\t\treturn {\n\t\t\talias: alias,\n\t\t\tname: intrinsicName,\n\t\t\tvalue: value\n\t\t};\n\t}\n\n\tthrow new $SyntaxError('intrinsic ' + name + ' does not exist!');\n};\n\nmodule.exports = function GetIntrinsic(name, allowMissing) {\n\tif (typeof name !== 'string' || name.length === 0) {\n\t\tthrow new $TypeError('intrinsic name must be a non-empty string');\n\t}\n\tif (arguments.length > 1 && typeof allowMissing !== 'boolean') {\n\t\tthrow new $TypeError('\"allowMissing\" argument must be a boolean');\n\t}\n\n\tvar parts = stringToPath(name);\n\tvar intrinsicBaseName = parts.length > 0 ? parts[0] : '';\n\n\tvar intrinsic = getBaseIntrinsic('%' + intrinsicBaseName + '%', allowMissing);\n\tvar intrinsicRealName = intrinsic.name;\n\tvar value = intrinsic.value;\n\tvar skipFurtherCaching = false;\n\n\tvar alias = intrinsic.alias;\n\tif (alias) {\n\t\tintrinsicBaseName = alias[0];\n\t\t$spliceApply(parts, $concat([0, 1], alias));\n\t}\n\n\tfor (var i = 1, isOwn = true; i < parts.length; i += 1) {\n\t\tvar part = parts[i];\n\t\tvar first = $strSlice(part, 0, 1);\n\t\tvar last = $strSlice(part, -1);\n\t\tif (\n\t\t\t(\n\t\t\t\t(first === '\"' || first === \"'\" || first === '`')\n\t\t\t\t|| (last === '\"' || last === \"'\" || last === '`')\n\t\t\t)\n\t\t\t&& first !== last\n\t\t) {\n\t\t\tthrow new $SyntaxError('property names with quotes must have matching quotes');\n\t\t}\n\t\tif (part === 'constructor' || !isOwn) {\n\t\t\tskipFurtherCaching = true;\n\t\t}\n\n\t\tintrinsicBaseName += '.' + part;\n\t\tintrinsicRealName = '%' + intrinsicBaseName + '%';\n\n\t\tif (hasOwn(INTRINSICS, intrinsicRealName)) {\n\t\t\tvalue = INTRINSICS[intrinsicRealName];\n\t\t} else if (value != null) {\n\t\t\tif (!(part in value)) {\n\t\t\t\tif (!allowMissing) {\n\t\t\t\t\tthrow new $TypeError('base intrinsic for ' + name + ' exists, but the property is not available.');\n\t\t\t\t}\n\t\t\t\treturn void undefined;\n\t\t\t}\n\t\t\tif ($gOPD && (i + 1) >= parts.length) {\n\t\t\t\tvar desc = $gOPD(value, part);\n\t\t\t\tisOwn = !!desc;\n\n\t\t\t\t// By convention, when a data property is converted to an accessor\n\t\t\t\t// property to emulate a data property that does not suffer from\n\t\t\t\t// the override mistake, that accessor's getter is marked with\n\t\t\t\t// an `originalValue` property. Here, when we detect this, we\n\t\t\t\t// uphold the illusion by pretending to see that original data\n\t\t\t\t// property, i.e., returning the value rather than the getter\n\t\t\t\t// itself.\n\t\t\t\tif (isOwn && 'get' in desc && !('originalValue' in desc.get)) {\n\t\t\t\t\tvalue = desc.get;\n\t\t\t\t} else {\n\t\t\t\t\tvalue = value[part];\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tisOwn = hasOwn(value, part);\n\t\t\t\tvalue = value[part];\n\t\t\t}\n\n\t\t\tif (isOwn && !skipFurtherCaching) {\n\t\t\t\tINTRINSICS[intrinsicRealName] = value;\n\t\t\t}\n\t\t}\n\t}\n\treturn value;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"210.js","mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./node_modules/get-intrinsic/index.js?00ce"],"sourcesContent":["'use strict';\n\nvar undefined;\n\nvar $SyntaxError = SyntaxError;\nvar $Function = Function;\nvar $TypeError = TypeError;\n\n// eslint-disable-next-line consistent-return\nvar getEvalledConstructor = function (expressionSyntax) {\n\ttry {\n\t\treturn $Function('\"use strict\"; return (' + expressionSyntax + ').constructor;')();\n\t} catch (e) {}\n};\n\nvar $gOPD = Object.getOwnPropertyDescriptor;\nif ($gOPD) {\n\ttry {\n\t\t$gOPD({}, '');\n\t} catch (e) {\n\t\t$gOPD = null; // this is IE 8, which has a broken gOPD\n\t}\n}\n\nvar throwTypeError = function () {\n\tthrow new $TypeError();\n};\nvar ThrowTypeError = $gOPD\n\t? (function () {\n\t\ttry {\n\t\t\t// eslint-disable-next-line no-unused-expressions, no-caller, no-restricted-properties\n\t\t\targuments.callee; // IE 8 does not throw here\n\t\t\treturn throwTypeError;\n\t\t} catch (calleeThrows) {\n\t\t\ttry {\n\t\t\t\t// IE 8 throws on Object.getOwnPropertyDescriptor(arguments, '')\n\t\t\t\treturn $gOPD(arguments, 'callee').get;\n\t\t\t} catch (gOPDthrows) {\n\t\t\t\treturn throwTypeError;\n\t\t\t}\n\t\t}\n\t}())\n\t: throwTypeError;\n\nvar hasSymbols = require('has-symbols')();\n\nvar getProto = Object.getPrototypeOf || function (x) { return x.__proto__; }; // eslint-disable-line no-proto\n\nvar needsEval = {};\n\nvar TypedArray = typeof Uint8Array === 'undefined' ? undefined : getProto(Uint8Array);\n\nvar INTRINSICS = {\n\t'%AggregateError%': typeof AggregateError === 'undefined' ? undefined : AggregateError,\n\t'%Array%': Array,\n\t'%ArrayBuffer%': typeof ArrayBuffer === 'undefined' ? undefined : ArrayBuffer,\n\t'%ArrayIteratorPrototype%': hasSymbols ? getProto([][Symbol.iterator]()) : undefined,\n\t'%AsyncFromSyncIteratorPrototype%': undefined,\n\t'%AsyncFunction%': needsEval,\n\t'%AsyncGenerator%': needsEval,\n\t'%AsyncGeneratorFunction%': needsEval,\n\t'%AsyncIteratorPrototype%': needsEval,\n\t'%Atomics%': typeof Atomics === 'undefined' ? undefined : Atomics,\n\t'%BigInt%': typeof BigInt === 'undefined' ? undefined : BigInt,\n\t'%Boolean%': Boolean,\n\t'%DataView%': typeof DataView === 'undefined' ? undefined : DataView,\n\t'%Date%': Date,\n\t'%decodeURI%': decodeURI,\n\t'%decodeURIComponent%': decodeURIComponent,\n\t'%encodeURI%': encodeURI,\n\t'%encodeURIComponent%': encodeURIComponent,\n\t'%Error%': Error,\n\t'%eval%': eval, // eslint-disable-line no-eval\n\t'%EvalError%': EvalError,\n\t'%Float32Array%': typeof Float32Array === 'undefined' ? undefined : Float32Array,\n\t'%Float64Array%': typeof Float64Array === 'undefined' ? undefined : Float64Array,\n\t'%FinalizationRegistry%': typeof FinalizationRegistry === 'undefined' ? undefined : FinalizationRegistry,\n\t'%Function%': $Function,\n\t'%GeneratorFunction%': needsEval,\n\t'%Int8Array%': typeof Int8Array === 'undefined' ? undefined : Int8Array,\n\t'%Int16Array%': typeof Int16Array === 'undefined' ? undefined : Int16Array,\n\t'%Int32Array%': typeof Int32Array === 'undefined' ? undefined : Int32Array,\n\t'%isFinite%': isFinite,\n\t'%isNaN%': isNaN,\n\t'%IteratorPrototype%': hasSymbols ? getProto(getProto([][Symbol.iterator]())) : undefined,\n\t'%JSON%': typeof JSON === 'object' ? JSON : undefined,\n\t'%Map%': typeof Map === 'undefined' ? undefined : Map,\n\t'%MapIteratorPrototype%': typeof Map === 'undefined' || !hasSymbols ? undefined : getProto(new Map()[Symbol.iterator]()),\n\t'%Math%': Math,\n\t'%Number%': Number,\n\t'%Object%': Object,\n\t'%parseFloat%': parseFloat,\n\t'%parseInt%': parseInt,\n\t'%Promise%': typeof Promise === 'undefined' ? undefined : Promise,\n\t'%Proxy%': typeof Proxy === 'undefined' ? undefined : Proxy,\n\t'%RangeError%': RangeError,\n\t'%ReferenceError%': ReferenceError,\n\t'%Reflect%': typeof Reflect === 'undefined' ? undefined : Reflect,\n\t'%RegExp%': RegExp,\n\t'%Set%': typeof Set === 'undefined' ? undefined : Set,\n\t'%SetIteratorPrototype%': typeof Set === 'undefined' || !hasSymbols ? undefined : getProto(new Set()[Symbol.iterator]()),\n\t'%SharedArrayBuffer%': typeof SharedArrayBuffer === 'undefined' ? undefined : SharedArrayBuffer,\n\t'%String%': String,\n\t'%StringIteratorPrototype%': hasSymbols ? getProto(''[Symbol.iterator]()) : undefined,\n\t'%Symbol%': hasSymbols ? Symbol : undefined,\n\t'%SyntaxError%': $SyntaxError,\n\t'%ThrowTypeError%': ThrowTypeError,\n\t'%TypedArray%': TypedArray,\n\t'%TypeError%': $TypeError,\n\t'%Uint8Array%': typeof Uint8Array === 'undefined' ? undefined : Uint8Array,\n\t'%Uint8ClampedArray%': typeof Uint8ClampedArray === 'undefined' ? undefined : Uint8ClampedArray,\n\t'%Uint16Array%': typeof Uint16Array === 'undefined' ? undefined : Uint16Array,\n\t'%Uint32Array%': typeof Uint32Array === 'undefined' ? undefined : Uint32Array,\n\t'%URIError%': URIError,\n\t'%WeakMap%': typeof WeakMap === 'undefined' ? undefined : WeakMap,\n\t'%WeakRef%': typeof WeakRef === 'undefined' ? undefined : WeakRef,\n\t'%WeakSet%': typeof WeakSet === 'undefined' ? undefined : WeakSet\n};\n\nvar doEval = function doEval(name) {\n\tvar value;\n\tif (name === '%AsyncFunction%') {\n\t\tvalue = getEvalledConstructor('async function () {}');\n\t} else if (name === '%GeneratorFunction%') {\n\t\tvalue = getEvalledConstructor('function* () {}');\n\t} else if (name === '%AsyncGeneratorFunction%') {\n\t\tvalue = getEvalledConstructor('async function* () {}');\n\t} else if (name === '%AsyncGenerator%') {\n\t\tvar fn = doEval('%AsyncGeneratorFunction%');\n\t\tif (fn) {\n\t\t\tvalue = fn.prototype;\n\t\t}\n\t} else if (name === '%AsyncIteratorPrototype%') {\n\t\tvar gen = doEval('%AsyncGenerator%');\n\t\tif (gen) {\n\t\t\tvalue = getProto(gen.prototype);\n\t\t}\n\t}\n\n\tINTRINSICS[name] = value;\n\n\treturn value;\n};\n\nvar LEGACY_ALIASES = {\n\t'%ArrayBufferPrototype%': ['ArrayBuffer', 'prototype'],\n\t'%ArrayPrototype%': ['Array', 'prototype'],\n\t'%ArrayProto_entries%': ['Array', 'prototype', 'entries'],\n\t'%ArrayProto_forEach%': ['Array', 'prototype', 'forEach'],\n\t'%ArrayProto_keys%': ['Array', 'prototype', 'keys'],\n\t'%ArrayProto_values%': ['Array', 'prototype', 'values'],\n\t'%AsyncFunctionPrototype%': ['AsyncFunction', 'prototype'],\n\t'%AsyncGenerator%': ['AsyncGeneratorFunction', 'prototype'],\n\t'%AsyncGeneratorPrototype%': ['AsyncGeneratorFunction', 'prototype', 'prototype'],\n\t'%BooleanPrototype%': ['Boolean', 'prototype'],\n\t'%DataViewPrototype%': ['DataView', 'prototype'],\n\t'%DatePrototype%': ['Date', 'prototype'],\n\t'%ErrorPrototype%': ['Error', 'prototype'],\n\t'%EvalErrorPrototype%': ['EvalError', 'prototype'],\n\t'%Float32ArrayPrototype%': ['Float32Array', 'prototype'],\n\t'%Float64ArrayPrototype%': ['Float64Array', 'prototype'],\n\t'%FunctionPrototype%': ['Function', 'prototype'],\n\t'%Generator%': ['GeneratorFunction', 'prototype'],\n\t'%GeneratorPrototype%': ['GeneratorFunction', 'prototype', 'prototype'],\n\t'%Int8ArrayPrototype%': ['Int8Array', 'prototype'],\n\t'%Int16ArrayPrototype%': ['Int16Array', 'prototype'],\n\t'%Int32ArrayPrototype%': ['Int32Array', 'prototype'],\n\t'%JSONParse%': ['JSON', 'parse'],\n\t'%JSONStringify%': ['JSON', 'stringify'],\n\t'%MapPrototype%': ['Map', 'prototype'],\n\t'%NumberPrototype%': ['Number', 'prototype'],\n\t'%ObjectPrototype%': ['Object', 'prototype'],\n\t'%ObjProto_toString%': ['Object', 'prototype', 'toString'],\n\t'%ObjProto_valueOf%': ['Object', 'prototype', 'valueOf'],\n\t'%PromisePrototype%': ['Promise', 'prototype'],\n\t'%PromiseProto_then%': ['Promise', 'prototype', 'then'],\n\t'%Promise_all%': ['Promise', 'all'],\n\t'%Promise_reject%': ['Promise', 'reject'],\n\t'%Promise_resolve%': ['Promise', 'resolve'],\n\t'%RangeErrorPrototype%': ['RangeError', 'prototype'],\n\t'%ReferenceErrorPrototype%': ['ReferenceError', 'prototype'],\n\t'%RegExpPrototype%': ['RegExp', 'prototype'],\n\t'%SetPrototype%': ['Set', 'prototype'],\n\t'%SharedArrayBufferPrototype%': ['SharedArrayBuffer', 'prototype'],\n\t'%StringPrototype%': ['String', 'prototype'],\n\t'%SymbolPrototype%': ['Symbol', 'prototype'],\n\t'%SyntaxErrorPrototype%': ['SyntaxError', 'prototype'],\n\t'%TypedArrayPrototype%': ['TypedArray', 'prototype'],\n\t'%TypeErrorPrototype%': ['TypeError', 'prototype'],\n\t'%Uint8ArrayPrototype%': ['Uint8Array', 'prototype'],\n\t'%Uint8ClampedArrayPrototype%': ['Uint8ClampedArray', 'prototype'],\n\t'%Uint16ArrayPrototype%': ['Uint16Array', 'prototype'],\n\t'%Uint32ArrayPrototype%': ['Uint32Array', 'prototype'],\n\t'%URIErrorPrototype%': ['URIError', 'prototype'],\n\t'%WeakMapPrototype%': ['WeakMap', 'prototype'],\n\t'%WeakSetPrototype%': ['WeakSet', 'prototype']\n};\n\nvar bind = require('function-bind');\nvar hasOwn = require('has');\nvar $concat = bind.call(Function.call, Array.prototype.concat);\nvar $spliceApply = bind.call(Function.apply, Array.prototype.splice);\nvar $replace = bind.call(Function.call, String.prototype.replace);\nvar $strSlice = bind.call(Function.call, String.prototype.slice);\n\n/* adapted from https://github.com/lodash/lodash/blob/4.17.15/dist/lodash.js#L6735-L6744 */\nvar rePropName = /[^%.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|%$))/g;\nvar reEscapeChar = /\\\\(\\\\)?/g; /** Used to match backslashes in property paths. */\nvar stringToPath = function stringToPath(string) {\n\tvar first = $strSlice(string, 0, 1);\n\tvar last = $strSlice(string, -1);\n\tif (first === '%' && last !== '%') {\n\t\tthrow new $SyntaxError('invalid intrinsic syntax, expected closing `%`');\n\t} else if (last === '%' && first !== '%') {\n\t\tthrow new $SyntaxError('invalid intrinsic syntax, expected opening `%`');\n\t}\n\tvar result = [];\n\t$replace(string, rePropName, function (match, number, quote, subString) {\n\t\tresult[result.length] = quote ? $replace(subString, reEscapeChar, '$1') : number || match;\n\t});\n\treturn result;\n};\n/* end adaptation */\n\nvar getBaseIntrinsic = function getBaseIntrinsic(name, allowMissing) {\n\tvar intrinsicName = name;\n\tvar alias;\n\tif (hasOwn(LEGACY_ALIASES, intrinsicName)) {\n\t\talias = LEGACY_ALIASES[intrinsicName];\n\t\tintrinsicName = '%' + alias[0] + '%';\n\t}\n\n\tif (hasOwn(INTRINSICS, intrinsicName)) {\n\t\tvar value = INTRINSICS[intrinsicName];\n\t\tif (value === needsEval) {\n\t\t\tvalue = doEval(intrinsicName);\n\t\t}\n\t\tif (typeof value === 'undefined' && !allowMissing) {\n\t\t\tthrow new $TypeError('intrinsic ' + name + ' exists, but is not available. Please file an issue!');\n\t\t}\n\n\t\treturn {\n\t\t\talias: alias,\n\t\t\tname: intrinsicName,\n\t\t\tvalue: value\n\t\t};\n\t}\n\n\tthrow new $SyntaxError('intrinsic ' + name + ' does not exist!');\n};\n\nmodule.exports = function GetIntrinsic(name, allowMissing) {\n\tif (typeof name !== 'string' || name.length === 0) {\n\t\tthrow new $TypeError('intrinsic name must be a non-empty string');\n\t}\n\tif (arguments.length > 1 && typeof allowMissing !== 'boolean') {\n\t\tthrow new $TypeError('\"allowMissing\" argument must be a boolean');\n\t}\n\n\tvar parts = stringToPath(name);\n\tvar intrinsicBaseName = parts.length > 0 ? parts[0] : '';\n\n\tvar intrinsic = getBaseIntrinsic('%' + intrinsicBaseName + '%', allowMissing);\n\tvar intrinsicRealName = intrinsic.name;\n\tvar value = intrinsic.value;\n\tvar skipFurtherCaching = false;\n\n\tvar alias = intrinsic.alias;\n\tif (alias) {\n\t\tintrinsicBaseName = alias[0];\n\t\t$spliceApply(parts, $concat([0, 1], alias));\n\t}\n\n\tfor (var i = 1, isOwn = true; i < parts.length; i += 1) {\n\t\tvar part = parts[i];\n\t\tvar first = $strSlice(part, 0, 1);\n\t\tvar last = $strSlice(part, -1);\n\t\tif (\n\t\t\t(\n\t\t\t\t(first === '\"' || first === \"'\" || first === '`')\n\t\t\t\t|| (last === '\"' || last === \"'\" || last === '`')\n\t\t\t)\n\t\t\t&& first !== last\n\t\t) {\n\t\t\tthrow new $SyntaxError('property names with quotes must have matching quotes');\n\t\t}\n\t\tif (part === 'constructor' || !isOwn) {\n\t\t\tskipFurtherCaching = true;\n\t\t}\n\n\t\tintrinsicBaseName += '.' + part;\n\t\tintrinsicRealName = '%' + intrinsicBaseName + '%';\n\n\t\tif (hasOwn(INTRINSICS, intrinsicRealName)) {\n\t\t\tvalue = INTRINSICS[intrinsicRealName];\n\t\t} else if (value != null) {\n\t\t\tif (!(part in value)) {\n\t\t\t\tif (!allowMissing) {\n\t\t\t\t\tthrow new $TypeError('base intrinsic for ' + name + ' exists, but the property is not available.');\n\t\t\t\t}\n\t\t\t\treturn void undefined;\n\t\t\t}\n\t\t\tif ($gOPD && (i + 1) >= parts.length) {\n\t\t\t\tvar desc = $gOPD(value, part);\n\t\t\t\tisOwn = !!desc;\n\n\t\t\t\t// By convention, when a data property is converted to an accessor\n\t\t\t\t// property to emulate a data property that does not suffer from\n\t\t\t\t// the override mistake, that accessor's getter is marked with\n\t\t\t\t// an `originalValue` property. Here, when we detect this, we\n\t\t\t\t// uphold the illusion by pretending to see that original data\n\t\t\t\t// property, i.e., returning the value rather than the getter\n\t\t\t\t// itself.\n\t\t\t\tif (isOwn && 'get' in desc && !('originalValue' in desc.get)) {\n\t\t\t\t\tvalue = desc.get;\n\t\t\t\t} else {\n\t\t\t\t\tvalue = value[part];\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tisOwn = hasOwn(value, part);\n\t\t\t\tvalue = value[part];\n\t\t\t}\n\n\t\t\tif (isOwn && !skipFurtherCaching) {\n\t\t\t\tINTRINSICS[intrinsicRealName] = value;\n\t\t\t}\n\t\t}\n\t}\n\treturn value;\n};\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///210\n")},1044:(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval("\n\nvar GetIntrinsic = __webpack_require__(210);\n\nvar $defineProperty = GetIntrinsic('%Object.defineProperty%', true);\n\nvar hasPropertyDescriptors = function hasPropertyDescriptors() {\n\tif ($defineProperty) {\n\t\ttry {\n\t\t\t$defineProperty({}, 'a', { value: 1 });\n\t\t\treturn true;\n\t\t} catch (e) {\n\t\t\t// IE 8 has a broken defineProperty\n\t\t\treturn false;\n\t\t}\n\t}\n\treturn false;\n};\n\nhasPropertyDescriptors.hasArrayLengthDefineBug = function hasArrayLengthDefineBug() {\n\t// node v0.6 has a bug where array lengths can be Set but not Defined\n\tif (!hasPropertyDescriptors()) {\n\t\treturn null;\n\t}\n\ttry {\n\t\treturn $defineProperty([], 'length', { value: 1 }).length !== 1;\n\t} catch (e) {\n\t\t// In Firefox 4-22, defining length on an array throws an exception.\n\t\treturn true;\n\t}\n};\n\nmodule.exports = hasPropertyDescriptors;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTA0NC5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9ibG9ja3N5T3B0aW9ucy8uL25vZGVfbW9kdWxlcy9oYXMtcHJvcGVydHktZGVzY3JpcHRvcnMvaW5kZXguanM/NjRiMCJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbnZhciBHZXRJbnRyaW5zaWMgPSByZXF1aXJlKCdnZXQtaW50cmluc2ljJyk7XG5cbnZhciAkZGVmaW5lUHJvcGVydHkgPSBHZXRJbnRyaW5zaWMoJyVPYmplY3QuZGVmaW5lUHJvcGVydHklJywgdHJ1ZSk7XG5cbnZhciBoYXNQcm9wZXJ0eURlc2NyaXB0b3JzID0gZnVuY3Rpb24gaGFzUHJvcGVydHlEZXNjcmlwdG9ycygpIHtcblx0aWYgKCRkZWZpbmVQcm9wZXJ0eSkge1xuXHRcdHRyeSB7XG5cdFx0XHQkZGVmaW5lUHJvcGVydHkoe30sICdhJywgeyB2YWx1ZTogMSB9KTtcblx0XHRcdHJldHVybiB0cnVlO1xuXHRcdH0gY2F0Y2ggKGUpIHtcblx0XHRcdC8vIElFIDggaGFzIGEgYnJva2VuIGRlZmluZVByb3BlcnR5XG5cdFx0XHRyZXR1cm4gZmFsc2U7XG5cdFx0fVxuXHR9XG5cdHJldHVybiBmYWxzZTtcbn07XG5cbmhhc1Byb3BlcnR5RGVzY3JpcHRvcnMuaGFzQXJyYXlMZW5ndGhEZWZpbmVCdWcgPSBmdW5jdGlvbiBoYXNBcnJheUxlbmd0aERlZmluZUJ1ZygpIHtcblx0Ly8gbm9kZSB2MC42IGhhcyBhIGJ1ZyB3aGVyZSBhcnJheSBsZW5ndGhzIGNhbiBiZSBTZXQgYnV0IG5vdCBEZWZpbmVkXG5cdGlmICghaGFzUHJvcGVydHlEZXNjcmlwdG9ycygpKSB7XG5cdFx0cmV0dXJuIG51bGw7XG5cdH1cblx0dHJ5IHtcblx0XHRyZXR1cm4gJGRlZmluZVByb3BlcnR5KFtdLCAnbGVuZ3RoJywgeyB2YWx1ZTogMSB9KS5sZW5ndGggIT09IDE7XG5cdH0gY2F0Y2ggKGUpIHtcblx0XHQvLyBJbiBGaXJlZm94IDQtMjIsIGRlZmluaW5nIGxlbmd0aCBvbiBhbiBhcnJheSB0aHJvd3MgYW4gZXhjZXB0aW9uLlxuXHRcdHJldHVybiB0cnVlO1xuXHR9XG59O1xuXG5tb2R1bGUuZXhwb3J0cyA9IGhhc1Byb3BlcnR5RGVzY3JpcHRvcnM7XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///1044\n")},1405:(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval("\n\nvar origSymbol = typeof Symbol !== 'undefined' && Symbol;\nvar hasSymbolSham = __webpack_require__(5419);\n\nmodule.exports = function hasNativeSymbols() {\n\tif (typeof origSymbol !== 'function') { return false; }\n\tif (typeof Symbol !== 'function') { return false; }\n\tif (typeof origSymbol('foo') !== 'symbol') { return false; }\n\tif (typeof Symbol('bar') !== 'symbol') { return false; }\n\n\treturn hasSymbolSham();\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTQwNS5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vbm9kZV9tb2R1bGVzL2hhcy1zeW1ib2xzL2luZGV4LmpzPzUxNTYiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG52YXIgb3JpZ1N5bWJvbCA9IHR5cGVvZiBTeW1ib2wgIT09ICd1bmRlZmluZWQnICYmIFN5bWJvbDtcbnZhciBoYXNTeW1ib2xTaGFtID0gcmVxdWlyZSgnLi9zaGFtcycpO1xuXG5tb2R1bGUuZXhwb3J0cyA9IGZ1bmN0aW9uIGhhc05hdGl2ZVN5bWJvbHMoKSB7XG5cdGlmICh0eXBlb2Ygb3JpZ1N5bWJvbCAhPT0gJ2Z1bmN0aW9uJykgeyByZXR1cm4gZmFsc2U7IH1cblx0aWYgKHR5cGVvZiBTeW1ib2wgIT09ICdmdW5jdGlvbicpIHsgcmV0dXJuIGZhbHNlOyB9XG5cdGlmICh0eXBlb2Ygb3JpZ1N5bWJvbCgnZm9vJykgIT09ICdzeW1ib2wnKSB7IHJldHVybiBmYWxzZTsgfVxuXHRpZiAodHlwZW9mIFN5bWJvbCgnYmFyJykgIT09ICdzeW1ib2wnKSB7IHJldHVybiBmYWxzZTsgfVxuXG5cdHJldHVybiBoYXNTeW1ib2xTaGFtKCk7XG59O1xuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///1405\n")},5419:module=>{"use strict";eval("\n\n/* eslint complexity: [2, 18], max-statements: [2, 33] */\nmodule.exports = function hasSymbols() {\n\tif (typeof Symbol !== 'function' || typeof Object.getOwnPropertySymbols !== 'function') { return false; }\n\tif (typeof Symbol.iterator === 'symbol') { return true; }\n\n\tvar obj = {};\n\tvar sym = Symbol('test');\n\tvar symObj = Object(sym);\n\tif (typeof sym === 'string') { return false; }\n\n\tif (Object.prototype.toString.call(sym) !== '[object Symbol]') { return false; }\n\tif (Object.prototype.toString.call(symObj) !== '[object Symbol]') { return false; }\n\n\t// temp disabled per https://github.com/ljharb/object.assign/issues/17\n\t// if (sym instanceof Symbol) { return false; }\n\t// temp disabled per https://github.com/WebReflection/get-own-property-symbols/issues/4\n\t// if (!(symObj instanceof Symbol)) { return false; }\n\n\t// if (typeof Symbol.prototype.toString !== 'function') { return false; }\n\t// if (String(sym) !== Symbol.prototype.toString.call(sym)) { return false; }\n\n\tvar symVal = 42;\n\tobj[sym] = symVal;\n\tfor (sym in obj) { return false; } // eslint-disable-line no-restricted-syntax, no-unreachable-loop\n\tif (typeof Object.keys === 'function' && Object.keys(obj).length !== 0) { return false; }\n\n\tif (typeof Object.getOwnPropertyNames === 'function' && Object.getOwnPropertyNames(obj).length !== 0) { return false; }\n\n\tvar syms = Object.getOwnPropertySymbols(obj);\n\tif (syms.length !== 1 || syms[0] !== sym) { return false; }\n\n\tif (!Object.prototype.propertyIsEnumerable.call(obj, sym)) { return false; }\n\n\tif (typeof Object.getOwnPropertyDescriptor === 'function') {\n\t\tvar descriptor = Object.getOwnPropertyDescriptor(obj, sym);\n\t\tif (descriptor.value !== symVal || descriptor.enumerable !== true) { return false; }\n\t}\n\n\treturn true;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNTQxOS5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9ibG9ja3N5T3B0aW9ucy8uL25vZGVfbW9kdWxlcy9oYXMtc3ltYm9scy9zaGFtcy5qcz8xNjk2Il0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuLyogZXNsaW50IGNvbXBsZXhpdHk6IFsyLCAxOF0sIG1heC1zdGF0ZW1lbnRzOiBbMiwgMzNdICovXG5tb2R1bGUuZXhwb3J0cyA9IGZ1bmN0aW9uIGhhc1N5bWJvbHMoKSB7XG5cdGlmICh0eXBlb2YgU3ltYm9sICE9PSAnZnVuY3Rpb24nIHx8IHR5cGVvZiBPYmplY3QuZ2V0T3duUHJvcGVydHlTeW1ib2xzICE9PSAnZnVuY3Rpb24nKSB7IHJldHVybiBmYWxzZTsgfVxuXHRpZiAodHlwZW9mIFN5bWJvbC5pdGVyYXRvciA9PT0gJ3N5bWJvbCcpIHsgcmV0dXJuIHRydWU7IH1cblxuXHR2YXIgb2JqID0ge307XG5cdHZhciBzeW0gPSBTeW1ib2woJ3Rlc3QnKTtcblx0dmFyIHN5bU9iaiA9IE9iamVjdChzeW0pO1xuXHRpZiAodHlwZW9mIHN5bSA9PT0gJ3N0cmluZycpIHsgcmV0dXJuIGZhbHNlOyB9XG5cblx0aWYgKE9iamVjdC5wcm90b3R5cGUudG9TdHJpbmcuY2FsbChzeW0pICE9PSAnW29iamVjdCBTeW1ib2xdJykgeyByZXR1cm4gZmFsc2U7IH1cblx0aWYgKE9iamVjdC5wcm90b3R5cGUudG9TdHJpbmcuY2FsbChzeW1PYmopICE9PSAnW29iamVjdCBTeW1ib2xdJykgeyByZXR1cm4gZmFsc2U7IH1cblxuXHQvLyB0ZW1wIGRpc2FibGVkIHBlciBodHRwczovL2dpdGh1Yi5jb20vbGpoYXJiL29iamVjdC5hc3NpZ24vaXNzdWVzLzE3XG5cdC8vIGlmIChzeW0gaW5zdGFuY2VvZiBTeW1ib2wpIHsgcmV0dXJuIGZhbHNlOyB9XG5cdC8vIHRlbXAgZGlzYWJsZWQgcGVyIGh0dHBzOi8vZ2l0aHViLmNvbS9XZWJSZWZsZWN0aW9uL2dldC1vd24tcHJvcGVydHktc3ltYm9scy9pc3N1ZXMvNFxuXHQvLyBpZiAoIShzeW1PYmogaW5zdGFuY2VvZiBTeW1ib2wpKSB7IHJldHVybiBmYWxzZTsgfVxuXG5cdC8vIGlmICh0eXBlb2YgU3ltYm9sLnByb3RvdHlwZS50b1N0cmluZyAhPT0gJ2Z1bmN0aW9uJykgeyByZXR1cm4gZmFsc2U7IH1cblx0Ly8gaWYgKFN0cmluZyhzeW0pICE9PSBTeW1ib2wucHJvdG90eXBlLnRvU3RyaW5nLmNhbGwoc3ltKSkgeyByZXR1cm4gZmFsc2U7IH1cblxuXHR2YXIgc3ltVmFsID0gNDI7XG5cdG9ialtzeW1dID0gc3ltVmFsO1xuXHRmb3IgKHN5bSBpbiBvYmopIHsgcmV0dXJuIGZhbHNlOyB9IC8vIGVzbGludC1kaXNhYmxlLWxpbmUgbm8tcmVzdHJpY3RlZC1zeW50YXgsIG5vLXVucmVhY2hhYmxlLWxvb3Bcblx0aWYgKHR5cGVvZiBPYmplY3Qua2V5cyA9PT0gJ2Z1bmN0aW9uJyAmJiBPYmplY3Qua2V5cyhvYmopLmxlbmd0aCAhPT0gMCkgeyByZXR1cm4gZmFsc2U7IH1cblxuXHRpZiAodHlwZW9mIE9iamVjdC5nZXRPd25Qcm9wZXJ0eU5hbWVzID09PSAnZnVuY3Rpb24nICYmIE9iamVjdC5nZXRPd25Qcm9wZXJ0eU5hbWVzKG9iaikubGVuZ3RoICE9PSAwKSB7IHJldHVybiBmYWxzZTsgfVxuXG5cdHZhciBzeW1zID0gT2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9scyhvYmopO1xuXHRpZiAoc3ltcy5sZW5ndGggIT09IDEgfHwgc3ltc1swXSAhPT0gc3ltKSB7IHJldHVybiBmYWxzZTsgfVxuXG5cdGlmICghT2JqZWN0LnByb3RvdHlwZS5wcm9wZXJ0eUlzRW51bWVyYWJsZS5jYWxsKG9iaiwgc3ltKSkgeyByZXR1cm4gZmFsc2U7IH1cblxuXHRpZiAodHlwZW9mIE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3IgPT09ICdmdW5jdGlvbicpIHtcblx0XHR2YXIgZGVzY3JpcHRvciA9IE9iamVjdC5nZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3Iob2JqLCBzeW0pO1xuXHRcdGlmIChkZXNjcmlwdG9yLnZhbHVlICE9PSBzeW1WYWwgfHwgZGVzY3JpcHRvci5lbnVtZXJhYmxlICE9PSB0cnVlKSB7IHJldHVybiBmYWxzZTsgfVxuXHR9XG5cblx0cmV0dXJuIHRydWU7XG59O1xuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///5419\n")},6410:(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval("\n\nvar hasSymbols = __webpack_require__(5419);\n\nmodule.exports = function hasToStringTagShams() {\n\treturn hasSymbols() && !!Symbol.toStringTag;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNjQxMC5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vbm9kZV9tb2R1bGVzL2hhcy10b3N0cmluZ3RhZy9zaGFtcy5qcz8wN2E0Il0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxudmFyIGhhc1N5bWJvbHMgPSByZXF1aXJlKCdoYXMtc3ltYm9scy9zaGFtcycpO1xuXG5tb2R1bGUuZXhwb3J0cyA9IGZ1bmN0aW9uIGhhc1RvU3RyaW5nVGFnU2hhbXMoKSB7XG5cdHJldHVybiBoYXNTeW1ib2xzKCkgJiYgISFTeW1ib2wudG9TdHJpbmdUYWc7XG59O1xuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///6410\n")},7642:(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval("\n\nvar bind = __webpack_require__(8612);\n\nmodule.exports = bind.call(Function.call, Object.prototype.hasOwnProperty);\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNzY0Mi5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9ub2RlX21vZHVsZXMvaGFzL3NyYy9pbmRleC5qcz9hMGQzIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxudmFyIGJpbmQgPSByZXF1aXJlKCdmdW5jdGlvbi1iaW5kJyk7XG5cbm1vZHVsZS5leHBvcnRzID0gYmluZC5jYWxsKEZ1bmN0aW9uLmNhbGwsIE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkpO1xuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///7642\n")},1143:module=>{"use strict";eval("/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\n\n/**\n * Use invariant() to assert state which your program assumes to be true.\n *\n * Provide sprintf-style format (only %s is supported) and arguments\n * to provide information about what broke and what you were\n * expecting.\n *\n * The invariant message will be stripped in production, but the invariant\n * will remain to ensure logic does not differ in production.\n */\n\nvar invariant = function(condition, format, a, b, c, d, e, f) {\n if (false) {}\n\n if (!condition) {\n var error;\n if (format === undefined) {\n error = new Error(\n 'Minified exception occurred; use the non-minified dev environment ' +\n 'for the full error message and additional helpful warnings.'\n );\n } else {\n var args = [a, b, c, d, e, f];\n var argIndex = 0;\n error = new Error(\n format.replace(/%s/g, function() { return args[argIndex++]; })\n );\n error.name = 'Invariant Violation';\n }\n\n error.framesToPop = 1; // we don't care about invariant's own frame\n throw error;\n }\n};\n\nmodule.exports = invariant;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTE0My5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUtBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9ibG9ja3N5T3B0aW9ucy8uL25vZGVfbW9kdWxlcy9pbnZhcmlhbnQvYnJvd3Nlci5qcz80MGI2Il0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDEzLXByZXNlbnQsIEZhY2Vib29rLCBJbmMuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKi9cblxuJ3VzZSBzdHJpY3QnO1xuXG4vKipcbiAqIFVzZSBpbnZhcmlhbnQoKSB0byBhc3NlcnQgc3RhdGUgd2hpY2ggeW91ciBwcm9ncmFtIGFzc3VtZXMgdG8gYmUgdHJ1ZS5cbiAqXG4gKiBQcm92aWRlIHNwcmludGYtc3R5bGUgZm9ybWF0IChvbmx5ICVzIGlzIHN1cHBvcnRlZCkgYW5kIGFyZ3VtZW50c1xuICogdG8gcHJvdmlkZSBpbmZvcm1hdGlvbiBhYm91dCB3aGF0IGJyb2tlIGFuZCB3aGF0IHlvdSB3ZXJlXG4gKiBleHBlY3RpbmcuXG4gKlxuICogVGhlIGludmFyaWFudCBtZXNzYWdlIHdpbGwgYmUgc3RyaXBwZWQgaW4gcHJvZHVjdGlvbiwgYnV0IHRoZSBpbnZhcmlhbnRcbiAqIHdpbGwgcmVtYWluIHRvIGVuc3VyZSBsb2dpYyBkb2VzIG5vdCBkaWZmZXIgaW4gcHJvZHVjdGlvbi5cbiAqL1xuXG52YXIgaW52YXJpYW50ID0gZnVuY3Rpb24oY29uZGl0aW9uLCBmb3JtYXQsIGEsIGIsIGMsIGQsIGUsIGYpIHtcbiAgaWYgKHByb2Nlc3MuZW52Lk5PREVfRU5WICE9PSAncHJvZHVjdGlvbicpIHtcbiAgICBpZiAoZm9ybWF0ID09PSB1bmRlZmluZWQpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignaW52YXJpYW50IHJlcXVpcmVzIGFuIGVycm9yIG1lc3NhZ2UgYXJndW1lbnQnKTtcbiAgICB9XG4gIH1cblxuICBpZiAoIWNvbmRpdGlvbikge1xuICAgIHZhciBlcnJvcjtcbiAgICBpZiAoZm9ybWF0ID09PSB1bmRlZmluZWQpIHtcbiAgICAgIGVycm9yID0gbmV3IEVycm9yKFxuICAgICAgICAnTWluaWZpZWQgZXhjZXB0aW9uIG9jY3VycmVkOyB1c2UgdGhlIG5vbi1taW5pZmllZCBkZXYgZW52aXJvbm1lbnQgJyArXG4gICAgICAgICdmb3IgdGhlIGZ1bGwgZXJyb3IgbWVzc2FnZSBhbmQgYWRkaXRpb25hbCBoZWxwZnVsIHdhcm5pbmdzLidcbiAgICAgICk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHZhciBhcmdzID0gW2EsIGIsIGMsIGQsIGUsIGZdO1xuICAgICAgdmFyIGFyZ0luZGV4ID0gMDtcbiAgICAgIGVycm9yID0gbmV3IEVycm9yKFxuICAgICAgICBmb3JtYXQucmVwbGFjZSgvJXMvZywgZnVuY3Rpb24oKSB7IHJldHVybiBhcmdzW2FyZ0luZGV4KytdOyB9KVxuICAgICAgKTtcbiAgICAgIGVycm9yLm5hbWUgPSAnSW52YXJpYW50IFZpb2xhdGlvbic7XG4gICAgfVxuXG4gICAgZXJyb3IuZnJhbWVzVG9Qb3AgPSAxOyAvLyB3ZSBkb24ndCBjYXJlIGFib3V0IGludmFyaWFudCdzIG93biBmcmFtZVxuICAgIHRocm93IGVycm9yO1xuICB9XG59O1xuXG5tb2R1bGUuZXhwb3J0cyA9IGludmFyaWFudDtcbiJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///1143\n")},2584:(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval("\n\nvar hasToStringTag = __webpack_require__(6410)();\nvar callBound = __webpack_require__(1924);\n\nvar $toString = callBound('Object.prototype.toString');\n\nvar isStandardArguments = function isArguments(value) {\n\tif (hasToStringTag && value && typeof value === 'object' && Symbol.toStringTag in value) {\n\t\treturn false;\n\t}\n\treturn $toString(value) === '[object Arguments]';\n};\n\nvar isLegacyArguments = function isArguments(value) {\n\tif (isStandardArguments(value)) {\n\t\treturn true;\n\t}\n\treturn value !== null &&\n\t\ttypeof value === 'object' &&\n\t\ttypeof value.length === 'number' &&\n\t\tvalue.length >= 0 &&\n\t\t$toString(value) !== '[object Array]' &&\n\t\t$toString(value.callee) === '[object Function]';\n};\n\nvar supportsStandardArguments = (function () {\n\treturn isStandardArguments(arguments);\n}());\n\nisStandardArguments.isLegacyArguments = isLegacyArguments; // for tests\n\nmodule.exports = supportsStandardArguments ? isStandardArguments : isLegacyArguments;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMjU4NC5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9ibG9ja3N5T3B0aW9ucy8uL25vZGVfbW9kdWxlcy9pcy1hcmd1bWVudHMvaW5kZXguanM/ZTM5YyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbnZhciBoYXNUb1N0cmluZ1RhZyA9IHJlcXVpcmUoJ2hhcy10b3N0cmluZ3RhZy9zaGFtcycpKCk7XG52YXIgY2FsbEJvdW5kID0gcmVxdWlyZSgnY2FsbC1iaW5kL2NhbGxCb3VuZCcpO1xuXG52YXIgJHRvU3RyaW5nID0gY2FsbEJvdW5kKCdPYmplY3QucHJvdG90eXBlLnRvU3RyaW5nJyk7XG5cbnZhciBpc1N0YW5kYXJkQXJndW1lbnRzID0gZnVuY3Rpb24gaXNBcmd1bWVudHModmFsdWUpIHtcblx0aWYgKGhhc1RvU3RyaW5nVGFnICYmIHZhbHVlICYmIHR5cGVvZiB2YWx1ZSA9PT0gJ29iamVjdCcgJiYgU3ltYm9sLnRvU3RyaW5nVGFnIGluIHZhbHVlKSB7XG5cdFx0cmV0dXJuIGZhbHNlO1xuXHR9XG5cdHJldHVybiAkdG9TdHJpbmcodmFsdWUpID09PSAnW29iamVjdCBBcmd1bWVudHNdJztcbn07XG5cbnZhciBpc0xlZ2FjeUFyZ3VtZW50cyA9IGZ1bmN0aW9uIGlzQXJndW1lbnRzKHZhbHVlKSB7XG5cdGlmIChpc1N0YW5kYXJkQXJndW1lbnRzKHZhbHVlKSkge1xuXHRcdHJldHVybiB0cnVlO1xuXHR9XG5cdHJldHVybiB2YWx1ZSAhPT0gbnVsbCAmJlxuXHRcdHR5cGVvZiB2YWx1ZSA9PT0gJ29iamVjdCcgJiZcblx0XHR0eXBlb2YgdmFsdWUubGVuZ3RoID09PSAnbnVtYmVyJyAmJlxuXHRcdHZhbHVlLmxlbmd0aCA+PSAwICYmXG5cdFx0JHRvU3RyaW5nKHZhbHVlKSAhPT0gJ1tvYmplY3QgQXJyYXldJyAmJlxuXHRcdCR0b1N0cmluZyh2YWx1ZS5jYWxsZWUpID09PSAnW29iamVjdCBGdW5jdGlvbl0nO1xufTtcblxudmFyIHN1cHBvcnRzU3RhbmRhcmRBcmd1bWVudHMgPSAoZnVuY3Rpb24gKCkge1xuXHRyZXR1cm4gaXNTdGFuZGFyZEFyZ3VtZW50cyhhcmd1bWVudHMpO1xufSgpKTtcblxuaXNTdGFuZGFyZEFyZ3VtZW50cy5pc0xlZ2FjeUFyZ3VtZW50cyA9IGlzTGVnYWN5QXJndW1lbnRzOyAvLyBmb3IgdGVzdHNcblxubW9kdWxlLmV4cG9ydHMgPSBzdXBwb3J0c1N0YW5kYXJkQXJndW1lbnRzID8gaXNTdGFuZGFyZEFyZ3VtZW50cyA6IGlzTGVnYWN5QXJndW1lbnRzO1xuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///2584\n")},8738:module=>{eval("/*!\n * Determine if an object is a Buffer\n *\n * @author Feross Aboukhadijeh \n * @license MIT\n */\n\n// The _isBuffer check is for Safari 5-7 support, because it's missing\n// Object.prototype.constructor. Remove this eventually\nmodule.exports = function (obj) {\n return obj != null && (isBuffer(obj) || isSlowBuffer(obj) || !!obj._isBuffer)\n}\n\nfunction isBuffer (obj) {\n return !!obj.constructor && typeof obj.constructor.isBuffer === 'function' && obj.constructor.isBuffer(obj)\n}\n\n// For Node v0.10 support. Remove this eventually.\nfunction isSlowBuffer (obj) {\n return typeof obj.readFloatLE === 'function' && typeof obj.slice === 'function' && isBuffer(obj.slice(0, 0))\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiODczOC5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9ibG9ja3N5T3B0aW9ucy8uL25vZGVfbW9kdWxlcy9pcy1idWZmZXIvaW5kZXguanM/MDQ0YiJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiFcbiAqIERldGVybWluZSBpZiBhbiBvYmplY3QgaXMgYSBCdWZmZXJcbiAqXG4gKiBAYXV0aG9yICAgRmVyb3NzIEFib3VraGFkaWplaCA8aHR0cHM6Ly9mZXJvc3Mub3JnPlxuICogQGxpY2Vuc2UgIE1JVFxuICovXG5cbi8vIFRoZSBfaXNCdWZmZXIgY2hlY2sgaXMgZm9yIFNhZmFyaSA1LTcgc3VwcG9ydCwgYmVjYXVzZSBpdCdzIG1pc3Npbmdcbi8vIE9iamVjdC5wcm90b3R5cGUuY29uc3RydWN0b3IuIFJlbW92ZSB0aGlzIGV2ZW50dWFsbHlcbm1vZHVsZS5leHBvcnRzID0gZnVuY3Rpb24gKG9iaikge1xuICByZXR1cm4gb2JqICE9IG51bGwgJiYgKGlzQnVmZmVyKG9iaikgfHwgaXNTbG93QnVmZmVyKG9iaikgfHwgISFvYmouX2lzQnVmZmVyKVxufVxuXG5mdW5jdGlvbiBpc0J1ZmZlciAob2JqKSB7XG4gIHJldHVybiAhIW9iai5jb25zdHJ1Y3RvciAmJiB0eXBlb2Ygb2JqLmNvbnN0cnVjdG9yLmlzQnVmZmVyID09PSAnZnVuY3Rpb24nICYmIG9iai5jb25zdHJ1Y3Rvci5pc0J1ZmZlcihvYmopXG59XG5cbi8vIEZvciBOb2RlIHYwLjEwIHN1cHBvcnQuIFJlbW92ZSB0aGlzIGV2ZW50dWFsbHkuXG5mdW5jdGlvbiBpc1Nsb3dCdWZmZXIgKG9iaikge1xuICByZXR1cm4gdHlwZW9mIG9iai5yZWFkRmxvYXRMRSA9PT0gJ2Z1bmN0aW9uJyAmJiB0eXBlb2Ygb2JqLnNsaWNlID09PSAnZnVuY3Rpb24nICYmIGlzQnVmZmVyKG9iai5zbGljZSgwLCAwKSlcbn1cbiJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///8738\n")},8923:(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval("\n\nvar getDay = Date.prototype.getDay;\nvar tryDateObject = function tryDateGetDayCall(value) {\n\ttry {\n\t\tgetDay.call(value);\n\t\treturn true;\n\t} catch (e) {\n\t\treturn false;\n\t}\n};\n\nvar toStr = Object.prototype.toString;\nvar dateClass = '[object Date]';\nvar hasToStringTag = __webpack_require__(6410)();\n\nmodule.exports = function isDateObject(value) {\n\tif (typeof value !== 'object' || value === null) {\n\t\treturn false;\n\t}\n\treturn hasToStringTag ? tryDateObject(value) : toStr.call(value) === dateClass;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiODkyMy5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vbm9kZV9tb2R1bGVzL2lzLWRhdGUtb2JqZWN0L2luZGV4LmpzPzBlNjUiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG52YXIgZ2V0RGF5ID0gRGF0ZS5wcm90b3R5cGUuZ2V0RGF5O1xudmFyIHRyeURhdGVPYmplY3QgPSBmdW5jdGlvbiB0cnlEYXRlR2V0RGF5Q2FsbCh2YWx1ZSkge1xuXHR0cnkge1xuXHRcdGdldERheS5jYWxsKHZhbHVlKTtcblx0XHRyZXR1cm4gdHJ1ZTtcblx0fSBjYXRjaCAoZSkge1xuXHRcdHJldHVybiBmYWxzZTtcblx0fVxufTtcblxudmFyIHRvU3RyID0gT2JqZWN0LnByb3RvdHlwZS50b1N0cmluZztcbnZhciBkYXRlQ2xhc3MgPSAnW29iamVjdCBEYXRlXSc7XG52YXIgaGFzVG9TdHJpbmdUYWcgPSByZXF1aXJlKCdoYXMtdG9zdHJpbmd0YWcvc2hhbXMnKSgpO1xuXG5tb2R1bGUuZXhwb3J0cyA9IGZ1bmN0aW9uIGlzRGF0ZU9iamVjdCh2YWx1ZSkge1xuXHRpZiAodHlwZW9mIHZhbHVlICE9PSAnb2JqZWN0JyB8fCB2YWx1ZSA9PT0gbnVsbCkge1xuXHRcdHJldHVybiBmYWxzZTtcblx0fVxuXHRyZXR1cm4gaGFzVG9TdHJpbmdUYWcgPyB0cnlEYXRlT2JqZWN0KHZhbHVlKSA6IHRvU3RyLmNhbGwodmFsdWUpID09PSBkYXRlQ2xhc3M7XG59O1xuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///8923\n")},8420:(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval("\n\nvar callBound = __webpack_require__(1924);\nvar hasToStringTag = __webpack_require__(6410)();\nvar has;\nvar $exec;\nvar isRegexMarker;\nvar badStringifier;\n\nif (hasToStringTag) {\n\thas = callBound('Object.prototype.hasOwnProperty');\n\t$exec = callBound('RegExp.prototype.exec');\n\tisRegexMarker = {};\n\n\tvar throwRegexMarker = function () {\n\t\tthrow isRegexMarker;\n\t};\n\tbadStringifier = {\n\t\ttoString: throwRegexMarker,\n\t\tvalueOf: throwRegexMarker\n\t};\n\n\tif (typeof Symbol.toPrimitive === 'symbol') {\n\t\tbadStringifier[Symbol.toPrimitive] = throwRegexMarker;\n\t}\n}\n\nvar $toString = callBound('Object.prototype.toString');\nvar gOPD = Object.getOwnPropertyDescriptor;\nvar regexClass = '[object RegExp]';\n\nmodule.exports = hasToStringTag\n\t// eslint-disable-next-line consistent-return\n\t? function isRegex(value) {\n\t\tif (!value || typeof value !== 'object') {\n\t\t\treturn false;\n\t\t}\n\n\t\tvar descriptor = gOPD(value, 'lastIndex');\n\t\tvar hasLastIndexDataProperty = descriptor && has(descriptor, 'value');\n\t\tif (!hasLastIndexDataProperty) {\n\t\t\treturn false;\n\t\t}\n\n\t\ttry {\n\t\t\t$exec(value, badStringifier);\n\t\t} catch (e) {\n\t\t\treturn e === isRegexMarker;\n\t\t}\n\t}\n\t: function isRegex(value) {\n\t\t// In older browsers, typeof regex incorrectly returns 'function'\n\t\tif (!value || (typeof value !== 'object' && typeof value !== 'function')) {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn $toString(value) === regexClass;\n\t};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiODQyMC5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vbm9kZV9tb2R1bGVzL2lzLXJlZ2V4L2luZGV4LmpzP2Q4ZDgiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG52YXIgY2FsbEJvdW5kID0gcmVxdWlyZSgnY2FsbC1iaW5kL2NhbGxCb3VuZCcpO1xudmFyIGhhc1RvU3RyaW5nVGFnID0gcmVxdWlyZSgnaGFzLXRvc3RyaW5ndGFnL3NoYW1zJykoKTtcbnZhciBoYXM7XG52YXIgJGV4ZWM7XG52YXIgaXNSZWdleE1hcmtlcjtcbnZhciBiYWRTdHJpbmdpZmllcjtcblxuaWYgKGhhc1RvU3RyaW5nVGFnKSB7XG5cdGhhcyA9IGNhbGxCb3VuZCgnT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eScpO1xuXHQkZXhlYyA9IGNhbGxCb3VuZCgnUmVnRXhwLnByb3RvdHlwZS5leGVjJyk7XG5cdGlzUmVnZXhNYXJrZXIgPSB7fTtcblxuXHR2YXIgdGhyb3dSZWdleE1hcmtlciA9IGZ1bmN0aW9uICgpIHtcblx0XHR0aHJvdyBpc1JlZ2V4TWFya2VyO1xuXHR9O1xuXHRiYWRTdHJpbmdpZmllciA9IHtcblx0XHR0b1N0cmluZzogdGhyb3dSZWdleE1hcmtlcixcblx0XHR2YWx1ZU9mOiB0aHJvd1JlZ2V4TWFya2VyXG5cdH07XG5cblx0aWYgKHR5cGVvZiBTeW1ib2wudG9QcmltaXRpdmUgPT09ICdzeW1ib2wnKSB7XG5cdFx0YmFkU3RyaW5naWZpZXJbU3ltYm9sLnRvUHJpbWl0aXZlXSA9IHRocm93UmVnZXhNYXJrZXI7XG5cdH1cbn1cblxudmFyICR0b1N0cmluZyA9IGNhbGxCb3VuZCgnT2JqZWN0LnByb3RvdHlwZS50b1N0cmluZycpO1xudmFyIGdPUEQgPSBPYmplY3QuZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9yO1xudmFyIHJlZ2V4Q2xhc3MgPSAnW29iamVjdCBSZWdFeHBdJztcblxubW9kdWxlLmV4cG9ydHMgPSBoYXNUb1N0cmluZ1RhZ1xuXHQvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgY29uc2lzdGVudC1yZXR1cm5cblx0PyBmdW5jdGlvbiBpc1JlZ2V4KHZhbHVlKSB7XG5cdFx0aWYgKCF2YWx1ZSB8fCB0eXBlb2YgdmFsdWUgIT09ICdvYmplY3QnKSB7XG5cdFx0XHRyZXR1cm4gZmFsc2U7XG5cdFx0fVxuXG5cdFx0dmFyIGRlc2NyaXB0b3IgPSBnT1BEKHZhbHVlLCAnbGFzdEluZGV4Jyk7XG5cdFx0dmFyIGhhc0xhc3RJbmRleERhdGFQcm9wZXJ0eSA9IGRlc2NyaXB0b3IgJiYgaGFzKGRlc2NyaXB0b3IsICd2YWx1ZScpO1xuXHRcdGlmICghaGFzTGFzdEluZGV4RGF0YVByb3BlcnR5KSB7XG5cdFx0XHRyZXR1cm4gZmFsc2U7XG5cdFx0fVxuXG5cdFx0dHJ5IHtcblx0XHRcdCRleGVjKHZhbHVlLCBiYWRTdHJpbmdpZmllcik7XG5cdFx0fSBjYXRjaCAoZSkge1xuXHRcdFx0cmV0dXJuIGUgPT09IGlzUmVnZXhNYXJrZXI7XG5cdFx0fVxuXHR9XG5cdDogZnVuY3Rpb24gaXNSZWdleCh2YWx1ZSkge1xuXHRcdC8vIEluIG9sZGVyIGJyb3dzZXJzLCB0eXBlb2YgcmVnZXggaW5jb3JyZWN0bHkgcmV0dXJucyAnZnVuY3Rpb24nXG5cdFx0aWYgKCF2YWx1ZSB8fCAodHlwZW9mIHZhbHVlICE9PSAnb2JqZWN0JyAmJiB0eXBlb2YgdmFsdWUgIT09ICdmdW5jdGlvbicpKSB7XG5cdFx0XHRyZXR1cm4gZmFsc2U7XG5cdFx0fVxuXG5cdFx0cmV0dXJuICR0b1N0cmluZyh2YWx1ZSkgPT09IHJlZ2V4Q2xhc3M7XG5cdH07XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///8420\n")},7465:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"KY\": () => (/* binding */ normalizeCondition),\n/* harmony export */ \"Nj\": () => (/* binding */ matchValuesWithCondition)\n/* harmony export */ });\n/* unused harmony export opg */\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 _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n};\n\nvar slicedToArray = function () {\n function sliceIterator(arr, i) {\n var _arr = [];\n var _n = true;\n var _d = false;\n var _e = undefined;\n\n try {\n for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"]) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n\n return _arr;\n }\n\n return function (arr, i) {\n if (Array.isArray(arr)) {\n return arr;\n } else if (Symbol.iterator in Object(arr)) {\n return sliceIterator(arr, i);\n } else {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance\");\n }\n };\n}();\n\nvar toArray = function (arr) {\n return Array.isArray(arr) ? arr : Array.from(arr);\n};\n\n/**\n * Get nested property value\n *\n * Usage:\n * var obj = {foo: {bar: 'ok'}};\n * opg('foo/bar', obj); // 'ok'\n *\n * @param {String} properties 'a.b.c'\n * @param {Object} obj\n * @param {*} [defaultValue] If property will not exist\n * @param {String} [delimiter] Default '/'\n */\nvar opg = function opg(properties, obj, defaultValue) {\n var delimiter = '/';\n\n if (typeof properties == 'string') {\n properties = properties.split(delimiter);\n } else {\n properties = [properties];\n }\n\n var property = properties.shift();\n\n if (!obj || typeof obj[property] == 'undefined') {\n return defaultValue;\n }\n\n if (properties.length) {\n properties = properties.join(delimiter);\n\n return opg(properties, obj[property], defaultValue, delimiter);\n } else {\n return obj[property];\n }\n};\n\nvar propertiesWithoutLast = function propertiesWithoutLast(properties) {\n var delimiter = '/';\n\n if (typeof properties == 'string') {\n properties = properties.split(delimiter);\n }\n\n if (properties.length > 1) {\n properties.pop();\n }\n\n return properties;\n};\n\nvar normalizeCondition = function normalizeCondition(conditionDescriptor) {\n if (!conditionDescriptor.all) {\n if (!conditionDescriptor.any) {\n conditionDescriptor = {\n all: conditionDescriptor\n };\n }\n }\n\n return conditionDescriptor;\n};\n\n/**\n * Support:\n *\n * // TODO: maybe implement short circuits for conditions\n *\n * {\n * 'path/to/elem': 'exact_value',\n * 'path/to/other_elem': '! negated_exact_value',\n * 'path/to/other_elem_1': 'first_val | second_val | third_possible_val',\n * 'path/to/other_elem_2': '! first_val | second_val',\n * }\n */\nvar matchValuesWithCondition = function matchValuesWithCondition(conditionDescriptor, inferedValuesForContext) {\n var conditionsObject = Object.values(conditionDescriptor)[0];\n\n var maybeGetMatcher = function maybeGetMatcher(matcher) {\n if (matcher.length > 4) {\n return false;\n }\n\n if (matcher.indexOf('any') === 0) {\n return 'any';\n }\n\n if (matcher.indexOf('all') === 0) {\n return 'all';\n }\n\n return false;\n };\n\n var valuesToCheck = Object.keys(conditionsObject).map(function (singleOptionPath, index) {\n var maybeThat = Object.values(conditionsObject)[index];\n\n if (maybeGetMatcher(singleOptionPath) === 'all' || maybeGetMatcher(singleOptionPath) === 'any') {\n return matchValuesWithCondition(defineProperty({}, singleOptionPath, maybeThat), inferedValuesForContext);\n }\n\n return tryToMatchValueWithOptionPath(maybeThat, singleOptionPath, inferedValuesForContext);\n });\n\n if (maybeGetMatcher(Object.keys(conditionDescriptor)[0]) === 'all') {\n return valuesToCheck.every(function (v) {\n return !!v;\n });\n }\n\n if (maybeGetMatcher(Object.keys(conditionDescriptor)[0]) === 'any') {\n return valuesToCheck.some(function (v) {\n return !!v;\n });\n }\n};\n\nfunction extractScalarValueFor(singleOptionPath, inferedValuesForContext) {\n var getAsInfered = function getAsInfered(path) {\n var values = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : inferedValuesForContext;\n return opg(path, values);\n };\n\n if (singleOptionPath.indexOf(':') > -1) {\n /**\n * Congrats, gentlemans, we are having a custom matcher here\n * To be honest, this is the dumbest thing I can figure out right now.\n * There probably is a better way to handle that. One could go about\n * getting an interface here or smth like that.\n *\n * WARNING: Hardcoded to ct-select.\n * Also doesn't work with ct-inherit, will report the value\n * incorrectly. Will be fixed properly when implementing the context\n * asbtraction properly.\n *\n * choices matcher\n * option_id:choices => LENGTH\n */\n\n var value = null;(function (thing, cb) {\n return cb(thing);\n })(singleOptionPath.split(':'), function (_ref) {\n var _ref2 = toArray(_ref),\n singleOptionPath = _ref2[0],\n matcher = _ref2.slice(1);\n\n // TODO: start implementing matchers after we are done with\n // everything else with Vue renderer\n\n matcher = matcher.join(':');\n\n if (matcher === 'visibility') {\n value = getAsInfered(singleOptionPath, _extends({}, inferedValuesForContext, defineProperty({}, propertiesWithoutLast(singleOptionPath), opg(propertiesWithoutLast(singleOptionPath), inferedValuesForContext)[inferedValuesForContext.wp_customizer_current_view] ? 'yes' : 'no')));\n }\n\n if (matcher === 'responsive') {\n value = getAsInfered(singleOptionPath, _extends({}, inferedValuesForContext, defineProperty({}, propertiesWithoutLast(singleOptionPath), opg(propertiesWithoutLast(singleOptionPath), inferedValuesForContext)[inferedValuesForContext.wp_customizer_current_view] || opg(propertiesWithoutLast(singleOptionPath), inferedValuesForContext))));\n }\n\n if (matcher === 'truthy') {\n value = !!getAsInfered(singleOptionPath) ? 'yes' : 'no';\n }\n\n if (matcher.indexOf('array-ids:') > -1) {\n var _matcher$split = matcher.split(':'),\n _matcher$split2 = slicedToArray(_matcher$split, 3),\n _ = _matcher$split2[0],\n id = _matcher$split2[1],\n path = _matcher$split2[2];\n\n var _properValue = getAsInfered(singleOptionPath).find(function (v) {\n return v.id === id;\n });\n\n value = !_properValue ? 'no' : opg(path, _properValue) || 'no';\n }\n\n if (matcher.indexOf('json:') > -1) {\n value = getAsInfered(singleOptionPath + '/' + matcher.split(':')[1]).toString();\n }\n\n if (matcher === 'array_length') {\n var _properValue2 = getAsInfered(singleOptionPath);\n\n value = (_properValue2 || []).length.toString();\n }\n\n if (!value) {\n throw new Error('Unknown matcher received. Please verify for typos. The received matcher: ' + matcher + '.');\n }\n });\n\n /**\n * Matcher got _matched_.\n */\n if (value) {\n return value;\n } else {\n // Fall back to raw value check, but omit the matcher.\n singleOptionPath = singleOptionPath.split(':')[0];\n }\n }\n\n var properValue = getAsInfered(singleOptionPath);\n\n if (!properValue) return false;\n\n if (properValue.desktop) {\n return properValue;\n }\n\n return properValue.toString();\n}\n\nfunction tryToMatchValueWithOptionPath(maybeThat, singleOptionPath, inferedValuesForContext) {\n var properValue = extractScalarValueFor(singleOptionPath, inferedValuesForContext);\n\n if (maybeThat && maybeThat.toString() && maybeThat.toString().indexOf('~') === 0) {\n var toMatch = maybeThat.replace('~', '');\n\n if (properValue.desktop) {\n return properValue.desktop === toMatch || properValue.tablet === toMatch || properValue.mobile === toMatch;\n }\n\n return properValue === toMatch;\n }\n\n properValue = properValue.toString();\n maybeThat = maybeThat.toString();\n\n /**\n * The context value is not yet stabilized\n */\n if (!properValue) return false;\n\n /**\n * Pipe operator\n */\n if (maybeThat.indexOf('|') > -1) {\n if (maybeThat.indexOf('!') === 0) {\n return maybeThat.substring(1).split('|').map(function (el) {\n return el.trim();\n }).includes(properValue.trim()) === -1;\n } else {\n return maybeThat.split('|').map(function (el) {\n return el.trim();\n }).indexOf(properValue.trim()) > -1;\n }\n }\n\n /**\n * Negation operator\n */\n if (maybeThat.indexOf('!') === 0) {\n return properValue !== maybeThat.substring(1).trim();\n }\n\n /**\n * Contains operator\n */\n if (maybeThat.indexOf('*') === 0) {\n return properValue.indexOf(maybeThat.trim().substring(1).trim()) > -1;\n }\n\n /**\n * Simple equality\n */\n return properValue === maybeThat.trim();\n}\n\n\n//# sourceMappingURL=index.es.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"7465.js","mappings":";;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./node_modules/match-conditions/dist/index.es.js?658c"],"sourcesContent":["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 _extends = Object.assign || function (target) {\n  for (var i = 1; i < arguments.length; i++) {\n    var source = arguments[i];\n\n    for (var key in source) {\n      if (Object.prototype.hasOwnProperty.call(source, key)) {\n        target[key] = source[key];\n      }\n    }\n  }\n\n  return target;\n};\n\nvar slicedToArray = function () {\n  function sliceIterator(arr, i) {\n    var _arr = [];\n    var _n = true;\n    var _d = false;\n    var _e = undefined;\n\n    try {\n      for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {\n        _arr.push(_s.value);\n\n        if (i && _arr.length === i) break;\n      }\n    } catch (err) {\n      _d = true;\n      _e = err;\n    } finally {\n      try {\n        if (!_n && _i[\"return\"]) _i[\"return\"]();\n      } finally {\n        if (_d) throw _e;\n      }\n    }\n\n    return _arr;\n  }\n\n  return function (arr, i) {\n    if (Array.isArray(arr)) {\n      return arr;\n    } else if (Symbol.iterator in Object(arr)) {\n      return sliceIterator(arr, i);\n    } else {\n      throw new TypeError(\"Invalid attempt to destructure non-iterable instance\");\n    }\n  };\n}();\n\nvar toArray = function (arr) {\n  return Array.isArray(arr) ? arr : Array.from(arr);\n};\n\n/**\n * Get nested property value\n *\n * Usage:\n * var obj = {foo: {bar: 'ok'}};\n * opg('foo/bar', obj); // 'ok'\n *\n * @param {String} properties 'a.b.c'\n * @param {Object} obj\n * @param {*} [defaultValue] If property will not exist\n * @param {String} [delimiter] Default '/'\n */\nvar opg = function opg(properties, obj, defaultValue) {\n  var delimiter = '/';\n\n  if (typeof properties == 'string') {\n    properties = properties.split(delimiter);\n  } else {\n    properties = [properties];\n  }\n\n  var property = properties.shift();\n\n  if (!obj || typeof obj[property] == 'undefined') {\n    return defaultValue;\n  }\n\n  if (properties.length) {\n    properties = properties.join(delimiter);\n\n    return opg(properties, obj[property], defaultValue, delimiter);\n  } else {\n    return obj[property];\n  }\n};\n\nvar propertiesWithoutLast = function propertiesWithoutLast(properties) {\n  var delimiter = '/';\n\n  if (typeof properties == 'string') {\n    properties = properties.split(delimiter);\n  }\n\n  if (properties.length > 1) {\n    properties.pop();\n  }\n\n  return properties;\n};\n\nvar normalizeCondition = function normalizeCondition(conditionDescriptor) {\n  if (!conditionDescriptor.all) {\n    if (!conditionDescriptor.any) {\n      conditionDescriptor = {\n        all: conditionDescriptor\n      };\n    }\n  }\n\n  return conditionDescriptor;\n};\n\n/**\n * Support:\n *\n * // TODO: maybe implement short circuits for conditions\n *\n * {\n *   'path/to/elem':         'exact_value',\n *   'path/to/other_elem':   '! negated_exact_value',\n *   'path/to/other_elem_1': 'first_val | second_val | third_possible_val',\n *   'path/to/other_elem_2': '! first_val | second_val',\n * }\n */\nvar matchValuesWithCondition = function matchValuesWithCondition(conditionDescriptor, inferedValuesForContext) {\n  var conditionsObject = Object.values(conditionDescriptor)[0];\n\n  var maybeGetMatcher = function maybeGetMatcher(matcher) {\n    if (matcher.length > 4) {\n      return false;\n    }\n\n    if (matcher.indexOf('any') === 0) {\n      return 'any';\n    }\n\n    if (matcher.indexOf('all') === 0) {\n      return 'all';\n    }\n\n    return false;\n  };\n\n  var valuesToCheck = Object.keys(conditionsObject).map(function (singleOptionPath, index) {\n    var maybeThat = Object.values(conditionsObject)[index];\n\n    if (maybeGetMatcher(singleOptionPath) === 'all' || maybeGetMatcher(singleOptionPath) === 'any') {\n      return matchValuesWithCondition(defineProperty({}, singleOptionPath, maybeThat), inferedValuesForContext);\n    }\n\n    return tryToMatchValueWithOptionPath(maybeThat, singleOptionPath, inferedValuesForContext);\n  });\n\n  if (maybeGetMatcher(Object.keys(conditionDescriptor)[0]) === 'all') {\n    return valuesToCheck.every(function (v) {\n      return !!v;\n    });\n  }\n\n  if (maybeGetMatcher(Object.keys(conditionDescriptor)[0]) === 'any') {\n    return valuesToCheck.some(function (v) {\n      return !!v;\n    });\n  }\n};\n\nfunction extractScalarValueFor(singleOptionPath, inferedValuesForContext) {\n  var getAsInfered = function getAsInfered(path) {\n    var values = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : inferedValuesForContext;\n    return opg(path, values);\n  };\n\n  if (singleOptionPath.indexOf(':') > -1) {\n    /**\n     * Congrats, gentlemans, we are having a custom matcher here\n     * To be honest, this is the dumbest thing I can figure out right now.\n     * There probably is a better way to handle that. One could go about\n     * getting an interface here or smth like that.\n     *\n     * WARNING: Hardcoded to ct-select.\n     * Also doesn't work with ct-inherit, will report the value\n     * incorrectly. Will be fixed properly when implementing the context\n     * asbtraction properly.\n     *\n     * choices matcher\n     * option_id:choices => LENGTH\n     */\n\n    var value = null;(function (thing, cb) {\n      return cb(thing);\n    })(singleOptionPath.split(':'), function (_ref) {\n      var _ref2 = toArray(_ref),\n          singleOptionPath = _ref2[0],\n          matcher = _ref2.slice(1);\n\n      // TODO: start implementing matchers after we are done with\n      // everything else with Vue renderer\n\n      matcher = matcher.join(':');\n\n      if (matcher === 'visibility') {\n        value = getAsInfered(singleOptionPath, _extends({}, inferedValuesForContext, defineProperty({}, propertiesWithoutLast(singleOptionPath), opg(propertiesWithoutLast(singleOptionPath), inferedValuesForContext)[inferedValuesForContext.wp_customizer_current_view] ? 'yes' : 'no')));\n      }\n\n      if (matcher === 'responsive') {\n        value = getAsInfered(singleOptionPath, _extends({}, inferedValuesForContext, defineProperty({}, propertiesWithoutLast(singleOptionPath), opg(propertiesWithoutLast(singleOptionPath), inferedValuesForContext)[inferedValuesForContext.wp_customizer_current_view] || opg(propertiesWithoutLast(singleOptionPath), inferedValuesForContext))));\n      }\n\n      if (matcher === 'truthy') {\n        value = !!getAsInfered(singleOptionPath) ? 'yes' : 'no';\n      }\n\n      if (matcher.indexOf('array-ids:') > -1) {\n        var _matcher$split = matcher.split(':'),\n            _matcher$split2 = slicedToArray(_matcher$split, 3),\n            _ = _matcher$split2[0],\n            id = _matcher$split2[1],\n            path = _matcher$split2[2];\n\n        var _properValue = getAsInfered(singleOptionPath).find(function (v) {\n          return v.id === id;\n        });\n\n        value = !_properValue ? 'no' : opg(path, _properValue) || 'no';\n      }\n\n      if (matcher.indexOf('json:') > -1) {\n        value = getAsInfered(singleOptionPath + '/' + matcher.split(':')[1]).toString();\n      }\n\n      if (matcher === 'array_length') {\n        var _properValue2 = getAsInfered(singleOptionPath);\n\n        value = (_properValue2 || []).length.toString();\n      }\n\n      if (!value) {\n        throw new Error('Unknown matcher received. Please verify for typos. The received matcher: ' + matcher + '.');\n      }\n    });\n\n    /**\n     * Matcher got _matched_.\n     */\n    if (value) {\n      return value;\n    } else {\n      // Fall back to raw value check, but omit the matcher.\n      singleOptionPath = singleOptionPath.split(':')[0];\n    }\n  }\n\n  var properValue = getAsInfered(singleOptionPath);\n\n  if (!properValue) return false;\n\n  if (properValue.desktop) {\n    return properValue;\n  }\n\n  return properValue.toString();\n}\n\nfunction tryToMatchValueWithOptionPath(maybeThat, singleOptionPath, inferedValuesForContext) {\n  var properValue = extractScalarValueFor(singleOptionPath, inferedValuesForContext);\n\n  if (maybeThat && maybeThat.toString() && maybeThat.toString().indexOf('~') === 0) {\n    var toMatch = maybeThat.replace('~', '');\n\n    if (properValue.desktop) {\n      return properValue.desktop === toMatch || properValue.tablet === toMatch || properValue.mobile === toMatch;\n    }\n\n    return properValue === toMatch;\n  }\n\n  properValue = properValue.toString();\n  maybeThat = maybeThat.toString();\n\n  /**\n   * The context value is not yet stabilized\n   */\n  if (!properValue) return false;\n\n  /**\n   * Pipe operator\n   */\n  if (maybeThat.indexOf('|') > -1) {\n    if (maybeThat.indexOf('!') === 0) {\n      return maybeThat.substring(1).split('|').map(function (el) {\n        return el.trim();\n      }).includes(properValue.trim()) === -1;\n    } else {\n      return maybeThat.split('|').map(function (el) {\n        return el.trim();\n      }).indexOf(properValue.trim()) > -1;\n    }\n  }\n\n  /**\n   * Negation operator\n   */\n  if (maybeThat.indexOf('!') === 0) {\n    return properValue !== maybeThat.substring(1).trim();\n  }\n\n  /**\n   * Contains operator\n   */\n  if (maybeThat.indexOf('*') === 0) {\n    return properValue.indexOf(maybeThat.trim().substring(1).trim()) > -1;\n  }\n\n  /**\n   * Simple equality\n   */\n  return properValue === maybeThat.trim();\n}\n\nexport { opg, normalizeCondition, matchValuesWithCondition };\n//# sourceMappingURL=index.es.js.map\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///7465\n")},2568:(module,__unused_webpack_exports,__webpack_require__)=>{eval("(function(){\r\n var crypt = __webpack_require__(1012),\r\n utf8 = (__webpack_require__(487).utf8),\r\n isBuffer = __webpack_require__(8738),\r\n bin = (__webpack_require__(487).bin),\r\n\r\n // The core\r\n md5 = function (message, options) {\r\n // Convert to byte array\r\n if (message.constructor == String)\r\n if (options && options.encoding === 'binary')\r\n message = bin.stringToBytes(message);\r\n else\r\n message = utf8.stringToBytes(message);\r\n else if (isBuffer(message))\r\n message = Array.prototype.slice.call(message, 0);\r\n else if (!Array.isArray(message) && message.constructor !== Uint8Array)\r\n message = message.toString();\r\n // else, assume byte array already\r\n\r\n var m = crypt.bytesToWords(message),\r\n l = message.length * 8,\r\n a = 1732584193,\r\n b = -271733879,\r\n c = -1732584194,\r\n d = 271733878;\r\n\r\n // Swap endian\r\n for (var i = 0; i < m.length; i++) {\r\n m[i] = ((m[i] << 8) | (m[i] >>> 24)) & 0x00FF00FF |\r\n ((m[i] << 24) | (m[i] >>> 8)) & 0xFF00FF00;\r\n }\r\n\r\n // Padding\r\n m[l >>> 5] |= 0x80 << (l % 32);\r\n m[(((l + 64) >>> 9) << 4) + 14] = l;\r\n\r\n // Method shortcuts\r\n var FF = md5._ff,\r\n GG = md5._gg,\r\n HH = md5._hh,\r\n II = md5._ii;\r\n\r\n for (var i = 0; i < m.length; i += 16) {\r\n\r\n var aa = a,\r\n bb = b,\r\n cc = c,\r\n dd = d;\r\n\r\n a = FF(a, b, c, d, m[i+ 0], 7, -680876936);\r\n d = FF(d, a, b, c, m[i+ 1], 12, -389564586);\r\n c = FF(c, d, a, b, m[i+ 2], 17, 606105819);\r\n b = FF(b, c, d, a, m[i+ 3], 22, -1044525330);\r\n a = FF(a, b, c, d, m[i+ 4], 7, -176418897);\r\n d = FF(d, a, b, c, m[i+ 5], 12, 1200080426);\r\n c = FF(c, d, a, b, m[i+ 6], 17, -1473231341);\r\n b = FF(b, c, d, a, m[i+ 7], 22, -45705983);\r\n a = FF(a, b, c, d, m[i+ 8], 7, 1770035416);\r\n d = FF(d, a, b, c, m[i+ 9], 12, -1958414417);\r\n c = FF(c, d, a, b, m[i+10], 17, -42063);\r\n b = FF(b, c, d, a, m[i+11], 22, -1990404162);\r\n a = FF(a, b, c, d, m[i+12], 7, 1804603682);\r\n d = FF(d, a, b, c, m[i+13], 12, -40341101);\r\n c = FF(c, d, a, b, m[i+14], 17, -1502002290);\r\n b = FF(b, c, d, a, m[i+15], 22, 1236535329);\r\n\r\n a = GG(a, b, c, d, m[i+ 1], 5, -165796510);\r\n d = GG(d, a, b, c, m[i+ 6], 9, -1069501632);\r\n c = GG(c, d, a, b, m[i+11], 14, 643717713);\r\n b = GG(b, c, d, a, m[i+ 0], 20, -373897302);\r\n a = GG(a, b, c, d, m[i+ 5], 5, -701558691);\r\n d = GG(d, a, b, c, m[i+10], 9, 38016083);\r\n c = GG(c, d, a, b, m[i+15], 14, -660478335);\r\n b = GG(b, c, d, a, m[i+ 4], 20, -405537848);\r\n a = GG(a, b, c, d, m[i+ 9], 5, 568446438);\r\n d = GG(d, a, b, c, m[i+14], 9, -1019803690);\r\n c = GG(c, d, a, b, m[i+ 3], 14, -187363961);\r\n b = GG(b, c, d, a, m[i+ 8], 20, 1163531501);\r\n a = GG(a, b, c, d, m[i+13], 5, -1444681467);\r\n d = GG(d, a, b, c, m[i+ 2], 9, -51403784);\r\n c = GG(c, d, a, b, m[i+ 7], 14, 1735328473);\r\n b = GG(b, c, d, a, m[i+12], 20, -1926607734);\r\n\r\n a = HH(a, b, c, d, m[i+ 5], 4, -378558);\r\n d = HH(d, a, b, c, m[i+ 8], 11, -2022574463);\r\n c = HH(c, d, a, b, m[i+11], 16, 1839030562);\r\n b = HH(b, c, d, a, m[i+14], 23, -35309556);\r\n a = HH(a, b, c, d, m[i+ 1], 4, -1530992060);\r\n d = HH(d, a, b, c, m[i+ 4], 11, 1272893353);\r\n c = HH(c, d, a, b, m[i+ 7], 16, -155497632);\r\n b = HH(b, c, d, a, m[i+10], 23, -1094730640);\r\n a = HH(a, b, c, d, m[i+13], 4, 681279174);\r\n d = HH(d, a, b, c, m[i+ 0], 11, -358537222);\r\n c = HH(c, d, a, b, m[i+ 3], 16, -722521979);\r\n b = HH(b, c, d, a, m[i+ 6], 23, 76029189);\r\n a = HH(a, b, c, d, m[i+ 9], 4, -640364487);\r\n d = HH(d, a, b, c, m[i+12], 11, -421815835);\r\n c = HH(c, d, a, b, m[i+15], 16, 530742520);\r\n b = HH(b, c, d, a, m[i+ 2], 23, -995338651);\r\n\r\n a = II(a, b, c, d, m[i+ 0], 6, -198630844);\r\n d = II(d, a, b, c, m[i+ 7], 10, 1126891415);\r\n c = II(c, d, a, b, m[i+14], 15, -1416354905);\r\n b = II(b, c, d, a, m[i+ 5], 21, -57434055);\r\n a = II(a, b, c, d, m[i+12], 6, 1700485571);\r\n d = II(d, a, b, c, m[i+ 3], 10, -1894986606);\r\n c = II(c, d, a, b, m[i+10], 15, -1051523);\r\n b = II(b, c, d, a, m[i+ 1], 21, -2054922799);\r\n a = II(a, b, c, d, m[i+ 8], 6, 1873313359);\r\n d = II(d, a, b, c, m[i+15], 10, -30611744);\r\n c = II(c, d, a, b, m[i+ 6], 15, -1560198380);\r\n b = II(b, c, d, a, m[i+13], 21, 1309151649);\r\n a = II(a, b, c, d, m[i+ 4], 6, -145523070);\r\n d = II(d, a, b, c, m[i+11], 10, -1120210379);\r\n c = II(c, d, a, b, m[i+ 2], 15, 718787259);\r\n b = II(b, c, d, a, m[i+ 9], 21, -343485551);\r\n\r\n a = (a + aa) >>> 0;\r\n b = (b + bb) >>> 0;\r\n c = (c + cc) >>> 0;\r\n d = (d + dd) >>> 0;\r\n }\r\n\r\n return crypt.endian([a, b, c, d]);\r\n };\r\n\r\n // Auxiliary functions\r\n md5._ff = function (a, b, c, d, x, s, t) {\r\n var n = a + (b & c | ~b & d) + (x >>> 0) + t;\r\n return ((n << s) | (n >>> (32 - s))) + b;\r\n };\r\n md5._gg = function (a, b, c, d, x, s, t) {\r\n var n = a + (b & d | c & ~d) + (x >>> 0) + t;\r\n return ((n << s) | (n >>> (32 - s))) + b;\r\n };\r\n md5._hh = function (a, b, c, d, x, s, t) {\r\n var n = a + (b ^ c ^ d) + (x >>> 0) + t;\r\n return ((n << s) | (n >>> (32 - s))) + b;\r\n };\r\n md5._ii = function (a, b, c, d, x, s, t) {\r\n var n = a + (c ^ (b | ~d)) + (x >>> 0) + t;\r\n return ((n << s) | (n >>> (32 - s))) + b;\r\n };\r\n\r\n // Package private blocksize\r\n md5._blocksize = 16;\r\n md5._digestsize = 16;\r\n\r\n module.exports = function (message, options) {\r\n if (message === undefined || message === null)\r\n throw new Error('Illegal argument ' + message);\r\n\r\n var digestbytes = crypt.wordsToBytes(md5(message, options));\r\n return options && options.asBytes ? digestbytes :\r\n options && options.asString ? bin.bytesToString(digestbytes) :\r\n crypt.bytesToHex(digestbytes);\r\n };\r\n\r\n})();\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"2568.js","mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./node_modules/md5/md5.js?6821"],"sourcesContent":["(function(){\r\n  var crypt = require('crypt'),\r\n      utf8 = require('charenc').utf8,\r\n      isBuffer = require('is-buffer'),\r\n      bin = require('charenc').bin,\r\n\r\n  // The core\r\n  md5 = function (message, options) {\r\n    // Convert to byte array\r\n    if (message.constructor == String)\r\n      if (options && options.encoding === 'binary')\r\n        message = bin.stringToBytes(message);\r\n      else\r\n        message = utf8.stringToBytes(message);\r\n    else if (isBuffer(message))\r\n      message = Array.prototype.slice.call(message, 0);\r\n    else if (!Array.isArray(message) && message.constructor !== Uint8Array)\r\n      message = message.toString();\r\n    // else, assume byte array already\r\n\r\n    var m = crypt.bytesToWords(message),\r\n        l = message.length * 8,\r\n        a =  1732584193,\r\n        b = -271733879,\r\n        c = -1732584194,\r\n        d =  271733878;\r\n\r\n    // Swap endian\r\n    for (var i = 0; i < m.length; i++) {\r\n      m[i] = ((m[i] <<  8) | (m[i] >>> 24)) & 0x00FF00FF |\r\n             ((m[i] << 24) | (m[i] >>>  8)) & 0xFF00FF00;\r\n    }\r\n\r\n    // Padding\r\n    m[l >>> 5] |= 0x80 << (l % 32);\r\n    m[(((l + 64) >>> 9) << 4) + 14] = l;\r\n\r\n    // Method shortcuts\r\n    var FF = md5._ff,\r\n        GG = md5._gg,\r\n        HH = md5._hh,\r\n        II = md5._ii;\r\n\r\n    for (var i = 0; i < m.length; i += 16) {\r\n\r\n      var aa = a,\r\n          bb = b,\r\n          cc = c,\r\n          dd = d;\r\n\r\n      a = FF(a, b, c, d, m[i+ 0],  7, -680876936);\r\n      d = FF(d, a, b, c, m[i+ 1], 12, -389564586);\r\n      c = FF(c, d, a, b, m[i+ 2], 17,  606105819);\r\n      b = FF(b, c, d, a, m[i+ 3], 22, -1044525330);\r\n      a = FF(a, b, c, d, m[i+ 4],  7, -176418897);\r\n      d = FF(d, a, b, c, m[i+ 5], 12,  1200080426);\r\n      c = FF(c, d, a, b, m[i+ 6], 17, -1473231341);\r\n      b = FF(b, c, d, a, m[i+ 7], 22, -45705983);\r\n      a = FF(a, b, c, d, m[i+ 8],  7,  1770035416);\r\n      d = FF(d, a, b, c, m[i+ 9], 12, -1958414417);\r\n      c = FF(c, d, a, b, m[i+10], 17, -42063);\r\n      b = FF(b, c, d, a, m[i+11], 22, -1990404162);\r\n      a = FF(a, b, c, d, m[i+12],  7,  1804603682);\r\n      d = FF(d, a, b, c, m[i+13], 12, -40341101);\r\n      c = FF(c, d, a, b, m[i+14], 17, -1502002290);\r\n      b = FF(b, c, d, a, m[i+15], 22,  1236535329);\r\n\r\n      a = GG(a, b, c, d, m[i+ 1],  5, -165796510);\r\n      d = GG(d, a, b, c, m[i+ 6],  9, -1069501632);\r\n      c = GG(c, d, a, b, m[i+11], 14,  643717713);\r\n      b = GG(b, c, d, a, m[i+ 0], 20, -373897302);\r\n      a = GG(a, b, c, d, m[i+ 5],  5, -701558691);\r\n      d = GG(d, a, b, c, m[i+10],  9,  38016083);\r\n      c = GG(c, d, a, b, m[i+15], 14, -660478335);\r\n      b = GG(b, c, d, a, m[i+ 4], 20, -405537848);\r\n      a = GG(a, b, c, d, m[i+ 9],  5,  568446438);\r\n      d = GG(d, a, b, c, m[i+14],  9, -1019803690);\r\n      c = GG(c, d, a, b, m[i+ 3], 14, -187363961);\r\n      b = GG(b, c, d, a, m[i+ 8], 20,  1163531501);\r\n      a = GG(a, b, c, d, m[i+13],  5, -1444681467);\r\n      d = GG(d, a, b, c, m[i+ 2],  9, -51403784);\r\n      c = GG(c, d, a, b, m[i+ 7], 14,  1735328473);\r\n      b = GG(b, c, d, a, m[i+12], 20, -1926607734);\r\n\r\n      a = HH(a, b, c, d, m[i+ 5],  4, -378558);\r\n      d = HH(d, a, b, c, m[i+ 8], 11, -2022574463);\r\n      c = HH(c, d, a, b, m[i+11], 16,  1839030562);\r\n      b = HH(b, c, d, a, m[i+14], 23, -35309556);\r\n      a = HH(a, b, c, d, m[i+ 1],  4, -1530992060);\r\n      d = HH(d, a, b, c, m[i+ 4], 11,  1272893353);\r\n      c = HH(c, d, a, b, m[i+ 7], 16, -155497632);\r\n      b = HH(b, c, d, a, m[i+10], 23, -1094730640);\r\n      a = HH(a, b, c, d, m[i+13],  4,  681279174);\r\n      d = HH(d, a, b, c, m[i+ 0], 11, -358537222);\r\n      c = HH(c, d, a, b, m[i+ 3], 16, -722521979);\r\n      b = HH(b, c, d, a, m[i+ 6], 23,  76029189);\r\n      a = HH(a, b, c, d, m[i+ 9],  4, -640364487);\r\n      d = HH(d, a, b, c, m[i+12], 11, -421815835);\r\n      c = HH(c, d, a, b, m[i+15], 16,  530742520);\r\n      b = HH(b, c, d, a, m[i+ 2], 23, -995338651);\r\n\r\n      a = II(a, b, c, d, m[i+ 0],  6, -198630844);\r\n      d = II(d, a, b, c, m[i+ 7], 10,  1126891415);\r\n      c = II(c, d, a, b, m[i+14], 15, -1416354905);\r\n      b = II(b, c, d, a, m[i+ 5], 21, -57434055);\r\n      a = II(a, b, c, d, m[i+12],  6,  1700485571);\r\n      d = II(d, a, b, c, m[i+ 3], 10, -1894986606);\r\n      c = II(c, d, a, b, m[i+10], 15, -1051523);\r\n      b = II(b, c, d, a, m[i+ 1], 21, -2054922799);\r\n      a = II(a, b, c, d, m[i+ 8],  6,  1873313359);\r\n      d = II(d, a, b, c, m[i+15], 10, -30611744);\r\n      c = II(c, d, a, b, m[i+ 6], 15, -1560198380);\r\n      b = II(b, c, d, a, m[i+13], 21,  1309151649);\r\n      a = II(a, b, c, d, m[i+ 4],  6, -145523070);\r\n      d = II(d, a, b, c, m[i+11], 10, -1120210379);\r\n      c = II(c, d, a, b, m[i+ 2], 15,  718787259);\r\n      b = II(b, c, d, a, m[i+ 9], 21, -343485551);\r\n\r\n      a = (a + aa) >>> 0;\r\n      b = (b + bb) >>> 0;\r\n      c = (c + cc) >>> 0;\r\n      d = (d + dd) >>> 0;\r\n    }\r\n\r\n    return crypt.endian([a, b, c, d]);\r\n  };\r\n\r\n  // Auxiliary functions\r\n  md5._ff  = function (a, b, c, d, x, s, t) {\r\n    var n = a + (b & c | ~b & d) + (x >>> 0) + t;\r\n    return ((n << s) | (n >>> (32 - s))) + b;\r\n  };\r\n  md5._gg  = function (a, b, c, d, x, s, t) {\r\n    var n = a + (b & d | c & ~d) + (x >>> 0) + t;\r\n    return ((n << s) | (n >>> (32 - s))) + b;\r\n  };\r\n  md5._hh  = function (a, b, c, d, x, s, t) {\r\n    var n = a + (b ^ c ^ d) + (x >>> 0) + t;\r\n    return ((n << s) | (n >>> (32 - s))) + b;\r\n  };\r\n  md5._ii  = function (a, b, c, d, x, s, t) {\r\n    var n = a + (c ^ (b | ~d)) + (x >>> 0) + t;\r\n    return ((n << s) | (n >>> (32 - s))) + b;\r\n  };\r\n\r\n  // Package private blocksize\r\n  md5._blocksize = 16;\r\n  md5._digestsize = 16;\r\n\r\n  module.exports = function (message, options) {\r\n    if (message === undefined || message === null)\r\n      throw new Error('Illegal argument ' + message);\r\n\r\n    var digestbytes = crypt.wordsToBytes(md5(message, options));\r\n    return options && options.asBytes ? digestbytes :\r\n        options && options.asString ? bin.bytesToString(digestbytes) :\r\n        crypt.bytesToHex(digestbytes);\r\n  };\r\n\r\n})();\r\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///2568\n")},1496:module=>{eval("// This file replaces `index.js` in bundlers like webpack or Rollup,\n// according to `browser` config in `package.json`.\n\nif (false) {}\n\nvar crypto = self.crypto || self.msCrypto\n\n// This alphabet uses a-z A-Z 0-9 _- symbols.\n// Symbols are generated for smaller size.\n// -_zyxwvutsrqponmlkjihgfedcba9876543210ZYXWVUTSRQPONMLKJIHGFEDCBA\nvar url = '-_'\n// Loop from 36 to 0 (from z to a and 9 to 0 in Base36).\nvar i = 36\nwhile (i--) {\n // 36 is radix. Number.prototype.toString(36) returns number\n // in Base36 representation. Base36 is like hex, but it uses 0–9 and a-z.\n url += i.toString(36)\n}\n// Loop from 36 to 10 (from Z to A in Base36).\ni = 36\nwhile (i-- - 10) {\n url += i.toString(36).toUpperCase()\n}\n\nmodule.exports = function (size) {\n var id = ''\n var bytes = crypto.getRandomValues(new Uint8Array(size || 21))\n i = size || 21\n\n // Compact alternative for `for (var i = 0; i < size; i++)`\n while (i--) {\n // We can’t use bytes bigger than the alphabet. 63 is 00111111 bitmask.\n // This mask reduces random byte 0-255 to 0-63 values.\n // There is no need in `|| ''` and `* 1.6` hacks in here,\n // because bitmask trim bytes exact to alphabet size.\n id += url[bytes[i] & 63]\n }\n return id\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTQ5Ni5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQWdCQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9ub2RlX21vZHVsZXMvbmFub2lkL2luZGV4LmJyb3dzZXIuanM/ZTFiZCJdLCJzb3VyY2VzQ29udGVudCI6WyIvLyBUaGlzIGZpbGUgcmVwbGFjZXMgYGluZGV4LmpzYCBpbiBidW5kbGVycyBsaWtlIHdlYnBhY2sgb3IgUm9sbHVwLFxuLy8gYWNjb3JkaW5nIHRvIGBicm93c2VyYCBjb25maWcgaW4gYHBhY2thZ2UuanNvbmAuXG5cbmlmIChwcm9jZXNzLmVudi5OT0RFX0VOViAhPT0gJ3Byb2R1Y3Rpb24nKSB7XG4gIC8vIEFsbCBidW5kbGVycyB3aWxsIHJlbW92ZSB0aGlzIGJsb2NrIGluIHByb2R1Y3Rpb24gYnVuZGxlXG4gIGlmICh0eXBlb2YgbmF2aWdhdG9yICE9PSAndW5kZWZpbmVkJyAmJiBuYXZpZ2F0b3IucHJvZHVjdCA9PT0gJ1JlYWN0TmF0aXZlJykge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICdSZWFjdCBOYXRpdmUgZG9lcyBub3QgaGF2ZSBhIGJ1aWx0LWluIHNlY3VyZSByYW5kb20gZ2VuZXJhdG9yLiAnICtcbiAgICAgICdJZiB5b3UgZG9u4oCZdCBuZWVkIHVucHJlZGljdGFibGUgSURzLCB5b3UgY2FuIHVzZSBgbmFub2lkL25vbi1zZWN1cmVgLiAnICtcbiAgICAgICdGb3Igc2VjdXJlIElEIGluc3RhbGwgYGV4cG8tcmFuZG9tYCBsb2NhbGx5IGFuZCB1c2UgYG5hbm9pZC9hc3luY2AuJ1xuICAgIClcbiAgfVxuICBpZiAodHlwZW9mIHNlbGYgPT09ICd1bmRlZmluZWQnIHx8ICghc2VsZi5jcnlwdG8gJiYgIXNlbGYubXNDcnlwdG8pKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgJ1lvdXIgYnJvd3NlciBkb2VzIG5vdCBoYXZlIHNlY3VyZSByYW5kb20gZ2VuZXJhdG9yLiAnICtcbiAgICAgICdJZiB5b3UgZG9u4oCZdCBuZWVkIHVucHJlZGljdGFibGUgSURzLCB5b3UgY2FuIHVzZSBuYW5vaWQvbm9uLXNlY3VyZS4nXG4gICAgKVxuICB9XG59XG5cbnZhciBjcnlwdG8gPSBzZWxmLmNyeXB0byB8fCBzZWxmLm1zQ3J5cHRvXG5cbi8vIFRoaXMgYWxwaGFiZXQgdXNlcyBhLXogQS1aIDAtOSBfLSBzeW1ib2xzLlxuLy8gU3ltYm9scyBhcmUgZ2VuZXJhdGVkIGZvciBzbWFsbGVyIHNpemUuXG4vLyAtX3p5eHd2dXRzcnFwb25tbGtqaWhnZmVkY2JhOTg3NjU0MzIxMFpZWFdWVVRTUlFQT05NTEtKSUhHRkVEQ0JBXG52YXIgdXJsID0gJy1fJ1xuLy8gTG9vcCBmcm9tIDM2IHRvIDAgKGZyb20geiB0byBhIGFuZCA5IHRvIDAgaW4gQmFzZTM2KS5cbnZhciBpID0gMzZcbndoaWxlIChpLS0pIHtcbiAgLy8gMzYgaXMgcmFkaXguIE51bWJlci5wcm90b3R5cGUudG9TdHJpbmcoMzYpIHJldHVybnMgbnVtYmVyXG4gIC8vIGluIEJhc2UzNiByZXByZXNlbnRhdGlvbi4gQmFzZTM2IGlzIGxpa2UgaGV4LCBidXQgaXQgdXNlcyAw4oCTOSBhbmQgYS16LlxuICB1cmwgKz0gaS50b1N0cmluZygzNilcbn1cbi8vIExvb3AgZnJvbSAzNiB0byAxMCAoZnJvbSBaIHRvIEEgaW4gQmFzZTM2KS5cbmkgPSAzNlxud2hpbGUgKGktLSAtIDEwKSB7XG4gIHVybCArPSBpLnRvU3RyaW5nKDM2KS50b1VwcGVyQ2FzZSgpXG59XG5cbm1vZHVsZS5leHBvcnRzID0gZnVuY3Rpb24gKHNpemUpIHtcbiAgdmFyIGlkID0gJydcbiAgdmFyIGJ5dGVzID0gY3J5cHRvLmdldFJhbmRvbVZhbHVlcyhuZXcgVWludDhBcnJheShzaXplIHx8IDIxKSlcbiAgaSA9IHNpemUgfHwgMjFcblxuICAvLyBDb21wYWN0IGFsdGVybmF0aXZlIGZvciBgZm9yICh2YXIgaSA9IDA7IGkgPCBzaXplOyBpKyspYFxuICB3aGlsZSAoaS0tKSB7XG4gICAgLy8gV2UgY2Fu4oCZdCB1c2UgYnl0ZXMgYmlnZ2VyIHRoYW4gdGhlIGFscGhhYmV0LiA2MyBpcyAwMDExMTExMSBiaXRtYXNrLlxuICAgIC8vIFRoaXMgbWFzayByZWR1Y2VzIHJhbmRvbSBieXRlIDAtMjU1IHRvIDAtNjMgdmFsdWVzLlxuICAgIC8vIFRoZXJlIGlzIG5vIG5lZWQgaW4gYHx8ICcnYCBhbmQgYCogMS42YCBoYWNrcyBpbiBoZXJlLFxuICAgIC8vIGJlY2F1c2UgYml0bWFzayB0cmltIGJ5dGVzIGV4YWN0IHRvIGFscGhhYmV0IHNpemUuXG4gICAgaWQgKz0gdXJsW2J5dGVzW2ldICYgNjNdXG4gIH1cbiAgcmV0dXJuIGlkXG59XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///1496\n")},4244:module=>{"use strict";eval("\n\nvar numberIsNaN = function (value) {\n\treturn value !== value;\n};\n\nmodule.exports = function is(a, b) {\n\tif (a === 0 && b === 0) {\n\t\treturn 1 / a === 1 / b;\n\t}\n\tif (a === b) {\n\t\treturn true;\n\t}\n\tif (numberIsNaN(a) && numberIsNaN(b)) {\n\t\treturn true;\n\t}\n\treturn false;\n};\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNDI0NC5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vbm9kZV9tb2R1bGVzL29iamVjdC1pcy9pbXBsZW1lbnRhdGlvbi5qcz9kNmVmIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxudmFyIG51bWJlcklzTmFOID0gZnVuY3Rpb24gKHZhbHVlKSB7XG5cdHJldHVybiB2YWx1ZSAhPT0gdmFsdWU7XG59O1xuXG5tb2R1bGUuZXhwb3J0cyA9IGZ1bmN0aW9uIGlzKGEsIGIpIHtcblx0aWYgKGEgPT09IDAgJiYgYiA9PT0gMCkge1xuXHRcdHJldHVybiAxIC8gYSA9PT0gMSAvIGI7XG5cdH1cblx0aWYgKGEgPT09IGIpIHtcblx0XHRyZXR1cm4gdHJ1ZTtcblx0fVxuXHRpZiAobnVtYmVySXNOYU4oYSkgJiYgbnVtYmVySXNOYU4oYikpIHtcblx0XHRyZXR1cm4gdHJ1ZTtcblx0fVxuXHRyZXR1cm4gZmFsc2U7XG59O1xuXG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///4244\n")},609:(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval("\n\nvar define = __webpack_require__(4289);\nvar callBind = __webpack_require__(5559);\n\nvar implementation = __webpack_require__(4244);\nvar getPolyfill = __webpack_require__(5624);\nvar shim = __webpack_require__(2281);\n\nvar polyfill = callBind(getPolyfill(), Object);\n\ndefine(polyfill, {\n\tgetPolyfill: getPolyfill,\n\timplementation: implementation,\n\tshim: shim\n});\n\nmodule.exports = polyfill;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNjA5LmpzIiwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vbm9kZV9tb2R1bGVzL29iamVjdC1pcy9pbmRleC5qcz82ZGI3Il0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxudmFyIGRlZmluZSA9IHJlcXVpcmUoJ2RlZmluZS1wcm9wZXJ0aWVzJyk7XG52YXIgY2FsbEJpbmQgPSByZXF1aXJlKCdjYWxsLWJpbmQnKTtcblxudmFyIGltcGxlbWVudGF0aW9uID0gcmVxdWlyZSgnLi9pbXBsZW1lbnRhdGlvbicpO1xudmFyIGdldFBvbHlmaWxsID0gcmVxdWlyZSgnLi9wb2x5ZmlsbCcpO1xudmFyIHNoaW0gPSByZXF1aXJlKCcuL3NoaW0nKTtcblxudmFyIHBvbHlmaWxsID0gY2FsbEJpbmQoZ2V0UG9seWZpbGwoKSwgT2JqZWN0KTtcblxuZGVmaW5lKHBvbHlmaWxsLCB7XG5cdGdldFBvbHlmaWxsOiBnZXRQb2x5ZmlsbCxcblx0aW1wbGVtZW50YXRpb246IGltcGxlbWVudGF0aW9uLFxuXHRzaGltOiBzaGltXG59KTtcblxubW9kdWxlLmV4cG9ydHMgPSBwb2x5ZmlsbDtcbiJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///609\n")},5624:(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval("\n\nvar implementation = __webpack_require__(4244);\n\nmodule.exports = function getPolyfill() {\n\treturn typeof Object.is === 'function' ? Object.is : implementation;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNTYyNC5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vbm9kZV9tb2R1bGVzL29iamVjdC1pcy9wb2x5ZmlsbC5qcz81ODM0Il0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxudmFyIGltcGxlbWVudGF0aW9uID0gcmVxdWlyZSgnLi9pbXBsZW1lbnRhdGlvbicpO1xuXG5tb2R1bGUuZXhwb3J0cyA9IGZ1bmN0aW9uIGdldFBvbHlmaWxsKCkge1xuXHRyZXR1cm4gdHlwZW9mIE9iamVjdC5pcyA9PT0gJ2Z1bmN0aW9uJyA/IE9iamVjdC5pcyA6IGltcGxlbWVudGF0aW9uO1xufTtcbiJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///5624\n")},2281:(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval("\n\nvar getPolyfill = __webpack_require__(5624);\nvar define = __webpack_require__(4289);\n\nmodule.exports = function shimObjectIs() {\n\tvar polyfill = getPolyfill();\n\tdefine(Object, { is: polyfill }, {\n\t\tis: function testObjectIs() {\n\t\t\treturn Object.is !== polyfill;\n\t\t}\n\t});\n\treturn polyfill;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMjI4MS5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9ub2RlX21vZHVsZXMvb2JqZWN0LWlzL3NoaW0uanM/YzE1YSJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbnZhciBnZXRQb2x5ZmlsbCA9IHJlcXVpcmUoJy4vcG9seWZpbGwnKTtcbnZhciBkZWZpbmUgPSByZXF1aXJlKCdkZWZpbmUtcHJvcGVydGllcycpO1xuXG5tb2R1bGUuZXhwb3J0cyA9IGZ1bmN0aW9uIHNoaW1PYmplY3RJcygpIHtcblx0dmFyIHBvbHlmaWxsID0gZ2V0UG9seWZpbGwoKTtcblx0ZGVmaW5lKE9iamVjdCwgeyBpczogcG9seWZpbGwgfSwge1xuXHRcdGlzOiBmdW5jdGlvbiB0ZXN0T2JqZWN0SXMoKSB7XG5cdFx0XHRyZXR1cm4gT2JqZWN0LmlzICE9PSBwb2x5ZmlsbDtcblx0XHR9XG5cdH0pO1xuXHRyZXR1cm4gcG9seWZpbGw7XG59O1xuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///2281\n")},8987:(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval("\n\nvar keysShim;\nif (!Object.keys) {\n\t// modified from https://github.com/es-shims/es5-shim\n\tvar has = Object.prototype.hasOwnProperty;\n\tvar toStr = Object.prototype.toString;\n\tvar isArgs = __webpack_require__(1414); // eslint-disable-line global-require\n\tvar isEnumerable = Object.prototype.propertyIsEnumerable;\n\tvar hasDontEnumBug = !isEnumerable.call({ toString: null }, 'toString');\n\tvar hasProtoEnumBug = isEnumerable.call(function () {}, 'prototype');\n\tvar dontEnums = [\n\t\t'toString',\n\t\t'toLocaleString',\n\t\t'valueOf',\n\t\t'hasOwnProperty',\n\t\t'isPrototypeOf',\n\t\t'propertyIsEnumerable',\n\t\t'constructor'\n\t];\n\tvar equalsConstructorPrototype = function (o) {\n\t\tvar ctor = o.constructor;\n\t\treturn ctor && ctor.prototype === o;\n\t};\n\tvar excludedKeys = {\n\t\t$applicationCache: true,\n\t\t$console: true,\n\t\t$external: true,\n\t\t$frame: true,\n\t\t$frameElement: true,\n\t\t$frames: true,\n\t\t$innerHeight: true,\n\t\t$innerWidth: true,\n\t\t$onmozfullscreenchange: true,\n\t\t$onmozfullscreenerror: true,\n\t\t$outerHeight: true,\n\t\t$outerWidth: true,\n\t\t$pageXOffset: true,\n\t\t$pageYOffset: true,\n\t\t$parent: true,\n\t\t$scrollLeft: true,\n\t\t$scrollTop: true,\n\t\t$scrollX: true,\n\t\t$scrollY: true,\n\t\t$self: true,\n\t\t$webkitIndexedDB: true,\n\t\t$webkitStorageInfo: true,\n\t\t$window: true\n\t};\n\tvar hasAutomationEqualityBug = (function () {\n\t\t/* global window */\n\t\tif (typeof window === 'undefined') { return false; }\n\t\tfor (var k in window) {\n\t\t\ttry {\n\t\t\t\tif (!excludedKeys['$' + k] && has.call(window, k) && window[k] !== null && typeof window[k] === 'object') {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tequalsConstructorPrototype(window[k]);\n\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\treturn true;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\t\treturn false;\n\t}());\n\tvar equalsConstructorPrototypeIfNotBuggy = function (o) {\n\t\t/* global window */\n\t\tif (typeof window === 'undefined' || !hasAutomationEqualityBug) {\n\t\t\treturn equalsConstructorPrototype(o);\n\t\t}\n\t\ttry {\n\t\t\treturn equalsConstructorPrototype(o);\n\t\t} catch (e) {\n\t\t\treturn false;\n\t\t}\n\t};\n\n\tkeysShim = function keys(object) {\n\t\tvar isObject = object !== null && typeof object === 'object';\n\t\tvar isFunction = toStr.call(object) === '[object Function]';\n\t\tvar isArguments = isArgs(object);\n\t\tvar isString = isObject && toStr.call(object) === '[object String]';\n\t\tvar theKeys = [];\n\n\t\tif (!isObject && !isFunction && !isArguments) {\n\t\t\tthrow new TypeError('Object.keys called on a non-object');\n\t\t}\n\n\t\tvar skipProto = hasProtoEnumBug && isFunction;\n\t\tif (isString && object.length > 0 && !has.call(object, 0)) {\n\t\t\tfor (var i = 0; i < object.length; ++i) {\n\t\t\t\ttheKeys.push(String(i));\n\t\t\t}\n\t\t}\n\n\t\tif (isArguments && object.length > 0) {\n\t\t\tfor (var j = 0; j < object.length; ++j) {\n\t\t\t\ttheKeys.push(String(j));\n\t\t\t}\n\t\t} else {\n\t\t\tfor (var name in object) {\n\t\t\t\tif (!(skipProto && name === 'prototype') && has.call(object, name)) {\n\t\t\t\t\ttheKeys.push(String(name));\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tif (hasDontEnumBug) {\n\t\t\tvar skipConstructor = equalsConstructorPrototypeIfNotBuggy(object);\n\n\t\t\tfor (var k = 0; k < dontEnums.length; ++k) {\n\t\t\t\tif (!(skipConstructor && dontEnums[k] === 'constructor') && has.call(object, dontEnums[k])) {\n\t\t\t\t\ttheKeys.push(dontEnums[k]);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn theKeys;\n\t};\n}\nmodule.exports = keysShim;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiODk4Ny5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9ub2RlX21vZHVsZXMvb2JqZWN0LWtleXMvaW1wbGVtZW50YXRpb24uanM/YjE4OSJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbnZhciBrZXlzU2hpbTtcbmlmICghT2JqZWN0LmtleXMpIHtcblx0Ly8gbW9kaWZpZWQgZnJvbSBodHRwczovL2dpdGh1Yi5jb20vZXMtc2hpbXMvZXM1LXNoaW1cblx0dmFyIGhhcyA9IE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHk7XG5cdHZhciB0b1N0ciA9IE9iamVjdC5wcm90b3R5cGUudG9TdHJpbmc7XG5cdHZhciBpc0FyZ3MgPSByZXF1aXJlKCcuL2lzQXJndW1lbnRzJyk7IC8vIGVzbGludC1kaXNhYmxlLWxpbmUgZ2xvYmFsLXJlcXVpcmVcblx0dmFyIGlzRW51bWVyYWJsZSA9IE9iamVjdC5wcm90b3R5cGUucHJvcGVydHlJc0VudW1lcmFibGU7XG5cdHZhciBoYXNEb250RW51bUJ1ZyA9ICFpc0VudW1lcmFibGUuY2FsbCh7IHRvU3RyaW5nOiBudWxsIH0sICd0b1N0cmluZycpO1xuXHR2YXIgaGFzUHJvdG9FbnVtQnVnID0gaXNFbnVtZXJhYmxlLmNhbGwoZnVuY3Rpb24gKCkge30sICdwcm90b3R5cGUnKTtcblx0dmFyIGRvbnRFbnVtcyA9IFtcblx0XHQndG9TdHJpbmcnLFxuXHRcdCd0b0xvY2FsZVN0cmluZycsXG5cdFx0J3ZhbHVlT2YnLFxuXHRcdCdoYXNPd25Qcm9wZXJ0eScsXG5cdFx0J2lzUHJvdG90eXBlT2YnLFxuXHRcdCdwcm9wZXJ0eUlzRW51bWVyYWJsZScsXG5cdFx0J2NvbnN0cnVjdG9yJ1xuXHRdO1xuXHR2YXIgZXF1YWxzQ29uc3RydWN0b3JQcm90b3R5cGUgPSBmdW5jdGlvbiAobykge1xuXHRcdHZhciBjdG9yID0gby5jb25zdHJ1Y3Rvcjtcblx0XHRyZXR1cm4gY3RvciAmJiBjdG9yLnByb3RvdHlwZSA9PT0gbztcblx0fTtcblx0dmFyIGV4Y2x1ZGVkS2V5cyA9IHtcblx0XHQkYXBwbGljYXRpb25DYWNoZTogdHJ1ZSxcblx0XHQkY29uc29sZTogdHJ1ZSxcblx0XHQkZXh0ZXJuYWw6IHRydWUsXG5cdFx0JGZyYW1lOiB0cnVlLFxuXHRcdCRmcmFtZUVsZW1lbnQ6IHRydWUsXG5cdFx0JGZyYW1lczogdHJ1ZSxcblx0XHQkaW5uZXJIZWlnaHQ6IHRydWUsXG5cdFx0JGlubmVyV2lkdGg6IHRydWUsXG5cdFx0JG9ubW96ZnVsbHNjcmVlbmNoYW5nZTogdHJ1ZSxcblx0XHQkb25tb3pmdWxsc2NyZWVuZXJyb3I6IHRydWUsXG5cdFx0JG91dGVySGVpZ2h0OiB0cnVlLFxuXHRcdCRvdXRlcldpZHRoOiB0cnVlLFxuXHRcdCRwYWdlWE9mZnNldDogdHJ1ZSxcblx0XHQkcGFnZVlPZmZzZXQ6IHRydWUsXG5cdFx0JHBhcmVudDogdHJ1ZSxcblx0XHQkc2Nyb2xsTGVmdDogdHJ1ZSxcblx0XHQkc2Nyb2xsVG9wOiB0cnVlLFxuXHRcdCRzY3JvbGxYOiB0cnVlLFxuXHRcdCRzY3JvbGxZOiB0cnVlLFxuXHRcdCRzZWxmOiB0cnVlLFxuXHRcdCR3ZWJraXRJbmRleGVkREI6IHRydWUsXG5cdFx0JHdlYmtpdFN0b3JhZ2VJbmZvOiB0cnVlLFxuXHRcdCR3aW5kb3c6IHRydWVcblx0fTtcblx0dmFyIGhhc0F1dG9tYXRpb25FcXVhbGl0eUJ1ZyA9IChmdW5jdGlvbiAoKSB7XG5cdFx0LyogZ2xvYmFsIHdpbmRvdyAqL1xuXHRcdGlmICh0eXBlb2Ygd2luZG93ID09PSAndW5kZWZpbmVkJykgeyByZXR1cm4gZmFsc2U7IH1cblx0XHRmb3IgKHZhciBrIGluIHdpbmRvdykge1xuXHRcdFx0dHJ5IHtcblx0XHRcdFx0aWYgKCFleGNsdWRlZEtleXNbJyQnICsga10gJiYgaGFzLmNhbGwod2luZG93LCBrKSAmJiB3aW5kb3dba10gIT09IG51bGwgJiYgdHlwZW9mIHdpbmRvd1trXSA9PT0gJ29iamVjdCcpIHtcblx0XHRcdFx0XHR0cnkge1xuXHRcdFx0XHRcdFx0ZXF1YWxzQ29uc3RydWN0b3JQcm90b3R5cGUod2luZG93W2tdKTtcblx0XHRcdFx0XHR9IGNhdGNoIChlKSB7XG5cdFx0XHRcdFx0XHRyZXR1cm4gdHJ1ZTtcblx0XHRcdFx0XHR9XG5cdFx0XHRcdH1cblx0XHRcdH0gY2F0Y2ggKGUpIHtcblx0XHRcdFx0cmV0dXJuIHRydWU7XG5cdFx0XHR9XG5cdFx0fVxuXHRcdHJldHVybiBmYWxzZTtcblx0fSgpKTtcblx0dmFyIGVxdWFsc0NvbnN0cnVjdG9yUHJvdG90eXBlSWZOb3RCdWdneSA9IGZ1bmN0aW9uIChvKSB7XG5cdFx0LyogZ2xvYmFsIHdpbmRvdyAqL1xuXHRcdGlmICh0eXBlb2Ygd2luZG93ID09PSAndW5kZWZpbmVkJyB8fCAhaGFzQXV0b21hdGlvbkVxdWFsaXR5QnVnKSB7XG5cdFx0XHRyZXR1cm4gZXF1YWxzQ29uc3RydWN0b3JQcm90b3R5cGUobyk7XG5cdFx0fVxuXHRcdHRyeSB7XG5cdFx0XHRyZXR1cm4gZXF1YWxzQ29uc3RydWN0b3JQcm90b3R5cGUobyk7XG5cdFx0fSBjYXRjaCAoZSkge1xuXHRcdFx0cmV0dXJuIGZhbHNlO1xuXHRcdH1cblx0fTtcblxuXHRrZXlzU2hpbSA9IGZ1bmN0aW9uIGtleXMob2JqZWN0KSB7XG5cdFx0dmFyIGlzT2JqZWN0ID0gb2JqZWN0ICE9PSBudWxsICYmIHR5cGVvZiBvYmplY3QgPT09ICdvYmplY3QnO1xuXHRcdHZhciBpc0Z1bmN0aW9uID0gdG9TdHIuY2FsbChvYmplY3QpID09PSAnW29iamVjdCBGdW5jdGlvbl0nO1xuXHRcdHZhciBpc0FyZ3VtZW50cyA9IGlzQXJncyhvYmplY3QpO1xuXHRcdHZhciBpc1N0cmluZyA9IGlzT2JqZWN0ICYmIHRvU3RyLmNhbGwob2JqZWN0KSA9PT0gJ1tvYmplY3QgU3RyaW5nXSc7XG5cdFx0dmFyIHRoZUtleXMgPSBbXTtcblxuXHRcdGlmICghaXNPYmplY3QgJiYgIWlzRnVuY3Rpb24gJiYgIWlzQXJndW1lbnRzKSB7XG5cdFx0XHR0aHJvdyBuZXcgVHlwZUVycm9yKCdPYmplY3Qua2V5cyBjYWxsZWQgb24gYSBub24tb2JqZWN0Jyk7XG5cdFx0fVxuXG5cdFx0dmFyIHNraXBQcm90byA9IGhhc1Byb3RvRW51bUJ1ZyAmJiBpc0Z1bmN0aW9uO1xuXHRcdGlmIChpc1N0cmluZyAmJiBvYmplY3QubGVuZ3RoID4gMCAmJiAhaGFzLmNhbGwob2JqZWN0LCAwKSkge1xuXHRcdFx0Zm9yICh2YXIgaSA9IDA7IGkgPCBvYmplY3QubGVuZ3RoOyArK2kpIHtcblx0XHRcdFx0dGhlS2V5cy5wdXNoKFN0cmluZyhpKSk7XG5cdFx0XHR9XG5cdFx0fVxuXG5cdFx0aWYgKGlzQXJndW1lbnRzICYmIG9iamVjdC5sZW5ndGggPiAwKSB7XG5cdFx0XHRmb3IgKHZhciBqID0gMDsgaiA8IG9iamVjdC5sZW5ndGg7ICsraikge1xuXHRcdFx0XHR0aGVLZXlzLnB1c2goU3RyaW5nKGopKTtcblx0XHRcdH1cblx0XHR9IGVsc2Uge1xuXHRcdFx0Zm9yICh2YXIgbmFtZSBpbiBvYmplY3QpIHtcblx0XHRcdFx0aWYgKCEoc2tpcFByb3RvICYmIG5hbWUgPT09ICdwcm90b3R5cGUnKSAmJiBoYXMuY2FsbChvYmplY3QsIG5hbWUpKSB7XG5cdFx0XHRcdFx0dGhlS2V5cy5wdXNoKFN0cmluZyhuYW1lKSk7XG5cdFx0XHRcdH1cblx0XHRcdH1cblx0XHR9XG5cblx0XHRpZiAoaGFzRG9udEVudW1CdWcpIHtcblx0XHRcdHZhciBza2lwQ29uc3RydWN0b3IgPSBlcXVhbHNDb25zdHJ1Y3RvclByb3RvdHlwZUlmTm90QnVnZ3kob2JqZWN0KTtcblxuXHRcdFx0Zm9yICh2YXIgayA9IDA7IGsgPCBkb250RW51bXMubGVuZ3RoOyArK2spIHtcblx0XHRcdFx0aWYgKCEoc2tpcENvbnN0cnVjdG9yICYmIGRvbnRFbnVtc1trXSA9PT0gJ2NvbnN0cnVjdG9yJykgJiYgaGFzLmNhbGwob2JqZWN0LCBkb250RW51bXNba10pKSB7XG5cdFx0XHRcdFx0dGhlS2V5cy5wdXNoKGRvbnRFbnVtc1trXSk7XG5cdFx0XHRcdH1cblx0XHRcdH1cblx0XHR9XG5cdFx0cmV0dXJuIHRoZUtleXM7XG5cdH07XG59XG5tb2R1bGUuZXhwb3J0cyA9IGtleXNTaGltO1xuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///8987\n")},2215:(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval("\n\nvar slice = Array.prototype.slice;\nvar isArgs = __webpack_require__(1414);\n\nvar origKeys = Object.keys;\nvar keysShim = origKeys ? function keys(o) { return origKeys(o); } : __webpack_require__(8987);\n\nvar originalKeys = Object.keys;\n\nkeysShim.shim = function shimObjectKeys() {\n\tif (Object.keys) {\n\t\tvar keysWorksWithArguments = (function () {\n\t\t\t// Safari 5.0 bug\n\t\t\tvar args = Object.keys(arguments);\n\t\t\treturn args && args.length === arguments.length;\n\t\t}(1, 2));\n\t\tif (!keysWorksWithArguments) {\n\t\t\tObject.keys = function keys(object) { // eslint-disable-line func-name-matching\n\t\t\t\tif (isArgs(object)) {\n\t\t\t\t\treturn originalKeys(slice.call(object));\n\t\t\t\t}\n\t\t\t\treturn originalKeys(object);\n\t\t\t};\n\t\t}\n\t} else {\n\t\tObject.keys = keysShim;\n\t}\n\treturn Object.keys || keysShim;\n};\n\nmodule.exports = keysShim;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMjIxNS5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9ub2RlX21vZHVsZXMvb2JqZWN0LWtleXMvaW5kZXguanM/ZDZjNyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbnZhciBzbGljZSA9IEFycmF5LnByb3RvdHlwZS5zbGljZTtcbnZhciBpc0FyZ3MgPSByZXF1aXJlKCcuL2lzQXJndW1lbnRzJyk7XG5cbnZhciBvcmlnS2V5cyA9IE9iamVjdC5rZXlzO1xudmFyIGtleXNTaGltID0gb3JpZ0tleXMgPyBmdW5jdGlvbiBrZXlzKG8pIHsgcmV0dXJuIG9yaWdLZXlzKG8pOyB9IDogcmVxdWlyZSgnLi9pbXBsZW1lbnRhdGlvbicpO1xuXG52YXIgb3JpZ2luYWxLZXlzID0gT2JqZWN0LmtleXM7XG5cbmtleXNTaGltLnNoaW0gPSBmdW5jdGlvbiBzaGltT2JqZWN0S2V5cygpIHtcblx0aWYgKE9iamVjdC5rZXlzKSB7XG5cdFx0dmFyIGtleXNXb3Jrc1dpdGhBcmd1bWVudHMgPSAoZnVuY3Rpb24gKCkge1xuXHRcdFx0Ly8gU2FmYXJpIDUuMCBidWdcblx0XHRcdHZhciBhcmdzID0gT2JqZWN0LmtleXMoYXJndW1lbnRzKTtcblx0XHRcdHJldHVybiBhcmdzICYmIGFyZ3MubGVuZ3RoID09PSBhcmd1bWVudHMubGVuZ3RoO1xuXHRcdH0oMSwgMikpO1xuXHRcdGlmICgha2V5c1dvcmtzV2l0aEFyZ3VtZW50cykge1xuXHRcdFx0T2JqZWN0LmtleXMgPSBmdW5jdGlvbiBrZXlzKG9iamVjdCkgeyAvLyBlc2xpbnQtZGlzYWJsZS1saW5lIGZ1bmMtbmFtZS1tYXRjaGluZ1xuXHRcdFx0XHRpZiAoaXNBcmdzKG9iamVjdCkpIHtcblx0XHRcdFx0XHRyZXR1cm4gb3JpZ2luYWxLZXlzKHNsaWNlLmNhbGwob2JqZWN0KSk7XG5cdFx0XHRcdH1cblx0XHRcdFx0cmV0dXJuIG9yaWdpbmFsS2V5cyhvYmplY3QpO1xuXHRcdFx0fTtcblx0XHR9XG5cdH0gZWxzZSB7XG5cdFx0T2JqZWN0LmtleXMgPSBrZXlzU2hpbTtcblx0fVxuXHRyZXR1cm4gT2JqZWN0LmtleXMgfHwga2V5c1NoaW07XG59O1xuXG5tb2R1bGUuZXhwb3J0cyA9IGtleXNTaGltO1xuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///2215\n")},1414:module=>{"use strict";eval("\n\nvar toStr = Object.prototype.toString;\n\nmodule.exports = function isArguments(value) {\n\tvar str = toStr.call(value);\n\tvar isArgs = str === '[object Arguments]';\n\tif (!isArgs) {\n\t\tisArgs = str !== '[object Array]' &&\n\t\t\tvalue !== null &&\n\t\t\ttypeof value === 'object' &&\n\t\t\ttypeof value.length === 'number' &&\n\t\t\tvalue.length >= 0 &&\n\t\t\ttoStr.call(value.callee) === '[object Function]';\n\t}\n\treturn isArgs;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTQxNC5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9ub2RlX21vZHVsZXMvb2JqZWN0LWtleXMvaXNBcmd1bWVudHMuanM/ZDRhYiJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbnZhciB0b1N0ciA9IE9iamVjdC5wcm90b3R5cGUudG9TdHJpbmc7XG5cbm1vZHVsZS5leHBvcnRzID0gZnVuY3Rpb24gaXNBcmd1bWVudHModmFsdWUpIHtcblx0dmFyIHN0ciA9IHRvU3RyLmNhbGwodmFsdWUpO1xuXHR2YXIgaXNBcmdzID0gc3RyID09PSAnW29iamVjdCBBcmd1bWVudHNdJztcblx0aWYgKCFpc0FyZ3MpIHtcblx0XHRpc0FyZ3MgPSBzdHIgIT09ICdbb2JqZWN0IEFycmF5XScgJiZcblx0XHRcdHZhbHVlICE9PSBudWxsICYmXG5cdFx0XHR0eXBlb2YgdmFsdWUgPT09ICdvYmplY3QnICYmXG5cdFx0XHR0eXBlb2YgdmFsdWUubGVuZ3RoID09PSAnbnVtYmVyJyAmJlxuXHRcdFx0dmFsdWUubGVuZ3RoID49IDAgJiZcblx0XHRcdHRvU3RyLmNhbGwodmFsdWUuY2FsbGVlKSA9PT0gJ1tvYmplY3QgRnVuY3Rpb25dJztcblx0fVxuXHRyZXR1cm4gaXNBcmdzO1xufTtcbiJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///1414\n")},2703:(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval("/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\n\nvar ReactPropTypesSecret = __webpack_require__(414);\n\nfunction emptyFunction() {}\nfunction emptyFunctionWithReset() {}\nemptyFunctionWithReset.resetWarningCache = emptyFunction;\n\nmodule.exports = function() {\n function shim(props, propName, componentName, location, propFullName, secret) {\n if (secret === ReactPropTypesSecret) {\n // It is still safe when called from React.\n return;\n }\n var err = new Error(\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use PropTypes.checkPropTypes() to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n err.name = 'Invariant Violation';\n throw err;\n };\n shim.isRequired = shim;\n function getShim() {\n return shim;\n };\n // Important!\n // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n var ReactPropTypes = {\n array: shim,\n bigint: shim,\n bool: shim,\n func: shim,\n number: shim,\n object: shim,\n string: shim,\n symbol: shim,\n\n any: shim,\n arrayOf: getShim,\n element: shim,\n elementType: shim,\n instanceOf: getShim,\n node: shim,\n objectOf: getShim,\n oneOf: getShim,\n oneOfType: getShim,\n shape: getShim,\n exact: getShim,\n\n checkPropTypes: emptyFunctionWithReset,\n resetWarningCache: emptyFunction\n };\n\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMjcwMy5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9ub2RlX21vZHVsZXMvcHJvcC10eXBlcy9mYWN0b3J5V2l0aFRocm93aW5nU2hpbXMuanM/ZDdhMCJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxMy1wcmVzZW50LCBGYWNlYm9vaywgSW5jLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICovXG5cbid1c2Ugc3RyaWN0JztcblxudmFyIFJlYWN0UHJvcFR5cGVzU2VjcmV0ID0gcmVxdWlyZSgnLi9saWIvUmVhY3RQcm9wVHlwZXNTZWNyZXQnKTtcblxuZnVuY3Rpb24gZW1wdHlGdW5jdGlvbigpIHt9XG5mdW5jdGlvbiBlbXB0eUZ1bmN0aW9uV2l0aFJlc2V0KCkge31cbmVtcHR5RnVuY3Rpb25XaXRoUmVzZXQucmVzZXRXYXJuaW5nQ2FjaGUgPSBlbXB0eUZ1bmN0aW9uO1xuXG5tb2R1bGUuZXhwb3J0cyA9IGZ1bmN0aW9uKCkge1xuICBmdW5jdGlvbiBzaGltKHByb3BzLCBwcm9wTmFtZSwgY29tcG9uZW50TmFtZSwgbG9jYXRpb24sIHByb3BGdWxsTmFtZSwgc2VjcmV0KSB7XG4gICAgaWYgKHNlY3JldCA9PT0gUmVhY3RQcm9wVHlwZXNTZWNyZXQpIHtcbiAgICAgIC8vIEl0IGlzIHN0aWxsIHNhZmUgd2hlbiBjYWxsZWQgZnJvbSBSZWFjdC5cbiAgICAgIHJldHVybjtcbiAgICB9XG4gICAgdmFyIGVyciA9IG5ldyBFcnJvcihcbiAgICAgICdDYWxsaW5nIFByb3BUeXBlcyB2YWxpZGF0b3JzIGRpcmVjdGx5IGlzIG5vdCBzdXBwb3J0ZWQgYnkgdGhlIGBwcm9wLXR5cGVzYCBwYWNrYWdlLiAnICtcbiAgICAgICdVc2UgUHJvcFR5cGVzLmNoZWNrUHJvcFR5cGVzKCkgdG8gY2FsbCB0aGVtLiAnICtcbiAgICAgICdSZWFkIG1vcmUgYXQgaHR0cDovL2ZiLm1lL3VzZS1jaGVjay1wcm9wLXR5cGVzJ1xuICAgICk7XG4gICAgZXJyLm5hbWUgPSAnSW52YXJpYW50IFZpb2xhdGlvbic7XG4gICAgdGhyb3cgZXJyO1xuICB9O1xuICBzaGltLmlzUmVxdWlyZWQgPSBzaGltO1xuICBmdW5jdGlvbiBnZXRTaGltKCkge1xuICAgIHJldHVybiBzaGltO1xuICB9O1xuICAvLyBJbXBvcnRhbnQhXG4gIC8vIEtlZXAgdGhpcyBsaXN0IGluIHN5bmMgd2l0aCBwcm9kdWN0aW9uIHZlcnNpb24gaW4gYC4vZmFjdG9yeVdpdGhUeXBlQ2hlY2tlcnMuanNgLlxuICB2YXIgUmVhY3RQcm9wVHlwZXMgPSB7XG4gICAgYXJyYXk6IHNoaW0sXG4gICAgYmlnaW50OiBzaGltLFxuICAgIGJvb2w6IHNoaW0sXG4gICAgZnVuYzogc2hpbSxcbiAgICBudW1iZXI6IHNoaW0sXG4gICAgb2JqZWN0OiBzaGltLFxuICAgIHN0cmluZzogc2hpbSxcbiAgICBzeW1ib2w6IHNoaW0sXG5cbiAgICBhbnk6IHNoaW0sXG4gICAgYXJyYXlPZjogZ2V0U2hpbSxcbiAgICBlbGVtZW50OiBzaGltLFxuICAgIGVsZW1lbnRUeXBlOiBzaGltLFxuICAgIGluc3RhbmNlT2Y6IGdldFNoaW0sXG4gICAgbm9kZTogc2hpbSxcbiAgICBvYmplY3RPZjogZ2V0U2hpbSxcbiAgICBvbmVPZjogZ2V0U2hpbSxcbiAgICBvbmVPZlR5cGU6IGdldFNoaW0sXG4gICAgc2hhcGU6IGdldFNoaW0sXG4gICAgZXhhY3Q6IGdldFNoaW0sXG5cbiAgICBjaGVja1Byb3BUeXBlczogZW1wdHlGdW5jdGlvbldpdGhSZXNldCxcbiAgICByZXNldFdhcm5pbmdDYWNoZTogZW1wdHlGdW5jdGlvblxuICB9O1xuXG4gIFJlYWN0UHJvcFR5cGVzLlByb3BUeXBlcyA9IFJlYWN0UHJvcFR5cGVzO1xuXG4gIHJldHVybiBSZWFjdFByb3BUeXBlcztcbn07XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///2703\n")},5697:(module,__unused_webpack_exports,__webpack_require__)=>{eval("/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nif (false) { var throwOnDirectAccess, ReactIs; } else {\n // By explicitly using `prop-types` you are opting into new production behavior.\n // http://fb.me/prop-types-in-prod\n module.exports = __webpack_require__(2703)();\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNTY5Ny5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBUUE7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9ibG9ja3N5T3B0aW9ucy8uL25vZGVfbW9kdWxlcy9wcm9wLXR5cGVzL2luZGV4LmpzP2Q3YmMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTMtcHJlc2VudCwgRmFjZWJvb2ssIEluYy5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqL1xuXG5pZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgIT09ICdwcm9kdWN0aW9uJykge1xuICB2YXIgUmVhY3RJcyA9IHJlcXVpcmUoJ3JlYWN0LWlzJyk7XG5cbiAgLy8gQnkgZXhwbGljaXRseSB1c2luZyBgcHJvcC10eXBlc2AgeW91IGFyZSBvcHRpbmcgaW50byBuZXcgZGV2ZWxvcG1lbnQgYmVoYXZpb3IuXG4gIC8vIGh0dHA6Ly9mYi5tZS9wcm9wLXR5cGVzLWluLXByb2RcbiAgdmFyIHRocm93T25EaXJlY3RBY2Nlc3MgPSB0cnVlO1xuICBtb2R1bGUuZXhwb3J0cyA9IHJlcXVpcmUoJy4vZmFjdG9yeVdpdGhUeXBlQ2hlY2tlcnMnKShSZWFjdElzLmlzRWxlbWVudCwgdGhyb3dPbkRpcmVjdEFjY2Vzcyk7XG59IGVsc2Uge1xuICAvLyBCeSBleHBsaWNpdGx5IHVzaW5nIGBwcm9wLXR5cGVzYCB5b3UgYXJlIG9wdGluZyBpbnRvIG5ldyBwcm9kdWN0aW9uIGJlaGF2aW9yLlxuICAvLyBodHRwOi8vZmIubWUvcHJvcC10eXBlcy1pbi1wcm9kXG4gIG1vZHVsZS5leHBvcnRzID0gcmVxdWlyZSgnLi9mYWN0b3J5V2l0aFRocm93aW5nU2hpbXMnKSgpO1xufVxuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///5697\n")},414:module=>{"use strict";eval("/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\n\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNDE0LmpzIiwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vbm9kZV9tb2R1bGVzL3Byb3AtdHlwZXMvbGliL1JlYWN0UHJvcFR5cGVzU2VjcmV0LmpzPzU5YjAiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTMtcHJlc2VudCwgRmFjZWJvb2ssIEluYy5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqL1xuXG4ndXNlIHN0cmljdCc7XG5cbnZhciBSZWFjdFByb3BUeXBlc1NlY3JldCA9ICdTRUNSRVRfRE9fTk9UX1BBU1NfVEhJU19PUl9ZT1VfV0lMTF9CRV9GSVJFRCc7XG5cbm1vZHVsZS5leHBvcnRzID0gUmVhY3RQcm9wVHlwZXNTZWNyZXQ7XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///414\n")},6362:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n "JN": () => (/* binding */ sortableContainer),\n "W8": () => (/* binding */ sortableElement),\n "W6": () => (/* binding */ sortableHandle)\n});\n\n// UNUSED EXPORTS: arrayMove, sortableContainer, sortableElement, sortableHandle\n\n// EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/esm/extends.js\nvar esm_extends = __webpack_require__(7462);\n;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/arrayWithHoles.js\nfunction _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}\n;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/iterableToArrayLimit.js\nfunction _iterableToArrayLimit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];\n\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n\n var _s, _e;\n\n try {\n for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i["return"] != null) _i["return"]();\n } finally {\n if (_d) throw _e;\n }\n }\n\n return _arr;\n}\n;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js\nfunction _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n\n for (var i = 0, arr2 = new Array(len); i < len; i++) {\n arr2[i] = arr[i];\n }\n\n return arr2;\n}\n;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js\n\nfunction _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === "string") return _arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === "Object" && o.constructor) n = o.constructor.name;\n if (n === "Map" || n === "Set") return Array.from(o);\n if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);\n}\n;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/nonIterableRest.js\nfunction _nonIterableRest() {\n throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");\n}\n;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/slicedToArray.js\n\n\n\n\nfunction _slicedToArray(arr, i) {\n return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest();\n}\n;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/defineProperty.js\nfunction _defineProperty(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;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/objectSpread.js\n\nfunction _objectSpread(target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i] != null ? Object(arguments[i]) : {};\n var ownKeys = Object.keys(source);\n\n if (typeof Object.getOwnPropertySymbols === \'function\') {\n ownKeys.push.apply(ownKeys, Object.getOwnPropertySymbols(source).filter(function (sym) {\n return Object.getOwnPropertyDescriptor(source, sym).enumerable;\n }));\n }\n\n ownKeys.forEach(function (key) {\n _defineProperty(target, key, source[key]);\n });\n }\n\n return target;\n}\n;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/classCallCheck.js\nfunction _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError("Cannot call a class as a function");\n }\n}\n;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/createClass.js\nfunction _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if ("value" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\n\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, "prototype", {\n writable: false\n });\n return Constructor;\n}\n;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/typeof.js\nfunction _typeof(obj) {\n "@babel/helpers - typeof";\n\n return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) {\n return typeof obj;\n } : function (obj) {\n return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;\n }, _typeof(obj);\n}\n// EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js\nvar assertThisInitialized = __webpack_require__(7326);\n;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/possibleConstructorReturn.js\n\n\nfunction _possibleConstructorReturn(self, call) {\n if (call && (_typeof(call) === "object" || typeof call === "function")) {\n return call;\n } else if (call !== void 0) {\n throw new TypeError("Derived constructors may only return object or undefined");\n }\n\n return (0,assertThisInitialized/* default */.Z)(self);\n}\n;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/getPrototypeOf.js\nfunction _getPrototypeOf(o) {\n _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n };\n return _getPrototypeOf(o);\n}\n// EXTERNAL MODULE: ./node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js\nvar setPrototypeOf = __webpack_require__(9611);\n;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/inherits.js\n\nfunction _inherits(subClass, superClass) {\n if (typeof superClass !== "function" && superClass !== null) {\n throw new TypeError("Super expression must either be null or a function");\n }\n\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n Object.defineProperty(subClass, "prototype", {\n writable: false\n });\n if (superClass) (0,setPrototypeOf/* default */.Z)(subClass, superClass);\n}\n// EXTERNAL MODULE: external "React"\nvar external_React_ = __webpack_require__(7363);\n// EXTERNAL MODULE: ./node_modules/prop-types/index.js\nvar prop_types = __webpack_require__(5697);\nvar prop_types_default = /*#__PURE__*/__webpack_require__.n(prop_types);\n// EXTERNAL MODULE: external "ReactDOM"\nvar external_ReactDOM_ = __webpack_require__(1533);\n// EXTERNAL MODULE: ./node_modules/invariant/browser.js\nvar browser = __webpack_require__(1143);\nvar browser_default = /*#__PURE__*/__webpack_require__.n(browser);\n;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js\n\nfunction _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) return _arrayLikeToArray(arr);\n}\n;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/iterableToArray.js\nfunction _iterableToArray(iter) {\n if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);\n}\n;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js\nfunction _nonIterableSpread() {\n throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");\n}\n;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js\n\n\n\n\nfunction _toConsumableArray(arr) {\n return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread();\n}\n;// CONCATENATED MODULE: ./node_modules/react-sortable-hoc/dist/react-sortable-hoc.esm.js\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nvar Manager = function () {\n function Manager() {\n _classCallCheck(this, Manager);\n\n _defineProperty(this, "refs", {});\n }\n\n _createClass(Manager, [{\n key: "add",\n value: function add(collection, ref) {\n if (!this.refs[collection]) {\n this.refs[collection] = [];\n }\n\n this.refs[collection].push(ref);\n }\n }, {\n key: "remove",\n value: function remove(collection, ref) {\n var index = this.getIndex(collection, ref);\n\n if (index !== -1) {\n this.refs[collection].splice(index, 1);\n }\n }\n }, {\n key: "isActive",\n value: function isActive() {\n return this.active;\n }\n }, {\n key: "getActive",\n value: function getActive() {\n var _this = this;\n\n return this.refs[this.active.collection].find(function (_ref) {\n var node = _ref.node;\n return node.sortableInfo.index == _this.active.index;\n });\n }\n }, {\n key: "getIndex",\n value: function getIndex(collection, ref) {\n return this.refs[collection].indexOf(ref);\n }\n }, {\n key: "getOrderedRefs",\n value: function getOrderedRefs() {\n var collection = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.active.collection;\n return this.refs[collection].sort(sortByIndex);\n }\n }]);\n\n return Manager;\n}();\n\nfunction sortByIndex(_ref2, _ref3) {\n var index1 = _ref2.node.sortableInfo.index;\n var index2 = _ref3.node.sortableInfo.index;\n return index1 - index2;\n}\n\nfunction arrayMove(array, from, to) {\n if (false) {}\n\n array = array.slice();\n array.splice(to < 0 ? array.length + to : to, 0, array.splice(from, 1)[0]);\n return array;\n}\nfunction omit(obj, keysToOmit) {\n return Object.keys(obj).reduce(function (acc, key) {\n if (keysToOmit.indexOf(key) === -1) {\n acc[key] = obj[key];\n }\n\n return acc;\n }, {});\n}\nvar events = {\n end: [\'touchend\', \'touchcancel\', \'mouseup\'],\n move: [\'touchmove\', \'mousemove\'],\n start: [\'touchstart\', \'mousedown\']\n};\nvar vendorPrefix = function () {\n if (typeof window === \'undefined\' || typeof document === \'undefined\') {\n return \'\';\n }\n\n var styles = window.getComputedStyle(document.documentElement, \'\') || [\'-moz-hidden-iframe\'];\n var pre = (Array.prototype.slice.call(styles).join(\'\').match(/-(moz|webkit|ms)-/) || styles.OLink === \'\' && [\'\', \'o\'])[1];\n\n switch (pre) {\n case \'ms\':\n return \'ms\';\n\n default:\n return pre && pre.length ? pre[0].toUpperCase() + pre.substr(1) : \'\';\n }\n}();\nfunction setInlineStyles(node, styles) {\n Object.keys(styles).forEach(function (key) {\n node.style[key] = styles[key];\n });\n}\nfunction setTranslate3d(node, translate) {\n node.style["".concat(vendorPrefix, "Transform")] = translate == null ? \'\' : "translate3d(".concat(translate.x, "px,").concat(translate.y, "px,0)");\n}\nfunction setTransitionDuration(node, duration) {\n node.style["".concat(vendorPrefix, "TransitionDuration")] = duration == null ? \'\' : "".concat(duration, "ms");\n}\nfunction closest(el, fn) {\n while (el) {\n if (fn(el)) {\n return el;\n }\n\n el = el.parentNode;\n }\n\n return null;\n}\nfunction limit(min, max, value) {\n return Math.max(min, Math.min(value, max));\n}\n\nfunction getPixelValue(stringValue) {\n if (stringValue.substr(-2) === \'px\') {\n return parseFloat(stringValue);\n }\n\n return 0;\n}\n\nfunction getElementMargin(element) {\n var style = window.getComputedStyle(element);\n return {\n bottom: getPixelValue(style.marginBottom),\n left: getPixelValue(style.marginLeft),\n right: getPixelValue(style.marginRight),\n top: getPixelValue(style.marginTop)\n };\n}\nfunction provideDisplayName(prefix, Component$$1) {\n var componentName = Component$$1.displayName || Component$$1.name;\n return componentName ? "".concat(prefix, "(").concat(componentName, ")") : prefix;\n}\nfunction getScrollAdjustedBoundingClientRect(node, scrollDelta) {\n var boundingClientRect = node.getBoundingClientRect();\n return {\n top: boundingClientRect.top + scrollDelta.top,\n left: boundingClientRect.left + scrollDelta.left\n };\n}\nfunction getPosition(event) {\n if (event.touches && event.touches.length) {\n return {\n x: event.touches[0].pageX,\n y: event.touches[0].pageY\n };\n } else if (event.changedTouches && event.changedTouches.length) {\n return {\n x: event.changedTouches[0].pageX,\n y: event.changedTouches[0].pageY\n };\n } else {\n return {\n x: event.pageX,\n y: event.pageY\n };\n }\n}\nfunction isTouchEvent(event) {\n return event.touches && event.touches.length || event.changedTouches && event.changedTouches.length;\n}\nfunction getEdgeOffset(node, parent) {\n var offset = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {\n left: 0,\n top: 0\n };\n\n if (!node) {\n return undefined;\n }\n\n var nodeOffset = {\n left: offset.left + node.offsetLeft,\n top: offset.top + node.offsetTop\n };\n\n if (node.parentNode === parent) {\n return nodeOffset;\n }\n\n return getEdgeOffset(node.parentNode, parent, nodeOffset);\n}\nfunction getTargetIndex(newIndex, prevIndex, oldIndex) {\n if (newIndex < oldIndex && newIndex > prevIndex) {\n return newIndex - 1;\n } else if (newIndex > oldIndex && newIndex < prevIndex) {\n return newIndex + 1;\n } else {\n return newIndex;\n }\n}\nfunction getLockPixelOffset(_ref) {\n var lockOffset = _ref.lockOffset,\n width = _ref.width,\n height = _ref.height;\n var offsetX = lockOffset;\n var offsetY = lockOffset;\n var unit = \'px\';\n\n if (typeof lockOffset === \'string\') {\n var match = /^[+-]?\\d*(?:\\.\\d*)?(px|%)$/.exec(lockOffset);\n browser_default()(match !== null, \'lockOffset value should be a number or a string of a \' + \'number followed by "px" or "%". Given %s\', lockOffset);\n offsetX = parseFloat(lockOffset);\n offsetY = parseFloat(lockOffset);\n unit = match[1];\n }\n\n browser_default()(isFinite(offsetX) && isFinite(offsetY), \'lockOffset value should be a finite. Given %s\', lockOffset);\n\n if (unit === \'%\') {\n offsetX = offsetX * width / 100;\n offsetY = offsetY * height / 100;\n }\n\n return {\n x: offsetX,\n y: offsetY\n };\n}\nfunction getLockPixelOffsets(_ref2) {\n var height = _ref2.height,\n width = _ref2.width,\n lockOffset = _ref2.lockOffset;\n var offsets = Array.isArray(lockOffset) ? lockOffset : [lockOffset, lockOffset];\n browser_default()(offsets.length === 2, \'lockOffset prop of SortableContainer should be a single \' + \'value or an array of exactly two values. Given %s\', lockOffset);\n\n var _offsets = _slicedToArray(offsets, 2),\n minLockOffset = _offsets[0],\n maxLockOffset = _offsets[1];\n\n return [getLockPixelOffset({\n height: height,\n lockOffset: minLockOffset,\n width: width\n }), getLockPixelOffset({\n height: height,\n lockOffset: maxLockOffset,\n width: width\n })];\n}\n\nfunction isScrollable(el) {\n var computedStyle = window.getComputedStyle(el);\n var overflowRegex = /(auto|scroll)/;\n var properties = [\'overflow\', \'overflowX\', \'overflowY\'];\n return properties.find(function (property) {\n return overflowRegex.test(computedStyle[property]);\n });\n}\n\nfunction getScrollingParent(el) {\n if (!(el instanceof HTMLElement)) {\n return null;\n } else if (isScrollable(el)) {\n return el;\n } else {\n return getScrollingParent(el.parentNode);\n }\n}\nfunction getContainerGridGap(element) {\n var style = window.getComputedStyle(element);\n\n if (style.display === \'grid\') {\n return {\n x: getPixelValue(style.gridColumnGap),\n y: getPixelValue(style.gridRowGap)\n };\n }\n\n return {\n x: 0,\n y: 0\n };\n}\nvar KEYCODE = {\n TAB: 9,\n ESC: 27,\n SPACE: 32,\n LEFT: 37,\n UP: 38,\n RIGHT: 39,\n DOWN: 40\n};\nvar NodeType = {\n Anchor: \'A\',\n Button: \'BUTTON\',\n Canvas: \'CANVAS\',\n Input: \'INPUT\',\n Option: \'OPTION\',\n Textarea: \'TEXTAREA\',\n Select: \'SELECT\'\n};\nfunction cloneNode(node) {\n var selector = \'input, textarea, select, canvas, [contenteditable]\';\n var fields = node.querySelectorAll(selector);\n var clonedNode = node.cloneNode(true);\n\n var clonedFields = _toConsumableArray(clonedNode.querySelectorAll(selector));\n\n clonedFields.forEach(function (field, i) {\n if (field.type !== \'file\') {\n field.value = fields[i].value;\n }\n\n if (field.type === \'radio\' && field.name) {\n field.name = "__sortableClone__".concat(field.name);\n }\n\n if (field.tagName === NodeType.Canvas && fields[i].width > 0 && fields[i].height > 0) {\n var destCtx = field.getContext(\'2d\');\n destCtx.drawImage(fields[i], 0, 0);\n }\n });\n return clonedNode;\n}\n\nfunction sortableHandle(WrappedComponent) {\n var _class, _temp;\n\n var config = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n withRef: false\n };\n return _temp = _class = function (_React$Component) {\n _inherits(WithSortableHandle, _React$Component);\n\n function WithSortableHandle() {\n _classCallCheck(this, WithSortableHandle);\n\n return _possibleConstructorReturn(this, _getPrototypeOf(WithSortableHandle).apply(this, arguments));\n }\n\n _createClass(WithSortableHandle, [{\n key: "componentDidMount",\n value: function componentDidMount() {\n var node = (0,external_ReactDOM_.findDOMNode)(this);\n node.sortableHandle = true;\n }\n }, {\n key: "getWrappedInstance",\n value: function getWrappedInstance() {\n browser_default()(config.withRef, \'To access the wrapped instance, you need to pass in {withRef: true} as the second argument of the SortableHandle() call\');\n return this.refs.wrappedInstance;\n }\n }, {\n key: "render",\n value: function render() {\n var ref = config.withRef ? \'wrappedInstance\' : null;\n return (0,external_React_.createElement)(WrappedComponent, (0,esm_extends["default"])({\n ref: ref\n }, this.props));\n }\n }]);\n\n return WithSortableHandle;\n }(external_React_.Component), _defineProperty(_class, "displayName", provideDisplayName(\'sortableHandle\', WrappedComponent)), _temp;\n}\nfunction isSortableHandle(node) {\n return node.sortableHandle != null;\n}\n\nvar AutoScroller = function () {\n function AutoScroller(container, onScrollCallback) {\n _classCallCheck(this, AutoScroller);\n\n this.container = container;\n this.onScrollCallback = onScrollCallback;\n }\n\n _createClass(AutoScroller, [{\n key: "clear",\n value: function clear() {\n if (this.interval == null) {\n return;\n }\n\n clearInterval(this.interval);\n this.interval = null;\n }\n }, {\n key: "update",\n value: function update(_ref) {\n var _this = this;\n\n var translate = _ref.translate,\n minTranslate = _ref.minTranslate,\n maxTranslate = _ref.maxTranslate,\n width = _ref.width,\n height = _ref.height;\n var direction = {\n x: 0,\n y: 0\n };\n var speed = {\n x: 1,\n y: 1\n };\n var acceleration = {\n x: 10,\n y: 10\n };\n var _this$container = this.container,\n scrollTop = _this$container.scrollTop,\n scrollLeft = _this$container.scrollLeft,\n scrollHeight = _this$container.scrollHeight,\n scrollWidth = _this$container.scrollWidth,\n clientHeight = _this$container.clientHeight,\n clientWidth = _this$container.clientWidth;\n var isTop = scrollTop === 0;\n var isBottom = scrollHeight - scrollTop - clientHeight === 0;\n var isLeft = scrollLeft === 0;\n var isRight = scrollWidth - scrollLeft - clientWidth === 0;\n\n if (translate.y >= maxTranslate.y - height / 2 && !isBottom) {\n direction.y = 1;\n speed.y = acceleration.y * Math.abs((maxTranslate.y - height / 2 - translate.y) / height);\n } else if (translate.x >= maxTranslate.x - width / 2 && !isRight) {\n direction.x = 1;\n speed.x = acceleration.x * Math.abs((maxTranslate.x - width / 2 - translate.x) / width);\n } else if (translate.y <= minTranslate.y + height / 2 && !isTop) {\n direction.y = -1;\n speed.y = acceleration.y * Math.abs((translate.y - height / 2 - minTranslate.y) / height);\n } else if (translate.x <= minTranslate.x + width / 2 && !isLeft) {\n direction.x = -1;\n speed.x = acceleration.x * Math.abs((translate.x - width / 2 - minTranslate.x) / width);\n }\n\n if (this.interval) {\n this.clear();\n this.isAutoScrolling = false;\n }\n\n if (direction.x !== 0 || direction.y !== 0) {\n this.interval = setInterval(function () {\n _this.isAutoScrolling = true;\n var offset = {\n left: speed.x * direction.x,\n top: speed.y * direction.y\n };\n _this.container.scrollTop += offset.top;\n _this.container.scrollLeft += offset.left;\n\n _this.onScrollCallback(offset);\n }, 5);\n }\n }\n }]);\n\n return AutoScroller;\n}();\n\nfunction defaultGetHelperDimensions(_ref) {\n var node = _ref.node;\n return {\n height: node.offsetHeight,\n width: node.offsetWidth\n };\n}\n\nfunction defaultShouldCancelStart(event) {\n var interactiveElements = [NodeType.Input, NodeType.Textarea, NodeType.Select, NodeType.Option, NodeType.Button];\n\n if (interactiveElements.indexOf(event.target.tagName) !== -1) {\n return true;\n }\n\n if (closest(event.target, function (el) {\n return el.contentEditable === \'true\';\n })) {\n return true;\n }\n\n return false;\n}\n\nvar propTypes = {\n axis: prop_types_default().oneOf([\'x\', \'y\', \'xy\']),\n contentWindow: (prop_types_default()).any,\n disableAutoscroll: (prop_types_default()).bool,\n distance: (prop_types_default()).number,\n getContainer: (prop_types_default()).func,\n getHelperDimensions: (prop_types_default()).func,\n helperClass: (prop_types_default()).string,\n helperContainer: prop_types_default().oneOfType([(prop_types_default()).func, typeof HTMLElement === \'undefined\' ? (prop_types_default()).any : prop_types_default().instanceOf(HTMLElement)]),\n hideSortableGhost: (prop_types_default()).bool,\n keyboardSortingTransitionDuration: (prop_types_default()).number,\n lockAxis: (prop_types_default()).string,\n lockOffset: prop_types_default().oneOfType([(prop_types_default()).number, (prop_types_default()).string, prop_types_default().arrayOf(prop_types_default().oneOfType([(prop_types_default()).number, (prop_types_default()).string]))]),\n lockToContainerEdges: (prop_types_default()).bool,\n onSortEnd: (prop_types_default()).func,\n onSortMove: (prop_types_default()).func,\n onSortOver: (prop_types_default()).func,\n onSortStart: (prop_types_default()).func,\n pressDelay: (prop_types_default()).number,\n pressThreshold: (prop_types_default()).number,\n keyCodes: prop_types_default().shape({\n lift: prop_types_default().arrayOf((prop_types_default()).number),\n drop: prop_types_default().arrayOf((prop_types_default()).number),\n cancel: prop_types_default().arrayOf((prop_types_default()).number),\n up: prop_types_default().arrayOf((prop_types_default()).number),\n down: prop_types_default().arrayOf((prop_types_default()).number)\n }),\n shouldCancelStart: (prop_types_default()).func,\n transitionDuration: (prop_types_default()).number,\n updateBeforeSortStart: (prop_types_default()).func,\n useDragHandle: (prop_types_default()).bool,\n useWindowAsScrollContainer: (prop_types_default()).bool\n};\nvar defaultKeyCodes = {\n lift: [KEYCODE.SPACE],\n drop: [KEYCODE.SPACE],\n cancel: [KEYCODE.ESC],\n up: [KEYCODE.UP, KEYCODE.LEFT],\n down: [KEYCODE.DOWN, KEYCODE.RIGHT]\n};\nvar defaultProps = {\n axis: \'y\',\n disableAutoscroll: false,\n distance: 0,\n getHelperDimensions: defaultGetHelperDimensions,\n hideSortableGhost: true,\n lockOffset: \'50%\',\n lockToContainerEdges: false,\n pressDelay: 0,\n pressThreshold: 5,\n keyCodes: defaultKeyCodes,\n shouldCancelStart: defaultShouldCancelStart,\n transitionDuration: 300,\n useWindowAsScrollContainer: false\n};\nvar omittedProps = Object.keys(propTypes);\nfunction validateProps(props) {\n browser_default()(!(props.distance && props.pressDelay), \'Attempted to set both `pressDelay` and `distance` on SortableContainer, you may only use one or the other, not both at the same time.\');\n}\n\nfunction _finallyRethrows(body, finalizer) {\n try {\n var result = body();\n } catch (e) {\n return finalizer(true, e);\n }\n\n if (result && result.then) {\n return result.then(finalizer.bind(null, false), finalizer.bind(null, true));\n }\n\n return finalizer(false, value);\n}\nfunction sortableContainer(WrappedComponent) {\n var _class, _temp;\n\n var config = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n withRef: false\n };\n return _temp = _class = function (_React$Component) {\n _inherits(WithSortableContainer, _React$Component);\n\n function WithSortableContainer(props) {\n var _this;\n\n _classCallCheck(this, WithSortableContainer);\n\n _this = _possibleConstructorReturn(this, _getPrototypeOf(WithSortableContainer).call(this, props));\n\n _defineProperty((0,assertThisInitialized/* default */.Z)((0,assertThisInitialized/* default */.Z)(_this)), "state", {});\n\n _defineProperty((0,assertThisInitialized/* default */.Z)((0,assertThisInitialized/* default */.Z)(_this)), "handleStart", function (event) {\n var _this$props = _this.props,\n distance = _this$props.distance,\n shouldCancelStart = _this$props.shouldCancelStart;\n\n if (event.button === 2 || shouldCancelStart(event)) {\n return;\n }\n\n _this.touched = true;\n _this.position = getPosition(event);\n var node = closest(event.target, function (el) {\n return el.sortableInfo != null;\n });\n\n if (node && node.sortableInfo && _this.nodeIsChild(node) && !_this.state.sorting) {\n var useDragHandle = _this.props.useDragHandle;\n var _node$sortableInfo = node.sortableInfo,\n index = _node$sortableInfo.index,\n collection = _node$sortableInfo.collection,\n disabled = _node$sortableInfo.disabled;\n\n if (disabled) {\n return;\n }\n\n if (useDragHandle && !closest(event.target, isSortableHandle)) {\n return;\n }\n\n _this.manager.active = {\n collection: collection,\n index: index\n };\n\n if (!isTouchEvent(event) && event.target.tagName === NodeType.Anchor) {\n event.preventDefault();\n }\n\n if (!distance) {\n if (_this.props.pressDelay === 0) {\n _this.handlePress(event);\n } else {\n _this.pressTimer = setTimeout(function () {\n return _this.handlePress(event);\n }, _this.props.pressDelay);\n }\n }\n }\n });\n\n _defineProperty((0,assertThisInitialized/* default */.Z)((0,assertThisInitialized/* default */.Z)(_this)), "nodeIsChild", function (node) {\n return node.sortableInfo.manager === _this.manager;\n });\n\n _defineProperty((0,assertThisInitialized/* default */.Z)((0,assertThisInitialized/* default */.Z)(_this)), "handleMove", function (event) {\n var _this$props2 = _this.props,\n distance = _this$props2.distance,\n pressThreshold = _this$props2.pressThreshold;\n\n if (!_this.state.sorting && _this.touched && !_this._awaitingUpdateBeforeSortStart) {\n var position = getPosition(event);\n var delta = {\n x: _this.position.x - position.x,\n y: _this.position.y - position.y\n };\n var combinedDelta = Math.abs(delta.x) + Math.abs(delta.y);\n _this.delta = delta;\n\n if (!distance && (!pressThreshold || combinedDelta >= pressThreshold)) {\n clearTimeout(_this.cancelTimer);\n _this.cancelTimer = setTimeout(_this.cancel, 0);\n } else if (distance && combinedDelta >= distance && _this.manager.isActive()) {\n _this.handlePress(event);\n }\n }\n });\n\n _defineProperty((0,assertThisInitialized/* default */.Z)((0,assertThisInitialized/* default */.Z)(_this)), "handleEnd", function () {\n _this.touched = false;\n\n _this.cancel();\n });\n\n _defineProperty((0,assertThisInitialized/* default */.Z)((0,assertThisInitialized/* default */.Z)(_this)), "cancel", function () {\n var distance = _this.props.distance;\n var sorting = _this.state.sorting;\n\n if (!sorting) {\n if (!distance) {\n clearTimeout(_this.pressTimer);\n }\n\n _this.manager.active = null;\n }\n });\n\n _defineProperty((0,assertThisInitialized/* default */.Z)((0,assertThisInitialized/* default */.Z)(_this)), "handlePress", function (event) {\n try {\n var active = _this.manager.getActive();\n\n var _temp6 = function () {\n if (active) {\n var _temp7 = function _temp7() {\n var index = _node.sortableInfo.index;\n var margin = getElementMargin(_node);\n var gridGap = getContainerGridGap(_this.container);\n\n var containerBoundingRect = _this.scrollContainer.getBoundingClientRect();\n\n var dimensions = _getHelperDimensions({\n index: index,\n node: _node,\n collection: _collection\n });\n\n _this.node = _node;\n _this.margin = margin;\n _this.gridGap = gridGap;\n _this.width = dimensions.width;\n _this.height = dimensions.height;\n _this.marginOffset = {\n x: _this.margin.left + _this.margin.right + _this.gridGap.x,\n y: Math.max(_this.margin.top, _this.margin.bottom, _this.gridGap.y)\n };\n _this.boundingClientRect = _node.getBoundingClientRect();\n _this.containerBoundingRect = containerBoundingRect;\n _this.index = index;\n _this.newIndex = index;\n _this.axis = {\n x: _axis.indexOf(\'x\') >= 0,\n y: _axis.indexOf(\'y\') >= 0\n };\n _this.offsetEdge = getEdgeOffset(_node, _this.container);\n\n if (_isKeySorting) {\n _this.initialOffset = getPosition(_objectSpread({}, event, {\n pageX: _this.boundingClientRect.left,\n pageY: _this.boundingClientRect.top\n }));\n } else {\n _this.initialOffset = getPosition(event);\n }\n\n _this.initialScroll = {\n left: _this.scrollContainer.scrollLeft,\n top: _this.scrollContainer.scrollTop\n };\n _this.initialWindowScroll = {\n left: window.pageXOffset,\n top: window.pageYOffset\n };\n _this.helper = _this.helperContainer.appendChild(cloneNode(_node));\n setInlineStyles(_this.helper, {\n boxSizing: \'border-box\',\n height: "".concat(_this.height, "px"),\n left: "".concat(_this.boundingClientRect.left - margin.left, "px"),\n pointerEvents: \'none\',\n position: \'fixed\',\n top: "".concat(_this.boundingClientRect.top - margin.top, "px"),\n width: "".concat(_this.width, "px")\n });\n\n if (_isKeySorting) {\n _this.helper.focus();\n }\n\n if (_hideSortableGhost) {\n _this.sortableGhost = _node;\n setInlineStyles(_node, {\n opacity: 0,\n visibility: \'hidden\'\n });\n }\n\n _this.minTranslate = {};\n _this.maxTranslate = {};\n\n if (_isKeySorting) {\n var _ref = _useWindowAsScrollContainer ? {\n top: 0,\n left: 0,\n width: _this.contentWindow.innerWidth,\n height: _this.contentWindow.innerHeight\n } : _this.containerBoundingRect,\n containerTop = _ref.top,\n containerLeft = _ref.left,\n containerWidth = _ref.width,\n containerHeight = _ref.height;\n\n var containerBottom = containerTop + containerHeight;\n var containerRight = containerLeft + containerWidth;\n\n if (_this.axis.x) {\n _this.minTranslate.x = containerLeft - _this.boundingClientRect.left;\n _this.maxTranslate.x = containerRight - (_this.boundingClientRect.left + _this.width);\n }\n\n if (_this.axis.y) {\n _this.minTranslate.y = containerTop - _this.boundingClientRect.top;\n _this.maxTranslate.y = containerBottom - (_this.boundingClientRect.top + _this.height);\n }\n } else {\n if (_this.axis.x) {\n _this.minTranslate.x = (_useWindowAsScrollContainer ? 0 : containerBoundingRect.left) - _this.boundingClientRect.left - _this.width / 2;\n _this.maxTranslate.x = (_useWindowAsScrollContainer ? _this.contentWindow.innerWidth : containerBoundingRect.left + containerBoundingRect.width) - _this.boundingClientRect.left - _this.width / 2;\n }\n\n if (_this.axis.y) {\n _this.minTranslate.y = (_useWindowAsScrollContainer ? 0 : containerBoundingRect.top) - _this.boundingClientRect.top - _this.height / 2;\n _this.maxTranslate.y = (_useWindowAsScrollContainer ? _this.contentWindow.innerHeight : containerBoundingRect.top + containerBoundingRect.height) - _this.boundingClientRect.top - _this.height / 2;\n }\n }\n\n if (_helperClass) {\n _helperClass.split(\' \').forEach(function (className) {\n return _this.helper.classList.add(className);\n });\n }\n\n _this.listenerNode = event.touches ? _node : _this.contentWindow;\n\n if (_isKeySorting) {\n _this.listenerNode.addEventListener(\'wheel\', _this.handleKeyEnd, true);\n\n _this.listenerNode.addEventListener(\'mousedown\', _this.handleKeyEnd, true);\n\n _this.listenerNode.addEventListener(\'keydown\', _this.handleKeyDown);\n } else {\n events.move.forEach(function (eventName) {\n return _this.listenerNode.addEventListener(eventName, _this.handleSortMove, false);\n });\n events.end.forEach(function (eventName) {\n return _this.listenerNode.addEventListener(eventName, _this.handleSortEnd, false);\n });\n }\n\n _this.setState({\n sorting: true,\n sortingIndex: index\n });\n\n if (_onSortStart) {\n _onSortStart({\n node: _node,\n index: index,\n collection: _collection,\n isKeySorting: _isKeySorting,\n nodes: _this.manager.getOrderedRefs(),\n helper: _this.helper\n }, event);\n }\n\n if (_isKeySorting) {\n _this.keyMove(0);\n }\n };\n\n var _this$props3 = _this.props,\n _axis = _this$props3.axis,\n _getHelperDimensions = _this$props3.getHelperDimensions,\n _helperClass = _this$props3.helperClass,\n _hideSortableGhost = _this$props3.hideSortableGhost,\n updateBeforeSortStart = _this$props3.updateBeforeSortStart,\n _onSortStart = _this$props3.onSortStart,\n _useWindowAsScrollContainer = _this$props3.useWindowAsScrollContainer;\n var _node = active.node,\n _collection = active.collection;\n var _isKeySorting = _this.manager.isKeySorting;\n\n var _temp8 = function () {\n if (typeof updateBeforeSortStart === \'function\') {\n _this._awaitingUpdateBeforeSortStart = true;\n\n var _temp9 = _finallyRethrows(function () {\n var index = _node.sortableInfo.index;\n return Promise.resolve(updateBeforeSortStart({\n collection: _collection,\n index: index,\n node: _node,\n isKeySorting: _isKeySorting\n }, event)).then(function () {});\n }, function (_wasThrown, _result) {\n _this._awaitingUpdateBeforeSortStart = false;\n if (_wasThrown) throw _result;\n return _result;\n });\n\n if (_temp9 && _temp9.then) return _temp9.then(function () {});\n }\n }();\n\n return _temp8 && _temp8.then ? _temp8.then(_temp7) : _temp7(_temp8);\n }\n }();\n\n return Promise.resolve(_temp6 && _temp6.then ? _temp6.then(function () {}) : void 0);\n } catch (e) {\n return Promise.reject(e);\n }\n });\n\n _defineProperty((0,assertThisInitialized/* default */.Z)((0,assertThisInitialized/* default */.Z)(_this)), "handleSortMove", function (event) {\n var onSortMove = _this.props.onSortMove;\n\n if (typeof event.preventDefault === \'function\') {\n event.preventDefault();\n }\n\n _this.updateHelperPosition(event);\n\n _this.animateNodes();\n\n _this.autoscroll();\n\n if (onSortMove) {\n onSortMove(event);\n }\n });\n\n _defineProperty((0,assertThisInitialized/* default */.Z)((0,assertThisInitialized/* default */.Z)(_this)), "handleSortEnd", function (event) {\n var _this$props4 = _this.props,\n hideSortableGhost = _this$props4.hideSortableGhost,\n onSortEnd = _this$props4.onSortEnd;\n var _this$manager = _this.manager,\n collection = _this$manager.active.collection,\n isKeySorting = _this$manager.isKeySorting;\n\n var nodes = _this.manager.getOrderedRefs();\n\n if (_this.listenerNode) {\n if (isKeySorting) {\n _this.listenerNode.removeEventListener(\'wheel\', _this.handleKeyEnd, true);\n\n _this.listenerNode.removeEventListener(\'mousedown\', _this.handleKeyEnd, true);\n\n _this.listenerNode.removeEventListener(\'keydown\', _this.handleKeyDown);\n } else {\n events.move.forEach(function (eventName) {\n return _this.listenerNode.removeEventListener(eventName, _this.handleSortMove);\n });\n events.end.forEach(function (eventName) {\n return _this.listenerNode.removeEventListener(eventName, _this.handleSortEnd);\n });\n }\n }\n\n _this.helper.parentNode.removeChild(_this.helper);\n\n if (hideSortableGhost && _this.sortableGhost) {\n setInlineStyles(_this.sortableGhost, {\n opacity: \'\',\n visibility: \'\'\n });\n }\n\n for (var i = 0, len = nodes.length; i < len; i++) {\n var _node2 = nodes[i];\n var el = _node2.node;\n _node2.edgeOffset = null;\n _node2.boundingClientRect = null;\n setTranslate3d(el, null);\n setTransitionDuration(el, null);\n _node2.translate = null;\n }\n\n _this.autoScroller.clear();\n\n _this.manager.active = null;\n _this.manager.isKeySorting = false;\n\n _this.setState({\n sorting: false,\n sortingIndex: null\n });\n\n if (typeof onSortEnd === \'function\') {\n onSortEnd({\n collection: collection,\n newIndex: _this.newIndex,\n oldIndex: _this.index,\n isKeySorting: isKeySorting,\n nodes: nodes\n }, event);\n }\n\n _this.touched = false;\n });\n\n _defineProperty((0,assertThisInitialized/* default */.Z)((0,assertThisInitialized/* default */.Z)(_this)), "autoscroll", function () {\n var disableAutoscroll = _this.props.disableAutoscroll;\n var isKeySorting = _this.manager.isKeySorting;\n\n if (disableAutoscroll) {\n _this.autoScroller.clear();\n\n return;\n }\n\n if (isKeySorting) {\n var translate = _objectSpread({}, _this.translate);\n\n var scrollX = 0;\n var scrollY = 0;\n\n if (_this.axis.x) {\n translate.x = Math.min(_this.maxTranslate.x, Math.max(_this.minTranslate.x, _this.translate.x));\n scrollX = _this.translate.x - translate.x;\n }\n\n if (_this.axis.y) {\n translate.y = Math.min(_this.maxTranslate.y, Math.max(_this.minTranslate.y, _this.translate.y));\n scrollY = _this.translate.y - translate.y;\n }\n\n _this.translate = translate;\n setTranslate3d(_this.helper, _this.translate);\n _this.scrollContainer.scrollLeft += scrollX;\n _this.scrollContainer.scrollTop += scrollY;\n return;\n }\n\n _this.autoScroller.update({\n height: _this.height,\n maxTranslate: _this.maxTranslate,\n minTranslate: _this.minTranslate,\n translate: _this.translate,\n width: _this.width\n });\n });\n\n _defineProperty((0,assertThisInitialized/* default */.Z)((0,assertThisInitialized/* default */.Z)(_this)), "onAutoScroll", function (offset) {\n _this.translate.x += offset.left;\n _this.translate.y += offset.top;\n\n _this.animateNodes();\n });\n\n _defineProperty((0,assertThisInitialized/* default */.Z)((0,assertThisInitialized/* default */.Z)(_this)), "handleKeyDown", function (event) {\n var keyCode = event.keyCode;\n var _this$props5 = _this.props,\n shouldCancelStart = _this$props5.shouldCancelStart,\n _this$props5$keyCodes = _this$props5.keyCodes,\n customKeyCodes = _this$props5$keyCodes === void 0 ? {} : _this$props5$keyCodes;\n\n var keyCodes = _objectSpread({}, defaultKeyCodes, customKeyCodes);\n\n if (_this.manager.active && !_this.manager.isKeySorting || !_this.manager.active && (!keyCodes.lift.includes(keyCode) || shouldCancelStart(event) || !_this.isValidSortingTarget(event))) {\n return;\n }\n\n event.stopPropagation();\n event.preventDefault();\n\n if (keyCodes.lift.includes(keyCode) && !_this.manager.active) {\n _this.keyLift(event);\n } else if (keyCodes.drop.includes(keyCode) && _this.manager.active) {\n _this.keyDrop(event);\n } else if (keyCodes.cancel.includes(keyCode)) {\n _this.newIndex = _this.manager.active.index;\n\n _this.keyDrop(event);\n } else if (keyCodes.up.includes(keyCode)) {\n _this.keyMove(-1);\n } else if (keyCodes.down.includes(keyCode)) {\n _this.keyMove(1);\n }\n });\n\n _defineProperty((0,assertThisInitialized/* default */.Z)((0,assertThisInitialized/* default */.Z)(_this)), "keyLift", function (event) {\n var target = event.target;\n var node = closest(target, function (el) {\n return el.sortableInfo != null;\n });\n var _node$sortableInfo2 = node.sortableInfo,\n index = _node$sortableInfo2.index,\n collection = _node$sortableInfo2.collection;\n _this.initialFocusedNode = target;\n _this.manager.isKeySorting = true;\n _this.manager.active = {\n index: index,\n collection: collection\n };\n\n _this.handlePress(event);\n });\n\n _defineProperty((0,assertThisInitialized/* default */.Z)((0,assertThisInitialized/* default */.Z)(_this)), "keyMove", function (shift) {\n var nodes = _this.manager.getOrderedRefs();\n\n var lastIndex = nodes[nodes.length - 1].node.sortableInfo.index;\n var newIndex = _this.newIndex + shift;\n var prevIndex = _this.newIndex;\n\n if (newIndex < 0 || newIndex > lastIndex) {\n return;\n }\n\n _this.prevIndex = prevIndex;\n _this.newIndex = newIndex;\n var targetIndex = getTargetIndex(_this.newIndex, _this.prevIndex, _this.index);\n var target = nodes.find(function (_ref2) {\n var node = _ref2.node;\n return node.sortableInfo.index === targetIndex;\n });\n var targetNode = target.node;\n var scrollDelta = _this.containerScrollDelta;\n var targetBoundingClientRect = target.boundingClientRect || getScrollAdjustedBoundingClientRect(targetNode, scrollDelta);\n var targetTranslate = target.translate || {\n x: 0,\n y: 0\n };\n var targetPosition = {\n top: targetBoundingClientRect.top + targetTranslate.y - scrollDelta.top,\n left: targetBoundingClientRect.left + targetTranslate.x - scrollDelta.left\n };\n var shouldAdjustForSize = prevIndex < newIndex;\n var sizeAdjustment = {\n x: shouldAdjustForSize && _this.axis.x ? targetNode.offsetWidth - _this.width : 0,\n y: shouldAdjustForSize && _this.axis.y ? targetNode.offsetHeight - _this.height : 0\n };\n\n _this.handleSortMove({\n pageX: targetPosition.left + sizeAdjustment.x,\n pageY: targetPosition.top + sizeAdjustment.y,\n ignoreTransition: shift === 0\n });\n });\n\n _defineProperty((0,assertThisInitialized/* default */.Z)((0,assertThisInitialized/* default */.Z)(_this)), "keyDrop", function (event) {\n _this.handleSortEnd(event);\n\n if (_this.initialFocusedNode) {\n _this.initialFocusedNode.focus();\n }\n });\n\n _defineProperty((0,assertThisInitialized/* default */.Z)((0,assertThisInitialized/* default */.Z)(_this)), "handleKeyEnd", function (event) {\n if (_this.manager.active) {\n _this.keyDrop(event);\n }\n });\n\n _defineProperty((0,assertThisInitialized/* default */.Z)((0,assertThisInitialized/* default */.Z)(_this)), "isValidSortingTarget", function (event) {\n var useDragHandle = _this.props.useDragHandle;\n var target = event.target;\n var node = closest(target, function (el) {\n return el.sortableInfo != null;\n });\n return node && node.sortableInfo && !node.sortableInfo.disabled && (useDragHandle ? isSortableHandle(target) : target.sortableInfo);\n });\n\n validateProps(props);\n _this.manager = new Manager();\n _this.events = {\n end: _this.handleEnd,\n move: _this.handleMove,\n start: _this.handleStart\n };\n return _this;\n }\n\n _createClass(WithSortableContainer, [{\n key: "getChildContext",\n value: function getChildContext() {\n return {\n manager: this.manager\n };\n }\n }, {\n key: "componentDidMount",\n value: function componentDidMount() {\n var _this2 = this;\n\n var useWindowAsScrollContainer = this.props.useWindowAsScrollContainer;\n var container = this.getContainer();\n Promise.resolve(container).then(function (containerNode) {\n _this2.container = containerNode;\n _this2.document = _this2.container.ownerDocument || document;\n var contentWindow = _this2.props.contentWindow || _this2.document.defaultView || window;\n _this2.contentWindow = typeof contentWindow === \'function\' ? contentWindow() : contentWindow;\n _this2.scrollContainer = useWindowAsScrollContainer ? _this2.document.scrollingElement || _this2.document.documentElement : getScrollingParent(_this2.container) || _this2.container;\n _this2.autoScroller = new AutoScroller(_this2.scrollContainer, _this2.onAutoScroll);\n Object.keys(_this2.events).forEach(function (key) {\n return events[key].forEach(function (eventName) {\n return _this2.container.addEventListener(eventName, _this2.events[key], false);\n });\n });\n\n _this2.container.addEventListener(\'keydown\', _this2.handleKeyDown);\n });\n }\n }, {\n key: "componentWillUnmount",\n value: function componentWillUnmount() {\n var _this3 = this;\n\n if (this.helper && this.helper.parentNode) {\n this.helper.parentNode.removeChild(this.helper);\n }\n\n if (!this.container) {\n return;\n }\n\n Object.keys(this.events).forEach(function (key) {\n return events[key].forEach(function (eventName) {\n return _this3.container.removeEventListener(eventName, _this3.events[key]);\n });\n });\n this.container.removeEventListener(\'keydown\', this.handleKeyDown);\n }\n }, {\n key: "updateHelperPosition",\n value: function updateHelperPosition(event) {\n var _this$props6 = this.props,\n lockAxis = _this$props6.lockAxis,\n lockOffset = _this$props6.lockOffset,\n lockToContainerEdges = _this$props6.lockToContainerEdges,\n transitionDuration = _this$props6.transitionDuration,\n _this$props6$keyboard = _this$props6.keyboardSortingTransitionDuration,\n keyboardSortingTransitionDuration = _this$props6$keyboard === void 0 ? transitionDuration : _this$props6$keyboard;\n var isKeySorting = this.manager.isKeySorting;\n var ignoreTransition = event.ignoreTransition;\n var offset = getPosition(event);\n var translate = {\n x: offset.x - this.initialOffset.x,\n y: offset.y - this.initialOffset.y\n };\n translate.y -= window.pageYOffset - this.initialWindowScroll.top;\n translate.x -= window.pageXOffset - this.initialWindowScroll.left;\n this.translate = translate;\n\n if (lockToContainerEdges) {\n var _getLockPixelOffsets = getLockPixelOffsets({\n height: this.height,\n lockOffset: lockOffset,\n width: this.width\n }),\n _getLockPixelOffsets2 = _slicedToArray(_getLockPixelOffsets, 2),\n minLockOffset = _getLockPixelOffsets2[0],\n maxLockOffset = _getLockPixelOffsets2[1];\n\n var minOffset = {\n x: this.width / 2 - minLockOffset.x,\n y: this.height / 2 - minLockOffset.y\n };\n var maxOffset = {\n x: this.width / 2 - maxLockOffset.x,\n y: this.height / 2 - maxLockOffset.y\n };\n translate.x = limit(this.minTranslate.x + minOffset.x, this.maxTranslate.x - maxOffset.x, translate.x);\n translate.y = limit(this.minTranslate.y + minOffset.y, this.maxTranslate.y - maxOffset.y, translate.y);\n }\n\n if (lockAxis === \'x\') {\n translate.y = 0;\n } else if (lockAxis === \'y\') {\n translate.x = 0;\n }\n\n if (isKeySorting && keyboardSortingTransitionDuration && !ignoreTransition) {\n setTransitionDuration(this.helper, keyboardSortingTransitionDuration);\n }\n\n setTranslate3d(this.helper, translate);\n }\n }, {\n key: "animateNodes",\n value: function animateNodes() {\n var _this$props7 = this.props,\n transitionDuration = _this$props7.transitionDuration,\n hideSortableGhost = _this$props7.hideSortableGhost,\n onSortOver = _this$props7.onSortOver;\n var containerScrollDelta = this.containerScrollDelta,\n windowScrollDelta = this.windowScrollDelta;\n var nodes = this.manager.getOrderedRefs();\n var sortingOffset = {\n left: this.offsetEdge.left + this.translate.x + containerScrollDelta.left,\n top: this.offsetEdge.top + this.translate.y + containerScrollDelta.top\n };\n var isKeySorting = this.manager.isKeySorting;\n var prevIndex = this.newIndex;\n this.newIndex = null;\n\n for (var i = 0, len = nodes.length; i < len; i++) {\n var _node3 = nodes[i].node;\n var index = _node3.sortableInfo.index;\n var width = _node3.offsetWidth;\n var height = _node3.offsetHeight;\n var offset = {\n height: this.height > height ? height / 2 : this.height / 2,\n width: this.width > width ? width / 2 : this.width / 2\n };\n var mustShiftBackward = isKeySorting && index > this.index && index <= prevIndex;\n var mustShiftForward = isKeySorting && index < this.index && index >= prevIndex;\n var translate = {\n x: 0,\n y: 0\n };\n var edgeOffset = nodes[i].edgeOffset;\n\n if (!edgeOffset) {\n edgeOffset = getEdgeOffset(_node3, this.container);\n nodes[i].edgeOffset = edgeOffset;\n\n if (isKeySorting) {\n nodes[i].boundingClientRect = getScrollAdjustedBoundingClientRect(_node3, containerScrollDelta);\n }\n }\n\n var nextNode = i < nodes.length - 1 && nodes[i + 1];\n var prevNode = i > 0 && nodes[i - 1];\n\n if (nextNode && !nextNode.edgeOffset) {\n nextNode.edgeOffset = getEdgeOffset(nextNode.node, this.container);\n\n if (isKeySorting) {\n nextNode.boundingClientRect = getScrollAdjustedBoundingClientRect(nextNode.node, containerScrollDelta);\n }\n }\n\n if (index === this.index) {\n if (hideSortableGhost) {\n this.sortableGhost = _node3;\n setInlineStyles(_node3, {\n opacity: 0,\n visibility: \'hidden\'\n });\n }\n\n continue;\n }\n\n if (transitionDuration) {\n setTransitionDuration(_node3, transitionDuration);\n }\n\n if (this.axis.x) {\n if (this.axis.y) {\n if (mustShiftForward || index < this.index && (sortingOffset.left + windowScrollDelta.left - offset.width <= edgeOffset.left && sortingOffset.top + windowScrollDelta.top <= edgeOffset.top + offset.height || sortingOffset.top + windowScrollDelta.top + offset.height <= edgeOffset.top)) {\n translate.x = this.width + this.marginOffset.x;\n\n if (edgeOffset.left + translate.x > this.containerBoundingRect.width - offset.width) {\n if (nextNode) {\n translate.x = nextNode.edgeOffset.left - edgeOffset.left;\n translate.y = nextNode.edgeOffset.top - edgeOffset.top;\n }\n }\n\n if (this.newIndex === null) {\n this.newIndex = index;\n }\n } else if (mustShiftBackward || index > this.index && (sortingOffset.left + windowScrollDelta.left + offset.width >= edgeOffset.left && sortingOffset.top + windowScrollDelta.top + offset.height >= edgeOffset.top || sortingOffset.top + windowScrollDelta.top + offset.height >= edgeOffset.top + height)) {\n translate.x = -(this.width + this.marginOffset.x);\n\n if (edgeOffset.left + translate.x < this.containerBoundingRect.left + offset.width) {\n if (prevNode) {\n translate.x = prevNode.edgeOffset.left - edgeOffset.left;\n translate.y = prevNode.edgeOffset.top - edgeOffset.top;\n }\n }\n\n this.newIndex = index;\n }\n } else {\n if (mustShiftBackward || index > this.index && sortingOffset.left + windowScrollDelta.left + offset.width >= edgeOffset.left) {\n translate.x = -(this.width + this.marginOffset.x);\n this.newIndex = index;\n } else if (mustShiftForward || index < this.index && sortingOffset.left + windowScrollDelta.left <= edgeOffset.left + offset.width) {\n translate.x = this.width + this.marginOffset.x;\n\n if (this.newIndex == null) {\n this.newIndex = index;\n }\n }\n }\n } else if (this.axis.y) {\n if (mustShiftBackward || index > this.index && sortingOffset.top + windowScrollDelta.top + offset.height >= edgeOffset.top) {\n translate.y = -(this.height + this.marginOffset.y);\n this.newIndex = index;\n } else if (mustShiftForward || index < this.index && sortingOffset.top + windowScrollDelta.top <= edgeOffset.top + offset.height) {\n translate.y = this.height + this.marginOffset.y;\n\n if (this.newIndex == null) {\n this.newIndex = index;\n }\n }\n }\n\n setTranslate3d(_node3, translate);\n nodes[i].translate = translate;\n }\n\n if (this.newIndex == null) {\n this.newIndex = this.index;\n }\n\n if (isKeySorting) {\n this.newIndex = prevIndex;\n }\n\n var oldIndex = isKeySorting ? this.prevIndex : prevIndex;\n\n if (onSortOver && this.newIndex !== oldIndex) {\n onSortOver({\n collection: this.manager.active.collection,\n index: this.index,\n newIndex: this.newIndex,\n oldIndex: oldIndex,\n isKeySorting: isKeySorting,\n nodes: nodes,\n helper: this.helper\n });\n }\n }\n }, {\n key: "getWrappedInstance",\n value: function getWrappedInstance() {\n browser_default()(config.withRef, \'To access the wrapped instance, you need to pass in {withRef: true} as the second argument of the SortableContainer() call\');\n return this.refs.wrappedInstance;\n }\n }, {\n key: "getContainer",\n value: function getContainer() {\n var getContainer = this.props.getContainer;\n\n if (typeof getContainer !== \'function\') {\n return (0,external_ReactDOM_.findDOMNode)(this);\n }\n\n return getContainer(config.withRef ? this.getWrappedInstance() : undefined);\n }\n }, {\n key: "render",\n value: function render() {\n var ref = config.withRef ? \'wrappedInstance\' : null;\n return (0,external_React_.createElement)(WrappedComponent, (0,esm_extends["default"])({\n ref: ref\n }, omit(this.props, omittedProps)));\n }\n }, {\n key: "helperContainer",\n get: function get() {\n var helperContainer = this.props.helperContainer;\n\n if (typeof helperContainer === \'function\') {\n return helperContainer();\n }\n\n return this.props.helperContainer || this.document.body;\n }\n }, {\n key: "containerScrollDelta",\n get: function get() {\n var useWindowAsScrollContainer = this.props.useWindowAsScrollContainer;\n\n if (useWindowAsScrollContainer) {\n return {\n left: 0,\n top: 0\n };\n }\n\n return {\n left: this.scrollContainer.scrollLeft - this.initialScroll.left,\n top: this.scrollContainer.scrollTop - this.initialScroll.top\n };\n }\n }, {\n key: "windowScrollDelta",\n get: function get() {\n return {\n left: this.contentWindow.pageXOffset - this.initialWindowScroll.left,\n top: this.contentWindow.pageYOffset - this.initialWindowScroll.top\n };\n }\n }]);\n\n return WithSortableContainer;\n }(external_React_.Component), _defineProperty(_class, "displayName", provideDisplayName(\'sortableList\', WrappedComponent)), _defineProperty(_class, "defaultProps", defaultProps), _defineProperty(_class, "propTypes", propTypes), _defineProperty(_class, "childContextTypes", {\n manager: (prop_types_default()).object.isRequired\n }), _temp;\n}\n\nvar propTypes$1 = {\n index: (prop_types_default()).number.isRequired,\n collection: prop_types_default().oneOfType([(prop_types_default()).number, (prop_types_default()).string]),\n disabled: (prop_types_default()).bool\n};\nvar omittedProps$1 = Object.keys(propTypes$1);\nfunction sortableElement(WrappedComponent) {\n var _class, _temp;\n\n var config = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n withRef: false\n };\n return _temp = _class = function (_React$Component) {\n _inherits(WithSortableElement, _React$Component);\n\n function WithSortableElement() {\n _classCallCheck(this, WithSortableElement);\n\n return _possibleConstructorReturn(this, _getPrototypeOf(WithSortableElement).apply(this, arguments));\n }\n\n _createClass(WithSortableElement, [{\n key: "componentDidMount",\n value: function componentDidMount() {\n this.register();\n }\n }, {\n key: "componentDidUpdate",\n value: function componentDidUpdate(prevProps) {\n if (this.node) {\n if (prevProps.index !== this.props.index) {\n this.node.sortableInfo.index = this.props.index;\n }\n\n if (prevProps.disabled !== this.props.disabled) {\n this.node.sortableInfo.disabled = this.props.disabled;\n }\n }\n\n if (prevProps.collection !== this.props.collection) {\n this.unregister(prevProps.collection);\n this.register();\n }\n }\n }, {\n key: "componentWillUnmount",\n value: function componentWillUnmount() {\n this.unregister();\n }\n }, {\n key: "register",\n value: function register() {\n var _this$props = this.props,\n collection = _this$props.collection,\n disabled = _this$props.disabled,\n index = _this$props.index;\n var node = (0,external_ReactDOM_.findDOMNode)(this);\n node.sortableInfo = {\n collection: collection,\n disabled: disabled,\n index: index,\n manager: this.context.manager\n };\n this.node = node;\n this.ref = {\n node: node\n };\n this.context.manager.add(collection, this.ref);\n }\n }, {\n key: "unregister",\n value: function unregister() {\n var collection = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.props.collection;\n this.context.manager.remove(collection, this.ref);\n }\n }, {\n key: "getWrappedInstance",\n value: function getWrappedInstance() {\n browser_default()(config.withRef, \'To access the wrapped instance, you need to pass in {withRef: true} as the second argument of the SortableElement() call\');\n return this.refs.wrappedInstance;\n }\n }, {\n key: "render",\n value: function render() {\n var ref = config.withRef ? \'wrappedInstance\' : null;\n return (0,external_React_.createElement)(WrappedComponent, (0,esm_extends["default"])({\n ref: ref\n }, omit(this.props, omittedProps$1)));\n }\n }]);\n\n return WithSortableElement;\n }(external_React_.Component), _defineProperty(_class, "displayName", provideDisplayName(\'sortableElement\', WrappedComponent)), _defineProperty(_class, "contextTypes", {\n manager: (prop_types_default()).object.isRequired\n }), _defineProperty(_class, "propTypes", propTypes$1), _defineProperty(_class, "defaultProps", {\n collection: 0\n }), _temp;\n}\n\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"6362.js","mappings":";;;;;;;;;;;;;AAAA;AACA;AACA;;ACFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRA;AACA;AACA;;ACFA;AACA;AACA;AACA;AACA;AACA;AACA;;ACNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClBA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACVA;AACA;AACA;AACA;AACA;AACA;;;;ACLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;ACjBA;AACA;AACA;AACA;;ACHA;AACA;AACA;;ACFA;AACA;AACA;;ACFA;AACA;AACA;AACA;AACA;AACA;AACA;;ACNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./node_modules/@babel/runtime/helpers/esm/arrayWithHoles.js?c112","webpack://blocksyOptions/./node_modules/@babel/runtime/helpers/esm/iterableToArrayLimit.js?d354","webpack://blocksyOptions/./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js?c24f","webpack://blocksyOptions/./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js?1001","webpack://blocksyOptions/./node_modules/@babel/runtime/helpers/esm/nonIterableRest.js?2ef4","webpack://blocksyOptions/./node_modules/@babel/runtime/helpers/esm/slicedToArray.js?227d","webpack://blocksyOptions/./node_modules/@babel/runtime/helpers/esm/defineProperty.js?93de","webpack://blocksyOptions/./node_modules/@babel/runtime/helpers/esm/objectSpread.js?5cec","webpack://blocksyOptions/./node_modules/@babel/runtime/helpers/esm/classCallCheck.js?f2b5","webpack://blocksyOptions/./node_modules/@babel/runtime/helpers/esm/createClass.js?7ea2","webpack://blocksyOptions/./node_modules/@babel/runtime/helpers/esm/typeof.js?119a","webpack://blocksyOptions/./node_modules/@babel/runtime/helpers/esm/possibleConstructorReturn.js?708b","webpack://blocksyOptions/./node_modules/@babel/runtime/helpers/esm/getPrototypeOf.js?ba6c","webpack://blocksyOptions/./node_modules/@babel/runtime/helpers/esm/inherits.js?aeb9","webpack://blocksyOptions/./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js?c3db","webpack://blocksyOptions/./node_modules/@babel/runtime/helpers/esm/iterableToArray.js?7a5c","webpack://blocksyOptions/./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js?9214","webpack://blocksyOptions/./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js?9a2e","webpack://blocksyOptions/./node_modules/react-sortable-hoc/dist/react-sortable-hoc.esm.js?6090"],"sourcesContent":["export default function _arrayWithHoles(arr) {\n  if (Array.isArray(arr)) return arr;\n}","export default function _iterableToArrayLimit(arr, i) {\n  var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n\n  if (_i == null) return;\n  var _arr = [];\n  var _n = true;\n  var _d = false;\n\n  var _s, _e;\n\n  try {\n    for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {\n      _arr.push(_s.value);\n\n      if (i && _arr.length === i) break;\n    }\n  } catch (err) {\n    _d = true;\n    _e = err;\n  } finally {\n    try {\n      if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n    } finally {\n      if (_d) throw _e;\n    }\n  }\n\n  return _arr;\n}","export default function _arrayLikeToArray(arr, len) {\n  if (len == null || len > arr.length) len = arr.length;\n\n  for (var i = 0, arr2 = new Array(len); i < len; i++) {\n    arr2[i] = arr[i];\n  }\n\n  return arr2;\n}","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nexport default function _unsupportedIterableToArray(o, minLen) {\n  if (!o) return;\n  if (typeof o === \"string\") return arrayLikeToArray(o, minLen);\n  var n = Object.prototype.toString.call(o).slice(8, -1);\n  if (n === \"Object\" && o.constructor) n = o.constructor.name;\n  if (n === \"Map\" || n === \"Set\") return Array.from(o);\n  if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return arrayLikeToArray(o, minLen);\n}","export default function _nonIterableRest() {\n  throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}","import arrayWithHoles from \"./arrayWithHoles.js\";\nimport iterableToArrayLimit from \"./iterableToArrayLimit.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableRest from \"./nonIterableRest.js\";\nexport default function _slicedToArray(arr, i) {\n  return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || unsupportedIterableToArray(arr, i) || nonIterableRest();\n}","export default function _defineProperty(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}","import defineProperty from \"./defineProperty.js\";\nexport default function _objectSpread(target) {\n  for (var i = 1; i < arguments.length; i++) {\n    var source = arguments[i] != null ? Object(arguments[i]) : {};\n    var ownKeys = Object.keys(source);\n\n    if (typeof Object.getOwnPropertySymbols === 'function') {\n      ownKeys.push.apply(ownKeys, Object.getOwnPropertySymbols(source).filter(function (sym) {\n        return Object.getOwnPropertyDescriptor(source, sym).enumerable;\n      }));\n    }\n\n    ownKeys.forEach(function (key) {\n      defineProperty(target, key, source[key]);\n    });\n  }\n\n  return target;\n}","export default function _classCallCheck(instance, Constructor) {\n  if (!(instance instanceof Constructor)) {\n    throw new TypeError(\"Cannot call a class as a function\");\n  }\n}","function _defineProperties(target, props) {\n  for (var i = 0; i < props.length; i++) {\n    var descriptor = props[i];\n    descriptor.enumerable = descriptor.enumerable || false;\n    descriptor.configurable = true;\n    if (\"value\" in descriptor) descriptor.writable = true;\n    Object.defineProperty(target, descriptor.key, descriptor);\n  }\n}\n\nexport default function _createClass(Constructor, protoProps, staticProps) {\n  if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n  if (staticProps) _defineProperties(Constructor, staticProps);\n  Object.defineProperty(Constructor, \"prototype\", {\n    writable: false\n  });\n  return Constructor;\n}","export default function _typeof(obj) {\n  \"@babel/helpers - typeof\";\n\n  return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) {\n    return typeof obj;\n  } : function (obj) {\n    return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n  }, _typeof(obj);\n}","import _typeof from \"./typeof.js\";\nimport assertThisInitialized from \"./assertThisInitialized.js\";\nexport default function _possibleConstructorReturn(self, call) {\n  if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n    return call;\n  } else if (call !== void 0) {\n    throw new TypeError(\"Derived constructors may only return object or undefined\");\n  }\n\n  return assertThisInitialized(self);\n}","export default function _getPrototypeOf(o) {\n  _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) {\n    return o.__proto__ || Object.getPrototypeOf(o);\n  };\n  return _getPrototypeOf(o);\n}","import setPrototypeOf from \"./setPrototypeOf.js\";\nexport default function _inherits(subClass, superClass) {\n  if (typeof superClass !== \"function\" && superClass !== null) {\n    throw new TypeError(\"Super expression must either be null or a function\");\n  }\n\n  subClass.prototype = Object.create(superClass && superClass.prototype, {\n    constructor: {\n      value: subClass,\n      writable: true,\n      configurable: true\n    }\n  });\n  Object.defineProperty(subClass, \"prototype\", {\n    writable: false\n  });\n  if (superClass) setPrototypeOf(subClass, superClass);\n}","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nexport default function _arrayWithoutHoles(arr) {\n  if (Array.isArray(arr)) return arrayLikeToArray(arr);\n}","export default function _iterableToArray(iter) {\n  if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n}","export default function _nonIterableSpread() {\n  throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}","import arrayWithoutHoles from \"./arrayWithoutHoles.js\";\nimport iterableToArray from \"./iterableToArray.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableSpread from \"./nonIterableSpread.js\";\nexport default function _toConsumableArray(arr) {\n  return arrayWithoutHoles(arr) || iterableToArray(arr) || unsupportedIterableToArray(arr) || nonIterableSpread();\n}","import _extends from '@babel/runtime/helpers/esm/extends';\nimport _slicedToArray from '@babel/runtime/helpers/esm/slicedToArray';\nimport _objectSpread from '@babel/runtime/helpers/esm/objectSpread';\nimport _classCallCheck from '@babel/runtime/helpers/esm/classCallCheck';\nimport _createClass from '@babel/runtime/helpers/esm/createClass';\nimport _possibleConstructorReturn from '@babel/runtime/helpers/esm/possibleConstructorReturn';\nimport _getPrototypeOf from '@babel/runtime/helpers/esm/getPrototypeOf';\nimport _inherits from '@babel/runtime/helpers/esm/inherits';\nimport _assertThisInitialized from '@babel/runtime/helpers/esm/assertThisInitialized';\nimport _defineProperty from '@babel/runtime/helpers/esm/defineProperty';\nimport { createElement, Component } from 'react';\nimport PropTypes from 'prop-types';\nimport { findDOMNode } from 'react-dom';\nimport invariant from 'invariant';\nimport _toConsumableArray from '@babel/runtime/helpers/esm/toConsumableArray';\n\nvar Manager = function () {\n  function Manager() {\n    _classCallCheck(this, Manager);\n\n    _defineProperty(this, \"refs\", {});\n  }\n\n  _createClass(Manager, [{\n    key: \"add\",\n    value: function add(collection, ref) {\n      if (!this.refs[collection]) {\n        this.refs[collection] = [];\n      }\n\n      this.refs[collection].push(ref);\n    }\n  }, {\n    key: \"remove\",\n    value: function remove(collection, ref) {\n      var index = this.getIndex(collection, ref);\n\n      if (index !== -1) {\n        this.refs[collection].splice(index, 1);\n      }\n    }\n  }, {\n    key: \"isActive\",\n    value: function isActive() {\n      return this.active;\n    }\n  }, {\n    key: \"getActive\",\n    value: function getActive() {\n      var _this = this;\n\n      return this.refs[this.active.collection].find(function (_ref) {\n        var node = _ref.node;\n        return node.sortableInfo.index == _this.active.index;\n      });\n    }\n  }, {\n    key: \"getIndex\",\n    value: function getIndex(collection, ref) {\n      return this.refs[collection].indexOf(ref);\n    }\n  }, {\n    key: \"getOrderedRefs\",\n    value: function getOrderedRefs() {\n      var collection = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.active.collection;\n      return this.refs[collection].sort(sortByIndex);\n    }\n  }]);\n\n  return Manager;\n}();\n\nfunction sortByIndex(_ref2, _ref3) {\n  var index1 = _ref2.node.sortableInfo.index;\n  var index2 = _ref3.node.sortableInfo.index;\n  return index1 - index2;\n}\n\nfunction arrayMove(array, from, to) {\n  if (process.env.NODE_ENV !== 'production') {\n    if (typeof console !== 'undefined') {\n      console.warn(\"Deprecation warning: arrayMove will no longer be exported by 'react-sortable-hoc' in the next major release. Please install the `array-move` package locally instead. https://www.npmjs.com/package/array-move\");\n    }\n  }\n\n  array = array.slice();\n  array.splice(to < 0 ? array.length + to : to, 0, array.splice(from, 1)[0]);\n  return array;\n}\nfunction omit(obj, keysToOmit) {\n  return Object.keys(obj).reduce(function (acc, key) {\n    if (keysToOmit.indexOf(key) === -1) {\n      acc[key] = obj[key];\n    }\n\n    return acc;\n  }, {});\n}\nvar events = {\n  end: ['touchend', 'touchcancel', 'mouseup'],\n  move: ['touchmove', 'mousemove'],\n  start: ['touchstart', 'mousedown']\n};\nvar vendorPrefix = function () {\n  if (typeof window === 'undefined' || typeof document === 'undefined') {\n    return '';\n  }\n\n  var styles = window.getComputedStyle(document.documentElement, '') || ['-moz-hidden-iframe'];\n  var pre = (Array.prototype.slice.call(styles).join('').match(/-(moz|webkit|ms)-/) || styles.OLink === '' && ['', 'o'])[1];\n\n  switch (pre) {\n    case 'ms':\n      return 'ms';\n\n    default:\n      return pre && pre.length ? pre[0].toUpperCase() + pre.substr(1) : '';\n  }\n}();\nfunction setInlineStyles(node, styles) {\n  Object.keys(styles).forEach(function (key) {\n    node.style[key] = styles[key];\n  });\n}\nfunction setTranslate3d(node, translate) {\n  node.style[\"\".concat(vendorPrefix, \"Transform\")] = translate == null ? '' : \"translate3d(\".concat(translate.x, \"px,\").concat(translate.y, \"px,0)\");\n}\nfunction setTransitionDuration(node, duration) {\n  node.style[\"\".concat(vendorPrefix, \"TransitionDuration\")] = duration == null ? '' : \"\".concat(duration, \"ms\");\n}\nfunction closest(el, fn) {\n  while (el) {\n    if (fn(el)) {\n      return el;\n    }\n\n    el = el.parentNode;\n  }\n\n  return null;\n}\nfunction limit(min, max, value) {\n  return Math.max(min, Math.min(value, max));\n}\n\nfunction getPixelValue(stringValue) {\n  if (stringValue.substr(-2) === 'px') {\n    return parseFloat(stringValue);\n  }\n\n  return 0;\n}\n\nfunction getElementMargin(element) {\n  var style = window.getComputedStyle(element);\n  return {\n    bottom: getPixelValue(style.marginBottom),\n    left: getPixelValue(style.marginLeft),\n    right: getPixelValue(style.marginRight),\n    top: getPixelValue(style.marginTop)\n  };\n}\nfunction provideDisplayName(prefix, Component$$1) {\n  var componentName = Component$$1.displayName || Component$$1.name;\n  return componentName ? \"\".concat(prefix, \"(\").concat(componentName, \")\") : prefix;\n}\nfunction getScrollAdjustedBoundingClientRect(node, scrollDelta) {\n  var boundingClientRect = node.getBoundingClientRect();\n  return {\n    top: boundingClientRect.top + scrollDelta.top,\n    left: boundingClientRect.left + scrollDelta.left\n  };\n}\nfunction getPosition(event) {\n  if (event.touches && event.touches.length) {\n    return {\n      x: event.touches[0].pageX,\n      y: event.touches[0].pageY\n    };\n  } else if (event.changedTouches && event.changedTouches.length) {\n    return {\n      x: event.changedTouches[0].pageX,\n      y: event.changedTouches[0].pageY\n    };\n  } else {\n    return {\n      x: event.pageX,\n      y: event.pageY\n    };\n  }\n}\nfunction isTouchEvent(event) {\n  return event.touches && event.touches.length || event.changedTouches && event.changedTouches.length;\n}\nfunction getEdgeOffset(node, parent) {\n  var offset = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {\n    left: 0,\n    top: 0\n  };\n\n  if (!node) {\n    return undefined;\n  }\n\n  var nodeOffset = {\n    left: offset.left + node.offsetLeft,\n    top: offset.top + node.offsetTop\n  };\n\n  if (node.parentNode === parent) {\n    return nodeOffset;\n  }\n\n  return getEdgeOffset(node.parentNode, parent, nodeOffset);\n}\nfunction getTargetIndex(newIndex, prevIndex, oldIndex) {\n  if (newIndex < oldIndex && newIndex > prevIndex) {\n    return newIndex - 1;\n  } else if (newIndex > oldIndex && newIndex < prevIndex) {\n    return newIndex + 1;\n  } else {\n    return newIndex;\n  }\n}\nfunction getLockPixelOffset(_ref) {\n  var lockOffset = _ref.lockOffset,\n      width = _ref.width,\n      height = _ref.height;\n  var offsetX = lockOffset;\n  var offsetY = lockOffset;\n  var unit = 'px';\n\n  if (typeof lockOffset === 'string') {\n    var match = /^[+-]?\\d*(?:\\.\\d*)?(px|%)$/.exec(lockOffset);\n    invariant(match !== null, 'lockOffset value should be a number or a string of a ' + 'number followed by \"px\" or \"%\". Given %s', lockOffset);\n    offsetX = parseFloat(lockOffset);\n    offsetY = parseFloat(lockOffset);\n    unit = match[1];\n  }\n\n  invariant(isFinite(offsetX) && isFinite(offsetY), 'lockOffset value should be a finite. Given %s', lockOffset);\n\n  if (unit === '%') {\n    offsetX = offsetX * width / 100;\n    offsetY = offsetY * height / 100;\n  }\n\n  return {\n    x: offsetX,\n    y: offsetY\n  };\n}\nfunction getLockPixelOffsets(_ref2) {\n  var height = _ref2.height,\n      width = _ref2.width,\n      lockOffset = _ref2.lockOffset;\n  var offsets = Array.isArray(lockOffset) ? lockOffset : [lockOffset, lockOffset];\n  invariant(offsets.length === 2, 'lockOffset prop of SortableContainer should be a single ' + 'value or an array of exactly two values. Given %s', lockOffset);\n\n  var _offsets = _slicedToArray(offsets, 2),\n      minLockOffset = _offsets[0],\n      maxLockOffset = _offsets[1];\n\n  return [getLockPixelOffset({\n    height: height,\n    lockOffset: minLockOffset,\n    width: width\n  }), getLockPixelOffset({\n    height: height,\n    lockOffset: maxLockOffset,\n    width: width\n  })];\n}\n\nfunction isScrollable(el) {\n  var computedStyle = window.getComputedStyle(el);\n  var overflowRegex = /(auto|scroll)/;\n  var properties = ['overflow', 'overflowX', 'overflowY'];\n  return properties.find(function (property) {\n    return overflowRegex.test(computedStyle[property]);\n  });\n}\n\nfunction getScrollingParent(el) {\n  if (!(el instanceof HTMLElement)) {\n    return null;\n  } else if (isScrollable(el)) {\n    return el;\n  } else {\n    return getScrollingParent(el.parentNode);\n  }\n}\nfunction getContainerGridGap(element) {\n  var style = window.getComputedStyle(element);\n\n  if (style.display === 'grid') {\n    return {\n      x: getPixelValue(style.gridColumnGap),\n      y: getPixelValue(style.gridRowGap)\n    };\n  }\n\n  return {\n    x: 0,\n    y: 0\n  };\n}\nvar KEYCODE = {\n  TAB: 9,\n  ESC: 27,\n  SPACE: 32,\n  LEFT: 37,\n  UP: 38,\n  RIGHT: 39,\n  DOWN: 40\n};\nvar NodeType = {\n  Anchor: 'A',\n  Button: 'BUTTON',\n  Canvas: 'CANVAS',\n  Input: 'INPUT',\n  Option: 'OPTION',\n  Textarea: 'TEXTAREA',\n  Select: 'SELECT'\n};\nfunction cloneNode(node) {\n  var selector = 'input, textarea, select, canvas, [contenteditable]';\n  var fields = node.querySelectorAll(selector);\n  var clonedNode = node.cloneNode(true);\n\n  var clonedFields = _toConsumableArray(clonedNode.querySelectorAll(selector));\n\n  clonedFields.forEach(function (field, i) {\n    if (field.type !== 'file') {\n      field.value = fields[i].value;\n    }\n\n    if (field.type === 'radio' && field.name) {\n      field.name = \"__sortableClone__\".concat(field.name);\n    }\n\n    if (field.tagName === NodeType.Canvas && fields[i].width > 0 && fields[i].height > 0) {\n      var destCtx = field.getContext('2d');\n      destCtx.drawImage(fields[i], 0, 0);\n    }\n  });\n  return clonedNode;\n}\n\nfunction sortableHandle(WrappedComponent) {\n  var _class, _temp;\n\n  var config = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n    withRef: false\n  };\n  return _temp = _class = function (_React$Component) {\n    _inherits(WithSortableHandle, _React$Component);\n\n    function WithSortableHandle() {\n      _classCallCheck(this, WithSortableHandle);\n\n      return _possibleConstructorReturn(this, _getPrototypeOf(WithSortableHandle).apply(this, arguments));\n    }\n\n    _createClass(WithSortableHandle, [{\n      key: \"componentDidMount\",\n      value: function componentDidMount() {\n        var node = findDOMNode(this);\n        node.sortableHandle = true;\n      }\n    }, {\n      key: \"getWrappedInstance\",\n      value: function getWrappedInstance() {\n        invariant(config.withRef, 'To access the wrapped instance, you need to pass in {withRef: true} as the second argument of the SortableHandle() call');\n        return this.refs.wrappedInstance;\n      }\n    }, {\n      key: \"render\",\n      value: function render() {\n        var ref = config.withRef ? 'wrappedInstance' : null;\n        return createElement(WrappedComponent, _extends({\n          ref: ref\n        }, this.props));\n      }\n    }]);\n\n    return WithSortableHandle;\n  }(Component), _defineProperty(_class, \"displayName\", provideDisplayName('sortableHandle', WrappedComponent)), _temp;\n}\nfunction isSortableHandle(node) {\n  return node.sortableHandle != null;\n}\n\nvar AutoScroller = function () {\n  function AutoScroller(container, onScrollCallback) {\n    _classCallCheck(this, AutoScroller);\n\n    this.container = container;\n    this.onScrollCallback = onScrollCallback;\n  }\n\n  _createClass(AutoScroller, [{\n    key: \"clear\",\n    value: function clear() {\n      if (this.interval == null) {\n        return;\n      }\n\n      clearInterval(this.interval);\n      this.interval = null;\n    }\n  }, {\n    key: \"update\",\n    value: function update(_ref) {\n      var _this = this;\n\n      var translate = _ref.translate,\n          minTranslate = _ref.minTranslate,\n          maxTranslate = _ref.maxTranslate,\n          width = _ref.width,\n          height = _ref.height;\n      var direction = {\n        x: 0,\n        y: 0\n      };\n      var speed = {\n        x: 1,\n        y: 1\n      };\n      var acceleration = {\n        x: 10,\n        y: 10\n      };\n      var _this$container = this.container,\n          scrollTop = _this$container.scrollTop,\n          scrollLeft = _this$container.scrollLeft,\n          scrollHeight = _this$container.scrollHeight,\n          scrollWidth = _this$container.scrollWidth,\n          clientHeight = _this$container.clientHeight,\n          clientWidth = _this$container.clientWidth;\n      var isTop = scrollTop === 0;\n      var isBottom = scrollHeight - scrollTop - clientHeight === 0;\n      var isLeft = scrollLeft === 0;\n      var isRight = scrollWidth - scrollLeft - clientWidth === 0;\n\n      if (translate.y >= maxTranslate.y - height / 2 && !isBottom) {\n        direction.y = 1;\n        speed.y = acceleration.y * Math.abs((maxTranslate.y - height / 2 - translate.y) / height);\n      } else if (translate.x >= maxTranslate.x - width / 2 && !isRight) {\n        direction.x = 1;\n        speed.x = acceleration.x * Math.abs((maxTranslate.x - width / 2 - translate.x) / width);\n      } else if (translate.y <= minTranslate.y + height / 2 && !isTop) {\n        direction.y = -1;\n        speed.y = acceleration.y * Math.abs((translate.y - height / 2 - minTranslate.y) / height);\n      } else if (translate.x <= minTranslate.x + width / 2 && !isLeft) {\n        direction.x = -1;\n        speed.x = acceleration.x * Math.abs((translate.x - width / 2 - minTranslate.x) / width);\n      }\n\n      if (this.interval) {\n        this.clear();\n        this.isAutoScrolling = false;\n      }\n\n      if (direction.x !== 0 || direction.y !== 0) {\n        this.interval = setInterval(function () {\n          _this.isAutoScrolling = true;\n          var offset = {\n            left: speed.x * direction.x,\n            top: speed.y * direction.y\n          };\n          _this.container.scrollTop += offset.top;\n          _this.container.scrollLeft += offset.left;\n\n          _this.onScrollCallback(offset);\n        }, 5);\n      }\n    }\n  }]);\n\n  return AutoScroller;\n}();\n\nfunction defaultGetHelperDimensions(_ref) {\n  var node = _ref.node;\n  return {\n    height: node.offsetHeight,\n    width: node.offsetWidth\n  };\n}\n\nfunction defaultShouldCancelStart(event) {\n  var interactiveElements = [NodeType.Input, NodeType.Textarea, NodeType.Select, NodeType.Option, NodeType.Button];\n\n  if (interactiveElements.indexOf(event.target.tagName) !== -1) {\n    return true;\n  }\n\n  if (closest(event.target, function (el) {\n    return el.contentEditable === 'true';\n  })) {\n    return true;\n  }\n\n  return false;\n}\n\nvar propTypes = {\n  axis: PropTypes.oneOf(['x', 'y', 'xy']),\n  contentWindow: PropTypes.any,\n  disableAutoscroll: PropTypes.bool,\n  distance: PropTypes.number,\n  getContainer: PropTypes.func,\n  getHelperDimensions: PropTypes.func,\n  helperClass: PropTypes.string,\n  helperContainer: PropTypes.oneOfType([PropTypes.func, typeof HTMLElement === 'undefined' ? PropTypes.any : PropTypes.instanceOf(HTMLElement)]),\n  hideSortableGhost: PropTypes.bool,\n  keyboardSortingTransitionDuration: PropTypes.number,\n  lockAxis: PropTypes.string,\n  lockOffset: PropTypes.oneOfType([PropTypes.number, PropTypes.string, PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.number, PropTypes.string]))]),\n  lockToContainerEdges: PropTypes.bool,\n  onSortEnd: PropTypes.func,\n  onSortMove: PropTypes.func,\n  onSortOver: PropTypes.func,\n  onSortStart: PropTypes.func,\n  pressDelay: PropTypes.number,\n  pressThreshold: PropTypes.number,\n  keyCodes: PropTypes.shape({\n    lift: PropTypes.arrayOf(PropTypes.number),\n    drop: PropTypes.arrayOf(PropTypes.number),\n    cancel: PropTypes.arrayOf(PropTypes.number),\n    up: PropTypes.arrayOf(PropTypes.number),\n    down: PropTypes.arrayOf(PropTypes.number)\n  }),\n  shouldCancelStart: PropTypes.func,\n  transitionDuration: PropTypes.number,\n  updateBeforeSortStart: PropTypes.func,\n  useDragHandle: PropTypes.bool,\n  useWindowAsScrollContainer: PropTypes.bool\n};\nvar defaultKeyCodes = {\n  lift: [KEYCODE.SPACE],\n  drop: [KEYCODE.SPACE],\n  cancel: [KEYCODE.ESC],\n  up: [KEYCODE.UP, KEYCODE.LEFT],\n  down: [KEYCODE.DOWN, KEYCODE.RIGHT]\n};\nvar defaultProps = {\n  axis: 'y',\n  disableAutoscroll: false,\n  distance: 0,\n  getHelperDimensions: defaultGetHelperDimensions,\n  hideSortableGhost: true,\n  lockOffset: '50%',\n  lockToContainerEdges: false,\n  pressDelay: 0,\n  pressThreshold: 5,\n  keyCodes: defaultKeyCodes,\n  shouldCancelStart: defaultShouldCancelStart,\n  transitionDuration: 300,\n  useWindowAsScrollContainer: false\n};\nvar omittedProps = Object.keys(propTypes);\nfunction validateProps(props) {\n  invariant(!(props.distance && props.pressDelay), 'Attempted to set both `pressDelay` and `distance` on SortableContainer, you may only use one or the other, not both at the same time.');\n}\n\nfunction _finallyRethrows(body, finalizer) {\n  try {\n    var result = body();\n  } catch (e) {\n    return finalizer(true, e);\n  }\n\n  if (result && result.then) {\n    return result.then(finalizer.bind(null, false), finalizer.bind(null, true));\n  }\n\n  return finalizer(false, value);\n}\nfunction sortableContainer(WrappedComponent) {\n  var _class, _temp;\n\n  var config = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n    withRef: false\n  };\n  return _temp = _class = function (_React$Component) {\n    _inherits(WithSortableContainer, _React$Component);\n\n    function WithSortableContainer(props) {\n      var _this;\n\n      _classCallCheck(this, WithSortableContainer);\n\n      _this = _possibleConstructorReturn(this, _getPrototypeOf(WithSortableContainer).call(this, props));\n\n      _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"state\", {});\n\n      _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"handleStart\", function (event) {\n        var _this$props = _this.props,\n            distance = _this$props.distance,\n            shouldCancelStart = _this$props.shouldCancelStart;\n\n        if (event.button === 2 || shouldCancelStart(event)) {\n          return;\n        }\n\n        _this.touched = true;\n        _this.position = getPosition(event);\n        var node = closest(event.target, function (el) {\n          return el.sortableInfo != null;\n        });\n\n        if (node && node.sortableInfo && _this.nodeIsChild(node) && !_this.state.sorting) {\n          var useDragHandle = _this.props.useDragHandle;\n          var _node$sortableInfo = node.sortableInfo,\n              index = _node$sortableInfo.index,\n              collection = _node$sortableInfo.collection,\n              disabled = _node$sortableInfo.disabled;\n\n          if (disabled) {\n            return;\n          }\n\n          if (useDragHandle && !closest(event.target, isSortableHandle)) {\n            return;\n          }\n\n          _this.manager.active = {\n            collection: collection,\n            index: index\n          };\n\n          if (!isTouchEvent(event) && event.target.tagName === NodeType.Anchor) {\n            event.preventDefault();\n          }\n\n          if (!distance) {\n            if (_this.props.pressDelay === 0) {\n              _this.handlePress(event);\n            } else {\n              _this.pressTimer = setTimeout(function () {\n                return _this.handlePress(event);\n              }, _this.props.pressDelay);\n            }\n          }\n        }\n      });\n\n      _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"nodeIsChild\", function (node) {\n        return node.sortableInfo.manager === _this.manager;\n      });\n\n      _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"handleMove\", function (event) {\n        var _this$props2 = _this.props,\n            distance = _this$props2.distance,\n            pressThreshold = _this$props2.pressThreshold;\n\n        if (!_this.state.sorting && _this.touched && !_this._awaitingUpdateBeforeSortStart) {\n          var position = getPosition(event);\n          var delta = {\n            x: _this.position.x - position.x,\n            y: _this.position.y - position.y\n          };\n          var combinedDelta = Math.abs(delta.x) + Math.abs(delta.y);\n          _this.delta = delta;\n\n          if (!distance && (!pressThreshold || combinedDelta >= pressThreshold)) {\n            clearTimeout(_this.cancelTimer);\n            _this.cancelTimer = setTimeout(_this.cancel, 0);\n          } else if (distance && combinedDelta >= distance && _this.manager.isActive()) {\n            _this.handlePress(event);\n          }\n        }\n      });\n\n      _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"handleEnd\", function () {\n        _this.touched = false;\n\n        _this.cancel();\n      });\n\n      _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"cancel\", function () {\n        var distance = _this.props.distance;\n        var sorting = _this.state.sorting;\n\n        if (!sorting) {\n          if (!distance) {\n            clearTimeout(_this.pressTimer);\n          }\n\n          _this.manager.active = null;\n        }\n      });\n\n      _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"handlePress\", function (event) {\n        try {\n          var active = _this.manager.getActive();\n\n          var _temp6 = function () {\n            if (active) {\n              var _temp7 = function _temp7() {\n                var index = _node.sortableInfo.index;\n                var margin = getElementMargin(_node);\n                var gridGap = getContainerGridGap(_this.container);\n\n                var containerBoundingRect = _this.scrollContainer.getBoundingClientRect();\n\n                var dimensions = _getHelperDimensions({\n                  index: index,\n                  node: _node,\n                  collection: _collection\n                });\n\n                _this.node = _node;\n                _this.margin = margin;\n                _this.gridGap = gridGap;\n                _this.width = dimensions.width;\n                _this.height = dimensions.height;\n                _this.marginOffset = {\n                  x: _this.margin.left + _this.margin.right + _this.gridGap.x,\n                  y: Math.max(_this.margin.top, _this.margin.bottom, _this.gridGap.y)\n                };\n                _this.boundingClientRect = _node.getBoundingClientRect();\n                _this.containerBoundingRect = containerBoundingRect;\n                _this.index = index;\n                _this.newIndex = index;\n                _this.axis = {\n                  x: _axis.indexOf('x') >= 0,\n                  y: _axis.indexOf('y') >= 0\n                };\n                _this.offsetEdge = getEdgeOffset(_node, _this.container);\n\n                if (_isKeySorting) {\n                  _this.initialOffset = getPosition(_objectSpread({}, event, {\n                    pageX: _this.boundingClientRect.left,\n                    pageY: _this.boundingClientRect.top\n                  }));\n                } else {\n                  _this.initialOffset = getPosition(event);\n                }\n\n                _this.initialScroll = {\n                  left: _this.scrollContainer.scrollLeft,\n                  top: _this.scrollContainer.scrollTop\n                };\n                _this.initialWindowScroll = {\n                  left: window.pageXOffset,\n                  top: window.pageYOffset\n                };\n                _this.helper = _this.helperContainer.appendChild(cloneNode(_node));\n                setInlineStyles(_this.helper, {\n                  boxSizing: 'border-box',\n                  height: \"\".concat(_this.height, \"px\"),\n                  left: \"\".concat(_this.boundingClientRect.left - margin.left, \"px\"),\n                  pointerEvents: 'none',\n                  position: 'fixed',\n                  top: \"\".concat(_this.boundingClientRect.top - margin.top, \"px\"),\n                  width: \"\".concat(_this.width, \"px\")\n                });\n\n                if (_isKeySorting) {\n                  _this.helper.focus();\n                }\n\n                if (_hideSortableGhost) {\n                  _this.sortableGhost = _node;\n                  setInlineStyles(_node, {\n                    opacity: 0,\n                    visibility: 'hidden'\n                  });\n                }\n\n                _this.minTranslate = {};\n                _this.maxTranslate = {};\n\n                if (_isKeySorting) {\n                  var _ref = _useWindowAsScrollContainer ? {\n                    top: 0,\n                    left: 0,\n                    width: _this.contentWindow.innerWidth,\n                    height: _this.contentWindow.innerHeight\n                  } : _this.containerBoundingRect,\n                      containerTop = _ref.top,\n                      containerLeft = _ref.left,\n                      containerWidth = _ref.width,\n                      containerHeight = _ref.height;\n\n                  var containerBottom = containerTop + containerHeight;\n                  var containerRight = containerLeft + containerWidth;\n\n                  if (_this.axis.x) {\n                    _this.minTranslate.x = containerLeft - _this.boundingClientRect.left;\n                    _this.maxTranslate.x = containerRight - (_this.boundingClientRect.left + _this.width);\n                  }\n\n                  if (_this.axis.y) {\n                    _this.minTranslate.y = containerTop - _this.boundingClientRect.top;\n                    _this.maxTranslate.y = containerBottom - (_this.boundingClientRect.top + _this.height);\n                  }\n                } else {\n                  if (_this.axis.x) {\n                    _this.minTranslate.x = (_useWindowAsScrollContainer ? 0 : containerBoundingRect.left) - _this.boundingClientRect.left - _this.width / 2;\n                    _this.maxTranslate.x = (_useWindowAsScrollContainer ? _this.contentWindow.innerWidth : containerBoundingRect.left + containerBoundingRect.width) - _this.boundingClientRect.left - _this.width / 2;\n                  }\n\n                  if (_this.axis.y) {\n                    _this.minTranslate.y = (_useWindowAsScrollContainer ? 0 : containerBoundingRect.top) - _this.boundingClientRect.top - _this.height / 2;\n                    _this.maxTranslate.y = (_useWindowAsScrollContainer ? _this.contentWindow.innerHeight : containerBoundingRect.top + containerBoundingRect.height) - _this.boundingClientRect.top - _this.height / 2;\n                  }\n                }\n\n                if (_helperClass) {\n                  _helperClass.split(' ').forEach(function (className) {\n                    return _this.helper.classList.add(className);\n                  });\n                }\n\n                _this.listenerNode = event.touches ? _node : _this.contentWindow;\n\n                if (_isKeySorting) {\n                  _this.listenerNode.addEventListener('wheel', _this.handleKeyEnd, true);\n\n                  _this.listenerNode.addEventListener('mousedown', _this.handleKeyEnd, true);\n\n                  _this.listenerNode.addEventListener('keydown', _this.handleKeyDown);\n                } else {\n                  events.move.forEach(function (eventName) {\n                    return _this.listenerNode.addEventListener(eventName, _this.handleSortMove, false);\n                  });\n                  events.end.forEach(function (eventName) {\n                    return _this.listenerNode.addEventListener(eventName, _this.handleSortEnd, false);\n                  });\n                }\n\n                _this.setState({\n                  sorting: true,\n                  sortingIndex: index\n                });\n\n                if (_onSortStart) {\n                  _onSortStart({\n                    node: _node,\n                    index: index,\n                    collection: _collection,\n                    isKeySorting: _isKeySorting,\n                    nodes: _this.manager.getOrderedRefs(),\n                    helper: _this.helper\n                  }, event);\n                }\n\n                if (_isKeySorting) {\n                  _this.keyMove(0);\n                }\n              };\n\n              var _this$props3 = _this.props,\n                  _axis = _this$props3.axis,\n                  _getHelperDimensions = _this$props3.getHelperDimensions,\n                  _helperClass = _this$props3.helperClass,\n                  _hideSortableGhost = _this$props3.hideSortableGhost,\n                  updateBeforeSortStart = _this$props3.updateBeforeSortStart,\n                  _onSortStart = _this$props3.onSortStart,\n                  _useWindowAsScrollContainer = _this$props3.useWindowAsScrollContainer;\n              var _node = active.node,\n                  _collection = active.collection;\n              var _isKeySorting = _this.manager.isKeySorting;\n\n              var _temp8 = function () {\n                if (typeof updateBeforeSortStart === 'function') {\n                  _this._awaitingUpdateBeforeSortStart = true;\n\n                  var _temp9 = _finallyRethrows(function () {\n                    var index = _node.sortableInfo.index;\n                    return Promise.resolve(updateBeforeSortStart({\n                      collection: _collection,\n                      index: index,\n                      node: _node,\n                      isKeySorting: _isKeySorting\n                    }, event)).then(function () {});\n                  }, function (_wasThrown, _result) {\n                    _this._awaitingUpdateBeforeSortStart = false;\n                    if (_wasThrown) throw _result;\n                    return _result;\n                  });\n\n                  if (_temp9 && _temp9.then) return _temp9.then(function () {});\n                }\n              }();\n\n              return _temp8 && _temp8.then ? _temp8.then(_temp7) : _temp7(_temp8);\n            }\n          }();\n\n          return Promise.resolve(_temp6 && _temp6.then ? _temp6.then(function () {}) : void 0);\n        } catch (e) {\n          return Promise.reject(e);\n        }\n      });\n\n      _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"handleSortMove\", function (event) {\n        var onSortMove = _this.props.onSortMove;\n\n        if (typeof event.preventDefault === 'function') {\n          event.preventDefault();\n        }\n\n        _this.updateHelperPosition(event);\n\n        _this.animateNodes();\n\n        _this.autoscroll();\n\n        if (onSortMove) {\n          onSortMove(event);\n        }\n      });\n\n      _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"handleSortEnd\", function (event) {\n        var _this$props4 = _this.props,\n            hideSortableGhost = _this$props4.hideSortableGhost,\n            onSortEnd = _this$props4.onSortEnd;\n        var _this$manager = _this.manager,\n            collection = _this$manager.active.collection,\n            isKeySorting = _this$manager.isKeySorting;\n\n        var nodes = _this.manager.getOrderedRefs();\n\n        if (_this.listenerNode) {\n          if (isKeySorting) {\n            _this.listenerNode.removeEventListener('wheel', _this.handleKeyEnd, true);\n\n            _this.listenerNode.removeEventListener('mousedown', _this.handleKeyEnd, true);\n\n            _this.listenerNode.removeEventListener('keydown', _this.handleKeyDown);\n          } else {\n            events.move.forEach(function (eventName) {\n              return _this.listenerNode.removeEventListener(eventName, _this.handleSortMove);\n            });\n            events.end.forEach(function (eventName) {\n              return _this.listenerNode.removeEventListener(eventName, _this.handleSortEnd);\n            });\n          }\n        }\n\n        _this.helper.parentNode.removeChild(_this.helper);\n\n        if (hideSortableGhost && _this.sortableGhost) {\n          setInlineStyles(_this.sortableGhost, {\n            opacity: '',\n            visibility: ''\n          });\n        }\n\n        for (var i = 0, len = nodes.length; i < len; i++) {\n          var _node2 = nodes[i];\n          var el = _node2.node;\n          _node2.edgeOffset = null;\n          _node2.boundingClientRect = null;\n          setTranslate3d(el, null);\n          setTransitionDuration(el, null);\n          _node2.translate = null;\n        }\n\n        _this.autoScroller.clear();\n\n        _this.manager.active = null;\n        _this.manager.isKeySorting = false;\n\n        _this.setState({\n          sorting: false,\n          sortingIndex: null\n        });\n\n        if (typeof onSortEnd === 'function') {\n          onSortEnd({\n            collection: collection,\n            newIndex: _this.newIndex,\n            oldIndex: _this.index,\n            isKeySorting: isKeySorting,\n            nodes: nodes\n          }, event);\n        }\n\n        _this.touched = false;\n      });\n\n      _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"autoscroll\", function () {\n        var disableAutoscroll = _this.props.disableAutoscroll;\n        var isKeySorting = _this.manager.isKeySorting;\n\n        if (disableAutoscroll) {\n          _this.autoScroller.clear();\n\n          return;\n        }\n\n        if (isKeySorting) {\n          var translate = _objectSpread({}, _this.translate);\n\n          var scrollX = 0;\n          var scrollY = 0;\n\n          if (_this.axis.x) {\n            translate.x = Math.min(_this.maxTranslate.x, Math.max(_this.minTranslate.x, _this.translate.x));\n            scrollX = _this.translate.x - translate.x;\n          }\n\n          if (_this.axis.y) {\n            translate.y = Math.min(_this.maxTranslate.y, Math.max(_this.minTranslate.y, _this.translate.y));\n            scrollY = _this.translate.y - translate.y;\n          }\n\n          _this.translate = translate;\n          setTranslate3d(_this.helper, _this.translate);\n          _this.scrollContainer.scrollLeft += scrollX;\n          _this.scrollContainer.scrollTop += scrollY;\n          return;\n        }\n\n        _this.autoScroller.update({\n          height: _this.height,\n          maxTranslate: _this.maxTranslate,\n          minTranslate: _this.minTranslate,\n          translate: _this.translate,\n          width: _this.width\n        });\n      });\n\n      _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"onAutoScroll\", function (offset) {\n        _this.translate.x += offset.left;\n        _this.translate.y += offset.top;\n\n        _this.animateNodes();\n      });\n\n      _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"handleKeyDown\", function (event) {\n        var keyCode = event.keyCode;\n        var _this$props5 = _this.props,\n            shouldCancelStart = _this$props5.shouldCancelStart,\n            _this$props5$keyCodes = _this$props5.keyCodes,\n            customKeyCodes = _this$props5$keyCodes === void 0 ? {} : _this$props5$keyCodes;\n\n        var keyCodes = _objectSpread({}, defaultKeyCodes, customKeyCodes);\n\n        if (_this.manager.active && !_this.manager.isKeySorting || !_this.manager.active && (!keyCodes.lift.includes(keyCode) || shouldCancelStart(event) || !_this.isValidSortingTarget(event))) {\n          return;\n        }\n\n        event.stopPropagation();\n        event.preventDefault();\n\n        if (keyCodes.lift.includes(keyCode) && !_this.manager.active) {\n          _this.keyLift(event);\n        } else if (keyCodes.drop.includes(keyCode) && _this.manager.active) {\n          _this.keyDrop(event);\n        } else if (keyCodes.cancel.includes(keyCode)) {\n          _this.newIndex = _this.manager.active.index;\n\n          _this.keyDrop(event);\n        } else if (keyCodes.up.includes(keyCode)) {\n          _this.keyMove(-1);\n        } else if (keyCodes.down.includes(keyCode)) {\n          _this.keyMove(1);\n        }\n      });\n\n      _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"keyLift\", function (event) {\n        var target = event.target;\n        var node = closest(target, function (el) {\n          return el.sortableInfo != null;\n        });\n        var _node$sortableInfo2 = node.sortableInfo,\n            index = _node$sortableInfo2.index,\n            collection = _node$sortableInfo2.collection;\n        _this.initialFocusedNode = target;\n        _this.manager.isKeySorting = true;\n        _this.manager.active = {\n          index: index,\n          collection: collection\n        };\n\n        _this.handlePress(event);\n      });\n\n      _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"keyMove\", function (shift) {\n        var nodes = _this.manager.getOrderedRefs();\n\n        var lastIndex = nodes[nodes.length - 1].node.sortableInfo.index;\n        var newIndex = _this.newIndex + shift;\n        var prevIndex = _this.newIndex;\n\n        if (newIndex < 0 || newIndex > lastIndex) {\n          return;\n        }\n\n        _this.prevIndex = prevIndex;\n        _this.newIndex = newIndex;\n        var targetIndex = getTargetIndex(_this.newIndex, _this.prevIndex, _this.index);\n        var target = nodes.find(function (_ref2) {\n          var node = _ref2.node;\n          return node.sortableInfo.index === targetIndex;\n        });\n        var targetNode = target.node;\n        var scrollDelta = _this.containerScrollDelta;\n        var targetBoundingClientRect = target.boundingClientRect || getScrollAdjustedBoundingClientRect(targetNode, scrollDelta);\n        var targetTranslate = target.translate || {\n          x: 0,\n          y: 0\n        };\n        var targetPosition = {\n          top: targetBoundingClientRect.top + targetTranslate.y - scrollDelta.top,\n          left: targetBoundingClientRect.left + targetTranslate.x - scrollDelta.left\n        };\n        var shouldAdjustForSize = prevIndex < newIndex;\n        var sizeAdjustment = {\n          x: shouldAdjustForSize && _this.axis.x ? targetNode.offsetWidth - _this.width : 0,\n          y: shouldAdjustForSize && _this.axis.y ? targetNode.offsetHeight - _this.height : 0\n        };\n\n        _this.handleSortMove({\n          pageX: targetPosition.left + sizeAdjustment.x,\n          pageY: targetPosition.top + sizeAdjustment.y,\n          ignoreTransition: shift === 0\n        });\n      });\n\n      _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"keyDrop\", function (event) {\n        _this.handleSortEnd(event);\n\n        if (_this.initialFocusedNode) {\n          _this.initialFocusedNode.focus();\n        }\n      });\n\n      _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"handleKeyEnd\", function (event) {\n        if (_this.manager.active) {\n          _this.keyDrop(event);\n        }\n      });\n\n      _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"isValidSortingTarget\", function (event) {\n        var useDragHandle = _this.props.useDragHandle;\n        var target = event.target;\n        var node = closest(target, function (el) {\n          return el.sortableInfo != null;\n        });\n        return node && node.sortableInfo && !node.sortableInfo.disabled && (useDragHandle ? isSortableHandle(target) : target.sortableInfo);\n      });\n\n      validateProps(props);\n      _this.manager = new Manager();\n      _this.events = {\n        end: _this.handleEnd,\n        move: _this.handleMove,\n        start: _this.handleStart\n      };\n      return _this;\n    }\n\n    _createClass(WithSortableContainer, [{\n      key: \"getChildContext\",\n      value: function getChildContext() {\n        return {\n          manager: this.manager\n        };\n      }\n    }, {\n      key: \"componentDidMount\",\n      value: function componentDidMount() {\n        var _this2 = this;\n\n        var useWindowAsScrollContainer = this.props.useWindowAsScrollContainer;\n        var container = this.getContainer();\n        Promise.resolve(container).then(function (containerNode) {\n          _this2.container = containerNode;\n          _this2.document = _this2.container.ownerDocument || document;\n          var contentWindow = _this2.props.contentWindow || _this2.document.defaultView || window;\n          _this2.contentWindow = typeof contentWindow === 'function' ? contentWindow() : contentWindow;\n          _this2.scrollContainer = useWindowAsScrollContainer ? _this2.document.scrollingElement || _this2.document.documentElement : getScrollingParent(_this2.container) || _this2.container;\n          _this2.autoScroller = new AutoScroller(_this2.scrollContainer, _this2.onAutoScroll);\n          Object.keys(_this2.events).forEach(function (key) {\n            return events[key].forEach(function (eventName) {\n              return _this2.container.addEventListener(eventName, _this2.events[key], false);\n            });\n          });\n\n          _this2.container.addEventListener('keydown', _this2.handleKeyDown);\n        });\n      }\n    }, {\n      key: \"componentWillUnmount\",\n      value: function componentWillUnmount() {\n        var _this3 = this;\n\n        if (this.helper && this.helper.parentNode) {\n          this.helper.parentNode.removeChild(this.helper);\n        }\n\n        if (!this.container) {\n          return;\n        }\n\n        Object.keys(this.events).forEach(function (key) {\n          return events[key].forEach(function (eventName) {\n            return _this3.container.removeEventListener(eventName, _this3.events[key]);\n          });\n        });\n        this.container.removeEventListener('keydown', this.handleKeyDown);\n      }\n    }, {\n      key: \"updateHelperPosition\",\n      value: function updateHelperPosition(event) {\n        var _this$props6 = this.props,\n            lockAxis = _this$props6.lockAxis,\n            lockOffset = _this$props6.lockOffset,\n            lockToContainerEdges = _this$props6.lockToContainerEdges,\n            transitionDuration = _this$props6.transitionDuration,\n            _this$props6$keyboard = _this$props6.keyboardSortingTransitionDuration,\n            keyboardSortingTransitionDuration = _this$props6$keyboard === void 0 ? transitionDuration : _this$props6$keyboard;\n        var isKeySorting = this.manager.isKeySorting;\n        var ignoreTransition = event.ignoreTransition;\n        var offset = getPosition(event);\n        var translate = {\n          x: offset.x - this.initialOffset.x,\n          y: offset.y - this.initialOffset.y\n        };\n        translate.y -= window.pageYOffset - this.initialWindowScroll.top;\n        translate.x -= window.pageXOffset - this.initialWindowScroll.left;\n        this.translate = translate;\n\n        if (lockToContainerEdges) {\n          var _getLockPixelOffsets = getLockPixelOffsets({\n            height: this.height,\n            lockOffset: lockOffset,\n            width: this.width\n          }),\n              _getLockPixelOffsets2 = _slicedToArray(_getLockPixelOffsets, 2),\n              minLockOffset = _getLockPixelOffsets2[0],\n              maxLockOffset = _getLockPixelOffsets2[1];\n\n          var minOffset = {\n            x: this.width / 2 - minLockOffset.x,\n            y: this.height / 2 - minLockOffset.y\n          };\n          var maxOffset = {\n            x: this.width / 2 - maxLockOffset.x,\n            y: this.height / 2 - maxLockOffset.y\n          };\n          translate.x = limit(this.minTranslate.x + minOffset.x, this.maxTranslate.x - maxOffset.x, translate.x);\n          translate.y = limit(this.minTranslate.y + minOffset.y, this.maxTranslate.y - maxOffset.y, translate.y);\n        }\n\n        if (lockAxis === 'x') {\n          translate.y = 0;\n        } else if (lockAxis === 'y') {\n          translate.x = 0;\n        }\n\n        if (isKeySorting && keyboardSortingTransitionDuration && !ignoreTransition) {\n          setTransitionDuration(this.helper, keyboardSortingTransitionDuration);\n        }\n\n        setTranslate3d(this.helper, translate);\n      }\n    }, {\n      key: \"animateNodes\",\n      value: function animateNodes() {\n        var _this$props7 = this.props,\n            transitionDuration = _this$props7.transitionDuration,\n            hideSortableGhost = _this$props7.hideSortableGhost,\n            onSortOver = _this$props7.onSortOver;\n        var containerScrollDelta = this.containerScrollDelta,\n            windowScrollDelta = this.windowScrollDelta;\n        var nodes = this.manager.getOrderedRefs();\n        var sortingOffset = {\n          left: this.offsetEdge.left + this.translate.x + containerScrollDelta.left,\n          top: this.offsetEdge.top + this.translate.y + containerScrollDelta.top\n        };\n        var isKeySorting = this.manager.isKeySorting;\n        var prevIndex = this.newIndex;\n        this.newIndex = null;\n\n        for (var i = 0, len = nodes.length; i < len; i++) {\n          var _node3 = nodes[i].node;\n          var index = _node3.sortableInfo.index;\n          var width = _node3.offsetWidth;\n          var height = _node3.offsetHeight;\n          var offset = {\n            height: this.height > height ? height / 2 : this.height / 2,\n            width: this.width > width ? width / 2 : this.width / 2\n          };\n          var mustShiftBackward = isKeySorting && index > this.index && index <= prevIndex;\n          var mustShiftForward = isKeySorting && index < this.index && index >= prevIndex;\n          var translate = {\n            x: 0,\n            y: 0\n          };\n          var edgeOffset = nodes[i].edgeOffset;\n\n          if (!edgeOffset) {\n            edgeOffset = getEdgeOffset(_node3, this.container);\n            nodes[i].edgeOffset = edgeOffset;\n\n            if (isKeySorting) {\n              nodes[i].boundingClientRect = getScrollAdjustedBoundingClientRect(_node3, containerScrollDelta);\n            }\n          }\n\n          var nextNode = i < nodes.length - 1 && nodes[i + 1];\n          var prevNode = i > 0 && nodes[i - 1];\n\n          if (nextNode && !nextNode.edgeOffset) {\n            nextNode.edgeOffset = getEdgeOffset(nextNode.node, this.container);\n\n            if (isKeySorting) {\n              nextNode.boundingClientRect = getScrollAdjustedBoundingClientRect(nextNode.node, containerScrollDelta);\n            }\n          }\n\n          if (index === this.index) {\n            if (hideSortableGhost) {\n              this.sortableGhost = _node3;\n              setInlineStyles(_node3, {\n                opacity: 0,\n                visibility: 'hidden'\n              });\n            }\n\n            continue;\n          }\n\n          if (transitionDuration) {\n            setTransitionDuration(_node3, transitionDuration);\n          }\n\n          if (this.axis.x) {\n            if (this.axis.y) {\n              if (mustShiftForward || index < this.index && (sortingOffset.left + windowScrollDelta.left - offset.width <= edgeOffset.left && sortingOffset.top + windowScrollDelta.top <= edgeOffset.top + offset.height || sortingOffset.top + windowScrollDelta.top + offset.height <= edgeOffset.top)) {\n                translate.x = this.width + this.marginOffset.x;\n\n                if (edgeOffset.left + translate.x > this.containerBoundingRect.width - offset.width) {\n                  if (nextNode) {\n                    translate.x = nextNode.edgeOffset.left - edgeOffset.left;\n                    translate.y = nextNode.edgeOffset.top - edgeOffset.top;\n                  }\n                }\n\n                if (this.newIndex === null) {\n                  this.newIndex = index;\n                }\n              } else if (mustShiftBackward || index > this.index && (sortingOffset.left + windowScrollDelta.left + offset.width >= edgeOffset.left && sortingOffset.top + windowScrollDelta.top + offset.height >= edgeOffset.top || sortingOffset.top + windowScrollDelta.top + offset.height >= edgeOffset.top + height)) {\n                translate.x = -(this.width + this.marginOffset.x);\n\n                if (edgeOffset.left + translate.x < this.containerBoundingRect.left + offset.width) {\n                  if (prevNode) {\n                    translate.x = prevNode.edgeOffset.left - edgeOffset.left;\n                    translate.y = prevNode.edgeOffset.top - edgeOffset.top;\n                  }\n                }\n\n                this.newIndex = index;\n              }\n            } else {\n              if (mustShiftBackward || index > this.index && sortingOffset.left + windowScrollDelta.left + offset.width >= edgeOffset.left) {\n                translate.x = -(this.width + this.marginOffset.x);\n                this.newIndex = index;\n              } else if (mustShiftForward || index < this.index && sortingOffset.left + windowScrollDelta.left <= edgeOffset.left + offset.width) {\n                translate.x = this.width + this.marginOffset.x;\n\n                if (this.newIndex == null) {\n                  this.newIndex = index;\n                }\n              }\n            }\n          } else if (this.axis.y) {\n            if (mustShiftBackward || index > this.index && sortingOffset.top + windowScrollDelta.top + offset.height >= edgeOffset.top) {\n              translate.y = -(this.height + this.marginOffset.y);\n              this.newIndex = index;\n            } else if (mustShiftForward || index < this.index && sortingOffset.top + windowScrollDelta.top <= edgeOffset.top + offset.height) {\n              translate.y = this.height + this.marginOffset.y;\n\n              if (this.newIndex == null) {\n                this.newIndex = index;\n              }\n            }\n          }\n\n          setTranslate3d(_node3, translate);\n          nodes[i].translate = translate;\n        }\n\n        if (this.newIndex == null) {\n          this.newIndex = this.index;\n        }\n\n        if (isKeySorting) {\n          this.newIndex = prevIndex;\n        }\n\n        var oldIndex = isKeySorting ? this.prevIndex : prevIndex;\n\n        if (onSortOver && this.newIndex !== oldIndex) {\n          onSortOver({\n            collection: this.manager.active.collection,\n            index: this.index,\n            newIndex: this.newIndex,\n            oldIndex: oldIndex,\n            isKeySorting: isKeySorting,\n            nodes: nodes,\n            helper: this.helper\n          });\n        }\n      }\n    }, {\n      key: \"getWrappedInstance\",\n      value: function getWrappedInstance() {\n        invariant(config.withRef, 'To access the wrapped instance, you need to pass in {withRef: true} as the second argument of the SortableContainer() call');\n        return this.refs.wrappedInstance;\n      }\n    }, {\n      key: \"getContainer\",\n      value: function getContainer() {\n        var getContainer = this.props.getContainer;\n\n        if (typeof getContainer !== 'function') {\n          return findDOMNode(this);\n        }\n\n        return getContainer(config.withRef ? this.getWrappedInstance() : undefined);\n      }\n    }, {\n      key: \"render\",\n      value: function render() {\n        var ref = config.withRef ? 'wrappedInstance' : null;\n        return createElement(WrappedComponent, _extends({\n          ref: ref\n        }, omit(this.props, omittedProps)));\n      }\n    }, {\n      key: \"helperContainer\",\n      get: function get() {\n        var helperContainer = this.props.helperContainer;\n\n        if (typeof helperContainer === 'function') {\n          return helperContainer();\n        }\n\n        return this.props.helperContainer || this.document.body;\n      }\n    }, {\n      key: \"containerScrollDelta\",\n      get: function get() {\n        var useWindowAsScrollContainer = this.props.useWindowAsScrollContainer;\n\n        if (useWindowAsScrollContainer) {\n          return {\n            left: 0,\n            top: 0\n          };\n        }\n\n        return {\n          left: this.scrollContainer.scrollLeft - this.initialScroll.left,\n          top: this.scrollContainer.scrollTop - this.initialScroll.top\n        };\n      }\n    }, {\n      key: \"windowScrollDelta\",\n      get: function get() {\n        return {\n          left: this.contentWindow.pageXOffset - this.initialWindowScroll.left,\n          top: this.contentWindow.pageYOffset - this.initialWindowScroll.top\n        };\n      }\n    }]);\n\n    return WithSortableContainer;\n  }(Component), _defineProperty(_class, \"displayName\", provideDisplayName('sortableList', WrappedComponent)), _defineProperty(_class, \"defaultProps\", defaultProps), _defineProperty(_class, \"propTypes\", propTypes), _defineProperty(_class, \"childContextTypes\", {\n    manager: PropTypes.object.isRequired\n  }), _temp;\n}\n\nvar propTypes$1 = {\n  index: PropTypes.number.isRequired,\n  collection: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n  disabled: PropTypes.bool\n};\nvar omittedProps$1 = Object.keys(propTypes$1);\nfunction sortableElement(WrappedComponent) {\n  var _class, _temp;\n\n  var config = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n    withRef: false\n  };\n  return _temp = _class = function (_React$Component) {\n    _inherits(WithSortableElement, _React$Component);\n\n    function WithSortableElement() {\n      _classCallCheck(this, WithSortableElement);\n\n      return _possibleConstructorReturn(this, _getPrototypeOf(WithSortableElement).apply(this, arguments));\n    }\n\n    _createClass(WithSortableElement, [{\n      key: \"componentDidMount\",\n      value: function componentDidMount() {\n        this.register();\n      }\n    }, {\n      key: \"componentDidUpdate\",\n      value: function componentDidUpdate(prevProps) {\n        if (this.node) {\n          if (prevProps.index !== this.props.index) {\n            this.node.sortableInfo.index = this.props.index;\n          }\n\n          if (prevProps.disabled !== this.props.disabled) {\n            this.node.sortableInfo.disabled = this.props.disabled;\n          }\n        }\n\n        if (prevProps.collection !== this.props.collection) {\n          this.unregister(prevProps.collection);\n          this.register();\n        }\n      }\n    }, {\n      key: \"componentWillUnmount\",\n      value: function componentWillUnmount() {\n        this.unregister();\n      }\n    }, {\n      key: \"register\",\n      value: function register() {\n        var _this$props = this.props,\n            collection = _this$props.collection,\n            disabled = _this$props.disabled,\n            index = _this$props.index;\n        var node = findDOMNode(this);\n        node.sortableInfo = {\n          collection: collection,\n          disabled: disabled,\n          index: index,\n          manager: this.context.manager\n        };\n        this.node = node;\n        this.ref = {\n          node: node\n        };\n        this.context.manager.add(collection, this.ref);\n      }\n    }, {\n      key: \"unregister\",\n      value: function unregister() {\n        var collection = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.props.collection;\n        this.context.manager.remove(collection, this.ref);\n      }\n    }, {\n      key: \"getWrappedInstance\",\n      value: function getWrappedInstance() {\n        invariant(config.withRef, 'To access the wrapped instance, you need to pass in {withRef: true} as the second argument of the SortableElement() call');\n        return this.refs.wrappedInstance;\n      }\n    }, {\n      key: \"render\",\n      value: function render() {\n        var ref = config.withRef ? 'wrappedInstance' : null;\n        return createElement(WrappedComponent, _extends({\n          ref: ref\n        }, omit(this.props, omittedProps$1)));\n      }\n    }]);\n\n    return WithSortableElement;\n  }(Component), _defineProperty(_class, \"displayName\", provideDisplayName('sortableElement', WrappedComponent)), _defineProperty(_class, \"contextTypes\", {\n    manager: PropTypes.object.isRequired\n  }), _defineProperty(_class, \"propTypes\", propTypes$1), _defineProperty(_class, \"defaultProps\", {\n    collection: 0\n  }), _temp;\n}\n\nexport { sortableContainer as SortableContainer, sortableContainer, sortableElement as SortableElement, sortableElement, sortableHandle as SortableHandle, sortableHandle, arrayMove };\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///6362\n')},4823:(__unused_webpack_module,exports,__webpack_require__)=>{"use strict";eval("var __webpack_unused_export__;\n\n\n__webpack_unused_export__ = ({ value: true });\n\nfunction _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'default' in ex) ? ex['default'] : ex; }\n\nvar _objectWithoutPropertiesLoose = _interopDefault(__webpack_require__(3366));\nvar _extends = _interopDefault(__webpack_require__(7462));\nvar React = __webpack_require__(7363);\nvar React__default = _interopDefault(React);\nvar ReactDOM = _interopDefault(__webpack_require__(1533));\n\nlet bugfixes = undefined;\nlet applyAnimatedValues = undefined;\nlet colorNames = [];\nlet requestFrame = cb => typeof window !== 'undefined' && window.requestAnimationFrame(cb);\nlet cancelFrame = cb => typeof window !== 'undefined' && window.cancelAnimationFrame(cb);\nlet interpolation = undefined;\nlet now = () => Date.now();\nlet defaultElement = undefined;\nlet createAnimatedStyle = undefined;\nconst injectApplyAnimatedValues = (fn, transform) => applyAnimatedValues = {\n fn,\n transform\n};\nconst injectColorNames = names => colorNames = names;\nconst injectBugfixes = fn => bugfixes = fn;\nconst injectInterpolation = cls => interpolation = cls;\nconst injectFrame = (raf, caf) => {\n var _ref = [raf, caf];\n requestFrame = _ref[0];\n cancelFrame = _ref[1];\n return _ref;\n};\nconst injectNow = nowFn => now = nowFn;\nconst injectDefaultElement = el => defaultElement = el;\nconst injectCreateAnimatedStyle = factory => createAnimatedStyle = factory;\n\nvar Globals = /*#__PURE__*/Object.freeze({\n get bugfixes () { return bugfixes; },\n get applyAnimatedValues () { return applyAnimatedValues; },\n get colorNames () { return colorNames; },\n get requestFrame () { return requestFrame; },\n get cancelFrame () { return cancelFrame; },\n get interpolation () { return interpolation; },\n get now () { return now; },\n get defaultElement () { return defaultElement; },\n get createAnimatedStyle () { return createAnimatedStyle; },\n injectApplyAnimatedValues: injectApplyAnimatedValues,\n injectColorNames: injectColorNames,\n injectBugfixes: injectBugfixes,\n injectInterpolation: injectInterpolation,\n injectFrame: injectFrame,\n injectNow: injectNow,\n injectDefaultElement: injectDefaultElement,\n injectCreateAnimatedStyle: injectCreateAnimatedStyle\n});\n\nclass Animated {\n attach() {}\n\n detach() {}\n\n getValue() {}\n\n getAnimatedValue() {\n return this.getValue();\n }\n\n addChild(child) {}\n\n removeChild(child) {}\n\n getChildren() {\n return [];\n }\n\n}\n\nconst getValues = object => Object.keys(object).map(k => object[k]);\n\nclass AnimatedWithChildren extends Animated {\n constructor() {\n var _this;\n\n super(...arguments);\n _this = this;\n this.children = [];\n\n this.getChildren = () => this.children;\n\n this.getPayload = function (index) {\n if (index === void 0) {\n index = undefined;\n }\n\n return index !== void 0 && _this.payload ? _this.payload[index] : _this.payload || _this;\n };\n }\n\n addChild(child) {\n if (this.children.length === 0) this.attach();\n this.children.push(child);\n }\n\n removeChild(child) {\n const index = this.children.indexOf(child);\n this.children.splice(index, 1);\n if (this.children.length === 0) this.detach();\n }\n\n}\nclass AnimatedArrayWithChildren extends AnimatedWithChildren {\n constructor() {\n super(...arguments);\n this.payload = [];\n\n this.getAnimatedValue = () => this.getValue();\n\n this.attach = () => this.payload.forEach(p => p instanceof Animated && p.addChild(this));\n\n this.detach = () => this.payload.forEach(p => p instanceof Animated && p.removeChild(this));\n }\n\n}\nclass AnimatedObjectWithChildren extends AnimatedWithChildren {\n constructor() {\n super(...arguments);\n this.payload = {};\n\n this.getAnimatedValue = () => this.getValue(true);\n\n this.attach = () => getValues(this.payload).forEach(s => s instanceof Animated && s.addChild(this));\n\n this.detach = () => getValues(this.payload).forEach(s => s instanceof Animated && s.removeChild(this));\n }\n\n getValue(animated) {\n if (animated === void 0) {\n animated = false;\n }\n\n const payload = {};\n\n for (const key in this.payload) {\n const value = this.payload[key];\n if (animated && !(value instanceof Animated)) continue;\n payload[key] = value instanceof Animated ? value[animated ? 'getAnimatedValue' : 'getValue']() : value;\n }\n\n return payload;\n }\n\n}\n\nclass AnimatedStyle extends AnimatedObjectWithChildren {\n constructor(style) {\n super();\n style = style || {};\n if (style.transform && !(style.transform instanceof Animated)) style = applyAnimatedValues.transform(style);\n this.payload = style;\n }\n\n}\n\n// http://www.w3.org/TR/css3-color/#svg-color\nconst colors = {\n transparent: 0x00000000,\n aliceblue: 0xf0f8ffff,\n antiquewhite: 0xfaebd7ff,\n aqua: 0x00ffffff,\n aquamarine: 0x7fffd4ff,\n azure: 0xf0ffffff,\n beige: 0xf5f5dcff,\n bisque: 0xffe4c4ff,\n black: 0x000000ff,\n blanchedalmond: 0xffebcdff,\n blue: 0x0000ffff,\n blueviolet: 0x8a2be2ff,\n brown: 0xa52a2aff,\n burlywood: 0xdeb887ff,\n burntsienna: 0xea7e5dff,\n cadetblue: 0x5f9ea0ff,\n chartreuse: 0x7fff00ff,\n chocolate: 0xd2691eff,\n coral: 0xff7f50ff,\n cornflowerblue: 0x6495edff,\n cornsilk: 0xfff8dcff,\n crimson: 0xdc143cff,\n cyan: 0x00ffffff,\n darkblue: 0x00008bff,\n darkcyan: 0x008b8bff,\n darkgoldenrod: 0xb8860bff,\n darkgray: 0xa9a9a9ff,\n darkgreen: 0x006400ff,\n darkgrey: 0xa9a9a9ff,\n darkkhaki: 0xbdb76bff,\n darkmagenta: 0x8b008bff,\n darkolivegreen: 0x556b2fff,\n darkorange: 0xff8c00ff,\n darkorchid: 0x9932ccff,\n darkred: 0x8b0000ff,\n darksalmon: 0xe9967aff,\n darkseagreen: 0x8fbc8fff,\n darkslateblue: 0x483d8bff,\n darkslategray: 0x2f4f4fff,\n darkslategrey: 0x2f4f4fff,\n darkturquoise: 0x00ced1ff,\n darkviolet: 0x9400d3ff,\n deeppink: 0xff1493ff,\n deepskyblue: 0x00bfffff,\n dimgray: 0x696969ff,\n dimgrey: 0x696969ff,\n dodgerblue: 0x1e90ffff,\n firebrick: 0xb22222ff,\n floralwhite: 0xfffaf0ff,\n forestgreen: 0x228b22ff,\n fuchsia: 0xff00ffff,\n gainsboro: 0xdcdcdcff,\n ghostwhite: 0xf8f8ffff,\n gold: 0xffd700ff,\n goldenrod: 0xdaa520ff,\n gray: 0x808080ff,\n green: 0x008000ff,\n greenyellow: 0xadff2fff,\n grey: 0x808080ff,\n honeydew: 0xf0fff0ff,\n hotpink: 0xff69b4ff,\n indianred: 0xcd5c5cff,\n indigo: 0x4b0082ff,\n ivory: 0xfffff0ff,\n khaki: 0xf0e68cff,\n lavender: 0xe6e6faff,\n lavenderblush: 0xfff0f5ff,\n lawngreen: 0x7cfc00ff,\n lemonchiffon: 0xfffacdff,\n lightblue: 0xadd8e6ff,\n lightcoral: 0xf08080ff,\n lightcyan: 0xe0ffffff,\n lightgoldenrodyellow: 0xfafad2ff,\n lightgray: 0xd3d3d3ff,\n lightgreen: 0x90ee90ff,\n lightgrey: 0xd3d3d3ff,\n lightpink: 0xffb6c1ff,\n lightsalmon: 0xffa07aff,\n lightseagreen: 0x20b2aaff,\n lightskyblue: 0x87cefaff,\n lightslategray: 0x778899ff,\n lightslategrey: 0x778899ff,\n lightsteelblue: 0xb0c4deff,\n lightyellow: 0xffffe0ff,\n lime: 0x00ff00ff,\n limegreen: 0x32cd32ff,\n linen: 0xfaf0e6ff,\n magenta: 0xff00ffff,\n maroon: 0x800000ff,\n mediumaquamarine: 0x66cdaaff,\n mediumblue: 0x0000cdff,\n mediumorchid: 0xba55d3ff,\n mediumpurple: 0x9370dbff,\n mediumseagreen: 0x3cb371ff,\n mediumslateblue: 0x7b68eeff,\n mediumspringgreen: 0x00fa9aff,\n mediumturquoise: 0x48d1ccff,\n mediumvioletred: 0xc71585ff,\n midnightblue: 0x191970ff,\n mintcream: 0xf5fffaff,\n mistyrose: 0xffe4e1ff,\n moccasin: 0xffe4b5ff,\n navajowhite: 0xffdeadff,\n navy: 0x000080ff,\n oldlace: 0xfdf5e6ff,\n olive: 0x808000ff,\n olivedrab: 0x6b8e23ff,\n orange: 0xffa500ff,\n orangered: 0xff4500ff,\n orchid: 0xda70d6ff,\n palegoldenrod: 0xeee8aaff,\n palegreen: 0x98fb98ff,\n paleturquoise: 0xafeeeeff,\n palevioletred: 0xdb7093ff,\n papayawhip: 0xffefd5ff,\n peachpuff: 0xffdab9ff,\n peru: 0xcd853fff,\n pink: 0xffc0cbff,\n plum: 0xdda0ddff,\n powderblue: 0xb0e0e6ff,\n purple: 0x800080ff,\n rebeccapurple: 0x663399ff,\n red: 0xff0000ff,\n rosybrown: 0xbc8f8fff,\n royalblue: 0x4169e1ff,\n saddlebrown: 0x8b4513ff,\n salmon: 0xfa8072ff,\n sandybrown: 0xf4a460ff,\n seagreen: 0x2e8b57ff,\n seashell: 0xfff5eeff,\n sienna: 0xa0522dff,\n silver: 0xc0c0c0ff,\n skyblue: 0x87ceebff,\n slateblue: 0x6a5acdff,\n slategray: 0x708090ff,\n slategrey: 0x708090ff,\n snow: 0xfffafaff,\n springgreen: 0x00ff7fff,\n steelblue: 0x4682b4ff,\n tan: 0xd2b48cff,\n teal: 0x008080ff,\n thistle: 0xd8bfd8ff,\n tomato: 0xff6347ff,\n turquoise: 0x40e0d0ff,\n violet: 0xee82eeff,\n wheat: 0xf5deb3ff,\n white: 0xffffffff,\n whitesmoke: 0xf5f5f5ff,\n yellow: 0xffff00ff,\n yellowgreen: 0x9acd32ff\n};\n\nclass Interpolation {\n // Default config = config, args\n // Short config = range, output, extrapolate\n static create(config, output, extra) {\n if (typeof config === 'function') return config;else if (interpolation && config.output && typeof config.output[0] === 'string') return interpolation(config);else if (Array.isArray(config)) return Interpolation.create({\n range: config,\n output,\n extrapolate: extra || 'extend'\n });\n let outputRange = config.output;\n let inputRange = config.range || [0, 1];\n\n let easing = config.easing || (t => t);\n\n let extrapolateLeft = 'extend';\n let map = config.map;\n if (config.extrapolateLeft !== undefined) extrapolateLeft = config.extrapolateLeft;else if (config.extrapolate !== undefined) extrapolateLeft = config.extrapolate;\n let extrapolateRight = 'extend';\n if (config.extrapolateRight !== undefined) extrapolateRight = config.extrapolateRight;else if (config.extrapolate !== undefined) extrapolateRight = config.extrapolate;\n return input => {\n let range = findRange(input, inputRange);\n return interpolate(input, inputRange[range], inputRange[range + 1], outputRange[range], outputRange[range + 1], easing, extrapolateLeft, extrapolateRight, map);\n };\n }\n\n}\n\nfunction interpolate(input, inputMin, inputMax, outputMin, outputMax, easing, extrapolateLeft, extrapolateRight, map) {\n let result = map ? map(input) : input; // Extrapolate\n\n if (result < inputMin) {\n if (extrapolateLeft === 'identity') return result;else if (extrapolateLeft === 'clamp') result = inputMin;\n }\n\n if (result > inputMax) {\n if (extrapolateRight === 'identity') return result;else if (extrapolateRight === 'clamp') result = inputMax;\n }\n\n if (outputMin === outputMax) return outputMin;\n if (inputMin === inputMax) return input <= inputMin ? outputMin : outputMax; // Input Range\n\n if (inputMin === -Infinity) result = -result;else if (inputMax === Infinity) result = result - inputMin;else result = (result - inputMin) / (inputMax - inputMin); // Easing\n\n result = easing(result); // Output Range\n\n if (outputMin === -Infinity) result = -result;else if (outputMax === Infinity) result = result + outputMin;else result = result * (outputMax - outputMin) + outputMin;\n return result;\n}\n\nfunction findRange(input, inputRange) {\n for (var i = 1; i < inputRange.length - 1; ++i) if (inputRange[i] >= input) break;\n\n return i - 1;\n}\n\n// const INTEGER = '[-+]?\\\\d+';\nconst NUMBER = '[-+]?\\\\d*\\\\.?\\\\d+';\nconst PERCENTAGE = NUMBER + '%';\n\nfunction call() {\n return '\\\\(\\\\s*(' + Array.prototype.slice.call(arguments).join(')\\\\s*,\\\\s*(') + ')\\\\s*\\\\)';\n}\n\nconst rgb = new RegExp('rgb' + call(NUMBER, NUMBER, NUMBER));\nconst rgba = new RegExp('rgba' + call(NUMBER, NUMBER, NUMBER, NUMBER));\nconst hsl = new RegExp('hsl' + call(NUMBER, PERCENTAGE, PERCENTAGE));\nconst hsla = new RegExp('hsla' + call(NUMBER, PERCENTAGE, PERCENTAGE, NUMBER));\nconst hex3 = /^#([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/;\nconst hex4 = /^#([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/;\nconst hex6 = /^#([0-9a-fA-F]{6})$/;\nconst hex8 = /^#([0-9a-fA-F]{8})$/;\n\n/*\nhttps://github.com/react-community/normalize-css-color\n\nBSD 3-Clause License\n\nCopyright (c) 2016, React Community\nAll rights reserved.\n\nRedistribution and use in source and binary forms, with or without\nmodification, are permitted provided that the following conditions are met:\n\n* Redistributions of source code must retain the above copyright notice, this\n list of conditions and the following disclaimer.\n\n* Redistributions in binary form must reproduce the above copyright notice,\n this list of conditions and the following disclaimer in the documentation\n and/or other materials provided with the distribution.\n\n* Neither the name of the copyright holder nor the names of its\n contributors may be used to endorse or promote products derived from\n this software without specific prior written permission.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\"\nAND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\nIMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\nFOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\nDAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\nSERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\nCAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\nOR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\nOF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n*/\nfunction normalizeColor(color) {\n let match;\n\n if (typeof color === 'number') {\n return color >>> 0 === color && color >= 0 && color <= 0xffffffff ? color : null;\n } // Ordered based on occurrences on Facebook codebase\n\n\n if (match = hex6.exec(color)) return parseInt(match[1] + 'ff', 16) >>> 0;\n if (colors.hasOwnProperty(color)) return colors[color];\n\n if (match = rgb.exec(color)) {\n return (parse255(match[1]) << 24 | // r\n parse255(match[2]) << 16 | // g\n parse255(match[3]) << 8 | // b\n 0x000000ff) >>> // a\n 0;\n }\n\n if (match = rgba.exec(color)) {\n return (parse255(match[1]) << 24 | // r\n parse255(match[2]) << 16 | // g\n parse255(match[3]) << 8 | // b\n parse1(match[4])) >>> // a\n 0;\n }\n\n if (match = hex3.exec(color)) {\n return parseInt(match[1] + match[1] + // r\n match[2] + match[2] + // g\n match[3] + match[3] + // b\n 'ff', // a\n 16) >>> 0;\n } // https://drafts.csswg.org/css-color-4/#hex-notation\n\n\n if (match = hex8.exec(color)) return parseInt(match[1], 16) >>> 0;\n\n if (match = hex4.exec(color)) {\n return parseInt(match[1] + match[1] + // r\n match[2] + match[2] + // g\n match[3] + match[3] + // b\n match[4] + match[4], // a\n 16) >>> 0;\n }\n\n if (match = hsl.exec(color)) {\n return (hslToRgb(parse360(match[1]), // h\n parsePercentage(match[2]), // s\n parsePercentage(match[3]) // l\n ) | 0x000000ff) >>> // a\n 0;\n }\n\n if (match = hsla.exec(color)) {\n return (hslToRgb(parse360(match[1]), // h\n parsePercentage(match[2]), // s\n parsePercentage(match[3]) // l\n ) | parse1(match[4])) >>> // a\n 0;\n }\n\n return null;\n}\n\nfunction hue2rgb(p, q, t) {\n if (t < 0) t += 1;\n if (t > 1) t -= 1;\n if (t < 1 / 6) return p + (q - p) * 6 * t;\n if (t < 1 / 2) return q;\n if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6;\n return p;\n}\n\nfunction hslToRgb(h, s, l) {\n const q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n const p = 2 * l - q;\n const r = hue2rgb(p, q, h + 1 / 3);\n const g = hue2rgb(p, q, h);\n const b = hue2rgb(p, q, h - 1 / 3);\n return Math.round(r * 255) << 24 | Math.round(g * 255) << 16 | Math.round(b * 255) << 8;\n}\n\nfunction parse255(str) {\n const int = parseInt(str, 10);\n if (int < 0) return 0;\n if (int > 255) return 255;\n return int;\n}\n\nfunction parse360(str) {\n const int = parseFloat(str);\n return (int % 360 + 360) % 360 / 360;\n}\n\nfunction parse1(str) {\n const num = parseFloat(str);\n if (num < 0) return 0;\n if (num > 1) return 255;\n return Math.round(num * 255);\n}\n\nfunction parsePercentage(str) {\n // parseFloat conveniently ignores the final %\n const int = parseFloat(str);\n if (int < 0) return 0;\n if (int > 100) return 1;\n return int / 100;\n}\n\nfunction colorToRgba(input) {\n let int32Color = normalizeColor(input);\n if (int32Color === null) return input;\n int32Color = int32Color || 0;\n let r = (int32Color & 0xff000000) >>> 24;\n let g = (int32Color & 0x00ff0000) >>> 16;\n let b = (int32Color & 0x0000ff00) >>> 8;\n let a = (int32Color & 0x000000ff) / 255;\n return `rgba(${r}, ${g}, ${b}, ${a})`;\n} // Problem: https://github.com/animatedjs/animated/pull/102\n// Solution: https://stackoverflow.com/questions/638565/parsing-scientific-notation-sensibly/658662\n\n\nconst stringShapeRegex = /[+\\-]?(?:0|[1-9]\\d*)(?:\\.\\d*)?(?:[eE][+\\-]?\\d+)?/g; // Covers rgb, rgba, hsl, hsla\n// Taken from https://gist.github.com/olmokramer/82ccce673f86db7cda5e\n\nconst colorRegex = /(#(?:[0-9a-f]{2}){2,4}|(#[0-9a-f]{3})|(rgb|hsl)a?\\((-?\\d+%?[,\\s]+){2,3}\\s*[\\d\\.]+%?\\))/gi; // Covers color names (transparent, blue, etc.)\n\nconst colorNamesRegex = new RegExp(`(${Object.keys(colors).join('|')})`, 'g');\n/**\n * Supports string shapes by extracting numbers so new values can be computed,\n * and recombines those values into new strings of the same shape. Supports\n * things like:\n *\n * rgba(123, 42, 99, 0.36) // colors\n * -45deg // values with units\n * 0 2px 2px 0px rgba(0, 0, 0, 0.12) // box shadows\n */\n\nfunction createInterpolation(config) {\n // Replace colors with rgba\n const outputRange = config.output.map(rangeValue => rangeValue.replace(colorRegex, colorToRgba)).map(rangeValue => rangeValue.replace(colorNamesRegex, colorToRgba)); // ->\n // [\n // [0, 50],\n // [100, 150],\n // [200, 250],\n // [0, 0.5],\n // ]\n\n const outputRanges = outputRange[0].match(stringShapeRegex).map(() => []);\n outputRange.forEach(value => {\n value.match(stringShapeRegex).forEach((number, i) => outputRanges[i].push(+number));\n });\n const interpolations = outputRange[0].match(stringShapeRegex).map((value, i) => {\n return Interpolation.create(_extends({}, config, {\n output: outputRanges[i]\n }));\n });\n return input => {\n let i = 0;\n return outputRange[0] // 'rgba(0, 100, 200, 0)'\n // ->\n // 'rgba(${interpolations[0](input)}, ${interpolations[1](input)}, ...'\n .replace(stringShapeRegex, () => interpolations[i++](input)) // rgba requires that the r,g,b are integers.... so we want to round them, but we *dont* want to\n // round the opacity (4th column).\n .replace(/rgba\\(([0-9\\.-]+), ([0-9\\.-]+), ([0-9\\.-]+), ([0-9\\.-]+)\\)/gi, (_, p1, p2, p3, p4) => `rgba(${Math.round(p1)}, ${Math.round(p2)}, ${Math.round(p3)}, ${p4})`);\n };\n}\n\nclass AnimatedInterpolation extends AnimatedArrayWithChildren {\n constructor(parents, _config, _arg) {\n super();\n\n this.getValue = () => this.calc(...this.payload.map(value => value.getValue()));\n\n this.updateConfig = (config, arg) => this.calc = Interpolation.create(config, arg);\n\n this.interpolate = (config, arg) => new AnimatedInterpolation(this, config, arg);\n\n this.payload = // AnimatedArrays should unfold, except AnimatedInterpolation which is taken as is\n parents instanceof AnimatedArrayWithChildren && !parents.updateConfig ? parents.payload : Array.isArray(parents) ? parents : [parents];\n this.calc = Interpolation.create(_config, _arg);\n }\n\n}\nconst interpolate$1 = (parents, config, arg) => parents && new AnimatedInterpolation(parents, config, arg);\n\n/**\n * Animated works by building a directed acyclic graph of dependencies\n * transparently when you render your Animated components.\n *\n * new Animated.Value(0)\n * .interpolate() .interpolate() new Animated.Value(1)\n * opacity translateY scale\n * style transform\n * View#234 style\n * View#123\n *\n * A) Top Down phase\n * When an Animated.Value is updated, we recursively go down through this\n * graph in order to find leaf nodes: the views that we flag as needing\n * an update.\n *\n * B) Bottom Up phase\n * When a view is flagged as needing an update, we recursively go back up\n * in order to build the new value that it needs. The reason why we need\n * this two-phases process is to deal with composite props such as\n * transform which can receive values from multiple parents.\n */\n\nfunction findAnimatedStyles(node, styles) {\n if (typeof node.update === 'function') styles.add(node);else node.getChildren().forEach(child => findAnimatedStyles(child, styles));\n}\n/**\n * Standard value for driving animations. One `Animated.Value` can drive\n * multiple properties in a synchronized fashion, but can only be driven by one\n * mechanism at a time. Using a new mechanism (e.g. starting a new animation,\n * or calling `setValue`) will stop any previous ones.\n */\n\n\nclass AnimatedValue extends AnimatedWithChildren {\n constructor(_value) {\n var _this;\n\n super();\n _this = this;\n\n this.setValue = function (value, flush) {\n if (flush === void 0) {\n flush = true;\n }\n\n _this.value = value;\n if (flush) _this.flush();\n };\n\n this.getValue = () => this.value;\n\n this.updateStyles = () => findAnimatedStyles(this, this.animatedStyles);\n\n this.updateValue = value => this.flush(this.value = value);\n\n this.interpolate = (config, arg) => new AnimatedInterpolation(this, config, arg);\n\n this.value = _value;\n this.animatedStyles = new Set();\n this.done = false;\n this.startPosition = _value;\n this.lastPosition = _value;\n this.lastVelocity = undefined;\n this.lastTime = undefined;\n this.controller = undefined;\n }\n\n flush() {\n if (this.animatedStyles.size === 0) this.updateStyles();\n this.animatedStyles.forEach(animatedStyle => animatedStyle.update());\n }\n\n prepare(controller) {\n // Values stay loyal to their original controller, this is also a way to\n // detect trailing values originating from a foreign controller\n if (this.controller === undefined) this.controller = controller;\n\n if (this.controller === controller) {\n this.startPosition = this.value;\n this.lastPosition = this.value;\n this.lastVelocity = controller.isActive ? this.lastVelocity : undefined;\n this.lastTime = controller.isActive ? this.lastTime : undefined;\n this.done = false;\n this.animatedStyles.clear();\n }\n }\n\n}\n\nclass AnimatedArray extends AnimatedArrayWithChildren {\n constructor(array) {\n var _this;\n\n super();\n _this = this;\n\n this.setValue = function (value, flush) {\n if (flush === void 0) {\n flush = true;\n }\n\n if (Array.isArray(value)) {\n if (value.length === _this.payload.length) value.forEach((v, i) => _this.payload[i].setValue(v, flush));\n } else _this.payload.forEach((v, i) => _this.payload[i].setValue(value, flush));\n };\n\n this.getValue = () => this.payload.map(v => v.getValue());\n\n this.interpolate = (config, arg) => new AnimatedInterpolation(this, config, arg);\n\n this.payload = array.map(n => new AnimatedValue(n));\n }\n\n}\n\nfunction withDefault(value, defaultValue) {\n return value === undefined || value === null ? defaultValue : value;\n}\nfunction toArray(a) {\n return a !== void 0 ? Array.isArray(a) ? a : [a] : [];\n}\nfunction shallowEqual(a, b) {\n if (typeof a !== typeof b) return false;\n if (typeof a === 'string' || typeof a === 'number') return a === b;\n let i;\n\n for (i in a) if (!(i in b)) return false;\n\n for (i in b) if (a[i] !== b[i]) return false;\n\n return i === void 0 ? a === b : true;\n}\nfunction callProp(obj) {\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n\n return typeof obj === 'function' ? obj(...args) : obj;\n}\nfunction getValues$1(object) {\n return Object.keys(object).map(k => object[k]);\n}\nfunction getForwardProps(props) {\n const to = props.to,\n from = props.from,\n config = props.config,\n native = props.native,\n onStart = props.onStart,\n onRest = props.onRest,\n onFrame = props.onFrame,\n children = props.children,\n reset = props.reset,\n reverse = props.reverse,\n force = props.force,\n immediate = props.immediate,\n impl = props.impl,\n inject = props.inject,\n delay = props.delay,\n attach = props.attach,\n destroyed = props.destroyed,\n interpolateTo = props.interpolateTo,\n autoStart = props.autoStart,\n ref = props.ref,\n forward = _objectWithoutPropertiesLoose(props, [\"to\", \"from\", \"config\", \"native\", \"onStart\", \"onRest\", \"onFrame\", \"children\", \"reset\", \"reverse\", \"force\", \"immediate\", \"impl\", \"inject\", \"delay\", \"attach\", \"destroyed\", \"interpolateTo\", \"autoStart\", \"ref\"]);\n\n return forward;\n}\nfunction interpolateTo(props) {\n const forward = getForwardProps(props);\n const rest = Object.keys(props).reduce((a, k) => forward[k] !== void 0 ? a : _extends({}, a, {\n [k]: props[k]\n }), {});\n return _extends({\n to: forward\n }, rest);\n}\nfunction convertToAnimatedValue(acc, _ref) {\n let name = _ref[0],\n value = _ref[1];\n return _extends({}, acc, {\n [name]: new (Array.isArray(value) ? AnimatedArray : AnimatedValue)(value)\n });\n}\nfunction convertValues(props) {\n const from = props.from,\n to = props.to,\n native = props.native;\n const allProps = Object.entries(_extends({}, from, to));\n return native ? allProps.reduce(convertToAnimatedValue, {}) : _extends({}, from, to);\n}\nfunction handleRef(ref, forward) {\n if (forward) {\n // If it's a function, assume it's a ref callback\n if (typeof forward === 'function') forward(ref);else if (typeof forward === 'object') {\n // If it's an object and has a 'current' property, assume it's a ref object\n forward.current = ref;\n }\n }\n\n return ref;\n}\n\nconst check = value => value === 'auto';\n\nconst overwrite = (width, height) => (acc, _ref) => {\n let name = _ref[0],\n value = _ref[1];\n return _extends({}, acc, {\n [name]: value === 'auto' ? ~name.indexOf('height') ? height : width : value\n });\n};\n\nfunction fixAuto(props, callback) {\n const from = props.from,\n to = props.to,\n children = props.children; // Dry-route props back if nothing's using 'auto' in there\n // TODO: deal with \"null\"\n\n if (!(getValues$1(to).some(check) || getValues$1(from).some(check))) return; // Fetch render v-dom\n\n let element = children(convertValues(props)); // A spring can return undefined/null, check against that (#153)\n\n if (!element) return; // Or it could be an array (#346) ...\n\n if (Array.isArray(element)) element = {\n type: 'div',\n props: {\n children: element\n } // Extract styles\n\n };\n const elementStyles = element.props.style; // Return v.dom with injected ref\n\n return React__default.createElement(element.type, _extends({\n key: element.key ? element.key : undefined\n }, element.props, {\n style: _extends({}, elementStyles, {\n position: 'absolute',\n visibility: 'hidden'\n }),\n ref: _ref2 => {\n if (_ref2) {\n // Once it's rendered out, fetch bounds (minus padding/margin/borders)\n let node = ReactDOM.findDOMNode(_ref2);\n let width, height;\n let cs = getComputedStyle(node);\n\n if (cs.boxSizing === 'border-box') {\n width = node.offsetWidth;\n height = node.offsetHeight;\n } else {\n const paddingX = parseFloat(cs.paddingLeft || 0) + parseFloat(cs.paddingRight || 0);\n const paddingY = parseFloat(cs.paddingTop || 0) + parseFloat(cs.paddingBottom || 0);\n const borderX = parseFloat(cs.borderLeftWidth || 0) + parseFloat(cs.borderRightWidth || 0);\n const borderY = parseFloat(cs.borderTopWidth || 0) + parseFloat(cs.borderBottomWidth || 0);\n width = node.offsetWidth - paddingX - borderX;\n height = node.offsetHeight - paddingY - borderY;\n }\n\n const convert = overwrite(width, height);\n callback(_extends({}, props, {\n from: Object.entries(from).reduce(convert, from),\n to: Object.entries(to).reduce(convert, to)\n }));\n }\n }\n }));\n}\n\nlet isUnitlessNumber = {\n animationIterationCount: true,\n borderImageOutset: true,\n borderImageSlice: true,\n borderImageWidth: true,\n boxFlex: true,\n boxFlexGroup: true,\n boxOrdinalGroup: true,\n columnCount: true,\n columns: true,\n flex: true,\n flexGrow: true,\n flexPositive: true,\n flexShrink: true,\n flexNegative: true,\n flexOrder: true,\n gridRow: true,\n gridRowEnd: true,\n gridRowSpan: true,\n gridRowStart: true,\n gridColumn: true,\n gridColumnEnd: true,\n gridColumnSpan: true,\n gridColumnStart: true,\n fontWeight: true,\n lineClamp: true,\n lineHeight: true,\n opacity: true,\n order: true,\n orphans: true,\n tabSize: true,\n widows: true,\n zIndex: true,\n zoom: true,\n // SVG-related properties\n fillOpacity: true,\n floodOpacity: true,\n stopOpacity: true,\n strokeDasharray: true,\n strokeDashoffset: true,\n strokeMiterlimit: true,\n strokeOpacity: true,\n strokeWidth: true\n};\n\nconst prefixKey = (prefix, key) => prefix + key.charAt(0).toUpperCase() + key.substring(1);\n\nconst prefixes = ['Webkit', 'Ms', 'Moz', 'O'];\nisUnitlessNumber = Object.keys(isUnitlessNumber).reduce((acc, prop) => {\n prefixes.forEach(prefix => acc[prefixKey(prefix, prop)] = acc[prop]);\n return acc;\n}, isUnitlessNumber);\n\nfunction dangerousStyleValue(name, value, isCustomProperty) {\n if (value == null || typeof value === 'boolean' || value === '') return '';\n if (!isCustomProperty && typeof value === 'number' && value !== 0 && !(isUnitlessNumber.hasOwnProperty(name) && isUnitlessNumber[name])) return value + 'px'; // Presumes implicit 'px' suffix for unitless numbers\n\n return ('' + value).trim();\n}\n\nconst attributeCache = {};\ninjectCreateAnimatedStyle(style => new AnimatedStyle(style));\ninjectDefaultElement('div');\ninjectInterpolation(createInterpolation);\ninjectColorNames(colors);\ninjectBugfixes(fixAuto);\ninjectApplyAnimatedValues((instance, props) => {\n if (instance.nodeType && instance.setAttribute !== undefined) {\n const style = props.style,\n children = props.children,\n scrollTop = props.scrollTop,\n scrollLeft = props.scrollLeft,\n attributes = _objectWithoutPropertiesLoose(props, [\"style\", \"children\", \"scrollTop\", \"scrollLeft\"]);\n\n if (scrollTop !== void 0) instance.scrollTop = scrollTop;\n if (scrollLeft !== void 0) instance.scrollLeft = scrollLeft; // Set textContent, if children is an animatable value\n\n if (children !== void 0) instance.textContent = children; // Set styles ...\n\n for (let styleName in style) {\n if (!style.hasOwnProperty(styleName)) continue;\n var isCustomProperty = styleName.indexOf('--') === 0;\n var styleValue = dangerousStyleValue(styleName, style[styleName], isCustomProperty);\n if (styleName === 'float') styleName = 'cssFloat';\n if (isCustomProperty) instance.style.setProperty(styleName, styleValue);else instance.style[styleName] = styleValue;\n } // Set attributes ...\n\n\n for (let name in attributes) {\n // Attributes are written in dash case\n const dashCase = attributeCache[name] || (attributeCache[name] = name.replace(/([A-Z])/g, n => '-' + n.toLowerCase()));\n if (typeof instance.getAttribute(dashCase) !== 'undefined') instance.setAttribute(dashCase, attributes[name]);\n }\n } else return false;\n}, style => style);\n\nlet active = false;\nconst controllers = new Set();\n\nconst frameLoop = () => {\n let time = now();\n\n for (let controller of controllers) {\n let isDone = true;\n let noChange = true;\n\n for (let configIdx = 0; configIdx < controller.configs.length; configIdx++) {\n let config = controller.configs[configIdx];\n let endOfAnimation, lastTime;\n\n for (let valIdx = 0; valIdx < config.animatedValues.length; valIdx++) {\n let animation = config.animatedValues[valIdx]; // If an animation is done, skip, until all of them conclude\n\n if (animation.done) continue;\n let from = config.fromValues[valIdx];\n let to = config.toValues[valIdx];\n let position = animation.lastPosition;\n let isAnimated = to instanceof Animated;\n let velocity = Array.isArray(config.initialVelocity) ? config.initialVelocity[valIdx] : config.initialVelocity;\n if (isAnimated) to = to.getValue(); // Conclude animation if it's either immediate, or from-values match end-state\n\n if (config.immediate || !isAnimated && !config.decay && from === to) {\n animation.updateValue(to);\n animation.done = true;\n continue;\n } // Doing delay here instead of setTimeout is one async worry less\n\n\n if (config.delay && time - controller.startTime < config.delay) {\n isDone = false;\n continue;\n } // Flag change\n\n\n noChange = false; // Break animation when string values are involved\n\n if (typeof from === 'string' || typeof to === 'string') {\n animation.updateValue(to);\n animation.done = true;\n continue;\n }\n\n if (config.duration !== void 0) {\n /** Duration easing */\n position = from + config.easing((time - controller.startTime - config.delay) / config.duration) * (to - from);\n endOfAnimation = time >= controller.startTime + config.delay + config.duration;\n } else if (config.decay) {\n /** Decay easing */\n position = from + velocity / (1 - 0.998) * (1 - Math.exp(-(1 - 0.998) * (time - controller.startTime)));\n endOfAnimation = Math.abs(animation.lastPosition - position) < 0.1;\n if (endOfAnimation) to = position;\n } else {\n /** Spring easing */\n lastTime = animation.lastTime !== void 0 ? animation.lastTime : time;\n velocity = animation.lastVelocity !== void 0 ? animation.lastVelocity : config.initialVelocity; // If we lost a lot of frames just jump to the end.\n\n if (time > lastTime + 64) lastTime = time; // http://gafferongames.com/game-physics/fix-your-timestep/\n\n let numSteps = Math.floor(time - lastTime);\n\n for (let i = 0; i < numSteps; ++i) {\n let force = -config.tension * (position - to);\n let damping = -config.friction * velocity;\n let acceleration = (force + damping) / config.mass;\n velocity = velocity + acceleration * 1 / 1000;\n position = position + velocity * 1 / 1000;\n } // Conditions for stopping the spring animation\n\n\n let isOvershooting = config.clamp && config.tension !== 0 ? from < to ? position > to : position < to : false;\n let isVelocity = Math.abs(velocity) <= config.precision;\n let isDisplacement = config.tension !== 0 ? Math.abs(to - position) <= config.precision : true;\n endOfAnimation = isOvershooting || isVelocity && isDisplacement;\n animation.lastVelocity = velocity;\n animation.lastTime = time;\n } // Trails aren't done until their parents conclude\n\n\n if (isAnimated && !config.toValues[valIdx].done) endOfAnimation = false;\n\n if (endOfAnimation) {\n // Ensure that we end up with a round value\n if (animation.value !== to) position = to;\n animation.done = true;\n } else isDone = false;\n\n animation.updateValue(position);\n animation.lastPosition = position;\n } // Keep track of updated values only when necessary\n\n\n if (controller.props.onFrame || !controller.props.native) controller.animatedProps[config.name] = config.interpolation.getValue();\n } // Update callbacks in the end of the frame\n\n\n if (controller.props.onFrame || !controller.props.native) {\n if (!controller.props.native && controller.onUpdate) controller.onUpdate();\n if (controller.props.onFrame) controller.props.onFrame(controller.animatedProps);\n } // Either call onEnd or next frame\n\n\n if (isDone) {\n controllers.delete(controller);\n controller.debouncedOnEnd({\n finished: true,\n noChange\n });\n }\n } // Loop over as long as there are controllers ...\n\n\n if (controllers.size) requestFrame(frameLoop);else active = false;\n};\n\nconst addController = controller => {\n if (!controllers.has(controller)) {\n controllers.add(controller);\n if (!active) requestFrame(frameLoop);\n active = true;\n }\n};\n\nconst removeController = controller => {\n if (controllers.has(controller)) {\n controllers.delete(controller);\n }\n};\n\nclass Controller {\n constructor(props, config) {\n if (config === void 0) {\n config = {\n native: true,\n interpolateTo: true,\n autoStart: true\n };\n }\n\n this.getValues = () => this.props.native ? this.interpolations : this.animatedProps;\n\n this.dependents = new Set();\n this.isActive = false;\n this.hasChanged = false;\n this.props = {};\n this.merged = {};\n this.animations = {};\n this.interpolations = {};\n this.animatedProps = {};\n this.configs = [];\n this.frame = undefined;\n this.startTime = undefined;\n this.lastTime = undefined;\n this.update(_extends({}, props, config));\n }\n\n update(props) {\n this.props = _extends({}, this.props, props);\n\n let _ref = this.props.interpolateTo ? interpolateTo(this.props) : this.props,\n _ref$from = _ref.from,\n from = _ref$from === void 0 ? {} : _ref$from,\n _ref$to = _ref.to,\n to = _ref$to === void 0 ? {} : _ref$to,\n _ref$config = _ref.config,\n config = _ref$config === void 0 ? {} : _ref$config,\n _ref$delay = _ref.delay,\n delay = _ref$delay === void 0 ? 0 : _ref$delay,\n reverse = _ref.reverse,\n attach = _ref.attach,\n reset = _ref.reset,\n immediate = _ref.immediate,\n autoStart = _ref.autoStart,\n ref = _ref.ref; // Reverse values when requested\n\n\n if (reverse) {\n var _ref2 = [to, from];\n from = _ref2[0];\n to = _ref2[1];\n }\n\n this.hasChanged = false; // Attachment handling, trailed springs can \"attach\" themselves to a previous spring\n\n let target = attach && attach(this); // Reset merged props when necessary\n\n let extra = reset ? {} : this.merged; // This will collect all props that were ever set\n\n this.merged = _extends({}, from, extra, to); // Reduces input { name: value } pairs into animated values\n\n this.animations = Object.entries(this.merged).reduce((acc, _ref3, i) => {\n let name = _ref3[0],\n value = _ref3[1];\n // Issue cached entries, except on reset\n let entry = !reset && acc[name] || {}; // Figure out what the value is supposed to be\n\n const isNumber = typeof value === 'number';\n const isString = typeof value === 'string' && !value.startsWith('#') && !/\\d/.test(value) && !colorNames[value];\n const isArray = !isNumber && !isString && Array.isArray(value);\n let fromValue = from[name] !== undefined ? from[name] : value;\n let toValue = isNumber || isArray ? value : isString ? value : 1;\n let toConfig = callProp(config, name);\n if (target) toValue = target.animations[name].parent; // Detect changes, animated values will be checked in the raf-loop\n\n if (toConfig.decay !== void 0 || !shallowEqual(entry.changes, value)) {\n this.hasChanged = true;\n let parent, interpolation$$1;\n if (isNumber || isString) parent = interpolation$$1 = entry.parent || new AnimatedValue(fromValue);else if (isArray) parent = interpolation$$1 = entry.parent || new AnimatedArray(fromValue);else {\n const prev = entry.interpolation && entry.interpolation.calc(entry.parent.value);\n\n if (entry.parent) {\n parent = entry.parent;\n parent.setValue(0, false);\n } else parent = new AnimatedValue(0);\n\n const range = {\n output: [prev !== void 0 ? prev : fromValue, value]\n };\n\n if (entry.interpolation) {\n interpolation$$1 = entry.interpolation;\n entry.interpolation.updateConfig(range);\n } else interpolation$$1 = parent.interpolate(range);\n } // Set immediate values\n\n if (callProp(immediate, name)) parent.setValue(value, false); // Reset animated values\n\n const animatedValues = toArray(parent.getPayload());\n animatedValues.forEach(value => value.prepare(this));\n return _extends({}, acc, {\n [name]: _extends({}, entry, {\n name,\n parent,\n interpolation: interpolation$$1,\n animatedValues,\n changes: value,\n fromValues: toArray(parent.getValue()),\n toValues: toArray(target ? toValue.getPayload() : toValue),\n immediate: callProp(immediate, name),\n delay: withDefault(toConfig.delay, delay || 0),\n initialVelocity: withDefault(toConfig.velocity, 0),\n clamp: withDefault(toConfig.clamp, false),\n precision: withDefault(toConfig.precision, 0.01),\n tension: withDefault(toConfig.tension, 170),\n friction: withDefault(toConfig.friction, 26),\n mass: withDefault(toConfig.mass, 1),\n duration: toConfig.duration,\n easing: withDefault(toConfig.easing, t => t),\n decay: toConfig.decay\n })\n });\n } else return acc;\n }, this.animations);\n\n if (this.hasChanged) {\n this.configs = getValues$1(this.animations);\n this.animatedProps = {};\n this.interpolations = {};\n\n for (let key in this.animations) {\n this.interpolations[key] = this.animations[key].interpolation;\n this.animatedProps[key] = this.animations[key].interpolation.getValue();\n }\n } // TODO: clean up ref in controller\n\n\n for (var _len = arguments.length, start = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n start[_key - 1] = arguments[_key];\n }\n\n if (!ref && (autoStart || start.length)) this.start(...start);\n const onEnd = start[0],\n onUpdate = start[1];\n this.onEnd = typeof onEnd === 'function' && onEnd;\n this.onUpdate = onUpdate;\n return this.getValues();\n }\n\n start(onEnd, onUpdate) {\n this.startTime = now();\n if (this.isActive) this.stop();\n this.isActive = true;\n this.onEnd = typeof onEnd === 'function' && onEnd;\n this.onUpdate = onUpdate;\n if (this.props.onStart) this.props.onStart();\n addController(this);\n return new Promise(res => this.resolve = res);\n }\n\n stop(finished) {\n if (finished === void 0) {\n finished = false;\n }\n\n // Reset collected changes since the animation has been stopped cold turkey\n if (finished) getValues$1(this.animations).forEach(a => a.changes = undefined);\n this.debouncedOnEnd({\n finished\n });\n }\n\n destroy() {\n removeController(this);\n this.props = {};\n this.merged = {};\n this.animations = {};\n this.interpolations = {};\n this.animatedProps = {};\n this.configs = [];\n }\n\n debouncedOnEnd(result) {\n removeController(this);\n this.isActive = false;\n const onEnd = this.onEnd;\n this.onEnd = null;\n if (onEnd) onEnd(result);\n if (this.resolve) this.resolve();\n this.resolve = null;\n }\n\n}\n\nclass AnimatedProps extends AnimatedObjectWithChildren {\n constructor(props, callback) {\n super();\n if (props.style) props = _extends({}, props, {\n style: createAnimatedStyle(props.style)\n });\n this.payload = props;\n this.update = callback;\n this.attach();\n }\n\n}\n\nfunction createAnimatedComponent(Component) {\n class AnimatedComponent extends React__default.Component {\n constructor(props) {\n super();\n\n this.callback = () => {\n if (this.node) {\n const didUpdate = applyAnimatedValues.fn(this.node, this.propsAnimated.getAnimatedValue(), this);\n if (didUpdate === false) this.forceUpdate();\n }\n };\n\n this.attachProps(props);\n }\n\n componentWillUnmount() {\n this.propsAnimated && this.propsAnimated.detach();\n }\n\n setNativeProps(props) {\n const didUpdate = applyAnimatedValues.fn(this.node, props, this);\n if (didUpdate === false) this.forceUpdate();\n } // The system is best designed when setNativeProps is implemented. It is\n // able to avoid re-rendering and directly set the attributes that\n // changed. However, setNativeProps can only be implemented on leaf\n // native components. If you want to animate a composite component, you\n // need to re-render it. In this case, we have a fallback that uses\n // forceUpdate.\n\n\n attachProps(_ref) {\n let forwardRef = _ref.forwardRef,\n nextProps = _objectWithoutPropertiesLoose(_ref, [\"forwardRef\"]);\n\n const oldPropsAnimated = this.propsAnimated;\n this.propsAnimated = new AnimatedProps(nextProps, this.callback); // When you call detach, it removes the element from the parent list\n // of children. If it goes to 0, then the parent also detaches itself\n // and so on.\n // An optimization is to attach the new elements and THEN detach the old\n // ones instead of detaching and THEN attaching.\n // This way the intermediate state isn't to go to 0 and trigger\n // this expensive recursive detaching to then re-attach everything on\n // the very next operation.\n\n oldPropsAnimated && oldPropsAnimated.detach();\n }\n\n shouldComponentUpdate(props) {\n const style = props.style,\n nextProps = _objectWithoutPropertiesLoose(props, [\"style\"]);\n\n const _this$props = this.props,\n currentStyle = _this$props.style,\n currentProps = _objectWithoutPropertiesLoose(_this$props, [\"style\"]);\n\n if (!shallowEqual(currentProps, nextProps) || !shallowEqual(currentStyle, style)) {\n this.attachProps(props);\n return true;\n }\n\n return false;\n }\n\n render() {\n const _this$propsAnimated$g = this.propsAnimated.getValue(),\n scrollTop = _this$propsAnimated$g.scrollTop,\n scrollLeft = _this$propsAnimated$g.scrollLeft,\n animatedProps = _objectWithoutPropertiesLoose(_this$propsAnimated$g, [\"scrollTop\", \"scrollLeft\"]);\n\n return React__default.createElement(Component, _extends({}, animatedProps, {\n ref: node => this.node = handleRef(node, this.props.forwardRef)\n }));\n }\n\n }\n\n return React__default.forwardRef((props, ref) => React__default.createElement(AnimatedComponent, _extends({}, props, {\n forwardRef: ref\n })));\n}\n\nconst config = {\n default: {\n tension: 170,\n friction: 26\n },\n gentle: {\n tension: 120,\n friction: 14\n },\n wobbly: {\n tension: 180,\n friction: 12\n },\n stiff: {\n tension: 210,\n friction: 20\n },\n slow: {\n tension: 280,\n friction: 60\n },\n molasses: {\n tension: 280,\n friction: 120\n }\n};\n\nclass Spring extends React__default.Component {\n constructor() {\n super(...arguments);\n this.state = {\n lastProps: {\n from: {},\n to: {}\n },\n propsChanged: false,\n internal: false\n };\n this.controller = new Controller(null, null);\n this.didUpdate = false;\n this.didInject = false;\n this.finished = true;\n\n this.start = () => {\n this.finished = false;\n let wasMounted = this.mounted;\n this.controller.start(props => this.finish(_extends({}, props, {\n wasMounted\n })), this.update);\n };\n\n this.stop = () => this.controller.stop(true);\n\n this.update = () => this.mounted && this.setState({\n internal: true\n });\n\n this.finish = (_ref) => {\n let finished = _ref.finished,\n noChange = _ref.noChange,\n wasMounted = _ref.wasMounted;\n this.finished = true;\n\n if (this.mounted && finished) {\n // Only call onRest if either we *were* mounted, or when there were changes\n if (this.props.onRest && (wasMounted || !noChange)) this.props.onRest(this.controller.merged); // Restore end-state\n\n if (this.mounted && this.didInject) {\n this.afterInject = convertValues(this.props);\n this.setState({\n internal: true\n });\n } // If we have an inject or values to apply after the animation we ping here\n\n\n if (this.mounted && (this.didInject || this.props.after)) this.setState({\n internal: true\n });\n this.didInject = false;\n }\n };\n }\n\n componentDidMount() {\n // componentDidUpdate isn't called on mount, we call it here to start animating\n this.componentDidUpdate();\n this.mounted = true;\n }\n\n componentWillUnmount() {\n // Stop all ongoing animtions\n this.mounted = false;\n this.stop();\n }\n\n static getDerivedStateFromProps(props, _ref2) {\n let internal = _ref2.internal,\n lastProps = _ref2.lastProps;\n // The following is a test against props that could alter the animation\n const from = props.from,\n to = props.to,\n reset = props.reset,\n force = props.force;\n const propsChanged = !shallowEqual(to, lastProps.to) || !shallowEqual(from, lastProps.from) || reset && !internal || force && !internal;\n return {\n propsChanged,\n lastProps: props,\n internal: false\n };\n }\n\n render() {\n const children = this.props.children;\n const propsChanged = this.state.propsChanged; // Inject phase -----------------------------------------------------------\n // Handle injected frames, for instance targets/web/fix-auto\n // An inject will return an intermediary React node which measures itself out\n // .. and returns a callback when the values sought after are ready, usually \"auto\".\n\n if (this.props.inject && propsChanged && !this.injectProps) {\n const frame = this.props.inject(this.props, injectProps => {\n // The inject frame has rendered, now let's update animations...\n this.injectProps = injectProps;\n this.setState({\n internal: true\n });\n }); // Render out injected frame\n\n if (frame) return frame;\n } // Update phase -----------------------------------------------------------\n\n\n if (this.injectProps || propsChanged) {\n // We can potentially cause setState, but we're inside render, the flag prevents that\n this.didInject = false; // Update animations, this turns from/to props into AnimatedValues\n // An update can occur on injected props, or when own-props have changed.\n\n if (this.injectProps) {\n this.controller.update(this.injectProps); // didInject is needed, because there will be a 3rd stage, where the original values\n // .. will be restored after the animation is finished. When someone animates towards\n // .. \"auto\", the end-result should be \"auto\", not \"1999px\", which would block nested\n // .. height/width changes.\n\n this.didInject = true;\n } else if (propsChanged) this.controller.update(this.props); // Flag an update that occured, componentDidUpdate will start the animation later on\n\n\n this.didUpdate = true;\n this.afterInject = undefined;\n this.injectProps = undefined;\n } // Render phase -----------------------------------------------------------\n // Render out raw values or AnimatedValues depending on \"native\"\n\n\n let values = _extends({}, this.controller.getValues(), this.afterInject);\n\n if (this.finished) values = _extends({}, values, this.props.after);\n return Object.keys(values).length ? children(values) : null;\n }\n\n componentDidUpdate() {\n // The animation has to start *after* render, since at that point the scene\n // .. graph should be established, so we do it here. Unfortunatelly, non-native\n // .. animations as well as \"auto\"-injects call forceUpdate, so it's causing a loop.\n // .. didUpdate prevents that as it gets set only on prop changes.\n if (this.didUpdate) this.start();\n this.didUpdate = false;\n }\n\n}\nSpring.defaultProps = {\n from: {},\n to: {},\n config: config.default,\n native: false,\n immediate: false,\n reset: false,\n force: false,\n inject: bugfixes\n};\n\nclass Trail extends React__default.PureComponent {\n constructor() {\n super(...arguments);\n this.first = true;\n this.instances = new Set();\n\n this.hook = (instance, index, length, reverse) => {\n // Add instance to set\n this.instances.add(instance); // Return undefined on the first index and from then on the previous instance\n\n if (reverse ? index === length - 1 : index === 0) return undefined;else return Array.from(this.instances)[reverse ? index + 1 : index - 1];\n };\n }\n\n render() {\n const _this$props = this.props,\n items = _this$props.items,\n _children = _this$props.children,\n _this$props$from = _this$props.from,\n from = _this$props$from === void 0 ? {} : _this$props$from,\n initial = _this$props.initial,\n reverse = _this$props.reverse,\n keys = _this$props.keys,\n delay = _this$props.delay,\n onRest = _this$props.onRest,\n props = _objectWithoutPropertiesLoose(_this$props, [\"items\", \"children\", \"from\", \"initial\", \"reverse\", \"keys\", \"delay\", \"onRest\"]);\n\n const array = toArray(items);\n return toArray(array).map((item, i) => React__default.createElement(Spring, _extends({\n onRest: i === 0 ? onRest : null,\n key: typeof keys === 'function' ? keys(item) : toArray(keys)[i],\n from: this.first && initial !== void 0 ? initial || {} : from\n }, props, {\n delay: i === 0 && delay || undefined,\n attach: instance => this.hook(instance, i, array.length, reverse),\n children: props => {\n const child = _children(item, i);\n\n return child ? child(props) : null;\n }\n })));\n }\n\n componentDidUpdate(prevProps) {\n this.first = false;\n if (prevProps.items !== this.props.items) this.instances.clear();\n }\n\n}\nTrail.defaultProps = {\n keys: item => item\n};\n\nconst DEFAULT = '__default';\n\nclass KeyframesImpl extends React__default.PureComponent {\n constructor() {\n var _this;\n\n super(...arguments);\n _this = this;\n this.guid = 0;\n this.state = {\n props: {},\n resolve: () => null,\n last: true,\n index: 0\n };\n\n this.next = function (props, last, index) {\n if (last === void 0) {\n last = true;\n }\n\n if (index === void 0) {\n index = 0;\n }\n\n _this.running = true;\n return new Promise(resolve => {\n _this.mounted && _this.setState(state => ({\n props,\n resolve,\n last,\n index\n }), () => _this.running = false);\n });\n };\n }\n\n componentDidMount() {\n this.mounted = true;\n this.componentDidUpdate({});\n }\n\n componentWillUnmount() {\n this.mounted = false;\n }\n\n componentDidUpdate(previous) {\n var _this2 = this;\n\n const _this$props = this.props,\n states = _this$props.states,\n f = _this$props.filter,\n state = _this$props.state;\n\n if (previous.state !== this.props.state || this.props.reset && !this.running || !shallowEqual(states[state], previous.states[previous.state])) {\n if (states && state && states[state]) {\n const localId = ++this.guid;\n const slots = states[state];\n\n if (slots) {\n if (Array.isArray(slots)) {\n let q = Promise.resolve();\n\n for (let i = 0; i < slots.length; i++) {\n let index = i;\n let slot = slots[index];\n let last = index === slots.length - 1;\n q = q.then(() => localId === this.guid && this.next(f(slot), last, index));\n }\n } else if (typeof slots === 'function') {\n let index = 0;\n slots( // next\n function (props, last) {\n if (last === void 0) {\n last = false;\n }\n\n return localId === _this2.guid && _this2.next(f(props), last, index++);\n }, // cancel\n () => requestFrame(() => this.instance && this.instance.stop()), // ownprops\n this.props);\n } else {\n this.next(f(states[state]));\n }\n }\n }\n }\n }\n\n render() {\n const _this$state = this.state,\n props = _this$state.props,\n resolve = _this$state.resolve,\n last = _this$state.last,\n index = _this$state.index;\n if (!props || Object.keys(props).length === 0) return null;\n\n let _this$props2 = this.props,\n state = _this$props2.state,\n filter = _this$props2.filter,\n states = _this$props2.states,\n config = _this$props2.config,\n Component = _this$props2.primitive,\n _onRest = _this$props2.onRest,\n forwardRef = _this$props2.forwardRef,\n rest = _objectWithoutPropertiesLoose(_this$props2, [\"state\", \"filter\", \"states\", \"config\", \"primitive\", \"onRest\", \"forwardRef\"]); // Arrayed configs need an index to process\n\n\n if (Array.isArray(config)) config = config[index];\n return React__default.createElement(Component, _extends({\n ref: _ref => this.instance = handleRef(_ref, forwardRef),\n config: config\n }, rest, props, {\n onRest: args => {\n resolve(args);\n if (_onRest && last) _onRest(args);\n }\n }));\n }\n\n}\n\nKeyframesImpl.defaultProps = {\n state: DEFAULT\n};\nconst Keyframes = React__default.forwardRef((props, ref) => React__default.createElement(KeyframesImpl, _extends({}, props, {\n forwardRef: ref\n})));\n\nKeyframes.create = primitive => function (states, filter) {\n if (filter === void 0) {\n filter = states => states;\n }\n\n if (typeof states === 'function' || Array.isArray(states)) states = {\n [DEFAULT]: states\n };\n return props => React__default.createElement(KeyframesImpl, _extends({\n primitive: primitive,\n states: states,\n filter: filter\n }, props));\n};\n\nKeyframes.Spring = states => Keyframes.create(Spring)(states, interpolateTo);\n\nKeyframes.Trail = states => Keyframes.create(Trail)(states, interpolateTo);\n\nlet guid = 0;\n\nlet get = props => {\n let items = props.items,\n keys = props.keys,\n rest = _objectWithoutPropertiesLoose(props, [\"items\", \"keys\"]);\n\n items = toArray(items !== void 0 ? items : null);\n keys = typeof keys === 'function' ? items.map(keys) : toArray(keys); // Make sure numeric keys are interpreted as Strings (5 !== \"5\")\n\n return _extends({\n items,\n keys: keys.map(key => String(key))\n }, rest);\n};\n\nclass Transition extends React__default.PureComponent {\n componentDidMount() {\n this.mounted = true;\n }\n\n componentWillUnmount() {\n this.mounted = false;\n }\n\n constructor(prevProps) {\n super(prevProps);\n\n this.destroyItem = (item, key, state) => values => {\n const _this$props = this.props,\n onRest = _this$props.onRest,\n onDestroyed = _this$props.onDestroyed;\n\n if (this.mounted) {\n onDestroyed && onDestroyed(item);\n this.setState((_ref) => {\n let deleted = _ref.deleted;\n return {\n deleted: deleted.filter(t => t.key !== key)\n };\n });\n onRest && onRest(item, state, values);\n }\n };\n\n this.state = {\n first: true,\n transitions: [],\n current: {},\n deleted: [],\n prevProps\n };\n }\n\n static getDerivedStateFromProps(props, _ref2) {\n let first = _ref2.first,\n prevProps = _ref2.prevProps,\n state = _objectWithoutPropertiesLoose(_ref2, [\"first\", \"prevProps\"]);\n\n let _get = get(props),\n items = _get.items,\n keys = _get.keys,\n initial = _get.initial,\n from = _get.from,\n enter = _get.enter,\n leave = _get.leave,\n update = _get.update,\n _get$trail = _get.trail,\n trail = _get$trail === void 0 ? 0 : _get$trail,\n unique = _get.unique,\n config = _get.config;\n\n let _get2 = get(prevProps),\n _keys = _get2.keys,\n _items = _get2.items;\n\n let current = _extends({}, state.current);\n\n let deleted = [...state.deleted]; // Compare next keys with current keys\n\n let currentKeys = Object.keys(current);\n let currentSet = new Set(currentKeys);\n let nextSet = new Set(keys);\n let added = keys.filter(item => !currentSet.has(item));\n let removed = state.transitions.filter(item => !item.destroyed && !nextSet.has(item.originalKey)).map(i => i.originalKey);\n let updated = keys.filter(item => currentSet.has(item));\n let delay = 0;\n added.forEach(key => {\n // In unique mode, remove fading out transitions if their key comes in again\n if (unique && deleted.find(d => d.originalKey === key)) deleted = deleted.filter(t => t.originalKey !== key);\n const keyIndex = keys.indexOf(key);\n const item = items[keyIndex];\n const state = 'enter';\n current[key] = {\n state,\n originalKey: key,\n key: unique ? String(key) : guid++,\n item,\n trail: delay = delay + trail,\n config: callProp(config, item, state),\n from: callProp(first ? initial !== void 0 ? initial || {} : from : from, item),\n to: callProp(enter, item)\n };\n });\n removed.forEach(key => {\n const keyIndex = _keys.indexOf(key);\n\n const item = _items[keyIndex];\n const state = 'leave';\n deleted.push(_extends({}, current[key], {\n state,\n destroyed: true,\n left: _keys[Math.max(0, keyIndex - 1)],\n right: _keys[Math.min(_keys.length, keyIndex + 1)],\n trail: delay = delay + trail,\n config: callProp(config, item, state),\n to: callProp(leave, item)\n }));\n delete current[key];\n });\n updated.forEach(key => {\n const keyIndex = keys.indexOf(key);\n const item = items[keyIndex];\n const state = 'update';\n current[key] = _extends({}, current[key], {\n item,\n state,\n trail: delay = delay + trail,\n config: callProp(config, item, state),\n to: callProp(update, item)\n });\n }); // This tries to restore order for deleted items by finding their last known siblings\n\n let out = keys.map(key => current[key]);\n deleted.forEach((_ref3) => {\n let left = _ref3.left,\n right = _ref3.right,\n transition = _objectWithoutPropertiesLoose(_ref3, [\"left\", \"right\"]);\n\n let pos; // Was it the element on the left, if yes, move there ...\n\n if ((pos = out.findIndex(t => t.originalKey === left)) !== -1) pos += 1; // Or how about the element on the right ...\n\n if (pos === -1) pos = out.findIndex(t => t.originalKey === right); // Maybe we'll find it in the list of deleted items\n\n if (pos === -1) pos = deleted.findIndex(t => t.originalKey === left); // Checking right side as well\n\n if (pos === -1) pos = deleted.findIndex(t => t.originalKey === right); // And if nothing else helps, move it to the start ¯\\_(ツ)_/¯\n\n pos = Math.max(0, pos);\n out = [...out.slice(0, pos), transition, ...out.slice(pos)];\n });\n return {\n first: first && added.length === 0,\n transitions: out,\n current,\n deleted,\n prevProps: props\n };\n }\n\n render() {\n const _this$props2 = this.props,\n initial = _this$props2.initial,\n _this$props2$from = _this$props2.from,\n _this$props2$enter = _this$props2.enter,\n _this$props2$leave = _this$props2.leave,\n _this$props2$update = _this$props2.update,\n onDestroyed = _this$props2.onDestroyed,\n keys = _this$props2.keys,\n items = _this$props2.items,\n onFrame = _this$props2.onFrame,\n onRest = _this$props2.onRest,\n onStart = _this$props2.onStart,\n trail = _this$props2.trail,\n config = _this$props2.config,\n _children = _this$props2.children,\n unique = _this$props2.unique,\n reset = _this$props2.reset,\n extra = _objectWithoutPropertiesLoose(_this$props2, [\"initial\", \"from\", \"enter\", \"leave\", \"update\", \"onDestroyed\", \"keys\", \"items\", \"onFrame\", \"onRest\", \"onStart\", \"trail\", \"config\", \"children\", \"unique\", \"reset\"]);\n\n return this.state.transitions.map((_ref4, i) => {\n let state = _ref4.state,\n key = _ref4.key,\n item = _ref4.item,\n from = _ref4.from,\n to = _ref4.to,\n trail = _ref4.trail,\n config = _ref4.config,\n destroyed = _ref4.destroyed;\n return React__default.createElement(Keyframes, _extends({\n reset: reset && state === 'enter',\n primitive: Spring,\n state: state,\n filter: interpolateTo,\n states: {\n [state]: to\n },\n key: key,\n onRest: destroyed ? this.destroyItem(item, key, state) : onRest && (values => onRest(item, state, values)),\n onStart: onStart && (() => onStart(item, state)),\n onFrame: onFrame && (values => onFrame(item, state, values)),\n delay: trail,\n config: config\n }, extra, {\n from: from,\n children: props => {\n const child = _children(item, state, i);\n\n return child ? child(props) : null;\n }\n }));\n });\n }\n\n}\nTransition.defaultProps = {\n keys: item => item,\n unique: false,\n reset: false\n};\n\nconst domElements = ['a', 'abbr', 'address', 'area', 'article', 'aside', 'audio', 'b', 'base', 'bdi', 'bdo', 'big', 'blockquote', 'body', 'br', 'button', 'canvas', 'caption', 'cite', 'code', 'col', 'colgroup', 'data', 'datalist', 'dd', 'del', 'details', 'dfn', 'dialog', 'div', 'dl', 'dt', 'em', 'embed', 'fieldset', 'figcaption', 'figure', 'footer', 'form', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'head', 'header', 'hgroup', 'hr', 'html', 'i', 'iframe', 'img', 'input', 'ins', 'kbd', 'keygen', 'label', 'legend', 'li', 'link', 'main', 'map', 'mark', 'marquee', 'menu', 'menuitem', 'meta', 'meter', 'nav', 'noscript', 'object', 'ol', 'optgroup', 'option', 'output', 'p', 'param', 'picture', 'pre', 'progress', 'q', 'rp', 'rt', 'ruby', 's', 'samp', 'script', 'section', 'select', 'small', 'source', 'span', 'strong', 'style', 'sub', 'summary', 'sup', 'table', 'tbody', 'td', 'textarea', 'tfoot', 'th', 'thead', 'time', 'title', 'tr', 'track', 'u', 'ul', 'var', 'video', 'wbr', // SVG\n'circle', 'clipPath', 'defs', 'ellipse', 'foreignObject', 'g', 'image', 'line', 'linearGradient', 'mask', 'path', 'pattern', 'polygon', 'polyline', 'radialGradient', 'rect', 'stop', 'svg', 'text', 'tspan'];\nconst extendedAnimated = domElements.reduce((acc, element) => {\n acc[element] = createAnimatedComponent(element);\n return acc;\n}, createAnimatedComponent);\n\n__webpack_unused_export__ = Spring;\n__webpack_unused_export__ = Keyframes;\nexports.uT = Transition;\n__webpack_unused_export__ = Trail;\n__webpack_unused_export__ = Controller;\n__webpack_unused_export__ = config;\nexports.q = extendedAnimated;\n__webpack_unused_export__ = interpolate$1;\n__webpack_unused_export__ = Globals;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"4823.js","mappings":";AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./node_modules/react-spring/renderprops.js?3f87"],"sourcesContent":["'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'default' in ex) ? ex['default'] : ex; }\n\nvar _objectWithoutPropertiesLoose = _interopDefault(require('@babel/runtime/helpers/esm/objectWithoutPropertiesLoose'));\nvar _extends = _interopDefault(require('@babel/runtime/helpers/esm/extends'));\nvar React = require('react');\nvar React__default = _interopDefault(React);\nvar ReactDOM = _interopDefault(require('react-dom'));\n\nlet bugfixes = undefined;\nlet applyAnimatedValues = undefined;\nlet colorNames = [];\nlet requestFrame = cb => typeof window !== 'undefined' && window.requestAnimationFrame(cb);\nlet cancelFrame = cb => typeof window !== 'undefined' && window.cancelAnimationFrame(cb);\nlet interpolation = undefined;\nlet now = () => Date.now();\nlet defaultElement = undefined;\nlet createAnimatedStyle = undefined;\nconst injectApplyAnimatedValues = (fn, transform) => applyAnimatedValues = {\n  fn,\n  transform\n};\nconst injectColorNames = names => colorNames = names;\nconst injectBugfixes = fn => bugfixes = fn;\nconst injectInterpolation = cls => interpolation = cls;\nconst injectFrame = (raf, caf) => {\n  var _ref = [raf, caf];\n  requestFrame = _ref[0];\n  cancelFrame = _ref[1];\n  return _ref;\n};\nconst injectNow = nowFn => now = nowFn;\nconst injectDefaultElement = el => defaultElement = el;\nconst injectCreateAnimatedStyle = factory => createAnimatedStyle = factory;\n\nvar Globals = /*#__PURE__*/Object.freeze({\n  get bugfixes () { return bugfixes; },\n  get applyAnimatedValues () { return applyAnimatedValues; },\n  get colorNames () { return colorNames; },\n  get requestFrame () { return requestFrame; },\n  get cancelFrame () { return cancelFrame; },\n  get interpolation () { return interpolation; },\n  get now () { return now; },\n  get defaultElement () { return defaultElement; },\n  get createAnimatedStyle () { return createAnimatedStyle; },\n  injectApplyAnimatedValues: injectApplyAnimatedValues,\n  injectColorNames: injectColorNames,\n  injectBugfixes: injectBugfixes,\n  injectInterpolation: injectInterpolation,\n  injectFrame: injectFrame,\n  injectNow: injectNow,\n  injectDefaultElement: injectDefaultElement,\n  injectCreateAnimatedStyle: injectCreateAnimatedStyle\n});\n\nclass Animated {\n  attach() {}\n\n  detach() {}\n\n  getValue() {}\n\n  getAnimatedValue() {\n    return this.getValue();\n  }\n\n  addChild(child) {}\n\n  removeChild(child) {}\n\n  getChildren() {\n    return [];\n  }\n\n}\n\nconst getValues = object => Object.keys(object).map(k => object[k]);\n\nclass AnimatedWithChildren extends Animated {\n  constructor() {\n    var _this;\n\n    super(...arguments);\n    _this = this;\n    this.children = [];\n\n    this.getChildren = () => this.children;\n\n    this.getPayload = function (index) {\n      if (index === void 0) {\n        index = undefined;\n      }\n\n      return index !== void 0 && _this.payload ? _this.payload[index] : _this.payload || _this;\n    };\n  }\n\n  addChild(child) {\n    if (this.children.length === 0) this.attach();\n    this.children.push(child);\n  }\n\n  removeChild(child) {\n    const index = this.children.indexOf(child);\n    this.children.splice(index, 1);\n    if (this.children.length === 0) this.detach();\n  }\n\n}\nclass AnimatedArrayWithChildren extends AnimatedWithChildren {\n  constructor() {\n    super(...arguments);\n    this.payload = [];\n\n    this.getAnimatedValue = () => this.getValue();\n\n    this.attach = () => this.payload.forEach(p => p instanceof Animated && p.addChild(this));\n\n    this.detach = () => this.payload.forEach(p => p instanceof Animated && p.removeChild(this));\n  }\n\n}\nclass AnimatedObjectWithChildren extends AnimatedWithChildren {\n  constructor() {\n    super(...arguments);\n    this.payload = {};\n\n    this.getAnimatedValue = () => this.getValue(true);\n\n    this.attach = () => getValues(this.payload).forEach(s => s instanceof Animated && s.addChild(this));\n\n    this.detach = () => getValues(this.payload).forEach(s => s instanceof Animated && s.removeChild(this));\n  }\n\n  getValue(animated) {\n    if (animated === void 0) {\n      animated = false;\n    }\n\n    const payload = {};\n\n    for (const key in this.payload) {\n      const value = this.payload[key];\n      if (animated && !(value instanceof Animated)) continue;\n      payload[key] = value instanceof Animated ? value[animated ? 'getAnimatedValue' : 'getValue']() : value;\n    }\n\n    return payload;\n  }\n\n}\n\nclass AnimatedStyle extends AnimatedObjectWithChildren {\n  constructor(style) {\n    super();\n    style = style || {};\n    if (style.transform && !(style.transform instanceof Animated)) style = applyAnimatedValues.transform(style);\n    this.payload = style;\n  }\n\n}\n\n// http://www.w3.org/TR/css3-color/#svg-color\nconst colors = {\n  transparent: 0x00000000,\n  aliceblue: 0xf0f8ffff,\n  antiquewhite: 0xfaebd7ff,\n  aqua: 0x00ffffff,\n  aquamarine: 0x7fffd4ff,\n  azure: 0xf0ffffff,\n  beige: 0xf5f5dcff,\n  bisque: 0xffe4c4ff,\n  black: 0x000000ff,\n  blanchedalmond: 0xffebcdff,\n  blue: 0x0000ffff,\n  blueviolet: 0x8a2be2ff,\n  brown: 0xa52a2aff,\n  burlywood: 0xdeb887ff,\n  burntsienna: 0xea7e5dff,\n  cadetblue: 0x5f9ea0ff,\n  chartreuse: 0x7fff00ff,\n  chocolate: 0xd2691eff,\n  coral: 0xff7f50ff,\n  cornflowerblue: 0x6495edff,\n  cornsilk: 0xfff8dcff,\n  crimson: 0xdc143cff,\n  cyan: 0x00ffffff,\n  darkblue: 0x00008bff,\n  darkcyan: 0x008b8bff,\n  darkgoldenrod: 0xb8860bff,\n  darkgray: 0xa9a9a9ff,\n  darkgreen: 0x006400ff,\n  darkgrey: 0xa9a9a9ff,\n  darkkhaki: 0xbdb76bff,\n  darkmagenta: 0x8b008bff,\n  darkolivegreen: 0x556b2fff,\n  darkorange: 0xff8c00ff,\n  darkorchid: 0x9932ccff,\n  darkred: 0x8b0000ff,\n  darksalmon: 0xe9967aff,\n  darkseagreen: 0x8fbc8fff,\n  darkslateblue: 0x483d8bff,\n  darkslategray: 0x2f4f4fff,\n  darkslategrey: 0x2f4f4fff,\n  darkturquoise: 0x00ced1ff,\n  darkviolet: 0x9400d3ff,\n  deeppink: 0xff1493ff,\n  deepskyblue: 0x00bfffff,\n  dimgray: 0x696969ff,\n  dimgrey: 0x696969ff,\n  dodgerblue: 0x1e90ffff,\n  firebrick: 0xb22222ff,\n  floralwhite: 0xfffaf0ff,\n  forestgreen: 0x228b22ff,\n  fuchsia: 0xff00ffff,\n  gainsboro: 0xdcdcdcff,\n  ghostwhite: 0xf8f8ffff,\n  gold: 0xffd700ff,\n  goldenrod: 0xdaa520ff,\n  gray: 0x808080ff,\n  green: 0x008000ff,\n  greenyellow: 0xadff2fff,\n  grey: 0x808080ff,\n  honeydew: 0xf0fff0ff,\n  hotpink: 0xff69b4ff,\n  indianred: 0xcd5c5cff,\n  indigo: 0x4b0082ff,\n  ivory: 0xfffff0ff,\n  khaki: 0xf0e68cff,\n  lavender: 0xe6e6faff,\n  lavenderblush: 0xfff0f5ff,\n  lawngreen: 0x7cfc00ff,\n  lemonchiffon: 0xfffacdff,\n  lightblue: 0xadd8e6ff,\n  lightcoral: 0xf08080ff,\n  lightcyan: 0xe0ffffff,\n  lightgoldenrodyellow: 0xfafad2ff,\n  lightgray: 0xd3d3d3ff,\n  lightgreen: 0x90ee90ff,\n  lightgrey: 0xd3d3d3ff,\n  lightpink: 0xffb6c1ff,\n  lightsalmon: 0xffa07aff,\n  lightseagreen: 0x20b2aaff,\n  lightskyblue: 0x87cefaff,\n  lightslategray: 0x778899ff,\n  lightslategrey: 0x778899ff,\n  lightsteelblue: 0xb0c4deff,\n  lightyellow: 0xffffe0ff,\n  lime: 0x00ff00ff,\n  limegreen: 0x32cd32ff,\n  linen: 0xfaf0e6ff,\n  magenta: 0xff00ffff,\n  maroon: 0x800000ff,\n  mediumaquamarine: 0x66cdaaff,\n  mediumblue: 0x0000cdff,\n  mediumorchid: 0xba55d3ff,\n  mediumpurple: 0x9370dbff,\n  mediumseagreen: 0x3cb371ff,\n  mediumslateblue: 0x7b68eeff,\n  mediumspringgreen: 0x00fa9aff,\n  mediumturquoise: 0x48d1ccff,\n  mediumvioletred: 0xc71585ff,\n  midnightblue: 0x191970ff,\n  mintcream: 0xf5fffaff,\n  mistyrose: 0xffe4e1ff,\n  moccasin: 0xffe4b5ff,\n  navajowhite: 0xffdeadff,\n  navy: 0x000080ff,\n  oldlace: 0xfdf5e6ff,\n  olive: 0x808000ff,\n  olivedrab: 0x6b8e23ff,\n  orange: 0xffa500ff,\n  orangered: 0xff4500ff,\n  orchid: 0xda70d6ff,\n  palegoldenrod: 0xeee8aaff,\n  palegreen: 0x98fb98ff,\n  paleturquoise: 0xafeeeeff,\n  palevioletred: 0xdb7093ff,\n  papayawhip: 0xffefd5ff,\n  peachpuff: 0xffdab9ff,\n  peru: 0xcd853fff,\n  pink: 0xffc0cbff,\n  plum: 0xdda0ddff,\n  powderblue: 0xb0e0e6ff,\n  purple: 0x800080ff,\n  rebeccapurple: 0x663399ff,\n  red: 0xff0000ff,\n  rosybrown: 0xbc8f8fff,\n  royalblue: 0x4169e1ff,\n  saddlebrown: 0x8b4513ff,\n  salmon: 0xfa8072ff,\n  sandybrown: 0xf4a460ff,\n  seagreen: 0x2e8b57ff,\n  seashell: 0xfff5eeff,\n  sienna: 0xa0522dff,\n  silver: 0xc0c0c0ff,\n  skyblue: 0x87ceebff,\n  slateblue: 0x6a5acdff,\n  slategray: 0x708090ff,\n  slategrey: 0x708090ff,\n  snow: 0xfffafaff,\n  springgreen: 0x00ff7fff,\n  steelblue: 0x4682b4ff,\n  tan: 0xd2b48cff,\n  teal: 0x008080ff,\n  thistle: 0xd8bfd8ff,\n  tomato: 0xff6347ff,\n  turquoise: 0x40e0d0ff,\n  violet: 0xee82eeff,\n  wheat: 0xf5deb3ff,\n  white: 0xffffffff,\n  whitesmoke: 0xf5f5f5ff,\n  yellow: 0xffff00ff,\n  yellowgreen: 0x9acd32ff\n};\n\nclass Interpolation {\n  // Default config = config, args\n  // Short config   = range, output, extrapolate\n  static create(config, output, extra) {\n    if (typeof config === 'function') return config;else if (interpolation && config.output && typeof config.output[0] === 'string') return interpolation(config);else if (Array.isArray(config)) return Interpolation.create({\n      range: config,\n      output,\n      extrapolate: extra || 'extend'\n    });\n    let outputRange = config.output;\n    let inputRange = config.range || [0, 1];\n\n    let easing = config.easing || (t => t);\n\n    let extrapolateLeft = 'extend';\n    let map = config.map;\n    if (config.extrapolateLeft !== undefined) extrapolateLeft = config.extrapolateLeft;else if (config.extrapolate !== undefined) extrapolateLeft = config.extrapolate;\n    let extrapolateRight = 'extend';\n    if (config.extrapolateRight !== undefined) extrapolateRight = config.extrapolateRight;else if (config.extrapolate !== undefined) extrapolateRight = config.extrapolate;\n    return input => {\n      let range = findRange(input, inputRange);\n      return interpolate(input, inputRange[range], inputRange[range + 1], outputRange[range], outputRange[range + 1], easing, extrapolateLeft, extrapolateRight, map);\n    };\n  }\n\n}\n\nfunction interpolate(input, inputMin, inputMax, outputMin, outputMax, easing, extrapolateLeft, extrapolateRight, map) {\n  let result = map ? map(input) : input; // Extrapolate\n\n  if (result < inputMin) {\n    if (extrapolateLeft === 'identity') return result;else if (extrapolateLeft === 'clamp') result = inputMin;\n  }\n\n  if (result > inputMax) {\n    if (extrapolateRight === 'identity') return result;else if (extrapolateRight === 'clamp') result = inputMax;\n  }\n\n  if (outputMin === outputMax) return outputMin;\n  if (inputMin === inputMax) return input <= inputMin ? outputMin : outputMax; // Input Range\n\n  if (inputMin === -Infinity) result = -result;else if (inputMax === Infinity) result = result - inputMin;else result = (result - inputMin) / (inputMax - inputMin); // Easing\n\n  result = easing(result); // Output Range\n\n  if (outputMin === -Infinity) result = -result;else if (outputMax === Infinity) result = result + outputMin;else result = result * (outputMax - outputMin) + outputMin;\n  return result;\n}\n\nfunction findRange(input, inputRange) {\n  for (var i = 1; i < inputRange.length - 1; ++i) if (inputRange[i] >= input) break;\n\n  return i - 1;\n}\n\n// const INTEGER = '[-+]?\\\\d+';\nconst NUMBER = '[-+]?\\\\d*\\\\.?\\\\d+';\nconst PERCENTAGE = NUMBER + '%';\n\nfunction call() {\n  return '\\\\(\\\\s*(' + Array.prototype.slice.call(arguments).join(')\\\\s*,\\\\s*(') + ')\\\\s*\\\\)';\n}\n\nconst rgb = new RegExp('rgb' + call(NUMBER, NUMBER, NUMBER));\nconst rgba = new RegExp('rgba' + call(NUMBER, NUMBER, NUMBER, NUMBER));\nconst hsl = new RegExp('hsl' + call(NUMBER, PERCENTAGE, PERCENTAGE));\nconst hsla = new RegExp('hsla' + call(NUMBER, PERCENTAGE, PERCENTAGE, NUMBER));\nconst hex3 = /^#([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/;\nconst hex4 = /^#([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/;\nconst hex6 = /^#([0-9a-fA-F]{6})$/;\nconst hex8 = /^#([0-9a-fA-F]{8})$/;\n\n/*\nhttps://github.com/react-community/normalize-css-color\n\nBSD 3-Clause License\n\nCopyright (c) 2016, React Community\nAll rights reserved.\n\nRedistribution and use in source and binary forms, with or without\nmodification, are permitted provided that the following conditions are met:\n\n* Redistributions of source code must retain the above copyright notice, this\n  list of conditions and the following disclaimer.\n\n* Redistributions in binary form must reproduce the above copyright notice,\n  this list of conditions and the following disclaimer in the documentation\n  and/or other materials provided with the distribution.\n\n* Neither the name of the copyright holder nor the names of its\n  contributors may be used to endorse or promote products derived from\n  this software without specific prior written permission.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\"\nAND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\nIMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\nFOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\nDAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\nSERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\nCAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\nOR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\nOF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n*/\nfunction normalizeColor(color) {\n  let match;\n\n  if (typeof color === 'number') {\n    return color >>> 0 === color && color >= 0 && color <= 0xffffffff ? color : null;\n  } // Ordered based on occurrences on Facebook codebase\n\n\n  if (match = hex6.exec(color)) return parseInt(match[1] + 'ff', 16) >>> 0;\n  if (colors.hasOwnProperty(color)) return colors[color];\n\n  if (match = rgb.exec(color)) {\n    return (parse255(match[1]) << 24 | // r\n    parse255(match[2]) << 16 | // g\n    parse255(match[3]) << 8 | // b\n    0x000000ff) >>> // a\n    0;\n  }\n\n  if (match = rgba.exec(color)) {\n    return (parse255(match[1]) << 24 | // r\n    parse255(match[2]) << 16 | // g\n    parse255(match[3]) << 8 | // b\n    parse1(match[4])) >>> // a\n    0;\n  }\n\n  if (match = hex3.exec(color)) {\n    return parseInt(match[1] + match[1] + // r\n    match[2] + match[2] + // g\n    match[3] + match[3] + // b\n    'ff', // a\n    16) >>> 0;\n  } // https://drafts.csswg.org/css-color-4/#hex-notation\n\n\n  if (match = hex8.exec(color)) return parseInt(match[1], 16) >>> 0;\n\n  if (match = hex4.exec(color)) {\n    return parseInt(match[1] + match[1] + // r\n    match[2] + match[2] + // g\n    match[3] + match[3] + // b\n    match[4] + match[4], // a\n    16) >>> 0;\n  }\n\n  if (match = hsl.exec(color)) {\n    return (hslToRgb(parse360(match[1]), // h\n    parsePercentage(match[2]), // s\n    parsePercentage(match[3]) // l\n    ) | 0x000000ff) >>> // a\n    0;\n  }\n\n  if (match = hsla.exec(color)) {\n    return (hslToRgb(parse360(match[1]), // h\n    parsePercentage(match[2]), // s\n    parsePercentage(match[3]) // l\n    ) | parse1(match[4])) >>> // a\n    0;\n  }\n\n  return null;\n}\n\nfunction hue2rgb(p, q, t) {\n  if (t < 0) t += 1;\n  if (t > 1) t -= 1;\n  if (t < 1 / 6) return p + (q - p) * 6 * t;\n  if (t < 1 / 2) return q;\n  if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6;\n  return p;\n}\n\nfunction hslToRgb(h, s, l) {\n  const q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n  const p = 2 * l - q;\n  const r = hue2rgb(p, q, h + 1 / 3);\n  const g = hue2rgb(p, q, h);\n  const b = hue2rgb(p, q, h - 1 / 3);\n  return Math.round(r * 255) << 24 | Math.round(g * 255) << 16 | Math.round(b * 255) << 8;\n}\n\nfunction parse255(str) {\n  const int = parseInt(str, 10);\n  if (int < 0) return 0;\n  if (int > 255) return 255;\n  return int;\n}\n\nfunction parse360(str) {\n  const int = parseFloat(str);\n  return (int % 360 + 360) % 360 / 360;\n}\n\nfunction parse1(str) {\n  const num = parseFloat(str);\n  if (num < 0) return 0;\n  if (num > 1) return 255;\n  return Math.round(num * 255);\n}\n\nfunction parsePercentage(str) {\n  // parseFloat conveniently ignores the final %\n  const int = parseFloat(str);\n  if (int < 0) return 0;\n  if (int > 100) return 1;\n  return int / 100;\n}\n\nfunction colorToRgba(input) {\n  let int32Color = normalizeColor(input);\n  if (int32Color === null) return input;\n  int32Color = int32Color || 0;\n  let r = (int32Color & 0xff000000) >>> 24;\n  let g = (int32Color & 0x00ff0000) >>> 16;\n  let b = (int32Color & 0x0000ff00) >>> 8;\n  let a = (int32Color & 0x000000ff) / 255;\n  return `rgba(${r}, ${g}, ${b}, ${a})`;\n} // Problem: https://github.com/animatedjs/animated/pull/102\n// Solution: https://stackoverflow.com/questions/638565/parsing-scientific-notation-sensibly/658662\n\n\nconst stringShapeRegex = /[+\\-]?(?:0|[1-9]\\d*)(?:\\.\\d*)?(?:[eE][+\\-]?\\d+)?/g; // Covers rgb, rgba, hsl, hsla\n// Taken from https://gist.github.com/olmokramer/82ccce673f86db7cda5e\n\nconst colorRegex = /(#(?:[0-9a-f]{2}){2,4}|(#[0-9a-f]{3})|(rgb|hsl)a?\\((-?\\d+%?[,\\s]+){2,3}\\s*[\\d\\.]+%?\\))/gi; // Covers color names (transparent, blue, etc.)\n\nconst colorNamesRegex = new RegExp(`(${Object.keys(colors).join('|')})`, 'g');\n/**\n * Supports string shapes by extracting numbers so new values can be computed,\n * and recombines those values into new strings of the same shape.  Supports\n * things like:\n *\n *   rgba(123, 42, 99, 0.36)           // colors\n *   -45deg                            // values with units\n *   0 2px 2px 0px rgba(0, 0, 0, 0.12) // box shadows\n */\n\nfunction createInterpolation(config) {\n  // Replace colors with rgba\n  const outputRange = config.output.map(rangeValue => rangeValue.replace(colorRegex, colorToRgba)).map(rangeValue => rangeValue.replace(colorNamesRegex, colorToRgba)); // ->\n  // [\n  //   [0, 50],\n  //   [100, 150],\n  //   [200, 250],\n  //   [0, 0.5],\n  // ]\n\n  const outputRanges = outputRange[0].match(stringShapeRegex).map(() => []);\n  outputRange.forEach(value => {\n    value.match(stringShapeRegex).forEach((number, i) => outputRanges[i].push(+number));\n  });\n  const interpolations = outputRange[0].match(stringShapeRegex).map((value, i) => {\n    return Interpolation.create(_extends({}, config, {\n      output: outputRanges[i]\n    }));\n  });\n  return input => {\n    let i = 0;\n    return outputRange[0] // 'rgba(0, 100, 200, 0)'\n    // ->\n    // 'rgba(${interpolations[0](input)}, ${interpolations[1](input)}, ...'\n    .replace(stringShapeRegex, () => interpolations[i++](input)) // rgba requires that the r,g,b are integers.... so we want to round them, but we *dont* want to\n    // round the opacity (4th column).\n    .replace(/rgba\\(([0-9\\.-]+), ([0-9\\.-]+), ([0-9\\.-]+), ([0-9\\.-]+)\\)/gi, (_, p1, p2, p3, p4) => `rgba(${Math.round(p1)}, ${Math.round(p2)}, ${Math.round(p3)}, ${p4})`);\n  };\n}\n\nclass AnimatedInterpolation extends AnimatedArrayWithChildren {\n  constructor(parents, _config, _arg) {\n    super();\n\n    this.getValue = () => this.calc(...this.payload.map(value => value.getValue()));\n\n    this.updateConfig = (config, arg) => this.calc = Interpolation.create(config, arg);\n\n    this.interpolate = (config, arg) => new AnimatedInterpolation(this, config, arg);\n\n    this.payload = // AnimatedArrays should unfold, except AnimatedInterpolation which is taken as is\n    parents instanceof AnimatedArrayWithChildren && !parents.updateConfig ? parents.payload : Array.isArray(parents) ? parents : [parents];\n    this.calc = Interpolation.create(_config, _arg);\n  }\n\n}\nconst interpolate$1 = (parents, config, arg) => parents && new AnimatedInterpolation(parents, config, arg);\n\n/**\n * Animated works by building a directed acyclic graph of dependencies\n * transparently when you render your Animated components.\n *\n *               new Animated.Value(0)\n *     .interpolate()        .interpolate()    new Animated.Value(1)\n *         opacity               translateY      scale\n *          style                         transform\n *         View#234                         style\n *                                         View#123\n *\n * A) Top Down phase\n * When an Animated.Value is updated, we recursively go down through this\n * graph in order to find leaf nodes: the views that we flag as needing\n * an update.\n *\n * B) Bottom Up phase\n * When a view is flagged as needing an update, we recursively go back up\n * in order to build the new value that it needs. The reason why we need\n * this two-phases process is to deal with composite props such as\n * transform which can receive values from multiple parents.\n */\n\nfunction findAnimatedStyles(node, styles) {\n  if (typeof node.update === 'function') styles.add(node);else node.getChildren().forEach(child => findAnimatedStyles(child, styles));\n}\n/**\n * Standard value for driving animations.  One `Animated.Value` can drive\n * multiple properties in a synchronized fashion, but can only be driven by one\n * mechanism at a time.  Using a new mechanism (e.g. starting a new animation,\n * or calling `setValue`) will stop any previous ones.\n */\n\n\nclass AnimatedValue extends AnimatedWithChildren {\n  constructor(_value) {\n    var _this;\n\n    super();\n    _this = this;\n\n    this.setValue = function (value, flush) {\n      if (flush === void 0) {\n        flush = true;\n      }\n\n      _this.value = value;\n      if (flush) _this.flush();\n    };\n\n    this.getValue = () => this.value;\n\n    this.updateStyles = () => findAnimatedStyles(this, this.animatedStyles);\n\n    this.updateValue = value => this.flush(this.value = value);\n\n    this.interpolate = (config, arg) => new AnimatedInterpolation(this, config, arg);\n\n    this.value = _value;\n    this.animatedStyles = new Set();\n    this.done = false;\n    this.startPosition = _value;\n    this.lastPosition = _value;\n    this.lastVelocity = undefined;\n    this.lastTime = undefined;\n    this.controller = undefined;\n  }\n\n  flush() {\n    if (this.animatedStyles.size === 0) this.updateStyles();\n    this.animatedStyles.forEach(animatedStyle => animatedStyle.update());\n  }\n\n  prepare(controller) {\n    // Values stay loyal to their original controller, this is also a way to\n    // detect trailing values originating from a foreign controller\n    if (this.controller === undefined) this.controller = controller;\n\n    if (this.controller === controller) {\n      this.startPosition = this.value;\n      this.lastPosition = this.value;\n      this.lastVelocity = controller.isActive ? this.lastVelocity : undefined;\n      this.lastTime = controller.isActive ? this.lastTime : undefined;\n      this.done = false;\n      this.animatedStyles.clear();\n    }\n  }\n\n}\n\nclass AnimatedArray extends AnimatedArrayWithChildren {\n  constructor(array) {\n    var _this;\n\n    super();\n    _this = this;\n\n    this.setValue = function (value, flush) {\n      if (flush === void 0) {\n        flush = true;\n      }\n\n      if (Array.isArray(value)) {\n        if (value.length === _this.payload.length) value.forEach((v, i) => _this.payload[i].setValue(v, flush));\n      } else _this.payload.forEach((v, i) => _this.payload[i].setValue(value, flush));\n    };\n\n    this.getValue = () => this.payload.map(v => v.getValue());\n\n    this.interpolate = (config, arg) => new AnimatedInterpolation(this, config, arg);\n\n    this.payload = array.map(n => new AnimatedValue(n));\n  }\n\n}\n\nfunction withDefault(value, defaultValue) {\n  return value === undefined || value === null ? defaultValue : value;\n}\nfunction toArray(a) {\n  return a !== void 0 ? Array.isArray(a) ? a : [a] : [];\n}\nfunction shallowEqual(a, b) {\n  if (typeof a !== typeof b) return false;\n  if (typeof a === 'string' || typeof a === 'number') return a === b;\n  let i;\n\n  for (i in a) if (!(i in b)) return false;\n\n  for (i in b) if (a[i] !== b[i]) return false;\n\n  return i === void 0 ? a === b : true;\n}\nfunction callProp(obj) {\n  for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n    args[_key - 1] = arguments[_key];\n  }\n\n  return typeof obj === 'function' ? obj(...args) : obj;\n}\nfunction getValues$1(object) {\n  return Object.keys(object).map(k => object[k]);\n}\nfunction getForwardProps(props) {\n  const to = props.to,\n        from = props.from,\n        config = props.config,\n        native = props.native,\n        onStart = props.onStart,\n        onRest = props.onRest,\n        onFrame = props.onFrame,\n        children = props.children,\n        reset = props.reset,\n        reverse = props.reverse,\n        force = props.force,\n        immediate = props.immediate,\n        impl = props.impl,\n        inject = props.inject,\n        delay = props.delay,\n        attach = props.attach,\n        destroyed = props.destroyed,\n        interpolateTo = props.interpolateTo,\n        autoStart = props.autoStart,\n        ref = props.ref,\n        forward = _objectWithoutPropertiesLoose(props, [\"to\", \"from\", \"config\", \"native\", \"onStart\", \"onRest\", \"onFrame\", \"children\", \"reset\", \"reverse\", \"force\", \"immediate\", \"impl\", \"inject\", \"delay\", \"attach\", \"destroyed\", \"interpolateTo\", \"autoStart\", \"ref\"]);\n\n  return forward;\n}\nfunction interpolateTo(props) {\n  const forward = getForwardProps(props);\n  const rest = Object.keys(props).reduce((a, k) => forward[k] !== void 0 ? a : _extends({}, a, {\n    [k]: props[k]\n  }), {});\n  return _extends({\n    to: forward\n  }, rest);\n}\nfunction convertToAnimatedValue(acc, _ref) {\n  let name = _ref[0],\n      value = _ref[1];\n  return _extends({}, acc, {\n    [name]: new (Array.isArray(value) ? AnimatedArray : AnimatedValue)(value)\n  });\n}\nfunction convertValues(props) {\n  const from = props.from,\n        to = props.to,\n        native = props.native;\n  const allProps = Object.entries(_extends({}, from, to));\n  return native ? allProps.reduce(convertToAnimatedValue, {}) : _extends({}, from, to);\n}\nfunction handleRef(ref, forward) {\n  if (forward) {\n    // If it's a function, assume it's a ref callback\n    if (typeof forward === 'function') forward(ref);else if (typeof forward === 'object') {\n      // If it's an object and has a 'current' property, assume it's a ref object\n      forward.current = ref;\n    }\n  }\n\n  return ref;\n}\n\nconst check = value => value === 'auto';\n\nconst overwrite = (width, height) => (acc, _ref) => {\n  let name = _ref[0],\n      value = _ref[1];\n  return _extends({}, acc, {\n    [name]: value === 'auto' ? ~name.indexOf('height') ? height : width : value\n  });\n};\n\nfunction fixAuto(props, callback) {\n  const from = props.from,\n        to = props.to,\n        children = props.children; // Dry-route props back if nothing's using 'auto' in there\n  // TODO: deal with \"null\"\n\n  if (!(getValues$1(to).some(check) || getValues$1(from).some(check))) return; // Fetch render v-dom\n\n  let element = children(convertValues(props)); // A spring can return undefined/null, check against that (#153)\n\n  if (!element) return; // Or it could be an array (#346) ...\n\n  if (Array.isArray(element)) element = {\n    type: 'div',\n    props: {\n      children: element\n    } // Extract styles\n\n  };\n  const elementStyles = element.props.style; // Return v.dom with injected ref\n\n  return React__default.createElement(element.type, _extends({\n    key: element.key ? element.key : undefined\n  }, element.props, {\n    style: _extends({}, elementStyles, {\n      position: 'absolute',\n      visibility: 'hidden'\n    }),\n    ref: _ref2 => {\n      if (_ref2) {\n        // Once it's rendered out, fetch bounds (minus padding/margin/borders)\n        let node = ReactDOM.findDOMNode(_ref2);\n        let width, height;\n        let cs = getComputedStyle(node);\n\n        if (cs.boxSizing === 'border-box') {\n          width = node.offsetWidth;\n          height = node.offsetHeight;\n        } else {\n          const paddingX = parseFloat(cs.paddingLeft || 0) + parseFloat(cs.paddingRight || 0);\n          const paddingY = parseFloat(cs.paddingTop || 0) + parseFloat(cs.paddingBottom || 0);\n          const borderX = parseFloat(cs.borderLeftWidth || 0) + parseFloat(cs.borderRightWidth || 0);\n          const borderY = parseFloat(cs.borderTopWidth || 0) + parseFloat(cs.borderBottomWidth || 0);\n          width = node.offsetWidth - paddingX - borderX;\n          height = node.offsetHeight - paddingY - borderY;\n        }\n\n        const convert = overwrite(width, height);\n        callback(_extends({}, props, {\n          from: Object.entries(from).reduce(convert, from),\n          to: Object.entries(to).reduce(convert, to)\n        }));\n      }\n    }\n  }));\n}\n\nlet isUnitlessNumber = {\n  animationIterationCount: true,\n  borderImageOutset: true,\n  borderImageSlice: true,\n  borderImageWidth: true,\n  boxFlex: true,\n  boxFlexGroup: true,\n  boxOrdinalGroup: true,\n  columnCount: true,\n  columns: true,\n  flex: true,\n  flexGrow: true,\n  flexPositive: true,\n  flexShrink: true,\n  flexNegative: true,\n  flexOrder: true,\n  gridRow: true,\n  gridRowEnd: true,\n  gridRowSpan: true,\n  gridRowStart: true,\n  gridColumn: true,\n  gridColumnEnd: true,\n  gridColumnSpan: true,\n  gridColumnStart: true,\n  fontWeight: true,\n  lineClamp: true,\n  lineHeight: true,\n  opacity: true,\n  order: true,\n  orphans: true,\n  tabSize: true,\n  widows: true,\n  zIndex: true,\n  zoom: true,\n  // SVG-related properties\n  fillOpacity: true,\n  floodOpacity: true,\n  stopOpacity: true,\n  strokeDasharray: true,\n  strokeDashoffset: true,\n  strokeMiterlimit: true,\n  strokeOpacity: true,\n  strokeWidth: true\n};\n\nconst prefixKey = (prefix, key) => prefix + key.charAt(0).toUpperCase() + key.substring(1);\n\nconst prefixes = ['Webkit', 'Ms', 'Moz', 'O'];\nisUnitlessNumber = Object.keys(isUnitlessNumber).reduce((acc, prop) => {\n  prefixes.forEach(prefix => acc[prefixKey(prefix, prop)] = acc[prop]);\n  return acc;\n}, isUnitlessNumber);\n\nfunction dangerousStyleValue(name, value, isCustomProperty) {\n  if (value == null || typeof value === 'boolean' || value === '') return '';\n  if (!isCustomProperty && typeof value === 'number' && value !== 0 && !(isUnitlessNumber.hasOwnProperty(name) && isUnitlessNumber[name])) return value + 'px'; // Presumes implicit 'px' suffix for unitless numbers\n\n  return ('' + value).trim();\n}\n\nconst attributeCache = {};\ninjectCreateAnimatedStyle(style => new AnimatedStyle(style));\ninjectDefaultElement('div');\ninjectInterpolation(createInterpolation);\ninjectColorNames(colors);\ninjectBugfixes(fixAuto);\ninjectApplyAnimatedValues((instance, props) => {\n  if (instance.nodeType && instance.setAttribute !== undefined) {\n    const style = props.style,\n          children = props.children,\n          scrollTop = props.scrollTop,\n          scrollLeft = props.scrollLeft,\n          attributes = _objectWithoutPropertiesLoose(props, [\"style\", \"children\", \"scrollTop\", \"scrollLeft\"]);\n\n    if (scrollTop !== void 0) instance.scrollTop = scrollTop;\n    if (scrollLeft !== void 0) instance.scrollLeft = scrollLeft; // Set textContent, if children is an animatable value\n\n    if (children !== void 0) instance.textContent = children; // Set styles ...\n\n    for (let styleName in style) {\n      if (!style.hasOwnProperty(styleName)) continue;\n      var isCustomProperty = styleName.indexOf('--') === 0;\n      var styleValue = dangerousStyleValue(styleName, style[styleName], isCustomProperty);\n      if (styleName === 'float') styleName = 'cssFloat';\n      if (isCustomProperty) instance.style.setProperty(styleName, styleValue);else instance.style[styleName] = styleValue;\n    } // Set attributes ...\n\n\n    for (let name in attributes) {\n      // Attributes are written in dash case\n      const dashCase = attributeCache[name] || (attributeCache[name] = name.replace(/([A-Z])/g, n => '-' + n.toLowerCase()));\n      if (typeof instance.getAttribute(dashCase) !== 'undefined') instance.setAttribute(dashCase, attributes[name]);\n    }\n  } else return false;\n}, style => style);\n\nlet active = false;\nconst controllers = new Set();\n\nconst frameLoop = () => {\n  let time = now();\n\n  for (let controller of controllers) {\n    let isDone = true;\n    let noChange = true;\n\n    for (let configIdx = 0; configIdx < controller.configs.length; configIdx++) {\n      let config = controller.configs[configIdx];\n      let endOfAnimation, lastTime;\n\n      for (let valIdx = 0; valIdx < config.animatedValues.length; valIdx++) {\n        let animation = config.animatedValues[valIdx]; // If an animation is done, skip, until all of them conclude\n\n        if (animation.done) continue;\n        let from = config.fromValues[valIdx];\n        let to = config.toValues[valIdx];\n        let position = animation.lastPosition;\n        let isAnimated = to instanceof Animated;\n        let velocity = Array.isArray(config.initialVelocity) ? config.initialVelocity[valIdx] : config.initialVelocity;\n        if (isAnimated) to = to.getValue(); // Conclude animation if it's either immediate, or from-values match end-state\n\n        if (config.immediate || !isAnimated && !config.decay && from === to) {\n          animation.updateValue(to);\n          animation.done = true;\n          continue;\n        } // Doing delay here instead of setTimeout is one async worry less\n\n\n        if (config.delay && time - controller.startTime < config.delay) {\n          isDone = false;\n          continue;\n        } // Flag change\n\n\n        noChange = false; // Break animation when string values are involved\n\n        if (typeof from === 'string' || typeof to === 'string') {\n          animation.updateValue(to);\n          animation.done = true;\n          continue;\n        }\n\n        if (config.duration !== void 0) {\n          /** Duration easing */\n          position = from + config.easing((time - controller.startTime - config.delay) / config.duration) * (to - from);\n          endOfAnimation = time >= controller.startTime + config.delay + config.duration;\n        } else if (config.decay) {\n          /** Decay easing */\n          position = from + velocity / (1 - 0.998) * (1 - Math.exp(-(1 - 0.998) * (time - controller.startTime)));\n          endOfAnimation = Math.abs(animation.lastPosition - position) < 0.1;\n          if (endOfAnimation) to = position;\n        } else {\n          /** Spring easing */\n          lastTime = animation.lastTime !== void 0 ? animation.lastTime : time;\n          velocity = animation.lastVelocity !== void 0 ? animation.lastVelocity : config.initialVelocity; // If we lost a lot of frames just jump to the end.\n\n          if (time > lastTime + 64) lastTime = time; // http://gafferongames.com/game-physics/fix-your-timestep/\n\n          let numSteps = Math.floor(time - lastTime);\n\n          for (let i = 0; i < numSteps; ++i) {\n            let force = -config.tension * (position - to);\n            let damping = -config.friction * velocity;\n            let acceleration = (force + damping) / config.mass;\n            velocity = velocity + acceleration * 1 / 1000;\n            position = position + velocity * 1 / 1000;\n          } // Conditions for stopping the spring animation\n\n\n          let isOvershooting = config.clamp && config.tension !== 0 ? from < to ? position > to : position < to : false;\n          let isVelocity = Math.abs(velocity) <= config.precision;\n          let isDisplacement = config.tension !== 0 ? Math.abs(to - position) <= config.precision : true;\n          endOfAnimation = isOvershooting || isVelocity && isDisplacement;\n          animation.lastVelocity = velocity;\n          animation.lastTime = time;\n        } // Trails aren't done until their parents conclude\n\n\n        if (isAnimated && !config.toValues[valIdx].done) endOfAnimation = false;\n\n        if (endOfAnimation) {\n          // Ensure that we end up with a round value\n          if (animation.value !== to) position = to;\n          animation.done = true;\n        } else isDone = false;\n\n        animation.updateValue(position);\n        animation.lastPosition = position;\n      } // Keep track of updated values only when necessary\n\n\n      if (controller.props.onFrame || !controller.props.native) controller.animatedProps[config.name] = config.interpolation.getValue();\n    } // Update callbacks in the end of the frame\n\n\n    if (controller.props.onFrame || !controller.props.native) {\n      if (!controller.props.native && controller.onUpdate) controller.onUpdate();\n      if (controller.props.onFrame) controller.props.onFrame(controller.animatedProps);\n    } // Either call onEnd or next frame\n\n\n    if (isDone) {\n      controllers.delete(controller);\n      controller.debouncedOnEnd({\n        finished: true,\n        noChange\n      });\n    }\n  } // Loop over as long as there are controllers ...\n\n\n  if (controllers.size) requestFrame(frameLoop);else active = false;\n};\n\nconst addController = controller => {\n  if (!controllers.has(controller)) {\n    controllers.add(controller);\n    if (!active) requestFrame(frameLoop);\n    active = true;\n  }\n};\n\nconst removeController = controller => {\n  if (controllers.has(controller)) {\n    controllers.delete(controller);\n  }\n};\n\nclass Controller {\n  constructor(props, config) {\n    if (config === void 0) {\n      config = {\n        native: true,\n        interpolateTo: true,\n        autoStart: true\n      };\n    }\n\n    this.getValues = () => this.props.native ? this.interpolations : this.animatedProps;\n\n    this.dependents = new Set();\n    this.isActive = false;\n    this.hasChanged = false;\n    this.props = {};\n    this.merged = {};\n    this.animations = {};\n    this.interpolations = {};\n    this.animatedProps = {};\n    this.configs = [];\n    this.frame = undefined;\n    this.startTime = undefined;\n    this.lastTime = undefined;\n    this.update(_extends({}, props, config));\n  }\n\n  update(props) {\n    this.props = _extends({}, this.props, props);\n\n    let _ref = this.props.interpolateTo ? interpolateTo(this.props) : this.props,\n        _ref$from = _ref.from,\n        from = _ref$from === void 0 ? {} : _ref$from,\n        _ref$to = _ref.to,\n        to = _ref$to === void 0 ? {} : _ref$to,\n        _ref$config = _ref.config,\n        config = _ref$config === void 0 ? {} : _ref$config,\n        _ref$delay = _ref.delay,\n        delay = _ref$delay === void 0 ? 0 : _ref$delay,\n        reverse = _ref.reverse,\n        attach = _ref.attach,\n        reset = _ref.reset,\n        immediate = _ref.immediate,\n        autoStart = _ref.autoStart,\n        ref = _ref.ref; // Reverse values when requested\n\n\n    if (reverse) {\n      var _ref2 = [to, from];\n      from = _ref2[0];\n      to = _ref2[1];\n    }\n\n    this.hasChanged = false; // Attachment handling, trailed springs can \"attach\" themselves to a previous spring\n\n    let target = attach && attach(this); // Reset merged props when necessary\n\n    let extra = reset ? {} : this.merged; // This will collect all props that were ever set\n\n    this.merged = _extends({}, from, extra, to); // Reduces input { name: value } pairs into animated values\n\n    this.animations = Object.entries(this.merged).reduce((acc, _ref3, i) => {\n      let name = _ref3[0],\n          value = _ref3[1];\n      // Issue cached entries, except on reset\n      let entry = !reset && acc[name] || {}; // Figure out what the value is supposed to be\n\n      const isNumber = typeof value === 'number';\n      const isString = typeof value === 'string' && !value.startsWith('#') && !/\\d/.test(value) && !colorNames[value];\n      const isArray = !isNumber && !isString && Array.isArray(value);\n      let fromValue = from[name] !== undefined ? from[name] : value;\n      let toValue = isNumber || isArray ? value : isString ? value : 1;\n      let toConfig = callProp(config, name);\n      if (target) toValue = target.animations[name].parent; // Detect changes, animated values will be checked in the raf-loop\n\n      if (toConfig.decay !== void 0 || !shallowEqual(entry.changes, value)) {\n        this.hasChanged = true;\n        let parent, interpolation$$1;\n        if (isNumber || isString) parent = interpolation$$1 = entry.parent || new AnimatedValue(fromValue);else if (isArray) parent = interpolation$$1 = entry.parent || new AnimatedArray(fromValue);else {\n          const prev = entry.interpolation && entry.interpolation.calc(entry.parent.value);\n\n          if (entry.parent) {\n            parent = entry.parent;\n            parent.setValue(0, false);\n          } else parent = new AnimatedValue(0);\n\n          const range = {\n            output: [prev !== void 0 ? prev : fromValue, value]\n          };\n\n          if (entry.interpolation) {\n            interpolation$$1 = entry.interpolation;\n            entry.interpolation.updateConfig(range);\n          } else interpolation$$1 = parent.interpolate(range);\n        } // Set immediate values\n\n        if (callProp(immediate, name)) parent.setValue(value, false); // Reset animated values\n\n        const animatedValues = toArray(parent.getPayload());\n        animatedValues.forEach(value => value.prepare(this));\n        return _extends({}, acc, {\n          [name]: _extends({}, entry, {\n            name,\n            parent,\n            interpolation: interpolation$$1,\n            animatedValues,\n            changes: value,\n            fromValues: toArray(parent.getValue()),\n            toValues: toArray(target ? toValue.getPayload() : toValue),\n            immediate: callProp(immediate, name),\n            delay: withDefault(toConfig.delay, delay || 0),\n            initialVelocity: withDefault(toConfig.velocity, 0),\n            clamp: withDefault(toConfig.clamp, false),\n            precision: withDefault(toConfig.precision, 0.01),\n            tension: withDefault(toConfig.tension, 170),\n            friction: withDefault(toConfig.friction, 26),\n            mass: withDefault(toConfig.mass, 1),\n            duration: toConfig.duration,\n            easing: withDefault(toConfig.easing, t => t),\n            decay: toConfig.decay\n          })\n        });\n      } else return acc;\n    }, this.animations);\n\n    if (this.hasChanged) {\n      this.configs = getValues$1(this.animations);\n      this.animatedProps = {};\n      this.interpolations = {};\n\n      for (let key in this.animations) {\n        this.interpolations[key] = this.animations[key].interpolation;\n        this.animatedProps[key] = this.animations[key].interpolation.getValue();\n      }\n    } // TODO: clean up ref in controller\n\n\n    for (var _len = arguments.length, start = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n      start[_key - 1] = arguments[_key];\n    }\n\n    if (!ref && (autoStart || start.length)) this.start(...start);\n    const onEnd = start[0],\n          onUpdate = start[1];\n    this.onEnd = typeof onEnd === 'function' && onEnd;\n    this.onUpdate = onUpdate;\n    return this.getValues();\n  }\n\n  start(onEnd, onUpdate) {\n    this.startTime = now();\n    if (this.isActive) this.stop();\n    this.isActive = true;\n    this.onEnd = typeof onEnd === 'function' && onEnd;\n    this.onUpdate = onUpdate;\n    if (this.props.onStart) this.props.onStart();\n    addController(this);\n    return new Promise(res => this.resolve = res);\n  }\n\n  stop(finished) {\n    if (finished === void 0) {\n      finished = false;\n    }\n\n    // Reset collected changes since the animation has been stopped cold turkey\n    if (finished) getValues$1(this.animations).forEach(a => a.changes = undefined);\n    this.debouncedOnEnd({\n      finished\n    });\n  }\n\n  destroy() {\n    removeController(this);\n    this.props = {};\n    this.merged = {};\n    this.animations = {};\n    this.interpolations = {};\n    this.animatedProps = {};\n    this.configs = [];\n  }\n\n  debouncedOnEnd(result) {\n    removeController(this);\n    this.isActive = false;\n    const onEnd = this.onEnd;\n    this.onEnd = null;\n    if (onEnd) onEnd(result);\n    if (this.resolve) this.resolve();\n    this.resolve = null;\n  }\n\n}\n\nclass AnimatedProps extends AnimatedObjectWithChildren {\n  constructor(props, callback) {\n    super();\n    if (props.style) props = _extends({}, props, {\n      style: createAnimatedStyle(props.style)\n    });\n    this.payload = props;\n    this.update = callback;\n    this.attach();\n  }\n\n}\n\nfunction createAnimatedComponent(Component) {\n  class AnimatedComponent extends React__default.Component {\n    constructor(props) {\n      super();\n\n      this.callback = () => {\n        if (this.node) {\n          const didUpdate = applyAnimatedValues.fn(this.node, this.propsAnimated.getAnimatedValue(), this);\n          if (didUpdate === false) this.forceUpdate();\n        }\n      };\n\n      this.attachProps(props);\n    }\n\n    componentWillUnmount() {\n      this.propsAnimated && this.propsAnimated.detach();\n    }\n\n    setNativeProps(props) {\n      const didUpdate = applyAnimatedValues.fn(this.node, props, this);\n      if (didUpdate === false) this.forceUpdate();\n    } // The system is best designed when setNativeProps is implemented. It is\n    // able to avoid re-rendering and directly set the attributes that\n    // changed. However, setNativeProps can only be implemented on leaf\n    // native components. If you want to animate a composite component, you\n    // need to re-render it. In this case, we have a fallback that uses\n    // forceUpdate.\n\n\n    attachProps(_ref) {\n      let forwardRef = _ref.forwardRef,\n          nextProps = _objectWithoutPropertiesLoose(_ref, [\"forwardRef\"]);\n\n      const oldPropsAnimated = this.propsAnimated;\n      this.propsAnimated = new AnimatedProps(nextProps, this.callback); // When you call detach, it removes the element from the parent list\n      // of children. If it goes to 0, then the parent also detaches itself\n      // and so on.\n      // An optimization is to attach the new elements and THEN detach the old\n      // ones instead of detaching and THEN attaching.\n      // This way the intermediate state isn't to go to 0 and trigger\n      // this expensive recursive detaching to then re-attach everything on\n      // the very next operation.\n\n      oldPropsAnimated && oldPropsAnimated.detach();\n    }\n\n    shouldComponentUpdate(props) {\n      const style = props.style,\n            nextProps = _objectWithoutPropertiesLoose(props, [\"style\"]);\n\n      const _this$props = this.props,\n            currentStyle = _this$props.style,\n            currentProps = _objectWithoutPropertiesLoose(_this$props, [\"style\"]);\n\n      if (!shallowEqual(currentProps, nextProps) || !shallowEqual(currentStyle, style)) {\n        this.attachProps(props);\n        return true;\n      }\n\n      return false;\n    }\n\n    render() {\n      const _this$propsAnimated$g = this.propsAnimated.getValue(),\n            scrollTop = _this$propsAnimated$g.scrollTop,\n            scrollLeft = _this$propsAnimated$g.scrollLeft,\n            animatedProps = _objectWithoutPropertiesLoose(_this$propsAnimated$g, [\"scrollTop\", \"scrollLeft\"]);\n\n      return React__default.createElement(Component, _extends({}, animatedProps, {\n        ref: node => this.node = handleRef(node, this.props.forwardRef)\n      }));\n    }\n\n  }\n\n  return React__default.forwardRef((props, ref) => React__default.createElement(AnimatedComponent, _extends({}, props, {\n    forwardRef: ref\n  })));\n}\n\nconst config = {\n  default: {\n    tension: 170,\n    friction: 26\n  },\n  gentle: {\n    tension: 120,\n    friction: 14\n  },\n  wobbly: {\n    tension: 180,\n    friction: 12\n  },\n  stiff: {\n    tension: 210,\n    friction: 20\n  },\n  slow: {\n    tension: 280,\n    friction: 60\n  },\n  molasses: {\n    tension: 280,\n    friction: 120\n  }\n};\n\nclass Spring extends React__default.Component {\n  constructor() {\n    super(...arguments);\n    this.state = {\n      lastProps: {\n        from: {},\n        to: {}\n      },\n      propsChanged: false,\n      internal: false\n    };\n    this.controller = new Controller(null, null);\n    this.didUpdate = false;\n    this.didInject = false;\n    this.finished = true;\n\n    this.start = () => {\n      this.finished = false;\n      let wasMounted = this.mounted;\n      this.controller.start(props => this.finish(_extends({}, props, {\n        wasMounted\n      })), this.update);\n    };\n\n    this.stop = () => this.controller.stop(true);\n\n    this.update = () => this.mounted && this.setState({\n      internal: true\n    });\n\n    this.finish = (_ref) => {\n      let finished = _ref.finished,\n          noChange = _ref.noChange,\n          wasMounted = _ref.wasMounted;\n      this.finished = true;\n\n      if (this.mounted && finished) {\n        // Only call onRest if either we *were* mounted, or when there were changes\n        if (this.props.onRest && (wasMounted || !noChange)) this.props.onRest(this.controller.merged); // Restore end-state\n\n        if (this.mounted && this.didInject) {\n          this.afterInject = convertValues(this.props);\n          this.setState({\n            internal: true\n          });\n        } // If we have an inject or values to apply after the animation we ping here\n\n\n        if (this.mounted && (this.didInject || this.props.after)) this.setState({\n          internal: true\n        });\n        this.didInject = false;\n      }\n    };\n  }\n\n  componentDidMount() {\n    // componentDidUpdate isn't called on mount, we call it here to start animating\n    this.componentDidUpdate();\n    this.mounted = true;\n  }\n\n  componentWillUnmount() {\n    // Stop all ongoing animtions\n    this.mounted = false;\n    this.stop();\n  }\n\n  static getDerivedStateFromProps(props, _ref2) {\n    let internal = _ref2.internal,\n        lastProps = _ref2.lastProps;\n    // The following is a test against props that could alter the animation\n    const from = props.from,\n          to = props.to,\n          reset = props.reset,\n          force = props.force;\n    const propsChanged = !shallowEqual(to, lastProps.to) || !shallowEqual(from, lastProps.from) || reset && !internal || force && !internal;\n    return {\n      propsChanged,\n      lastProps: props,\n      internal: false\n    };\n  }\n\n  render() {\n    const children = this.props.children;\n    const propsChanged = this.state.propsChanged; // Inject phase -----------------------------------------------------------\n    // Handle injected frames, for instance targets/web/fix-auto\n    // An inject will return an intermediary React node which measures itself out\n    // .. and returns a callback when the values sought after are ready, usually \"auto\".\n\n    if (this.props.inject && propsChanged && !this.injectProps) {\n      const frame = this.props.inject(this.props, injectProps => {\n        // The inject frame has rendered, now let's update animations...\n        this.injectProps = injectProps;\n        this.setState({\n          internal: true\n        });\n      }); // Render out injected frame\n\n      if (frame) return frame;\n    } // Update phase -----------------------------------------------------------\n\n\n    if (this.injectProps || propsChanged) {\n      // We can potentially cause setState, but we're inside render, the flag prevents that\n      this.didInject = false; // Update animations, this turns from/to props into AnimatedValues\n      // An update can occur on injected props, or when own-props have changed.\n\n      if (this.injectProps) {\n        this.controller.update(this.injectProps); // didInject is needed, because there will be a 3rd stage, where the original values\n        // .. will be restored after the animation is finished. When someone animates towards\n        // .. \"auto\", the end-result should be \"auto\", not \"1999px\", which would block nested\n        // .. height/width changes.\n\n        this.didInject = true;\n      } else if (propsChanged) this.controller.update(this.props); // Flag an update that occured, componentDidUpdate will start the animation later on\n\n\n      this.didUpdate = true;\n      this.afterInject = undefined;\n      this.injectProps = undefined;\n    } // Render phase -----------------------------------------------------------\n    // Render out raw values or AnimatedValues depending on \"native\"\n\n\n    let values = _extends({}, this.controller.getValues(), this.afterInject);\n\n    if (this.finished) values = _extends({}, values, this.props.after);\n    return Object.keys(values).length ? children(values) : null;\n  }\n\n  componentDidUpdate() {\n    // The animation has to start *after* render, since at that point the scene\n    // .. graph should be established, so we do it here. Unfortunatelly, non-native\n    // .. animations as well as \"auto\"-injects call forceUpdate, so it's causing a loop.\n    // .. didUpdate prevents that as it gets set only on prop changes.\n    if (this.didUpdate) this.start();\n    this.didUpdate = false;\n  }\n\n}\nSpring.defaultProps = {\n  from: {},\n  to: {},\n  config: config.default,\n  native: false,\n  immediate: false,\n  reset: false,\n  force: false,\n  inject: bugfixes\n};\n\nclass Trail extends React__default.PureComponent {\n  constructor() {\n    super(...arguments);\n    this.first = true;\n    this.instances = new Set();\n\n    this.hook = (instance, index, length, reverse) => {\n      // Add instance to set\n      this.instances.add(instance); // Return undefined on the first index and from then on the previous instance\n\n      if (reverse ? index === length - 1 : index === 0) return undefined;else return Array.from(this.instances)[reverse ? index + 1 : index - 1];\n    };\n  }\n\n  render() {\n    const _this$props = this.props,\n          items = _this$props.items,\n          _children = _this$props.children,\n          _this$props$from = _this$props.from,\n          from = _this$props$from === void 0 ? {} : _this$props$from,\n          initial = _this$props.initial,\n          reverse = _this$props.reverse,\n          keys = _this$props.keys,\n          delay = _this$props.delay,\n          onRest = _this$props.onRest,\n          props = _objectWithoutPropertiesLoose(_this$props, [\"items\", \"children\", \"from\", \"initial\", \"reverse\", \"keys\", \"delay\", \"onRest\"]);\n\n    const array = toArray(items);\n    return toArray(array).map((item, i) => React__default.createElement(Spring, _extends({\n      onRest: i === 0 ? onRest : null,\n      key: typeof keys === 'function' ? keys(item) : toArray(keys)[i],\n      from: this.first && initial !== void 0 ? initial || {} : from\n    }, props, {\n      delay: i === 0 && delay || undefined,\n      attach: instance => this.hook(instance, i, array.length, reverse),\n      children: props => {\n        const child = _children(item, i);\n\n        return child ? child(props) : null;\n      }\n    })));\n  }\n\n  componentDidUpdate(prevProps) {\n    this.first = false;\n    if (prevProps.items !== this.props.items) this.instances.clear();\n  }\n\n}\nTrail.defaultProps = {\n  keys: item => item\n};\n\nconst DEFAULT = '__default';\n\nclass KeyframesImpl extends React__default.PureComponent {\n  constructor() {\n    var _this;\n\n    super(...arguments);\n    _this = this;\n    this.guid = 0;\n    this.state = {\n      props: {},\n      resolve: () => null,\n      last: true,\n      index: 0\n    };\n\n    this.next = function (props, last, index) {\n      if (last === void 0) {\n        last = true;\n      }\n\n      if (index === void 0) {\n        index = 0;\n      }\n\n      _this.running = true;\n      return new Promise(resolve => {\n        _this.mounted && _this.setState(state => ({\n          props,\n          resolve,\n          last,\n          index\n        }), () => _this.running = false);\n      });\n    };\n  }\n\n  componentDidMount() {\n    this.mounted = true;\n    this.componentDidUpdate({});\n  }\n\n  componentWillUnmount() {\n    this.mounted = false;\n  }\n\n  componentDidUpdate(previous) {\n    var _this2 = this;\n\n    const _this$props = this.props,\n          states = _this$props.states,\n          f = _this$props.filter,\n          state = _this$props.state;\n\n    if (previous.state !== this.props.state || this.props.reset && !this.running || !shallowEqual(states[state], previous.states[previous.state])) {\n      if (states && state && states[state]) {\n        const localId = ++this.guid;\n        const slots = states[state];\n\n        if (slots) {\n          if (Array.isArray(slots)) {\n            let q = Promise.resolve();\n\n            for (let i = 0; i < slots.length; i++) {\n              let index = i;\n              let slot = slots[index];\n              let last = index === slots.length - 1;\n              q = q.then(() => localId === this.guid && this.next(f(slot), last, index));\n            }\n          } else if (typeof slots === 'function') {\n            let index = 0;\n            slots( // next\n            function (props, last) {\n              if (last === void 0) {\n                last = false;\n              }\n\n              return localId === _this2.guid && _this2.next(f(props), last, index++);\n            }, // cancel\n            () => requestFrame(() => this.instance && this.instance.stop()), // ownprops\n            this.props);\n          } else {\n            this.next(f(states[state]));\n          }\n        }\n      }\n    }\n  }\n\n  render() {\n    const _this$state = this.state,\n          props = _this$state.props,\n          resolve = _this$state.resolve,\n          last = _this$state.last,\n          index = _this$state.index;\n    if (!props || Object.keys(props).length === 0) return null;\n\n    let _this$props2 = this.props,\n        state = _this$props2.state,\n        filter = _this$props2.filter,\n        states = _this$props2.states,\n        config = _this$props2.config,\n        Component = _this$props2.primitive,\n        _onRest = _this$props2.onRest,\n        forwardRef = _this$props2.forwardRef,\n        rest = _objectWithoutPropertiesLoose(_this$props2, [\"state\", \"filter\", \"states\", \"config\", \"primitive\", \"onRest\", \"forwardRef\"]); // Arrayed configs need an index to process\n\n\n    if (Array.isArray(config)) config = config[index];\n    return React__default.createElement(Component, _extends({\n      ref: _ref => this.instance = handleRef(_ref, forwardRef),\n      config: config\n    }, rest, props, {\n      onRest: args => {\n        resolve(args);\n        if (_onRest && last) _onRest(args);\n      }\n    }));\n  }\n\n}\n\nKeyframesImpl.defaultProps = {\n  state: DEFAULT\n};\nconst Keyframes = React__default.forwardRef((props, ref) => React__default.createElement(KeyframesImpl, _extends({}, props, {\n  forwardRef: ref\n})));\n\nKeyframes.create = primitive => function (states, filter) {\n  if (filter === void 0) {\n    filter = states => states;\n  }\n\n  if (typeof states === 'function' || Array.isArray(states)) states = {\n    [DEFAULT]: states\n  };\n  return props => React__default.createElement(KeyframesImpl, _extends({\n    primitive: primitive,\n    states: states,\n    filter: filter\n  }, props));\n};\n\nKeyframes.Spring = states => Keyframes.create(Spring)(states, interpolateTo);\n\nKeyframes.Trail = states => Keyframes.create(Trail)(states, interpolateTo);\n\nlet guid = 0;\n\nlet get = props => {\n  let items = props.items,\n      keys = props.keys,\n      rest = _objectWithoutPropertiesLoose(props, [\"items\", \"keys\"]);\n\n  items = toArray(items !== void 0 ? items : null);\n  keys = typeof keys === 'function' ? items.map(keys) : toArray(keys); // Make sure numeric keys are interpreted as Strings (5 !== \"5\")\n\n  return _extends({\n    items,\n    keys: keys.map(key => String(key))\n  }, rest);\n};\n\nclass Transition extends React__default.PureComponent {\n  componentDidMount() {\n    this.mounted = true;\n  }\n\n  componentWillUnmount() {\n    this.mounted = false;\n  }\n\n  constructor(prevProps) {\n    super(prevProps);\n\n    this.destroyItem = (item, key, state) => values => {\n      const _this$props = this.props,\n            onRest = _this$props.onRest,\n            onDestroyed = _this$props.onDestroyed;\n\n      if (this.mounted) {\n        onDestroyed && onDestroyed(item);\n        this.setState((_ref) => {\n          let deleted = _ref.deleted;\n          return {\n            deleted: deleted.filter(t => t.key !== key)\n          };\n        });\n        onRest && onRest(item, state, values);\n      }\n    };\n\n    this.state = {\n      first: true,\n      transitions: [],\n      current: {},\n      deleted: [],\n      prevProps\n    };\n  }\n\n  static getDerivedStateFromProps(props, _ref2) {\n    let first = _ref2.first,\n        prevProps = _ref2.prevProps,\n        state = _objectWithoutPropertiesLoose(_ref2, [\"first\", \"prevProps\"]);\n\n    let _get = get(props),\n        items = _get.items,\n        keys = _get.keys,\n        initial = _get.initial,\n        from = _get.from,\n        enter = _get.enter,\n        leave = _get.leave,\n        update = _get.update,\n        _get$trail = _get.trail,\n        trail = _get$trail === void 0 ? 0 : _get$trail,\n        unique = _get.unique,\n        config = _get.config;\n\n    let _get2 = get(prevProps),\n        _keys = _get2.keys,\n        _items = _get2.items;\n\n    let current = _extends({}, state.current);\n\n    let deleted = [...state.deleted]; // Compare next keys with current keys\n\n    let currentKeys = Object.keys(current);\n    let currentSet = new Set(currentKeys);\n    let nextSet = new Set(keys);\n    let added = keys.filter(item => !currentSet.has(item));\n    let removed = state.transitions.filter(item => !item.destroyed && !nextSet.has(item.originalKey)).map(i => i.originalKey);\n    let updated = keys.filter(item => currentSet.has(item));\n    let delay = 0;\n    added.forEach(key => {\n      // In unique mode, remove fading out transitions if their key comes in again\n      if (unique && deleted.find(d => d.originalKey === key)) deleted = deleted.filter(t => t.originalKey !== key);\n      const keyIndex = keys.indexOf(key);\n      const item = items[keyIndex];\n      const state = 'enter';\n      current[key] = {\n        state,\n        originalKey: key,\n        key: unique ? String(key) : guid++,\n        item,\n        trail: delay = delay + trail,\n        config: callProp(config, item, state),\n        from: callProp(first ? initial !== void 0 ? initial || {} : from : from, item),\n        to: callProp(enter, item)\n      };\n    });\n    removed.forEach(key => {\n      const keyIndex = _keys.indexOf(key);\n\n      const item = _items[keyIndex];\n      const state = 'leave';\n      deleted.push(_extends({}, current[key], {\n        state,\n        destroyed: true,\n        left: _keys[Math.max(0, keyIndex - 1)],\n        right: _keys[Math.min(_keys.length, keyIndex + 1)],\n        trail: delay = delay + trail,\n        config: callProp(config, item, state),\n        to: callProp(leave, item)\n      }));\n      delete current[key];\n    });\n    updated.forEach(key => {\n      const keyIndex = keys.indexOf(key);\n      const item = items[keyIndex];\n      const state = 'update';\n      current[key] = _extends({}, current[key], {\n        item,\n        state,\n        trail: delay = delay + trail,\n        config: callProp(config, item, state),\n        to: callProp(update, item)\n      });\n    }); // This tries to restore order for deleted items by finding their last known siblings\n\n    let out = keys.map(key => current[key]);\n    deleted.forEach((_ref3) => {\n      let left = _ref3.left,\n          right = _ref3.right,\n          transition = _objectWithoutPropertiesLoose(_ref3, [\"left\", \"right\"]);\n\n      let pos; // Was it the element on the left, if yes, move there ...\n\n      if ((pos = out.findIndex(t => t.originalKey === left)) !== -1) pos += 1; // Or how about the element on the right ...\n\n      if (pos === -1) pos = out.findIndex(t => t.originalKey === right); // Maybe we'll find it in the list of deleted items\n\n      if (pos === -1) pos = deleted.findIndex(t => t.originalKey === left); // Checking right side as well\n\n      if (pos === -1) pos = deleted.findIndex(t => t.originalKey === right); // And if nothing else helps, move it to the start ¯\\_(ツ)_/¯\n\n      pos = Math.max(0, pos);\n      out = [...out.slice(0, pos), transition, ...out.slice(pos)];\n    });\n    return {\n      first: first && added.length === 0,\n      transitions: out,\n      current,\n      deleted,\n      prevProps: props\n    };\n  }\n\n  render() {\n    const _this$props2 = this.props,\n          initial = _this$props2.initial,\n          _this$props2$from = _this$props2.from,\n          _this$props2$enter = _this$props2.enter,\n          _this$props2$leave = _this$props2.leave,\n          _this$props2$update = _this$props2.update,\n          onDestroyed = _this$props2.onDestroyed,\n          keys = _this$props2.keys,\n          items = _this$props2.items,\n          onFrame = _this$props2.onFrame,\n          onRest = _this$props2.onRest,\n          onStart = _this$props2.onStart,\n          trail = _this$props2.trail,\n          config = _this$props2.config,\n          _children = _this$props2.children,\n          unique = _this$props2.unique,\n          reset = _this$props2.reset,\n          extra = _objectWithoutPropertiesLoose(_this$props2, [\"initial\", \"from\", \"enter\", \"leave\", \"update\", \"onDestroyed\", \"keys\", \"items\", \"onFrame\", \"onRest\", \"onStart\", \"trail\", \"config\", \"children\", \"unique\", \"reset\"]);\n\n    return this.state.transitions.map((_ref4, i) => {\n      let state = _ref4.state,\n          key = _ref4.key,\n          item = _ref4.item,\n          from = _ref4.from,\n          to = _ref4.to,\n          trail = _ref4.trail,\n          config = _ref4.config,\n          destroyed = _ref4.destroyed;\n      return React__default.createElement(Keyframes, _extends({\n        reset: reset && state === 'enter',\n        primitive: Spring,\n        state: state,\n        filter: interpolateTo,\n        states: {\n          [state]: to\n        },\n        key: key,\n        onRest: destroyed ? this.destroyItem(item, key, state) : onRest && (values => onRest(item, state, values)),\n        onStart: onStart && (() => onStart(item, state)),\n        onFrame: onFrame && (values => onFrame(item, state, values)),\n        delay: trail,\n        config: config\n      }, extra, {\n        from: from,\n        children: props => {\n          const child = _children(item, state, i);\n\n          return child ? child(props) : null;\n        }\n      }));\n    });\n  }\n\n}\nTransition.defaultProps = {\n  keys: item => item,\n  unique: false,\n  reset: false\n};\n\nconst domElements = ['a', 'abbr', 'address', 'area', 'article', 'aside', 'audio', 'b', 'base', 'bdi', 'bdo', 'big', 'blockquote', 'body', 'br', 'button', 'canvas', 'caption', 'cite', 'code', 'col', 'colgroup', 'data', 'datalist', 'dd', 'del', 'details', 'dfn', 'dialog', 'div', 'dl', 'dt', 'em', 'embed', 'fieldset', 'figcaption', 'figure', 'footer', 'form', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'head', 'header', 'hgroup', 'hr', 'html', 'i', 'iframe', 'img', 'input', 'ins', 'kbd', 'keygen', 'label', 'legend', 'li', 'link', 'main', 'map', 'mark', 'marquee', 'menu', 'menuitem', 'meta', 'meter', 'nav', 'noscript', 'object', 'ol', 'optgroup', 'option', 'output', 'p', 'param', 'picture', 'pre', 'progress', 'q', 'rp', 'rt', 'ruby', 's', 'samp', 'script', 'section', 'select', 'small', 'source', 'span', 'strong', 'style', 'sub', 'summary', 'sup', 'table', 'tbody', 'td', 'textarea', 'tfoot', 'th', 'thead', 'time', 'title', 'tr', 'track', 'u', 'ul', 'var', 'video', 'wbr', // SVG\n'circle', 'clipPath', 'defs', 'ellipse', 'foreignObject', 'g', 'image', 'line', 'linearGradient', 'mask', 'path', 'pattern', 'polygon', 'polyline', 'radialGradient', 'rect', 'stop', 'svg', 'text', 'tspan'];\nconst extendedAnimated = domElements.reduce((acc, element) => {\n  acc[element] = createAnimatedComponent(element);\n  return acc;\n}, createAnimatedComponent);\n\nexports.Spring = Spring;\nexports.Keyframes = Keyframes;\nexports.Transition = Transition;\nexports.Trail = Trail;\nexports.Controller = Controller;\nexports.config = config;\nexports.animated = extendedAnimated;\nexports.interpolate = interpolate$1;\nexports.Globals = Globals;\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///4823\n")},3697:(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval("\n\nvar functionsHaveConfigurableNames = (__webpack_require__(5972).functionsHaveConfigurableNames)();\n\nvar $Object = Object;\nvar $TypeError = TypeError;\n\nmodule.exports = function flags() {\n\tif (this != null && this !== $Object(this)) {\n\t\tthrow new $TypeError('RegExp.prototype.flags getter called on non-object');\n\t}\n\tvar result = '';\n\tif (this.hasIndices) {\n\t\tresult += 'd';\n\t}\n\tif (this.global) {\n\t\tresult += 'g';\n\t}\n\tif (this.ignoreCase) {\n\t\tresult += 'i';\n\t}\n\tif (this.multiline) {\n\t\tresult += 'm';\n\t}\n\tif (this.dotAll) {\n\t\tresult += 's';\n\t}\n\tif (this.unicode) {\n\t\tresult += 'u';\n\t}\n\tif (this.sticky) {\n\t\tresult += 'y';\n\t}\n\treturn result;\n};\n\nif (functionsHaveConfigurableNames && Object.defineProperty) {\n\tObject.defineProperty(module.exports, \"name\", ({ value: 'get flags' }));\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMzY5Ny5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9ibG9ja3N5T3B0aW9ucy8uL25vZGVfbW9kdWxlcy9yZWdleHAucHJvdG90eXBlLmZsYWdzL2ltcGxlbWVudGF0aW9uLmpzPzU3MDgiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG52YXIgZnVuY3Rpb25zSGF2ZUNvbmZpZ3VyYWJsZU5hbWVzID0gcmVxdWlyZSgnZnVuY3Rpb25zLWhhdmUtbmFtZXMnKS5mdW5jdGlvbnNIYXZlQ29uZmlndXJhYmxlTmFtZXMoKTtcblxudmFyICRPYmplY3QgPSBPYmplY3Q7XG52YXIgJFR5cGVFcnJvciA9IFR5cGVFcnJvcjtcblxubW9kdWxlLmV4cG9ydHMgPSBmdW5jdGlvbiBmbGFncygpIHtcblx0aWYgKHRoaXMgIT0gbnVsbCAmJiB0aGlzICE9PSAkT2JqZWN0KHRoaXMpKSB7XG5cdFx0dGhyb3cgbmV3ICRUeXBlRXJyb3IoJ1JlZ0V4cC5wcm90b3R5cGUuZmxhZ3MgZ2V0dGVyIGNhbGxlZCBvbiBub24tb2JqZWN0Jyk7XG5cdH1cblx0dmFyIHJlc3VsdCA9ICcnO1xuXHRpZiAodGhpcy5oYXNJbmRpY2VzKSB7XG5cdFx0cmVzdWx0ICs9ICdkJztcblx0fVxuXHRpZiAodGhpcy5nbG9iYWwpIHtcblx0XHRyZXN1bHQgKz0gJ2cnO1xuXHR9XG5cdGlmICh0aGlzLmlnbm9yZUNhc2UpIHtcblx0XHRyZXN1bHQgKz0gJ2knO1xuXHR9XG5cdGlmICh0aGlzLm11bHRpbGluZSkge1xuXHRcdHJlc3VsdCArPSAnbSc7XG5cdH1cblx0aWYgKHRoaXMuZG90QWxsKSB7XG5cdFx0cmVzdWx0ICs9ICdzJztcblx0fVxuXHRpZiAodGhpcy51bmljb2RlKSB7XG5cdFx0cmVzdWx0ICs9ICd1Jztcblx0fVxuXHRpZiAodGhpcy5zdGlja3kpIHtcblx0XHRyZXN1bHQgKz0gJ3knO1xuXHR9XG5cdHJldHVybiByZXN1bHQ7XG59O1xuXG5pZiAoZnVuY3Rpb25zSGF2ZUNvbmZpZ3VyYWJsZU5hbWVzICYmIE9iamVjdC5kZWZpbmVQcm9wZXJ0eSkge1xuXHRPYmplY3QuZGVmaW5lUHJvcGVydHkobW9kdWxlLmV4cG9ydHMsICduYW1lJywgeyB2YWx1ZTogJ2dldCBmbGFncycgfSk7XG59XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///3697\n")},2847:(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval("\n\nvar define = __webpack_require__(4289);\nvar callBind = __webpack_require__(5559);\n\nvar implementation = __webpack_require__(3697);\nvar getPolyfill = __webpack_require__(1721);\nvar shim = __webpack_require__(2753);\n\nvar flagsBound = callBind(getPolyfill());\n\ndefine(flagsBound, {\n\tgetPolyfill: getPolyfill,\n\timplementation: implementation,\n\tshim: shim\n});\n\nmodule.exports = flagsBound;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMjg0Ny5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9ibG9ja3N5T3B0aW9ucy8uL25vZGVfbW9kdWxlcy9yZWdleHAucHJvdG90eXBlLmZsYWdzL2luZGV4LmpzP2U3MTAiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG52YXIgZGVmaW5lID0gcmVxdWlyZSgnZGVmaW5lLXByb3BlcnRpZXMnKTtcbnZhciBjYWxsQmluZCA9IHJlcXVpcmUoJ2NhbGwtYmluZCcpO1xuXG52YXIgaW1wbGVtZW50YXRpb24gPSByZXF1aXJlKCcuL2ltcGxlbWVudGF0aW9uJyk7XG52YXIgZ2V0UG9seWZpbGwgPSByZXF1aXJlKCcuL3BvbHlmaWxsJyk7XG52YXIgc2hpbSA9IHJlcXVpcmUoJy4vc2hpbScpO1xuXG52YXIgZmxhZ3NCb3VuZCA9IGNhbGxCaW5kKGdldFBvbHlmaWxsKCkpO1xuXG5kZWZpbmUoZmxhZ3NCb3VuZCwge1xuXHRnZXRQb2x5ZmlsbDogZ2V0UG9seWZpbGwsXG5cdGltcGxlbWVudGF0aW9uOiBpbXBsZW1lbnRhdGlvbixcblx0c2hpbTogc2hpbVxufSk7XG5cbm1vZHVsZS5leHBvcnRzID0gZmxhZ3NCb3VuZDtcbiJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///2847\n")},1721:(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval("\n\nvar implementation = __webpack_require__(3697);\n\nvar supportsDescriptors = (__webpack_require__(4289).supportsDescriptors);\nvar $gOPD = Object.getOwnPropertyDescriptor;\n\nmodule.exports = function getPolyfill() {\n\tif (supportsDescriptors && (/a/mig).flags === 'gim') {\n\t\tvar descriptor = $gOPD(RegExp.prototype, 'flags');\n\t\tif (\n\t\t\tdescriptor\n\t\t\t&& typeof descriptor.get === 'function'\n\t\t\t&& typeof RegExp.prototype.dotAll === 'boolean'\n\t\t\t&& typeof RegExp.prototype.hasIndices === 'boolean'\n\t\t) {\n\t\t\t/* eslint getter-return: 0 */\n\t\t\tvar calls = '';\n\t\t\tvar o = {};\n\t\t\tObject.defineProperty(o, 'hasIndices', {\n\t\t\t\tget: function () {\n\t\t\t\t\tcalls += 'd';\n\t\t\t\t}\n\t\t\t});\n\t\t\tObject.defineProperty(o, 'sticky', {\n\t\t\t\tget: function () {\n\t\t\t\t\tcalls += 'y';\n\t\t\t\t}\n\t\t\t});\n\t\t\tif (calls === 'dy') {\n\t\t\t\treturn descriptor.get;\n\t\t\t}\n\t\t}\n\t}\n\treturn implementation;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTcyMS5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9ibG9ja3N5T3B0aW9ucy8uL25vZGVfbW9kdWxlcy9yZWdleHAucHJvdG90eXBlLmZsYWdzL3BvbHlmaWxsLmpzPzU3ZWMiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG52YXIgaW1wbGVtZW50YXRpb24gPSByZXF1aXJlKCcuL2ltcGxlbWVudGF0aW9uJyk7XG5cbnZhciBzdXBwb3J0c0Rlc2NyaXB0b3JzID0gcmVxdWlyZSgnZGVmaW5lLXByb3BlcnRpZXMnKS5zdXBwb3J0c0Rlc2NyaXB0b3JzO1xudmFyICRnT1BEID0gT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcjtcblxubW9kdWxlLmV4cG9ydHMgPSBmdW5jdGlvbiBnZXRQb2x5ZmlsbCgpIHtcblx0aWYgKHN1cHBvcnRzRGVzY3JpcHRvcnMgJiYgKC9hL21pZykuZmxhZ3MgPT09ICdnaW0nKSB7XG5cdFx0dmFyIGRlc2NyaXB0b3IgPSAkZ09QRChSZWdFeHAucHJvdG90eXBlLCAnZmxhZ3MnKTtcblx0XHRpZiAoXG5cdFx0XHRkZXNjcmlwdG9yXG5cdFx0XHQmJiB0eXBlb2YgZGVzY3JpcHRvci5nZXQgPT09ICdmdW5jdGlvbidcblx0XHRcdCYmIHR5cGVvZiBSZWdFeHAucHJvdG90eXBlLmRvdEFsbCA9PT0gJ2Jvb2xlYW4nXG5cdFx0XHQmJiB0eXBlb2YgUmVnRXhwLnByb3RvdHlwZS5oYXNJbmRpY2VzID09PSAnYm9vbGVhbidcblx0XHQpIHtcblx0XHRcdC8qIGVzbGludCBnZXR0ZXItcmV0dXJuOiAwICovXG5cdFx0XHR2YXIgY2FsbHMgPSAnJztcblx0XHRcdHZhciBvID0ge307XG5cdFx0XHRPYmplY3QuZGVmaW5lUHJvcGVydHkobywgJ2hhc0luZGljZXMnLCB7XG5cdFx0XHRcdGdldDogZnVuY3Rpb24gKCkge1xuXHRcdFx0XHRcdGNhbGxzICs9ICdkJztcblx0XHRcdFx0fVxuXHRcdFx0fSk7XG5cdFx0XHRPYmplY3QuZGVmaW5lUHJvcGVydHkobywgJ3N0aWNreScsIHtcblx0XHRcdFx0Z2V0OiBmdW5jdGlvbiAoKSB7XG5cdFx0XHRcdFx0Y2FsbHMgKz0gJ3knO1xuXHRcdFx0XHR9XG5cdFx0XHR9KTtcblx0XHRcdGlmIChjYWxscyA9PT0gJ2R5Jykge1xuXHRcdFx0XHRyZXR1cm4gZGVzY3JpcHRvci5nZXQ7XG5cdFx0XHR9XG5cdFx0fVxuXHR9XG5cdHJldHVybiBpbXBsZW1lbnRhdGlvbjtcbn07XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///1721\n")},2753:(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval("\n\nvar supportsDescriptors = (__webpack_require__(4289).supportsDescriptors);\nvar getPolyfill = __webpack_require__(1721);\nvar gOPD = Object.getOwnPropertyDescriptor;\nvar defineProperty = Object.defineProperty;\nvar TypeErr = TypeError;\nvar getProto = Object.getPrototypeOf;\nvar regex = /a/;\n\nmodule.exports = function shimFlags() {\n\tif (!supportsDescriptors || !getProto) {\n\t\tthrow new TypeErr('RegExp.prototype.flags requires a true ES5 environment that supports property descriptors');\n\t}\n\tvar polyfill = getPolyfill();\n\tvar proto = getProto(regex);\n\tvar descriptor = gOPD(proto, 'flags');\n\tif (!descriptor || descriptor.get !== polyfill) {\n\t\tdefineProperty(proto, 'flags', {\n\t\t\tconfigurable: true,\n\t\t\tenumerable: false,\n\t\t\tget: polyfill\n\t\t});\n\t}\n\treturn polyfill;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMjc1My5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9ub2RlX21vZHVsZXMvcmVnZXhwLnByb3RvdHlwZS5mbGFncy9zaGltLmpzPzFjN2UiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG52YXIgc3VwcG9ydHNEZXNjcmlwdG9ycyA9IHJlcXVpcmUoJ2RlZmluZS1wcm9wZXJ0aWVzJykuc3VwcG9ydHNEZXNjcmlwdG9ycztcbnZhciBnZXRQb2x5ZmlsbCA9IHJlcXVpcmUoJy4vcG9seWZpbGwnKTtcbnZhciBnT1BEID0gT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcjtcbnZhciBkZWZpbmVQcm9wZXJ0eSA9IE9iamVjdC5kZWZpbmVQcm9wZXJ0eTtcbnZhciBUeXBlRXJyID0gVHlwZUVycm9yO1xudmFyIGdldFByb3RvID0gT2JqZWN0LmdldFByb3RvdHlwZU9mO1xudmFyIHJlZ2V4ID0gL2EvO1xuXG5tb2R1bGUuZXhwb3J0cyA9IGZ1bmN0aW9uIHNoaW1GbGFncygpIHtcblx0aWYgKCFzdXBwb3J0c0Rlc2NyaXB0b3JzIHx8ICFnZXRQcm90bykge1xuXHRcdHRocm93IG5ldyBUeXBlRXJyKCdSZWdFeHAucHJvdG90eXBlLmZsYWdzIHJlcXVpcmVzIGEgdHJ1ZSBFUzUgZW52aXJvbm1lbnQgdGhhdCBzdXBwb3J0cyBwcm9wZXJ0eSBkZXNjcmlwdG9ycycpO1xuXHR9XG5cdHZhciBwb2x5ZmlsbCA9IGdldFBvbHlmaWxsKCk7XG5cdHZhciBwcm90byA9IGdldFByb3RvKHJlZ2V4KTtcblx0dmFyIGRlc2NyaXB0b3IgPSBnT1BEKHByb3RvLCAnZmxhZ3MnKTtcblx0aWYgKCFkZXNjcmlwdG9yIHx8IGRlc2NyaXB0b3IuZ2V0ICE9PSBwb2x5ZmlsbCkge1xuXHRcdGRlZmluZVByb3BlcnR5KHByb3RvLCAnZmxhZ3MnLCB7XG5cdFx0XHRjb25maWd1cmFibGU6IHRydWUsXG5cdFx0XHRlbnVtZXJhYmxlOiBmYWxzZSxcblx0XHRcdGdldDogcG9seWZpbGxcblx0XHR9KTtcblx0fVxuXHRyZXR1cm4gcG9seWZpbGw7XG59O1xuIl0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///2753\n")},6399:module=>{eval("/**\n * Bare-bones equivalent for the functionality of d3.scale.linear\n * @param {Array} domain\n * @param {Array} range\n * @returns {Function} scale function\n * @example\n * var linearScale = require('simple-linear-scale');\n *\n * var scaleFunction = linearScale([0, 1], [0, 100]);\n * scaleFunction(0.5); // 50\n *\n * // clamp option ensures that output is within range\n * var scaleFunction = linearScale([0, 1], [0, 10], true);\n * scaleFunction(100); // 10\n */\nfunction linearScale(domain, range, clamp) {\n return function(value) {\n if (domain[0] === domain[1] || range[0] === range[1]) {\n return range[0];\n }\n var ratio = (range[1] - range[0]) / (domain[1] - domain[0]),\n result = range[0] + ratio * (value - domain[0]);\n return clamp ? Math.min(range[1], Math.max(range[0], result)) : result;\n };\n}\n\nmodule.exports = linearScale;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNjM5OS5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9ibG9ja3N5T3B0aW9ucy8uL25vZGVfbW9kdWxlcy9zaW1wbGUtbGluZWFyLXNjYWxlL2luZGV4LmpzPzg1ZjEiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBCYXJlLWJvbmVzIGVxdWl2YWxlbnQgZm9yIHRoZSBmdW5jdGlvbmFsaXR5IG9mIGQzLnNjYWxlLmxpbmVhclxuICogQHBhcmFtIHtBcnJheTxudW1iZXI+fSBkb21haW5cbiAqIEBwYXJhbSB7QXJyYXk8bnVtYmVyPn0gcmFuZ2VcbiAqIEByZXR1cm5zIHtGdW5jdGlvbn0gc2NhbGUgZnVuY3Rpb25cbiAqIEBleGFtcGxlXG4gKiB2YXIgbGluZWFyU2NhbGUgPSByZXF1aXJlKCdzaW1wbGUtbGluZWFyLXNjYWxlJyk7XG4gKlxuICogdmFyIHNjYWxlRnVuY3Rpb24gPSBsaW5lYXJTY2FsZShbMCwgMV0sIFswLCAxMDBdKTtcbiAqIHNjYWxlRnVuY3Rpb24oMC41KTsgLy8gNTBcbiAqXG4gKiAvLyBjbGFtcCBvcHRpb24gZW5zdXJlcyB0aGF0IG91dHB1dCBpcyB3aXRoaW4gcmFuZ2VcbiAqIHZhciBzY2FsZUZ1bmN0aW9uID0gbGluZWFyU2NhbGUoWzAsIDFdLCBbMCwgMTBdLCB0cnVlKTtcbiAqIHNjYWxlRnVuY3Rpb24oMTAwKTsgLy8gMTBcbiAqL1xuZnVuY3Rpb24gbGluZWFyU2NhbGUoZG9tYWluLCByYW5nZSwgY2xhbXApIHtcbiAgcmV0dXJuIGZ1bmN0aW9uKHZhbHVlKSB7XG4gICAgaWYgKGRvbWFpblswXSA9PT0gZG9tYWluWzFdIHx8IHJhbmdlWzBdID09PSByYW5nZVsxXSkge1xuICAgICAgcmV0dXJuIHJhbmdlWzBdO1xuICAgIH1cbiAgICB2YXIgcmF0aW8gPSAocmFuZ2VbMV0gLSByYW5nZVswXSkgLyAoZG9tYWluWzFdIC0gZG9tYWluWzBdKSxcbiAgICAgIHJlc3VsdCA9IHJhbmdlWzBdICsgcmF0aW8gKiAodmFsdWUgLSBkb21haW5bMF0pO1xuICAgIHJldHVybiBjbGFtcCA/IE1hdGgubWluKHJhbmdlWzFdLCBNYXRoLm1heChyYW5nZVswXSwgcmVzdWx0KSkgOiByZXN1bHQ7XG4gIH07XG59XG5cbm1vZHVsZS5leHBvcnRzID0gbGluZWFyU2NhbGU7XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///6399\n")},4760:module=>{eval("var candidateSelectors = [\n 'input',\n 'select',\n 'textarea',\n 'a[href]',\n 'button',\n '[tabindex]',\n 'audio[controls]',\n 'video[controls]',\n '[contenteditable]:not([contenteditable=\"false\"])',\n];\nvar candidateSelector = candidateSelectors.join(',');\n\nvar matches = typeof Element === 'undefined'\n ? function () {}\n : Element.prototype.matches || Element.prototype.msMatchesSelector || Element.prototype.webkitMatchesSelector;\n\nfunction tabbable(el, options) {\n options = options || {};\n\n var elementDocument = el.ownerDocument || el;\n var regularTabbables = [];\n var orderedTabbables = [];\n\n var untouchabilityChecker = new UntouchabilityChecker(elementDocument);\n var candidates = el.querySelectorAll(candidateSelector);\n\n if (options.includeContainer) {\n if (matches.call(el, candidateSelector)) {\n candidates = Array.prototype.slice.apply(candidates);\n candidates.unshift(el);\n }\n }\n\n var i, candidate, candidateTabindex;\n for (i = 0; i < candidates.length; i++) {\n candidate = candidates[i];\n\n if (!isNodeMatchingSelectorTabbable(candidate, untouchabilityChecker)) continue;\n\n candidateTabindex = getTabindex(candidate);\n if (candidateTabindex === 0) {\n regularTabbables.push(candidate);\n } else {\n orderedTabbables.push({\n documentOrder: i,\n tabIndex: candidateTabindex,\n node: candidate,\n });\n }\n }\n\n var tabbableNodes = orderedTabbables\n .sort(sortOrderedTabbables)\n .map(function(a) { return a.node })\n .concat(regularTabbables);\n\n return tabbableNodes;\n}\n\ntabbable.isTabbable = isTabbable;\ntabbable.isFocusable = isFocusable;\n\nfunction isNodeMatchingSelectorTabbable(node, untouchabilityChecker) {\n if (\n !isNodeMatchingSelectorFocusable(node, untouchabilityChecker)\n || isNonTabbableRadio(node)\n || getTabindex(node) < 0\n ) {\n return false;\n }\n return true;\n}\n\nfunction isTabbable(node, untouchabilityChecker) {\n if (!node) throw new Error('No node provided');\n if (matches.call(node, candidateSelector) === false) return false;\n return isNodeMatchingSelectorTabbable(node, untouchabilityChecker);\n}\n\nfunction isNodeMatchingSelectorFocusable(node, untouchabilityChecker) {\n untouchabilityChecker = untouchabilityChecker || new UntouchabilityChecker(node.ownerDocument || node);\n if (\n node.disabled\n || isHiddenInput(node)\n || untouchabilityChecker.isUntouchable(node)\n ) {\n return false;\n }\n return true;\n}\n\nvar focusableCandidateSelector = candidateSelectors.concat('iframe').join(',');\nfunction isFocusable(node, untouchabilityChecker) {\n if (!node) throw new Error('No node provided');\n if (matches.call(node, focusableCandidateSelector) === false) return false;\n return isNodeMatchingSelectorFocusable(node, untouchabilityChecker);\n}\n\nfunction getTabindex(node) {\n var tabindexAttr = parseInt(node.getAttribute('tabindex'), 10);\n if (!isNaN(tabindexAttr)) return tabindexAttr;\n // Browsers do not return `tabIndex` correctly for contentEditable nodes;\n // so if they don't have a tabindex attribute specifically set, assume it's 0.\n if (isContentEditable(node)) return 0;\n return node.tabIndex;\n}\n\nfunction sortOrderedTabbables(a, b) {\n return a.tabIndex === b.tabIndex ? a.documentOrder - b.documentOrder : a.tabIndex - b.tabIndex;\n}\n\n// Array.prototype.find not available in IE.\nfunction find(list, predicate) {\n for (var i = 0, length = list.length; i < length; i++) {\n if (predicate(list[i])) return list[i];\n }\n}\n\nfunction isContentEditable(node) {\n return node.contentEditable === 'true';\n}\n\nfunction isInput(node) {\n return node.tagName === 'INPUT';\n}\n\nfunction isHiddenInput(node) {\n return isInput(node) && node.type === 'hidden';\n}\n\nfunction isRadio(node) {\n return isInput(node) && node.type === 'radio';\n}\n\nfunction isNonTabbableRadio(node) {\n return isRadio(node) && !isTabbableRadio(node);\n}\n\nfunction getCheckedRadio(nodes) {\n for (var i = 0; i < nodes.length; i++) {\n if (nodes[i].checked) {\n return nodes[i];\n }\n }\n}\n\nfunction isTabbableRadio(node) {\n if (!node.name) return true;\n // This won't account for the edge case where you have radio groups with the same\n // in separate forms on the same page.\n var radioSet = node.ownerDocument.querySelectorAll('input[type=\"radio\"][name=\"' + node.name + '\"]');\n var checked = getCheckedRadio(radioSet);\n return !checked || checked === node;\n}\n\n// An element is \"untouchable\" if *it or one of its ancestors* has\n// `visibility: hidden` or `display: none`.\nfunction UntouchabilityChecker(elementDocument) {\n this.doc = elementDocument;\n // Node cache must be refreshed on every check, in case\n // the content of the element has changed. The cache contains tuples\n // mapping nodes to their boolean result.\n this.cache = [];\n}\n\n// getComputedStyle accurately reflects `visibility: hidden` of ancestors\n// but not `display: none`, so we need to recursively check parents.\nUntouchabilityChecker.prototype.hasDisplayNone = function hasDisplayNone(node, nodeComputedStyle) {\n if (node.nodeType !== Node.ELEMENT_NODE) return false;\n\n // Search for a cached result.\n var cached = find(this.cache, function(item) {\n return item === node;\n });\n if (cached) return cached[1];\n\n nodeComputedStyle = nodeComputedStyle || this.doc.defaultView.getComputedStyle(node);\n\n var result = false;\n\n if (nodeComputedStyle.display === 'none') {\n result = true;\n } else if (node.parentNode) {\n result = this.hasDisplayNone(node.parentNode);\n }\n\n this.cache.push([node, result]);\n\n return result;\n}\n\nUntouchabilityChecker.prototype.isUntouchable = function isUntouchable(node) {\n if (node === this.doc.documentElement) return false;\n var computedStyle = this.doc.defaultView.getComputedStyle(node);\n if (this.hasDisplayNone(node, computedStyle)) return true;\n return computedStyle.visibility === 'hidden';\n}\n\nmodule.exports = tabbable;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"4760.js","mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://blocksyOptions/./node_modules/tabbable/index.js?0580"],"sourcesContent":["var candidateSelectors = [\n  'input',\n  'select',\n  'textarea',\n  'a[href]',\n  'button',\n  '[tabindex]',\n  'audio[controls]',\n  'video[controls]',\n  '[contenteditable]:not([contenteditable=\"false\"])',\n];\nvar candidateSelector = candidateSelectors.join(',');\n\nvar matches = typeof Element === 'undefined'\n  ? function () {}\n  : Element.prototype.matches || Element.prototype.msMatchesSelector || Element.prototype.webkitMatchesSelector;\n\nfunction tabbable(el, options) {\n  options = options || {};\n\n  var elementDocument = el.ownerDocument || el;\n  var regularTabbables = [];\n  var orderedTabbables = [];\n\n  var untouchabilityChecker = new UntouchabilityChecker(elementDocument);\n  var candidates = el.querySelectorAll(candidateSelector);\n\n  if (options.includeContainer) {\n    if (matches.call(el, candidateSelector)) {\n      candidates = Array.prototype.slice.apply(candidates);\n      candidates.unshift(el);\n    }\n  }\n\n  var i, candidate, candidateTabindex;\n  for (i = 0; i < candidates.length; i++) {\n    candidate = candidates[i];\n\n    if (!isNodeMatchingSelectorTabbable(candidate, untouchabilityChecker)) continue;\n\n    candidateTabindex = getTabindex(candidate);\n    if (candidateTabindex === 0) {\n      regularTabbables.push(candidate);\n    } else {\n      orderedTabbables.push({\n        documentOrder: i,\n        tabIndex: candidateTabindex,\n        node: candidate,\n      });\n    }\n  }\n\n  var tabbableNodes = orderedTabbables\n    .sort(sortOrderedTabbables)\n    .map(function(a) { return a.node })\n    .concat(regularTabbables);\n\n  return tabbableNodes;\n}\n\ntabbable.isTabbable = isTabbable;\ntabbable.isFocusable = isFocusable;\n\nfunction isNodeMatchingSelectorTabbable(node, untouchabilityChecker) {\n  if (\n    !isNodeMatchingSelectorFocusable(node, untouchabilityChecker)\n    || isNonTabbableRadio(node)\n    || getTabindex(node) < 0\n  ) {\n    return false;\n  }\n  return true;\n}\n\nfunction isTabbable(node, untouchabilityChecker) {\n  if (!node) throw new Error('No node provided');\n  if (matches.call(node, candidateSelector) === false) return false;\n  return isNodeMatchingSelectorTabbable(node, untouchabilityChecker);\n}\n\nfunction isNodeMatchingSelectorFocusable(node, untouchabilityChecker) {\n  untouchabilityChecker = untouchabilityChecker || new UntouchabilityChecker(node.ownerDocument || node);\n  if (\n    node.disabled\n    || isHiddenInput(node)\n    || untouchabilityChecker.isUntouchable(node)\n  ) {\n    return false;\n  }\n  return true;\n}\n\nvar focusableCandidateSelector = candidateSelectors.concat('iframe').join(',');\nfunction isFocusable(node, untouchabilityChecker) {\n  if (!node) throw new Error('No node provided');\n  if (matches.call(node, focusableCandidateSelector) === false) return false;\n  return isNodeMatchingSelectorFocusable(node, untouchabilityChecker);\n}\n\nfunction getTabindex(node) {\n  var tabindexAttr = parseInt(node.getAttribute('tabindex'), 10);\n  if (!isNaN(tabindexAttr)) return tabindexAttr;\n  // Browsers do not return `tabIndex` correctly for contentEditable nodes;\n  // so if they don't have a tabindex attribute specifically set, assume it's 0.\n  if (isContentEditable(node)) return 0;\n  return node.tabIndex;\n}\n\nfunction sortOrderedTabbables(a, b) {\n  return a.tabIndex === b.tabIndex ? a.documentOrder - b.documentOrder : a.tabIndex - b.tabIndex;\n}\n\n// Array.prototype.find not available in IE.\nfunction find(list, predicate) {\n  for (var i = 0, length = list.length; i < length; i++) {\n    if (predicate(list[i])) return list[i];\n  }\n}\n\nfunction isContentEditable(node) {\n  return node.contentEditable === 'true';\n}\n\nfunction isInput(node) {\n  return node.tagName === 'INPUT';\n}\n\nfunction isHiddenInput(node) {\n  return isInput(node) && node.type === 'hidden';\n}\n\nfunction isRadio(node) {\n  return isInput(node) && node.type === 'radio';\n}\n\nfunction isNonTabbableRadio(node) {\n  return isRadio(node) && !isTabbableRadio(node);\n}\n\nfunction getCheckedRadio(nodes) {\n  for (var i = 0; i < nodes.length; i++) {\n    if (nodes[i].checked) {\n      return nodes[i];\n    }\n  }\n}\n\nfunction isTabbableRadio(node) {\n  if (!node.name) return true;\n  // This won't account for the edge case where you have radio groups with the same\n  // in separate forms on the same page.\n  var radioSet = node.ownerDocument.querySelectorAll('input[type=\"radio\"][name=\"' + node.name + '\"]');\n  var checked = getCheckedRadio(radioSet);\n  return !checked || checked === node;\n}\n\n// An element is \"untouchable\" if *it or one of its ancestors* has\n// `visibility: hidden` or `display: none`.\nfunction UntouchabilityChecker(elementDocument) {\n  this.doc = elementDocument;\n  // Node cache must be refreshed on every check, in case\n  // the content of the element has changed. The cache contains tuples\n  // mapping nodes to their boolean result.\n  this.cache = [];\n}\n\n// getComputedStyle accurately reflects `visibility: hidden` of ancestors\n// but not `display: none`, so we need to recursively check parents.\nUntouchabilityChecker.prototype.hasDisplayNone = function hasDisplayNone(node, nodeComputedStyle) {\n  if (node.nodeType !== Node.ELEMENT_NODE) return false;\n\n    // Search for a cached result.\n    var cached = find(this.cache, function(item) {\n      return item === node;\n    });\n    if (cached) return cached[1];\n\n    nodeComputedStyle = nodeComputedStyle || this.doc.defaultView.getComputedStyle(node);\n\n    var result = false;\n\n    if (nodeComputedStyle.display === 'none') {\n      result = true;\n    } else if (node.parentNode) {\n      result = this.hasDisplayNone(node.parentNode);\n    }\n\n    this.cache.push([node, result]);\n\n    return result;\n}\n\nUntouchabilityChecker.prototype.isUntouchable = function isUntouchable(node) {\n  if (node === this.doc.documentElement) return false;\n  var computedStyle = this.doc.defaultView.getComputedStyle(node);\n  if (this.hasDisplayNone(node, computedStyle)) return true;\n  return computedStyle.visibility === 'hidden';\n}\n\nmodule.exports = tabbable;\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///4760\n")},5933:(module,exports,__webpack_require__)=>{eval('var __WEBPACK_AMD_DEFINE_RESULT__;/* Web Font Loader v1.6.28 - (c) Adobe Systems, Google. License: Apache 2.0 */(function(){function aa(a,b,c){return a.call.apply(a.bind,arguments)}function ba(a,b,c){if(!a)throw Error();if(2=b.f?e():a.fonts.load(fa(b.a),b.h).then(function(a){1<=a.length?d():setTimeout(f,25)},function(){e()})}f()}),e=null,f=new Promise(function(a,d){e=setTimeout(d,b.f)});Promise.race([f,d]).then(function(){e&&(clearTimeout(e),e=null);b.g(b.a)},function(){b.j(b.a)})};function Q(a,b,c,d,e,f,g){this.v=a;this.B=b;this.c=c;this.a=d;this.s=g||"BESbswy";this.f={};this.w=e||3E3;this.u=f||null;this.m=this.j=this.h=this.g=null;this.g=new M(this.c,this.s);this.h=new M(this.c,this.s);this.j=new M(this.c,this.s);this.m=new M(this.c,this.s);a=new G(this.a.c+",serif",J(this.a));a=O(a);this.g.a.style.cssText=a;a=new G(this.a.c+",sans-serif",J(this.a));a=O(a);this.h.a.style.cssText=a;a=new G("serif",J(this.a));a=O(a);this.j.a.style.cssText=a;a=new G("sans-serif",J(this.a));a=\nO(a);this.m.a.style.cssText=a;N(this.g);N(this.h);N(this.j);N(this.m)}var R={D:"serif",C:"sans-serif"},S=null;function T(){if(null===S){var a=/AppleWebKit\\/([0-9]+)(?:\\.([0-9]+))/.exec(window.navigator.userAgent);S=!!a&&(536>parseInt(a[1],10)||536===parseInt(a[1],10)&&11>=parseInt(a[2],10))}return S}Q.prototype.start=function(){this.f.serif=this.j.a.offsetWidth;this.f["sans-serif"]=this.m.a.offsetWidth;this.A=q();U(this)};\nfunction la(a,b,c){for(var d in R)if(R.hasOwnProperty(d)&&b===a.f[R[d]]&&c===a.f[R[d]])return!0;return!1}function U(a){var b=a.g.a.offsetWidth,c=a.h.a.offsetWidth,d;(d=b===a.f.serif&&c===a.f["sans-serif"])||(d=T()&&la(a,b,c));d?q()-a.A>=a.w?T()&&la(a,b,c)&&(null===a.u||a.u.hasOwnProperty(a.a.c))?V(a,a.v):V(a,a.B):ma(a):V(a,a.v)}function ma(a){setTimeout(p(function(){U(this)},a),50)}function V(a,b){setTimeout(p(function(){v(this.g.a);v(this.h.a);v(this.j.a);v(this.m.a);b(this.a)},a),0)};function W(a,b,c){this.c=a;this.a=b;this.f=0;this.m=this.j=!1;this.s=c}var X=null;W.prototype.g=function(a){var b=this.a;b.g&&w(b.f,[b.a.c("wf",a.c,J(a).toString(),"active")],[b.a.c("wf",a.c,J(a).toString(),"loading"),b.a.c("wf",a.c,J(a).toString(),"inactive")]);K(b,"fontactive",a);this.m=!0;na(this)};\nW.prototype.h=function(a){var b=this.a;if(b.g){var c=y(b.f,b.a.c("wf",a.c,J(a).toString(),"active")),d=[],e=[b.a.c("wf",a.c,J(a).toString(),"loading")];c||d.push(b.a.c("wf",a.c,J(a).toString(),"inactive"));w(b.f,d,e)}K(b,"fontinactive",a);na(this)};function na(a){0==--a.f&&a.j&&(a.m?(a=a.a,a.g&&w(a.f,[a.a.c("wf","active")],[a.a.c("wf","loading"),a.a.c("wf","inactive")]),K(a,"active")):L(a.a))};function oa(a){this.j=a;this.a=new ja;this.h=0;this.f=this.g=!0}oa.prototype.load=function(a){this.c=new ca(this.j,a.context||this.j);this.g=!1!==a.events;this.f=!1!==a.classes;pa(this,new ha(this.c,a),a)};\nfunction qa(a,b,c,d,e){var f=0==--a.h;(a.f||a.g)&&setTimeout(function(){var a=e||null,m=d||null||{};if(0===c.length&&f)L(b.a);else{b.f+=c.length;f&&(b.j=f);var h,l=[];for(h=0;h{eval("module.exports = extend\n\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\n\nfunction extend() {\n var target = {}\n\n for (var i = 0; i < arguments.length; i++) {\n var source = arguments[i]\n\n for (var key in source) {\n if (hasOwnProperty.call(source, key)) {\n target[key] = source[key]\n }\n }\n }\n\n return target\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNzUyOS5qcyIsIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vbm9kZV9tb2R1bGVzL3h0ZW5kL2ltbXV0YWJsZS5qcz81M2E4Il0sInNvdXJjZXNDb250ZW50IjpbIm1vZHVsZS5leHBvcnRzID0gZXh0ZW5kXG5cbnZhciBoYXNPd25Qcm9wZXJ0eSA9IE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHk7XG5cbmZ1bmN0aW9uIGV4dGVuZCgpIHtcbiAgICB2YXIgdGFyZ2V0ID0ge31cblxuICAgIGZvciAodmFyIGkgPSAwOyBpIDwgYXJndW1lbnRzLmxlbmd0aDsgaSsrKSB7XG4gICAgICAgIHZhciBzb3VyY2UgPSBhcmd1bWVudHNbaV1cblxuICAgICAgICBmb3IgKHZhciBrZXkgaW4gc291cmNlKSB7XG4gICAgICAgICAgICBpZiAoaGFzT3duUHJvcGVydHkuY2FsbChzb3VyY2UsIGtleSkpIHtcbiAgICAgICAgICAgICAgICB0YXJnZXRba2V5XSA9IHNvdXJjZVtrZXldXG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICByZXR1cm4gdGFyZ2V0XG59XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///7529\n")},1764:(e,n,t)=>{var g={"./ct-addable-box.js":9285,"./ct-background.js":8601,"./ct-border.js":9218,"./ct-box-shadow.js":9795,"./ct-button.js":9838,"./ct-checkboxes.js":3413,"./ct-color-palettes-picker.js":2757,"./ct-color-picker.js":2495,"./ct-customizer-reset-options.js":9158,"./ct-divider.js":8163,"./ct-footer-builder.js":5821,"./ct-header-builder.js":5565,"./ct-image-picker.js":6962,"./ct-image-uploader.js":3048,"./ct-layers-mirror.js":379,"./ct-layers.js":6780,"./ct-multi-image-uploader.js":546,"./ct-notification.js":9875,"./ct-number.js":4949,"./ct-panel.js":3731,"./ct-radio.js":7636,"./ct-ratio.js":9735,"./ct-select.js":1404,"./ct-slider.js":8252,"./ct-spacer.js":1282,"./ct-spacing.js":5286,"./ct-switch.js":9497,"./ct-title.js":7896,"./ct-typography.js":5183,"./ct-visibility.js":5138,"./ct-woocommerce-columns-and-rows.js":6223,"./ct-woocommerce-ratio.js":6761,"./date-time-picker.js":7946,"./hidden.js":6897,"./html.js":6904,"./jsx.js":5491,"./react-outside-click-handler.js":8204,"./text.js":977,"./textarea.js":1323,"./wp-editor.js":9313};function I(e){var n=l(e);return t(n)}function l(e){if(!t.o(g,e)){var n=new Error("Cannot find module '"+e+"'");throw n.code="MODULE_NOT_FOUND",n}return g[e]}I.keys=function(){return Object.keys(g)},I.resolve=l,e.exports=I,I.id=1764},7363:e=>{"use strict";e.exports=React},1533:e=>{"use strict";e.exports=ReactDOM},2243:e=>{"use strict";e.exports=ctEvents},5311:e=>{"use strict";e.exports=jQuery},6715:e=>{"use strict";e.exports=window._},8441:e=>{"use strict";e.exports=window.wp.components},3356:e=>{"use strict";e.exports=window.wp.compose},1381:e=>{"use strict";e.exports=window.wp.element},5652:e=>{"use strict";e.exports=window.wp.i18n},7228:e=>{"use strict";e.exports=window.wp.keycodes},4737:e=>{"use strict";e.exports=window.wp.primitives},7326:(__unused_webpack___webpack_module__,__webpack_exports__,__webpack_require__)=>{"use strict";eval('/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "Z": () => (/* binding */ _assertThisInitialized)\n/* harmony export */ });\nfunction _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError("this hasn\'t been initialised - super() hasn\'t been called");\n }\n\n return self;\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNzMyNi5qcyIsIm1hcHBpbmdzIjoiOzs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vbm9kZV9tb2R1bGVzL0BiYWJlbC9ydW50aW1lL2hlbHBlcnMvZXNtL2Fzc2VydFRoaXNJbml0aWFsaXplZC5qcz9mMDk4Il0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIF9hc3NlcnRUaGlzSW5pdGlhbGl6ZWQoc2VsZikge1xuICBpZiAoc2VsZiA9PT0gdm9pZCAwKSB7XG4gICAgdGhyb3cgbmV3IFJlZmVyZW5jZUVycm9yKFwidGhpcyBoYXNuJ3QgYmVlbiBpbml0aWFsaXNlZCAtIHN1cGVyKCkgaGFzbid0IGJlZW4gY2FsbGVkXCIpO1xuICB9XG5cbiAgcmV0dXJuIHNlbGY7XG59Il0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///7326\n')},7462:(__unused_webpack___webpack_module__,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (/* binding */ _extends)\n/* harmony export */ });\nfunction _extends() {\n _extends = Object.assign ? Object.assign.bind() : function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n };\n return _extends.apply(this, arguments);\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNzQ2Mi5qcyIsIm1hcHBpbmdzIjoiOzs7O0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9ibG9ja3N5T3B0aW9ucy8uL25vZGVfbW9kdWxlcy9AYmFiZWwvcnVudGltZS9oZWxwZXJzL2VzbS9leHRlbmRzLmpzPzRiMDkiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gX2V4dGVuZHMoKSB7XG4gIF9leHRlbmRzID0gT2JqZWN0LmFzc2lnbiA/IE9iamVjdC5hc3NpZ24uYmluZCgpIDogZnVuY3Rpb24gKHRhcmdldCkge1xuICAgIGZvciAodmFyIGkgPSAxOyBpIDwgYXJndW1lbnRzLmxlbmd0aDsgaSsrKSB7XG4gICAgICB2YXIgc291cmNlID0gYXJndW1lbnRzW2ldO1xuXG4gICAgICBmb3IgKHZhciBrZXkgaW4gc291cmNlKSB7XG4gICAgICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwoc291cmNlLCBrZXkpKSB7XG4gICAgICAgICAgdGFyZ2V0W2tleV0gPSBzb3VyY2Vba2V5XTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiB0YXJnZXQ7XG4gIH07XG4gIHJldHVybiBfZXh0ZW5kcy5hcHBseSh0aGlzLCBhcmd1bWVudHMpO1xufSJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///7462\n')},4578:(__unused_webpack___webpack_module__,__webpack_exports__,__webpack_require__)=>{"use strict";eval('/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "Z": () => (/* binding */ _inheritsLoose)\n/* harmony export */ });\n/* harmony import */ var _setPrototypeOf_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(9611);\n\nfunction _inheritsLoose(subClass, superClass) {\n subClass.prototype = Object.create(superClass.prototype);\n subClass.prototype.constructor = subClass;\n (0,_setPrototypeOf_js__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .Z)(subClass, superClass);\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNDU3OC5qcyIsIm1hcHBpbmdzIjoiOzs7O0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vYmxvY2tzeU9wdGlvbnMvLi9ub2RlX21vZHVsZXMvQGJhYmVsL3J1bnRpbWUvaGVscGVycy9lc20vaW5oZXJpdHNMb29zZS5qcz80MWRmIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzZXRQcm90b3R5cGVPZiBmcm9tIFwiLi9zZXRQcm90b3R5cGVPZi5qc1wiO1xuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gX2luaGVyaXRzTG9vc2Uoc3ViQ2xhc3MsIHN1cGVyQ2xhc3MpIHtcbiAgc3ViQ2xhc3MucHJvdG90eXBlID0gT2JqZWN0LmNyZWF0ZShzdXBlckNsYXNzLnByb3RvdHlwZSk7XG4gIHN1YkNsYXNzLnByb3RvdHlwZS5jb25zdHJ1Y3RvciA9IHN1YkNsYXNzO1xuICBzZXRQcm90b3R5cGVPZihzdWJDbGFzcywgc3VwZXJDbGFzcyk7XG59Il0sIm5hbWVzIjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///4578\n')},3366:(__unused_webpack___webpack_module__,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (/* binding */ _objectWithoutPropertiesLoose)\n/* harmony export */ });\nfunction _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n\n return target;\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMzM2Ni5qcyIsIm1hcHBpbmdzIjoiOzs7O0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vbm9kZV9tb2R1bGVzL0BiYWJlbC9ydW50aW1lL2hlbHBlcnMvZXNtL29iamVjdFdpdGhvdXRQcm9wZXJ0aWVzTG9vc2UuanM/Njk2MSJdLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBfb2JqZWN0V2l0aG91dFByb3BlcnRpZXNMb29zZShzb3VyY2UsIGV4Y2x1ZGVkKSB7XG4gIGlmIChzb3VyY2UgPT0gbnVsbCkgcmV0dXJuIHt9O1xuICB2YXIgdGFyZ2V0ID0ge307XG4gIHZhciBzb3VyY2VLZXlzID0gT2JqZWN0LmtleXMoc291cmNlKTtcbiAgdmFyIGtleSwgaTtcblxuICBmb3IgKGkgPSAwOyBpIDwgc291cmNlS2V5cy5sZW5ndGg7IGkrKykge1xuICAgIGtleSA9IHNvdXJjZUtleXNbaV07XG4gICAgaWYgKGV4Y2x1ZGVkLmluZGV4T2Yoa2V5KSA+PSAwKSBjb250aW51ZTtcbiAgICB0YXJnZXRba2V5XSA9IHNvdXJjZVtrZXldO1xuICB9XG5cbiAgcmV0dXJuIHRhcmdldDtcbn0iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///3366\n')},9611:(__unused_webpack___webpack_module__,__webpack_exports__,__webpack_require__)=>{"use strict";eval('/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "Z": () => (/* binding */ _setPrototypeOf)\n/* harmony export */ });\nfunction _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n return _setPrototypeOf(o, p);\n}//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiOTYxMS5qcyIsIm1hcHBpbmdzIjoiOzs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsid2VicGFjazovL2Jsb2Nrc3lPcHRpb25zLy4vbm9kZV9tb2R1bGVzL0BiYWJlbC9ydW50aW1lL2hlbHBlcnMvZXNtL3NldFByb3RvdHlwZU9mLmpzPzVkMjQiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gX3NldFByb3RvdHlwZU9mKG8sIHApIHtcbiAgX3NldFByb3RvdHlwZU9mID0gT2JqZWN0LnNldFByb3RvdHlwZU9mID8gT2JqZWN0LnNldFByb3RvdHlwZU9mLmJpbmQoKSA6IGZ1bmN0aW9uIF9zZXRQcm90b3R5cGVPZihvLCBwKSB7XG4gICAgby5fX3Byb3RvX18gPSBwO1xuICAgIHJldHVybiBvO1xuICB9O1xuICByZXR1cm4gX3NldFByb3RvdHlwZU9mKG8sIHApO1xufSJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///9611\n')},6765:(__unused_webpack___webpack_module__,__webpack_exports__,__webpack_require__)=>{"use strict";eval('/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "Vi": () => (/* binding */ w),\n/* harmony export */ "l7": () => (/* binding */ k)\n/* harmony export */ });\n/* unused harmony exports Colord, getFormat, random */\nvar r={grad:.9,turn:360,rad:360/(2*Math.PI)},t=function(r){return"string"==typeof r?r.length>0:"number"==typeof r},n=function(r,t,n){return void 0===t&&(t=0),void 0===n&&(n=Math.pow(10,t)),Math.round(n*r)/n+0},e=function(r,t,n){return void 0===t&&(t=0),void 0===n&&(n=1),r>n?n:r>t?r:t},u=function(r){return(r=isFinite(r)?r%360:0)>0?r:r+360},a=function(r){return{r:e(r.r,0,255),g:e(r.g,0,255),b:e(r.b,0,255),a:e(r.a)}},o=function(r){return{r:n(r.r),g:n(r.g),b:n(r.b),a:n(r.a,3)}},i=/^#([0-9a-f]{3,8})$/i,s=function(r){var t=r.toString(16);return t.length<2?"0"+t:t},h=function(r){var t=r.r,n=r.g,e=r.b,u=r.a,a=Math.max(t,n,e),o=a-Math.min(t,n,e),i=o?a===t?(n-e)/o:a===n?2+(e-t)/o:4+(t-n)/o:0;return{h:60*(i<0?i+6:i),s:a?o/a*100:0,v:a/255*100,a:u}},b=function(r){var t=r.h,n=r.s,e=r.v,u=r.a;t=t/360*6,n/=100,e/=100;var a=Math.floor(t),o=e*(1-n),i=e*(1-(t-a)*n),s=e*(1-(1-t+a)*n),h=a%6;return{r:255*[e,i,o,o,s,e][h],g:255*[s,e,e,i,o,o][h],b:255*[o,o,s,e,e,i][h],a:u}},g=function(r){return{h:u(r.h),s:e(r.s,0,100),l:e(r.l,0,100),a:e(r.a)}},d=function(r){return{h:n(r.h),s:n(r.s),l:n(r.l),a:n(r.a,3)}},f=function(r){return b((n=(t=r).s,{h:t.h,s:(n*=((e=t.l)<50?e:100-e)/100)>0?2*n/(e+n)*100:0,v:e+n,a:t.a}));var t,n,e},c=function(r){return{h:(t=h(r)).h,s:(u=(200-(n=t.s))*(e=t.v)/100)>0&&u<200?n*e/100/(u<=100?u:200-u)*100:0,l:u/2,a:t.a};var t,n,e,u},l=/^hsla?\\(\\s*([+-]?\\d*\\.?\\d+)(deg|rad|grad|turn)?\\s*,\\s*([+-]?\\d*\\.?\\d+)%\\s*,\\s*([+-]?\\d*\\.?\\d+)%\\s*(?:,\\s*([+-]?\\d*\\.?\\d+)(%)?\\s*)?\\)$/i,p=/^hsla?\\(\\s*([+-]?\\d*\\.?\\d+)(deg|rad|grad|turn)?\\s+([+-]?\\d*\\.?\\d+)%\\s+([+-]?\\d*\\.?\\d+)%\\s*(?:\\/\\s*([+-]?\\d*\\.?\\d+)(%)?\\s*)?\\)$/i,v=/^rgba?\\(\\s*([+-]?\\d*\\.?\\d+)(%)?\\s*,\\s*([+-]?\\d*\\.?\\d+)(%)?\\s*,\\s*([+-]?\\d*\\.?\\d+)(%)?\\s*(?:,\\s*([+-]?\\d*\\.?\\d+)(%)?\\s*)?\\)$/i,m=/^rgba?\\(\\s*([+-]?\\d*\\.?\\d+)(%)?\\s+([+-]?\\d*\\.?\\d+)(%)?\\s+([+-]?\\d*\\.?\\d+)(%)?\\s*(?:\\/\\s*([+-]?\\d*\\.?\\d+)(%)?\\s*)?\\)$/i,y={string:[[function(r){var t=i.exec(r);return t?(r=t[1]).length<=4?{r:parseInt(r[0]+r[0],16),g:parseInt(r[1]+r[1],16),b:parseInt(r[2]+r[2],16),a:4===r.length?n(parseInt(r[3]+r[3],16)/255,2):1}:6===r.length||8===r.length?{r:parseInt(r.substr(0,2),16),g:parseInt(r.substr(2,2),16),b:parseInt(r.substr(4,2),16),a:8===r.length?n(parseInt(r.substr(6,2),16)/255,2):1}:null:null},"hex"],[function(r){var t=v.exec(r)||m.exec(r);return t?t[2]!==t[4]||t[4]!==t[6]?null:a({r:Number(t[1])/(t[2]?100/255:1),g:Number(t[3])/(t[4]?100/255:1),b:Number(t[5])/(t[6]?100/255:1),a:void 0===t[7]?1:Number(t[7])/(t[8]?100:1)}):null},"rgb"],[function(t){var n=l.exec(t)||p.exec(t);if(!n)return null;var e,u,a=g({h:(e=n[1],u=n[2],void 0===u&&(u="deg"),Number(e)*(r[u]||1)),s:Number(n[3]),l:Number(n[4]),a:void 0===n[5]?1:Number(n[5])/(n[6]?100:1)});return f(a)},"hsl"]],object:[[function(r){var n=r.r,e=r.g,u=r.b,o=r.a,i=void 0===o?1:o;return t(n)&&t(e)&&t(u)?a({r:Number(n),g:Number(e),b:Number(u),a:Number(i)}):null},"rgb"],[function(r){var n=r.h,e=r.s,u=r.l,a=r.a,o=void 0===a?1:a;if(!t(n)||!t(e)||!t(u))return null;var i=g({h:Number(n),s:Number(e),l:Number(u),a:Number(o)});return f(i)},"hsl"],[function(r){var n=r.h,a=r.s,o=r.v,i=r.a,s=void 0===i?1:i;if(!t(n)||!t(a)||!t(o))return null;var h=function(r){return{h:u(r.h),s:e(r.s,0,100),v:e(r.v,0,100),a:e(r.a)}}({h:Number(n),s:Number(a),v:Number(o),a:Number(s)});return b(h)},"hsv"]]},N=function(r,t){for(var n=0;n=.5},r.prototype.toHex=function(){return r=o(this.rgba),t=r.r,e=r.g,u=r.b,i=(a=r.a)<1?s(n(255*a)):"","#"+s(t)+s(e)+s(u)+i;var r,t,e,u,a,i},r.prototype.toRgb=function(){return o(this.rgba)},r.prototype.toRgbString=function(){return r=o(this.rgba),t=r.r,n=r.g,e=r.b,(u=r.a)<1?"rgba("+t+", "+n+", "+e+", "+u+")":"rgb("+t+", "+n+", "+e+")";var r,t,n,e,u},r.prototype.toHsl=function(){return d(c(this.rgba))},r.prototype.toHslString=function(){return r=d(c(this.rgba)),t=r.h,n=r.s,e=r.l,(u=r.a)<1?"hsla("+t+", "+n+"%, "+e+"%, "+u+")":"hsl("+t+", "+n+"%, "+e+"%)";var r,t,n,e,u},r.prototype.toHsv=function(){return r=h(this.rgba),{h:n(r.h),s:n(r.s),v:n(r.v),a:n(r.a,3)};var r},r.prototype.invert=function(){return w({r:255-(r=this.rgba).r,g:255-r.g,b:255-r.b,a:r.a});var r},r.prototype.saturate=function(r){return void 0===r&&(r=.1),w(M(this.rgba,r))},r.prototype.desaturate=function(r){return void 0===r&&(r=.1),w(M(this.rgba,-r))},r.prototype.grayscale=function(){return w(M(this.rgba,-1))},r.prototype.lighten=function(r){return void 0===r&&(r=.1),w($(this.rgba,r))},r.prototype.darken=function(r){return void 0===r&&(r=.1),w($(this.rgba,-r))},r.prototype.rotate=function(r){return void 0===r&&(r=15),this.hue(this.hue()+r)},r.prototype.alpha=function(r){return"number"==typeof r?w({r:(t=this.rgba).r,g:t.g,b:t.b,a:r}):n(this.rgba.a,3);var t},r.prototype.hue=function(r){var t=c(this.rgba);return"number"==typeof r?w({h:r,s:t.s,l:t.l,a:t.a}):n(t.h)},r.prototype.isEqual=function(r){return this.toHex()===w(r).toHex()},r}(),w=function(r){return r instanceof j?r:new j(r)},S=[],k=function(r){r.forEach(function(r){S.indexOf(r)<0&&(r(j,y),S.push(r))})},E=function(){return new j({r:255*Math.random(),g:255*Math.random(),b:255*Math.random()})};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"6765.js","mappings":";;;;;AAAA","sources":["webpack://blocksyOptions/./node_modules/colord/index.mjs?f033"],"sourcesContent":["var r={grad:.9,turn:360,rad:360/(2*Math.PI)},t=function(r){return\"string\"==typeof r?r.length>0:\"number\"==typeof r},n=function(r,t,n){return void 0===t&&(t=0),void 0===n&&(n=Math.pow(10,t)),Math.round(n*r)/n+0},e=function(r,t,n){return void 0===t&&(t=0),void 0===n&&(n=1),r>n?n:r>t?r:t},u=function(r){return(r=isFinite(r)?r%360:0)>0?r:r+360},a=function(r){return{r:e(r.r,0,255),g:e(r.g,0,255),b:e(r.b,0,255),a:e(r.a)}},o=function(r){return{r:n(r.r),g:n(r.g),b:n(r.b),a:n(r.a,3)}},i=/^#([0-9a-f]{3,8})$/i,s=function(r){var t=r.toString(16);return t.length<2?\"0\"+t:t},h=function(r){var t=r.r,n=r.g,e=r.b,u=r.a,a=Math.max(t,n,e),o=a-Math.min(t,n,e),i=o?a===t?(n-e)/o:a===n?2+(e-t)/o:4+(t-n)/o:0;return{h:60*(i<0?i+6:i),s:a?o/a*100:0,v:a/255*100,a:u}},b=function(r){var t=r.h,n=r.s,e=r.v,u=r.a;t=t/360*6,n/=100,e/=100;var a=Math.floor(t),o=e*(1-n),i=e*(1-(t-a)*n),s=e*(1-(1-t+a)*n),h=a%6;return{r:255*[e,i,o,o,s,e][h],g:255*[s,e,e,i,o,o][h],b:255*[o,o,s,e,e,i][h],a:u}},g=function(r){return{h:u(r.h),s:e(r.s,0,100),l:e(r.l,0,100),a:e(r.a)}},d=function(r){return{h:n(r.h),s:n(r.s),l:n(r.l),a:n(r.a,3)}},f=function(r){return b((n=(t=r).s,{h:t.h,s:(n*=((e=t.l)<50?e:100-e)/100)>0?2*n/(e+n)*100:0,v:e+n,a:t.a}));var t,n,e},c=function(r){return{h:(t=h(r)).h,s:(u=(200-(n=t.s))*(e=t.v)/100)>0&&u<200?n*e/100/(u<=100?u:200-u)*100:0,l:u/2,a:t.a};var t,n,e,u},l=/^hsla?\\(\\s*([+-]?\\d*\\.?\\d+)(deg|rad|grad|turn)?\\s*,\\s*([+-]?\\d*\\.?\\d+)%\\s*,\\s*([+-]?\\d*\\.?\\d+)%\\s*(?:,\\s*([+-]?\\d*\\.?\\d+)(%)?\\s*)?\\)$/i,p=/^hsla?\\(\\s*([+-]?\\d*\\.?\\d+)(deg|rad|grad|turn)?\\s+([+-]?\\d*\\.?\\d+)%\\s+([+-]?\\d*\\.?\\d+)%\\s*(?:\\/\\s*([+-]?\\d*\\.?\\d+)(%)?\\s*)?\\)$/i,v=/^rgba?\\(\\s*([+-]?\\d*\\.?\\d+)(%)?\\s*,\\s*([+-]?\\d*\\.?\\d+)(%)?\\s*,\\s*([+-]?\\d*\\.?\\d+)(%)?\\s*(?:,\\s*([+-]?\\d*\\.?\\d+)(%)?\\s*)?\\)$/i,m=/^rgba?\\(\\s*([+-]?\\d*\\.?\\d+)(%)?\\s+([+-]?\\d*\\.?\\d+)(%)?\\s+([+-]?\\d*\\.?\\d+)(%)?\\s*(?:\\/\\s*([+-]?\\d*\\.?\\d+)(%)?\\s*)?\\)$/i,y={string:[[function(r){var t=i.exec(r);return t?(r=t[1]).length<=4?{r:parseInt(r[0]+r[0],16),g:parseInt(r[1]+r[1],16),b:parseInt(r[2]+r[2],16),a:4===r.length?n(parseInt(r[3]+r[3],16)/255,2):1}:6===r.length||8===r.length?{r:parseInt(r.substr(0,2),16),g:parseInt(r.substr(2,2),16),b:parseInt(r.substr(4,2),16),a:8===r.length?n(parseInt(r.substr(6,2),16)/255,2):1}:null:null},\"hex\"],[function(r){var t=v.exec(r)||m.exec(r);return t?t[2]!==t[4]||t[4]!==t[6]?null:a({r:Number(t[1])/(t[2]?100/255:1),g:Number(t[3])/(t[4]?100/255:1),b:Number(t[5])/(t[6]?100/255:1),a:void 0===t[7]?1:Number(t[7])/(t[8]?100:1)}):null},\"rgb\"],[function(t){var n=l.exec(t)||p.exec(t);if(!n)return null;var e,u,a=g({h:(e=n[1],u=n[2],void 0===u&&(u=\"deg\"),Number(e)*(r[u]||1)),s:Number(n[3]),l:Number(n[4]),a:void 0===n[5]?1:Number(n[5])/(n[6]?100:1)});return f(a)},\"hsl\"]],object:[[function(r){var n=r.r,e=r.g,u=r.b,o=r.a,i=void 0===o?1:o;return t(n)&&t(e)&&t(u)?a({r:Number(n),g:Number(e),b:Number(u),a:Number(i)}):null},\"rgb\"],[function(r){var n=r.h,e=r.s,u=r.l,a=r.a,o=void 0===a?1:a;if(!t(n)||!t(e)||!t(u))return null;var i=g({h:Number(n),s:Number(e),l:Number(u),a:Number(o)});return f(i)},\"hsl\"],[function(r){var n=r.h,a=r.s,o=r.v,i=r.a,s=void 0===i?1:i;if(!t(n)||!t(a)||!t(o))return null;var h=function(r){return{h:u(r.h),s:e(r.s,0,100),v:e(r.v,0,100),a:e(r.a)}}({h:Number(n),s:Number(a),v:Number(o),a:Number(s)});return b(h)},\"hsv\"]]},N=function(r,t){for(var n=0;n<t.length;n++){var e=t[n][0](r);if(e)return[e,t[n][1]]}return[null,void 0]},x=function(r){return\"string\"==typeof r?N(r.trim(),y.string):\"object\"==typeof r&&null!==r?N(r,y.object):[null,void 0]},I=function(r){return x(r)[1]},M=function(r,t){var n=c(r);return{h:n.h,s:e(n.s+100*t,0,100),l:n.l,a:n.a}},H=function(r){return(299*r.r+587*r.g+114*r.b)/1e3/255},$=function(r,t){var n=c(r);return{h:n.h,s:n.s,l:e(n.l+100*t,0,100),a:n.a}},j=function(){function r(r){this.parsed=x(r)[0],this.rgba=this.parsed||{r:0,g:0,b:0,a:1}}return r.prototype.isValid=function(){return null!==this.parsed},r.prototype.brightness=function(){return n(H(this.rgba),2)},r.prototype.isDark=function(){return H(this.rgba)<.5},r.prototype.isLight=function(){return H(this.rgba)>=.5},r.prototype.toHex=function(){return r=o(this.rgba),t=r.r,e=r.g,u=r.b,i=(a=r.a)<1?s(n(255*a)):\"\",\"#\"+s(t)+s(e)+s(u)+i;var r,t,e,u,a,i},r.prototype.toRgb=function(){return o(this.rgba)},r.prototype.toRgbString=function(){return r=o(this.rgba),t=r.r,n=r.g,e=r.b,(u=r.a)<1?\"rgba(\"+t+\", \"+n+\", \"+e+\", \"+u+\")\":\"rgb(\"+t+\", \"+n+\", \"+e+\")\";var r,t,n,e,u},r.prototype.toHsl=function(){return d(c(this.rgba))},r.prototype.toHslString=function(){return r=d(c(this.rgba)),t=r.h,n=r.s,e=r.l,(u=r.a)<1?\"hsla(\"+t+\", \"+n+\"%, \"+e+\"%, \"+u+\")\":\"hsl(\"+t+\", \"+n+\"%, \"+e+\"%)\";var r,t,n,e,u},r.prototype.toHsv=function(){return r=h(this.rgba),{h:n(r.h),s:n(r.s),v:n(r.v),a:n(r.a,3)};var r},r.prototype.invert=function(){return w({r:255-(r=this.rgba).r,g:255-r.g,b:255-r.b,a:r.a});var r},r.prototype.saturate=function(r){return void 0===r&&(r=.1),w(M(this.rgba,r))},r.prototype.desaturate=function(r){return void 0===r&&(r=.1),w(M(this.rgba,-r))},r.prototype.grayscale=function(){return w(M(this.rgba,-1))},r.prototype.lighten=function(r){return void 0===r&&(r=.1),w($(this.rgba,r))},r.prototype.darken=function(r){return void 0===r&&(r=.1),w($(this.rgba,-r))},r.prototype.rotate=function(r){return void 0===r&&(r=15),this.hue(this.hue()+r)},r.prototype.alpha=function(r){return\"number\"==typeof r?w({r:(t=this.rgba).r,g:t.g,b:t.b,a:r}):n(this.rgba.a,3);var t},r.prototype.hue=function(r){var t=c(this.rgba);return\"number\"==typeof r?w({h:r,s:t.s,l:t.l,a:t.a}):n(t.h)},r.prototype.isEqual=function(r){return this.toHex()===w(r).toHex()},r}(),w=function(r){return r instanceof j?r:new j(r)},S=[],k=function(r){r.forEach(function(r){S.indexOf(r)<0&&(r(j,y),S.push(r))})},E=function(){return new j({r:255*Math.random(),g:255*Math.random(),b:255*Math.random()})};export{j as Colord,w as colord,k as extend,I as getFormat,E as random};\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///6765\n')}},__webpack_module_cache__={},inProgress,dataWebpackPrefix;function __webpack_require__(e){var n=__webpack_module_cache__[e];if(void 0!==n)return n.exports;var t=__webpack_module_cache__[e]={id:e,loaded:!1,exports:{}};return __webpack_modules__[e].call(t.exports,t,t.exports,__webpack_require__),t.loaded=!0,t.exports}__webpack_require__.m=__webpack_modules__,__webpack_require__.n=e=>{var n=e&&e.__esModule?()=>e.default:()=>e;return __webpack_require__.d(n,{a:n}),n},__webpack_require__.d=(e,n)=>{for(var t in n)__webpack_require__.o(n,t)&&!__webpack_require__.o(e,t)&&Object.defineProperty(e,t,{enumerable:!0,get:n[t]})},__webpack_require__.f={},__webpack_require__.e=e=>Promise.all(Object.keys(__webpack_require__.f).reduce(((n,t)=>(__webpack_require__.f[t](e,n),n)),[])),__webpack_require__.u=e=>e+"."+{149:"14b20ad0a8288ce671e8",188:"e336139f8a253ffc7c1c",904:"ef3d94e7d7f89419586d"}[e]+".js",__webpack_require__.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),__webpack_require__.o=(e,n)=>Object.prototype.hasOwnProperty.call(e,n),inProgress={},dataWebpackPrefix="blocksyOptions:",__webpack_require__.l=(e,n,t,g)=>{if(inProgress[e])inProgress[e].push(n);else{var I,l;if(void 0!==t)for(var c=document.getElementsByTagName("script"),B=0;B{I.onerror=I.onload=null,clearTimeout(d);var g=inProgress[e];if(delete inProgress[e],I.parentNode&&I.parentNode.removeChild(I),g&&g.forEach((e=>e(t))),n)return n(t)},d=setTimeout(b.bind(null,void 0,{type:"timeout",target:I}),12e4);I.onerror=b.bind(null,I.onerror),I.onload=b.bind(null,I.onload),l&&document.head.appendChild(I)}},__webpack_require__.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},__webpack_require__.nmd=e=>(e.paths=[],e.children||(e.children=[]),e),(()=>{var e;__webpack_require__.g.importScripts&&(e=__webpack_require__.g.location+"");var n=__webpack_require__.g.document;if(!e&&n&&(n.currentScript&&(e=n.currentScript.src),!e)){var t=n.getElementsByTagName("script");t.length&&(e=t[t.length-1].src)}if(!e)throw new Error("Automatic publicPath is not supported in this browser");e=e.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),__webpack_require__.p=e})(),(()=>{var e={179:0};__webpack_require__.f.j=(n,t)=>{var g=__webpack_require__.o(e,n)?e[n]:void 0;if(0!==g)if(g)t.push(g[2]);else{var I=new Promise(((t,I)=>g=e[n]=[t,I]));t.push(g[2]=I);var l=__webpack_require__.p+__webpack_require__.u(n),c=new Error;__webpack_require__.l(l,(t=>{if(__webpack_require__.o(e,n)&&(0!==(g=e[n])&&(e[n]=void 0),g)){var I=t&&("load"===t.type?"missing":t.type),l=t&&t.target&&t.target.src;c.message="Loading chunk "+n+" failed.\n("+I+": "+l+")",c.name="ChunkLoadError",c.type=I,c.request=l,g[1](c)}}),"chunk-"+n,n)}};var n=(n,t)=>{var g,I,[l,c,B]=t,i=0;if(l.some((n=>0!==e[n]))){for(g in c)__webpack_require__.o(c,g)&&(__webpack_require__.m[g]=c[g]);B&&B(__webpack_require__)}for(n&&n(t);i