{"version":3,"file":"facet-e0a59354.js","sources":["../../../../src/scripts/coveo/components/facet-breadcrumbs.tsx","../../../../src/scripts/coveo/components/facet.tsx"],"sourcesContent":["import React, { useEffect, useState, useContext } from 'react';\nimport {\n facetBreadcrumb,\n facetLabelsProps,\n facetsLabels\n} from '../controllers/controller';\nimport {\n BreadcrumbManager,\n BreadcrumbValue,\n FacetBreadcrumb,\n FacetValue,\n NumericFacetBreadcrumb,\n NumericFacetValue,\n CategoryFacetBreadcrumb\n} from '@coveo/headless';\nimport Clear from './clear';\nimport SecondCall from './second-call-context';\nimport { createDataLayerString } from '../../helpers/helpers';\ntype FacetBreadcrumbsProps = {\n extraClasses?: string;\n clearLabel: string;\n};\n\nfunction FacetBreadcrumbs({ extraClasses, clearLabel }: FacetBreadcrumbsProps) {\n const [state, setState] = useState(\n (facetBreadcrumb as BreadcrumbManager).state\n );\n const secondCallContext = useContext(SecondCall);\n\n useEffect(() => {\n (facetBreadcrumb as BreadcrumbManager).subscribe(() =>\n setState((facetBreadcrumb as BreadcrumbManager).state)\n );\n }, []);\n\n const handleFacetClick = (breadcrumb: CategoryFacetBreadcrumb) => {\n if (breadcrumb.path.length > 1) {\n window.dispatchEvent(\n new CustomEvent('deselectFacetTree', {\n detail: {\n value: breadcrumb.path[breadcrumb.path.length - 2]\n }\n })\n );\n } else {\n breadcrumb.deselect();\n }\n };\n\n const renderCategoryFacetBreadcrumbs = (\n breadcrumbs: CategoryFacetBreadcrumb[]\n ) => {\n return (\n <>\n {breadcrumbs.map(breadcrumb =>\n breadcrumb.path.map((facet, index) => {\n return (\n