windmill-components 1.510.1 → 1.511.1

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 (69) hide show
  1. package/package/components/AppConnectInner.svelte +28 -5
  2. package/package/components/ArgInput.svelte +14 -4
  3. package/package/components/Editor.svelte +108 -84
  4. package/package/components/Editor.svelte.d.ts +30 -55
  5. package/package/components/FlowPreviewContent.svelte +1 -0
  6. package/package/components/FlowPreviewContent.svelte.d.ts +3 -0
  7. package/package/components/FlowStatusViewer.svelte +2 -1
  8. package/package/components/FlowStatusViewer.svelte.d.ts +3 -0
  9. package/package/components/FlowStatusViewerInner.svelte +3 -1
  10. package/package/components/FlowStatusViewerInner.svelte.d.ts +3 -0
  11. package/package/components/HttpAgentWorkerDrawer.svelte +1 -1
  12. package/package/components/JsonEditor.svelte +11 -11
  13. package/package/components/JsonEditor.svelte.d.ts +14 -56
  14. package/package/components/Label.svelte +6 -11
  15. package/package/components/Label.svelte.d.ts +14 -39
  16. package/package/components/NumberTypeNarrowing.svelte +13 -16
  17. package/package/components/NumberTypeNarrowing.svelte.d.ts +4 -18
  18. package/package/components/ResourceTypePicker.svelte +20 -17
  19. package/package/components/ResourceTypePicker.svelte.d.ts +7 -6
  20. package/package/components/Section.svelte +7 -20
  21. package/package/components/Section.svelte.d.ts +20 -47
  22. package/package/components/SimpleEditor.svelte +4 -4
  23. package/package/components/SimpleEditor.svelte.d.ts +1 -0
  24. package/package/components/SqlRepl.svelte +0 -1
  25. package/package/components/Subsection.svelte +10 -12
  26. package/package/components/Subsection.svelte.d.ts +15 -39
  27. package/package/components/WorkerGroup.svelte +260 -165
  28. package/package/components/WorkerGroup.svelte.d.ts +2 -0
  29. package/package/components/WorkerTagPicker.svelte +3 -3
  30. package/package/components/WorkerTagSelect.svelte +3 -3
  31. package/package/components/copilot/AIFormSettings.svelte +3 -4
  32. package/package/components/copilot/AIFormSettings.svelte.d.ts +5 -19
  33. package/package/components/copilot/autocomplete/Autocompletor.d.ts +3 -1
  34. package/package/components/copilot/autocomplete/Autocompletor.js +250 -34
  35. package/package/components/copilot/autocomplete/request.d.ts +3 -0
  36. package/package/components/copilot/autocomplete/request.js +15 -7
  37. package/package/components/copilot/chat/script/core.js +30 -22
  38. package/package/components/copilot/lib.d.ts +1 -1
  39. package/package/components/copilot/lib.js +3 -0
  40. package/package/components/custom_ui.d.ts +1 -0
  41. package/package/components/flows/content/FlowModuleCache.svelte +4 -4
  42. package/package/components/flows/content/FlowModuleCache.svelte.d.ts +4 -18
  43. package/package/components/flows/content/FlowModuleComponent.svelte +1 -1
  44. package/package/components/flows/content/FlowModuleDeleteAfterUse.svelte +3 -4
  45. package/package/components/flows/content/FlowModuleDeleteAfterUse.svelte.d.ts +4 -18
  46. package/package/components/flows/content/FlowModuleSleep.svelte +6 -7
  47. package/package/components/flows/content/FlowModuleSleep.svelte.d.ts +4 -18
  48. package/package/components/flows/content/FlowModuleSuspend.svelte +19 -17
  49. package/package/components/flows/content/FlowModuleSuspend.svelte.d.ts +4 -18
  50. package/package/components/flows/content/FlowModuleTimeout.svelte +4 -4
  51. package/package/components/flows/content/FlowModuleTimeout.svelte.d.ts +4 -18
  52. package/package/components/triggers/gcp/GcpTriggerEditorInner.svelte +4 -4
  53. package/package/components/triggers/http/OpenAPISpecGenerator.svelte +2 -2
  54. package/package/components/triggers/http/RouteEditorConfigSection.svelte +26 -23
  55. package/package/components/triggers/http/RouteEditorConfigSection.svelte.d.ts +5 -19
  56. package/package/components/triggers/http/RouteEditorInner.svelte +18 -18
  57. package/package/components/triggers/kafka/KafkaTriggerEditorInner.svelte +4 -4
  58. package/package/components/triggers/mqtt/MqttTriggerEditorInner.svelte +4 -4
  59. package/package/components/triggers/nats/NatsTriggerEditorInner.svelte +4 -4
  60. package/package/components/triggers/schedules/ScheduleEditorInner.svelte +4 -4
  61. package/package/components/triggers/sqs/SqsTriggerEditorInner.svelte +4 -4
  62. package/package/components/triggers/websocket/WebsocketTriggerEditorInner.svelte +4 -4
  63. package/package/gen/core/OpenAPI.js +1 -1
  64. package/package/gen/schemas.gen.d.ts +26 -18
  65. package/package/gen/schemas.gen.js +29 -21
  66. package/package/gen/types.gen.d.ts +25 -6
  67. package/package/inferArgSig.d.ts +14 -7
  68. package/package/inferArgSig.js +22 -15
  69. package/package.json +12 -12
