windmill-components 1.82.4 → 1.82.6

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 (169) hide show
  1. package/common.d.ts +2 -2
  2. package/components/ArgInput.svelte +72 -52
  3. package/components/ArgInput.svelte.d.ts +3 -1
  4. package/components/DisplayResult.svelte +17 -17
  5. package/components/Editor.svelte +3 -0
  6. package/components/Editor.svelte.d.ts +1 -0
  7. package/components/FieldHeader.svelte +1 -0
  8. package/components/FieldHeader.svelte.d.ts +4 -0
  9. package/components/FlowBuilder.svelte +0 -6
  10. package/components/FlowStatusViewer.svelte +4 -7
  11. package/components/FlowStatusViewer.svelte.d.ts +0 -1
  12. package/components/FlowViewer.svelte +1 -0
  13. package/components/InputTransformForm.svelte +1 -0
  14. package/components/LightweightArgInput.svelte +14 -1
  15. package/components/LightweightArgInput.svelte.d.ts +3 -1
  16. package/components/Multiselect.svelte.d.ts +2 -2
  17. package/components/SimpleEditor.svelte +1 -0
  18. package/components/SimpleEditor.svelte.d.ts +1 -0
  19. package/components/TemplateEditor.svelte +1 -0
  20. package/components/Toggle.svelte +1 -1
  21. package/components/Toggle.svelte.d.ts +1 -0
  22. package/components/apps/components/buttons/AppButton.svelte +17 -3
  23. package/components/apps/components/buttons/AppForm.svelte +10 -2
  24. package/components/apps/components/buttons/AppFormButton.svelte +82 -58
  25. package/components/apps/components/display/AppDisplayComponent.svelte +17 -23
  26. package/components/apps/components/display/AppHtml.svelte +1 -7
  27. package/components/apps/components/display/AppHtml.svelte.d.ts +0 -2
  28. package/components/apps/components/display/AppMap.svelte +1 -1
  29. package/components/apps/components/display/AppPdf.svelte +1 -1
  30. package/components/apps/components/display/PlotlyHtml.svelte +3 -20
  31. package/components/apps/components/display/PlotlyHtml.svelte.d.ts +0 -2
  32. package/components/apps/components/display/table/AppAggridTable.svelte +1 -1
  33. package/components/apps/components/display/table/AppTable.svelte +49 -75
  34. package/components/apps/components/display/table/AppTable.svelte.d.ts +1 -1
  35. package/components/apps/components/display/table/AppTableFooter.svelte +1 -2
  36. package/components/apps/components/display/table/AppTableFooter.svelte.d.ts +0 -1
  37. package/components/apps/components/display/table/tableOptions.js +1 -1
  38. package/components/apps/components/helpers/DebouncedInput.svelte +0 -1
  39. package/components/apps/components/helpers/DebouncedInput.svelte.d.ts +0 -2
  40. package/components/apps/components/helpers/HiddenComponent.svelte +2 -3
  41. package/components/apps/components/helpers/HiddenComponent.svelte.d.ts +1 -2
  42. package/components/apps/components/helpers/InputValue.svelte +3 -3
  43. package/components/apps/components/helpers/RefreshButton.svelte +10 -3
  44. package/components/apps/components/helpers/RefreshButton.svelte.d.ts +0 -1
  45. package/components/apps/components/helpers/RunnableComponent.svelte +15 -19
  46. package/components/apps/components/helpers/RunnableComponent.svelte.d.ts +1 -2
  47. package/components/apps/components/helpers/RunnableWrapper.svelte +1 -3
  48. package/components/apps/components/helpers/RunnableWrapper.svelte.d.ts +0 -1
  49. package/components/apps/components/helpers/eval.d.ts +2 -4
  50. package/components/apps/components/helpers/eval.js +4 -6
  51. package/components/apps/components/inputs/AppCheckbox.svelte +4 -0
  52. package/components/apps/components/inputs/AppDateInput.svelte +2 -2
  53. package/components/apps/components/inputs/AppMultiSelect.svelte +5 -13
  54. package/components/apps/components/inputs/AppMultiSelect.svelte.d.ts +2 -0
  55. package/components/apps/components/inputs/AppNumberInput.svelte +3 -3
  56. package/components/apps/components/inputs/AppSelect.svelte +4 -11
  57. package/components/apps/components/inputs/AppSelect.svelte.d.ts +2 -0
  58. package/components/apps/components/inputs/AppSliderInputs.svelte +1 -1
  59. package/components/apps/components/inputs/AppTextInput.svelte +43 -53
  60. package/components/apps/components/inputs/AppTextInput.svelte.d.ts +1 -1
  61. package/components/apps/components/inputs/currency/AppCurrencyInput.svelte +1 -1
  62. package/components/apps/components/layout/AppContainer.svelte +2 -2
  63. package/components/apps/components/layout/AppDrawer.svelte +2 -1
  64. package/components/apps/components/layout/AppSplitpanes.svelte +3 -3
  65. package/components/apps/components/layout/AppTabs.svelte +1 -1
  66. package/components/apps/editor/AppEditor.svelte +21 -49
  67. package/components/apps/editor/AppEditorHeader.svelte +0 -5
  68. package/components/apps/editor/AppPreview.svelte +7 -18
  69. package/components/apps/editor/ComponentHeader.svelte +0 -1
  70. package/components/apps/editor/ComponentHeader.svelte.d.ts +1 -1
  71. package/components/apps/editor/GridEditor.svelte +12 -22
  72. package/components/apps/editor/GridViewer.svelte +2 -2
  73. package/components/apps/editor/GridViewer.svelte.d.ts +1 -1
  74. package/components/apps/editor/RecomputeAllComponents.svelte +7 -5
  75. package/components/apps/editor/SettingsPanel.svelte +4 -4
  76. package/components/apps/editor/SubGridEditor.svelte +12 -13
  77. package/components/apps/editor/appUtils.d.ts +0 -1
  78. package/components/apps/editor/appUtils.js +0 -19
  79. package/components/apps/editor/component/Component.svelte +8 -19
  80. package/components/apps/editor/component/Component.svelte.d.ts +1 -1
  81. package/components/apps/editor/component/ComponentNavigation.svelte +47 -57
  82. package/components/apps/editor/component/README.md +0 -4
  83. package/components/apps/editor/component/components.d.ts +28 -45
  84. package/components/apps/editor/component/components.js +27 -41
  85. package/components/apps/editor/component/sets.js +1 -2
  86. package/components/apps/editor/componentsPanel/ComponentList.svelte +1 -1
  87. package/components/apps/editor/componentsPanel/CssProperty.svelte +48 -62
  88. package/components/apps/editor/componentsPanel/CssProperty.svelte.d.ts +2 -3
  89. package/components/apps/editor/componentsPanel/CssSettings.svelte +0 -1
  90. package/components/apps/editor/componentsPanel/store.js +4 -4
  91. package/components/apps/editor/contextPanel/ComponentOutput.svelte +26 -2
  92. package/components/apps/editor/contextPanel/ComponentOutput.svelte.d.ts +1 -0
  93. package/components/apps/editor/contextPanel/ComponentOutputViewer.svelte +6 -8
  94. package/components/apps/editor/contextPanel/ContextPanel.svelte +14 -7
  95. package/components/apps/editor/contextPanel/components/BackgroundScriptOutput.svelte +25 -2
  96. package/components/apps/editor/contextPanel/components/MinMaxButton.svelte +25 -0
  97. package/components/apps/editor/contextPanel/components/MinMaxButton.svelte.d.ts +16 -0
  98. package/components/apps/editor/contextPanel/components/OutputHeader.svelte +40 -29
  99. package/components/apps/editor/contextPanel/components/OutputHeader.svelte.d.ts +2 -1
  100. package/components/apps/editor/inlineScriptsPanel/EmptyInlineScript.svelte +7 -2
  101. package/components/apps/editor/inlineScriptsPanel/EmptyInlineScript.svelte.d.ts +1 -1
  102. package/components/apps/editor/inlineScriptsPanel/InlineScriptEditor.svelte +11 -10
  103. package/components/apps/editor/inlineScriptsPanel/InlineScriptEditorPanel.svelte +3 -4
  104. package/components/apps/editor/inlineScriptsPanel/InlineScriptEditorPanel.svelte.d.ts +0 -1
  105. package/components/apps/editor/inlineScriptsPanel/InlineScriptsPanel.svelte +1 -0
  106. package/components/apps/editor/inlineScriptsPanel/InlineScriptsPanelList.svelte +2 -2
  107. package/components/apps/editor/inlineScriptsPanel/InlineScriptsPanelWithTable.svelte +0 -2
  108. package/components/apps/editor/settingsPanel/ArrayStaticInputEditor.svelte +19 -22
  109. package/components/apps/editor/settingsPanel/ComponentPanel.svelte +13 -42
  110. package/components/apps/editor/settingsPanel/GridTab.svelte +2 -1
  111. package/components/apps/editor/settingsPanel/InputsSpecEditor.svelte +1 -2
  112. package/components/apps/editor/settingsPanel/InputsSpecEditor.svelte.d.ts +0 -4
  113. package/components/apps/editor/settingsPanel/InputsSpecsEditor.svelte +0 -1
  114. package/components/apps/editor/settingsPanel/SelectedRunnable.svelte +2 -1
  115. package/components/apps/editor/settingsPanel/TableActions.svelte +3 -3
  116. package/components/apps/editor/settingsPanel/inputEditor/ColorInput.svelte +12 -12
  117. package/components/apps/editor/settingsPanel/inputEditor/ColorInput.svelte.d.ts +2 -3
  118. package/components/apps/editor/settingsPanel/inputEditor/EvalInputEditor.svelte +1 -5
  119. package/components/apps/editor/settingsPanel/inputEditor/IconSelectInput.svelte +3 -3
  120. package/components/apps/editor/settingsPanel/inputEditor/JsonEditor.svelte +2 -3
  121. package/components/apps/editor/settingsPanel/inputEditor/JsonEditor.svelte.d.ts +1 -4
  122. package/components/apps/editor/settingsPanel/inputEditor/StaticInputEditor.svelte +3 -3
  123. package/components/apps/editor/settingsPanel/triggerLists/ComponentTriggerList.svelte +1 -1
  124. package/components/apps/inputType.d.ts +2 -2
  125. package/components/apps/rx.d.ts +2 -2
  126. package/components/apps/svelte-grid/Grid.svelte +34 -50
  127. package/components/apps/svelte-grid/Grid.svelte.d.ts +9 -14
  128. package/components/apps/svelte-grid/MoveResize.svelte +55 -76
  129. package/components/apps/svelte-grid/MoveResize.svelte.d.ts +9 -15
  130. package/components/apps/svelte-grid/utils/helper.d.ts +1 -0
  131. package/components/apps/svelte-grid/utils/helper.js +3 -0
  132. package/components/apps/types.d.ts +5 -9
  133. package/components/apps/utils.d.ts +0 -2
  134. package/components/apps/utils.js +1 -33
  135. package/components/common/button/ButtonPopup.svelte +2 -5
  136. package/components/common/button/ButtonPopup.svelte.d.ts +1 -5
  137. package/components/common/button/ButtonPopupItem.svelte +1 -2
  138. package/components/common/button/ButtonPopupItem.svelte.d.ts +0 -1
  139. package/components/common/index.d.ts +0 -1
  140. package/components/common/index.js +0 -1
  141. package/components/common/kbd/Kbd.svelte +1 -4
  142. package/components/common/kbd/Kbd.svelte.d.ts +14 -6
  143. package/components/common/menu/Menu.svelte +2 -8
  144. package/components/common/menu/Menu.svelte.d.ts +1 -4
  145. package/components/flows/map/MapItem.svelte +3 -3
  146. package/components/propertyPicker/ObjectViewer.svelte +3 -0
  147. package/components/scriptEditor/LogPanel.svelte +3 -3
  148. package/infer.js +1 -6
  149. package/package.json +2 -11
  150. package/utils.d.ts +0 -1
  151. package/utils.js +0 -3
  152. package/components/apps/editor/componentsPanel/QuickStyleMenu.svelte +0 -170
  153. package/components/apps/editor/componentsPanel/QuickStyleMenu.svelte.d.ts +0 -18
  154. package/components/apps/editor/componentsPanel/QuickStyleProperty.svelte +0 -130
  155. package/components/apps/editor/componentsPanel/QuickStyleProperty.svelte.d.ts +0 -21
  156. package/components/apps/editor/componentsPanel/quickStyleProperties.d.ts +0 -535
  157. package/components/apps/editor/componentsPanel/quickStyleProperties.js +0 -598
  158. package/components/apps/editor/settingsPanel/StylePanel.svelte +0 -61
  159. package/components/apps/editor/settingsPanel/StylePanel.svelte.d.ts +0 -17
  160. package/components/apps/editor/settingsPanel/secondaryMenu/SecondaryMenu.svelte +0 -47
  161. package/components/apps/editor/settingsPanel/secondaryMenu/SecondaryMenu.svelte.d.ts +0 -14
  162. package/components/apps/editor/settingsPanel/secondaryMenu/index.d.ts +0 -2
  163. package/components/apps/editor/settingsPanel/secondaryMenu/index.js +0 -2
  164. package/components/apps/editor/settingsPanel/secondaryMenu/menuStore.d.ts +0 -12
  165. package/components/apps/editor/settingsPanel/secondaryMenu/menuStore.js +0 -10
  166. package/components/common/clearableInput/ClearableInput.svelte +0 -56
  167. package/components/common/clearableInput/ClearableInput.svelte.d.ts +0 -28
  168. package/components/common/modal/AlwaysMountedModal.svelte +0 -109
  169. package/components/common/modal/AlwaysMountedModal.svelte.d.ts +0 -22
