Socket
Socket
Sign inDemoInstall

angular-extensions

Package Overview
Dependencies
21
Maintainers
1
Versions
222
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 1.0.26 to 1.0.27

44

bundles/angular-extensions-controls-file-control.umd.js
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('ngx-awesome-uploader'), require('rxjs'), require('ngx-filesize'), require('angular-extensions/controls/base-control'), require('@angular/material/icon'), require('@angular/common'), require('@angular/material/form-field')) :
typeof define === 'function' && define.amd ? define('angular-extensions/controls/file-control', ['exports', '@angular/core', 'ngx-awesome-uploader', 'rxjs', 'ngx-filesize', 'angular-extensions/controls/base-control', '@angular/material/icon', '@angular/common', '@angular/material/form-field'], factory) :
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory((global["angular-extensions"] = global["angular-extensions"] || {}, global["angular-extensions"].controls = global["angular-extensions"].controls || {}, global["angular-extensions"].controls["file-control"] = {}), global.ng.core, global["ngx-awesome-uploader"], global.rxjs, global["ngx-filesize"], global["angular-extensions"].controls["base-control"], global.ng.material.icon, global.ng.common, global.ng.material.formField));
})(this, (function (exports, i0, i4, rxjs, i1, i3, i5, i6, i7) { 'use strict';
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('ngx-awesome-uploader'), require('rxjs'), require('ngx-filesize'), require('angular-extensions/controls/base-control'), require('@angular/material/button'), require('@angular/material/icon'), require('@angular/common'), require('@angular/material/form-field')) :
typeof define === 'function' && define.amd ? define('angular-extensions/controls/file-control', ['exports', '@angular/core', 'ngx-awesome-uploader', 'rxjs', 'ngx-filesize', 'angular-extensions/controls/base-control', '@angular/material/button', '@angular/material/icon', '@angular/common', '@angular/material/form-field'], factory) :
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory((global["angular-extensions"] = global["angular-extensions"] || {}, global["angular-extensions"].controls = global["angular-extensions"].controls || {}, global["angular-extensions"].controls["file-control"] = {}), global.ng.core, global["ngx-awesome-uploader"], global.rxjs, global["ngx-filesize"], global["angular-extensions"].controls["base-control"], global.ng.material.button, global.ng.material.icon, global.ng.common, global.ng.material.formField));
})(this, (function (exports, i0, i4, rxjs, i1, i3, i5, i6, i7, i8) { 'use strict';

@@ -32,2 +32,3 @@ function _interopNamespace(e) {

var i7__namespace = /*#__PURE__*/_interopNamespace(i7);
var i8__namespace = /*#__PURE__*/_interopNamespace(i8);

@@ -372,6 +373,6 @@ /*! *****************************************************************************

var FileControlComponent = /** @class */ (function () {
function FileControlComponent(fileSizePipe, defaultAdapter) {
function FileControlComponent(elementRef, fileSizePipe, defaultAdapter) {
this.elementRef = elementRef;
this.fileSizePipe = fileSizePipe;
this.defaultAdapter = defaultAdapter;
this.allowedFileExtensions = [];
this.accept = [];

@@ -384,2 +385,10 @@ this.autoUpload = false;

FileControlComponent.prototype.ngOnInit = function () {
var _this = this;
this.elementRef.nativeElement.addEventListener("change", function () {
// replace file is single select mode
if (!_this.multiple) {
_this.filePicker.files = [];
}
_this.field.control.markAsTouched();
}, { capture: true });
};

@@ -423,4 +432,4 @@ FileControlComponent.prototype.onValidationError = function (error) {

}());
FileControlComponent.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: FileControlComponent, deps: [{ token: i1__namespace.FileSizePipe }, { token: FileService }], target: i0__namespace.ɵɵFactoryTarget.Component });
FileControlComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: FileControlComponent, selector: "file-control", inputs: { field: "field", disabled: "disabled", multiple: "multiple", allowedFileExtensions: "allowedFileExtensions", accept: "accept", maxFileSize: "maxFileSize", totalFileSize: "totalFileSize", autoUpload: "autoUpload", adapter: "adapter" }, outputs: { changes: "changes" }, providers: [FileService], ngImport: i0__namespace, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <div class=\"field-label\">\r\n\r\n <ngx-awesome-uploader #uploader\r\n [adapter]=\"adapter\"\r\n [showeDragDropZone]=\"true\"\r\n [uploadType]=\"multiple ? 'multi' : 'single'\"\r\n [fileMaxSize]=\"maxFileSize\"\r\n [totalMaxSize]=\"totalFileSize\"\r\n [fileMaxCount]=\"multiple ? $any(undefined) : 1\"\r\n [accept]=\"accept.toString()\"\r\n [itemTemplate]=\"fileItemTemplate\"\r\n [enableAutoUpload]=\"autoUpload\"\r\n [fileExtensions]=\"allowedFileExtensions\"\r\n (validationError)=\"onValidationError($event)\"\r\n (fileAdded)=\"onFileAdded($event)\">\r\n\r\n <div class=\"dropzoneTemplate\">\r\n <button mat-raised-button\r\n type=\"button\"\r\n (click)=\"field.control.markAsTouched()\">{{ field.label }}</button>\r\n </div>\r\n\r\n </ngx-awesome-uploader>\r\n\r\n </div>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized && field.control.touched\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n <ng-container *ngIf=\"validationErrors\">\r\n <mat-error *ngFor=\"let error of validationErrors\">\r\n {{ error.error }}\r\n </mat-error>\r\n </ng-container>\r\n </mat-error>\r\n</base-control>\r\n\r\n<ng-template #fileItemTemplate\r\n let-fileItem=\"fileItem\"\r\n let-uploadProgress=\"uploadProgress\">\r\n <div class=\"toolbar\">\r\n <span class=\"text-left\">\r\n {{ fileItem.fileName }}\r\n </span>\r\n\r\n <div *ngIf=\"fileItem\">\r\n <button mat-button\r\n mat-icon-button\r\n type=\"button\"\r\n (click)=\"uploader.removeFile(fileItem); onFileRemoved(fileItem)\">\r\n <mat-icon>clear</mat-icon>\r\n </button>\r\n </div>\r\n </div>\r\n</ng-template>\r\n", styles: [":host .field-label{width:100%}:host ::ng-deep ngx-awesome-uploader{max-width:none!important}:host ::ng-deep .file-drop-wrapper{background:#fff!important;padding-top:0!important}:host ::ng-deep .file-drop-wrapper #dropZone{padding:5px 0;border:none;max-width:none}:host ::ng-deep .file-drop-wrapper file-drop{padding:0 3px}:host ::ng-deep file-preview-item{position:initial;padding:10px 16px;max-width:none}:host .toolbar{position:relative;display:flex;justify-content:space-between;align-items:center}:host .toolbar mat-icon{cursor:pointer}:host .toolbar .editor-label{padding:8px 14px;display:inline-block;line-height:1em;height:34px}:host .toolbar .form-control{width:auto;display:inline-block;line-height:1em;height:34px;margin-right:.3em}\n"], components: [{ type: i3__namespace.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i4__namespace.FilePickerComponent, selector: "ngx-awesome-uploader", inputs: ["enableCropper", "showeDragDropZone", "showPreviewContainer", "uploadType", "croppedCanvasOptions", "captions", "enableAutoUpload", "cropperOptions", "customValidator", "itemTemplate", "fileMaxSize", "fileMaxCount", "totalMaxSize", "accept", "fileExtensions", "adapter", "dropzoneTemplate", "fileInputCapture"], outputs: ["uploadSuccess", "uploadFail", "removeSuccess", "validationError", "fileAdded", "fileRemoved"] }, { type: i5__namespace.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i6__namespace.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7__namespace.MatError, selector: "mat-error", inputs: ["id"] }, { type: i6__namespace.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i6__namespace.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
FileControlComponent.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: FileControlComponent, deps: [{ token: i0__namespace.ElementRef }, { token: i1__namespace.FileSizePipe }, { token: FileService }], target: i0__namespace.ɵɵFactoryTarget.Component });
FileControlComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: FileControlComponent, selector: "file-control", inputs: { field: "field", disabled: "disabled", multiple: "multiple", allowedFileExtensions: "allowedFileExtensions", accept: "accept", maxFileSize: "maxFileSize", totalFileSize: "totalFileSize", autoUpload: "autoUpload", adapter: "adapter", showPreview: "showPreview" }, outputs: { changes: "changes" }, providers: [FileService], viewQueries: [{ propertyName: "filePicker", first: true, predicate: i4.FilePickerComponent, descendants: true }], ngImport: i0__namespace, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <div class=\"field-label\">\r\n <ngx-awesome-uploader #uploader\r\n [adapter]=\"adapter\"\r\n [showeDragDropZone]=\"true\"\r\n [showPreviewContainer]=\"showPreview\"\r\n [uploadType]=\"multiple ? 'multi' : 'single'\"\r\n [fileMaxSize]=\"maxFileSize\"\r\n [totalMaxSize]=\"totalFileSize\"\r\n [accept]=\"accept.toString()\"\r\n [itemTemplate]=\"fileItemTemplate\"\r\n [enableAutoUpload]=\"autoUpload\"\r\n [fileExtensions]=\"allowedFileExtensions\"\r\n (validationError)=\"onValidationError($event)\"\r\n (fileAdded)=\"onFileAdded($event)\">\r\n\r\n <div class=\"dropzoneTemplate\">\r\n <button mat-raised-button\r\n type=\"button\">{{ field.label }}</button>\r\n </div>\r\n </ngx-awesome-uploader>\r\n </div>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized && field.control.touched\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n <ng-container *ngIf=\"validationErrors\">\r\n <mat-error *ngFor=\"let error of validationErrors\">\r\n {{ error.error }}\r\n </mat-error>\r\n </ng-container>\r\n </mat-error>\r\n</base-control>\r\n\r\n<ng-template #fileItemTemplate\r\n let-fileItem=\"fileItem\"\r\n let-uploadProgress=\"uploadProgress\">\r\n <div class=\"toolbar\">\r\n <span class=\"text-left\">\r\n {{ fileItem.fileName }}\r\n </span>\r\n\r\n <div *ngIf=\"fileItem\">\r\n <button mat-button\r\n mat-icon-button\r\n type=\"button\"\r\n (click)=\"uploader.removeFile(fileItem); onFileRemoved(fileItem)\">\r\n <mat-icon>clear</mat-icon>\r\n </button>\r\n </div>\r\n </div>\r\n</ng-template>\r\n", styles: [":host .field-label{width:100%}:host ::ng-deep ngx-awesome-uploader{max-width:none!important}:host ::ng-deep .file-drop-wrapper{width:auto!important;background:none!important;padding-top:0!important}:host ::ng-deep .file-drop-wrapper #dropZone{padding:5px 0;border:none;max-width:none;background:none}:host ::ng-deep .file-drop-wrapper file-drop{padding:0 3px}:host ::ng-deep file-preview-item{position:initial;padding:10px 16px;max-width:none}:host .toolbar{position:relative;display:flex;justify-content:space-between;align-items:center}:host .toolbar mat-icon{cursor:pointer}:host .toolbar .editor-label{padding:8px 14px;display:inline-block;line-height:1em;height:34px}:host .toolbar .form-control{width:auto;display:inline-block;line-height:1em;height:34px;margin-right:.3em}\n"], components: [{ type: i3__namespace.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i4__namespace.FilePickerComponent, selector: "ngx-awesome-uploader", inputs: ["enableCropper", "showeDragDropZone", "showPreviewContainer", "uploadType", "croppedCanvasOptions", "captions", "enableAutoUpload", "cropperOptions", "customValidator", "itemTemplate", "fileMaxSize", "fileMaxCount", "totalMaxSize", "accept", "fileExtensions", "adapter", "dropzoneTemplate", "fileInputCapture"], outputs: ["uploadSuccess", "uploadFail", "removeSuccess", "validationError", "fileAdded", "fileRemoved"] }, { type: i5__namespace.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i6__namespace.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i7__namespace.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8__namespace.MatError, selector: "mat-error", inputs: ["id"] }, { type: i7__namespace.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i7__namespace.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: FileControlComponent, decorators: [{

@@ -434,3 +443,3 @@ type: i0.Component,

}]
}], ctorParameters: function () { return [{ type: i1__namespace.FileSizePipe }, { type: FileService }]; }, propDecorators: { field: [{
}], ctorParameters: function () { return [{ type: i0__namespace.ElementRef }, { type: i1__namespace.FileSizePipe }, { type: FileService }]; }, propDecorators: { field: [{
type: i0.Input

@@ -453,4 +462,9 @@ }], disabled: [{

type: i0.Input
}], showPreview: [{
type: i0.Input
}], changes: [{
type: i0.Output
}], filePicker: [{
type: i0.ViewChild,
args: [i4.FilePickerComponent]
}] } });

@@ -464,6 +478,8 @@

NgxFileControlModule.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: NgxFileControlModule, deps: [], target: i0__namespace.ɵɵFactoryTarget.NgModule });
NgxFileControlModule.ɵmod = i0__namespace.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: NgxFileControlModule, declarations: [FileControlComponent], imports: [i6.CommonModule,
NgxFileControlModule.ɵmod = i0__namespace.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: NgxFileControlModule, declarations: [FileControlComponent], imports: [i7.CommonModule,
i3.NgxBaseControlModule,
i5.MatButtonModule,
i1.NgxFilesizeModule,
i4.FilePickerModule], exports: [i3.NgxBaseControlModule,
i5.MatButtonModule,
i1.NgxFilesizeModule,

@@ -475,7 +491,9 @@ i4.FilePickerModule,

], imports: [[
i6.CommonModule,
i7.CommonModule,
i3.NgxBaseControlModule,
i5.MatButtonModule,
i1.NgxFilesizeModule,
i4.FilePickerModule,
], i3.NgxBaseControlModule,
i5.MatButtonModule,
i1.NgxFilesizeModule,

@@ -487,4 +505,5 @@ i4.FilePickerModule] });

imports: [
i6.CommonModule,
i7.CommonModule,
i3.NgxBaseControlModule,
i5.MatButtonModule,
i1.NgxFilesizeModule,

@@ -495,2 +514,3 @@ i4.FilePickerModule,

i3.NgxBaseControlModule,
i5.MatButtonModule,
i1.NgxFilesizeModule,

@@ -497,0 +517,0 @@ i4.FilePickerModule,

@@ -1,4 +0,4 @@

import { OnInit, EventEmitter } from "@angular/core";
import { EventEmitter, ElementRef, OnInit } from "@angular/core";
import { FileSizePipe } from "ngx-filesize";
import { FilePickerAdapter, FilePreviewModel, ValidationError } from "ngx-awesome-uploader";
import { FilePickerAdapter, FilePickerComponent, FilePreviewModel, ValidationError } from "ngx-awesome-uploader";
import { Field } from "angular-extensions/models";

@@ -8,2 +8,3 @@ import { FileService } from "./file.service";

export declare class FileControlComponent implements OnInit {
private elementRef;
private fileSizePipe;

@@ -20,5 +21,7 @@ defaultAdapter: FileService;

adapter: FilePickerAdapter;
showPreview: boolean;
changes: EventEmitter<File[]>;
filePicker: FilePickerComponent;
validationErrors: ValidationError[];
constructor(fileSizePipe: FileSizePipe, defaultAdapter: FileService);
constructor(elementRef: ElementRef<HTMLFieldSetElement>, fileSizePipe: FileSizePipe, defaultAdapter: FileService);
ngOnInit(): void;

@@ -30,3 +33,3 @@ onValidationError(error: ValidationError): void;

static ɵfac: i0.ɵɵFactoryDeclaration<FileControlComponent, never>;
static ɵcmp: i0.ɵɵComponentDeclaration<FileControlComponent, "file-control", never, { "field": "field"; "disabled": "disabled"; "multiple": "multiple"; "allowedFileExtensions": "allowedFileExtensions"; "accept": "accept"; "maxFileSize": "maxFileSize"; "totalFileSize": "totalFileSize"; "autoUpload": "autoUpload"; "adapter": "adapter"; }, { "changes": "changes"; }, never, never>;
static ɵcmp: i0.ɵɵComponentDeclaration<FileControlComponent, "file-control", never, { "field": "field"; "disabled": "disabled"; "multiple": "multiple"; "allowedFileExtensions": "allowedFileExtensions"; "accept": "accept"; "maxFileSize": "maxFileSize"; "totalFileSize": "totalFileSize"; "autoUpload": "autoUpload"; "adapter": "adapter"; "showPreview": "showPreview"; }, { "changes": "changes"; }, never, never>;
}

@@ -5,8 +5,9 @@ import * as i0 from "@angular/core";

import * as i3 from "angular-extensions/controls/base-control";
import * as i4 from "ngx-filesize";
import * as i5 from "ngx-awesome-uploader";
import * as i4 from "@angular/material/button";
import * as i5 from "ngx-filesize";
import * as i6 from "ngx-awesome-uploader";
export declare class NgxFileControlModule {
static ɵfac: i0.ɵɵFactoryDeclaration<NgxFileControlModule, never>;
static ɵmod: i0.ɵɵNgModuleDeclaration<NgxFileControlModule, [typeof i1.FileControlComponent], [typeof i2.CommonModule, typeof i3.NgxBaseControlModule, typeof i4.NgxFilesizeModule, typeof i5.FilePickerModule], [typeof i3.NgxBaseControlModule, typeof i4.NgxFilesizeModule, typeof i5.FilePickerModule, typeof i1.FileControlComponent]>;
static ɵmod: i0.ɵɵNgModuleDeclaration<NgxFileControlModule, [typeof i1.FileControlComponent], [typeof i2.CommonModule, typeof i3.NgxBaseControlModule, typeof i4.MatButtonModule, typeof i5.NgxFilesizeModule, typeof i6.FilePickerModule], [typeof i3.NgxBaseControlModule, typeof i4.MatButtonModule, typeof i5.NgxFilesizeModule, typeof i6.FilePickerModule, typeof i1.FileControlComponent]>;
static ɵinj: i0.ɵɵInjectorDeclaration<NgxFileControlModule>;
}
export * from "angular-extensions/controls/base-control";
export * from "angular-extensions/controls/text-control";
export * from "angular-extensions/controls/textarea-control";
export * from "angular-extensions/controls/file-control";
export * from "./date-control/date-control.component";

@@ -5,0 +6,0 @@ export * from "./time-control/time-control.component";

@@ -1,3 +0,3 @@

import { Component, Input, Output, EventEmitter } from "@angular/core";
import { FileValidationTypes } from "ngx-awesome-uploader";
import { Component, Input, Output, EventEmitter, ViewChild } from "@angular/core";
import { FilePickerComponent, FileValidationTypes } from "ngx-awesome-uploader";
import { FileService } from "./file.service";

@@ -9,10 +9,11 @@ import * as i0 from "@angular/core";

import * as i4 from "ngx-awesome-uploader";
import * as i5 from "@angular/material/icon";
import * as i6 from "@angular/common";
import * as i7 from "@angular/material/form-field";
import * as i5 from "@angular/material/button";
import * as i6 from "@angular/material/icon";
import * as i7 from "@angular/common";
import * as i8 from "@angular/material/form-field";
export class FileControlComponent {
constructor(fileSizePipe, defaultAdapter) {
constructor(elementRef, fileSizePipe, defaultAdapter) {
this.elementRef = elementRef;
this.fileSizePipe = fileSizePipe;
this.defaultAdapter = defaultAdapter;
this.allowedFileExtensions = [];
this.accept = [];

@@ -25,2 +26,9 @@ this.autoUpload = false;

ngOnInit() {
this.elementRef.nativeElement.addEventListener("change", () => {
// replace file is single select mode
if (!this.multiple) {
this.filePicker.files = [];
}
this.field.control.markAsTouched();
}, { capture: true });
}

@@ -64,4 +72,4 @@ onValidationError(error) {

}
FileControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: FileControlComponent, deps: [{ token: i1.FileSizePipe }, { token: i2.FileService }], target: i0.ɵɵFactoryTarget.Component });
FileControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: FileControlComponent, selector: "file-control", inputs: { field: "field", disabled: "disabled", multiple: "multiple", allowedFileExtensions: "allowedFileExtensions", accept: "accept", maxFileSize: "maxFileSize", totalFileSize: "totalFileSize", autoUpload: "autoUpload", adapter: "adapter" }, outputs: { changes: "changes" }, providers: [FileService], ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <div class=\"field-label\">\r\n\r\n <ngx-awesome-uploader #uploader\r\n [adapter]=\"adapter\"\r\n [showeDragDropZone]=\"true\"\r\n [uploadType]=\"multiple ? 'multi' : 'single'\"\r\n [fileMaxSize]=\"maxFileSize\"\r\n [totalMaxSize]=\"totalFileSize\"\r\n [fileMaxCount]=\"multiple ? $any(undefined) : 1\"\r\n [accept]=\"accept.toString()\"\r\n [itemTemplate]=\"fileItemTemplate\"\r\n [enableAutoUpload]=\"autoUpload\"\r\n [fileExtensions]=\"allowedFileExtensions\"\r\n (validationError)=\"onValidationError($event)\"\r\n (fileAdded)=\"onFileAdded($event)\">\r\n\r\n <div class=\"dropzoneTemplate\">\r\n <button mat-raised-button\r\n type=\"button\"\r\n (click)=\"field.control.markAsTouched()\">{{ field.label }}</button>\r\n </div>\r\n\r\n </ngx-awesome-uploader>\r\n\r\n </div>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized && field.control.touched\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n <ng-container *ngIf=\"validationErrors\">\r\n <mat-error *ngFor=\"let error of validationErrors\">\r\n {{ error.error }}\r\n </mat-error>\r\n </ng-container>\r\n </mat-error>\r\n</base-control>\r\n\r\n<ng-template #fileItemTemplate\r\n let-fileItem=\"fileItem\"\r\n let-uploadProgress=\"uploadProgress\">\r\n <div class=\"toolbar\">\r\n <span class=\"text-left\">\r\n {{ fileItem.fileName }}\r\n </span>\r\n\r\n <div *ngIf=\"fileItem\">\r\n <button mat-button\r\n mat-icon-button\r\n type=\"button\"\r\n (click)=\"uploader.removeFile(fileItem); onFileRemoved(fileItem)\">\r\n <mat-icon>clear</mat-icon>\r\n </button>\r\n </div>\r\n </div>\r\n</ng-template>\r\n", styles: [":host .field-label{width:100%}:host ::ng-deep ngx-awesome-uploader{max-width:none!important}:host ::ng-deep .file-drop-wrapper{background:#fff!important;padding-top:0!important}:host ::ng-deep .file-drop-wrapper #dropZone{padding:5px 0;border:none;max-width:none}:host ::ng-deep .file-drop-wrapper file-drop{padding:0 3px}:host ::ng-deep file-preview-item{position:initial;padding:10px 16px;max-width:none}:host .toolbar{position:relative;display:flex;justify-content:space-between;align-items:center}:host .toolbar mat-icon{cursor:pointer}:host .toolbar .editor-label{padding:8px 14px;display:inline-block;line-height:1em;height:34px}:host .toolbar .form-control{width:auto;display:inline-block;line-height:1em;height:34px;margin-right:.3em}\n"], components: [{ type: i3.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i4.FilePickerComponent, selector: "ngx-awesome-uploader", inputs: ["enableCropper", "showeDragDropZone", "showPreviewContainer", "uploadType", "croppedCanvasOptions", "captions", "enableAutoUpload", "cropperOptions", "customValidator", "itemTemplate", "fileMaxSize", "fileMaxCount", "totalMaxSize", "accept", "fileExtensions", "adapter", "dropzoneTemplate", "fileInputCapture"], outputs: ["uploadSuccess", "uploadFail", "removeSuccess", "validationError", "fileAdded", "fileRemoved"] }, { type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.MatError, selector: "mat-error", inputs: ["id"] }, { type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
FileControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: FileControlComponent, deps: [{ token: i0.ElementRef }, { token: i1.FileSizePipe }, { token: i2.FileService }], target: i0.ɵɵFactoryTarget.Component });
FileControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: FileControlComponent, selector: "file-control", inputs: { field: "field", disabled: "disabled", multiple: "multiple", allowedFileExtensions: "allowedFileExtensions", accept: "accept", maxFileSize: "maxFileSize", totalFileSize: "totalFileSize", autoUpload: "autoUpload", adapter: "adapter", showPreview: "showPreview" }, outputs: { changes: "changes" }, providers: [FileService], viewQueries: [{ propertyName: "filePicker", first: true, predicate: FilePickerComponent, descendants: true }], ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <div class=\"field-label\">\r\n <ngx-awesome-uploader #uploader\r\n [adapter]=\"adapter\"\r\n [showeDragDropZone]=\"true\"\r\n [showPreviewContainer]=\"showPreview\"\r\n [uploadType]=\"multiple ? 'multi' : 'single'\"\r\n [fileMaxSize]=\"maxFileSize\"\r\n [totalMaxSize]=\"totalFileSize\"\r\n [accept]=\"accept.toString()\"\r\n [itemTemplate]=\"fileItemTemplate\"\r\n [enableAutoUpload]=\"autoUpload\"\r\n [fileExtensions]=\"allowedFileExtensions\"\r\n (validationError)=\"onValidationError($event)\"\r\n (fileAdded)=\"onFileAdded($event)\">\r\n\r\n <div class=\"dropzoneTemplate\">\r\n <button mat-raised-button\r\n type=\"button\">{{ field.label }}</button>\r\n </div>\r\n </ngx-awesome-uploader>\r\n </div>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized && field.control.touched\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n <ng-container *ngIf=\"validationErrors\">\r\n <mat-error *ngFor=\"let error of validationErrors\">\r\n {{ error.error }}\r\n </mat-error>\r\n </ng-container>\r\n </mat-error>\r\n</base-control>\r\n\r\n<ng-template #fileItemTemplate\r\n let-fileItem=\"fileItem\"\r\n let-uploadProgress=\"uploadProgress\">\r\n <div class=\"toolbar\">\r\n <span class=\"text-left\">\r\n {{ fileItem.fileName }}\r\n </span>\r\n\r\n <div *ngIf=\"fileItem\">\r\n <button mat-button\r\n mat-icon-button\r\n type=\"button\"\r\n (click)=\"uploader.removeFile(fileItem); onFileRemoved(fileItem)\">\r\n <mat-icon>clear</mat-icon>\r\n </button>\r\n </div>\r\n </div>\r\n</ng-template>\r\n", styles: [":host .field-label{width:100%}:host ::ng-deep ngx-awesome-uploader{max-width:none!important}:host ::ng-deep .file-drop-wrapper{width:auto!important;background:none!important;padding-top:0!important}:host ::ng-deep .file-drop-wrapper #dropZone{padding:5px 0;border:none;max-width:none;background:none}:host ::ng-deep .file-drop-wrapper file-drop{padding:0 3px}:host ::ng-deep file-preview-item{position:initial;padding:10px 16px;max-width:none}:host .toolbar{position:relative;display:flex;justify-content:space-between;align-items:center}:host .toolbar mat-icon{cursor:pointer}:host .toolbar .editor-label{padding:8px 14px;display:inline-block;line-height:1em;height:34px}:host .toolbar .form-control{width:auto;display:inline-block;line-height:1em;height:34px;margin-right:.3em}\n"], components: [{ type: i3.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i4.FilePickerComponent, selector: "ngx-awesome-uploader", inputs: ["enableCropper", "showeDragDropZone", "showPreviewContainer", "uploadType", "croppedCanvasOptions", "captions", "enableAutoUpload", "cropperOptions", "customValidator", "itemTemplate", "fileMaxSize", "fileMaxCount", "totalMaxSize", "accept", "fileExtensions", "adapter", "dropzoneTemplate", "fileInputCapture"], outputs: ["uploadSuccess", "uploadFail", "removeSuccess", "validationError", "fileAdded", "fileRemoved"] }, { type: i5.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.MatError, selector: "mat-error", inputs: ["id"] }, { type: i7.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: FileControlComponent, decorators: [{

@@ -75,3 +83,3 @@ type: Component,

}]
}], ctorParameters: function () { return [{ type: i1.FileSizePipe }, { type: i2.FileService }]; }, propDecorators: { field: [{
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.FileSizePipe }, { type: i2.FileService }]; }, propDecorators: { field: [{
type: Input

@@ -94,5 +102,10 @@ }], disabled: [{

type: Input
}], showPreview: [{
type: Input
}], changes: [{
type: Output
}], filePicker: [{
type: ViewChild,
args: [FilePickerComponent]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-control.component.js","sourceRoot":"","sources":["../../../../../projects/angular-extensions/controls/file-control/file-control.component.ts","../../../../../projects/angular-extensions/controls/file-control/file-control.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, Output, EventEmitter } from \"@angular/core\";\r\nimport { FileSizePipe } from \"ngx-filesize\";\r\nimport { FilePickerAdapter, FilePreviewModel, FileValidationTypes, ValidationError } from \"ngx-awesome-uploader\";\r\n\r\nimport { Field } from \"angular-extensions/models\";\r\nimport { FileService } from \"./file.service\";\r\n\r\n@Component({\r\n  selector: \"file-control\",\r\n  templateUrl: \"./file-control.component.html\",\r\n  styleUrls: [\"./file-control.component.scss\"],\r\n  providers: [FileService]\r\n})\r\nexport class FileControlComponent implements OnInit {\r\n\r\n  @Input()\r\n  public field: Field<File[]>;\r\n\r\n  @Input()\r\n  public disabled: boolean;\r\n\r\n  @Input()\r\n  public multiple: boolean;\r\n\r\n  @Input()\r\n  public allowedFileExtensions: string[] = [];\r\n\r\n  @Input()\r\n  public accept: string[] = [];\r\n\r\n  @Input()\r\n  public maxFileSize: number;\r\n\r\n  @Input()\r\n  public totalFileSize: number;\r\n\r\n  @Input()\r\n  public autoUpload = false;\r\n\r\n  @Input()\r\n  public adapter: FilePickerAdapter;\r\n\r\n  @Output()\r\n  public changes: EventEmitter<File[]> = new EventEmitter<File[]>();\r\n\r\n  public validationErrors: ValidationError[] = [];\r\n\r\n  constructor(\r\n    private fileSizePipe: FileSizePipe,\r\n    public defaultAdapter: FileService\r\n  ) {\r\n    this.adapter = this.adapter || defaultAdapter;\r\n  }\r\n\r\n  public ngOnInit() {\r\n  }\r\n\r\n  public onValidationError(error: ValidationError) {\r\n    const errIndex = this.validationErrors.findIndex(e => e.file == error.file);\r\n    error.error = this.getValidationErrorMessage(error.error as FileValidationTypes);\r\n\r\n    if (errIndex != -1) {\r\n      this.validationErrors[errIndex] = error;\r\n    }\r\n    else {\r\n      this.validationErrors.push(error);\r\n    }\r\n  }\r\n\r\n  public onFileAdded(file: FilePreviewModel) {\r\n    this.validationErrors = [];\r\n\r\n    this.field.value = this.field.value\r\n      ? [...this.field.value, file.file as File]\r\n      : [file.file as File];\r\n  }\r\n\r\n  public onFileRemoved(removedFile: FilePreviewModel) {\r\n    this.validationErrors = [];\r\n\r\n    this.field.value = this.field.value\r\n      ? this.field.value.filter(file => file.name != removedFile.fileName)\r\n      : [removedFile.file as File];\r\n  }\r\n\r\n  private getValidationErrorMessage(errorType: FileValidationTypes) {\r\n    switch (errorType) {\r\n\r\n      case FileValidationTypes.uploadType:\r\n        return this.multiple ? \"Select multiple files\" : \"Select only one file\";\r\n\r\n      case FileValidationTypes.extensions:\r\n        return `Selected file should have ${this.allowedFileExtensions} extension`;\r\n\r\n      case FileValidationTypes.fileMaxSize:\r\n        return `The size of selected file is larger than ${this.fileSizePipe.transform(this.maxFileSize)}`;\r\n\r\n      case FileValidationTypes.totalMaxSize:\r\n        return `The total size of selected files is larger than ${this.fileSizePipe.transform(this.totalFileSize)}`;\r\n\r\n      default:\r\n        return \"There was an error while adding your file\";\r\n    }\r\n  }\r\n}\r\n","<base-control #baseControl\r\n              [field]=\"field\">\r\n  <div class=\"field-label\">\r\n\r\n    <ngx-awesome-uploader #uploader\r\n                          [adapter]=\"adapter\"\r\n                          [showeDragDropZone]=\"true\"\r\n                          [uploadType]=\"multiple ? 'multi' : 'single'\"\r\n                          [fileMaxSize]=\"maxFileSize\"\r\n                          [totalMaxSize]=\"totalFileSize\"\r\n                          [fileMaxCount]=\"multiple ? $any(undefined) : 1\"\r\n                          [accept]=\"accept.toString()\"\r\n                          [itemTemplate]=\"fileItemTemplate\"\r\n                          [enableAutoUpload]=\"autoUpload\"\r\n                          [fileExtensions]=\"allowedFileExtensions\"\r\n                          (validationError)=\"onValidationError($event)\"\r\n                          (fileAdded)=\"onFileAdded($event)\">\r\n\r\n      <div class=\"dropzoneTemplate\">\r\n        <button mat-raised-button\r\n                type=\"button\"\r\n                (click)=\"field.control.markAsTouched()\">{{ field.label }}</button>\r\n      </div>\r\n\r\n    </ngx-awesome-uploader>\r\n\r\n  </div>\r\n\r\n  <mat-error *ngIf=\"baseControl.initialized && field.control.touched\">\r\n    <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n    <ng-container *ngIf=\"validationErrors\">\r\n      <mat-error *ngFor=\"let error of validationErrors\">\r\n        {{ error.error }}\r\n      </mat-error>\r\n    </ng-container>\r\n  </mat-error>\r\n</base-control>\r\n\r\n<ng-template #fileItemTemplate\r\n             let-fileItem=\"fileItem\"\r\n             let-uploadProgress=\"uploadProgress\">\r\n  <div class=\"toolbar\">\r\n    <span class=\"text-left\">\r\n      {{ fileItem.fileName }}\r\n    </span>\r\n\r\n    <div *ngIf=\"fileItem\">\r\n      <button mat-button\r\n              mat-icon-button\r\n              type=\"button\"\r\n              (click)=\"uploader.removeFile(fileItem); onFileRemoved(fileItem)\">\r\n        <mat-icon>clear</mat-icon>\r\n      </button>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-control.component.js","sourceRoot":"","sources":["../../../../../projects/angular-extensions/controls/file-control/file-control.component.ts","../../../../../projects/angular-extensions/controls/file-control/file-control.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, ViewChild, ElementRef, OnInit } from \"@angular/core\";\r\nimport { FileSizePipe } from \"ngx-filesize\";\r\nimport { FilePickerAdapter, FilePickerComponent, FilePreviewModel, FileValidationTypes, ValidationError } from \"ngx-awesome-uploader\";\r\n\r\nimport { Field } from \"angular-extensions/models\";\r\nimport { FileService } from \"./file.service\";\r\n\r\n@Component({\r\n  selector: \"file-control\",\r\n  templateUrl: \"./file-control.component.html\",\r\n  styleUrls: [\"./file-control.component.scss\"],\r\n  providers: [FileService]\r\n})\r\nexport class FileControlComponent implements OnInit {\r\n\r\n  @Input()\r\n  public field: Field<File[]>;\r\n\r\n  @Input()\r\n  public disabled: boolean;\r\n\r\n  @Input()\r\n  public multiple: boolean;\r\n\r\n  @Input()\r\n  public allowedFileExtensions: string[];\r\n\r\n  @Input()\r\n  public accept: string[] = [];\r\n\r\n  @Input()\r\n  public maxFileSize: number;\r\n\r\n  @Input()\r\n  public totalFileSize: number;\r\n\r\n  @Input()\r\n  public autoUpload = false;\r\n\r\n  @Input()\r\n  public adapter: FilePickerAdapter;\r\n\r\n  @Input()\r\n  public showPreview: boolean;\r\n\r\n  @Output()\r\n  public changes: EventEmitter<File[]> = new EventEmitter<File[]>();\r\n\r\n  @ViewChild(FilePickerComponent)\r\n  public filePicker: FilePickerComponent;\r\n\r\n  public validationErrors: ValidationError[] = [];\r\n\r\n  constructor(\r\n    private elementRef: ElementRef<HTMLFieldSetElement>,\r\n    private fileSizePipe: FileSizePipe,\r\n    public defaultAdapter: FileService,\r\n  ) {\r\n    this.adapter = this.adapter || defaultAdapter;\r\n  }\r\n\r\n  public ngOnInit() {\r\n    this.elementRef.nativeElement.addEventListener(\r\n      \"change\",\r\n      () => {\r\n        // replace file is single select mode\r\n        if (!this.multiple) {\r\n          this.filePicker.files = [];\r\n        }\r\n\r\n        this.field.control.markAsTouched();\r\n      },\r\n      { capture: true });\r\n  }\r\n\r\n  public onValidationError(error: ValidationError) {\r\n    const errIndex = this.validationErrors.findIndex(e => e.file == error.file);\r\n    error.error = this.getValidationErrorMessage(error.error as FileValidationTypes);\r\n\r\n    if (errIndex != -1) {\r\n      this.validationErrors[errIndex] = error;\r\n    }\r\n    else {\r\n      this.validationErrors.push(error);\r\n    }\r\n  }\r\n\r\n  public onFileAdded(file: FilePreviewModel) {\r\n    this.validationErrors = [];\r\n\r\n    this.field.value = this.field.value\r\n      ? [...this.field.value, file.file as File]\r\n      : [file.file as File];\r\n  }\r\n\r\n  public onFileRemoved(removedFile: FilePreviewModel) {\r\n    this.validationErrors = [];\r\n\r\n    this.field.value = this.field.value\r\n      ? this.field.value.filter(file => file.name != removedFile.fileName)\r\n      : [removedFile.file as File];\r\n  }\r\n\r\n  private getValidationErrorMessage(errorType: FileValidationTypes) {\r\n    switch (errorType) {\r\n\r\n      case FileValidationTypes.uploadType:\r\n        return this.multiple ? \"Select multiple files\" : \"Select only one file\";\r\n\r\n      case FileValidationTypes.extensions:\r\n        return `Selected file should have ${this.allowedFileExtensions} extension`;\r\n\r\n      case FileValidationTypes.fileMaxSize:\r\n        return `The size of selected file is larger than ${this.fileSizePipe.transform(this.maxFileSize)}`;\r\n\r\n      case FileValidationTypes.totalMaxSize:\r\n        return `The total size of selected files is larger than ${this.fileSizePipe.transform(this.totalFileSize)}`;\r\n\r\n      default:\r\n        return \"There was an error while adding your file\";\r\n    }\r\n  }\r\n}\r\n","<base-control #baseControl\r\n              [field]=\"field\">\r\n  <div class=\"field-label\">\r\n    <ngx-awesome-uploader #uploader\r\n                          [adapter]=\"adapter\"\r\n                          [showeDragDropZone]=\"true\"\r\n                          [showPreviewContainer]=\"showPreview\"\r\n                          [uploadType]=\"multiple ? 'multi' : 'single'\"\r\n                          [fileMaxSize]=\"maxFileSize\"\r\n                          [totalMaxSize]=\"totalFileSize\"\r\n                          [accept]=\"accept.toString()\"\r\n                          [itemTemplate]=\"fileItemTemplate\"\r\n                          [enableAutoUpload]=\"autoUpload\"\r\n                          [fileExtensions]=\"allowedFileExtensions\"\r\n                          (validationError)=\"onValidationError($event)\"\r\n                          (fileAdded)=\"onFileAdded($event)\">\r\n\r\n      <div class=\"dropzoneTemplate\">\r\n        <button mat-raised-button\r\n                type=\"button\">{{ field.label }}</button>\r\n      </div>\r\n    </ngx-awesome-uploader>\r\n  </div>\r\n\r\n  <mat-error *ngIf=\"baseControl.initialized && field.control.touched\">\r\n    <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n    <ng-container *ngIf=\"validationErrors\">\r\n      <mat-error *ngFor=\"let error of validationErrors\">\r\n        {{ error.error }}\r\n      </mat-error>\r\n    </ng-container>\r\n  </mat-error>\r\n</base-control>\r\n\r\n<ng-template #fileItemTemplate\r\n             let-fileItem=\"fileItem\"\r\n             let-uploadProgress=\"uploadProgress\">\r\n  <div class=\"toolbar\">\r\n    <span class=\"text-left\">\r\n      {{ fileItem.fileName }}\r\n    </span>\r\n\r\n    <div *ngIf=\"fileItem\">\r\n      <button mat-button\r\n              mat-icon-button\r\n              type=\"button\"\r\n              (click)=\"uploader.removeFile(fileItem); onFileRemoved(fileItem)\">\r\n        <mat-icon>clear</mat-icon>\r\n      </button>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n"]}

@@ -7,2 +7,3 @@ import { NgModule } from "@angular/core";

import { FileControlComponent } from "./file-control.component";
import { MatButtonModule } from "@angular/material/button";
import * as i0 from "@angular/core";

@@ -14,4 +15,6 @@ export class NgxFileControlModule {

NgxBaseControlModule,
MatButtonModule,
NgxFilesizeModule,
FilePickerModule], exports: [NgxBaseControlModule,
MatButtonModule,
NgxFilesizeModule,

@@ -25,5 +28,7 @@ FilePickerModule,

NgxBaseControlModule,
MatButtonModule,
NgxFilesizeModule,
FilePickerModule,
], NgxBaseControlModule,
MatButtonModule,
NgxFilesizeModule,

@@ -37,2 +42,3 @@ FilePickerModule] });

NgxBaseControlModule,
MatButtonModule,
NgxFilesizeModule,

@@ -43,2 +49,3 @@ FilePickerModule,

NgxBaseControlModule,
MatButtonModule,
NgxFilesizeModule,

@@ -56,2 +63,2 @@ FilePickerModule,

}] });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWZpbGUtY29udHJvbC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLWV4dGVuc2lvbnMvY29udHJvbHMvZmlsZS1jb250cm9sL25neC1maWxlLWNvbnRyb2wubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFPLHNCQUFzQixDQUFDO0FBQ3pELE9BQU8sRUFBRSxZQUFZLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFFL0QsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDaEYsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7O0FBdUJoRSxNQUFNLE9BQU8sb0JBQW9COztpSEFBcEIsb0JBQW9CO2tIQUFwQixvQkFBb0IsaUJBTjdCLG9CQUFvQixhQWJwQixZQUFZO1FBQ1osb0JBQW9CO1FBQ3BCLGlCQUFpQjtRQUNqQixnQkFBZ0IsYUFHaEIsb0JBQW9CO1FBQ3BCLGlCQUFpQjtRQUNqQixnQkFBZ0I7UUFFaEIsb0JBQW9CO2tIQVNYLG9CQUFvQixhQUpwQjtRQUNULFlBQVk7S0FDYixZQWxCUTtZQUNQLFlBQVk7WUFDWixvQkFBb0I7WUFDcEIsaUJBQWlCO1lBQ2pCLGdCQUFnQjtTQUNqQixFQUVDLG9CQUFvQjtRQUNwQixpQkFBaUI7UUFDakIsZ0JBQWdCOzJGQVdQLG9CQUFvQjtrQkFyQmhDLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osb0JBQW9CO3dCQUNwQixpQkFBaUI7d0JBQ2pCLGdCQUFnQjtxQkFDakI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLG9CQUFvQjt3QkFDcEIsaUJBQWlCO3dCQUNqQixnQkFBZ0I7d0JBRWhCLG9CQUFvQjtxQkFDckI7b0JBQ0QsWUFBWSxFQUFFO3dCQUNaLG9CQUFvQjtxQkFDckI7b0JBQ0QsU0FBUyxFQUFFO3dCQUNULFlBQVk7cUJBQ2I7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuaW1wb3J0IHsgRmlsZVBpY2tlck1vZHVsZSB9IGZyb20gIFwibmd4LWF3ZXNvbWUtdXBsb2FkZXJcIjtcclxuaW1wb3J0IHsgRmlsZVNpemVQaXBlLCBOZ3hGaWxlc2l6ZU1vZHVsZSB9IGZyb20gXCJuZ3gtZmlsZXNpemVcIjtcclxuXHJcbmltcG9ydCB7IE5neEJhc2VDb250cm9sTW9kdWxlIH0gZnJvbSBcImFuZ3VsYXItZXh0ZW5zaW9ucy9jb250cm9scy9iYXNlLWNvbnRyb2xcIjtcclxuaW1wb3J0IHsgRmlsZUNvbnRyb2xDb21wb25lbnQgfSBmcm9tIFwiLi9maWxlLWNvbnRyb2wuY29tcG9uZW50XCI7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIE5neEJhc2VDb250cm9sTW9kdWxlLFxyXG4gICAgTmd4RmlsZXNpemVNb2R1bGUsXHJcbiAgICBGaWxlUGlja2VyTW9kdWxlLFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgTmd4QmFzZUNvbnRyb2xNb2R1bGUsXHJcbiAgICBOZ3hGaWxlc2l6ZU1vZHVsZSxcclxuICAgIEZpbGVQaWNrZXJNb2R1bGUsXHJcblxyXG4gICAgRmlsZUNvbnRyb2xDb21wb25lbnQsXHJcbiAgXSxcclxuICBkZWNsYXJhdGlvbnM6IFtcclxuICAgIEZpbGVDb250cm9sQ29tcG9uZW50LFxyXG4gIF0sXHJcbiAgcHJvdmlkZXJzOiBbXHJcbiAgICBGaWxlU2l6ZVBpcGUsXHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgTmd4RmlsZUNvbnRyb2xNb2R1bGUgeyB9XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWZpbGUtY29udHJvbC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLWV4dGVuc2lvbnMvY29udHJvbHMvZmlsZS1jb250cm9sL25neC1maWxlLWNvbnRyb2wubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFPLHNCQUFzQixDQUFDO0FBQ3pELE9BQU8sRUFBRSxZQUFZLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFFL0QsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDaEYsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDaEUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDOztBQXlCM0QsTUFBTSxPQUFPLG9CQUFvQjs7aUhBQXBCLG9CQUFvQjtrSEFBcEIsb0JBQW9CLGlCQU43QixvQkFBb0IsYUFmcEIsWUFBWTtRQUNaLG9CQUFvQjtRQUNwQixlQUFlO1FBQ2YsaUJBQWlCO1FBQ2pCLGdCQUFnQixhQUdoQixvQkFBb0I7UUFDcEIsZUFBZTtRQUNmLGlCQUFpQjtRQUNqQixnQkFBZ0I7UUFFaEIsb0JBQW9CO2tIQVNYLG9CQUFvQixhQUpwQjtRQUNULFlBQVk7S0FDYixZQXBCUTtZQUNQLFlBQVk7WUFDWixvQkFBb0I7WUFDcEIsZUFBZTtZQUNmLGlCQUFpQjtZQUNqQixnQkFBZ0I7U0FDakIsRUFFQyxvQkFBb0I7UUFDcEIsZUFBZTtRQUNmLGlCQUFpQjtRQUNqQixnQkFBZ0I7MkZBV1Asb0JBQW9CO2tCQXZCaEMsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixvQkFBb0I7d0JBQ3BCLGVBQWU7d0JBQ2YsaUJBQWlCO3dCQUNqQixnQkFBZ0I7cUJBQ2pCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxvQkFBb0I7d0JBQ3BCLGVBQWU7d0JBQ2YsaUJBQWlCO3dCQUNqQixnQkFBZ0I7d0JBRWhCLG9CQUFvQjtxQkFDckI7b0JBQ0QsWUFBWSxFQUFFO3dCQUNaLG9CQUFvQjtxQkFDckI7b0JBQ0QsU0FBUyxFQUFFO3dCQUNULFlBQVk7cUJBQ2I7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuaW1wb3J0IHsgRmlsZVBpY2tlck1vZHVsZSB9IGZyb20gIFwibmd4LWF3ZXNvbWUtdXBsb2FkZXJcIjtcclxuaW1wb3J0IHsgRmlsZVNpemVQaXBlLCBOZ3hGaWxlc2l6ZU1vZHVsZSB9IGZyb20gXCJuZ3gtZmlsZXNpemVcIjtcclxuXHJcbmltcG9ydCB7IE5neEJhc2VDb250cm9sTW9kdWxlIH0gZnJvbSBcImFuZ3VsYXItZXh0ZW5zaW9ucy9jb250cm9scy9iYXNlLWNvbnRyb2xcIjtcclxuaW1wb3J0IHsgRmlsZUNvbnRyb2xDb21wb25lbnQgfSBmcm9tIFwiLi9maWxlLWNvbnRyb2wuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9idXR0b25cIjtcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgTmd4QmFzZUNvbnRyb2xNb2R1bGUsXHJcbiAgICBNYXRCdXR0b25Nb2R1bGUsXHJcbiAgICBOZ3hGaWxlc2l6ZU1vZHVsZSxcclxuICAgIEZpbGVQaWNrZXJNb2R1bGUsXHJcbiAgXSxcclxuICBleHBvcnRzOiBbXHJcbiAgICBOZ3hCYXNlQ29udHJvbE1vZHVsZSxcclxuICAgIE1hdEJ1dHRvbk1vZHVsZSxcclxuICAgIE5neEZpbGVzaXplTW9kdWxlLFxyXG4gICAgRmlsZVBpY2tlck1vZHVsZSxcclxuXHJcbiAgICBGaWxlQ29udHJvbENvbXBvbmVudCxcclxuICBdLFxyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgRmlsZUNvbnRyb2xDb21wb25lbnQsXHJcbiAgXSxcclxuICBwcm92aWRlcnM6IFtcclxuICAgIEZpbGVTaXplUGlwZSxcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBOZ3hGaWxlQ29udHJvbE1vZHVsZSB7IH1cclxuIl19
export * from "angular-extensions/controls/base-control";
export * from "angular-extensions/controls/text-control";
export * from "angular-extensions/controls/textarea-control";
export * from "angular-extensions/controls/file-control";
export * from "./date-control/date-control.component";

