{"version":3,"sources":["redux/constants.js","redux/actions/actionFetchMarkers.js","components/InfoWindowComponent.js","components/MarkerComponent.js","containers/Map.js","mapStyle.js","components/Header.js","images/logo.png","ClearCache.js","App.js","reportWebVitals.js","redux/reducers/reducerFetchMarkers.js","redux/store.js","index.js"],"names":["FETCH_MARKERS_LOADING","FETCH_MARKERS_SUCCESS","FETCH_MARKERS_ERROR","fetchMarkers","axios","defaults","headers","get","process","disatch","type","then","res","markersArray","data","markers","payload","catch","error","fetchMarkersError","message","InfoWindowComponent","props","selected","email","contact","phone","astreintePhone","displayEmail","displayPhone","displayAstreintePhone","isOpen","allowGestInfo","position","lat","latitude","lng","longitude","onCloseClick","name","isWa","busySlots","totalSlots","toFixed","style","color","Moment","format","lastUpdate","MarkerComponent","marker","icon","url","ratio","isLargePassageArea","isWA","pourcent","handlePinImgPath","scaledSize","window","google","maps","Size","origin","Point","anchor","animation","onClick","mapContainerStyle","width","height","center","options","styles","disableDefaultUI","zoomControl","Map","state","useSelector","dispatch","useDispatch","useState","setSelected","mapRef","useRef","useLoadScript","googleMapsApiKey","isLoaded","loadError","onMapLoad","useCallback","map","current","useEffect","zoom","onLoad","isLoading","className","console","log","Header","id","to","src","alt","withClearCache","ClearCacheComponent","Component","isLatestBuildDate","setIsLatestBuildDate","fetch","response","json","meta","latestDate","currentDate","momLatestDateTime","moment","momCurrentDateTime","isAfter","buildDateGreaterThan","buildDate","packageJson","refreshCacheAndReload","caches","keys","names","delete","location","reload","Fragment","exact","path","component","App","reportWebVitals","onPerfEntry","Function","getCLS","getFID","getFCP","getLCP","getTTFB","initialState","reducerFetchMarkers","action","rootreducer","combineReducers","store","createStore","applyMiddleware","thunk","ReactDOM","render","document","getElementById"],"mappings":"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","file":"static/js/main.2a751ebf.chunk.js","sourcesContent":["// FET MARKERS\r\nexport const FETCH_MARKERS_LOADING = 'FETCH_MARKERS_LOADING'\r\nexport const FETCH_MARKERS_SUCCESS = 'FETCH_MARKERS_SUCCESS'\r\nexport const FETCH_MARKERS_ERROR = 'FETCH_MARKERS_ERROR'","import {FETCH_MARKERS_LOADING, FETCH_MARKERS_SUCCESS, FETCH_MARKERS_ERROR} from '../constants'\r\nimport axios from 'axios'\r\n\r\nconst fetchMarkersLoading = () => {\r\n return {\r\n type: FETCH_MARKERS_LOADING\r\n }\r\n}\r\n\r\nconst fetchMarkersSuccess = data => {\r\n return {\r\n type: FETCH_MARKERS_SUCCESS,\r\n payload: data\r\n }\r\n}\r\n\r\nconst fetchMarkersError = error => {\r\n return {\r\n type: FETCH_MARKERS_ERROR,\r\n payload: error\r\n }\r\n}\r\n\r\nexport const fetchMarkers = () => {\r\n\r\n axios.defaults.headers.get['ApiKey'] = process.env.REACT_APP_WA3_API_KEY;\r\n \r\n return disatch => {\r\n disatch(fetchMarkersLoading())\r\n\r\n axios.get(`${process.env.REACT_APP_API}Markers/GetMarkers`)\r\n .then(res => {\r\n const markersArray = res.data.markers;\r\n disatch(fetchMarkersSuccess(markersArray))\r\n })\r\n .catch(error => {\r\n disatch(fetchMarkersError(error.message))\r\n })\r\n }\r\n}","import React from 'react'\r\nimport { InfoWindow } from '@react-google-maps/api'\r\nimport Moment from 'moment';\r\n\r\nconst InfoWindowComponent = (props) => {\r\n\r\n const selected = props.selected;\r\n const email = selected.contact.email;\r\n const phone = selected.contact.phone;\r\n const astreintePhone = selected.contact.astreintePhone;\r\n\r\n const displayEmail = email &&\r\n
\r\n Email:\r\n \r\n   {email}\r\n \r\n \r\n
\r\n
;\r\n\r\n const displayPhone = phone &&\r\n
\r\n Téléphone:\r\n \r\n   {phone}\r\n \r\n \r\n
\r\n
;\r\n\r\n const displayAstreintePhone = astreintePhone &&\r\n
\r\n Astreinte:\r\n \r\n   {astreintePhone}\r\n \r\n \r\n
\r\n
;\r\n\r\nif (selected.isOpen === 1) {\r\n if (selected.allowGestInfo) {\r\n return (\r\n \r\n
\r\n {selected.name}

\r\n \r\n Fermée\r\n \r\n {displayEmail}\r\n {displayPhone}\r\n {displayAstreintePhone}\r\n
\r\n \r\n ) \r\n }else{\r\n return (\r\n \r\n
\r\n {selected.name}

\r\n \r\n Fermée\r\n \r\n
\r\n \r\n ) \r\n }\r\n \r\n}else{\r\n if (selected.isWa && selected.name === \"Sainte Savine\") {\r\n return (\r\n \r\n
\r\n {selected.name}

\r\n \r\n Taux d'occupation:\r\n \r\n   {(selected.busySlots / selected.totalSlots * 100).toFixed(0)}%\r\n \r\n \r\n
\r\n Emplacements disponibles:\r\n \r\n   {selected.totalSlots - selected.busySlots}/{selected.totalSlots}\r\n \r\n   (Sous réserve de confirmation)\r\n \r\n
\r\n {displayEmail}\r\n {displayPhone}\r\n {displayAstreintePhone}\r\n
\r\n \r\n \r\n Date:\r\n \r\n   {Moment().format('YYYY-MM-DD HH:mm')}\r\n \r\n \r\n
\r\n \r\n \r\n )\r\n }\r\n if (selected.isWa) {\r\n return (\r\n \r\n
\r\n {selected.name}

\r\n \r\n Taux d'occupation:\r\n \r\n   {(selected.busySlots / selected.totalSlots * 100).toFixed(0)}%\r\n \r\n \r\n
\r\n Emplacements disponibles:\r\n \r\n   {selected.totalSlots - selected.busySlots}/{selected.totalSlots}\r\n \r\n \r\n
\r\n {displayEmail}\r\n {displayPhone}\r\n {displayAstreintePhone}\r\n
\r\n \r\n \r\n Date:\r\n \r\n   {Moment().format('YYYY-MM-DD HH:mm')}\r\n \r\n \r\n
\r\n \r\n \r\n )\r\n }else{\r\n return (\r\n \r\n
\r\n {selected.name}

\r\n \r\n Taux d'occupation:\r\n \r\n   {(selected.busySlots / selected.totalSlots * 100).toFixed(0)}%\r\n \r\n \r\n
\r\n Emplacements disponibles:\r\n \r\n   {selected.totalSlots - selected.busySlots}/{selected.totalSlots}\r\n \r\n \r\n
\r\n {displayEmail}\r\n {displayPhone}\r\n {displayAstreintePhone}\r\n
\r\n \r\n \r\n Date:\r\n \r\n   {Moment(selected.lastUpdate).format('YYYY-MM-DD HH:mm')}\r\n \r\n \r\n
\r\n \r\n \r\n )\r\n }\r\n \r\n }\r\n}\r\n\r\nexport default InfoWindowComponent\r\n","import React from 'react'\r\nimport { Marker } from '@react-google-maps/api'\r\n\r\n\r\nconst MarkerComponent = (props) => {\r\n\r\n const marker = props.marker;\r\n\r\n const handlePinImgPath = (ratio, isLargePassageArea, isWA, isOpen) => {\r\n\r\n let pourcent = 0;\r\n\r\n if (ratio === 0)\r\n pourcent = 0;\r\n else if (ratio <= 10)\r\n pourcent = 10;\r\n else if (ratio <= 20)\r\n pourcent = 20;\r\n else if (ratio <= 30)\r\n pourcent = 30;\r\n else if (ratio <= 40)\r\n pourcent = 40;\r\n else if (ratio <= 50)\r\n pourcent = 50;\r\n else if (ratio <= 60)\r\n pourcent = 60;\r\n else if (ratio <= 70)\r\n pourcent = 70;\r\n else if (ratio <= 80)\r\n pourcent = 80;\r\n else if (ratio <= 90)\r\n pourcent = 90;\r\n else if (ratio <= 100)\r\n pourcent = 100;\r\n else\r\n pourcent = 0;\r\n\r\n if (isLargePassageArea) {\r\n if (ratio === 0)\r\n return \"/google-pins/marqueur_gp_tout-libre_etat-normal@2x.png\";\r\n return `/google-pins/marqueur_gp_occupation-${pourcent}pct_etat-normal@2x.png`;\r\n }\r\n else if (!isWA){\r\n if (ratio === 0 && isOpen === 0)\r\n return \"/google-pins/marqueur_non_aire_tout-libre_etat-normal@2x.png\";\r\n if (isOpen === 1) \r\n return \"/google-pins/marqueur_non_aire_tout-libre_ferme_etat-normal@2x.png\"; \r\n \r\n return `/google-pins/marqueur_non_aire_occupation-${pourcent}pct_etat-normal@2x.png`\r\n }\r\n else {\r\n if (ratio === 0 && isOpen === 0)\r\n return \"/google-pins/marqueur_aire_tout-libre_etat-normal@2x.png\";\r\n if (isOpen === 1) \r\n return \"/google-pins/marqueur_aire_tout-libre_etat-ferme-normal@2x.png\"; \r\n return `/google-pins/marqueur_aire_occupation-${pourcent}pct_etat-normal@2x.png`\r\n }\r\n }\r\n return (\r\n \r\n )\r\n}\r\n\r\nexport default MarkerComponent\r\n","import React, { useState, useRef, useCallback, useEffect } from 'react';\r\nimport { useSelector, useDispatch } from 'react-redux';\r\nimport { GoogleMap, useLoadScript } from '@react-google-maps/api';\r\nimport Loader from 'react-loader-spinner';\r\nimport { fetchMarkers } from '../redux/actions/actionFetchMarkers';\r\nimport InfoWindowComponent from '../components/InfoWindowComponent';\r\nimport MarkerComponent from '../components/MarkerComponent';\r\nimport mapStyles from '../mapStyle';\r\n\r\nconst mapContainerStyle = {\r\n width: \"100vw\",\r\n height: \"100vh\"\r\n}\r\n\r\nconst center = {\r\n lat: 47.227638,\r\n lng: 2.213749\r\n}\r\n\r\nconst options = {\r\n styles: mapStyles,\r\n disableDefaultUI: true,\r\n zoomControl: true\r\n}\r\n\r\nconst Map = () => {\r\n\r\n const state = useSelector(state => state.markers)\r\n const dispatch = useDispatch()\r\n const [selected, setSelected] = useState(null)\r\n const mapRef = useRef([])\r\n\r\n const { isLoaded, loadError } = useLoadScript({\r\n googleMapsApiKey: process.env.REACT_APP_GOOGLE_API_KEY\r\n })\r\n\r\n const onMapLoad = useCallback((map) => {\r\n mapRef.current = map;\r\n }, [])\r\n\r\n useEffect(() => {\r\n dispatch(fetchMarkers());\r\n\r\n }, [dispatch])\r\n\r\n if (loadError)\r\n return \"Error loading map\"\r\n if (!isLoaded)\r\n return \"Map is loading...\"\r\n return (\r\n \r\n {state.isLoading ? ()\r\n : state.error !== '' ? (

{console.log(state.error)}

)\r\n : state.fetchMarkers.map(marker => { setSelected(marker) }} key={marker.name} />)}\r\n\r\n {selected ? ( { setSelected(null) }} />) : null}\r\n\r\n \r\n )\r\n}\r\n\r\nexport default Map\r\n","const mapStyle = [\r\n {\r\n \"featureType\": \"all\",\r\n \"elementType\": \"all\",\r\n \"stylers\": [\r\n {\r\n \"invert_lightness\": true\r\n },\r\n {\r\n \"saturation\": 10\r\n },\r\n {\r\n \"lightness\": 50\r\n },\r\n {\r\n \"gamma\": 0.5\r\n },\r\n {\r\n \"hue\": \"#435158\"\r\n }\r\n ]\r\n }\r\n]\r\n\r\nexport default mapStyle;\r\n\r\n","import React from 'react'\r\nimport { Link } from 'react-router-dom'\r\nimport logo from '../images/logo.png'\r\n\r\nconst Header = () => {\r\n return (\r\n
\r\n \"logo\"\r\n
\r\n )\r\n}\r\n\r\nexport default Header\r\n","export default \"\"","import React, { useState, useEffect } from \"react\";\r\nimport packageJson from \"../package.json\";\r\nimport moment from 'moment';\r\n\r\nconst buildDateGreaterThan = (latestDate, currentDate) => {\r\n const momLatestDateTime = moment(latestDate);\r\n const momCurrentDateTime = moment(currentDate);\r\n\r\n if (momLatestDateTime.isAfter(momCurrentDateTime)) {\r\n return true;\r\n } else {\r\n return false;\r\n }\r\n};\r\n\r\nfunction withClearCache(Component) {\r\n function ClearCacheComponent(props) {\r\n const [isLatestBuildDate, setIsLatestBuildDate] = useState(false);\r\n\r\n useEffect(() => {\r\n fetch(\"/meta.json\")\r\n .then((response) => response.json())\r\n .then((meta) => {\r\n const latestVersionDate = meta.buildDate;\r\n const currentVersionDate = packageJson.buildDate;\r\n\r\n const shouldForceRefresh = buildDateGreaterThan(\r\n latestVersionDate,\r\n currentVersionDate\r\n );\r\n if (shouldForceRefresh) {\r\n setIsLatestBuildDate(false);\r\n refreshCacheAndReload();\r\n } else {\r\n setIsLatestBuildDate(true);\r\n }\r\n });\r\n }, []);\r\n\r\n const refreshCacheAndReload = () => {\r\n if (caches) {\r\n // Service worker cache should be cleared with caches.delete()\r\n caches.keys().then((names) => {\r\n for (const name of names) {\r\n caches.delete(name);\r\n }\r\n });\r\n }\r\n // delete browser cache and hard reload\r\n window.location.reload(true);\r\n };\r\n\r\n return (\r\n \r\n {isLatestBuildDate ? : null}\r\n \r\n );\r\n }\r\n\r\n return ClearCacheComponent;\r\n}\r\n\r\nexport default withClearCache;\r\n\r\n","import Map from './containers/Map';\r\nimport { BrowserRouter as Router, Route, Switch } from 'react-router-dom'\r\nimport Header from './components/Header';\r\nimport './App.css'\r\nimport withClearCache from \"./ClearCache\";\r\n\r\nconst ClearCacheComponent = withClearCache(MainApp);\r\n\r\nfunction App() {\r\n return ;\r\n}\r\n\r\nfunction MainApp(props) {\r\n return (\r\n \r\n
\r\n \r\n \r\n \r\n \r\n \r\n );\r\n}\r\n\r\nexport default App;\r\n","const reportWebVitals = onPerfEntry => {\r\n if (onPerfEntry && onPerfEntry instanceof Function) {\r\n import('web-vitals').then(({ getCLS, getFID, getFCP, getLCP, getTTFB }) => {\r\n getCLS(onPerfEntry);\r\n getFID(onPerfEntry);\r\n getFCP(onPerfEntry);\r\n getLCP(onPerfEntry);\r\n getTTFB(onPerfEntry);\r\n });\r\n }\r\n};\r\n\r\nexport default reportWebVitals;\r\n","import {FETCH_MARKERS_LOADING, FETCH_MARKERS_SUCCESS, FETCH_MARKERS_ERROR} from '../constants'\r\n\r\nconst initialState = {\r\n isLoading: false,\r\n fetchMarkers: [],\r\n error: ''\r\n}\r\n\r\nfunction reducerFetchMarkers(state = initialState, action) {\r\n switch (action.type) {\r\n case FETCH_MARKERS_LOADING:\r\n return {\r\n ...state,\r\n isLoading: true,\r\n fetchMarkers: [],\r\n error: ''\r\n }\r\n\r\n case FETCH_MARKERS_SUCCESS:\r\n return {\r\n ...state,\r\n isLoading: false,\r\n fetchMarkers: action.payload,\r\n error: ''\r\n }\r\n case FETCH_MARKERS_ERROR:\r\n return {\r\n ...state,\r\n isLoading: false,\r\n fetchMarkers: [],\r\n error: action.payload\r\n }\r\n \r\n default:\r\n return state;\r\n }\r\n}\r\n\r\nexport default reducerFetchMarkers\r\n","import {createStore, combineReducers, applyMiddleware} from 'redux'\r\nimport reducerFetchMarkers from './reducers/reducerFetchMarkers'\r\nimport thunk from 'redux-thunk'\r\n\r\nconst rootreducer = combineReducers({\r\n markers: reducerFetchMarkers\r\n})\r\n\r\nconst store = createStore(rootreducer, applyMiddleware(thunk))\r\n\r\nexport default store","import React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport { Provider } from 'react-redux'\r\nimport App from './App';\r\nimport reportWebVitals from './reportWebVitals';\r\nimport store from './redux/store'\r\n\r\nReactDOM.render(\r\n \r\n \r\n ,\r\n document.getElementById('root')\r\n);\r\n\r\n// If you want to start measuring performance in your app, pass a function\r\n// to log results (for example: reportWebVitals(console.log))\r\n// or send to an analytics endpoint. Learn more: https://bit.ly/CRA-vitals\r\nreportWebVitals();\r\n"],"sourceRoot":""}