Files
AFFiNE-Mirror/blocksuite/affine/blocks/embed/src/embed-linked-doc-block/utils.ts
fundon 539b2e87ad refactor(editor): get loading icon with theme (#12079)
<!-- This is an auto-generated comment: release notes by coderabbit.ai -->
## Summary by CodeRabbit

- **New Features**
  - Introduced a unified loading spinner icon that adapts to light or dark themes automatically.

- **Refactor**
  - Streamlined loading icon usage across the app by replacing multiple theme-based icons with a single helper function for consistent and simplified icon management.

- **Chores**
  - Removed an unused dependency to improve package management.
<!-- end of auto-generated comment: release notes by coderabbit.ai -->
2025-04-30 14:42:05 +08:00

116 lines
3.5 KiB
TypeScript

import {
EmbedEdgelessIcon,
EmbedPageIcon,
getLoadingIconWith,
ReloadIcon,
} from '@blocksuite/affine-components/icons';
import {
ColorScheme,
type EmbedLinkedDocStyles,
} from '@blocksuite/affine-model';
import type { TemplateResult } from 'lit';
import {
DarkSyncedDocErrorBanner,
LightSyncedDocErrorBanner,
} from '../embed-synced-doc-block/styles.js';
import {
DarkLinkedEdgelessDeletedLargeBanner,
DarkLinkedEdgelessDeletedSmallBanner,
DarkLinkedEdgelessEmptyLargeBanner,
DarkLinkedEdgelessEmptySmallBanner,
DarkLinkedPageDeletedLargeBanner,
DarkLinkedPageDeletedSmallBanner,
DarkLinkedPageEmptyLargeBanner,
DarkLinkedPageEmptySmallBanner,
LightLinkedEdgelessDeletedLargeBanner,
LightLinkedEdgelessDeletedSmallBanner,
LightLinkedEdgelessEmptyLargeBanner,
LightLinkedEdgelessEmptySmallBanner,
LightLinkedPageDeletedLargeBanner,
LightLinkedPageDeletedSmallBanner,
LightLinkedPageEmptyLargeBanner,
LightLinkedPageEmptySmallBanner,
LinkedDocDeletedIcon,
} from './styles.js';
type EmbedCardImages = {
LoadingIcon: TemplateResult<1>;
ReloadIcon: TemplateResult<1>;
LinkedDocIcon: TemplateResult<1>;
LinkedDocDeletedIcon: TemplateResult<1>;
LinkedDocEmptyBanner: TemplateResult<1>;
LinkedDocDeletedBanner: TemplateResult<1>;
SyncedDocErrorBanner: TemplateResult<1>;
};
export function getEmbedLinkedDocIcons(
theme: ColorScheme,
editorMode: 'page' | 'edgeless',
style: (typeof EmbedLinkedDocStyles)[number]
): EmbedCardImages {
const small = style !== 'vertical';
const LoadingIcon = getLoadingIconWith(theme);
if (editorMode === 'page') {
if (theme === ColorScheme.Light) {
return {
LoadingIcon,
ReloadIcon,
LinkedDocIcon: EmbedPageIcon,
LinkedDocDeletedIcon,
LinkedDocEmptyBanner: small
? LightLinkedPageEmptySmallBanner
: LightLinkedPageEmptyLargeBanner,
LinkedDocDeletedBanner: small
? LightLinkedPageDeletedSmallBanner
: LightLinkedPageDeletedLargeBanner,
SyncedDocErrorBanner: LightSyncedDocErrorBanner,
};
} else {
return {
ReloadIcon,
LoadingIcon,
LinkedDocIcon: EmbedPageIcon,
LinkedDocDeletedIcon,
LinkedDocEmptyBanner: small
? DarkLinkedPageEmptySmallBanner
: DarkLinkedPageEmptyLargeBanner,
LinkedDocDeletedBanner: small
? DarkLinkedPageDeletedSmallBanner
: DarkLinkedPageDeletedLargeBanner,
SyncedDocErrorBanner: DarkSyncedDocErrorBanner,
};
}
} else {
if (theme === ColorScheme.Light) {
return {
ReloadIcon,
LoadingIcon,
LinkedDocIcon: EmbedEdgelessIcon,
LinkedDocDeletedIcon,
LinkedDocEmptyBanner: small
? LightLinkedEdgelessEmptySmallBanner
: LightLinkedEdgelessEmptyLargeBanner,
LinkedDocDeletedBanner: small
? LightLinkedEdgelessDeletedSmallBanner
: LightLinkedEdgelessDeletedLargeBanner,
SyncedDocErrorBanner: LightSyncedDocErrorBanner,
};
} else {
return {
ReloadIcon,
LoadingIcon,
LinkedDocIcon: EmbedEdgelessIcon,
LinkedDocDeletedIcon,
LinkedDocEmptyBanner: small
? DarkLinkedEdgelessEmptySmallBanner
: DarkLinkedEdgelessEmptyLargeBanner,
LinkedDocDeletedBanner: small
? DarkLinkedEdgelessDeletedSmallBanner
: DarkLinkedEdgelessDeletedLargeBanner,
SyncedDocErrorBanner: DarkSyncedDocErrorBanner,
};
}
}
}