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,15 +1,14 @@
1
- import { d as defineComponent, r as ref, 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, g as createTextVNode, a5 as withDirectives, a6 as vModelText, i as createCommentVNode, h as createBlock, a7 as Teleport } from "./index-683fc198.js";
2
- import { u as useNodeStore } from "./vue-codemirror.esm-dc5e3348.js";
3
- import { G as GenericNodeSettings } from "./genericNodeSettings-def5879b.js";
4
- import { N as NodeButton, a as NodeTitle } from "./nodeTitle-a16db7c3.js";
5
- import "./designer-6c322d8e.js";
6
- const _hoisted_1$1 = {
1
+ import { d as defineComponent, r as ref, 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, g as createTextVNode, a8 as withDirectives, a9 as vModelText, i as createCommentVNode } from "./index-5ec791df.js";
2
+ import { u as useNodeStore } from "./vue-codemirror.esm-b1dfaa46.js";
3
+ import { G as GenericNodeSettings } from "./genericNodeSettings-38410ebf.js";
4
+ import "./designer-1667687d.js";
5
+ const _hoisted_1 = {
7
6
  key: 0,
8
7
  class: "listbox-wrapper"
9
8
  };
10
9
  const _hoisted_2 = { class: "listbox-wrapper" };
11
- const _sfc_main$1 = /* @__PURE__ */ defineComponent({
12
- __name: "sample",
10
+ const _sfc_main = /* @__PURE__ */ defineComponent({
11
+ __name: "Sample",
13
12
  setup(__props, { expose: __expose }) {
14
13
  const nodeStore = useNodeStore();
15
14
  const showContextMenu = ref(false);
@@ -50,7 +49,6 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
50
49
  }
51
50
  nodeStore.updateSettings(nodeSample);
52
51
  dataLoaded.value = false;
53
- nodeStore.isDrawerOpen = false;
54
52
  };
55
53
  __expose({
56
54
  loadNodeData,
@@ -66,7 +64,7 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
66
64
  return (_ctx, _cache) => {
67
65
  const _component_el_col = resolveComponent("el-col");
68
66
  const _component_el_row = resolveComponent("el-row");
69
- return dataLoaded.value && nodeSample.value ? (openBlock(), createElementBlock("div", _hoisted_1$1, [
67
+ return dataLoaded.value && nodeSample.value ? (openBlock(), createElementBlock("div", _hoisted_1, [
70
68
  createVNode(GenericNodeSettings, {
71
69
  modelValue: nodeSample.value,
72
70
  "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => nodeSample.value = $event)
@@ -113,73 +111,6 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
113
111
  };
114
112
  }
115
113
  });
116
- const _hoisted_1 = { ref: "el" };
117
- const _sfc_main = /* @__PURE__ */ defineComponent({
118
- __name: "Sample",
119
- props: {
120
- nodeId: {
121
- type: Number,
122
- required: true
123
- }
124
- },
125
- setup(__props) {
126
- const nodeStore = useNodeStore();
127
- const childComp = ref(null);
128
- const props = __props;
129
- const drawer = ref(false);
130
- const closeOnDrawer = () => {
131
- var _a;
132
- (_a = childComp.value) == null ? void 0 : _a.pushNodeData();
133
- drawer.value = false;
134
- nodeStore.isDrawerOpen = false;
135
- };
136
- const openDrawer = async () => {
137
- if (nodeStore.node_id === props.nodeId) {
138
- return;
139
- }
140
- nodeStore.closeDrawer();
141
- drawer.value = true;
142
- const drawerOpen = nodeStore.isDrawerOpen;
143
- nodeStore.isDrawerOpen = true;
144
- await nextTick();
145
- if (nodeStore.node_id === props.nodeId && drawerOpen) {
146
- return;
147
- }
148
- if (childComp.value) {
149
- childComp.value.loadNodeData(props.nodeId);
150
- nodeStore.openDrawer(closeOnDrawer);
151
- }
152
- };
153
- onMounted(async () => {
154
- await nextTick();
155
- });
156
- return (_ctx, _cache) => {
157
- return openBlock(), createElementBlock("div", _hoisted_1, [
158
- createVNode(NodeButton, {
159
- ref: "nodeButton",
160
- "node-id": __props.nodeId,
161
- "image-src": "sample.png",
162
- title: `${__props.nodeId}: Sample`,
163
- onClick: openDrawer
164
- }, null, 8, ["node-id", "title"]),
165
- drawer.value ? (openBlock(), createBlock(Teleport, {
166
- key: 0,
167
- to: "#nodesettings"
168
- }, [
169
- createVNode(NodeTitle, {
170
- title: "Sample",
171
- intro: "When taking a sample, the most crucial factor to consider is the size of the sample. The size refers to the number of items or observations included in the sample from a larger population. This number is pivotal because it influences the accuracy and reliability of the results obtained from the sample. By carefully determining the sample size, we ensure that our findings are representative of the larger group, allowing us to make informed decisions or predictions based on the sample data"
172
- }),
173
- createVNode(_sfc_main$1, {
174
- ref_key: "childComp",
175
- ref: childComp,
176
- "node-id": __props.nodeId
177
- }, null, 8, ["node-id"])
178
- ])) : createCommentVNode("", true)
179
- ], 512);
180
- };
181
- }
182
- });
183
114
  export {
184
115
  _sfc_main as default
185
116
  };
@@ -1,5 +1,5 @@
1
- import { r as ref, l as computed, d as defineComponent, n as onMounted, e as createElementBlock, p as createBaseVNode, v as withModifiers, a5 as withDirectives, a6 as vModelText, ah as vModelDynamic, s as normalizeClass, g as createTextVNode, t as toDisplayString, u as unref, O as isRef, i as createCommentVNode, F as Fragment, q as renderList, c as openBlock } from "./index-683fc198.js";
2
- import { f as fetchSecretsApi, a as addSecretApi, g as getSecretValueApi, d as deleteSecretApi } from "./secretApi-baceb6f9.js";
1
+ import { r as ref, l as computed, d as defineComponent, n as onMounted, e as createElementBlock, p as createBaseVNode, v as withModifiers, a8 as withDirectives, a9 as vModelText, al as vModelDynamic, s as normalizeClass, g as createTextVNode, t as toDisplayString, u as unref, O as isRef, i as createCommentVNode, F as Fragment, q as renderList, c as openBlock } from "./index-5ec791df.js";
2
+ import { f as fetchSecretsApi, a as addSecretApi, g as getSecretValueApi, d as deleteSecretApi } from "./secretApi-b3cb072e.js";
3
3
  function useSecretManager() {
4
4
  const secrets = ref([]);
5
5
  const isLoading = ref(true);
@@ -1,11 +1,10 @@
1
- import { r as ref, d as defineComponent, c as openBlock, e as createElementBlock, f as createVNode, w as withCtx, h as createBlock, u as unref, n as onMounted, R as nextTick, a7 as Teleport, i as createCommentVNode } from "./index-683fc198.js";
2
- import { C as CodeLoader } from "./vue-content-loader.es-ba94b82f.js";
3
- import { u as useNodeStore } from "./vue-codemirror.esm-dc5e3348.js";
4
- import { s as selectDynamic } from "./selectDynamic-de91449a.js";
5
- import { G as GenericNodeSettings } from "./genericNodeSettings-def5879b.js";
6
- import { N as NodeButton, a as NodeTitle } from "./nodeTitle-a16db7c3.js";
7
- import "./UnavailableFields-8b0cb48e.js";
8
- import "./designer-6c322d8e.js";
1
+ import { r as ref, d as defineComponent, c as openBlock, e as createElementBlock, f as createVNode, w as withCtx, h as createBlock, u as unref } from "./index-5ec791df.js";
2
+ import { C as CodeLoader } from "./vue-content-loader.es-22bac17c.js";
3
+ import { u as useNodeStore } from "./vue-codemirror.esm-b1dfaa46.js";
4
+ import { s as selectDynamic } from "./selectDynamic-7ad95bca.js";
5
+ import { G as GenericNodeSettings } from "./genericNodeSettings-38410ebf.js";
6
+ import "./UnavailableFields-66239e83.js";
7
+ import "./designer-1667687d.js";
9
8
  const createSelectInput = (column_name, data_type = void 0, position = void 0, original_position = void 0) => {
10
9
  const selectInput = {
11
10
  old_name: column_name,
@@ -60,12 +59,12 @@ const createNodeSelect = (flowId = -1, nodeId = -1, pos_x = 0, pos_y = 0, cache_
60
59
  });
61
60
  return nodeSelectRef;
62
61
  };
63
- const _hoisted_1$1 = {
62
+ const _hoisted_1 = {
64
63
  key: 0,
65
64
  class: "listbox-wrapper"
66
65
  };
67
- const _sfc_main$1 = /* @__PURE__ */ defineComponent({
68
- __name: "select",
66
+ const _sfc_main = /* @__PURE__ */ defineComponent({
67
+ __name: "Select",
69
68
  setup(__props, { expose: __expose }) {
70
69
  const keepMissing = ref(false);
71
70
  const nodeStore = useNodeStore();
@@ -73,7 +72,6 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
73
72
  const dataLoaded = ref(false);
74
73
  const loadNodeData = async (nodeId) => {
75
74
  const result = await nodeStore.getNodeData(nodeId, false);
76
- console.log("got result data");
77
75
  if (result) {
78
76
  const main_input = result.main_input;
79
77
  try {
@@ -85,7 +83,6 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
85
83
  throw new Error("Setting input not available");
86
84
  }
87
85
  } catch (error) {
88
- console.log("doing this");
89
86
  if (main_input && nodeSelect.value) {
90
87
  nodeSelect.value = createNodeSelect(nodeStore.flow_id, nodeStore.node_id).value;
91
88
  nodeSelect.value.depending_on_id = main_input.node_id;
@@ -128,7 +125,7 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
128
125
  pushNodeData
129
126
  });
130
127
  return (_ctx, _cache) => {
131
- return dataLoaded.value ? (openBlock(), createElementBlock("div", _hoisted_1$1, [
128
+ return dataLoaded.value ? (openBlock(), createElementBlock("div", _hoisted_1, [
132
129
  createVNode(GenericNodeSettings, {
133
130
  modelValue: nodeSelect.value,
134
131
  "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => nodeSelect.value = $event)
@@ -155,77 +152,6 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
155
152
  };
156
153
  }
157
154
  });
158
- const _hoisted_1 = { ref: "el" };
159
- const _sfc_main = /* @__PURE__ */ defineComponent({
160
- __name: "Select",
161
- props: {
162
- nodeId: {
163
- type: Number,
164
- required: true
165
- }
166
- },
167
- setup(__props) {
168
- const nodeStore = useNodeStore();
169
- const childComp = ref(null);
170
- const drawer = ref(false);
171
- let isSelected = ref(false);
172
- const props = __props;
173
- onMounted(async () => {
174
- await nextTick();
175
- });
176
- const closeOnDrawer = () => {
177
- var _a;
178
- if (drawer.value) {
179
- isSelected.value = false;
180
- (_a = childComp.value) == null ? void 0 : _a.pushNodeData();
181
- drawer.value = false;
182
- nodeStore.isDrawerOpen = false;
183
- }
184
- };
185
- const openDrawer = async () => {
186
- if (nodeStore.node_id === props.nodeId) {
187
- return;
188
- }
189
- nodeStore.closeDrawer();
190
- drawer.value = true;
191
- const drawerOpen = nodeStore.isDrawerOpen;
192
- nodeStore.isDrawerOpen = true;
193
- await nextTick();
194
- if (nodeStore.node_id === props.nodeId && drawerOpen) {
195
- return;
196
- }
197
- if (childComp.value) {
198
- childComp.value.loadNodeData(props.nodeId);
199
- nodeStore.openDrawer(closeOnDrawer);
200
- }
201
- };
202
- return (_ctx, _cache) => {
203
- return openBlock(), createElementBlock("div", _hoisted_1, [
204
- createVNode(NodeButton, {
205
- ref: "nodeButton",
206
- "node-id": __props.nodeId,
207
- "image-src": "select.png",
208
- title: `${__props.nodeId}: Select data`,
209
- onClick: openDrawer
210
- }, null, 8, ["node-id", "title"]),
211
- drawer.value ? (openBlock(), createBlock(Teleport, {
212
- key: 0,
213
- to: "#nodesettings"
214
- }, [
215
- createVNode(NodeTitle, {
216
- title: "Select data",
217
- intro: "Select columns from the data"
218
- }),
219
- createVNode(_sfc_main$1, {
220
- ref_key: "childComp",
221
- ref: childComp,
222
- "node-id": __props.nodeId
223
- }, null, 8, ["node-id"])
224
- ])) : createCommentVNode("", true)
225
- ], 512);
226
- };
227
- }
228
- });
229
155
  export {
230
156
  _sfc_main as default
231
157
  };
@@ -0,0 +1,21 @@
1
+
2
+ .items-container[data-v-fd7e6af1] {
3
+ display: flex;
4
+ flex-wrap: wrap;
5
+ gap: 10px; /* Space between items */
6
+ }
7
+ .item-box[data-v-fd7e6af1] {
8
+ display: flex;
9
+ align-items: center;
10
+ padding: 5px 10px;
11
+ background-color: #f0f0f0;
12
+ border-radius: 4px;
13
+ font-size: 12px; /* Font size set to 12px */
14
+ position: relative;
15
+ }
16
+ .remove-btn[data-v-fd7e6af1] {
17
+ margin-left: 8px;
18
+ cursor: pointer;
19
+ color: #100f0f72;
20
+ font-weight: bold;
21
+ }
@@ -1,41 +1,4 @@
1
- import { d as defineComponent, c as openBlock, e as createElementBlock, p as createBaseVNode, F as Fragment, q as renderList, s as normalizeClass, t as toDisplayString, T as normalizeStyle, _ as _export_sfc, g as createTextVNode, i as createCommentVNode } from "./index-683fc198.js";
2
- const _hoisted_1$1 = ["onClick"];
3
- const _sfc_main$1 = /* @__PURE__ */ defineComponent({
4
- __name: "ContextMenu",
5
- props: {
6
- position: { type: Object, required: true },
7
- options: {
8
- type: Array,
9
- required: true
10
- }
11
- },
12
- emits: ["select", "close"],
13
- setup(__props, { emit: __emit }) {
14
- const emit = __emit;
15
- const selectOption = (action) => {
16
- emit("select", action);
17
- emit("close");
18
- };
19
- return (_ctx, _cache) => {
20
- return openBlock(), createElementBlock("div", {
21
- class: "context-menu",
22
- style: normalizeStyle({ top: __props.position.y + "px", left: __props.position.x + "px" })
23
- }, [
24
- createBaseVNode("ul", null, [
25
- (openBlock(true), createElementBlock(Fragment, null, renderList(__props.options, (option) => {
26
- return openBlock(), createElementBlock("li", {
27
- key: option.action,
28
- class: normalizeClass({ disabled: option.disabled }),
29
- onClick: ($event) => !option.disabled && selectOption(option.action)
30
- }, toDisplayString(option.label), 11, _hoisted_1$1);
31
- }), 128))
32
- ])
33
- ], 4);
34
- };
35
- }
36
- });
37
- const ContextMenu_vue_vue_type_style_index_0_scoped_a562ba5e_lang = "";
38
- const ContextMenu = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["__scopeId", "data-v-a562ba5e"]]);
1
+ import { d as defineComponent, c as openBlock, e as createElementBlock, p as createBaseVNode, t as toDisplayString, F as Fragment, q as renderList, g as createTextVNode, i as createCommentVNode, _ as _export_sfc } from "./index-5ec791df.js";
39
2
  const _hoisted_1 = { class: "listbox-wrapper" };
40
3
  const _hoisted_2 = { class: "listbox-row" };
41
4
  const _hoisted_3 = { class: "listbox-subtitle" };
@@ -82,6 +45,5 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
82
45
  const SettingsSection_vue_vue_type_style_index_0_scoped_89e3a043_lang = "";
83
46
  const SettingsSection = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-89e3a043"]]);
84
47
  export {
85
- ContextMenu as C,
86
- SettingsSection as S
48
+ SettingsSection as default
87
49
  };
@@ -0,0 +1,45 @@
1
+ import { d as defineComponent, c as openBlock, e as createElementBlock, p as createBaseVNode, t as toDisplayString, g as createTextVNode, i as createCommentVNode, _ as _export_sfc } from "./index-5ec791df.js";
2
+ const _hoisted_1 = { class: "listbox-wrapper" };
3
+ const _hoisted_2 = { class: "listbox-row" };
4
+ const _hoisted_3 = { class: "listbox-subtitle" };
5
+ const _hoisted_4 = { class: "items-container" };
6
+ const _hoisted_5 = {
7
+ key: 0,
8
+ class: "item-box"
9
+ };
10
+ const _sfc_main = /* @__PURE__ */ defineComponent({
11
+ __name: "SettingsSection",
12
+ props: {
13
+ title: { type: String, required: true },
14
+ item: { type: String, required: true }
15
+ // Changed to a single item
16
+ },
17
+ emits: ["removeItem"],
18
+ setup(__props, { emit: __emit }) {
19
+ const emit = __emit;
20
+ const emitRemove = (item) => {
21
+ emit("removeItem", item);
22
+ };
23
+ return (_ctx, _cache) => {
24
+ return openBlock(), createElementBlock("div", _hoisted_1, [
25
+ createBaseVNode("div", _hoisted_2, [
26
+ createBaseVNode("div", _hoisted_3, toDisplayString(__props.title), 1),
27
+ createBaseVNode("div", _hoisted_4, [
28
+ __props.item !== "" ? (openBlock(), createElementBlock("div", _hoisted_5, [
29
+ createTextVNode(toDisplayString(__props.item) + " ", 1),
30
+ createBaseVNode("span", {
31
+ class: "remove-btn",
32
+ onClick: _cache[0] || (_cache[0] = ($event) => emitRemove(__props.item))
33
+ }, "x")
34
+ ])) : createCommentVNode("", true)
35
+ ])
36
+ ])
37
+ ]);
38
+ };
39
+ }
40
+ });
41
+ const SettingsSection_vue_vue_type_style_index_0_scoped_43acf78a_lang = "";
42
+ const SettingsSection = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-43acf78a"]]);
43
+ export {
44
+ SettingsSection as default
45
+ };
@@ -0,0 +1,20 @@
1
+
2
+ .items-container[data-v-43acf78a] {
3
+ display: flex;
4
+ gap: 10px; /* Space between items */
5
+ }
6
+ .item-box[data-v-43acf78a] {
7
+ display: flex;
8
+ align-items: center;
9
+ padding: 5px 10px;
10
+ background-color: #f0f0f0;
11
+ border-radius: 4px;
12
+ font-size: 12px; /* Font size set to 12px */
13
+ position: relative;
14
+ }
15
+ .remove-btn[data-v-43acf78a] {
16
+ margin-left: 8px;
17
+ cursor: pointer;
18
+ color: #100f0f72;
19
+ font-weight: bold;
20
+ }
@@ -0,0 +1,21 @@
1
+
2
+ .items-container[data-v-89e3a043] {
3
+ display: flex;
4
+ flex-wrap: wrap;
5
+ gap: 10px; /* Space between items */
6
+ }
7
+ .item-box[data-v-89e3a043] {
8
+ display: flex;
9
+ align-items: center;
10
+ padding: 5px 10px;
11
+ background-color: #f0f0f0;
12
+ border-radius: 4px;
13
+ font-size: 12px; /* Font size set to 12px */
14
+ position: relative;
15
+ }
16
+ .remove-btn[data-v-89e3a043] {
17
+ margin-left: 8px;
18
+ cursor: pointer;
19
+ color: #100f0f72;
20
+ font-weight: bold;
21
+ }
@@ -0,0 +1,53 @@
1
+ import { d as defineComponent, c as openBlock, e as createElementBlock, p as createBaseVNode, T as normalizeStyle, t as toDisplayString, F as Fragment, q as renderList, g as createTextVNode, i as createCommentVNode, _ as _export_sfc } from "./index-5ec791df.js";
2
+ const _hoisted_1 = { class: "listbox-wrapper" };
3
+ const _hoisted_2 = { class: "listbox-row" };
4
+ const _hoisted_3 = { class: "items-container" };
5
+ const _hoisted_4 = { key: 0 };
6
+ const _hoisted_5 = ["onClick"];
7
+ const _sfc_main = /* @__PURE__ */ defineComponent({
8
+ __name: "SettingsSection",
9
+ props: {
10
+ title: { type: String, required: true },
11
+ titleFontSize: { type: String, default: "15px" },
12
+ items: { type: Array, required: true }
13
+ },
14
+ emits: ["removeItem"],
15
+ setup(__props, { emit: __emit }) {
16
+ const props = __props;
17
+ const emit = __emit;
18
+ const emitRemove = (item) => {
19
+ emit("removeItem", item);
20
+ };
21
+ return (_ctx, _cache) => {
22
+ return openBlock(), createElementBlock("div", _hoisted_1, [
23
+ createBaseVNode("div", _hoisted_2, [
24
+ createBaseVNode("div", {
25
+ class: "listbox-title",
26
+ style: normalizeStyle({ fontSize: props.titleFontSize })
27
+ }, toDisplayString(__props.title), 5),
28
+ createBaseVNode("div", _hoisted_3, [
29
+ (openBlock(true), createElementBlock(Fragment, null, renderList(__props.items, (item, index) => {
30
+ return openBlock(), createElementBlock("div", {
31
+ key: index,
32
+ class: "item-box"
33
+ }, [
34
+ item !== "" ? (openBlock(), createElementBlock("div", _hoisted_4, [
35
+ createTextVNode(toDisplayString(item) + " ", 1),
36
+ createBaseVNode("span", {
37
+ class: "remove-btn",
38
+ onClick: ($event) => emitRemove(item)
39
+ }, "x", 8, _hoisted_5)
40
+ ])) : createCommentVNode("", true)
41
+ ]);
42
+ }), 128))
43
+ ])
44
+ ])
45
+ ]);
46
+ };
47
+ }
48
+ });
49
+ const SettingsSection_vue_vue_type_style_index_0_scoped_fd7e6af1_lang = "";
50
+ const SettingsSection = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-fd7e6af1"]]);
51
+ export {
52
+ SettingsSection as default
53
+ };
@@ -0,0 +1,5 @@
1
+ import { _ as _sfc_main } from "./SingleSelect.vue_vue_type_script_setup_true_lang-43807bad.js";
2
+ import "./index-5ec791df.js";
3
+ export {
4
+ _sfc_main as default
5
+ };
@@ -0,0 +1,62 @@
1
+ import { d as defineComponent, l as computed, b as resolveComponent, c as openBlock, e as createElementBlock, p as createBaseVNode, t as toDisplayString, f as createVNode, w as withCtx, F as Fragment, q as renderList, h as createBlock } 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: "SingleSelect",
6
+ props: {
7
+ schema: {
8
+ type: Object,
9
+ required: true
10
+ },
11
+ modelValue: {
12
+ type: [String, Number, Object],
13
+ default: null
14
+ },
15
+ incomingColumns: {
16
+ type: Array,
17
+ default: () => []
18
+ }
19
+ },
20
+ emits: ["update:modelValue"],
21
+ setup(__props) {
22
+ const props = __props;
23
+ const options = computed(() => {
24
+ if (props.schema.options && !Array.isArray(props.schema.options) && props.schema.options.__type__ === "IncomingColumns") {
25
+ return props.incomingColumns;
26
+ }
27
+ if (Array.isArray(props.schema.options)) {
28
+ return props.schema.options;
29
+ }
30
+ return [];
31
+ });
32
+ return (_ctx, _cache) => {
33
+ const _component_el_option = resolveComponent("el-option");
34
+ const _component_el_select = resolveComponent("el-select");
35
+ return openBlock(), createElementBlock("div", _hoisted_1, [
36
+ createBaseVNode("label", _hoisted_2, toDisplayString(__props.schema.label), 1),
37
+ createVNode(_component_el_select, {
38
+ "model-value": __props.modelValue,
39
+ filterable: "",
40
+ placeholder: "Select an option",
41
+ style: { "width": "100%" },
42
+ size: "large",
43
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => _ctx.$emit("update:modelValue", $event))
44
+ }, {
45
+ default: withCtx(() => [
46
+ (openBlock(true), createElementBlock(Fragment, null, renderList(options.value, (item) => {
47
+ return openBlock(), createBlock(_component_el_option, {
48
+ key: Array.isArray(item) ? item[0] : item,
49
+ label: Array.isArray(item) ? item[1] : item,
50
+ value: Array.isArray(item) ? item[0] : item
51
+ }, null, 8, ["label", "value"]);
52
+ }), 128))
53
+ ]),
54
+ _: 1
55
+ }, 8, ["model-value"])
56
+ ]);
57
+ };
58
+ }
59
+ });
60
+ export {
61
+ _sfc_main as _
62
+ };
@@ -0,0 +1,40 @@
1
+ import { d as defineComponent, b as resolveComponent, c as openBlock, e as createElementBlock, p as createBaseVNode, t as toDisplayString, f as createVNode, _ as _export_sfc } from "./index-5ec791df.js";
2
+ const _hoisted_1 = { class: "component-container" };
3
+ const _hoisted_2 = { class: "listbox-subtitle" };
4
+ const _hoisted_3 = { class: "slider-wrapper" };
5
+ const _sfc_main = /* @__PURE__ */ defineComponent({
6
+ __name: "SliderInput",
7
+ props: {
8
+ schema: {
9
+ type: Object,
10
+ required: true
11
+ },
12
+ modelValue: Number
13
+ },
14
+ emits: ["update:modelValue"],
15
+ setup(__props) {
16
+ return (_ctx, _cache) => {
17
+ const _component_el_slider = resolveComponent("el-slider");
18
+ return openBlock(), createElementBlock("div", _hoisted_1, [
19
+ createBaseVNode("label", _hoisted_2, toDisplayString(__props.schema.label), 1),
20
+ createBaseVNode("div", _hoisted_3, [
21
+ createVNode(_component_el_slider, {
22
+ "model-value": __props.modelValue,
23
+ min: __props.schema.min_value,
24
+ max: __props.schema.max_value,
25
+ step: __props.schema.step || 1,
26
+ "show-input": true,
27
+ size: "large",
28
+ style: { "width": "100%" },
29
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => _ctx.$emit("update:modelValue", $event))
30
+ }, null, 8, ["model-value", "min", "max", "step"])
31
+ ])
32
+ ]);
33
+ };
34
+ }
35
+ });
36
+ const SliderInput_vue_vue_type_style_index_0_scoped_8182875c_lang = "";
37
+ const SliderInput = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-8182875c"]]);
38
+ export {
39
+ SliderInput as default
40
+ };
@@ -0,0 +1,4 @@
1
+
2
+ .slider-wrapper[data-v-8182875c] {
3
+ padding: 0 10px;
4
+ }
@@ -1,5 +1,5 @@
1
1
 
2
- .context-menu[data-v-f29b10dc] {
2
+ .context-menu[data-v-0177dec6] {
3
3
  position: fixed;
4
4
  z-index: 1000;
5
5
  border: 1px solid #ccc;
@@ -9,7 +9,7 @@
9
9
  border-radius: 4px;
10
10
  user-select: none;
11
11
  }
12
- .context-menu button[data-v-f29b10dc] {
12
+ .context-menu button[data-v-0177dec6] {
13
13
  display: block;
14
14
  background: none;
15
15
  border: none;
@@ -19,17 +19,17 @@
19
19
  cursor: pointer;
20
20
  z-index: 100;
21
21
  }
22
- .context-menu button[data-v-f29b10dc]:hover {
22
+ .context-menu button[data-v-0177dec6]:hover {
23
23
  background-color: #f0f0f0;
24
24
  }
25
- .table-wrapper[data-v-f29b10dc] {
25
+ .table-wrapper[data-v-0177dec6] {
26
26
  max-height: 300px; /* Adjust this value as needed */
27
27
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1); /* subtle shadow for depth */
28
28
  border-radius: 8px; /* rounded corners */
29
29
  overflow: auto; /* ensures the rounded corners are applied to the child elements */
30
30
  margin: 5px; /* adds a small margin around the table */
31
31
  }
32
- .context-menu[data-v-f29b10dc] {
32
+ .context-menu[data-v-0177dec6] {
33
33
  position: fixed;
34
34
  z-index: 1000;
35
35
  border: 1px solid #ccc;
@@ -37,15 +37,15 @@
37
37
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
38
38
  border-radius: 4px;
39
39
  }
40
- .context-menu ul[data-v-f29b10dc] {
40
+ .context-menu ul[data-v-0177dec6] {
41
41
  list-style: none;
42
42
  padding: 0;
43
43
  margin: 0;
44
44
  }
45
- .context-menu li[data-v-f29b10dc] {
45
+ .context-menu li[data-v-0177dec6] {
46
46
  padding: 8px 16px;
47
47
  cursor: pointer;
48
48
  }
49
- .context-menu li[data-v-f29b10dc]:hover {
49
+ .context-menu li[data-v-0177dec6]:hover {
50
50
  background-color: #f0f0f0;
51
51
  }