@@ -1,16 +1,12 @@
1
- <script lang="ts">import '@codingame/monaco-vscode-standalone-json-language-features';
1
+ <script lang="ts">import { run } from 'svelte/legacy';
2
+ import '@codingame/monaco-vscode-standalone-json-language-features';
2
3
  import SimpleEditor from './SimpleEditor.svelte';
3
4
  import { createEventDispatcher } from 'svelte';
4
5
  import { createDispatcherIfMounted } from '../createDispatcherIfMounted';
5
6
  import Button from './common/button/Button.svelte';
6
- export let code;
7
- export let value = undefined;
8
- export let error = '';
9
- export let editor = undefined;
10
- export let small = false;
11
- export let loadAsync = false;
12
- $: tooBig = code && code?.length > 1000000;
13
- let loadTooBigAnyway = false;
7
+ let { code = $bindable(), value = $bindable(undefined), error = $bindable(), editor = $bindable(undefined), small = false, loadAsync = false, class: clazz = undefined, disabled = false, fixedOverflowWidgets = true } = $props();
8
+ let tooBig = $derived(code && code?.length > 1000000);
9
+ let loadTooBigAnyway = $state(false);
14
10
  const dispatch = createEventDispatcher();
15
11
  const dispatchIfMounted = createDispatcherIfMounted(dispatch);
16
12
  function parseJson() {
@@ -28,7 +24,9 @@ function parseJson() {
28
24
  error = e.message;
29
25
  }
30
26
  }
31
- $: code != undefined && parseJson();
27
+ run(() => {
28
+ code != undefined && parseJson();
29
+ });
32
30
  </script>
33
31
 
34
32
  {#if tooBig && !loadTooBigAnyway}
@@ -51,7 +49,9 @@ $: code != undefined && parseJson();
51
49
  autoHeight
52
50
  lang="json"
53
51
  bind:code
54
- class={$$props.class}
52
+ class={clazz}
53
+ {disabled}
54
+ {fixedOverflowWidgets}
55
55
  />
56
56
  </div>
57
57
  {#if error != ''}
@@ -1,5 +1,16 @@
1
- import { SvelteComponent } from "svelte";
2
1
  import '@codingame/monaco-vscode-standalone-json-language-features';
2
+ import SimpleEditor from './SimpleEditor.svelte';
3
+ interface Props {
4
+ code: string | undefined;
5
+ value?: any;
6
+ error?: string;
7
+ editor?: SimpleEditor | undefined;
8
+ small?: boolean;
9
+ loadAsync?: boolean;
10
+ class?: string | undefined;
11
+ disabled?: boolean;
12
+ fixedOverflowWidgets?: boolean;
13
+ }
3
14
  interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
4
15
  new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
5
16
  $$bindings?: Bindings;
@@ -13,65 +24,12 @@ interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> =
13
24
  };
14
25
  z_$$bindings?: Bindings;
15
26
  }
16
- declare const JsonEditor: $$__sveltets_2_IsomorphicComponent<{
17
- [x: string]: any;
18
- code: string | undefined;
19
- value?: any;
20
- error?: string | undefined;
21
- editor?: (SvelteComponent<{
22
- lang: string;
23
- code?: string;
24
- hash?: string;
25
- cmdEnterAction?: () => void;
26
- formatAction?: () => void;
27
- automaticLayout?: boolean;
28
- extraLib?: string;
29
- placeholder?: string;
30
- disableSuggestions?: boolean;
31
- disableLinting?: boolean;
32
- hideLineNumbers?: boolean;
33
- shouldBindKey?: boolean;
34
- autoHeight?: boolean;
35
- fixedOverflowWidgets?: boolean;
36
- small?: boolean;
37
- domLib?: boolean;
38
- autofocus?: boolean;
39
- allowVim?: boolean;
40
- tailwindClasses?: string[];
41
- class?: string;
42
- loadAsync?: boolean;
43
- initialCursorPos?: import("monaco-editor").IPosition;
44
- key?: string;
45
- }, {
46
- change: CustomEvent<any>;
47
- focus: CustomEvent<any>;
48
- blur: CustomEvent<any>;
49
- } & {
50
- [evt: string]: CustomEvent<any>;
51
- }, {}> & {
52
- $$bindings?: "code" | undefined;
53
- } & {
54
- getCode: () => string;
55
- insertAtCursor: (code: string) => void;
56
- setCode: (ncode: string, formatCode?: boolean) => void;
57
- formatCode: () => void;
58
- format: () => void;
59
- focus: () => void;
60
- getSelectedLines: () => string | undefined;
61
- onDidChangeCursorSelection: (f: (e: import("monaco-editor").editor.ICursorSelectionChangedEvent) => void) => import("monaco-editor").IDisposable | undefined;
62
- show: () => void;
63
- hide: () => void;
64
- setSuggestion: (value: string) => void;
65
- setCursorToEnd: () => void;
66
- }) | undefined;
67
- small?: boolean | undefined;
68
- loadAsync?: boolean | undefined;
69
- }, {
27
+ declare const JsonEditor: $$__sveltets_2_IsomorphicComponent<Props, {
70
28
  focus: CustomEvent<any>;
71
29
  blur: CustomEvent<any>;
72
30
  change: CustomEvent<any>;
73
31
  } & {
74
32
  [evt: string]: CustomEvent<any>;
75
- }, {}, {}, string>;
33
+ }, {}, {}, "value" | "error" | "code" | "editor">;
76
34
  type JsonEditor = InstanceType<typeof JsonEditor>;
77
35
  export default JsonEditor;
@@ -1,14 +1,9 @@
1
1
  <script lang="ts">import { twMerge } from 'tailwind-merge';
2
2
  import Required from './Required.svelte';
3
- export let label = undefined;
4
- export let primary = false;
5
- export let disabled = false;
6
- export let headless = false;
7
- export let required = false;
8
- export let headerClass = '';
3
+ let { label = undefined, primary = false, disabled = false, headless = false, required = false, headerClass = '', class: clazz = undefined, header, error, action, children } = $props();
9
4
  </script>
10
5
 
11
- <div class={twMerge(disabled ? 'opacity-60 pointer-events-none' : '', $$props.class)}>
6
+ <div class={twMerge(disabled ? 'opacity-60 pointer-events-none' : '', clazz)}>
12
7
  <div class="flex flex-row justify-between items-center w-full">
13
8
  {#if !headless}
14
9
  <div class={twMerge('flex flex-row items-center gap-2', headerClass)}>
@@ -19,11 +14,11 @@ export let headerClass = '';
19
14
  <Required required={true} />
20
15
  {/if}
21
16
  </span>
22
- <slot name="header" />
17
+ {@render header?.()}
23
18
  </div>
24
19
  {/if}
25
- <slot name="error" />
26
- <slot name="action" />
20
+ {@render error?.()}
21
+ {@render action?.()}
27
22
  </div>
28
- <slot />
23
+ {@render children?.()}
29
24
  </div>
@@ -1,41 +1,16 @@
1
- interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
2
- new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
3
- $$bindings?: Bindings;
4
- } & Exports;
5
- (internal: unknown, props: Props & {
6
- $$events?: Events;
7
- $$slots?: Slots;
8
- }): Exports & {
9
- $set?: any;
10
- $on?: any;
11
- };
12
- z_$$bindings?: Bindings;
1
+ interface Props {
2
+ label?: string | undefined;
3
+ primary?: boolean;
4
+ disabled?: boolean;
5
+ headless?: boolean;
6
+ required?: boolean;
7
+ headerClass?: string;
8
+ class?: string | undefined;
9
+ header?: import('svelte').Snippet;
10
+ error?: import('svelte').Snippet;
11
+ action?: import('svelte').Snippet;
12
+ children?: import('svelte').Snippet;
13
13
  }
14
- type $$__sveltets_2_PropsWithChildren<Props, Slots> = Props & (Slots extends {
15
- default: any;
16
- } ? Props extends Record<string, never> ? any : {
17
- children?: any;
18
- } : {});
19
- declare const Label: $$__sveltets_2_IsomorphicComponent<$$__sveltets_2_PropsWithChildren<{
20
- [x: string]: any;
21
- label?: string | undefined | undefined;
22
- primary?: boolean | undefined;
23
- disabled?: boolean | undefined;
24
- headless?: boolean | undefined;
25
- required?: boolean | undefined;
26
- headerClass?: string | undefined;
27
- }, {
28
- header: {};
29
- error: {};
30
- action: {};
31
- default: {};
32
- }>, {
33
- [evt: string]: CustomEvent<any>;
34
- }, {
35
- header: {};
36
- error: {};
37
- action: {};
38
- default: {};
39
- }, {}, string>;
40
- type Label = InstanceType<typeof Label>;
14
+ declare const Label: import("svelte").Component<Props, {}, "">;
15
+ type Label = ReturnType<typeof Label>;
41
16
  export default Label;
@@ -2,24 +2,21 @@
2
2
  import Toggle from './Toggle.svelte';
3
3
  import Tooltip from './Tooltip.svelte';
4
4
  import { selectOptions } from './apps/editor/component';
5
- export let min;
6
- export let max;
7
- export let currency;
8
- export let currencyLocale;
9
- let minChecked = min != undefined;
10
- let maxChecked = max != undefined;
5
+ let { min = $bindable(), max = $bindable(), currency = $bindable(), currencyLocale = $bindable() } = $props();
6
+ let minChecked = $state(min != undefined);
7
+ let maxChecked = $state(max != undefined);
11
8
  </script>
12
9
 
13
10
  <div class="flex flex-col gap-2">
14
11
  <div class="grid grid-cols-2 gap-4">
15
12
  <Label label="Min" class="w-full col-span-1">
16
- <svelte:fragment slot="header">
13
+ {#snippet header()}
17
14
  <Tooltip light small>
18
15
  Set a minimum value for the number. If both min and max are set, the input will render as
19
16
  a range slider.
20
17
  </Tooltip>
21
- </svelte:fragment>
22
- <svelte:fragment slot="action">
18
+ {/snippet}
19
+ {#snippet action()}
23
20
  <Toggle
24
21
  bind:checked={minChecked}
25
22
  on:change={(e) => {
@@ -32,17 +29,17 @@ let maxChecked = max != undefined;
32
29
  options={{ right: 'Enabled' }}
33
30
  size="xs"
34
31
  />
35
- </svelte:fragment> <input type="number" bind:value={min} disabled={!minChecked} />
32
+ {/snippet} <input type="number" bind:value={min} disabled={!minChecked} />
36
33
  </Label>
37
34
 
38
35
  <Label label="Max" class="w-full col-span-1 ">
39
- <svelte:fragment slot="header">
36
+ {#snippet header()}
40
37
  <Tooltip light small>
41
38
  Set a maximum value for the number. If both min and max are set, the input will render as
42
39
  a range slider.
43
40
  </Tooltip>
44
- </svelte:fragment>
45
- <svelte:fragment slot="action">
41
+ {/snippet}
42
+ {#snippet action()}
46
43
  <Toggle
47
44
  bind:checked={maxChecked}
48
45
  on:change={(e) => {
@@ -55,18 +52,18 @@ let maxChecked = max != undefined;
55
52
  options={{ right: 'Enabled' }}
56
53
  size="xs"
57
54
  />
58
- </svelte:fragment>
55
+ {/snippet}
59
56
  <input type="number" bind:value={max} disabled={!maxChecked} />
60
57
  </Label>
61
58
  </div>
62
59
  <div class="grid grid-cols-3 gap-4">
63
60
  <Label label="Currency" class="w-full col-span-2">
64
- <svelte:fragment slot="header">
61
+ {#snippet header()}
65
62
  <Tooltip light small>
66
63
  Select a currency to display the number in. If a currency is selected, you can also select
67
64
  a locale to format the number according to that locale.
68
65
  </Tooltip>
69
- </svelte:fragment>
66
+ {/snippet}
70
67
  <select bind:value={currency}>
71
68
  <option value={undefined}> No currency </option>
72
69
  {#each selectOptions.currencyOptions as c}
@@ -1,23 +1,9 @@
1
- interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
2
- new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
3
- $$bindings?: Bindings;
4
- } & Exports;
5
- (internal: unknown, props: Props & {
6
- $$events?: Events;
7
- $$slots?: Slots;
8
- }): Exports & {
9
- $set?: any;
10
- $on?: any;
11
- };
12
- z_$$bindings?: Bindings;
13
- }
14
- declare const NumberTypeNarrowing: $$__sveltets_2_IsomorphicComponent<{
1
+ interface Props {
15
2
  min: number | undefined;
16
3
  max: number | undefined;
17
4
  currency: string | undefined;
18
5
  currencyLocale: string | undefined;
19
- }, {
20
- [evt: string]: CustomEvent<any>;
21
- }, {}, {}, string>;
22
- type NumberTypeNarrowing = InstanceType<typeof NumberTypeNarrowing>;
6
+ }
7
+ declare const NumberTypeNarrowing: import("svelte").Component<Props, {}, "currency" | "min" | "max" | "currencyLocale">;
8
+ type NumberTypeNarrowing = ReturnType<typeof NumberTypeNarrowing>;
23
9
  export default NumberTypeNarrowing;
@@ -8,10 +8,9 @@ import { offset, flip, shift } from 'svelte-floating-ui/dom';
8
8
  import Label from './Label.svelte';
9
9
  import Tooltip from './Tooltip.svelte';
10
10
  import Badge from './common/badge/Badge.svelte';
11
- export let value;
12
- export let notPickable = false;
13
- export let nonePickable = false;
14
- let resources = [];
11
+ import { untrack } from 'svelte';
12
+ let { value = $bindable(), notPickable = false, nonePickable = false } = $props();
13
+ let resources = $state([]);
15
14
  async function loadResources() {
16
15
  resources = await ResourceService.listResourceTypeNames({ workspace: $workspaceStore });
17
16
  }
@@ -20,19 +19,23 @@ function onClick(resource) {
20
19
  value = resource;
21
20
  dispatch('click', resource);
22
21
  }
23
- $: if ($workspaceStore) {
24
- loadResources();
25
- }
26
- let search = '';
27
- $: filteredResources = resources.filter((r) => r.toLowerCase().includes(search.toLowerCase()));
22
+ $effect(() => {
23
+ if ($workspaceStore) {
24
+ untrack(() => {
25
+ loadResources();
26
+ });
27
+ }
28
+ });
29
+ let search = $state('');
30
+ let filteredResources = $derived(resources.filter((r) => r.toLowerCase().includes(search.toLowerCase())));
28
31
  </script>
29
32
 
30
33
  <Label label="Resource type" class="w-full col-span-2">
31
- <svelte:fragment slot="header">
34
+ {#snippet header()}
32
35
  <Tooltip light small>Select a resource type to narrow down the object type.</Tooltip>
33
- </svelte:fragment>
36
+ {/snippet}
34
37
 
35
- <svelte:fragment slot="action">
38
+ {#snippet action()}
36
39
  <div class="flex flex-row gap-1">
37
40
  <Button
38
41
  size="xs"
@@ -50,10 +53,10 @@ $: filteredResources = resources.filter((r) => r.toLowerCase().includes(search.t
50
53
  }}
51
54
  contentClasses="flex flex-col gap-2 h-full p-4 max-h-[40vh] w-[500px]"
52
55
  >
53
- <svelte:fragment slot="trigger">
56
+ {#snippet trigger()}
54
57
  <Button nonCaptureEvent size="xs" color="dark">Select resource type</Button>
55
- </svelte:fragment>
56
- <svelte:fragment slot="content" let:close>
58
+ {/snippet}
59
+ {#snippet content({ close })}
57
60
  <ClearableInput bind:value={search} placeholder="Search resource..." />
58
61
 
59
62
  <div class="overflow-y-scroll h-full">
@@ -98,10 +101,10 @@ $: filteredResources = resources.filter((r) => r.toLowerCase().includes(search.t
98
101
  {/if}
99
102
  </div>
100
103
  </div>
101
- </svelte:fragment>
104
+ {/snippet}
102
105
  </Popover>
103
106
  </div>
104
- </svelte:fragment>
107
+ {/snippet}
105
108
  <div class="flex flex-row items-center w-full justify-between">
106
109
  <Badge color={!value ? 'gray' : 'blue'}>
107
110
  {value ?? 'None'}
@@ -1,3 +1,8 @@
1
+ interface Props {
2
+ value: string | undefined;
3
+ notPickable?: boolean;
4
+ nonePickable?: boolean;
5
+ }
1
6
  interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
2
7
  new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
3
8
  $$bindings?: Bindings;
@@ -11,14 +16,10 @@ interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> =
11
16
  };
12
17
  z_$$bindings?: Bindings;
13
18
  }
14
- declare const ResourceTypePicker: $$__sveltets_2_IsomorphicComponent<{
15
- value: string | undefined;
16
- notPickable?: boolean;
17
- nonePickable?: boolean;
18
- }, {
19
+ declare const ResourceTypePicker: $$__sveltets_2_IsomorphicComponent<Props, {
19
20
  click: CustomEvent<any>;
20
21
  } & {
21
22
  [evt: string]: CustomEvent<any>;
22
- }, {}, {}, string>;
23
+ }, {}, {}, "value">;
23
24
  type ResourceTypePicker = InstanceType<typeof ResourceTypePicker>;
24
25
  export default ResourceTypePicker;
@@ -3,18 +3,7 @@ import { AlertTriangle, ChevronRight } from 'lucide-svelte';
3
3
  import Tooltip from './Tooltip.svelte';
4
4
  import { twMerge } from 'tailwind-merge';
5
5
  import { slide } from 'svelte/transition';
6
- export let label = undefined;
7
- export let tooltip = undefined;
8
- export let documentationLink = undefined;
9
- export let eeOnly = false;
10
- export let small = false;
11
- export let wrapperClass = '';
12
- export let headerClass = '';
13
- export let collapsable = false;
14
- export let collapsed = true;
15
- export let headless = false;
16
- export let animate = false;
17
- export let breakAll = false;
6
+ let { label = undefined, tooltip = undefined, documentationLink = undefined, eeOnly = false, small = false, wrapperClass = '', headerClass = '', collapsable = false, collapsed = $bindable(true), headless = false, animate = false, breakAll = false, class: clazz = undefined, header, action, badge, children } = $props();
18
7
  </script>
19
8
 
20
9
  <div class={twMerge('w-full flex flex-col', wrapperClass)}>
@@ -29,7 +18,7 @@ export let breakAll = false;
29
18
  )}
30
19
  >
31
20
  {#if collapsable}
32
- <button class="flex items-center gap-1" on:click={() => (collapsed = !collapsed)}>
21
+ <button class="flex items-center gap-1" onclick={() => (collapsed = !collapsed)}>
33
22
  <ChevronRight
34
23
  size={16}
35
24
  class={twMerge(
@@ -44,11 +33,9 @@ export let breakAll = false;
44
33
  {label}
45
34
  {/if}
46
35
 
47
- <slot name="header" />
36
+ {@render header?.()}
48
37
  {#if tooltip}
49
38
  <Tooltip {documentationLink}>{tooltip}</Tooltip>
50
- {:else if $$slots.tooltip}
51
- <slot name="tooltip" />
52
39
  {/if}
53
40
  {#if eeOnly}
54
41
  {#if !$enterpriseLicense}
@@ -59,18 +46,18 @@ export let breakAll = false;
59
46
  {/if}
60
47
  {/if}
61
48
  </h2>
62
- <slot name="action" />
49
+ {@render action?.()}
63
50
  {#if collapsable && collapsed}
64
- <slot name="badge" />
51
+ {@render badge?.()}
65
52
  {/if}
66
53
  </div>
67
54
  {/if}
68
55
  {#if !collapsable || !collapsed}
69
56
  <div
70
- class={twMerge('grow min-h-0', $$props.class)}
57
+ class={twMerge('grow min-h-0', clazz)}
71
58
  transition:slide={animate ? { duration: 200 } : { duration: 0 }}
72
59
  >
73
- <slot />
60
+ {@render children?.()}
74
61
  </div>
75
62
  {/if}
76
63
  </div>
@@ -1,49 +1,22 @@
1
- interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
2
- new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
3
- $$bindings?: Bindings;
4
- } & Exports;
5
- (internal: unknown, props: Props & {
6
- $$events?: Events;
7
- $$slots?: Slots;
8
- }): Exports & {
9
- $set?: any;
10
- $on?: any;
11
- };
12
- z_$$bindings?: Bindings;
1
+ interface Props {
2
+ label?: string | undefined;
3
+ tooltip?: string | undefined;
4
+ documentationLink?: string | undefined;
5
+ eeOnly?: boolean;
6
+ small?: boolean;
7
+ wrapperClass?: string;
8
+ headerClass?: string;
9
+ collapsable?: boolean;
10
+ collapsed?: boolean;
11
+ headless?: boolean;
12
+ animate?: boolean;
13
+ breakAll?: boolean;
14
+ class?: string | undefined;
15
+ header?: import('svelte').Snippet;
16
+ action?: import('svelte').Snippet;
17
+ badge?: import('svelte').Snippet;
18
+ children?: import('svelte').Snippet;
13
19
  }
14
- type $$__sveltets_2_PropsWithChildren<Props, Slots> = Props & (Slots extends {
15
- default: any;
16
- } ? Props extends Record<string, never> ? any : {
17
- children?: any;
18
- } : {});
19
- declare const Section: $$__sveltets_2_IsomorphicComponent<$$__sveltets_2_PropsWithChildren<{
20
- [x: string]: any;
21
- label?: string | undefined | undefined;
22
- tooltip?: string | undefined | undefined;
23
- documentationLink?: string | undefined | undefined;
24
- eeOnly?: boolean | undefined;
25
- small?: boolean | undefined;
26
- wrapperClass?: string | undefined;
27
- headerClass?: string | undefined;
28
- collapsable?: boolean | undefined;
29
- collapsed?: boolean | undefined;
30
- headless?: boolean | undefined;
31
- animate?: boolean | undefined;
32
- breakAll?: boolean | undefined;
33
- }, {
34
- header: {};
35
- tooltip: {};
36
- action: {};
37
- badge: {};
38
- default: {};
39
- }>, {
40
- [evt: string]: CustomEvent<any>;
41
- }, {
42
- header: {};
43
- tooltip: {};
44
- action: {};
45
- badge: {};
46
- default: {};
47
- }, {}, string>;
48
- type Section = InstanceType<typeof Section>;
20
+ declare const Section: import("svelte").Component<Props, {}, "collapsed">;
21
+ type Section = ReturnType<typeof Section>;
49
22
  export default Section;
@@ -89,7 +89,7 @@ let suggestion = $state('');
89
89
  let placeholderVisible = $state(false);
90
90
  let mounted = $state(false);
91
91
  let valueAfterDispose = undefined;
92
- let { lang, code = $bindable(), hash = createHash(), cmdEnterAction, formatAction, automaticLayout = true, extraLib = '', placeholder = '', disableSuggestions = false, disableLinting = false, hideLineNumbers = false, shouldBindKey = true, autoHeight = false, fixedOverflowWidgets = true, small = false, domLib = false, autofocus = false, allowVim = false, tailwindClasses = [], class: className = '', loadAsync = false, key } = $props();
92
+ let { lang, code = $bindable(), hash = createHash(), cmdEnterAction, formatAction, automaticLayout = true, extraLib = '', placeholder = '', disableSuggestions = false, disableLinting = false, hideLineNumbers = false, shouldBindKey = true, autoHeight = false, fixedOverflowWidgets = true, small = false, domLib = false, autofocus = false, allowVim = false, tailwindClasses = [], class: className = '', loadAsync = false, key, disabled = false } = $props();
93
93
  const dispatch = createEventDispatcher();
94
94
  const uri = `file:///${hash}.${langToExt(lang)}`;
95
95
  export function getCode() {
@@ -546,9 +546,9 @@ updatePlaceholderVisibility(code ?? '');
546
546
 
547
547
  <div
548
548
  bind:this={divEl}
549
- class="relative {className} {!editor ? 'hidden' : ''} editor simple-editor {!allowVim
550
- ? 'nonmain-editor'
551
- : ''}"
549
+ class="relative {className} {!editor ? 'hidden' : ''} editor {disabled
550
+ ? 'disabled'
551
+ : ''} simple-editor {!allowVim ? 'nonmain-editor' : ''}"
552
552
  bind:clientWidth={width}
553
553
  >
554
554
  {#if placeholder}
@@ -28,6 +28,7 @@ type $$ComponentProps = {
28
28
  loadAsync?: boolean;
29
29
  initialCursorPos?: IPosition;
30
30
  key?: string;
31
+ disabled?: boolean;
31
32
  };
32
33
  interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
33
34
  new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
@@ -135,7 +135,6 @@ let editor = $state(null);
135
135
  <Module.default
136
136
  bind:this={editor}
137
137
  bind:code
138
- lang="sql"
139
138
  scriptLang="mysql"
140
139
  class="w-full h-full"
141
140
  cmdEnterAction={run}
@@ -2,12 +2,10 @@
2
2
  import { AlertTriangle, ChevronDown, ChevronRight } from 'lucide-svelte';
3
3
  import Tooltip from './Tooltip.svelte';
4
4
  import { twMerge } from 'tailwind-merge';
5
- export let label = undefined;
6
- export let tooltip = undefined;
7
- export let eeOnly = false;
8
- export let collapsable = false;
9
- export let collapsed = true;
10
- export let headless = false;
5
+ let { label = undefined, tooltip = undefined, eeOnly = false, collapsable = false, collapsed = $bindable(true), openInitially = false, headless = false, class: clazz = undefined, header, action, badge, children } = $props();
6
+ if (openInitially && collapsable && collapsed) {
7
+ collapsed = false;
8
+ }
11
9
  </script>
12
10
 
13
11
  <div class="w-full">
@@ -15,7 +13,7 @@ export let headless = false;
15
13
  <div class="flex flex-row justify-between items-center mb-1">
16
14
  <h3 class={twMerge('font-semibold flex flex-row items-center gap-2', 'text-sm')}>
17
15
  {#if collapsable}
18
- <button class="flex items-center gap-1" on:click={() => (collapsed = !collapsed)}>
16
+ <button class="flex items-center gap-1" onclick={() => (collapsed = !collapsed)}>
19
17
  {#if collapsed}
20
18
  <ChevronRight size={16} />
21
19
  {:else}
@@ -27,7 +25,7 @@ export let headless = false;
27
25
  {label}
28
26
  {/if}
29
27
 
30
- <slot name="header" />
28
+ {@render header?.()}
31
29
  {#if tooltip}
32
30
  <Tooltip>{tooltip}</Tooltip>
33
31
  {/if}
@@ -40,13 +38,13 @@ export let headless = false;
40
38
  {/if}
41
39
  {/if}
42
40
  </h3>
43
- <slot name="action" />
41
+ {@render action?.()}
44
42
  {#if collapsable && collapsed}
45
- <slot name="badge" />
43
+ {@render badge?.()}
46
44
  {/if}
47
45
  </div>
48
46
  {/if}
49
- <div class={collapsable && collapsed ? `hidden ${$$props.class}` : `${$$props.class}`}>
50
- <slot />
47
+ <div class={collapsable && collapsed ? `hidden ${clazz ?? ''}` : `${clazz ?? ''}`}>
48
+ {@render children?.()}
51
49
  </div>
52
50
  </div>