Skip to content

chrismojekwu/react-smartmultiparts

Repository files navigation

react-smartmultiparts

smartmultiparts are file input components for React that return a form with specified values. Upon submission the form will pass the multipart form data into a callback function provided by you. FormOne will return a single set of input fields for a group of file types. FormTwo will return a specified set of fields for each individual file type. FormThree will return one specified set of fields for multiple files based on the file extension.

npm i react-smartmultiparts

Usage:

The FormOne component accepts a list of filetypes as a "fileTypes" prop and form fields as "fields" prop.

The FormTwo component allows you to specify an object containing the supported file types as keys and their correspending fields as an array using the "fileTypes" prop.

The FormThree component allows a user to upload multiple files. The same combination of inputs will be generated for each type of file. You can limit the amount of files using the "fileLimit" prop.

All Forms must be passed a callback function to handle the multipart data using the "cb" prop.

FormOne Example:

import {FormOne} from 'react-smartmultiparts';

const fields = ["Title", "Submitee", "Name", "Comments"];

const fileTypes = ["wav","jpg","jpeg","mp3","mp4","png", "pdf"];

const printData = (data) => { 
    console.log(data);
};

<FormOne fields={fields} fileTypes={fileTypes} cb={printData}/>

FormTwo Example:

import {FormTwo} from 'react-smartmultiparts';

const printData = (data) => { 
    console.log(data);
};

const formObj = {
    wav: ["Title", "Artist", "Comments"],
    mp3: ["Title", "Artist"],
    jpg: ["Title", "Subject", "Source"]
};

<FormTwo fileTypes={formObj} cb={printData}/>

FormThree Example:

import {FormThree} from 'react-smartmultiparts';

const printData = (data) => { 
    console.log(data);
};

const formObj = {
    wav: ["Title", "Artist", "Comments"],
    mp3: ["Title", "Artist"],
    jpg: ["Title", "Subject", "Source"]
};

<FormThree fileTypes={formObj} cb={printData} fileLimit={5}/>

Input Types Supported:

Input Type - (Field Name) - Info

Text Input - (*) - Any unlisted field value supplied will generate a text input by default.

Text Area - (comments) - Providing a "comments" field will generate a Text Area Input.

Filename - (filename) - Using "filename" as a field will generate the filename inside of the form and include it in the multipart data.

Date - (date) - Using "date" as a field will generate a date input.

Range - (range[minValue_maxValue_stepValue_label_<]) - You can generate a range field by using "range" followed by a bracket that specifies min, max, step, & label values separated by an underscore. Optionally you can include left angle bracket "<", to instruct the form to render the label before the input.

Value Checkbox - (checkbox[stringValue]) - You can generate a value checkbox by using "checkbox" followed by a value surrounded by brackets.

Query Checkbox - (checkbox, checkbox[index]) - You can generate a query checkbox by using "checkbox". You must provide a matching array of checkbox objects to correspond with the number of checkboxes you would like to generate. If using Form Two you must use "checkbox[index]", the index should correspond with the index of the checkbox object needed for that file type.

Radio Query - (radios, radios[index]) - You can generate a radio query by using "radios". You must provide a matching array of radio objects to correspond with the number of radios you would like to generate. If using Form Two you must use "radios[index]", the index should correspond with the index of the radio object needed for that file type.

A checkbox object requires 2 key value pairs:

"query", your question for the group of checkboxes.
"boxes", your options for the checkbox values;

See Below:

<FormOne ... checkboxes={...}/>
<FormTwo ... checkboxes={...}/>

Select - (select, select[index]) - You can generate a select field by using "select" in a fields array. You must provide a matching array of select objects to correspond with the number of selects you would like to generate. FormOne will render selects based on their position in the fields array and the order inside of the select objects array. If using FormTwo you must use "select[index]", the index should correspond with the index of the select object needed for that file type.

A select object requires 3 key value pairs:

"query", your question for the select.
"select", your options for the select dropdown.
"placeholder, your initial/default value.

See Below:

const selectObj = {
    query: "Whats your name?",
    select: ["Chris", "Emeka", "Maya", "Pat", "Arthur"],
    placeholder: "Choose a name"
};
const selectObj2 = {
    query: "Whats your sign?",
    select: ["Virgo", "Libra", "Cancer", "Leo", "Pisces"],
    placeholder: "Choose a sign"
>};

<FormOne ... select={[selectObj, selectObj2]}/>
<FormTwo ... select={[selectObj, selectObj2]}/>

Required Attribute

You can require applicable input types by using an exclamation point at the end of its field name string.

File Size Limit(s)

You can specify a file size limit in MB to both forms by using the "fileSize" prop. FormOne takes a single number to be applied to all file types. FormTwo takes an object of key/value pairs using the extension as a key and limit as value.

Text Config

You can supply a textConfig prop containing key/value pairs for "typeLabel", "inputLabel", "disabled", "errorMessage", "invalidExt", "logoAlt", "submitLabel", "fileSizeLabel", & "fileSizeMessage".

If the textConfig is supplied, unwanted values should be empty strings.

File Type Label

Default - Supported File Types:

File Input Label

Default - File:

Form Disable Message

Default - Thanks

Error Message

Default - Internal Error

Error Message - Unsupported Extension

Default - Invalid Extension

Logo Alt

Default - Company Logo

Submit Label

Default - Submit

File Size Label

Default - File Size Limit:

File Size Over Limit Message

Default - File Over Limit - ${fileSizeProp} MB

Styling:

Logo -

You can provide a "logo" prop using a path to an image of your choice. That element can be styled using the "form-logo-img" class selector.

You can style the various aspects of the form using CSS Class selectors.

Body/Container - .form-body

File List - .form-file-list

File Size Limit(s) - .form-file-limits

Logo - .form-logo-img

File Input - .form-fileinput

Labels - .form-label

Filename - .form-filename

Comments - .form-text-area

Text Input - .form-text-input

Select Element - .form-select

Select Options - .form-select-option

Date Input - .form-date-input

Range Input - .form-range-input

Range Value - .form-range-value

Value Checkbox - .form-checkbox

Value Checkbox Label - .form-checkbox-label

Query Checkbox Question - .form-checkbox-object-query

Query Checkbox Input Div - .form-checkbox-object-input-div

Query Checkbox Checkbox - .form-checkbox-object-checkbox

Query Checkbox Label - .form-checkbox-object-label

Radio Query - .form-radio-query

Radio Input Div - .form-radio-input-div

Radio Input - .form-radio-radio

Submit Button - .form-button

About

Form generating file upload components for React

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published