your personal website on atproto - mirror blento.app
at main 72 lines 2.8 kB view raw
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'; 28 29export const AllCardDefinitions = [ 30 ImageCardDefinition, 31 VideoCardDefinition, 32 TextCardDefinition, 33 LinkCardDefinition, 34 BigSocialCardDefinition, 35 UpdatedBlentosCardDefitition, 36 YoutubeCardDefinition, 37 BlueskyPostCardDefinition, 38 LivestreamCardDefitition, 39 LivestreamEmbedCardDefitition, 40 EmbedCardDefinition, 41 MapCardDefinition, 42 ATProtoCollectionsCardDefinition, 43 SectionCardDefinition, 44 BlueskyMediaCardDefinition, 45 DinoGameCardDefinition, 46 BlueskyProfileCardDefinition, 47 GithubProfileCardDefitition, 48 TetrisCardDefinition, 49 FluidTextCardDefinition, 50 GifCardDefinition, 51 PopfeedReviewsCardDefinition, 52 TealFMPlaysCardDefinition, 53 PhotoGalleryCardDefinition, 54 StandardSiteDocumentListCardDefinition, 55 StatusphereCardDefinition 56] as const; 57 58export const CardDefinitionsByType = AllCardDefinitions.reduce( 59 (acc, item) => { 60 acc[item.type] = item; 61 return acc; 62 }, 63 {} as Record<string, CardDefinition> 64); 65 66export function getColor(item: Item): string { 67 if (item.color) return item.color; 68 69 const cardDefColor = CardDefinitionsByType[item.cardType]?.defaultColor; 70 71 return cardDefColor || 'base'; 72}