From 60e48a82e0673394b27496dfd5ede83985a80148 Mon Sep 17 00:00:00 2001 From: Vjacheslav Trushkin Date: Fri, 14 May 2021 22:29:43 +0300 Subject: [PATCH] Render Svelte component immediately if icon data is available, fix typos in Svelte component's package.json --- packages/svelte/package.json | 6 +++--- packages/svelte/src/Icon.svelte | 4 ++-- packages/svelte/src/functions.ts | 4 +++- 3 files changed, 8 insertions(+), 6 deletions(-) diff --git a/packages/svelte/package.json b/packages/svelte/package.json index e7f55ee..af625e9 100644 --- a/packages/svelte/package.json +++ b/packages/svelte/package.json @@ -12,9 +12,9 @@ "directory": "packages/svelte" }, "svelte": "dist/Icon.svelte", - "module": "dist/bundle.mjs", - "main": "dist/bundle.js", - "types": "dist/bundle.d.ts", + "module": "dist/index.mjs", + "main": "dist/index.js", + "types": "dist/index.d.ts", "scripts": { "build": "node build", "build:tsc": "tsc -b", diff --git a/packages/svelte/src/Icon.svelte b/packages/svelte/src/Icon.svelte index e792885..70012af 100644 --- a/packages/svelte/src/Icon.svelte +++ b/packages/svelte/src/Icon.svelte @@ -63,8 +63,8 @@ export { // Generate data $: { counter; - const iconData = checkIconState($$props.icon, state, loaded, $$props.onLoad); - data = mounted && iconData ? generateIcon(iconData.data, $$props) : null; + const iconData = checkIconState($$props.icon, state, mounted, loaded, $$props.onLoad); + data = iconData ? generateIcon(iconData.data, $$props) : null; if (data && iconData.classes) { // Add classes data.attributes['class'] = (typeof $$props['class'] === 'string' ? $$props['class'] + ' ' : '') + iconData.classes.join(' '); diff --git a/packages/svelte/src/functions.ts b/packages/svelte/src/functions.ts index 54ec884..0a2deb6 100644 --- a/packages/svelte/src/functions.ts +++ b/packages/svelte/src/functions.ts @@ -330,6 +330,7 @@ export interface CheckIconStateResult { export function checkIconState( icon: string | IconifyIcon, state: IconState, + mounted: boolean, callback: IconStateCallback, onload?: IconifyIconOnLoad ): CheckIconStateResult | null { @@ -367,7 +368,8 @@ export function checkIconState( const data = getIconData(iconName); if (data === null) { // Icon needs to be loaded - if (!state.loading || state.loading.name !== icon) { + // Do not load icon until component is mounted + if (mounted && (!state.loading || state.loading.name !== icon)) { // New icon to load abortLoading(); state.name = '';