Flowfile 0.3.9__py3-none-any.whl → 0.4.0__py3-none-any.whl

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.

Potentially problematic release.


This version of Flowfile might be problematic. Click here for more details.

Files changed (169) hide show
  1. flowfile/__init__.py +6 -1
  2. flowfile/api.py +0 -1
  3. flowfile/web/static/assets/{CloudConnectionManager-c97c25f8.js → CloudConnectionManager-109ecc3c.js} +2 -2
  4. flowfile/web/static/assets/{CloudStorageReader-f1ff509e.js → CloudStorageReader-19cdd67a.js} +11 -78
  5. flowfile/web/static/assets/{CloudStorageWriter-034f8b78.js → CloudStorageWriter-48e0ae20.js} +12 -79
  6. flowfile/web/static/assets/{CloudStorageWriter-49c9a4b2.css → CloudStorageWriter-b0ee067f.css} +24 -24
  7. flowfile/web/static/assets/ColumnSelector-47996a16.css +10 -0
  8. flowfile/web/static/assets/ColumnSelector-ecaf7c44.js +83 -0
  9. flowfile/web/static/assets/ContextMenu-2b348c4c.js +41 -0
  10. flowfile/web/static/assets/{SettingsSection-9c836ecc.css → ContextMenu-4c74eef1.css} +0 -21
  11. flowfile/web/static/assets/ContextMenu-63cfa99b.css +26 -0
  12. flowfile/web/static/assets/ContextMenu-a779eed7.js +41 -0
  13. flowfile/web/static/assets/ContextMenu-c13f91d0.css +26 -0
  14. flowfile/web/static/assets/ContextMenu-eca26a03.js +41 -0
  15. flowfile/web/static/assets/{CrossJoin-41efa4cb.css → CrossJoin-1119d18e.css} +18 -18
  16. flowfile/web/static/assets/{CrossJoin-9e156ebe.js → CrossJoin-a88f8142.js} +14 -84
  17. flowfile/web/static/assets/CustomNode-74a37f74.css +32 -0
  18. flowfile/web/static/assets/CustomNode-cb863dff.js +211 -0
  19. flowfile/web/static/assets/{DatabaseConnectionSettings-d5c625b3.js → DatabaseConnectionSettings-819d3267.js} +3 -3
  20. flowfile/web/static/assets/{DatabaseManager-265adc5e.js → DatabaseManager-84ee2834.js} +2 -2
  21. flowfile/web/static/assets/{DatabaseReader-0b10551e.js → DatabaseReader-060dd412.js} +14 -114
  22. flowfile/web/static/assets/{DatabaseReader-f50c6558.css → DatabaseReader-ae61773c.css} +0 -27
  23. flowfile/web/static/assets/{DatabaseWriter-c17c6916.js → DatabaseWriter-7fc7750f.js} +13 -74
  24. flowfile/web/static/assets/{ExploreData-5bdae813.css → ExploreData-2d0cf4db.css} +8 -14
  25. flowfile/web/static/assets/ExploreData-82c95991.js +192 -0
  26. flowfile/web/static/assets/{ExternalSource-3a66556c.js → ExternalSource-e1a6ddc7.js} +8 -79
  27. flowfile/web/static/assets/{Filter-91ad87e7.js → Filter-8aca894a.js} +12 -85
  28. flowfile/web/static/assets/{Filter-a9d08ba1.css → Filter-f62091b3.css} +3 -3
  29. flowfile/web/static/assets/{Formula-29f19d21.css → Formula-bb96803d.css} +4 -4
  30. flowfile/web/static/assets/{Formula-3c395ab1.js → Formula-e33686d9.js} +18 -85
  31. flowfile/web/static/assets/{FuzzyMatch-6857de82.css → FuzzyMatch-1010f966.css} +42 -42
  32. flowfile/web/static/assets/{FuzzyMatch-2df0d230.js → FuzzyMatch-abda150d.js} +16 -87
  33. flowfile/web/static/assets/{GraphSolver-d285877f.js → GraphSolver-4ecad1d7.js} +13 -159
  34. flowfile/web/static/assets/GraphSolver-f0cb7bfb.css +22 -0
  35. flowfile/web/static/assets/{GroupBy-0bd1cc6b.js → GroupBy-656d07f3.js} +12 -75
  36. flowfile/web/static/assets/{Unique-b5615727.css → GroupBy-b9505323.css} +8 -8
  37. flowfile/web/static/assets/{Join-5a78a203.js → Join-b84ec849.js} +15 -85
  38. flowfile/web/static/assets/{Join-f45eff22.css → Join-fd79b451.css} +20 -20
  39. flowfile/web/static/assets/{ManualInput-a71b52c6.css → ManualInput-3246a08d.css} +20 -20
  40. flowfile/web/static/assets/{ManualInput-93aef9d6.js → ManualInput-346f4135.js} +11 -82
  41. flowfile/web/static/assets/MultiSelect-61b98268.js +5 -0
  42. flowfile/web/static/assets/MultiSelect.vue_vue_type_script_setup_true_lang-2a7c8312.js +63 -0
  43. flowfile/web/static/assets/NumericInput-e36602c2.js +5 -0
  44. flowfile/web/static/assets/NumericInput.vue_vue_type_script_setup_true_lang-211a1990.js +35 -0
  45. flowfile/web/static/assets/Output-ddc9079f.css +37 -0
  46. flowfile/web/static/assets/{Output-411ecaee.js → Output-eb041599.js} +13 -243
  47. flowfile/web/static/assets/Pivot-cf333e3d.css +22 -0
  48. flowfile/web/static/assets/{Pivot-89db4b04.js → Pivot-f5c774f4.js} +14 -138
  49. flowfile/web/static/assets/PivotValidation-26546cbc.js +61 -0
  50. flowfile/web/static/assets/PivotValidation-891ddfb0.css +13 -0
  51. flowfile/web/static/assets/PivotValidation-c46cd420.css +13 -0
  52. flowfile/web/static/assets/PivotValidation-e150a24b.js +61 -0
  53. flowfile/web/static/assets/{PolarsCode-a9f974f8.js → PolarsCode-da3a7abf.js} +13 -80
  54. flowfile/web/static/assets/Read-0c768769.js +243 -0
  55. flowfile/web/static/assets/Read-6b17491f.css +62 -0
  56. flowfile/web/static/assets/RecordCount-84736276.js +53 -0
  57. flowfile/web/static/assets/{RecordId-55ae7d36.js → RecordId-60055e6d.js} +8 -80
  58. flowfile/web/static/assets/SQLQueryComponent-36cef432.css +27 -0
  59. flowfile/web/static/assets/SQLQueryComponent-8a486004.js +38 -0
  60. flowfile/web/static/assets/{Sample-b4a18476.js → Sample-2d662611.js} +8 -77
  61. flowfile/web/static/assets/{SecretManager-b066d13a.js → SecretManager-ef586cab.js} +2 -2
  62. flowfile/web/static/assets/{Select-727688dc.js → Select-2e4a6965.js} +11 -85
  63. flowfile/web/static/assets/SettingsSection-2e4d03c4.css +21 -0
  64. flowfile/web/static/assets/{SettingsSection-695ac487.js → SettingsSection-310b61c0.js} +2 -40
  65. flowfile/web/static/assets/SettingsSection-5634f439.js +45 -0
  66. flowfile/web/static/assets/SettingsSection-5c696bee.css +20 -0
  67. flowfile/web/static/assets/SettingsSection-71e6b7e3.css +21 -0
  68. flowfile/web/static/assets/SettingsSection-7c68b19f.js +53 -0
  69. flowfile/web/static/assets/SingleSelect-7298811a.js +5 -0
  70. flowfile/web/static/assets/SingleSelect.vue_vue_type_script_setup_true_lang-43807bad.js +62 -0
  71. flowfile/web/static/assets/SliderInput-53105476.js +40 -0
  72. flowfile/web/static/assets/SliderInput-b8fb6a8c.css +4 -0
  73. flowfile/web/static/assets/{GroupBy-ab1ea74b.css → Sort-3643d625.css} +8 -8
  74. flowfile/web/static/assets/{Sort-be3339a8.js → Sort-4fdebe74.js} +12 -97
  75. flowfile/web/static/assets/TextInput-28366b7e.js +5 -0
  76. flowfile/web/static/assets/TextInput.vue_vue_type_script_setup_true_lang-9cad14ba.js +32 -0
  77. flowfile/web/static/assets/{TextToRows-c92d1ec2.css → TextToRows-5d2c1190.css} +9 -9
  78. flowfile/web/static/assets/{TextToRows-7b8998da.js → TextToRows-73ffa692.js} +14 -83
  79. flowfile/web/static/assets/ToggleSwitch-598add30.js +5 -0
  80. flowfile/web/static/assets/ToggleSwitch.vue_vue_type_script_setup_true_lang-f620cd32.js +31 -0
  81. flowfile/web/static/assets/{UnavailableFields-8b0cb48e.js → UnavailableFields-66239e83.js} +2 -2
  82. flowfile/web/static/assets/Union-26b10614.js +77 -0
  83. flowfile/web/static/assets/{Union-8d9ac7f9.css → Union-af6c3d9b.css} +6 -6
  84. flowfile/web/static/assets/{Unique-af5a80b4.js → Unique-33b9edbb.js} +22 -91
  85. flowfile/web/static/assets/{Sort-7ccfa0fe.css → Unique-f9fb0809.css} +8 -8
  86. flowfile/web/static/assets/Unpivot-1e422df3.css +30 -0
  87. flowfile/web/static/assets/{Unpivot-5195d411.js → Unpivot-ef69d0e2.js} +12 -166
  88. flowfile/web/static/assets/UnpivotValidation-0d240eeb.css +13 -0
  89. flowfile/web/static/assets/UnpivotValidation-8658388e.js +51 -0
  90. flowfile/web/static/assets/{ExploreData-18a4fe52.js → VueGraphicWalker-4d7861f4.js} +4 -264
  91. flowfile/web/static/assets/VueGraphicWalker-ed5ab88b.css +6 -0
  92. flowfile/web/static/assets/{api-023d1733.js → api-2d1394bd.js} +1 -1
  93. flowfile/web/static/assets/{api-cb00cce6.js → api-c908fffe.js} +1 -1
  94. flowfile/web/static/assets/{designer-6c322d8e.js → designer-1667687d.js} +2201 -705
  95. flowfile/web/static/assets/{designer-2197d782.css → designer-665e9408.css} +836 -201
  96. flowfile/web/static/assets/{documentation-4d1fafe1.js → documentation-5eed779e.js} +1 -1
  97. flowfile/web/static/assets/{dropDown-0b46dd77.js → dropDown-41ebe3c2.js} +1 -1
  98. flowfile/web/static/assets/{fullEditor-ec4e4f95.js → fullEditor-0670d32d.js} +2 -2
  99. flowfile/web/static/assets/{genericNodeSettings-def5879b.js → genericNodeSettings-38410ebf.js} +3 -3
  100. flowfile/web/static/assets/{index-681a3ed0.css → index-50508d4d.css} +8 -0
  101. flowfile/web/static/assets/{index-683fc198.js → index-5ec791df.js} +210 -31
  102. flowfile/web/static/assets/outputCsv-059583b6.js +86 -0
  103. flowfile/web/static/assets/{Output-48f81019.css → outputCsv-9cc59e0b.css} +0 -143
  104. flowfile/web/static/assets/outputExcel-76b1e02c.js +56 -0
  105. flowfile/web/static/assets/outputExcel-b41305c0.css +102 -0
  106. flowfile/web/static/assets/outputParquet-440fd4c7.js +31 -0
  107. flowfile/web/static/assets/outputParquet-cf8cf3f2.css +4 -0
  108. flowfile/web/static/assets/readCsv-9813903a.js +178 -0
  109. flowfile/web/static/assets/readCsv-bca3ed53.css +52 -0
  110. flowfile/web/static/assets/readExcel-7f40d237.js +203 -0
  111. flowfile/web/static/assets/readExcel-e1b381ea.css +64 -0
  112. flowfile/web/static/assets/readParquet-22d56002.js +26 -0
  113. flowfile/web/static/assets/readParquet-cee068e2.css +19 -0
  114. flowfile/web/static/assets/{secretApi-baceb6f9.js → secretApi-b3cb072e.js} +1 -1
  115. flowfile/web/static/assets/{selectDynamic-de91449a.js → selectDynamic-7ad95bca.js} +7 -7
  116. flowfile/web/static/assets/{selectDynamic-b062bc9b.css → selectDynamic-aa913ff4.css} +16 -16
  117. flowfile/web/static/assets/user-defined-icon-0ae16c90.png +0 -0
  118. flowfile/web/static/assets/{vue-codemirror.esm-dc5e3348.js → vue-codemirror.esm-b1dfaa46.js} +59 -33
  119. flowfile/web/static/assets/{vue-content-loader.es-ba94b82f.js → vue-content-loader.es-22bac17c.js} +1 -1
  120. flowfile/web/static/index.html +2 -2
  121. {flowfile-0.3.9.dist-info → flowfile-0.4.0.dist-info}/METADATA +1 -1
  122. {flowfile-0.3.9.dist-info → flowfile-0.4.0.dist-info}/RECORD +160 -102
  123. flowfile_core/configs/flow_logger.py +5 -13
  124. flowfile_core/configs/node_store/__init__.py +30 -0
  125. flowfile_core/configs/node_store/nodes.py +383 -99
  126. flowfile_core/configs/node_store/user_defined_node_registry.py +193 -0
  127. flowfile_core/configs/settings.py +2 -1
  128. flowfile_core/database/connection.py +5 -21
  129. flowfile_core/fileExplorer/funcs.py +239 -121
  130. flowfile_core/flowfile/flow_data_engine/flow_file_column/interface.py +4 -0
  131. flowfile_core/flowfile/flow_data_engine/flow_file_column/main.py +19 -34
  132. flowfile_core/flowfile/flow_data_engine/flow_file_column/type_registry.py +36 -0
  133. flowfile_core/flowfile/flow_data_engine/subprocess_operations/subprocess_operations.py +28 -8
  134. flowfile_core/flowfile/flow_graph.py +117 -34
  135. flowfile_core/flowfile/flow_node/flow_node.py +45 -13
  136. flowfile_core/flowfile/handler.py +22 -3
  137. flowfile_core/flowfile/manage/open_flowfile.py +9 -1
  138. flowfile_core/flowfile/node_designer/__init__.py +47 -0
  139. flowfile_core/flowfile/node_designer/_type_registry.py +197 -0
  140. flowfile_core/flowfile/node_designer/custom_node.py +371 -0
  141. flowfile_core/flowfile/node_designer/data_types.py +146 -0
  142. flowfile_core/flowfile/node_designer/ui_components.py +277 -0
  143. flowfile_core/flowfile/schema_callbacks.py +8 -4
  144. flowfile_core/flowfile/setting_generator/settings.py +0 -1
  145. flowfile_core/main.py +5 -1
  146. flowfile_core/routes/routes.py +73 -28
  147. flowfile_core/routes/user_defined_components.py +55 -0
  148. flowfile_core/schemas/input_schema.py +7 -1
  149. flowfile_core/schemas/output_model.py +5 -2
  150. flowfile_core/schemas/schemas.py +8 -3
  151. flowfile_core/schemas/transform_schema.py +1 -0
  152. flowfile_core/utils/validate_setup.py +3 -1
  153. flowfile_worker/__init__.py +6 -35
  154. flowfile_worker/main.py +5 -2
  155. flowfile_worker/routes.py +47 -5
  156. shared/__init__.py +15 -0
  157. shared/storage_config.py +258 -0
  158. flowfile/web/static/assets/GraphSolver-17fd26db.css +0 -68
  159. flowfile/web/static/assets/Pivot-f415e85f.css +0 -35
  160. flowfile/web/static/assets/Read-80dc1675.css +0 -197
  161. flowfile/web/static/assets/Read-c3b1929c.js +0 -701
  162. flowfile/web/static/assets/RecordCount-4e95f98e.js +0 -122
  163. flowfile/web/static/assets/Union-89fd73dc.js +0 -146
  164. flowfile/web/static/assets/Unpivot-246e9bbd.css +0 -77
  165. flowfile/web/static/assets/nodeTitle-a16db7c3.js +0 -227
  166. flowfile/web/static/assets/nodeTitle-f4b12bcb.css +0 -134
  167. {flowfile-0.3.9.dist-info → flowfile-0.4.0.dist-info}/LICENSE +0 -0
  168. {flowfile-0.3.9.dist-info → flowfile-0.4.0.dist-info}/WHEEL +0 -0
  169. {flowfile-0.3.9.dist-info → flowfile-0.4.0.dist-info}/entry_points.txt +0 -0
