1
0
Fork 0
mirror of https://github.com/immich-app/immich.git synced 2025-01-04 02:46:47 +01:00

feat(web): support uploading Insta360 file format (#2725)

Insta360 "raw" formats `insv` and `insp` are actually
mp4 (video) and jpeg (picture) respectively.
However, we don't want user to rename the original files,
because they follow Insta360 convention, which is required
by Insta360 Studio.
This commit is contained in:
TruongSinh Tran-Nguyen 2023-06-12 08:29:03 -05:00 committed by GitHub
parent e101e40c47
commit 48492b9f4e
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 11 additions and 1 deletions

View file

@ -47,6 +47,12 @@ class FileHelper {
case 'webm': case 'webm':
return {"type": "video", "subType": "webm"}; return {"type": "video", "subType": "webm"};
case 'insp':
return {"type": "image", "subType": "jpeg"};
case 'insv':
return {"type": "video", "subType": "mp4"};
default: default:
return {"type": "unsupport", "subType": "unsupport"}; return {"type": "unsupport", "subType": "unsupport"};
} }

View file

@ -146,6 +146,10 @@ export function getFileMimeType(file: File): string {
return 'image/x-fuji-raf'; return 'image/x-fuji-raf';
case 'srw': case 'srw':
return 'image/x-samsung-srw'; return 'image/x-samsung-srw';
case 'insp':
return 'image/jpeg';
case 'insv':
return 'video/mp4';
default: default:
return ''; return '';
} }

View file

@ -22,7 +22,7 @@ export const openFileUploadDialog = async (
// When adding a content type that is unsupported by browsers, make sure // When adding a content type that is unsupported by browsers, make sure
// to also add it to getFileMimeType() otherwise the upload will fail. // to also add it to getFileMimeType() otherwise the upload will fail.
fileSelector.accept = 'image/*,video/*,.heic,.heif,.dng,.3gp,.nef,.srw,.raf'; fileSelector.accept = 'image/*,video/*,.heic,.heif,.dng,.3gp,.nef,.srw,.raf,.insp,.insv';
fileSelector.onchange = async (e: Event) => { fileSelector.onchange = async (e: Event) => {
const target = e.target as HTMLInputElement; const target = e.target as HTMLInputElement;