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,8 +1,320 @@
|
|
|
1
|
-
function _typeof(o){"@babel/helpers - typeof";return _typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?
|
|
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 _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
|
|
3
|
+
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; }
|
|
4
|
+
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; }
|
|
5
|
+
function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); }
|
|
6
|
+
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); } }
|
|
7
|
+
function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; }
|
|
8
|
+
function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }
|
|
9
|
+
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); }
|
|
10
|
+
function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; }
|
|
11
|
+
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
|
|
12
|
+
function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); }
|
|
13
|
+
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); }
|
|
14
|
+
function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); }
|
|
15
|
+
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; }
|
|
16
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
|
|
17
|
+
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); }
|
|
18
|
+
/**
|
|
2
19
|
* Copyright 2024 Sourcepole AG
|
|
3
20
|
* All rights reserved.
|
|
4
21
|
*
|
|
5
22
|
* This source code is licensed under the BSD-style license found in the
|
|
6
23
|
* LICENSE file in the root directory of this source tree.
|
|
7
|
-
*/
|
|
8
|
-
|
|
24
|
+
*/
|
|
25
|
+
|
|
26
|
+
import React from 'react';
|
|
27
|
+
import mime from 'mime-to-extensions';
|
|
28
|
+
import PropTypes from 'prop-types';
|
|
29
|
+
import { v4 as uuidv4 } from 'uuid';
|
|
30
|
+
import { showImageEditor } from '../utils/ImageEditor';
|
|
31
|
+
import LocaleUtils from '../utils/LocaleUtils';
|
|
32
|
+
import Icon from './Icon';
|
|
33
|
+
import ButtonBar from './widgets/ButtonBar';
|
|
34
|
+
import ModalDialog from './widgets/ModalDialog';
|
|
35
|
+
import './style/EditUploadField.css';
|
|
36
|
+
var EditUploadField = /*#__PURE__*/function (_React$Component) {
|
|
37
|
+
function EditUploadField(props) {
|
|
38
|
+
var _this;
|
|
39
|
+
_classCallCheck(this, EditUploadField);
|
|
40
|
+
_this = _callSuper(this, EditUploadField, [props]);
|
|
41
|
+
_defineProperty(_this, "state", {
|
|
42
|
+
camera: false,
|
|
43
|
+
imageData: null,
|
|
44
|
+
imageFilename: null
|
|
45
|
+
});
|
|
46
|
+
_defineProperty(_this, "fileSelected", function (ev) {
|
|
47
|
+
if (ev.target.files[0].type.startsWith("image/")) {
|
|
48
|
+
var reader = new FileReader();
|
|
49
|
+
reader.readAsDataURL(ev.target.files[0]);
|
|
50
|
+
reader.onload = function () {
|
|
51
|
+
_this.setState({
|
|
52
|
+
imageData: reader.result,
|
|
53
|
+
imageFilename: ev.target.files[0].name
|
|
54
|
+
});
|
|
55
|
+
_this.props.updateFile(_this.props.fieldId, new File([_this.dataUriToBlob(reader.result)], ev.target.files[0].name, {
|
|
56
|
+
type: ev.target.files[0].type
|
|
57
|
+
}));
|
|
58
|
+
_this.props.updateField(_this.props.fieldId, '');
|
|
59
|
+
};
|
|
60
|
+
} else {
|
|
61
|
+
_this.props.updateField(_this.props.fieldId, '');
|
|
62
|
+
_this.props.updateFile(_this.props.fieldId, ev.target.files[0]);
|
|
63
|
+
}
|
|
64
|
+
});
|
|
65
|
+
_defineProperty(_this, "enableCamera", function () {
|
|
66
|
+
_this.setState({
|
|
67
|
+
camera: true
|
|
68
|
+
});
|
|
69
|
+
});
|
|
70
|
+
_defineProperty(_this, "disableCamera", function () {
|
|
71
|
+
_this.disableMediaStream();
|
|
72
|
+
_this.setState({
|
|
73
|
+
camera: false
|
|
74
|
+
});
|
|
75
|
+
});
|
|
76
|
+
_defineProperty(_this, "renderCaptureFrame", function () {
|
|
77
|
+
return /*#__PURE__*/React.createElement(ModalDialog, {
|
|
78
|
+
icon: "camera",
|
|
79
|
+
onClose: _this.disableCamera,
|
|
80
|
+
title: LocaleUtils.tr("editing.takepicture")
|
|
81
|
+
}, /*#__PURE__*/React.createElement("video", {
|
|
82
|
+
className: "edit-capture-frame",
|
|
83
|
+
ref: _this.activateMediaStream
|
|
84
|
+
}), /*#__PURE__*/React.createElement("div", {
|
|
85
|
+
className: "edit-capture-controls"
|
|
86
|
+
}, /*#__PURE__*/React.createElement(Icon, {
|
|
87
|
+
icon: "camera",
|
|
88
|
+
onClick: _this.capturePicture
|
|
89
|
+
})));
|
|
90
|
+
});
|
|
91
|
+
_defineProperty(_this, "capturePicture", function () {
|
|
92
|
+
if (_this.cameraStream) {
|
|
93
|
+
var width = _this.videoElement.videoWidth;
|
|
94
|
+
var height = _this.videoElement.videoHeight;
|
|
95
|
+
var canvas = document.createElement("canvas");
|
|
96
|
+
canvas.width = width;
|
|
97
|
+
canvas.height = height;
|
|
98
|
+
var context = canvas.getContext("2d");
|
|
99
|
+
context.drawImage(_this.videoElement, 0, 0, width, height);
|
|
100
|
+
var imageData = canvas.toDataURL("image/jpeg");
|
|
101
|
+
_this.setState({
|
|
102
|
+
imageData: imageData,
|
|
103
|
+
imageFilename: uuidv4() + ".jpg"
|
|
104
|
+
});
|
|
105
|
+
_this.props.updateField(_this.props.fieldId, '');
|
|
106
|
+
_this.props.updateFile(_this.props.fieldId, new File([_this.dataUriToBlob(imageData)], uuidv4() + ".jpg", {
|
|
107
|
+
type: "image/jpeg"
|
|
108
|
+
}));
|
|
109
|
+
}
|
|
110
|
+
_this.disableCamera();
|
|
111
|
+
});
|
|
112
|
+
_defineProperty(_this, "imageButtonClicked", function (action) {
|
|
113
|
+
if (action === "Draw") {
|
|
114
|
+
var fileValue = _this.props.value.startsWith("attachment:") ? _this.props.value.replace(/attachment:\/\//, '') : "";
|
|
115
|
+
var fileType = mime.lookup(fileValue);
|
|
116
|
+
var fileUrl = _this.props.iface.resolveAttachmentUrl(_this.props.dataset, fileValue);
|
|
117
|
+
var imageData = fileType && fileType.startsWith('image/') ? fileUrl : _this.state.imageData;
|
|
118
|
+
showImageEditor(imageData, function (newImageData) {
|
|
119
|
+
_this.setState({
|
|
120
|
+
imageData: newImageData,
|
|
121
|
+
imageFilename: fileValue.replace(/.*\//, '')
|
|
122
|
+
});
|
|
123
|
+
_this.props.updateField(_this.props.fieldId, '');
|
|
124
|
+
_this.props.updateFile(_this.props.fieldId, new File([_this.dataUriToBlob(newImageData)], uuidv4() + ".jpg", {
|
|
125
|
+
type: "image/jpeg"
|
|
126
|
+
}));
|
|
127
|
+
});
|
|
128
|
+
} else if (action === "Clear") {
|
|
129
|
+
_this.clearImage();
|
|
130
|
+
}
|
|
131
|
+
});
|
|
132
|
+
_defineProperty(_this, "clearImage", function () {
|
|
133
|
+
_this.setState({
|
|
134
|
+
imageData: null,
|
|
135
|
+
imageFilename: null
|
|
136
|
+
});
|
|
137
|
+
_this.props.updateField(_this.props.fieldId, '');
|
|
138
|
+
_this.props.updateFile(_this.props.fieldId, null);
|
|
139
|
+
});
|
|
140
|
+
_defineProperty(_this, "activateMediaStream", function (el) {
|
|
141
|
+
if (_this.state.camera && !_this.cameraStream) {
|
|
142
|
+
var constraints = {
|
|
143
|
+
video: {
|
|
144
|
+
width: {
|
|
145
|
+
ideal: 4096
|
|
146
|
+
},
|
|
147
|
+
height: {
|
|
148
|
+
ideal: 2160
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
};
|
|
152
|
+
navigator.mediaDevices.getUserMedia(constraints).then(function (mediaStream) {
|
|
153
|
+
_this.cameraStream = mediaStream;
|
|
154
|
+
el.srcObject = mediaStream;
|
|
155
|
+
el.play();
|
|
156
|
+
_this.videoElement = el;
|
|
157
|
+
})["catch"](function (err) {
|
|
158
|
+
// eslint-disable-next-line
|
|
159
|
+
console.warn("Unable to access camera: " + err);
|
|
160
|
+
});
|
|
161
|
+
}
|
|
162
|
+
});
|
|
163
|
+
_defineProperty(_this, "disableMediaStream", function () {
|
|
164
|
+
if (_this.cameraStream) {
|
|
165
|
+
_this.cameraStream.getTracks()[0].stop();
|
|
166
|
+
_this.cameraStream = null;
|
|
167
|
+
_this.videoElement = null;
|
|
168
|
+
}
|
|
169
|
+
});
|
|
170
|
+
_defineProperty(_this, "download", function (href, filename) {
|
|
171
|
+
var a = document.createElement("a");
|
|
172
|
+
a.href = href;
|
|
173
|
+
a.target = "_blank";
|
|
174
|
+
a.setAttribute("download", filename);
|
|
175
|
+
a.click();
|
|
176
|
+
});
|
|
177
|
+
_defineProperty(_this, "dataUriToBlob", function (dataUri) {
|
|
178
|
+
var parts = dataUri.split(',');
|
|
179
|
+
var byteString = parts[0].indexOf('base64') >= 0 ? atob(parts[1]) : decodeURI(parts[1]);
|
|
180
|
+
var mimeString = parts[0].split(':')[1].split(';')[0];
|
|
181
|
+
var ia = new Uint8Array(byteString.length);
|
|
182
|
+
for (var i = 0; i < byteString.length; i++) {
|
|
183
|
+
ia[i] = byteString.charCodeAt(i);
|
|
184
|
+
}
|
|
185
|
+
return new Blob([ia], {
|
|
186
|
+
type: mimeString
|
|
187
|
+
});
|
|
188
|
+
});
|
|
189
|
+
_this.cameraStream = null;
|
|
190
|
+
_this.videoElement = null;
|
|
191
|
+
_this.portal = document.createElement("div");
|
|
192
|
+
document.body.appendChild(_this.portal);
|
|
193
|
+
return _this;
|
|
194
|
+
}
|
|
195
|
+
_inherits(EditUploadField, _React$Component);
|
|
196
|
+
return _createClass(EditUploadField, [{
|
|
197
|
+
key: "componentWillUnmount",
|
|
198
|
+
value: function componentWillUnmount() {
|
|
199
|
+
this.disableMediaStream();
|
|
200
|
+
}
|
|
201
|
+
}, {
|
|
202
|
+
key: "render",
|
|
203
|
+
value: function render() {
|
|
204
|
+
var _this2 = this;
|
|
205
|
+
var isAttachment = this.props.value.startsWith("attachment:");
|
|
206
|
+
var fileValue = isAttachment ? this.props.value.replace(/attachment:\/\//, '') : this.props.value;
|
|
207
|
+
var fileType = mime.lookup(fileValue);
|
|
208
|
+
var fileUrl = isAttachment ? this.props.iface.resolveAttachmentUrl(this.props.dataset, fileValue) : fileValue;
|
|
209
|
+
var constraints = _objectSpread(_objectSpread({}, this.props.constraints), {}, {
|
|
210
|
+
accept: (this.props.constraints.accept || "").split(",").map(function (ext) {
|
|
211
|
+
return mime.lookup(ext);
|
|
212
|
+
}).join(",")
|
|
213
|
+
});
|
|
214
|
+
var mediaSupport = 'mediaDevices' in navigator && constraints.accept.split(",").includes("image/jpeg");
|
|
215
|
+
var imageData = fileType && fileType.startsWith('image/') ? fileUrl : this.state.imageData;
|
|
216
|
+
if (imageData) {
|
|
217
|
+
if (this.props.showThumbnails) {
|
|
218
|
+
var extension = fileValue ? fileValue.replace(/^.*\./, '') : 'jpg';
|
|
219
|
+
var imagebuttons = [{
|
|
220
|
+
key: 'Draw',
|
|
221
|
+
icon: 'paint',
|
|
222
|
+
tooltip: LocaleUtils.tr("editing.paint"),
|
|
223
|
+
disabled: this.props.disabled
|
|
224
|
+
}, {
|
|
225
|
+
key: 'Clear',
|
|
226
|
+
icon: 'clear',
|
|
227
|
+
tooltip: LocaleUtils.tr("editing.clearpicture"),
|
|
228
|
+
disabled: this.props.disabled
|
|
229
|
+
}];
|
|
230
|
+
return /*#__PURE__*/React.createElement("span", {
|
|
231
|
+
className: "edit-upload-field-image"
|
|
232
|
+
}, /*#__PURE__*/React.createElement("img", {
|
|
233
|
+
onClick: function onClick() {
|
|
234
|
+
return _this2.download(imageData, _this2.props.fieldId + "." + extension);
|
|
235
|
+
},
|
|
236
|
+
src: imageData
|
|
237
|
+
}), this.state.imageData ? /*#__PURE__*/React.createElement("input", {
|
|
238
|
+
"data-filename": this.state.imageFilename,
|
|
239
|
+
name: this.props.name,
|
|
240
|
+
type: "hidden",
|
|
241
|
+
value: this.state.imageData
|
|
242
|
+
}) : null, !this.props.report && !this.props.disabled ? /*#__PURE__*/React.createElement(ButtonBar, {
|
|
243
|
+
buttons: imagebuttons,
|
|
244
|
+
onClick: this.imageButtonClicked,
|
|
245
|
+
tooltipPos: "top"
|
|
246
|
+
}) : null);
|
|
247
|
+
} else {
|
|
248
|
+
var _extension = fileValue ? fileValue.replace(/^.*\./, '') : 'jpg';
|
|
249
|
+
return /*#__PURE__*/React.createElement("span", {
|
|
250
|
+
className: "edit-upload-field edit-upload-field-imagelink" + (this.props.disabled ? " edit-upload-field-disabled" : "")
|
|
251
|
+
}, fileValue ? /*#__PURE__*/React.createElement("a", {
|
|
252
|
+
href: fileUrl,
|
|
253
|
+
rel: "noreferrer",
|
|
254
|
+
target: "_blank"
|
|
255
|
+
}, fileValue.replace(/.*\//, '')) : /*#__PURE__*/React.createElement("a", {
|
|
256
|
+
href: "#",
|
|
257
|
+
onClick: function onClick(ev) {
|
|
258
|
+
_this2.download(imageData, _this2.state.imageFilename);
|
|
259
|
+
ev.preventDefault();
|
|
260
|
+
},
|
|
261
|
+
rel: "noreferrer",
|
|
262
|
+
target: "_blank"
|
|
263
|
+
}, this.state.imageFilename), /*#__PURE__*/React.createElement("img", {
|
|
264
|
+
onClick: function onClick() {
|
|
265
|
+
return _this2.download(imageData, _this2.props.fieldId + "." + _extension);
|
|
266
|
+
},
|
|
267
|
+
src: imageData
|
|
268
|
+
}), this.props.report ? null : /*#__PURE__*/React.createElement(Icon, {
|
|
269
|
+
icon: "clear",
|
|
270
|
+
onClick: this.props.disabled ? null : this.clearImage
|
|
271
|
+
}));
|
|
272
|
+
}
|
|
273
|
+
} else if (fileValue) {
|
|
274
|
+
return /*#__PURE__*/React.createElement("span", {
|
|
275
|
+
className: "edit-upload-field edit-upload-field-imagelink" + (this.props.disabled ? " edit-upload-field-disabled" : "")
|
|
276
|
+
}, /*#__PURE__*/React.createElement("a", {
|
|
277
|
+
href: fileUrl,
|
|
278
|
+
rel: "noreferrer",
|
|
279
|
+
target: "_blank"
|
|
280
|
+
}, fileValue.replace(/.*\//, '')), this.props.report ? null : /*#__PURE__*/React.createElement(Icon, {
|
|
281
|
+
icon: "clear",
|
|
282
|
+
onClick: this.props.disabled ? null : this.clearImage
|
|
283
|
+
}));
|
|
284
|
+
} else if (!this.props.report) {
|
|
285
|
+
return /*#__PURE__*/React.createElement("span", {
|
|
286
|
+
className: "edit-upload-field-input" + (this.props.disabled ? " edit-upload-field-input-disabled" : "")
|
|
287
|
+
}, /*#__PURE__*/React.createElement("input", _extends({
|
|
288
|
+
disabled: this.props.disabled,
|
|
289
|
+
name: this.props.name,
|
|
290
|
+
type: "file"
|
|
291
|
+
}, constraints, {
|
|
292
|
+
onChange: this.fileSelected
|
|
293
|
+
})), mediaSupport ? /*#__PURE__*/React.createElement(Icon, {
|
|
294
|
+
icon: "camera",
|
|
295
|
+
onClick: this.props.disabled ? null : this.enableCamera
|
|
296
|
+
}) : null, this.state.camera ? this.renderCaptureFrame() : null);
|
|
297
|
+
} else {
|
|
298
|
+
return null;
|
|
299
|
+
}
|
|
300
|
+
}
|
|
301
|
+
}]);
|
|
302
|
+
}(React.Component);
|
|
303
|
+
_defineProperty(EditUploadField, "propTypes", {
|
|
304
|
+
constraints: PropTypes.object,
|
|
305
|
+
dataset: PropTypes.string,
|
|
306
|
+
disabled: PropTypes.bool,
|
|
307
|
+
fieldId: PropTypes.string,
|
|
308
|
+
iface: PropTypes.object,
|
|
309
|
+
name: PropTypes.string,
|
|
310
|
+
report: PropTypes.bool,
|
|
311
|
+
showThumbnails: PropTypes.bool,
|
|
312
|
+
updateField: PropTypes.func,
|
|
313
|
+
updateFile: PropTypes.func,
|
|
314
|
+
value: PropTypes.string
|
|
315
|
+
});
|
|
316
|
+
_defineProperty(EditUploadField, "defaultProps", {
|
|
317
|
+
showThumbnails: true,
|
|
318
|
+
updateFile: function updateFile() {}
|
|
319
|
+
});
|
|
320
|
+
export { EditUploadField as default };
|
|
@@ -1,7 +1,208 @@
|
|
|
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 PropTypes from 'prop-types';
|
|
27
|
+
import MiscUtils from '../utils/MiscUtils';
|
|
28
|
+
import './style/ExportSelection.css';
|
|
29
|
+
var ExportSelection = /*#__PURE__*/function (_React$Component) {
|
|
30
|
+
function ExportSelection() {
|
|
31
|
+
var _this;
|
|
32
|
+
_classCallCheck(this, ExportSelection);
|
|
33
|
+
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
34
|
+
args[_key] = arguments[_key];
|
|
35
|
+
}
|
|
36
|
+
_this = _callSuper(this, ExportSelection, [].concat(args));
|
|
37
|
+
_defineProperty(_this, "state", {
|
|
38
|
+
x: 0,
|
|
39
|
+
y: 0,
|
|
40
|
+
width: 0,
|
|
41
|
+
height: 0,
|
|
42
|
+
frameRatio: null
|
|
43
|
+
});
|
|
44
|
+
_defineProperty(_this, "startMoveSelection", function (ev) {
|
|
45
|
+
if (ev.ctrlKey) {
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
var startStateX = _this.state.x;
|
|
49
|
+
var startStateY = _this.state.y;
|
|
50
|
+
var onMouseMove = function onMouseMove(event) {
|
|
51
|
+
_this.setState({
|
|
52
|
+
x: startStateX + event.clientX - ev.clientX,
|
|
53
|
+
y: startStateY + event.clientY - ev.clientY
|
|
54
|
+
});
|
|
55
|
+
};
|
|
56
|
+
ev.view.addEventListener('pointermove', onMouseMove);
|
|
57
|
+
ev.view.addEventListener('pointerup', function () {
|
|
58
|
+
ev.view.removeEventListener('pointermove', onMouseMove);
|
|
59
|
+
_this.props.onFrameChanged(_this.state);
|
|
60
|
+
}, {
|
|
61
|
+
once: true
|
|
62
|
+
});
|
|
63
|
+
MiscUtils.killEvent(ev);
|
|
64
|
+
});
|
|
65
|
+
_defineProperty(_this, "startResizeSelection", function (ev, sx, sy) {
|
|
66
|
+
if (ev.ctrlKey) {
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
var _this$state = _this.state,
|
|
70
|
+
x = _this$state.x,
|
|
71
|
+
y = _this$state.y,
|
|
72
|
+
width = _this$state.width,
|
|
73
|
+
height = _this$state.height,
|
|
74
|
+
frameRatio = _this$state.frameRatio;
|
|
75
|
+
var onMouseMove = function onMouseMove(event) {
|
|
76
|
+
var dx = event.clientX - ev.clientX;
|
|
77
|
+
var dy = event.clientY - ev.clientY;
|
|
78
|
+
var newwidth = width + dx * sx;
|
|
79
|
+
var newheight = height + dy * sy;
|
|
80
|
+
if (frameRatio) {
|
|
81
|
+
if (sx !== 0) {
|
|
82
|
+
newheight = Math.round(newwidth * frameRatio);
|
|
83
|
+
} else {
|
|
84
|
+
newwidth = Math.round(newheight / frameRatio);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
var newx = sx < 0 ? x + (width - newwidth) : x;
|
|
88
|
+
var newy = sy < 0 ? y + (height - newheight) : y;
|
|
89
|
+
if (sx === 0) {
|
|
90
|
+
newx += 0.5 * (width - newwidth);
|
|
91
|
+
}
|
|
92
|
+
if (sy === 0) {
|
|
93
|
+
newy += 0.5 * (height - newheight);
|
|
94
|
+
}
|
|
95
|
+
_this.setState({
|
|
96
|
+
x: newx,
|
|
97
|
+
y: newy,
|
|
98
|
+
width: newwidth,
|
|
99
|
+
height: newheight
|
|
100
|
+
});
|
|
101
|
+
};
|
|
102
|
+
ev.view.addEventListener('pointermove', onMouseMove);
|
|
103
|
+
ev.view.addEventListener('pointerup', function () {
|
|
104
|
+
ev.view.removeEventListener('pointermove', onMouseMove);
|
|
105
|
+
_this.props.onFrameChanged(_this.state);
|
|
106
|
+
}, {
|
|
107
|
+
once: true
|
|
108
|
+
});
|
|
109
|
+
MiscUtils.killEvent(ev);
|
|
110
|
+
});
|
|
111
|
+
return _this;
|
|
112
|
+
}
|
|
113
|
+
_inherits(ExportSelection, _React$Component);
|
|
114
|
+
return _createClass(ExportSelection, [{
|
|
115
|
+
key: "componentDidUpdate",
|
|
116
|
+
value: function componentDidUpdate(prevProps) {
|
|
117
|
+
var _this2 = this;
|
|
118
|
+
if (this.props.frame !== prevProps.frame) {
|
|
119
|
+
this.setState(_objectSpread({}, this.props.frame));
|
|
120
|
+
}
|
|
121
|
+
if (this.props.frameRatio !== prevProps.frameRatio) {
|
|
122
|
+
this.setState(function (state) {
|
|
123
|
+
var newheight = _this2.props.frameRatio ? Math.round(state.width * _this2.props.frameRatio) : state.height;
|
|
124
|
+
return {
|
|
125
|
+
frameRatio: _this2.props.frameRatio,
|
|
126
|
+
y: state.y + 0.5 * (state.height - newheight),
|
|
127
|
+
height: newheight
|
|
128
|
+
};
|
|
129
|
+
}, function () {
|
|
130
|
+
_this2.props.onFrameChanged(_this2.state);
|
|
131
|
+
});
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
}, {
|
|
135
|
+
key: "render",
|
|
136
|
+
value: function render() {
|
|
137
|
+
var _this3 = this;
|
|
138
|
+
var boxStyle = {
|
|
139
|
+
left: this.state.x + 'px',
|
|
140
|
+
top: this.state.y + 'px',
|
|
141
|
+
width: this.state.width + 'px',
|
|
142
|
+
height: this.state.height + 'px'
|
|
143
|
+
};
|
|
144
|
+
return /*#__PURE__*/React.createElement("div", {
|
|
145
|
+
className: "export-selection-container"
|
|
146
|
+
}, /*#__PURE__*/React.createElement("div", {
|
|
147
|
+
className: "export-selection",
|
|
148
|
+
onContextMenu: MiscUtils.killEvent,
|
|
149
|
+
onPointerDown: this.startMoveSelection,
|
|
150
|
+
style: boxStyle
|
|
151
|
+
}, /*#__PURE__*/React.createElement("span", {
|
|
152
|
+
className: "export-selection-label"
|
|
153
|
+
}, this.state.width + " x " + this.state.height), /*#__PURE__*/React.createElement("div", {
|
|
154
|
+
className: "export-selection-resize-top",
|
|
155
|
+
onPointerDown: function onPointerDown(ev) {
|
|
156
|
+
return _this3.startResizeSelection(ev, 0, -1);
|
|
157
|
+
}
|
|
158
|
+
}), /*#__PURE__*/React.createElement("div", {
|
|
159
|
+
className: "export-selection-resize-bottom",
|
|
160
|
+
onPointerDown: function onPointerDown(ev) {
|
|
161
|
+
return _this3.startResizeSelection(ev, 0, 1);
|
|
162
|
+
}
|
|
163
|
+
}), /*#__PURE__*/React.createElement("div", {
|
|
164
|
+
className: "export-selection-resize-left",
|
|
165
|
+
onPointerDown: function onPointerDown(ev) {
|
|
166
|
+
return _this3.startResizeSelection(ev, -1, 0);
|
|
167
|
+
}
|
|
168
|
+
}), /*#__PURE__*/React.createElement("div", {
|
|
169
|
+
className: "export-selection-resize-right",
|
|
170
|
+
onPointerDown: function onPointerDown(ev) {
|
|
171
|
+
return _this3.startResizeSelection(ev, 1, 0);
|
|
172
|
+
}
|
|
173
|
+
}), /*#__PURE__*/React.createElement("div", {
|
|
174
|
+
className: "export-selection-resize-topleft",
|
|
175
|
+
onPointerDown: function onPointerDown(ev) {
|
|
176
|
+
return _this3.startResizeSelection(ev, -1, -1);
|
|
177
|
+
}
|
|
178
|
+
}), /*#__PURE__*/React.createElement("div", {
|
|
179
|
+
className: "export-selection-resize-topright",
|
|
180
|
+
onPointerDown: function onPointerDown(ev) {
|
|
181
|
+
return _this3.startResizeSelection(ev, 1, -1);
|
|
182
|
+
}
|
|
183
|
+
}), /*#__PURE__*/React.createElement("div", {
|
|
184
|
+
className: "export-selection-resize-bottomleft",
|
|
185
|
+
onPointerDown: function onPointerDown(ev) {
|
|
186
|
+
return _this3.startResizeSelection(ev, -1, 1);
|
|
187
|
+
}
|
|
188
|
+
}), /*#__PURE__*/React.createElement("div", {
|
|
189
|
+
className: "export-selection-resize-bottomright",
|
|
190
|
+
onPointerDown: function onPointerDown(ev) {
|
|
191
|
+
return _this3.startResizeSelection(ev, 1, 1);
|
|
192
|
+
}
|
|
193
|
+
})));
|
|
194
|
+
}
|
|
195
|
+
}]);
|
|
196
|
+
}(React.Component);
|
|
197
|
+
_defineProperty(ExportSelection, "propTypes", {
|
|
198
|
+
frame: PropTypes.shape({
|
|
199
|
+
x: PropTypes.number,
|
|
200
|
+
y: PropTypes.number,
|
|
201
|
+
width: PropTypes.number,
|
|
202
|
+
height: PropTypes.number
|
|
203
|
+
}),
|
|
204
|
+
frameRatio: PropTypes.number,
|
|
205
|
+
mapElement: PropTypes.object,
|
|
206
|
+
onFrameChanged: PropTypes.func
|
|
207
|
+
});
|
|
208
|
+
export { ExportSelection as default };
|