windmill-components 1.75.0 → 1.77.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (156) hide show
  1. package/components/DisplayResult.svelte +1 -1
  2. package/components/Dropdown.svelte +14 -4
  3. package/components/FlowGraphViewer.svelte +1 -1
  4. package/components/FolderUsageInfo.svelte +16 -6
  5. package/components/FolderUsageInfo.svelte.d.ts +2 -0
  6. package/components/PageHeader.svelte +1 -1
  7. package/components/Path.svelte +22 -3
  8. package/components/ScriptBuilder.svelte +122 -122
  9. package/components/SettingSection.svelte +44 -0
  10. package/components/SettingSection.svelte.d.ts +21 -0
  11. package/components/Tooltip.svelte +3 -1
  12. package/components/WhitelistIp.svelte +1 -3
  13. package/components/apps/components/buttons/AppButton.svelte +11 -5
  14. package/components/apps/components/buttons/AppButton.svelte.d.ts +1 -0
  15. package/components/apps/components/buttons/AppForm.svelte +3 -7
  16. package/components/apps/components/buttons/AppFormButton.svelte +2 -6
  17. package/components/apps/components/display/table/AppAggridTable.svelte +4 -1
  18. package/components/apps/components/display/table/AppTable.svelte +4 -1
  19. package/components/apps/components/helpers/HiddenComponent.svelte +3 -0
  20. package/components/apps/components/helpers/HiddenComponent.svelte.d.ts +1 -0
  21. package/components/apps/components/helpers/InputValue.svelte +26 -43
  22. package/components/apps/components/helpers/InputValue.svelte.d.ts +4 -3
  23. package/components/apps/components/helpers/RefreshButton.svelte +2 -3
  24. package/components/apps/components/helpers/RunnableComponent.svelte +61 -34
  25. package/components/apps/components/helpers/RunnableComponent.svelte.d.ts +2 -0
  26. package/components/apps/components/helpers/RunnableWrapper.svelte +2 -0
  27. package/components/apps/components/helpers/RunnableWrapper.svelte.d.ts +1 -0
  28. package/components/apps/components/helpers/eval.d.ts +5 -0
  29. package/components/apps/components/helpers/eval.js +57 -0
  30. package/components/apps/components/layout/AppContainer.svelte +1 -6
  31. package/components/apps/components/layout/AppDrawer.svelte +0 -3
  32. package/components/apps/components/layout/AppSplitpanes.svelte +1 -6
  33. package/components/apps/components/layout/AppTabs.svelte +64 -33
  34. package/components/apps/components/layout/AppTabs.svelte.d.ts +1 -0
  35. package/components/apps/editor/AppEditor.svelte +136 -131
  36. package/components/apps/editor/AppEditorHeader.svelte +43 -35
  37. package/components/apps/editor/AppPreview.svelte +3 -2
  38. package/components/apps/editor/ComponentHeader.svelte +3 -1
  39. package/components/apps/editor/ComponentHeader.svelte.d.ts +1 -0
  40. package/components/apps/editor/GridEditor.svelte +53 -51
  41. package/components/apps/editor/RecomputeAllComponents.svelte +7 -1
  42. package/components/apps/editor/SettingsPanel.svelte +23 -10
  43. package/components/apps/editor/SubGridEditor.svelte +56 -52
  44. package/components/apps/editor/SubGridEditor.svelte.d.ts +3 -4
  45. package/components/apps/editor/appUtils.d.ts +12 -3
  46. package/components/apps/editor/appUtils.js +111 -37
  47. package/components/apps/editor/component/Component.svelte +4 -9
  48. package/components/apps/editor/component/ComponentNavigation.svelte +91 -46
  49. package/components/apps/editor/component/components.d.ts +1 -1
  50. package/components/apps/editor/component/components.js +24 -43
  51. package/components/apps/editor/componentsPanel/componentStaticValues.d.ts +1 -0
  52. package/components/apps/editor/componentsPanel/componentStaticValues.js +1 -0
  53. package/components/apps/editor/contextPanel/ComponentOutput.svelte +77 -0
  54. package/components/apps/editor/contextPanel/ComponentOutput.svelte.d.ts +21 -0
  55. package/components/apps/editor/contextPanel/ComponentOutputViewer.svelte +9 -5
  56. package/components/apps/editor/contextPanel/ContextPanel.svelte +80 -136
  57. package/components/apps/editor/contextPanel/SubGridOutput.svelte +71 -0
  58. package/components/apps/editor/contextPanel/SubGridOutput.svelte.d.ts +19 -0
  59. package/components/apps/editor/contextPanel/components/BackgroundScriptOutput.svelte +38 -0
  60. package/components/apps/editor/contextPanel/components/BackgroundScriptOutput.svelte.d.ts +19 -0
  61. package/components/apps/editor/contextPanel/components/BackgroundScriptsOutput.svelte +10 -0
  62. package/components/apps/editor/contextPanel/components/BackgroundScriptsOutput.svelte.d.ts +16 -0
  63. package/components/apps/editor/contextPanel/components/MinMaxButton.svelte +25 -0
  64. package/components/apps/editor/contextPanel/components/MinMaxButton.svelte.d.ts +16 -0
  65. package/components/apps/editor/contextPanel/components/OutputHeader.svelte +78 -0
  66. package/components/apps/editor/contextPanel/components/OutputHeader.svelte.d.ts +26 -0
  67. package/components/apps/editor/contextPanel/components/TableActionOutput.svelte +19 -0
  68. package/components/apps/editor/contextPanel/components/TableActionOutput.svelte.d.ts +18 -0
  69. package/components/apps/editor/contextPanel/components/TableActionsOutput.svelte +14 -0
  70. package/components/apps/editor/contextPanel/components/TableActionsOutput.svelte.d.ts +18 -0
  71. package/components/apps/editor/inlineScriptsPanel/EmptyInlineScript.svelte +53 -21
  72. package/components/apps/editor/inlineScriptsPanel/InlineScriptEditor.svelte +69 -43
  73. package/components/apps/editor/inlineScriptsPanel/InlineScriptEditorDrawer.svelte +1 -1
  74. package/components/apps/editor/settingsPanel/ArrayStaticInputEditor.svelte.d.ts +2 -2
  75. package/components/apps/editor/settingsPanel/ComponentPanel.svelte +32 -31
  76. package/components/apps/editor/settingsPanel/GridTab.svelte +4 -12
  77. package/components/apps/editor/settingsPanel/Recompute.svelte +1 -0
  78. package/components/apps/editor/settingsPanel/SelectedRunnable.svelte +6 -0
  79. package/components/apps/editor/settingsPanel/TableActions.svelte +2 -1
  80. package/components/apps/editor/settingsPanel/inputEditor/ConnectedInputEditor.svelte +2 -8
  81. package/components/apps/editor/settingsPanel/inputEditor/EvalInputEditor.svelte +2 -2
  82. package/components/apps/editor/settingsPanel/inputEditor/IconSelectInput.svelte +58 -46
  83. package/components/apps/editor/settingsPanel/inputEditor/JsonEditor.svelte +1 -1
  84. package/components/apps/editor/settingsPanel/inputEditor/JsonEditor.svelte.d.ts +2 -0
  85. package/components/apps/rx.d.ts +6 -4
  86. package/components/apps/rx.js +34 -14
  87. package/components/apps/svelte-grid/Grid.svelte +171 -0
  88. package/components/apps/svelte-grid/Grid.svelte.d.ts +47 -0
  89. package/components/apps/svelte-grid/LICENSE +23 -0
  90. package/components/apps/svelte-grid/MoveResize.svelte +328 -0
  91. package/components/apps/svelte-grid/MoveResize.svelte.d.ts +46 -0
  92. package/components/apps/svelte-grid/types.d.ts +25 -0
  93. package/components/apps/svelte-grid/utils/container.d.ts +1 -0
  94. package/components/apps/svelte-grid/utils/container.js +4 -0
  95. package/components/apps/svelte-grid/utils/helper.d.ts +14 -0
  96. package/components/apps/svelte-grid/utils/helper.js +36 -0
  97. package/components/apps/svelte-grid/utils/item.d.ts +14 -0
  98. package/components/apps/svelte-grid/utils/item.js +192 -0
  99. package/components/apps/svelte-grid/utils/matrix.d.ts +6 -0
  100. package/components/apps/svelte-grid/utils/matrix.js +53 -0
  101. package/components/apps/svelte-grid/utils/other.d.ts +3 -0
  102. package/components/apps/svelte-grid/utils/other.js +30 -0
  103. package/components/apps/types.d.ts +10 -7
  104. package/components/apps/utils.d.ts +1 -1
  105. package/components/apps/utils.js +13 -7
  106. package/components/common/CloseButton.svelte +18 -0
  107. package/components/common/CloseButton.svelte.d.ts +27 -0
  108. package/components/common/badge/Badge.svelte +6 -1
  109. package/components/common/badge/Badge.svelte.d.ts +1 -0
  110. package/components/common/drawer/DrawerContent.svelte +2 -6
  111. package/components/common/languageIcons/JavaScript.svelte +11 -0
  112. package/components/common/languageIcons/JavaScript.svelte.d.ts +25 -0
  113. package/components/common/languageIcons/LanguageIcon.svelte +3 -1
  114. package/components/common/languageIcons/LanguageIcon.svelte.d.ts +1 -1
  115. package/components/common/menu/Menu.svelte +1 -1
  116. package/components/common/popup/Popup.svelte +2 -1
  117. package/components/common/popup/Popup.svelte.d.ts +9 -0
  118. package/components/common/table/AppRow.svelte +1 -4
  119. package/components/common/table/FlowRow.svelte +1 -4
  120. package/components/common/table/ScriptRow.svelte +1 -4
  121. package/components/common/tabs/Tab.svelte +1 -0
  122. package/components/common/tabs/Tab.svelte.d.ts +2 -0
  123. package/components/flows/pickers/FlowScriptPicker.svelte.d.ts +1 -1
  124. package/components/graph/FlowGraph.svelte +1 -1
  125. package/components/sidebar/SidebarContent.svelte +2 -2
  126. package/consts.js +1 -1
  127. package/history.js +8 -1
  128. package/package.json +21 -27
  129. package/utils.js +0 -1
  130. package/components/apps/editor/settingsPanel/MoveToOtherGrid.svelte +0 -92
  131. package/components/apps/editor/settingsPanel/MoveToOtherGrid.svelte.d.ts +0 -18
  132. package/components/graph/svelvet/d3/controllers/README.md +0 -3
  133. package/components/graph/svelvet/d3/controllers/d3Old.d.ts +0 -1
  134. package/components/graph/svelvet/d3/controllers/d3Old.js +0 -43
  135. package/components/graph/svelvet/docs/CHANGELOG.md +0 -145
  136. package/components/graph/svelvet/docs/DESIGN_PATTERNS.md +0 -44
  137. package/components/graph/svelvet/docs/DOCUMENTATION.md +0 -5
  138. package/components/graph/svelvet/docs/README.md +0 -34
  139. package/components/graph/svelvet/docs/TODO.md +0 -14
  140. package/components/graph/svelvet/docs/Tutorials.md +0 -25
  141. package/components/graph/svelvet/docs/images/css-background-after.png +0 -0
  142. package/components/graph/svelvet/docs/images/css-background-before.png +0 -0
  143. package/components/graph/svelvet/docs/images/custom-edges-after.png +0 -0
  144. package/components/graph/svelvet/docs/images/custom-edges-before.png +0 -0
  145. package/components/graph/svelvet/docs/images/custom-nodes-after.png +0 -0
  146. package/components/graph/svelvet/docs/images/custom-nodes-before.png +0 -0
  147. package/components/graph/svelvet/docs/images/custom-svelte-components-after.png +0 -0
  148. package/components/graph/svelvet/docs/images/custom-svelte-components-before.png +0 -0
  149. package/components/graph/svelvet/docs/images/html-docs-after.png +0 -0
  150. package/components/graph/svelvet/docs/images/html-docs-before.png +0 -0
  151. package/components/graph/svelvet/docs/images/minimap-after.png +0 -0
  152. package/components/graph/svelvet/docs/images/minimap-before.png +0 -0
  153. package/components/graph/svelvet/docs/images/node-classes-after.png +0 -0
  154. package/components/graph/svelvet/docs/images/node-classes-before.png +0 -0
  155. package/components/graph/svelvet/docs/images/node-create-after.png +0 -0
  156. package/components/graph/svelvet/docs/images/node-create-before.png +0 -0
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "windmill-components",
3
- "version": "1.75.0",
3
+ "version": "1.77.0",
4
4
  "devDependencies": {
5
5
  "@playwright/test": "^1.31.1",
6
6
  "@sveltejs/adapter-static": "^1.0.0",
@@ -14,7 +14,6 @@
14
14
  "@types/vscode": "~1.74.0",
15
15
  "@typescript-eslint/eslint-plugin": "^5.49.0",
16
16
  "@typescript-eslint/parser": "^5.48.0",
17
- "@windmill-components-labs/svelte-grid": "^5.1.6",
18
17
  "@zerodevx/svelte-toast": "^0.8.1",
19
18
  "autoprefixer": "^10.4.13",
20
19
  "cssnano": "^5.1.14",
@@ -160,6 +159,7 @@
160
159
  "./components/ScriptPicker.svelte": "./components/ScriptPicker.svelte",
161
160
  "./components/ScriptSchema.svelte": "./components/ScriptSchema.svelte",
162
161
  "./components/SearchItems.svelte": "./components/SearchItems.svelte",
162
+ "./components/SettingSection.svelte": "./components/SettingSection.svelte",
163
163
  "./components/ShareModal.svelte": "./components/ShareModal.svelte",
164
164
  "./components/SharedBadge.svelte": "./components/SharedBadge.svelte",
165
165
  "./components/SimpleEditor.svelte": "./components/SimpleEditor.svelte",
@@ -210,6 +210,7 @@
210
210
  "./components/apps/components/helpers/ResizeWrapper.svelte": "./components/apps/components/helpers/ResizeWrapper.svelte",
211
211
  "./components/apps/components/helpers/RunnableComponent.svelte": "./components/apps/components/helpers/RunnableComponent.svelte",
212
212
  "./components/apps/components/helpers/RunnableWrapper.svelte": "./components/apps/components/helpers/RunnableWrapper.svelte",
213
+ "./components/apps/components/helpers/eval": "./components/apps/components/helpers/eval.js",
213
214
  "./components/apps/components/helpers": "./components/apps/components/helpers/index.js",
214
215
  "./components/apps/components/icon": "./components/apps/components/icon.js",
215
216
  "./components/apps/components": "./components/apps/components/index.js",
@@ -259,8 +260,16 @@
259
260
  "./components/apps/editor/componentsPanel/componentDefaultProps": "./components/apps/editor/componentsPanel/componentDefaultProps.js",
260
261
  "./components/apps/editor/componentsPanel/componentStaticValues": "./components/apps/editor/componentsPanel/componentStaticValues.js",
261
262
  "./components/apps/editor/componentsPanel/store": "./components/apps/editor/componentsPanel/store.js",
263
+ "./components/apps/editor/contextPanel/ComponentOutput.svelte": "./components/apps/editor/contextPanel/ComponentOutput.svelte",
262
264
  "./components/apps/editor/contextPanel/ComponentOutputViewer.svelte": "./components/apps/editor/contextPanel/ComponentOutputViewer.svelte",
263
265
  "./components/apps/editor/contextPanel/ContextPanel.svelte": "./components/apps/editor/contextPanel/ContextPanel.svelte",
266
+ "./components/apps/editor/contextPanel/SubGridOutput.svelte": "./components/apps/editor/contextPanel/SubGridOutput.svelte",
267
+ "./components/apps/editor/contextPanel/components/BackgroundScriptOutput.svelte": "./components/apps/editor/contextPanel/components/BackgroundScriptOutput.svelte",
268
+ "./components/apps/editor/contextPanel/components/BackgroundScriptsOutput.svelte": "./components/apps/editor/contextPanel/components/BackgroundScriptsOutput.svelte",
269
+ "./components/apps/editor/contextPanel/components/MinMaxButton.svelte": "./components/apps/editor/contextPanel/components/MinMaxButton.svelte",
270
+ "./components/apps/editor/contextPanel/components/OutputHeader.svelte": "./components/apps/editor/contextPanel/components/OutputHeader.svelte",
271
+ "./components/apps/editor/contextPanel/components/TableActionOutput.svelte": "./components/apps/editor/contextPanel/components/TableActionOutput.svelte",
272
+ "./components/apps/editor/contextPanel/components/TableActionsOutput.svelte": "./components/apps/editor/contextPanel/components/TableActionsOutput.svelte",
264
273
  "./components/apps/editor/inlineScriptsPanel/EmptyInlineScript.svelte": "./components/apps/editor/inlineScriptsPanel/EmptyInlineScript.svelte",
265
274
  "./components/apps/editor/inlineScriptsPanel/InlineScriptEditor.svelte": "./components/apps/editor/inlineScriptsPanel/InlineScriptEditor.svelte",
266
275
  "./components/apps/editor/inlineScriptsPanel/InlineScriptEditorDrawer.svelte": "./components/apps/editor/inlineScriptsPanel/InlineScriptEditorDrawer.svelte",
@@ -276,7 +285,6 @@
276
285
  "./components/apps/editor/settingsPanel/GridTab.svelte": "./components/apps/editor/settingsPanel/GridTab.svelte",
277
286
  "./components/apps/editor/settingsPanel/InputsSpecEditor.svelte": "./components/apps/editor/settingsPanel/InputsSpecEditor.svelte",
278
287
  "./components/apps/editor/settingsPanel/InputsSpecsEditor.svelte": "./components/apps/editor/settingsPanel/InputsSpecsEditor.svelte",
279
- "./components/apps/editor/settingsPanel/MoveToOtherGrid.svelte": "./components/apps/editor/settingsPanel/MoveToOtherGrid.svelte",
280
288
  "./components/apps/editor/settingsPanel/PickFlow.svelte": "./components/apps/editor/settingsPanel/PickFlow.svelte",
281
289
  "./components/apps/editor/settingsPanel/PickInlineScript.svelte": "./components/apps/editor/settingsPanel/PickInlineScript.svelte",
282
290
  "./components/apps/editor/settingsPanel/Recompute.svelte": "./components/apps/editor/settingsPanel/Recompute.svelte",
@@ -302,8 +310,17 @@
302
310
  "./components/apps/inputType": "./components/apps/inputType.js",
303
311
  "./components/apps/rx": "./components/apps/rx.js",
304
312
  "./components/apps/store": "./components/apps/store.js",
313
+ "./components/apps/svelte-grid/Grid.svelte": "./components/apps/svelte-grid/Grid.svelte",
314
+ "./components/apps/svelte-grid/LICENSE": "./components/apps/svelte-grid/LICENSE",
315
+ "./components/apps/svelte-grid/MoveResize.svelte": "./components/apps/svelte-grid/MoveResize.svelte",
316
+ "./components/apps/svelte-grid/utils/container": "./components/apps/svelte-grid/utils/container.js",
317
+ "./components/apps/svelte-grid/utils/helper": "./components/apps/svelte-grid/utils/helper.js",
318
+ "./components/apps/svelte-grid/utils/item": "./components/apps/svelte-grid/utils/item.js",
319
+ "./components/apps/svelte-grid/utils/matrix": "./components/apps/svelte-grid/utils/matrix.js",
320
+ "./components/apps/svelte-grid/utils/other": "./components/apps/svelte-grid/utils/other.js",
305
321
  "./components/apps/types": "./components/apps/types.js",
306
322
  "./components/apps/utils": "./components/apps/utils.js",
323
+ "./components/common/CloseButton.svelte": "./components/common/CloseButton.svelte",
307
324
  "./components/common/actionRow/ActionRow.svelte": "./components/common/actionRow/ActionRow.svelte",
308
325
  "./components/common/alert/Alert.svelte": "./components/common/alert/Alert.svelte",
309
326
  "./components/common/alert/model": "./components/common/alert/model.js",
@@ -326,6 +343,7 @@
326
343
  "./components/common/kbd/Kbd.svelte": "./components/common/kbd/Kbd.svelte",
327
344
  "./components/common/languageIcons/Bash.svelte": "./components/common/languageIcons/Bash.svelte",
328
345
  "./components/common/languageIcons/Go.svelte": "./components/common/languageIcons/Go.svelte",
346
+ "./components/common/languageIcons/JavaScript.svelte": "./components/common/languageIcons/JavaScript.svelte",
329
347
  "./components/common/languageIcons/LanguageIcon.svelte": "./components/common/languageIcons/LanguageIcon.svelte",
330
348
  "./components/common/languageIcons/Python.svelte": "./components/common/languageIcons/Python.svelte",
331
349
  "./components/common/languageIcons/TypeScript.svelte": "./components/common/languageIcons/TypeScript.svelte",
@@ -420,31 +438,7 @@
420
438
  "./components/graph/svelvet/container/views/GraphView.svelte": "./components/graph/svelvet/container/views/GraphView.svelte",
421
439
  "./components/graph/svelvet/container/views/Svelvet.svelte": "./components/graph/svelvet/container/views/Svelvet.svelte",
422
440
  "./components/graph/svelvet/customCss/controllers/getCss": "./components/graph/svelvet/customCss/controllers/getCss.js",
423
- "./components/graph/svelvet/d3/controllers/README.md": "./components/graph/svelvet/d3/controllers/README.md",
424
441
  "./components/graph/svelvet/d3/controllers/d3": "./components/graph/svelvet/d3/controllers/d3.js",
425
- "./components/graph/svelvet/d3/controllers/d3Old": "./components/graph/svelvet/d3/controllers/d3Old.js",
426
- "./components/graph/svelvet/docs/CHANGELOG.md": "./components/graph/svelvet/docs/CHANGELOG.md",
427
- "./components/graph/svelvet/docs/DESIGN_PATTERNS.md": "./components/graph/svelvet/docs/DESIGN_PATTERNS.md",
428
- "./components/graph/svelvet/docs/DOCUMENTATION.md": "./components/graph/svelvet/docs/DOCUMENTATION.md",
429
- "./components/graph/svelvet/docs/README.md": "./components/graph/svelvet/docs/README.md",
430
- "./components/graph/svelvet/docs/TODO.md": "./components/graph/svelvet/docs/TODO.md",
431
- "./components/graph/svelvet/docs/Tutorials.md": "./components/graph/svelvet/docs/Tutorials.md",
432
- "./components/graph/svelvet/docs/images/css-background-after.png": "./components/graph/svelvet/docs/images/css-background-after.png",
433
- "./components/graph/svelvet/docs/images/css-background-before.png": "./components/graph/svelvet/docs/images/css-background-before.png",
434
- "./components/graph/svelvet/docs/images/custom-edges-after.png": "./components/graph/svelvet/docs/images/custom-edges-after.png",
435
- "./components/graph/svelvet/docs/images/custom-edges-before.png": "./components/graph/svelvet/docs/images/custom-edges-before.png",
436
- "./components/graph/svelvet/docs/images/custom-nodes-after.png": "./components/graph/svelvet/docs/images/custom-nodes-after.png",
437
- "./components/graph/svelvet/docs/images/custom-nodes-before.png": "./components/graph/svelvet/docs/images/custom-nodes-before.png",
438
- "./components/graph/svelvet/docs/images/custom-svelte-components-after.png": "./components/graph/svelvet/docs/images/custom-svelte-components-after.png",
439
- "./components/graph/svelvet/docs/images/custom-svelte-components-before.png": "./components/graph/svelvet/docs/images/custom-svelte-components-before.png",
440
- "./components/graph/svelvet/docs/images/html-docs-after.png": "./components/graph/svelvet/docs/images/html-docs-after.png",
441
- "./components/graph/svelvet/docs/images/html-docs-before.png": "./components/graph/svelvet/docs/images/html-docs-before.png",
442
- "./components/graph/svelvet/docs/images/minimap-after.png": "./components/graph/svelvet/docs/images/minimap-after.png",
443
- "./components/graph/svelvet/docs/images/minimap-before.png": "./components/graph/svelvet/docs/images/minimap-before.png",
444
- "./components/graph/svelvet/docs/images/node-classes-after.png": "./components/graph/svelvet/docs/images/node-classes-after.png",
445
- "./components/graph/svelvet/docs/images/node-classes-before.png": "./components/graph/svelvet/docs/images/node-classes-before.png",
446
- "./components/graph/svelvet/docs/images/node-create-after.png": "./components/graph/svelvet/docs/images/node-create-after.png",
447
- "./components/graph/svelvet/docs/images/node-create-before.png": "./components/graph/svelvet/docs/images/node-create-before.png",
448
442
  "./components/graph/svelvet/edges/controllers/anchorCbDev": "./components/graph/svelvet/edges/controllers/anchorCbDev.js",
449
443
  "./components/graph/svelvet/edges/controllers/anchorCbUser": "./components/graph/svelvet/edges/controllers/anchorCbUser.js",
450
444
  "./components/graph/svelvet/edges/controllers/util": "./components/graph/svelvet/edges/controllers/util.js",
package/utils.js CHANGED
@@ -248,7 +248,6 @@ export function setQueryWithoutLoad(url, args, bounceTime) {
248
248
  debounced && clearTimeout(debounced);
249
249
  debounced = setTimeout(() => {
250
250
  const nurl = new URL(url.toString());
251
- console.log(url.toString());
252
251
  for (const { key, value } of args) {
253
252
  if (value) {
254
253
  nurl.searchParams.set(key, value);
@@ -1,92 +0,0 @@
1
- <script>import { Button } from '../../../common';
2
- import { dirtyStore } from '../../../common/confirmationModal/dirtyStore';
3
- import { push } from '../../../../history';
4
- import { faCopy } from '@fortawesome/free-solid-svg-icons';
5
- import { getContext } from 'svelte';
6
- import { createNewGridItem, deleteGridItem, findGridItem, getAllSubgridsAndComponentIds, insertNewGridItem } from '../appUtils';
7
- export let component;
8
- export let parent;
9
- let selectedOption;
10
- const { app } = getContext('AppViewerContext');
11
- const { history } = getContext('AppEditorContext');
12
- function listAllSubGrids(app) {
13
- return app.subgrids ? Object.keys(app.subgrids) : [];
14
- }
15
- function findAndDelete(id) {
16
- const node = findGridItem($app, id);
17
- if (!node) {
18
- return;
19
- }
20
- const data = JSON.parse(JSON.stringify(node.data));
21
- const shouldKeepSubGrid = data.numberOfSubgrids ? data.numberOfSubgrids >= 1 : false;
22
- $dirtyStore = true;
23
- deleteGridItem($app, data, parent, shouldKeepSubGrid);
24
- return data;
25
- }
26
- function insertComponentInSubGrid(data, targetId, targetSubGridIndex) {
27
- push(history, $app);
28
- const focusedGrid = {
29
- parentComponentId: targetId,
30
- subGridIndex: targetSubGridIndex
31
- };
32
- insertNewGridItem($app, data, focusedGrid, true);
33
- $app.grid = [...$app.grid];
34
- }
35
- function insertComponentInMainGrid(data) {
36
- const newComponent = createNewGridItem($app.grid, data.id, data);
37
- $app.grid = [...$app.grid, newComponent];
38
- }
39
- function onMove(component) {
40
- push(history, $app);
41
- const data = findAndDelete(component.id);
42
- if (!data) {
43
- return;
44
- }
45
- if (selectedOption !== 'main-grid') {
46
- const [targetId, targetSubGridIndex] = selectedOption.split('-');
47
- insertComponentInSubGrid(data, targetId, parseInt(targetSubGridIndex));
48
- }
49
- else {
50
- insertComponentInMainGrid(data);
51
- }
52
- }
53
- const defaultOption = {
54
- label: 'Main grid',
55
- value: 'main-grid',
56
- disabled: parent === undefined
57
- };
58
- $: [subgrids] = component ? getAllSubgridsAndComponentIds($app, component) : [[], []];
59
- $: availableGrids = listAllSubGrids($app);
60
- $: options = availableGrids
61
- ? [
62
- defaultOption,
63
- ...availableGrids?.map((grid) => ({
64
- label: grid,
65
- value: grid,
66
- disabled: grid === parent || subgrids.includes(grid)
67
- }))
68
- ]
69
- : [defaultOption];
70
- </script>
71
-
72
- {#if component && !options.every((option) => option.disabled)}
73
- <select bind:value={selectedOption} class="w-full">
74
- {#each options as option}
75
- <option value={option.value} disabled={option.disabled}>{option.label}</option>
76
- {/each}
77
- </select>
78
- <Button
79
- size="xs"
80
- color="dark"
81
- startIcon={{ icon: faCopy }}
82
- on:click={() => {
83
- if (component) {
84
- onMove(component)
85
- }
86
- }}
87
- >
88
- Move component: {component.id}
89
- </Button>
90
- {:else}
91
- <p class="text-gray-500 text-sm">No grids available</p>
92
- {/if}
@@ -1,18 +0,0 @@
1
- import { SvelteComponentTyped } from "svelte";
2
- import type { AppComponent } from '../component';
3
- declare const __propDef: {
4
- props: {
5
- component: AppComponent | undefined;
6
- parent: string | undefined;
7
- };
8
- events: {
9
- [evt: string]: CustomEvent<any>;
10
- };
11
- slots: {};
12
- };
13
- export type MoveToOtherGridProps = typeof __propDef.props;
14
- export type MoveToOtherGridEvents = typeof __propDef.events;
15
- export type MoveToOtherGridSlots = typeof __propDef.slots;
16
- export default class MoveToOtherGrid extends SvelteComponentTyped<MoveToOtherGridProps, MoveToOtherGridEvents, MoveToOtherGridSlots> {
17
- }
18
- export {};
@@ -1,3 +0,0 @@
1
- d3 is responsible for zooming and panning.
2
-
3
- The code works but is obviously in a bad state. However, at least it is modularized so it doesn't clutter graphview anymore.
@@ -1 +0,0 @@
1
- export declare function d3ZoomCreator(nodeSelected: any, movementStore: any, backgroundStore: any, canvasId: any, gridSize: any, dotSize: any, d3Scale: any, d3: any): any;
@@ -1,43 +0,0 @@
1
- import { writable, derived, get, readable } from 'svelte/store';
2
- export function d3ZoomCreator(nodeSelected, movementStore, backgroundStore, canvasId, gridSize, dotSize, d3Scale, d3) {
3
- // TODO: Update d3Zoom type (refer to d3Zoom docs)
4
- let d3Zoom = d3
5
- .zoom()
6
- .filter(() => !get(nodeSelected))
7
- .scaleExtent([0.4, 2])
8
- .on('zoom', handleZoom);
9
- return d3Zoom;
10
- // function to handle zoom events - arguments: d3ZoomEvent
11
- function handleZoom(e) {
12
- if (!get(movementStore))
13
- return;
14
- //add a store that contains the current value of the d3-zoom's scale to be used in onMouseMove function
15
- d3Scale.set(e.transform.k);
16
- // should not run d3.select below if backgroundStore is false
17
- if (get(backgroundStore)) {
18
- d3.select(`#background-${canvasId}`)
19
- .attr('x', e.transform.x)
20
- .attr('y', e.transform.y)
21
- .attr('width', gridSize * e.transform.k)
22
- .attr('height', gridSize * e.transform.k)
23
- .selectAll('#dot')
24
- .attr('x', (gridSize * e.transform.k) / 2 - dotSize / 2)
25
- .attr('y', (gridSize * e.transform.k) / 2 - dotSize / 2)
26
- .attr('opacity', Math.min(e.transform.k, 1));
27
- }
28
- // transform 'g' SVG elements (edge, edge text, edge anchor)
29
- d3.select(`.Edges-${canvasId} g`).attr('transform', e.transform);
30
- // transform div elements (nodes)
31
- let transform = d3.zoomTransform(this);
32
- // selects and transforms all node divs from class 'Node' and performs transformation
33
- d3.select(`.Node-${canvasId}`)
34
- .style('transform', 'translate(' +
35
- transform.x +
36
- 'px,' +
37
- transform.y +
38
- 'px) scale(' +
39
- transform.k +
40
- ')')
41
- .style('transform-origin', '0 0');
42
- }
43
- }
@@ -1,145 +0,0 @@
1
- # CHANGELOG
2
-
3
- This article documents the changes from Svelvet5 to Svelvet6. It is for internal use.
4
-
5
- ## custom-nodes
6
-
7
- https://www.svelvet.io/docs/custom-nodes/
8
-
9
- Anchor points no longer display on nodes in isolation. This is because anchor points are no longer tied to the node object.
10
-
11
- <img src="./images/custom-nodes-before.png" width="150" height="150">
12
- <img src="./images/custom-nodes-after.png" width="150" height="150">
13
-
14
- ## custom-edges
15
-
16
- https://www.svelvet.io/docs/custom-edges/
17
-
18
- Edges now use adaptive anchors by default. Previously, source/target anchors were placed on the top/bottom of the node by default. It looks nice in the specific causes when target nodes are located below source nodes, but in the general case there will be intersecting edges.
19
-
20
- <img src="./images/custom-edges-before.png" width="150" height="150">
21
- <img src="./images/custom-edges-after.png" width="150" height="150">
22
-
23
- ## panning and zooming
24
-
25
- https://www.svelvet.io/docs/pan-and-zoom/
26
-
27
- Panning and zooming is functional. Removed option to stop panning, lock nodes due to store pollution. This is simple to add back if it is a community requested feature.
28
-
29
- TODO: need to update this text in docs:
30
-
31
- ```
32
- play around with the flow diagram below! If you wish to stop panning, set the movement prop to false. If you wish to stop node dragging, pass in the locked prop.
33
- ```
34
-
35
- ## usage with typescript
36
-
37
- https://www.svelvet.io/docs/typescript/
38
-
39
- Type names changed from Node, Edge ,to UserNodeType, UserEdgeType. The main reason for this is:
40
-
41
- - The internal state of Svelvet is stored in objects Node, Edge which are different from the specifications passed in by users (hereafter referred to as UserNode, UserEdge). For example, UserNodes have "sourcePosition" and "targetPosition" parameters. However, the internal node project does not have "sourcePosition" and "targetPosition"; instead that functionality has been abstracted to a separate Anchor class. This promotes greater code modularity.
42
-
43
- ## CSS-Background
44
-
45
- https://www.svelvet.io/docs/CSS-Background/
46
-
47
- <img src="./images/css-background-before.png" width="150" height="150">
48
- <img src="./images/css-background-after.png" width="150" height="150">
49
-
50
- No visual changes. Moved background color out of store in order to minimize store pollution. This means that background color will not be serialized using the import-export-store feature. We talk more about this later in import-export-store section.
51
-
52
- ## node-grouping
53
-
54
- https://www.svelvet.io/docs/node-grouping/
55
-
56
- No change in functionality.
57
-
58
- ## snap-to-grid
59
-
60
- https://www.svelvet.io/docs/snap-to-grid/
61
- http://localhost:3000/compatability-8-snap-to-grid/
62
-
63
- No change in functionality
64
-
65
- ## html-docs
66
-
67
- https://www.svelvet.io/docs/snap-to-grid/
68
- http://localhost:3000/compatability-8-snap-to-grid/
69
-
70
- <img src="./images/html-docs-before.png" width="150" height="150">
71
- <img src="./images/html-docs-after.png" width="150" height="150">
72
-
73
- no change in functionality
74
-
75
- ## node-create
76
-
77
- https://www.svelvet.io/docs/Interactive-Nodes/
78
- http://localhost:3000/compatibility-10-node-create/
79
-
80
- <img src="./images/node-create-before.png" width="150" height="150">
81
- <img src="./images/node-create-after.png" width="150" height="150">
82
-
83
- - Previously, the new node inherits from the old node. Now, the new node is created with default parameters. Note that we have functionality to edit nodes.
84
- - edge creation works the same as before (not shown)
85
- - there are now 4 potential anchor points, rather than one source / on target anchor point.
86
-
87
- ## custom-svelte-components
88
-
89
- https://www.svelvet.io/docs/Custom-Svelte/
90
- http://localhost:3000/compatibility-11-custom-svelte-components/
91
-
92
- <img src="./images/custom-svelte-components-before.png" width="150" height="150">
93
- <img src="./images/custom-svelte-components-after.png" width="150" height="150">
94
-
95
- Same functionality as before. The reason why it looks different is because I created my own dummy Svelte component to test.
96
-
97
- ## Minimap
98
-
99
- http://localhost:3000/compatibility-12-minimap/
100
- https://www.svelvet.io/docs/Minimap/
101
-
102
- Same functionality as before. It looks like there is a big with HTML feature (unrelated to minimap)
103
-
104
- <img src="./images/minimap-before.png" width="150" height="150">
105
- <img src="./images/minimap-after.png" width="150" height="150">
106
-
107
- ## Initial zoom and location
108
-
109
- Same functionality as Svelvet5. It appears the center of the canvas is 0,0
110
-
111
- ## node classes
112
-
113
- <img src="./images/node-classes-before.png" width="150" height="150">
114
- <img src="./images/node-classes-after.png" width="150" height="150">
115
-
116
- You need to put !important in the CSS
117
-
118
- ## ImportDiagrams
119
-
120
- https://www.svelvet.io/docs/importDiagrams/
121
- http://localhost:3000/featureImportExport/
122
-
123
- Feature works as expected. Note that previous version of Svelvet did not serialize callbacks (there is no general way to do this since callbacks can involve closures). We do not do serialize callbacks in Svelvet6; this includes anchors which are reset to adaptive upon serialization.
124
-
125
- As before, any canvas-wide parameters (such as nodeCreate, backgroundColor, etc.) will not be serialized.
126
-
127
- This feature is fragile since there is no guarantee that it will work with new features involving nodes and edges. In order to future-proof this feature, it would be best to specify that import/export of diagrams only serializes certain parameters.
128
-
129
- ## Diagram Boundary
130
-
131
- http://localhost:3000/compatibility-15-diagramBoundary/
132
- https://www.svelvet.io/docs/boundary/
133
-
134
- Feature works as expected
135
-
136
- ## Iteractive Editable nodes
137
-
138
- http://localhost:3000/compatibility-16-nodeEdit/
139
- https://www.svelvet.io/docs/editNodes/
140
-
141
- Feature works as expected. NodeEdit is now active by default. This is to reduce store pollution. In addition, node edit chaning width/height of nodes has been removed because this functionality is duplicated by resizableNodes
142
-
143
- ## Deletable nodes
144
-
145
- This feature has been removed to reduce feature bloat. Its functionality is duplicated by Interactive Editable nodes feature.
@@ -1,44 +0,0 @@
1
- # Design Patterns
2
-
3
- Svelvet was originally written as a monolith. This increased development speed but made the code fragile. Teams struggled to implement simple features such as deleting nodes and resizing nodes. One major goal of Svelvet6 was to re-design Svelvet with more robust design patterns. This document serves as an opinionated guide towards how Svelvet should be structured.
4
-
5
- ## Each Svelvet feature should have its own folder
6
-
7
- Svelvet has a lot of features that interact with each other. In order to encourage modularity, each feature should be given its own folder. For example, code related to the "resizableNodes" feature can be found in the folder `$lib/resizableNodes`.
8
-
9
- ## Svelvet should follow an MVC Architecture
10
-
11
- While Svelvet is a frontend libray, it has components that interact in a complex way. As such, code should adhere to an MVC architecture to increase modularity. One useful way to think about MVC is drawing an analogy to frontend/backend/database. The frontend is the "view" of MVC, the backend is the "controller" of MVC, and the database is the "model" of MVC. To that end, within each feature folder there should be four folders: models, views, controllers, types.
12
-
13
- - models: holds code related to the internal state of Svelvet
14
- - controllers: holds code used to interact with the Svelvet models. Ideally, all interaction with Svelvet models/stores should take place through controllers.
15
- - views: holds code used to visualize the Svelvet state. Ideally, views should not modify models directly.
16
- - types: holds types/interfaces for Typescript. This is unrelated to MVC.
17
-
18
- More comments: Explicitly labeling folders as model/view/controller increases verbosity and most projects do not do this. We feel that this increased verbosity is worth the tradeoff of reminding developers they should be following establshed design patterns when coding. If you are considering removing explicit model/view/controller folders, consider that Svelvet is an OSP where developers may have little to no prior coding experience; increased verbosity may be helpful in guiding developers towards established design principles.
19
-
20
- ## Svelvet's internal state should be an object-relational data structure
21
-
22
- Too Long Didn't Read: The main takeaway can be summed up as: make the Svelvet store look more like PostgreSQL and less like mongoDB.
23
-
24
- ### A longer explanation
25
-
26
- The store holds Svelvet's internal state. We urge future developers to structure the store as a relational object rather than an unstructured object. To give an analogy, if Svelvet was a full-stack app with a backend and database, you should use a postgreSQL instead of mongoDB to store the internal state of Svelvet because nodes/edges are inherently relational. We give an example of a bad design pattern and a good design pattern below.
27
-
28
- Suppose you want to implement a "resizableNodes" feature, where users can resize nodes by dragging a node corner. One (bad) way to do this is by could do this by hacking in an extra div on the Node component representing a draggable control point, then hacking in a "resizeNode" method on the Node object so that when the control point is dragged the node is resized. While it may be easier to throw everything on an unstructured Node object, this is bad for modularity. As more and more features get added in, the Node object becomes bloated, difficult to read, and difficult to debug.
29
-
30
- The better way to do this is to create a brand new resizableNodes model. This model should hold `nodeId` (a foreign key to a node object), `positionX` (its x-position), and `positionY` (its y-position). This model should also have a method `setPosition` that sets its x,y position, but also sets the width/height of the associated node defined by `nodeId`. Note the similarity of the process described above to adding extra data to a SQL database; a big advantage of SQL is that it is easy to add new relational data by creating a brand new table and linking with a foreign key.
31
-
32
- By creating new objects/tables whenever adding new features, you make the code more readable, more modular, and more testable.
33
-
34
- ### Foreign keys
35
-
36
- One question you may come up with when adding new tables is how to structure foreign keys. In our resizableNodes example, we placed a foreign key `nodeId` on our ResizableNode object/table. Alternatively, we could have placed a foreign key `ResizableNodeId` on our Node object/table. How do we choose between these two alternatives (or maybe we could even do two foreign keys)?
37
-
38
- You can make the decision on foreign keys based on your component heirarchy. A Node can exist without functionality to resize itself, but a ResizableNode should not exist if its parent Node does not exist. Therefore, you should place a `nodeId` foreign key on ResizableNode.
39
-
40
- This decision has the following advantages:
41
-
42
- - Increased readability: When developers are reading the Node class definition, they are not overwhelmed by all the different Svelvet features. On the other hand, when developers are reading the ResizableNode class definition, they should realize that ResizableNodes are children of Nodes.
43
- - Increased modularity: You can remove a ResizableNode without disturbing core Node functionality.
44
- - Easy deletes: Previous teams struggled with implementing delete functionality. When you think about a SQL database, deleting rows is very simple. You simply delete the row, then specify cascade to delete other rows that reference the primary key of the row you deleted. Keeping a disciplined approach when structuring foreign keys makes the entity hierarchies clear, and makes operations such as delete easy to implement.
@@ -1,5 +0,0 @@
1
- # Documentation
2
-
3
- - Documentation should be written assuming the developer working on Svelvet has coding experience equivalent to six weeks of bootcamp.
4
- - If you write documents in tsDoc format, you can use TypeDoc to generate documentation automatically. For instructions on how to use TypeDoc, see Tutorials.md
5
- - Write READMEs for every feature so that future teams can understand how they work. Put your email down if you want to be a resource for future teams.
@@ -1,34 +0,0 @@
1
- # README
2
-
3
- This README provides suggestions to developers working on Svelvet.
4
-
5
- ## What is Svelvet?
6
-
7
- Svelvet is a frontend library that allows users to programmatically create graph diagrams. Graphs are composed of nodes and edges; each edge connects two nodes. There are two main challenges when working with Svelvet: (1) nodes and edges interact in complex ways, making new features difficult to implement without interfering with old features, and (2) Svelvet has an active userbase, making breaking changes undesirable.
8
-
9
- ## Things to think about as a Svelvet developer
10
-
11
- - Svelvet teams have 3.5 weeks to iterate on the project, less if you consider time spent on marketing/deployment. It is important for code to be readable, otherwise future teams will be unable to understand the codebase within a reasonable timeframe.
12
- - It is important to write documentation that is easy understand. Write comments/documentation assuming that developers have ~6 weeks of prior bootcamp experience.
13
- - Writing non-modular code with zero tests and zero documentation increases technical debt and puts future teams in a bad place. Accumulated technical debt can kill projects.
14
- - Svelvet has an active userbase. When possible, breaking changes should be avoided. However, if a breaking change must occur, it is better that it happen sooner rather than later.
15
-
16
- ## Suggestions
17
-
18
- - Write modular code, separated by feature. For suggestions, see `./DESIGN_PATTERNS.md`
19
-
20
- - Write tests. Svelvet components interact with each other in complex ways, making it difficult to predict whether changes will break Svelvet without tests.
21
-
22
- - Writing tests and documentation is good for your resume. A long list of features by itself makes for poor resume; mentioning testing, documentation, and specific technologies used to implement specific features make for a stronger resume.
23
-
24
- - Don't leave typescript warnings unaddressed. This makes it so much easier to debug.
25
-
26
- ## Where to start
27
-
28
- Here is one way to start understanding the Svelvet codebase
29
-
30
- (1) Read the Node class (`$lib/nodes/models/Node.ts`)
31
- (2) Create a new branch, delete all features except for nodes, containers, and store, then try to get Svelvet to running only rendering nodes to the screen. You can test Svelvet using routes such as `testingplayground` at `http://localhost:3000/testingplayground`.
32
- (3) Try to refactor Node.ts. You may notice that Node.ts has 16 fields, when really only six of them are important (id, canvasId, positionX, positionY, widthX, widthY). Create a new table `NodeAttributes` that links to Node via foreign key, move all attributes (bgColor, textColor, etc) to this new table and get Node rendering again.
33
- (4) After understanding how Node works, add back the "edges" folder. Try to get Svelvet working rendering only nodes and edges to the screen.
34
- (5) Node / Edge / Anchor form the core tables of Svelvet. All other feature build on top of these core tables.
@@ -1,14 +0,0 @@
1
- ## custom node functionality should be refactored into its own table.''
2
-
3
- ## tay10alan60@gmail.com - minimap, d3, node deletion, interactiveNodes
4
-
5
- ## dillan - customSvelete components, deletable nodes, node classes
6
-
7
- ## Minimap 75 boundless, 200 bounded
8
-
9
- ## New team:
10
-
11
- - split up the website and the svelvet npm package
12
- - continue store refactoring
13
- - refactor store dispatch into flux architecture
14
- - testing - 1 full iteration
@@ -1,25 +0,0 @@
1
- # Tutorials
2
-
3
- This file contains instructions on how to do useful things such as generating developer documentation, publishing to npm, etc.
4
-
5
- ## TypeDoc
6
-
7
- You may notice TSDoc comments throughout our code. These TSDoc comments can be converted into documentation using TypeDoc:
8
-
9
- ```
10
- npx typedoc --entryPointStrategy expand src/lib
11
- ```
12
-
13
- This command will create documentation in root folder `./docs`.
14
-
15
- ## Publishing to npm
16
-
17
- - create an account on npm.js. You can skip this step if you already have an account
18
- - log in with `$ npm login`
19
- - Within the `src/lib` directory, type `npm version patch` to increment version number. Or if you want a new name, you can modify `src/lib/package.json` directly
20
- - In the base directory, type `npm run package`. This will use svelte-kit's package feature to create an npm package in `./package`.
21
- - Within the `./package` directory, type `npm publish` to publish to npm. Note that you cannot "overwrite" previous publishes, you must increment the version number
22
-
23
- ## Testing npm package
24
-
25
- - install locally with `npm install svelvet-lime@latest -f`, where svelvet-lime is replaced with whatever you named your package. Note that if you have a previously installed version of svelvet, you must force a re-install otherwise you will be using an outdated npm package.