Flowfile 0.3.9__py3-none-any.whl → 0.5.1__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.
Files changed (201) hide show
  1. flowfile/__init__.py +8 -1
  2. flowfile/api.py +1 -3
  3. flowfile/web/static/assets/{CloudConnectionManager-c97c25f8.js → CloudConnectionManager-0dfba9f2.js} +2 -2
  4. flowfile/web/static/assets/{CloudStorageReader-f1ff509e.js → CloudStorageReader-d5b1b6c9.js} +11 -78
  5. flowfile/web/static/assets/{CloudStorageWriter-034f8b78.js → CloudStorageWriter-00d87aad.js} +12 -79
  6. flowfile/web/static/assets/{CloudStorageWriter-49c9a4b2.css → CloudStorageWriter-b0ee067f.css} +24 -24
  7. flowfile/web/static/assets/ColumnSelector-4685e75d.js +83 -0
  8. flowfile/web/static/assets/ColumnSelector-47996a16.css +10 -0
  9. flowfile/web/static/assets/ContextMenu-23e909da.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-70ae0c79.js +41 -0
  13. flowfile/web/static/assets/ContextMenu-c13f91d0.css +26 -0
  14. flowfile/web/static/assets/ContextMenu-f149cf7c.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-702a3edd.js} +14 -84
  17. flowfile/web/static/assets/CustomNode-74a37f74.css +32 -0
  18. flowfile/web/static/assets/CustomNode-b1519993.js +211 -0
  19. flowfile/web/static/assets/{DatabaseConnectionSettings-d5c625b3.js → DatabaseConnectionSettings-6f3e4ea5.js} +3 -3
  20. flowfile/web/static/assets/{DatabaseManager-265adc5e.js → DatabaseManager-cf5ef661.js} +2 -2
  21. flowfile/web/static/assets/{DatabaseReader-f50c6558.css → DatabaseReader-ae61773c.css} +0 -27
  22. flowfile/web/static/assets/{DatabaseReader-0b10551e.js → DatabaseReader-d38c7295.js} +14 -114
  23. flowfile/web/static/assets/{DatabaseWriter-c17c6916.js → DatabaseWriter-b04ef46a.js} +13 -74
  24. flowfile/web/static/assets/{ExploreData-5bdae813.css → ExploreData-2d0cf4db.css} +8 -14
  25. flowfile/web/static/assets/ExploreData-5fa10ed8.js +192 -0
  26. flowfile/web/static/assets/{ExternalSource-3a66556c.js → ExternalSource-d39af878.js} +8 -79
  27. flowfile/web/static/assets/{Filter-91ad87e7.js → Filter-9b6d08db.js} +12 -85
  28. flowfile/web/static/assets/{Filter-a9d08ba1.css → Filter-f62091b3.css} +3 -3
  29. flowfile/web/static/assets/{Formula-3c395ab1.js → Formula-6b04fb1d.js} +20 -87
  30. flowfile/web/static/assets/{Formula-29f19d21.css → Formula-bb96803d.css} +4 -4
  31. flowfile/web/static/assets/{FuzzyMatch-6857de82.css → FuzzyMatch-1010f966.css} +42 -42
  32. flowfile/web/static/assets/{FuzzyMatch-2df0d230.js → FuzzyMatch-999521f4.js} +16 -87
  33. flowfile/web/static/assets/{GraphSolver-d285877f.js → GraphSolver-17dd2198.js} +13 -159
  34. flowfile/web/static/assets/GraphSolver-f0cb7bfb.css +22 -0
  35. flowfile/web/static/assets/{GroupBy-0bd1cc6b.js → GroupBy-6b039e18.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-24d0f113.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-34639209.js} +11 -82
  41. flowfile/web/static/assets/MultiSelect-0e8724a3.js +5 -0
  42. flowfile/web/static/assets/MultiSelect.vue_vue_type_script_setup_true_lang-b0e538c2.js +63 -0
  43. flowfile/web/static/assets/NumericInput-3d63a470.js +5 -0
  44. flowfile/web/static/assets/NumericInput.vue_vue_type_script_setup_true_lang-e0edeccc.js +35 -0
  45. flowfile/web/static/assets/Output-283fe388.css +37 -0
  46. flowfile/web/static/assets/{Output-411ecaee.js → Output-edea9802.js} +62 -273
  47. flowfile/web/static/assets/{Pivot-89db4b04.js → Pivot-61d19301.js} +14 -138
  48. flowfile/web/static/assets/Pivot-cf333e3d.css +22 -0
  49. flowfile/web/static/assets/PivotValidation-891ddfb0.css +13 -0
  50. flowfile/web/static/assets/PivotValidation-c46cd420.css +13 -0
  51. flowfile/web/static/assets/PivotValidation-de9f43fe.js +61 -0
  52. flowfile/web/static/assets/PivotValidation-f97fec5b.js +61 -0
  53. flowfile/web/static/assets/{PolarsCode-a9f974f8.js → PolarsCode-bc3c9984.js} +13 -80
  54. flowfile/web/static/assets/Read-64a3f259.js +218 -0
  55. flowfile/web/static/assets/Read-e808b239.css +62 -0
  56. flowfile/web/static/assets/RecordCount-3d5039be.js +53 -0
  57. flowfile/web/static/assets/{RecordId-55ae7d36.js → RecordId-597510e0.js} +8 -80
  58. flowfile/web/static/assets/SQLQueryComponent-36cef432.css +27 -0
  59. flowfile/web/static/assets/SQLQueryComponent-df51adbe.js +38 -0
  60. flowfile/web/static/assets/{Sample-b4a18476.js → Sample-4be0a507.js} +8 -77
  61. flowfile/web/static/assets/{SecretManager-b066d13a.js → SecretManager-4839be57.js} +2 -2
  62. flowfile/web/static/assets/{Select-727688dc.js → Select-9b72f201.js} +11 -85
  63. flowfile/web/static/assets/SettingsSection-2e4d03c4.css +21 -0
  64. flowfile/web/static/assets/SettingsSection-5c696bee.css +20 -0
  65. flowfile/web/static/assets/SettingsSection-71e6b7e3.css +21 -0
  66. flowfile/web/static/assets/SettingsSection-7ded385d.js +45 -0
  67. flowfile/web/static/assets/{SettingsSection-695ac487.js → SettingsSection-e1e9c953.js} +2 -40
  68. flowfile/web/static/assets/SettingsSection-f0f75a42.js +53 -0
  69. flowfile/web/static/assets/SingleSelect-6c777aac.js +5 -0
  70. flowfile/web/static/assets/SingleSelect.vue_vue_type_script_setup_true_lang-33e3ff9b.js +62 -0
  71. flowfile/web/static/assets/SliderInput-7cb93e62.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-6cbde21a.js} +12 -97
  75. flowfile/web/static/assets/TextInput-d9a40c11.js +5 -0
  76. flowfile/web/static/assets/TextInput.vue_vue_type_script_setup_true_lang-5896c375.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-c4fcbf4d.js} +14 -83
  79. flowfile/web/static/assets/ToggleSwitch-4ef91d19.js +5 -0
  80. flowfile/web/static/assets/ToggleSwitch.vue_vue_type_script_setup_true_lang-38478c20.js +31 -0
  81. flowfile/web/static/assets/{UnavailableFields-8b0cb48e.js → UnavailableFields-a03f512c.js} +2 -2
  82. flowfile/web/static/assets/{Union-8d9ac7f9.css → Union-af6c3d9b.css} +6 -6
  83. flowfile/web/static/assets/Union-bfe9b996.js +77 -0
  84. flowfile/web/static/assets/{Unique-af5a80b4.js → Unique-5d023a27.js} +23 -104
  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-91cc5354.js} +12 -166
  88. flowfile/web/static/assets/UnpivotValidation-0d240eeb.css +13 -0
  89. flowfile/web/static/assets/UnpivotValidation-7ee2de44.js +51 -0
  90. flowfile/web/static/assets/{ExploreData-18a4fe52.js → VueGraphicWalker-e51b9924.js} +4 -264
  91. flowfile/web/static/assets/VueGraphicWalker-ed5ab88b.css +6 -0
  92. flowfile/web/static/assets/{api-cb00cce6.js → api-c1bad5ca.js} +1 -1
  93. flowfile/web/static/assets/{api-023d1733.js → api-cf1221f0.js} +1 -1
  94. flowfile/web/static/assets/{designer-2197d782.css → designer-8da3ba3a.css} +859 -201
  95. flowfile/web/static/assets/{designer-6c322d8e.js → designer-9633482a.js} +2297 -733
  96. flowfile/web/static/assets/{documentation-4d1fafe1.js → documentation-ca400224.js} +1 -1
  97. flowfile/web/static/assets/{dropDown-0b46dd77.js → dropDown-614b998d.js} +1 -1
  98. flowfile/web/static/assets/{fullEditor-ec4e4f95.js → fullEditor-f7971590.js} +2 -2
  99. flowfile/web/static/assets/{genericNodeSettings-def5879b.js → genericNodeSettings-4fe5f36b.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-5429bbf8.js} +208 -31
  102. flowfile/web/static/assets/nodeInput-5d0d6b79.js +41 -0
  103. flowfile/web/static/assets/outputCsv-076b85ab.js +86 -0
  104. flowfile/web/static/assets/{Output-48f81019.css → outputCsv-9cc59e0b.css} +0 -143
  105. flowfile/web/static/assets/outputExcel-0fd17dbe.js +56 -0
  106. flowfile/web/static/assets/outputExcel-b41305c0.css +102 -0
  107. flowfile/web/static/assets/outputParquet-b61e0847.js +31 -0
  108. flowfile/web/static/assets/outputParquet-cf8cf3f2.css +4 -0
  109. flowfile/web/static/assets/readCsv-a8bb8b61.js +179 -0
  110. flowfile/web/static/assets/readCsv-c767cb37.css +52 -0
  111. flowfile/web/static/assets/readExcel-67b4aee0.js +201 -0
  112. flowfile/web/static/assets/readExcel-806d2826.css +64 -0
  113. flowfile/web/static/assets/readParquet-48c81530.css +19 -0
  114. flowfile/web/static/assets/readParquet-92ce1dbc.js +23 -0
  115. flowfile/web/static/assets/{secretApi-baceb6f9.js → secretApi-68435402.js} +1 -1
  116. flowfile/web/static/assets/{selectDynamic-de91449a.js → selectDynamic-92e25ee3.js} +7 -7
  117. flowfile/web/static/assets/{selectDynamic-b062bc9b.css → selectDynamic-aa913ff4.css} +16 -16
  118. flowfile/web/static/assets/user-defined-icon-0ae16c90.png +0 -0
  119. flowfile/web/static/assets/{vue-codemirror.esm-dc5e3348.js → vue-codemirror.esm-41b0e0d7.js} +65 -36
  120. flowfile/web/static/assets/{vue-content-loader.es-ba94b82f.js → vue-content-loader.es-2c8e608f.js} +1 -1
  121. flowfile/web/static/index.html +2 -2
  122. {flowfile-0.3.9.dist-info → flowfile-0.5.1.dist-info}/METADATA +5 -3
  123. {flowfile-0.3.9.dist-info → flowfile-0.5.1.dist-info}/RECORD +191 -121
  124. {flowfile-0.3.9.dist-info → flowfile-0.5.1.dist-info}/WHEEL +1 -1
  125. {flowfile-0.3.9.dist-info → flowfile-0.5.1.dist-info}/entry_points.txt +1 -0
  126. flowfile_core/__init__.py +3 -0
  127. flowfile_core/configs/flow_logger.py +5 -13
  128. flowfile_core/configs/node_store/__init__.py +30 -0
  129. flowfile_core/configs/node_store/nodes.py +383 -99
  130. flowfile_core/configs/node_store/user_defined_node_registry.py +193 -0
  131. flowfile_core/configs/settings.py +2 -1
  132. flowfile_core/database/connection.py +5 -21
  133. flowfile_core/fileExplorer/funcs.py +239 -121
  134. flowfile_core/flowfile/analytics/analytics_processor.py +1 -0
  135. flowfile_core/flowfile/code_generator/code_generator.py +62 -64
  136. flowfile_core/flowfile/flow_data_engine/create/funcs.py +73 -56
  137. flowfile_core/flowfile/flow_data_engine/flow_data_engine.py +77 -86
  138. flowfile_core/flowfile/flow_data_engine/flow_file_column/interface.py +4 -0
  139. flowfile_core/flowfile/flow_data_engine/flow_file_column/main.py +19 -34
  140. flowfile_core/flowfile/flow_data_engine/flow_file_column/type_registry.py +36 -0
  141. flowfile_core/flowfile/flow_data_engine/fuzzy_matching/prepare_for_fuzzy_match.py +23 -23
  142. flowfile_core/flowfile/flow_data_engine/join/utils.py +1 -1
  143. flowfile_core/flowfile/flow_data_engine/join/verify_integrity.py +9 -4
  144. flowfile_core/flowfile/flow_data_engine/subprocess_operations/subprocess_operations.py +212 -86
  145. flowfile_core/flowfile/flow_data_engine/utils.py +2 -0
  146. flowfile_core/flowfile/flow_graph.py +240 -54
  147. flowfile_core/flowfile/flow_node/flow_node.py +48 -13
  148. flowfile_core/flowfile/flow_node/models.py +2 -1
  149. flowfile_core/flowfile/handler.py +24 -5
  150. flowfile_core/flowfile/manage/compatibility_enhancements.py +404 -41
  151. flowfile_core/flowfile/manage/io_flowfile.py +394 -0
  152. flowfile_core/flowfile/node_designer/__init__.py +47 -0
  153. flowfile_core/flowfile/node_designer/_type_registry.py +197 -0
  154. flowfile_core/flowfile/node_designer/custom_node.py +371 -0
  155. flowfile_core/flowfile/node_designer/ui_components.py +277 -0
  156. flowfile_core/flowfile/schema_callbacks.py +17 -10
  157. flowfile_core/flowfile/setting_generator/settings.py +15 -10
  158. flowfile_core/main.py +5 -1
  159. flowfile_core/routes/routes.py +73 -30
  160. flowfile_core/routes/user_defined_components.py +55 -0
  161. flowfile_core/schemas/cloud_storage_schemas.py +0 -2
  162. flowfile_core/schemas/input_schema.py +228 -65
  163. flowfile_core/schemas/output_model.py +5 -2
  164. flowfile_core/schemas/schemas.py +153 -35
  165. flowfile_core/schemas/transform_schema.py +1083 -412
  166. flowfile_core/schemas/yaml_types.py +103 -0
  167. flowfile_core/types.py +156 -0
  168. flowfile_core/utils/validate_setup.py +3 -1
  169. flowfile_frame/__init__.py +3 -1
  170. flowfile_frame/flow_frame.py +31 -24
  171. flowfile_frame/flow_frame_methods.py +12 -9
  172. flowfile_worker/__init__.py +9 -35
  173. flowfile_worker/create/__init__.py +3 -21
  174. flowfile_worker/create/funcs.py +68 -56
  175. flowfile_worker/create/models.py +130 -62
  176. flowfile_worker/main.py +5 -2
  177. flowfile_worker/routes.py +52 -13
  178. shared/__init__.py +15 -0
  179. shared/storage_config.py +258 -0
  180. tools/migrate/README.md +56 -0
  181. tools/migrate/__init__.py +12 -0
  182. tools/migrate/__main__.py +131 -0
  183. tools/migrate/legacy_schemas.py +621 -0
  184. tools/migrate/migrate.py +598 -0
  185. tools/migrate/tests/__init__.py +0 -0
  186. tools/migrate/tests/conftest.py +23 -0
  187. tools/migrate/tests/test_migrate.py +627 -0
  188. tools/migrate/tests/test_migration_e2e.py +1010 -0
  189. tools/migrate/tests/test_node_migrations.py +813 -0
  190. flowfile/web/static/assets/GraphSolver-17fd26db.css +0 -68
  191. flowfile/web/static/assets/Pivot-f415e85f.css +0 -35
  192. flowfile/web/static/assets/Read-80dc1675.css +0 -197
  193. flowfile/web/static/assets/Read-c3b1929c.js +0 -701
  194. flowfile/web/static/assets/RecordCount-4e95f98e.js +0 -122
  195. flowfile/web/static/assets/Union-89fd73dc.js +0 -146
  196. flowfile/web/static/assets/Unpivot-246e9bbd.css +0 -77
  197. flowfile/web/static/assets/nodeTitle-a16db7c3.js +0 -227
  198. flowfile/web/static/assets/nodeTitle-f4b12bcb.css +0 -134
  199. flowfile_core/flowfile/manage/open_flowfile.py +0 -135
  200. {flowfile-0.3.9.dist-info → flowfile-0.5.1.dist-info/licenses}/LICENSE +0 -0
  201. /flowfile_core/flowfile/manage/manage_flowfile.py → /tools/__init__.py +0 -0
