react-spatial 1.2.2 → 1.2.3-beta.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LayerService.js +128 -184
- package/LayerService.js.map +7 -1
- package/components/BaseLayerSwitcher/BaseLayerSwitcher.js +163 -221
- package/components/BaseLayerSwitcher/BaseLayerSwitcher.js.map +7 -1
- package/components/BaseLayerSwitcher/index.js +1 -3
- package/components/BaseLayerSwitcher/index.js.map +7 -1
- package/components/BasicMap/BasicMap.js +147 -285
- package/components/BasicMap/BasicMap.js.map +7 -1
- package/components/BasicMap/index.js +1 -3
- package/components/BasicMap/index.js.map +7 -1
- package/components/CanvasSaveButton/CanvasSaveButton.js +165 -419
- package/components/CanvasSaveButton/CanvasSaveButton.js.map +7 -1
- package/components/CanvasSaveButton/index.js +1 -3
- package/components/CanvasSaveButton/index.js.map +7 -1
- package/components/Copyright/Copyright.js +29 -70
- package/components/Copyright/Copyright.js.map +7 -1
- package/components/Copyright/index.js +1 -3
- package/components/Copyright/index.js.map +7 -1
- package/components/FeatureExportButton/FeatureExportButton.js +40 -106
- package/components/FeatureExportButton/FeatureExportButton.js.map +7 -1
- package/components/FeatureExportButton/index.js +1 -3
- package/components/FeatureExportButton/index.js.map +7 -1
- package/components/FilterButton/FilterButton.js +41 -106
- package/components/FilterButton/FilterButton.js.map +7 -1
- package/components/FilterButton/index.js +1 -3
- package/components/FilterButton/index.js.map +7 -1
- package/components/FitExtent/FitExtent.js +17 -50
- package/components/FitExtent/FitExtent.js.map +7 -1
- package/components/FitExtent/index.js +1 -3
- package/components/FitExtent/index.js.map +7 -1
- package/components/FollowButton/FollowButton.js +41 -111
- package/components/FollowButton/FollowButton.js.map +7 -1
- package/components/FollowButton/index.js +1 -3
- package/components/FollowButton/index.js.map +7 -1
- package/components/Geolocation/Geolocation.js +104 -213
- package/components/Geolocation/Geolocation.js.map +7 -1
- package/components/Geolocation/index.js +1 -3
- package/components/Geolocation/index.js.map +7 -1
- package/components/LayerTree/LayerTree.js +204 -410
- package/components/LayerTree/LayerTree.js.map +7 -1
- package/components/LayerTree/index.js +1 -3
- package/components/LayerTree/index.js.map +7 -1
- package/components/MousePosition/MousePosition.js +61 -130
- package/components/MousePosition/MousePosition.js.map +7 -1
- package/components/MousePosition/index.js +1 -3
- package/components/MousePosition/index.js.map +7 -1
- package/components/NorthArrow/NorthArrow.js +22 -62
- package/components/NorthArrow/NorthArrow.js.map +7 -1
- package/components/NorthArrow/index.js +1 -3
- package/components/NorthArrow/index.js.map +7 -1
- package/components/Overlay/Overlay.js +83 -130
- package/components/Overlay/Overlay.js.map +7 -1
- package/components/Overlay/index.js +1 -3
- package/components/Overlay/index.js.map +7 -1
- package/components/Permalink/Permalink.js +150 -244
- package/components/Permalink/Permalink.js.map +7 -1
- package/components/Permalink/index.js +1 -3
- package/components/Permalink/index.js.map +7 -1
- package/components/Popup/Popup.js +106 -233
- package/components/Popup/Popup.js.map +7 -1
- package/components/Popup/index.js +1 -3
- package/components/Popup/index.js.map +7 -1
- package/components/ResizeHandler/ResizeHandler.js +58 -113
- package/components/ResizeHandler/ResizeHandler.js.map +7 -1
- package/components/ResizeHandler/index.js +1 -3
- package/components/ResizeHandler/index.js.map +7 -1
- package/components/RouteSchedule/RouteSchedule.js +150 -283
- package/components/RouteSchedule/RouteSchedule.js.map +7 -1
- package/components/RouteSchedule/index.js +1 -3
- package/components/RouteSchedule/index.js.map +7 -1
- package/components/ScaleLine/ScaleLine.js +21 -45
- package/components/ScaleLine/ScaleLine.js.map +7 -1
- package/components/ScaleLine/index.js +1 -3
- package/components/ScaleLine/index.js.map +7 -1
- package/components/Search/Search.js +122 -186
- package/components/Search/Search.js.map +7 -1
- package/components/Search/SearchService.js +45 -69
- package/components/Search/SearchService.js.map +7 -1
- package/components/Search/engines/Engine.js +18 -25
- package/components/Search/engines/Engine.js.map +7 -1
- package/components/Search/engines/StopFinder.js +21 -38
- package/components/Search/engines/StopFinder.js.map +7 -1
- package/components/Search/index.js +3 -6
- package/components/Search/index.js.map +7 -1
- package/components/StopsFinder/StopsFinder.js +123 -174
- package/components/StopsFinder/StopsFinder.js.map +7 -1
- package/components/StopsFinder/StopsFinderOption.js +37 -54
- package/components/StopsFinder/StopsFinderOption.js.map +7 -1
- package/components/StopsFinder/index.js +1 -3
- package/components/StopsFinder/index.js.map +7 -1
- package/components/TrackerControl/TrackerControl.js +73 -128
- package/components/TrackerControl/TrackerControl.js.map +7 -1
- package/components/TrackerControl/index.js +1 -3
- package/components/TrackerControl/index.js.map +7 -1
- package/components/Zoom/Zoom.js +69 -112
- package/components/Zoom/Zoom.js.map +7 -1
- package/components/Zoom/index.js +1 -3
- package/components/Zoom/index.js.map +7 -1
- package/package.json +10 -5
- package/propTypes.js +17 -23
- package/propTypes.js.map +7 -1
- package/setupTests.js +2 -4
- package/setupTests.js.map +7 -1
- package/themes/README.md +26 -0
- package/themes/default/components.scss +0 -1
- package/themes/default/examples.scss +0 -1
- package/utils/GlobalsForOle.js +63 -64
- package/utils/GlobalsForOle.js.map +7 -1
- package/utils/KML.js +178 -364
- package/utils/KML.js.map +7 -1
- package/utils/KMLFormat.js +37 -73
- package/utils/KMLFormat.js.map +7 -1
- package/utils/Styles.js +24 -32
- package/utils/Styles.js.map +7 -1
- package/utils/getPolygonPattern.js +11 -44
- package/utils/getPolygonPattern.js.map +7 -1
- package/utils/timeUtils.js +16 -35
- package/utils/timeUtils.js.map +7 -1
- package/LayerService.test.js +0 -160
- package/LayerService.test.js.map +0 -1
- package/Projections.js +0 -16
- package/Projections.js.map +0 -1
- package/components/BaseLayerSwitcher/BaseLayerSwitcher.test.js +0 -88
- package/components/BaseLayerSwitcher/BaseLayerSwitcher.test.js.map +0 -1
- package/components/BaseLayerToggler/BaseLayerToggler.js +0 -490
- package/components/BaseLayerToggler/BaseLayerToggler.js.map +0 -1
- package/components/BaseLayerToggler/BaseLayerToggler.md.scss +0 -9
- package/components/BaseLayerToggler/BaseLayerToggler.scss +0 -49
- package/components/BaseLayerToggler/BaseLayerToggler.test.js +0 -127
- package/components/BaseLayerToggler/BaseLayerToggler.test.js.map +0 -1
- package/components/BaseLayerToggler/index.js +0 -3
- package/components/BaseLayerToggler/index.js.map +0 -1
- package/components/BasicMap/BasicMap.test.js +0 -288
- package/components/BasicMap/BasicMap.test.js.map +0 -1
- package/components/CanvasSaveButton/CanvasSaveButton.test.js +0 -173
- package/components/CanvasSaveButton/CanvasSaveButton.test.js.map +0 -1
- package/components/Copyright/Copyright.test.js +0 -133
- package/components/Copyright/Copyright.test.js.map +0 -1
- package/components/FeatureExportButton/FeatureExportButton.test.js +0 -407
- package/components/FeatureExportButton/FeatureExportButton.test.js.map +0 -1
- package/components/FilterButton/FilterButton.test.js +0 -48
- package/components/FilterButton/FilterButton.test.js.map +0 -1
- package/components/FitExtent/FitExtent.test.js +0 -44
- package/components/FitExtent/FitExtent.test.js.map +0 -1
- package/components/FollowButton/FollowButton.test.js +0 -57
- package/components/FollowButton/FollowButton.test.js.map +0 -1
- package/components/Geolocation/Geolocation.test.js +0 -263
- package/components/Geolocation/Geolocation.test.js.map +0 -1
- package/components/LayerTree/LayerTree.test.js +0 -323
- package/components/LayerTree/LayerTree.test.js.map +0 -1
- package/components/MousePosition/MousePosition.test.js +0 -125
- package/components/MousePosition/MousePosition.test.js.map +0 -1
- package/components/NorthArrow/NorthArrow.test.js +0 -106
- package/components/NorthArrow/NorthArrow.test.js.map +0 -1
- package/components/Overlay/Overlay.test.js +0 -145
- package/components/Overlay/Overlay.test.js.map +0 -1
- package/components/Permalink/Permalink.test.js +0 -267
- package/components/Permalink/Permalink.test.js.map +0 -1
- package/components/Popup/Popup.test.js +0 -291
- package/components/Popup/Popup.test.js.map +0 -1
- package/components/ResizeHandler/ResizeHandler.test.js +0 -410
- package/components/ResizeHandler/ResizeHandler.test.js.map +0 -1
- package/components/RouteSchedule/RouteSchedule.test.js +0 -102
- package/components/RouteSchedule/RouteSchedule.test.js.map +0 -1
- package/components/ScaleLine/ScaleLine.test.js +0 -32
- package/components/ScaleLine/ScaleLine.test.js.map +0 -1
- package/components/Search/Search.test.js +0 -15
- package/components/Search/Search.test.js.map +0 -1
- package/components/StopsFinder/StopsFinder.test.js +0 -19
- package/components/StopsFinder/StopsFinder.test.js.map +0 -1
- package/components/TrackerControl/TrackerControl.test.js +0 -17
- package/components/TrackerControl/TrackerControl.test.js.map +0 -1
- package/components/Zoom/Zoom.test.js +0 -150
- package/components/Zoom/Zoom.test.js.map +0 -1
- package/styleguidist/ComponentsList.js +0 -52
- package/styleguidist/ComponentsList.js.map +0 -1
- package/styleguidist/StyleGuide.js +0 -253
- package/styleguidist/StyleGuide.js.map +0 -1
- package/utils/KML.test.js +0 -163
- package/utils/KML.test.js.map +0 -1
- package/utils/KMLFormat.test.js +0 -22
- package/utils/KMLFormat.test.js.map +0 -1
- package/utils/getPolygonPattern.test.js +0 -66
- package/utils/getPolygonPattern.test.js.map +0 -1
- package/utils/timeUtils.test.js +0 -32
- package/utils/timeUtils.test.js.map +0 -1
|
@@ -1,67 +1,50 @@
|
|
|
1
|
-
import React, { lazy, Suspense } from
|
|
2
|
-
import PropTypes from
|
|
3
|
-
import { makeStyles } from
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
var iconForMot = {};
|
|
1
|
+
import React, { lazy, Suspense } from "react";
|
|
2
|
+
import PropTypes from "prop-types";
|
|
3
|
+
import { makeStyles } from "@material-ui/core";
|
|
4
|
+
const ext = "_round-blue-01.svg";
|
|
5
|
+
const iconForMot = {};
|
|
7
6
|
[
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
7
|
+
"bus",
|
|
8
|
+
"ferry",
|
|
9
|
+
"gondola",
|
|
10
|
+
"tram",
|
|
11
|
+
"rail",
|
|
12
|
+
"funicular",
|
|
13
|
+
"cable_car",
|
|
14
|
+
"subway"
|
|
15
|
+
].forEach((mot) => {
|
|
16
|
+
iconForMot[mot] = lazy(() => {
|
|
17
|
+
return import(`../../images/mots/${mot}${ext}`);
|
|
18
18
|
});
|
|
19
19
|
});
|
|
20
|
-
|
|
21
|
-
var useStyles = makeStyles(function (theme) {
|
|
20
|
+
const useStyles = makeStyles((theme) => {
|
|
22
21
|
return {
|
|
23
22
|
flex: {
|
|
24
|
-
display:
|
|
25
|
-
alignItems:
|
|
23
|
+
display: "flex",
|
|
24
|
+
alignItems: "center"
|
|
26
25
|
},
|
|
27
26
|
icon: {
|
|
28
|
-
marginRight: theme.spacing(2)
|
|
29
|
-
}
|
|
27
|
+
marginRight: theme.spacing(2)
|
|
28
|
+
}
|
|
30
29
|
};
|
|
31
30
|
});
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
return (
|
|
48
|
-
React.createElement( 'span', { className: classes.icon },
|
|
49
|
-
React.createElement( MotIcon, null )
|
|
50
|
-
)
|
|
51
|
-
);
|
|
52
|
-
}
|
|
53
|
-
return React.createElement( React.Fragment, null );
|
|
54
|
-
}),
|
|
55
|
-
React.createElement( 'span', null, option.properties.name )
|
|
56
|
-
)
|
|
57
|
-
)
|
|
58
|
-
);
|
|
31
|
+
function StopsFinderOption({ option }) {
|
|
32
|
+
const classes = useStyles();
|
|
33
|
+
return /* @__PURE__ */ React.createElement(Suspense, {
|
|
34
|
+
fallback: /* @__PURE__ */ React.createElement("div", null)
|
|
35
|
+
}, /* @__PURE__ */ React.createElement("div", {
|
|
36
|
+
className: classes.flex
|
|
37
|
+
}, Object.entries(option.properties.mot).map(([key, value]) => {
|
|
38
|
+
if (value) {
|
|
39
|
+
const MotIcon = iconForMot[key];
|
|
40
|
+
return /* @__PURE__ */ React.createElement("span", {
|
|
41
|
+
className: classes.icon
|
|
42
|
+
}, /* @__PURE__ */ React.createElement(MotIcon, null));
|
|
43
|
+
}
|
|
44
|
+
return /* @__PURE__ */ React.createElement(React.Fragment, null);
|
|
45
|
+
}), /* @__PURE__ */ React.createElement("span", null, option.properties.name)));
|
|
59
46
|
}
|
|
60
|
-
|
|
61
47
|
StopsFinderOption.propTypes = {
|
|
62
|
-
option: PropTypes.object.isRequired
|
|
48
|
+
option: PropTypes.object.isRequired
|
|
63
49
|
};
|
|
64
|
-
|
|
65
50
|
export default React.memo(StopsFinderOption);
|
|
66
|
-
|
|
67
|
-
//# sourceMappingURL=StopsFinderOption.js.map
|
|
@@ -1 +1,7 @@
|
|
|
1
|
-
{
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/StopsFinder/StopsFinderOption.js"],
|
|
4
|
+
"sourcesContent": ["import React, { lazy, Suspense } from 'react';\nimport PropTypes from 'prop-types';\nimport { makeStyles } from '@material-ui/core';\n\nconst ext = '_round-blue-01.svg';\nconst iconForMot = {};\n[\n 'bus',\n 'ferry',\n 'gondola',\n 'tram',\n 'rail',\n 'funicular',\n 'cable_car',\n 'subway',\n].forEach((mot) => {\n iconForMot[mot] = lazy(() => {\n return import(`../../images/mots/${mot}${ext}`);\n });\n});\n\nconst useStyles = makeStyles((theme) => {\n return {\n flex: {\n display: 'flex',\n alignItems: 'center',\n },\n icon: {\n marginRight: theme.spacing(2),\n },\n };\n});\n\nfunction StopsFinderOption({ option }) {\n const classes = useStyles();\n\n return (\n <Suspense fallback={<div />}>\n <div className={classes.flex}>\n {Object.entries(option.properties.mot).map(([key, value]) => {\n if (value) {\n const MotIcon = iconForMot[key];\n return (\n <span className={classes.icon}>\n <MotIcon />\n </span>\n );\n }\n return <></>;\n })}\n <span>{option.properties.name}</span>\n </div>\n </Suspense>\n );\n}\n\nStopsFinderOption.propTypes = {\n option: PropTypes.object.isRequired,\n};\n\nexport default React.memo(StopsFinderOption);\n"],
|
|
5
|
+
"mappings": "AAAA,OAAO,SAAS,MAAM,gBAAgB;AACtC,OAAO,eAAe;AACtB,SAAS,kBAAkB;AAE3B,MAAM,MAAM;AACZ,MAAM,aAAa,CAAC;AACpB;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,EAAE,QAAQ,CAAC,QAAQ;AACjB,aAAW,OAAO,KAAK,MAAM;AAC3B,WAAO,OAAO,qBAAqB,MAAM;AAAA,EAC3C,CAAC;AACH,CAAC;AAED,MAAM,YAAY,WAAW,CAAC,UAAU;AACtC,SAAO;AAAA,IACL,MAAM;AAAA,MACJ,SAAS;AAAA,MACT,YAAY;AAAA,IACd;AAAA,IACA,MAAM;AAAA,MACJ,aAAa,MAAM,QAAQ,CAAC;AAAA,IAC9B;AAAA,EACF;AACF,CAAC;AAED,SAAS,kBAAkB,EAAE,OAAO,GAAG;AACrC,QAAM,UAAU,UAAU;AAE1B,SACE,oCAAC;AAAA,IAAS,UAAU,oCAAC,WAAI;AAAA,KACvB,oCAAC;AAAA,IAAI,WAAW,QAAQ;AAAA,KACrB,OAAO,QAAQ,OAAO,WAAW,GAAG,EAAE,IAAI,CAAC,CAAC,KAAK,KAAK,MAAM;AAC3D,QAAI,OAAO;AACT,YAAM,UAAU,WAAW;AAC3B,aACE,oCAAC;AAAA,QAAK,WAAW,QAAQ;AAAA,SACvB,oCAAC,aAAQ,CACX;AAAA,IAEJ;AACA,WAAO,wDAAE;AAAA,EACX,CAAC,GACD,oCAAC,cAAM,OAAO,WAAW,IAAK,CAChC,CACF;AAEJ;AAEA,kBAAkB,YAAY;AAAA,EAC5B,QAAQ,UAAU,OAAO;AAC3B;AAEA,eAAe,MAAM,KAAK,iBAAiB;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -1 +1,7 @@
|
|
|
1
|
-
{
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/StopsFinder/index.js"],
|
|
4
|
+
"sourcesContent": ["export { default } from './StopsFinder';\n"],
|
|
5
|
+
"mappings": "AAAA,wBAAwB;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -1,171 +1,116 @@
|
|
|
1
|
-
import React, { useState, useEffect, useCallback } from
|
|
2
|
-
import PropTypes from
|
|
3
|
-
import { IoIosSpeedometer } from
|
|
4
|
-
import { FaPlay, FaForward, FaBackward, FaRegDotCircle } from
|
|
5
|
-
import { TrackerLayer } from
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
var delta = 0.1;
|
|
1
|
+
import React, { useState, useEffect, useCallback } from "react";
|
|
2
|
+
import PropTypes from "prop-types";
|
|
3
|
+
import { IoIosSpeedometer } from "react-icons/io";
|
|
4
|
+
import { FaPlay, FaForward, FaBackward, FaRegDotCircle } from "react-icons/fa";
|
|
5
|
+
import { RealtimeLayer as TrackerLayer } from "mobility-toolbox-js/ol";
|
|
6
|
+
const increaseSpeed = (speed) => {
|
|
7
|
+
let delta = 0.1;
|
|
9
8
|
if (speed >= 1) {
|
|
10
9
|
delta = 1;
|
|
11
10
|
}
|
|
12
11
|
if (speed >= 10) {
|
|
13
12
|
delta = 5;
|
|
14
13
|
}
|
|
15
|
-
|
|
14
|
+
const nextSpeed = speed + delta;
|
|
16
15
|
return nextSpeed > 30 ? speed : nextSpeed;
|
|
17
16
|
};
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
var delta = 0.1;
|
|
17
|
+
const decreaseSpeed = (speed) => {
|
|
18
|
+
let delta = 0.1;
|
|
21
19
|
if (speed > 1) {
|
|
22
20
|
delta = 1;
|
|
23
21
|
}
|
|
24
22
|
if (speed > 10) {
|
|
25
23
|
delta = 5;
|
|
26
24
|
}
|
|
27
|
-
|
|
25
|
+
const nextSpeed = speed - delta;
|
|
28
26
|
if (nextSpeed < 0.1) {
|
|
29
27
|
return speed;
|
|
30
28
|
}
|
|
31
29
|
return nextSpeed;
|
|
32
30
|
};
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
31
|
+
const defaultRenderButton = (icon, onClick, title) => {
|
|
32
|
+
return /* @__PURE__ */ React.createElement("div", {
|
|
33
|
+
"aria-label": title,
|
|
34
|
+
role: "button",
|
|
35
|
+
onClick,
|
|
36
|
+
onKeyPress: onClick,
|
|
37
|
+
className: "rt-control-button",
|
|
38
|
+
tabIndex: 0,
|
|
39
|
+
title
|
|
40
|
+
}, icon);
|
|
41
41
|
};
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
var trackerLayer = ref.trackerLayer;
|
|
56
|
-
|
|
57
|
-
var ref$1 = useState(1);
|
|
58
|
-
var speed = ref$1[0];
|
|
59
|
-
var setSpeed = ref$1[1];
|
|
60
|
-
|
|
61
|
-
var onSpeedChange = useCallback(
|
|
62
|
-
function (newSpeed) {
|
|
42
|
+
function TrackerControl({
|
|
43
|
+
className,
|
|
44
|
+
iconDateReset,
|
|
45
|
+
iconSpeedDown,
|
|
46
|
+
iconSpeedReset,
|
|
47
|
+
iconSpeedUp,
|
|
48
|
+
iconSpeed,
|
|
49
|
+
renderButton,
|
|
50
|
+
trackerLayer
|
|
51
|
+
}) {
|
|
52
|
+
const [speed, setSpeed] = useState(1);
|
|
53
|
+
const onSpeedChange = useCallback(
|
|
54
|
+
(newSpeed) => {
|
|
63
55
|
if (trackerLayer) {
|
|
64
|
-
// eslint-disable-next-line no-param-reassign
|
|
65
56
|
trackerLayer.speed = newSpeed;
|
|
66
57
|
}
|
|
67
58
|
},
|
|
68
59
|
[trackerLayer]
|
|
69
60
|
);
|
|
70
|
-
|
|
71
|
-
var resetDate = function () {
|
|
61
|
+
const resetDate = () => {
|
|
72
62
|
trackerLayer.setCurrTime(new Date());
|
|
73
63
|
};
|
|
74
|
-
|
|
75
|
-
useEffect(function () {
|
|
64
|
+
useEffect(() => {
|
|
76
65
|
onSpeedChange(speed);
|
|
77
66
|
}, [speed, onSpeedChange]);
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
)
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
'speed up'
|
|
108
|
-
),
|
|
109
|
-
React.createElement( 'div', { className: "rt-tracker-speed" },
|
|
110
|
-
iconSpeed,
|
|
111
|
-
("" + (speed < 1 ? speed.toFixed(1) : speed))
|
|
112
|
-
)
|
|
113
|
-
)
|
|
114
|
-
);
|
|
67
|
+
return /* @__PURE__ */ React.createElement("div", {
|
|
68
|
+
className
|
|
69
|
+
}, renderButton(
|
|
70
|
+
iconDateReset,
|
|
71
|
+
() => {
|
|
72
|
+
return resetDate();
|
|
73
|
+
},
|
|
74
|
+
"reset date"
|
|
75
|
+
), renderButton(
|
|
76
|
+
iconSpeedDown,
|
|
77
|
+
() => {
|
|
78
|
+
return setSpeed(decreaseSpeed(speed));
|
|
79
|
+
},
|
|
80
|
+
"speed down"
|
|
81
|
+
), renderButton(
|
|
82
|
+
iconSpeedReset,
|
|
83
|
+
() => {
|
|
84
|
+
return setSpeed(1);
|
|
85
|
+
},
|
|
86
|
+
"speed reset"
|
|
87
|
+
), renderButton(
|
|
88
|
+
iconSpeedUp,
|
|
89
|
+
() => {
|
|
90
|
+
return setSpeed(increaseSpeed(speed));
|
|
91
|
+
},
|
|
92
|
+
"speed up"
|
|
93
|
+
), /* @__PURE__ */ React.createElement("div", {
|
|
94
|
+
className: "rt-tracker-speed"
|
|
95
|
+
}, iconSpeed, `${speed < 1 ? speed.toFixed(1) : speed}`));
|
|
115
96
|
}
|
|
116
|
-
|
|
117
97
|
TrackerControl.propTypes = {
|
|
118
|
-
/**
|
|
119
|
-
* CSS class of the tracker control.
|
|
120
|
-
*/
|
|
121
98
|
className: PropTypes.string,
|
|
122
|
-
|
|
123
|
-
/**
|
|
124
|
-
* Icon of the date reset button.
|
|
125
|
-
*/
|
|
126
99
|
iconDateReset: PropTypes.element,
|
|
127
|
-
|
|
128
|
-
/**
|
|
129
|
-
* Icon of the speed down button.
|
|
130
|
-
*/
|
|
131
100
|
iconSpeedDown: PropTypes.element,
|
|
132
|
-
|
|
133
|
-
/**
|
|
134
|
-
* Icon of the speed up button.
|
|
135
|
-
*/
|
|
136
101
|
iconSpeedUp: PropTypes.element,
|
|
137
|
-
|
|
138
|
-
/**
|
|
139
|
-
* Icon of the speed reset button.
|
|
140
|
-
*/
|
|
141
102
|
iconSpeedReset: PropTypes.element,
|
|
142
|
-
|
|
143
|
-
/**
|
|
144
|
-
* Icon speed.
|
|
145
|
-
*/
|
|
146
103
|
iconSpeed: PropTypes.element,
|
|
147
|
-
|
|
148
|
-
/**
|
|
149
|
-
* Render function for buttons.
|
|
150
|
-
*/
|
|
151
104
|
renderButton: PropTypes.func,
|
|
152
|
-
|
|
153
|
-
/**
|
|
154
|
-
* Trackerlayer.
|
|
155
|
-
*/
|
|
156
|
-
trackerLayer: PropTypes.instanceOf(TrackerLayer).isRequired,
|
|
105
|
+
trackerLayer: PropTypes.instanceOf(TrackerLayer).isRequired
|
|
157
106
|
};
|
|
158
|
-
|
|
159
107
|
TrackerControl.defaultProps = {
|
|
160
|
-
className:
|
|
161
|
-
iconDateReset: React.createElement(
|
|
162
|
-
iconSpeedDown: React.createElement(
|
|
163
|
-
iconSpeedReset: React.createElement(
|
|
164
|
-
iconSpeedUp: React.createElement(
|
|
165
|
-
iconSpeed: React.createElement(
|
|
166
|
-
renderButton: defaultRenderButton
|
|
108
|
+
className: "rt-tracker-control",
|
|
109
|
+
iconDateReset: /* @__PURE__ */ React.createElement(FaRegDotCircle, null),
|
|
110
|
+
iconSpeedDown: /* @__PURE__ */ React.createElement(FaBackward, null),
|
|
111
|
+
iconSpeedReset: /* @__PURE__ */ React.createElement(FaPlay, null),
|
|
112
|
+
iconSpeedUp: /* @__PURE__ */ React.createElement(FaForward, null),
|
|
113
|
+
iconSpeed: /* @__PURE__ */ React.createElement(IoIosSpeedometer, null),
|
|
114
|
+
renderButton: defaultRenderButton
|
|
167
115
|
};
|
|
168
|
-
|
|
169
116
|
export default TrackerControl;
|
|
170
|
-
|
|
171
|
-
//# sourceMappingURL=TrackerControl.js.map
|
|
@@ -1 +1,7 @@
|
|
|
1
|
-
{
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/TrackerControl/TrackerControl.js"],
|
|
4
|
+
"sourcesContent": ["import React, { useState, useEffect, useCallback } from 'react';\nimport PropTypes from 'prop-types';\nimport { IoIosSpeedometer } from 'react-icons/io';\nimport { FaPlay, FaForward, FaBackward, FaRegDotCircle } from 'react-icons/fa';\nimport { RealtimeLayer as TrackerLayer } from 'mobility-toolbox-js/ol';\n\nconst increaseSpeed = (speed) => {\n let delta = 0.1;\n if (speed >= 1) {\n delta = 1;\n }\n if (speed >= 10) {\n delta = 5;\n }\n const nextSpeed = speed + delta;\n return nextSpeed > 30 ? speed : nextSpeed;\n};\n\nconst decreaseSpeed = (speed) => {\n let delta = 0.1;\n if (speed > 1) {\n delta = 1;\n }\n if (speed > 10) {\n delta = 5;\n }\n const nextSpeed = speed - delta;\n if (nextSpeed < 0.1) {\n return speed;\n }\n return nextSpeed;\n};\n\nconst defaultRenderButton = (icon, onClick, title) => {\n return (\n <div\n aria-label={title}\n role=\"button\"\n onClick={onClick}\n onKeyPress={onClick}\n className=\"rt-control-button\"\n tabIndex={0}\n title={title}\n >\n {icon}\n </div>\n );\n};\n\n/**\n * TrackerControl allows the user to control the speed of a\n * [mobility-toolbox-js tracker layer](https://mobility-toolbox-js.geops.io/api/class/src/mapbox/layers/RealtimeLayer%20js~RealtimeLayer%20html-offset-anchor).\n */\nfunction TrackerControl({\n className,\n iconDateReset,\n iconSpeedDown,\n iconSpeedReset,\n iconSpeedUp,\n iconSpeed,\n renderButton,\n trackerLayer,\n}) {\n const [speed, setSpeed] = useState(1);\n\n const onSpeedChange = useCallback(\n (newSpeed) => {\n if (trackerLayer) {\n // eslint-disable-next-line no-param-reassign\n trackerLayer.speed = newSpeed;\n }\n },\n [trackerLayer],\n );\n\n const resetDate = () => {\n trackerLayer.setCurrTime(new Date());\n };\n\n useEffect(() => {\n onSpeedChange(speed);\n }, [speed, onSpeedChange]);\n\n return (\n <div className={className}>\n {renderButton(\n iconDateReset,\n () => {\n return resetDate();\n },\n 'reset date',\n )}\n {renderButton(\n iconSpeedDown,\n () => {\n return setSpeed(decreaseSpeed(speed));\n },\n 'speed down',\n )}\n {renderButton(\n iconSpeedReset,\n () => {\n return setSpeed(1);\n },\n 'speed reset',\n )}\n {renderButton(\n iconSpeedUp,\n () => {\n return setSpeed(increaseSpeed(speed));\n },\n 'speed up',\n )}\n <div className=\"rt-tracker-speed\">\n {iconSpeed}\n {`${speed < 1 ? speed.toFixed(1) : speed}`}\n </div>\n </div>\n );\n}\n\nTrackerControl.propTypes = {\n /**\n * CSS class of the tracker control.\n */\n className: PropTypes.string,\n\n /**\n * Icon of the date reset button.\n */\n iconDateReset: PropTypes.element,\n\n /**\n * Icon of the speed down button.\n */\n iconSpeedDown: PropTypes.element,\n\n /**\n * Icon of the speed up button.\n */\n iconSpeedUp: PropTypes.element,\n\n /**\n * Icon of the speed reset button.\n */\n iconSpeedReset: PropTypes.element,\n\n /**\n * Icon speed.\n */\n iconSpeed: PropTypes.element,\n\n /**\n * Render function for buttons.\n */\n renderButton: PropTypes.func,\n\n /**\n * Trackerlayer.\n */\n trackerLayer: PropTypes.instanceOf(TrackerLayer).isRequired,\n};\n\nTrackerControl.defaultProps = {\n className: 'rt-tracker-control',\n iconDateReset: <FaRegDotCircle />,\n iconSpeedDown: <FaBackward />,\n iconSpeedReset: <FaPlay />,\n iconSpeedUp: <FaForward />,\n iconSpeed: <IoIosSpeedometer />,\n renderButton: defaultRenderButton,\n};\n\nexport default TrackerControl;\n"],
|
|
5
|
+
"mappings": "AAAA,OAAO,SAAS,UAAU,WAAW,mBAAmB;AACxD,OAAO,eAAe;AACtB,SAAS,wBAAwB;AACjC,SAAS,QAAQ,WAAW,YAAY,sBAAsB;AAC9D,SAAS,iBAAiB,oBAAoB;AAE9C,MAAM,gBAAgB,CAAC,UAAU;AAC/B,MAAI,QAAQ;AACZ,MAAI,SAAS,GAAG;AACd,YAAQ;AAAA,EACV;AACA,MAAI,SAAS,IAAI;AACf,YAAQ;AAAA,EACV;AACA,QAAM,YAAY,QAAQ;AAC1B,SAAO,YAAY,KAAK,QAAQ;AAClC;AAEA,MAAM,gBAAgB,CAAC,UAAU;AAC/B,MAAI,QAAQ;AACZ,MAAI,QAAQ,GAAG;AACb,YAAQ;AAAA,EACV;AACA,MAAI,QAAQ,IAAI;AACd,YAAQ;AAAA,EACV;AACA,QAAM,YAAY,QAAQ;AAC1B,MAAI,YAAY,KAAK;AACnB,WAAO;AAAA,EACT;AACA,SAAO;AACT;AAEA,MAAM,sBAAsB,CAAC,MAAM,SAAS,UAAU;AACpD,SACE,oCAAC;AAAA,IACC,cAAY;AAAA,IACZ,MAAK;AAAA,IACL;AAAA,IACA,YAAY;AAAA,IACZ,WAAU;AAAA,IACV,UAAU;AAAA,IACV;AAAA,KAEC,IACH;AAEJ;AAMA,SAAS,eAAe;AAAA,EACtB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAAG;AACD,QAAM,CAAC,OAAO,QAAQ,IAAI,SAAS,CAAC;AAEpC,QAAM,gBAAgB;AAAA,IACpB,CAAC,aAAa;AACZ,UAAI,cAAc;AAEhB,qBAAa,QAAQ;AAAA,MACvB;AAAA,IACF;AAAA,IACA,CAAC,YAAY;AAAA,EACf;AAEA,QAAM,YAAY,MAAM;AACtB,iBAAa,YAAY,IAAI,KAAK,CAAC;AAAA,EACrC;AAEA,YAAU,MAAM;AACd,kBAAc,KAAK;AAAA,EACrB,GAAG,CAAC,OAAO,aAAa,CAAC;AAEzB,SACE,oCAAC;AAAA,IAAI;AAAA,KACF;AAAA,IACC;AAAA,IACA,MAAM;AACJ,aAAO,UAAU;AAAA,IACnB;AAAA,IACA;AAAA,EACF,GACC;AAAA,IACC;AAAA,IACA,MAAM;AACJ,aAAO,SAAS,cAAc,KAAK,CAAC;AAAA,IACtC;AAAA,IACA;AAAA,EACF,GACC;AAAA,IACC;AAAA,IACA,MAAM;AACJ,aAAO,SAAS,CAAC;AAAA,IACnB;AAAA,IACA;AAAA,EACF,GACC;AAAA,IACC;AAAA,IACA,MAAM;AACJ,aAAO,SAAS,cAAc,KAAK,CAAC;AAAA,IACtC;AAAA,IACA;AAAA,EACF,GACA,oCAAC;AAAA,IAAI,WAAU;AAAA,KACZ,WACA,GAAG,QAAQ,IAAI,MAAM,QAAQ,CAAC,IAAI,OACrC,CACF;AAEJ;AAEA,eAAe,YAAY;AAAA,EAIzB,WAAW,UAAU;AAAA,EAKrB,eAAe,UAAU;AAAA,EAKzB,eAAe,UAAU;AAAA,EAKzB,aAAa,UAAU;AAAA,EAKvB,gBAAgB,UAAU;AAAA,EAK1B,WAAW,UAAU;AAAA,EAKrB,cAAc,UAAU;AAAA,EAKxB,cAAc,UAAU,WAAW,YAAY,EAAE;AACnD;AAEA,eAAe,eAAe;AAAA,EAC5B,WAAW;AAAA,EACX,eAAe,oCAAC,oBAAe;AAAA,EAC/B,eAAe,oCAAC,gBAAW;AAAA,EAC3B,gBAAgB,oCAAC,YAAO;AAAA,EACxB,aAAa,oCAAC,eAAU;AAAA,EACxB,WAAW,oCAAC,sBAAiB;AAAA,EAC7B,cAAc;AAChB;AAEA,eAAe;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -1 +1,7 @@
|
|
|
1
|
-
{
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/TrackerControl/index.js"],
|
|
4
|
+
"sourcesContent": ["export { default } from './TrackerControl';\n"],
|
|
5
|
+
"mappings": "AAAA,wBAAwB;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|