@trops/dash-core 0.1.183 → 0.1.185

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/index.js CHANGED
@@ -40521,17 +40521,44 @@ var ThemeDetail = function ThemeDetail(_ref6) {
40521
40521
 
40522
40522
  function ownKeys$5(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; }
40523
40523
  function _objectSpread$5(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$5(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$5(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
40524
- var ThemesSection = function ThemesSection(_ref) {
40525
- var _ref$onOpenThemeEdito = _ref.onOpenThemeEditor,
40526
- onOpenThemeEditor = _ref$onOpenThemeEdito === void 0 ? null : _ref$onOpenThemeEdito,
40527
- _ref$dashApi = _ref.dashApi,
40528
- dashApi = _ref$dashApi === void 0 ? null : _ref$dashApi,
40529
- _ref$credentials = _ref.credentials,
40530
- credentials = _ref$credentials === void 0 ? null : _ref$credentials,
40531
- _ref$createRequested = _ref.createRequested,
40532
- createRequested = _ref$createRequested === void 0 ? false : _ref$createRequested,
40533
- _ref$onCreateAcknowle = _ref.onCreateAcknowledged,
40534
- onCreateAcknowledged = _ref$onCreateAcknowle === void 0 ? null : _ref$onCreateAcknowle;
40524
+ var BackToChooser = function BackToChooser(_ref) {
40525
+ var onClick = _ref.onClick,
40526
+ children = _ref.children;
40527
+ return /*#__PURE__*/jsxRuntime.jsxs("div", {
40528
+ className: "flex flex-col h-full overflow-hidden",
40529
+ children: [/*#__PURE__*/jsxRuntime.jsx("div", {
40530
+ className: "flex-shrink-0 px-4 pt-4",
40531
+ children: /*#__PURE__*/jsxRuntime.jsxs("button", {
40532
+ type: "button",
40533
+ onClick: onClick,
40534
+ className: "flex items-center gap-1.5 text-sm opacity-60 hover:opacity-100 transition-opacity",
40535
+ children: [/*#__PURE__*/jsxRuntime.jsx(DashReact.FontAwesomeIcon, {
40536
+ icon: "arrow-left",
40537
+ className: "h-3 w-3"
40538
+ }), /*#__PURE__*/jsxRuntime.jsx("span", {
40539
+ children: "Back"
40540
+ })]
40541
+ })
40542
+ }), /*#__PURE__*/jsxRuntime.jsx("div", {
40543
+ className: "flex-1 min-h-0 overflow-y-auto",
40544
+ children: children
40545
+ })]
40546
+ });
40547
+ };
40548
+
40549
+ // ─── Main Component ──────────────────────────────────────────────────────
40550
+
40551
+ var ThemesSection = function ThemesSection(_ref2) {
40552
+ var _ref2$onOpenThemeEdit = _ref2.onOpenThemeEditor,
40553
+ onOpenThemeEditor = _ref2$onOpenThemeEdit === void 0 ? null : _ref2$onOpenThemeEdit,
40554
+ _ref2$dashApi = _ref2.dashApi,
40555
+ dashApi = _ref2$dashApi === void 0 ? null : _ref2$dashApi,
40556
+ _ref2$credentials = _ref2.credentials,
40557
+ credentials = _ref2$credentials === void 0 ? null : _ref2$credentials,
40558
+ _ref2$createRequested = _ref2.createRequested,
40559
+ createRequested = _ref2$createRequested === void 0 ? false : _ref2$createRequested,
40560
+ _ref2$onCreateAcknowl = _ref2.onCreateAcknowledged,
40561
+ onCreateAcknowledged = _ref2$onCreateAcknowl === void 0 ? null : _ref2$onCreateAcknowl;
40535
40562
  var _useContext = React.useContext(DashReact.ThemeContext),
40536
40563
  themes = _useContext.themes,
40537
40564
  currentThemeKey = _useContext.themeKey,
@@ -40569,6 +40596,10 @@ var ThemesSection = function ThemesSection(_ref) {
40569
40596
  _useState12 = _slicedToArray(_useState11, 2),
40570
40597
  enteredViaChooser = _useState12[0],
40571
40598
  setEnteredViaChooser = _useState12[1];
40599
+ var _useState13 = React.useState(null),
40600
+ _useState14 = _slicedToArray(_useState13, 2),
40601
+ initialMethod = _useState14[0],
40602
+ setInitialMethod = _useState14[1];
40572
40603
  var themeEntries = themes ? Object.entries(themes) : [];
40573
40604
  var appId = credentials === null || credentials === void 0 ? void 0 : credentials.appId;
40574
40605
  var rowStyles = DashReact.getStylesForItem(DashReact.themeObjects.PANEL_HEADER, currentTheme, {
@@ -40629,9 +40660,9 @@ var ThemesSection = function ThemesSection(_ref) {
40629
40660
  if (!dashApi || !appId) return;
40630
40661
  if (key === currentThemeKey) {
40631
40662
  var _themeEntries$find;
40632
- var otherKey = (_themeEntries$find = themeEntries.find(function (_ref2) {
40633
- var _ref3 = _slicedToArray(_ref2, 1),
40634
- k = _ref3[0];
40663
+ var otherKey = (_themeEntries$find = themeEntries.find(function (_ref3) {
40664
+ var _ref4 = _slicedToArray(_ref3, 1),
40665
+ k = _ref4[0];
40635
40666
  return k !== key;
40636
40667
  })) === null || _themeEntries$find === void 0 ? void 0 : _themeEntries$find[0];
40637
40668
  if (otherKey) {
@@ -40747,10 +40778,10 @@ var ThemesSection = function ThemesSection(_ref) {
40747
40778
  }), /*#__PURE__*/jsxRuntime.jsx("div", {
40748
40779
  className: "flex-1 overflow-y-auto min-h-0",
40749
40780
  children: /*#__PURE__*/jsxRuntime.jsxs(DashReact.Sidebar.Content, {
40750
- children: [themeEntries.map(function (_ref4) {
40751
- var _ref5 = _slicedToArray(_ref4, 2),
40752
- key = _ref5[0],
40753
- theme = _ref5[1];
40781
+ children: [themeEntries.map(function (_ref5) {
40782
+ var _ref6 = _slicedToArray(_ref5, 2),
40783
+ key = _ref6[0],
40784
+ theme = _ref6[1];
40754
40785
  var isActive = key === currentThemeKey;
40755
40786
  var isSelected = selectedThemeKey === key && generateMode === GENERATE_MODES.NONE && installMode !== "marketplace";
40756
40787
  return /*#__PURE__*/jsxRuntime.jsx(DashReact.Sidebar.Item, {
@@ -40811,38 +40842,57 @@ var ThemesSection = function ThemesSection(_ref) {
40811
40842
  setInstallMode("marketplace");
40812
40843
  setEnteredViaChooser(true);
40813
40844
  },
40814
- onCreateNew: function onCreateNew() {
40815
- setGenerateMode(GENERATE_MODES.WIZARD);
40816
- },
40817
- onCreateFromUrl: function onCreateFromUrl() {
40818
- setGenerateMode(GENERATE_MODES.FROM_URL);
40845
+ onSelectMethod: function onSelectMethod(method) {
40846
+ setInitialMethod(method);
40847
+ if (method === "presets") setGenerateMode(GENERATE_MODES.PRESETS);else if (method === "color") setGenerateMode(GENERATE_MODES.COLOR);else if (method === "from-url") setGenerateMode(GENERATE_MODES.FROM_URL);else setGenerateMode(GENERATE_MODES.WIZARD);
40819
40848
  }
40820
40849
  });
40821
40850
  } else if (generateMode === GENERATE_MODES.WIZARD) {
40822
- detailContent = /*#__PURE__*/jsxRuntime.jsx(ThemeQuickCreate, {
40823
- wizardName: wizardName,
40824
- setWizardName: setWizardName,
40825
- wizardMethod: wizardMethod,
40826
- setWizardMethod: setWizardMethod,
40827
- wizardTheme: wizardTheme,
40828
- setWizardTheme: setWizardTheme,
40829
- onComplete: handleWizardComplete,
40830
- onExtract: handleUrlExtract,
40831
- onMapToTheme: handleUrlMapToTheme
40851
+ detailContent = /*#__PURE__*/jsxRuntime.jsx(BackToChooser, {
40852
+ onClick: function onClick() {
40853
+ return setGenerateMode(GENERATE_MODES.CHOOSER);
40854
+ },
40855
+ children: /*#__PURE__*/jsxRuntime.jsx(ThemeQuickCreate, {
40856
+ wizardName: wizardName,
40857
+ setWizardName: setWizardName,
40858
+ wizardMethod: wizardMethod,
40859
+ setWizardMethod: setWizardMethod,
40860
+ wizardTheme: wizardTheme,
40861
+ setWizardTheme: setWizardTheme,
40862
+ onComplete: handleWizardComplete,
40863
+ onExtract: handleUrlExtract,
40864
+ onMapToTheme: handleUrlMapToTheme,
40865
+ initialMethod: initialMethod
40866
+ })
40832
40867
  });
40833
40868
  } else if (generateMode === GENERATE_MODES.PRESETS) {
40834
- detailContent = /*#__PURE__*/jsxRuntime.jsx(PresetGallery, {
40835
- onSelect: handleCreateFromPreset
40869
+ detailContent = /*#__PURE__*/jsxRuntime.jsx(BackToChooser, {
40870
+ onClick: function onClick() {
40871
+ return setGenerateMode(GENERATE_MODES.CHOOSER);
40872
+ },
40873
+ children: /*#__PURE__*/jsxRuntime.jsx(PresetGallery, {
40874
+ onSelect: handleCreateFromPreset
40875
+ })
40836
40876
  });
40837
40877
  } else if (generateMode === GENERATE_MODES.FROM_URL) {
40838
- detailContent = /*#__PURE__*/jsxRuntime.jsx(DashReact.ThemeFromUrlPane, {
40839
- onExtract: handleUrlExtract,
40840
- onMapToTheme: handleUrlMapToTheme,
40841
- onGenerate: handleUrlThemeGenerated
40878
+ detailContent = /*#__PURE__*/jsxRuntime.jsx(BackToChooser, {
40879
+ onClick: function onClick() {
40880
+ return setGenerateMode(GENERATE_MODES.CHOOSER);
40881
+ },
40882
+ children: /*#__PURE__*/jsxRuntime.jsx(DashReact.ThemeFromUrlPane, {
40883
+ onExtract: handleUrlExtract,
40884
+ onMapToTheme: handleUrlMapToTheme,
40885
+ onGenerate: handleUrlThemeGenerated
40886
+ })
40842
40887
  });
40843
40888
  } else if (generateMode === GENERATE_MODES.COLOR) {
40844
- detailContent = /*#__PURE__*/jsxRuntime.jsx(ColorHarmonyPicker, {
40845
- onGenerate: handleCreateFromHarmony
40889
+ detailContent = /*#__PURE__*/jsxRuntime.jsx(BackToChooser, {
40890
+ onClick: function onClick() {
40891
+ return setGenerateMode(GENERATE_MODES.CHOOSER);
40892
+ },
40893
+ children: /*#__PURE__*/jsxRuntime.jsx(ColorHarmonyPicker, {
40894
+ onGenerate: handleCreateFromHarmony
40895
+ })
40846
40896
  });
40847
40897
  } else if (selectedThemeKey && themes && themes[selectedThemeKey]) {
40848
40898
  detailContent = /*#__PURE__*/jsxRuntime.jsx(ThemeDetail, {