@trops/dash-core 0.1.422 → 0.1.425
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/dist/electron/index.js +188 -28
- package/dist/electron/index.js.map +1 -1
- package/dist/index.esm.js +525 -177
- package/dist/index.esm.js.map +1 -1
- package/dist/index.js +590 -224
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
package/dist/index.esm.js
CHANGED
|
@@ -2,7 +2,7 @@ import _slicedToArray from '@babel/runtime/helpers/slicedToArray';
|
|
|
2
2
|
import _typeof from '@babel/runtime/helpers/typeof';
|
|
3
3
|
import _defineProperty from '@babel/runtime/helpers/defineProperty';
|
|
4
4
|
import * as DashReact from '@trops/dash-react';
|
|
5
|
-
import { isObject, ThemeContext, deepCopy, MainSection, getUUID, getStylesForItem, themeObjects, Heading, SearchInput, ButtonIcon, SubHeading3, InputText, Button, FontAwesomeIcon, Tag, Modal, Paragraph, Sidebar, Panel, Stepper, Tag2, Tag3, Card2, Card3, Heading3, MenuItem3, FormLabel, SelectMenu, Switch, SelectInput,
|
|
5
|
+
import { isObject, ThemeContext, deepCopy, MainSection, getUUID, getStylesForItem, themeObjects, Heading, SearchInput, ButtonIcon, SubHeading3, InputText, Button, FontAwesomeIcon, Tag, Modal, Paragraph, Sidebar, Panel, Stepper, Tag2, Tag3, Card2, Card3, Heading3, MenuItem3, FormLabel, SelectMenu, Switch, SelectInput, CodeEditorVS, SettingsModal, SubHeading2, tailwindHeightFractions, Menu3, Panel3, ButtonIcon2, DropdownPanel, MenuItem2, DragComponent, ConfirmationModal, DropComponent, getStyleName, capitalizeFirstLetter, colorTypes, getCSSStyleForClassname, Panel2, Heading2, SubHeading, Paragraph2, Paragraph3, Button2, Button3, MenuItem, ButtonIcon3, DashPanel, colorNames, shades, themeVariants, Tabs3, DataList, Checkbox, StatCard, Card, Tabs, Accordion, Alert, Toast, ProgressBar, Toggle, Breadcrumbs, Tabs2, Accordion2, Alert2, Toast2, ProgressBar2, Toggle2, Breadcrumbs2, Accordion3, Alert3, Toast3, ProgressBar3, Toggle3, Breadcrumbs3, ThemeFromUrlPane, TextArea, CodeEditorInline, Icon2, AlgoliaSearchBox, CommandPalette, useSidebar, EmptyState, Navbar, withRouter, Menu as Menu$1 } from '@trops/dash-react';
|
|
6
6
|
export * from '@trops/dash-react';
|
|
7
7
|
export { ThemeContext } from '@trops/dash-react';
|
|
8
8
|
import _toConsumableArray from '@babel/runtime/helpers/toConsumableArray';
|
|
@@ -32,8 +32,8 @@ import { InstantSearch, Hits } from 'react-instantsearch-hooks-web';
|
|
|
32
32
|
import { Link } from 'react-router-dom';
|
|
33
33
|
import { marked } from 'marked';
|
|
34
34
|
|
|
35
|
-
function ownKeys$
|
|
36
|
-
function _objectSpread$
|
|
35
|
+
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; }
|
|
36
|
+
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; }
|
|
37
37
|
var event = {
|
|
38
38
|
list: new Map(),
|
|
39
39
|
// Map(1) { '<widget-UUID>' => { 'CustomSearchbar[10].searchQueryChanged': [] } }
|
|
@@ -95,7 +95,7 @@ var event = {
|
|
|
95
95
|
uuid: subscriber["uuid"]
|
|
96
96
|
};
|
|
97
97
|
if ("action" in subscriber && subscriber.action !== undefined) {
|
|
98
|
-
subscriber["action"](_objectSpread$
|
|
98
|
+
subscriber["action"](_objectSpread$_({}, objectToSend));
|
|
99
99
|
}
|
|
100
100
|
});
|
|
101
101
|
}
|
|
@@ -2873,8 +2873,8 @@ var DashboardWrapper = function DashboardWrapper(_ref) {
|
|
|
2873
2873
|
});
|
|
2874
2874
|
};
|
|
2875
2875
|
|
|
2876
|
-
function ownKeys$
|
|
2877
|
-
function _objectSpread$
|
|
2876
|
+
function ownKeys$Z(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; }
|
|
2877
|
+
function _objectSpread$Z(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$Z(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$Z(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
2878
2878
|
function ThemeBroadcast(_ref) {
|
|
2879
2879
|
var ctx = _ref.ctx;
|
|
2880
2880
|
useEffect(function () {
|
|
@@ -2907,7 +2907,7 @@ var DashboardThemeProvider = function DashboardThemeProvider(_ref2) {
|
|
|
2907
2907
|
var dashboardTheme = themes[themeKey];
|
|
2908
2908
|
var themeValue = dashboardTheme ? dashboardTheme[themeVariant] || null : null;
|
|
2909
2909
|
if (!themeValue) return null;
|
|
2910
|
-
return _objectSpread$
|
|
2910
|
+
return _objectSpread$Z(_objectSpread$Z({}, parentContext), {}, {
|
|
2911
2911
|
currentTheme: themeValue,
|
|
2912
2912
|
currentThemeKey: themeKey,
|
|
2913
2913
|
theme: themeValue,
|
|
@@ -2934,8 +2934,8 @@ var DashboardThemeProvider = function DashboardThemeProvider(_ref2) {
|
|
|
2934
2934
|
});
|
|
2935
2935
|
};
|
|
2936
2936
|
|
|
2937
|
-
function ownKeys$
|
|
2938
|
-
function _objectSpread$
|
|
2937
|
+
function ownKeys$Y(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; }
|
|
2938
|
+
function _objectSpread$Y(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$Y(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$Y(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
2939
2939
|
var AppThemeScope = function AppThemeScope(_ref) {
|
|
2940
2940
|
var children = _ref.children;
|
|
2941
2941
|
var ctx = useContext(ThemeContext);
|
|
@@ -2943,7 +2943,7 @@ var AppThemeScope = function AppThemeScope(_ref) {
|
|
|
2943
2943
|
children: children
|
|
2944
2944
|
});
|
|
2945
2945
|
return /*#__PURE__*/jsx(ThemeContext.Provider, {
|
|
2946
|
-
value: _objectSpread$
|
|
2946
|
+
value: _objectSpread$Y(_objectSpread$Y({}, ctx), {}, {
|
|
2947
2947
|
currentTheme: ctx.appTheme,
|
|
2948
2948
|
currentThemeKey: ctx.appThemeKey,
|
|
2949
2949
|
theme: ctx.appTheme,
|
|
@@ -3055,8 +3055,8 @@ var LayoutContainer = function LayoutContainer(_ref) {
|
|
|
3055
3055
|
});
|
|
3056
3056
|
};
|
|
3057
3057
|
|
|
3058
|
-
function ownKeys$
|
|
3059
|
-
function _objectSpread$
|
|
3058
|
+
function ownKeys$X(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; }
|
|
3059
|
+
function _objectSpread$X(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$X(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$X(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
3060
3060
|
function _createForOfIteratorHelper$t(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray$t(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t["return"] || t["return"](); } finally { if (u) throw o; } } }; }
|
|
3061
3061
|
function _unsupportedIterableToArray$t(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray$t(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$t(r, a) : void 0; } }
|
|
3062
3062
|
function _arrayLikeToArray$t(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; }
|
|
@@ -3338,7 +3338,7 @@ function createLayoutFromTemplate(template) {
|
|
|
3338
3338
|
try {
|
|
3339
3339
|
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
3340
3340
|
var cell = _step.value;
|
|
3341
|
-
grid[cell.key] = _objectSpread$
|
|
3341
|
+
grid[cell.key] = _objectSpread$X({
|
|
3342
3342
|
component: null,
|
|
3343
3343
|
hide: cell.hide || false
|
|
3344
3344
|
}, cell.span ? {
|
|
@@ -4267,8 +4267,8 @@ var RegistryAuthModal = function RegistryAuthModal(_ref) {
|
|
|
4267
4267
|
function _createForOfIteratorHelper$s(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray$s(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t["return"] || t["return"](); } finally { if (u) throw o; } } }; }
|
|
4268
4268
|
function _unsupportedIterableToArray$s(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray$s(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$s(r, a) : void 0; } }
|
|
4269
4269
|
function _arrayLikeToArray$s(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; }
|
|
4270
|
-
function ownKeys$
|
|
4271
|
-
function _objectSpread$
|
|
4270
|
+
function ownKeys$W(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; }
|
|
4271
|
+
function _objectSpread$W(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$W(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$W(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
4272
4272
|
var RegistryDashboardDetail = function RegistryDashboardDetail(_ref) {
|
|
4273
4273
|
var dashboardPackage = _ref.dashboardPackage,
|
|
4274
4274
|
appId = _ref.appId,
|
|
@@ -4384,7 +4384,7 @@ var RegistryDashboardDetail = function RegistryDashboardDetail(_ref) {
|
|
|
4384
4384
|
setProgressWidgets(function (prev) {
|
|
4385
4385
|
var next = _toConsumableArray(prev);
|
|
4386
4386
|
if (data.index >= 0 && data.index < next.length) {
|
|
4387
|
-
next[data.index] = _objectSpread$
|
|
4387
|
+
next[data.index] = _objectSpread$W(_objectSpread$W({}, next[data.index]), {}, {
|
|
4388
4388
|
status: data.status,
|
|
4389
4389
|
error: data.error || null
|
|
4390
4390
|
});
|
|
@@ -4480,7 +4480,7 @@ var RegistryDashboardDetail = function RegistryDashboardDetail(_ref) {
|
|
|
4480
4480
|
var raw = preview === null || preview === void 0 ? void 0 : preview.compatibility;
|
|
4481
4481
|
if (!raw) return raw;
|
|
4482
4482
|
var cMap = ComponentManager.componentMap();
|
|
4483
|
-
var augWidgets = _objectSpread$
|
|
4483
|
+
var augWidgets = _objectSpread$W({}, raw.widgets);
|
|
4484
4484
|
var fixedCount = 0;
|
|
4485
4485
|
var _loop = function _loop() {
|
|
4486
4486
|
var _Object$entries$_i = _slicedToArray(_Object$entries[_i], 2),
|
|
@@ -5063,8 +5063,8 @@ var DiscoverDashboardsDetail = function DiscoverDashboardsDetail(_ref) {
|
|
|
5063
5063
|
});
|
|
5064
5064
|
};
|
|
5065
5065
|
|
|
5066
|
-
function ownKeys$
|
|
5067
|
-
function _objectSpread$
|
|
5066
|
+
function ownKeys$V(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; }
|
|
5067
|
+
function _objectSpread$V(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$V(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$V(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
5068
5068
|
var LayoutManagerModal = function LayoutManagerModal(_ref) {
|
|
5069
5069
|
var open = _ref.open,
|
|
5070
5070
|
setIsOpen = _ref.setIsOpen,
|
|
@@ -5309,7 +5309,7 @@ var LayoutManagerModal = function LayoutManagerModal(_ref) {
|
|
|
5309
5309
|
}
|
|
5310
5310
|
return _context2.abrupt("return");
|
|
5311
5311
|
case 6:
|
|
5312
|
-
updatedWorkspace = _objectSpread$
|
|
5312
|
+
updatedWorkspace = _objectSpread$V(_objectSpread$V({}, importedWorkspace), {}, {
|
|
5313
5313
|
name: dashboardName.trim(),
|
|
5314
5314
|
menuId: menuId,
|
|
5315
5315
|
themeKey: selectedThemeKey
|
|
@@ -7067,8 +7067,8 @@ function applyFilters(items, filters, mode) {
|
|
|
7067
7067
|
function _createForOfIteratorHelper$q(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray$q(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t["return"] || t["return"](); } finally { if (u) throw o; } } }; }
|
|
7068
7068
|
function _unsupportedIterableToArray$q(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray$q(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$q(r, a) : void 0; } }
|
|
7069
7069
|
function _arrayLikeToArray$q(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; }
|
|
7070
|
-
function ownKeys$
|
|
7071
|
-
function _objectSpread$
|
|
7070
|
+
function ownKeys$U(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; }
|
|
7071
|
+
function _objectSpread$U(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$U(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$U(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
7072
7072
|
var WizardCustomizeStep = function WizardCustomizeStep(_ref) {
|
|
7073
7073
|
var _state$selectedDashbo, _state$selectedDashbo2;
|
|
7074
7074
|
var state = _ref.state,
|
|
@@ -7238,7 +7238,7 @@ var WizardCustomizeStep = function WizardCustomizeStep(_ref) {
|
|
|
7238
7238
|
_context2.next = 7;
|
|
7239
7239
|
break;
|
|
7240
7240
|
}
|
|
7241
|
-
updatedWorkspace = _objectSpread$
|
|
7241
|
+
updatedWorkspace = _objectSpread$U(_objectSpread$U({}, installResult.workspace), {}, {
|
|
7242
7242
|
name: name.trim(),
|
|
7243
7243
|
menuId: menuId || 1,
|
|
7244
7244
|
themeKey: theme
|
|
@@ -7993,8 +7993,8 @@ var WizardCustomizeStep = function WizardCustomizeStep(_ref) {
|
|
|
7993
7993
|
});
|
|
7994
7994
|
};
|
|
7995
7995
|
|
|
7996
|
-
function ownKeys$
|
|
7997
|
-
function _objectSpread$
|
|
7996
|
+
function ownKeys$T(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; }
|
|
7997
|
+
function _objectSpread$T(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$T(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$T(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
7998
7998
|
var TOTAL_STEPS = 2; // Steps 0-1: Discover, Customize
|
|
7999
7999
|
|
|
8000
8000
|
var initialState = {
|
|
@@ -8020,20 +8020,20 @@ var initialState = {
|
|
|
8020
8020
|
function wizardReducer(state, action) {
|
|
8021
8021
|
switch (action.type) {
|
|
8022
8022
|
case "SET_STEP":
|
|
8023
|
-
return _objectSpread$
|
|
8023
|
+
return _objectSpread$T(_objectSpread$T({}, state), {}, {
|
|
8024
8024
|
step: action.payload
|
|
8025
8025
|
});
|
|
8026
8026
|
case "SET_FILTERS":
|
|
8027
|
-
return _objectSpread$
|
|
8028
|
-
filters: _objectSpread$
|
|
8027
|
+
return _objectSpread$T(_objectSpread$T({}, state), {}, {
|
|
8028
|
+
filters: _objectSpread$T(_objectSpread$T({}, state.filters), action.payload)
|
|
8029
8029
|
});
|
|
8030
8030
|
case "TOGGLE_FILTER_CATEGORY":
|
|
8031
8031
|
{
|
|
8032
8032
|
var categories = state.filters.categories.includes(action.payload) ? state.filters.categories.filter(function (c) {
|
|
8033
8033
|
return c !== action.payload;
|
|
8034
8034
|
}) : [].concat(_toConsumableArray(state.filters.categories), [action.payload]);
|
|
8035
|
-
return _objectSpread$
|
|
8036
|
-
filters: _objectSpread$
|
|
8035
|
+
return _objectSpread$T(_objectSpread$T({}, state), {}, {
|
|
8036
|
+
filters: _objectSpread$T(_objectSpread$T({}, state.filters), {}, {
|
|
8037
8037
|
categories: categories
|
|
8038
8038
|
})
|
|
8039
8039
|
});
|
|
@@ -8043,15 +8043,15 @@ function wizardReducer(state, action) {
|
|
|
8043
8043
|
var providers = state.filters.providers.includes(action.payload) ? state.filters.providers.filter(function (p) {
|
|
8044
8044
|
return p !== action.payload;
|
|
8045
8045
|
}) : [].concat(_toConsumableArray(state.filters.providers), [action.payload]);
|
|
8046
|
-
return _objectSpread$
|
|
8047
|
-
filters: _objectSpread$
|
|
8046
|
+
return _objectSpread$T(_objectSpread$T({}, state), {}, {
|
|
8047
|
+
filters: _objectSpread$T(_objectSpread$T({}, state.filters), {}, {
|
|
8048
8048
|
providers: providers
|
|
8049
8049
|
})
|
|
8050
8050
|
});
|
|
8051
8051
|
}
|
|
8052
8052
|
case "SET_SEARCH_QUERY":
|
|
8053
|
-
return _objectSpread$
|
|
8054
|
-
filters: _objectSpread$
|
|
8053
|
+
return _objectSpread$T(_objectSpread$T({}, state), {}, {
|
|
8054
|
+
filters: _objectSpread$T(_objectSpread$T({}, state.filters), {}, {
|
|
8055
8055
|
query: action.payload
|
|
8056
8056
|
})
|
|
8057
8057
|
});
|
|
@@ -8061,7 +8061,7 @@ function wizardReducer(state, action) {
|
|
|
8061
8061
|
var widgetOrder = action.payload.map(function (w) {
|
|
8062
8062
|
return w.name || w.key;
|
|
8063
8063
|
});
|
|
8064
|
-
return _objectSpread$
|
|
8064
|
+
return _objectSpread$T(_objectSpread$T({}, state), {}, {
|
|
8065
8065
|
selectedWidgets: action.payload,
|
|
8066
8066
|
layout: {
|
|
8067
8067
|
templateKey: templateKey,
|
|
@@ -8081,7 +8081,7 @@ function wizardReducer(state, action) {
|
|
|
8081
8081
|
var toggleWidgetOrder = selectedWidgets.map(function (w) {
|
|
8082
8082
|
return w.name || w.key;
|
|
8083
8083
|
});
|
|
8084
|
-
return _objectSpread$
|
|
8084
|
+
return _objectSpread$T(_objectSpread$T({}, state), {}, {
|
|
8085
8085
|
selectedWidgets: selectedWidgets,
|
|
8086
8086
|
layout: {
|
|
8087
8087
|
templateKey: toggleTemplateKey,
|
|
@@ -8090,29 +8090,29 @@ function wizardReducer(state, action) {
|
|
|
8090
8090
|
});
|
|
8091
8091
|
}
|
|
8092
8092
|
case "SET_SELECTED_DASHBOARD":
|
|
8093
|
-
return _objectSpread$
|
|
8093
|
+
return _objectSpread$T(_objectSpread$T({}, state), {}, {
|
|
8094
8094
|
selectedDashboard: action.payload
|
|
8095
8095
|
});
|
|
8096
8096
|
case "SET_PATH":
|
|
8097
|
-
return _objectSpread$
|
|
8097
|
+
return _objectSpread$T(_objectSpread$T({}, state), {}, {
|
|
8098
8098
|
path: action.payload
|
|
8099
8099
|
});
|
|
8100
8100
|
case "SET_LAYOUT":
|
|
8101
|
-
return _objectSpread$
|
|
8101
|
+
return _objectSpread$T(_objectSpread$T({}, state), {}, {
|
|
8102
8102
|
layout: action.payload
|
|
8103
8103
|
});
|
|
8104
8104
|
case "REORDER_WIDGETS":
|
|
8105
|
-
return _objectSpread$
|
|
8106
|
-
layout: _objectSpread$
|
|
8105
|
+
return _objectSpread$T(_objectSpread$T({}, state), {}, {
|
|
8106
|
+
layout: _objectSpread$T(_objectSpread$T({}, state.layout), {}, {
|
|
8107
8107
|
widgetOrder: action.payload
|
|
8108
8108
|
})
|
|
8109
8109
|
});
|
|
8110
8110
|
case "SET_CUSTOMIZATION":
|
|
8111
|
-
return _objectSpread$
|
|
8112
|
-
customization: _objectSpread$
|
|
8111
|
+
return _objectSpread$T(_objectSpread$T({}, state), {}, {
|
|
8112
|
+
customization: _objectSpread$T(_objectSpread$T({}, state.customization), action.payload)
|
|
8113
8113
|
});
|
|
8114
8114
|
case "RESET":
|
|
8115
|
-
return _objectSpread$
|
|
8115
|
+
return _objectSpread$T({}, initialState);
|
|
8116
8116
|
default:
|
|
8117
8117
|
return state;
|
|
8118
8118
|
}
|
|
@@ -12922,8 +12922,8 @@ var _excluded$6 = ["rows", "cols"];
|
|
|
12922
12922
|
function _createForOfIteratorHelper$p(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray$p(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t["return"] || t["return"](); } finally { if (u) throw o; } } }; }
|
|
12923
12923
|
function _unsupportedIterableToArray$p(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray$p(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$p(r, a) : void 0; } }
|
|
12924
12924
|
function _arrayLikeToArray$p(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; }
|
|
12925
|
-
function ownKeys$
|
|
12926
|
-
function _objectSpread$
|
|
12925
|
+
function ownKeys$S(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; }
|
|
12926
|
+
function _objectSpread$S(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$S(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$S(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
12927
12927
|
var defaultGrid = {
|
|
12928
12928
|
rows: 1,
|
|
12929
12929
|
cols: 1,
|
|
@@ -12944,7 +12944,7 @@ function GridEditor(_ref) {
|
|
|
12944
12944
|
setGrid = _useState2[1];
|
|
12945
12945
|
var addRow = function addRow() {
|
|
12946
12946
|
var newRow = grid.rows;
|
|
12947
|
-
var newGrid = _objectSpread$
|
|
12947
|
+
var newGrid = _objectSpread$S(_objectSpread$S({}, grid), {}, {
|
|
12948
12948
|
rows: grid.rows + 1
|
|
12949
12949
|
});
|
|
12950
12950
|
for (var col = 0; col < grid.cols; col++) {
|
|
@@ -12959,7 +12959,7 @@ function GridEditor(_ref) {
|
|
|
12959
12959
|
};
|
|
12960
12960
|
var addColumn = function addColumn() {
|
|
12961
12961
|
var newCol = grid.cols;
|
|
12962
|
-
var newGrid = _objectSpread$
|
|
12962
|
+
var newGrid = _objectSpread$S(_objectSpread$S({}, grid), {}, {
|
|
12963
12963
|
cols: grid.cols + 1
|
|
12964
12964
|
});
|
|
12965
12965
|
for (var row = 0; row < grid.rows; row++) {
|
|
@@ -12992,8 +12992,8 @@ function GridEditor(_ref) {
|
|
|
12992
12992
|
});
|
|
12993
12993
|
}
|
|
12994
12994
|
if (grid[nextKey]) {
|
|
12995
|
-
var newGrid = _objectSpread$
|
|
12996
|
-
newGrid[currentKey] = _objectSpread$
|
|
12995
|
+
var newGrid = _objectSpread$S({}, grid);
|
|
12996
|
+
newGrid[currentKey] = _objectSpread$S(_objectSpread$S({}, newGrid[currentKey]), {}, {
|
|
12997
12997
|
colSpan: newGrid[currentKey].colSpan + 1
|
|
12998
12998
|
});
|
|
12999
12999
|
delete newGrid[nextKey];
|
|
@@ -13006,8 +13006,8 @@ function GridEditor(_ref) {
|
|
|
13006
13006
|
var currentKey = "".concat(row, ".").concat(col);
|
|
13007
13007
|
var belowKey = "".concat(row + 1, ".").concat(col);
|
|
13008
13008
|
if (grid[belowKey]) {
|
|
13009
|
-
var newGrid = _objectSpread$
|
|
13010
|
-
newGrid[currentKey] = _objectSpread$
|
|
13009
|
+
var newGrid = _objectSpread$S({}, grid);
|
|
13010
|
+
newGrid[currentKey] = _objectSpread$S(_objectSpread$S({}, newGrid[currentKey]), {}, {
|
|
13011
13011
|
rowSpan: newGrid[currentKey].rowSpan + 1
|
|
13012
13012
|
});
|
|
13013
13013
|
delete newGrid[belowKey];
|
|
@@ -13024,7 +13024,7 @@ function GridEditor(_ref) {
|
|
|
13024
13024
|
var splitCell = function splitCell(row, col) {
|
|
13025
13025
|
var key = "".concat(row, ".").concat(col);
|
|
13026
13026
|
var cell = grid[key];
|
|
13027
|
-
var newGrid = _objectSpread$
|
|
13027
|
+
var newGrid = _objectSpread$S({}, grid);
|
|
13028
13028
|
|
|
13029
13029
|
// we have to check the colspan, and since the colspan is greater than 1
|
|
13030
13030
|
// Only handle horizontal split if colSpan > 1
|
|
@@ -13040,13 +13040,13 @@ function GridEditor(_ref) {
|
|
|
13040
13040
|
var oldKey = "".concat(row, ".").concat(c);
|
|
13041
13041
|
var newKey = "".concat(row, ".").concat(c + 1);
|
|
13042
13042
|
if (newGrid[oldKey]) {
|
|
13043
|
-
newGrid[newKey] = _objectSpread$
|
|
13043
|
+
newGrid[newKey] = _objectSpread$S({}, newGrid[oldKey]);
|
|
13044
13044
|
delete newGrid[oldKey];
|
|
13045
13045
|
}
|
|
13046
13046
|
}
|
|
13047
13047
|
|
|
13048
13048
|
// Update the original cell's colSpan
|
|
13049
|
-
newGrid[key] = _objectSpread$
|
|
13049
|
+
newGrid[key] = _objectSpread$S(_objectSpread$S({}, cell), {}, {
|
|
13050
13050
|
colSpan: cell.colSpan - 1
|
|
13051
13051
|
});
|
|
13052
13052
|
|
|
@@ -13058,7 +13058,7 @@ function GridEditor(_ref) {
|
|
|
13058
13058
|
};
|
|
13059
13059
|
}
|
|
13060
13060
|
if (cell.rowSpan > 1) {
|
|
13061
|
-
newGrid[key] = _objectSpread$
|
|
13061
|
+
newGrid[key] = _objectSpread$S(_objectSpread$S({}, newGrid[key]), {}, {
|
|
13062
13062
|
rowSpan: cell.rowSpan - 1
|
|
13063
13063
|
});
|
|
13064
13064
|
newGrid["".concat(row + 1, ".").concat(col)] = {
|
|
@@ -13177,7 +13177,7 @@ function GridEditor(_ref) {
|
|
|
13177
13177
|
var fromKey = "".concat(from.row, ".").concat(from.col);
|
|
13178
13178
|
var toKey = "".concat(to.row, ".").concat(to.col);
|
|
13179
13179
|
if (fromKey === toKey) return;
|
|
13180
|
-
var newGrid = _objectSpread$
|
|
13180
|
+
var newGrid = _objectSpread$S({}, grid);
|
|
13181
13181
|
|
|
13182
13182
|
// Swap the cells
|
|
13183
13183
|
var temp = newGrid[fromKey];
|
|
@@ -13203,7 +13203,7 @@ function GridEditor(_ref) {
|
|
|
13203
13203
|
// console.log("Grid updated:", sequencedGrid);
|
|
13204
13204
|
}
|
|
13205
13205
|
function resetGridLayout() {
|
|
13206
|
-
var newGrid = _objectSpread$
|
|
13206
|
+
var newGrid = _objectSpread$S({}, defaultGrid);
|
|
13207
13207
|
setGrid(newGrid);
|
|
13208
13208
|
onUpdate(newGrid);
|
|
13209
13209
|
}
|
|
@@ -13481,8 +13481,8 @@ var PanelEditItemGrid = function PanelEditItemGrid(_ref) {
|
|
|
13481
13481
|
});
|
|
13482
13482
|
};
|
|
13483
13483
|
|
|
13484
|
-
function ownKeys$
|
|
13485
|
-
function _objectSpread$
|
|
13484
|
+
function ownKeys$R(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; }
|
|
13485
|
+
function _objectSpread$R(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$R(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$R(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
13486
13486
|
var PanelEditItemNotifications = function PanelEditItemNotifications(_ref) {
|
|
13487
13487
|
var item = _ref.item;
|
|
13488
13488
|
_ref.workspace;
|
|
@@ -13505,7 +13505,7 @@ var PanelEditItemNotifications = function PanelEditItemNotifications(_ref) {
|
|
|
13505
13505
|
}, [widgetUuid, notificationDefs.length]);
|
|
13506
13506
|
function handleNotifToggle(typeKey, value) {
|
|
13507
13507
|
var _window$mainApi2;
|
|
13508
|
-
var updated = _objectSpread$
|
|
13508
|
+
var updated = _objectSpread$R(_objectSpread$R({}, notifPrefs), {}, _defineProperty({}, typeKey, value));
|
|
13509
13509
|
setNotifPrefs(updated);
|
|
13510
13510
|
if ((_window$mainApi2 = window.mainApi) !== null && _window$mainApi2 !== void 0 && (_window$mainApi2 = _window$mainApi2.notifications) !== null && _window$mainApi2 !== void 0 && _window$mainApi2.setPreferences && widgetUuid) {
|
|
13511
13511
|
window.mainApi.notifications.setPreferences(widgetUuid, _defineProperty({}, typeKey, value));
|
|
@@ -13550,8 +13550,8 @@ var PanelEditItemNotifications = function PanelEditItemNotifications(_ref) {
|
|
|
13550
13550
|
function _createForOfIteratorHelper$o(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray$o(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t["return"] || t["return"](); } finally { if (u) throw o; } } }; }
|
|
13551
13551
|
function _unsupportedIterableToArray$o(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray$o(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$o(r, a) : void 0; } }
|
|
13552
13552
|
function _arrayLikeToArray$o(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; }
|
|
13553
|
-
function ownKeys$
|
|
13554
|
-
function _objectSpread$
|
|
13553
|
+
function ownKeys$Q(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; }
|
|
13554
|
+
function _objectSpread$Q(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$Q(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$Q(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
13555
13555
|
var DAYS = [{
|
|
13556
13556
|
key: "mon",
|
|
13557
13557
|
label: "Mon"
|
|
@@ -13652,7 +13652,7 @@ function TaskScheduleEditor(_ref) {
|
|
|
13652
13652
|
var _window$mainApi;
|
|
13653
13653
|
var overrides = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
13654
13654
|
if (!((_window$mainApi = window.mainApi) !== null && _window$mainApi !== void 0 && (_window$mainApi = _window$mainApi.scheduler) !== null && _window$mainApi !== void 0 && _window$mainApi.registerTask)) return;
|
|
13655
|
-
var payload = _objectSpread$
|
|
13655
|
+
var payload = _objectSpread$Q({
|
|
13656
13656
|
widgetId: widgetId,
|
|
13657
13657
|
widgetName: widgetName,
|
|
13658
13658
|
workspaceId: workspaceId || "",
|
|
@@ -13927,6 +13927,25 @@ var PanelEditItemSchedule = function PanelEditItemSchedule(_ref2) {
|
|
|
13927
13927
|
});
|
|
13928
13928
|
};
|
|
13929
13929
|
|
|
13930
|
+
function ownKeys$P(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; }
|
|
13931
|
+
function _objectSpread$P(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$P(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$P(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
13932
|
+
var DERIVED_FIELDS = ["widgetConfig",
|
|
13933
|
+
// biggest offender — full component definition blob
|
|
13934
|
+
"uuid", "dashboardId", "parentWorkspaceName", "componentName", "siblingCount", "hasChildren", "canHaveChildren", "events",
|
|
13935
|
+
// declared by the widget's .dash.js, not editable per-item
|
|
13936
|
+
"eventHandlers"];
|
|
13937
|
+
function stripDerivedFields(item) {
|
|
13938
|
+
if (!item || _typeof(item) !== "object") return item;
|
|
13939
|
+
var out = {};
|
|
13940
|
+
for (var _i = 0, _Object$entries = Object.entries(item); _i < _Object$entries.length; _i++) {
|
|
13941
|
+
var _Object$entries$_i = _slicedToArray(_Object$entries[_i], 2),
|
|
13942
|
+
k = _Object$entries$_i[0],
|
|
13943
|
+
v = _Object$entries$_i[1];
|
|
13944
|
+
if (DERIVED_FIELDS.includes(k)) continue;
|
|
13945
|
+
out[k] = v;
|
|
13946
|
+
}
|
|
13947
|
+
return out;
|
|
13948
|
+
}
|
|
13930
13949
|
var PanelCode = function PanelCode(_ref) {
|
|
13931
13950
|
var workspace = _ref.workspace,
|
|
13932
13951
|
onUpdate = _ref.onUpdate,
|
|
@@ -13961,18 +13980,43 @@ var PanelCode = function PanelCode(_ref) {
|
|
|
13961
13980
|
}
|
|
13962
13981
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
13963
13982
|
}, [workspace, item]);
|
|
13983
|
+
var displayJson = useMemo(function () {
|
|
13984
|
+
if (!itemSelected) return "";
|
|
13985
|
+
return JSON.stringify(stripDerivedFields(itemSelected), null, 2);
|
|
13986
|
+
}, [itemSelected]);
|
|
13964
13987
|
function handleCodeChange(code) {
|
|
13965
|
-
|
|
13966
|
-
|
|
13988
|
+
try {
|
|
13989
|
+
var edited = JSON.parse(code);
|
|
13990
|
+
// Preserve the derived fields from the live item so save +
|
|
13991
|
+
// re-render stays in sync with what the rest of the layout
|
|
13992
|
+
// expects. LayoutModel re-derives these on reload, but losing
|
|
13993
|
+
// them between render cycles can cause flashes of "unknown
|
|
13994
|
+
// widget" state.
|
|
13995
|
+
var merged = _objectSpread$P({}, itemSelected);
|
|
13996
|
+
for (var _i2 = 0, _Object$keys = Object.keys(edited); _i2 < _Object$keys.length; _i2++) {
|
|
13997
|
+
var k = _Object$keys[_i2];
|
|
13998
|
+
merged[k] = edited[k];
|
|
13999
|
+
}
|
|
14000
|
+
onUpdate(merged, workspaceSelected);
|
|
14001
|
+
} catch (_unused) {
|
|
14002
|
+
// Malformed JSON — leave state alone; the editor keeps the
|
|
14003
|
+
// user's text so they can fix it.
|
|
14004
|
+
}
|
|
13967
14005
|
}
|
|
13968
14006
|
return itemSelected && workspaceSelected && /*#__PURE__*/jsx("div", {
|
|
13969
14007
|
className: "flex flex-col flex-1 min-h-0",
|
|
13970
14008
|
children: /*#__PURE__*/jsx("div", {
|
|
13971
|
-
className: "flex-1 min-h-0 overflow-hidden",
|
|
13972
|
-
children: /*#__PURE__*/jsx(
|
|
13973
|
-
|
|
13974
|
-
|
|
13975
|
-
|
|
14009
|
+
className: "flex-1 min-h-0 overflow-hidden relative",
|
|
14010
|
+
children: /*#__PURE__*/jsx("div", {
|
|
14011
|
+
className: "absolute inset-0",
|
|
14012
|
+
children: /*#__PURE__*/jsx(CodeEditorVS, {
|
|
14013
|
+
code: displayJson,
|
|
14014
|
+
language: "json",
|
|
14015
|
+
onChange: handleCodeChange,
|
|
14016
|
+
readOnly: false,
|
|
14017
|
+
minimapEnabled: false,
|
|
14018
|
+
padding: "p-0"
|
|
14019
|
+
})
|
|
13976
14020
|
})
|
|
13977
14021
|
})
|
|
13978
14022
|
});
|
|
@@ -14508,6 +14552,39 @@ var LayoutBuilderConfigModal = function LayoutBuilderConfigModal(_ref) {
|
|
|
14508
14552
|
var activeDef = sections.find(function (s) {
|
|
14509
14553
|
return s.key === activeSection;
|
|
14510
14554
|
}) || sections[0];
|
|
14555
|
+
|
|
14556
|
+
// Scope/package label for the footer so the user can tell which
|
|
14557
|
+
// package a widget comes from (ambiguous component names like
|
|
14558
|
+
// `ProspectListColumn` can live under either `@ai-built/…` or
|
|
14559
|
+
// `@trops/pipeline`). Same derivation order as WidgetCardHeader:
|
|
14560
|
+
// widget config id → widget config package → layout item workspace.
|
|
14561
|
+
var footerPackageLabel = function () {
|
|
14562
|
+
if (!itemSelected) return "";
|
|
14563
|
+
var cfg = ComponentManager.config(itemSelected.component, itemSelected);
|
|
14564
|
+
var dropTrailingComponent = function dropTrailingComponent(s) {
|
|
14565
|
+
if (typeof s !== "string") return "";
|
|
14566
|
+
var lastDot = s.lastIndexOf(".");
|
|
14567
|
+
return lastDot > 0 ? s.slice(0, lastDot) : s;
|
|
14568
|
+
};
|
|
14569
|
+
var fromId = dropTrailingComponent((cfg === null || cfg === void 0 ? void 0 : cfg.id) || "");
|
|
14570
|
+
if (fromId) return fromId;
|
|
14571
|
+
if (cfg !== null && cfg !== void 0 && cfg["package"]) return String(cfg["package"]);
|
|
14572
|
+
var ws = itemSelected.workspace;
|
|
14573
|
+
if (typeof ws === "string" && ws && ws !== "layout") {
|
|
14574
|
+
return ws.startsWith("@") ? ws : "@".concat(ws);
|
|
14575
|
+
}
|
|
14576
|
+
return "";
|
|
14577
|
+
}();
|
|
14578
|
+
var componentName = itemSelected ? itemSelected["component"] : "";
|
|
14579
|
+
var footerLeftContent = footerPackageLabel ? /*#__PURE__*/jsxs("span", {
|
|
14580
|
+
className: "flex flex-col leading-tight",
|
|
14581
|
+
children: [/*#__PURE__*/jsx("span", {
|
|
14582
|
+
children: componentName
|
|
14583
|
+
}), /*#__PURE__*/jsx("span", {
|
|
14584
|
+
className: "text-[10px] opacity-50",
|
|
14585
|
+
children: footerPackageLabel
|
|
14586
|
+
})]
|
|
14587
|
+
}) : componentName;
|
|
14511
14588
|
return itemSelected !== null && /*#__PURE__*/jsxs(SettingsModal, {
|
|
14512
14589
|
isOpen: open,
|
|
14513
14590
|
setIsOpen: setIsOpen,
|
|
@@ -14570,7 +14647,7 @@ var LayoutBuilderConfigModal = function LayoutBuilderConfigModal(_ref) {
|
|
|
14570
14647
|
workspace: workspaceSelected
|
|
14571
14648
|
})]
|
|
14572
14649
|
}), /*#__PURE__*/jsxs(SettingsModal.Footer, {
|
|
14573
|
-
leftContent:
|
|
14650
|
+
leftContent: footerLeftContent,
|
|
14574
14651
|
children: [/*#__PURE__*/jsx(Button, {
|
|
14575
14652
|
title: "Cancel",
|
|
14576
14653
|
onClick: function onClick() {
|
|
@@ -20756,7 +20833,8 @@ var LayoutBuilder = function LayoutBuilder(_ref) {
|
|
|
20756
20833
|
try {
|
|
20757
20834
|
var hasChildren = config.type === "workspace";
|
|
20758
20835
|
var newLayout = addItemToItemLayout(ws.layout, gridItem.id, _objectSpread$I(_objectSpread$I({}, config), {}, {
|
|
20759
|
-
component: widgetComponentName
|
|
20836
|
+
component: widgetComponentName,
|
|
20837
|
+
packageId: config._sourcePackage || config.packageId || null
|
|
20760
20838
|
}), hasChildren);
|
|
20761
20839
|
var newWidgetId = newLayout[newLayout.length - 1].id;
|
|
20762
20840
|
var updatedGrid = newLayout.find(function (item) {
|
|
@@ -20800,7 +20878,11 @@ var LayoutBuilder = function LayoutBuilder(_ref) {
|
|
|
20800
20878
|
try {
|
|
20801
20879
|
var newLayout = updateLayoutItem(ws.layout, {
|
|
20802
20880
|
id: widgetId,
|
|
20803
|
-
component: widgetComponentName
|
|
20881
|
+
component: widgetComponentName,
|
|
20882
|
+
// Stamp the replacement's source package onto the item so
|
|
20883
|
+
// publish-time attribution routes to the new package, not
|
|
20884
|
+
// whatever the item was previously carrying.
|
|
20885
|
+
packageId: config._sourcePackage || config.packageId || null
|
|
20804
20886
|
});
|
|
20805
20887
|
if (!newLayout) {
|
|
20806
20888
|
return;
|
|
@@ -20909,13 +20991,11 @@ var LayoutBuilder = function LayoutBuilder(_ref) {
|
|
|
20909
20991
|
try {
|
|
20910
20992
|
var dashboard = new DashboardModel(currentWorkspace);
|
|
20911
20993
|
dashboard.removeItemFromLayout(id);
|
|
20912
|
-
|
|
20913
|
-
|
|
20914
|
-
|
|
20915
|
-
|
|
20916
|
-
|
|
20917
|
-
// newWorkspace["layout"] = newLayout;
|
|
20918
|
-
// setCurrentWorkspace(newWorkspace);
|
|
20994
|
+
var nextWorkspace = dashboard.workspace();
|
|
20995
|
+
setCurrentWorkspace(nextWorkspace);
|
|
20996
|
+
if (typeof onWorkspaceChangeRef.current === "function") {
|
|
20997
|
+
onWorkspaceChangeRef.current(nextWorkspace);
|
|
20998
|
+
}
|
|
20919
20999
|
} catch (e) {
|
|
20920
21000
|
}
|
|
20921
21001
|
}
|
|
@@ -21327,7 +21407,8 @@ var LayoutBuilder = function LayoutBuilder(_ref) {
|
|
|
21327
21407
|
if (!config) return;
|
|
21328
21408
|
var widgetItem = _objectSpread$I(_objectSpread$I({}, config), {}, {
|
|
21329
21409
|
component: widgetKey,
|
|
21330
|
-
key: widgetKey
|
|
21410
|
+
key: widgetKey,
|
|
21411
|
+
packageId: config._sourcePackage || config.packageId || null
|
|
21331
21412
|
});
|
|
21332
21413
|
|
|
21333
21414
|
// Remove old widget from layout if the target cell is already occupied
|
|
@@ -21359,6 +21440,9 @@ var LayoutBuilder = function LayoutBuilder(_ref) {
|
|
|
21359
21440
|
var newWorkspace = JSON.parse(JSON.stringify(_workspace));
|
|
21360
21441
|
newWorkspace["layout"] = newLayout;
|
|
21361
21442
|
setCurrentWorkspace(newWorkspace);
|
|
21443
|
+
if (typeof onWorkspaceChangeRef.current === "function") {
|
|
21444
|
+
onWorkspaceChangeRef.current(newWorkspace);
|
|
21445
|
+
}
|
|
21362
21446
|
} catch (e) {
|
|
21363
21447
|
}
|
|
21364
21448
|
}
|
|
@@ -21368,6 +21452,9 @@ var LayoutBuilder = function LayoutBuilder(_ref) {
|
|
|
21368
21452
|
dashboard.moveWidgetToCell(gridContainerId, sourceCellNumber, targetCellNumber);
|
|
21369
21453
|
var newWorkspace = dashboard.workspace();
|
|
21370
21454
|
setCurrentWorkspace(newWorkspace);
|
|
21455
|
+
if (typeof onWorkspaceChangeRef.current === "function") {
|
|
21456
|
+
onWorkspaceChangeRef.current(newWorkspace);
|
|
21457
|
+
}
|
|
21371
21458
|
} catch (e) {
|
|
21372
21459
|
}
|
|
21373
21460
|
}
|
|
@@ -27579,6 +27666,17 @@ var LayoutModel = function LayoutModel(layoutItem, workspaceLayout, dashboardId)
|
|
|
27579
27666
|
// Preserve provider selections for this widget
|
|
27580
27667
|
layout.selectedProviders = "selectedProviders" in obj ? obj.selectedProviders : {};
|
|
27581
27668
|
|
|
27669
|
+
// Record the exact source package id (e.g. "@ai-built/pipeline")
|
|
27670
|
+
// from which this widget instance was added. Used by the publish
|
|
27671
|
+
// flow to attribute the widget to the correct package without
|
|
27672
|
+
// guessing when multiple installed packages declare the same
|
|
27673
|
+
// component name. Back-compat: read `_sourcePackage` (set by
|
|
27674
|
+
// dash-electron's widget registration) if `packageId` is missing.
|
|
27675
|
+
// Legacy layout items (added before this field existed) carry
|
|
27676
|
+
// neither — those still go through the ranking heuristic in
|
|
27677
|
+
// buildWidgetDependencies as a fallback.
|
|
27678
|
+
layout.packageId = "packageId" in obj ? obj["packageId"] : obj._sourcePackage ? obj._sourcePackage : null;
|
|
27679
|
+
|
|
27582
27680
|
/**
|
|
27583
27681
|
* @param {Object} grid Grid layout configuration
|
|
27584
27682
|
* Structure: {
|
|
@@ -54968,6 +55066,139 @@ var DashboardConfigModal = function DashboardConfigModal(_ref) {
|
|
|
54968
55066
|
return b.required && !b.resolvedProviderName;
|
|
54969
55067
|
}).length;
|
|
54970
55068
|
|
|
55069
|
+
// Dependencies tab data — groups every widget instance in the
|
|
55070
|
+
// workspace by the package it belongs to, so the user can audit
|
|
55071
|
+
// which packages the dashboard actually references (and see which
|
|
55072
|
+
// pages/sidebar hold each instance). Matches the same derivation
|
|
55073
|
+
// order we use in WidgetCardHeader / LayoutBuilderConfigModal's
|
|
55074
|
+
// footer so the same package label shows in every surface.
|
|
55075
|
+
var dependencies = useMemo(function () {
|
|
55076
|
+
var byPackage = new Map();
|
|
55077
|
+
var stripTrailingComponent = function stripTrailingComponent(s) {
|
|
55078
|
+
if (typeof s !== "string") return "";
|
|
55079
|
+
var lastDot = s.lastIndexOf(".");
|
|
55080
|
+
return lastDot > 0 ? s.slice(0, lastDot) : s;
|
|
55081
|
+
};
|
|
55082
|
+
var derivePackage = function derivePackage(item) {
|
|
55083
|
+
// The layout item records the exact source package id when the
|
|
55084
|
+
// widget was added. If present, trust it — no heuristics. This
|
|
55085
|
+
// matches the publish flow's attribution, so the Dependencies
|
|
55086
|
+
// tab and the Publish modal always agree.
|
|
55087
|
+
if (item !== null && item !== void 0 && item.packageId) return String(item.packageId);
|
|
55088
|
+
var cfg = typeof getWidgetConfig === "function" ? getWidgetConfig(item.component) : null;
|
|
55089
|
+
if (cfg !== null && cfg !== void 0 && cfg._sourcePackage) return String(cfg._sourcePackage);
|
|
55090
|
+
var fromId = stripTrailingComponent((cfg === null || cfg === void 0 ? void 0 : cfg.id) || "");
|
|
55091
|
+
if (fromId) return fromId;
|
|
55092
|
+
if (cfg !== null && cfg !== void 0 && cfg["package"]) return String(cfg["package"]);
|
|
55093
|
+
var ws = item === null || item === void 0 ? void 0 : item.workspace;
|
|
55094
|
+
if (typeof ws === "string" && ws && ws !== "layout") {
|
|
55095
|
+
return ws.startsWith("@") ? ws : "@".concat(ws);
|
|
55096
|
+
}
|
|
55097
|
+
return "(unknown)";
|
|
55098
|
+
};
|
|
55099
|
+
|
|
55100
|
+
// Tag each visit with its location so we can show users exactly
|
|
55101
|
+
// where in the tree a package is referenced. forEachWidget walks
|
|
55102
|
+
// the standard places but doesn't surface which one — so we do a
|
|
55103
|
+
// lightweight parallel walk and annotate.
|
|
55104
|
+
var annotatedWalks = [];
|
|
55105
|
+
if (Array.isArray(workspace === null || workspace === void 0 ? void 0 : workspace.layout)) {
|
|
55106
|
+
annotatedWalks.push({
|
|
55107
|
+
location: "root",
|
|
55108
|
+
layout: workspace.layout
|
|
55109
|
+
});
|
|
55110
|
+
}
|
|
55111
|
+
if (Array.isArray(workspace === null || workspace === void 0 ? void 0 : workspace.pages)) {
|
|
55112
|
+
var _iterator2 = _createForOfIteratorHelper$4(workspace.pages),
|
|
55113
|
+
_step2;
|
|
55114
|
+
try {
|
|
55115
|
+
for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
|
|
55116
|
+
var page = _step2.value;
|
|
55117
|
+
if (Array.isArray(page === null || page === void 0 ? void 0 : page.layout)) {
|
|
55118
|
+
annotatedWalks.push({
|
|
55119
|
+
location: "page: ".concat(page.name || page.id || "?"),
|
|
55120
|
+
layout: page.layout
|
|
55121
|
+
});
|
|
55122
|
+
}
|
|
55123
|
+
}
|
|
55124
|
+
} catch (err) {
|
|
55125
|
+
_iterator2.e(err);
|
|
55126
|
+
} finally {
|
|
55127
|
+
_iterator2.f();
|
|
55128
|
+
}
|
|
55129
|
+
}
|
|
55130
|
+
if (Array.isArray(workspace === null || workspace === void 0 ? void 0 : workspace.sidebarLayout)) {
|
|
55131
|
+
annotatedWalks.push({
|
|
55132
|
+
location: "sidebar",
|
|
55133
|
+
layout: workspace.sidebarLayout
|
|
55134
|
+
});
|
|
55135
|
+
}
|
|
55136
|
+
var visitedByLocation = new WeakSet();
|
|
55137
|
+
var _collect = function collect(items, location) {
|
|
55138
|
+
if (!Array.isArray(items)) return;
|
|
55139
|
+
var _iterator3 = _createForOfIteratorHelper$4(items),
|
|
55140
|
+
_step3;
|
|
55141
|
+
try {
|
|
55142
|
+
for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
|
|
55143
|
+
var item = _step3.value;
|
|
55144
|
+
if (!item || _typeof(item) !== "object") continue;
|
|
55145
|
+
if (item.component && !visitedByLocation.has(item)) {
|
|
55146
|
+
visitedByLocation.add(item);
|
|
55147
|
+
// Ignore layout containers — they're not widgets.
|
|
55148
|
+
if (item.component !== "Container" && item.component !== "LayoutGridContainer") {
|
|
55149
|
+
var pkg = derivePackage(item);
|
|
55150
|
+
if (!byPackage.has(pkg)) {
|
|
55151
|
+
byPackage.set(pkg, {
|
|
55152
|
+
packageLabel: pkg,
|
|
55153
|
+
components: new Map(),
|
|
55154
|
+
locations: new Set(),
|
|
55155
|
+
total: 0
|
|
55156
|
+
});
|
|
55157
|
+
}
|
|
55158
|
+
var entry = byPackage.get(pkg);
|
|
55159
|
+
entry.total += 1;
|
|
55160
|
+
entry.locations.add(location);
|
|
55161
|
+
var cKey = item.component;
|
|
55162
|
+
entry.components.set(cKey, (entry.components.get(cKey) || 0) + 1);
|
|
55163
|
+
}
|
|
55164
|
+
}
|
|
55165
|
+
if (Array.isArray(item.items)) _collect(item.items, location);
|
|
55166
|
+
if (Array.isArray(item.layout)) _collect(item.layout, location);
|
|
55167
|
+
}
|
|
55168
|
+
} catch (err) {
|
|
55169
|
+
_iterator3.e(err);
|
|
55170
|
+
} finally {
|
|
55171
|
+
_iterator3.f();
|
|
55172
|
+
}
|
|
55173
|
+
};
|
|
55174
|
+
for (var _i2 = 0, _annotatedWalks = annotatedWalks; _i2 < _annotatedWalks.length; _i2++) {
|
|
55175
|
+
var w = _annotatedWalks[_i2];
|
|
55176
|
+
_collect(w.layout, w.location);
|
|
55177
|
+
}
|
|
55178
|
+
return Array.from(byPackage.values()).map(function (e) {
|
|
55179
|
+
return _objectSpread$8(_objectSpread$8({}, e), {}, {
|
|
55180
|
+
components: Array.from(e.components.entries()).map(function (_ref2) {
|
|
55181
|
+
var _ref3 = _slicedToArray(_ref2, 2),
|
|
55182
|
+
component = _ref3[0],
|
|
55183
|
+
count = _ref3[1];
|
|
55184
|
+
return {
|
|
55185
|
+
component: component,
|
|
55186
|
+
count: count
|
|
55187
|
+
};
|
|
55188
|
+
}),
|
|
55189
|
+
locations: Array.from(e.locations)
|
|
55190
|
+
});
|
|
55191
|
+
}).sort(function (a, b) {
|
|
55192
|
+
return a.packageLabel.localeCompare(b.packageLabel);
|
|
55193
|
+
});
|
|
55194
|
+
}, [workspace, getWidgetConfig]);
|
|
55195
|
+
var dependencyCount = dependencies.length;
|
|
55196
|
+
// Second pass used for the badge when the user has an `(unknown)`
|
|
55197
|
+
// bucket — usually a sign of a stale reference they want to clean up.
|
|
55198
|
+
var hasUnknownDependency = dependencies.some(function (d) {
|
|
55199
|
+
return d.packageLabel === "(unknown)";
|
|
55200
|
+
});
|
|
55201
|
+
|
|
54971
55202
|
// Listeners tab data — emitter list, receiver list, current wiring,
|
|
54972
55203
|
// orphans. All recompute when the workspace or staged delta changes
|
|
54973
55204
|
// so the UI reflects pending edits without saving first.
|
|
@@ -55003,11 +55234,11 @@ var DashboardConfigModal = function DashboardConfigModal(_ref) {
|
|
|
55003
55234
|
}
|
|
55004
55235
|
if (stagedListeners.adds.length > 0) {
|
|
55005
55236
|
// Append; avoid duplicates against current state.
|
|
55006
|
-
var
|
|
55007
|
-
|
|
55237
|
+
var _iterator4 = _createForOfIteratorHelper$4(stagedListeners.adds),
|
|
55238
|
+
_step4;
|
|
55008
55239
|
try {
|
|
55009
55240
|
var _loop = function _loop() {
|
|
55010
|
-
var a =
|
|
55241
|
+
var a = _step4.value;
|
|
55011
55242
|
if (!next.some(function (w) {
|
|
55012
55243
|
return sameWiringEntry(w, a);
|
|
55013
55244
|
})) {
|
|
@@ -55016,28 +55247,28 @@ var DashboardConfigModal = function DashboardConfigModal(_ref) {
|
|
|
55016
55247
|
})]);
|
|
55017
55248
|
}
|
|
55018
55249
|
};
|
|
55019
|
-
for (
|
|
55250
|
+
for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {
|
|
55020
55251
|
_loop();
|
|
55021
55252
|
}
|
|
55022
55253
|
} catch (err) {
|
|
55023
|
-
|
|
55254
|
+
_iterator4.e(err);
|
|
55024
55255
|
} finally {
|
|
55025
|
-
|
|
55256
|
+
_iterator4.f();
|
|
55026
55257
|
}
|
|
55027
55258
|
}
|
|
55028
55259
|
if (orphans.length === 0) return next;
|
|
55029
55260
|
var orphanIndex = new Map();
|
|
55030
|
-
var
|
|
55031
|
-
|
|
55261
|
+
var _iterator5 = _createForOfIteratorHelper$4(orphans),
|
|
55262
|
+
_step5;
|
|
55032
55263
|
try {
|
|
55033
|
-
for (
|
|
55034
|
-
var o =
|
|
55264
|
+
for (_iterator5.s(); !(_step5 = _iterator5.n()).done;) {
|
|
55265
|
+
var o = _step5.value;
|
|
55035
55266
|
orphanIndex.set("".concat(o.receiverItemId, "|").concat(o.handlerName, "|").concat(o.sourceComponent, "|").concat(o.sourceItemId, "|").concat(o.eventName), o.reason);
|
|
55036
55267
|
}
|
|
55037
55268
|
} catch (err) {
|
|
55038
|
-
|
|
55269
|
+
_iterator5.e(err);
|
|
55039
55270
|
} finally {
|
|
55040
|
-
|
|
55271
|
+
_iterator5.f();
|
|
55041
55272
|
}
|
|
55042
55273
|
return next.map(function (w) {
|
|
55043
55274
|
var key = "".concat(w.receiverItemId, "|").concat(w.handlerName, "|").concat(w.sourceComponent, "|").concat(w.sourceItemId, "|").concat(w.eventName);
|
|
@@ -55069,17 +55300,17 @@ var DashboardConfigModal = function DashboardConfigModal(_ref) {
|
|
|
55069
55300
|
function stagePrefFieldForAll(targetWidgets, key, value) {
|
|
55070
55301
|
setStagedPrefs(function (prev) {
|
|
55071
55302
|
var next = _objectSpread$8({}, prev);
|
|
55072
|
-
var
|
|
55073
|
-
|
|
55303
|
+
var _iterator6 = _createForOfIteratorHelper$4(targetWidgets),
|
|
55304
|
+
_step6;
|
|
55074
55305
|
try {
|
|
55075
|
-
for (
|
|
55076
|
-
var w =
|
|
55306
|
+
for (_iterator6.s(); !(_step6 = _iterator6.n()).done;) {
|
|
55307
|
+
var w = _step6.value;
|
|
55077
55308
|
next[w.id] = _objectSpread$8(_objectSpread$8({}, next[w.id] || {}), {}, _defineProperty({}, key, value));
|
|
55078
55309
|
}
|
|
55079
55310
|
} catch (err) {
|
|
55080
|
-
|
|
55311
|
+
_iterator6.e(err);
|
|
55081
55312
|
} finally {
|
|
55082
|
-
|
|
55313
|
+
_iterator6.f();
|
|
55083
55314
|
}
|
|
55084
55315
|
return next;
|
|
55085
55316
|
});
|
|
@@ -55103,18 +55334,18 @@ var DashboardConfigModal = function DashboardConfigModal(_ref) {
|
|
|
55103
55334
|
});
|
|
55104
55335
|
setStaged(function (prev) {
|
|
55105
55336
|
var next = _objectSpread$8({}, prev);
|
|
55106
|
-
var
|
|
55107
|
-
|
|
55337
|
+
var _iterator7 = _createForOfIteratorHelper$4(affected),
|
|
55338
|
+
_step7;
|
|
55108
55339
|
try {
|
|
55109
|
-
for (
|
|
55110
|
-
var b =
|
|
55340
|
+
for (_iterator7.s(); !(_step7 = _iterator7.n()).done;) {
|
|
55341
|
+
var b = _step7.value;
|
|
55111
55342
|
if (!b.widgetId) continue;
|
|
55112
55343
|
next[b.widgetId] = _objectSpread$8(_objectSpread$8({}, next[b.widgetId] || {}), {}, _defineProperty({}, providerType, providerName || ""));
|
|
55113
55344
|
}
|
|
55114
55345
|
} catch (err) {
|
|
55115
|
-
|
|
55346
|
+
_iterator7.e(err);
|
|
55116
55347
|
} finally {
|
|
55117
|
-
|
|
55348
|
+
_iterator7.f();
|
|
55118
55349
|
}
|
|
55119
55350
|
return next;
|
|
55120
55351
|
});
|
|
@@ -55172,12 +55403,12 @@ var DashboardConfigModal = function DashboardConfigModal(_ref) {
|
|
|
55172
55403
|
function handleSave() {
|
|
55173
55404
|
// Provider changes
|
|
55174
55405
|
var providerChanges = [];
|
|
55175
|
-
for (var
|
|
55176
|
-
var _Object$entries2$_i = _slicedToArray(_Object$entries2[
|
|
55406
|
+
for (var _i3 = 0, _Object$entries2 = Object.entries(staged); _i3 < _Object$entries2.length; _i3++) {
|
|
55407
|
+
var _Object$entries2$_i = _slicedToArray(_Object$entries2[_i3], 2),
|
|
55177
55408
|
widgetId = _Object$entries2$_i[0],
|
|
55178
55409
|
byType = _Object$entries2$_i[1];
|
|
55179
|
-
for (var
|
|
55180
|
-
var _Object$entries3$_i = _slicedToArray(_Object$entries3[
|
|
55410
|
+
for (var _i4 = 0, _Object$entries3 = Object.entries(byType); _i4 < _Object$entries3.length; _i4++) {
|
|
55411
|
+
var _Object$entries3$_i = _slicedToArray(_Object$entries3[_i4], 2),
|
|
55181
55412
|
providerType = _Object$entries3$_i[0],
|
|
55182
55413
|
providerName = _Object$entries3$_i[1];
|
|
55183
55414
|
providerChanges.push({
|
|
@@ -55198,12 +55429,12 @@ var DashboardConfigModal = function DashboardConfigModal(_ref) {
|
|
|
55198
55429
|
|
|
55199
55430
|
// Widget userPrefs changes (Widgets tab)
|
|
55200
55431
|
var prefChanges = [];
|
|
55201
|
-
for (var
|
|
55202
|
-
var _Object$entries4$_i = _slicedToArray(_Object$entries4[
|
|
55432
|
+
for (var _i5 = 0, _Object$entries4 = Object.entries(stagedPrefs); _i5 < _Object$entries4.length; _i5++) {
|
|
55433
|
+
var _Object$entries4$_i = _slicedToArray(_Object$entries4[_i5], 2),
|
|
55203
55434
|
_widgetId = _Object$entries4$_i[0],
|
|
55204
55435
|
fields = _Object$entries4$_i[1];
|
|
55205
|
-
for (var
|
|
55206
|
-
var _Object$entries5$_i = _slicedToArray(_Object$entries5[
|
|
55436
|
+
for (var _i6 = 0, _Object$entries5 = Object.entries(fields); _i6 < _Object$entries5.length; _i6++) {
|
|
55437
|
+
var _Object$entries5$_i = _slicedToArray(_Object$entries5[_i6], 2),
|
|
55207
55438
|
key = _Object$entries5$_i[0],
|
|
55208
55439
|
value = _Object$entries5$_i[1];
|
|
55209
55440
|
prefChanges.push({
|
|
@@ -55289,6 +55520,18 @@ var DashboardConfigModal = function DashboardConfigModal(_ref) {
|
|
|
55289
55520
|
},
|
|
55290
55521
|
className: "px-3 py-1.5 text-sm font-medium -mb-px border-b-2 ".concat(activeTab === "widgets" ? "border-indigo-400" : "border-transparent opacity-60 hover:opacity-100"),
|
|
55291
55522
|
children: "Widgets"
|
|
55523
|
+
}), /*#__PURE__*/jsxs("button", {
|
|
55524
|
+
type: "button",
|
|
55525
|
+
onClick: function onClick() {
|
|
55526
|
+
return setActiveTab("dependencies");
|
|
55527
|
+
},
|
|
55528
|
+
className: "px-3 py-1.5 text-sm font-medium -mb-px border-b-2 ".concat(activeTab === "dependencies" ? "border-indigo-400" : "border-transparent opacity-60 hover:opacity-100"),
|
|
55529
|
+
children: ["Dependencies", dependencyCount > 0 && /*#__PURE__*/jsxs("span", {
|
|
55530
|
+
className: "ml-2 text-[10px] opacity-60",
|
|
55531
|
+
children: ["(", dependencyCount, ")"]
|
|
55532
|
+
}), hasUnknownDependency && /*#__PURE__*/jsx("span", {
|
|
55533
|
+
className: "ml-1 inline-block h-1.5 w-1.5 rounded-full bg-amber-400 align-middle"
|
|
55534
|
+
})]
|
|
55292
55535
|
})]
|
|
55293
55536
|
}), /*#__PURE__*/jsxs("div", {
|
|
55294
55537
|
className: "flex-1 min-h-0 ".concat(activeTab === "widgets" ? "" : "p-5"),
|
|
@@ -55309,6 +55552,8 @@ var DashboardConfigModal = function DashboardConfigModal(_ref) {
|
|
|
55309
55552
|
stagedPrefs: stagedPrefs,
|
|
55310
55553
|
stagePrefField: stagePrefField,
|
|
55311
55554
|
stagePrefFieldForAll: stagePrefFieldForAll
|
|
55555
|
+
}), activeTab === "dependencies" && /*#__PURE__*/jsx(DependenciesTab, {
|
|
55556
|
+
dependencies: dependencies
|
|
55312
55557
|
})]
|
|
55313
55558
|
}), /*#__PURE__*/jsxs("div", {
|
|
55314
55559
|
className: "flex-shrink-0 flex flex-row justify-end gap-2 p-4 border-t border-white/10",
|
|
@@ -55331,12 +55576,12 @@ var DashboardConfigModal = function DashboardConfigModal(_ref) {
|
|
|
55331
55576
|
* dot per-type when any widget of that type is unresolved). Column 2
|
|
55332
55577
|
* shows the selected type's bulk dropdown + per-widget dropdowns.
|
|
55333
55578
|
*/
|
|
55334
|
-
function ProvidersTab(
|
|
55579
|
+
function ProvidersTab(_ref4) {
|
|
55335
55580
|
var _typeEntries$, _selectedRows$;
|
|
55336
|
-
var grouped =
|
|
55337
|
-
providersByType =
|
|
55338
|
-
onBulk =
|
|
55339
|
-
onPerWidget =
|
|
55581
|
+
var grouped = _ref4.grouped,
|
|
55582
|
+
providersByType = _ref4.providersByType,
|
|
55583
|
+
onBulk = _ref4.onBulk,
|
|
55584
|
+
onPerWidget = _ref4.onPerWidget;
|
|
55340
55585
|
var typeEntries = useMemo(function () {
|
|
55341
55586
|
return Array.from(grouped.entries());
|
|
55342
55587
|
}, [grouped]);
|
|
@@ -55373,10 +55618,10 @@ function ProvidersTab(_ref2) {
|
|
|
55373
55618
|
children: "Provider Types"
|
|
55374
55619
|
}), /*#__PURE__*/jsx("div", {
|
|
55375
55620
|
className: "overflow-y-auto flex-1",
|
|
55376
|
-
children: typeEntries.map(function (
|
|
55377
|
-
var
|
|
55378
|
-
providerType =
|
|
55379
|
-
rows =
|
|
55621
|
+
children: typeEntries.map(function (_ref5) {
|
|
55622
|
+
var _ref6 = _slicedToArray(_ref5, 2),
|
|
55623
|
+
providerType = _ref6[0],
|
|
55624
|
+
rows = _ref6[1];
|
|
55380
55625
|
var isActive = selectedType === providerType;
|
|
55381
55626
|
var unresolvedHere = rows.filter(function (r) {
|
|
55382
55627
|
return r.required && !r.resolvedProviderName;
|
|
@@ -55512,6 +55757,73 @@ function ProvidersTab(_ref2) {
|
|
|
55512
55757
|
});
|
|
55513
55758
|
}
|
|
55514
55759
|
|
|
55760
|
+
// ─── Dependencies tab ──────────────────────────────────────────────────────
|
|
55761
|
+
|
|
55762
|
+
/**
|
|
55763
|
+
* Read-only breakdown of every widget package referenced by the
|
|
55764
|
+
* workspace. Same source of truth as the dashboard publish plan (it
|
|
55765
|
+
* walks layout + pages + sidebar + nested LayoutGridContainer items),
|
|
55766
|
+
* surfaced earlier in the authoring flow so the user can verify which
|
|
55767
|
+
* packages the dashboard actually pulls in — and catch stale references
|
|
55768
|
+
* before hitting the Publish modal.
|
|
55769
|
+
*
|
|
55770
|
+
* `(unknown)` buckets mean a component we couldn't map back to a
|
|
55771
|
+
* package (no `config.id` / `config.package` / item.workspace hint).
|
|
55772
|
+
* Usually this is a stale layout item whose widget got uninstalled.
|
|
55773
|
+
*/
|
|
55774
|
+
function DependenciesTab(_ref8) {
|
|
55775
|
+
var dependencies = _ref8.dependencies;
|
|
55776
|
+
if (!dependencies || dependencies.length === 0) {
|
|
55777
|
+
return /*#__PURE__*/jsx("div", {
|
|
55778
|
+
className: "flex items-center justify-center h-full text-sm opacity-60 text-center",
|
|
55779
|
+
children: /*#__PURE__*/jsx("div", {
|
|
55780
|
+
children: "No widget packages referenced by this dashboard."
|
|
55781
|
+
})
|
|
55782
|
+
});
|
|
55783
|
+
}
|
|
55784
|
+
return /*#__PURE__*/jsxs("div", {
|
|
55785
|
+
className: "flex flex-col h-full min-h-0 overflow-y-auto gap-3",
|
|
55786
|
+
children: [/*#__PURE__*/jsx("div", {
|
|
55787
|
+
className: "text-xs opacity-60",
|
|
55788
|
+
children: "Every widget instance in this workspace, grouped by the package it belongs to. Locations show where each package is referenced."
|
|
55789
|
+
}), dependencies.map(function (dep) {
|
|
55790
|
+
var isUnknown = dep.packageLabel === "(unknown)";
|
|
55791
|
+
return /*#__PURE__*/jsxs("div", {
|
|
55792
|
+
className: "border rounded-lg px-4 py-3 ".concat(isUnknown ? "bg-amber-900/10 border-amber-700/40" : "bg-white/5 border-white/10"),
|
|
55793
|
+
children: [/*#__PURE__*/jsxs("div", {
|
|
55794
|
+
className: "flex items-center gap-2 flex-wrap",
|
|
55795
|
+
children: [/*#__PURE__*/jsx("code", {
|
|
55796
|
+
className: "text-sm font-semibold ".concat(isUnknown ? "text-amber-200" : ""),
|
|
55797
|
+
children: dep.packageLabel
|
|
55798
|
+
}), /*#__PURE__*/jsxs("span", {
|
|
55799
|
+
className: "text-xs opacity-60",
|
|
55800
|
+
children: [dep.total, " instance", dep.total === 1 ? "" : "s"]
|
|
55801
|
+
}), isUnknown && /*#__PURE__*/jsx("span", {
|
|
55802
|
+
className: "text-[10px] text-amber-300 uppercase tracking-wide",
|
|
55803
|
+
children: "no package mapping"
|
|
55804
|
+
})]
|
|
55805
|
+
}), /*#__PURE__*/jsxs("div", {
|
|
55806
|
+
className: "mt-2 text-xs opacity-70",
|
|
55807
|
+
children: [/*#__PURE__*/jsxs("div", {
|
|
55808
|
+
children: [/*#__PURE__*/jsx("span", {
|
|
55809
|
+
className: "opacity-60 mr-1",
|
|
55810
|
+
children: "Widgets:"
|
|
55811
|
+
}), dep.components.map(function (c) {
|
|
55812
|
+
return "".concat(c.component).concat(c.count > 1 ? " \xD7".concat(c.count) : "");
|
|
55813
|
+
}).join(", ")]
|
|
55814
|
+
}), /*#__PURE__*/jsxs("div", {
|
|
55815
|
+
className: "mt-1",
|
|
55816
|
+
children: [/*#__PURE__*/jsx("span", {
|
|
55817
|
+
className: "opacity-60 mr-1",
|
|
55818
|
+
children: "Locations:"
|
|
55819
|
+
}), dep.locations.join(", ")]
|
|
55820
|
+
})]
|
|
55821
|
+
})]
|
|
55822
|
+
}, dep.packageLabel);
|
|
55823
|
+
})]
|
|
55824
|
+
});
|
|
55825
|
+
}
|
|
55826
|
+
|
|
55515
55827
|
// ─── Listeners tab ──────────────────────────────────────────────────────────
|
|
55516
55828
|
|
|
55517
55829
|
/**
|
|
@@ -55533,13 +55845,13 @@ function sameWiringEntry(a, b) {
|
|
|
55533
55845
|
* adjusts wiring per handler from a single dropdown of all emitters'
|
|
55534
55846
|
* (widget × event) pairs.
|
|
55535
55847
|
*/
|
|
55536
|
-
function ListenersTab(
|
|
55848
|
+
function ListenersTab(_ref9) {
|
|
55537
55849
|
var _receivers$;
|
|
55538
|
-
var emitters =
|
|
55539
|
-
receivers =
|
|
55540
|
-
wiring =
|
|
55541
|
-
onAdd =
|
|
55542
|
-
onRemove =
|
|
55850
|
+
var emitters = _ref9.emitters,
|
|
55851
|
+
receivers = _ref9.receivers,
|
|
55852
|
+
wiring = _ref9.wiring,
|
|
55853
|
+
onAdd = _ref9.onAdd,
|
|
55854
|
+
onRemove = _ref9.onRemove;
|
|
55543
55855
|
var _useState11 = useState(((_receivers$ = receivers[0]) === null || _receivers$ === void 0 ? void 0 : _receivers$.key) || null),
|
|
55544
55856
|
_useState12 = _slicedToArray(_useState11, 2),
|
|
55545
55857
|
selectedReceiverKey = _useState12[0],
|
|
@@ -55563,17 +55875,17 @@ function ListenersTab(_ref6) {
|
|
|
55563
55875
|
// Receiver lookup (by composite key) for label resolution in chips.
|
|
55564
55876
|
var receiverByKey = useMemo(function () {
|
|
55565
55877
|
var m = new Map();
|
|
55566
|
-
var
|
|
55567
|
-
|
|
55878
|
+
var _iterator8 = _createForOfIteratorHelper$4(receivers),
|
|
55879
|
+
_step8;
|
|
55568
55880
|
try {
|
|
55569
|
-
for (
|
|
55570
|
-
var r =
|
|
55881
|
+
for (_iterator8.s(); !(_step8 = _iterator8.n()).done;) {
|
|
55882
|
+
var r = _step8.value;
|
|
55571
55883
|
m.set(r.key, r);
|
|
55572
55884
|
}
|
|
55573
55885
|
} catch (err) {
|
|
55574
|
-
|
|
55886
|
+
_iterator8.e(err);
|
|
55575
55887
|
} finally {
|
|
55576
|
-
|
|
55888
|
+
_iterator8.f();
|
|
55577
55889
|
}
|
|
55578
55890
|
return m;
|
|
55579
55891
|
}, [receivers]);
|
|
@@ -55647,24 +55959,24 @@ function ListenersTab(_ref6) {
|
|
|
55647
55959
|
* third column. Matches the left-column look from
|
|
55648
55960
|
* PanelEditItemHandlers.
|
|
55649
55961
|
*/
|
|
55650
|
-
function HandlersColumn(
|
|
55651
|
-
var receiver =
|
|
55652
|
-
myWiring =
|
|
55653
|
-
selectedHandler =
|
|
55654
|
-
onSelectHandler =
|
|
55962
|
+
function HandlersColumn(_ref1) {
|
|
55963
|
+
var receiver = _ref1.receiver,
|
|
55964
|
+
myWiring = _ref1.myWiring,
|
|
55965
|
+
selectedHandler = _ref1.selectedHandler,
|
|
55966
|
+
onSelectHandler = _ref1.onSelectHandler;
|
|
55655
55967
|
var countsByHandler = useMemo(function () {
|
|
55656
55968
|
var m = new Map();
|
|
55657
|
-
var
|
|
55658
|
-
|
|
55969
|
+
var _iterator9 = _createForOfIteratorHelper$4(myWiring),
|
|
55970
|
+
_step9;
|
|
55659
55971
|
try {
|
|
55660
|
-
for (
|
|
55661
|
-
var w =
|
|
55972
|
+
for (_iterator9.s(); !(_step9 = _iterator9.n()).done;) {
|
|
55973
|
+
var w = _step9.value;
|
|
55662
55974
|
m.set(w.handlerName, (m.get(w.handlerName) || 0) + 1);
|
|
55663
55975
|
}
|
|
55664
55976
|
} catch (err) {
|
|
55665
|
-
|
|
55977
|
+
_iterator9.e(err);
|
|
55666
55978
|
} finally {
|
|
55667
|
-
|
|
55979
|
+
_iterator9.f();
|
|
55668
55980
|
}
|
|
55669
55981
|
return m;
|
|
55670
55982
|
}, [myWiring]);
|
|
@@ -55712,23 +56024,23 @@ function HandlersColumn(_ref8) {
|
|
|
55712
56024
|
* Checked = wired; toggling commits an add/remove. Mirrors the
|
|
55713
56025
|
* right-column UX of PanelEditItemHandlers.
|
|
55714
56026
|
*/
|
|
55715
|
-
function EventsColumn(
|
|
55716
|
-
var receiver =
|
|
55717
|
-
handlerName =
|
|
55718
|
-
myWiring =
|
|
55719
|
-
emitters =
|
|
55720
|
-
onAdd =
|
|
55721
|
-
onRemove =
|
|
56027
|
+
function EventsColumn(_ref10) {
|
|
56028
|
+
var receiver = _ref10.receiver,
|
|
56029
|
+
handlerName = _ref10.handlerName,
|
|
56030
|
+
myWiring = _ref10.myWiring,
|
|
56031
|
+
emitters = _ref10.emitters,
|
|
56032
|
+
onAdd = _ref10.onAdd,
|
|
56033
|
+
onRemove = _ref10.onRemove;
|
|
55722
56034
|
// Wired-for-this-handler: dedupe defensively (legacy workspaces
|
|
55723
56035
|
// occasionally contain duplicate entries under the same handler).
|
|
55724
56036
|
var wiredHere = useMemo(function () {
|
|
55725
56037
|
var seen = new Set();
|
|
55726
56038
|
var out = [];
|
|
55727
|
-
var
|
|
55728
|
-
|
|
56039
|
+
var _iterator0 = _createForOfIteratorHelper$4(myWiring),
|
|
56040
|
+
_step0;
|
|
55729
56041
|
try {
|
|
55730
|
-
for (
|
|
55731
|
-
var w =
|
|
56042
|
+
for (_iterator0.s(); !(_step0 = _iterator0.n()).done;) {
|
|
56043
|
+
var w = _step0.value;
|
|
55732
56044
|
if (w.handlerName !== handlerName) continue;
|
|
55733
56045
|
var key = "".concat(w.sourceComponent, "|").concat(w.sourceItemId, "|").concat(w.eventName);
|
|
55734
56046
|
if (seen.has(key)) continue;
|
|
@@ -55736,9 +56048,9 @@ function EventsColumn(_ref9) {
|
|
|
55736
56048
|
out.push(w);
|
|
55737
56049
|
}
|
|
55738
56050
|
} catch (err) {
|
|
55739
|
-
|
|
56051
|
+
_iterator0.e(err);
|
|
55740
56052
|
} finally {
|
|
55741
|
-
|
|
56053
|
+
_iterator0.f();
|
|
55742
56054
|
}
|
|
55743
56055
|
return out;
|
|
55744
56056
|
}, [myWiring, handlerName]);
|
|
@@ -56888,6 +57200,42 @@ var DashboardStageInner = function DashboardStageInner(_ref3) {
|
|
|
56888
57200
|
});
|
|
56889
57201
|
});
|
|
56890
57202
|
}
|
|
57203
|
+
|
|
57204
|
+
// Mirror the change into the layout refs so the save path always
|
|
57205
|
+
// sees the same truth regardless of whether it reads from refs or
|
|
57206
|
+
// state. Previously a mutation that propagated via
|
|
57207
|
+
// onWorkspaceChange (drag-drop, swap, place, delete) would update
|
|
57208
|
+
// openTabs but leave sidebarWorkspaceRef/pageRefsMap stale, and
|
|
57209
|
+
// `handleClickSaveWorkspace` reads from those refs FIRST — so it
|
|
57210
|
+
// clobbered the new sidebarLayout with the stale ref contents on
|
|
57211
|
+
// save. Keeping everything in sync here closes that window.
|
|
57212
|
+
if (Array.isArray(wsModel.sidebarLayout)) {
|
|
57213
|
+
sidebarWorkspaceRef.current = _objectSpread$6(_objectSpread$6({}, sidebarWorkspaceRef.current || {}), {}, {
|
|
57214
|
+
layout: wsModel.sidebarLayout
|
|
57215
|
+
});
|
|
57216
|
+
}
|
|
57217
|
+
if (Array.isArray(wsModel.pages)) {
|
|
57218
|
+
var _iterator = _createForOfIteratorHelper$3(wsModel.pages),
|
|
57219
|
+
_step;
|
|
57220
|
+
try {
|
|
57221
|
+
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
57222
|
+
var page = _step.value;
|
|
57223
|
+
if (!page || !page.id || !Array.isArray(page.layout)) continue;
|
|
57224
|
+
if (!pageRefsMap.current[page.id]) {
|
|
57225
|
+
pageRefsMap.current[page.id] = {
|
|
57226
|
+
current: null
|
|
57227
|
+
};
|
|
57228
|
+
}
|
|
57229
|
+
pageRefsMap.current[page.id].current = _objectSpread$6(_objectSpread$6({}, pageRefsMap.current[page.id].current || {}), {}, {
|
|
57230
|
+
layout: page.layout
|
|
57231
|
+
});
|
|
57232
|
+
}
|
|
57233
|
+
} catch (err) {
|
|
57234
|
+
_iterator.e(err);
|
|
57235
|
+
} finally {
|
|
57236
|
+
_iterator.f();
|
|
57237
|
+
}
|
|
57238
|
+
}
|
|
56891
57239
|
}
|
|
56892
57240
|
}
|
|
56893
57241
|
function handleProviderSelect(event) {
|
|
@@ -56934,14 +57282,14 @@ var DashboardStageInner = function DashboardStageInner(_ref3) {
|
|
|
56934
57282
|
|
|
56935
57283
|
// Start from the current map, layer changes on top.
|
|
56936
57284
|
var nextSelectedProviders = _objectSpread$6({}, workspaceSelected.selectedProviders || {});
|
|
56937
|
-
var
|
|
56938
|
-
|
|
57285
|
+
var _iterator2 = _createForOfIteratorHelper$3(changes),
|
|
57286
|
+
_step2;
|
|
56939
57287
|
try {
|
|
56940
|
-
for (
|
|
56941
|
-
var
|
|
56942
|
-
widgetId =
|
|
56943
|
-
providerType =
|
|
56944
|
-
providerName =
|
|
57288
|
+
for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
|
|
57289
|
+
var _step2$value = _step2.value,
|
|
57290
|
+
widgetId = _step2$value.widgetId,
|
|
57291
|
+
providerType = _step2$value.providerType,
|
|
57292
|
+
providerName = _step2$value.providerName;
|
|
56945
57293
|
if (!widgetId || !providerType) continue;
|
|
56946
57294
|
var prevForWidget = nextSelectedProviders[widgetId] ? _objectSpread$6({}, nextSelectedProviders[widgetId]) : {};
|
|
56947
57295
|
if (providerName) {
|
|
@@ -56954,9 +57302,9 @@ var DashboardStageInner = function DashboardStageInner(_ref3) {
|
|
|
56954
57302
|
nextSelectedProviders[widgetId] = prevForWidget;
|
|
56955
57303
|
}
|
|
56956
57304
|
} catch (err) {
|
|
56957
|
-
|
|
57305
|
+
_iterator2.e(err);
|
|
56958
57306
|
} finally {
|
|
56959
|
-
|
|
57307
|
+
_iterator2.f();
|
|
56960
57308
|
}
|
|
56961
57309
|
var updatedWorkspace = _objectSpread$6(_objectSpread$6({}, workspaceSelected), {}, {
|
|
56962
57310
|
selectedProviders: nextSelectedProviders
|
|
@@ -56986,14 +57334,14 @@ var DashboardStageInner = function DashboardStageInner(_ref3) {
|
|
|
56986
57334
|
|
|
56987
57335
|
// Group changes by widgetId so we can patch each item once.
|
|
56988
57336
|
var byWidget = new Map();
|
|
56989
|
-
var
|
|
56990
|
-
|
|
57337
|
+
var _iterator3 = _createForOfIteratorHelper$3(changes),
|
|
57338
|
+
_step3;
|
|
56991
57339
|
try {
|
|
56992
|
-
for (
|
|
56993
|
-
var
|
|
56994
|
-
widgetId =
|
|
56995
|
-
key =
|
|
56996
|
-
value =
|
|
57340
|
+
for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
|
|
57341
|
+
var _step3$value = _step3.value,
|
|
57342
|
+
widgetId = _step3$value.widgetId,
|
|
57343
|
+
key = _step3$value.key,
|
|
57344
|
+
value = _step3$value.value;
|
|
56997
57345
|
if (!widgetId || !key) continue;
|
|
56998
57346
|
if (!byWidget.has(widgetId)) byWidget.set(widgetId, {});
|
|
56999
57347
|
byWidget.get(widgetId)[key] = value;
|
|
@@ -57004,9 +57352,9 @@ var DashboardStageInner = function DashboardStageInner(_ref3) {
|
|
|
57004
57352
|
// Uses forEachWidget's walk under the hood by visiting each item
|
|
57005
57353
|
// in the cloned containers.
|
|
57006
57354
|
} catch (err) {
|
|
57007
|
-
|
|
57355
|
+
_iterator3.e(err);
|
|
57008
57356
|
} finally {
|
|
57009
|
-
|
|
57357
|
+
_iterator3.f();
|
|
57010
57358
|
}
|
|
57011
57359
|
var updatedWorkspace = JSON.parse(JSON.stringify(workspaceSelected));
|
|
57012
57360
|
var patchItem = function patchItem(item) {
|