{"version":3,"file":"68fc1adff6e257aaf151c4be85b7bd3e8460edf7-5663c4a30c80d584e630.js","mappings":"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","sources":["webpack://shadepro-gatsby/./node_modules/react-bootstrap/esm/createChainedFunction.js","webpack://shadepro-gatsby/./src/components/Brands/index.js","webpack://shadepro-gatsby/./src/components/Brands/images/similarweb.png","webpack://shadepro-gatsby/./src/components/Brands/images/autodesk.png","webpack://shadepro-gatsby/./src/components/Brands/images/saleforce.png","webpack://shadepro-gatsby/./src/components/Brands/images/dhl.png","webpack://shadepro-gatsby/./src/components/Brands/images/cisco.png","webpack://shadepro-gatsby/./src/components/Brands/images/broadcom.png","webpack://shadepro-gatsby/./src/components/Brands/images/uber.png","webpack://shadepro-gatsby/./src/components/Brands/images/wsj.png","webpack://shadepro-gatsby/./node_modules/react-bootstrap/esm/Collapse.js","webpack://shadepro-gatsby/./src/components/FAQ.js"],"sourcesContent":["/**\n * Safe chained function\n *\n * Will only create a new function if needed,\n * otherwise will pass back existing functions or null.\n *\n * @param {function} functions to chain\n * @returns {function|null}\n */\nfunction createChainedFunction() {\n for (var _len = arguments.length, funcs = new Array(_len), _key = 0; _key < _len; _key++) {\n funcs[_key] = arguments[_key];\n }\n\n return funcs.filter(function (f) {\n return f != null;\n }).reduce(function (acc, f) {\n if (typeof f !== 'function') {\n throw new Error('Invalid Argument Type, must only provide functions, undefined, or null.');\n }\n\n if (acc === null) return f;\n return function chainedFunction() {\n for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n args[_key2] = arguments[_key2];\n } // @ts-ignore\n\n\n acc.apply(this, args); // @ts-ignore\n\n f.apply(this, args);\n };\n }, null);\n}\n\nexport default createChainedFunction;","import React from 'react';\nimport { useTranslation } from 'react-i18next';\nimport ContentSection from '../ContentSection';\n\nimport similarwebImage from './images/similarweb.png';\nimport autodeskImage from './images/autodesk.png';\nimport salesforceImage from './images/saleforce.png';\nimport dhlImage from './images/dhl.png';\nimport ciscoImage from './images/cisco.png';\nimport broadcomImage from './images/broadcom.png';\nimport uberImage from './images/uber.png';\nimport wsjImage from './images/wsj.png';\n\nimport './styles.css';\n\nconst brands = [\n { src: similarwebImage, alt: 'SimilarWeb', width: 111, height: 16 },\n { src: autodeskImage, alt: 'Autodesk', width: 111, height: 19 },\n { src: salesforceImage, alt: 'Salesforce', width: 111, height: 78 },\n { src: dhlImage, alt: 'DHL', width: 111, height: 19 },\n { src: ciscoImage, alt: 'Cisco', width: 111, height: 58 },\n { src: broadcomImage, alt: 'Broadcom', width: 111, height: 54 },\n { src: uberImage, alt: 'Uber', width: 111, height: 37 },\n { src: wsjImage, alt: 'WSJ', width: 111, height: 37 },\n];\n\nfunction Brands(props) {\n const { t } = useTranslation();\n const {\n title = t('SpySerpBrands.title'),\n description = t('SpySerpBrands.description'),\n noDescription,\n } = props;\n\n return (\n \n
\n {brands.map(({ src, alt, width, height }) => (\n
\n {alt}\n
\n ))}\n
\n \n );\n}\n\nexport default Brands;\n","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nvar _excluded = [\"onEnter\", \"onEntering\", \"onEntered\", \"onExit\", \"onExiting\", \"className\", \"children\", \"dimension\", \"getDimensionValue\"];\n\nvar _collapseStyles;\n\nimport classNames from 'classnames';\nimport css from 'dom-helpers/css';\nimport React, { useMemo } from 'react';\nimport Transition, { ENTERED, ENTERING, EXITED, EXITING } from 'react-transition-group/Transition';\nimport transitionEndListener from './transitionEndListener';\nimport createChainedFunction from './createChainedFunction';\nimport triggerBrowserReflow from './triggerBrowserReflow';\nvar MARGINS = {\n height: ['marginTop', 'marginBottom'],\n width: ['marginLeft', 'marginRight']\n};\n\nfunction getDefaultDimensionValue(dimension, elem) {\n var offset = \"offset\" + dimension[0].toUpperCase() + dimension.slice(1);\n var value = elem[offset];\n var margins = MARGINS[dimension];\n return value + // @ts-ignore\n parseInt(css(elem, margins[0]), 10) + // @ts-ignore\n parseInt(css(elem, margins[1]), 10);\n}\n\nvar collapseStyles = (_collapseStyles = {}, _collapseStyles[EXITED] = 'collapse', _collapseStyles[EXITING] = 'collapsing', _collapseStyles[ENTERING] = 'collapsing', _collapseStyles[ENTERED] = 'collapse show', _collapseStyles);\nvar defaultProps = {\n in: false,\n timeout: 300,\n mountOnEnter: false,\n unmountOnExit: false,\n appear: false,\n getDimensionValue: getDefaultDimensionValue\n};\nvar Collapse = /*#__PURE__*/React.forwardRef(function (_ref, ref) {\n var onEnter = _ref.onEnter,\n onEntering = _ref.onEntering,\n onEntered = _ref.onEntered,\n onExit = _ref.onExit,\n onExiting = _ref.onExiting,\n className = _ref.className,\n children = _ref.children,\n _ref$dimension = _ref.dimension,\n dimension = _ref$dimension === void 0 ? 'height' : _ref$dimension,\n _ref$getDimensionValu = _ref.getDimensionValue,\n getDimensionValue = _ref$getDimensionValu === void 0 ? getDefaultDimensionValue : _ref$getDimensionValu,\n props = _objectWithoutPropertiesLoose(_ref, _excluded);\n /* Compute dimension */\n\n\n var computedDimension = typeof dimension === 'function' ? dimension() : dimension;\n /* -- Expanding -- */\n\n var handleEnter = useMemo(function () {\n return createChainedFunction(function (elem) {\n elem.style[computedDimension] = '0';\n }, onEnter);\n }, [computedDimension, onEnter]);\n var handleEntering = useMemo(function () {\n return createChainedFunction(function (elem) {\n var scroll = \"scroll\" + computedDimension[0].toUpperCase() + computedDimension.slice(1);\n elem.style[computedDimension] = elem[scroll] + \"px\";\n }, onEntering);\n }, [computedDimension, onEntering]);\n var handleEntered = useMemo(function () {\n return createChainedFunction(function (elem) {\n elem.style[computedDimension] = null;\n }, onEntered);\n }, [computedDimension, onEntered]);\n /* -- Collapsing -- */\n\n var handleExit = useMemo(function () {\n return createChainedFunction(function (elem) {\n elem.style[computedDimension] = getDimensionValue(computedDimension, elem) + \"px\";\n triggerBrowserReflow(elem);\n }, onExit);\n }, [onExit, getDimensionValue, computedDimension]);\n var handleExiting = useMemo(function () {\n return createChainedFunction(function (elem) {\n elem.style[computedDimension] = null;\n }, onExiting);\n }, [computedDimension, onExiting]);\n return /*#__PURE__*/React.createElement(Transition // @ts-ignore\n , _extends({\n ref: ref,\n addEndListener: transitionEndListener\n }, props, {\n \"aria-expanded\": props.role ? props.in : null,\n onEnter: handleEnter,\n onEntering: handleEntering,\n onEntered: handleEntered,\n onExit: handleExit,\n onExiting: handleExiting\n }), function (state, innerProps) {\n return /*#__PURE__*/React.cloneElement(children, _extends({}, innerProps, {\n className: classNames(className, children.props.className, collapseStyles[state], computedDimension === 'width' && 'width')\n }));\n });\n}); // @ts-ignore\n// @ts-ignore\n\nCollapse.defaultProps = defaultProps;\nexport default Collapse;","import React, { useState } from 'react';\nimport PropTypes from 'prop-types';\nimport { useTranslation } from 'react-i18next';\nimport { Helmet } from 'react-helmet-async';\nimport { Col, Collapse, Row } from 'react-bootstrap';\n\nfunction FAQ(props) {\n const [openItem, setOpenItem] = useState(0);\n const { t } = useTranslation();\n const title = props.title || t('FAQ.title');\n const { items } = props;\n\n return (\n <>\n \n\n
\n

{title}

\n
\n\n \n \n
\n {items.map((item, index) => (\n \n \n \n setOpenItem(openItem === index ? null : index)\n }\n >\n {item.question}\n \n
\n\n \n \n \n {item.answer}\n \n \n \n \n ))}\n \n \n
\n \n );\n}\n\nexport default FAQ;\n\nFAQ.propTypes = {\n title: PropTypes.string,\n items: PropTypes.arrayOf(\n PropTypes.shape({\n question: PropTypes.string.isRequired,\n answer: PropTypes.string.isRequired,\n })\n ).isRequired,\n};\n"],"names":["_len","arguments","length","funcs","Array","_key","filter","f","reduce","acc","Error","_len2","args","_key2","apply","this","brands","src","alt","width","height","props","t","useTranslation","title","description","noDescription","ContentSection","className","map","key","_collapseStyles","_excluded","MARGINS","getDefaultDimensionValue","dimension","elem","value","toUpperCase","slice","margins","parseInt","css","collapseStyles","defaultProps","in","timeout","mountOnEnter","unmountOnExit","appear","getDimensionValue","Collapse","_ref","ref","onEnter","onEntering","onEntered","onExit","onExiting","children","_ref$dimension","_ref$getDimensionValu","computedDimension","handleEnter","useMemo","createChainedFunction","style","handleEntering","scroll","handleEntered","handleExit","triggerBrowserReflow","handleExiting","Transition","addEndListener","transitionEndListener","role","state","innerProps","useState","openItem","setOpenItem","items","Helmet","htmlAttributes","itemScope","itemType","Row","Col","xl","lg","item","index","itemProp","id","onClick","question","answer"],"sourceRoot":""}