From a81f0f71570d1f8ff263c80f985160d54789e69d Mon Sep 17 00:00:00 2001 From: Matthias Date: Wed, 4 Dec 2024 23:53:16 +0100 Subject: [PATCH 1/3] fix race condition in Svelte template --- ...{{pascal_case collection_name}}.svelte.hbs | 6 ++++-- ...{{pascal_case entry_type.name}}.svelte.hbs | 6 ++++-- ....svelte{{\302\241if}}{{\302\241each}}.hbs" | 7 ++++--- ...ntry_type.name}}.svelte{{\302\241if}}.hbs" | 6 ++++-- ...al_case entry_type.name}}Detail.svelte.hbs | 6 ++++-- .../svelte/example/ui/src/App.svelte.hbs | 17 +++++++++++------ ...renceable.name}}.svelte{{\302\241if}}.hbs" | 6 ++++-- ...renceable.name}}.svelte{{\302\241if}}.hbs" | 7 ++++--- .../svelte/web-app/ui/src/App.svelte.hbs | 19 +++++++++++++------ .../svelte/web-app/ui/src/contexts.ts.hbs | 8 +++++++- 10 files changed, 59 insertions(+), 29 deletions(-) diff --git a/templates/ui-frameworks/svelte/collection/ui/src/{{dna_role_name}}/{{coordinator_zome_manifest.name}}/{{pascal_case collection_name}}.svelte.hbs b/templates/ui-frameworks/svelte/collection/ui/src/{{dna_role_name}}/{{coordinator_zome_manifest.name}}/{{pascal_case collection_name}}.svelte.hbs index 5069f8c28..84c842111 100644 --- a/templates/ui-frameworks/svelte/collection/ui/src/{{dna_role_name}}/{{coordinator_zome_manifest.name}}/{{pascal_case collection_name}}.svelte.hbs +++ b/templates/ui-frameworks/svelte/collection/ui/src/{{dna_role_name}}/{{coordinator_zome_manifest.name}}/{{pascal_case collection_name}}.svelte.hbs @@ -11,11 +11,12 @@ import type { HolochainError, } from '@holochain/client'; import { SignalType } from '@holochain/client' -import { clientContext } from '../../contexts'; +import { type ClientContext, clientContext } from '../../contexts'; import {{pascal_case referenceable.name}}Detail from './{{pascal_case referenceable.name}}Detail.svelte'; import type { {{pascal_case coordinator_zome_manifest.name}}Signal } from './types'; -const client: AppClient = (getContext(clientContext) as any).getClient(); +let client: AppClient; +const appClientContext = getContext(clientContext); let hashes: Array<{{referenceable.hash_type}}> = []; let loading = false; @@ -32,6 +33,7 @@ onMount(async () => { throw new Error(`The author input is required for the {{pascal_case collection_name}} element`); } {{/if}} + client = await appClientContext.getClient(); await fetch{{pascal_case (plural referenceable.name)}}(); client.on('signal', signal => { if (!(SignalType.App in signal)) return; diff --git a/templates/ui-frameworks/svelte/entry-type/ui/src/{{dna_role_name}}/{{coordinator_zome_manifest.name}}/Create{{pascal_case entry_type.name}}.svelte.hbs b/templates/ui-frameworks/svelte/entry-type/ui/src/{{dna_role_name}}/{{coordinator_zome_manifest.name}}/Create{{pascal_case entry_type.name}}.svelte.hbs index 65a4139e3..975d1cc50 100644 --- a/templates/ui-frameworks/svelte/entry-type/ui/src/{{dna_role_name}}/{{coordinator_zome_manifest.name}}/Create{{pascal_case entry_type.name}}.svelte.hbs +++ b/templates/ui-frameworks/svelte/entry-type/ui/src/{{dna_role_name}}/{{coordinator_zome_manifest.name}}/Create{{pascal_case entry_type.name}}.svelte.hbs @@ -1,7 +1,7 @@
diff --git "a/templates/ui-frameworks/svelte/link-type/ui/src/{{dna_role_name}}/{{coordinator_zome_manifest.name}}/{{#if (and bidireccional (and to_referenceable (ne from_referenceable.hash_type 'AgentPubKey')))}}{{pascal_case (plural from_referenceable.name)}}For{{pascal_case to_referenceable.name}}.svelte{{\302\241if}}.hbs" "b/templates/ui-frameworks/svelte/link-type/ui/src/{{dna_role_name}}/{{coordinator_zome_manifest.name}}/{{#if (and bidireccional (and to_referenceable (ne from_referenceable.hash_type 'AgentPubKey')))}}{{pascal_case (plural from_referenceable.name)}}For{{pascal_case to_referenceable.name}}.svelte{{\302\241if}}.hbs" index 9aa119cc3..377df8431 100644 --- "a/templates/ui-frameworks/svelte/link-type/ui/src/{{dna_role_name}}/{{coordinator_zome_manifest.name}}/{{#if (and bidireccional (and to_referenceable (ne from_referenceable.hash_type 'AgentPubKey')))}}{{pascal_case (plural from_referenceable.name)}}For{{pascal_case to_referenceable.name}}.svelte{{\302\241if}}.hbs" +++ "b/templates/ui-frameworks/svelte/link-type/ui/src/{{dna_role_name}}/{{coordinator_zome_manifest.name}}/{{#if (and bidireccional (and to_referenceable (ne from_referenceable.hash_type 'AgentPubKey')))}}{{pascal_case (plural from_referenceable.name)}}For{{pascal_case to_referenceable.name}}.svelte{{\302\241if}}.hbs" @@ -11,11 +11,12 @@ import type { HolochainError, } from '@holochain/client'; import { SignalType } from '@holochain/client'; -import { clientContext } from '../../contexts'; +import { type ClientContext, clientContext } from '../../contexts'; import {{pascal_case from_referenceable.name}}Detail from './{{pascal_case from_referenceable.name}}Detail.svelte'; import type { {{pascal_case coordinator_zome_manifest.name}}Signal } from './types'; -const client: AppClient = (getContext(clientContext) as any).getClient(); +let client: AppClient; +const appClientContext = getContext(clientContext); let hashes: Array<{{from_referenceable.hash_type}}> | undefined; let loading = false; @@ -32,6 +33,7 @@ onMount(async () => { try { loading = true; + client = await appClientContext.getClient(); const links: Array = await client.callZome({ role_name: '{{dna_role_name}}', zome_name: '{{snake_case coordinator_zome_manifest.name}}', diff --git "a/templates/ui-frameworks/svelte/link-type/ui/src/{{dna_role_name}}/{{coordinator_zome_manifest.name}}/{{#if (and to_referenceable (ne to_referenceable.hash_type 'AgentPubKey'))}}{{pascal_case (plural to_referenceable.name)}}For{{pascal_case from_referenceable.name}}.svelte{{\302\241if}}.hbs" "b/templates/ui-frameworks/svelte/link-type/ui/src/{{dna_role_name}}/{{coordinator_zome_manifest.name}}/{{#if (and to_referenceable (ne to_referenceable.hash_type 'AgentPubKey'))}}{{pascal_case (plural to_referenceable.name)}}For{{pascal_case from_referenceable.name}}.svelte{{\302\241if}}.hbs" index f7ae2c163..636126d13 100644 --- "a/templates/ui-frameworks/svelte/link-type/ui/src/{{dna_role_name}}/{{coordinator_zome_manifest.name}}/{{#if (and to_referenceable (ne to_referenceable.hash_type 'AgentPubKey'))}}{{pascal_case (plural to_referenceable.name)}}For{{pascal_case from_referenceable.name}}.svelte{{\302\241if}}.hbs" +++ "b/templates/ui-frameworks/svelte/link-type/ui/src/{{dna_role_name}}/{{coordinator_zome_manifest.name}}/{{#if (and to_referenceable (ne to_referenceable.hash_type 'AgentPubKey'))}}{{pascal_case (plural to_referenceable.name)}}For{{pascal_case from_referenceable.name}}.svelte{{\302\241if}}.hbs" @@ -11,11 +11,12 @@ import type { HolochainError, } from '@holochain/client'; import { SignalType } from '@holochain/client'; -import { clientContext } from '../../contexts'; +import { type ClientContext, clientContext } from '../../contexts'; import {{pascal_case to_referenceable.name}}Detail from './{{pascal_case to_referenceable.name}}Detail.svelte'; import type { {{pascal_case coordinator_zome_manifest.name}}Signal } from './types'; -const client: AppClient = (getContext(clientContext) as any).getClient(); +let client: AppClient; +const appClientContext = getContext(clientContext); let hashes: Array<{{to_referenceable.hash_type}}> | undefined; let loading = false; @@ -29,7 +30,7 @@ onMount(async () => { if (!{{camel_case from_referenceable.singular_arg}}) { throw new Error(`The {{camel_case from_referenceable.singular_arg}} input is required for the {{pascal_case (plural to_referenceable.name)}}For{{pascal_case from_referenceable.name}} element`); } - + client = await appClientContext.getClient(); try { loading = true; const links: Array = await client.callZome({ diff --git a/templates/ui-frameworks/svelte/web-app/ui/src/App.svelte.hbs b/templates/ui-frameworks/svelte/web-app/ui/src/App.svelte.hbs index e2748fd01..81fc46309 100644 --- a/templates/ui-frameworks/svelte/web-app/ui/src/App.svelte.hbs +++ b/templates/ui-frameworks/svelte/web-app/ui/src/App.svelte.hbs @@ -7,7 +7,7 @@ {{/if}} import logo from './assets/holochainLogo.svg'; - import { clientContext } from './contexts'; + import { type ClientContext, clientContext } from './contexts'; {{#if holo_enabled}} const IS_HOLO = ['true', '1', 't'].includes(import.meta.env.VITE_APP_IS_HOLO?.toLowerCase()) @@ -21,6 +21,15 @@ let error: HolochainError | undefined; let loading = false; + const appClientContext = { + getClient: async () => { + if (!client) { + client = await AppWebsocket.connect(); + } + return client; + }, + }; + onMount(async () => { {{#if holo_enabled}} try { @@ -37,7 +46,7 @@ }); (client as WebSdk).signUp({ cancellable: false }); } else { - client = await AppWebsocket.connect(); + client = await appClientContext.getClient(); loading = false; } } catch (e) { @@ -48,7 +57,7 @@ {{else}} try { loading = true; - client = await AppWebsocket.connect(); + client = await appClientContext.getClient(); } catch (e) { error = e as HolochainError; } finally { @@ -57,9 +66,7 @@ {{/if}} }); - setContext(clientContext, { - getClient: () => client, - }); + setContext(clientContext, appClientContext);
diff --git a/templates/ui-frameworks/svelte/web-app/ui/src/contexts.ts.hbs b/templates/ui-frameworks/svelte/web-app/ui/src/contexts.ts.hbs index 9f41a2624..988b48279 100644 --- a/templates/ui-frameworks/svelte/web-app/ui/src/contexts.ts.hbs +++ b/templates/ui-frameworks/svelte/web-app/ui/src/contexts.ts.hbs @@ -1 +1,7 @@ -export const clientContext = 'AppClient'; \ No newline at end of file +import { type AppClient } from "@holochain/client"; + +export const clientContext = "AppClient"; + +export type ClientContext = { + getClient: () => Promise; +}; From 981b106a1e5c7bcf46a43d128645a256d6074d68 Mon Sep 17 00:00:00 2001 From: Matthias Date: Thu, 5 Dec 2024 00:26:57 +0100 Subject: [PATCH 2/3] bump incompativle vite-plugin-svelte version --- templates/ui-frameworks/svelte/web-app/ui/package.json.hbs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/templates/ui-frameworks/svelte/web-app/ui/package.json.hbs b/templates/ui-frameworks/svelte/web-app/ui/package.json.hbs index c017f761c..a401f4047 100644 --- a/templates/ui-frameworks/svelte/web-app/ui/package.json.hbs +++ b/templates/ui-frameworks/svelte/web-app/ui/package.json.hbs @@ -18,7 +18,7 @@ "@msgpack/msgpack": "^2.8.0" }, "devDependencies": { - "@sveltejs/vite-plugin-svelte": "^2.5.3", + "@sveltejs/vite-plugin-svelte": "^3.1.2", "@tsconfig/svelte": "^3.0.0", "bestzip": "^2.2.1", "rimraf": "^5.0.10", From 4434b58fef39f1f8aed04973cf4df71ca255cccb Mon Sep 17 00:00:00 2001 From: Matthias Date: Thu, 5 Dec 2024 00:35:01 +0100 Subject: [PATCH 3/3] added missing asyncs --- .../Create{{pascal_case entry_type.name}}.svelte.hbs | 2 +- ...dit{{pascal_case entry_type.name}}.svelte{{\302\241if}}.hbs" | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/templates/ui-frameworks/svelte/entry-type/ui/src/{{dna_role_name}}/{{coordinator_zome_manifest.name}}/Create{{pascal_case entry_type.name}}.svelte.hbs b/templates/ui-frameworks/svelte/entry-type/ui/src/{{dna_role_name}}/{{coordinator_zome_manifest.name}}/Create{{pascal_case entry_type.name}}.svelte.hbs index 975d1cc50..a73ccb42a 100644 --- a/templates/ui-frameworks/svelte/entry-type/ui/src/{{dna_role_name}}/{{coordinator_zome_manifest.name}}/Create{{pascal_case entry_type.name}}.svelte.hbs +++ b/templates/ui-frameworks/svelte/entry-type/ui/src/{{dna_role_name}}/{{coordinator_zome_manifest.name}}/Create{{pascal_case entry_type.name}}.svelte.hbs @@ -39,7 +39,7 @@ export let {{camel_case field_name}}{{#if (eq cardinality "single")}}!{{/if}}: { $: {{#each entry_type.fields}}{{camel_case field_name}}{{#unless @last}}, {{/unless}}{{/each}}; $: is{{pascal_case entry_type.name}}Valid = true{{#each entry_type.fields}}{{#if widget}}{{#if (eq cardinality "single")}} && {{> (concat field_type.type "/" widget "/is-valid") variable_to_validate=(camel_case field_name) }}{{/if}}{{#if (eq cardinality "vector")}} && {{camel_case field_name}}.every(e => {{> (concat field_type.type "/" widget "/is-valid") variable_to_validate="e" }}){{/if}}{{/if}}{{/each}}; -onMount(() => { +onMount(async () => { {{#each entry_type.fields}} {{#if (not widget) }} {{#if (ne cardinality "option")}} diff --git "a/templates/ui-frameworks/svelte/entry-type/ui/src/{{dna_role_name}}/{{coordinator_zome_manifest.name}}/{{#if crud.update}}Edit{{pascal_case entry_type.name}}.svelte{{\302\241if}}.hbs" "b/templates/ui-frameworks/svelte/entry-type/ui/src/{{dna_role_name}}/{{coordinator_zome_manifest.name}}/{{#if crud.update}}Edit{{pascal_case entry_type.name}}.svelte{{\302\241if}}.hbs" index 6aa20b18f..f17d6b54f 100644 --- "a/templates/ui-frameworks/svelte/entry-type/ui/src/{{dna_role_name}}/{{coordinator_zome_manifest.name}}/{{#if crud.update}}Edit{{pascal_case entry_type.name}}.svelte{{\302\241if}}.hbs" +++ "b/templates/ui-frameworks/svelte/entry-type/ui/src/{{dna_role_name}}/{{coordinator_zome_manifest.name}}/{{#if crud.update}}Edit{{pascal_case entry_type.name}}.svelte{{\302\241if}}.hbs" @@ -36,7 +36,7 @@ let {{camel_case field_name}}: Array<{{> (concat field_type.type "/type")}} | un $: {{#each (filter entry_type.fields "widget")}}{{camel_case field_name}}{{#unless @last}}, {{/unless}}{{/each}}; $: is{{pascal_case entry_type.name}}Valid = true{{#each entry_type.fields}}{{#if widget}}{{#if (eq cardinality "single")}} && {{> (concat field_type.type "/" widget "/is-valid") variable_to_validate=(camel_case field_name) }}{{/if}}{{#if (eq cardinality "vector")}} && {{camel_case field_name}}.every(e => {{> (concat field_type.type "/" widget "/is-valid") variable_to_validate="e" }}){{/if}}{{/if}}{{/each}}; -onMount(() => { +onMount(async () => { if (!currentRecord) { throw new Error(`The currentRecord input is required for the Edit{{pascal_case entry_type.name}} element`); }