UNPKG

angular-material-fileupload

Version:
231 lines 17.9 kB
/** * @fileoverview added by tsickle * Generated from: lib/mat-file-upload-queue/mat-file-upload-queue.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, ChangeDetectionStrategy, ContentChildren, forwardRef, QueryList, Input, ChangeDetectorRef, } from "@angular/core"; import { merge } from "rxjs"; import { HttpHeaders, HttpParams } from "@angular/common/http"; import { startWith } from "rxjs/operators"; import { MatFileUploadQueueService } from "./mat-file-upload-queue.service"; import { MatFileUploadComponent } from "../mat-file-upload/mat-file-upload.component"; var MatFileUploadQueueComponent = /** @class */ (function () { function MatFileUploadQueueComponent(matFileUploadQueueService, changeDetectorRef) { this.matFileUploadQueueService = matFileUploadQueueService; this.changeDetectorRef = changeDetectorRef; this.files = []; this.httpRequestHeaders = new HttpHeaders(); this.httpRequestParams = new HttpParams(); this.fileAlias = "file"; this.uploadAllColor = "primary"; this.uploadAllLabel = "Upload All"; this.removeAllColor = "primary"; this.removeAllLabel = "Remove All"; } Object.defineProperty(MatFileUploadQueueComponent.prototype, "fileUploadRemoveEvents", { /** Combined stream of all of the file upload remove change events. */ get: /** * Combined stream of all of the file upload remove change events. * @return {?} */ function () { return merge.apply(void 0, tslib_1.__spread(this.fileUploads.map((/** * @param {?} fileUpload * @return {?} */ function (fileUpload) { return fileUpload.removeEvent; })))); }, enumerable: true, configurable: true }); /** * @param {?} changes * @return {?} */ MatFileUploadQueueComponent.prototype.ngOnChanges = /** * @param {?} changes * @return {?} */ function (changes) { this.matFileUploadQueueService.initialize({ httpUrl: changes["httpUrl"] ? changes["httpUrl"].currentValue : undefined, httpRequestHeaders: changes["httpRequestHeaders"] ? changes["httpRequestHeaders"].currentValue : undefined, httpRequestParams: changes["httpRequestParams"] ? changes["httpRequestParams"].currentValue : undefined, fileAlias: changes["fileAlias"] ? changes["fileAlias"].currentValue : undefined, }); }; /** * @return {?} */ MatFileUploadQueueComponent.prototype.ngAfterViewInit = /** * @return {?} */ function () { var _this = this; // When the list changes, re-subscribe this._changeSubscription = this.fileUploads.changes .pipe(startWith(null)) .subscribe((/** * @return {?} */ function () { if (_this._fileRemoveSubscription) { _this._fileRemoveSubscription.unsubscribe(); } _this._listenTofileRemoved(); })); }; /** * @private * @return {?} */ MatFileUploadQueueComponent.prototype._listenTofileRemoved = /** * @private * @return {?} */ function () { var _this = this; this._fileRemoveSubscription = this.fileUploadRemoveEvents.subscribe((/** * @param {?} event * @return {?} */ function (event) { _this.files.splice(event.id, 1); _this.changeDetectorRef.markForCheck(); })); }; /** * @param {?} file * @return {?} */ MatFileUploadQueueComponent.prototype.add = /** * @param {?} file * @return {?} */ function (file) { this.files.push(file); this.changeDetectorRef.markForCheck(); }; /** * @return {?} */ MatFileUploadQueueComponent.prototype.uploadAll = /** * @return {?} */ function () { this.fileUploads.forEach((/** * @param {?} fileUpload * @return {?} */ function (fileUpload) { fileUpload.upload(); })); }; /** * @return {?} */ MatFileUploadQueueComponent.prototype.removeAll = /** * @return {?} */ function () { this.files.splice(0, this.files.length); this.changeDetectorRef.markForCheck(); }; /** * @return {?} */ MatFileUploadQueueComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { if (this._changeSubscription) this._changeSubscription.unsubscribe(); if (this._fileRemoveSubscription) this._fileRemoveSubscription.unsubscribe(); if (this.files) { this.removeAll(); } }; MatFileUploadQueueComponent.decorators = [ { type: Component, args: [{ selector: "mat-file-upload-queue", template: "<ng-content></ng-content>\n<br />\n<button\n mat-raised-button\n [color]=\"uploadAllColor\"\n *ngIf=\"files.length > 0\"\n (click)=\"uploadAll()\"\n>\n {{ uploadAllLabel }}\n</button>\n<button\n mat-raised-button\n [color]=\"removeAllColor\"\n *ngIf=\"files.length > 0\"\n (click)=\"removeAll()\"\n>\n {{ removeAllLabel }}\n</button>\n", changeDetection: ChangeDetectionStrategy.OnPush, providers: [MatFileUploadQueueService], styles: [""] }] } ]; /** @nocollapse */ MatFileUploadQueueComponent.ctorParameters = function () { return [ { type: MatFileUploadQueueService }, { type: ChangeDetectorRef } ]; }; MatFileUploadQueueComponent.propDecorators = { fileUploads: [{ type: ContentChildren, args: [forwardRef((/** * @return {?} */ function () { return MatFileUploadComponent; })),] }], httpUrl: [{ type: Input }], httpRequestHeaders: [{ type: Input }], httpRequestParams: [{ type: Input }], fileAlias: [{ type: Input }], uploadAllColor: [{ type: Input }], uploadAllLabel: [{ type: Input }], removeAllColor: [{ type: Input }], removeAllLabel: [{ type: Input }] }; return MatFileUploadQueueComponent; }()); export { MatFileUploadQueueComponent }; if (false) { /** @type {?} */ MatFileUploadQueueComponent.prototype.fileUploads; /** * Subscription to remove changes in files. * @type {?} * @private */ MatFileUploadQueueComponent.prototype._fileRemoveSubscription; /** * Subscription to changes in the files. * @type {?} * @private */ MatFileUploadQueueComponent.prototype._changeSubscription; /** @type {?} */ MatFileUploadQueueComponent.prototype.files; /** @type {?} */ MatFileUploadQueueComponent.prototype.httpUrl; /** @type {?} */ MatFileUploadQueueComponent.prototype.httpRequestHeaders; /** @type {?} */ MatFileUploadQueueComponent.prototype.httpRequestParams; /** @type {?} */ MatFileUploadQueueComponent.prototype.fileAlias; /** @type {?} */ MatFileUploadQueueComponent.prototype.uploadAllColor; /** @type {?} */ MatFileUploadQueueComponent.prototype.uploadAllLabel; /** @type {?} */ MatFileUploadQueueComponent.prototype.removeAllColor; /** @type {?} */ MatFileUploadQueueComponent.prototype.removeAllLabel; /** * @type {?} * @private */ MatFileUploadQueueComponent.prototype.matFileUploadQueueService; /** * @type {?} * @private */ MatFileUploadQueueComponent.prototype.changeDetectorRef; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mat-file-upload-queue.component.js","sourceRoot":"ng://angular-material-fileupload/","sources":["lib/mat-file-upload-queue/mat-file-upload-queue.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ChangeDetectionStrategy,\n  ContentChildren,\n  forwardRef,\n  OnDestroy,\n  OnChanges,\n  QueryList,\n  SimpleChanges,\n  Input,\n  ChangeDetectorRef,\n} from \"@angular/core\";\nimport { Subscription, Observable, merge } from \"rxjs\";\nimport { HttpHeaders, HttpParams } from \"@angular/common/http\";\nimport { startWith } from \"rxjs/operators\";\nimport { MatFileUploadQueueService } from \"./mat-file-upload-queue.service\";\nimport { MatFileUploadComponent } from \"../mat-file-upload/mat-file-upload.component\";\n\n@Component({\n  selector: \"mat-file-upload-queue\",\n  templateUrl: \"./mat-file-upload-queue.component.html\",\n  styleUrls: [\"./mat-file-upload-queue.component.scss\"],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [MatFileUploadQueueService],\n})\nexport class MatFileUploadQueueComponent implements OnChanges, OnDestroy {\n  @ContentChildren(forwardRef(() => MatFileUploadComponent))\n  fileUploads: QueryList<MatFileUploadComponent>;\n\n  /** Subscription to remove changes in files. */\n  private _fileRemoveSubscription: Subscription | null;\n\n  /** Subscription to changes in the files. */\n  private _changeSubscription: Subscription;\n\n  /** Combined stream of all of the file upload remove change events. */\n  get fileUploadRemoveEvents(): Observable<MatFileUploadComponent> {\n    return merge(\n      ...this.fileUploads.map((fileUpload) => fileUpload.removeEvent)\n    );\n  }\n\n  public files: Array<any> = [];\n\n  ngOnChanges(changes: SimpleChanges): void {\n    this.matFileUploadQueueService.initialize({\n      httpUrl: changes[\"httpUrl\"] ? changes[\"httpUrl\"].currentValue : undefined,\n      httpRequestHeaders: changes[\"httpRequestHeaders\"]\n        ? changes[\"httpRequestHeaders\"].currentValue\n        : undefined,\n      httpRequestParams: changes[\"httpRequestParams\"]\n        ? changes[\"httpRequestParams\"].currentValue\n        : undefined,\n      fileAlias: changes[\"fileAlias\"]\n        ? changes[\"fileAlias\"].currentValue\n        : undefined,\n    });\n  }\n\n  constructor(\n    private matFileUploadQueueService: MatFileUploadQueueService,\n    private changeDetectorRef: ChangeDetectorRef\n  ) {}\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      } = new HttpHeaders();\n\n  @Input()\n  httpRequestParams:\n    | HttpParams\n    | {\n        [param: string]: string | string[];\n      } = new HttpParams();\n\n  @Input()\n  fileAlias: string = \"file\";\n\n  @Input()\n  uploadAllColor = \"primary\";\n\n  @Input()\n  uploadAllLabel = \"Upload All\";\n\n  @Input()\n  removeAllColor = \"primary\";\n\n  @Input()\n  removeAllLabel = \"Remove All\";\n\n  ngAfterViewInit() {\n    // When the list changes, re-subscribe\n    this._changeSubscription = this.fileUploads.changes\n      .pipe(startWith(null))\n      .subscribe(() => {\n        if (this._fileRemoveSubscription) {\n          this._fileRemoveSubscription.unsubscribe();\n        }\n        this._listenTofileRemoved();\n      });\n  }\n\n  private _listenTofileRemoved(): void {\n    this._fileRemoveSubscription = this.fileUploadRemoveEvents.subscribe(\n      (event: MatFileUploadComponent) => {\n        this.files.splice(event.id, 1);\n        this.changeDetectorRef.markForCheck();\n      }\n    );\n  }\n\n  add(file: any) {\n    this.files.push(file);\n    this.changeDetectorRef.markForCheck();\n  }\n\n  public uploadAll() {\n    this.fileUploads.forEach((fileUpload) => {\n      fileUpload.upload();\n    });\n  }\n\n  public removeAll() {\n    this.files.splice(0, this.files.length);\n    this.changeDetectorRef.markForCheck();\n  }\n\n  ngOnDestroy() {\n    if (this._changeSubscription) this._changeSubscription.unsubscribe();\n    if (this._fileRemoveSubscription)\n      this._fileRemoveSubscription.unsubscribe();\n\n    if (this.files) {\n      this.removeAll();\n    }\n  }\n}\n"]}