@acpaas-ui/ngx-forms 4.4.0 → 4.6.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/acpaas-ui-ngx-forms.metadata.json +1 -1
- package/bundles/acpaas-ui-ngx-forms.umd.js +91 -18
- package/bundles/acpaas-ui-ngx-forms.umd.js.map +1 -1
- package/bundles/acpaas-ui-ngx-forms.umd.min.js +1 -1
- package/bundles/acpaas-ui-ngx-forms.umd.min.js.map +1 -1
- package/esm2015/lib/datepicker/components/datepicker/datepicker.component.js +16 -5
- package/esm2015/lib/upload/components/upload/upload.component.js +10 -2
- package/esm2015/lib/upload/components/upload-zone/upload-zone.component.js +44 -4
- package/esm5/lib/datepicker/components/datepicker/datepicker.component.js +21 -5
- package/esm5/lib/upload/components/upload/upload.component.js +10 -2
- package/esm5/lib/upload/components/upload-zone/upload-zone.component.js +48 -4
- package/fesm2015/acpaas-ui-ngx-forms.js +66 -7
- package/fesm2015/acpaas-ui-ngx-forms.js.map +1 -1
- package/fesm5/acpaas-ui-ngx-forms.js +75 -7
- package/fesm5/acpaas-ui-ngx-forms.js.map +1 -1
- package/lib/datepicker/components/datepicker/datepicker.component.d.ts +2 -1
- package/lib/upload/components/upload/upload.component.d.ts +2 -0
- package/lib/upload/components/upload-zone/upload-zone.component.d.ts +7 -2
- package/package.json +6 -6
|
@@ -3,14 +3,16 @@
|
|
|
3
3
|
* Generated from: lib/upload/components/upload-zone/upload-zone.component.ts
|
|
4
4
|
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
|
5
5
|
*/
|
|
6
|
-
import { Component, ElementRef, EventEmitter, HostListener, Input, Output, ViewChild } from '@angular/core';
|
|
6
|
+
import { Component, ElementRef, EventEmitter, HostListener, Input, Output, Renderer2, ViewChild } from '@angular/core';
|
|
7
7
|
import { Uploader } from '../../classes/uploader.class';
|
|
8
8
|
var UploadZoneComponent = /** @class */ (function () {
|
|
9
|
-
function UploadZoneComponent() {
|
|
9
|
+
function UploadZoneComponent(renderer) {
|
|
10
|
+
this.renderer = renderer;
|
|
10
11
|
this.disabled = false;
|
|
11
12
|
this.multiple = true;
|
|
12
13
|
this.id = '';
|
|
13
14
|
this.ariaId = '';
|
|
15
|
+
this.accept = [];
|
|
14
16
|
this.uploadedFiles = new EventEmitter();
|
|
15
17
|
this.queuedFiles = new EventEmitter();
|
|
16
18
|
this.invalidFiles = new EventEmitter();
|
|
@@ -76,6 +78,36 @@ var UploadZoneComponent = /** @class */ (function () {
|
|
|
76
78
|
var files = this.fileListToArray(this.fileInput.nativeElement.files);
|
|
77
79
|
this.handleFiles(files);
|
|
78
80
|
};
|
|
81
|
+
/**
|
|
82
|
+
* @param {?} event
|
|
83
|
+
* @return {?}
|
|
84
|
+
*/
|
|
85
|
+
UploadZoneComponent.prototype.onFileClick = /**
|
|
86
|
+
* @param {?} event
|
|
87
|
+
* @return {?}
|
|
88
|
+
*/
|
|
89
|
+
function (event) {
|
|
90
|
+
// When removing a file make sure you can add it again later
|
|
91
|
+
// See: https://stackoverflow.com/questions/59870335/ng2-file-upload-not-allowing-me-to-add-same-doc-after-ive-removed-it-from-que
|
|
92
|
+
event.target.value = '';
|
|
93
|
+
};
|
|
94
|
+
/**
|
|
95
|
+
* @return {?}
|
|
96
|
+
*/
|
|
97
|
+
UploadZoneComponent.prototype.ngAfterViewInit = /**
|
|
98
|
+
* @return {?}
|
|
99
|
+
*/
|
|
100
|
+
function () {
|
|
101
|
+
if (this.multiple !== false) {
|
|
102
|
+
this.renderer.setProperty(this.fileInput.nativeElement, 'multiple', 'multiple');
|
|
103
|
+
}
|
|
104
|
+
if (this.accept) {
|
|
105
|
+
this.renderer.setProperty(this.fileInput.nativeElement, 'accept', this.accept.join());
|
|
106
|
+
}
|
|
107
|
+
if (this.disabled) {
|
|
108
|
+
this.renderer.setProperty(this.fileInput.nativeElement, 'disabled', 'disabled');
|
|
109
|
+
}
|
|
110
|
+
};
|
|
79
111
|
/**
|
|
80
112
|
* @protected
|
|
81
113
|
* @param {?} files
|
|
@@ -162,9 +194,13 @@ var UploadZoneComponent = /** @class */ (function () {
|
|
|
162
194
|
UploadZoneComponent.decorators = [
|
|
163
195
|
{ type: Component, args: [{
|
|
164
196
|
selector: 'aui-upload-zone',
|
|
165
|
-
template: "<div *ngIf=\"uploader.options.type === 'drop'\" [class.is-disabled]=\"disabled\" class=\"m-upload\">\n <div class=\"m-upload__inner\">\n <div class=\"m-upload__dropzone\">\n <input
|
|
197
|
+
template: "<div *ngIf=\"uploader.options.type === 'drop'\" [class.is-disabled]=\"disabled\" class=\"m-upload\">\n <div class=\"m-upload__inner\">\n <div class=\"m-upload__dropzone\">\n\n <input\n #fileInput\n type=\"file\"\n class=\"m-upload__input\"\n [id]=\"id\"\n [attr.aria-labelledby]=\"ariaId\"\n (change)=\"updateFiles()\"\n (click)=\"onFileClick($event)\">\n\n <div *ngIf=\"!uploadProgress || uploadProgress === 0\" class=\"m-upload__content\">\n <p [id]=\"ariaId\" class=\"m-upload__message\">\n <ng-content select=\".m-upload__message\"></ng-content>\n </p>\n </div>\n\n <ng-container *ngIf=\"uploadProgress > 0\">\n <p class=\"m-upload__uploads u-text-bold u-margin-bottom-xs\">\n <ng-container *ngFor=\"let file of uploadingFiles; let last = last\">\n {{ file.name }}\n <ng-container *ngIf=\"!last\">,</ng-container>\n </ng-container>\n </p>\n <aui-progress-bar [value]=\"uploadProgress\" max=\"100\"></aui-progress-bar>\n </ng-container>\n </div>\n </div>\n\n <small class=\"m-upload__description\">\n <ng-content select=\".m-upload__description\"></ng-content>\n </small>\n</div>\n\n<button (click)=\"triggerFile()\" *ngIf=\"uploader.options.type === 'button'\" [disabled]=\"disabled\" class=\"a-button m-upload__button\"\n type=\"button\">\n <span [id]=\"ariaId\"><ng-content select=\".m-upload__button\"></ng-content></span>\n <input\n #fileInput\n type=\"file\"\n class=\"m-upload__input\"\n [id]=\"id\"\n [attr.aria-labelledby]=\"ariaId\"\n (change)=\"updateFiles()\"\n (click)=\"onFileClick($event)\">\n</button>\n"
|
|
166
198
|
}] }
|
|
167
199
|
];
|
|
200
|
+
/** @nocollapse */
|
|
201
|
+
UploadZoneComponent.ctorParameters = function () { return [
|
|
202
|
+
{ type: Renderer2 }
|
|
203
|
+
]; };
|
|
168
204
|
UploadZoneComponent.propDecorators = {
|
|
169
205
|
fileInput: [{ type: ViewChild, args: ['fileInput', { static: false },] }],
|
|
170
206
|
uploader: [{ type: Input }],
|
|
@@ -172,6 +208,7 @@ var UploadZoneComponent = /** @class */ (function () {
|
|
|
172
208
|
multiple: [{ type: Input }],
|
|
173
209
|
id: [{ type: Input }],
|
|
174
210
|
ariaId: [{ type: Input }],
|
|
211
|
+
accept: [{ type: Input }],
|
|
175
212
|
uploadedFiles: [{ type: Output }],
|
|
176
213
|
queuedFiles: [{ type: Output }],
|
|
177
214
|
invalidFiles: [{ type: Output }],
|
|
@@ -196,6 +233,8 @@ if (false) {
|
|
|
196
233
|
/** @type {?} */
|
|
197
234
|
UploadZoneComponent.prototype.ariaId;
|
|
198
235
|
/** @type {?} */
|
|
236
|
+
UploadZoneComponent.prototype.accept;
|
|
237
|
+
/** @type {?} */
|
|
199
238
|
UploadZoneComponent.prototype.uploadedFiles;
|
|
200
239
|
/** @type {?} */
|
|
201
240
|
UploadZoneComponent.prototype.queuedFiles;
|
|
@@ -209,5 +248,10 @@ if (false) {
|
|
|
209
248
|
UploadZoneComponent.prototype.uploadProgress;
|
|
210
249
|
/** @type {?} */
|
|
211
250
|
UploadZoneComponent.prototype.uploadingFiles;
|
|
251
|
+
/**
|
|
252
|
+
* @type {?}
|
|
253
|
+
* @private
|
|
254
|
+
*/
|
|
255
|
+
UploadZoneComponent.prototype.renderer;
|
|
212
256
|
}
|
|
213
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
257
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload-zone.component.js","sourceRoot":"ng://@acpaas-ui/ngx-forms/","sources":["lib/upload/components/upload-zone/upload-zone.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, ElementRef, EventEmitter, HostListener, Input, Output, Renderer2, ViewChild} from '@angular/core';\n\nimport {InvalidFile} from '../../types/upload.types';\nimport {Uploader} from '../../classes/uploader.class';\n\n@Component({\n  selector: 'aui-upload-zone',\n  templateUrl: './upload-zone.component.html',\n})\nexport class UploadZoneComponent implements AfterViewInit {\n  @ViewChild('fileInput', {static: false}) fileInput: ElementRef;\n\n  @Input() public uploader: Uploader;\n  @Input() public disabled = false;\n  @Input() public multiple = true;\n  @Input() public id = '';\n  @Input() public ariaId = '';\n  @Input() public accept = [];\n  @Output() public uploadedFiles: EventEmitter<object[]> = new EventEmitter<object[]>();\n  @Output() public queuedFiles: EventEmitter<File[]> = new EventEmitter<File[]>();\n  @Output() public invalidFiles: EventEmitter<InvalidFile[]> = new EventEmitter<InvalidFile[]>();\n\n  public hasDragOver = false;\n  public classNames: string;\n  public uploadProgress = 0;\n  public uploadingFiles: File[];\n\n  constructor(\n    private renderer: Renderer2,\n  ) {}\n\n  @HostListener('dragover', ['$event'])\n  public onDragOver(event: any): void {\n    this.preventAndStop(event);\n    this.hasDragOver = true;\n  }\n\n  @HostListener('dragleave', ['$event'])\n  public onDragLeave(event: any): void {\n    this.preventAndStop(event);\n    this.hasDragOver = false;\n  }\n\n  @HostListener('drop', ['$event'])\n  public onDrop(event: any): void {\n    this.preventAndStop(event);\n    this.hasDragOver = false;\n    const files = this.fileListToArray(event.dataTransfer.files);\n    this.handleFiles(files);\n  }\n\n  public triggerFile() {\n    this.fileInput.nativeElement.click();\n  }\n\n  public updateFiles() {\n    const files: any[] = this.fileListToArray(this.fileInput.nativeElement.files);\n    this.handleFiles(files);\n  }\n\n  public onFileClick(event) {\n    // When removing a file make sure you can add it again later\n    // See: https://stackoverflow.com/questions/59870335/ng2-file-upload-not-allowing-me-to-add-same-doc-after-ive-removed-it-from-que\n    event.target.value = '';\n  }\n\n  ngAfterViewInit() {\n    if (this.multiple !== false) { this.renderer.setProperty(this.fileInput.nativeElement, 'multiple', 'multiple'); }\n    if (this.accept) { this.renderer.setProperty(this.fileInput.nativeElement, 'accept', this.accept.join()); }\n    if (this.disabled) { this.renderer.setProperty(this.fileInput.nativeElement, 'disabled', 'disabled'); }\n  }\n\n  protected handleFiles(files) {\n    const response = this.uploader.validateFiles(files);\n    this.invalidFiles.emit(response.invalidFiles);\n\n    if (this.uploader.options.autoUpload && response.validFiles.length > 0) {\n      this.uploadFiles(response.validFiles);\n    } else {\n      this.queuedFiles.emit(response.validFiles);\n    }\n  }\n\n  protected uploadFiles(files) {\n    // Reset progress\n    this.uploadProgress = 0;\n    this.uploadingFiles = files;\n\n    // upload\n    this.uploader.uploadFiles(files).subscribe(\n      (response) => {\n        if (response.progress) {\n          this.uploadProgress = Math.floor(response.progress * 100);\n        }\n        if (response.data) {\n          this.uploadedFiles.emit(response.data);\n        }\n      },\n      (err) => {\n        console.log(err);\n      }\n    );\n  }\n\n  protected fileListToArray(list: FileList): object[] {\n    return Array.from(list);\n  }\n\n  protected preventAndStop(event: any): any {\n    event.preventDefault();\n    event.stopPropagation();\n  }\n}\n"]}
|
|
@@ -692,11 +692,11 @@ class DatepickerComponent {
|
|
|
692
692
|
* @return {?}
|
|
693
693
|
*/
|
|
694
694
|
writeValue(value) {
|
|
695
|
+
this.selectedDate = typeof value === 'string'
|
|
696
|
+
? this.isISODateFormat(value) ? new Date(value) : DateHelper.parseDate(value, 'DD/MM/YYYY', true)
|
|
697
|
+
: value;
|
|
695
698
|
/** @type {?} */
|
|
696
|
-
const
|
|
697
|
-
/** @type {?} */
|
|
698
|
-
const dateString = date ? this.formatDate(date) : '';
|
|
699
|
-
this.selectedDate = date;
|
|
699
|
+
const dateString = this.selectedDate ? this.formatDate(this.selectedDate) : '';
|
|
700
700
|
this.formControl.setValue(dateString);
|
|
701
701
|
}
|
|
702
702
|
/**
|
|
@@ -786,6 +786,17 @@ class DatepickerComponent {
|
|
|
786
786
|
this.blur.emit(e);
|
|
787
787
|
this.onTouched(e);
|
|
788
788
|
}
|
|
789
|
+
/**
|
|
790
|
+
* @private
|
|
791
|
+
* @param {?} value
|
|
792
|
+
* @return {?}
|
|
793
|
+
*/
|
|
794
|
+
isISODateFormat(value) {
|
|
795
|
+
if (typeof value !== 'string') {
|
|
796
|
+
return false;
|
|
797
|
+
}
|
|
798
|
+
return value.match(/\d{4}-\d{2}-\d{2}T.*/);
|
|
799
|
+
}
|
|
789
800
|
}
|
|
790
801
|
DatepickerComponent.decorators = [
|
|
791
802
|
{ type: Component, args: [{
|
|
@@ -2220,8 +2231,10 @@ if (false) {
|
|
|
2220
2231
|
class UploadComponent {
|
|
2221
2232
|
constructor() {
|
|
2222
2233
|
this.id = '';
|
|
2234
|
+
this.accept = [];
|
|
2223
2235
|
this.ariaLabelRemove = 'Verwijder';
|
|
2224
2236
|
this.disabled = false;
|
|
2237
|
+
this.multiple = true;
|
|
2225
2238
|
this.options = UPLOAD_OPTIONS_DEFAULT;
|
|
2226
2239
|
this.selectUploadedFiles = new EventEmitter();
|
|
2227
2240
|
this.uploadedFiles = [];
|
|
@@ -2263,14 +2276,16 @@ class UploadComponent {
|
|
|
2263
2276
|
UploadComponent.decorators = [
|
|
2264
2277
|
{ type: Component, args: [{
|
|
2265
2278
|
selector: 'aui-upload',
|
|
2266
|
-
template: "<div class=\"m-upload aui-upload\">\n <aui-upload-zone (invalidFiles)=\"onInvalidFiles($event)\" (queuedFiles)=\"onQueuedFiles($event)\" (uploadedFiles)=\"onUploadedFiles($event)\" [ariaId]=\"ariaId\"\n [disabled]=\"disabled\" [id]=\"id\"\n [uploader]=\"uploader\">\n <div class=\"m-upload__message\">\n <ng-content select=\".m-upload__message\"></ng-content>\n </div>\n <div class=\"m-upload__description\">\n <ng-content select=\".m-upload__description\"></ng-content>\n </div>\n <div class=\"m-upload__button\">\n <ng-content select=\".m-upload__button\"></ng-content>\n </div>\n </aui-upload-zone>\n <aui-validation-list [ariaLabelRemove]=\"ariaLabelRemove\" [invalidFiles]=\"invalidFiles\"></aui-validation-list>\n <aui-upload-queue (uploadedFiles)=\"onUploadedFiles($event)\" *ngIf=\"!options?.autoUpload\" [ariaLabelRemove]=\"ariaLabelRemove\"\n [files]=\"queuedFiles\" [uploader]=\"uploader\"></aui-upload-queue>\n</div>\n",
|
|
2279
|
+
template: "<div class=\"m-upload aui-upload\">\n <aui-upload-zone (invalidFiles)=\"onInvalidFiles($event)\" (queuedFiles)=\"onQueuedFiles($event)\" (uploadedFiles)=\"onUploadedFiles($event)\" [ariaId]=\"ariaId\"\n [disabled]=\"disabled\" [id]=\"id\" [accept]=\"accept\" [multiple]=\"multiple\"\n [uploader]=\"uploader\">\n <div class=\"m-upload__message\">\n <ng-content select=\".m-upload__message\"></ng-content>\n </div>\n <div class=\"m-upload__description\">\n <ng-content select=\".m-upload__description\"></ng-content>\n </div>\n <div class=\"m-upload__button\">\n <ng-content select=\".m-upload__button\"></ng-content>\n </div>\n </aui-upload-zone>\n <aui-validation-list [ariaLabelRemove]=\"ariaLabelRemove\" [invalidFiles]=\"invalidFiles\"></aui-validation-list>\n <aui-upload-queue (uploadedFiles)=\"onUploadedFiles($event)\" *ngIf=\"!options?.autoUpload\" [ariaLabelRemove]=\"ariaLabelRemove\"\n [files]=\"queuedFiles\" [uploader]=\"uploader\"></aui-upload-queue>\n</div>\n",
|
|
2267
2280
|
styles: [".m-upload__button>.m-upload__input{display:none}"]
|
|
2268
2281
|
}] }
|
|
2269
2282
|
];
|
|
2270
2283
|
UploadComponent.propDecorators = {
|
|
2271
2284
|
id: [{ type: Input }],
|
|
2285
|
+
accept: [{ type: Input }],
|
|
2272
2286
|
ariaLabelRemove: [{ type: Input }],
|
|
2273
2287
|
disabled: [{ type: Input }],
|
|
2288
|
+
multiple: [{ type: Input }],
|
|
2274
2289
|
options: [{ type: Input }],
|
|
2275
2290
|
selectUploadedFiles: [{ type: Output }]
|
|
2276
2291
|
};
|
|
@@ -2278,10 +2293,14 @@ if (false) {
|
|
|
2278
2293
|
/** @type {?} */
|
|
2279
2294
|
UploadComponent.prototype.id;
|
|
2280
2295
|
/** @type {?} */
|
|
2296
|
+
UploadComponent.prototype.accept;
|
|
2297
|
+
/** @type {?} */
|
|
2281
2298
|
UploadComponent.prototype.ariaLabelRemove;
|
|
2282
2299
|
/** @type {?} */
|
|
2283
2300
|
UploadComponent.prototype.disabled;
|
|
2284
2301
|
/** @type {?} */
|
|
2302
|
+
UploadComponent.prototype.multiple;
|
|
2303
|
+
/** @type {?} */
|
|
2285
2304
|
UploadComponent.prototype.options;
|
|
2286
2305
|
/** @type {?} */
|
|
2287
2306
|
UploadComponent.prototype.selectUploadedFiles;
|
|
@@ -2434,11 +2453,16 @@ if (false) {
|
|
|
2434
2453
|
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
|
2435
2454
|
*/
|
|
2436
2455
|
class UploadZoneComponent {
|
|
2437
|
-
|
|
2456
|
+
/**
|
|
2457
|
+
* @param {?} renderer
|
|
2458
|
+
*/
|
|
2459
|
+
constructor(renderer) {
|
|
2460
|
+
this.renderer = renderer;
|
|
2438
2461
|
this.disabled = false;
|
|
2439
2462
|
this.multiple = true;
|
|
2440
2463
|
this.id = '';
|
|
2441
2464
|
this.ariaId = '';
|
|
2465
|
+
this.accept = [];
|
|
2442
2466
|
this.uploadedFiles = new EventEmitter();
|
|
2443
2467
|
this.queuedFiles = new EventEmitter();
|
|
2444
2468
|
this.invalidFiles = new EventEmitter();
|
|
@@ -2486,6 +2510,29 @@ class UploadZoneComponent {
|
|
|
2486
2510
|
const files = this.fileListToArray(this.fileInput.nativeElement.files);
|
|
2487
2511
|
this.handleFiles(files);
|
|
2488
2512
|
}
|
|
2513
|
+
/**
|
|
2514
|
+
* @param {?} event
|
|
2515
|
+
* @return {?}
|
|
2516
|
+
*/
|
|
2517
|
+
onFileClick(event) {
|
|
2518
|
+
// When removing a file make sure you can add it again later
|
|
2519
|
+
// See: https://stackoverflow.com/questions/59870335/ng2-file-upload-not-allowing-me-to-add-same-doc-after-ive-removed-it-from-que
|
|
2520
|
+
event.target.value = '';
|
|
2521
|
+
}
|
|
2522
|
+
/**
|
|
2523
|
+
* @return {?}
|
|
2524
|
+
*/
|
|
2525
|
+
ngAfterViewInit() {
|
|
2526
|
+
if (this.multiple !== false) {
|
|
2527
|
+
this.renderer.setProperty(this.fileInput.nativeElement, 'multiple', 'multiple');
|
|
2528
|
+
}
|
|
2529
|
+
if (this.accept) {
|
|
2530
|
+
this.renderer.setProperty(this.fileInput.nativeElement, 'accept', this.accept.join());
|
|
2531
|
+
}
|
|
2532
|
+
if (this.disabled) {
|
|
2533
|
+
this.renderer.setProperty(this.fileInput.nativeElement, 'disabled', 'disabled');
|
|
2534
|
+
}
|
|
2535
|
+
}
|
|
2489
2536
|
/**
|
|
2490
2537
|
* @protected
|
|
2491
2538
|
* @param {?} files
|
|
@@ -2552,9 +2599,13 @@ class UploadZoneComponent {
|
|
|
2552
2599
|
UploadZoneComponent.decorators = [
|
|
2553
2600
|
{ type: Component, args: [{
|
|
2554
2601
|
selector: 'aui-upload-zone',
|
|
2555
|
-
template: "<div *ngIf=\"uploader.options.type === 'drop'\" [class.is-disabled]=\"disabled\" class=\"m-upload\">\n <div class=\"m-upload__inner\">\n <div class=\"m-upload__dropzone\">\n <input
|
|
2602
|
+
template: "<div *ngIf=\"uploader.options.type === 'drop'\" [class.is-disabled]=\"disabled\" class=\"m-upload\">\n <div class=\"m-upload__inner\">\n <div class=\"m-upload__dropzone\">\n\n <input\n #fileInput\n type=\"file\"\n class=\"m-upload__input\"\n [id]=\"id\"\n [attr.aria-labelledby]=\"ariaId\"\n (change)=\"updateFiles()\"\n (click)=\"onFileClick($event)\">\n\n <div *ngIf=\"!uploadProgress || uploadProgress === 0\" class=\"m-upload__content\">\n <p [id]=\"ariaId\" class=\"m-upload__message\">\n <ng-content select=\".m-upload__message\"></ng-content>\n </p>\n </div>\n\n <ng-container *ngIf=\"uploadProgress > 0\">\n <p class=\"m-upload__uploads u-text-bold u-margin-bottom-xs\">\n <ng-container *ngFor=\"let file of uploadingFiles; let last = last\">\n {{ file.name }}\n <ng-container *ngIf=\"!last\">,</ng-container>\n </ng-container>\n </p>\n <aui-progress-bar [value]=\"uploadProgress\" max=\"100\"></aui-progress-bar>\n </ng-container>\n </div>\n </div>\n\n <small class=\"m-upload__description\">\n <ng-content select=\".m-upload__description\"></ng-content>\n </small>\n</div>\n\n<button (click)=\"triggerFile()\" *ngIf=\"uploader.options.type === 'button'\" [disabled]=\"disabled\" class=\"a-button m-upload__button\"\n type=\"button\">\n <span [id]=\"ariaId\"><ng-content select=\".m-upload__button\"></ng-content></span>\n <input\n #fileInput\n type=\"file\"\n class=\"m-upload__input\"\n [id]=\"id\"\n [attr.aria-labelledby]=\"ariaId\"\n (change)=\"updateFiles()\"\n (click)=\"onFileClick($event)\">\n</button>\n"
|
|
2556
2603
|
}] }
|
|
2557
2604
|
];
|
|
2605
|
+
/** @nocollapse */
|
|
2606
|
+
UploadZoneComponent.ctorParameters = () => [
|
|
2607
|
+
{ type: Renderer2 }
|
|
2608
|
+
];
|
|
2558
2609
|
UploadZoneComponent.propDecorators = {
|
|
2559
2610
|
fileInput: [{ type: ViewChild, args: ['fileInput', { static: false },] }],
|
|
2560
2611
|
uploader: [{ type: Input }],
|
|
@@ -2562,6 +2613,7 @@ UploadZoneComponent.propDecorators = {
|
|
|
2562
2613
|
multiple: [{ type: Input }],
|
|
2563
2614
|
id: [{ type: Input }],
|
|
2564
2615
|
ariaId: [{ type: Input }],
|
|
2616
|
+
accept: [{ type: Input }],
|
|
2565
2617
|
uploadedFiles: [{ type: Output }],
|
|
2566
2618
|
queuedFiles: [{ type: Output }],
|
|
2567
2619
|
invalidFiles: [{ type: Output }],
|
|
@@ -2583,6 +2635,8 @@ if (false) {
|
|
|
2583
2635
|
/** @type {?} */
|
|
2584
2636
|
UploadZoneComponent.prototype.ariaId;
|
|
2585
2637
|
/** @type {?} */
|
|
2638
|
+
UploadZoneComponent.prototype.accept;
|
|
2639
|
+
/** @type {?} */
|
|
2586
2640
|
UploadZoneComponent.prototype.uploadedFiles;
|
|
2587
2641
|
/** @type {?} */
|
|
2588
2642
|
UploadZoneComponent.prototype.queuedFiles;
|
|
@@ -2596,6 +2650,11 @@ if (false) {
|
|
|
2596
2650
|
UploadZoneComponent.prototype.uploadProgress;
|
|
2597
2651
|
/** @type {?} */
|
|
2598
2652
|
UploadZoneComponent.prototype.uploadingFiles;
|
|
2653
|
+
/**
|
|
2654
|
+
* @type {?}
|
|
2655
|
+
* @private
|
|
2656
|
+
*/
|
|
2657
|
+
UploadZoneComponent.prototype.renderer;
|
|
2599
2658
|
}
|
|
2600
2659
|
|
|
2601
2660
|
/**
|