easy-file-picker
v1.1.0
Published
Easy File Picker is a straightforward library with no dependencies to upload/pick/read files in the browser.
Downloads
374
Maintainers
Readme
Easy File Picker
Easy File Picker is a straightforward library with no dependencies to upload/pick/read files in the browser that can be used with any frontend framework.
Table of Contents
Install
npm install easy-file-picker
Usage
Example on how to upload a file in various javascript frameworks:
Vanila Javascript
HTML:
<button id="uploader">Upload!</button>
Javascript/TypeScript:
import { getFile, uploadFilesTo } from 'easy-file-picker';
document.querySelector("#uploader").addEventListener("click", () => getFile().then((file) => { if(file) uploadFilesTo("http://example.com", file)}));
Angular
HTML:
<button (click)="uploadFile()">Upload!</button>
TypeScript:
import { getFile, uploadFilesTo } from 'easy-file-picker';
async uploadFile(): Promise<void> {
const file = await getFile();
if(file) {
await uploadFilesTo("http://example.com", file);
}
}
React
Javascript:
import { getFile, uploadFilesTo } from 'easy-file-picker';
async uploadFile() {
const file = await getFile();
if(file) {
await uploadFilesTo("http://example.com", file);
}
}
render() {
return <button onClick={uploadFile}>Upload!</button>;
}
Vue
HTML:
<button @click="uploadFile">Upload!</button>
Javascript:
import { getFile, uploadFilesTo } from 'easy-file-picker';
methods: {
async uploadFile() {
const file = await getFile();
if(file) {
await uploadFilesTo("http://example.com", file);
}
}
}
Svelte
Svelte:
<script>
import { getFile, uploadFilesTo } from 'easy-file-picker';
async function uploadFile() {
const file = await getFile();
if(file) {
await uploadFilesTo("http://example.com", file);
}
}
</script>
<button on:click={uploadFile}>Upload!</button>
Functions
GetFile
Shows a system file dialog where the user can select a single file and returns it. Returns null if no file is selected.
function getFile(options?: FilePickerOptions): Promise<File | null>
GetFiles
Shows a system file dialog where the user can select multiple files and returns them. Returns empty array if no file is selected.
function getFiles(options?: FilePickerOptions): Promise<File[]>
GetFileAsString
Shows a system file dialog where the user can select a single file and returns a string representation of the file content. Returns null if no file is selected.
function getFileAsString(options?: FilePickerOptions): Promise<FileStringResult | null>
GetFilesAsString
Shows a system file dialog where the user can select multple files and returns string representations of the selected files content. Returns empty array if no file is selected.
function getFilesAsString(options?: FilePickerOptions): Promise<FileStringResult[]>
UploadFilesTo
Makes a HTTP request to the indicated url with the files as the body (content-type: form data).
function uploadFilesTo(url: string, files: File | File[], httpMethod: 'POST' | 'PUT' = 'POST'): Promise<Response>
Model
FilePickerOptions
| Name | Type | Required | Default | Description | | :--------------: | :--------: | :------: | :-----: | :--------------------- | |acceptedExtensions| string[] | NO | "" | An array of unique file type specifiers, describing which file types to allow. |
FileStringResult
| Name | Type | Required | Default | Description | | :--------------: | :--------: | :------: | :-----: | :--------------------- | | name | string | YES | undefined | The name of the file. | | size | number | YES | undefined | The size of the file in bytes. | | type | string | YES | undefined | The MIME type of the file. | | lastModified | number | YES | undefined | The last modified time of the file, in millisecond since the UNIX epoch. | |webkitRelativePath| string | YES | undefined | The path the URL of the file is relative to. | | content | string | YES | undefined | The string representation of the file's content |
Changelog
Version 1.1:
- now handles when the user does not select a file
- now handles input errors
- updated examples and documentation
- updated TypeScript version
Version 1.0.4:
- added example for Svelte
- updated TypeScript version
Version 1.0.3:
- added git repository
- added FileStringResult type
Version 1.0.2:
- added example for VueJS
Version 1.0.1:
- fixed typo in documentation
Version 1.0:
- published library
FAQs
No FAQs for now. (⌐■_■)