From a770e55520245b7afc2b7a30aa6127eebcb6ea0d Mon Sep 17 00:00:00 2001 From: MohamedBassem Date: Sun, 22 Sep 2024 14:56:19 +0000 Subject: feature(web): Show attachments and allow users to manipulate them. --- packages/shared/types/bookmarks.ts | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) (limited to 'packages/shared') diff --git a/packages/shared/types/bookmarks.ts b/packages/shared/types/bookmarks.ts index beefbfb9..c15146f3 100644 --- a/packages/shared/types/bookmarks.ts +++ b/packages/shared/types/bookmarks.ts @@ -11,6 +11,18 @@ export const enum BookmarkTypes { UNKNOWN = "unknown", } +export const zAssetTypesSchema = z.enum([ + "screenshot", + "bannerImage", + "fullPageArchive", +]); +export type ZAssetType = z.infer; + +export const zAssetSchema = z.object({ + id: z.string(), + assetType: zAssetTypesSchema, +}); + export const zBookmarkedLinkSchema = z.object({ type: z.literal(BookmarkTypes.LINK), url: z.string().url(), @@ -63,6 +75,7 @@ export const zBookmarkSchema = zBareBookmarkSchema.merge( z.object({ tags: z.array(zBookmarkTagSchema), content: zBookmarkContentSchema, + assets: z.array(zAssetSchema), }), ); export type ZBookmark = z.infer; @@ -71,6 +84,7 @@ const zBookmarkTypeLinkSchema = zBareBookmarkSchema.merge( z.object({ tags: z.array(zBookmarkTagSchema), content: zBookmarkedLinkSchema, + assets: z.array(zAssetSchema), }), ); export type ZBookmarkTypeLink = z.infer; @@ -79,6 +93,7 @@ const zBookmarkTypeTextSchema = zBareBookmarkSchema.merge( z.object({ tags: z.array(zBookmarkTagSchema), content: zBookmarkedTextSchema, + assets: z.array(zAssetSchema), }), ); export type ZBookmarkTypeText = z.infer; @@ -87,6 +102,7 @@ const zBookmarkTypeAssetSchema = zBareBookmarkSchema.merge( z.object({ tags: z.array(zBookmarkTagSchema), content: zBookmarkedAssetSchema, + assets: z.array(zAssetSchema), }), ); export type ZBookmarkTypeAsset = z.infer; -- cgit v1.2.3-70-g09d2