your personal website on atproto - mirror blento.app
at button 88 lines 3.4 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'; 34import { ButtonCardDefinition } from './ButtonCard'; 35// import { Model3DCardDefinition } from './Model3DCard'; 36 37export const AllCardDefinitions = [ 38 ButtonCardDefinition, 39 ImageCardDefinition, 40 VideoCardDefinition, 41 TextCardDefinition, 42 LinkCardDefinition, 43 BigSocialCardDefinition, 44 UpdatedBlentosCardDefitition, 45 YoutubeCardDefinition, 46 BlueskyPostCardDefinition, 47 LatestBlueskyPostCardDefinition, 48 LivestreamCardDefitition, 49 LivestreamEmbedCardDefitition, 50 EmbedCardDefinition, 51 MapCardDefinition, 52 ATProtoCollectionsCardDefinition, 53 SectionCardDefinition, 54 BlueskyMediaCardDefinition, 55 DinoGameCardDefinition, 56 BlueskyProfileCardDefinition, 57 GithubProfileCardDefitition, 58 TetrisCardDefinition, 59 FluidTextCardDefinition, 60 GifCardDefinition, 61 PopfeedReviewsCardDefinition, 62 TealFMPlaysCardDefinition, 63 PhotoGalleryCardDefinition, 64 StandardSiteDocumentListCardDefinition, 65 StatusphereCardDefinition, 66 EventCardDefinition, 67 VCardCardDefinition, 68 DrawCardDefinition, 69 TimerCardDefinition, 70 SpotifyCardDefinition 71 // Model3DCardDefinition 72] as const; 73 74export const CardDefinitionsByType = AllCardDefinitions.reduce( 75 (acc, item) => { 76 acc[item.type] = item; 77 return acc; 78 }, 79 {} as Record<string, CardDefinition> 80); 81 82export function getColor(item: Item): string { 83 if (item.color) return item.color; 84 85 const cardDefColor = CardDefinitionsByType[item.cardType]?.defaultColor; 86 87 return cardDefColor || 'base'; 88}