mirror of
https://github.com/toeverything/AFFiNE.git
synced 2026-02-25 18:26:05 +08:00
<!-- 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 -->
116 lines
3.5 KiB
TypeScript
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,
|
|
};
|
|
}
|
|
}
|
|
}
|