@@ -1,47 +0,0 @@
1
- <script>import { fly } from 'svelte/transition';
2
- import { faChevronLeft } from '@fortawesome/free-solid-svg-icons';
3
- import { Badge, Button } from '../../../../common';
4
- import { secondaryMenu, SECONDARY_MENU_ID } from './';
5
- import { getContext } from 'svelte';
6
- const { selectedComponent } = getContext('AppViewerContext');
7
- let width;
8
- let lastSelected = $selectedComponent;
9
- $: if (lastSelected !== $selectedComponent) {
10
- secondaryMenu.close();
11
- lastSelected = $selectedComponent;
12
- }
13
- </script>
14
-
15
- <div
16
- bind:clientWidth={width}
17
- class="absolute z-50 inset-0 overflow-hidden"
18
- class:pointer-events-none={!$secondaryMenu.isOpen}
19
- >
20
- {#if $secondaryMenu.isOpen && $secondaryMenu.component}
21
- <div
22
- transition:fly|local={{ duration: 300, x: width, y: 0, opacity: 1 }}
23
- id={SECONDARY_MENU_ID}
24
- class="flex flex-col w-full h-full bg-white"
25
- >
26
- <div class="flex justify-between items-center bg-white gap-1 p-3">
27
- <Button
28
- color="light"
29
- size="xs"
30
- variant="border"
31
- startIcon={{ icon: faChevronLeft }}
32
- on:click={secondaryMenu.close}
33
- >
34
- Back
35
- </Button>
36
- <Badge color="blue">{$selectedComponent}</Badge>
37
- </div>
38
- <div class="relative h-full overflow-y-auto px-3 pb-3">
39
- {#if typeof $secondaryMenu.component === 'string'}
40
- {@html $secondaryMenu.component}
41
- {:else}
42
- <svelte:component this={$secondaryMenu.component} {...$secondaryMenu.props} />
43
- {/if}
44
- </div>
45
- </div>
46
- {/if}
47
- </div>
@@ -1,14 +0,0 @@
1
- import { SvelteComponentTyped } from "svelte";
2
- declare const __propDef: {
3
- props: Record<string, never>;
4
- events: {
5
- [evt: string]: CustomEvent<any>;
6
- };
7
- slots: {};
8
- };
9
- export type SecondaryMenuProps = typeof __propDef.props;
10
- export type SecondaryMenuEvents = typeof __propDef.events;
11
- export type SecondaryMenuSlots = typeof __propDef.slots;
12
- export default class SecondaryMenu extends SvelteComponentTyped<SecondaryMenuProps, SecondaryMenuEvents, SecondaryMenuSlots> {
13
- }
14
- export {};
@@ -1,2 +0,0 @@
1
- export { default as SecondaryMenu } from './SecondaryMenu.svelte';
2
- export * from './menuStore';
@@ -1,2 +0,0 @@
1
- export { default as SecondaryMenu } from './SecondaryMenu.svelte';
2
- export * from './menuStore';
@@ -1,12 +0,0 @@
1
- import type { SvelteComponent } from 'svelte';
2
- export declare const SECONDARY_MENU_ID: "app-secondary-menu";
3
- export interface SecondaryMenuStore {
4
- isOpen: boolean;
5
- component?: typeof SvelteComponent | string;
6
- props: Record<string, any>;
7
- }
8
- export declare const secondaryMenu: {
9
- readonly subscribe: (this: void, run: import("svelte/store").Subscriber<SecondaryMenuStore>, invalidate?: ((value?: SecondaryMenuStore | undefined) => void) | undefined) => import("svelte/store").Unsubscriber;
10
- readonly open: (component: SecondaryMenuStore['component'], props?: SecondaryMenuStore['props']) => void;
11
- readonly close: () => void;
12
- };
@@ -1,10 +0,0 @@
1
- import { writable } from 'svelte/store';
2
- export const SECONDARY_MENU_ID = 'app-secondary-menu';
3
- const store = writable({ isOpen: false, component: undefined, props: {} });
4
- export const secondaryMenu = {
5
- subscribe: store.subscribe,
6
- open: (component, props = {}) => {
7
- store.set({ isOpen: true, component, props });
8
- },
9
- close: () => store.set({ isOpen: false, component: undefined, props: {} })
10
- };
@@ -1,56 +0,0 @@
1
- <script>import { createEventDispatcher } from 'svelte';
2
- import { fade } from 'svelte/transition';
3
- import { X } from 'lucide-svelte';
4
- export let value = '';
5
- export let placeholder = '';
6
- export let type = 'text';
7
- export let inputClass = '';
8
- export let wrapperClass = '';
9
- export let buttonClass = '';
10
- const dispatch = createEventDispatcher();
11
- $: isNumeric = ['number', 'range'].includes(type);
12
- $: dispatch('change', value);
13
- function handleInput(e) {
14
- value = isNumeric ? +e.target.value : e.target.value;
15
- }
16
- function clear() {
17
- value = '';
18
- }
19
- </script>
20
-
21
- <div class="relative grow {wrapperClass}">
22
- {#if type === 'textarea'}
23
- <textarea
24
- {value}
25
- {placeholder}
26
- rows="1"
27
- class="resize-y duration-200 {inputClass}"
28
- {...$$restProps}
29
- on:input={handleInput}
30
- on:focus
31
- on:blur
32
- />
33
- {:else}
34
- <input
35
- {type}
36
- {value}
37
- {placeholder}
38
- class="duration-200 {(type === 'number' && value ? '!pr-[26px] ' : '') + inputClass}"
39
- {...$$restProps}
40
- on:input={handleInput}
41
- on:focus
42
- on:blur
43
- />
44
- {/if}
45
- {#if value}
46
- <button
47
- transition:fade|local={{ duration: 100 }}
48
- class="absolute z-10 top-1.5 right-1 rounded-full p-1 bg-white/60 duration-200 hover:bg-gray-200 {buttonClass}"
49
- aria-label="Clear"
50
- on:click|preventDefault|stopPropagation={clear}
51
- >
52
- <X size={14} />
53
- </button>
54
- {/if}
55
- <slot />
56
- </div>
@@ -1,28 +0,0 @@
1
- import { SvelteComponentTyped } from "svelte";
2
- declare const __propDef: {
3
- props: {
4
- [x: string]: any;
5
- value?: any;
6
- placeholder?: string | undefined;
7
- type?: "number" | "text" | "textarea" | undefined;
8
- inputClass?: string | undefined;
9
- wrapperClass?: string | undefined;
10
- buttonClass?: string | undefined;
11
- };
12
- events: {
13
- focus: FocusEvent;
14
- blur: FocusEvent;
15
- change: CustomEvent<any>;
16
- } & {
17
- [evt: string]: CustomEvent<any>;
18
- };
19
- slots: {
20
- default: {};
21
- };
22
- };
23
- export type ClearableInputProps = typeof __propDef.props;
24
- export type ClearableInputEvents = typeof __propDef.events;
25
- export type ClearableInputSlots = typeof __propDef.slots;
26
- export default class ClearableInput extends SvelteComponentTyped<ClearableInputProps, ClearableInputEvents, ClearableInputSlots> {
27
- }
28
- export {};
@@ -1,109 +0,0 @@
1
- <script context="module">let onTop;
2
- const modals = {};
3
- export function getModal(id = '') {
4
- return modals[id];
5
- }
6
- </script>
7
-
8
- <script>import { onDestroy } from 'svelte';
9
- import { twMerge } from 'tailwind-merge';
10
- import { Badge } from '..';
11
- import Button from '../button/Button.svelte';
12
- let topDiv;
13
- let visible = false;
14
- let prevOnTop;
15
- export let title;
16
- export let style = '';
17
- export let id = '';
18
- function onKeyDown(event) {
19
- if (onTop == topDiv) {
20
- switch (event.key) {
21
- case 'Enter':
22
- event.stopPropagation();
23
- event.preventDefault();
24
- break;
25
- case 'Escape':
26
- event.stopPropagation();
27
- event.preventDefault();
28
- close();
29
- break;
30
- }
31
- }
32
- }
33
- function open() {
34
- if (visible) {
35
- return;
36
- }
37
- prevOnTop = onTop;
38
- onTop = topDiv;
39
- window.addEventListener('keydown', onKeyDown);
40
- document.body.style.overflow = 'hidden';
41
- visible = true;
42
- document.body.appendChild(topDiv);
43
- }
44
- function close() {
45
- if (!visible) {
46
- return;
47
- }
48
- window.removeEventListener('keydown', onKeyDown);
49
- onTop = prevOnTop;
50
- if (onTop == null) {
51
- document.body.style.overflow = '';
52
- }
53
- visible = false;
54
- }
55
- modals[id] = { open, close };
56
- onDestroy(() => {
57
- delete modals[id];
58
- window.removeEventListener('keydown', onKeyDown);
59
- });
60
- </script>
61
-
62
- <!-- svelte-ignore a11y-click-events-have-key-events -->
63
- <div id="topModal" class:visible bind:this={topDiv} on:click={() => close()}>
64
- <!-- svelte-ignore a11y-click-events-have-key-events -->
65
- <div class="relative bg-white p-4 rounded-md" on:click|stopPropagation={() => {}}>
66
- <div class={twMerge('max-w-screen-lg max-h-screen-80 overflow-auto', $$props.class)} {style}>
67
- <div class="flex">
68
- <div class="ml-4 text-left flex-1">
69
- <h3 class="text-lg font-medium text-gray-900">
70
- {title}
71
- </h3>
72
- <div class="mt-2 text-sm text-gray-500">
73
- <slot />
74
- </div>
75
- </div>
76
- </div>
77
- <div class="flex items-center space-x-2 flex-row-reverse space-x-reverse mt-4">
78
- <Button
79
- on:click={() => {
80
- close()
81
- }}
82
- color="light"
83
- size="sm"
84
- >
85
- <span class="gap-2">Cancel <Badge color="dark-gray">Escape</Badge></span>
86
- </Button>
87
- </div>
88
- </div>
89
- </div>
90
- </div>
91
-
92
- <style>
93
- #topModal {
94
- visibility: hidden;
95
- z-index: 9999;
96
- position: fixed;
97
- top: 0;
98
- left: 0;
99
- right: 0;
100
- bottom: 0;
101
- background: #4448;
102
- display: flex;
103
- align-items: center;
104
- justify-content: center;
105
- }
106
-
107
- .visible {
108
- visibility: visible !important;
109
- }</style>
@@ -1,22 +0,0 @@
1
- import { SvelteComponentTyped } from "svelte";
2
- export declare function getModal(id?: string): any;
3
- declare const __propDef: {
4
- props: {
5
- [x: string]: any;
6
- title: string;
7
- style?: string | undefined;
8
- id?: string | undefined;
9
- };
10
- events: {
11
- [evt: string]: CustomEvent<any>;
12
- };
13
- slots: {
14
- default: {};
15
- };
16
- };
17
- export type AlwaysMountedModalProps = typeof __propDef.props;
18
- export type AlwaysMountedModalEvents = typeof __propDef.events;
19
- export type AlwaysMountedModalSlots = typeof __propDef.slots;
20
- export default class AlwaysMountedModal extends SvelteComponentTyped<AlwaysMountedModalProps, AlwaysMountedModalEvents, AlwaysMountedModalSlots> {
21
- }
22
- export {};