your personal website on atproto - mirror blento.app
at fix-build 86 lines 3.3 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 { LatestBlueskyPostCardDefinition } from './LatestBlueskyPostCard'; 7import { DinoGameCardDefinition } from './GameCards/DinoGameCard'; 8import { EmbedCardDefinition } from './EmbedCard'; 9import { TetrisCardDefinition } from './GameCards/TetrisCard'; 10import { ImageCardDefinition } from './ImageCard'; 11import { LinkCardDefinition } from './LinkCard'; 12import { LivestreamCardDefitition, LivestreamEmbedCardDefitition } from './LivestreamCard'; 13import { MapCardDefinition } from './MapCard'; 14import { SectionCardDefinition } from './SectionCard'; 15import { UpdatedBlentosCardDefitition } from './SpecialCards/UpdatedBlentos'; 16import { TextCardDefinition } from './TextCard'; 17import type { CardDefinition } from './types'; 18import { VideoCardDefinition } from './VideoCard'; 19import { YoutubeCardDefinition } from './YoutubeVideoCard'; 20import { BlueskyProfileCardDefinition } from './BlueskyProfileCard'; 21import { GithubProfileCardDefitition } from './GitHubProfileCard'; 22import { FluidTextCardDefinition } from './FluidTextCard'; 23import { GifCardDefinition } from './GIFCard'; 24import { PopfeedReviewsCardDefinition } from './PopfeedReviews'; 25import { TealFMPlaysCardDefinition } from './TealFMPlaysCard'; 26import { PhotoGalleryCardDefinition } from './PhotoGalleryCard'; 27import { StandardSiteDocumentListCardDefinition } from './StandardSiteDocumentListCard'; 28import { StatusphereCardDefinition } from './StatusphereCard'; 29import { EventCardDefinition } from './EventCard'; 30import { VCardCardDefinition } from './VCardCard'; 31import { DrawCardDefinition } from './DrawCard'; 32import { TimerCardDefinition } from './TimerCard'; 33import { SpotifyCardDefinition } from './SpotifyCard'; 34// import { Model3DCardDefinition } from './Model3DCard'; 35 36export const AllCardDefinitions = [ 37 ImageCardDefinition, 38 VideoCardDefinition, 39 TextCardDefinition, 40 LinkCardDefinition, 41 BigSocialCardDefinition, 42 UpdatedBlentosCardDefitition, 43 YoutubeCardDefinition, 44 BlueskyPostCardDefinition, 45 LatestBlueskyPostCardDefinition, 46 LivestreamCardDefitition, 47 LivestreamEmbedCardDefitition, 48 EmbedCardDefinition, 49 MapCardDefinition, 50 ATProtoCollectionsCardDefinition, 51 SectionCardDefinition, 52 BlueskyMediaCardDefinition, 53 DinoGameCardDefinition, 54 BlueskyProfileCardDefinition, 55 GithubProfileCardDefitition, 56 TetrisCardDefinition, 57 FluidTextCardDefinition, 58 GifCardDefinition, 59 PopfeedReviewsCardDefinition, 60 TealFMPlaysCardDefinition, 61 PhotoGalleryCardDefinition, 62 StandardSiteDocumentListCardDefinition, 63 StatusphereCardDefinition, 64 EventCardDefinition, 65 VCardCardDefinition, 66 DrawCardDefinition, 67 TimerCardDefinition, 68 SpotifyCardDefinition 69 // Model3DCardDefinition 70] as const; 71 72export const CardDefinitionsByType = AllCardDefinitions.reduce( 73 (acc, item) => { 74 acc[item.type] = item; 75 return acc; 76 }, 77 {} as Record<string, CardDefinition> 78); 79 80export function getColor(item: Item): string { 81 if (item.color) return item.color; 82 83 const cardDefColor = CardDefinitionsByType[item.cardType]?.defaultColor; 84 85 return cardDefColor || 'base'; 86}