@@ -13,2 +14,2 @@ export * from "./time-control/time-control.component";

export * from "./ngx-controls.module";
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItZXh0ZW5zaW9ucy9jb250cm9scy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsMENBQTBDLENBQUM7QUFDekQsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLDhDQUE4QyxDQUFDO0FBRTdELGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYywwREFBMEQsQ0FBQztBQUN6RSxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyxtREFBbUQsQ0FBQztBQUNsRSxjQUFjLHVCQUF1QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcImFuZ3VsYXItZXh0ZW5zaW9ucy9jb250cm9scy9iYXNlLWNvbnRyb2xcIjtcclxuZXhwb3J0ICogZnJvbSBcImFuZ3VsYXItZXh0ZW5zaW9ucy9jb250cm9scy90ZXh0LWNvbnRyb2xcIjtcclxuZXhwb3J0ICogZnJvbSBcImFuZ3VsYXItZXh0ZW5zaW9ucy9jb250cm9scy90ZXh0YXJlYS1jb250cm9sXCI7XHJcblxyXG5leHBvcnQgKiBmcm9tIFwiLi9kYXRlLWNvbnRyb2wvZGF0ZS1jb250cm9sLmNvbXBvbmVudFwiO1xyXG5leHBvcnQgKiBmcm9tIFwiLi90aW1lLWNvbnRyb2wvdGltZS1jb250cm9sLmNvbXBvbmVudFwiO1xyXG5leHBvcnQgKiBmcm9tIFwiLi9kYXRldGltZS1jb250cm9sL2RhdGV0aW1lLWNvbnRyb2wuY29tcG9uZW50XCI7XHJcbmV4cG9ydCAqIGZyb20gXCIuL3NlbGVjdC1jb250cm9sL3NlbGVjdC1jb250cm9sLmNvbXBvbmVudFwiO1xyXG5leHBvcnQgKiBmcm9tIFwiLi9zZWxlY3QtY29udHJvbC9vcHRpb24tY29udGV4dC9vcHRpb24tY29udGV4dC5kaXJlY3RpdmVcIjtcclxuZXhwb3J0ICogZnJvbSBcIi4vY2hlY2tib3gtY29udHJvbC9jaGVja2JveC1jb250cm9sLmNvbXBvbmVudFwiO1xyXG5leHBvcnQgKiBmcm9tIFwiLi9zcGlubmVyL3NwaW5uZXIuY29tcG9uZW50XCI7XHJcbmV4cG9ydCAqIGZyb20gXCIuL2NvbGxlY3Rpb24tY29udHJvbC9jb2xsZWN0aW9uLWNvbnRyb2wuY29tcG9uZW50XCI7XHJcbmV4cG9ydCAqIGZyb20gXCIuL25neC1jb250cm9scy5tb2R1bGVcIjtcclxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItZXh0ZW5zaW9ucy9jb250cm9scy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsMENBQTBDLENBQUM7QUFDekQsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsMENBQTBDLENBQUM7QUFFekQsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLDBEQUEwRCxDQUFDO0FBQ3pFLGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsdUJBQXVCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiYW5ndWxhci1leHRlbnNpb25zL2NvbnRyb2xzL2Jhc2UtY29udHJvbFwiO1xyXG5leHBvcnQgKiBmcm9tIFwiYW5ndWxhci1leHRlbnNpb25zL2NvbnRyb2xzL3RleHQtY29udHJvbFwiO1xyXG5leHBvcnQgKiBmcm9tIFwiYW5ndWxhci1leHRlbnNpb25zL2NvbnRyb2xzL3RleHRhcmVhLWNvbnRyb2xcIjtcclxuZXhwb3J0ICogZnJvbSBcImFuZ3VsYXItZXh0ZW5zaW9ucy9jb250cm9scy9maWxlLWNvbnRyb2xcIjtcclxuXHJcbmV4cG9ydCAqIGZyb20gXCIuL2RhdGUtY29udHJvbC9kYXRlLWNvbnRyb2wuY29tcG9uZW50XCI7XHJcbmV4cG9ydCAqIGZyb20gXCIuL3RpbWUtY29udHJvbC90aW1lLWNvbnRyb2wuY29tcG9uZW50XCI7XHJcbmV4cG9ydCAqIGZyb20gXCIuL2RhdGV0aW1lLWNvbnRyb2wvZGF0ZXRpbWUtY29udHJvbC5jb21wb25lbnRcIjtcclxuZXhwb3J0ICogZnJvbSBcIi4vc2VsZWN0LWNvbnRyb2wvc2VsZWN0LWNvbnRyb2wuY29tcG9uZW50XCI7XHJcbmV4cG9ydCAqIGZyb20gXCIuL3NlbGVjdC1jb250cm9sL29wdGlvbi1jb250ZXh0L29wdGlvbi1jb250ZXh0LmRpcmVjdGl2ZVwiO1xyXG5leHBvcnQgKiBmcm9tIFwiLi9jaGVja2JveC1jb250cm9sL2NoZWNrYm94LWNvbnRyb2wuY29tcG9uZW50XCI7XHJcbmV4cG9ydCAqIGZyb20gXCIuL3NwaW5uZXIvc3Bpbm5lci5jb21wb25lbnRcIjtcclxuZXhwb3J0ICogZnJvbSBcIi4vY29sbGVjdGlvbi1jb250cm9sL2NvbGxlY3Rpb24tY29udHJvbC5jb21wb25lbnRcIjtcclxuZXhwb3J0ICogZnJvbSBcIi4vbmd4LWNvbnRyb2xzLm1vZHVsZVwiO1xyXG4iXX0=
import * as i0 from '@angular/core';
import { Injectable, EventEmitter, Component, Input, Output, NgModule } from '@angular/core';
import { Injectable, EventEmitter, Component, Input, Output, ViewChild, NgModule } from '@angular/core';
import * as i4 from 'ngx-awesome-uploader';
import { FilePickerAdapter, FileValidationTypes, FilePickerModule } from 'ngx-awesome-uploader';
import { FilePickerAdapter, FileValidationTypes, FilePickerComponent, FilePickerModule } from 'ngx-awesome-uploader';
import { of } from 'rxjs';

