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
package/plugins/ValueTool.js
CHANGED
|
@@ -1,11 +1,426 @@
|
|
|
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 _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); }
|
|
5
|
+
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
6
|
+
function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); }
|
|
7
|
+
function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); }
|
|
8
|
+
function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
|
|
9
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
10
|
+
function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
|
|
11
|
+
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
|
|
12
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
13
|
+
function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
|
|
14
|
+
function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); }
|
|
15
|
+
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); } }
|
|
16
|
+
function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; }
|
|
17
|
+
function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }
|
|
18
|
+
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); }
|
|
19
|
+
function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; }
|
|
20
|
+
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
|
|
21
|
+
function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); }
|
|
22
|
+
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); }
|
|
23
|
+
function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); }
|
|
24
|
+
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; }
|
|
25
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
|
|
26
|
+
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); }
|
|
27
|
+
/**
|
|
2
28
|
* Copyright 2025 Sourcepole AG
|
|
3
29
|
* All rights reserved.
|
|
4
30
|
*
|
|
5
31
|
* This source code is licensed under the BSD-style license found in the
|
|
6
32
|
* LICENSE file in the root directory of this source tree.
|
|
7
|
-
*/
|
|
33
|
+
*/
|
|
34
|
+
|
|
35
|
+
import React from 'react';
|
|
36
|
+
import { Line } from 'react-chartjs-2';
|
|
37
|
+
import { connect } from 'react-redux';
|
|
38
|
+
import isEmpty from 'lodash.isempty';
|
|
39
|
+
import PropTypes from 'prop-types';
|
|
40
|
+
import { v4 as uuidv4 } from 'uuid';
|
|
41
|
+
import { LayerRole } from '../actions/layers';
|
|
42
|
+
import { setCurrentTask } from '../actions/task';
|
|
43
|
+
import Icon from '../components/Icon';
|
|
44
|
+
import ResizeableWindow from '../components/ResizeableWindow';
|
|
45
|
+
import ButtonBar from '../components/widgets/ButtonBar';
|
|
46
|
+
import NumberInput from '../components/widgets/NumberInput';
|
|
47
|
+
import TextInput from '../components/widgets/TextInput';
|
|
48
|
+
import IdentifyUtils from '../utils/IdentifyUtils';
|
|
49
|
+
import LayerUtils from '../utils/LayerUtils';
|
|
50
|
+
import LocaleUtils from '../utils/LocaleUtils';
|
|
51
|
+
import MapUtils from '../utils/MapUtils';
|
|
52
|
+
import './style/ValueTool.css';
|
|
53
|
+
|
|
54
|
+
/**
|
|
8
55
|
* Displays raster band values of active raster layers at the hovered mouse position,
|
|
9
56
|
* queried via GetFeatureInfo.
|
|
10
|
-
*/
|
|
11
|
-
|
|
57
|
+
*/
|
|
58
|
+
var ValueTool = /*#__PURE__*/function (_React$Component) {
|
|
59
|
+
function ValueTool(props) {
|
|
60
|
+
var _this;
|
|
61
|
+
_classCallCheck(this, ValueTool);
|
|
62
|
+
_this = _callSuper(this, ValueTool, [props]);
|
|
63
|
+
_defineProperty(_this, "renderTableTab", function () {
|
|
64
|
+
if (isEmpty(_this.state.values)) {
|
|
65
|
+
return /*#__PURE__*/React.createElement("span", null, /*#__PURE__*/React.createElement("i", null, LocaleUtils.tr("valuetool.nodata")));
|
|
66
|
+
}
|
|
67
|
+
return /*#__PURE__*/React.createElement("table", {
|
|
68
|
+
className: "valuetool-table"
|
|
69
|
+
}, /*#__PURE__*/React.createElement("tbody", null, Object.entries(_this.state.values).map(function (_ref) {
|
|
70
|
+
var _ref2 = _slicedToArray(_ref, 2),
|
|
71
|
+
key = _ref2[0],
|
|
72
|
+
data = _ref2[1];
|
|
73
|
+
var bandvals = Object.entries(data.values);
|
|
74
|
+
if (_this.state.selectedBands[key]) {
|
|
75
|
+
var activeBands = _this.state.selectedBands[key].split(",").map(function (x) {
|
|
76
|
+
return parseInt(x.trim(), 10) - 1;
|
|
77
|
+
});
|
|
78
|
+
bandvals = bandvals.filter(function (_, i) {
|
|
79
|
+
return activeBands.includes(i);
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
return [/*#__PURE__*/React.createElement("tr", {
|
|
83
|
+
key: key
|
|
84
|
+
}, /*#__PURE__*/React.createElement("th", {
|
|
85
|
+
colSpan: "2"
|
|
86
|
+
}, data.layertitle)), bandvals.map(function (_ref3) {
|
|
87
|
+
var _ref4 = _slicedToArray(_ref3, 2),
|
|
88
|
+
bandname = _ref4[0],
|
|
89
|
+
bandval = _ref4[1];
|
|
90
|
+
return /*#__PURE__*/React.createElement("tr", {
|
|
91
|
+
key: key + "_" + bandname
|
|
92
|
+
}, /*#__PURE__*/React.createElement("td", null, bandname), /*#__PURE__*/React.createElement("td", null, bandval));
|
|
93
|
+
})];
|
|
94
|
+
})));
|
|
95
|
+
});
|
|
96
|
+
_defineProperty(_this, "renderGraphTab", function () {
|
|
97
|
+
var values = Object.values(_this.state.values).map(function (x) {
|
|
98
|
+
return Object.values(x.values);
|
|
99
|
+
}).flat().filter(function (x) {
|
|
100
|
+
return x;
|
|
101
|
+
});
|
|
102
|
+
var data = {
|
|
103
|
+
labels: values.map(function (_, i) {
|
|
104
|
+
return String(i);
|
|
105
|
+
}),
|
|
106
|
+
datasets: [{
|
|
107
|
+
data: values,
|
|
108
|
+
borderColor: "rgb(255,0,0)",
|
|
109
|
+
borderWidth: 2
|
|
110
|
+
}]
|
|
111
|
+
};
|
|
112
|
+
var yAxisConfig = {};
|
|
113
|
+
if (_this.state.graphMinY) {
|
|
114
|
+
yAxisConfig.min = _this.state.graphMinY;
|
|
115
|
+
}
|
|
116
|
+
if (_this.state.graphMaxY) {
|
|
117
|
+
yAxisConfig.max = _this.state.graphMaxY;
|
|
118
|
+
}
|
|
119
|
+
var options = {
|
|
120
|
+
responsive: true,
|
|
121
|
+
maintainAspectRatio: false,
|
|
122
|
+
animation: {
|
|
123
|
+
duration: 0
|
|
124
|
+
},
|
|
125
|
+
scales: {
|
|
126
|
+
y: yAxisConfig
|
|
127
|
+
}
|
|
128
|
+
};
|
|
129
|
+
return /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement("div", {
|
|
130
|
+
className: "valuetool-chart-options"
|
|
131
|
+
}, /*#__PURE__*/React.createElement("span", null, LocaleUtils.tr("valuetool.ymin"), ": "), /*#__PURE__*/React.createElement(NumberInput, {
|
|
132
|
+
onChange: function onChange(value) {
|
|
133
|
+
return _this.setState({
|
|
134
|
+
graphMinY: value
|
|
135
|
+
});
|
|
136
|
+
},
|
|
137
|
+
value: _this.state.graphMinY
|
|
138
|
+
}), /*#__PURE__*/React.createElement("span", {
|
|
139
|
+
style: {
|
|
140
|
+
marginLeft: '0.5em'
|
|
141
|
+
}
|
|
142
|
+
}), /*#__PURE__*/React.createElement("span", null, LocaleUtils.tr("valuetool.ymax"), ": "), /*#__PURE__*/React.createElement(NumberInput, {
|
|
143
|
+
onChange: function onChange(value) {
|
|
144
|
+
return _this.setState({
|
|
145
|
+
graphMaxY: value
|
|
146
|
+
});
|
|
147
|
+
},
|
|
148
|
+
value: _this.state.graphMaxY
|
|
149
|
+
})), /*#__PURE__*/React.createElement("div", {
|
|
150
|
+
className: "valuetool-chart-container"
|
|
151
|
+
}, /*#__PURE__*/React.createElement(Line, {
|
|
152
|
+
data: data,
|
|
153
|
+
options: options
|
|
154
|
+
})));
|
|
155
|
+
});
|
|
156
|
+
_defineProperty(_this, "renderOptionsTab", function () {
|
|
157
|
+
var options = _this.state.showLayers === "selected" || _this.state.showBands === "selected" ? [/*#__PURE__*/React.createElement("hr", {
|
|
158
|
+
key: "sep"
|
|
159
|
+
}), /*#__PURE__*/React.createElement("div", {
|
|
160
|
+
key: "label"
|
|
161
|
+
}, LocaleUtils.tr("valuetool.selectlayersbands")), /*#__PURE__*/React.createElement("table", {
|
|
162
|
+
className: "valuetool-table-selection",
|
|
163
|
+
key: "table"
|
|
164
|
+
}, /*#__PURE__*/React.createElement("tbody", null, /*#__PURE__*/React.createElement("tr", null, /*#__PURE__*/React.createElement("th", null, LocaleUtils.tr("valuetool.layer")), _this.state.showBands === "selected" ? /*#__PURE__*/React.createElement("th", null, LocaleUtils.tr("valuetool.bands")) : null), _this.props.layers.map(function (layer) {
|
|
165
|
+
var sublayers = LayerUtils.getSublayerNames(layer, true, function (sublayer) {
|
|
166
|
+
return sublayer.geometryType === null;
|
|
167
|
+
});
|
|
168
|
+
return sublayers.map(function (sublayer) {
|
|
169
|
+
var key = layer.url + "#" + sublayer;
|
|
170
|
+
return /*#__PURE__*/React.createElement("tr", {
|
|
171
|
+
key: key
|
|
172
|
+
}, /*#__PURE__*/React.createElement("td", null, _this.state.showLayers === "selected" ? /*#__PURE__*/React.createElement(Icon, {
|
|
173
|
+
icon: _this.state.selectedLayers.includes(key) ? "checked" : "unchecked",
|
|
174
|
+
onClick: function onClick() {
|
|
175
|
+
return _this.toggleSelectedLayer(key);
|
|
176
|
+
}
|
|
177
|
+
}) : null, sublayer), _this.state.showBands === "selected" ? /*#__PURE__*/React.createElement("td", null, /*#__PURE__*/React.createElement(TextInput, {
|
|
178
|
+
onChange: function onChange(value) {
|
|
179
|
+
return _this.setLayerBands(key, value);
|
|
180
|
+
},
|
|
181
|
+
placeholder: LocaleUtils.tr("valuetool.all"),
|
|
182
|
+
value: _this.state.selectedBands[key] || ""
|
|
183
|
+
})) : null);
|
|
184
|
+
});
|
|
185
|
+
})))] : null;
|
|
186
|
+
return /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement("table", {
|
|
187
|
+
className: "valuetool-table-options"
|
|
188
|
+
}, /*#__PURE__*/React.createElement("tbody", null, /*#__PURE__*/React.createElement("tr", null, /*#__PURE__*/React.createElement("td", null, LocaleUtils.tr("valuetool.showlayers"), ":"), /*#__PURE__*/React.createElement("td", null, /*#__PURE__*/React.createElement("select", {
|
|
189
|
+
onChange: function onChange(ev) {
|
|
190
|
+
return _this.setState({
|
|
191
|
+
showLayers: ev.target.value
|
|
192
|
+
});
|
|
193
|
+
},
|
|
194
|
+
value: _this.state.showLayers
|
|
195
|
+
}, /*#__PURE__*/React.createElement("option", {
|
|
196
|
+
value: "visible"
|
|
197
|
+
}, LocaleUtils.tr("valuetool.visiblelayers")), /*#__PURE__*/React.createElement("option", {
|
|
198
|
+
value: "all"
|
|
199
|
+
}, LocaleUtils.tr("valuetool.alllayers")), /*#__PURE__*/React.createElement("option", {
|
|
200
|
+
value: "selected"
|
|
201
|
+
}, LocaleUtils.tr("valuetool.selectedlayers"))))), /*#__PURE__*/React.createElement("tr", null, /*#__PURE__*/React.createElement("td", null, LocaleUtils.tr("valuetool.showbands"), ":"), /*#__PURE__*/React.createElement("td", null, /*#__PURE__*/React.createElement("select", {
|
|
202
|
+
onChange: function onChange(ev) {
|
|
203
|
+
return _this.setState({
|
|
204
|
+
showBands: ev.target.value
|
|
205
|
+
});
|
|
206
|
+
},
|
|
207
|
+
value: _this.state.showBands
|
|
208
|
+
}, /*#__PURE__*/React.createElement("option", {
|
|
209
|
+
value: "all"
|
|
210
|
+
}, LocaleUtils.tr("valuetool.allbands")), /*#__PURE__*/React.createElement("option", {
|
|
211
|
+
value: "selected"
|
|
212
|
+
}, LocaleUtils.tr("valuetool.selectedbands"))))))), options);
|
|
213
|
+
});
|
|
214
|
+
_defineProperty(_this, "toggleSelectedLayer", function (key) {
|
|
215
|
+
_this.setState(function (state) {
|
|
216
|
+
return {
|
|
217
|
+
selectedLayers: state.selectedLayers.includes(key) ? state.selectedLayers.filter(function (x) {
|
|
218
|
+
return x !== key;
|
|
219
|
+
}) : [].concat(_toConsumableArray(state.selectedLayers), [key])
|
|
220
|
+
};
|
|
221
|
+
});
|
|
222
|
+
});
|
|
223
|
+
_defineProperty(_this, "setLayerBands", function (key, bands) {
|
|
224
|
+
_this.setState(function (state) {
|
|
225
|
+
return {
|
|
226
|
+
selectedBands: _objectSpread(_objectSpread({}, state.selectedBands), {}, _defineProperty({}, key, _toConsumableArray(new Set(bands.split(",").map(function (x) {
|
|
227
|
+
return parseInt(x.trim(), 10) || 0;
|
|
228
|
+
}).sort().filter(function (x) {
|
|
229
|
+
return x;
|
|
230
|
+
}))).join(", ")))
|
|
231
|
+
};
|
|
232
|
+
});
|
|
233
|
+
});
|
|
234
|
+
_defineProperty(_this, "onWindowClose", function () {
|
|
235
|
+
_this.props.setCurrentTask(null);
|
|
236
|
+
});
|
|
237
|
+
_defineProperty(_this, "scheduleQueryValues", function (ev) {
|
|
238
|
+
var coordinate = ev.coordinate;
|
|
239
|
+
clearTimeout(_this.queryTimeout);
|
|
240
|
+
_this.queryTimeout = setTimeout(function () {
|
|
241
|
+
return _this.queryValues(coordinate);
|
|
242
|
+
}, 100);
|
|
243
|
+
});
|
|
244
|
+
_defineProperty(_this, "queryValues", function (coordinate) {
|
|
245
|
+
var options = {
|
|
246
|
+
info_format: 'text/xml',
|
|
247
|
+
feature_count: 5,
|
|
248
|
+
with_geometry: false,
|
|
249
|
+
with_htmlcontent: false
|
|
250
|
+
};
|
|
251
|
+
var reqId = uuidv4();
|
|
252
|
+
_this.reqId = reqId;
|
|
253
|
+
var newValues = {};
|
|
254
|
+
_this.props.layers.forEach(function (layer) {
|
|
255
|
+
var layerActive = null;
|
|
256
|
+
if (_this.state.showLayers === "all") {
|
|
257
|
+
layerActive = function layerActive() {
|
|
258
|
+
return true;
|
|
259
|
+
};
|
|
260
|
+
} else if (_this.state.showLayers === "selected") {
|
|
261
|
+
layerActive = function layerActive(sublayer) {
|
|
262
|
+
return _this.state.selectedLayers.includes(layer.url + "#" + sublayer.name);
|
|
263
|
+
};
|
|
264
|
+
} else if (_this.state.showLayers === "visible") {
|
|
265
|
+
layerActive = function layerActive(sublayer) {
|
|
266
|
+
return sublayer.visibility;
|
|
267
|
+
};
|
|
268
|
+
}
|
|
269
|
+
var queryLayers = LayerUtils.getSublayerNames(layer, true, function (sublayer) {
|
|
270
|
+
return layerActive(sublayer) && sublayer.geometryType === null;
|
|
271
|
+
});
|
|
272
|
+
if (isEmpty(queryLayers)) {
|
|
273
|
+
return;
|
|
274
|
+
}
|
|
275
|
+
// Preserve previous result rows, but with empty values, to prevent "flickering"
|
|
276
|
+
queryLayers.forEach(function (sublayername) {
|
|
277
|
+
var key = layer.url + "#" + sublayername;
|
|
278
|
+
if (_this.state.values[key]) {
|
|
279
|
+
newValues[key] = _objectSpread(_objectSpread({}, _this.state.values[key]), {}, {
|
|
280
|
+
values: Object.fromEntries(Object.keys(_this.state.values[key].values).map(function (k) {
|
|
281
|
+
return [k, ""];
|
|
282
|
+
}))
|
|
283
|
+
});
|
|
284
|
+
}
|
|
285
|
+
});
|
|
286
|
+
var request = IdentifyUtils.buildRequest(layer, queryLayers.join(","), coordinate, _this.props.map, options);
|
|
287
|
+
IdentifyUtils.sendRequest(request, function (response) {
|
|
288
|
+
if (_this.reqId === reqId) {
|
|
289
|
+
var result = IdentifyUtils.parseXmlResponse(response || "", _this.props.map.projection, layer);
|
|
290
|
+
_this.setState(function (state) {
|
|
291
|
+
return {
|
|
292
|
+
values: _objectSpread(_objectSpread({}, state.values), Object.entries(result).reduce(function (res, _ref5) {
|
|
293
|
+
var _ref6 = _slicedToArray(_ref5, 2),
|
|
294
|
+
sublayername = _ref6[0],
|
|
295
|
+
features = _ref6[1];
|
|
296
|
+
var key = layer.url + "#" + sublayername;
|
|
297
|
+
res[key] = {
|
|
298
|
+
layertitle: features[0].layertitle,
|
|
299
|
+
values: features[0].properties
|
|
300
|
+
};
|
|
301
|
+
return res;
|
|
302
|
+
}, {}))
|
|
303
|
+
};
|
|
304
|
+
});
|
|
305
|
+
}
|
|
306
|
+
});
|
|
307
|
+
});
|
|
308
|
+
_this.setState({
|
|
309
|
+
values: newValues
|
|
310
|
+
});
|
|
311
|
+
});
|
|
312
|
+
_this.queryTimeout = null;
|
|
313
|
+
_this.reqId = null;
|
|
314
|
+
_this.state = ValueTool.defaultState;
|
|
315
|
+
return _this;
|
|
316
|
+
}
|
|
317
|
+
_inherits(ValueTool, _React$Component);
|
|
318
|
+
return _createClass(ValueTool, [{
|
|
319
|
+
key: "componentDidUpdate",
|
|
320
|
+
value: function componentDidUpdate(prevProps) {
|
|
321
|
+
if (this.props.enabled && !prevProps.enabled) {
|
|
322
|
+
MapUtils.getHook(MapUtils.ADD_POINTER_MOVE_LISTENER)(this.scheduleQueryValues);
|
|
323
|
+
} else if (!this.props.enabled && prevProps.enabled) {
|
|
324
|
+
MapUtils.getHook(MapUtils.REMOVE_POINTER_MOVE_LISTENER)(this.scheduleQueryValues);
|
|
325
|
+
clearTimeout(this.queryTimeout);
|
|
326
|
+
this.queryTimeout = null;
|
|
327
|
+
this.setState(ValueTool.defaultState);
|
|
328
|
+
}
|
|
329
|
+
}
|
|
330
|
+
}, {
|
|
331
|
+
key: "render",
|
|
332
|
+
value: function render() {
|
|
333
|
+
var _this2 = this;
|
|
334
|
+
if (!this.props.enabled) {
|
|
335
|
+
return null;
|
|
336
|
+
}
|
|
337
|
+
var buttons = [{
|
|
338
|
+
key: "Table",
|
|
339
|
+
label: LocaleUtils.tr("valuetool.table")
|
|
340
|
+
}, {
|
|
341
|
+
key: "Graph",
|
|
342
|
+
label: LocaleUtils.tr("valuetool.graph")
|
|
343
|
+
}, {
|
|
344
|
+
key: "Options",
|
|
345
|
+
label: LocaleUtils.tr("valuetool.options")
|
|
346
|
+
}];
|
|
347
|
+
var tab = null;
|
|
348
|
+
if (this.state.activeTab === "Table") {
|
|
349
|
+
tab = this.renderTableTab();
|
|
350
|
+
} else if (this.state.activeTab === "Graph") {
|
|
351
|
+
tab = this.renderGraphTab();
|
|
352
|
+
} else if (this.state.activeTab === "Options") {
|
|
353
|
+
tab = this.renderOptionsTab();
|
|
354
|
+
}
|
|
355
|
+
return /*#__PURE__*/React.createElement(ResizeableWindow, {
|
|
356
|
+
dockable: this.props.geometry.side,
|
|
357
|
+
icon: "info-sign",
|
|
358
|
+
initialHeight: this.props.geometry.initialHeight,
|
|
359
|
+
initialWidth: this.props.geometry.initialWidth,
|
|
360
|
+
initialX: this.props.geometry.initialX,
|
|
361
|
+
initialY: this.props.geometry.initialY,
|
|
362
|
+
initiallyDocked: this.props.geometry.initiallyDocked,
|
|
363
|
+
onClose: this.onWindowClose,
|
|
364
|
+
title: LocaleUtils.tr("valuetool.title")
|
|
365
|
+
}, /*#__PURE__*/React.createElement("div", {
|
|
366
|
+
className: "valuetool-body",
|
|
367
|
+
role: "body"
|
|
368
|
+
}, /*#__PURE__*/React.createElement(ButtonBar, {
|
|
369
|
+
active: this.state.activeTab,
|
|
370
|
+
buttons: buttons,
|
|
371
|
+
onClick: function onClick(key) {
|
|
372
|
+
return _this2.setState({
|
|
373
|
+
activeTab: key
|
|
374
|
+
});
|
|
375
|
+
}
|
|
376
|
+
}), tab));
|
|
377
|
+
}
|
|
378
|
+
}]);
|
|
379
|
+
}(React.Component);
|
|
380
|
+
_defineProperty(ValueTool, "propTypes", {
|
|
381
|
+
/** The number of decimal places to display for elevation values. */
|
|
382
|
+
enabled: PropTypes.bool,
|
|
383
|
+
/** Default window geometry with size, position and docking status. Positive position values (including '0') are related to top (InitialY) and left (InitialX), negative values (including '-0') to bottom (InitialY) and right (InitialX). */
|
|
384
|
+
geometry: PropTypes.shape({
|
|
385
|
+
initialWidth: PropTypes.number,
|
|
386
|
+
initialHeight: PropTypes.number,
|
|
387
|
+
initialX: PropTypes.number,
|
|
388
|
+
initialY: PropTypes.number,
|
|
389
|
+
initiallyDocked: PropTypes.bool,
|
|
390
|
+
side: PropTypes.string
|
|
391
|
+
}),
|
|
392
|
+
layers: PropTypes.array,
|
|
393
|
+
map: PropTypes.object,
|
|
394
|
+
setCurrentTask: PropTypes.func
|
|
395
|
+
});
|
|
396
|
+
_defineProperty(ValueTool, "defaultProps", {
|
|
397
|
+
geometry: {
|
|
398
|
+
initialWidth: 240,
|
|
399
|
+
initialHeight: 320,
|
|
400
|
+
initialX: 0,
|
|
401
|
+
initialY: 0,
|
|
402
|
+
initiallyDocked: false,
|
|
403
|
+
side: 'left'
|
|
404
|
+
}
|
|
405
|
+
});
|
|
406
|
+
_defineProperty(ValueTool, "defaultState", {
|
|
407
|
+
activeTab: 'Table',
|
|
408
|
+
showLayers: 'visible',
|
|
409
|
+
showBands: 'all',
|
|
410
|
+
selectedLayers: [],
|
|
411
|
+
selectedBands: {},
|
|
412
|
+
values: {},
|
|
413
|
+
graphMinY: null,
|
|
414
|
+
graphMaxY: null
|
|
415
|
+
});
|
|
416
|
+
export default connect(function (state) {
|
|
417
|
+
return {
|
|
418
|
+
enabled: state.task.id === "ValueTool",
|
|
419
|
+
layers: state.layers.flat.filter(function (layer) {
|
|
420
|
+
return (layer.role === LayerRole.THEME || layer.role === LayerRole.USERLAYER) && (layer.infoFormats || []).includes("text/xml");
|
|
421
|
+
}),
|
|
422
|
+
map: state.map
|
|
423
|
+
};
|
|
424
|
+
}, {
|
|
425
|
+
setCurrentTask: setCurrentTask
|
|
426
|
+
})(ValueTool);
|