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:
parent
e101e40c47
commit
48492b9f4e
3 changed files with 11 additions and 1 deletions
|
@ -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"};
|
||||||
}
|
}
|
||||||
|
|
|
@ -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 '';
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
|
Loading…
Reference in a new issue