@gradio/core 0.29.2 → 1.0.0-dev.3

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 (107) hide show
  1. package/CHANGELOG.md +103 -0
  2. package/dist/index.d.ts +1 -1
  3. package/dist/index.js +1 -1
  4. package/dist/src/Blocks.svelte +518 -999
  5. package/dist/src/Blocks.svelte.d.ts +31 -46
  6. package/dist/src/Embed.svelte +82 -55
  7. package/dist/src/Embed.svelte.d.ts +39 -30
  8. package/dist/src/Login.svelte +33 -29
  9. package/dist/src/Login.svelte.d.ts +21 -19
  10. package/dist/src/MountComponents.svelte +19 -25
  11. package/dist/src/MountComponents.svelte.d.ts +5 -28
  12. package/dist/src/{init.d.ts → _init.d.ts} +5 -4
  13. package/dist/src/{init.js → _init.js} +31 -108
  14. package/dist/src/api_docs/ApiBanner.svelte +12 -8
  15. package/dist/src/api_docs/ApiBanner.svelte.d.ts +22 -20
  16. package/dist/src/api_docs/ApiDocs.svelte +338 -246
  17. package/dist/src/api_docs/ApiDocs.svelte.d.ts +26 -24
  18. package/dist/src/api_docs/ApiRecorder.svelte +9 -3
  19. package/dist/src/api_docs/ApiRecorder.svelte.d.ts +19 -17
  20. package/dist/src/api_docs/CodeSnippet.svelte +60 -30
  21. package/dist/src/api_docs/CodeSnippet.svelte.d.ts +27 -24
  22. package/dist/src/api_docs/CopyButton.svelte +69 -13
  23. package/dist/src/api_docs/CopyButton.svelte.d.ts +18 -16
  24. package/dist/src/api_docs/CopyMarkdown.svelte +734 -0
  25. package/dist/src/api_docs/CopyMarkdown.svelte.d.ts +37 -0
  26. package/dist/src/api_docs/EndpointDetail.svelte +8 -6
  27. package/dist/src/api_docs/EndpointDetail.svelte.d.ts +20 -18
  28. package/dist/src/api_docs/IconArrowUpRight.svelte +34 -0
  29. package/dist/src/api_docs/IconArrowUpRight.svelte.d.ts +20 -0
  30. package/dist/src/api_docs/IconCaret.svelte +39 -0
  31. package/dist/src/api_docs/IconCaret.svelte.d.ts +20 -0
  32. package/dist/src/api_docs/IconHuggingChat.svelte +62 -0
  33. package/dist/src/api_docs/IconHuggingChat.svelte.d.ts +20 -0
  34. package/dist/src/api_docs/InputPayload.svelte +17 -11
  35. package/dist/src/api_docs/InputPayload.svelte.d.ts +25 -23
  36. package/dist/src/api_docs/InstallSnippet.svelte +9 -6
  37. package/dist/src/api_docs/InstallSnippet.svelte.d.ts +18 -16
  38. package/dist/src/api_docs/MCPSnippet.svelte +119 -99
  39. package/dist/src/api_docs/MCPSnippet.svelte.d.ts +59 -58
  40. package/dist/src/api_docs/NoApi.svelte +8 -5
  41. package/dist/src/api_docs/NoApi.svelte.d.ts +20 -18
  42. package/dist/src/api_docs/ParametersSnippet.svelte +8 -6
  43. package/dist/src/api_docs/ParametersSnippet.svelte.d.ts +21 -19
  44. package/dist/src/api_docs/RecordingSnippet.svelte +124 -110
  45. package/dist/src/api_docs/RecordingSnippet.svelte.d.ts +24 -22
  46. package/dist/src/api_docs/ResponseSnippet.svelte +7 -5
  47. package/dist/src/api_docs/ResponseSnippet.svelte.d.ts +21 -19
  48. package/dist/src/api_docs/Settings.svelte +73 -62
  49. package/dist/src/api_docs/Settings.svelte.d.ts +25 -23
  50. package/dist/src/api_docs/SettingsBanner.svelte +11 -8
  51. package/dist/src/api_docs/SettingsBanner.svelte.d.ts +20 -18
  52. package/dist/src/api_docs/TryButton.svelte +5 -3
  53. package/dist/src/api_docs/TryButton.svelte.d.ts +19 -17
  54. package/dist/src/api_docs/img/IconCheck.svelte +33 -0
  55. package/dist/src/api_docs/img/IconCheck.svelte.d.ts +26 -0
  56. package/dist/src/api_docs/img/IconCopy.svelte +40 -0
  57. package/dist/src/api_docs/img/IconCopy.svelte.d.ts +26 -0
  58. package/dist/src/api_docs/img/clear.svelte.d.ts +22 -21
  59. package/dist/src/dependency.d.ts +142 -0
  60. package/dist/src/dependency.js +653 -0
  61. package/dist/src/init.svelte.d.ts +78 -0
  62. package/dist/src/init.svelte.js +469 -0
  63. package/dist/src/init_utils.d.ts +32 -0
  64. package/dist/src/init_utils.js +73 -0
  65. package/dist/src/lang/en.json +10 -1
  66. package/dist/src/lang/get_lang_names.js +0 -3
  67. package/dist/src/lang/ru.json +10 -1
  68. package/dist/src/stores.d.ts +0 -21
  69. package/dist/src/stories/I18nMultiLanguageTestComponent.svelte +5 -3
  70. package/dist/src/stories/I18nMultiLanguageTestComponent.svelte.d.ts +16 -14
  71. package/dist/src/stories/I18nTestSetup.svelte +14 -10
  72. package/dist/src/stories/I18nTestSetup.svelte.d.ts +18 -16
  73. package/dist/src/types.d.ts +29 -25
  74. package/index.ts +1 -1
  75. package/package.json +59 -59
  76. package/src/Blocks.svelte +344 -1059
  77. package/src/MountComponents.svelte +17 -27
  78. package/src/{init.ts → _init.ts} +49 -126
  79. package/src/api_docs/ApiDocs.svelte +67 -62
  80. package/src/api_docs/ApiRecorder.svelte +3 -0
  81. package/src/api_docs/CodeSnippet.svelte +20 -5
  82. package/src/api_docs/CopyButton.svelte +61 -7
  83. package/src/api_docs/CopyMarkdown.svelte +734 -0
  84. package/src/api_docs/IconArrowUpRight.svelte +34 -0
  85. package/src/api_docs/IconCaret.svelte +39 -0
  86. package/src/api_docs/IconHuggingChat.svelte +62 -0
  87. package/src/api_docs/MCPSnippet.svelte +24 -46
  88. package/src/api_docs/NoApi.svelte +1 -1
  89. package/src/api_docs/ParametersSnippet.svelte +1 -1
  90. package/src/api_docs/ResponseSnippet.svelte +1 -1
  91. package/src/api_docs/Settings.svelte +11 -11
  92. package/src/api_docs/img/IconCheck.svelte +33 -0
  93. package/src/api_docs/img/IconCopy.svelte +40 -0
  94. package/src/dependency.ts +880 -0
  95. package/src/init.svelte.ts +717 -0
  96. package/src/init_utils.ts +99 -0
  97. package/src/lang/en.json +10 -1
  98. package/src/lang/get_lang_names.js +0 -3
  99. package/src/lang/ru.json +10 -1
  100. package/src/stores.ts +22 -22
  101. package/src/types.ts +54 -43
  102. package/dist/src/Render.svelte +0 -105
  103. package/dist/src/Render.svelte.d.ts +0 -31
  104. package/dist/src/RenderComponent.svelte +0 -72
  105. package/dist/src/RenderComponent.svelte.d.ts +0 -33
  106. package/src/Render.svelte +0 -126
  107. package/src/RenderComponent.svelte +0 -91
