File input
The File input component allows users to attach one file to a form field by browsing their device.
import { ... } from '@ag.ds-next/react/file-input';
<FileInput label="Passport" />
The File input component is a simple input for selecting and uploading files in a form. It is a wrapper around the native <input type="file" />
element. Use a File input component when you need to upload one file per form field or when you have multiple form fileds on a page that require one file attachment each. If you need to upload multiple attachments to one form field, use the File upload component instead.
Do
- use if only one file is being uploaded per form field
- use to conserve vertical space
- use when a drag and drop zone isn’t required
- indicate size and type requirements in the hint
Don’t
- use if the user might need to remove the file after uploading
- use if you want the file to be uploaded immediately
- use for uploading multiple files
- use if the user might benefit from a drag and drop zone
- use if it’s the only form element on the page
Hint
Use the hint
prop to provide help that’s relevant to the majority of users, like how their information will be used, or where to find it.
Don’t use long paragraphs in hint text. Screen readers read out the entire text when users interact with the form element. This could frustrate users if the text is long.
Don’t include links within hint text. While screen readers will read out the link text when describing the field, they will not tell users that the text is a link.
<FileInput label="Passport" hint="Hint text" />
Required
The required
prop can be used to indicate that user input is required on the field before a form can be submitted.
Required fields do not append ‘(optional)’ to the label and also use aria-required to indicate to screen readers that the field is required.
Hide optional label
The hideOptionalLabel
prop can be used in situations where you want to indicate to screen reader users that a field is optional but don’t want to show the ‘(optional)’ label.
The usage of hideOptionalLabel
should be reserved for inputs that filter data in a table or chart, and should never be used in standard forms for submitting information.
<Stack gap={1}> <FileInput label="Passport" required /> <FileInput label="Passport" required={false} /> <FileInput label="Passport with hideOptionalLabel" required={false} hideOptionalLabel={true} /> </Stack>
Invalid
Use the invalid
prop to indicate if the user input is invalid.
<FileInput label="Passport" invalid message="Passport must be added" required />
Accept
Use the accept
prop to guide the user toward the accepted file types. This will automatically render a hint, although you can override this by providing your own hint
.
NOTE: for security reasons you must validate the file type in your backend and not rely on frontend validation. The accept
prop does not stop users uploading other file types.
Accept with default hint
<FileInput accept="image/jpg, image/jpeg, .png" label="Upload image" />
Accept with custom hint
<FileInput accept="image/jpg, image/jpeg, image/png" hint="Files accepted: .jpg, .jpeg, .png. Max files that can be uploaded is 1." label="Upload image" />
Accept as array of file extensions
<FileInput accept={['.jpg', '.jpeg', '.png']} label="Upload image" />
Accept as array of mime types
Using an array of mime types allows you to leverage TypeScript types and autocomplete. Additionally, you can use glob selectors to provide succinct hints. e.g. here we use image/*
and the default hint includes “Any image file”.
<FileInput accept={['image/*', 'application/pdf']} label="Upload image or document" />
Related components
- File upload – The File upload component allows users to attach one or multiple files to a form via drag-and-drop or by browsing their device.