n8n-editor-ui 1.107.3 → 1.109.0

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.
Files changed (124) hide show
  1. package/dist/assets/{AddDataStoreModal-BWJ9lPXD.js → AddDataStoreModal-DQSrUeGv.js} +27 -10
  2. package/dist/assets/{AnimatedSpinner-DNlzAAjE.js → AnimatedSpinner-DG0OJkY1.js} +1 -1
  3. package/dist/assets/{AnnotationTagsDropdown.ee.vue_vue_type_script_setup_true_lang-CNykFw3C.js → AnnotationTagsDropdown.ee.vue_vue_type_script_setup_true_lang-DL7yrAdr.js} +1 -1
  4. package/dist/assets/{AuthView-CBZF2tp7.js → AuthView-BjsoW1-5.js} +2 -2
  5. package/dist/assets/{ChangePasswordView-BNZ4Lec-.js → ChangePasswordView-wL-Pegb8.js} +3 -3
  6. package/dist/assets/CollectionParameter-CGRCLW5F.js +4 -0
  7. package/dist/assets/{ConsumedTokensDetails.vue_vue_type_script_setup_true_lang-CWb4OBYA.js → ConsumedTokensDetails.vue_vue_type_script_setup_true_lang-Y9jgPwUm.js} +1 -1
  8. package/dist/assets/{CredentialsView-CsNObRPu.js → CredentialsView-Cp-dKa-6.js} +8 -8
  9. package/dist/assets/DataStoreActions.vue_vue_type_script_setup_true_lang-jUSBJd47.js +89 -0
  10. package/dist/assets/{WorkflowActivator-22RW64G2.css → DataStoreDetailsView-BxDmY87S.css} +268 -200
  11. package/dist/assets/DataStoreDetailsView-D9YNa5HC.js +41178 -0
  12. package/dist/assets/{DataStoreView-BNXibrgV.js → DataStoreView-Bs-qcZ8z.js} +63 -155
  13. package/dist/assets/{DataStoreView-D-Wmcgs5.css → DataStoreView-bZrewhaR.css} +10 -15
  14. package/dist/assets/{DemoFooter-DN__rQTx.js → DemoFooter-DPTKA9IL.js} +6 -6
  15. package/dist/assets/{EmptySharedSectionActionBox.vue_vue_type_script_setup_true_lang-BLs3shin.js → EmptySharedSectionActionBox.vue_vue_type_script_setup_true_lang-DiIUOGo1.js} +1 -1
  16. package/dist/assets/{EntityNotFound-DwzIV-IA.js → EntityNotFound-7GWizCKV.js} +1 -1
  17. package/dist/assets/{EntityUnAuthorised-Uk7UofGI.js → EntityUnAuthorised-BGNR4Y6R.js} +1 -1
  18. package/dist/assets/{ErrorView-2aaHp4mm.js → ErrorView-Dbc4jM8G.js} +1 -1
  19. package/dist/assets/{EvaluationsRootView-DajOMNNe.js → EvaluationsRootView-bKi3SFkK.js} +1 -1
  20. package/dist/assets/{EvaluationsView-D9B7p6ca.js → EvaluationsView-URJMmngS.js} +4 -4
  21. package/dist/assets/{ExecutionsTime.vue_vue_type_script_setup_true_lang-xG0FUKDV.js → ExecutionsTime.vue_vue_type_script_setup_true_lang-C8GA5YsR.js} +4 -4
  22. package/dist/assets/{ExecutionsView-CcstUltt.js → ExecutionsView-C32NF_Mi.js} +11 -11
  23. package/dist/assets/{FixedCollectionParameter-B0MexyJU.js → FixedCollectionParameter-C32o7Xw1.js} +1 -1
  24. package/dist/assets/{ForgotMyPasswordView-Bah9hI_a.js → ForgotMyPasswordView-BIGcjM0k.js} +3 -3
  25. package/dist/assets/{InfoAccordion-BL8J1chC.js → InfoAccordion-DVdDpADr.js} +2 -2
  26. package/dist/assets/{InsightsChartAverageRuntime-PuDIJUWO.js → InsightsChartAverageRuntime-CjOAk50Z.js} +4 -4
  27. package/dist/assets/{InsightsChartFailed-e8gNXvOD.js → InsightsChartFailed-DCQYezXm.js} +4 -4
  28. package/dist/assets/{InsightsChartFailureRate-CTHQ0RyF.js → InsightsChartFailureRate-L674yUIQ.js} +4 -4
  29. package/dist/assets/{InsightsChartTimeSaved-DnvNXWyi.js → InsightsChartTimeSaved-B6a4bv2j.js} +4 -4
  30. package/dist/assets/{InsightsChartTotal-DD_g0FlT.js → InsightsChartTotal-BGmz_E44.js} +4 -4
  31. package/dist/assets/{InsightsDashboard-Dd6ng80b.js → InsightsDashboard-CbtPLqME.js} +10 -10
  32. package/dist/assets/{InsightsPaywall-CMRBFk7F.js → InsightsPaywall-iTfZzLCq.js} +1 -1
  33. package/dist/assets/{InsightsSummary-od7C9keP.js → InsightsSummary-D0XZxoWu.js} +2 -2
  34. package/dist/assets/{InsightsTableWorkflows-bDP7Feik.js → InsightsTableWorkflows-DYL5sIeL.js} +15 -13
  35. package/dist/assets/{Logo-DccSZavS.js → Logo-BF6xE_TK.js} +1 -1
  36. package/dist/assets/{LogsPanel-B-Tmod-K.css → LogsPanel-BinqqXXh.css} +14 -17
  37. package/dist/assets/{LogsPanel-CgRsN0f1.js → LogsPanel-DhSbCRI8.js} +193 -141
  38. package/dist/assets/{MainHeader-C7eM_NQZ.css → MainHeader-BofAi8wS.css} +42 -42
  39. package/dist/assets/{MainHeader-BuQIia5G.js → MainHeader-C992btCf.js} +488 -481
  40. package/dist/assets/{MainSidebar-DmJW5X0O.js → MainSidebar-CfBkhJuz.js} +47 -66
  41. package/dist/assets/{NodeCreation-BWPpAKFI.js → NodeCreation-C4-JrWkw.js} +4 -4
  42. package/dist/assets/{NodeCreator-CcJ3ERxm.js → NodeCreator-BHFu5J3H.js} +19 -17
  43. package/dist/assets/{NodeCreator-COgNP4W1.css → NodeCreator-vQ-Sfr_5.css} +8 -9
  44. package/dist/assets/{NodeDetailsView-CCLWHias.js → NodeDetailsView-DucQbxES.js} +14 -14
  45. package/dist/assets/{NodeDetailsViewV2-dXQZWfaF.js → NodeDetailsViewV2-By7jano3.js} +25 -25
  46. package/dist/assets/{NodeDetailsViewV2-Bn1PbAPe.css → NodeDetailsViewV2-J_3cfdea.css} +15 -15
  47. package/dist/assets/{NodeView-DXfRa5dq.js → NodeView-Bi4OfDJp.js} +15 -11
  48. package/dist/assets/ProjectBreadcrumb-B1Hnf5da.css +445 -0
  49. package/dist/assets/ProjectBreadcrumb-l5PnV6Jp.js +381 -0
  50. package/dist/assets/{ProjectHeader-B9EjwT8u.js → ProjectHeader-D1veUs2f.js} +27 -30
  51. package/dist/assets/{ProjectSettings-DxChDPJp.js → ProjectSettings-CiMu32JB.js} +6 -6
  52. package/dist/assets/{PushConnectionTracker.vue_vue_type_script_setup_true_lang-CAcI_6zc.js → PushConnectionTracker.vue_vue_type_script_setup_true_lang-Cl5RoRJK.js} +2 -2
  53. package/dist/assets/{ResourcesListLayout-BXykiIem.js → ResourcesListLayout-V2ovJZd-.js} +3 -3
  54. package/dist/assets/{RunDataJson-DQ-wEydT.js → RunDataJson--o61ywP4.js} +3 -3
  55. package/dist/assets/{RunDataJsonActions-DkwJw6g0.js → RunDataJsonActions-BuTnnCdp.js} +14 -14
  56. package/dist/assets/{RunDataParsedAiContent-pthnU6es.js → RunDataParsedAiContent-Dv43fJJj.js} +2 -2
  57. package/dist/assets/{RunDataSearch-Dz5_0Sop.js → RunDataSearch-DhhRomuh.js} +1 -1
  58. package/dist/assets/{RunDataTable-DlwkWBoU.js → RunDataTable-BRNjCbjf.js} +6 -6
  59. package/dist/assets/{SamlOnboarding-BfiycZyp.js → SamlOnboarding-ChVfS2ix.js} +3 -3
  60. package/dist/assets/{SettingsApiView-D6E5CVxl.js → SettingsApiView-EJcHWxis.js} +1 -1
  61. package/dist/assets/{SettingsCommunityNodesView-CQV4UbKm.js → SettingsCommunityNodesView-BCGKGJGl.js} +5 -5
  62. package/dist/assets/{SettingsExternalSecrets-nYlsTral.js → SettingsExternalSecrets-DQ6GuwI_.js} +1 -1
  63. package/dist/assets/{SettingsLdapView-C35iJN3N.js → SettingsLdapView-YMEEL5g4.js} +1 -1
  64. package/dist/assets/{SettingsLogStreamingView-DF2IVwuv.js → SettingsLogStreamingView-CMRM9qEX.js} +1 -1
  65. package/dist/assets/{SettingsPersonalView-DvTBCV7u.js → SettingsPersonalView-CQ3j6jFh.js} +2 -2
  66. package/dist/assets/{SettingsSourceControl-Bp7kBNsF.js → SettingsSourceControl-W3xQHBQs.js} +2 -2
  67. package/dist/assets/{SettingsSso-D3MsGwAG.js → SettingsSso-B-RJISS8.js} +8 -6
  68. package/dist/assets/{SettingsUsageAndPlan-BvSyV6eq.js → SettingsUsageAndPlan-BI4z3ArV.js} +2 -2
  69. package/dist/assets/{SettingsUsersView-BKx9xQmw.js → SettingsUsersView-FdTxfP_9.js} +3 -3
  70. package/dist/assets/{SettingsView-N1braOIS.js → SettingsView-enVRJi4X.js} +1 -1
  71. package/dist/assets/{SetupView-DB325RA-.js → SetupView-DhQVRFto.js} +3 -3
  72. package/dist/assets/{SetupWorkflowCredentialsButton-Bv6XJXPb.js → SetupWorkflowCredentialsButton-o-0v9TC0.js} +1 -1
  73. package/dist/assets/{SetupWorkflowFromTemplateView-DvJ9hJNk.js → SetupWorkflowFromTemplateView-t24Wf8j0.js} +4 -4
  74. package/dist/assets/{SigninView-Do_ZE4PN.js → SigninView-CqnnxcHH.js} +3 -3
  75. package/dist/assets/{SignoutView-RMWoU9ka.js → SignoutView-BYkRErR0.js} +1 -1
  76. package/dist/assets/{SignupView-DaSOlcHH.js → SignupView-CZ5xz8Ej.js} +3 -3
  77. package/dist/assets/{TableBase-DEfTMdd5.js → TableBase-DZ3KHAaq.js} +1 -1
  78. package/dist/assets/{Tag-Bpg7pWwM.js → Tag-BZXOdJeY.js} +1 -1
  79. package/dist/assets/{Tags-BOko1qXh.js → Tags-BGrNA-zc.js} +2 -2
  80. package/dist/assets/{TemplateDetails-DKT_t-A1.js → TemplateDetails-CGeXTU0J.js} +2 -2
  81. package/dist/assets/{TemplateList-CKb1zA2_.js → TemplateList-BUJPQKR1.js} +1 -1
  82. package/dist/assets/{TemplatesCollectionView-D47Zvruw.js → TemplatesCollectionView-CDz25qgN.js} +7 -7
  83. package/dist/assets/{TemplatesSearchView-C1Drn--8.js → TemplatesSearchView-l-Ueq6ha.js} +3 -3
  84. package/dist/assets/{TemplatesView-DLGApF1u.js → TemplatesView-CbzVhmOD.js} +1 -1
  85. package/dist/assets/{TemplatesWorkflowView-BU_v7Vg5.js → TemplatesWorkflowView-D2fR5qLE.js} +7 -7
  86. package/dist/assets/{TriggerPanel-DmVMaaLr.css → TriggerPanel-BFPMKijE.css} +4 -4
  87. package/dist/assets/{TriggerPanel-BEWhhdtu.js → TriggerPanel-BNb8Fkp3.js} +23 -12
  88. package/dist/assets/{VariablesView-CvBjaoev.js → VariablesView-ZO4oTir0.js} +9 -9
  89. package/dist/assets/{WorkerView-cFswonAF.js → WorkerView-DjYjCGEz.js} +6 -6
  90. package/dist/assets/{WorkflowActivator-mjgVWRcp.js → WorkflowActivator-CFrLXTxM.js} +13 -389
  91. package/dist/assets/WorkflowActivator-jI4sUqXL.css +391 -0
  92. package/dist/assets/{WorkflowExecutionsInfoAccordion-CZwCkYjJ.js → WorkflowExecutionsInfoAccordion-C8Tc4Mno.js} +3 -3
  93. package/dist/assets/{WorkflowExecutionsLandingPage-C5AsTUva.js → WorkflowExecutionsLandingPage-BiuuJ3ll.js} +3 -3
  94. package/dist/assets/{WorkflowExecutionsPreview-1HvxolBT.js → WorkflowExecutionsPreview-CYoDxL8E.js} +4 -4
  95. package/dist/assets/{WorkflowExecutionsView-YiB3L6cC.js → WorkflowExecutionsView-C78loZuv.js} +8 -8
  96. package/dist/assets/{WorkflowHistory-DMhEstvs.js → WorkflowHistory-CqoFF8_8.js} +4 -4
  97. package/dist/assets/{WorkflowOnboardingView-Dnm-Rnp-.js → WorkflowOnboardingView-dpvpoau1.js} +1 -1
  98. package/dist/assets/{WorkflowPreview-Dy8KQCnA.js → WorkflowPreview-83_iB67I.js} +1 -1
  99. package/dist/assets/{WorkflowsView-Cv689d2r.js → WorkflowsView-Bhr5Vfcw.js} +24 -23
  100. package/dist/assets/{WorkflowsView-eYGsq80b.css → WorkflowsView-BuvoAeDm.css} +18 -17
  101. package/dist/assets/{canvas-DBxg3FGB.js → canvas-Kg89rGSt.js} +1 -1
  102. package/dist/assets/{chartjs.utils-ziIypBRK.js → chartjs.utils-6nSeP00a.js} +2 -2
  103. package/dist/assets/{core-BQX74yIJ.js → core-BiQ8TPaF.js} +9 -8
  104. package/dist/assets/dataStore.store-Bru4R38e.js +268 -0
  105. package/dist/assets/{en-CdefH_p-.js → en-CZDXhi4W.js} +50 -27
  106. package/dist/assets/{global-link-actions-BgqtAMjH.js → global-link-actions-BfwrTt1h.js} +1 -1
  107. package/dist/assets/{index-BFyMw9-0.css → index-Am8RmnT4.css} +233 -241
  108. package/dist/assets/{index-D4wn1X5v.js → index-CZxO9Y7t.js} +1 -1
  109. package/dist/assets/{index-eiGMGof4.js → index-V25MIkzH.js} +6310 -5682
  110. package/dist/assets/{pickBy-D-ZGPPK6.js → pickBy-CInoejW7.js} +1 -1
  111. package/dist/assets/{polyfills-eMEFRc79.js → polyfills-BhZQ1FDI.js} +44 -0
  112. package/dist/assets/{readyToRunWorkflows.store-BAFBPhWS.js → readyToRunWorkflows.store-D8qADh9A.js} +1 -1
  113. package/dist/assets/{templateActions-BI7pkM1w.js → templateActions-CytValxU.js} +1 -1
  114. package/dist/assets/{typescript.worker-ku8s_Oaf.js → typescript.worker-BcoVIdo9.js} +8 -8
  115. package/dist/assets/{useBeforeUnload-BjekgFaf.js → useBeforeUnload-yQFY1z_s.js} +1 -1
  116. package/dist/assets/{useExecutionDebugging-B38snoEK.js → useExecutionDebugging-DiCw9NpL.js} +1 -1
  117. package/dist/assets/{useImportCurlCommand-Cm4bDewX.js → useImportCurlCommand-UhCp_Hxn.js} +44 -37
  118. package/dist/assets/{useProjectPages-ALKmwRBA.js → useProjectPages-DNuz01tw.js} +1 -1
  119. package/dist/assets/{usePushConnection-CEXhOxd5.js → usePushConnection-BOddel3U.js} +3 -3
  120. package/dist/assets/{useWorkflowActivate-B8jSp35O.js → useWorkflowActivate-DKZ9PzgK.js} +1 -1
  121. package/dist/index.html +3 -3
  122. package/package.json +1 -1
  123. package/dist/assets/CollectionParameter-BNLFCXfs.js +0 -4
  124. package/dist/assets/dataStore.store-BPclFpMe.js +0 -98
