{"version":3,"file":"component---src-v-3-templates-search-results-search-results-tsx-dcaa391bb10058f690bc.js","mappings":"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","sources":["webpack://keolis.com/./src/v3/templates/search-results/search-results.module.scss","webpack://keolis.com/./src/v3/templates/search-results/form-input/form-input.tsx","webpack://keolis.com/./src/v3/templates/search-results/form-input/form-input.module.scss","webpack://keolis.com/./static/vectors/magnifying_glass.svg","webpack://keolis.com/./src/v3/templates/search-results/no-search-results/no-search-results.tsx","webpack://keolis.com/./src/v3/templates/search-results/no-search-results/no-search-results.module.scss","webpack://keolis.com/./src/v3/templates/search-results/search-results-items/search-results-items.tsx","webpack://keolis.com/./src/v3/templates/search-results/search-results-items/search-results-items.module.scss","webpack://keolis.com/./src/v3/templates/search-results/search-results.tsx"],"sourcesContent":["// extracted by mini-css-extract-plugin\nexport var container = \"search-results-module--container--ca5bb\";\nexport var error = \"search-results-module--error--3aeb7\";\nexport var message = \"search-results-module--message--00535\";","import React, { useState } from \"react\"\nimport { ReactSVG } from \"react-svg\"\nimport * as styles from \"./form-input.module.scss\"\nimport magnifyingGlass from \"../../../../../static/vectors/magnifying_glass.svg\"\n\ntype RenderProps = {\n searchTerms: string\n placeholder: string\n onChange: (value: string) => void\n centered?: boolean\n}\n\nconst FormInput: React.FC<RenderProps> = ({ searchTerms, placeholder, onChange, centered }) => {\n const [value, setValue] = useState(searchTerms)\n const handleSubmit = (event: React.FormEvent<HTMLFormElement>) => {\n onChange(value)\n event.preventDefault()\n }\n\n return (\n <form\n method=\"get\"\n role=\"search\"\n onSubmit={handleSubmit}\n className={styles.searchForm}\n style={centered && { margin: \"32px auto\" }}\n >\n <input type=\"text\" name=\"query\" value={value} onChange={e => setValue(e.target.value)} aria-label={placeholder} />\n <button type=\"submit\" className={styles.searchButton} value=\"ok\" aria-label={placeholder}>\n <ReactSVG src={magnifyingGlass} className={styles.icon} aria-hidden={true} />\n </button>\n </form>\n )\n}\n\nexport default FormInput\n","// extracted by mini-css-extract-plugin\nexport var icon = \"form-input-module--icon--0265c\";\nexport var searchButton = \"form-input-module--searchButton--ebf07\";\nexport var searchForm = \"form-input-module--searchForm--dc969\";","export default \"\"","import React from \"react\"\nimport { graphql } from \"gatsby\"\nimport { NoSearchResultsFieldsFragment } from \"../../../../../graphql-types\"\nimport * as styles from \"./no-search-results.module.scss\"\nimport RichDatoCmsContent from \"../../../components/rich-dato-cms-content/rich_dato_cms_content\"\nimport { DisplayImage } from \"../../../components/display-image/display-image\"\nimport FormInput from \"../form-input/form-input\"\n\ntype RenderProps = {\n data: NoSearchResultsFieldsFragment\n searchTerms: string\n onChange: (value: string) => void\n}\n\nconst NoSearchResults: React.FC<RenderProps> = ({ data, searchTerms, onChange }) => (\n <div className={styles.content}>\n <div className={styles.textContainer}>\n <h1 className={styles.title}>{`${data.resultsNotFoundTitle} \"${searchTerms}\" !`}</h1>\n <div className={styles.structuredText}>\n <RichDatoCmsContent data={data.resultsNotFoundText} />\n </div>\n\n <FormInput searchTerms={searchTerms} placeholder={data.placeholder} onChange={onChange} />\n </div>\n\n <DisplayImage image={data.resultsNotFoundImage} imgStyle={styles.photo} />\n </div>\n)\n\nexport const fragment = graphql`\n fragment NoSearchResultsFields on DatoCmsHeader {\n id\n placeholder\n resultsPageTitle\n resultsNotFoundTitle\n resultsNotFoundImage {\n alt\n format\n title\n url\n }\n resultsNotFoundText {\n __typename\n ... on DatoCmsStructuredText {\n structuredText {\n value\n }\n }\n }\n searchInProgressMessage\n errorMessage\n resultsFor\n }\n`\n\nexport default NoSearchResults\n","// extracted by mini-css-extract-plugin\nexport var content = \"no-search-results-module--content--569ce\";\nexport var photo = \"no-search-results-module--photo--06dd7\";\nexport var structuredText = \"no-search-results-module--structuredText--a69d9\";\nexport var textContainer = \"no-search-results-module--textContainer--69bb8\";\nexport var title = \"no-search-results-module--title--2670d\";","import React from \"react\"\nimport * as styles from \"./search-results-items.module.scss\"\nimport { SearchState } from \"../search-results\"\nimport FormInput from \"../form-input/form-input\"\n\ntype RenderProps = {\n data: {\n attributes: {\n body_excerpt: string\n title: string\n url: string\n }\n }[]\n searchState: SearchState\n searchContent: string\n label: string\n searchTerms: string\n placeholder: string\n onChange: (value: string) => void\n}\n\nconst SearchResultsItems: React.FC<RenderProps> = ({\n data,\n searchState,\n searchContent,\n label,\n searchTerms,\n placeholder,\n onChange,\n}) => {\n return (\n <div className={styles.containerSearchResults}>\n <FormInput searchTerms={searchTerms} placeholder={placeholder} onChange={onChange} centered={true} />\n\n {searchState === SearchState.Success && (\n <>\n <h2 className={styles.resultsSentence}>\n {data.length} {label} “{searchContent}â€\n </h2>\n <div className={styles.searchResultWrapper}>\n {data.map(item => (\n <div className={styles.searchResult} key={item.attributes.url}>\n {item.attributes.title && (\n <a href={item.attributes.url} className={styles.title}>\n <span>{item.attributes.title}</span>\n </a>\n )}\n <span className={styles.body}>{item.attributes.body_excerpt}</span>\n </div>\n ))}\n </div>\n </>\n )}\n </div>\n )\n}\n\nexport default SearchResultsItems\n","// extracted by mini-css-extract-plugin\nexport var body = \"search-results-items-module--body--5ccfc\";\nexport var containerSearchResults = \"search-results-items-module--containerSearchResults--5cf0a\";\nexport var resultsSentence = \"search-results-items-module--resultsSentence--61d2a\";\nexport var searchResult = \"search-results-items-module--searchResult--9e8f5\";\nexport var searchResultWrapper = \"search-results-items-module--searchResultWrapper--ce3c9\";\nexport var title = \"search-results-items-module--title--7b5e4\";","import React, { useEffect, useState } from \"react\"\nimport { buildClient } from \"@datocms/cma-client-browser\"\nimport { graphql } from \"gatsby\"\nimport { DatoCmsSlugsConfiguration, SearchResultsQuery } from \"../../../../graphql-types\"\nimport * as config from \"../../../../config\"\nimport * as styles from \"./search-results.module.scss\"\nimport { StringParam, useQueryParam } from \"use-query-params\"\nimport { useFormatLocale, useIsMobile, useSlugValue } from \"../../hooks\"\nimport Layout from \"../../components/layout/layout\"\nimport Breadcrumb from \"../../components/breadcrumb/breadcrumb\"\nimport NoSearchResults from \"./no-search-results/no-search-results\"\nimport SearchResultsItems from \"./search-results-items/search-results-items\"\nimport SEO from \"../../components/seo/seo\"\nimport { HrefLangLinks } from \"../../components/hrefLangLinks/hrefLangLinks\"\n\nexport enum SearchState {\n NoSearch,\n Searching,\n Success,\n Error,\n}\n\ntype RenderProps = {\n data: SearchResultsQuery\n location: Location\n pageContext: {\n locale: string\n defaultLocale: string\n slugs: DatoCmsSlugsConfiguration\n }\n}\n\nconst SearchResults: React.FC<RenderProps> = ({ data, location, pageContext }) => {\n const isMobile = useIsMobile()\n const client = buildClient({ apiToken: config.search_token })\n const [searchResults, setSearchResults] = useState([])\n const [searchState, setSearchState] = useState(SearchState.NoSearch)\n const [searchTerms, setSearchTerms] = useQueryParam(\"query\", StringParam)\n\n useEffect(() => {\n if (!searchTerms) return\n\n let allResults = []\n const fetchResults = async () => {\n for (let offset = 0, searching = true; searching; offset += 100) {\n await client.searchResults\n .rawList({\n filter: {\n fuzzy: true,\n query: searchTerms,\n build_trigger_id: \"Production\",\n locale: pageContext.locale,\n },\n page: {\n limit: 100,\n offset: offset,\n },\n })\n .then(\n ({ data: results }) => {\n if (results.length < 100) {\n searching = false\n }\n allResults.push(...results)\n },\n error => {\n console.error(error)\n setSearchState(SearchState.Error)\n searching = false\n }\n )\n }\n }\n\n fetchResults().then(() => {\n setSearchResults(allResults)\n setSearchState(SearchState.Success)\n })\n }, [searchTerms])\n\n return (\n <Layout\n pageContext={pageContext}\n location={location}\n header={data.datoCmsV3Header}\n footer={data.datoCmsFooter}\n subsidiaryLogo={data.datoCmsGlobalConfiguration.subsidiaryLogo}\n contactButton={data.datoCmsV3ContactButton}\n currentRoute={useSlugValue(pageContext.slugs._allSearchPageSlugLocales, pageContext.locale)}\n pageTemplate=\"search results\"\n >\n <section className={styles.container}>\n {!isMobile && (\n <Breadcrumb\n title={data.datoCmsHeader.resultsPageTitle}\n homeLabel={data.datoCmsGlobalConfiguration.homePageTitle}\n />\n )}\n {searchState === SearchState.Searching && (\n <p className={styles.message}>{data.datoCmsHeader.searchInProgressMessage}</p>\n )}\n {searchState === SearchState.Error && (\n <p className={`${styles.message} ${styles.error}`}>{data.datoCmsHeader.errorMessage}</p>\n )}\n {searchState === SearchState.Success && searchResults.length === 0 && (\n <NoSearchResults data={data.datoCmsHeader} searchTerms={searchTerms} onChange={setSearchTerms} />\n )}\n {(searchState === SearchState.NoSearch ||\n (searchState === SearchState.Success && searchResults.length > 0)) && (\n <SearchResultsItems\n data={searchResults}\n searchState={searchState}\n searchContent={searchTerms}\n label={data.datoCmsHeader.resultsFor}\n searchTerms={searchTerms}\n placeholder={data.datoCmsHeader.placeholder}\n onChange={setSearchTerms}\n />\n )}\n </section>\n </Layout>\n )\n}\n\nexport const Head: React.FC<RenderProps> = ({ data, pageContext }) => (\n <>\n <SEO\n title={data.datoCmsHeader.resultsPageTitle}\n description={data.datoCmsGlobalConfiguration.metaDescription}\n locale={useFormatLocale(pageContext.locale)}\n />\n <meta name=\"viewport\" content=\"width=device-width\" />\n {typeof window !== \"undefined\" && (\n <HrefLangLinks\n defaultDomain={window.location.origin}\n defaultLocale={pageContext.defaultLocale}\n slugs={[pageContext.slugs._allSearchPageSlugLocales]}\n />\n )}\n </>\n)\n\nexport const pageQuery = graphql`\n query SearchResults($locale: String!) {\n datoCmsGlobalConfiguration(locale: $locale) {\n metaDescription\n homePageTitle\n subsidiaryLogo {\n alt\n format\n originalId\n url\n }\n }\n\n datoCmsV3Header(locale: $locale) {\n ...V3HeaderFields\n }\n datoCmsFooter(locale: $locale) {\n ...FooterFields\n }\n datoCmsV3ContactButton(locale: $locale) {\n ...V3ContactButtonFields\n }\n\n datoCmsHeader(locale: $locale) {\n ...NoSearchResultsFields\n }\n }\n`\n\nexport default SearchResults\n"],"names":["message","_ref","searchTerms","placeholder","onChange","centered","_useState","useState","value","setValue","React","method","role","onSubmit","event","preventDefault","className","style","margin","type","name","e","target","ReactSVG","src","data","resultsNotFoundTitle","RichDatoCmsContent","resultsNotFoundText","FormInput","DisplayImage","image","resultsNotFoundImage","imgStyle","searchState","searchContent","label","SearchState","Success","length","map","item","key","attributes","url","title","href","body_excerpt","Head","_ref4","pageContext","SEO","datoCmsHeader","resultsPageTitle","description","datoCmsGlobalConfiguration","metaDescription","locale","useFormatLocale","content","window","HrefLangLinks","defaultDomain","location","origin","defaultLocale","slugs","_allSearchPageSlugLocales","isMobile","useIsMobile","client","buildClient","apiToken","config","search_token","searchResults","setSearchResults","_useState2","NoSearch","setSearchState","_useQueryParam","useQueryParam","StringParam","setSearchTerms","useEffect","allResults","fetchResults","_ref2","_asyncToGenerator","_regeneratorRuntime","_callee","_loop","offset","searching","_context2","prev","next","_searching","_context","rawList","filter","fuzzy","query","build_trigger_id","page","limit","then","_ref3","results","push","apply","_toConsumableArray","error","console","Error","stop","delegateYield","arguments","Layout","header","datoCmsV3Header","footer","datoCmsFooter","subsidiaryLogo","contactButton","datoCmsV3ContactButton","currentRoute","useSlugValue","pageTemplate","Breadcrumb","homeLabel","homePageTitle","Searching","styles","searchInProgressMessage","errorMessage","NoSearchResults","SearchResultsItems","resultsFor"],"sourceRoot":""}