ngx-uploadx
Angular Resumable Upload Module
data:image/s3,"s3://crabby-images/3f6c7/3f6c7606abe4b39731cd1585d0ee35aef9a786a6" alt="Build status"
Key Features
- Pause / Resume / Cancel Uploads
- Retries using exponential back-off strategy
- Chunking
Setups
- Add ngx-uploadx module as dependency :
npm install ngx-uploadx
import { UploadxModule } from 'ngx-uploadx';
@NgModule({
imports: [
UploadxModule,
});
Basic usage
import { Observable } from 'rxjs';
import { UploadxOptions, UploadState } from 'ngx-uploadx';
@Component({
selector: 'app-home',
templateUrl: `
<input type="file" [uploadx]="options" (uploadxState)="onUpload($event)">
`
})
export class AppHomeComponent {
options: UploadxOptions = { url: `[URL]`};
onUpload(state: Observable<UploadState>) {
state
.subscribe((item: UploadState) => {
console.log(item);
}
}
Server-side setup
Directive
<input
type="file"
[uploadx]="options"
[uploadxAction]="control"
(uploadxState)="onUpload($event)"
/>
Selector
[uploadx]
inputs
- [uploadx]: UploadxOptions
- [uploadxAction]: UploadxControlEvent
Output
- (uploadxState): $event <Observable>UploadState
Service
UploadxService
Public Methods
-
init(options: UploadxOptions): Observable<UploadState>
-
connect(options: UploadxOptions): Observable<Uploader[]>
Set global module options
uploadxOptions: UploadxOptions = {
concurrency: 2,
endpoint: `${environment.api}/upload?uploadType=uploadx`,
token: () => {
return localStorage.getItem('access_token');
},
autoUpload: true,
chunkSize: 1024 * 256 * 8
};
ngOnInit() {
this.uploadService.init(this.uploadxOptions)
.subscribe((item: UploadState) => {
console.log(item);
}
}
-
handleFile(file: File): <void>
Create Uploader for the file and add to the queue
-
handleFileList(fileList: FileList): <void>
Add files to the upload queue
-
control(event: UploadxControlEvent): void
Send event
pause(uploadId: string) {
this.uploadService.control({ action: 'pause', uploadId });
}
-
queue: Uploader[]
Uploaders array
-
events: Observable<UploadState>
Uploadx Events
Interfaces
UploadxOptions
Name | Defaults? | Description |
---|
[allowedTypes] | - | Set "accept" attribute |
[autoUpload] | true | Auto upload with global options |
[chunkSize] | 1MiB | If set to > 0 use chunked upload |
[concurrency] | 2 | Limit the number of concurrent uploads |
[headers] | - | Custom headers |
[method] | "POST" | Upload API initial method |
[token] | - | Auth Bearer token / token Getter |
[endpoint] | "/upload" | API URL |
[maxRetryAttempts] | 3 | Maximum number of retries to allow |
[withCredentials] | false | CORS option |
<Observable> UploadState
Name | Type | Description |
---|
file | File | FileAPI File |
name | string | file name |
percentage | number | progress percentage |
remaining | number | ETA |
response | Object | null | response body |
responseStatus | number | response’s status |
size | number | file size |
speed | number | upload speed bytes/sec |
status | UploadStatus | 'added', 'queue', 'uploading', 'complete','retry', 'error', 'cancelled', 'paused' |
uploadId | string | upload id |
URI | string | file URI |
UploadItem
Item custom options, override globals
Name | Type | Description |
---|
[method] | string | API initial method |
[uploadId] | string | internal upload id ( ReadOnly ) |
[URI] | string | Item URL |
[headers] | { [key: string]: string } | Add custom headers |
[metadata] | any | Add custom data |
UploadxControlEvent
Name | Type | Description |
---|
action | UploadAction | 'uploadAll', 'upload', 'cancel', 'cancelAll', 'pauseAll, 'pause', 'refreshToken' |
[uploadId] | string | upload id ( ReadOnly ) |
[itemOptions] | UploadItem | custom options |
Run demo
- Start server
npm run server
- Run demo app
npm start
- Navigate to
http://localhost:4200/
Build
Run npm run build
to build the lib.
packaged by ng-packagr
Contributing
Pull requests are welcome!
Collaborators
Links
License
The MIT License (see the LICENSE file for the full text)