@@ -297,38 +297,39 @@
297
297
  -------------------------- */
298
298
  /* BEM
299
299
  -------------------------- */
300
- ._cardLink_ycbf3_123 {
300
+ ._cardLink_9y0d7_123 {
301
301
  transition: box-shadow 0.3s ease;
302
302
  cursor: pointer;
303
303
  padding: 0;
304
304
  align-items: stretch;
305
305
  }
306
- ._cardLink_ycbf3_123:hover {
306
+ ._cardLink_9y0d7_123:hover {
307
307
  box-shadow: 0 2px 8px rgba(68, 28, 23, 0.1);
308
308
  }
309
- ._cardHeading_ycbf3_133 {
309
+ ._cardHeading_9y0d7_133 {
310
310
  font-size: var(--font-size-s);
311
311
  word-break: break-word;
312
312
  padding: var(--spacing-s) 0 0 var(--spacing-s);
313
313
  }
314
- ._cardHeading_ycbf3_133 span {
314
+ ._cardHeading_9y0d7_133 span {
315
315
  color: var(--color-text-light);
316
316
  }
317
- ._cardHeadingArchived_ycbf3_142 {
317
+ ._cardHeadingArchived_9y0d7_142 {
318
318
  color: var(--color-text-light);
319
319
  }
320
- ._cardDescription_ycbf3_146 {
320
+ ._cardDescription_9y0d7_146 {
321
321
  min-height: 19px;
322
322
  display: flex;
323
323
  align-items: center;
324
324
  padding: 0 0 var(--spacing-s) var(--spacing-s);
325
325
  }
326
- ._cardTags_ycbf3_153 {
326
+ ._cardTags_9y0d7_153 {
327
327
  display: inline-block;
328
328
  margin-top: var(--spacing-4xs);
329
329
  }
330
- ._cardActions_ycbf3_158 {
330
+ ._cardActions_9y0d7_158 {
331
331
  display: flex;
332
+ gap: var(--spacing-2xs);
332
333
  flex-direction: row;
333
334
  justify-content: center;
334
335
  align-items: center;
@@ -336,38 +337,38 @@
336
337
  padding: 0 var(--spacing-s) 0 0;
337
338
  cursor: default;
338
339
  }
339
- ._cardBadge_ycbf3_168 {
340
+ ._cardBadge_9y0d7_169 {
340
341
  background-color: var(--color-background-xlight);
341
342
  }
342
- ._cardBadge_ycbf3_168._with-breadcrumbs_ycbf3_172 .n8n-badge {
343
+ ._cardBadge_9y0d7_169._with-breadcrumbs_9y0d7_173 .n8n-badge {
343
344
  padding-right: 0;
344
345
  }
345
- ._cardBadge_ycbf3_168._with-breadcrumbs_ycbf3_172 .n8n-breadcrumbs {
346
+ ._cardBadge_9y0d7_169._with-breadcrumbs_9y0d7_173 .n8n-breadcrumbs {
346
347
  padding-left: var(--spacing-5xs);
347
348
  }
348
- ._cardArchived_ycbf3_179 {
349
+ ._cardArchived_9y0d7_180 {
349
350
  background-color: var(--color-background-light);
350
351
  border-color: var(--color-foreground-light);
351
352
  color: var(--color-text-base);
352
353
  }
353
354
  @media screen and (max-width: 991px) {
354
- ._cardLink_ycbf3_123 {
355
+ ._cardLink_9y0d7_123 {
355
356
  --card--padding: 0 var(--spacing-s) var(--spacing-s);
356
357
  --card--append--width: 100%;
357
358
  flex-direction: column;
358
359
  }
359
- ._cardActions_ycbf3_158 {
360
+ ._cardActions_9y0d7_158 {
360
361
  width: 100%;
361
362
  padding: 0 var(--spacing-s) var(--spacing-s);
362
363
  justify-content: end;
363
364
  }
364
- ._cardBadge_ycbf3_168,
365
- ._breadcrumbs_ycbf3_197 {
365
+ ._cardBadge_9y0d7_169,
366
+ ._breadcrumbs_9y0d7_198 {
366
367
  margin-right: auto;
367
368
  }
368
369
  }
369
370
  @media screen and (max-width: 767px) {
370
- ._breadcrumbs_ycbf3_197 > div {
371
+ ._breadcrumbs_9y0d7_198 > div {
371
372
  flex-direction: column;
372
373
  }
373
374
  }/* BEM support Func
@@ -1,4 +1,4 @@
1
- import { W as createEventBus } from "./index-eiGMGof4.js";
1
+ import { aq as createEventBus } from "./index-V25MIkzH.js";
2
2
  const canvasEventBus = createEventBus();
3
3
  export {
4
4
  canvasEventBus as c
@@ -1,5 +1,5 @@
1
- import { fX as useCssVar, hA as merge } from "./index-eiGMGof4.js";
2
- import { s as smartDecimal } from "./InsightsSummary-od7C9keP.js";
1
+ import { fT as useCssVar, hI as merge } from "./index-V25MIkzH.js";
2
+ import { s as smartDecimal } from "./InsightsSummary-D0XZxoWu.js";
3
3
  const generateLinearGradient = (ctx, height) => {
4
4
  const gradient = ctx.createLinearGradient(0, 0, 0, height);
5
5
  gradient.addColorStop(0, "rgba(255, 111,92, 1)");
@@ -1,4 +1,4 @@
1
- import { d as defineComponent, r as ref, ft as MarkdownIt, x as computed, aY as h, bZ as getDefaultExportFromCjs } from "./index-eiGMGof4.js";
1
+ import { d as defineComponent, r as ref, fn as MarkdownIt, x as computed, aW as h, bR as getDefaultExportFromCjs } from "./index-V25MIkzH.js";
2
2
  const VueMarkdown = defineComponent({
3
3
  name: "VueMarkdown",
4
4
  props: {
@@ -914,7 +914,7 @@ function requireCore() {
914
914
  }
915
915
  return mode;
916
916
  }
917
- var version = "11.9.0";
917
+ var version = "11.11.1";
918
918
  class HTMLInjectionError extends Error {
919
919
  constructor(reason, html) {
920
920
  super(reason);
@@ -1228,6 +1228,7 @@ function requireCore() {
1228
1228
  }
1229
1229
  }
1230
1230
  if (match.type === "illegal" && lexeme === "") {
1231
+ modeBuffer += "\n";
1231
1232
  return 1;
1232
1233
  }
1233
1234
  if (iterations > 1e5 && iterations > match.index * 3) {
@@ -1414,19 +1415,19 @@ function requireCore() {
1414
1415
  }
1415
1416
  let wantsHighlight = false;
1416
1417
  function highlightAll() {
1418
+ function boot() {
1419
+ highlightAll();
1420
+ }
1417
1421
  if (document.readyState === "loading") {
1422
+ if (!wantsHighlight) {
1423
+ window.addEventListener("DOMContentLoaded", boot, false);
1424
+ }
1418
1425
  wantsHighlight = true;
1419
1426
  return;
1420
1427
  }
1421
1428
  const blocks = document.querySelectorAll(options.cssSelector);
1422
1429
  blocks.forEach(highlightElement);
1423
1430
  }
1424
- function boot() {
1425
- if (wantsHighlight) highlightAll();
1426
- }
1427
- if (typeof window !== "undefined" && window.addEventListener) {
1428
- window.addEventListener("DOMContentLoaded", boot, false);
1429
- }
1430
1431
  function registerLanguage(languageName, languageDefinition) {
1431
1432
  let lang = null;
1432
1433
  try {
@@ -0,0 +1,268 @@
1
+ import { e$ as makeRestApiRequest, $ as defineStore, at as useRootStore, au as useProjectsStore, r as ref, gx as DATA_STORE_STORE } from "./index-V25MIkzH.js";
2
+ const fetchDataStoresApi = async (context, projectId, options, filter) => {
3
+ const apiEndpoint = projectId ? `/projects/${projectId}/data-stores` : "/data-stores-global";
4
+ return await makeRestApiRequest(
5
+ context,
6
+ "GET",
7
+ apiEndpoint,
8
+ {
9
+ options: options ?? void 0,
10
+ filter: filter ?? void 0
11
+ }
12
+ );
13
+ };
14
+ const createDataStoreApi = async (context, name, projectId, columns) => {
15
+ return await makeRestApiRequest(
16
+ context,
17
+ "POST",
18
+ `/projects/${projectId}/data-stores`,
19
+ {
20
+ name,
21
+ columns: []
22
+ }
23
+ );
24
+ };
25
+ const deleteDataStoreApi = async (context, dataStoreId, projectId) => {
26
+ return await makeRestApiRequest(
27
+ context,
28
+ "DELETE",
29
+ `/projects/${projectId}/data-stores/${dataStoreId}`,
30
+ {
31
+ dataStoreId,
32
+ projectId
33
+ }
34
+ );
35
+ };
36
+ const updateDataStoreApi = async (context, dataStoreId, name, projectId) => {
37
+ return await makeRestApiRequest(
38
+ context,
39
+ "PATCH",
40
+ `/projects/${projectId}/data-stores/${dataStoreId}`,
41
+ {
42
+ name
43
+ }
44
+ );
45
+ };
46
+ const addDataStoreColumnApi = async (context, dataStoreId, projectId, column) => {
47
+ return await makeRestApiRequest(
48
+ context,
49
+ "POST",
50
+ `/projects/${projectId}/data-stores/${dataStoreId}/columns`,
51
+ {
52
+ ...column
53
+ }
54
+ );
55
+ };
56
+ const deleteDataStoreColumnApi = async (context, dataStoreId, projectId, columnId) => {
57
+ return await makeRestApiRequest(
58
+ context,
59
+ "DELETE",
60
+ `/projects/${projectId}/data-stores/${dataStoreId}/columns/${columnId}`
61
+ );
62
+ };
63
+ const moveDataStoreColumnApi = async (context, dataStoreId, projectId, columnId, targetIndex) => {
64
+ return await makeRestApiRequest(
65
+ context,
66
+ "PATCH",
67
+ `/projects/${projectId}/data-stores/${dataStoreId}/columns/${columnId}/move`,
68
+ {
69
+ targetIndex
70
+ }
71
+ );
72
+ };
73
+ const getDataStoreRowsApi = async (context, dataStoreId, projectId, options) => {
74
+ return await makeRestApiRequest(context, "GET", `/projects/${projectId}/data-stores/${dataStoreId}/rows`, {
75
+ ...options ?? {}
76
+ });
77
+ };
78
+ const insertDataStoreRowApi = async (context, dataStoreId, row, projectId) => {
79
+ return await makeRestApiRequest(
80
+ context,
81
+ "POST",
82
+ `/projects/${projectId}/data-stores/${dataStoreId}/insert`,
83
+ {
84
+ data: [row]
85
+ }
86
+ );
87
+ };
88
+ const updateDataStoreRowsApi = async (context, dataStoreId, rowId, rowData, projectId) => {
89
+ return await makeRestApiRequest(
90
+ context,
91
+ "PATCH",
92
+ `/projects/${projectId}/data-stores/${dataStoreId}/rows`,
93
+ {
94
+ filter: { id: rowId },
95
+ data: rowData
96
+ }
97
+ );
98
+ };
99
+ const useDataStoreStore = defineStore(DATA_STORE_STORE, () => {
100
+ const rootStore = useRootStore();
101
+ const projectStore = useProjectsStore();
102
+ const dataStores = ref([]);
103
+ const totalCount = ref(0);
104
+ const fetchDataStores = async (projectId, page, pageSize) => {
105
+ const response = await fetchDataStoresApi(rootStore.restApiContext, projectId, {
106
+ skip: (page - 1) * pageSize,
107
+ take: pageSize
108
+ });
109
+ dataStores.value = response.data;
110
+ totalCount.value = response.count;
111
+ };
112
+ const createDataStore = async (name, projectId) => {
113
+ const newStore = await createDataStoreApi(rootStore.restApiContext, name, projectId);
114
+ if (!newStore.project && projectId) {
115
+ const project = await projectStore.fetchProject(projectId);
116
+ if (project) {
117
+ newStore.project = project;
118
+ }
119
+ }
120
+ dataStores.value.push(newStore);
121
+ totalCount.value += 1;
122
+ return newStore;
123
+ };
124
+ const deleteDataStore = async (datastoreId, projectId) => {
125
+ const deleted = await deleteDataStoreApi(rootStore.restApiContext, datastoreId, projectId);
126
+ if (deleted) {
127
+ dataStores.value = dataStores.value.filter((store) => store.id !== datastoreId);
128
+ totalCount.value -= 1;
129
+ }
130
+ return deleted;
131
+ };
132
+ const deleteDataStoreColumn = async (datastoreId, projectId, columnId) => {
133
+ const deleted = await deleteDataStoreColumnApi(
134
+ rootStore.restApiContext,
135
+ datastoreId,
136
+ projectId,
137
+ columnId
138
+ );
139
+ if (deleted) {
140
+ const index = dataStores.value.findIndex((store) => store.id === datastoreId);
141
+ if (index !== -1) {
142
+ dataStores.value[index].columns = dataStores.value[index].columns.filter(
143
+ (col) => col.id !== columnId
144
+ );
145
+ }
146
+ }
147
+ return deleted;
148
+ };
149
+ const updateDataStore = async (datastoreId, name, projectId) => {
150
+ const updated = await updateDataStoreApi(
151
+ rootStore.restApiContext,
152
+ datastoreId,
153
+ name,
154
+ projectId
155
+ );
156
+ if (updated) {
157
+ const index = dataStores.value.findIndex((store) => store.id === datastoreId);
158
+ if (index !== -1) {
159
+ dataStores.value[index] = { ...dataStores.value[index], name };
160
+ }
161
+ }
162
+ return updated;
163
+ };
164
+ const fetchDataStoreDetails = async (datastoreId, projectId) => {
165
+ const response = await fetchDataStoresApi(rootStore.restApiContext, projectId, void 0, {
166
+ projectId,
167
+ id: datastoreId
168
+ });
169
+ if (response.data.length > 0) {
170
+ dataStores.value = response.data;
171
+ return response.data[0];
172
+ }
173
+ return null;
174
+ };
175
+ const fetchOrFindDataStore = async (datastoreId, projectId) => {
176
+ const existingStore = dataStores.value.find((store) => store.id === datastoreId);
177
+ if (existingStore) {
178
+ return existingStore;
179
+ }
180
+ return await fetchDataStoreDetails(datastoreId, projectId);
181
+ };
182
+ const addDataStoreColumn = async (datastoreId, projectId, column) => {
183
+ const newColumn = await addDataStoreColumnApi(
184
+ rootStore.restApiContext,
185
+ datastoreId,
186
+ projectId,
187
+ column
188
+ );
189
+ if (newColumn) {
190
+ const index = dataStores.value.findIndex((store) => store.id === datastoreId);
191
+ if (index !== -1) {
192
+ dataStores.value[index].columns.push(newColumn);
193
+ }
194
+ }
195
+ return newColumn;
196
+ };
197
+ const moveDataStoreColumn = async (datastoreId, projectId, columnId, targetIndex) => {
198
+ const moved = await moveDataStoreColumnApi(
199
+ rootStore.restApiContext,
200
+ datastoreId,
201
+ projectId,
202
+ columnId,
203
+ targetIndex
204
+ );
205
+ if (moved) {
206
+ const dsIndex = dataStores.value.findIndex((store) => store.id === datastoreId);
207
+ const fromIndex = dataStores.value[dsIndex].columns.findIndex((col) => col.id === columnId);
208
+ dataStores.value[dsIndex].columns = dataStores.value[dsIndex].columns.map((col) => {
209
+ if (col.id === columnId) return { ...col, index: targetIndex };
210
+ if (fromIndex < targetIndex && col.index > fromIndex && col.index <= targetIndex) {
211
+ return { ...col, index: col.index - 1 };
212
+ }
213
+ if (fromIndex > targetIndex && col.index >= targetIndex && col.index < fromIndex) {
214
+ return { ...col, index: col.index + 1 };
215
+ }
216
+ return col;
217
+ });
218
+ }
219
+ return moved;
220
+ };
221
+ const fetchDataStoreContent = async (datastoreId, projectId, page, pageSize) => {
222
+ return await getDataStoreRowsApi(rootStore.restApiContext, datastoreId, projectId, {
223
+ skip: (page - 1) * pageSize,
224
+ take: pageSize
225
+ });
226
+ };
227
+ const insertEmptyRow = async (dataStore) => {
228
+ const emptyRow = {};
229
+ dataStore.columns.forEach((column) => {
230
+ emptyRow[column.name] = null;
231
+ });
232
+ const inserted = await insertDataStoreRowApi(
233
+ rootStore.restApiContext,
234
+ dataStore.id,
235
+ emptyRow,
236
+ dataStore.projectId
237
+ );
238
+ return inserted[0];
239
+ };
240
+ const updateRow = async (dataStoreId, projectId, rowId, rowData) => {
241
+ return await updateDataStoreRowsApi(
242
+ rootStore.restApiContext,
243
+ dataStoreId,
244
+ rowId,
245
+ rowData,
246
+ projectId
247
+ );
248
+ };
249
+ return {
250
+ dataStores,
251
+ totalCount,
252
+ fetchDataStores,
253
+ createDataStore,
254
+ deleteDataStore,
255
+ updateDataStore,
256
+ fetchDataStoreDetails,
257
+ fetchOrFindDataStore,
258
+ addDataStoreColumn,
259
+ deleteDataStoreColumn,
260
+ moveDataStoreColumn,
261
+ fetchDataStoreContent,
262
+ insertEmptyRow,
263
+ updateRow
264
+ };
265
+ });
266
+ export {
267
+ useDataStoreStore as u
268
+ };
@@ -1,4 +1,4 @@
1
- const _reusableBaseText = { "cancel": "Cancel", "codeNodeEditor": { "linter": { "useJson": "Access the properties of an item under `.json`, e.g. `item.json`" }, "completer": { "all": "Returns an array of the node's output items", "first": "Returns the first item output by the node", "last": "Returns the last item output by the node", "itemMatching": "Returns the matching item, i.e. the one used to produce the item in the current node at the specified index." } }, "name": "Name", "save": "Save", "dismiss": "Dismiss", "unlimited": "Unlimited", "activate": "Activate", "user": "User", "enabled": "Enabled", "disabled": "Disabled" };
1
+ const _reusableBaseText = { "cancel": "Cancel", "codeNodeEditor": { "linter": { "useJson": "Access the properties of an item under `.json`, e.g. `item.json`" }, "completer": { "all": "Returns an array of the node's output items", "first": "Returns the first item output by the node", "last": "Returns the last item output by the node", "itemMatching": "Returns the matching item, i.e. the one used to produce the item in the current node at the specified index." } }, "name": "Name", "save": "Save", "dismiss": "Dismiss", "unlimited": "Unlimited", "activate": "Activate", "user": "User", "enabled": "Enabled", "disabled": "Disabled", "type": "Type" };
2
2
  const _reusableDynamicText = { "readMore": "Read more", "learnMore": "Learn more", "moreInfo": "More info", "oauth2": { "clientId": "Client ID", "clientSecret": "Client Secret" } };
3
3
  const error = "Error";
4
4
  const forgotPassword = "Forgot my password";
@@ -56,6 +56,7 @@ const en = {
56
56
  "generic.tryNow": "Try now",
57
57
  "generic.startNow": "Start now",
58
58
  "generic.dismiss": "Dismiss",
59
+ "generic.saving": "Saving",
59
60
  "generic.unsavedWork.confirmMessage.headline": "Save changes before leaving?",
60
61
  "generic.unsavedWork.confirmMessage.message": "If you don't save, you will lose your changes.",
61
62
  "generic.unsavedWork.confirmMessage.confirmButtonText": "Save",
@@ -664,8 +665,7 @@ Return "Good morning" if time is before 10am, "Good day" it's before 5pm, otherw
664
665
  "credentials.noResults": "No credentials found",
665
666
  "credentials.noResults.withSearch.switchToShared.preamble": "some credentials may be",
666
667
  "credentials.noResults.withSearch.switchToShared.link": "hidden",
667
- "credentials.create.personal.toast.title": "Credential successfully created",
668
- "credentials.create.personal.toast.text": "This credential has been created inside your personal space.",
668
+ "credentials.create.personal.toast.title": "Credential successfully created inside your personal space",
669
669
  "credentials.create.project.toast.title": "Credential successfully created in {projectName}",
670
670
  "credentials.create.project.toast.text": "All members from {projectName} will have access to this credential.",
671
671
  "dataDisplay.needHelp": "Need help?",
@@ -2555,6 +2555,7 @@ Return "Good morning" if time is before 10am, "Good day" it's before 5pm, otherw
2555
2555
  "workflowSettings.helpTexts.workflowCallerPolicy": "Workflows that are allowed to call this workflow using the Execute Workflow node",
2556
2556
  "workflowSettings.hours": "hours",
2557
2557
  "workflowSettings.minutes": "minutes",
2558
+ "workflowSettings.name": "Workflow name",
2558
2559
  "workflowSettings.noWorkflow": "- No Workflow -",
2559
2560
  "workflowSettings.save": "@:_reusableBaseText.save",
2560
2561
  "workflowSettings.saveDataErrorExecution": "Save failed production executions",
@@ -2711,8 +2712,7 @@ Return "Good morning" if time is before 10am, "Good day" it's before 5pm, otherw
2711
2712
  "workflows.concurrentChanges.confirmMessage.message": 'Someone saved this workflow while you were editing it. You can <a href="{url}" target="_blank">view their version</a> (in new tab).<br/><br/>Overwrite their changes with yours?',
2712
2713
  "workflows.concurrentChanges.confirmMessage.cancelButtonText": "Cancel",
2713
2714
  "workflows.concurrentChanges.confirmMessage.confirmButtonText": "Overwrite and Save",
2714
- "workflows.create.personal.toast.title": "Workflow successfully created",
2715
- "workflows.create.personal.toast.text": "This workflow has been created inside your personal space.",
2715
+ "workflows.create.personal.toast.title": "Workflow successfully created inside your personal space",
2716
2716
  "workflows.create.project.toast.title": "Workflow successfully created in {projectName}",
2717
2717
  "workflows.create.folder.toast.title": 'Workflow successfully created in "{projectName}", within "{folderName}"',
2718
2718
  "workflows.create.project.toast.text": "All members from {projectName} will have access to this workflow.",
@@ -2811,10 +2811,10 @@ Return "Good morning" if time is before 10am, "Good day" it's before 5pm, otherw
2811
2811
  "contextual.users.settings.unavailable.button.cloud": "Upgrade now",
2812
2812
  "contextual.feature.unavailable.title": "Available on the Enterprise Plan",
2813
2813
  "contextual.feature.unavailable.title.cloud": "Available on the Pro Plan",
2814
- "dataStore.tab.label": "Data Store",
2815
- "dataStore.empty.label": "You don't have any data stores yet",
2816
- "dataStore.empty.description": "Once you create data stores for your projects, they will appear here",
2817
- "dataStore.empty.button.label": 'Create data store in "{projectName}"',
2814
+ "dataStore.dataStores": "Data Tables",
2815
+ "dataStore.empty.label": "You don't have any data tables yet",
2816
+ "dataStore.empty.description": "Once you create data tables for your projects, they will appear here",
2817
+ "dataStore.empty.button.label": 'Create Data Table in "{projectName}"',
2818
2818
  "dataStore.card.size": "{size}MB",
2819
2819
  "dataStore.card.column.count": "{count} column | {count} columns",
2820
2820
  "dataStore.card.row.count": "{count} record | {count} records",
@@ -2823,17 +2823,37 @@ Return "Good morning" if time is before 10am, "Good day" it's before 5pm, otherw
2823
2823
  "dataStore.sort.nameAsc": "Sort by name (A-Z)",
2824
2824
  "dataStore.sort.nameDesc": "Sort by name (Z-A)",
2825
2825
  "dataStore.search.placeholder": "Search",
2826
- "dataStore.error.fetching": "Error loading data stores",
2827
- "dataStore.add.title": "Create data store",
2828
- "dataStore.add.description": "Set up a new data store to organize and manage your data.",
2829
- "dataStore.add.button.label": "Create Data Store",
2830
- "dataStore.add.input.name.label": "Data Store Name",
2831
- "dataStore.add.input.name.placeholder": "Enter data store name",
2832
- "dataStore.add.error": "Error creating data store",
2833
- "dataStore.delete.confirm.title": "Delete data store",
2834
- "dataStore.delete.confirm.message": 'Are you sure you want to delete the data store "{name}"? This action cannot be undone.',
2835
- "dataStore.delete.error": "Error deleting data store",
2836
- "dataStore.rename.error": "Error renaming data store",
2826
+ "dataStore.error.fetching": "Error loading data tables",
2827
+ "dataStore.add.title": "Create new data table",
2828
+ "dataStore.add.description": "Set up a new data table to organize and manage your data.",
2829
+ "dataStore.add.button.label": "Create Data Table",
2830
+ "dataStore.add.input.name.label": "Data Table Name",
2831
+ "dataStore.add.input.name.placeholder": "Enter data table name",
2832
+ "dataStore.add.error": "Error creating data table",
2833
+ "dataStore.delete.confirm.title": "Delete data table",
2834
+ "dataStore.delete.confirm.message": 'Are you sure you want to delete the data table "{name}"? This action cannot be undone.',
2835
+ "dataStore.delete.error": "Error deleting data table",
2836
+ "dataStore.rename.error": "Error renaming data table",
2837
+ "dataStore.getDetails.error": "Error fetching data table details",
2838
+ "dataStore.notFound": "Data table not found",
2839
+ "dataStore.noColumns.heading": "No columns yet",
2840
+ "dataStore.noColumns.description": "Add columns to start storing data in this data table.",
2841
+ "dataStore.noColumns.button.label": "Add first column",
2842
+ "dataStore.addColumn.label": "Add Column",
2843
+ "dataStore.addColumn.nameInput.label": "@:_reusableBaseText.name",
2844
+ "dataStore.addColumn.nameInput.placeholder": "Enter column name",
2845
+ "dataStore.addColumn.typeInput.label": "@:_reusableBaseText.type",
2846
+ "dataStore.addColumn.error": "Error adding column",
2847
+ "dataStore.moveColumn.error": "Error moving column",
2848
+ "dataStore.deleteColumn.error": "Error deleting column",
2849
+ "dataStore.deleteColumn.confirm.title": "Delete column",
2850
+ "dataStore.deleteColumn.confirm.message": 'Are you sure you want to delete the column "{name}"? This action cannot be undone.',
2851
+ "dataStore.addColumn.invalidName.error": "Invalid column name",
2852
+ "dataStore.addColumn.invalidName.description": "Only alphanumeric characters and non-leading dashes are allowed for column names",
2853
+ "dataStore.fetchContent.error": "Error fetching data store content",
2854
+ "dataStore.addRow.label": "Add Row",
2855
+ "dataStore.addRow.error": "Error adding row",
2856
+ "dataStore.updateRow.error": "Error updating row",
2837
2857
  "settings.ldap": "LDAP",
2838
2858
  "settings.ldap.note": "LDAP allows users to authenticate with their centralized account. It's compatible with services that provide an LDAP interface like Active Directory, Okta and Jumpcloud.",
2839
2859
  "settings.ldap.infoTip": "Learn more about <a href='https://docs.n8n.io/user-management/ldap/' target='_blank'>LDAP in the Docs</a>",
@@ -3094,15 +3114,15 @@ Return "Good morning" if time is before 10am, "Good day" it's before 5pm, otherw
3094
3114
  "settings.personal.mfa.toast.disabledMfa.error.message": "Error disabling two-factor authentication",
3095
3115
  "settings.personal.mfa.toast.canEnableMfa.title": "MFA pre-requisite failed",
3096
3116
  "settings.personal.mfa.enforced": "The settings on this instance <strong>require you to set up 2FA</strong>. Please enable it to continue working in this instance.",
3097
- "settings.personal.mfa.enforce.message": "Enforces 2FA for all users on this instance.",
3098
- "settings.personal.mfa.enforce.unlicensed_tooltip": "You can enforce 2FA for all users on this instance when you upgrade your plan. {action}",
3117
+ "settings.personal.mfa.enforce.message": "Enforces 2FA for all users on this instance authenticating with email and password logins.",
3118
+ "settings.personal.mfa.enforce.unlicensed_tooltip": "You can enforce 2FA for all users on this instance authenticating with email and password logins when you upgrade your plan. {action}",
3099
3119
  "settings.personal.mfa.enforce.unlicensed_tooltip.link": "View plans",
3100
3120
  "settings.personal.mfa.enforce.title": "Enforce two-factor authentication",
3101
3121
  "settings.personal.mfa.enforce.error": "Cannot enforce 2FA for all users",
3102
3122
  "settings.personal.mfa.enforce.enabled.title": "2FA Enforced",
3103
- "settings.personal.mfa.enforce.enabled.message": "Two-factor authentication is now required for all users on this instance.",
3123
+ "settings.personal.mfa.enforce.enabled.message": "Two-factor authentication is now required for all users on this instance authenticating with email and password logins.",
3104
3124
  "settings.personal.mfa.enforce.disabled.title": "2FA No Longer Enforced",
3105
- "settings.personal.mfa.enforce.disabled.message": "Two-factor authentication is no longer mandatory for users on this instance.",
3125
+ "settings.personal.mfa.enforce.disabled.message": "Two-factor authentication is no longer mandatory for users on this instance authenticating with email and password logins.",
3106
3126
  "settings.mfa.toast.noRecoveryCodeLeft.title": "No 2FA recovery codes remaining",
3107
3127
  "settings.mfa.toast.noRecoveryCodeLeft.message": "You have used all of your recovery codes. Disable then re-enable two-factor authentication to generate new codes. <a href='/settings/personal' target='_blank' >Open settings</a>",
3108
3128
  "sso.login.divider": "or",
@@ -3383,9 +3403,12 @@ Return "Good morning" if time is before 10am, "Good day" it's before 5pm, otherw
3383
3403
  "workflowDiff.local": "Local",
3384
3404
  "workflowDiff.remote": "Remote ({branchName})",
3385
3405
  "workflowDiff.noChanges": "No changes",
3386
- "workflowDiff.deletedWorkflow": "Deleted workflow",
3387
- "workflowDiff.deletedWorkflow.database": "The workflow was deleted on the database",
3388
- "workflowDiff.deletedWorkflow.remote": "The workflow was deleted on remote"
3406
+ "workflowDiff.deletedWorkflow": "Missing workflow",
3407
+ "workflowDiff.deletedWorkflow.database": "The workflow doesn't exist in the database",
3408
+ "workflowDiff.deletedWorkflow.remote": "The workflow doesn't exist on remote",
3409
+ "workflowDiff.newWorkflow": "New workflow",
3410
+ "workflowDiff.newWorkflow.database": "The workflow will be created in the database",
3411
+ "workflowDiff.newWorkflow.remote": "The workflow will be created on remote"
3389
3412
  };
3390
3413
  export {
3391
3414
  _reusableBaseText,
@@ -1,4 +1,4 @@
1
- import { W as createEventBus } from "./index-eiGMGof4.js";
1
+ import { aq as createEventBus } from "./index-V25MIkzH.js";
2
2
  const globalLinkActionsEventBus = createEventBus();
3
3
  export {
4
4
  globalLinkActionsEventBus as g