@@ -1,11 +1,10 @@
1
- import { d as defineComponent, r as ref, b as resolveComponent, c as openBlock, e as createElementBlock, f as createVNode, w as withCtx, p as createBaseVNode, g as createTextVNode, i as createCommentVNode, u as unref, a5 as withDirectives, a6 as vModelText, h as createBlock, _ as _export_sfc, n as onMounted, R as nextTick, a7 as Teleport } from "./index-683fc198.js";
2
- import { C as CodeLoader } from "./vue-content-loader.es-ba94b82f.js";
3
- import { C as ColumnSelector } from "./dropDown-0b46dd77.js";
4
- import { u as useNodeStore } from "./vue-codemirror.esm-dc5e3348.js";
5
- import mainEditorRef from "./fullEditor-ec4e4f95.js";
6
- import { G as GenericNodeSettings } from "./genericNodeSettings-def5879b.js";
7
- import { N as NodeButton, a as NodeTitle } from "./nodeTitle-a16db7c3.js";
8
- import "./designer-6c322d8e.js";
1
+ import { d as defineComponent, r as ref, b as resolveComponent, c as openBlock, e as createElementBlock, f as createVNode, w as withCtx, p as createBaseVNode, g as createTextVNode, i as createCommentVNode, u as unref, a8 as withDirectives, a9 as vModelText, h as createBlock, _ as _export_sfc } from "./index-5429bbf8.js";
2
+ import { C as CodeLoader } from "./vue-content-loader.es-2c8e608f.js";
3
+ import { C as ColumnSelector } from "./dropDown-614b998d.js";
4
+ import { u as useNodeStore } from "./vue-codemirror.esm-41b0e0d7.js";
5
+ import mainEditorRef from "./fullEditor-f7971590.js";
6
+ import { G as GenericNodeSettings } from "./genericNodeSettings-4fe5f36b.js";
7
+ import "./designer-9633482a.js";
9
8
  const _hoisted_1 = { key: 0 };
