mirror of
https://github.com/overleaf/overleaf.git
synced 2024-12-15 15:40:56 -05:00
edf2c68c51
[web] Use importedAt timestamp for linked files if present GitOrigin-RevId: 2132dfede83778a018e02fdba3d40180838f37af
31 lines
1.2 KiB
TypeScript
31 lines
1.2 KiB
TypeScript
import { FileRef } from '../../../../../types/file-ref'
|
|
import { BinaryFile } from '@/features/file-view/types/binary-file'
|
|
|
|
export function convertFileRefToBinaryFile(fileRef: FileRef): BinaryFile {
|
|
const timestamp = fileRef.linkedFileData?.importedAt ?? fileRef.created
|
|
return {
|
|
_id: fileRef._id,
|
|
name: fileRef.name,
|
|
id: fileRef._id,
|
|
type: 'file',
|
|
selected: true,
|
|
linkedFileData: fileRef.linkedFileData,
|
|
created: timestamp ? new Date(timestamp) : new Date(),
|
|
hash: fileRef.hash,
|
|
}
|
|
}
|
|
|
|
// `FileViewHeader`, which is TypeScript, expects a BinaryFile, which has a
|
|
// `created` property of type `Date`, while `TPRFileViewInfo`, written in JS,
|
|
// into which `FileViewHeader` passes its BinaryFile, expects a file object with
|
|
// `created` property of type `string`, which is a mismatch. `TPRFileViewInfo`
|
|
// is the only one making runtime complaints and it seems that other uses of
|
|
// `FileViewHeader` pass in a string for `created`, so that's what this function
|
|
// does too.
|
|
export function fileViewFile(fileRef: FileRef) {
|
|
const converted = convertFileRefToBinaryFile(fileRef)
|
|
return {
|
|
...converted,
|
|
created: converted.created.toISOString(),
|
|
}
|
|
}
|