@@ -1,10 +1,9 @@
1
- import { d as defineComponent, r as ref, l as computed, n as onMounted, R as nextTick, o as onUnmounted, b as resolveComponent, c as openBlock, e as createElementBlock, f as createVNode, w as withCtx, p as createBaseVNode, F as Fragment, q as renderList, s as normalizeClass, t as toDisplayString, i as createCommentVNode, T as normalizeStyle, v as withModifiers, h as createBlock, u as unref, _ as _export_sfc, a7 as Teleport } from "./index-683fc198.js";
2
- import { u as useNodeStore } from "./vue-codemirror.esm-dc5e3348.js";
3
- import { C as CodeLoader } from "./vue-content-loader.es-ba94b82f.js";
4
- import { G as GenericNodeSettings } from "./genericNodeSettings-def5879b.js";
5
- import { N as NodeButton, a as NodeTitle } from "./nodeTitle-a16db7c3.js";
6
- import "./designer-6c322d8e.js";
7
- const _hoisted_1$1 = {
1
+ import { d as defineComponent, r as ref, l as computed, b as resolveComponent, c as openBlock, e as createElementBlock, f as createVNode, w as withCtx, p as createBaseVNode, F as Fragment, q as renderList, s as normalizeClass, t as toDisplayString, i as createCommentVNode, T as normalizeStyle, v as withModifiers, h as createBlock, u as unref, _ as _export_sfc } from "./index-5ec791df.js";
2
+ import { u as useNodeStore } from "./vue-codemirror.esm-b1dfaa46.js";
3
+ import { C as CodeLoader } from "./vue-content-loader.es-22bac17c.js";
4
+ import { G as GenericNodeSettings } from "./genericNodeSettings-38410ebf.js";
5
+ import "./designer-1667687d.js";
6
+ const _hoisted_1 = {
8
7
  key: 0,
9
8
  class: "listbox-wrapper"
10
9
  };
@@ -22,8 +21,8 @@ const _hoisted_6 = {
22
21
  const _hoisted_7 = { class: "styled-table" };
23
22
  const _hoisted_8 = { key: 0 };
24
23
  const _hoisted_9 = ["onContextmenu"];
25
- const _sfc_main$1 = /* @__PURE__ */ defineComponent({
26
- __name: "sort",
24
+ const _sfc_main = /* @__PURE__ */ defineComponent({
25
+ __name: "Sort",
27
26
  setup(__props, { expose: __expose }) {
28
27
  const nodeStore = useNodeStore();
29
28
  const showContextMenu = ref(false);
@@ -103,34 +102,17 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
103
102
  nodeSort.value.is_setup = true;
104
103
  }
105
104
  };
106
- const handleClickOutside = (event) => {
107
- var _a;
108
- if (!((_a = contextMenuRef.value) == null ? void 0 : _a.contains(event.target))) {
109
- showContextMenu.value = false;
110
- contextMenuColumn.value = null;
111
- showContextMenuRemove.value = false;
112
- }
113
- };
114
105
  const pushNodeData = async () => {
115
106
  nodeStore.updateSettings(nodeSort);
116
- dataLoaded.value = false;
117
- nodeStore.isDrawerOpen = false;
118
107
  };
119
108
  __expose({
120
109
  loadNodeData,
121
110
  pushNodeData
122
111
  });
123
- onMounted(async () => {
124
- await nextTick();
125
- window.addEventListener("click", handleClickOutside);
126
- });
127
- onUnmounted(() => {
128
- window.removeEventListener("click", handleClickOutside);
129
- });
130
112
  return (_ctx, _cache) => {
131
113
  const _component_el_option = resolveComponent("el-option");
132
114
  const _component_el_select = resolveComponent("el-select");
133
- return dataLoaded.value && nodeSort.value ? (openBlock(), createElementBlock("div", _hoisted_1$1, [
115
+ return dataLoaded.value && nodeSort.value ? (openBlock(), createElementBlock("div", _hoisted_1, [
134
116
  createVNode(GenericNodeSettings, {
135
117
  modelValue: nodeSort.value,
136
118
  "onUpdate:modelValue": _cache[3] || (_cache[3] = ($event) => nodeSort.value = $event)
@@ -235,75 +217,8 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
235
217
  };
236
218
  }
237
219
  });
238
- const sort_vue_vue_type_style_index_0_scoped_001e3d98_lang = "";
239
- const readInput = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["__scopeId", "data-v-001e3d98"]]);
240
- const _hoisted_1 = { ref: "el" };
241
- const _sfc_main = /* @__PURE__ */ defineComponent({
242
- __name: "Sort",
243
- props: {
244
- nodeId: {
245
- type: Number,
246
- required: true
247
- }
248
- },
249
- setup(__props) {
250
- const nodeStore = useNodeStore();
251
- const childComp = ref(null);
252
- const drawer = ref(false);
253
- const props = __props;
254
- const closeOnDrawer = () => {
255
- var _a;
256
- (_a = childComp.value) == null ? void 0 : _a.pushNodeData();
257
- drawer.value = false;
258
- nodeStore.isDrawerOpen = false;
259
- };
260
- const openDrawer = async () => {
261
- if (nodeStore.node_id === props.nodeId) {
262
- return;
263
- }
264
- nodeStore.closeDrawer();
265
- drawer.value = true;
266
- const drawerOpen = nodeStore.isDrawerOpen;
267
- nodeStore.isDrawerOpen = true;
268
- await nextTick();
269
- if (nodeStore.node_id === props.nodeId && drawerOpen) {
270
- return;
271
- }
272
- if (childComp.value) {
273
- childComp.value.loadNodeData(props.nodeId);
274
- nodeStore.openDrawer(closeOnDrawer);
275
- }
276
- };
277
- onMounted(async () => {
278
- await nextTick();
279
- });
280
- return (_ctx, _cache) => {
281
- return openBlock(), createElementBlock("div", _hoisted_1, [
282
- createVNode(NodeButton, {
283
- ref: "nodeButton",
284
- "node-id": __props.nodeId,
285
- "image-src": "sort.png",
286
- title: `${__props.nodeId}: Sort`,
287
- onClick: openDrawer
288
- }, null, 8, ["node-id", "title"]),
289
- drawer.value ? (openBlock(), createBlock(Teleport, {
290
- key: 0,
291
- to: "#nodesettings"
292
- }, [
293
- createVNode(NodeTitle, {
294
- title: "Sort data",
295
- intro: "Sort rows in the data based on one or more columns"
296
- }),
297
- createVNode(readInput, {
298
- ref_key: "childComp",
299
- ref: childComp,
300
- "node-id": __props.nodeId
301
- }, null, 8, ["node-id"])
302
- ])) : createCommentVNode("", true)
303
- ], 512);
304
- };
305
- }
306
- });
220
+ const Sort_vue_vue_type_style_index_0_scoped_0177dec6_lang = "";
221
+ const Sort = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-0177dec6"]]);
307
222
  export {
308
- _sfc_main as default
223
+ Sort as default
309
224
  };
@@ -0,0 +1,5 @@
1
+ import { _ as _sfc_main } from "./TextInput.vue_vue_type_script_setup_true_lang-9cad14ba.js";
2
+ import "./index-5ec791df.js";
3
+ export {
4
+ _sfc_main as default
5
+ };
@@ -0,0 +1,32 @@
1
+ import { d as defineComponent, b as resolveComponent, c as openBlock, e as createElementBlock, p as createBaseVNode, t as toDisplayString, f as createVNode } from "./index-5ec791df.js";
2
+ const _hoisted_1 = { class: "component-container" };
3
+ const _hoisted_2 = { class: "listbox-subtitle" };
4
+ const _sfc_main = /* @__PURE__ */ defineComponent({
5
+ __name: "TextInput",
6
+ props: {
7
+ schema: {
8
+ type: Object,
9
+ required: true
10
+ },
11
+ modelValue: String
12
+ },
13
+ emits: ["update:modelValue"],
14
+ setup(__props) {
15
+ return (_ctx, _cache) => {
16
+ const _component_el_input = resolveComponent("el-input");
17
+ return openBlock(), createElementBlock("div", _hoisted_1, [
18
+ createBaseVNode("label", _hoisted_2, toDisplayString(__props.schema.label), 1),
19
+ createVNode(_component_el_input, {
20
+ "model-value": __props.modelValue,
21
+ placeholder: __props.schema.placeholder || "Enter value...",
22
+ clearable: "",
23
+ size: "large",
24
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => _ctx.$emit("update:modelValue", $event))
25
+ }, null, 8, ["model-value", "placeholder"])
26
+ ]);
27
+ };
28
+ }
29
+ });
30
+ export {
31
+ _sfc_main as _
32
+ };
@@ -1,48 +1,48 @@
1
1
 
2
- .selectors[data-v-bf118d5c] {
2
+ .selectors[data-v-f1232e87] {
3
3
  display: flex;
4
4
  flex-direction: column;
5
5
  gap: 8px;
6
6
  }
7
- .input-wrapper[data-v-bf118d5c] {
7
+ .input-wrapper[data-v-f1232e87] {
8
8
  display: flex;
9
9
  flex-direction: column;
10
10
  gap: 4px;
11
11
  }
12
- label[data-v-bf118d5c] {
12
+ label[data-v-f1232e87] {
13
13
  font-weight: 500;
14
14
  color: #333;
15
15
  font-size: 14px;
16
16
  }
17
- input[data-v-bf118d5c] {
17
+ input[data-v-f1232e87] {
18
18
  padding: 3px;
19
19
  border: 1px solid #ccc;
20
20
  border-radius: 4px;
21
21
  font-size: 14px;
22
22
  width: 100%;
23
23
  }
24
- .row[data-v-bf118d5c] {
24
+ .row[data-v-f1232e87] {
25
25
  display: flex;
26
26
  align-items: center;
27
27
  justify-content: space-between;
28
28
  gap: 16px;
29
29
  }
30
- .error-msg[data-v-bf118d5c] {
30
+ .error-msg[data-v-f1232e87] {
31
31
  font-size: 13px;
32
32
  color: #ff4d4f;
33
33
  display: flex;
34
34
  align-items: center;
35
35
  gap: 6px;
36
36
  }
37
- .error-icon[data-v-bf118d5c] {
37
+ .error-icon[data-v-f1232e87] {
38
38
  margin-right: 6px;
39
39
  }
40
- .table[data-v-bf118d5c] {
40
+ .table[data-v-f1232e87] {
41
41
  padding: 12px;
42
42
  border-radius: 6px;
43
43
 
44
44
  box-shadow: 0 1px 5px rgba(0, 0, 0, 0.05);
45
45
  }
46
- el-checkbox[data-v-bf118d5c] {
46
+ el-checkbox[data-v-f1232e87] {
47
47
  margin-top: 10px;
48
48
  }
@@ -1,12 +1,11 @@
1
- import { d as defineComponent, r as ref, l as computed, n as onMounted, R as nextTick, b as resolveComponent, c as openBlock, e as createElementBlock, f as createVNode, w as withCtx, p as createBaseVNode, g as createTextVNode, i as createCommentVNode, a5 as withDirectives, a6 as vModelText, h as createBlock, u as unref, _ as _export_sfc, a7 as Teleport } from "./index-683fc198.js";
2
- import { u as useNodeStore } from "./vue-codemirror.esm-dc5e3348.js";
3
- import { C as ColumnSelector } from "./dropDown-0b46dd77.js";
4
- import { u as unavailableField } from "./UnavailableFields-8b0cb48e.js";
5
- import { G as GenericNodeSettings } from "./genericNodeSettings-def5879b.js";
6
- import { C as CodeLoader } from "./vue-content-loader.es-ba94b82f.js";
7
- import { N as NodeButton, a as NodeTitle } from "./nodeTitle-a16db7c3.js";
8
- import "./designer-6c322d8e.js";
9
- const _hoisted_1$1 = {
1
+ import { d as defineComponent, r as ref, l as computed, n as onMounted, R as nextTick, b as resolveComponent, c as openBlock, e as createElementBlock, f as createVNode, w as withCtx, p as createBaseVNode, g as createTextVNode, i as createCommentVNode, a8 as withDirectives, a9 as vModelText, h as createBlock, u as unref, _ as _export_sfc } from "./index-5ec791df.js";
2
+ import { u as useNodeStore } from "./vue-codemirror.esm-b1dfaa46.js";
3
+ import { C as ColumnSelector } from "./dropDown-41ebe3c2.js";
4
+ import { u as unavailableField } from "./UnavailableFields-66239e83.js";
5
+ import { G as GenericNodeSettings } from "./genericNodeSettings-38410ebf.js";
6
+ import { C as CodeLoader } from "./vue-content-loader.es-22bac17c.js";
7
+ import "./designer-1667687d.js";
8
+ const _hoisted_1 = {
10
9
  key: 0,
11
10
  class: "listbox-wrapper"
12
11
  };
@@ -31,8 +30,8 @@ const _hoisted_9 = {
31
30
  class: "row"
32
31
  };
33
32
  const _hoisted_10 = { class: "row" };
34
- const _sfc_main$1 = /* @__PURE__ */ defineComponent({
35
- __name: "textToRows",
33
+ const _sfc_main = /* @__PURE__ */ defineComponent({
34
+ __name: "TextToRows",
36
35
  setup(__props, { expose: __expose }) {
37
36
  const containsVal = (arr, val) => {
38
37
  return arr.includes(val);
@@ -76,7 +75,6 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
76
75
  };
77
76
  const pushNodeData = async () => {
78
77
  isLoaded.value = false;
79
- nodeStore.isDrawerOpen = false;
80
78
  if (nodeTextToRows.value) {
81
79
  nodeTextToRows.value.is_setup = true;
82
80
  }
@@ -95,7 +93,7 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
95
93
  const _component_el_radio = resolveComponent("el-radio");
96
94
  const _component_el_radio_group = resolveComponent("el-radio-group");
97
95
  const _component_el_col = resolveComponent("el-col");
98
- return isLoaded.value && nodeTextToRows.value ? (openBlock(), createElementBlock("div", _hoisted_1$1, [
96
+ return isLoaded.value && nodeTextToRows.value ? (openBlock(), createElementBlock("div", _hoisted_1, [
99
97
  createVNode(GenericNodeSettings, {
100
98
  modelValue: nodeTextToRows.value,
101
99
  "onUpdate:modelValue": _cache[7] || (_cache[7] = ($event) => nodeTextToRows.value = $event)
@@ -238,75 +236,8 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
238
236
  };
239
237
  }
240
238
  });
241
- const textToRows_vue_vue_type_style_index_0_scoped_bf118d5c_lang = "";
242
- const joinInput = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["__scopeId", "data-v-bf118d5c"]]);
243
- const _hoisted_1 = { ref: "el" };
244
- const _sfc_main = /* @__PURE__ */ defineComponent({
245
- __name: "TextToRows",
246
- props: {
247
- nodeId: {
248
- type: Number,
249
- required: true
250
- }
251
- },
252
- setup(__props) {
253
- const nodeStore = useNodeStore();
254
- const props = __props;
255
- const childComp = ref(null);
256
- const drawer = ref(false);
257
- const closeOnDrawer = () => {
258
- var _a;
259
- (_a = childComp.value) == null ? void 0 : _a.pushNodeData();
260
- drawer.value = false;
261
- nodeStore.isDrawerOpen = false;
262
- };
263
- const openDrawer = async () => {
264
- if (nodeStore.node_id === props.nodeId) {
265
- return;
266
- }
267
- nodeStore.closeDrawer();
268
- drawer.value = true;
269
- const drawerOpen = nodeStore.isDrawerOpen;
270
- nodeStore.isDrawerOpen = true;
271
- await nextTick();
272
- if (nodeStore.node_id === props.nodeId && drawerOpen) {
273
- return;
274
- }
275
- if (childComp.value) {
276
- childComp.value.loadNodeData(props.nodeId);
277
- nodeStore.openDrawer(closeOnDrawer);
278
- }
279
- };
280
- onMounted(async () => {
281
- await nextTick();
282
- });
283
- return (_ctx, _cache) => {
284
- return openBlock(), createElementBlock("div", _hoisted_1, [
285
- createVNode(NodeButton, {
286
- ref: "nodeButton",
287
- "node-id": __props.nodeId,
288
- "image-src": "text_to_rows.png",
289
- title: `${__props.nodeId}: Fuzzy match`,
290
- onClick: openDrawer
291
- }, null, 8, ["node-id", "title"]),
292
- drawer.value ? (openBlock(), createBlock(Teleport, {
293
- key: 0,
294
- to: "#nodesettings"
295
- }, [
296
- createVNode(NodeTitle, {
297
- title: "Text to rows",
298
- intro: "Split text into rows based on a delimiter"
299
- }),
300
- createVNode(joinInput, {
301
- ref_key: "childComp",
302
- ref: childComp,
303
- "node-id": __props.nodeId
304
- }, null, 8, ["node-id"])
305
- ])) : createCommentVNode("", true)
306
- ], 512);
307
- };
308
- }
309
- });
239
+ const TextToRows_vue_vue_type_style_index_0_scoped_f1232e87_lang = "";
240
+ const TextToRows = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-f1232e87"]]);
310
241
  export {
311
- _sfc_main as default
242
+ TextToRows as default
312
243
  };
@@ -0,0 +1,5 @@
1
+ import { _ as _sfc_main } from "./ToggleSwitch.vue_vue_type_script_setup_true_lang-f620cd32.js";
2
+ import "./index-5ec791df.js";
3
+ export {
4
+ _sfc_main as default
5
+ };
@@ -0,0 +1,31 @@
1
+ import { d as defineComponent, b as resolveComponent, c as openBlock, e as createElementBlock, p as createBaseVNode, t as toDisplayString, f as createVNode } from "./index-5ec791df.js";
2
+ const _hoisted_1 = { class: "component-container" };
3
+ const _hoisted_2 = { class: "listbox-subtitle" };
4
+ const _sfc_main = /* @__PURE__ */ defineComponent({
5
+ __name: "ToggleSwitch",
6
+ props: {
7
+ schema: {
8
+ type: Object,
9
+ required: true
10
+ },
11
+ modelValue: Boolean
12
+ },
13
+ emits: ["update:modelValue"],
14
+ setup(__props) {
15
+ return (_ctx, _cache) => {
16
+ const _component_el_switch = resolveComponent("el-switch");
17
+ return openBlock(), createElementBlock("div", _hoisted_1, [
18
+ createBaseVNode("label", _hoisted_2, toDisplayString(__props.schema.label), 1),
19
+ createVNode(_component_el_switch, {
20
+ "model-value": __props.modelValue,
21
+ size: "large",
22
+ "inline-prompt": "",
23
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => _ctx.$emit("update:modelValue", $event))
24
+ }, null, 8, ["model-value"])
25
+ ]);
26
+ };
27
+ }
28
+ });
29
+ export {
30
+ _sfc_main as _
31
+ };
@@ -1,5 +1,5 @@
1
- import { P as PopOver } from "./vue-codemirror.esm-dc5e3348.js";
2
- import { d as defineComponent, c as openBlock, h as createBlock, w as withCtx, p as createBaseVNode, t as toDisplayString, _ as _export_sfc } from "./index-683fc198.js";
1
+ import { P as PopOver } from "./vue-codemirror.esm-b1dfaa46.js";
2
+ import { d as defineComponent, c as openBlock, h as createBlock, w as withCtx, p as createBaseVNode, t as toDisplayString, _ as _export_sfc } from "./index-5ec791df.js";
3
3
  const _hoisted_1 = { class: "icon-wrapper" };
4
4
  const _hoisted_2 = { class: "unavailable-icon" };
5
5
  const _sfc_main = /* @__PURE__ */ defineComponent({
@@ -0,0 +1,77 @@
1
+ import { u as useNodeStore } from "./vue-codemirror.esm-b1dfaa46.js";
2
+ import { G as GenericNodeSettings } from "./genericNodeSettings-38410ebf.js";
3
+ import { d as defineComponent, r as ref, n as onMounted, R as nextTick, o as onUnmounted, c as openBlock, e as createElementBlock, f as createVNode, w as withCtx, g as createTextVNode, i as createCommentVNode, _ as _export_sfc } from "./index-5ec791df.js";
4
+ import "./designer-1667687d.js";
5
+ const _hoisted_1 = {
6
+ key: 0,
7
+ class: "listbox-wrapper"
8
+ };
9
+ const _sfc_main = /* @__PURE__ */ defineComponent({
10
+ __name: "Union",
11
+ setup(__props, { expose: __expose }) {
12
+ const nodeStore = useNodeStore();
13
+ const showContextMenu = ref(false);
14
+ const dataLoaded = ref(false);
15
+ const nodeData = ref(null);
16
+ const unionInput = ref({ mode: "relaxed" });
17
+ const nodeUnion = ref(null);
18
+ const loadNodeData = async (nodeId) => {
19
+ var _a;
20
+ console.log("loadNodeData from union ");
21
+ nodeData.value = await nodeStore.getNodeData(nodeId, false);
22
+ nodeUnion.value = (_a = nodeData.value) == null ? void 0 : _a.setting_input;
23
+ if (nodeData.value) {
24
+ if (nodeUnion.value) {
25
+ if (nodeUnion.value.union_input) {
26
+ unionInput.value = nodeUnion.value.union_input;
27
+ } else {
28
+ nodeUnion.value.union_input = unionInput.value;
29
+ }
30
+ }
31
+ }
32
+ dataLoaded.value = true;
33
+ console.log("loadNodeData from groupby");
34
+ };
35
+ const handleClickOutside = (event) => {
36
+ const targetEvent = event.target;
37
+ if (targetEvent.id === "pivot-context-menu")
38
+ return;
39
+ showContextMenu.value = false;
40
+ };
41
+ const pushNodeData = async () => {
42
+ if (unionInput.value) {
43
+ nodeStore.updateSettings(nodeUnion);
44
+ }
45
+ };
46
+ __expose({
47
+ loadNodeData,
48
+ pushNodeData
49
+ });
50
+ onMounted(async () => {
51
+ await nextTick();
52
+ window.addEventListener("click", handleClickOutside);
53
+ });
54
+ onUnmounted(() => {
55
+ window.removeEventListener("click", handleClickOutside);
56
+ });
57
+ return (_ctx, _cache) => {
58
+ return dataLoaded.value && nodeUnion.value ? (openBlock(), createElementBlock("div", _hoisted_1, [
59
+ createVNode(GenericNodeSettings, {
60
+ modelValue: nodeUnion.value,
61
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => nodeUnion.value = $event)
62
+ }, {
63
+ default: withCtx(() => _cache[1] || (_cache[1] = [
64
+ createTextVNode(" 'Union multiple tables into one table, this node does not have settings' ")
65
+ ])),
66
+ _: 1,
67
+ __: [1]
68
+ }, 8, ["modelValue"])
69
+ ])) : createCommentVNode("", true);
70
+ };
71
+ }
72
+ });
73
+ const Union_vue_vue_type_style_index_0_scoped_5786442f_lang = "";
74
+ const Union = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-5786442f"]]);
75
+ export {
76
+ Union as default
77
+ };
@@ -1,5 +1,5 @@
1
1
 
2
- .context-menu[data-v-beb191a2] {
2
+ .context-menu[data-v-5786442f] {
3
3
  position: fixed;
4
4
  z-index: 1000;
5
5
  border: 1px solid #ccc;
@@ -8,23 +8,23 @@
8
8
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
9
9
  border-radius: 4px;
10
10
  }
11
- .context-menu ul[data-v-beb191a2] {
11
+ .context-menu ul[data-v-5786442f] {
12
12
  list-style: none;
13
13
  padding: 0;
14
14
  margin: 0;
15
15
  }
16
- .context-menu li[data-v-beb191a2] {
16
+ .context-menu li[data-v-5786442f] {
17
17
  padding: 8px 16px;
18
18
  cursor: pointer;
19
19
  }
20
- .context-menu li[data-v-beb191a2]:hover {
20
+ .context-menu li[data-v-5786442f]:hover {
21
21
  background-color: #f0f0f0;
22
22
  }
23
- .switch-container[data-v-beb191a2] {
23
+ .switch-container[data-v-5786442f] {
24
24
  display: flex;
25
25
  align-items: center;
26
26
  margin: 12px;
27
27
  }
28
- .switch-container span[data-v-beb191a2] {
28
+ .switch-container span[data-v-5786442f] {
29
29
  margin-right: 10px;
30
30
  }