diff --git a/bun.lockb b/bun.lockb index 2d94931965..447149b32e 100755 Binary files a/bun.lockb and b/bun.lockb differ diff --git a/package.json b/package.json index 29da9ba4b5..a6d8c18d77 100644 --- a/package.json +++ b/package.json @@ -20,7 +20,7 @@ ], "dependencies": { "@geist-ui/icons": "^1.0.2", - "@gitbook/api": "^0.36.0", + "@gitbook/api": "^0.38.0", "@radix-ui/react-checkbox": "^1.0.4", "@radix-ui/react-popover": "^1.0.7", "@sentry/nextjs": "^7.94.1", diff --git a/src/components/DocumentView/BlockSyncedBlock.tsx b/src/components/DocumentView/BlockSyncedBlock.tsx index 2bc64baaa5..3cdd21229b 100644 --- a/src/components/DocumentView/BlockSyncedBlock.tsx +++ b/src/components/DocumentView/BlockSyncedBlock.tsx @@ -1,6 +1,7 @@ import { DocumentBlockSyncedBlock } from '@gitbook/api'; import { getSyncedBlock } from '@/lib/api'; +import { resolveContentRefWithFiles } from '@/lib/references'; import { BlockProps } from './Block'; import { Blocks } from './Blocks'; @@ -13,22 +14,34 @@ export async function BlockSyncedBlock(props: BlockProps { + if (!syncedBlock?.files) { + return context.resolveContentRef(ref, options); + } + const result = resolveContentRefWithFiles(syncedBlock.files, ref); + if (result !== undefined) { + return result; + } + return context.resolveContentRef(ref, options); + }, + }} style={style} /> ); diff --git a/src/components/DocumentView/Drawing.tsx b/src/components/DocumentView/Drawing.tsx index b4adf477a9..1b0d83d404 100644 --- a/src/components/DocumentView/Drawing.tsx +++ b/src/components/DocumentView/Drawing.tsx @@ -19,7 +19,7 @@ export async function Drawing(props: BlockProps) { sources={{ light: { src: resolved.href, - size: resolved.fileDimensions, + size: resolved.file?.dimensions, }, }} alt="Drawing" diff --git a/src/components/DocumentView/File.tsx b/src/components/DocumentView/File.tsx index f86d063af3..e4b99ed69f 100644 --- a/src/components/DocumentView/File.tsx +++ b/src/components/DocumentView/File.tsx @@ -4,7 +4,6 @@ import IconImage from '@geist-ui/icons/image'; import IconPaperClip from '@geist-ui/icons/paperclip'; import { DocumentBlockFile } from '@gitbook/api'; -import { getRevisionFile } from '@/lib/api'; import { tcls } from '@/lib/tailwind'; import { BlockProps } from './Block'; @@ -12,13 +11,9 @@ import { BlockProps } from './Block'; export async function File(props: BlockProps) { const { block, context, style } = props; - const file = context.content - ? await getRevisionFile( - context.content.spaceId, - context.content.revisionId, - block.data.ref.file, - ) - : null; + const contentRef = await context.resolveContentRef(block.data.ref); + const file = contentRef?.file; + if (!file) { return null; } diff --git a/src/components/DocumentView/Images.tsx b/src/components/DocumentView/Images.tsx index 1bb7d67f32..a9595dd988 100644 --- a/src/components/DocumentView/Images.tsx +++ b/src/components/DocumentView/Images.tsx @@ -89,12 +89,12 @@ async function ImageBlock(props: { sources={{ light: { src: src.href, - size: src.fileDimensions, + size: src.file?.dimensions, }, dark: darkSrc ? { src: darkSrc.href, - size: darkSrc.fileDimensions, + size: darkSrc.file?.dimensions, } : null, }} diff --git a/src/components/DocumentView/InlineImage.tsx b/src/components/DocumentView/InlineImage.tsx index c3c35fbc45..799af9bcb3 100644 --- a/src/components/DocumentView/InlineImage.tsx +++ b/src/components/DocumentView/InlineImage.tsx @@ -32,12 +32,12 @@ export async function InlineImage(props: InlineProps) { sources={{ light: { src: src.href, - size: src.fileDimensions, + size: src.file?.dimensions, }, dark: darkSrc ? { src: darkSrc.href, - size: darkSrc.fileDimensions, + size: darkSrc.file?.dimensions, } : null, }} @@ -55,7 +55,7 @@ async function getImageSizes(size: 'original' | 'line', src: ResolvedContentRef) switch (size) { case 'line': { const imageSize = - src.fileDimensions ?? + src.file?.dimensions ?? (await getImageSize(src.href, { dpr: 3, })); diff --git a/src/components/DocumentView/Table/RecordCard.tsx b/src/components/DocumentView/Table/RecordCard.tsx index c79f772b83..7658891d60 100644 --- a/src/components/DocumentView/Table/RecordCard.tsx +++ b/src/components/DocumentView/Table/RecordCard.tsx @@ -52,7 +52,7 @@ export async function RecordCard( sources={{ light: { src: cover.href, - size: cover.fileDimensions, + size: cover.file?.dimensions, }, }} sizes={[ diff --git a/src/lib/references.ts b/src/lib/references.ts index 8c5a8bdaff..b7f6771f99 100644 --- a/src/lib/references.ts +++ b/src/lib/references.ts @@ -1,4 +1,4 @@ -import { ContentRef, Revision, RevisionPageDocument, Space } from '@gitbook/api'; +import { ContentRef, Revision, RevisionFile, RevisionPageDocument, Space } from '@gitbook/api'; import assertNever from 'assert-never'; import { @@ -24,8 +24,8 @@ export interface ResolvedContentRef { href: string; /** True if the content ref is active */ active: boolean; - /** Image size, if the reference is a image file */ - fileDimensions?: { width: number; height: number }; + /** File, if the reference is a file */ + file?: RevisionFile; } export interface ContentRefContext extends PageHrefContext { @@ -90,7 +90,7 @@ export async function resolveContentRef( href: file.downloadURL, text: file.name, active: false, - fileDimensions: file.dimensions, + file, }; } else { return null; @@ -251,3 +251,22 @@ async function resolveContentRefInSpace(spaceId: string, contentRef: ContentRef) baseUrl, }); } + +export function resolveContentRefWithFiles( + files: RevisionFile[], + contentRef: ContentRef, +): ResolvedContentRef | null | undefined { + if (contentRef.kind === 'file') { + const file = files.find((file) => file.id === contentRef.file); + if (file) { + return { + href: file.downloadURL, + text: file.name, + active: false, + file, + }; + } + return null; + } + return undefined; +}