File uploader is used to upload single or multiple files.
File uploader is the component that can be used to upload file(s) in your application. It consists of the conventional drag and drop method.
File uploader can be composed using two components - dropzone and file list. As the name suggests, dropzone is the area where the users can drop file(s) to upload whereas file list is a list of the files that have been dropped at the drop zone. These files can be in different states - uploaded, in progress, etc.
Dropzone component comes in 3 sizes basis on the space available.
This size should be used in cases when there are no constraints in the space available.
 
    
This size should be used when the height available is not sufficient to use the standard size.
 
    
This size should be used when the height and width available is not sufficient to use neither the standard size nor the compressed size.
 
    
Dropzone component comes in 4 states - default, active, error and disabled.
 
    
Basis on the requirement, file uploader can either -
It is suggested to use the latter so as to minimize the resource load (network calls).
To show the status of a file being uploaded, a file uploader item is used which contains information such as the file name, upload progress, any error, etc. Progress ring is used to indicate the progress.
 
    
Note: A list of file uploader items is shown using the Flat (No shadow) card component.
Using the standard drag and drop file uploader when there is no option to adjust the height dynamically converts it to the compressed variant as shown in the example.
Here the height of the card remains the same and it can accommodate a maximum of 3 file uploader items before scrolling occurs.
 
    
File uploader provides the option to indicate that a file format is not accepted or the file size exceeds the limit through different visual cues.
Note: Users can still drop the file. In that case, a file uploader item will be used to show the error as illustrated in the next section.
 
    
File uploader also provides the option to indicate that there was an error while uploading the file. These types of errors are shown using the file uploader item.
 
    
File uploader is a simple component and it does not involve processing or analyzing file(s) as a part of it. But there can be cases when you need to process or analyze the uploaded file to check whether the content of the file matches your requirement(s).
If the case arises, always process or analyze the file after an Upload, Submit, or similar action has been triggered by the users.
 
    
The state of the submit button in a form depends on whether the file will be uploaded right away on the server or if it will be uploaded after the users click on submit.
 
    
