Package Exports
- angular-uploader
- angular-uploader/package.json
Readme
Angular File Upload Widget
(With Integrated Cloud Storage)
Get Started โ Try on StackBlitz
100% Serverless File Upload Widget
Powered by Upload.io
DMCA Compliant โข GDPR Compliant โข 99.9% Uptime SLA
Supports: Rate Limiting, Volume Limiting, File Size & Type Limiting, JWT Auth, and more...
Installation
Install via NPM:
npm install angular-uploader uploaderOr via YARN:
yarn add angular-uploader uploaderInitialization
Add the UploaderModule to your app:
import { NgModule } from "@angular/core";
import { BrowserModule } from "@angular/platform-browser";
import { UploaderModule } from "angular-uploader";
import { AppComponent } from "./app.component";
@NgModule({
declarations: [AppComponent],
imports: [
BrowserModule,
UploaderModule // <-- Add the Uploader module here.
],
bootstrap: [AppComponent]
})
export class AppModule {}Components & Directives
Choose one of these options:
Option 1: Create an Upload Button โ Try on StackBlitz
The uploadButton directive displays a file upload modal on click.
Inputs:
uploader(required): an instance of theUploaderclass.uploadOptions(optional): an object following theUploadWidgetConfiginterface.uploadComplete(optional): a callback containing a single parameter โ an array of uploaded files.
import { Component } from '@angular/core';
import { Uploader, UploadWidgetConfig, UploadWidgetResult } from 'uploader';
@Component({
selector: 'app-root',
template: `
<a href="{{ uploadedFileUrl }}" target="_blank">{{ uploadedFileUrl }}</a>
<button
uploadButton
[uploadComplete]="onComplete"
[uploadOptions]="options"
[uploader]="uploader"
>
Upload a file...
</button>
`,
})
export class AppComponent {
uploader = Uploader({
apiKey: 'free', // <-- Get production-ready API keys from Upload.io
});
options: UploadWidgetConfig = {
multi: false,
};
onComplete = (files: UploadWidgetResult[]) => {
this.uploadedFileUrl = files[0]?.fileUrl;
};
uploadedFileUrl = undefined;
}Option 2: Create a Dropzone โ Try on StackBlitz
The upload-dropzone component renders an inline drag-and-drop file uploader.
Inputs:
uploader(required): an instance of theUploaderclass.options(optional): an object following theUploadWidgetConfiginterface.onComplete(optional): a callback containing the array of uploaded files as its parameter.onUpdate(optional): same as above, but called after every file upload or removal.width(optional): width of the dropzone.height(optional): height of the dropzone.
import { Component } from "@angular/core";
import { Uploader, UploadWidgetConfig, UploadWidgetResult } from "uploader";
@Component({
selector: "app-root",
template: `
<upload-dropzone [uploader]="uploader"
[options]="options"
[onUpdate]="onUpdate"
[width]="width"
[height]="height">
</upload-dropzone>
`
})
export class AppComponent {
uploader = Uploader({
apiKey: "free"
});
options: UploadWidgetConfig = {
multi: false
};
// 'onUpdate' vs 'onComplete' attrs on 'upload-dropzone':
// - Dropzones are non-terminal by default (they don't have an end
// state), so by default we use 'onUpdate' instead of 'onComplete'.
// - To create a terminal dropzone, use the 'onComplete' attribute
// instead and add the 'showFinishButton: true' option.
onUpdate = (files: UploadWidgetResult[]) => {
alert(files.map(x => x.fileUrl).join("\n"));
};
width = "600px";
height = "375px";
}The Result
The callbacks receive a Array<UploadWidgetResult>:
{
fileUrl: "https://upcdn.io/FW25...", // URL to use when serving this file.
filePath: "/uploads/example.jpg", // File path (we recommend saving this to your database).
editedFile: undefined, // Edited file (for image crops). Same structure as below.
originalFile: {
fileUrl: "https://upcdn.io/FW25...", // Uploaded file URL.
filePath: "/uploads/example.jpg", // Uploaded file path (relative to your raw file directory).
accountId: "FW251aX", // Upload.io account the file was uploaded to.
originalFileName: "example.jpg", // Original file name from the user's machine.
file: { ... }, // Original DOM file object from the <input> element.
size: 12345, // File size in bytes.
lastModified: 1663410542397, // Epoch timestamp of when the file was uploaded or updated.
mime: "image/jpeg", // File MIME type.
metadata: {
... // User-provided JSON object.
},
tags: [
"tag1", // User-provided & auto-generated tags.
"tag2",
...
]
}
}๐ API Support
๐ File Management API
Upload.io provides an Upload API that allows you to:
- File uploading.
- File listing.
- File deleting.
- And more...
Uploading a "Hello World" text file is as simple as:
curl --data "Hello World" \
-u apikey:free \
-X POST "https://api.upload.io/v1/files/basic"Note: Remember to set -H "Content-Type: mime/type" when uploading other file types!
๐ Image Processing API (Resize, Crop, etc.)
Upload.io also provides an Image Processing API, which supports the following:
- Automatic Image Cropping
- Manual Image Cropping
- Image Resizing
- Text Layering (e.g for text watermarks)
- Image Layering (e.g. for image watermarks)
- Adjustments (blur, sharpen, brightness, etc.)
- and more...
Read the Image Processing API docs ยป
Original Image
Here's an example using a photo of Chicago:
https://upcdn.io/W142hJk/raw/example/city-landscape.jpgProcessed Image
You can use the Image Processing API to convert the above photo into this processed image:
https://upcdn.io/W142hJk/image/example/city-landscape.jpg
?w=900
&h=600
&fit=crop
&f=webp
&q=80
&blur=4
&text=WATERMARK
&layer-opacity=80
&blend=overlay
&layer-rotate=315
&font-size=100
&padding=10
&font-weight=900
&color=ffffff
&repeat=true
&text=Chicago
&gravity=bottom
&padding-x=50
&padding-bottom=20
&font=/example/fonts/Lobster.ttf
&color=ffe400Full Documentation
Angular Uploader Documentation ยป
Need a Headless (no UI) File Upload Library?
Can I use my own storage?
Yes! Upload.io supports custom S3 buckets on Upload Plus plans.
For ease and simplicity, your files are stored in Upload.io's internal S3 buckets by default. You can change this on a folder-by-folder basis โ to use your existing S3 bucket(s) โ in the Upload Dashboard.
๐ Create your Upload.io Account
Angular Uploader is the Angular file upload component for Upload.io: the file upload service for web apps.
Create an Upload.io account ยป
