verdnatura-chat/app/lib/methods/mediaPicker.ts

119 lines
3.4 KiB
TypeScript
Raw Normal View History

2022-08-23 12:00:06 +00:00
import * as FileSystem from 'expo-file-system';
import * as ImagePicker from 'expo-image-picker';
import { PermissionsAndroid } from 'react-native';
2022-09-15 13:13:02 +00:00
import * as mime from 'react-native-mime-types';
2022-08-23 12:00:06 +00:00
import { isAndroid } from './helpers';
import log from './helpers/log';
2022-09-15 17:24:30 +00:00
interface ImagePickerFile extends ImagePicker.ImageInfo {
path: string;
filename: string;
size?: number;
mime: string;
}
const handlePermission = async (): Promise<boolean> => {
if (isAndroid) {
const permissions = await PermissionsAndroid.requestMultiple([
PermissionsAndroid.PERMISSIONS.WRITE_EXTERNAL_STORAGE,
PermissionsAndroid.PERMISSIONS.CAMERA
]);
if (permissions['android.permission.CAMERA'] !== 'granted') {
return false;
}
} else {
const permission = await ImagePicker.requestCameraPermissionsAsync();
if (!permission.granted) {
return false;
}
2022-08-23 12:00:06 +00:00
}
const permission = await ImagePicker.getCameraPermissionsAsync();
if (!permission.granted) {
return false;
2022-08-23 12:00:06 +00:00
}
return true;
2022-08-23 12:00:06 +00:00
};
2022-09-15 17:24:30 +00:00
const addAdditionalPropsToFile = async (file: ImagePicker.ImageInfo) => {
const fileInfo = await FileSystem.getInfoAsync(file.uri);
const data = {
...file,
path: file.uri,
filename: `${file.uri.substring(file.uri.lastIndexOf('/') + 1)}`,
size: fileInfo.size,
mime: mime.lookup(file.uri)
};
return data;
};
const pickFromCamera = async (
allowsEditing: boolean,
2022-09-15 13:13:02 +00:00
mediaType: ImagePicker.MediaTypeOptions
2022-09-15 17:24:30 +00:00
): Promise<ImagePickerFile | null> => {
2022-08-23 12:00:06 +00:00
try {
const hasPermission = await handlePermission();
if (!hasPermission) return null;
2022-09-15 13:13:02 +00:00
const image = await ImagePicker.launchCameraAsync({
mediaTypes: mediaType,
2022-09-20 23:08:09 +00:00
quality: 0.8,
2022-08-23 12:00:06 +00:00
allowsEditing
});
2022-09-15 17:24:30 +00:00
if (!image.cancelled) return addAdditionalPropsToFile(image);
2022-08-23 12:00:06 +00:00
return null;
} catch (error) {
log(error);
return null;
}
};
2022-09-15 17:44:31 +00:00
export const pickMultipleImageAndVideoFromLibrary = async (): Promise<ImagePickerFile | ImagePickerFile[] | null> => {
try {
const result = await ImagePicker.launchImageLibraryAsync({
mediaTypes: ImagePicker.MediaTypeOptions.All,
2022-11-21 12:03:00 +00:00
quality: isAndroid ? 1 : undefined, // TODO - Apply fix for iOS processing error
allowsMultipleSelection: true
});
if (!result.cancelled) {
2022-09-15 17:44:31 +00:00
if (result.selected) {
const selectedFiles = result.selected.map(file => addAdditionalPropsToFile(file));
const files = await Promise.all(selectedFiles);
return files;
}
// @ts-ignore - The type for when returning only one file is wrong.
const selectedFile = await addAdditionalPropsToFile(result);
return [selectedFile];
}
return null;
} catch (error) {
log(error);
return null;
}
};
2022-09-15 18:25:39 +00:00
export async function pickImageFromLibrary({ animatedGif = true }: { animatedGif: boolean }): Promise<ImagePickerFile | null> {
2022-09-15 17:24:30 +00:00
try {
const image = await ImagePicker.launchImageLibraryAsync({
mediaTypes: ImagePicker.MediaTypeOptions.Images,
2022-09-20 23:08:09 +00:00
quality: animatedGif ? 1 : 0.8,
2022-09-15 18:25:39 +00:00
base64: true
2022-09-15 17:24:30 +00:00
});
2022-09-15 18:25:39 +00:00
if (!image.cancelled) {
const selectedImage = await addAdditionalPropsToFile(image);
return selectedImage;
}
2022-09-15 17:24:30 +00:00
return null;
} catch (error) {
log(error);
return null;
}
}
2022-09-20 23:08:09 +00:00
export const pickVideoFromCamera = (allowsEditing = false): Promise<ImagePickerFile | null> =>
2022-09-15 13:13:02 +00:00
pickFromCamera(allowsEditing, ImagePicker.MediaTypeOptions.Videos);
2022-09-20 23:08:09 +00:00
export const pickImageFromCamera = (allowsEditing = false): Promise<ImagePickerFile | null> =>
2022-09-15 13:13:02 +00:00
pickFromCamera(allowsEditing, ImagePicker.MediaTypeOptions.Images);