your personal website on atproto - mirror
blento.app
1import type { Item } from '$lib/types';
2import { ATProtoCollectionsCardDefinition } from './ATProtoCollectionsCard';
3import { BigSocialCardDefinition } from './BigSocialCard';
4import { BlueskyMediaCardDefinition } from './BlueskyMediaCard';
5import { BlueskyPostCardDefinition } from './BlueskyPostCard';
6import { DinoGameCardDefinition } from './GameCards/DinoGameCard';
7import { EmbedCardDefinition } from './EmbedCard';
8import { TetrisCardDefinition } from './GameCards/TetrisCard';
9import { ImageCardDefinition } from './ImageCard';
10import { LinkCardDefinition } from './LinkCard';
11import { LivestreamCardDefitition, LivestreamEmbedCardDefitition } from './LivestreamCard';
12import { MapCardDefinition } from './MapCard';
13import { SectionCardDefinition } from './SectionCard';
14import { UpdatedBlentosCardDefitition } from './SpecialCards/UpdatedBlentos';
15import { TextCardDefinition } from './TextCard';
16import type { CardDefinition } from './types';
17import { VideoCardDefinition } from './VideoCard';
18import { YoutubeCardDefinition } from './YoutubeVideoCard';
19import { BlueskyProfileCardDefinition } from './BlueskyProfileCard';
20import { GithubProfileCardDefitition } from './GitHubProfileCard';
21import { FluidTextCardDefinition } from './FluidTextCard';
22import { GifCardDefinition } from './GIFCard';
23import { PopfeedReviewsCardDefinition } from './PopfeedReviews';
24import { TealFMPlaysCardDefinition } from './TealFMPlaysCard';
25import { PhotoGalleryCardDefinition } from './PhotoGalleryCard';
26import { StandardSiteDocumentListCardDefinition } from './StandardSiteDocumentListCard';
27import { StatusphereCardDefinition } from './StatusphereCard';
28import { EventCardDefinition } from './EventCard';
29
30export const AllCardDefinitions = [
31 ImageCardDefinition,
32 VideoCardDefinition,
33 TextCardDefinition,
34 LinkCardDefinition,
35 BigSocialCardDefinition,
36 UpdatedBlentosCardDefitition,
37 YoutubeCardDefinition,
38 BlueskyPostCardDefinition,
39 LivestreamCardDefitition,
40 LivestreamEmbedCardDefitition,
41 EmbedCardDefinition,
42 MapCardDefinition,
43 ATProtoCollectionsCardDefinition,
44 SectionCardDefinition,
45 BlueskyMediaCardDefinition,
46 DinoGameCardDefinition,
47 BlueskyProfileCardDefinition,
48 GithubProfileCardDefitition,
49 TetrisCardDefinition,
50 FluidTextCardDefinition,
51 GifCardDefinition,
52 PopfeedReviewsCardDefinition,
53 TealFMPlaysCardDefinition,
54 PhotoGalleryCardDefinition,
55 StandardSiteDocumentListCardDefinition,
56 StatusphereCardDefinition,
57 EventCardDefinition
58] as const;
59
60export const CardDefinitionsByType = AllCardDefinitions.reduce(
61 (acc, item) => {
62 acc[item.type] = item;
63 return acc;
64 },
65 {} as Record<string, CardDefinition>
66);
67
68export function getColor(item: Item): string {
69 if (item.color) return item.color;
70
71 const cardDefColor = CardDefinitionsByType[item.cardType]?.defaultColor;
72
73 return cardDefColor || 'base';
74}