1
0
mirror of https://github.com/ascribe/onion.git synced 2025-01-20 09:39:53 +01:00

Merge pull request #67 from ascribe/AD-1362-implement-portfolioreview-judging-flow

Use mime types for <input>'s accept property
This commit is contained in:
Brett Sun 2015-12-14 16:32:14 +01:00
commit 33db8e2cbe
2 changed files with 20 additions and 4 deletions

View File

@ -1,5 +1,7 @@
'use strict'; 'use strict';
import MimeTypes from '../../constants/mime_types';
export const formSubmissionValidation = { export const formSubmissionValidation = {
/** /**
* Returns a boolean if there has been at least one file uploaded * Returns a boolean if there has been at least one file uploaded
@ -73,8 +75,11 @@ export function displayValidProgressFilesFilter(file) {
* @return {string} Joined string (comma-separated) of the passed-in array * @return {string} Joined string (comma-separated) of the passed-in array
*/ */
export function transformAllowedExtensionsToInputAcceptProp(allowedExtensions) { export function transformAllowedExtensionsToInputAcceptProp(allowedExtensions) {
// add a dot in front of the extension // Get the mime type of the extension if it's defined or add a dot in front of the extension
let prefixedAllowedExtensions = allowedExtensions.map((ext) => '.' + ext); // This is important for Safari as it doesn't understand just the extension.
let prefixedAllowedExtensions = allowedExtensions.map((ext) => {
return MimeTypes[ext] || ('.' + ext);
});
// generate a comma separated list to add them to the DOM element // generate a comma separated list to add them to the DOM element
// See: http://stackoverflow.com/questions/4328947/limit-file-format-when-using-input-type-file // See: http://stackoverflow.com/questions/4328947/limit-file-format-when-using-input-type-file

View File

@ -0,0 +1,11 @@
'use strict';
const MimeTypes = {
'jpg': 'image/jpeg',
'jpeg': 'image/jpeg',
'gif': 'image/gif',
'pdf': 'application/pdf',
'png': 'image/png'
};
export default MimeTypes;