@iobroker/adapter-react-v5 3.1.34 → 3.1.35
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/Components/404.js +0 -23
- package/Components/404.js.map +1 -1
- package/Components/ColorPicker.js +6 -37
- package/Components/ColorPicker.js.map +1 -1
- package/Components/ComplexCron.js +10 -84
- package/Components/ComplexCron.js.map +1 -1
- package/Components/CustomModal.js +29 -54
- package/Components/CustomModal.js.map +1 -1
- package/Components/FileBrowser.js +15 -265
- package/Components/FileBrowser.js.map +1 -1
- package/Components/FileViewer.js +7 -68
- package/Components/FileViewer.js.map +1 -1
- package/Components/Icon.d.ts +1 -1
- package/Components/Icon.js +2 -42
- package/Components/Icon.js.map +1 -1
- package/Components/IconPicker.js +6 -28
- package/Components/IconPicker.js.map +1 -1
- package/Components/IconSelector.js +3 -55
- package/Components/IconSelector.js.map +1 -1
- package/Components/Image.js +1 -38
- package/Components/Image.js.map +1 -1
- package/Components/JsonConfigComponent/ChipInput.js +66 -197
- package/Components/JsonConfigComponent/ChipInput.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigAlive.js +0 -31
- package/Components/JsonConfigComponent/ConfigAlive.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigAutocomplete.js +6 -39
- package/Components/JsonConfigComponent/ConfigAutocomplete.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigAutocompleteSendTo.js +6 -52
- package/Components/JsonConfigComponent/ConfigAutocompleteSendTo.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigCRON.js +5 -39
- package/Components/JsonConfigComponent/ConfigCRON.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigCertificateSelect.js +4 -42
- package/Components/JsonConfigComponent/ConfigCertificateSelect.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigCheckbox.js +0 -28
- package/Components/JsonConfigComponent/ConfigCheckbox.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigChip.js +4 -33
- package/Components/JsonConfigComponent/ConfigChip.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigColor.js +0 -34
- package/Components/JsonConfigComponent/ConfigColor.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigCoordinates.js +0 -33
- package/Components/JsonConfigComponent/ConfigCoordinates.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigCustom.js +14 -73
- package/Components/JsonConfigComponent/ConfigCustom.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigDatePicker.js +0 -25
- package/Components/JsonConfigComponent/ConfigDatePicker.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigFile.js +0 -46
- package/Components/JsonConfigComponent/ConfigFile.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigFileSelector.js +7 -126
- package/Components/JsonConfigComponent/ConfigFileSelector.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigFunc.js +0 -34
- package/Components/JsonConfigComponent/ConfigFunc.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigGeneric.js +15 -110
- package/Components/JsonConfigComponent/ConfigGeneric.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigIP.js +2 -35
- package/Components/JsonConfigComponent/ConfigIP.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigImageUpload.js +4 -44
- package/Components/JsonConfigComponent/ConfigImageUpload.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigInstanceSelect.js +1 -59
- package/Components/JsonConfigComponent/ConfigInstanceSelect.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigJsonEditor.js +7 -40
- package/Components/JsonConfigComponent/ConfigJsonEditor.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigLanguage.js +2 -42
- package/Components/JsonConfigComponent/ConfigLanguage.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigNumber.js +2 -45
- package/Components/JsonConfigComponent/ConfigNumber.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigObjectId.js +6 -40
- package/Components/JsonConfigComponent/ConfigObjectId.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigPanel.js +7 -91
- package/Components/JsonConfigComponent/ConfigPanel.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigPassword.js +0 -42
- package/Components/JsonConfigComponent/ConfigPassword.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigPattern.js +0 -25
- package/Components/JsonConfigComponent/ConfigPattern.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigRoom.js +0 -34
- package/Components/JsonConfigComponent/ConfigRoom.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigSelect.js +4 -34
- package/Components/JsonConfigComponent/ConfigSelect.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigSelectSendTo.js +11 -67
- package/Components/JsonConfigComponent/ConfigSelectSendTo.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigSendto.js +8 -91
- package/Components/JsonConfigComponent/ConfigSendto.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigSetState.js +0 -55
- package/Components/JsonConfigComponent/ConfigSetState.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigSlider.js +0 -28
- package/Components/JsonConfigComponent/ConfigSlider.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigStaticDivider.js +0 -21
- package/Components/JsonConfigComponent/ConfigStaticDivider.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigStaticHeader.js +0 -24
- package/Components/JsonConfigComponent/ConfigStaticHeader.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigStaticImage.js +0 -23
- package/Components/JsonConfigComponent/ConfigStaticImage.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigStaticText.js +0 -31
- package/Components/JsonConfigComponent/ConfigStaticText.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigTable.js +13 -105
- package/Components/JsonConfigComponent/ConfigTable.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigTabs.js +2 -35
- package/Components/JsonConfigComponent/ConfigTabs.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigText.js +0 -34
- package/Components/JsonConfigComponent/ConfigText.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigTextSendTo.js +0 -37
- package/Components/JsonConfigComponent/ConfigTextSendTo.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigTimePicker.js +0 -25
- package/Components/JsonConfigComponent/ConfigTimePicker.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigTopic.js +0 -29
- package/Components/JsonConfigComponent/ConfigTopic.js.map +1 -1
- package/Components/JsonConfigComponent/ConfigUser.js +2 -40
- package/Components/JsonConfigComponent/ConfigUser.js.map +1 -1
- package/Components/JsonConfigComponent/index.js +5 -81
- package/Components/JsonConfigComponent/index.js.map +1 -1
- package/Components/Loader.js +2 -20
- package/Components/Loader.js.map +1 -1
- package/Components/Loaders/PT.js +2 -20
- package/Components/Loaders/PT.js.map +1 -1
- package/Components/Loaders/Vendor.js +2 -21
- package/Components/Loaders/Vendor.js.map +1 -1
- package/Components/Logo.js +6 -39
- package/Components/Logo.js.map +1 -1
- package/Components/MDUtils.js +3 -27
- package/Components/MDUtils.js.map +1 -1
- package/Components/ObjectBrowser.d.ts +1 -1
- package/Components/ObjectBrowser.js +181 -788
- package/Components/ObjectBrowser.js.map +1 -1
- package/Components/Router.js +7 -31
- package/Components/Router.js.map +1 -1
- package/Components/SaveCloseButtons.js +2 -32
- package/Components/SaveCloseButtons.js.map +1 -1
- package/Components/Schedule.js +29 -251
- package/Components/Schedule.js.map +1 -1
- package/Components/SelectWithIcon.d.ts +1 -1
- package/Components/SelectWithIcon.js +0 -48
- package/Components/SelectWithIcon.js.map +1 -1
- package/Components/SimpleCron/cron2text.js +45 -91
- package/Components/SimpleCron/cron2text.js.map +1 -1
- package/Components/SimpleCron/cronText.js +0 -6
- package/Components/SimpleCron/cronText.js.map +1 -1
- package/Components/SimpleCron/index.js +19 -102
- package/Components/SimpleCron/index.js.map +1 -1
- package/Components/SimpleCron/jquery.cron.locale.js +44 -24
- package/Components/SimpleCron/jquery.cron.locale.js.map +1 -1
- package/Components/TabContainer.js +2 -23
- package/Components/TabContainer.js.map +1 -1
- package/Components/TabContent.js +2 -22
- package/Components/TabContent.js.map +1 -1
- package/Components/TabHeader.js +1 -17
- package/Components/TabHeader.js.map +1 -1
- package/Components/TableResize.js +6 -51
- package/Components/TableResize.js.map +1 -1
- package/Components/TextWithIcon.js +0 -20
- package/Components/TextWithIcon.js.map +1 -1
- package/Components/ToggleThemeMenu.js +5 -13
- package/Components/ToggleThemeMenu.js.map +1 -1
- package/Components/TreeTable.js +4 -121
- package/Components/TreeTable.js.map +1 -1
- package/Components/UploadImage.js +17 -60
- package/Components/UploadImage.js.map +1 -1
- package/Components/Utils.js +87 -263
- package/Components/Utils.js.map +1 -1
- package/Components/copy-to-clipboard.js +16 -38
- package/Components/copy-to-clipboard.js.map +1 -1
- package/Components/withWidth.js +2 -10
- package/Components/withWidth.js.map +1 -1
- package/Connection.d.ts +1 -0
- package/Connection.js +156 -527
- package/Connection.js.map +1 -1
- package/Dialogs/ComplexCron.js +0 -34
- package/Dialogs/ComplexCron.js.map +1 -1
- package/Dialogs/Confirm.js +1 -39
- package/Dialogs/Confirm.js.map +1 -1
- package/Dialogs/Cron.js +1 -37
- package/Dialogs/Cron.js.map +1 -1
- package/Dialogs/Error.d.ts +1 -1
- package/Dialogs/Error.js +2 -29
- package/Dialogs/Error.js.map +1 -1
- package/Dialogs/FileSelect.js +2 -36
- package/Dialogs/FileSelect.js.map +1 -1
- package/Dialogs/Message.js +2 -27
- package/Dialogs/Message.js.map +1 -1
- package/Dialogs/SelectID.d.ts +1 -1
- package/Dialogs/SelectID.js +3 -40
- package/Dialogs/SelectID.js.map +1 -1
- package/Dialogs/SimpleCron.js +1 -33
- package/Dialogs/SimpleCron.js.map +1 -1
- package/Dialogs/TextInput.js +2 -34
- package/Dialogs/TextInput.js.map +1 -1
- package/GenericApp.js +54 -150
- package/GenericApp.js.map +1 -1
- package/Prompt.js +0 -2
- package/Prompt.js.map +1 -1
- package/README.md +8 -4
- package/Theme.js +7 -22
- package/Theme.js.map +1 -1
- package/i18n.d.ts +2 -0
- package/i18n.js +9 -29
- package/i18n.js.map +1 -1
- package/icons/IconAdapter.d.ts +2 -2
- package/icons/IconAdapter.js +2 -6
- package/icons/IconAdapter.js.map +1 -1
- package/icons/IconAlias.d.ts +2 -2
- package/icons/IconAlias.js +2 -6
- package/icons/IconAlias.js.map +1 -1
- package/icons/IconChannel.d.ts +2 -2
- package/icons/IconChannel.js +2 -6
- package/icons/IconChannel.js.map +1 -1
- package/icons/IconClearFilter.d.ts +2 -2
- package/icons/IconClearFilter.js +0 -5
- package/icons/IconClearFilter.js.map +1 -1
- package/icons/IconClosed.d.ts +2 -2
- package/icons/IconClosed.js +0 -5
- package/icons/IconClosed.js.map +1 -1
- package/icons/IconCopy.d.ts +2 -2
- package/icons/IconCopy.js +0 -5
- package/icons/IconCopy.js.map +1 -1
- package/icons/IconDevice.d.ts +2 -2
- package/icons/IconDevice.js +0 -5
- package/icons/IconDevice.js.map +1 -1
- package/icons/IconDocument.d.ts +2 -2
- package/icons/IconDocument.js +0 -5
- package/icons/IconDocument.js.map +1 -1
- package/icons/IconDocumentReadOnly.d.ts +2 -2
- package/icons/IconDocumentReadOnly.js +0 -5
- package/icons/IconDocumentReadOnly.js.map +1 -1
- package/icons/IconExpert.d.ts +2 -2
- package/icons/IconExpert.js +0 -5
- package/icons/IconExpert.js.map +1 -1
- package/icons/IconFx.d.ts +2 -2
- package/icons/IconFx.js +0 -5
- package/icons/IconFx.js.map +1 -1
- package/icons/IconInstance.d.ts +2 -2
- package/icons/IconInstance.js +0 -5
- package/icons/IconInstance.js.map +1 -1
- package/icons/IconLogout.d.ts +2 -2
- package/icons/IconLogout.js +0 -5
- package/icons/IconLogout.js.map +1 -1
- package/icons/IconNoIcon.d.ts +2 -2
- package/icons/IconNoIcon.js +0 -5
- package/icons/IconNoIcon.js.map +1 -1
- package/icons/IconOpen.d.ts +2 -2
- package/icons/IconOpen.js +0 -5
- package/icons/IconOpen.js.map +1 -1
- package/icons/IconState.d.ts +2 -2
- package/icons/IconState.js +0 -6
- package/icons/IconState.js.map +1 -1
- package/package.json +15 -15
package/Components/Router.js
CHANGED
|
@@ -1,52 +1,36 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
7
|
exports["default"] = void 0;
|
|
9
|
-
|
|
10
8
|
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
11
|
-
|
|
12
9
|
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
13
|
-
|
|
14
10
|
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
|
|
15
|
-
|
|
16
11
|
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
|
|
17
|
-
|
|
18
12
|
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
|
|
19
|
-
|
|
20
13
|
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
|
|
21
|
-
|
|
22
14
|
var _react = _interopRequireDefault(require("react"));
|
|
23
|
-
|
|
24
15
|
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
|
|
25
|
-
|
|
26
16
|
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
|
27
|
-
|
|
28
17
|
/**
|
|
29
18
|
* @template P Type of the properties object.
|
|
30
19
|
* @template S Type of the internal state object.
|
|
31
20
|
* @extends {React.Component<P, S>}
|
|
32
|
-
*/
|
|
33
|
-
var Router = /*#__PURE__*/function (_React$Component) {
|
|
21
|
+
*/var Router = /*#__PURE__*/function (_React$Component) {
|
|
34
22
|
(0, _inherits2["default"])(Router, _React$Component);
|
|
35
|
-
|
|
36
23
|
var _super = _createSuper(Router);
|
|
37
|
-
|
|
38
24
|
/**
|
|
39
25
|
* @param {P} props The React properties of this component.
|
|
40
26
|
*/
|
|
41
27
|
function Router(props) {
|
|
42
28
|
var _this;
|
|
43
|
-
|
|
44
29
|
(0, _classCallCheck2["default"])(this, Router);
|
|
45
30
|
_this = _super.call(this, props);
|
|
46
31
|
_this.onHashChangedBound = _this.onHashChanged.bind((0, _assertThisInitialized2["default"])(_this));
|
|
47
32
|
return _this;
|
|
48
33
|
}
|
|
49
|
-
|
|
50
34
|
(0, _createClass2["default"])(Router, [{
|
|
51
35
|
key: "componentDidMount",
|
|
52
36
|
value: function componentDidMount() {
|
|
@@ -59,13 +43,14 @@ var Router = /*#__PURE__*/function (_React$Component) {
|
|
|
59
43
|
}
|
|
60
44
|
}, {
|
|
61
45
|
key: "onHashChanged",
|
|
62
|
-
value: function onHashChanged() {
|
|
46
|
+
value: function onHashChanged() {
|
|
47
|
+
// override this function
|
|
63
48
|
}
|
|
49
|
+
|
|
64
50
|
/**
|
|
65
51
|
* Gets the location object.
|
|
66
52
|
* @returns {{ tab: string; dialog: string; id: string; arg: string; }}
|
|
67
53
|
*/
|
|
68
|
-
|
|
69
54
|
}], [{
|
|
70
55
|
key: "getLocation",
|
|
71
56
|
value: function getLocation() {
|
|
@@ -78,8 +63,8 @@ var Router = /*#__PURE__*/function (_React$Component) {
|
|
|
78
63
|
console.error('Router: Cannot decode ' + item);
|
|
79
64
|
return item || '';
|
|
80
65
|
}
|
|
81
|
-
});
|
|
82
|
-
|
|
66
|
+
});
|
|
67
|
+
// #tabName/dialogName/deviceId
|
|
83
68
|
return {
|
|
84
69
|
tab: parts[0] || '',
|
|
85
70
|
dialog: parts[1] || '',
|
|
@@ -87,6 +72,7 @@ var Router = /*#__PURE__*/function (_React$Component) {
|
|
|
87
72
|
arg: parts[3] || ''
|
|
88
73
|
};
|
|
89
74
|
}
|
|
75
|
+
|
|
90
76
|
/**
|
|
91
77
|
* Navigate to a new location. Any parameters that are not set will be taken from the current location.
|
|
92
78
|
* @param {string | undefined} [tab]
|
|
@@ -94,43 +80,34 @@ var Router = /*#__PURE__*/function (_React$Component) {
|
|
|
94
80
|
* @param {string | undefined} [id]
|
|
95
81
|
* @param {string | undefined} [arg]
|
|
96
82
|
*/
|
|
97
|
-
|
|
98
83
|
}, {
|
|
99
84
|
key: "doNavigate",
|
|
100
85
|
value: function doNavigate(tab, dialog, id, arg) {
|
|
101
86
|
var hash = '';
|
|
102
87
|
var location = Router.getLocation();
|
|
103
|
-
|
|
104
88
|
if (arg !== undefined && !id) {
|
|
105
89
|
id = location.id;
|
|
106
90
|
}
|
|
107
|
-
|
|
108
91
|
if (id && !dialog) {
|
|
109
92
|
dialog = location.dialog;
|
|
110
93
|
}
|
|
111
|
-
|
|
112
94
|
if (dialog && !tab) {
|
|
113
95
|
tab = location.tab;
|
|
114
96
|
} else if (tab === null) {
|
|
115
97
|
tab = location.tab;
|
|
116
98
|
}
|
|
117
|
-
|
|
118
99
|
if (tab) {
|
|
119
100
|
hash = '#' + tab;
|
|
120
|
-
|
|
121
101
|
if (dialog) {
|
|
122
102
|
hash += '/' + dialog;
|
|
123
|
-
|
|
124
103
|
if (id) {
|
|
125
104
|
hash += '/' + id;
|
|
126
|
-
|
|
127
105
|
if (arg !== undefined) {
|
|
128
106
|
hash += '/' + arg;
|
|
129
107
|
}
|
|
130
108
|
}
|
|
131
109
|
}
|
|
132
110
|
}
|
|
133
|
-
|
|
134
111
|
if (window.location.hash !== hash) {
|
|
135
112
|
window.location.hash = hash;
|
|
136
113
|
}
|
|
@@ -138,7 +115,6 @@ var Router = /*#__PURE__*/function (_React$Component) {
|
|
|
138
115
|
}]);
|
|
139
116
|
return Router;
|
|
140
117
|
}(_react["default"].Component);
|
|
141
|
-
|
|
142
118
|
var _default = Router;
|
|
143
119
|
exports["default"] = _default;
|
|
144
120
|
//# sourceMappingURL=Router.js.map
|
package/Components/Router.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Router.js","names":["Router","props","onHashChangedBound","onHashChanged","bind","window","addEventListener","removeEventListener","hash","location","replace","parts","split","map","item","decodeURIComponent","e","console","error","tab","dialog","id","arg","getLocation","undefined","React","Component"],"sources":["Router.js"],"sourcesContent":["// please do not delete React, as without it other projects could not be compiled: ReferenceError: React is not defined\nimport React from 'react';\n\n/**\n * @template P Type of the properties object.\n * @template S Type of the internal state object.\n * @extends {React.Component<P, S>}\n */\nclass Router extends React.Component {\n /**\n * @param {P} props The React properties of this component.\n */\n constructor(props) {\n super(props);\n this.onHashChangedBound = this.onHashChanged.bind(this);\n }\n\n componentDidMount() {\n window.addEventListener('hashchange', this.onHashChangedBound);\n }\n\n componentWillUnmount() {\n window.removeEventListener('hashchange', this.onHashChangedBound);\n }\n\n onHashChanged() {\n // override this function\n }\n\n /**\n * Gets the location object.\n * @returns {{ tab: string; dialog: string; id: string; arg: string; }}\n */\n static getLocation() {\n let hash = window.location.hash;\n hash = hash.replace(/^#/, '');\n const parts = hash.split('/').map(item => {\n try {\n return item ? decodeURIComponent(item) : ''\n } catch (e) {\n console.error('Router: Cannot decode ' + item);\n return item || '';\n }\n });\n // #tabName/dialogName/deviceId\n return {\n tab: parts[0] || '',\n dialog: parts[1] || '',\n id: parts[2] || '',\n arg: parts[3] || ''\n };\n }\n\n /**\n * Navigate to a new location. Any parameters that are not set will be taken from the current location.\n * @param {string | undefined} [tab]\n * @param {string | undefined} [dialog]\n * @param {string | undefined} [id]\n * @param {string | undefined} [arg]\n */\n static doNavigate(tab, dialog, id, arg) {\n let hash = '';\n const location = Router.getLocation();\n if (arg !== undefined && !id) {\n id = location.id;\n }\n if (id && !dialog) {\n dialog = location.dialog;\n }\n if (dialog && !tab) {\n tab = location.tab;\n } else\n if (tab === null) {\n tab = location.tab;\n }\n\n if (tab) {\n hash = '#' + tab;\n if (dialog) {\n hash += '/' + dialog;\n\n if (id) {\n hash += '/' + id;\n if (arg !== undefined) {\n hash += '/' + arg;\n }\n }\n }\n }\n if (window.location.hash !== hash) {\n window.location.hash = hash;\n }\n }\n}\n\nexport default Router;"],"mappings":"
|
|
1
|
+
{"version":3,"file":"Router.js","names":["Router","props","onHashChangedBound","onHashChanged","bind","window","addEventListener","removeEventListener","hash","location","replace","parts","split","map","item","decodeURIComponent","e","console","error","tab","dialog","id","arg","getLocation","undefined","React","Component"],"sources":["Router.js"],"sourcesContent":["// please do not delete React, as without it other projects could not be compiled: ReferenceError: React is not defined\nimport React from 'react';\n\n/**\n * @template P Type of the properties object.\n * @template S Type of the internal state object.\n * @extends {React.Component<P, S>}\n */\nclass Router extends React.Component {\n /**\n * @param {P} props The React properties of this component.\n */\n constructor(props) {\n super(props);\n this.onHashChangedBound = this.onHashChanged.bind(this);\n }\n\n componentDidMount() {\n window.addEventListener('hashchange', this.onHashChangedBound);\n }\n\n componentWillUnmount() {\n window.removeEventListener('hashchange', this.onHashChangedBound);\n }\n\n onHashChanged() {\n // override this function\n }\n\n /**\n * Gets the location object.\n * @returns {{ tab: string; dialog: string; id: string; arg: string; }}\n */\n static getLocation() {\n let hash = window.location.hash;\n hash = hash.replace(/^#/, '');\n const parts = hash.split('/').map(item => {\n try {\n return item ? decodeURIComponent(item) : ''\n } catch (e) {\n console.error('Router: Cannot decode ' + item);\n return item || '';\n }\n });\n // #tabName/dialogName/deviceId\n return {\n tab: parts[0] || '',\n dialog: parts[1] || '',\n id: parts[2] || '',\n arg: parts[3] || ''\n };\n }\n\n /**\n * Navigate to a new location. Any parameters that are not set will be taken from the current location.\n * @param {string | undefined} [tab]\n * @param {string | undefined} [dialog]\n * @param {string | undefined} [id]\n * @param {string | undefined} [arg]\n */\n static doNavigate(tab, dialog, id, arg) {\n let hash = '';\n const location = Router.getLocation();\n if (arg !== undefined && !id) {\n id = location.id;\n }\n if (id && !dialog) {\n dialog = location.dialog;\n }\n if (dialog && !tab) {\n tab = location.tab;\n } else\n if (tab === null) {\n tab = location.tab;\n }\n\n if (tab) {\n hash = '#' + tab;\n if (dialog) {\n hash += '/' + dialog;\n\n if (id) {\n hash += '/' + id;\n if (arg !== undefined) {\n hash += '/' + arg;\n }\n }\n }\n }\n if (window.location.hash !== hash) {\n window.location.hash = hash;\n }\n }\n}\n\nexport default Router;"],"mappings":"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"}
|
|
@@ -1,42 +1,25 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
7
|
exports["default"] = void 0;
|
|
9
|
-
|
|
10
8
|
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
11
|
-
|
|
12
9
|
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
13
|
-
|
|
14
10
|
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
|
|
15
|
-
|
|
16
11
|
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
|
|
17
|
-
|
|
18
12
|
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
|
|
19
|
-
|
|
20
13
|
var _react = _interopRequireDefault(require("react"));
|
|
21
|
-
|
|
22
14
|
var _withStyles = _interopRequireDefault(require("@mui/styles/withStyles"));
|
|
23
|
-
|
|
24
15
|
var _Fab = _interopRequireDefault(require("@mui/material/Fab"));
|
|
25
|
-
|
|
26
16
|
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
27
|
-
|
|
28
17
|
var _Toolbar = _interopRequireDefault(require("@mui/material/Toolbar"));
|
|
29
|
-
|
|
30
18
|
var _i18n = _interopRequireDefault(require("../i18n"));
|
|
31
|
-
|
|
32
19
|
var _Save = _interopRequireDefault(require("@mui/icons-material/Save"));
|
|
33
|
-
|
|
34
20
|
var _Close = _interopRequireDefault(require("@mui/icons-material/Close"));
|
|
35
|
-
|
|
36
21
|
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
|
|
37
|
-
|
|
38
22
|
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
|
39
|
-
|
|
40
23
|
var styles = function styles(theme) {
|
|
41
24
|
return {
|
|
42
25
|
buttonIcon: {
|
|
@@ -44,6 +27,7 @@ var styles = function styles(theme) {
|
|
|
44
27
|
}
|
|
45
28
|
};
|
|
46
29
|
};
|
|
30
|
+
|
|
47
31
|
/**
|
|
48
32
|
* @typedef {object} SaveCloseButtonsProps
|
|
49
33
|
* @property {boolean} noTextOnButtons Are the buttons without text
|
|
@@ -55,37 +39,28 @@ var styles = function styles(theme) {
|
|
|
55
39
|
*
|
|
56
40
|
* @extends {React.Component<SaveCloseButtonsProps>}
|
|
57
41
|
*/
|
|
58
|
-
|
|
59
|
-
|
|
60
42
|
var SaveCloseButtons = /*#__PURE__*/function (_React$Component) {
|
|
61
43
|
(0, _inherits2["default"])(SaveCloseButtons, _React$Component);
|
|
62
|
-
|
|
63
44
|
var _super = _createSuper(SaveCloseButtons);
|
|
64
|
-
|
|
65
45
|
/**
|
|
66
46
|
* @param {SaveCloseButtonsProps} props
|
|
67
47
|
*/
|
|
68
48
|
function SaveCloseButtons(props) {
|
|
69
49
|
var _this;
|
|
70
|
-
|
|
71
50
|
(0, _classCallCheck2["default"])(this, SaveCloseButtons);
|
|
72
51
|
_this = _super.call(this, props);
|
|
73
52
|
var newReact = props.newReact === undefined ? true : props.newReact;
|
|
74
|
-
|
|
75
53
|
try {
|
|
76
54
|
_this.isIFrame = !newReact && window.self !== window.top;
|
|
77
55
|
} catch (e) {
|
|
78
56
|
_this.isIFrame = !newReact;
|
|
79
57
|
}
|
|
80
|
-
|
|
81
58
|
return _this;
|
|
82
59
|
}
|
|
83
|
-
|
|
84
60
|
(0, _createClass2["default"])(SaveCloseButtons, [{
|
|
85
61
|
key: "render",
|
|
86
62
|
value: function render() {
|
|
87
63
|
var _this2 = this;
|
|
88
|
-
|
|
89
64
|
var noTextOnButtons = this.props.noTextOnButtons;
|
|
90
65
|
var buttonStyle = {
|
|
91
66
|
borderRadius: this.props.theme.saveToolbar.button.borderRadius || 3,
|
|
@@ -98,15 +73,12 @@ var SaveCloseButtons = /*#__PURE__*/function (_React$Component) {
|
|
|
98
73
|
position: 'absolute',
|
|
99
74
|
background: this.props.theme.saveToolbar.background
|
|
100
75
|
};
|
|
101
|
-
|
|
102
76
|
if (this.props.dense) {
|
|
103
77
|
style.minHeight = 48;
|
|
104
78
|
}
|
|
105
|
-
|
|
106
79
|
if (this.props.error) {
|
|
107
80
|
buttonStyle.border = '1px solid red';
|
|
108
81
|
}
|
|
109
|
-
|
|
110
82
|
return /*#__PURE__*/_react["default"].createElement(_Toolbar["default"], {
|
|
111
83
|
position: "absolute",
|
|
112
84
|
style: style
|
|
@@ -150,7 +122,6 @@ var SaveCloseButtons = /*#__PURE__*/function (_React$Component) {
|
|
|
150
122
|
}]);
|
|
151
123
|
return SaveCloseButtons;
|
|
152
124
|
}(_react["default"].Component);
|
|
153
|
-
|
|
154
125
|
SaveCloseButtons.propTypes = {
|
|
155
126
|
dense: _propTypes["default"].bool,
|
|
156
127
|
paddingLeft: _propTypes["default"].number,
|
|
@@ -163,10 +134,9 @@ SaveCloseButtons.propTypes = {
|
|
|
163
134
|
onClose: _propTypes["default"].func.isRequired,
|
|
164
135
|
newReact: _propTypes["default"].bool
|
|
165
136
|
};
|
|
166
|
-
/** @type {typeof SaveCloseButtons} */
|
|
167
137
|
|
|
138
|
+
/** @type {typeof SaveCloseButtons} */
|
|
168
139
|
var _export = (0, _withStyles["default"])(styles)(SaveCloseButtons);
|
|
169
|
-
|
|
170
140
|
var _default = _export;
|
|
171
141
|
exports["default"] = _default;
|
|
172
142
|
//# sourceMappingURL=SaveCloseButtons.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SaveCloseButtons.js","names":["styles","theme","buttonIcon","marginRight","SaveCloseButtons","props","newReact","undefined","isIFrame","window","self","top","e","noTextOnButtons","buttonStyle","borderRadius","saveToolbar","button","height","style","bottom","left","paddingLeft","right","position","background","dense","minHeight","error","border","changed","onSave","classes","I18n","t","Object","assign","marginLeft","flexGrow","onClose","React","Component","propTypes","PropTypes","bool","number","object","isRequired","func","_export","withStyles"],"sources":["SaveCloseButtons.js"],"sourcesContent":["// please do not delete React, as without it other projects could not be compiled: ReferenceError: React is not defined\nimport React from 'react';\nimport withStyles from '@mui/styles/withStyles';\nimport Fab from '@mui/material/Fab';\nimport PropTypes from 'prop-types';\n\nimport Toolbar from '@mui/material/Toolbar';\n\nimport I18n from '../i18n';\n\nimport IconSave from '@mui/icons-material/Save';\nimport IconClose from '@mui/icons-material/Close';\n\nconst styles = theme => ({\n buttonIcon: {\n marginRight: 8\n },\n});\n\n/**\n * @typedef {object} SaveCloseButtonsProps\n * @property {boolean} noTextOnButtons Are the buttons without text\n * @property {any} theme Theme object (from this.state.theme)\n * @property {boolean} isIFrame bottom position 0 or 38 for iFrame\n * @property {boolean} newReact is used in new react\n * @property {function} onSave on Save handler\n * @property {function} onClose on Close handler\n *\n * @extends {React.Component<SaveCloseButtonsProps>}\n */\nclass SaveCloseButtons extends React.Component {\n /**\n * @param {SaveCloseButtonsProps} props\n */\n constructor(props) {\n super(props);\n const newReact = props.newReact === undefined ? true : props.newReact;\n\n try {\n this.isIFrame = !newReact && window.self !== window.top;\n } catch (e) {\n this.isIFrame = !newReact;\n }\n }\n\n render() {\n const noTextOnButtons = this.props.noTextOnButtons;\n const buttonStyle = {\n borderRadius: this.props.theme.saveToolbar.button.borderRadius || 3,\n height: this.props.theme.saveToolbar.button.height || 32,\n };\n\n const style = {\n bottom: this.isIFrame ? 38 : 0,\n left: this.props.paddingLeft || 0,\n right: 0,\n position: 'absolute',\n background: this.props.theme.saveToolbar.background\n };\n if (this.props.dense) {\n style.minHeight = 48;\n }\n\n if (this.props.error) {\n buttonStyle.border = '1px solid red';\n }\n\n return <Toolbar position=\"absolute\" style={style}>\n <Fab\n variant=\"extended\"\n aria-label=\"Save\"\n disabled={!this.props.changed || this.props.error}\n onClick={() => this.props.onSave(false)}\n style={buttonStyle}\n >\n <IconSave className={!noTextOnButtons ? this.props.classes.buttonIcon : ''}/>{!noTextOnButtons && I18n.t('ra_Save')}\n </Fab>\n <Fab\n variant=\"extended\"\n aria-label=\"Save and close\"\n disabled={!this.props.changed || this.props.error}\n onClick={() => this.props.onSave(true)}\n style={Object.assign({}, buttonStyle, {marginLeft: 10})}>\n <IconSave className={!noTextOnButtons ? this.props.classes.buttonIcon : ''}/>\n {!noTextOnButtons ? I18n.t('ra_Save and close') : '+'}\n {noTextOnButtons && <IconClose/>}\n </Fab>\n <div style={{flexGrow: 1}}/>\n <Fab variant=\"extended\" aria-label=\"Close\" onClick={() => this.props.onClose()} style={buttonStyle}>\n <IconClose className={!noTextOnButtons ? this.props.classes.buttonIcon : ''}/>{!noTextOnButtons && I18n.t('ra_Close')}\n </Fab>\n </Toolbar>;\n }\n}\n\nSaveCloseButtons.propTypes = {\n dense: PropTypes.bool,\n paddingLeft: PropTypes.number,\n noTextOnButtons: PropTypes.bool,\n theme: PropTypes.object,\n isIFrame: PropTypes.bool,\n changed: PropTypes.bool.isRequired,\n error: PropTypes.bool,\n onSave: PropTypes.func.isRequired,\n onClose: PropTypes.func.isRequired,\n newReact: PropTypes.bool,\n};\n\n/** @type {typeof SaveCloseButtons} */\nconst _export = withStyles(styles)(SaveCloseButtons);\nexport default _export;"],"mappings":"
|
|
1
|
+
{"version":3,"file":"SaveCloseButtons.js","names":["styles","theme","buttonIcon","marginRight","SaveCloseButtons","props","newReact","undefined","isIFrame","window","self","top","e","noTextOnButtons","buttonStyle","borderRadius","saveToolbar","button","height","style","bottom","left","paddingLeft","right","position","background","dense","minHeight","error","border","changed","onSave","classes","I18n","t","Object","assign","marginLeft","flexGrow","onClose","React","Component","propTypes","PropTypes","bool","number","object","isRequired","func","_export","withStyles"],"sources":["SaveCloseButtons.js"],"sourcesContent":["// please do not delete React, as without it other projects could not be compiled: ReferenceError: React is not defined\nimport React from 'react';\nimport withStyles from '@mui/styles/withStyles';\nimport Fab from '@mui/material/Fab';\nimport PropTypes from 'prop-types';\n\nimport Toolbar from '@mui/material/Toolbar';\n\nimport I18n from '../i18n';\n\nimport IconSave from '@mui/icons-material/Save';\nimport IconClose from '@mui/icons-material/Close';\n\nconst styles = theme => ({\n buttonIcon: {\n marginRight: 8\n },\n});\n\n/**\n * @typedef {object} SaveCloseButtonsProps\n * @property {boolean} noTextOnButtons Are the buttons without text\n * @property {any} theme Theme object (from this.state.theme)\n * @property {boolean} isIFrame bottom position 0 or 38 for iFrame\n * @property {boolean} newReact is used in new react\n * @property {function} onSave on Save handler\n * @property {function} onClose on Close handler\n *\n * @extends {React.Component<SaveCloseButtonsProps>}\n */\nclass SaveCloseButtons extends React.Component {\n /**\n * @param {SaveCloseButtonsProps} props\n */\n constructor(props) {\n super(props);\n const newReact = props.newReact === undefined ? true : props.newReact;\n\n try {\n this.isIFrame = !newReact && window.self !== window.top;\n } catch (e) {\n this.isIFrame = !newReact;\n }\n }\n\n render() {\n const noTextOnButtons = this.props.noTextOnButtons;\n const buttonStyle = {\n borderRadius: this.props.theme.saveToolbar.button.borderRadius || 3,\n height: this.props.theme.saveToolbar.button.height || 32,\n };\n\n const style = {\n bottom: this.isIFrame ? 38 : 0,\n left: this.props.paddingLeft || 0,\n right: 0,\n position: 'absolute',\n background: this.props.theme.saveToolbar.background\n };\n if (this.props.dense) {\n style.minHeight = 48;\n }\n\n if (this.props.error) {\n buttonStyle.border = '1px solid red';\n }\n\n return <Toolbar position=\"absolute\" style={style}>\n <Fab\n variant=\"extended\"\n aria-label=\"Save\"\n disabled={!this.props.changed || this.props.error}\n onClick={() => this.props.onSave(false)}\n style={buttonStyle}\n >\n <IconSave className={!noTextOnButtons ? this.props.classes.buttonIcon : ''}/>{!noTextOnButtons && I18n.t('ra_Save')}\n </Fab>\n <Fab\n variant=\"extended\"\n aria-label=\"Save and close\"\n disabled={!this.props.changed || this.props.error}\n onClick={() => this.props.onSave(true)}\n style={Object.assign({}, buttonStyle, {marginLeft: 10})}>\n <IconSave className={!noTextOnButtons ? this.props.classes.buttonIcon : ''}/>\n {!noTextOnButtons ? I18n.t('ra_Save and close') : '+'}\n {noTextOnButtons && <IconClose/>}\n </Fab>\n <div style={{flexGrow: 1}}/>\n <Fab variant=\"extended\" aria-label=\"Close\" onClick={() => this.props.onClose()} style={buttonStyle}>\n <IconClose className={!noTextOnButtons ? this.props.classes.buttonIcon : ''}/>{!noTextOnButtons && I18n.t('ra_Close')}\n </Fab>\n </Toolbar>;\n }\n}\n\nSaveCloseButtons.propTypes = {\n dense: PropTypes.bool,\n paddingLeft: PropTypes.number,\n noTextOnButtons: PropTypes.bool,\n theme: PropTypes.object,\n isIFrame: PropTypes.bool,\n changed: PropTypes.bool.isRequired,\n error: PropTypes.bool,\n onSave: PropTypes.func.isRequired,\n onClose: PropTypes.func.isRequired,\n newReact: PropTypes.bool,\n};\n\n/** @type {typeof SaveCloseButtons} */\nconst _export = withStyles(styles)(SaveCloseButtons);\nexport default _export;"],"mappings":"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"}
|