UNPKG

angular-material-fileupload

Version:
221 lines 18.2 kB
/** * @fileoverview added by tsickle * Generated from: lib/mat-file-upload/mat-file-upload.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ChangeDetectionStrategy, Input, Output, EventEmitter, } from "@angular/core"; import { ReplaySubject, BehaviorSubject, Subscription } from "rxjs"; import { HttpClient, HttpEventType, } from "@angular/common/http"; import { MatFileUploadQueueService } from "../mat-file-upload-queue/mat-file-upload-queue.service"; export class MatFileUploadComponent { /** * @param {?} HttpClient * @param {?} matFileUploadQueueService */ constructor(HttpClient, matFileUploadQueueService) { this.HttpClient = HttpClient; this.matFileUploadQueueService = matFileUploadQueueService; this.uploadProgressSubject = new ReplaySubject(); this.uploadProgress$ = this.uploadProgressSubject.asObservable(); this.uploadInProgressSubject = new BehaviorSubject(false); this.uploadInProgress$ = this.uploadInProgressSubject.asObservable(); this.subs = new Subscription(); this.fileUploadAriaLabel = "File Upload"; this.cancelAriaLabel = "Cancel File Upload"; /** * Output */ this.removeEvent = new EventEmitter(); this.onUpload = new EventEmitter(); /** @type {?} */ const queueInput = this.matFileUploadQueueService.getInputValue(); if (queueInput) { this.httpUrl = this.httpUrl || queueInput.httpUrl; this.httpRequestHeaders = this.httpRequestHeaders || queueInput.httpRequestHeaders; this.httpRequestParams = this.httpRequestParams || queueInput.httpRequestParams; this.fileAlias = this.fileAlias || queueInput.fileAlias; } } /** * @return {?} */ get file() { return this._file; } /** * @param {?} file * @return {?} */ set file(file) { this._file = file; } /** * @param {?} id * @return {?} */ set id(id) { this._id = id; } /** * @return {?} */ get id() { return this._id; } /** * @return {?} */ ngOnInit() { this.uploadProgressSubject.next({ progressPercentage: 0, loaded: 0, total: this._file.size, }); } /** * @return {?} */ upload() { this.uploadInProgressSubject.next(true); // How to set the alias? /** @type {?} */ let formData = new FormData(); formData.set(this.fileAlias, this._file, this._file.name); this.subs.add(this.HttpClient.post(this.httpUrl, formData, { headers: this.httpRequestHeaders, observe: "events", params: this.httpRequestParams, reportProgress: true, responseType: "json", }).subscribe((/** * @param {?} event * @return {?} */ (event) => { if (event.type === HttpEventType.UploadProgress) { this.uploadProgressSubject.next({ progressPercentage: Math.floor((event.loaded * 100) / event.total), loaded: event.loaded, total: event.total, }); } this.onUpload.emit({ file: this._file, event: event }); }), (/** * @param {?} error * @return {?} */ (error) => { if (this.fileUploadSubscription) { this.fileUploadSubscription.unsubscribe(); } this.uploadInProgressSubject.next(false); this.onUpload.emit({ file: this._file, event: event }); }), (/** * @return {?} */ () => this.uploadInProgressSubject.next(false)))); } /** * @return {?} */ remove() { this.subs.unsubscribe(); this.removeEvent.emit(this); } /** * @return {?} */ ngOnDestroy() { this.subs.unsubscribe(); } } MatFileUploadComponent.decorators = [ { type: Component, args: [{ selector: "mat-file-upload", template: "<ng-container *ngIf=\"uploadProgress$ | async as uploadProgress\">\n <mat-card>\n <span class=\"file-summary\">{{ file.name }}({{ file.size | bytes }})</span>\n <div class=\"upload-progress\">\n <mat-progress-bar\n [value]=\"uploadProgress.progressPercentage\"\n ></mat-progress-bar>\n\n <button\n mat-icon-button\n [attr.aria-label]=\"fileUploadAriaLabel\"\n (click)=\"upload()\"\n [disabled]=\"uploadInProgress$ | async\"\n >\n <mat-icon>file_upload</mat-icon>\n </button>\n\n <button\n mat-icon-button\n [attr.aria-label]=\"cancelAriaLabel\"\n (click)=\"remove()\"\n >\n <mat-icon>cancel</mat-icon>\n </button>\n </div>\n <span class=\"file-summary\">{{ uploadProgress.progressPercentage }}%</span>\n <span>\n {{ uploadProgress.loaded | bytes }} of\n {{ uploadProgress.total | bytes }}</span\n >\n </mat-card>\n</ng-container>\n", changeDetection: ChangeDetectionStrategy.OnPush, styles: [".file-summary{font-size:.85rem}.upload-progress{display:flex;align-content:center;align-items:center;height:10px}.upload-progress ::ng-deep .mat-progress-bar .mat-progress-bar-element{transition:none}"] }] } ]; /** @nocollapse */ MatFileUploadComponent.ctorParameters = () => [ { type: HttpClient }, { type: MatFileUploadQueueService } ]; MatFileUploadComponent.propDecorators = { httpUrl: [{ type: Input }], httpRequestHeaders: [{ type: Input }], httpRequestParams: [{ type: Input }], fileAlias: [{ type: Input }], file: [{ type: Input }], id: [{ type: Input }], fileUploadAriaLabel: [{ type: Input }], cancelAriaLabel: [{ type: Input }], removeEvent: [{ type: Output }], onUpload: [{ type: Output }] }; if (false) { /** * @type {?} * @private */ MatFileUploadComponent.prototype.uploadProgressSubject; /** @type {?} */ MatFileUploadComponent.prototype.uploadProgress$; /** * @type {?} * @private */ MatFileUploadComponent.prototype.uploadInProgressSubject; /** @type {?} */ MatFileUploadComponent.prototype.uploadInProgress$; /** @type {?} */ MatFileUploadComponent.prototype.subs; /** @type {?} */ MatFileUploadComponent.prototype.httpUrl; /** @type {?} */ MatFileUploadComponent.prototype.httpRequestHeaders; /** @type {?} */ MatFileUploadComponent.prototype.httpRequestParams; /** @type {?} */ MatFileUploadComponent.prototype.fileAlias; /** * @type {?} * @private */ MatFileUploadComponent.prototype._file; /** * @type {?} * @private */ MatFileUploadComponent.prototype._id; /** @type {?} */ MatFileUploadComponent.prototype.fileUploadAriaLabel; /** @type {?} */ MatFileUploadComponent.prototype.cancelAriaLabel; /** * Output * @type {?} */ MatFileUploadComponent.prototype.removeEvent; /** @type {?} */ MatFileUploadComponent.prototype.onUpload; /** * @type {?} * @private */ MatFileUploadComponent.prototype.fileUploadSubscription; /** * @type {?} * @private */ MatFileUploadComponent.prototype.HttpClient; /** * @type {?} * @private */ MatFileUploadComponent.prototype.matFileUploadQueueService; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mat-file-upload.component.js","sourceRoot":"ng://angular-material-fileupload/","sources":["lib/mat-file-upload/mat-file-upload.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  ChangeDetectionStrategy,\n  OnDestroy,\n  Input,\n  Output,\n  EventEmitter,\n} from \"@angular/core\";\nimport { ReplaySubject, BehaviorSubject, Subscription } from \"rxjs\";\nimport {\n  HttpHeaders,\n  HttpParams,\n  HttpClient,\n  HttpEventType,\n} from \"@angular/common/http\";\nimport { MatFileUploadQueueService } from \"../mat-file-upload-queue/mat-file-upload-queue.service\";\nimport { IUploadProgress } from \"../mat-file-upload.type\";\n\n@Component({\n  selector: \"mat-file-upload\",\n  templateUrl: \"./mat-file-upload.component.html\",\n  styleUrls: [\"./mat-file-upload.component.scss\"],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class MatFileUploadComponent implements OnInit, OnDestroy {\n  private uploadProgressSubject = new ReplaySubject<IUploadProgress>();\n  uploadProgress$ = this.uploadProgressSubject.asObservable();\n\n  private uploadInProgressSubject = new BehaviorSubject<boolean>(false);\n  uploadInProgress$ = this.uploadInProgressSubject.asObservable();\n\n  public subs = new Subscription();\n\n  /* Http request input bindings */\n  @Input()\n  httpUrl: string;\n\n  @Input()\n  httpRequestHeaders:\n    | HttpHeaders\n    | {\n        [header: string]: string | string[];\n      };\n\n  @Input()\n  httpRequestParams:\n    | HttpParams\n    | {\n        [param: string]: string | string[];\n      };\n\n  @Input()\n  fileAlias: string;\n\n  private _file: any;\n  private _id: number;\n\n  @Input()\n  get file(): any {\n    return this._file;\n  }\n  set file(file: any) {\n    this._file = file;\n  }\n\n  @Input()\n  set id(id: number) {\n    this._id = id;\n  }\n  get id(): number {\n    return this._id;\n  }\n\n  @Input()\n  fileUploadAriaLabel = \"File Upload\";\n\n  @Input()\n  cancelAriaLabel = \"Cancel File Upload\";\n\n  /** Output  */\n  @Output() removeEvent = new EventEmitter<MatFileUploadComponent>();\n  @Output() onUpload = new EventEmitter();\n\n  private fileUploadSubscription: any;\n\n  constructor(\n    private HttpClient: HttpClient,\n    private matFileUploadQueueService: MatFileUploadQueueService\n  ) {\n    const queueInput = this.matFileUploadQueueService.getInputValue();\n    if (queueInput) {\n      this.httpUrl = this.httpUrl || queueInput.httpUrl;\n      this.httpRequestHeaders =\n        this.httpRequestHeaders || queueInput.httpRequestHeaders;\n      this.httpRequestParams =\n        this.httpRequestParams || queueInput.httpRequestParams;\n      this.fileAlias = this.fileAlias || queueInput.fileAlias;\n    }\n  }\n\n  ngOnInit() {\n    this.uploadProgressSubject.next({\n      progressPercentage: 0,\n      loaded: 0,\n      total: this._file.size,\n    });\n  }\n\n  public upload(): void {\n    this.uploadInProgressSubject.next(true);\n    // How to set the alias?\n    let formData = new FormData();\n    formData.set(this.fileAlias, this._file, this._file.name);\n    this.subs.add(\n      this.HttpClient.post(this.httpUrl, formData, {\n        headers: this.httpRequestHeaders,\n        observe: \"events\",\n        params: this.httpRequestParams,\n        reportProgress: true,\n        responseType: \"json\",\n      }).subscribe(\n        (event: any) => {\n          if (event.type === HttpEventType.UploadProgress) {\n            this.uploadProgressSubject.next({\n              progressPercentage: Math.floor(\n                (event.loaded * 100) / event.total\n              ),\n              loaded: event.loaded,\n              total: event.total,\n            });\n          }\n          this.onUpload.emit({ file: this._file, event: event });\n        },\n        (error: any) => {\n          if (this.fileUploadSubscription) {\n            this.fileUploadSubscription.unsubscribe();\n          }\n          this.uploadInProgressSubject.next(false);\n          this.onUpload.emit({ file: this._file, event: event });\n        },\n        () => this.uploadInProgressSubject.next(false)\n      )\n    );\n  }\n\n  public remove(): void {\n    this.subs.unsubscribe();\n    this.removeEvent.emit(this);\n  }\n\n  ngOnDestroy() {\n    this.subs.unsubscribe();\n  }\n}\n"]}