@@ -1,49 +1,34 @@
1
- import { SvelteComponent } from "svelte";
2
1
  import { Client } from "@gradio/client";
3
- import type { ComponentMeta, Dependency, LayoutNode } from "./types";
2
+ import type { ComponentMeta, Dependency as IDependency, LayoutNode } from "./types";
4
3
  import type { ThemeMode } from "./types";
5
- import type { ToastMessage } from "@gradio/statustracker";
6
- declare const __propDef: {
7
- props: {
8
- root: string;
9
- components: ComponentMeta[];
10
- layout: LayoutNode;
11
- dependencies: Dependency[];
12
- title?: string;
13
- target: HTMLElement;
14
- autoscroll: boolean;
15
- show_api?: boolean;
16
- show_footer?: boolean;
17
- control_page_title?: boolean;
18
- app_mode: boolean;
19
- theme_mode: ThemeMode;
20
- app: Awaited<ReturnType<typeof Client.connect>>;
21
- space_id: string | null;
22
- version: string;
23
- js: string | null;
24
- fill_height?: boolean;
25
- ready: boolean;
26
- username: string | null;
27
- api_prefix?: string;
28
- max_file_size?: number | undefined;
29
- initial_layout?: ComponentMeta | undefined;
30
- css?: string | null | undefined;
31
- vibe_mode?: boolean;
32
- search_params: URLSearchParams;
33
- render_complete?: boolean;
34
- add_new_message?: (title: string, message: string, type: ToastMessage["type"]) => void;
35
- };
36
- events: {
37
- [evt: string]: CustomEvent<any>;
38
- };
39
- slots: {};
40
- exports?: {} | undefined;
41
- bindings?: string | undefined;
4
+ type $$ComponentProps = {
5
+ root: string;
6
+ components: ComponentMeta[];
7
+ layout: LayoutNode;
8
+ dependencies: IDependency[];
9
+ title: string;
10
+ target: HTMLElement;
11
+ autoscroll: boolean;
12
+ footer_links: string[];
13
+ control_page_title: boolean;
14
+ app_mode: boolean;
15
+ theme_mode: ThemeMode;
16
+ app: Awaited<ReturnType<typeof Client.connect>>;
17
+ space_id: string | null;
18
+ version: string;
19
+ js: string | null;
20
+ fill_height: boolean;
21
+ username: string | null;
22
+ api_prefix: string;
23
+ max_file_size: number | undefined;
24
+ initial_layout: ComponentMeta | undefined;
25
+ css: string | null | undefined;
26
+ vibe_mode: boolean;
27
+ search_params: URLSearchParams;
28
+ render_complete: boolean;
29
+ ready: boolean;
30
+ reload_count: number;
42
31
  };
43
- export type BlocksProps = typeof __propDef.props;
44
- export type BlocksEvents = typeof __propDef.events;
45
- export type BlocksSlots = typeof __propDef.slots;
46
- export default class Blocks extends SvelteComponent<BlocksProps, BlocksEvents, BlocksSlots> {
47
- get add_new_message(): (title: string, message: string, type: ToastMessage["type"]) => void;
48
- }
49
- export {};
32
+ declare const Blocks: import("svelte").Component<$$ComponentProps, {}, "ready" | "reload_count">;
33
+ type Blocks = ReturnType<typeof Blocks>;
34
+ export default Blocks;
@@ -1,58 +1,85 @@
1
- <script>import { getContext, onMount } from "svelte";
2
- import space_logo from "./images/spaces.svg";
3
- import { _ } from "svelte-i18n";
4
- import { navbar_config } from "./navbar_store";
5
- export let wrapper;
6
- export let version;
7
- export let initial_height;
8
- export let fill_width;
9
- export let is_embed;
10
- export let space;
11
- export let display;
12
- export let info;
13
- export let loaded;
14
- export let pages = [];
15
- export let current_page = "";
16
- export let root;
17
- export let components = [];
18
- let navbar_component = components.find((c) => c.type === "navbar");
19
- let navbar = navbar_component ? {
20
- visible: navbar_component.props.visible,
21
- main_page_name: navbar_component.props.main_page_name,
22
- value: navbar_component.props.value
23
- } : null;
24
- if (navbar) {
25
- navbar_config.set(navbar);
26
- }
27
- $: if ($navbar_config) {
28
- navbar = {
29
- visible: $navbar_config.visible ?? true,
30
- main_page_name: $navbar_config.main_page_name ?? "Home",
31
- value: $navbar_config.value ?? null
32
- };
33
- }
34
- $: show_navbar = pages.length > 1 && (navbar === null || navbar.visible !== false);
35
- $: effective_pages = (() => {
36
- let visible_pages = pages.filter(([route, label, show], index) => {
37
- if (index === 0 && route === "") {
38
- return navbar?.main_page_name !== false;
39
- }
40
- return show !== false;
41
- });
42
- let base_pages = navbar && navbar.main_page_name !== false && navbar.main_page_name !== "Home" ? visible_pages.map(
43
- ([route, label, show], index) => index === 0 && route === "" && label === "Home" ? [route, navbar.main_page_name] : [route, label]
44
- ) : visible_pages.map(
45
- ([route, label]) => [route, label]
46
- );
47
- if (navbar?.value && navbar.value.length > 0) {
48
- const existing_routes = new Set(base_pages.map(([route]) => route));
49
- const additional_pages = navbar.value.map(
50
- ([page_name, page_path]) => [page_path, page_name]
51
- ).filter(([route]) => !existing_routes.has(route));
52
- return [...base_pages, ...additional_pages];
53
- }
54
- return base_pages;
55
- })();
1
+ <script lang="ts">
2
+ import { getContext, onMount } from "svelte";
3
+ import space_logo from "./images/spaces.svg";
4
+ import { _ } from "svelte-i18n";
5
+ import { navbar_config } from "./navbar_store";
6
+
7
+ export let wrapper: HTMLDivElement;
8
+ export let version: string;
9
+ export let initial_height: string;
10
+ export let fill_width: boolean;
11
+ export let is_embed: boolean;
12
+
13
+ export let space: string | null;
14
+ export let display: boolean;
15
+ export let info: boolean;
16
+ export let loaded: boolean;
17
+ export let pages: [string, string, boolean][] = [];
18
+ export let current_page = "";
19
+ export let root: string;
20
+ export let components: any[] = [];
21
+
22
+ let navbar_component = components.find((c) => c.type === "navbar");
23
+ let navbar: {
24
+ visible: boolean;
25
+ main_page_name: string | false;
26
+ value: [string, string][] | null;
27
+ } | null = navbar_component
28
+ ? {
29
+ visible: navbar_component.props.visible,
30
+ main_page_name: navbar_component.props.main_page_name,
31
+ value: navbar_component.props.value
32
+ }
33
+ : null;
34
+
35
+ if (navbar) {
36
+ navbar_config.set(navbar);
37
+ }
38
+
39
+ $: if ($navbar_config) {
40
+ navbar = {
41
+ visible: $navbar_config.visible ?? true,
42
+ main_page_name: $navbar_config.main_page_name ?? "Home",
43
+ value: $navbar_config.value ?? null
44
+ };
45
+ }
46
+
47
+ $: show_navbar =
48
+ pages.length > 1 && (navbar === null || navbar.visible !== false);
49
+
50
+ $: effective_pages = (() => {
51
+ let visible_pages = pages.filter(([route, label, show], index) => {
52
+ if (index === 0 && route === "") {
53
+ return navbar?.main_page_name !== false;
54
+ }
55
+ return show !== false;
56
+ });
57
+
58
+ let base_pages =
59
+ navbar &&
60
+ navbar.main_page_name !== false &&
61
+ navbar.main_page_name !== "Home"
62
+ ? visible_pages.map(([route, label, show], index) =>
63
+ index === 0 && route === "" && label === "Home"
64
+ ? ([route, navbar!.main_page_name] as [string, string])
65
+ : ([route, label] as [string, string])
66
+ )
67
+ : visible_pages.map(
68
+ ([route, label]) => [route, label] as [string, string]
69
+ );
70
+
71
+ if (navbar?.value && navbar.value.length > 0) {
72
+ const existing_routes = new Set(base_pages.map(([route]) => route));
73
+ const additional_pages = navbar.value
74
+ .map(
75
+ ([page_name, page_path]) => [page_path, page_name] as [string, string]
76
+ )
77
+ .filter(([route]) => !existing_routes.has(route));
78
+ return [...base_pages, ...additional_pages];
79
+ }
80
+
81
+ return base_pages;
82
+ })();
56
83
  </script>
57
84
 
58
85
  <div
@@ -1,32 +1,41 @@
1
- import { SvelteComponent } from "svelte";
2
- declare const __propDef: {
3
- props: {
4
- wrapper: HTMLDivElement;
5
- version: string;
6
- initial_height: string;
7
- fill_width: boolean;
8
- is_embed: boolean;
9
- space: string | null;
10
- display: boolean;
11
- info: boolean;
12
- loaded: boolean;
13
- pages?: [string, string, boolean][];
14
- current_page?: string;
15
- root: string;
16
- components?: any[];
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;
17
11
  };
18
- events: {
19
- [evt: string]: CustomEvent<any>;
20
- };
21
- slots: {
22
- default: {};
23
- };
24
- exports?: {} | undefined;
25
- bindings?: string | undefined;
26
- };
27
- export type EmbedProps = typeof __propDef.props;
28
- export type EmbedEvents = typeof __propDef.events;
29
- export type EmbedSlots = typeof __propDef.slots;
30
- export default class Embed extends SvelteComponent<EmbedProps, EmbedEvents, EmbedSlots> {
12
+ z_$$bindings?: Bindings;
31
13
  }
32
- export {};
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 Embed: $$__sveltets_2_IsomorphicComponent<$$__sveltets_2_PropsWithChildren<{
20
+ wrapper: HTMLDivElement;
21
+ version: string;
22
+ initial_height: string;
23
+ fill_width: boolean;
24
+ is_embed: boolean;
25
+ space: string | null;
26
+ display: boolean;
27
+ info: boolean;
28
+ loaded: boolean;
29
+ pages?: [string, string, boolean][];
30
+ current_page?: string;
31
+ root: string;
32
+ components?: any[];
33
+ }, {
34
+ default: {};
35
+ }>, {
36
+ [evt: string]: CustomEvent<any>;
37
+ }, {
38
+ default: {};
39
+ }, {}, string>;
40
+ type Embed = InstanceType<typeof Embed>;
41
+ export default Embed;
@@ -1,32 +1,36 @@
1
- <script>import Form from "@gradio/form";
2
- import { BaseTextbox as Textbox } from "@gradio/textbox";
3
- import { BaseButton } from "@gradio/button";
4
- import Column from "@gradio/column";
5
- import { Block } from "@gradio/atoms";
6
- import { _ } from "svelte-i18n";
7
- export let root;
8
- export let auth_message;
9
- export let app_mode;
10
- export let space_id;
11
- let username = "";
12
- let password = "";
13
- let incorrect_credentials = false;
14
- const submit = async () => {
15
- const formData = new FormData();
16
- formData.append("username", username);
17
- formData.append("password", password);
18
- let response = await fetch(root + "/login", {
19
- method: "POST",
20
- body: formData
21
- });
22
- if (response.status === 400) {
23
- incorrect_credentials = true;
24
- username = "";
25
- password = "";
26
- } else if (response.status == 200) {
27
- location.reload();
28
- }
29
- };
1
+ <script lang="ts">
2
+ import Form from "@gradio/form";
3
+ import { BaseTextbox as Textbox } from "@gradio/textbox";
4
+ import { BaseButton } from "@gradio/button";
5
+ import Column from "@gradio/column";
6
+ import { Block } from "@gradio/atoms";
7
+ import { _ } from "svelte-i18n";
8
+ export let root: string;
9
+ export let auth_message: string | null;
10
+ export let app_mode: boolean;
11
+ export let space_id: string | null;
12
+
13
+ let username = "";
14
+ let password = "";
15
+ let incorrect_credentials = false;
16
+
17
+ const submit = async (): Promise<void> => {
18
+ const formData = new FormData();
19
+ formData.append("username", username);
20
+ formData.append("password", password);
21
+
22
+ let response = await fetch(root + "/login", {
23
+ method: "POST",
24
+ body: formData
25
+ });
26
+ if (response.status === 400) {
27
+ incorrect_credentials = true;
28
+ username = "";
29
+ password = "";
30
+ } else if (response.status == 200) {
31
+ location.reload();
32
+ }
33
+ };
30
34
  </script>
31
35
 
32
36
  <div class="wrap" class:min-h-screen={app_mode}>
@@ -1,21 +1,23 @@
1
- import { SvelteComponent } from "svelte";
2
- declare const __propDef: {
3
- props: {
4
- root: string;
5
- auth_message: string | null;
6
- app_mode: boolean;
7
- space_id: string | null;
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;
8
11
  };
9
- events: {
10
- [evt: string]: CustomEvent<any>;
11
- };
12
- slots: {};
13
- exports?: {} | undefined;
14
- bindings?: string | undefined;
15
- };
16
- export type LoginProps = typeof __propDef.props;
17
- export type LoginEvents = typeof __propDef.events;
18
- export type LoginSlots = typeof __propDef.slots;
19
- export default class Login extends SvelteComponent<LoginProps, LoginEvents, LoginSlots> {
12
+ z_$$bindings?: Bindings;
20
13
  }
21
- export {};
14
+ declare const Login: $$__sveltets_2_IsomorphicComponent<{
15
+ root: string;
16
+ auth_message: string | null;
17
+ app_mode: boolean;
18
+ space_id: string | null;
19
+ }, {
20
+ [evt: string]: CustomEvent<any>;
21
+ }, {}, {}, string>;
22
+ type Login = InstanceType<typeof Login>;
23
+ export default Login;
@@ -1,28 +1,22 @@
1
- <script>import { onMount, createEventDispatcher } from "svelte";
2
- import Render from "./Render.svelte";
3
- export let rootNode;
4
- export let root;
5
- export let target;
6
- export let theme_mode;
7
- export let version;
8
- export let autoscroll;
9
- export let max_file_size = null;
10
- export let client;
11
- const dispatch = createEventDispatcher();
12
- onMount(() => {
13
- dispatch("mount");
14
- });
1
+ <script lang="ts">
2
+ import Self from "./MountComponents.svelte";
3
+ let { node } = $props();
4
+
5
+ let component = $derived(await node.component);
15
6
  </script>
16
7
 
17
- {#if rootNode}
18
- <Render
19
- node={rootNode}
20
- {root}
21
- {target}
22
- {theme_mode}
23
- {version}
24
- {autoscroll}
25
- {max_file_size}
26
- {client}
27
- />
8
+ {#if node && component}
9
+ {#if node.props.shared_props.visible}
10
+ <svelte:component
11
+ this={component.default}
12
+ shared_props={node.props.shared_props}
13
+ props={node.props.props}
14
+ >
15
+ {#if node.children && node.children.length}
16
+ {#each node.children as _node}
17
+ <Self node={_node} />
18
+ {/each}
19
+ {/if}
20
+ </svelte:component>
21
+ {/if}
28
22
  {/if}
@@ -1,28 +1,5 @@
1
- import { SvelteComponent } from "svelte";
2
- import type { Client } from "@gradio/client";
3
- declare const __propDef: {
4
- props: {
5
- rootNode: any;
6
- root: any;
7
- target: any;
8
- theme_mode: any;
9
- version: any;
10
- autoscroll: boolean;
11
- max_file_size?: number | null;
12
- client: Client;
13
- };
14
- events: {
15
- mount?: CustomEvent<undefined> | undefined;
16
- } & {
17
- [evt: string]: CustomEvent<any>;
18
- };
19
- slots: {};
20
- exports?: {} | undefined;
21
- bindings?: string | undefined;
22
- };
23
- export type MountComponentsProps = typeof __propDef.props;
24
- export type MountComponentsEvents = typeof __propDef.events;
25
- export type MountComponentsSlots = typeof __propDef.slots;
26
- export default class MountComponents extends SvelteComponent<MountComponentsProps, MountComponentsEvents, MountComponentsSlots> {
27
- }
28
- export {};
1
+ declare const MountComponents: import("svelte").Component<{
2
+ node: any;
3
+ }, {}, "">;
4
+ type MountComponents = ReturnType<typeof MountComponents>;
5
+ export default MountComponents;
@@ -7,6 +7,8 @@ export interface UpdateTransaction {
7
7
  value: any;
8
8
  prop: string;
9
9
  }
10
+ type set_data_type = (data: Record<string, unknown>) => void;
11
+ type get_data_type = () => Promise<Record<string, unknown>>;
10
12
  /**
11
13
  * Create a store with the layout and a map of targets
12
14
  * @returns A store with the layout and a map of targets
@@ -16,13 +18,12 @@ export declare function create_components({ initial_layout }?: {
16
18
  }): {
17
19
  layout: Writable<ComponentMeta>;
18
20
  targets: Writable<TargetMap>;
19
- update_value: (updates: UpdateTransaction[]) => void;
20
- get_data: (id: number) => any | Promise<any>;
21
+ get_data: (id: number) => Promise<unknown> | void;
22
+ set_data: (id: number, data: Record<string, unknown>) => void;
21
23
  modify_stream: (id: number, state: "open" | "waiting" | "closed") => void;
22
24
  get_stream_state: (id: number) => "open" | "waiting" | "closed" | "not_set";
23
25
  set_time_limit: (id: number, time_limit: number | undefined) => void;
24
26
  loading_status: ReturnType<typeof create_loading_status_store>;
25
- scheduled_updates: Writable<boolean>;
26
27
  create_layout: (args: {
27
28
  app: client_return;
28
29
  components: ComponentMeta[];
@@ -40,7 +41,7 @@ export declare function create_components({ initial_layout }?: {
40
41
  root: string;
41
42
  dependencies: Dependency[];
42
43
  }) => void;
43
- value_change: (cb: (id: number, value: any) => void) => void;
44
+ register_component: (id: number, set: set_data_type, get: get_data_type) => void;
44
45
  };
45
46
  /** An async version of 'new Function' */
46
47
  export declare const AsyncFunction: new (...args: string[]) => (...args: any[]) => Promise<any>;