@@ -10,6 +10,8 @@ import * as i1 from 'ngx-filesize';

import { NgxBaseControlModule } from 'angular-extensions/controls/base-control';
import * as i5 from '@angular/material/icon';
import * as i6 from '@angular/common';
import * as i5 from '@angular/material/button';
import { MatButtonModule } from '@angular/material/button';
import * as i6 from '@angular/material/icon';
import * as i7 from '@angular/common';
import { CommonModule } from '@angular/common';
import * as i7 from '@angular/material/form-field';
import * as i8 from '@angular/material/form-field';

@@ -34,6 +36,6 @@ class FileService extends FilePickerAdapter {

class FileControlComponent {
constructor(fileSizePipe, defaultAdapter) {
constructor(elementRef, fileSizePipe, defaultAdapter) {
this.elementRef = elementRef;
this.fileSizePipe = fileSizePipe;
this.defaultAdapter = defaultAdapter;
this.allowedFileExtensions = [];
this.accept = [];

@@ -46,2 +48,9 @@ this.autoUpload = false;

ngOnInit() {
this.elementRef.nativeElement.addEventListener("change", () => {
// replace file is single select mode
if (!this.multiple) {
this.filePicker.files = [];
}
this.field.control.markAsTouched();
}, { capture: true });
}

@@ -85,4 +94,4 @@ onValidationError(error) {

}
FileControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: FileControlComponent, deps: [{ token: i1.FileSizePipe }, { token: FileService }], target: i0.ɵɵFactoryTarget.Component });
FileControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: FileControlComponent, selector: "file-control", inputs: { field: "field", disabled: "disabled", multiple: "multiple", allowedFileExtensions: "allowedFileExtensions", accept: "accept", maxFileSize: "maxFileSize", totalFileSize: "totalFileSize", autoUpload: "autoUpload", adapter: "adapter" }, outputs: { changes: "changes" }, providers: [FileService], ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <div class=\"field-label\">\r\n\r\n <ngx-awesome-uploader #uploader\r\n [adapter]=\"adapter\"\r\n [showeDragDropZone]=\"true\"\r\n [uploadType]=\"multiple ? 'multi' : 'single'\"\r\n [fileMaxSize]=\"maxFileSize\"\r\n [totalMaxSize]=\"totalFileSize\"\r\n [fileMaxCount]=\"multiple ? $any(undefined) : 1\"\r\n [accept]=\"accept.toString()\"\r\n [itemTemplate]=\"fileItemTemplate\"\r\n [enableAutoUpload]=\"autoUpload\"\r\n [fileExtensions]=\"allowedFileExtensions\"\r\n (validationError)=\"onValidationError($event)\"\r\n (fileAdded)=\"onFileAdded($event)\">\r\n\r\n <div class=\"dropzoneTemplate\">\r\n <button mat-raised-button\r\n type=\"button\"\r\n (click)=\"field.control.markAsTouched()\">{{ field.label }}</button>\r\n </div>\r\n\r\n </ngx-awesome-uploader>\r\n\r\n </div>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized && field.control.touched\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n <ng-container *ngIf=\"validationErrors\">\r\n <mat-error *ngFor=\"let error of validationErrors\">\r\n {{ error.error }}\r\n </mat-error>\r\n </ng-container>\r\n </mat-error>\r\n</base-control>\r\n\r\n<ng-template #fileItemTemplate\r\n let-fileItem=\"fileItem\"\r\n let-uploadProgress=\"uploadProgress\">\r\n <div class=\"toolbar\">\r\n <span class=\"text-left\">\r\n {{ fileItem.fileName }}\r\n </span>\r\n\r\n <div *ngIf=\"fileItem\">\r\n <button mat-button\r\n mat-icon-button\r\n type=\"button\"\r\n (click)=\"uploader.removeFile(fileItem); onFileRemoved(fileItem)\">\r\n <mat-icon>clear</mat-icon>\r\n </button>\r\n </div>\r\n </div>\r\n</ng-template>\r\n", styles: [":host .field-label{width:100%}:host ::ng-deep ngx-awesome-uploader{max-width:none!important}:host ::ng-deep .file-drop-wrapper{background:#fff!important;padding-top:0!important}:host ::ng-deep .file-drop-wrapper #dropZone{padding:5px 0;border:none;max-width:none}:host ::ng-deep .file-drop-wrapper file-drop{padding:0 3px}:host ::ng-deep file-preview-item{position:initial;padding:10px 16px;max-width:none}:host .toolbar{position:relative;display:flex;justify-content:space-between;align-items:center}:host .toolbar mat-icon{cursor:pointer}:host .toolbar .editor-label{padding:8px 14px;display:inline-block;line-height:1em;height:34px}:host .toolbar .form-control{width:auto;display:inline-block;line-height:1em;height:34px;margin-right:.3em}\n"], components: [{ type: i3.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i4.FilePickerComponent, selector: "ngx-awesome-uploader", inputs: ["enableCropper", "showeDragDropZone", "showPreviewContainer", "uploadType", "croppedCanvasOptions", "captions", "enableAutoUpload", "cropperOptions", "customValidator", "itemTemplate", "fileMaxSize", "fileMaxCount", "totalMaxSize", "accept", "fileExtensions", "adapter", "dropzoneTemplate", "fileInputCapture"], outputs: ["uploadSuccess", "uploadFail", "removeSuccess", "validationError", "fileAdded", "fileRemoved"] }, { type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.MatError, selector: "mat-error", inputs: ["id"] }, { type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
FileControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: FileControlComponent, deps: [{ token: i0.ElementRef }, { token: i1.FileSizePipe }, { token: FileService }], target: i0.ɵɵFactoryTarget.Component });
FileControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: FileControlComponent, selector: "file-control", inputs: { field: "field", disabled: "disabled", multiple: "multiple", allowedFileExtensions: "allowedFileExtensions", accept: "accept", maxFileSize: "maxFileSize", totalFileSize: "totalFileSize", autoUpload: "autoUpload", adapter: "adapter", showPreview: "showPreview" }, outputs: { changes: "changes" }, providers: [FileService], viewQueries: [{ propertyName: "filePicker", first: true, predicate: FilePickerComponent, descendants: true }], ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <div class=\"field-label\">\r\n <ngx-awesome-uploader #uploader\r\n [adapter]=\"adapter\"\r\n [showeDragDropZone]=\"true\"\r\n [showPreviewContainer]=\"showPreview\"\r\n [uploadType]=\"multiple ? 'multi' : 'single'\"\r\n [fileMaxSize]=\"maxFileSize\"\r\n [totalMaxSize]=\"totalFileSize\"\r\n [accept]=\"accept.toString()\"\r\n [itemTemplate]=\"fileItemTemplate\"\r\n [enableAutoUpload]=\"autoUpload\"\r\n [fileExtensions]=\"allowedFileExtensions\"\r\n (validationError)=\"onValidationError($event)\"\r\n (fileAdded)=\"onFileAdded($event)\">\r\n\r\n <div class=\"dropzoneTemplate\">\r\n <button mat-raised-button\r\n type=\"button\">{{ field.label }}</button>\r\n </div>\r\n </ngx-awesome-uploader>\r\n </div>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized && field.control.touched\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n <ng-container *ngIf=\"validationErrors\">\r\n <mat-error *ngFor=\"let error of validationErrors\">\r\n {{ error.error }}\r\n </mat-error>\r\n </ng-container>\r\n </mat-error>\r\n</base-control>\r\n\r\n<ng-template #fileItemTemplate\r\n let-fileItem=\"fileItem\"\r\n let-uploadProgress=\"uploadProgress\">\r\n <div class=\"toolbar\">\r\n <span class=\"text-left\">\r\n {{ fileItem.fileName }}\r\n </span>\r\n\r\n <div *ngIf=\"fileItem\">\r\n <button mat-button\r\n mat-icon-button\r\n type=\"button\"\r\n (click)=\"uploader.removeFile(fileItem); onFileRemoved(fileItem)\">\r\n <mat-icon>clear</mat-icon>\r\n </button>\r\n </div>\r\n </div>\r\n</ng-template>\r\n", styles: [":host .field-label{width:100%}:host ::ng-deep ngx-awesome-uploader{max-width:none!important}:host ::ng-deep .file-drop-wrapper{width:auto!important;background:none!important;padding-top:0!important}:host ::ng-deep .file-drop-wrapper #dropZone{padding:5px 0;border:none;max-width:none;background:none}:host ::ng-deep .file-drop-wrapper file-drop{padding:0 3px}:host ::ng-deep file-preview-item{position:initial;padding:10px 16px;max-width:none}:host .toolbar{position:relative;display:flex;justify-content:space-between;align-items:center}:host .toolbar mat-icon{cursor:pointer}:host .toolbar .editor-label{padding:8px 14px;display:inline-block;line-height:1em;height:34px}:host .toolbar .form-control{width:auto;display:inline-block;line-height:1em;height:34px;margin-right:.3em}\n"], components: [{ type: i3.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i4.FilePickerComponent, selector: "ngx-awesome-uploader", inputs: ["enableCropper", "showeDragDropZone", "showPreviewContainer", "uploadType", "croppedCanvasOptions", "captions", "enableAutoUpload", "cropperOptions", "customValidator", "itemTemplate", "fileMaxSize", "fileMaxCount", "totalMaxSize", "accept", "fileExtensions", "adapter", "dropzoneTemplate", "fileInputCapture"], outputs: ["uploadSuccess", "uploadFail", "removeSuccess", "validationError", "fileAdded", "fileRemoved"] }, { type: i5.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.MatError, selector: "mat-error", inputs: ["id"] }, { type: i7.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: FileControlComponent, decorators: [{

@@ -96,3 +105,3 @@ type: Component,

}]
}], ctorParameters: function () { return [{ type: i1.FileSizePipe }, { type: FileService }]; }, propDecorators: { field: [{
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.FileSizePipe }, { type: FileService }]; }, propDecorators: { field: [{
type: Input

@@ -115,4 +124,9 @@ }], disabled: [{

type: Input
}], showPreview: [{
type: Input
}], changes: [{
type: Output
}], filePicker: [{
type: ViewChild,
args: [FilePickerComponent]
}] } });

