Skip to content
Open
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
53 changes: 37 additions & 16 deletions src/sections/Community/Web-based-from/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -18,29 +18,50 @@ const validateEmail = (value) => {
return error;
};


const validatePictureUrl = (value) => {
let error;
if (value) {

if (value.startsWith("data:")) {
error = "Data URIs are not allowed. Please provide a URL, starting with http:// or https:// to an image file.";
} else {
try {
new URL(value);
const allowedImageExtensions = ["jpg", "jpeg", "png", "webp", "svg", "gif"];
const extension = value.split(".").pop().toLowerCase();
if (!allowedImageExtensions.includes(extension)) {
error = "URL must point to an image file (jpg, jpeg, png, svg, webp or gif).";
}
} catch (err) {
console.error("Error in validatePictureUrl:", err);
return "Please enter a URL to an image file.";
}
if (!value) return error;

// Block base64 / data URIs
if (value.startsWith("data:")) {
return "Data URIs are not allowed. Please provide an image URL or Google Drive link.";
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Let's not callout Google Drive, specifically.

"Data URI" is not user-friendly language either.

We simply need to state that a hyperlink to an image is what is required.

}

const isGoogleDrive =
value.includes("drive.google.com/file/d/") ||
value.includes("drive.google.com/open?id=") ||
value.includes("drive.google.com/uc?id=");

if (isGoogleDrive) {
return error;
}
try {
new URL(value);

const allowedImageExtensions = [
"jpg",
"jpeg",
"png",
"webp",
"svg",
"gif"
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What about avif?

];

const extension = value.split(".").pop().toLowerCase();

if (!allowedImageExtensions.includes(extension)) {
error =
"URL must be an image (jpg, jpeg, png, svg, webp, gif) or a Google Drive image link.";
}
} catch (err) {
return "Please enter a valid image URL or Google Drive link.";
}

return error;
};


const WebBasedForm = () => {

const [stepNumber, setStepNumber] = useState(0);
Expand Down