From 52499be33e95f22e79a6143791c764ea5e073220 Mon Sep 17 00:00:00 2001 From: himeshr Date: Mon, 6 May 2024 13:41:19 +0530 Subject: [PATCH] #1133 | Handle missing or invalid media unsigned url values in create/edit form / summary page --- src/adminApp/service/MediaService.js | 8 +- src/dataEntryApp/components/MediaUploader.js | 105 +++++-------- src/dataEntryApp/components/Observations.js | 147 +++++-------------- 3 files changed, 74 insertions(+), 186 deletions(-) diff --git a/src/adminApp/service/MediaService.js b/src/adminApp/service/MediaService.js index f12ec7753..53967ed41 100644 --- a/src/adminApp/service/MediaService.js +++ b/src/adminApp/service/MediaService.js @@ -1,8 +1,12 @@ import http from "../../common/utils/httpClient"; class MediaService { - static getMedia(url) { - return http.get(http.withParams(`/media/signedUrl`, { url: url })).then(res => res.data); + static async getMedia(url) { + try { + return await http.get(http.withParams(`/media/signedUrl`, { url: url })).then(res => res.data); + } catch (exception) { + return "Unable to fetch media. Value: " + url; + } } } diff --git a/src/dataEntryApp/components/MediaUploader.js b/src/dataEntryApp/components/MediaUploader.js index c6b298363..a3fc5b62f 100644 --- a/src/dataEntryApp/components/MediaUploader.js +++ b/src/dataEntryApp/components/MediaUploader.js @@ -1,5 +1,5 @@ import React, { Fragment, useEffect, useState } from "react"; -import { get, isEmpty, includes, lowerCase, isArrayLikeObject, omit } from "lodash"; +import { get, isEmpty, includes, lowerCase, isArrayLikeObject, omit, startsWith } from "lodash"; import { Box, Button, Grid, makeStyles, Typography } from "@material-ui/core"; import FormControl from "@material-ui/core/FormControl"; import http from "../../common/utils/httpClient"; @@ -51,9 +51,7 @@ const isValidFile = (allowedTypes, type) => { }; const isValidType = (formElement, type, isFile) => { - return isFile - ? isValidFile(formElement.allowedTypes, type) - : includes(type, lowerCase(formElement.getType())); + return isFile ? isValidFile(formElement.allowedTypes, type) : includes(type, lowerCase(formElement.getType())); }; function addObsResultsToPreview(observationValue, setPreview) { @@ -91,13 +89,7 @@ function invokeUpdate(update, mediaUrl) { update(mediaUrl); } -function addMediaUrlToLocalObsValue( - update, - fileName, - isMultiSelect, - localObsValue, - setLocalObsValue -) { +function addMediaUrlToLocalObsValue(update, fileName, isMultiSelect, localObsValue, setLocalObsValue) { invokeUpdate(update, fileName); if (isMultiSelect) { setLocalObsValue(locObsValue => @@ -110,13 +102,7 @@ function addMediaUrlToLocalObsValue( } } -function removeMediaUrlFromLocalObsValue( - update, - fileName, - isMultiSelect, - localObsValue, - setLocalObsValue -) { +function removeMediaUrlFromLocalObsValue(update, fileName, isMultiSelect, localObsValue, setLocalObsValue) { invokeUpdate(update, fileName); if (isMultiSelect && isArrayLikeObject(localObsValue)) { setLocalObsValue(locObsValue => locObsValue.filter(item => item !== fileName)); @@ -128,15 +114,12 @@ function removeMediaUrlFromLocalObsValue( function consolidateAlerts(etFiles, formElement, isFileDataType, alerts) { etFiles.forEach(file => { if (!isValidType(formElement, file.type, isFileDataType)) { - alerts.push( - `Selected files type not supported for file ${file.name}. Please choose proper files.\n` - ); + alerts.push(`Selected files type not supported for file ${file.name}. Please choose proper files.\n`); } if (isFileDataType && isBiggerFile(formElement, file.size)) { const oneMBInBytes = 1000000; alerts.push( - `Selected file size ${file.size / - oneMBInBytes} MB is more than the set max file size ${formElement.allowedMaxSize / + `Selected file size ${file.size / oneMBInBytes} MB is more than the set max file size ${formElement.allowedMaxSize / oneMBInBytes} MB for file ${file.name}.\n` ); } @@ -161,18 +144,10 @@ function uploadMediaAndUpdateObservationValue( .uploadFile("/web/uploadMedia", file) .then(r => { setUploadButtonClicked(oldValue => oldValue - 1); - addMediaUrlToLocalObsValue( - update, - r.data, - isMultiSelect, - localObsValue, - setLocalObsValue - ); + addMediaUrlToLocalObsValue(update, r.data, isMultiSelect, localObsValue, setLocalObsValue); }) .catch(r => { - const error = `${get(r, "response.data") || - get(r, "message") || - "Unknown error occurred while uploadButtonClicked media"}`; + const error = `${get(r, "response.data") || get(r, "message") || "Unknown error occurred while uploadButtonClicked media"}`; setUploadButtonClicked(oldValue => oldValue - 1); onDelete(file.name); alert(error); @@ -181,6 +156,7 @@ function uploadMediaAndUpdateObservationValue( }); } +const MissingSignedMediaMessage = "Unable to fetch media. Value: "; export const MediaUploader = ({ label, obsValue, mediaType, update, formElement }) => { const classes = useStyles(); const Icon = iconMap[mediaType]; @@ -216,38 +192,16 @@ export const MediaUploader = ({ label, obsValue, mediaType, update, formElement alert(alerts); return; } - uploadMediaAndUpdateObservationValue( - etFiles, - setUploadButtonClicked, - setLocalObsValue, - isMultiSelect, - localObsValue, - update, - onDelete - ); + uploadMediaAndUpdateObservationValue(etFiles, setUploadButtonClicked, setLocalObsValue, isMultiSelect, localObsValue, update, onDelete); }; const onDelete = fileName => { - removeMediaUrlFromLocalObsValue( - update, - fileName, - isMultiSelect, - localObsValue, - setLocalObsValue - ); + removeMediaUrlFromLocalObsValue(update, fileName, isMultiSelect, localObsValue, setLocalObsValue); removeFileFromPreview(fileName, preview, setPreview); }; - const mediaPreviewMap = fileToPreview => ({ - image: ( - {label} setOpenImage(fileToPreview)} - /> - ), + const mediaPreviewMap = (fileToPreview, label) => ({ + image: {label} setOpenImage(fileToPreview)} />, video: (