This Repository it's a fork from ng2-file-upload from valor software We want to continue mantaining this repository, any help is welcome!
- A recommended way to install @myog-io/ngx-chunk-file-upload is through npm package manager using the following command:
npm i @myog-io/ngx-chunk-file-upload --save
Alternatively, you can download it in a ZIP file.
-
Currently
@myog-io/ngx-chunk-file-upload
contains two directives:ngx-file-select
andngx-file-drop
.ngx-file-select
is used for 'file-input' field of form andngx-file-drop
is used for area that will be used for dropping of file or files. -
More information regarding using of @myog-io/ngx-chunk-file-upload is located in demo and demo sources.
-
Install as shown in the above section.
-
Import
FileUploadModule
into the module that declares the component using @myog-io/ngx-chunk-file-upload:
import { FileUploadModule } from '@myog-io/ngx-chunk-file-upload';
- Add it to
[imports]
under@NgModule
:
imports: [ ... FileUploadModule, ... ]
- Import
FileUploader
into the component:
import { FileUploader } from '@myog-io/ngx-chunk-file-upload';
- Create a variable for the API url:
const URL = 'path_to_api';
- Initialize it:
public uploader:FileUploader = new FileUploader({url: URL});
uploader
- (FileUploader
) - uploader object. See using in demo
onFileSelected
- fires when files are selected and added to the uploader queue
uploader
- (FileUploader
) - uploader object. See using in demo
uploaderService
- Your own uploaderService extending FileUploaderServiceauthToken
- Auth token that will be applied as 'Authorization' header during file send.disableMultipart
- If 'true', disable using a multipart form for file upload and instead stream the file. Some APIs (e.g. Amazon S3) may expect the file to be streamed rather than sent via a form. Defaults to false.isHTML5
- item alias (form name redefenition)
fileOver
- it fires during 'over' and 'out' events for Drop Area; returnsboolean
:true
if file is over Drop Area,false
in case of out. See using in ts demo and html demoonFileDrop
- it fires after a file has been dropped on a Drop Area; you can pass in$event
to get the list of files that were dropped. i.e.(onFileDrop)="dropped($event)"
import { Injectable } from '@angular/core';
import {
FileUploaderService,
FileItem,
FileUploaderOptions,
UploaderServiceOptions,
UploaderLinksOptions,
} from '@myog-io/ngx-chunk-file-upload';
import { HttpClient } from '@angular/common/http';
@Injectable()
export class SimpleDemoService extends FileUploaderService {
/**
* Links for the Post of file, this links will go trough Interceptor,
* you can manipulate if necessary
*/
public links: UploaderLinksOptions = {
downloadEntry: '/file/#id#/',
updateEntry: '/file/#id#/',
createEntry: '/file/',
deleteEntry: '/file/#id#/',
};
/**
* Uploader Options
*/
public options: UploaderServiceOptions = {
createMethod: 'POST',
updateMethod: 'PATCH',
authorizationHeaderName: 'Authorization',
tokenPattern: 'Bearer #token#',
token: null,
chunkSize: 1024 * 1024 * 3,
bytesParamName: 'bytes',
totalChunkParamName: 'total_chunks',
currentChunkParamName: 'current_chunk',
contentTypeParamName: 'content_type',
fileParamName: 'file',
extensionParamName: 'extension',
idAttribute: 'id'
};
constructor(protected http: HttpClient) {
super(http);
this.init(this.links, this.options);
}
/**
* Determines whether before upload on
* Place your Authentiaction Tactics here
* @param item
* @param options
* @returns before upload
*/
public onBeforeUpload(
item: FileItem,
options: FileUploaderOptions,
): Promise<any> {
return new Promise((resolve, reject) => {
resolve(true);
});
}
}
Please follow this guidelines when reporting bugs and feature requests:
- Use GitHub Issues board to report bugs and feature requests (not our email address)
- Please always write steps to reproduce the error. That way we can focus on fixing the bug, not scratching our heads trying to reproduce it.
Thanks for understanding!
If you want to send the files chunked you can just set the chunk paramets on the uploader object
If your chunk request changes the link after the first request you should use this code
this.uploader.onCompleteChunk = (item,response,status,headers)=>{
response = JSON.parse(response);
if(response['id']){
item.setId(response['id']);
}
}
The Chunk functions are inside the Service, UploaderServiceOptions
...
import { FileUploader } from '@myog-io/ngx-chunk-file-upload';
...
export class SimpleDemoComponent {
...
uploader:FileUploader;
...
// SimpleDemoService is your Service to handle the Upload
constructor (simpleDemoFileUploaderService: SimpleDemoService) {
...
this.uploader = new FileUploader({
uploaderService: simpleDemoFileUploaderService,
authToken: 'pre_token',
disableMultipart: false,
isHTML5: true,
});
this.uploader.onBeforeUploadItem = (item) => {
// If you use credentials this might help you with the "Access-Control-Allow-Origin" error
item.withCredentials = false;
};
this.uploader.onCompleteChunk = (item, response, status, headers) => {
//Insert the Logic here to start uploading next chunks
// Example, setting the ID of the File uploaded and chaning the link for the next request
// In my Case the API is using a put method with the link containing the PK of the object
response = JSON.parse(response);
if (response['id']) {
// After settting ID, the Url will be changed
item.setId(response['id']);
}
};
this.uploader.onErrorItem = (item, response, status, headers) => {
// Treat the error on the upload
// On the chunk method we try to upload a chunk for 10 times before triggering this error
};
this.uploader.onRemoveItem = (item) => {
// Treat the file removal from the server
};
...
}
The MIT License (see the LICENSE file for the full text)