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