qwc2 2025.10.9 → 2025.10.14
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/actions/display.js +30 -1
- package/actions/editing.js +22 -1
- package/actions/layerinfo.js +13 -1
- package/actions/layers.js +213 -3
- package/actions/localConfig.js +58 -1
- package/actions/locale.js +21 -1
- package/actions/locate.js +26 -1
- package/actions/logging.js +10 -1
- package/actions/map.js +105 -2
- package/actions/measurement.js +12 -1
- package/actions/processNotifications.js +37 -1
- package/actions/redlining.js +18 -1
- package/actions/redliningPick.js +12 -1
- package/actions/search.js +12 -1
- package/actions/serviceinfo.js +12 -1
- package/actions/task.js +55 -3
- package/actions/theme.js +339 -19
- package/actions/windows.js +164 -5
- package/components/AppMenu.js +435 -3
- package/components/AttributeForm.js +928 -32
- package/components/AttributeTableWidget.js +1105 -13
- package/components/AutoEditForm.js +189 -3
- package/components/CoordinateDisplayer.js +78 -2
- package/components/EditComboField.js +190 -6
- package/components/EditUploadField.js +315 -3
- package/components/ExportSelection.js +203 -2
- package/components/FullscreenSwitcher.js +90 -3
- package/components/Icon.js +81 -2
- package/components/IdentifyViewer.js +1161 -6
- package/components/ImportLayer.js +718 -20
- package/components/LayerInfoWindow.js +145 -2
- package/components/LinkFeatureForm.js +246 -5
- package/components/MapButton.js +88 -2
- package/components/MapSelection.js +287 -8
- package/components/MessageBar.js +68 -2
- package/components/NumericInputWindow.js +359 -2
- package/components/PickFeature.js +266 -2
- package/components/PluginsContainer.js +227 -8
- package/components/PrintSelection.js +620 -49
- package/components/ProcessNotifications.js +104 -2
- package/components/QtDesignerForm.js +1137 -18
- package/components/ResizeableWindow.js +591 -8
- package/components/SearchBox.js +1307 -20
- package/components/ServiceInfoWindow.js +107 -2
- package/components/SideBar.js +204 -4
- package/components/StandardApp.js +381 -20
- package/components/Swipeable.js +15 -1
- package/components/TaskBar.js +85 -2
- package/components/ThemeLayersListWindow.js +216 -4
- package/components/ThemeList.js +381 -7
- package/components/Toolbar.js +106 -2
- package/components/WindowManager.js +178 -2
- package/components/map/OlLayer.js +257 -6
- package/components/map/OlMap.js +405 -5
- package/components/map/layers/BingLayer.js +31 -2
- package/components/map/layers/GoogleLayer.js +222 -19
- package/components/map/layers/GraticuleLayer.js +21 -1
- package/components/map/layers/ImageLayer.js +15 -1
- package/components/map/layers/MVTLayer.js +52 -2
- package/components/map/layers/OSMLayer.js +24 -2
- package/components/map/layers/OverlayLayer.js +55 -3
- package/components/map/layers/VectorLayer.js +173 -8
- package/components/map/layers/WFSLayer.js +220 -6
- package/components/map/layers/WMSLayer.js +180 -6
- package/components/map/layers/WMTSLayer.js +67 -3
- package/components/map/layers/XYZLayer.js +24 -2
- package/components/map/layers/index.js +28 -1
- package/components/map3d/EditDataset3D.js +190 -3
- package/components/map3d/HeightProfile3D.js +402 -3
- package/components/map3d/ImportObjects3D.js +162 -2
- package/components/map3d/Map3D.js +1304 -38
- package/components/map3d/MapControls3D.js +392 -7
- package/components/map3d/SearchField3D.js +183 -11
- package/components/map3d/View3DSwitcher.js +98 -2
- package/components/map3d/drawtool/CreateTool3D.js +174 -4
- package/components/map3d/drawtool/EditTool3D.js +590 -6
- package/components/map3d/drawtool/NumericInput3D.js +336 -4
- package/components/map3d/layers/GeoTIFFLayer3D.js +15 -1
- package/components/map3d/layers/VectorLayer3D.js +53 -2
- package/components/map3d/layers/WFSLayer3D.js +109 -3
- package/components/map3d/layers/WMSLayer3D.js +70 -2
- package/components/map3d/layers/WMTSLayer3D.js +27 -3
- package/components/map3d/layers/index.js +14 -1
- package/components/map3d/utils/FirstPersonControls3D.js +423 -16
- package/components/map3d/utils/MiscUtils3D.js +221 -13
- package/components/map3d/utils/OrbitControls3D.js +176 -5
- package/components/map3d/utils/Tiles3DStyle.js +238 -9
- package/components/share/ShareLink.js +54 -2
- package/components/share/ShareQRCode.js +62 -2
- package/components/share/ShareSocials.js +125 -3
- package/components/timeline/FixedTimeline.js +236 -5
- package/components/timeline/InfiniteTimeline.js +347 -8
- package/components/timeline/TimelineFeaturesSlider.js +439 -5
- package/components/widgets/AccordeonWidget.js +96 -2
- package/components/widgets/ButtonBar.js +124 -2
- package/components/widgets/ColorButton.js +201 -3
- package/components/widgets/ComboBox.js +166 -2
- package/components/widgets/CopyButton.js +110 -2
- package/components/widgets/DateTimeInput.js +100 -3
- package/components/widgets/EditableSelect.js +230 -3
- package/components/widgets/FileSelector.js +128 -4
- package/components/widgets/Input.js +124 -2
- package/components/widgets/InputContainer.js +96 -2
- package/components/widgets/LayerCatalogWidget.js +219 -3
- package/components/widgets/MenuButton.js +157 -1
- package/components/widgets/ModalDialog.js +64 -2
- package/components/widgets/NavBar.js +119 -2
- package/components/widgets/NumberInput.js +226 -4
- package/components/widgets/PopupMenu.js +72 -1
- package/components/widgets/Primitives.js +6 -1
- package/components/widgets/ReCaptchaWidget.js +55 -1
- package/components/widgets/SearchWidget.js +255 -2
- package/components/widgets/Spinner.js +44 -2
- package/components/widgets/SuggestionInput.js +77 -2
- package/components/widgets/TextInput.js +308 -2
- package/components/widgets/ToggleSwitch.js +85 -2
- package/components/widgets/VectorLayerPicker.js +85 -3
- package/libs/openlayers.js +225 -5
- package/package.json +1 -1
- package/plugins/API.js +358 -15
- package/plugins/AttributeTable.js +109 -3
- package/plugins/Authentication.js +130 -5
- package/plugins/BackgroundSwitcher.js +218 -4
- package/plugins/Bookmark.js +289 -3
- package/plugins/BottomBar.js +298 -4
- package/plugins/CookiePopup.js +67 -3
- package/plugins/Cyclomedia.js +442 -5
- package/plugins/Editing.js +497 -9
- package/plugins/FeatureForm.js +366 -4
- package/plugins/FeatureSearch.js +458 -3
- package/plugins/GeometryDigitizer.js +664 -7
- package/plugins/HeightProfile.js +763 -15
- package/plugins/Help.js +102 -3
- package/plugins/HomeButton.js +80 -3
- package/plugins/Identify.js +543 -5
- package/plugins/LayerCatalog.js +215 -4
- package/plugins/LayerTree.js +1194 -6
- package/plugins/LocateButton.js +94 -3
- package/plugins/Map.js +320 -16
- package/plugins/MapCompare.js +94 -3
- package/plugins/MapCopyright.js +127 -5
- package/plugins/MapExport.js +613 -20
- package/plugins/MapFilter.js +868 -12
- package/plugins/MapInfoTooltip.js +277 -3
- package/plugins/MapLegend.js +253 -4
- package/plugins/MapTip.js +290 -4
- package/plugins/Measure.js +220 -4
- package/plugins/NewsPopup.js +137 -3
- package/plugins/OverviewMap.js +167 -7
- package/plugins/Panoramax.js +340 -2
- package/plugins/Portal.js +199 -4
- package/plugins/Print.js +1231 -15
- package/plugins/Redlining.js +750 -6
- package/plugins/Reports.js +332 -3
- package/plugins/Routing.js +1278 -15
- package/plugins/ScratchDrawing.js +173 -5
- package/plugins/Settings.js +241 -4
- package/plugins/Share.js +198 -3
- package/plugins/StartupMarker.js +84 -4
- package/plugins/TaskButton.js +88 -3
- package/plugins/ThemeSwitcher.js +164 -4
- package/plugins/TimeManager.js +971 -10
- package/plugins/TopBar.js +300 -7
- package/plugins/TourGuide.js +213 -2
- package/plugins/ValueTool.js +419 -4
- package/plugins/View3D.js +519 -14
- package/plugins/ZoomButtons.js +165 -3
- package/plugins/map/EditingSupport.js +199 -7
- package/plugins/map/LocateSupport.js +260 -4
- package/plugins/map/MeasurementSupport.js +216 -8
- package/plugins/map/RedliningPickSupport.js +201 -7
- package/plugins/map/RedliningSupport.js +726 -17
- package/plugins/map/SnapInteraction.js +101 -1
- package/plugins/map/SnapSupport.js +210 -2
- package/plugins/map/SnappingSupport.js +356 -17
- package/plugins/map3d/BackgroundSwitcher3D.js +44 -3
- package/plugins/map3d/BottomBar3D.js +118 -3
- package/plugins/map3d/Compare3D.js +422 -8
- package/plugins/map3d/Draw3D.js +353 -6
- package/plugins/map3d/ExportObjects3D.js +393 -18
- package/plugins/map3d/HideObjects3D.js +313 -12
- package/plugins/map3d/Identify3D.js +283 -12
- package/plugins/map3d/LayerTree3D.js +323 -3
- package/plugins/map3d/MapCopyright3D.js +128 -5
- package/plugins/map3d/MapExport3D.js +590 -10
- package/plugins/map3d/MapLight3D.js +553 -6
- package/plugins/map3d/Measure3D.js +571 -20
- package/plugins/map3d/OverviewMap3D.js +169 -3
- package/plugins/map3d/Settings3D.js +73 -3
- package/plugins/map3d/TopBar3D.js +207 -9
- package/plugins/redlining/RedliningBufferSupport.js +206 -3
- package/reducers/display.js +34 -2
- package/reducers/editing.js +68 -3
- package/reducers/index.js +9 -1
- package/reducers/layerinfo.js +26 -2
- package/reducers/layers.js +456 -9
- package/reducers/localConfig.js +122 -2
- package/reducers/locale.js +38 -2
- package/reducers/locate.js +40 -2
- package/reducers/map.js +176 -5
- package/reducers/measurement.js +42 -2
- package/reducers/processNotifications.js +49 -2
- package/reducers/redlining.js +50 -2
- package/reducers/redliningPick.js +27 -2
- package/reducers/search.js +20 -1
- package/reducers/serviceinfo.js +25 -2
- package/reducers/task.js +45 -2
- package/reducers/theme.js +51 -2
- package/reducers/windows.js +203 -2
- package/scripts/dist.sh +1 -1
- package/scripts/gen-plugin-docs.js +152 -2
- package/scripts/makeIconkit.js +85 -6
- package/scripts/themesConfig.js +742 -40
- package/scripts/updateTranslations.js +251 -10
- package/selectors/searchproviders.js +44 -2
- package/stores/StandardStore.js +42 -2
- package/utils/ConfigUtils.js +84 -3
- package/utils/CoordinatesUtils.js +234 -23
- package/utils/DxfUtils.js +237 -11
- package/utils/EditingInterface.js +421 -87
- package/utils/EditingUtils.js +357 -13
- package/utils/ElevationInterface.js +83 -22
- package/utils/FeatureStyles.js +429 -5
- package/utils/IdentifyUtils.js +443 -7
- package/utils/ImageEditor.js +79 -9
- package/utils/LayerUtils.js +1516 -50
- package/utils/LocaleUtils.js +117 -7
- package/utils/MapUtils.js +241 -59
- package/utils/MeasureUtils.js +323 -2
- package/utils/MiscUtils.js +189 -11
- package/utils/PermaLinkUtils.js +429 -6
- package/utils/PluginStore.js +27 -1
- package/utils/ResourceRegistry.js +15 -1
- package/utils/RoutingInterface.js +307 -7
- package/utils/SearchProviders.js +722 -19
- package/utils/ServiceLayerUtils.js +669 -14
- package/utils/Signal.js +32 -2
- package/utils/ThemeUtils.js +341 -7
- package/utils/VectorLayerUtils.js +589 -15
- package/utils/expr_grammar/grammar.js +2239 -2
- package/utils/expr_grammar/test.js +65 -3
|
@@ -1,13 +1,292 @@
|
|
|
1
|
-
function _typeof(o){"@babel/helpers - typeof";return _typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(o){
|
|
1
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
2
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
3
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
4
|
+
function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); }
|
|
5
|
+
function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } }
|
|
6
|
+
function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; }
|
|
7
|
+
function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }
|
|
8
|
+
function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); }
|
|
9
|
+
function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; }
|
|
10
|
+
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
|
|
11
|
+
function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); }
|
|
12
|
+
function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); }
|
|
13
|
+
function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); }
|
|
14
|
+
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
|
|
15
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
|
|
16
|
+
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
17
|
+
/**
|
|
2
18
|
* Copyright 2024 Sourcepole AG
|
|
3
19
|
* All rights reserved.
|
|
4
20
|
*
|
|
5
21
|
* This source code is licensed under the BSD-style license found in the
|
|
6
22
|
* LICENSE file in the root directory of this source tree.
|
|
7
|
-
*/
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
23
|
+
*/
|
|
24
|
+
|
|
25
|
+
import React from 'react';
|
|
26
|
+
import { connect } from 'react-redux';
|
|
27
|
+
import ol from 'openlayers';
|
|
28
|
+
import PropTypes from 'prop-types';
|
|
29
|
+
import FeatureStyles from '../utils/FeatureStyles';
|
|
30
|
+
import MapUtils from '../utils/MapUtils';
|
|
31
|
+
import MeasureUtils from '../utils/MeasureUtils';
|
|
32
|
+
var MapSelection = /*#__PURE__*/function (_React$Component) {
|
|
33
|
+
function MapSelection(props) {
|
|
34
|
+
var _this;
|
|
35
|
+
_classCallCheck(this, MapSelection);
|
|
36
|
+
_this = _callSuper(this, MapSelection, [props]);
|
|
37
|
+
_defineProperty(_this, "state", {
|
|
38
|
+
geometry: null,
|
|
39
|
+
modifiers: {
|
|
40
|
+
alt: false,
|
|
41
|
+
ctrl: false,
|
|
42
|
+
shift: false
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
_defineProperty(_this, "addDrawInteraction", function () {
|
|
46
|
+
// cleanup old interaction
|
|
47
|
+
if (_this.drawInteraction) {
|
|
48
|
+
_this.removeDrawInteraction();
|
|
49
|
+
}
|
|
50
|
+
if (_this.props.geomType === "DragBox") {
|
|
51
|
+
_this.drawInteraction = new ol.interaction.DragBox({
|
|
52
|
+
className: 'selection-drag-box',
|
|
53
|
+
condition: _this.props.drawCondition
|
|
54
|
+
});
|
|
55
|
+
_this.drawInteraction.on('boxend', function () {
|
|
56
|
+
_this.updateSelectionState(_this.drawInteraction.getGeometry());
|
|
57
|
+
});
|
|
58
|
+
} else {
|
|
59
|
+
var typeMap = {
|
|
60
|
+
Point: "Point",
|
|
61
|
+
LineString: "LineString",
|
|
62
|
+
Polygon: "Polygon",
|
|
63
|
+
Circle: "Circle",
|
|
64
|
+
Box: "Circle"
|
|
65
|
+
};
|
|
66
|
+
if (!typeMap[_this.props.geomType]) {
|
|
67
|
+
// Unknown geom type
|
|
68
|
+
return;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
// create an interaction to draw with
|
|
72
|
+
_this.drawInteraction = new ol.interaction.Draw({
|
|
73
|
+
stopClick: true,
|
|
74
|
+
source: _this.selectionLayer.getSource(),
|
|
75
|
+
condition: _this.props.drawCondition,
|
|
76
|
+
type: typeMap[_this.props.geomType],
|
|
77
|
+
style: function style(feature) {
|
|
78
|
+
return FeatureStyles[_this.props.styleName](feature, _objectSpread(_objectSpread({}, _this.props.styleOptions), {}, {
|
|
79
|
+
circleRadius: 0
|
|
80
|
+
}));
|
|
81
|
+
},
|
|
82
|
+
geometryFunction: _this.props.geomType === "Box" ? ol.interaction.createBox() : undefined
|
|
83
|
+
});
|
|
84
|
+
_this.drawInteraction.on('drawstart', function (evt) {
|
|
85
|
+
// clear previous sketches
|
|
86
|
+
_this.selectionLayer.getSource().clear();
|
|
87
|
+
evt.feature.on('change', function () {
|
|
88
|
+
return _this.updateMeasurements(evt.feature);
|
|
89
|
+
});
|
|
90
|
+
}, _this);
|
|
91
|
+
_this.drawInteraction.on('drawend', function (evt) {
|
|
92
|
+
_this.updateSelectionState(evt.feature.getGeometry());
|
|
93
|
+
}, _this);
|
|
94
|
+
}
|
|
95
|
+
_this.map.addInteraction(_this.drawInteraction);
|
|
96
|
+
window.addEventListener('keydown', _this.checkModifier);
|
|
97
|
+
window.addEventListener('keyup', _this.checkModifier);
|
|
98
|
+
if (_this.props.cursor) {
|
|
99
|
+
_this.map.getViewport().style.cursor = _this.props.cursor;
|
|
100
|
+
}
|
|
101
|
+
});
|
|
102
|
+
_defineProperty(_this, "removeDrawInteraction", function () {
|
|
103
|
+
if (_this.drawInteraction !== null) {
|
|
104
|
+
_this.map.removeInteraction(_this.drawInteraction);
|
|
105
|
+
_this.drawInteraction = null;
|
|
106
|
+
}
|
|
107
|
+
window.removeEventListener('keydown', _this.checkModifier);
|
|
108
|
+
window.removeEventListener('keyup', _this.checkModifier);
|
|
109
|
+
_this.map.getViewport().style.cursor = '';
|
|
110
|
+
});
|
|
111
|
+
_defineProperty(_this, "checkModifier", function (ev) {
|
|
112
|
+
var down = ev.type === "keydown";
|
|
113
|
+
_this.setState(function (state) {
|
|
114
|
+
return {
|
|
115
|
+
modifiers: {
|
|
116
|
+
alt: ev.key === 'Alt' ? down : state.modifiers.alt,
|
|
117
|
+
ctrl: ev.key === 'Control' ? down : state.modifiers.ctrl,
|
|
118
|
+
shift: ev.key === 'Shift' ? down : state.modifiers.shift
|
|
119
|
+
}
|
|
120
|
+
};
|
|
121
|
+
});
|
|
122
|
+
});
|
|
123
|
+
_defineProperty(_this, "updateSelectionState", function (geometry) {
|
|
124
|
+
if (!geometry) {
|
|
125
|
+
return;
|
|
126
|
+
}
|
|
127
|
+
var coords = _this.props.geomType === 'Circle' ? null : geometry.getCoordinates();
|
|
128
|
+
if (_this.props.geomType === "Circle") {
|
|
129
|
+
// Also store poligonized circle
|
|
130
|
+
var center = geometry.getCenter();
|
|
131
|
+
var radius = geometry.getRadius();
|
|
132
|
+
var deg2rad = Math.PI / 180;
|
|
133
|
+
var polycords = [Array.apply(null, Array(91)).map(function (item, index) {
|
|
134
|
+
return [center[0] + radius * Math.cos(4 * index * deg2rad), center[1] + radius * Math.sin(4 * index * deg2rad)];
|
|
135
|
+
})];
|
|
136
|
+
_this.setState({
|
|
137
|
+
geometry: {
|
|
138
|
+
type: "Polygon",
|
|
139
|
+
coordinates: polycords,
|
|
140
|
+
center: center,
|
|
141
|
+
radius: radius
|
|
142
|
+
}
|
|
143
|
+
});
|
|
144
|
+
} else if (_this.props.geomType === "DragBox" || _this.props.geomType === "Box") {
|
|
145
|
+
var boxcoords = [[Math.min(coords[0][0][0], coords[0][2][0]), Math.min(coords[0][0][1], coords[0][2][1]), Math.max(coords[0][0][0], coords[0][2][0]), Math.max(coords[0][0][1], coords[0][2][1])]];
|
|
146
|
+
_this.setState({
|
|
147
|
+
geometry: {
|
|
148
|
+
type: "Polygon",
|
|
149
|
+
coordinates: boxcoords
|
|
150
|
+
}
|
|
151
|
+
});
|
|
152
|
+
} else {
|
|
153
|
+
_this.setState({
|
|
154
|
+
geometry: {
|
|
155
|
+
type: _this.props.geomType,
|
|
156
|
+
coordinates: coords
|
|
157
|
+
}
|
|
158
|
+
});
|
|
159
|
+
}
|
|
160
|
+
});
|
|
161
|
+
_defineProperty(_this, "updateMeasurements", function (feature) {
|
|
162
|
+
if (!_this.props.measure) {
|
|
163
|
+
return;
|
|
164
|
+
}
|
|
165
|
+
var settings = {
|
|
166
|
+
lenUnit: 'metric',
|
|
167
|
+
areaUnit: 'metric'
|
|
168
|
+
};
|
|
169
|
+
MeasureUtils.updateFeatureMeasurements(feature, _this.props.geomType, _this.props.projection, settings);
|
|
170
|
+
});
|
|
171
|
+
_this.drawInteraction = null;
|
|
172
|
+
_this.map = MapUtils.getHook(MapUtils.GET_MAP);
|
|
173
|
+
|
|
174
|
+
// create a layer to draw on
|
|
175
|
+
_this.selectionLayer = new ol.layer.Vector({
|
|
176
|
+
source: new ol.source.Vector(),
|
|
177
|
+
zIndex: 1000000,
|
|
178
|
+
style: function style(feature) {
|
|
179
|
+
return FeatureStyles[_this.props.styleName](feature, _this.props.styleOptions);
|
|
180
|
+
}
|
|
181
|
+
});
|
|
182
|
+
_this.selectionLayer.setVisible(!_this.props.hideGeometry);
|
|
183
|
+
return _this;
|
|
184
|
+
}
|
|
185
|
+
_inherits(MapSelection, _React$Component);
|
|
186
|
+
return _createClass(MapSelection, [{
|
|
187
|
+
key: "componentDidMount",
|
|
188
|
+
value: function componentDidMount() {
|
|
189
|
+
this.map.addLayer(this.selectionLayer);
|
|
190
|
+
if (this.props.active) {
|
|
191
|
+
this.addDrawInteraction();
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
}, {
|
|
195
|
+
key: "componentDidUpdate",
|
|
196
|
+
value: function componentDidUpdate(prevProps, prevState) {
|
|
197
|
+
if (this.props.hideGeometry !== prevProps.hideGeometry) {
|
|
198
|
+
this.selectionLayer.setVisible(!this.props.hideGeometry);
|
|
199
|
+
}
|
|
200
|
+
if (this.props.geomType !== prevProps.geomType) {
|
|
201
|
+
this.selectionLayer.getSource().clear();
|
|
202
|
+
}
|
|
203
|
+
if (this.props.active && !prevProps.active || this.props.active && this.props.geomType !== prevProps.geomType) {
|
|
204
|
+
this.addDrawInteraction();
|
|
205
|
+
} else if (!this.props.active && prevProps.active) {
|
|
206
|
+
this.removeDrawInteraction();
|
|
207
|
+
}
|
|
208
|
+
if (this.state.geometry !== prevState.geometry) {
|
|
209
|
+
if (this.state.geometry !== this.props.geometry) {
|
|
210
|
+
this.props.geometryChanged(this.state.geometry, _objectSpread({}, this.state.modifiers));
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
if (this.props.geometry !== prevProps.geometry && this.props.geometry !== this.state.geometry) {
|
|
214
|
+
if (!this.props.geometry) {
|
|
215
|
+
this.selectionLayer.getSource().clear();
|
|
216
|
+
} else {
|
|
217
|
+
var feature = this.selectionLayer.getSource().getFeatures()[0];
|
|
218
|
+
if (!feature) {
|
|
219
|
+
feature = new ol.Feature();
|
|
220
|
+
this.selectionLayer.getSource().addFeature(feature);
|
|
221
|
+
}
|
|
222
|
+
if (this.props.geometry.type === "Point") {
|
|
223
|
+
feature.setGeometry(new ol.geom.Point(this.props.geometry.coordinates));
|
|
224
|
+
} else if (this.props.geometry.type === "MultiPoint") {
|
|
225
|
+
feature.setGeometry(new ol.geom.Multi(this.props.geometry.coordinates));
|
|
226
|
+
} else if (this.props.geometry.type === "LineString") {
|
|
227
|
+
feature.setGeometry(new ol.geom.LineString(this.props.geometry.coordinates));
|
|
228
|
+
} else if (this.props.geometry.type === "MultiLineString") {
|
|
229
|
+
feature.setGeometry(new ol.geom.MultiLineString(this.props.geometry.coordinates));
|
|
230
|
+
} else if (this.props.geometry.type === "Polygon") {
|
|
231
|
+
if (this.props.geometry.center && this.props.geometry.radius) {
|
|
232
|
+
feature.setGeometry(new ol.geom.Circle(this.props.geometry.center, this.props.geometry.radius));
|
|
233
|
+
} else {
|
|
234
|
+
feature.setGeometry(new ol.geom.Polygon(this.props.geometry.coordinates));
|
|
235
|
+
}
|
|
236
|
+
} else if (this.props.geometry.type === "MultiPolygon") {
|
|
237
|
+
feature.setGeometry(new ol.geom.MultiPolygon(this.props.geometry.coordinates));
|
|
238
|
+
}
|
|
239
|
+
this.setState({
|
|
240
|
+
geometry: this.props.geometry
|
|
241
|
+
});
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
}, {
|
|
246
|
+
key: "componentWillUnmount",
|
|
247
|
+
value: function componentWillUnmount() {
|
|
248
|
+
this.map.removeLayer(this.selectionLayer);
|
|
249
|
+
this.removeDrawInteraction();
|
|
250
|
+
}
|
|
251
|
+
}, {
|
|
252
|
+
key: "render",
|
|
253
|
+
value: function render() {
|
|
254
|
+
return null;
|
|
255
|
+
}
|
|
256
|
+
}]);
|
|
257
|
+
}(React.Component);
|
|
258
|
+
_defineProperty(MapSelection, "propTypes", {
|
|
259
|
+
/** Whether the selection tool is active */
|
|
260
|
+
active: PropTypes.bool,
|
|
261
|
+
/** Optional, a css-cursor to use when drawing */
|
|
262
|
+
cursor: PropTypes.string,
|
|
263
|
+
/** The draw interaction condition. */
|
|
264
|
+
drawCondition: PropTypes.func,
|
|
265
|
+
/** The selection geometry type (Point, LineString, Polygon, Circle, DragBox, Box) */
|
|
266
|
+
geomType: PropTypes.string,
|
|
267
|
+
/** Initial geometry or geometry to update. */
|
|
268
|
+
geometry: PropTypes.object,
|
|
269
|
+
/** The callback which is invoked with a drawn geometry. */
|
|
270
|
+
geometryChanged: PropTypes.func,
|
|
271
|
+
/** Whether to hide the current selection (except while drawing). */
|
|
272
|
+
hideGeometry: PropTypes.bool,
|
|
273
|
+
/** Whether to show measurements while drawing. */
|
|
274
|
+
measure: PropTypes.bool,
|
|
275
|
+
projection: PropTypes.string,
|
|
276
|
+
/** Optional: the selection feature style name. */
|
|
277
|
+
styleName: PropTypes.string,
|
|
278
|
+
/** Optional: the selection feature style options. */
|
|
279
|
+
styleOptions: PropTypes.object
|
|
280
|
+
});
|
|
281
|
+
_defineProperty(MapSelection, "defaultProps", {
|
|
282
|
+
drawCondition: function drawCondition(event) {
|
|
283
|
+
return event.originalEvent.buttons === 1;
|
|
284
|
+
},
|
|
285
|
+
styleName: 'default',
|
|
286
|
+
styleOptions: {}
|
|
287
|
+
});
|
|
288
|
+
export default connect(function (state) {
|
|
289
|
+
return {
|
|
290
|
+
projection: state.map.projection
|
|
291
|
+
};
|
|
292
|
+
}, {})(MapSelection);
|
package/components/MessageBar.js
CHANGED
|
@@ -1,7 +1,73 @@
|
|
|
1
|
-
function _typeof(o){"@babel/helpers - typeof";return _typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(o){
|
|
1
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
2
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
3
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
4
|
+
function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); }
|
|
5
|
+
function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } }
|
|
6
|
+
function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; }
|
|
7
|
+
function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }
|
|
8
|
+
function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); }
|
|
9
|
+
function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; }
|
|
10
|
+
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
|
|
11
|
+
function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); }
|
|
12
|
+
function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); }
|
|
13
|
+
function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); }
|
|
14
|
+
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
|
|
15
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
|
|
16
|
+
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
17
|
+
/**
|
|
2
18
|
* Copyright 2025 Sourcepole AG
|
|
3
19
|
* All rights reserved.
|
|
4
20
|
*
|
|
5
21
|
* This source code is licensed under the BSD-style license found in the
|
|
6
22
|
* LICENSE file in the root directory of this source tree.
|
|
7
|
-
*/
|
|
23
|
+
*/
|
|
24
|
+
|
|
25
|
+
import React from 'react';
|
|
26
|
+
import ReactDOM from 'react-dom';
|
|
27
|
+
import PropTypes from 'prop-types';
|
|
28
|
+
import { MapContainerPortalContext } from '../components/PluginsContainer';
|
|
29
|
+
import Icon from './Icon';
|
|
30
|
+
import './style/MessageBar.css';
|
|
31
|
+
var MessageBar = /*#__PURE__*/function (_React$Component) {
|
|
32
|
+
function MessageBar() {
|
|
33
|
+
var _this;
|
|
34
|
+
_classCallCheck(this, MessageBar);
|
|
35
|
+
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
36
|
+
args[_key] = arguments[_key];
|
|
37
|
+
}
|
|
38
|
+
_this = _callSuper(this, MessageBar, [].concat(args));
|
|
39
|
+
_defineProperty(_this, "renderRole", function (role) {
|
|
40
|
+
var children = typeof _this.props.children === "function" ? _this.props.children() : React.Children.toArray(_this.props.children).reduce(function (res, child) {
|
|
41
|
+
return _objectSpread(_objectSpread({}, res), {}, _defineProperty({}, child.props.role, child));
|
|
42
|
+
}, {});
|
|
43
|
+
return children[role];
|
|
44
|
+
});
|
|
45
|
+
return _this;
|
|
46
|
+
}
|
|
47
|
+
_inherits(MessageBar, _React$Component);
|
|
48
|
+
return _createClass(MessageBar, [{
|
|
49
|
+
key: "render",
|
|
50
|
+
value: function render() {
|
|
51
|
+
return /*#__PURE__*/ReactDOM.createPortal(/*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement("div", {
|
|
52
|
+
className: "messagebar-container"
|
|
53
|
+
}, /*#__PURE__*/React.createElement("div", {
|
|
54
|
+
className: "messagebar"
|
|
55
|
+
}, /*#__PURE__*/React.createElement("div", {
|
|
56
|
+
className: "body"
|
|
57
|
+
}, this.renderRole("body")), this.props.onClose ? /*#__PURE__*/React.createElement("span", {
|
|
58
|
+
className: "closewrapper"
|
|
59
|
+
}, /*#__PURE__*/React.createElement(Icon, {
|
|
60
|
+
className: "close",
|
|
61
|
+
icon: "remove",
|
|
62
|
+
onClick: this.props.onClose,
|
|
63
|
+
size: "large"
|
|
64
|
+
})) : null)), this.renderRole("extra")), this.context);
|
|
65
|
+
}
|
|
66
|
+
}]);
|
|
67
|
+
}(React.Component);
|
|
68
|
+
_defineProperty(MessageBar, "contextType", MapContainerPortalContext);
|
|
69
|
+
_defineProperty(MessageBar, "propTypes", {
|
|
70
|
+
children: PropTypes.oneOfType([PropTypes.node, PropTypes.func]),
|
|
71
|
+
onClose: PropTypes.func
|
|
72
|
+
});
|
|
73
|
+
export { MessageBar as default };
|