From cd3f6348c4e918b5367587bce58d724aec44eddd Mon Sep 17 00:00:00 2001 From: Ben Holmes Date: Wed, 6 Jul 2022 16:58:28 -0400 Subject: [PATCH] Fix `client:visible` directive in safari (#3839) * fix: client visible on safari * chore: changeset * refactor: wait for children with mutation observer * fix: remove unecessary settimeout * refactor: remove unecessary awaits --- .changeset/twenty-meals-train.md | 5 +++++ .../astro/src/runtime/server/astro-island.ts | 17 +++++++++++++++-- 2 files changed, 20 insertions(+), 2 deletions(-) create mode 100644 .changeset/twenty-meals-train.md diff --git a/.changeset/twenty-meals-train.md b/.changeset/twenty-meals-train.md new file mode 100644 index 000000000..931679b8e --- /dev/null +++ b/.changeset/twenty-meals-train.md @@ -0,0 +1,5 @@ +--- +'astro': patch +--- + +Fix `client:visible` directive in safari diff --git a/packages/astro/src/runtime/server/astro-island.ts b/packages/astro/src/runtime/server/astro-island.ts index 10c69aa8e..6cb5a5339 100644 --- a/packages/astro/src/runtime/server/astro-island.ts +++ b/packages/astro/src/runtime/server/astro-island.ts @@ -41,7 +41,20 @@ declare const Astro: { public Component: any; public hydrator: any; static observedAttributes = ['props']; - async connectedCallback() { + connectedCallback() { + if(this.getAttribute('client') === 'only' || this.firstChild) { + this.childrenConnectedCallback(); + } else { + // connectedCallback may run *before* children are rendered (ex. HTML streaming) + // If SSR children are expected, but not yet rendered, + // Wait with a mutation observer + new MutationObserver((_, mo) => { + mo.disconnect(); + this.childrenConnectedCallback(); + }).observe(this, { childList: true }); + } + } + async childrenConnectedCallback() { window.addEventListener('astro:hydrate', this.hydrate); await import(this.getAttribute('before-hydration-url')!); const opts = JSON.parse(this.getAttribute('opts')!) as Record; @@ -57,7 +70,7 @@ declare const Astro: { return this.hydrate; }, opts, - this + this, ); } hydrate = () => {