{"version":3,"sources":["webpack:///./presentation/hocs/withLanguage.tsx","webpack:///../node_modules/@ux/type-size/dist/es/type-size.js","webpack:///../node_modules/@ux/px2em/dist/es/px2em.js","webpack:///../node_modules/@ux/px2em/dist/es/px2em.production.js","webpack:///../node_modules/px2em-sync/lib/index.js","webpack:///../node_modules/px2em-sync/lib/px2emSync.js","webpack:///../node_modules/react-equalizer/lib/equalizer.js","webpack:///./presentation/utils/debounce.js","webpack:///./presentation/components/ribbons/salesboard/constants.ts","webpack:///src/presentation/components/ribbons/salesboard/Salesboard.stylesheet.ts","webpack:///src/presentation/components/ribbons/salesboard/Navigation.tsx","webpack:///src/presentation/components/ribbons/salesboard/PaginationItem.tsx","webpack:///./presentation/components/ribbons/salesboard/Pagination.tsx","webpack:///src/presentation/components/ribbons/salesboard/Item.stylesheet.ts","webpack:///src/presentation/components/ribbons/salesboard/ItemFeatures.stylesheet.ts","webpack:///./presentation/components/ribbons/salesboard/ItemFeature.tsx","webpack:///src/presentation/components/ribbons/salesboard/ItemFeature.stylesheet.ts","webpack:///./presentation/components/ribbons/salesboard/ItemFeatures.tsx","webpack:///./presentation/components/ribbons/salesboard/ItemPrice.tsx","webpack:///src/presentation/components/ribbons/salesboard/ItemPrice.stylesheet.ts","webpack:///./presentation/components/ribbons/salesboard/ItemDetails.tsx","webpack:///src/presentation/components/ribbons/salesboard/ItemDetails.stylesheet.ts","webpack:///./presentation/components/ribbons/salesboard/ItemHeader.tsx","webpack:///src/presentation/components/ribbons/salesboard/ItemHeader.stylesheet.ts","webpack:///./presentation/components/ribbons/salesboard/Item.tsx","webpack:///./presentation/components/ribbons/salesboard/utils.ts","webpack:///./presentation/components/ribbons/salesboard/Salesboard.tsx","webpack:///./presentation/utils/isTouchDevice.js","webpack:///./presentation/components/ribbons/salesboard/index.ts"],"names":["Component","props","currentLanguage","useCurrentLanguage","_SizeMap","_defineProperty","obj","key","value","Object","defineProperty","enumerable","configurable","writable","SMALL","MEDIUM","LARGE","_SizeMap$1","_SizeMap$2","_SizeMap$3","_SizeMap$4","_LineHeightMap","_SizeMap$5","_SizeMap$6","_SizeMap$7","content","fontSize","lineHeight","footnote","smallprint","SizeMap$1","headingXxl","theme","size","typography","sizing","SizeMap$2","headingXl","SizeMap$3","LineHeightMap","headingL","height","SizeMap$4","LineHeightMap$1","headingM","SizeMap$5","LineHeightMap$2","headingS","SizeMap$6","LineHeightMap$3","headingXs","SizeMap$7","LineHeightMap$4","headingXxs","module","exports","px2em","m","format","base","_px2emSync2","__esModule","default","_interopRequireDefault","_extends","assign","target","i","arguments","length","source","prototype","hasOwnProperty","call","px","options","TypeError","_base$format$options","em","Math","round","_createClass","defineProperties","descriptor","Constructor","protoProps","staticProps","_react","_react2","_propTypes2","Equalizer","_Component","instance","_classCallCheck","this","_this","self","ReferenceError","_possibleConstructorReturn","__proto__","getPrototypeOf","handleResize","func","wait","immediate","timeout","args","context","timestamp","result","later","last","Date","now","setTimeout","apply","debounced","callNow","clear","clearTimeout","debounce","bind","updateChildrenHeights","subClass","superClass","create","constructor","setPrototypeOf","_inherits","addEventListener","rootNode","removeEventListener","_props","property","byRow","enabled","node","undefined","children","nodes","heights","getHeights","row","max","style","_this2","_props2","otherProps","keys","indexOf","_objectWithoutProperties","createElement","ref","onLoad","lastElTopOffset","groups","maxHeight","minHeight","_node$getBoundingClie","getBoundingClientRect","elOffsetTop","top","elHeight","push","j","map","item","defaultProps","component","propTypes","isRequired","string","bool","VisibleItems","XS","SM","MD","LG","XL","pageNavControls","PureSalesboardNavigation","colorway","styles","spacing","useTheme","useStyles","root","display","justifyContent","button","backgroundColor","color","palette","outline","borderWidth","gu2px","cursor","cssSides","Side","icon","width","getBodyColor","useStylesheet","onButtonClick","onNavigationClick","type","onClick","name","PureSalesboardPaginationItem","index","active","activeIndex","visibleItems","curvature","opacify","transition","borderRadius","Curvature","getBorderRadius","unsafeColorway","Colorway","aria-hidden","PureSalesboardPagination","itemCount","alignItems","Array","fill","PaginationItem","role","displayName","body","endorsed","grey","primary","PureSalesboardItemFeature","feature","first","longhand","paddingTop","borderTopWidth","paddingBottom","Shortcode","code","text","against","LIGHT","isLastVisibleItem","f","v","arr","isLast","PureSalesboardItemFeatures","hasMoreFeatures","onShowMoreClick","isEndorsed","showMoreFeatures","visibleFeatureLimit","features","maxFeatureLimit","id","parsedFeatures","toAddNumber","splitFeatures","slice","isNilOrEmpty","reverse","visibleFeatures","moreFeatures","openFeatures","toggleHeight","toggleIcon","list","listStyle","toggle","textAlign","toggleOpen","marginBottom","classNames","topBorderColor","cx","toggleBox","getClassNames","className","ItemFeature","duration","side","X","PureSalesboardItemPrice","ctas","product","pricingStrategy","ctaProps","JSON","parse","stringify","kind","Kind","PRIMARY","isMinSm","isMinLg","useBreakpoints","flexDirection","cta","marginTop","cssTheme","gu3","ProductPrice","showLegalCaveat","CallToAction","ribbonId","block","glyph","data-selector","label","PureSalesboardItemDetails","hBaseline","title","depth","PureSalesboardItemHeader","endorse","imageUrl","illustration","imageAspectRatio","imagesWithAspectRatios","breakpoints","activeImage","getActiveImageWithAspectRatios","hasBanner","url","bannerUrl","createImageUrl","position","endorseText","textOverflow","overflow","whiteSpace","left","right","fontFamily","bannerAspect","padding","imageAspectRatioPercentage","grey12","bannerImage","minWidth","transform","modifier","loading","alt","createImageAlt","src","urlLanguageParse","withLanguage","PureSalesboardItem","productId","descRef","hasFeaturedProduct","productName","prodSelectors","getName","tagline","getTagline","Boolean","legalText","opacity","borderless","ColorwayType","NEUTRAL","endorsedColorway","data-value","border","PureSalesboard","layout","products","initialScrollOffset","visible","isMinMd","isMinXl","getVisibleItems","setActiveIndex","useState","setShowMoreFeatures","showPagination","showNavigation","prefixes","split","window","DocumentTouch","document","query","matchMedia","matches","mq","join","isTouchDevice","scroller","scrollerRef","onScroll","currentVisible","el","findIndex","scrollToNode","useCallback","idx","scrollTo","min","offset","behavior","useRef","direction","clickZone","bottom","marginLeft","featureLengthArray","forEach","getFeaturesLengths","getMaxFeatureLimit","activeVisibleFeatureLimit","findResponsiveItem","supportNull","productsLength","useEffect","currency","useCurrency","brandId","useBrandId","items","salesboardProduct","term","pricingTier","skuId","itemId","defaultSkuId","Number","itemPrice","productSelectors","getPrice","includeTax","categoryName","defaultPrice","dispatchGA4Event","Ribbon","Type","SALESBOARD","fluid","parsedNodes","current","getNodes","values","customScrollSnap","Item","concat","String","Pagination","Navigation","errorBoundary","visibilitySet","Salesboard"],"mappings":"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","file":"pex-static/34/47.54abed43dcb2be517454.chunk.js","sourcesContent":["import React from 'react';\nimport { useCurrentLanguage } from 'domain/selectors/page';\n\nexport default (Component: any) => {\n  return function EnhancedComponent(props: any) {\n    const currentLanguage = useCurrentLanguage();\n    return <Component {...props} currentLanguage={currentLanguage} />;\n  };\n};\n","import { useTheme, TypographySizing } from '@ux/theme-utils';\nimport px2em from '@ux/px2em';\n\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\nvar _SizeMap;\nvar SizeMap = (_SizeMap = {}, _defineProperty(_SizeMap, TypographySizing.SMALL, 48), _defineProperty(_SizeMap, TypographySizing.MEDIUM, 55), _defineProperty(_SizeMap, TypographySizing.LARGE, 63), _SizeMap);\nvar display = (function () {\n  var _useTheme = useTheme(),\n      theme = _useTheme.theme;\n\n  var size = SizeMap[theme.typography.sizing] || 55;\n  return {\n    fontSize: px2em(size),\n    lineHeight: '1.14'\n  };\n});\n\n// content is the same on any size scale\nvar content = (function () {\n  return {\n    fontSize: px2em(16),\n    lineHeight: '1.5'\n  };\n});\n\n// footnote is the same on any size scale\nvar footnote = (function () {\n  return {\n    fontSize: px2em(14),\n    lineHeight: '1.5'\n  };\n});\n\n// smallprint is the same on any size scale\nvar smallprint = (function () {\n  return {\n    fontSize: px2em(12),\n    lineHeight: '1.5'\n  };\n});\n\nvar _SizeMap$1;\nvar SizeMap$1 = (_SizeMap$1 = {}, _defineProperty(_SizeMap$1, TypographySizing.SMALL, 32), _defineProperty(_SizeMap$1, TypographySizing.MEDIUM, 36), _defineProperty(_SizeMap$1, TypographySizing.LARGE, 42), _SizeMap$1);\nvar headingXxl = (function () {\n  var _useTheme = useTheme(),\n      theme = _useTheme.theme;\n\n  var size = SizeMap$1[theme.typography.sizing] || 36;\n  return {\n    fontSize: px2em(size),\n    lineHeight: '1.2'\n  };\n});\n\nvar _SizeMap$2;\nvar SizeMap$2 = (_SizeMap$2 = {}, _defineProperty(_SizeMap$2, TypographySizing.SMALL, 28), _defineProperty(_SizeMap$2, TypographySizing.MEDIUM, 32), _defineProperty(_SizeMap$2, TypographySizing.LARGE, 36), _SizeMap$2);\nvar headingXl = (function () {\n  var _useTheme = useTheme(),\n      theme = _useTheme.theme;\n\n  var size = SizeMap$2[theme.typography.sizing] || 32;\n  return {\n    fontSize: px2em(size),\n    lineHeight: '1.2'\n  };\n});\n\nvar _SizeMap$3;\nvar SizeMap$3 = (_SizeMap$3 = {}, _defineProperty(_SizeMap$3, TypographySizing.SMALL, 24), _defineProperty(_SizeMap$3, TypographySizing.MEDIUM, 28), _defineProperty(_SizeMap$3, TypographySizing.LARGE, 32), _SizeMap$3);\n\nvar LineHeightMap = _defineProperty({}, TypographySizing.SMALL, '1.25');\n\nvar headingL = (function () {\n  var _useTheme = useTheme(),\n      theme = _useTheme.theme;\n\n  var size = SizeMap$3[theme.typography.sizing] || 28;\n  var height = LineHeightMap[theme.typography.sizing] || '1.2';\n  return {\n    fontSize: px2em(size),\n    lineHeight: height\n  };\n});\n\nvar _SizeMap$4, _LineHeightMap;\nvar SizeMap$4 = (_SizeMap$4 = {}, _defineProperty(_SizeMap$4, TypographySizing.SMALL, 21), _defineProperty(_SizeMap$4, TypographySizing.MEDIUM, 24), _defineProperty(_SizeMap$4, TypographySizing.LARGE, 28), _SizeMap$4);\nvar LineHeightMap$1 = (_LineHeightMap = {}, _defineProperty(_LineHeightMap, TypographySizing.SMALL, '1.3'), _defineProperty(_LineHeightMap, TypographySizing.MEDIUM, '1.25'), _defineProperty(_LineHeightMap, TypographySizing.LARGE, '1.2'), _LineHeightMap);\nvar headingM = (function () {\n  var _useTheme = useTheme(),\n      theme = _useTheme.theme;\n\n  var size = SizeMap$4[theme.typography.sizing] || 24;\n  var height = LineHeightMap$1[theme.typography.sizing] || '1.25';\n  return {\n    fontSize: px2em(size),\n    lineHeight: height\n  };\n});\n\nvar _SizeMap$5;\nvar SizeMap$5 = (_SizeMap$5 = {}, _defineProperty(_SizeMap$5, TypographySizing.SMALL, 18), _defineProperty(_SizeMap$5, TypographySizing.MEDIUM, 21), _defineProperty(_SizeMap$5, TypographySizing.LARGE, 24), _SizeMap$5);\n\nvar LineHeightMap$2 = _defineProperty({}, TypographySizing.LARGE, '1.25');\n\nvar headingS = (function () {\n  var _useTheme = useTheme(),\n      theme = _useTheme.theme;\n\n  var size = SizeMap$5[theme.typography.sizing] || 21;\n  var height = LineHeightMap$2[theme.typography.sizing] || '1.3';\n  return {\n    fontSize: px2em(size),\n    lineHeight: height\n  };\n});\n\nvar _SizeMap$6;\nvar SizeMap$6 = (_SizeMap$6 = {}, _defineProperty(_SizeMap$6, TypographySizing.SMALL, 16), _defineProperty(_SizeMap$6, TypographySizing.MEDIUM, 18), _defineProperty(_SizeMap$6, TypographySizing.LARGE, 21), _SizeMap$6);\n\nvar LineHeightMap$3 = _defineProperty({}, TypographySizing.SMALL, '1.5');\n\nvar headingXs = (function () {\n  var _useTheme = useTheme(),\n      theme = _useTheme.theme;\n\n  var size = SizeMap$6[theme.typography.sizing] || 18;\n  var height = LineHeightMap$3[theme.typography.sizing] || '1.3';\n  return {\n    fontSize: px2em(size),\n    lineHeight: height\n  };\n});\n\nvar _SizeMap$7;\nvar SizeMap$7 = (_SizeMap$7 = {}, _defineProperty(_SizeMap$7, TypographySizing.SMALL, 14), _defineProperty(_SizeMap$7, TypographySizing.MEDIUM, 16), _defineProperty(_SizeMap$7, TypographySizing.LARGE, 18), _SizeMap$7);\n\nvar LineHeightMap$4 = _defineProperty({}, TypographySizing.LARGE, '1.3');\n\nvar headingXxs = (function () {\n  var _useTheme = useTheme(),\n      theme = _useTheme.theme;\n\n  var size = SizeMap$7[theme.typography.sizing] || 16;\n  var height = LineHeightMap$4[theme.typography.sizing] || '1.5';\n  return {\n    fontSize: px2em(size),\n    lineHeight: height\n  };\n});\n\nexport { content, display, footnote, headingL, headingM, headingS, headingXl, headingXs, headingXxl, headingXxs, smallprint };\n","// @flow\nif (process.env.NODE_ENV === 'production') {\n  module.exports = require('./px2em.production.js');\n} else {\n  module.exports = require('./px2em.development.js');\n}\n","import px2EmSync from\"px2em-sync\";var px2em=function(m){return px2EmSync(m,{format:\"rem\",base:16})};export default px2em;export{px2em};\n","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _px2emSync = require('./px2emSync');\n\nvar _px2emSync2 = _interopRequireDefault(_px2emSync);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _px2emSync2.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _extends = Object.assign || 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; };\n\n//@flow\n\nvar px2EmSync = function px2EmSync(px, options) {\n  if (typeof px !== 'number') {\n    throw new TypeError('`px` should be a number');\n  }\n\n  var _base$format$options = _extends({\n    base: 16,\n    format: null\n  }, options),\n      base = _base$format$options.base,\n      format = _base$format$options.format;\n\n  if (typeof base !== 'number' || base < 0) {\n    throw new TypeError('`base` should be a number greater than zero');\n  }\n\n  var em = Math.round(px / base * 1000) / 1000;\n\n  if (format == null) {\n    return em;\n  }\n\n  return '' + em + format;\n};\n\nexports.default = px2EmSync;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _extends = Object.assign || 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; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _propTypes = require('prop-types');\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\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\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\nvar Equalizer = function (_Component) {\n  _inherits(Equalizer, _Component);\n\n  function Equalizer() {\n    _classCallCheck(this, Equalizer);\n\n    var _this = _possibleConstructorReturn(this, (Equalizer.__proto__ || Object.getPrototypeOf(Equalizer)).call(this));\n\n    _this.handleResize = debounce(_this.handleResize.bind(_this), 50);\n    _this.updateChildrenHeights = _this.updateChildrenHeights.bind(_this);\n    return _this;\n  }\n\n  _createClass(Equalizer, [{\n    key: 'componentDidMount',\n    value: function componentDidMount() {\n      this.handleResize();\n      addEventListener('resize', this.handleResize);\n    }\n  }, {\n    key: 'componentWillUnmount',\n    value: function componentWillUnmount() {\n      this.rootNode = null;\n      this.handleResize.clear();\n      removeEventListener('resize', this.handleResize);\n    }\n  }, {\n    key: 'componentDidUpdate',\n    value: function componentDidUpdate() {\n      this.handleResize();\n    }\n  }, {\n    key: 'handleResize',\n    value: function handleResize() {\n      setTimeout(this.updateChildrenHeights, 0);\n    }\n  }, {\n    key: 'updateChildrenHeights',\n    value: function updateChildrenHeights() {\n      var _props = this.props,\n          property = _props.property,\n          byRow = _props.byRow,\n          enabled = _props.enabled;\n\n      var node = this.rootNode;\n\n      if (!node || !enabled(this, node)) {\n        return;\n      }\n\n      if (node !== undefined) {\n        var children = this.props.nodes(this, node);\n        var heights = this.constructor.getHeights(children, byRow);\n\n        for (var row = 0; row < heights.length; row++) {\n          var max = heights[row][heights[row].length - 1];\n\n          for (var i = 0; i < heights[row].length - 1; i++) {\n            heights[row][i][0].style[property] = max + 'px';\n          }\n        }\n      }\n    }\n  }, {\n    key: 'render',\n    value: function render() {\n      var _this2 = this;\n\n      var _props2 = this.props,\n          children = _props2.children,\n          property = _props2.property,\n          byRow = _props2.byRow,\n          enabled = _props2.enabled,\n          nodes = _props2.nodes,\n          otherProps = _objectWithoutProperties(_props2, ['children', 'property', 'byRow', 'enabled', 'nodes']);\n\n      return _react2.default.createElement(\n        'div',\n        _extends({ ref: function ref(node) {\n            return _this2.rootNode = node;\n          }, onLoad: this.handleResize }, otherProps),\n        children\n      );\n    }\n  }], [{\n    key: 'getHeights',\n    value: function getHeights(nodes) {\n      var byRow = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n\n      var lastElTopOffset = 0,\n          groups = [],\n          row = 0;\n\n      groups[row] = [];\n\n      for (var i = 0; i < nodes.length; i++) {\n        var node = nodes[i];\n\n        node.style.height = 'auto';\n        node.style.maxHeight = '';\n        node.style.minHeight = '';\n\n        // http://ejohn.org/blog/getboundingclientrect-is-awesome/\n\n        var _node$getBoundingClie = node.getBoundingClientRect(),\n            elOffsetTop = _node$getBoundingClie.top,\n            elHeight = _node$getBoundingClie.height;\n\n        if (i === 0) {\n          lastElTopOffset = elOffsetTop;\n        }\n\n        if (elOffsetTop != lastElTopOffset && byRow) {\n          row++;\n          groups[row] = [];\n          lastElTopOffset = elOffsetTop;\n        }\n\n        groups[row].push([node, elHeight]);\n      }\n\n      for (var j = 0; j < groups.length; j++) {\n        var heights = groups[j].map(function (item) {\n          return item[1];\n        });\n        var max = Math.max.apply(null, heights);\n        groups[j].push(max);\n      }\n\n      return groups;\n    }\n  }]);\n\n  return Equalizer;\n}(_react.Component);\n\nexports.default = Equalizer;\n\n\nEqualizer.defaultProps = {\n  property: 'height',\n  byRow: true,\n  enabled: function enabled() {\n    return true;\n  },\n  nodes: function nodes(component, node) {\n    return node.children;\n  }\n};\n\nEqualizer.propTypes = {\n  children: _propTypes2.default.node.isRequired,\n  property: _propTypes2.default.string,\n  byRow: _propTypes2.default.bool,\n  enabled: _propTypes2.default.func,\n  nodes: _propTypes2.default.func\n};\n\n// from: https://github.com/component/debounce\nfunction debounce(func, wait, immediate) {\n  var timeout, args, context, timestamp, result;\n  if (null == wait) wait = 100;\n\n  function later() {\n    var last = Date.now() - timestamp;\n\n    if (last < wait && last >= 0) {\n      timeout = setTimeout(later, wait - last);\n    } else {\n      timeout = null;\n      if (!immediate) {\n        result = func.apply(context, args);\n        context = args = null;\n      }\n    }\n  }\n\n  var debounced = function debounced() {\n    context = this;\n    args = arguments;\n    timestamp = Date.now();\n    var callNow = immediate && !timeout;\n    if (!timeout) timeout = setTimeout(later, wait);\n    if (callNow) {\n      result = func.apply(context, args);\n      context = args = null;\n    }\n\n    return result;\n  };\n\n  debounced.clear = function () {\n    if (timeout) {\n      clearTimeout(timeout);\n      timeout = null;\n    }\n  };\n\n  return debounced;\n}","// from: https://github.com/component/debounce\n/* eslint-disable */\nexport default (func, wait, immediate) => {\n  var timeout, args, context, timestamp, result;\n  if (null == wait) wait = 100;\n\n  function later() {\n    var last = Date.now() - timestamp;\n\n    if (last < wait && last >= 0) {\n      timeout = setTimeout(later, wait - last);\n    } else {\n      timeout = null;\n      if (!immediate) {\n        result = func.apply(context, args);\n        context = args = null;\n      }\n    }\n  }\n\n  var debounced = function () {\n    context = this;\n    args = arguments;\n    timestamp = Date.now();\n    var callNow = immediate && !timeout;\n    if (!timeout) timeout = setTimeout(later, wait);\n    if (callNow) {\n      result = func.apply(context, args);\n      context = args = null;\n    }\n\n    return result;\n  };\n\n  debounced.clear = function () {\n    if (timeout) {\n      clearTimeout(timeout);\n      timeout = null;\n    }\n  };\n\n  return debounced;\n};\n","export const VisibleItems = {\n  XS: 1,\n  SM: 2,\n  MD: 3,\n  LG: 4,\n  XL: 6,\n};\n\nexport default null;\n","import { useStyles } from '@team-griffin/stylr';\nimport { cssTheme, gu2px, Theme } from '@uds/theme-utils';\nimport { css, cx } from 'linaria';\n\nconst pageNavControls = {\n  default: css`\n    margin-top: ${cssTheme.gu1};\n    &&& ${cssTheme.breakpoints.sm} {\n      margin-top: ${cssTheme.gu2};\n    }\n  `,\n  showNavigation: css`\n    display: flex;\n    width: 100%;\n    justify-content: space-between;\n    align-items: center;\n  `,\n};\nexport const getClassNames = ({ showNavigation }: { showNavigation: boolean }) => {\n  return {\n    pageNavControls: cx(pageNavControls.default, showNavigation && pageNavControls.showNavigation),\n  };\n};\nexport default ({ theme: { spacing } }: { theme: Theme }) => {\n  return useStyles(\n    {\n      default: {\n        root: {\n          position: 'relative',\n          overflow: 'hidden',\n        },\n        clickZone: {\n          position: 'absolute',\n          // arbitrary number high enough to fill the void off screen\n          width: '20%',\n          left: '100%',\n          top: 0,\n          bottom: 0,\n          // 4gu clickable target\n          marginLeft: 0 - gu2px(4, spacing),\n        },\n      },\n    },\n    {},\n  );\n};\n","import React from 'react';\nimport Glyph from '@uds/glyphs';\nimport { Colorway, gu2px, useTheme } from '@uds/theme-utils';\nimport cssSides, { Side } from '@team-griffin/css-sides';\nimport { useStyles } from '@team-griffin/stylr';\nimport { getBodyColor } from 'presentation/utils/colorway';\n\ninterface OuterProps {\n  colorway: Colorway;\n  onNavigationClick: (direction: string) => void;\n}\n\nconst useStylesheet = ({ colorway }: { colorway: Colorway }) => {\n  const {\n    theme,\n    theme: { palette, spacing },\n  } = useTheme();\n  return useStyles({\n    default: {\n      root: {\n        display: 'flex',\n        justifyContent: 'space-between',\n      },\n      button: {\n        backgroundColor: 'transparent',\n        color: palette.grey02,\n        outline: 0,\n        borderWidth: 0,\n        height: gu2px(6, spacing),\n        cursor: 'pointer',\n        ...cssSides('padding', Side.X, gu2px(3, spacing)),\n        ...cssSides('padding', Side.Y, 0),\n      },\n      icon: {\n        width: gu2px(3, spacing),\n        color: getBodyColor(theme, colorway),\n      },\n    },\n  });\n};\n\nconst PureSalesboardNavigation = ({ onNavigationClick, colorway }: OuterProps) => {\n  const { styles } = useStylesheet({\n    colorway,\n  });\n\n  const onButtonClick = (direction: string) => onNavigationClick(direction);\n\n  return (\n    <div style={styles.root}>\n      <button type=\"button\" style={styles.button} onClick={() => onButtonClick('prev')}>\n        <Glyph size={styles.icon.width as number} color={styles.icon.color as string} name=\"arrowLeft\" />\n      </button>\n      <button type=\"button\" style={styles.button} onClick={() => onButtonClick('next')}>\n        <Glyph size={styles.icon.width as number} color={styles.icon.color as string} name=\"arrowRight\" />\n      </button>\n    </div>\n  );\n};\n\nPureSalesboardNavigation.displayName = 'SalesboardNavigation';\n\nexport default PureSalesboardNavigation;\n","import React from 'react';\nimport { opacify } from '@ux/style-utils';\nimport { gu2px, Curvature, Colorway, useTheme } from '@uds/theme-utils';\nimport cssSides, { Side } from '@team-griffin/css-sides';\nimport { useStyles } from '@team-griffin/stylr';\n\ninterface OuterProps {\n  colorway: Colorway;\n  activeIndex: number;\n  index: number;\n  visibleItems: number;\n  role: string;\n}\n\nconst useStylesheet = ({ colorway, active }: { colorway: Colorway; active: boolean }) => {\n  const {\n    theme: { spacing, palette, curvature },\n  } = useTheme();\n  const getBorderRadius = (curvature: Curvature) => {\n    if (curvature === Curvature.WEAK) {\n      return 2;\n    }\n    if (curvature === Curvature.STRONG) {\n      return gu2px(2, spacing);\n    }\n    return 0;\n  };\n  return useStyles(\n    {\n      default: {\n        root: {\n          display: 'block',\n          height: gu2px(0.5, spacing),\n          width: gu2px(3, spacing),\n          ...cssSides('margin', Side.X, gu2px(0.5, spacing)),\n          backgroundColor: opacify(palette.grey06, 0.5),\n          transition: 'background-color 0.2s ease-in-out, height 0.2s ease-in-out',\n          borderRadius: getBorderRadius(curvature),\n        },\n      },\n      unsafeColorway: {\n        root: {\n          backgroundColor: opacify(palette.grey09, 0.5),\n        },\n      },\n      active: {\n        root: {\n          backgroundColor: palette.secondary,\n          height: gu2px(1, spacing),\n        },\n      },\n    },\n    [\n      {\n        unsafeColorway:\n          [Colorway.PRIMARY, Colorway.DARK, Colorway.PRIMARY_GRADIENT, Colorway.HIGHLIGHT].indexOf(colorway) > -1,\n      },\n      { active },\n    ],\n  );\n};\n\nconst PureSalesboardPaginationItem = ({ colorway, visibleItems, activeIndex, index }: OuterProps) => {\n  const visible = visibleItems - 1; // others are 0 indexed\n\n  // it's active if if it's the current index,\n  // or it's between the activeIndex and the visibleLimit added together\n  const active = index === activeIndex || (index >= activeIndex && index <= activeIndex + visible);\n\n  const { styles } = useStylesheet({\n    colorway,\n    active,\n  });\n  return <span style={styles.root} aria-hidden=\"true\" />;\n};\n\nPureSalesboardPaginationItem.displayName = 'SalesboardPaginationItem';\n\nexport default PureSalesboardPaginationItem;\n","import React from 'react';\nimport { gu2px, useTheme, Colorway } from '@uds/theme-utils';\nimport { useStyles } from '@team-griffin/stylr';\n\nimport PaginationItem from './PaginationItem';\n\ninterface OuterProps {\n  itemCount: number;\n  activeIndex: number;\n  colorway: Colorway;\n  visibleItems: number;\n}\n\nconst useStylesheet = () => {\n  const {\n    theme: { spacing },\n  } = useTheme();\n  return useStyles({\n    default: {\n      root: {\n        display: 'flex',\n        justifyContent: 'center',\n        alignItems: 'center',\n        height: gu2px(1, spacing),\n      },\n    },\n  });\n};\n\ndeclare const i: number;\n\nconst PureSalesboardPagination = ({ itemCount, activeIndex, visibleItems, colorway }: OuterProps) => {\n  const { styles } = useStylesheet();\n  return (\n    <div style={styles.root}>\n      <For each=\"item\" of={new Array(itemCount).fill(0)} index=\"i\">\n        <PaginationItem\n          colorway={colorway}\n          role=\"button\"\n          key={`item_${i}`}\n          activeIndex={activeIndex}\n          visibleItems={visibleItems}\n          index={i}\n        />\n      </For>\n    </div>\n  );\n};\n\nPureSalesboardPagination.displayName = 'SalesboardPagination';\n\nexport default PureSalesboardPagination;\n","import { useStyles } from '@team-griffin/stylr';\nimport { gu2px, useTheme, Colorway, cssTheme } from '@uds/theme-utils';\nimport { smallprint } from '@ux/type-size';\nimport cssSides, { Side } from '@team-griffin/css-sides';\nimport { getBodyColor } from 'presentation/utils/colorway';\nimport { useBreakpoints } from '@ux/responsive';\nimport { css, cx } from 'linaria';\n\nconst body = {\n  default: css`\n    display: flex;\n    flex-direction: column;\n    justify-content: space-between;\n    height: 100%;\n  `,\n  endorsed: {\n    grey: css`\n      border-bottom-color: ${cssTheme.palette.grey02};\n    `,\n    primary: css`\n      border-bottom-color: ${cssTheme.palette.primary};\n    `,\n  },\n};\nconst root = {\n  default: css`\n    background: transparent;\n    flex: 1;\n    flex-basis: auto;\n  `,\n  featured: css`\n    margin-top: ${cssTheme.gu4};\n  `,\n  endorsed: css`\n    margin-top: 0;\n  `,\n};\nexport const getClassNames = ({\n  isEndorsed,\n  hasFeaturedProduct,\n  colorway,\n}: {\n  isEndorsed: boolean;\n  hasFeaturedProduct?: boolean;\n  colorway: Colorway;\n}) => {\n  const endorsedColorway =\n    [Colorway.PRIMARY, Colorway.PRIMARY_GRADIENT, Colorway.HIGHLIGHT].indexOf(colorway) > -1 ? 'grey' : 'primary';\n  return {\n    root: cx(root.default, hasFeaturedProduct && root.featured, isEndorsed && root.endorsed),\n    body: cx(body.default, isEndorsed && body.endorsed[endorsedColorway]),\n  };\n};\n\nexport default ({ colorway }: { colorway: Colorway }) => {\n  const { isMinLg } = useBreakpoints();\n  const {\n    theme,\n    theme: { spacing },\n  } = useTheme();\n\n  return useStyles(\n    {\n      default: {\n        legalText: {\n          ...smallprint(),\n          ...cssSides('margin', Side.X, gu2px(3, spacing)),\n          marginTop: gu2px(1, spacing),\n          color: getBodyColor(theme, colorway),\n          opacity: 0.9,\n        },\n      },\n      isMinLg: {\n        legalText: {\n          ...cssSides('margin', Side.X, gu2px(4, spacing)),\n        },\n      },\n    },\n    [{ isMinLg }],\n  );\n};\n","import { useStyles } from '@team-griffin/stylr';\nimport cssSides, { Side } from '@team-griffin/css-sides';\nimport { Colorway, gu2px, useTheme, cssTheme } from '@uds/theme-utils';\nimport { css, cx } from 'linaria';\n\nconst root = {\n  default: css`\n    border-top-color: rgba(${cssTheme.palette.rgb.grey06}, 0.2);\n    border-top-style: solid;\n    border-top-width: calc(0.5 * ${cssTheme.gu1});\n  `,\n  grey: css`\n    border-top-color: ${cssTheme.palette.grey02};\n  `,\n  primary: css`\n    border-top-color: ${cssTheme.palette.primary};\n  `,\n};\nexport const getClassNames = ({ isEndorsed, colorway }: { isEndorsed: boolean; colorway: Colorway }) => {\n  const topBorderColor =\n    [Colorway.PRIMARY, Colorway.PRIMARY_GRADIENT, Colorway.HIGHLIGHT].indexOf(colorway) > -1 ? 'grey' : 'primary';\n  return {\n    root: cx(root.default, isEndorsed && root[topBorderColor]),\n    toggleBox: css`\n      position: relative;\n      // offset 3GU padding + 2GU item padding  + 1GU peak\n      top: calc(${cssTheme.gu6} * -1);\n      margin-bottom: calc(${cssTheme.gu6} * -1);\n      box-shadow: 0 calc(-0.5 * ${cssTheme.gu1}) 0 rgba(${cssTheme.palette.rgb.grey06}, 0.2);\n      &&& ${cssTheme.breakpoints.lg} {\n        // offset 4GU padding + 2GU item padding  + 1GU peak\n        top: calc(-7 * ${cssTheme.gu1});\n        margin-bottom: calc(-7 * ${cssTheme.gu1});\n      }\n    `,\n  };\n};\nexport default ({ toggleHeight, hasMoreFeatures }: { toggleHeight: string | number; hasMoreFeatures: boolean }) => {\n  const {\n    theme: { spacing, palette },\n  } = useTheme();\n  return useStyles(\n    {\n      default: {\n        list: {\n          ...cssSides('margin', Side.A, 0),\n          ...cssSides('padding', Side.A, 0),\n          listStyle: 'none',\n        },\n        toggle: {\n          borderWidth: 0,\n          display: 'block',\n          width: '100%',\n          cursor: 'pointer',\n          ...cssSides('padding', Side.X, 0),\n          ...cssSides('padding', Side.Y, gu2px(2, spacing)),\n          backgroundColor: '#fff',\n          color: palette.primary,\n          textAlign: 'center',\n          outline: 0,\n        },\n        toggleIcon: {\n          width: gu2px(3, spacing),\n          color: palette.primary,\n        },\n      },\n      toggleOpen: {\n        list: {\n          // compensate for negative margin of toggle box\n          marginBottom: gu2px(4, spacing),\n        },\n      },\n    },\n    [{ toggleOpen: toggleHeight === 'auto' && hasMoreFeatures }],\n  );\n};\n","import React from 'react';\nimport Shortcode, { ShortcodeProps } from 'components/Shortcode';\nimport { useTheme, Colorway } from '@uds/theme-utils';\n\nimport useStylesheet from './ItemFeature.stylesheet';\n\nexport type FeatureProps = {\n  text: ShortcodeProps | string;\n};\n\ninterface OuterProps {\n  feature: FeatureProps;\n  first?: boolean;\n  last?: boolean;\n}\n\nconst PureSalesboardItemFeature = ({ feature, first, last }: OuterProps) => {\n  const { theme } = useTheme();\n  const { styles } = useStylesheet({\n    theme,\n    first,\n    last,\n  });\n  return (\n    <li style={styles.root}>\n      <Shortcode code={feature.text} against={Colorway.LIGHT} />\n    </li>\n  );\n};\n\nPureSalesboardItemFeature.displayName = 'SalesboardItemFeature';\n\nexport default PureSalesboardItemFeature;\n","import { useStyles } from '@team-griffin/stylr';\nimport cssSides, { Side } from '@team-griffin/css-sides';\nimport { gu2px, Theme } from '@uds/theme-utils';\nimport { opacify } from '@ux/style-utils';\nimport longhand from '@team-griffin/css-longhand';\n\nexport default ({\n  theme: { spacing, palette },\n  first,\n  last,\n}: {\n  theme: Theme;\n  first: boolean | undefined;\n  last: boolean | undefined;\n}) =>\n  useStyles(\n    {\n      default: {\n        root: {\n          ...cssSides('padding', Side.Y, gu2px(2, spacing)),\n          ...cssSides('margin', Side.A, 0),\n          ...longhand('borderTop', {\n            style: 'solid',\n            width: 1,\n            color: opacify(palette.grey06, 0.2),\n          }),\n        },\n      },\n\n      first: {\n        root: {\n          paddingTop: 0,\n          borderTopWidth: 0,\n        },\n      },\n\n      last: {\n        root: {\n          paddingBottom: 0,\n        },\n      },\n    },\n    [{ first }, { last }],\n  );\n","import React from 'react';\nimport AnimateHeight from 'react-animate-height';\nimport PaddingBox, { Side } from '@uds/padding-box';\nimport Glyph, { IconName } from '@uds/glyphs';\nimport { isNilOrEmpty } from 'presentation/utils/generalUtils';\nimport { Colorway } from '@uds/theme-utils';\n\nimport useStylesheet, { getClassNames } from './ItemFeatures.stylesheet';\nimport ItemFeature, { FeatureProps } from './ItemFeature';\n\ninterface OuterProps {\n  colorway: Colorway;\n  features: Array<FeatureProps>;\n  visibleFeatureLimit: number;\n  maxFeatureLimit: number;\n  id: string;\n  index: number;\n  hasMoreFeatures: boolean;\n  showMoreFeatures: boolean;\n  isEndorsed: boolean;\n  onShowMoreClick: (evt: any) => void;\n}\n\nexport interface InnerProps extends OuterProps {\n  toggleHeight: string | number;\n  toggleIcon: 'string';\n}\n\nconst isLast = (index: number, arr: Array<any>) => index === arr.length - 1;\n// we have no hidden features, and item is last in array\nconst isLastVisibleItem = (f: boolean, v: Array<any>, i: number) => !f && isLast(i, v);\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\ndeclare const i: number;\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\ndeclare const feature: FeatureProps;\n\nconst PureSalesboardItemFeatures = ({\n  colorway,\n  hasMoreFeatures,\n  onShowMoreClick,\n  isEndorsed,\n  showMoreFeatures,\n  visibleFeatureLimit,\n  features,\n  maxFeatureLimit,\n  index,\n  id,\n}: OuterProps) => {\n  // pad the array so it is the same length as the longest product\n  const parsedFeatures = [...features];\n  const toAddNumber = maxFeatureLimit - features.length;\n  if (toAddNumber > 0) {\n    for (let i = 0; i < toAddNumber; i += 1) {\n      parsedFeatures.push({\n        text: '\\u2014',\n      });\n    }\n  }\n  // split into 2 arrays of visible items and hidden items\n  let splitFeatures = [parsedFeatures.slice(0, visibleFeatureLimit), parsedFeatures.slice(visibleFeatureLimit)];\n  if (isNilOrEmpty(visibleFeatureLimit)) {\n    splitFeatures = splitFeatures.reverse();\n  }\n  const visibleFeatures = splitFeatures[0].map((value, i) => ({\n    value,\n    index: `vf_${i}_${id}_${index}`,\n  }));\n  const moreFeatures = splitFeatures[1].map((value, i) => ({\n    value,\n    index: `mf${i}_${id}_${index}`,\n  }));\n  // if showMoreFeatures toggle has been activated,\n  // or we have a `null` visibleFeatureLimit\n  // we want to open up the animated height area\n  const openFeatures = showMoreFeatures || visibleFeatureLimit === null;\n\n  const { toggleHeight, toggleIcon } = (() => {\n    if (openFeatures) {\n      return {\n        toggleHeight: 'auto' as string | number,\n        toggleIcon: 'chevronUp' as IconName,\n      };\n    }\n    return {\n      toggleHeight: 0,\n      toggleIcon: 'chevronDown' as IconName,\n    };\n  })();\n\n  const { styles } = useStylesheet({\n    toggleHeight,\n    hasMoreFeatures,\n  });\n  const classNames = getClassNames({ isEndorsed, colorway });\n  return (\n    <>\n      <PaddingBox className={classNames.root}>\n        <ul style={styles.list}>\n          {visibleFeatures.map((feature, i) => (\n            <ItemFeature\n              key={feature.index}\n              feature={feature.value}\n              first={i === 0}\n              last={isLastVisibleItem(hasMoreFeatures, visibleFeatures, i)}\n            />\n          ))}\n          <AnimateHeight height={toggleHeight} duration={300}>\n            {moreFeatures.map((feature) => (\n              <ItemFeature key={feature.index} feature={feature.value} />\n            ))}\n          </AnimateHeight>\n        </ul>\n      </PaddingBox>\n      {hasMoreFeatures && (\n        <PaddingBox side={Side.X} className={classNames.toggleBox}>\n          <button type=\"button\" onClick={onShowMoreClick} style={styles.toggle}>\n            <Glyph\n              name={toggleIcon}\n              size={styles.toggleIcon.width as number}\n              color={styles.toggleIcon.color as string}\n            />\n          </button>\n        </PaddingBox>\n      )}\n    </>\n  );\n};\n\nPureSalesboardItemFeatures.displayName = 'SalesboardItemFeatures';\n\nexport default PureSalesboardItemFeatures;\n","import React from 'react';\nimport Message from '@uds/message';\nimport CallToAction from 'components/common/CallToAction';\nimport { Kind } from '@uds/button';\nimport ProductPrice from 'components/common/ProductPrice';\nimport { useBreakpoints } from '@ux/responsive';\nimport { CTA } from 'core/ribbons/cta';\nimport { Product } from '@uds/product';\nimport { PricingStrategy } from 'presentation/components/common/ProductPrice/constants';\nimport { isNilOrEmpty } from 'presentation/utils/generalUtils';\n\nimport useStylesheet from './ItemPrice.stylesheet';\n\ninterface OuterProps {\n  ctas?: Array<CTA>;\n  index: number;\n  id: string | number;\n  product: Product;\n  pricingStrategy: PricingStrategy;\n}\n\nconst PureSalesboardItemPrice = ({ ctas = [], product, pricingStrategy, id, index }: OuterProps) => {\n  const ctaProps = JSON.parse(JSON.stringify(ctas[0] || {}));\n  ctaProps.kind = Kind.PRIMARY;\n  const { isMinSm, isMinLg } = useBreakpoints();\n  const { styles } = useStylesheet({ isMinLg });\n  return (\n    <div>\n      <div style={styles.body}>\n        <ProductPrice product={product} pricingStrategy={pricingStrategy} showLegalCaveat={false} />\n      </div>\n      {!isNilOrEmpty(ctas[0]) && (\n        <div style={styles.cta}>\n          <CallToAction\n            product={product}\n            ribbonId={id as string}\n            index={index}\n            block={!isMinSm}\n            glyph=\"arrowRight\"\n            data-selector=\"salesboard-item-cta\"\n            label={<Message id=\"usf.salesboard.item.select\" />}\n            {...ctaProps}\n          />\n        </div>\n      )}\n    </div>\n  );\n};\n\nPureSalesboardItemPrice.displayName = 'SalesboardItemPrice';\n\nexport default PureSalesboardItemPrice;\n","import { useStyles } from '@team-griffin/stylr';\nimport { cssTheme } from '@uds/theme-utils';\n\nexport default ({ isMinLg }: { isMinLg: boolean }) =>\n  useStyles(\n    {\n      default: {\n        body: {\n          display: 'flex',\n          flexDirection: 'column',\n          justifyContent: 'center',\n        },\n        cta: {\n          marginTop: cssTheme.gu3,\n        },\n      },\n    },\n    [{ isMinLg }],\n  );\n","import React from 'react';\nimport { Heading03, BodyCopy } from '@uds/typography';\nimport { ShortcodeProps } from 'presentation/components/Shortcode';\n\nimport getClassNames from './ItemDetails.stylesheet';\n\ninterface OuterProps {\n  hBaseline: number;\n  title: ShortcodeProps | string;\n  text: ShortcodeProps | string;\n}\n\nconst PureSalesboardItemDetails = ({ hBaseline, title, text }: OuterProps) => {\n  const classNames = getClassNames();\n  return (\n    <div>\n      <Heading03 depth={hBaseline} className={classNames.title}>\n        <>{title}</>\n      </Heading03>\n      <BodyCopy className={classNames.text}>\n        <>{text}</>\n      </BodyCopy>\n    </div>\n  );\n};\n\nPureSalesboardItemDetails.displayName = 'SalesboardItemDetails';\n\nexport default PureSalesboardItemDetails;\n","import { cssTheme } from '@uds/theme-utils';\nimport { css } from 'linaria';\n\nexport default () => {\n  return {\n    title: css`\n      color: ${cssTheme.palette.grey02};\n    `,\n    text: css`\n      color: ${cssTheme.palette.grey04};\n    `,\n  };\n};\n","import React, { ComponentType, ReactNode } from 'react';\nimport { Colorway, useTheme } from '@uds/theme-utils';\nimport { useBreakpoints } from '@ux/responsive';\nimport { ImagesWithAspectRatios } from 'core/ribbons/primitives';\nimport { ImageAspectRatio } from 'domain/constants/imageAspectRatio';\nimport withLanguage from 'presentation/hocs/withLanguage';\nimport createImageAlt from 'presentation/utils/createImageAlt';\nimport urlLanguageParse from 'presentation/utils/urlLanguageParse';\nimport createImageUrl from 'presentation/utils/createImageUrl';\nimport getActiveImageWithAspectRatios from 'presentation/utils/getActiveImageWithAspectRatios';\nimport { isNilOrEmpty } from 'presentation/utils/generalUtils';\n\nimport useStylesheet from './ItemHeader.stylesheet';\n\ninterface OuterProps {\n  imageUrl: string | undefined;\n  imageAspectRatio?: ImageAspectRatio;\n  imagesWithAspectRatios?: ImagesWithAspectRatios;\n  illustration: string | undefined;\n  endorse: ReactNode;\n  isEndorsed: boolean;\n  colorway: Colorway;\n}\n\nexport interface InnerProps extends OuterProps {\n  currentLanguage: string;\n}\n\nconst PureSalesboardItemHeader = ({\n  endorse,\n  isEndorsed,\n  currentLanguage,\n  imageUrl,\n  illustration,\n  colorway,\n  imageAspectRatio,\n  imagesWithAspectRatios,\n}: InnerProps) => {\n  const { theme } = useTheme();\n  const breakpoints = useBreakpoints();\n  const activeImage = getActiveImageWithAspectRatios(\n    breakpoints,\n    {\n      imageUrl,\n      imageAspectRatio,\n    },\n    imagesWithAspectRatios,\n  );\n  const hasBanner = !isNilOrEmpty(activeImage.url) || !isNilOrEmpty(illustration);\n  const bannerUrl = createImageUrl(\n    {\n      illustration,\n      imageUrl: activeImage.url,\n    },\n    theme,\n    currentLanguage,\n  );\n  const { styles } = useStylesheet({\n    colorway,\n    imageAspectRatio: activeImage.imageAspectRatio,\n    theme,\n  });\n\n  return (\n    <div style={styles.root}>\n      {hasBanner && (\n        <div style={styles.bannerAspect}>\n          <img\n            loading=\"lazy\"\n            alt={createImageAlt({ imageUrl: bannerUrl })}\n            src={urlLanguageParse(bannerUrl, currentLanguage)}\n            style={styles.bannerImage}\n          />\n        </div>\n      )}\n      {isEndorsed && (\n        <div style={styles.endorse}>\n          <span style={styles.endorseText}>{endorse}</span>\n        </div>\n      )}\n    </div>\n  );\n};\n\nPureSalesboardItemHeader.displayName = 'SalesboardItemHeader';\n\nexport default withLanguage(PureSalesboardItemHeader) as ComponentType<OuterProps>;\n","import { useStyles } from '@team-griffin/stylr';\nimport cssSides, { Side } from '@team-griffin/css-sides';\nimport { headingXxs } from '@ux/type-size';\nimport { gu2px, Theme, Colorway } from '@uds/theme-utils';\nimport { modifier } from '@ux/style-utils';\nimport { imageAspectRatioPercentage } from 'presentation/utils/imageAspectRatioPercentage';\nimport { ImageAspectRatio } from 'domain/constants/imageAspectRatio';\nimport { useBreakpoints } from '@ux/responsive';\n\nexport default ({\n  colorway,\n  imageAspectRatio,\n  theme: { spacing, palette, typography },\n}: {\n  colorway: Colorway;\n  imageAspectRatio: ImageAspectRatio | undefined;\n  theme: Theme;\n}) => {\n  const { isMinLg } = useBreakpoints();\n\n  return useStyles(\n    {\n      default: {\n        root: {\n          position: 'relative',\n        },\n        illustration: {\n          width: gu2px(10, spacing),\n        },\n        endorse: {\n          backgroundColor: palette.primary,\n          color: palette.primaryContrast,\n          display: 'flex',\n          alignItems: 'center',\n          height: gu2px(4, spacing),\n          maxHeight: gu2px(4, spacing),\n          position: 'relative',\n          ...cssSides('padding', Side.Y, gu2px(1, spacing)),\n        },\n        endorseText: {\n          ...headingXxs(),\n          ...cssSides('padding', Side.X, gu2px(3, spacing)),\n          position: 'absolute',\n          textOverflow: 'ellipsis',\n          overflow: 'hidden',\n          whiteSpace: 'nowrap',\n          left: 0,\n          right: 0,\n          lineHeight: 1, // to keep it centered\n          fontFamily: typography.display,\n        },\n        bannerAspect: {\n          display: 'flex',\n          justifyContent: 'flex-content',\n          position: 'relative',\n          width: '100%',\n          height: 0,\n          padding: 0,\n          overflow: 'hidden',\n          paddingTop: imageAspectRatioPercentage(imageAspectRatio),\n          backgroundColor: palette.grey12,\n        },\n        bannerImage: {\n          position: 'absolute',\n          minHeight: '100%',\n          minWidth: '100%',\n          top: '50%',\n          transform: 'translateY(-50%)',\n          width: '100%',\n        },\n      },\n\n      isMinLg: {\n        endorseText: {\n          ...cssSides('padding', Side.X, gu2px(4, spacing)),\n        },\n      },\n\n      [modifier('colorway', Colorway.PRIMARY)]: {\n        endorse: {\n          backgroundColor: palette.grey02,\n          color: '#fff',\n        },\n      },\n\n      [modifier('colorway', Colorway.PRIMARY_GRADIENT)]: {\n        endorse: {\n          backgroundColor: palette.grey02,\n          color: '#fff',\n        },\n      },\n\n      [modifier('colorway', Colorway.HIGHLIGHT)]: {\n        endorse: {\n          backgroundColor: palette.grey02,\n          color: '#fff',\n        },\n      },\n    },\n    [{ isMinLg }, { colorway }, { imageAspectRatio }],\n  );\n};\n","import React, { ReactNode } from 'react';\nimport { Panel } from '@uds/panel';\nimport PaddingBox from '@uds/padding-box';\nimport { Product, selectors as prodSelectors } from '@uds/product';\nimport { Colorway as ColorwayType } from '@uds/theme-utils';\nimport Colorway from '@uds/colorway';\nimport { LegalText } from 'components/common/ProductPrice';\nimport { CTA } from 'core/ribbons/cta';\nimport { ImagesWithAspectRatios } from 'core/ribbons/primitives';\nimport { ImageAspectRatio } from 'domain/constants/imageAspectRatio';\nimport { PricingStrategy } from 'presentation/components/common/ProductPrice/constants';\n\nimport { FeatureProps } from './ItemFeature';\nimport useStylesheet, { getClassNames } from './Item.stylesheet';\nimport Features from './ItemFeatures';\nimport Price from './ItemPrice';\nimport Details from './ItemDetails';\nimport Header from './ItemHeader';\n\nexport type ProductDetailsType = {\n  tagline: string;\n  productName: string;\n};\n\ninterface OuterProps {\n  colorway: ColorwayType;\n  product?: Product;\n  features: Array<FeatureProps>;\n  hBaseline: number;\n  illustration?: string;\n  imageUrl?: string;\n  imageAspectRatio?: ImageAspectRatio;\n  imagesWithAspectRatios?: ImagesWithAspectRatios;\n  ctas: Array<CTA>;\n  pricingStrategy: PricingStrategy;\n  endorse: ReactNode;\n  productId: string;\n  index: number;\n  id: string;\n  visibleFeatureLimit: number;\n  maxFeatureLimit: number;\n  hasMoreFeatures: boolean;\n  showMoreFeatures: boolean;\n  onShowMoreClick: (evt: any) => void;\n  descRef: any;\n  hasFeaturedProduct?: boolean;\n  text?: ProductDetailsType;\n}\n\nconst PureSalesboardItem = ({\n  colorway,\n  features,\n  endorse,\n  hBaseline,\n  illustration,\n  imageUrl,\n  imageAspectRatio,\n  imagesWithAspectRatios,\n  product = {} as Product,\n  ctas,\n  pricingStrategy,\n  productId,\n  visibleFeatureLimit,\n  maxFeatureLimit,\n  hasMoreFeatures,\n  showMoreFeatures,\n  descRef,\n  id,\n  index,\n  onShowMoreClick,\n  hasFeaturedProduct,\n  text,\n}: OuterProps) => {\n  const name = text?.productName ?? prodSelectors.getName({ product });\n  const tagline = text?.tagline ?? prodSelectors.getTagline({ product });\n\n  const isEndorsed = Boolean(endorse);\n  const { styles } = useStylesheet({\n    colorway,\n  });\n  const borderless = [ColorwayType.LIGHT, ColorwayType.NEUTRAL].indexOf(colorway) === -1;\n  const classNames = getClassNames({\n    colorway,\n    hasFeaturedProduct,\n    isEndorsed,\n  });\n  return (\n    <div data-selector=\"salesboard-item\" data-value={productId}>\n      <Panel border={!borderless} className={classNames.root}>\n        <Header\n          colorway={colorway}\n          illustration={illustration}\n          imageUrl={imageUrl}\n          imageAspectRatio={imageAspectRatio}\n          imagesWithAspectRatios={imagesWithAspectRatios}\n          isEndorsed={isEndorsed}\n          endorse={endorse}\n        />\n        <Colorway colorway={ColorwayType.LIGHT}>\n          <div ref={descRef}>\n            <PaddingBox className={classNames.body}>\n              <Details hBaseline={hBaseline} title={name} text={tagline} />\n              <Price ctas={ctas} id={id} index={index} product={product} pricingStrategy={pricingStrategy} />\n            </PaddingBox>\n          </div>\n          <Features\n            colorway={colorway}\n            isEndorsed={isEndorsed}\n            features={features}\n            onShowMoreClick={onShowMoreClick}\n            showMoreFeatures={showMoreFeatures}\n            hasMoreFeatures={hasMoreFeatures}\n            visibleFeatureLimit={visibleFeatureLimit}\n            maxFeatureLimit={maxFeatureLimit}\n            id={id}\n            index={index}\n          />\n        </Colorway>\n      </Panel>\n      <div style={styles.legalText}>\n        <LegalText product={product} pricingStrategy={pricingStrategy} />\n      </div>\n    </div>\n  );\n};\n\nPureSalesboardItem.displayName = 'SalesboardItem';\n\nexport default PureSalesboardItem;\n","import { BreakpointProps } from '@ux/responsive';\n\nimport { VisibleItems } from './constants';\nimport { SalesboardProductType } from './Salesboard';\n\nexport const getFeaturesLengths = (products: Array<SalesboardProductType>) => {\n  const featureLengthArray = [] as Array<number>;\n  products.forEach((product) => {\n    featureLengthArray.push(product.features?.length ?? 0);\n  });\n  return featureLengthArray;\n};\n\nexport const getMaxFeatureLimit = (products: Array<SalesboardProductType>) => {\n  const featureLengthArray = getFeaturesLengths(products);\n  return Math.max(...featureLengthArray);\n};\n\nexport const getVisibleItems = (breakpoints: BreakpointProps) => {\n  const { isMinSm, isMinMd, isMinLg, isMinXl } = breakpoints;\n  if (isMinXl) {\n    return VisibleItems.XL;\n  }\n  if (isMinLg) {\n    return VisibleItems.LG;\n  }\n  if (isMinMd) {\n    return VisibleItems.MD;\n  }\n  if (isMinSm) {\n    return VisibleItems.SM;\n  }\n  return VisibleItems.XS;\n};\n","import React, { useRef, useState, useEffect, ComponentType, useCallback } from 'react';\nimport Ribbon from 'components/ribbons/Ribbon';\nimport PaddingBox from '@uds/padding-box';\nimport Slider from '@uds/slider';\nimport { Container } from '@uds/grid';\nimport Equalizer from 'react-equalizer';\nimport { useBreakpoints } from '@uds/responsive';\nimport findResponsiveItem from 'presentation/utils/findResponsiveItem';\nimport errorBoundary from 'presentation/hocs/errorBoundary';\nimport visibilitySet from 'presentation/hocs/visibilitySet';\nimport debounce from 'presentation/utils/debounce';\nimport isTouchDevice from 'presentation/utils/isTouchDevice';\nimport { useTheme } from '@uds/theme-utils';\nimport { RibbonProps, Type } from 'domain/constants/ribbons';\nimport { Product, selectors as productSelectors } from '@uds/product';\nimport { CTA } from 'core/ribbons/cta';\nimport { PricingStrategy } from 'presentation/components/common/ProductPrice/constants';\nimport { dispatchGA4Event } from 'infrastructure/ga4';\nimport { useCurrency } from '@ux/currency';\nimport { useBrandId } from '@ux/whitelabel';\n\nimport { FeatureProps } from './ItemFeature';\nimport { VisibleItems } from './constants';\nimport useStylesheet, { getClassNames } from './Salesboard.stylesheet';\nimport Navigation from './Navigation';\nimport Pagination from './Pagination';\nimport Item, { ProductDetailsType } from './Item';\nimport { getMaxFeatureLimit, getVisibleItems } from './utils';\n\nexport type SalesboardProductType = {\n  action?: string;\n  ctas: Array<CTA>;\n  endorse: boolean;\n  features: Array<FeatureProps>;\n  illustration?: string;\n  imageUrl?: string;\n  pricingStrategy: PricingStrategy;\n  product: Product;\n  productId: string;\n  text?: ProductDetailsType;\n};\n\ninterface OuterProps extends RibbonProps {\n  initialScrollOffset?: number;\n  products?: Array<SalesboardProductType>;\n  hBaseline?: number;\n  visibleFeatureLimit: number;\n}\n\nconst PureSalesboard = ({\n  layout,\n  name,\n  products = [],\n  colorway,\n  loading,\n  hBaseline = 1,\n  id,\n  visibleFeatureLimit,\n  initialScrollOffset = 0,\n  visible\n}: OuterProps) => {\n  const { theme } = useTheme();\n  const breakpoints = useBreakpoints();\n\n  const visibleItems = getVisibleItems(breakpoints);\n  const [activeIndex, setActiveIndex] = useState(initialScrollOffset);\n  const [showMoreFeatures, setShowMoreFeatures] = useState(false);\n  const onShowMoreClick = () => setShowMoreFeatures(!showMoreFeatures);\n\n  // we have more items than fit on the screen\n  const showPagination = products.length > visibleItems;\n  // only show arrow nav if we're not a touch device\n  const showNavigation = !isTouchDevice() && showPagination;\n\n  const [scroller, scrollerRef]: [any, any] = useState(null);\n\n  const onScroll = debounce(() => {\n    // run the active index setter via scroll\n    const arrayedCollection = Array(...scroller.children).map((el) => el.getBoundingClientRect().left);\n    const currentVisible = arrayedCollection.findIndex((value) => value >= 0 && value < 1000);\n    if (currentVisible > -1) {\n      setActiveIndex(currentVisible);\n    }\n  }, 100);\n  // take an index and scroll to that node, used for desktop/button nav\n  const scrollToNode = useCallback(\n    (idx: number) => {\n      if (!scroller || !scroller.scrollTo || !scroller.children) {\n        return;\n      }\n\n      // check index is with bounds\n      const index = idx < 0 ? 0 : Math.min(idx, products.length - visibleItems);\n\n      const node = scroller.children[index];\n\n      if (!node) {\n        return;\n      }\n\n      const offset = node.getBoundingClientRect();\n\n      scroller.scrollTo({\n        left: offset.width * index,\n        top: offset.top,\n        behavior: 'smooth',\n      });\n      setActiveIndex(index);\n    },\n    [products.length, scroller, visibleItems],\n  );\n\n  const nodes = (() => {\n    const nodes = [];\n    for (let i = 0; i < 12; i += 1) {\n      // TODO: This should mostly likely be refactored, but not in the scope of upgrading eslint-config.\n      // This seems to work, so not changing now.\n      // eslint-disable-next-line react-hooks/rules-of-hooks\n      nodes.push(useRef());\n    }\n    return nodes;\n  })();\n  const getNodes = () => {\n    const parsedNodes = [] as Array<any>;\n    nodes.forEach((node) => {\n      if (node.current) {\n        parsedNodes.push(node.current);\n      }\n    });\n    return parsedNodes;\n  };\n\n  const onNavigationClick = (direction: string) => {\n    if (direction === 'next') {\n      scrollToNode(activeIndex + 1);\n    }\n\n    if (direction === 'prev') {\n      scrollToNode(activeIndex - 1);\n    }\n  };\n\n  const { styles } = useStylesheet({\n    theme,\n  });\n\n  const maxFeatureLimit = getMaxFeatureLimit(products);\n\n  const activeVisibleFeatureLimit = findResponsiveItem(breakpoints, visibleFeatureLimit, {\n    supportNull: true,\n  });\n\n  const hasMoreFeatures = activeVisibleFeatureLimit !== null && activeVisibleFeatureLimit < maxFeatureLimit;\n\n  let hasFeaturedProduct = false;\n  let i = 0;\n  const productsLength = products.length;\n\n  while (hasFeaturedProduct === false && i < productsLength) {\n    if (products[i].endorse) {\n      hasFeaturedProduct = true;\n    }\n    i += 1;\n  }\n  // on first load, scroll to the correct node\n  useEffect(() => {\n    scrollToNode(initialScrollOffset);\n  }, [scroller, scrollToNode, initialScrollOffset]);\n\n  const classNames = getClassNames({\n    showNavigation,\n  });\n\n  // Send GA4 ecommerce data\n  const currency = useCurrency();\n  const brandId = useBrandId();\n  useEffect(() => {\n    if (visible) {\n      const items = products.map((salesboardProduct) => {\n        const behavior = salesboardProduct.ctas?.[0]?.behavior;\n        const term = behavior != null && 'pricingTier' in behavior ? behavior.pricingTier?.term : undefined;\n        const skuId = behavior != null && 'productId' in behavior ? behavior.productId : undefined;\n        const product = salesboardProduct.product;\n        const itemId = product?.defaultSkuId ?? Number(skuId);\n        const itemPrice = product == null ? undefined : productSelectors.getPrice({\n          product,\n          includeTax: true,\n        });\n\n        return {\n          'item_name': product?.name,\n          'item_id': itemId,\n          'item_group_id': itemId,\n          'item_brand': brandId,\n          'item_category': product?.categoryName,\n          'item_variant': `${product?.name} ${term ?? product?.defaultPrice?.term}`,\n          'currency': currency,\n          'price': itemPrice,\n          'quantity': 1,\n        }\n      });\n      dispatchGA4Event('view_item', { items});\n    }\n  }, [visible, products, currency, brandId]);\n\n  return (\n    <Ribbon id={id} layout={layout} name={name} colorway={colorway} loading={loading} type={Type.SALESBOARD}>\n      <div style={styles.root}>\n        <Container fluid={showPagination}>\n          <Equalizer byRow={false} nodes={() => getNodes()}>\n            <Slider\n              ref={scrollerRef}\n              onScroll={onScroll}\n              visibleItems={Object.values(VisibleItems)}\n              customScrollSnap=\"start\"\n            >\n              {products.map((item, i) => (\n                <Item\n                  key={`salesboard_item_${id}`.concat(String(i))}\n                  id={id}\n                  index={i}\n                  descRef={nodes[i]}\n                  hasFeaturedProduct={hasFeaturedProduct}\n                  colorway={colorway}\n                  hBaseline={hBaseline}\n                  onShowMoreClick={onShowMoreClick}\n                  showMoreFeatures={showMoreFeatures}\n                  hasMoreFeatures={hasMoreFeatures}\n                  maxFeatureLimit={maxFeatureLimit}\n                  visibleFeatureLimit={activeVisibleFeatureLimit}\n                  {...item}\n                />\n              ))}\n            </Slider>\n          </Equalizer>\n        </Container>\n        <Container>\n          {showPagination && (\n            <div style={styles.clickZone} role=\"button\" aria-hidden=\"true\" onClick={() => onNavigationClick('next')} />\n          )}\n          {(showPagination || showNavigation) && (\n            <PaddingBox className={classNames.pageNavControls}>\n              {showPagination && (\n                <Pagination\n                  colorway={colorway}\n                  visibleItems={visibleItems}\n                  activeIndex={activeIndex}\n                  itemCount={products.length}\n                />\n              )}\n              {showNavigation && <Navigation colorway={colorway} onNavigationClick={onNavigationClick} />}\n            </PaddingBox>\n          )}\n        </Container>\n      </div>\n    </Ribbon>\n  );\n};\n\nPureSalesboard.displayName = 'Salesboard';\n\nexport default errorBoundary(visibilitySet(PureSalesboard)) as ComponentType<OuterProps>;\n","export default () => {\n  const prefixes = ' -webkit- -moz- -o- -ms- '.split(' ');\n  const mq = (query) => {\n    return window.matchMedia(query).matches;\n  };\n\n  if ('ontouchstart' in window || (window.DocumentTouch && document instanceof window.DocumentTouch)) {\n    return true;\n  }\n\n  // include the 'heartz' as a way to have a non matching MQ to help terminate the join\n  // https://git.io/vznFH\n  const query = ['(', prefixes.join('touch-enabled),('), 'heartz', ')'].join('');\n  return mq(query);\n};\n","import Salesboard from './Salesboard';\n\nexport default Salesboard;\n"],"sourceRoot":""}