10
9
  const _hoisted_2 = { class: "listbox-wrapper" };
11
10
  const _hoisted_3 = { style: { "border-radius": "20px" } };
@@ -15,8 +14,8 @@ const _hoisted_6 = { class: "selectors-row" };
15
14
  const _hoisted_7 = { key: 0 };
16
15
  const _hoisted_8 = { key: 1 };
17
16
  const _hoisted_9 = { key: 2 };
18
- const _sfc_main$1 = /* @__PURE__ */ defineComponent({
19
- __name: "filter",
17
+ const _sfc_main = /* @__PURE__ */ defineComponent({
18
+ __name: "Filter",
20
19
  setup(__props, { expose: __expose }) {
21
20
  const editorString = ref("");
22
21
  const isLoaded = ref(false);
@@ -88,8 +87,6 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
88
87
  }
89
88
  nodeStore.updateSettings(nodeFilter);
90
89
  }
91
- isLoaded.value = false;
92
- nodeStore.isDrawerOpen = false;
93
90
  };
94
91
  __expose({ loadNodeData, pushNodeData });
95
92
  return (_ctx, _cache) => {
@@ -160,78 +157,8 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
160
157
  };
161
158
  }
162
159
  });
163
- const filter_vue_vue_type_style_index_0_scoped_84dc735d_lang = "";
164
- const filterInput = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["__scopeId", "data-v-84dc735d"]]);
165
- const _sfc_main = /* @__PURE__ */ defineComponent({
166
- __name: "Filter",
167
- props: {
168
- nodeId: {
169
- type: Number,
170
- required: true
171
- }
172
- },
173
- setup(__props) {
174
- const nodeStore = useNodeStore();
175
- const childComp = ref(null);
176
- const props = __props;
177
- const el = ref(null);
178
- const drawer = ref(false);
179
- const closeOnDrawer = () => {
180
- var _a;
181
- (_a = childComp.value) == null ? void 0 : _a.pushNodeData();
182
- drawer.value = false;
183
- nodeStore.isDrawerOpen = false;
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
- onMounted(async () => {
203
- await nextTick();
204
- });
205
- return (_ctx, _cache) => {
206
- return openBlock(), createElementBlock("div", {
207
- ref_key: "el",
208
- ref: el
209
- }, [
210
- createVNode(NodeButton, {
211
- ref: "nodeButton",
212
- "node-id": __props.nodeId,
213
- "image-src": "filter.png",
214
- title: `${__props.nodeId}: Filter`,
215
- onClick: openDrawer
216
- }, null, 8, ["node-id", "title"]),
217
- drawer.value ? (openBlock(), createBlock(Teleport, {
218
- key: 0,
219
- to: "#nodesettings"
220
- }, [
221
- createVNode(NodeTitle, {
222
- title: "Filter data",
223
- intro: "Filter rows in the data"
224
- }),
225
- createVNode(filterInput, {
226
- ref_key: "childComp",
227
- ref: childComp,
228
- "node-id": __props.nodeId
229
- }, null, 8, ["node-id"])
230
- ])) : createCommentVNode("", true)
231
- ], 512);
232
- };
233
- }
234
- });
160
+ const Filter_vue_vue_type_style_index_0_scoped_08e238c3_lang = "";
161
+ const Filter = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-08e238c3"]]);
235
162
  export {
236
- _sfc_main as default
163
+ Filter as default
237
164
  };
@@ -1,7 +1,7 @@
1
- .x-flip[data-v-84dc735d] {
1
+ .x-flip[data-v-08e238c3] {
2
2
  transform: scaleX(-100%);
3
3
  }
4
- .input-field[data-v-84dc735d] {
4
+ .input-field[data-v-08e238c3] {
5
5
  width: 100%; /* Full width to fit container */
6
6
  padding: 6px 10px; /* Reduced padding */
7
7
  font-size: 14px; /* Smaller font size */
@@ -12,7 +12,7 @@
12
12
  outline: none; /* Remove the default focus outline */
13
13
  transition: border-color 0.2s, box-shadow 0.2s; /* Smooth transition for focus */
14
14
  }
15
- .selectors-row[data-v-84dc735d] {
15
+ .selectors-row[data-v-08e238c3] {
16
16
  display: flex;
17
17
  justify-content: space-between;
18
18
  margin-bottom: 20px; /* Spacing between rows */
@@ -1,17 +1,16 @@
1
- import { C as CodeLoader } from "./vue-content-loader.es-ba94b82f.js";
2
- import { u as useNodeStore } from "./vue-codemirror.esm-dc5e3348.js";
3
- import mainEditorRef from "./fullEditor-ec4e4f95.js";
4
- import { C as ColumnSelector } from "./dropDown-0b46dd77.js";
5
- import { d as defineComponent, r as ref, m as watch, c as openBlock, e as createElementBlock, t as toDisplayString, i as createCommentVNode, p as createBaseVNode, f as createVNode, _ as _export_sfc, w as withCtx, u as unref, h as createBlock, n as onMounted, R as nextTick, a7 as Teleport } from "./index-683fc198.js";
6
- import { G as GenericNodeSettings } from "./genericNodeSettings-def5879b.js";
7
- import { N as NodeButton, a as NodeTitle } from "./nodeTitle-a16db7c3.js";
8
- import "./designer-6c322d8e.js";
9
- const _hoisted_1$2 = {
1
+ import { C as CodeLoader } from "./vue-content-loader.es-2c8e608f.js";
2
+ import { u as useNodeStore } from "./vue-codemirror.esm-41b0e0d7.js";
3
+ import mainEditorRef from "./fullEditor-f7971590.js";
4
+ import { C as ColumnSelector } from "./dropDown-614b998d.js";
5
+ import { d as defineComponent, r as ref, m as watch, c as openBlock, e as createElementBlock, t as toDisplayString, i as createCommentVNode, p as createBaseVNode, f as createVNode, _ as _export_sfc, w as withCtx, u as unref, h as createBlock } from "./index-5429bbf8.js";
6
+ import { G as GenericNodeSettings } from "./genericNodeSettings-4fe5f36b.js";
7
+ import "./designer-9633482a.js";
8
+ const _hoisted_1$1 = {
10
9
  key: 0,
11
10
  class: "label"
12
11
  };
13
12
  const _hoisted_2$1 = { class: "select-wrapper" };
14
- const _sfc_main$2 = /* @__PURE__ */ defineComponent({
13
+ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
15
14
  __name: "dropDownGeneric",
16
15
  props: {
17
16
  modelValue: {
@@ -56,7 +55,7 @@ const _sfc_main$2 = /* @__PURE__ */ defineComponent({
56
55
  });
57
56
  return (_ctx, _cache) => {
58
57
  return openBlock(), createElementBlock("div", null, [
59
- __props.title !== "" ? (openBlock(), createElementBlock("p", _hoisted_1$2, toDisplayString(__props.title), 1)) : createCommentVNode("", true),
58
+ __props.title !== "" ? (openBlock(), createElementBlock("p", _hoisted_1$1, toDisplayString(__props.title), 1)) : createCommentVNode("", true),
60
59
  createBaseVNode("div", _hoisted_2$1, [
61
60
  createVNode(ColumnSelector, {
62
61
  modelValue: localSelectedValue.value,
@@ -72,8 +71,8 @@ const _sfc_main$2 = /* @__PURE__ */ defineComponent({
72
71
  }
73
72
  });
74
73
  const dropDownGeneric_vue_vue_type_style_index_0_scoped_f2958f57_lang = "";
75
- const DropDownGeneric = /* @__PURE__ */ _export_sfc(_sfc_main$2, [["__scopeId", "data-v-f2958f57"]]);
76
- const createFormulaInput = (field_name = "", data_type = "String", function_def = "") => {
74
+ const DropDownGeneric = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["__scopeId", "data-v-f2958f57"]]);
75
+ const createFormulaInput = (field_name = "", data_type = "Auto", function_def = "") => {
77
76
  const fieldInput = {
78
77
  name: field_name,
79
78
  data_type
@@ -84,7 +83,7 @@ const createFormulaInput = (field_name = "", data_type = "String", function_def
84
83
  };
85
84
  return functionInput;
86
85
  };
87
- const createFormulaNode = (flowId = -1, nodeId = -1, pos_x = 0, pos_y = 0, field_name = "output_field", data_type = "String", function_def = "") => {
86
+ const createFormulaNode = (flowId = -1, nodeId = -1, pos_x = 0, pos_y = 0, field_name = "output_field", data_type = "Auto", function_def = "") => {
88
87
  const func_info = createFormulaInput(field_name, data_type, function_def);
89
88
  const nodeFunction = {
90
89
  flow_id: flowId,
@@ -96,7 +95,7 @@ const createFormulaNode = (flowId = -1, nodeId = -1, pos_x = 0, pos_y = 0, field
96
95
  };
97
96
  return nodeFunction;
98
97
  };
99
- const _hoisted_1$1 = {
98
+ const _hoisted_1 = {
100
99
  key: 0,
101
100
  class: "listbox-wrapper"
102
101
  };
@@ -105,8 +104,8 @@ const _hoisted_3 = {
105
104
  key: 0,
106
105
  class: "selector-container"
107
106
  };
108
- const _sfc_main$1 = /* @__PURE__ */ defineComponent({
109
- __name: "formula",
107
+ const _sfc_main = /* @__PURE__ */ defineComponent({
108
+ __name: "Formula",
110
109
  setup(__props, { expose: __expose }) {
111
110
  const showEditor = ref(false);
112
111
  const nodeStore = useNodeStore();
@@ -148,7 +147,7 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
148
147
  };
149
148
  __expose({ loadNodeData, pushNodeData });
150
149
  return (_ctx, _cache) => {
151
- return dataLoaded.value && nodeFormula.value ? (openBlock(), createElementBlock("div", _hoisted_1$1, [
150
+ return dataLoaded.value && nodeFormula.value ? (openBlock(), createElementBlock("div", _hoisted_1, [
152
151
  createVNode(GenericNodeSettings, {
153
152
  modelValue: nodeFormula.value,
154
153
  "onUpdate:modelValue": _cache[2] || (_cache[2] = ($event) => nodeFormula.value = $event)
@@ -189,74 +188,8 @@ const _sfc_main$1 = /* @__PURE__ */ defineComponent({
189
188
  };
190
189
  }
191
190
  });
192
- const formula_vue_vue_type_style_index_0_scoped_710d5b5e_lang = "";
193
- const editorInput = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["__scopeId", "data-v-710d5b5e"]]);
194
- const _hoisted_1 = { ref: "el" };
195
- const _sfc_main = /* @__PURE__ */ defineComponent({
196
- __name: "Formula",
197
- props: {
198
- nodeId: {
199
- type: Number,
200
- required: true
201
- }
202
- },
203
- setup(__props) {
204
- const nodeStore = useNodeStore();
205
- const childComp = ref(null);
206
- const drawer = ref(false);
207
- const props = __props;
208
- const closeOnDrawer = () => {
209
- var _a;
210
- (_a = childComp.value) == null ? void 0 : _a.pushNodeData();
211
- drawer.value = false;
212
- nodeStore.isDrawerOpen = false;
213
- };
214
- const openDrawer = async () => {
215
- if (nodeStore.node_id === props.nodeId) {
216
- return;
217
- }
218
- nodeStore.closeDrawer();
219
- drawer.value = true;
220
- const drawerOpen = nodeStore.isDrawerOpen;
221
- nodeStore.isDrawerOpen = true;
222
- await nextTick();
223
- if (nodeStore.node_id === props.nodeId && drawerOpen) {
224
- return;
225
- }
226
- if (childComp.value) {
227
- childComp.value.loadNodeData(props.nodeId);
228
- nodeStore.openDrawer(closeOnDrawer);
229
- }
230
- };
231
- onMounted(async () => {
232
- await nextTick();
233
- });
234
- return (_ctx, _cache) => {
235
- return openBlock(), createElementBlock("div", _hoisted_1, [
236
- createVNode(NodeButton, {
237
- ref: "nodeButton",
238
- "node-id": __props.nodeId,
239
- "image-src": "formula.png",
240
- title: `${__props.nodeId}: Formula`,
241
- onClick: openDrawer
242
- }, null, 8, ["node-id", "title"]),
243
- drawer.value ? (openBlock(), createBlock(Teleport, {
244
- key: 0,
245
- to: "#nodesettings"
246
- }, [
247
- createVNode(NodeTitle, {
248
- title: "Formula",
249
- intro: "Create a new column with a formula"
250
- }),
251
- createVNode(editorInput, {
252
- ref_key: "childComp",
253
- ref: childComp
254
- }, null, 512)
255
- ])) : createCommentVNode("", true)
256
- ], 512);
257
- };
258
- }
259
- });
191
+ const Formula_vue_vue_type_style_index_0_scoped_eac276b3_lang = "";
192
+ const Formula = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-eac276b3"]]);
260
193
  export {
261
- _sfc_main as default
194
+ Formula as default
262
195
  };
@@ -8,18 +8,18 @@
8
8
  width: 100%;
9
9
  position: relative;
10
10
  }
11
- .x-flip[data-v-710d5b5e] {
11
+ .x-flip[data-v-eac276b3] {
12
12
  transform: scaleX(-1);
13
13
  }
14
- .va-navbar__item[data-v-710d5b5e] {
14
+ .va-navbar__item[data-v-eac276b3] {
15
15
  cursor: pointer;
16
16
  margin-bottom: 20px; /* Added margin for spacing */
17
17
  }
18
- .data-type-select[data-v-710d5b5e] {
18
+ .data-type-select[data-v-eac276b3] {
19
19
  margin-top: 10px;
20
20
  margin-bottom: 20px;
21
21
  }
22
- .selector-container[data-v-710d5b5e] {
22
+ .selector-container[data-v-eac276b3] {
23
23
  display: flex; /* Make children align horizontally */
24
24
  align-items: center; /* Center items vertically */
25
25
  gap: 10px; /* Add space between items */
@@ -1,13 +1,13 @@
1
1
 
2
2
  /* Modern styling for an AI app */
3
- .fuzzy-join-container[data-v-99f9b22f] {
3
+ .fuzzy-join-container[data-v-3c562315] {
4
4
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
5
5
  color: #1a202c;
6
6
  max-width: 100%;
7
7
  }
8
8
 
9
9
  /* Tabs Navigation */
10
- .tabs-navigation[data-v-99f9b22f] {
10
+ .tabs-navigation[data-v-3c562315] {
11
11
  display: flex;
12
12
  border-bottom: 1px solid #e2e8f0;
13
13
  margin-bottom: 1.25rem;
@@ -15,7 +15,7 @@
15
15
  border-radius: 8px 8px 0 0;
16
16
  overflow: hidden;
17
17
  }
18
- .tab-button[data-v-99f9b22f] {
18
+ .tab-button[data-v-3c562315] {
19
19
  background: none;
20
20
  border: none;
21
21
  padding: 0.75rem 1.25rem;
@@ -29,21 +29,21 @@
29
29
  flex: 1;
30
30
  text-align: center;
31
31
  }
32
- .tab-button[data-v-99f9b22f]:hover {
32
+ .tab-button[data-v-3c562315]:hover {
33
33
  color: #4a5568;
34
34
  background-color: #edf2f7;
35
35
  }
36
- .tab-button.active[data-v-99f9b22f] {
36
+ .tab-button.active[data-v-3c562315] {
37
37
  border-bottom-color: #3182ce;
38
38
  color: #3182ce;
39
39
  background-color: #ebf8ff;
40
40
  }
41
- .tab-content[data-v-99f9b22f] {
41
+ .tab-content[data-v-3c562315] {
42
42
  min-height: 300px;
43
43
  }
44
44
 
45
45
  /* Card styling */
46
- .settings-card[data-v-99f9b22f] {
46
+ .settings-card[data-v-3c562315] {
47
47
  background-color: #ffffff;
48
48
  border-radius: 8px;
49
49
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
@@ -51,45 +51,45 @@
51
51
  border: 1px solid #edf2f7;
52
52
  overflow: hidden;
53
53
  }
54
- .card-header[data-v-99f9b22f] {
54
+ .card-header[data-v-3c562315] {
55
55
  padding: 1rem 1.25rem;
56
56
  border-bottom: 1px solid #edf2f7;
57
57
  background-color: #fafafa;
58
58
  }
59
- .section-title[data-v-99f9b22f] {
59
+ .section-title[data-v-3c562315] {
60
60
  margin: 0;
61
61
  font-size: 1rem;
62
62
  font-weight: 600;
63
63
  color: #2d3748;
64
64
  }
65
- .card-content[data-v-99f9b22f] {
65
+ .card-content[data-v-3c562315] {
66
66
  padding: 1rem 1.25rem;
67
67
  }
68
68
 
69
69
  /* Join Settings */
70
- .join-settings[data-v-99f9b22f] {
70
+ .join-settings[data-v-3c562315] {
71
71
  display: flex;
72
72
  flex-direction: column;
73
73
  gap: 1.25rem;
74
74
  }
75
- .setting-panel[data-v-99f9b22f] {
75
+ .setting-panel[data-v-3c562315] {
76
76
  background-color: #f8fafc;
77
77
  border-radius: 6px;
78
78
  padding: 1rem;
79
79
  border: 1px solid #edf2f7;
80
80
  transition: all 0.2s ease;
81
81
  }
82
- .setting-panel[data-v-99f9b22f]:hover {
82
+ .setting-panel[data-v-3c562315]:hover {
83
83
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.04);
84
84
  border-color: #e2e8f0;
85
85
  }
86
- .setting-header[data-v-99f9b22f] {
86
+ .setting-header[data-v-3c562315] {
87
87
  display: flex;
88
88
  justify-content: space-between;
89
89
  align-items: center;
90
90
  margin-bottom: 1rem;
91
91
  }
92
- .setting-title[data-v-99f9b22f] {
92
+ .setting-title[data-v-3c562315] {
93
93
  font-size: 0.95rem;
94
94
  font-weight: 600;
95
95
  color: #4a5568;
@@ -97,54 +97,54 @@
97
97
  display: flex;
98
98
  align-items: center;
99
99
  }
100
- .unavailable-field[data-v-99f9b22f] {
100
+ .unavailable-field[data-v-3c562315] {
101
101
  margin-right: 0.5rem;
102
102
  }
103
103
 
104
104
  /* Column Selection Grid */
105
- .columns-grid[data-v-99f9b22f] {
105
+ .columns-grid[data-v-3c562315] {
106
106
  display: grid;
107
107
  grid-template-columns: 1fr 1fr;
108
108
  gap: 1rem;
109
109
  margin-bottom: 1rem;
110
110
  }
111
- .column-field[data-v-99f9b22f] {
111
+ .column-field[data-v-3c562315] {
112
112
  display: flex;
113
113
  flex-direction: column;
114
114
  gap: 0.5rem;
115
115
  }
116
- .column-field label[data-v-99f9b22f] {
116
+ .column-field label[data-v-3c562315] {
117
117
  font-size: 0.875rem;
118
118
  font-weight: 500;
119
119
  color: #4a5568;
120
120
  }
121
121
 
122
122
  /* Settings Grid */
123
- .settings-grid[data-v-99f9b22f] {
123
+ .settings-grid[data-v-3c562315] {
124
124
  display: grid;
125
125
  grid-template-columns: 1fr 1fr;
126
126
  gap: 1rem;
127
127
  }
128
- .threshold-field[data-v-99f9b22f],
129
- .select-field[data-v-99f9b22f] {
128
+ .threshold-field[data-v-3c562315],
129
+ .select-field[data-v-3c562315] {
130
130
  display: flex;
131
131
  flex-direction: column;
132
132
  gap: 0.5rem;
133
133
  }
134
- .threshold-field label[data-v-99f9b22f],
135
- .select-field label[data-v-99f9b22f] {
134
+ .threshold-field label[data-v-3c562315],
135
+ .select-field label[data-v-3c562315] {
136
136
  font-size: 0.875rem;
137
137
  font-weight: 500;
138
138
  color: #4a5568;
139
139
  }
140
140
 
141
141
  /* Range Input */
142
- .range-container[data-v-99f9b22f] {
142
+ .range-container[data-v-3c562315] {
143
143
  display: flex;
144
144
  align-items: center;
145
145
  gap: 1rem;
146
146
  }
147
- .range-slider[data-v-99f9b22f] {
147
+ .range-slider[data-v-3c562315] {
148
148
  flex: 1;
149
149
  -webkit-appearance: none;
150
150
  width: 100%;
@@ -153,7 +153,7 @@
153
153
  background: #e2e8f0;
154
154
  outline: none;
155
155
  }
156
- .range-slider[data-v-99f9b22f]::-webkit-slider-thumb {
156
+ .range-slider[data-v-3c562315]::-webkit-slider-thumb {
157
157
  -webkit-appearance: none;
158
158
  appearance: none;
159
159
  width: 16px;
@@ -164,7 +164,7 @@
164
164
  border: 2px solid white;
165
165
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
166
166
  }
167
- .range-slider[data-v-99f9b22f]::-moz-range-thumb {
167
+ .range-slider[data-v-3c562315]::-moz-range-thumb {
168
168
  width: 16px;
169
169
  height: 16px;
170
170
  border-radius: 50%;
@@ -173,7 +173,7 @@
173
173
  border: 2px solid white;
174
174
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
175
175
  }
176
- .range-value[data-v-99f9b22f] {
176
+ .range-value[data-v-3c562315] {
177
177
  min-width: 3rem;
178
178
  text-align: right;
179
179
  font-size: 0.875rem;
@@ -182,10 +182,10 @@
182
182
  }
183
183
 
184
184
  /* Select Input */
185
- .select-wrapper[data-v-99f9b22f] {
185
+ .select-wrapper[data-v-3c562315] {
186
186
  position: relative;
187
187
  }
188
- .select-input[data-v-99f9b22f] {
188
+ .select-input[data-v-3c562315] {
189
189
  width: 100%;
190
190
  padding: 0.5rem 0.75rem;
191
191
  font-size: 0.875rem;
@@ -197,14 +197,14 @@
197
197
  outline: none;
198
198
  transition: all 0.2s ease;
199
199
  }
200
- .select-input[data-v-99f9b22f]:focus {
200
+ .select-input[data-v-3c562315]:focus {
201
201
  border-color: #3182ce;
202
202
  box-shadow: 0 0 0 2px rgba(49, 130, 206, 0.15);
203
203
  }
204
204
 
205
205
  /* Buttons */
206
- .add-button[data-v-99f9b22f],
207
- .remove-button[data-v-99f9b22f] {
206
+ .add-button[data-v-3c562315],
207
+ .remove-button[data-v-3c562315] {
208
208
  padding: 0.5rem 0.75rem;
209
209
  border: 1px solid #e2e8f0;
210
210
  border-radius: 6px;
@@ -215,7 +215,7 @@
215
215
  cursor: pointer;
216
216
  transition: all 0.2s ease;
217
217
  }
218
- .add-button[data-v-99f9b22f] {
218
+ .add-button[data-v-3c562315] {
219
219
  background-color: #ebf8ff;
220
220
  color: #3182ce;
221
221
  margin-top: 0.5rem;
@@ -224,22 +224,22 @@
224
224
  justify-content: center;
225
225
  align-items: center;
226
226
  }
227
- .add-button[data-v-99f9b22f]:hover {
227
+ .add-button[data-v-3c562315]:hover {
228
228
  background-color: #bee3f8;
229
229
  }
230
- .remove-button[data-v-99f9b22f] {
230
+ .remove-button[data-v-3c562315] {
231
231
  background-color: transparent;
232
232
  border: 1px solid #e2e8f0;
233
233
  }
234
- .remove-button[data-v-99f9b22f]:hover {
234
+ .remove-button[data-v-3c562315]:hover {
235
235
  background-color: #fee2e2;
236
236
  color: #e53e3e;
237
237
  border-color: #fbd5d5;
238
238
  }
239
- .select-section[data-v-99f9b22f] {
239
+ .select-section[data-v-3c562315] {
240
240
  margin-top: 1rem;
241
241
  }
242
- .select-section + .select-section[data-v-99f9b22f] {
242
+ .select-section + .select-section[data-v-3c562315] {
243
243
  margin-top: 2rem;
244
244
  padding-top: 1.5rem;
245
245
  border-top: 1px solid #edf2f7;
@@ -247,8 +247,8 @@
247
247
 
248
248
  /* Responsive adjustments */
249
249
  @media (max-width: 768px) {
250
- .columns-grid[data-v-99f9b22f],
251
- .settings-grid[data-v-99f9b22f] {
250
+ .columns-grid[data-v-3c562315],
251
+ .settings-grid[data-v-3c562315] {
252
252
  grid-template-columns: 1fr;
253
253
  }
254
254
  }