{"version":3,"file":"js/9011.chunk.js","mappings":"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","sources":["webpack:///./assets/common/src/components/storelocator/StoreBoutiquesNearby.tsx","webpack:///./assets/common/src/components/storelocator/StorePage.tsx","webpack:///./assets/common/src/utils/JsonLd.tsx"],"sourcesContent":["import { currentStoreSelector } from '@state/features/storelocator.selectors';\nimport analytics from '@utils/analytics';\nimport React, { useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { useSelector } from 'react-redux';\nimport StoreAddress from './StoreAddress';\nimport StoreLocatorMap from './StoreLocatorMap';\nconst StoreBoutiquesNearby = (props) => {\n const { t } = useTranslation();\n const { stores } = props;\n const [selectedStore, setSelectedStore] = useState(stores[0]);\n const { baseUrl } = useSelector((state) => state.storelocator);\n const currentStore = useSelector(currentStoreSelector);\n return (React.createElement(\"div\", { className: \"row justify-center boutiques-nearby\" },\n React.createElement(\"div\", { className: \"col-12 wrapper-title\" },\n React.createElement(\"h2\", { className: \"section-title\" }, t('storelocator.boutiquesnearby')),\n React.createElement(\"a\", { href: `${baseUrl}/storelocator`, onClick: () => analytics.storelocatorStoreCta(currentStore.name, 'find a boutique'), className: \"button button--tertiary button--arrow-right \" }, t('storelocator.findboutique'))),\n React.createElement(\"div\", { className: \"col-sm-8 col-md-3\" },\n React.createElement(\"div\", { className: \"nearby-store-details\" },\n React.createElement(\"button\", { onClick: () => {\n if (selectedStore) {\n analytics.storelocatorSelect(selectedStore.name);\n }\n } },\n React.createElement(\"h3\", { className: \"title\" }, selectedStore.name),\n React.createElement(StoreAddress, { store: selectedStore, hidename: true, showphone: true, showmail: true })),\n React.createElement(\"a\", { href: `${baseUrl}/storelocator/${selectedStore.slug}`, onClick: () => analytics.storelocatorStoreCta(selectedStore.name, 'view boutique'), className: \"button button--secondary\" },\n React.createElement(\"span\", null, t('button.viewdetails'))))),\n React.createElement(\"div\", { className: \"col-sm-8 col-md-5\" },\n React.createElement(StoreLocatorMap, Object.assign({}, props, { localMap: true, stores: stores, currentStore: selectedStore, setCurrentStore: (storeId) => setSelectedStore(stores.find((store) => store.ID === storeId)) })))));\n};\nexport default StoreBoutiquesNearby;\n","import Metatags from '@components/common/Metatags';\nimport StoreLocatorMap from '@components/storelocator/StoreLocatorMap';\nimport { StoreLocatorActionTypes } from '@state/features/common.types';\nimport { currentStoreSelector } from '@state/features/storelocator.selectors';\nimport JsonLd from '@utils/JsonLd';\nimport React, { useEffect } from 'react';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { useParams } from 'react-router';\nimport StoreAvailableServices from './StoreAvailableServices';\nimport StoreBoutiqueCollections from './StoreBoutiqueCollections';\nimport StoreBoutiqueInformation from './StoreBoutiqueInformation';\nimport StoreBoutiquesNearby from './StoreBoutiquesNearby';\nimport StoreBreadcrumb from './StoreBreadcrumb';\nimport StoreSummary from './StoreSummary';\nconst StorePage = (props) => {\n var _a;\n const { store, country, city } = useParams();\n const dispatch = useDispatch();\n useEffect(() => {\n if (store) {\n const slug = `${country}/${city}/${store}`;\n dispatch({ type: StoreLocatorActionTypes.FETCH_STORE_DETAILS, payload: slug });\n }\n }, []);\n const storedetail = useSelector(currentStoreSelector);\n if (!storedetail) {\n return React.createElement(React.Fragment, null);\n }\n return (React.createElement(\"div\", { className: \"store-page\" },\n React.createElement(Metatags, { pageMetaTags: storedetail.pageMetaTags, meta: storedetail.meta }),\n React.createElement(JsonLd, { data: {\n '@context': 'https://schema.org',\n '@type': 'Store',\n image: storedetail.image && false ? [storedetail.image] : [props.storedetailimage],\n // doesn't have to be a valid url, only a stable ID with the form of an url\n '@id': `http://store.moncler.com/${storedetail.ID}`,\n name: storedetail.name,\n // TODO openingHoursSpecification\n address: {\n '@type': 'PostalAddress',\n streetAddress: storedetail.address1,\n addressLocality: storedetail.city,\n addressRegion: storedetail.stateCode,\n postalCode: storedetail.postalCode,\n addressCountry: (_a = storedetail.countryCode) === null || _a === void 0 ? void 0 : _a.value,\n },\n geo: {\n '@type': 'GeoCoordinates',\n latitude: storedetail.latitude,\n longitude: storedetail.longitude,\n },\n url: `${window.homeurl}/storelocator/${storedetail.slug}`,\n telephone: storedetail.phone,\n } }),\n React.createElement(\"div\", { className: \"container\" },\n React.createElement(\"div\", { className: \"row justify-center\" },\n React.createElement(\"div\", { className: \"col-sm-8\" },\n React.createElement(\"div\", { className: \"store-detail__title\" },\n React.createElement(\"p\", null,\n \"MONCLER \",\n storedetail.city),\n React.createElement(\"h1\", null, storedetail.name)))),\n React.createElement(\"div\", { className: \"row justify-center\" },\n React.createElement(\"div\", { className: \"col-sm-8\" },\n React.createElement(StoreBreadcrumb, { store: storedetail }))),\n storedetail.image && (React.createElement(\"div\", { className: \"row justify-center\" },\n React.createElement(\"div\", { className: \"col-sm-8\" },\n React.createElement(\"div\", { className: \"picture\" },\n React.createElement(\"img\", { src: storedetail.image, alt: \"\" }))))),\n React.createElement(\"div\", { className: \"row justify-center spaced-row\" },\n React.createElement(\"div\", { className: \"col-sm-8 col-lg-3\" },\n React.createElement(StoreSummary, { store: storedetail, inPage: true }),\n React.createElement(StoreBoutiqueInformation, Object.assign({ store: storedetail }, props)),\n React.createElement(StoreBoutiqueCollections, { collections: storedetail.storeCollections })),\n React.createElement(\"div\", { className: \"col-sm-8 col-lg-5\" },\n React.createElement(StoreLocatorMap, Object.assign({}, props, { localMap: true, stores: [storedetail], currentStore: storedetail })))),\n storedetail.storeEvents && (React.createElement(\"div\", { className: \"row justify-center\" },\n React.createElement(\"div\", { className: \"col-sm-8\" },\n React.createElement(\"div\", { className: \"store-quote\" },\n React.createElement(\"img\", { src: \"/on/demandware.static/-/Sites/default/images/background-quote.jpeg\", alt: \"store quote\" }),\n React.createElement(\"div\", { className: \"quote-wrapper\", dangerouslySetInnerHTML: { __html: storedetail.storeEvents } }))))),\n storedetail.hasInStoreServices && (React.createElement(\"div\", { className: \"row justify-center\" },\n React.createElement(\"div\", { className: \"col-sm-8\" },\n React.createElement(StoreAvailableServices, { services: storedetail.storeServices, inPage: true })))),\n storedetail.hasNearbyStores && React.createElement(StoreBoutiquesNearby, Object.assign({}, props, { stores: storedetail.nearbyStores })))));\n};\nexport default StorePage;\n","import React from 'react';\nimport { Helmet } from 'react-helmet';\nconst JsonLd = ({ data }) => (React.createElement(Helmet, null,\n React.createElement(\"script\", { type: \"application/ld+json\" }, JSON.stringify(data))));\nexport default JsonLd;\n"],"names":["props","t","useTranslation","stores","selectedStore","setSelectedStore","useState","baseUrl","state","storelocator","currentStore","className","href","onClick","analytics","name","StoreAddress","store","hidename","showphone","showmail","slug","StoreLocatorMap","Object","assign","localMap","setCurrentStore","storeId","find","ID","_a","country","city","dispatch","useEffect","type","payload","storedetail","Metatags","pageMetaTags","meta","JsonLd","data","image","storedetailimage","address","streetAddress","address1","addressLocality","addressRegion","stateCode","postalCode","addressCountry","countryCode","value","geo","latitude","longitude","url","window","homeurl","telephone","phone","StoreBreadcrumb","src","alt","StoreSummary","inPage","StoreBoutiqueInformation","StoreBoutiqueCollections","collections","storeCollections","storeEvents","dangerouslySetInnerHTML","__html","hasInStoreServices","StoreAvailableServices","services","storeServices","hasNearbyStores","nearbyStores","JSON","stringify"],"sourceRoot":""}