Skip to content

Commit

Permalink
#1133 | Handle missing or invalid media unsigned url values in create…
Browse files Browse the repository at this point in the history
…/edit form / summary page
  • Loading branch information
himeshr authored and petmongrels committed Jun 10, 2024
1 parent a0a9002 commit 4f44924
Show file tree
Hide file tree
Showing 3 changed files with 74 additions and 186 deletions.
8 changes: 6 additions & 2 deletions src/adminApp/service/MediaService.js
Original file line number Diff line number Diff line change
@@ -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;
}
}
}

Expand Down
105 changes: 33 additions & 72 deletions src/dataEntryApp/components/MediaUploader.js
Original file line number Diff line number Diff line change
@@ -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";
Expand Down Expand Up @@ -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) {
Expand Down Expand Up @@ -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 =>
Expand All @@ -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));
Expand All @@ -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`
);
}
Expand All @@ -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);
Expand All @@ -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];
Expand Down Expand Up @@ -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: (
<img
src={fileToPreview}
alt={label}
width={200}
height={200}
onClick={() => setOpenImage(fileToPreview)}
/>
),
const mediaPreviewMap = (fileToPreview, label) => ({
image: <img src={fileToPreview} alt={label} width={200} height={200} onClick={() => setOpenImage(fileToPreview)} />,
video: (
<video preload="auto" controls width={200} height={200} controlsList="nodownload">
<source src={fileToPreview} type="video/mp4" />
Expand All @@ -260,13 +214,25 @@ export const MediaUploader = ({ label, obsValue, mediaType, update, formElement

const renderMedia = fileName => {
return (
<Box
display={"flex"}
flexDirection={"row"}
alignItems={"flex-start"}
className={classes.boxStyle}
>
{mediaPreviewMap(preview[fileName])[mediaType]}
<Box display={"flex"} flexDirection={"row"} alignItems={"flex-start"} className={classes.boxStyle}>
{startsWith(preview[fileName], MissingSignedMediaMessage) ? (
<p
style={{
color: "orangered",
margin: "5px",
padding: "5px",
border: "1px solid #999",
width: "200px",
height: "200px",
textAlign: "center",
overflow: "scroll"
}}
>
{preview[fileName]}
</p>
) : (
mediaPreviewMap(preview[fileName], MissingSignedMediaMessage + fileName)[mediaType]
)}
<Button style={{ float: "left", color: "red" }} onClick={() => onDelete(fileName)}>
<CloseIcon />
</Button>
Expand All @@ -288,12 +254,7 @@ export const MediaUploader = ({ label, obsValue, mediaType, update, formElement
});
return (
<div className="imagePreviewContainer">
<ReactImageVideoLightbox
data={data}
startIndex={startIndex}
showResourceCount={true}
onCloseCallback={() => setOpenImage()}
/>
<ReactImageVideoLightbox data={data} startIndex={startIndex} showResourceCount={true} onCloseCallback={() => setOpenImage()} />
</div>
);
};
Expand Down
Loading

0 comments on commit 4f44924

Please sign in to comment.