@@ -125,4 +139,6 @@

NgxBaseControlModule,
MatButtonModule,
NgxFilesizeModule,
FilePickerModule], exports: [NgxBaseControlModule,
MatButtonModule,
NgxFilesizeModule,

@@ -136,5 +152,7 @@ FilePickerModule,

NgxBaseControlModule,
MatButtonModule,
NgxFilesizeModule,
FilePickerModule,
], NgxBaseControlModule,
MatButtonModule,
NgxFilesizeModule,

@@ -148,2 +166,3 @@ FilePickerModule] });

NgxBaseControlModule,
MatButtonModule,
NgxFilesizeModule,

@@ -154,2 +173,3 @@ FilePickerModule,

NgxBaseControlModule,
MatButtonModule,
NgxFilesizeModule,

@@ -156,0 +176,0 @@ FilePickerModule,

@@ -8,2 +8,3 @@ import * as i1 from 'angular-extensions/controls/base-control';

export * from 'angular-extensions/controls/textarea-control';
export * from 'angular-extensions/controls/file-control';
import * as i0 from '@angular/core';

@@ -10,0 +11,0 @@ import { Component, Inject, Input, ViewEncapsulation, TemplateRef, ContentChild, Directive, ChangeDetectionStrategy, Optional, ViewChild, EventEmitter, Output, NgModule } from '@angular/core';

{
"name": "angular-extensions",
"version": "1.0.26",
"version": "1.0.27",
"repository": "https://github.com/nazar-kuzo/angular-extensions.git",

@@ -5,0 +5,0 @@ "author": "Nazar Kuzo",

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc