From 751dc4aedb26117d5396bff9cb449794e09f784a Mon Sep 17 00:00:00 2001 From: sua yoo Date: Thu, 12 Dec 2024 10:10:50 -0800 Subject: [PATCH] simplify thumbnails --- .../collections/collection-metadata-dialog.ts | 6 ++- .../collections/collection-replay-dialog.ts | 20 +++---- .../collections/collection-thumbnail.ts | 50 +++++++++-------- .../features/collections/collections-grid.ts | 4 +- .../features/collections/share-collection.ts | 54 ++++++++++--------- frontend/src/pages/org/collection-detail.ts | 8 ++- frontend/src/types/collection.ts | 1 + 7 files changed, 77 insertions(+), 66 deletions(-) diff --git a/frontend/src/features/collections/collection-metadata-dialog.ts b/frontend/src/features/collections/collection-metadata-dialog.ts index 2727f59589..ea7fd7326d 100644 --- a/frontend/src/features/collections/collection-metadata-dialog.ts +++ b/frontend/src/features/collections/collection-metadata-dialog.ts @@ -208,7 +208,7 @@ export class CollectionMetadataDialog extends BtrixElement { this.selectCollectionAccess?.value || this.collection?.access || CollectionAccess.Private, - defaultThumbnailName: DEFAULT_THUMBNAIL.fileName, + defaultThumbnailName: DEFAULT_THUMBNAIL.name, }); let path = `/orgs/${this.orgId}/collections`; let method = "POST"; @@ -229,7 +229,9 @@ export class CollectionMetadataDialog extends BtrixElement { }) as CollectionSavedEvent, ); this.notify.toast({ - message: msg(str`"${data.name || name}" metadata updated`), + message: this.collection + ? msg(str`"${data.name || name}" metadata updated`) + : msg(str`Created "${data.name || name}" collection`), variant: "success", icon: "check2-circle", id: "collection-metadata-status", diff --git a/frontend/src/features/collections/collection-replay-dialog.ts b/frontend/src/features/collections/collection-replay-dialog.ts index 9bc8cc2b42..8c0ec09521 100644 --- a/frontend/src/features/collections/collection-replay-dialog.ts +++ b/frontend/src/features/collections/collection-replay-dialog.ts @@ -4,6 +4,7 @@ import { serialize } from "@shoelace-style/shoelace/dist/utilities/form.js"; import { html, nothing, type PropertyValues } from "lit"; import { customElement, property, query, state } from "lit/decorators.js"; import { when } from "lit/directives/when.js"; +import queryString from "query-string"; import { CollectionThumbnail, Thumbnail } from "./collection-thumbnail"; import type { SelectSnapshotDetail } from "./select-collection-start-page"; @@ -245,12 +246,19 @@ export class CollectionStartPageDialog extends BtrixElement { private renderReplay() { const replaySource = `/api/orgs/${this.orgId}/collections/${this.collectionId}/replay.json`; + // TODO Get query from replay-web-page embed + const query = queryString.stringify({ + source: replaySource, + customColl: this.collectionId, + embed: "default", + noCache: 1, + }); return html`
`; @@ -271,16 +279,10 @@ export class CollectionStartPageDialog extends BtrixElement { }); const shouldUpload = homeView === HomeView.URL && useThumbnail === "on"; - const { fileName } = CollectionThumbnail.Variants[Thumbnail.Custom]; + const { name: fileName } = CollectionThumbnail.Variants[Thumbnail.Custom]; let file: File | undefined; if (shouldUpload && this.thumbnailPreview?.src) { - this.notify.toast({ - message: msg("Updating collection thumbnail..."), - variant: "info", - icon: "hourglass-split", - }); - // Wait to get the thumbnail image before closing the dialog try { const resp = await this.thumbnailPreview.contentWindow!.fetch( @@ -347,7 +349,7 @@ export class CollectionStartPageDialog extends BtrixElement { `/orgs/${this.orgId}/collections/${this.collectionId}`, { method: "PATCH", - body: JSON.stringify({ defaultThumbnailName: fileName }), + body: JSON.stringify({ defaultThumbnailName: null }), }, ); diff --git a/frontend/src/features/collections/collection-thumbnail.ts b/frontend/src/features/collections/collection-thumbnail.ts index 79c446a689..be0069c101 100644 --- a/frontend/src/features/collections/collection-thumbnail.ts +++ b/frontend/src/features/collections/collection-thumbnail.ts @@ -13,36 +13,34 @@ export enum Thumbnail { Green = "thumbnail-green", Orange = "thumbnail-orange", Yellow = "thumbnail-yellow", - Custom = "thumbnail-custom", + // Custom = "thumbnail-custom", } @localized() @customElement("btrix-collection-thumbnail") export class CollectionThumbnail extends BtrixElement { - static readonly Variants: Record< - Thumbnail, - { fileName: string; src?: string } - > = { - [Thumbnail.Cyan]: { - fileName: `${Thumbnail.Cyan}.avif`, - src: thumbnailCyanSrc, - }, - [Thumbnail.Green]: { - fileName: `${Thumbnail.Green}.avif`, - src: thumbnailGreenSrc, - }, - [Thumbnail.Orange]: { - fileName: `${Thumbnail.Orange}.avif`, - src: thumbnailOrangeSrc, - }, - [Thumbnail.Yellow]: { - fileName: `${Thumbnail.Yellow}.avif`, - src: thumbnailYellowSrc, - }, - [Thumbnail.Custom]: { - fileName: `${Thumbnail.Custom}.jpeg`, - }, - }; + static readonly Variants: Record = + { + [Thumbnail.Cyan]: { + name: `${Thumbnail.Cyan}.avif`, + path: thumbnailCyanSrc, + }, + [Thumbnail.Green]: { + name: `${Thumbnail.Green}.avif`, + path: thumbnailGreenSrc, + }, + [Thumbnail.Orange]: { + name: `${Thumbnail.Orange}.avif`, + path: thumbnailOrangeSrc, + }, + [Thumbnail.Yellow]: { + name: `${Thumbnail.Yellow}.avif`, + path: thumbnailYellowSrc, + }, + // [Thumbnail.Custom]: { + // name: `${Thumbnail.Custom}.jpeg`, + // }, + }; @property({ type: String }) src?: string; @@ -51,7 +49,7 @@ export class CollectionThumbnail extends BtrixElement { return html` `; } diff --git a/frontend/src/features/collections/collections-grid.ts b/frontend/src/features/collections/collections-grid.ts index 6895cc7325..cc7b15cfc0 100644 --- a/frontend/src/features/collections/collections-grid.ts +++ b/frontend/src/features/collections/collections-grid.ts @@ -72,9 +72,9 @@ export class CollectionsGrid extends BtrixElement { src=${ifDefined( collection.thumbnail?.path || Object.values(CollectionThumbnail.Variants).find( - ({ fileName }) => + ({ name: fileName }) => fileName === collection.defaultThumbnailName, - )?.src, + )?.path, )} > ${this.renderDateBadge(collection)} diff --git a/frontend/src/features/collections/share-collection.ts b/frontend/src/features/collections/share-collection.ts index e11ea4e4e7..a30bac92d7 100644 --- a/frontend/src/features/collections/share-collection.ts +++ b/frontend/src/features/collections/share-collection.ts @@ -20,7 +20,11 @@ import { SelectCollectionAccess } from "./select-collection-access"; import { BtrixElement } from "@/classes/BtrixElement"; import { ClipboardController } from "@/controllers/clipboard"; import { RouteNamespace } from "@/routes"; -import { CollectionAccess, type Collection } from "@/types/collection"; +import { + CollectionAccess, + PublicCollection, + type Collection, +} from "@/types/collection"; import { tw } from "@/utils/tailwind"; export type SelectVisibilityDetail = { @@ -28,7 +32,7 @@ export type SelectVisibilityDetail = { }; export type SelectThumbnailDetail = { - fileName: string; + defaultThumbnailName: Thumbnail | null; }; /** @@ -258,47 +262,47 @@ export class ShareCollection extends BtrixElement { } private renderThumbnails() { - let selectedImgSrc = DEFAULT_THUMBNAIL.src; + let selectedImgSrc = DEFAULT_THUMBNAIL.path; - if ( - this.collection?.defaultThumbnailName === - CollectionThumbnail.Variants[Thumbnail.Custom].fileName && - this.collection.thumbnail - ) { - selectedImgSrc = this.collection.thumbnail.path; - } else if (this.collection?.defaultThumbnailName) { + if (this.collection?.defaultThumbnailName) { const { defaultThumbnailName } = this.collection; const thumbnail = Object.values(CollectionThumbnail.Variants).find( - ({ fileName }) => fileName === defaultThumbnailName, + ({ name }) => name === defaultThumbnailName, ); if (thumbnail) { - selectedImgSrc = thumbnail.src; + selectedImgSrc = thumbnail.path; } + } else if (this.collection?.thumbnail) { + selectedImgSrc = this.collection.thumbnail.path; } - const thumbnail = (thumbnail: Thumbnail) => { - const variant = CollectionThumbnail.Variants[thumbnail]; - const { fileName } = variant; - let { src } = variant; + const thumbnail = ( + thumbnail: Thumbnail | NonNullable, + ) => { + let name: Thumbnail | null = null; + let path = ""; - if (thumbnail === Thumbnail.Custom) { - src = this.collection?.thumbnail?.path; + if (Object.values(Thumbnail).some((t) => t === thumbnail)) { + name = thumbnail as Thumbnail; + path = CollectionThumbnail.Variants[name].path; + } else { + path = (thumbnail as NonNullable).path; } let content = html``; let tooltipContent = msg("Use thumbnail"); let classNames = ""; - if (src) { + if (path) { content = html`
- ${src === selectedImgSrc + ${path === selectedImgSrc ? html`` : nothing} @@ -319,12 +323,12 @@ export class ShareCollection extends BtrixElement { classNames, )} @click=${() => { - if (src) { + if (path) { this.dispatchEvent( new CustomEvent( "btrix-select-thumbnail", { - detail: { fileName }, + detail: { defaultThumbnailName: name }, }, ), ); @@ -341,7 +345,7 @@ export class ShareCollection extends BtrixElement { return html`
- ${when(this.collection?.thumbnail, () => thumbnail(Thumbnail.Custom))} + ${when(this.collection?.thumbnail, (t) => thumbnail(t))} ${thumbnail(Thumbnail.Cyan)} ${thumbnail(Thumbnail.Green)} ${thumbnail(Thumbnail.Yellow)} ${thumbnail(Thumbnail.Orange)}
diff --git a/frontend/src/pages/org/collection-detail.ts b/frontend/src/pages/org/collection-detail.ts index 200f30392f..73ffbc278e 100644 --- a/frontend/src/pages/org/collection-detail.ts +++ b/frontend/src/pages/org/collection-detail.ts @@ -151,7 +151,7 @@ export class CollectionDetail extends BtrixElement { e: CustomEvent, ) => { e.stopPropagation(); - void this.updateThumbnail(e.detail.fileName); + void this.updateThumbnail(e.detail); }} > ${when(this.isCrawler, this.renderActions)} @@ -777,7 +777,11 @@ export class CollectionDetail extends BtrixElement { } } - async updateThumbnail(defaultThumbnailName: string) { + async updateThumbnail({ + defaultThumbnailName, + }: { + defaultThumbnailName: string; + }) { const prevValue = this.collection?.defaultThumbnailName; // Optimistic update diff --git a/frontend/src/types/collection.ts b/frontend/src/types/collection.ts index 26986eb8bc..eec5456fcb 100644 --- a/frontend/src/types/collection.ts +++ b/frontend/src/types/collection.ts @@ -19,6 +19,7 @@ export const publicCollectionSchema = z.object({ .object({ name: z.string(), path: z.string().url(), + originalFilename: z.string().nullable().optional(), }) .nullable(), defaultThumbnailName: z.string().nullable(),