Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@iplab/ngx-file-upload

Package Overview
Dependencies
Maintainers
1
Versions
69
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@iplab/ngx-file-upload - npm Package Compare versions

Comparing version 1.1.1 to 1.1.2

10

components/file-upload-attr.component.d.ts

@@ -20,15 +20,15 @@ import { OnInit, ElementRef, Renderer2, OnDestroy, TemplateRef, AfterViewInit } from '@angular/core';

readonly isInvalid: boolean;
private setEvents();
private checkAndMarkAsDisabled();
private preventDragEvents(event);
private setEvents;
private checkAndMarkAsDisabled;
private preventDragEvents;
/**
* on file over add class name
*/
private onDragOver(event);
private onDragOver;
/**
* on mouse out remove class name
*/
private onDragLeave(event);
private onDragLeave;
onDrop(event: DragEvent): void;
private onTouch;
}

@@ -28,20 +28,20 @@ import { OnInit, ElementRef, Renderer2, OnDestroy, TemplateRef, ChangeDetectorRef } from '@angular/core';

readonly isInvalid: boolean;
private setEvents();
private checkAndMarkAsDisabled();
private preventDragEvents(event);
private setEvents;
private checkAndMarkAsDisabled;
private preventDragEvents;
/**
* on file over add class name
*/
private onDragOver(event);
private onDragOver;
/**
* on mouse out remove class name
*/
private onDragLeave(event);
private onDragLeave;
onDrop(event: DragEvent): void;
onInputChange(event: Event): void;
private clearInputEl();
private clearInputEl;
/**
* ControlValueAccessor implementation
*/
private connectToForm();
private connectToForm;
/**

@@ -48,0 +48,0 @@ * model -> view changes

@@ -18,5 +18,5 @@ import { OnChanges, SimpleChanges } from '@angular/core';

export declare class FileSizeValidator implements Validator, OnChanges {
private filesize;
private minsize;
private maxsize;
filesize: string | number;
minsize: string | number;
maxsize: string | number;
private validator;

@@ -27,3 +27,3 @@ private onChange;

registerOnValidatorChange(fn: () => void): void;
private _createValidator();
private _createValidator;
}

@@ -43,3 +43,3 @@ /**

export declare class FilesLimitValidator implements Validator, OnChanges {
private fileslimit;
fileslimit: string | number;
private validator;

@@ -50,3 +50,3 @@ private onChange;

registerOnValidatorChange(fn: () => void): void;
private _createValidator();
private _createValidator;
}

@@ -68,3 +68,3 @@ /**

export declare class FilesAcceptValidator implements Validator, OnChanges {
private accept;
accept: string;
private validator;

@@ -75,3 +75,3 @@ private onChange;

registerOnValidatorChange(fn: () => void): void;
private _createValidator();
private _createValidator;
}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/

@@ -134,3 +134,4 @@ import { Input, ElementRef, HostListener, Renderer2, HostBinding, Inject, ViewChild, ContentChild, TemplateRef, Component } from '@angular/core';

}
const /** @type {?} */ files = event.dataTransfer.files;
/** @type {?} */
const files = event.dataTransfer.files;
this.control.addFiles(files);

@@ -195,3 +196,3 @@ this.onTouch();

};
function FileUploadAttributeComponent_tsickle_Closure_declarations() {
if (false) {
/** @type {?} */

@@ -218,3 +219,2 @@ FileUploadAttributeComponent.prototype.control;

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload-attr.component.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["components/file-upload-attr.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Input,\r\n    OnInit,\r\n    ElementRef,\r\n    HostListener,\r\n    Renderer2,\r\n    OnDestroy,\r\n    HostBinding,\r\n    Inject,\r\n    ViewChild,\r\n    ContentChild,\r\n    TemplateRef,\r\n    Component,\r\n    AfterViewInit\r\n} from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\n\r\nimport { FileUploadControl } from '../helpers/control.class';\r\nimport { IsNullOrEmpty } from '../helpers/helpers.class';\r\nimport { FileUploadService } from '../services/file-upload.service';\r\nimport { DRAGOVER, TOUCHED } from './file-upload.component';\r\nimport { Subscription } from 'rxjs';\r\n\r\n\r\n@Component({\r\n    selector: `[file-drop-zone]`,\r\n    template: `\r\n        <ng-content></ng-content>\r\n        <div #overlay class=\"overlay\" *ngIf=\"fileUploadService.isFileDragDropAvailable()\">\r\n\r\n            <div class=\"upload-input\">\r\n                <ng-container *ngTemplateOutlet=\"templateRef ? templateRef : defaultTemplate\"></ng-container>\r\n\r\n                <ng-template #defaultTemplate>\r\n                    <div class=\"icon\">\r\n                        <svg viewBox=\"0 0 96 96\">\r\n                            <g>\r\n                                <path d=\"M62.8,68.1c0-0.6-0.2-1.1-0.6-1.5c-0.4-0.4-0.9-0.6-1.5-0.6s-1.1,0.2-1.5,0.6\r\n                                    c-0.4,0.4-0.6,0.9-0.6,1.5c0,0.6,0.2,1.1,0.6,1.5c0.4,0.4,0.9,0.6,1.5,0.6s1.1-0.2,1.5-0.6S62.8,68.7,62.8,68.1z M71.3,68.1\r\n                                    c0-0.6-0.2-1.1-0.6-1.5c-0.4-0.4-0.9-0.6-1.5-0.6c-0.6,0-1.1,0.2-1.5,0.6C67.2,67,67,67.5,67,68.1c0,0.6,0.2,1.1,0.6,1.5\r\n                                    s0.9,0.6,1.5,0.6c0.6,0,1.1-0.2,1.5-0.6C71.1,69.2,71.3,68.7,71.3,68.1z M75.5,60.7v10.6c0,0.9-0.3,1.6-0.9,2.2\r\n                                    c-0.6,0.6-1.4,0.9-2.2,0.9H23.7c-0.9,0-1.6-0.3-2.2-0.9c-0.6-0.6-0.9-1.4-0.9-2.2V60.7c0-0.9,0.3-1.6,0.9-2.2\r\n                                    c0.6-0.6,1.4-0.9,2.2-0.9h14.1c0.5,1.2,1.2,2.2,2.3,3c1.1,0.8,2.3,1.2,3.7,1.2h8.5c1.3,0,2.6-0.4,3.7-1.2c1.1-0.8,1.9-1.8,2.3-3\r\n                                    h14.1c0.9,0,1.6,0.3,2.2,0.9C75.2,59.1,75.5,59.8,75.5,60.7z M64.8,39.3c-0.4,0.9-1,1.3-2,1.3h-8.5v14.8c0,0.6-0.2,1.1-0.6,1.5\r\n                                    c-0.4,0.4-0.9,0.6-1.5,0.6h-8.5c-0.6,0-1.1-0.2-1.5-0.6c-0.4-0.4-0.6-0.9-0.6-1.5V40.6h-8.5c-0.9,0-1.6-0.4-2-1.3\r\n                                    c-0.4-0.9-0.2-1.6,0.5-2.3l14.8-14.8c0.4-0.4,0.9-0.6,1.5-0.6s1.1,0.2,1.5,0.6L64.3,37C65,37.7,65.1,38.4,64.8,39.3z\"/>\r\n                            </g>\r\n                        </svg>\r\n                    </div>\r\n                \r\n                    <div class=\"upload-text\">\r\n                        <b>Drop</b> it here\r\n                    </div>\r\n                </ng-template>\r\n            </div>\r\n        </div>\r\n    `,\r\n    styles: [`:host{position:relative;display:block}:host .overlay{display:none;background:rgba(255,255,255,.8);outline:#92b0b3 dashed 2px;outline-offset:-10px;position:absolute;top:0;left:0;right:0;bottom:0}:host(.dragover:not(.disabled)) .overlay{display:block}.icon{height:35px;width:35px;border:1px solid #eaeaea;border-radius:4px;margin:0 auto 10px}:host /deep/ .icon svg{fill:#80a9d2}.upload-input{pointer-events:none;cursor:pointer;display:inline-block;color:#80a9d2;position:absolute;top:50%;left:50%;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);transition:all .15s ease-in-out}`],\r\n    providers: [ \r\n        FileUploadService\r\n    ]\r\n})\r\nexport class FileUploadAttributeComponent implements OnInit, AfterViewInit, OnDestroy {\r\n\r\n    @Input()\r\n    public control: FileUploadControl = null;\r\n\r\n    @ViewChild('overlay')\r\n    public overlay: ElementRef<HTMLDivElement>;\r\n\r\n    @ContentChild('placeholder')\r\n    public templateRef: TemplateRef<any> = null;\r\n\r\n    private hooks: Array<Function> = [];\r\n\r\n    private subscriptions: Array<Subscription> = [];\r\n\r\n    constructor(\r\n        public fileUploadService: FileUploadService,\r\n        private hostElementRef: ElementRef,\r\n        private renderer: Renderer2,\r\n        @Inject(DOCUMENT) private document\r\n    ) {}\r\n\r\n    public ngOnInit() {\r\n        if (IsNullOrEmpty(this.control)) {\r\n            this.control = new FileUploadControl();\r\n        }\r\n    }\r\n\r\n    public ngAfterViewInit(): void {\r\n        if (this.fileUploadService.isFileDragDropAvailable()) {\r\n            this.setEvents();\r\n            this.checkAndMarkAsDisabled();\r\n        }\r\n    }\r\n\r\n    public ngOnDestroy(): void {\r\n        this.hooks.forEach((hook) => hook());\r\n        this.hooks.length = 0;\r\n        this.subscriptions.forEach((subscription) => subscription.unsubscribe());\r\n        this.subscriptions.length = 0;\r\n    }\r\n\r\n    @HostBinding('class.has-files')\r\n    public get hasFiles(): boolean {\r\n        return this.control.isListVisible && this.control.size > 0;\r\n    }\r\n\r\n    @HostBinding('class.ng-invalid')\r\n    public get isInvalid(): boolean {\r\n        return !this.control.disabled && this.control.invalid;\r\n    }\r\n\r\n    private setEvents(): void {\r\n        ['drag', 'dragstart', 'dragend', 'dragover', 'dragenter', 'dragleave', 'drop'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.document, eventName, (event: any) => this.preventDragEvents(event))\r\n            );\r\n        });\r\n\r\n        ['dragover', 'dragenter'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.hostElementRef.nativeElement, eventName, (event: any) => this.onDragOver(event))\r\n            );\r\n        });\r\n\r\n        ['dragleave', 'dragend', 'drop'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.hostElementRef.nativeElement, eventName, (event: any) => {\r\n                    if(this.control.disabled && eventName === 'dragleave' || eventName !== 'dragleave') {\r\n                        this.onDragLeave(event);\r\n                    }\r\n                })\r\n            );\r\n        });\r\n\r\n        ['dragleave'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.overlay.nativeElement, eventName, (event: any) => this.onDragLeave(event))\r\n            );\r\n        });\r\n\r\n        this.subscriptions.push(\r\n            this.control.statusChanges.subscribe((status) => this.checkAndMarkAsDisabled())\r\n        );\r\n    }\r\n\r\n    private checkAndMarkAsDisabled(): void {\r\n        if (this.control.disabled) {\r\n            this.renderer.addClass(this.hostElementRef.nativeElement, 'disabled');\r\n        } else {\r\n            this.renderer.removeClass(this.hostElementRef.nativeElement, 'disabled');\r\n        }\r\n    }\r\n\r\n    private preventDragEvents(event: DragEvent): void {\r\n        event.preventDefault();\r\n        event.stopPropagation();\r\n    }\r\n\r\n    /**\r\n     * on file over add class name\r\n     */\r\n    private onDragOver(event: DragEvent): void {\r\n        this.renderer.addClass(this.hostElementRef.nativeElement, DRAGOVER);\r\n    }\r\n\r\n    /**\r\n     * on mouse out remove class name\r\n     */\r\n    private onDragLeave(event: DragEvent): void {\r\n        this.renderer.removeClass(this.hostElementRef.nativeElement, DRAGOVER);\r\n    }\r\n\r\n    @HostListener('drop', ['$event'])\r\n    public onDrop(event: DragEvent): void {\r\n        if (this.control.disabled) {\r\n            return;\r\n        }\r\n        const files = event.dataTransfer.files;\r\n        this.control.addFiles(files);\r\n        this.onTouch();\r\n    }\r\n\r\n    private onTouch: () => void = () => {\r\n        this.renderer.addClass(this.hostElementRef.nativeElement, TOUCHED);\r\n    };\r\n\r\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload-attr.component.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["components/file-upload-attr.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Input,\r\n    OnInit,\r\n    ElementRef,\r\n    HostListener,\r\n    Renderer2,\r\n    OnDestroy,\r\n    HostBinding,\r\n    Inject,\r\n    ViewChild,\r\n    ContentChild,\r\n    TemplateRef,\r\n    Component,\r\n    AfterViewInit\r\n} from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\n\r\nimport { FileUploadControl } from '../helpers/control.class';\r\nimport { IsNullOrEmpty } from '../helpers/helpers.class';\r\nimport { FileUploadService } from '../services/file-upload.service';\r\nimport { DRAGOVER, TOUCHED } from './file-upload.component';\r\nimport { Subscription } from 'rxjs';\r\n\r\n\r\n@Component({\r\n    selector: `[file-drop-zone]`,\r\n    template: `\r\n        <ng-content></ng-content>\r\n        <div #overlay class=\"overlay\" *ngIf=\"fileUploadService.isFileDragDropAvailable()\">\r\n\r\n            <div class=\"upload-input\">\r\n                <ng-container *ngTemplateOutlet=\"templateRef ? templateRef : defaultTemplate\"></ng-container>\r\n\r\n                <ng-template #defaultTemplate>\r\n                    <div class=\"icon\">\r\n                        <svg viewBox=\"0 0 96 96\">\r\n                            <g>\r\n                                <path d=\"M62.8,68.1c0-0.6-0.2-1.1-0.6-1.5c-0.4-0.4-0.9-0.6-1.5-0.6s-1.1,0.2-1.5,0.6\r\n                                    c-0.4,0.4-0.6,0.9-0.6,1.5c0,0.6,0.2,1.1,0.6,1.5c0.4,0.4,0.9,0.6,1.5,0.6s1.1-0.2,1.5-0.6S62.8,68.7,62.8,68.1z M71.3,68.1\r\n                                    c0-0.6-0.2-1.1-0.6-1.5c-0.4-0.4-0.9-0.6-1.5-0.6c-0.6,0-1.1,0.2-1.5,0.6C67.2,67,67,67.5,67,68.1c0,0.6,0.2,1.1,0.6,1.5\r\n                                    s0.9,0.6,1.5,0.6c0.6,0,1.1-0.2,1.5-0.6C71.1,69.2,71.3,68.7,71.3,68.1z M75.5,60.7v10.6c0,0.9-0.3,1.6-0.9,2.2\r\n                                    c-0.6,0.6-1.4,0.9-2.2,0.9H23.7c-0.9,0-1.6-0.3-2.2-0.9c-0.6-0.6-0.9-1.4-0.9-2.2V60.7c0-0.9,0.3-1.6,0.9-2.2\r\n                                    c0.6-0.6,1.4-0.9,2.2-0.9h14.1c0.5,1.2,1.2,2.2,2.3,3c1.1,0.8,2.3,1.2,3.7,1.2h8.5c1.3,0,2.6-0.4,3.7-1.2c1.1-0.8,1.9-1.8,2.3-3\r\n                                    h14.1c0.9,0,1.6,0.3,2.2,0.9C75.2,59.1,75.5,59.8,75.5,60.7z M64.8,39.3c-0.4,0.9-1,1.3-2,1.3h-8.5v14.8c0,0.6-0.2,1.1-0.6,1.5\r\n                                    c-0.4,0.4-0.9,0.6-1.5,0.6h-8.5c-0.6,0-1.1-0.2-1.5-0.6c-0.4-0.4-0.6-0.9-0.6-1.5V40.6h-8.5c-0.9,0-1.6-0.4-2-1.3\r\n                                    c-0.4-0.9-0.2-1.6,0.5-2.3l14.8-14.8c0.4-0.4,0.9-0.6,1.5-0.6s1.1,0.2,1.5,0.6L64.3,37C65,37.7,65.1,38.4,64.8,39.3z\"/>\r\n                            </g>\r\n                        </svg>\r\n                    </div>\r\n                \r\n                    <div class=\"upload-text\">\r\n                        <b>Drop</b> it here\r\n                    </div>\r\n                </ng-template>\r\n            </div>\r\n        </div>\r\n    `,\r\n    styles: [`:host{position:relative;display:block}:host .overlay{display:none;background:rgba(255,255,255,.8);outline:#92b0b3 dashed 2px;outline-offset:-10px;position:absolute;top:0;left:0;right:0;bottom:0}:host(.dragover:not(.disabled)) .overlay{display:block}.icon{height:35px;width:35px;border:1px solid #eaeaea;border-radius:4px;margin:0 auto 10px}:host /deep/ .icon svg{fill:#80a9d2}.upload-input{pointer-events:none;cursor:pointer;display:inline-block;color:#80a9d2;position:absolute;top:50%;left:50%;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);transition:all .15s ease-in-out}`],\r\n    providers: [ \r\n        FileUploadService\r\n    ]\r\n})\r\nexport class FileUploadAttributeComponent implements OnInit, AfterViewInit, OnDestroy {\r\n\r\n    @Input()\r\n    public control: FileUploadControl = null;\r\n\r\n    @ViewChild('overlay')\r\n    public overlay: ElementRef<HTMLDivElement>;\r\n\r\n    @ContentChild('placeholder')\r\n    public templateRef: TemplateRef<any> = null;\r\n\r\n    private hooks: Array<Function> = [];\r\n\r\n    private subscriptions: Array<Subscription> = [];\r\n\r\n    constructor(\r\n        public fileUploadService: FileUploadService,\r\n        private hostElementRef: ElementRef,\r\n        private renderer: Renderer2,\r\n        @Inject(DOCUMENT) private document\r\n    ) {}\r\n\r\n    public ngOnInit() {\r\n        if (IsNullOrEmpty(this.control)) {\r\n            this.control = new FileUploadControl();\r\n        }\r\n    }\r\n\r\n    public ngAfterViewInit(): void {\r\n        if (this.fileUploadService.isFileDragDropAvailable()) {\r\n            this.setEvents();\r\n            this.checkAndMarkAsDisabled();\r\n        }\r\n    }\r\n\r\n    public ngOnDestroy(): void {\r\n        this.hooks.forEach((hook) => hook());\r\n        this.hooks.length = 0;\r\n        this.subscriptions.forEach((subscription) => subscription.unsubscribe());\r\n        this.subscriptions.length = 0;\r\n    }\r\n\r\n    @HostBinding('class.has-files')\r\n    public get hasFiles(): boolean {\r\n        return this.control.isListVisible && this.control.size > 0;\r\n    }\r\n\r\n    @HostBinding('class.ng-invalid')\r\n    public get isInvalid(): boolean {\r\n        return !this.control.disabled && this.control.invalid;\r\n    }\r\n\r\n    private setEvents(): void {\r\n        ['drag', 'dragstart', 'dragend', 'dragover', 'dragenter', 'dragleave', 'drop'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.document, eventName, (event: any) => this.preventDragEvents(event))\r\n            );\r\n        });\r\n\r\n        ['dragover', 'dragenter'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.hostElementRef.nativeElement, eventName, (event: any) => this.onDragOver(event))\r\n            );\r\n        });\r\n\r\n        ['dragleave', 'dragend', 'drop'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.hostElementRef.nativeElement, eventName, (event: any) => {\r\n                    if(this.control.disabled && eventName === 'dragleave' || eventName !== 'dragleave') {\r\n                        this.onDragLeave(event);\r\n                    }\r\n                })\r\n            );\r\n        });\r\n\r\n        ['dragleave'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.overlay.nativeElement, eventName, (event: any) => this.onDragLeave(event))\r\n            );\r\n        });\r\n\r\n        this.subscriptions.push(\r\n            this.control.statusChanges.subscribe((status) => this.checkAndMarkAsDisabled())\r\n        );\r\n    }\r\n\r\n    private checkAndMarkAsDisabled(): void {\r\n        if (this.control.disabled) {\r\n            this.renderer.addClass(this.hostElementRef.nativeElement, 'disabled');\r\n        } else {\r\n            this.renderer.removeClass(this.hostElementRef.nativeElement, 'disabled');\r\n        }\r\n    }\r\n\r\n    private preventDragEvents(event: DragEvent): void {\r\n        event.preventDefault();\r\n        event.stopPropagation();\r\n    }\r\n\r\n    /**\r\n     * on file over add class name\r\n     */\r\n    private onDragOver(event: DragEvent): void {\r\n        this.renderer.addClass(this.hostElementRef.nativeElement, DRAGOVER);\r\n    }\r\n\r\n    /**\r\n     * on mouse out remove class name\r\n     */\r\n    private onDragLeave(event: DragEvent): void {\r\n        this.renderer.removeClass(this.hostElementRef.nativeElement, DRAGOVER);\r\n    }\r\n\r\n    @HostListener('drop', ['$event'])\r\n    public onDrop(event: DragEvent): void {\r\n        if (this.control.disabled) {\r\n            return;\r\n        }\r\n        const files = event.dataTransfer.files;\r\n        this.control.addFiles(files);\r\n        this.onTouch();\r\n    }\r\n\r\n    private onTouch: () => void = () => {\r\n        this.renderer.addClass(this.hostElementRef.nativeElement, TOUCHED);\r\n    };\r\n\r\n}"]}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/

@@ -134,3 +134,3 @@ import { Component, Input } from '@angular/core';

};
function FileUploadIconComponent_tsickle_Closure_declarations() {
if (false) {
/** @type {?} */

@@ -143,3 +143,2 @@ FileUploadIconComponent.prototype.file;

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload-icon.component.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["components/file-upload-icon.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,mCAAmC,CAAC;AA8EtE,MAAM;;;;IAOF,YAAoB,iBAAoC;QAApC,sBAAiB,GAAjB,iBAAiB,CAAmB;wBAF9B,SAAS;KAGlC;;;;IAEM,QAAQ;QACX,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;;;;;;IAG3D,MAAM,CAAC,IAA0C;QACpD,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;YACX,KAAK,MAAM;gBACP,MAAM,CAAC,IAAI,CAAC,QAAQ,KAAK,MAAM,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK;oBACtD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI;oBACjD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK;oBAClD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM;oBACnD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK;oBAClD,IAAI,CAAC,QAAQ,KAAK,MAAM,CAAC;YACjC,KAAK,OAAO;gBACR,MAAM,CAAC,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM;oBACtD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK;oBAClD,IAAI,CAAC,QAAQ,KAAK,MAAM,CAAC;YACjC,KAAK,OAAO;gBACR,MAAM,CAAC,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK;oBACrD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK;oBAClD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM;oBACnD,IAAI,CAAC,QAAQ,KAAK,KAAK,CAAC;YAChC,KAAK,OAAO;gBACR,MAAM,CAAC,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM;oBACtD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM;oBACnD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK,CAAC;SAC9D;;;;YA/GR,SAAS,SAAC;gBACP,QAAQ,EAAE,kBAAkB;gBAC5B,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gBAsEE;gBACZ,MAAM,EAAE,CAAC,wFAAwF,CAAC;aACrG;;;;YA7EQ,iBAAiB;;;mBAgFrB,KAAK","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\r\nimport { FileUploadService } from './../services/file-upload.service';\r\n\r\n\r\n@Component({\r\n    selector: `file-upload-icon`,\r\n    template: `\r\n\r\n<ng-container [ngSwitch]=\"true\">\r\n\r\n    <svg *ngSwitchDefault viewBox=\"0 0 96 96\">\r\n        <g>\r\n            <path d=\"M71.4,30.7c0.6,0.6,1.2,1.5,1.6,2.5c0.4,1.1,0.7,2.1,0.7,2.9v38.6c0,0.9-0.3,1.7-0.9,2.3\r\n                S71.4,78,70.5,78h-45c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V21.2c0-0.9,0.3-1.7,0.9-2.3c0.6-0.6,1.4-0.9,2.3-0.9h30\r\n                c0.9,0,1.9,0.2,2.9,0.7c1.1,0.4,1.9,1,2.5,1.6L71.4,30.7z M56.6,22.6v12.6h12.6c-0.2-0.6-0.5-1.1-0.7-1.4L57.9,23.3\r\n                C57.7,23,57.2,22.8,56.6,22.6z M69.4,73.7V39.4H55.5c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V22.3H26.6v51.4H69.4z\"/>\r\n        </g>\r\n    </svg>\r\n\r\n    <svg *ngSwitchCase=\"isIcon('image')\" viewBox=\"0 0 96 96\">\r\n        <g>\r\n            <path d=\"M71.4,30.7c0.6,0.6,1.2,1.5,1.6,2.5c0.4,1.1,0.7,2.1,0.7,2.9v38.6c0,0.9-0.3,1.7-0.9,2.3\r\n                S71.4,78,70.5,78h-45c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V21.2c0-0.9,0.3-1.7,0.9-2.3c0.6-0.6,1.4-0.9,2.3-0.9h30\r\n                c0.9,0,1.9,0.2,2.9,0.7c1.1,0.4,1.9,1,2.5,1.6L71.4,30.7z M56.6,22.6v12.6h12.6c-0.2-0.6-0.5-1.1-0.7-1.4L57.9,23.3\r\n                C57.7,23,57.2,22.8,56.6,22.6z M69.4,73.7V39.4H55.5c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V22.3H26.6v51.4H69.4z\r\n                M65.1,58.7v10.7H30.9V63l6.4-6.4l4.3,4.3L54.4,48L65.1,58.7z M37.3,52.3c-1.8,0-3.3-0.6-4.6-1.9c-1.3-1.2-1.9-2.8-1.9-4.6\r\n                c0-1.8,0.6-3.3,1.9-4.6c1.3-1.2,2.8-1.9,4.6-1.9s3.3,0.6,4.6,1.9c1.3,1.3,1.9,2.8,1.9,4.6c0,1.8-0.6,3.3-1.9,4.6\r\n                C40.6,51.7,39.1,52.3,37.3,52.3z\"/>\r\n        </g>\r\n    </svg>\r\n\r\n    <svg *ngSwitchCase=\"isIcon('audio')\" viewBox=\"0 0 96 96\">\r\n        <g>\r\n            <path d=\"M71.4,30.7c0.6,0.6,1.2,1.5,1.6,2.5c0.4,1.1,0.7,2.1,0.7,2.9v38.6c0,0.9-0.3,1.7-0.9,2.3\r\n                S71.4,78,70.5,78h-45c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V21.2c0-0.9,0.3-1.7,0.9-2.3c0.6-0.6,1.4-0.9,2.3-0.9h30\r\n                c0.9,0,1.9,0.2,2.9,0.7c1.1,0.4,1.9,1,2.5,1.6L71.4,30.7z M56.6,22.6v12.6h12.6c-0.2-0.6-0.5-1.1-0.7-1.4L57.9,23.3\r\n                C57.7,23,57.2,22.8,56.6,22.6z M69.4,73.7V39.4H55.5c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V22.3H26.6v51.4H69.4z\r\n                M43,46.5c0.4,0.2,0.7,0.5,0.7,1v18.2c0,0.5-0.2,0.8-0.7,1c-0.2,0-0.3,0.1-0.4,0.1c-0.3,0-0.5-0.1-0.8-0.3l-5.6-5.6h-4.4\r\n                c-0.3,0-0.6-0.1-0.8-0.3c-0.2-0.2-0.3-0.5-0.3-0.8v-6.4c0-0.3,0.1-0.6,0.3-0.8c0.2-0.2,0.5-0.3,0.8-0.3h4.4l5.6-5.6\r\n                C42.2,46.4,42.6,46.3,43,46.5z M57,69.5c0.7,0,1.3-0.3,1.7-0.8c2.9-3.5,4.3-7.6,4.3-12.2s-1.4-8.6-4.3-12.2\r\n                c-0.4-0.5-0.8-0.7-1.4-0.8c-0.6-0.1-1.1,0.1-1.6,0.5c-0.5,0.4-0.7,0.9-0.8,1.5c-0.1,0.6,0.1,1.1,0.5,1.6c2.2,2.7,3.3,5.9,3.3,9.4\r\n                c0,3.5-1.1,6.7-3.3,9.4c-0.4,0.5-0.5,1-0.5,1.6c0.1,0.6,0.3,1.1,0.8,1.4C56.1,69.4,56.5,69.5,57,69.5z M49.9,64.6\r\n                c0.6,0,1.1-0.2,1.6-0.7c1.9-2.1,2.9-4.5,2.9-7.3s-1-5.3-2.9-7.3c-0.4-0.4-0.9-0.6-1.5-0.7c-0.6,0-1.1,0.2-1.5,0.6s-0.6,0.9-0.7,1.5\r\n                c0,0.6,0.2,1.1,0.6,1.6c1.2,1.3,1.7,2.7,1.7,4.4c0,1.7-0.6,3.1-1.7,4.4c-0.4,0.4-0.6,1-0.6,1.6c0,0.6,0.2,1.1,0.7,1.5\r\n                C48.9,64.4,49.4,64.6,49.9,64.6z\"/>\r\n        </g>\r\n    </svg>\r\n\r\n    <svg *ngSwitchCase=\"isIcon('text')\" viewBox=\"0 0 96 96\">\r\n        <g>\r\n            <path d=\"M71.4,30.7c0.6,0.6,1.2,1.5,1.6,2.5c0.4,1.1,0.7,2.1,0.7,2.9v38.6c0,0.9-0.3,1.7-0.9,2.3\r\n                S71.4,78,70.5,78h-45c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V21.2c0-0.9,0.3-1.7,0.9-2.3c0.6-0.6,1.4-0.9,2.3-0.9h30\r\n                c0.9,0,1.9,0.2,2.9,0.7c1.1,0.4,1.9,1,2.5,1.6L71.4,30.7z M56.6,22.6v12.6h12.6c-0.2-0.6-0.5-1.1-0.7-1.4L57.9,23.3\r\n                C57.7,23,57.2,22.8,56.6,22.6z M69.4,73.7V39.4H55.5c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V22.3H26.6v51.4H69.4z\r\n                M35.1,44.8c0-0.3,0.1-0.6,0.3-0.8c0.2-0.2,0.5-0.3,0.8-0.3h23.6c0.3,0,0.6,0.1,0.8,0.3c0.2,0.2,0.3,0.5,0.3,0.8v2.1\r\n                c0,0.3-0.1,0.6-0.3,0.8c-0.2,0.2-0.5,0.3-0.8,0.3H36.2c-0.3,0-0.6-0.1-0.8-0.3c-0.2-0.2-0.3-0.5-0.3-0.8V44.8z M59.8,52.3\r\n                c0.3,0,0.6,0.1,0.8,0.3c0.2,0.2,0.3,0.5,0.3,0.8v2.1c0,0.3-0.1,0.6-0.3,0.8c-0.2,0.2-0.5,0.3-0.8,0.3H36.2c-0.3,0-0.6-0.1-0.8-0.3\r\n                c-0.2-0.2-0.3-0.5-0.3-0.8v-2.1c0-0.3,0.1-0.6,0.3-0.8c0.2-0.2,0.5-0.3,0.8-0.3H59.8z M59.8,60.9c0.3,0,0.6,0.1,0.8,0.3\r\n                c0.2,0.2,0.3,0.5,0.3,0.8v2.1c0,0.3-0.1,0.6-0.3,0.8c-0.2,0.2-0.5,0.3-0.8,0.3H36.2c-0.3,0-0.6-0.1-0.8-0.3\r\n                c-0.2-0.2-0.3-0.5-0.3-0.8v-2.1c0-0.3,0.1-0.6,0.3-0.8c0.2-0.2,0.5-0.3,0.8-0.3H59.8z\"/>\r\n        </g>\r\n    </svg>\r\n\r\n    <svg *ngSwitchCase=\"isIcon('video')\" viewBox=\"0 0 96 96\">\r\n        <g>\r\n            <path d=\"M71.4,30.7c0.6,0.6,1.2,1.5,1.6,2.5c0.4,1.1,0.7,2.1,0.7,2.9v38.6c0,0.9-0.3,1.7-0.9,2.3\r\n                S71.4,78,70.5,78h-45c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V21.2c0-0.9,0.3-1.7,0.9-2.3c0.6-0.6,1.4-0.9,2.3-0.9h30\r\n                c0.9,0,1.9,0.2,2.9,0.7c1.1,0.4,1.9,1,2.5,1.6L71.4,30.7z M56.6,22.6v12.6h12.6c-0.2-0.6-0.5-1.1-0.7-1.4L57.9,23.3\r\n                C57.7,23,57.2,22.8,56.6,22.6z M69.4,73.7V39.4H55.5c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V22.3H26.6v51.4H69.4z\r\n                M48,43.7c1.2,0,2.2,0.4,3,1.3c0.8,0.8,1.3,1.9,1.3,3v12.9c0,1.2-0.4,2.2-1.3,3c-0.8,0.8-1.9,1.3-3,1.3H35.1c-1.2,0-2.2-0.4-3-1.3\r\n                c-0.8-0.8-1.3-1.9-1.3-3V48c0-1.2,0.4-2.2,1.3-3c0.8-0.8,1.9-1.3,3-1.3H48z M64.5,43.8c0.4,0.2,0.7,0.5,0.7,1v19.3\r\n                c0,0.5-0.2,0.8-0.7,1c-0.2,0-0.3,0.1-0.4,0.1c-0.3,0-0.6-0.1-0.8-0.3l-8.9-8.9v-3l8.9-8.9c0.2-0.2,0.5-0.3,0.8-0.3\r\n                C64.2,43.7,64.3,43.7,64.5,43.8z\"/>\r\n        </g>\r\n    </svg>\r\n\r\n</ng-container>`,\r\n    styles: [`:host{display:block;border:1px solid #eaeaea;border-radius:4px}:host svg{fill:#909293}`]\r\n})\r\nexport class FileUploadIconComponent implements OnInit {\r\n\r\n    @Input()\r\n    public file: File;\r\n\r\n    public fileType: string = 'unknown';\r\n\r\n    constructor(private fileUploadService: FileUploadService) {\r\n    }\r\n\r\n    public ngOnInit(): void {\r\n        this.fileType = this.fileUploadService.getFileType(this.file);\r\n    }\r\n\r\n    public isIcon(type: 'text' | 'audio' | 'video' | 'image'): boolean {\r\n        switch (type) {\r\n            case 'text':\r\n                return this.fileType === 'html' || this.fileType === 'css' ||\r\n                    this.fileType === 'csv' || this.fileType === 'js' ||\r\n                    this.fileType === 'pdf' || this.fileType === 'ppt' ||\r\n                    this.fileType === 'xls' || this.fileType === 'xlsx' ||\r\n                    this.fileType === 'xml' || this.fileType === 'doc' ||\r\n                    this.fileType === 'docx';\r\n            case 'audio':\r\n                return this.fileType === 'aac' || this.fileType === 'midi' ||\r\n                    this.fileType === 'oga' || this.fileType === 'wav' ||\r\n                    this.fileType === 'weba';\r\n            case 'image':\r\n                return this.fileType === 'png' || this.fileType === 'bmp' ||\r\n                    this.fileType === 'gif' || this.fileType === 'jpg' ||\r\n                    this.fileType === 'svg' || this.fileType === 'webp' ||\r\n                    this.fileType === 'ico';\r\n            case 'video':\r\n                return this.fileType === 'avi' || this.fileType === 'mpeg' ||\r\n                    this.fileType === 'ogv' || this.fileType === 'webm' ||\r\n                    this.fileType === '3gp' || this.fileType === '3g2';\r\n        }\r\n    }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload-icon.component.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["components/file-upload-icon.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,mCAAmC,CAAC;AA8EtE,MAAM,OAAO,uBAAuB;;;;IAOhC,YAAoB,iBAAoC;QAApC,sBAAiB,GAAjB,iBAAiB,CAAmB;QAFjD,aAAQ,GAAW,SAAS,CAAC;IAGpC,CAAC;;;;IAEM,QAAQ;QACX,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAClE,CAAC;;;;;IAEM,MAAM,CAAC,IAA0C;QACpD,QAAQ,IAAI,EAAE;YACV,KAAK,MAAM;gBACP,OAAO,IAAI,CAAC,QAAQ,KAAK,MAAM,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK;oBACtD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI;oBACjD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK;oBAClD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM;oBACnD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK;oBAClD,IAAI,CAAC,QAAQ,KAAK,MAAM,CAAC;YACjC,KAAK,OAAO;gBACR,OAAO,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM;oBACtD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK;oBAClD,IAAI,CAAC,QAAQ,KAAK,MAAM,CAAC;YACjC,KAAK,OAAO;gBACR,OAAO,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK;oBACrD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK;oBAClD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM;oBACnD,IAAI,CAAC,QAAQ,KAAK,KAAK,CAAC;YAChC,KAAK,OAAO;gBACR,OAAO,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM;oBACtD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM;oBACnD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK,CAAC;SAC9D;IACL,CAAC;;;YAhHJ,SAAS,SAAC;gBACP,QAAQ,EAAE,kBAAkB;gBAC5B,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gBAsEE;gBACZ,MAAM,EAAE,CAAC,wFAAwF,CAAC;aACrG;;;;YA7EQ,iBAAiB;;;mBAgFrB,KAAK;;;;IAAN,uCACkB;;IAElB,2CAAoC;;IAExB,oDAA4C","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\r\nimport { FileUploadService } from './../services/file-upload.service';\r\n\r\n\r\n@Component({\r\n    selector: `file-upload-icon`,\r\n    template: `\r\n\r\n<ng-container [ngSwitch]=\"true\">\r\n\r\n    <svg *ngSwitchDefault viewBox=\"0 0 96 96\">\r\n        <g>\r\n            <path d=\"M71.4,30.7c0.6,0.6,1.2,1.5,1.6,2.5c0.4,1.1,0.7,2.1,0.7,2.9v38.6c0,0.9-0.3,1.7-0.9,2.3\r\n                S71.4,78,70.5,78h-45c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V21.2c0-0.9,0.3-1.7,0.9-2.3c0.6-0.6,1.4-0.9,2.3-0.9h30\r\n                c0.9,0,1.9,0.2,2.9,0.7c1.1,0.4,1.9,1,2.5,1.6L71.4,30.7z M56.6,22.6v12.6h12.6c-0.2-0.6-0.5-1.1-0.7-1.4L57.9,23.3\r\n                C57.7,23,57.2,22.8,56.6,22.6z M69.4,73.7V39.4H55.5c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V22.3H26.6v51.4H69.4z\"/>\r\n        </g>\r\n    </svg>\r\n\r\n    <svg *ngSwitchCase=\"isIcon('image')\" viewBox=\"0 0 96 96\">\r\n        <g>\r\n            <path d=\"M71.4,30.7c0.6,0.6,1.2,1.5,1.6,2.5c0.4,1.1,0.7,2.1,0.7,2.9v38.6c0,0.9-0.3,1.7-0.9,2.3\r\n                S71.4,78,70.5,78h-45c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V21.2c0-0.9,0.3-1.7,0.9-2.3c0.6-0.6,1.4-0.9,2.3-0.9h30\r\n                c0.9,0,1.9,0.2,2.9,0.7c1.1,0.4,1.9,1,2.5,1.6L71.4,30.7z M56.6,22.6v12.6h12.6c-0.2-0.6-0.5-1.1-0.7-1.4L57.9,23.3\r\n                C57.7,23,57.2,22.8,56.6,22.6z M69.4,73.7V39.4H55.5c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V22.3H26.6v51.4H69.4z\r\n                M65.1,58.7v10.7H30.9V63l6.4-6.4l4.3,4.3L54.4,48L65.1,58.7z M37.3,52.3c-1.8,0-3.3-0.6-4.6-1.9c-1.3-1.2-1.9-2.8-1.9-4.6\r\n                c0-1.8,0.6-3.3,1.9-4.6c1.3-1.2,2.8-1.9,4.6-1.9s3.3,0.6,4.6,1.9c1.3,1.3,1.9,2.8,1.9,4.6c0,1.8-0.6,3.3-1.9,4.6\r\n                C40.6,51.7,39.1,52.3,37.3,52.3z\"/>\r\n        </g>\r\n    </svg>\r\n\r\n    <svg *ngSwitchCase=\"isIcon('audio')\" viewBox=\"0 0 96 96\">\r\n        <g>\r\n            <path d=\"M71.4,30.7c0.6,0.6,1.2,1.5,1.6,2.5c0.4,1.1,0.7,2.1,0.7,2.9v38.6c0,0.9-0.3,1.7-0.9,2.3\r\n                S71.4,78,70.5,78h-45c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V21.2c0-0.9,0.3-1.7,0.9-2.3c0.6-0.6,1.4-0.9,2.3-0.9h30\r\n                c0.9,0,1.9,0.2,2.9,0.7c1.1,0.4,1.9,1,2.5,1.6L71.4,30.7z M56.6,22.6v12.6h12.6c-0.2-0.6-0.5-1.1-0.7-1.4L57.9,23.3\r\n                C57.7,23,57.2,22.8,56.6,22.6z M69.4,73.7V39.4H55.5c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V22.3H26.6v51.4H69.4z\r\n                M43,46.5c0.4,0.2,0.7,0.5,0.7,1v18.2c0,0.5-0.2,0.8-0.7,1c-0.2,0-0.3,0.1-0.4,0.1c-0.3,0-0.5-0.1-0.8-0.3l-5.6-5.6h-4.4\r\n                c-0.3,0-0.6-0.1-0.8-0.3c-0.2-0.2-0.3-0.5-0.3-0.8v-6.4c0-0.3,0.1-0.6,0.3-0.8c0.2-0.2,0.5-0.3,0.8-0.3h4.4l5.6-5.6\r\n                C42.2,46.4,42.6,46.3,43,46.5z M57,69.5c0.7,0,1.3-0.3,1.7-0.8c2.9-3.5,4.3-7.6,4.3-12.2s-1.4-8.6-4.3-12.2\r\n                c-0.4-0.5-0.8-0.7-1.4-0.8c-0.6-0.1-1.1,0.1-1.6,0.5c-0.5,0.4-0.7,0.9-0.8,1.5c-0.1,0.6,0.1,1.1,0.5,1.6c2.2,2.7,3.3,5.9,3.3,9.4\r\n                c0,3.5-1.1,6.7-3.3,9.4c-0.4,0.5-0.5,1-0.5,1.6c0.1,0.6,0.3,1.1,0.8,1.4C56.1,69.4,56.5,69.5,57,69.5z M49.9,64.6\r\n                c0.6,0,1.1-0.2,1.6-0.7c1.9-2.1,2.9-4.5,2.9-7.3s-1-5.3-2.9-7.3c-0.4-0.4-0.9-0.6-1.5-0.7c-0.6,0-1.1,0.2-1.5,0.6s-0.6,0.9-0.7,1.5\r\n                c0,0.6,0.2,1.1,0.6,1.6c1.2,1.3,1.7,2.7,1.7,4.4c0,1.7-0.6,3.1-1.7,4.4c-0.4,0.4-0.6,1-0.6,1.6c0,0.6,0.2,1.1,0.7,1.5\r\n                C48.9,64.4,49.4,64.6,49.9,64.6z\"/>\r\n        </g>\r\n    </svg>\r\n\r\n    <svg *ngSwitchCase=\"isIcon('text')\" viewBox=\"0 0 96 96\">\r\n        <g>\r\n            <path d=\"M71.4,30.7c0.6,0.6,1.2,1.5,1.6,2.5c0.4,1.1,0.7,2.1,0.7,2.9v38.6c0,0.9-0.3,1.7-0.9,2.3\r\n                S71.4,78,70.5,78h-45c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V21.2c0-0.9,0.3-1.7,0.9-2.3c0.6-0.6,1.4-0.9,2.3-0.9h30\r\n                c0.9,0,1.9,0.2,2.9,0.7c1.1,0.4,1.9,1,2.5,1.6L71.4,30.7z M56.6,22.6v12.6h12.6c-0.2-0.6-0.5-1.1-0.7-1.4L57.9,23.3\r\n                C57.7,23,57.2,22.8,56.6,22.6z M69.4,73.7V39.4H55.5c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V22.3H26.6v51.4H69.4z\r\n                M35.1,44.8c0-0.3,0.1-0.6,0.3-0.8c0.2-0.2,0.5-0.3,0.8-0.3h23.6c0.3,0,0.6,0.1,0.8,0.3c0.2,0.2,0.3,0.5,0.3,0.8v2.1\r\n                c0,0.3-0.1,0.6-0.3,0.8c-0.2,0.2-0.5,0.3-0.8,0.3H36.2c-0.3,0-0.6-0.1-0.8-0.3c-0.2-0.2-0.3-0.5-0.3-0.8V44.8z M59.8,52.3\r\n                c0.3,0,0.6,0.1,0.8,0.3c0.2,0.2,0.3,0.5,0.3,0.8v2.1c0,0.3-0.1,0.6-0.3,0.8c-0.2,0.2-0.5,0.3-0.8,0.3H36.2c-0.3,0-0.6-0.1-0.8-0.3\r\n                c-0.2-0.2-0.3-0.5-0.3-0.8v-2.1c0-0.3,0.1-0.6,0.3-0.8c0.2-0.2,0.5-0.3,0.8-0.3H59.8z M59.8,60.9c0.3,0,0.6,0.1,0.8,0.3\r\n                c0.2,0.2,0.3,0.5,0.3,0.8v2.1c0,0.3-0.1,0.6-0.3,0.8c-0.2,0.2-0.5,0.3-0.8,0.3H36.2c-0.3,0-0.6-0.1-0.8-0.3\r\n                c-0.2-0.2-0.3-0.5-0.3-0.8v-2.1c0-0.3,0.1-0.6,0.3-0.8c0.2-0.2,0.5-0.3,0.8-0.3H59.8z\"/>\r\n        </g>\r\n    </svg>\r\n\r\n    <svg *ngSwitchCase=\"isIcon('video')\" viewBox=\"0 0 96 96\">\r\n        <g>\r\n            <path d=\"M71.4,30.7c0.6,0.6,1.2,1.5,1.6,2.5c0.4,1.1,0.7,2.1,0.7,2.9v38.6c0,0.9-0.3,1.7-0.9,2.3\r\n                S71.4,78,70.5,78h-45c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V21.2c0-0.9,0.3-1.7,0.9-2.3c0.6-0.6,1.4-0.9,2.3-0.9h30\r\n                c0.9,0,1.9,0.2,2.9,0.7c1.1,0.4,1.9,1,2.5,1.6L71.4,30.7z M56.6,22.6v12.6h12.6c-0.2-0.6-0.5-1.1-0.7-1.4L57.9,23.3\r\n                C57.7,23,57.2,22.8,56.6,22.6z M69.4,73.7V39.4H55.5c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V22.3H26.6v51.4H69.4z\r\n                M48,43.7c1.2,0,2.2,0.4,3,1.3c0.8,0.8,1.3,1.9,1.3,3v12.9c0,1.2-0.4,2.2-1.3,3c-0.8,0.8-1.9,1.3-3,1.3H35.1c-1.2,0-2.2-0.4-3-1.3\r\n                c-0.8-0.8-1.3-1.9-1.3-3V48c0-1.2,0.4-2.2,1.3-3c0.8-0.8,1.9-1.3,3-1.3H48z M64.5,43.8c0.4,0.2,0.7,0.5,0.7,1v19.3\r\n                c0,0.5-0.2,0.8-0.7,1c-0.2,0-0.3,0.1-0.4,0.1c-0.3,0-0.6-0.1-0.8-0.3l-8.9-8.9v-3l8.9-8.9c0.2-0.2,0.5-0.3,0.8-0.3\r\n                C64.2,43.7,64.3,43.7,64.5,43.8z\"/>\r\n        </g>\r\n    </svg>\r\n\r\n</ng-container>`,\r\n    styles: [`:host{display:block;border:1px solid #eaeaea;border-radius:4px}:host svg{fill:#909293}`]\r\n})\r\nexport class FileUploadIconComponent implements OnInit {\r\n\r\n    @Input()\r\n    public file: File;\r\n\r\n    public fileType: string = 'unknown';\r\n\r\n    constructor(private fileUploadService: FileUploadService) {\r\n    }\r\n\r\n    public ngOnInit(): void {\r\n        this.fileType = this.fileUploadService.getFileType(this.file);\r\n    }\r\n\r\n    public isIcon(type: 'text' | 'audio' | 'video' | 'image'): boolean {\r\n        switch (type) {\r\n            case 'text':\r\n                return this.fileType === 'html' || this.fileType === 'css' ||\r\n                    this.fileType === 'csv' || this.fileType === 'js' ||\r\n                    this.fileType === 'pdf' || this.fileType === 'ppt' ||\r\n                    this.fileType === 'xls' || this.fileType === 'xlsx' ||\r\n                    this.fileType === 'xml' || this.fileType === 'doc' ||\r\n                    this.fileType === 'docx';\r\n            case 'audio':\r\n                return this.fileType === 'aac' || this.fileType === 'midi' ||\r\n                    this.fileType === 'oga' || this.fileType === 'wav' ||\r\n                    this.fileType === 'weba';\r\n            case 'image':\r\n                return this.fileType === 'png' || this.fileType === 'bmp' ||\r\n                    this.fileType === 'gif' || this.fileType === 'jpg' ||\r\n                    this.fileType === 'svg' || this.fileType === 'webp' ||\r\n                    this.fileType === 'ico';\r\n            case 'video':\r\n                return this.fileType === 'avi' || this.fileType === 'mpeg' ||\r\n                    this.fileType === 'ogv' || this.fileType === 'webm' ||\r\n                    this.fileType === '3gp' || this.fileType === '3g2';\r\n        }\r\n    }\r\n}\r\n"]}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/

@@ -67,3 +67,3 @@ import { Component, Input } from '@angular/core';

};
function FileUploadListItemComponent_tsickle_Closure_declarations() {
if (false) {
/** @type {?} */

@@ -78,3 +78,2 @@ FileUploadListItemComponent.prototype.index;

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQtbGlzdC1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BpcGxhYi9uZ3gtZmlsZS11cGxvYWQvIiwic291cmNlcyI6WyJjb21wb25lbnRzL2ZpbGUtdXBsb2FkLWxpc3QtaXRlbS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQy9ELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBNEJ0RSxNQUFNOzs7O0lBV0YsWUFBb0IsaUJBQW9DO1FBQXBDLHNCQUFpQixHQUFqQixpQkFBaUIsQ0FBbUI7S0FDdkQ7Ozs7O0lBRU0sVUFBVSxDQUFDLElBQVU7UUFDeEIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUM7Ozs7OztJQUczQixhQUFhLENBQUMsSUFBWTtRQUM5QixNQUFNLENBQUMsSUFBSSxDQUFDLGlCQUFpQixDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQzs7OztZQTdDeEQsU0FBUyxTQUFDO2dCQUNQLFFBQVEsRUFBRSx1QkFBdUI7Z0JBQ2pDLFFBQVEsRUFBRTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0tBcUJUO2dCQUNELE1BQU0sRUFBRSxDQUFDLHVWQUF1VixDQUFDO2FBQ3BXOzs7O1lBM0JRLGlCQUFpQjs7O29CQThCckIsS0FBSzttQkFHTCxLQUFLO3NCQUdMLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEZpbGVVcGxvYWRDb250cm9sIH0gZnJvbSAnLi8uLi9oZWxwZXJzL2NvbnRyb2wuY2xhc3MnO1xyXG5pbXBvcnQgeyBGaWxlVXBsb2FkU2VydmljZSB9IGZyb20gJy4vLi4vc2VydmljZXMvZmlsZS11cGxvYWQuc2VydmljZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiBgZmlsZS11cGxvYWQtbGlzdC1pdGVtYCxcclxuICAgIHRlbXBsYXRlOiBgXHJcbiAgICA8ZmlsZS11cGxvYWQtaWNvbiBbZmlsZV09XCJmaWxlXCI+PC9maWxlLXVwbG9hZC1pY29uPlxyXG4gICAgPGRpdiBjbGFzcz1cImZpbGUtaW5mb1wiPlxyXG4gICAgICAgIDxzcGFuIGNsYXNzPVwiZmlsZS1uYW1lXCI+e3sgZmlsZS5uYW1lIH19PC9zcGFuPiAoe3sgY2FsY3VsYXRlU2l6ZSggZmlsZS5zaXplICkgfX0pXHJcbiAgICA8L2Rpdj5cclxuICAgIDxkaXYgY2xhc3M9XCJmaWxlLWJ1dHRvbnNcIj5cclxuICAgICAgICA8c3BhbiBjbGFzcz1cInJlbW92ZS1idG5cIiAoY2xpY2spPVwicmVtb3ZlRmlsZShmaWxlKVwiPlxyXG4gICAgICAgIDxzdmcgdmlld0JveD1cIjAgMCA5NiA5NlwiPlxyXG4gICAgICAgICAgICA8Zz5cclxuICAgICAgICAgICAgICAgIDxwYXRoIGQ9XCJNNDAuNSw2Ni44VjM5LjNjMC0wLjQtMC4xLTAuNy0wLjQtMC45UzM5LjYsMzgsMzkuMywzOGgtMi41Yy0wLjQsMC0wLjcsMC4xLTAuOSwwLjRcclxuICAgICAgICAgICAgICAgICAgICBzLTAuNCwwLjUtMC40LDAuOXYyNy41YzAsMC40LDAuMSwwLjcsMC40LDAuOXMwLjUsMC40LDAuOSwwLjRoMi41YzAuNCwwLDAuNy0wLjEsMC45LTAuNFM0MC41LDY3LjEsNDAuNSw2Ni44eiBNNTAuNSw2Ni44VjM5LjNcclxuICAgICAgICAgICAgICAgICAgICBjMC0wLjQtMC4xLTAuNy0wLjQtMC45UzQ5LjYsMzgsNDkuMywzOGgtMi41Yy0wLjQsMC0wLjcsMC4xLTAuOSwwLjRzLTAuNCwwLjUtMC40LDAuOXYyNy41YzAsMC40LDAuMSwwLjcsMC40LDAuOXMwLjUsMC40LDAuOSwwLjRcclxuICAgICAgICAgICAgICAgICAgICBoMi41YzAuNCwwLDAuNy0wLjEsMC45LTAuNFM1MC41LDY3LjEsNTAuNSw2Ni44eiBNNjAuNSw2Ni44VjM5LjNjMC0wLjQtMC4xLTAuNy0wLjQtMC45UzU5LjYsMzgsNTkuMywzOGgtMi41XHJcbiAgICAgICAgICAgICAgICAgICAgYy0wLjQsMC0wLjcsMC4xLTAuOSwwLjRzLTAuNCwwLjUtMC40LDAuOXYyNy41YzAsMC40LDAuMSwwLjcsMC40LDAuOXMwLjUsMC40LDAuOSwwLjRoMi41YzAuNCwwLDAuNy0wLjEsMC45LTAuNFxyXG4gICAgICAgICAgICAgICAgICAgIFM2MC41LDY3LjEsNjAuNSw2Ni44eiBNMzkuMywyOGgxNy41bC0xLjktNC42Yy0wLjItMC4yLTAuNC0wLjQtMC43LTAuNEg0MS44Yy0wLjMsMC4xLTAuNSwwLjItMC43LDAuNEwzOS4zLDI4eiBNNzUuNSwyOS4zdjIuNVxyXG4gICAgICAgICAgICAgICAgICAgIGMwLDAuNC0wLjEsMC43LTAuNCwwLjlTNzQuNiwzMyw3NC4zLDMzaC0zLjh2MzdjMCwyLjItMC42LDQtMS44LDUuNlM2Niw3OCw2NC4zLDc4SDMxLjhjLTEuNywwLTMuMi0wLjgtNC40LTIuM3MtMS44LTMuNC0xLjgtNS41XHJcbiAgICAgICAgICAgICAgICAgICAgVjMzaC0zLjhjLTAuNCwwLTAuNy0wLjEtMC45LTAuNHMtMC40LTAuNS0wLjQtMC45di0yLjVjMC0wLjQsMC4xLTAuNywwLjQtMC45czAuNS0wLjQsMC45LTAuNGgxMi4xbDIuNy02LjVjMC40LTEsMS4xLTEuOCwyLjEtMi41XHJcbiAgICAgICAgICAgICAgICAgICAgczItMSwzLjEtMWgxMi41YzEsMCwyLjEsMC4zLDMuMSwxczEuNywxLjUsMi4xLDIuNWwyLjcsNi41aDEyLjFjMC40LDAsMC43LDAuMSwwLjksMC40Uzc1LjUsMjguOSw3NS41LDI5LjN6XCIvPlxyXG4gICAgICAgICAgICA8L2c+XHJcbiAgICAgICAgPC9zdmc+IFJlbW92ZTwvc3Bhbj5cclxuICAgIDwvZGl2PlxyXG4gICAgYCxcclxuICAgIHN0eWxlczogW2A6aG9zdHtkaXNwbGF5OmJsb2NrO2ZvbnQtc2l6ZToxNHB4O2NvbG9yOiM2NDY0NjR9Omhvc3Q6YWZ0ZXJ7Y2xlYXI6Ym90aDtjb250ZW50OlwiXFxcXDBBMFwiO2Rpc3BsYXk6YmxvY2s7aGVpZ2h0OjA7bGluZS1oZWlnaHQ6MDt2aXNpYmlsaXR5OmhpZGRlbjt6b29tOjF9ZmlsZS11cGxvYWQtaWNvbntmbG9hdDpsZWZ0O3dpZHRoOjMwcHg7aGVpZ2h0OjM2cHg7bWFyZ2luOjAgMTBweCAwIDB9LnJlbW92ZS1idG57Zm9udC1zaXplOjEycHg7Y3Vyc29yOnBvaW50ZXJ9LnJlbW92ZS1idG4gc3Zne2Rpc3BsYXk6aW5saW5lLWJsb2NrO3ZlcnRpY2FsLWFsaWduOi0yMCU7aGVpZ2h0OjE4cHg7d2lkdGg6MThweH1gXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgRmlsZVVwbG9hZExpc3RJdGVtQ29tcG9uZW50IHtcclxuXHJcbiAgICBASW5wdXQoKVxyXG4gICAgcHVibGljIGluZGV4OiBudW1iZXI7XHJcblxyXG4gICAgQElucHV0KClcclxuICAgIHB1YmxpYyBmaWxlOiBGaWxlO1xyXG5cclxuICAgIEBJbnB1dCgpXHJcbiAgICBwdWJsaWMgY29udHJvbDogRmlsZVVwbG9hZENvbnRyb2w7XHJcblxyXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBmaWxlVXBsb2FkU2VydmljZTogRmlsZVVwbG9hZFNlcnZpY2UpIHtcclxuICAgIH1cclxuXHJcbiAgICBwdWJsaWMgcmVtb3ZlRmlsZShmaWxlOiBGaWxlKTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5jb250cm9sLnJlbW92ZUZpbGUoZmlsZSk7XHJcbiAgICB9XHJcblxyXG4gICAgcHVibGljIGNhbGN1bGF0ZVNpemUoc2l6ZTogbnVtYmVyKTogc3RyaW5nIHtcclxuICAgICAgIHJldHVybiB0aGlzLmZpbGVVcGxvYWRTZXJ2aWNlLmNhbGN1bGF0ZVNpemUoc2l6ZSk7XHJcbiAgICB9XHJcbn0iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQtbGlzdC1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BpcGxhYi9uZ3gtZmlsZS11cGxvYWQvIiwic291cmNlcyI6WyJjb21wb25lbnRzL2ZpbGUtdXBsb2FkLWxpc3QtaXRlbS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQy9ELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBNEJ0RSxNQUFNLE9BQU8sMkJBQTJCOzs7O0lBV3BDLFlBQW9CLGlCQUFvQztRQUFwQyxzQkFBaUIsR0FBakIsaUJBQWlCLENBQW1CO0lBQ3hELENBQUM7Ozs7O0lBRU0sVUFBVSxDQUFDLElBQVU7UUFDeEIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDbEMsQ0FBQzs7Ozs7SUFFTSxhQUFhLENBQUMsSUFBWTtRQUM5QixPQUFPLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDckQsQ0FBQzs7O1lBOUNKLFNBQVMsU0FBQztnQkFDUCxRQUFRLEVBQUUsdUJBQXVCO2dCQUNqQyxRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztLQXFCVDtnQkFDRCxNQUFNLEVBQUUsQ0FBQyx1VkFBdVYsQ0FBQzthQUNwVzs7OztZQTNCUSxpQkFBaUI7OztvQkE4QnJCLEtBQUs7bUJBR0wsS0FBSztzQkFHTCxLQUFLOzs7O0lBTk4sNENBQ3FCOztJQUVyQiwyQ0FDa0I7O0lBRWxCLDhDQUNrQzs7SUFFdEIsd0RBQTRDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBGaWxlVXBsb2FkQ29udHJvbCB9IGZyb20gJy4vLi4vaGVscGVycy9jb250cm9sLmNsYXNzJztcclxuaW1wb3J0IHsgRmlsZVVwbG9hZFNlcnZpY2UgfSBmcm9tICcuLy4uL3NlcnZpY2VzL2ZpbGUtdXBsb2FkLnNlcnZpY2UnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogYGZpbGUtdXBsb2FkLWxpc3QtaXRlbWAsXHJcbiAgICB0ZW1wbGF0ZTogYFxyXG4gICAgPGZpbGUtdXBsb2FkLWljb24gW2ZpbGVdPVwiZmlsZVwiPjwvZmlsZS11cGxvYWQtaWNvbj5cclxuICAgIDxkaXYgY2xhc3M9XCJmaWxlLWluZm9cIj5cclxuICAgICAgICA8c3BhbiBjbGFzcz1cImZpbGUtbmFtZVwiPnt7IGZpbGUubmFtZSB9fTwvc3Bhbj4gKHt7IGNhbGN1bGF0ZVNpemUoIGZpbGUuc2l6ZSApIH19KVxyXG4gICAgPC9kaXY+XHJcbiAgICA8ZGl2IGNsYXNzPVwiZmlsZS1idXR0b25zXCI+XHJcbiAgICAgICAgPHNwYW4gY2xhc3M9XCJyZW1vdmUtYnRuXCIgKGNsaWNrKT1cInJlbW92ZUZpbGUoZmlsZSlcIj5cclxuICAgICAgICA8c3ZnIHZpZXdCb3g9XCIwIDAgOTYgOTZcIj5cclxuICAgICAgICAgICAgPGc+XHJcbiAgICAgICAgICAgICAgICA8cGF0aCBkPVwiTTQwLjUsNjYuOFYzOS4zYzAtMC40LTAuMS0wLjctMC40LTAuOVMzOS42LDM4LDM5LjMsMzhoLTIuNWMtMC40LDAtMC43LDAuMS0wLjksMC40XHJcbiAgICAgICAgICAgICAgICAgICAgcy0wLjQsMC41LTAuNCwwLjl2MjcuNWMwLDAuNCwwLjEsMC43LDAuNCwwLjlzMC41LDAuNCwwLjksMC40aDIuNWMwLjQsMCwwLjctMC4xLDAuOS0wLjRTNDAuNSw2Ny4xLDQwLjUsNjYuOHogTTUwLjUsNjYuOFYzOS4zXHJcbiAgICAgICAgICAgICAgICAgICAgYzAtMC40LTAuMS0wLjctMC40LTAuOVM0OS42LDM4LDQ5LjMsMzhoLTIuNWMtMC40LDAtMC43LDAuMS0wLjksMC40cy0wLjQsMC41LTAuNCwwLjl2MjcuNWMwLDAuNCwwLjEsMC43LDAuNCwwLjlzMC41LDAuNCwwLjksMC40XHJcbiAgICAgICAgICAgICAgICAgICAgaDIuNWMwLjQsMCwwLjctMC4xLDAuOS0wLjRTNTAuNSw2Ny4xLDUwLjUsNjYuOHogTTYwLjUsNjYuOFYzOS4zYzAtMC40LTAuMS0wLjctMC40LTAuOVM1OS42LDM4LDU5LjMsMzhoLTIuNVxyXG4gICAgICAgICAgICAgICAgICAgIGMtMC40LDAtMC43LDAuMS0wLjksMC40cy0wLjQsMC41LTAuNCwwLjl2MjcuNWMwLDAuNCwwLjEsMC43LDAuNCwwLjlzMC41LDAuNCwwLjksMC40aDIuNWMwLjQsMCwwLjctMC4xLDAuOS0wLjRcclxuICAgICAgICAgICAgICAgICAgICBTNjAuNSw2Ny4xLDYwLjUsNjYuOHogTTM5LjMsMjhoMTcuNWwtMS45LTQuNmMtMC4yLTAuMi0wLjQtMC40LTAuNy0wLjRINDEuOGMtMC4zLDAuMS0wLjUsMC4yLTAuNywwLjRMMzkuMywyOHogTTc1LjUsMjkuM3YyLjVcclxuICAgICAgICAgICAgICAgICAgICBjMCwwLjQtMC4xLDAuNy0wLjQsMC45Uzc0LjYsMzMsNzQuMywzM2gtMy44djM3YzAsMi4yLTAuNiw0LTEuOCw1LjZTNjYsNzgsNjQuMyw3OEgzMS44Yy0xLjcsMC0zLjItMC44LTQuNC0yLjNzLTEuOC0zLjQtMS44LTUuNVxyXG4gICAgICAgICAgICAgICAgICAgIFYzM2gtMy44Yy0wLjQsMC0wLjctMC4xLTAuOS0wLjRzLTAuNC0wLjUtMC40LTAuOXYtMi41YzAtMC40LDAuMS0wLjcsMC40LTAuOXMwLjUtMC40LDAuOS0wLjRoMTIuMWwyLjctNi41YzAuNC0xLDEuMS0xLjgsMi4xLTIuNVxyXG4gICAgICAgICAgICAgICAgICAgIHMyLTEsMy4xLTFoMTIuNWMxLDAsMi4xLDAuMywzLjEsMXMxLjcsMS41LDIuMSwyLjVsMi43LDYuNWgxMi4xYzAuNCwwLDAuNywwLjEsMC45LDAuNFM3NS41LDI4LjksNzUuNSwyOS4zelwiLz5cclxuICAgICAgICAgICAgPC9nPlxyXG4gICAgICAgIDwvc3ZnPiBSZW1vdmU8L3NwYW4+XHJcbiAgICA8L2Rpdj5cclxuICAgIGAsXHJcbiAgICBzdHlsZXM6IFtgOmhvc3R7ZGlzcGxheTpibG9jaztmb250LXNpemU6MTRweDtjb2xvcjojNjQ2NDY0fTpob3N0OmFmdGVye2NsZWFyOmJvdGg7Y29udGVudDpcIlxcXFwwQTBcIjtkaXNwbGF5OmJsb2NrO2hlaWdodDowO2xpbmUtaGVpZ2h0OjA7dmlzaWJpbGl0eTpoaWRkZW47em9vbToxfWZpbGUtdXBsb2FkLWljb257ZmxvYXQ6bGVmdDt3aWR0aDozMHB4O2hlaWdodDozNnB4O21hcmdpbjowIDEwcHggMCAwfS5yZW1vdmUtYnRue2ZvbnQtc2l6ZToxMnB4O2N1cnNvcjpwb2ludGVyfS5yZW1vdmUtYnRuIHN2Z3tkaXNwbGF5OmlubGluZS1ibG9jazt2ZXJ0aWNhbC1hbGlnbjotMjAlO2hlaWdodDoxOHB4O3dpZHRoOjE4cHh9YF1cclxufSlcclxuZXhwb3J0IGNsYXNzIEZpbGVVcGxvYWRMaXN0SXRlbUNvbXBvbmVudCB7XHJcblxyXG4gICAgQElucHV0KClcclxuICAgIHB1YmxpYyBpbmRleDogbnVtYmVyO1xyXG5cclxuICAgIEBJbnB1dCgpXHJcbiAgICBwdWJsaWMgZmlsZTogRmlsZTtcclxuXHJcbiAgICBASW5wdXQoKVxyXG4gICAgcHVibGljIGNvbnRyb2w6IEZpbGVVcGxvYWRDb250cm9sO1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgZmlsZVVwbG9hZFNlcnZpY2U6IEZpbGVVcGxvYWRTZXJ2aWNlKSB7XHJcbiAgICB9XHJcblxyXG4gICAgcHVibGljIHJlbW92ZUZpbGUoZmlsZTogRmlsZSk6IHZvaWQge1xyXG4gICAgICAgIHRoaXMuY29udHJvbC5yZW1vdmVGaWxlKGZpbGUpO1xyXG4gICAgfVxyXG5cclxuICAgIHB1YmxpYyBjYWxjdWxhdGVTaXplKHNpemU6IG51bWJlcik6IHN0cmluZyB7XHJcbiAgICAgICByZXR1cm4gdGhpcy5maWxlVXBsb2FkU2VydmljZS5jYWxjdWxhdGVTaXplKHNpemUpO1xyXG4gICAgfVxyXG59Il19
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/

@@ -11,4 +11,6 @@ import { Component, Input, ElementRef, HostListener, Renderer2, HostBinding, Inject, TemplateRef, ViewChild, ChangeDetectionStrategy, ContentChild, forwardRef, ChangeDetectorRef } from '@angular/core';

import { FileUploadService } from './../services/file-upload.service';
export const /** @type {?} */ DRAGOVER = 'dragover';
export const /** @type {?} */ TOUCHED = 'ng-touched';
/** @type {?} */
export const DRAGOVER = 'dragover';
/** @type {?} */
export const TOUCHED = 'ng-touched';
export class FileUploadComponent {

@@ -136,3 +138,4 @@ /**

}
const /** @type {?} */ files = event.dataTransfer.files;
/** @type {?} */
const files = event.dataTransfer.files;
this.control.addFiles(files);

@@ -146,3 +149,4 @@ this.onTouch();

onInputChange(event) {
const /** @type {?} */ input = /** @type {?} */ ((event.target));
/** @type {?} */
const input = (/** @type {?} */ ((event.target)));
if (!this.control.disabled) {

@@ -276,3 +280,3 @@ this.control.addFiles(input.files);

};
function FileUploadComponent_tsickle_Closure_declarations() {
if (false) {
/** @type {?} */

@@ -307,3 +311,2 @@ FileUploadComponent.prototype.control;

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload.component.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["components/file-upload.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Component,\r\n    Input,\r\n    OnInit,\r\n    ElementRef,\r\n    HostListener,\r\n    Renderer2,\r\n    OnDestroy,\r\n    HostBinding,\r\n    Inject,\r\n    TemplateRef,\r\n    ViewChild,\r\n    ChangeDetectionStrategy,\r\n    ContentChild,\r\n    forwardRef,\r\n    ChangeDetectorRef\r\n} from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\r\n\r\nimport { FileUploadControl } from './../helpers/control.class';\r\nimport { IsNullOrEmpty } from './../helpers/helpers.class';\r\nimport { FileUploadService } from './../services/file-upload.service';\r\nimport { Subscription } from 'rxjs';\r\n\r\nexport const DRAGOVER = 'dragover';\r\nexport const TOUCHED = 'ng-touched';\r\n\r\n@Component({\r\n    selector: `file-upload`,\r\n    template: `<label class=\"upload-input\">\r\n\r\n    <ng-container *ngTemplateOutlet=\"templateRef ? templateRef : defaultTemplate; context: templateContext\"></ng-container>\r\n\r\n    <ng-template #defaultTemplate let-isFileDragDropAvailable=\"isFileDragDropAvailable\">\r\n        <div class=\"icon\">\r\n            <svg viewBox=\"0 0 96 96\">\r\n                <g>\r\n                    <path d=\"M62.8,68.1c0-0.6-0.2-1.1-0.6-1.5c-0.4-0.4-0.9-0.6-1.5-0.6s-1.1,0.2-1.5,0.6\r\n                        c-0.4,0.4-0.6,0.9-0.6,1.5c0,0.6,0.2,1.1,0.6,1.5c0.4,0.4,0.9,0.6,1.5,0.6s1.1-0.2,1.5-0.6S62.8,68.7,62.8,68.1z M71.3,68.1\r\n                        c0-0.6-0.2-1.1-0.6-1.5c-0.4-0.4-0.9-0.6-1.5-0.6c-0.6,0-1.1,0.2-1.5,0.6C67.2,67,67,67.5,67,68.1c0,0.6,0.2,1.1,0.6,1.5\r\n                        s0.9,0.6,1.5,0.6c0.6,0,1.1-0.2,1.5-0.6C71.1,69.2,71.3,68.7,71.3,68.1z M75.5,60.7v10.6c0,0.9-0.3,1.6-0.9,2.2\r\n                        c-0.6,0.6-1.4,0.9-2.2,0.9H23.7c-0.9,0-1.6-0.3-2.2-0.9c-0.6-0.6-0.9-1.4-0.9-2.2V60.7c0-0.9,0.3-1.6,0.9-2.2\r\n                        c0.6-0.6,1.4-0.9,2.2-0.9h14.1c0.5,1.2,1.2,2.2,2.3,3c1.1,0.8,2.3,1.2,3.7,1.2h8.5c1.3,0,2.6-0.4,3.7-1.2c1.1-0.8,1.9-1.8,2.3-3\r\n                        h14.1c0.9,0,1.6,0.3,2.2,0.9C75.2,59.1,75.5,59.8,75.5,60.7z M64.8,39.3c-0.4,0.9-1,1.3-2,1.3h-8.5v14.8c0,0.6-0.2,1.1-0.6,1.5\r\n                        c-0.4,0.4-0.9,0.6-1.5,0.6h-8.5c-0.6,0-1.1-0.2-1.5-0.6c-0.4-0.4-0.6-0.9-0.6-1.5V40.6h-8.5c-0.9,0-1.6-0.4-2-1.3\r\n                        c-0.4-0.9-0.2-1.6,0.5-2.3l14.8-14.8c0.4-0.4,0.9-0.6,1.5-0.6s1.1,0.2,1.5,0.6L64.3,37C65,37.7,65.1,38.4,64.8,39.3z\"/>\r\n                </g>\r\n            </svg>\r\n        </div>\r\n    \r\n        <div class=\"upload-text\">\r\n            <ng-container *ngIf=\"isFileDragDropAvailable; else isNotDragDropAvailable\">\r\n                <b>Drag and drop</b> files<br> or click here\r\n            </ng-container>\r\n            <ng-template #isNotDragDropAvailable>\r\n                <b>Click here</b> to<br> choose a files\r\n            </ng-template>\r\n        </div>\r\n    </ng-template>\r\n\r\n    <input #inputRef type=\"file\" class=\"files-input\" multiple (change)=\"onInputChange($event)\">\r\n</label>\r\n\r\n<div class=\"upload-list\" *ngIf=\"(control.listVisibilityChanges | async) && control.size > 0\">\r\n    <ng-template ngFor let-file let-i=\"index\" [ngForOf]=\"control.valueChanges | async\">\r\n        <ng-container *ngTemplateOutlet=\"listItem ? listItem : defaultItemTemplate; context: { $implicit: file, file: file, index: i, control: control }\"></ng-container>\r\n    </ng-template>\r\n    \r\n    <ng-template #defaultItemTemplate let-i=\"index\" let-file=\"file\" let-control=\"control\">\r\n        <file-upload-list-item  [index]=\"i\" [file]=\"file\" [control]=\"control\"></file-upload-list-item>\r\n    </ng-template>\r\n</div>`,\r\n    styles: [`:host,:host>*{box-sizing:border-box}:host{overflow:hidden;display:block;background:#fafafa;padding:20px 66px 20px 20px;min-height:140px;outline:#92b0b3 dashed 1px;outline-offset:-10px;position:relative}:host(.dragover){outline-width:2px}:host(.disabled){opacity:.5;cursor:no-drop}.files-input{width:.1px;height:.1px;opacity:0;position:absolute;left:-100%;top:-100%;overflow:hidden}.icon{height:35px;width:35px;border:1px solid #eaeaea;border-radius:4px;float:left;margin-right:20px}:host(.has-files) .icon{margin:0}.icon svg{fill:#909293}.upload-input:after{clear:both;content:\"\\\\0A0\";display:block;height:0;line-height:0;visibility:hidden;zoom:1}.upload-input{cursor:pointer;display:inline-block;color:#646464;position:absolute;top:50%;left:50%;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);transition:all .15s ease-in-out}:host(.disabled) .upload-input{cursor:not-allowed}:host(.has-files) .upload-input{top:20px;left:100%;margin-left:-20px;-webkit-transform:translate(-100%,0);transform:translate(-100%,0);text-align:center}.upload-text{overflow:hidden;width:auto}:host(.has-files) .upload-text{display:none}:host(.dragover:not(.disabled)) .upload-input,:host(:not(.disabled)) .upload-input:hover{color:#80a9d2}:host(.dragover:not(.disabled)) .icon svg,:host(:not(.disabled)) .upload-input:hover svg{fill:#80a9d2}:host(:not(.disabled)) .upload-input:hover .icon{border-color:#80a9d2}file-upload-list-item{padding:10px 0 0}file-upload-list-item:first-child{padding:0}`],\r\n    providers: [ \r\n        FileUploadService,\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: forwardRef(() => FileUploadComponent),\r\n            multi: true\r\n        }\r\n    ],\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class FileUploadComponent implements OnInit, OnDestroy, ControlValueAccessor {\r\n\r\n    @Input()\r\n    public control: FileUploadControl = null;\r\n\r\n    @ContentChild('placeholder')\r\n    public templateRef: TemplateRef<any> = null;\r\n\r\n    @ContentChild('item')\r\n    public listItem: TemplateRef<any> = null;\r\n\r\n    @ViewChild('inputRef')\r\n    public input: ElementRef<HTMLInputElement>;\r\n\r\n    public templateContext = {\r\n        $implicit: this.fileUploadService.isFileDragDropAvailable(),\r\n        isFileDragDropAvailable: this.fileUploadService.isFileDragDropAvailable()\r\n    };\r\n\r\n    private hooks: Array<Function> = [];\r\n\r\n    private subscriptions: Array<Subscription> = [];\r\n\r\n    constructor(\r\n        public fileUploadService: FileUploadService,\r\n        private hostElementRef: ElementRef,\r\n        private renderer: Renderer2,\r\n        @Inject(DOCUMENT) private document,\r\n        private cdr: ChangeDetectorRef\r\n    ) {}\r\n\r\n    public ngOnInit() {\r\n        if (IsNullOrEmpty(this.control)) {\r\n            this.control = new FileUploadControl();\r\n        }\r\n\r\n        this.setEvents();\r\n        this.checkAndMarkAsDisabled();\r\n        this.connectToForm();\r\n    }\r\n\r\n    public ngOnDestroy(): void {\r\n        this.cdr.detach();\r\n        this.hooks.forEach((hook) => hook());\r\n        this.hooks.length = 0;\r\n        this.subscriptions.forEach((subscription) => subscription.unsubscribe());\r\n        this.subscriptions.length = 0;\r\n    }\r\n\r\n    @HostBinding('class.has-files')\r\n    public get hasFiles(): boolean {\r\n        return this.control.isListVisible && this.control.size > 0;\r\n    }\r\n\r\n    @HostBinding('class.ng-invalid')\r\n    public get isInvalid(): boolean {\r\n        return !this.control.disabled && this.control.invalid;\r\n    }\r\n\r\n    private setEvents(): void {\r\n        ['drag', 'dragstart', 'dragend', 'dragover', 'dragenter', 'dragleave', 'drop'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.document, eventName, (event: any) => this.preventDragEvents(event))\r\n            );\r\n        });\r\n\r\n        ['dragover', 'dragenter'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.hostElementRef.nativeElement, eventName, (event: any) => this.onDragOver(event))\r\n            );\r\n        });\r\n\r\n        ['dragleave', 'dragend', 'drop'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.hostElementRef.nativeElement, eventName, (event: any) => this.onDragLeave(event))\r\n            );\r\n        });\r\n\r\n        this.subscriptions.push(\r\n            this.control.statusChanges.subscribe((status) => this.checkAndMarkAsDisabled())\r\n        );\r\n\r\n        this.subscriptions.push(\r\n            this.control.valueChanges.subscribe((files) => this.cdr.markForCheck())\r\n        );\r\n    }\r\n\r\n    private checkAndMarkAsDisabled(): void {\r\n        if (this.control.disabled) {\r\n            this.renderer.addClass(this.hostElementRef.nativeElement, 'disabled');\r\n            this.renderer.setProperty(this.input.nativeElement, 'disabled', true);\r\n        } else {\r\n            this.renderer.removeClass(this.hostElementRef.nativeElement, 'disabled');\r\n            this.renderer.setProperty(this.input.nativeElement, 'disabled', false);\r\n        }\r\n    }\r\n\r\n    private preventDragEvents(event: DragEvent): void {\r\n        event.preventDefault();\r\n        event.stopPropagation();\r\n    }\r\n\r\n    /**\r\n     * on file over add class name\r\n     */\r\n    private onDragOver(event: DragEvent): void {\r\n        this.renderer.addClass(this.hostElementRef.nativeElement, DRAGOVER);\r\n    }\r\n\r\n    /**\r\n     * on mouse out remove class name\r\n     */\r\n    private onDragLeave(event: DragEvent): void {\r\n        this.renderer.removeClass(this.hostElementRef.nativeElement, DRAGOVER);\r\n    }\r\n\r\n    @HostListener('drop', ['$event'])\r\n    public onDrop(event: DragEvent): void {\r\n        if (this.control.disabled) {\r\n            return;\r\n        }\r\n        const files = event.dataTransfer.files;\r\n        this.control.addFiles(files);\r\n        this.onTouch();\r\n    }\r\n\r\n    public onInputChange(event: Event): void {\r\n        const input = (event.target) as HTMLInputElement;\r\n\r\n        if (!this.control.disabled) {\r\n            this.control.addFiles(input.files);\r\n        }\r\n        this.clearInputEl();\r\n        this.onTouch();\r\n    }\r\n\r\n    private clearInputEl(): void {\r\n        this.input.nativeElement.value = null;\r\n    }\r\n\r\n    /**\r\n     * ControlValueAccessor implementation\r\n     */\r\n    private connectToForm(): void {\r\n        this.subscriptions.push(\r\n            this.control.valueChanges.subscribe((v) => this.onChange(v))\r\n        );\r\n    }\r\n\r\n     /**\r\n      * model -> view changes\r\n      */\r\n    public writeValue(files: any): void {\r\n        if (!IsNullOrEmpty(files)) {\r\n            this.control.setValue(files);\r\n        }\r\n    }\r\n\r\n    private onChange: (v: Array<File>) => void = () => {};\r\n\r\n    /**\r\n     * register function which will be called on UI change\r\n     * to update view -> model\r\n     */\r\n    public registerOnChange(fn: (v: Array<File>) => void): void {\r\n        this.onChange = fn;\r\n    }\r\n\r\n    private onTouch: () => void = () => {\r\n        this.renderer.addClass(this.hostElementRef.nativeElement, TOUCHED);\r\n    };\r\n\r\n    public registerOnTouched(fn: any): void {\r\n        this.onTouch = fn;\r\n    }\r\n\r\n    public setDisabledState(isDisabled: boolean): void {\r\n        this.control.disable(isDisabled);\r\n    }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload.component.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["components/file-upload.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Component,\r\n    Input,\r\n    OnInit,\r\n    ElementRef,\r\n    HostListener,\r\n    Renderer2,\r\n    OnDestroy,\r\n    HostBinding,\r\n    Inject,\r\n    TemplateRef,\r\n    ViewChild,\r\n    ChangeDetectionStrategy,\r\n    ContentChild,\r\n    forwardRef,\r\n    ChangeDetectorRef\r\n} from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\r\n\r\nimport { FileUploadControl } from './../helpers/control.class';\r\nimport { IsNullOrEmpty } from './../helpers/helpers.class';\r\nimport { FileUploadService } from './../services/file-upload.service';\r\nimport { Subscription } from 'rxjs';\r\n\r\nexport const DRAGOVER = 'dragover';\r\nexport const TOUCHED = 'ng-touched';\r\n\r\n@Component({\r\n    selector: `file-upload`,\r\n    template: `<label class=\"upload-input\">\r\n\r\n    <ng-container *ngTemplateOutlet=\"templateRef ? templateRef : defaultTemplate; context: templateContext\"></ng-container>\r\n\r\n    <ng-template #defaultTemplate let-isFileDragDropAvailable=\"isFileDragDropAvailable\">\r\n        <div class=\"icon\">\r\n            <svg viewBox=\"0 0 96 96\">\r\n                <g>\r\n                    <path d=\"M62.8,68.1c0-0.6-0.2-1.1-0.6-1.5c-0.4-0.4-0.9-0.6-1.5-0.6s-1.1,0.2-1.5,0.6\r\n                        c-0.4,0.4-0.6,0.9-0.6,1.5c0,0.6,0.2,1.1,0.6,1.5c0.4,0.4,0.9,0.6,1.5,0.6s1.1-0.2,1.5-0.6S62.8,68.7,62.8,68.1z M71.3,68.1\r\n                        c0-0.6-0.2-1.1-0.6-1.5c-0.4-0.4-0.9-0.6-1.5-0.6c-0.6,0-1.1,0.2-1.5,0.6C67.2,67,67,67.5,67,68.1c0,0.6,0.2,1.1,0.6,1.5\r\n                        s0.9,0.6,1.5,0.6c0.6,0,1.1-0.2,1.5-0.6C71.1,69.2,71.3,68.7,71.3,68.1z M75.5,60.7v10.6c0,0.9-0.3,1.6-0.9,2.2\r\n                        c-0.6,0.6-1.4,0.9-2.2,0.9H23.7c-0.9,0-1.6-0.3-2.2-0.9c-0.6-0.6-0.9-1.4-0.9-2.2V60.7c0-0.9,0.3-1.6,0.9-2.2\r\n                        c0.6-0.6,1.4-0.9,2.2-0.9h14.1c0.5,1.2,1.2,2.2,2.3,3c1.1,0.8,2.3,1.2,3.7,1.2h8.5c1.3,0,2.6-0.4,3.7-1.2c1.1-0.8,1.9-1.8,2.3-3\r\n                        h14.1c0.9,0,1.6,0.3,2.2,0.9C75.2,59.1,75.5,59.8,75.5,60.7z M64.8,39.3c-0.4,0.9-1,1.3-2,1.3h-8.5v14.8c0,0.6-0.2,1.1-0.6,1.5\r\n                        c-0.4,0.4-0.9,0.6-1.5,0.6h-8.5c-0.6,0-1.1-0.2-1.5-0.6c-0.4-0.4-0.6-0.9-0.6-1.5V40.6h-8.5c-0.9,0-1.6-0.4-2-1.3\r\n                        c-0.4-0.9-0.2-1.6,0.5-2.3l14.8-14.8c0.4-0.4,0.9-0.6,1.5-0.6s1.1,0.2,1.5,0.6L64.3,37C65,37.7,65.1,38.4,64.8,39.3z\"/>\r\n                </g>\r\n            </svg>\r\n        </div>\r\n    \r\n        <div class=\"upload-text\">\r\n            <ng-container *ngIf=\"isFileDragDropAvailable; else isNotDragDropAvailable\">\r\n                <b>Drag and drop</b> files<br> or click here\r\n            </ng-container>\r\n            <ng-template #isNotDragDropAvailable>\r\n                <b>Click here</b> to<br> choose a files\r\n            </ng-template>\r\n        </div>\r\n    </ng-template>\r\n\r\n    <input #inputRef type=\"file\" class=\"files-input\" multiple (change)=\"onInputChange($event)\">\r\n</label>\r\n\r\n<div class=\"upload-list\" *ngIf=\"(control.listVisibilityChanges | async) && control.size > 0\">\r\n    <ng-template ngFor let-file let-i=\"index\" [ngForOf]=\"control.valueChanges | async\">\r\n        <ng-container *ngTemplateOutlet=\"listItem ? listItem : defaultItemTemplate; context: { $implicit: file, file: file, index: i, control: control }\"></ng-container>\r\n    </ng-template>\r\n    \r\n    <ng-template #defaultItemTemplate let-i=\"index\" let-file=\"file\" let-control=\"control\">\r\n        <file-upload-list-item  [index]=\"i\" [file]=\"file\" [control]=\"control\"></file-upload-list-item>\r\n    </ng-template>\r\n</div>`,\r\n    styles: [`:host,:host>*{box-sizing:border-box}:host{overflow:hidden;display:block;background:#fafafa;padding:20px 66px 20px 20px;min-height:140px;outline:#92b0b3 dashed 1px;outline-offset:-10px;position:relative}:host(.dragover){outline-width:2px}:host(.disabled){opacity:.5;cursor:no-drop}.files-input{width:.1px;height:.1px;opacity:0;position:absolute;left:-100%;top:-100%;overflow:hidden}.icon{height:35px;width:35px;border:1px solid #eaeaea;border-radius:4px;float:left;margin-right:20px}:host(.has-files) .icon{margin:0}.icon svg{fill:#909293}.upload-input:after{clear:both;content:\"\\\\0A0\";display:block;height:0;line-height:0;visibility:hidden;zoom:1}.upload-input{cursor:pointer;display:inline-block;color:#646464;position:absolute;top:50%;left:50%;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);transition:all .15s ease-in-out}:host(.disabled) .upload-input{cursor:not-allowed}:host(.has-files) .upload-input{top:20px;left:100%;margin-left:-20px;-webkit-transform:translate(-100%,0);transform:translate(-100%,0);text-align:center}.upload-text{overflow:hidden;width:auto}:host(.has-files) .upload-text{display:none}:host(.dragover:not(.disabled)) .upload-input,:host(:not(.disabled)) .upload-input:hover{color:#80a9d2}:host(.dragover:not(.disabled)) .icon svg,:host(:not(.disabled)) .upload-input:hover svg{fill:#80a9d2}:host(:not(.disabled)) .upload-input:hover .icon{border-color:#80a9d2}file-upload-list-item{padding:10px 0 0}file-upload-list-item:first-child{padding:0}`],\r\n    providers: [ \r\n        FileUploadService,\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: forwardRef(() => FileUploadComponent),\r\n            multi: true\r\n        }\r\n    ],\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class FileUploadComponent implements OnInit, OnDestroy, ControlValueAccessor {\r\n\r\n    @Input()\r\n    public control: FileUploadControl = null;\r\n\r\n    @ContentChild('placeholder')\r\n    public templateRef: TemplateRef<any> = null;\r\n\r\n    @ContentChild('item')\r\n    public listItem: TemplateRef<any> = null;\r\n\r\n    @ViewChild('inputRef')\r\n    public input: ElementRef<HTMLInputElement>;\r\n\r\n    public templateContext = {\r\n        $implicit: this.fileUploadService.isFileDragDropAvailable(),\r\n        isFileDragDropAvailable: this.fileUploadService.isFileDragDropAvailable()\r\n    };\r\n\r\n    private hooks: Array<Function> = [];\r\n\r\n    private subscriptions: Array<Subscription> = [];\r\n\r\n    constructor(\r\n        public fileUploadService: FileUploadService,\r\n        private hostElementRef: ElementRef,\r\n        private renderer: Renderer2,\r\n        @Inject(DOCUMENT) private document,\r\n        private cdr: ChangeDetectorRef\r\n    ) {}\r\n\r\n    public ngOnInit() {\r\n        if (IsNullOrEmpty(this.control)) {\r\n            this.control = new FileUploadControl();\r\n        }\r\n\r\n        this.setEvents();\r\n        this.checkAndMarkAsDisabled();\r\n        this.connectToForm();\r\n    }\r\n\r\n    public ngOnDestroy(): void {\r\n        this.cdr.detach();\r\n        this.hooks.forEach((hook) => hook());\r\n        this.hooks.length = 0;\r\n        this.subscriptions.forEach((subscription) => subscription.unsubscribe());\r\n        this.subscriptions.length = 0;\r\n    }\r\n\r\n    @HostBinding('class.has-files')\r\n    public get hasFiles(): boolean {\r\n        return this.control.isListVisible && this.control.size > 0;\r\n    }\r\n\r\n    @HostBinding('class.ng-invalid')\r\n    public get isInvalid(): boolean {\r\n        return !this.control.disabled && this.control.invalid;\r\n    }\r\n\r\n    private setEvents(): void {\r\n        ['drag', 'dragstart', 'dragend', 'dragover', 'dragenter', 'dragleave', 'drop'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.document, eventName, (event: any) => this.preventDragEvents(event))\r\n            );\r\n        });\r\n\r\n        ['dragover', 'dragenter'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.hostElementRef.nativeElement, eventName, (event: any) => this.onDragOver(event))\r\n            );\r\n        });\r\n\r\n        ['dragleave', 'dragend', 'drop'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.hostElementRef.nativeElement, eventName, (event: any) => this.onDragLeave(event))\r\n            );\r\n        });\r\n\r\n        this.subscriptions.push(\r\n            this.control.statusChanges.subscribe((status) => this.checkAndMarkAsDisabled())\r\n        );\r\n\r\n        this.subscriptions.push(\r\n            this.control.valueChanges.subscribe((files) => this.cdr.markForCheck())\r\n        );\r\n    }\r\n\r\n    private checkAndMarkAsDisabled(): void {\r\n        if (this.control.disabled) {\r\n            this.renderer.addClass(this.hostElementRef.nativeElement, 'disabled');\r\n            this.renderer.setProperty(this.input.nativeElement, 'disabled', true);\r\n        } else {\r\n            this.renderer.removeClass(this.hostElementRef.nativeElement, 'disabled');\r\n            this.renderer.setProperty(this.input.nativeElement, 'disabled', false);\r\n        }\r\n    }\r\n\r\n    private preventDragEvents(event: DragEvent): void {\r\n        event.preventDefault();\r\n        event.stopPropagation();\r\n    }\r\n\r\n    /**\r\n     * on file over add class name\r\n     */\r\n    private onDragOver(event: DragEvent): void {\r\n        this.renderer.addClass(this.hostElementRef.nativeElement, DRAGOVER);\r\n    }\r\n\r\n    /**\r\n     * on mouse out remove class name\r\n     */\r\n    private onDragLeave(event: DragEvent): void {\r\n        this.renderer.removeClass(this.hostElementRef.nativeElement, DRAGOVER);\r\n    }\r\n\r\n    @HostListener('drop', ['$event'])\r\n    public onDrop(event: DragEvent): void {\r\n        if (this.control.disabled) {\r\n            return;\r\n        }\r\n        const files = event.dataTransfer.files;\r\n        this.control.addFiles(files);\r\n        this.onTouch();\r\n    }\r\n\r\n    public onInputChange(event: Event): void {\r\n        const input = (event.target) as HTMLInputElement;\r\n\r\n        if (!this.control.disabled) {\r\n            this.control.addFiles(input.files);\r\n        }\r\n        this.clearInputEl();\r\n        this.onTouch();\r\n    }\r\n\r\n    private clearInputEl(): void {\r\n        this.input.nativeElement.value = null;\r\n    }\r\n\r\n    /**\r\n     * ControlValueAccessor implementation\r\n     */\r\n    private connectToForm(): void {\r\n        this.subscriptions.push(\r\n            this.control.valueChanges.subscribe((v) => this.onChange(v))\r\n        );\r\n    }\r\n\r\n     /**\r\n      * model -> view changes\r\n      */\r\n    public writeValue(files: any): void {\r\n        if (!IsNullOrEmpty(files)) {\r\n            this.control.setValue(files);\r\n        }\r\n    }\r\n\r\n    private onChange: (v: Array<File>) => void = () => {};\r\n\r\n    /**\r\n     * register function which will be called on UI change\r\n     * to update view -> model\r\n     */\r\n    public registerOnChange(fn: (v: Array<File>) => void): void {\r\n        this.onChange = fn;\r\n    }\r\n\r\n    private onTouch: () => void = () => {\r\n        this.renderer.addClass(this.hostElementRef.nativeElement, TOUCHED);\r\n    };\r\n\r\n    public registerOnTouched(fn: any): void {\r\n        this.onTouch = fn;\r\n    }\r\n\r\n    public setDisabledState(isDisabled: boolean): void {\r\n        this.control.disable(isDisabled);\r\n    }\r\n}\r\n"]}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/

@@ -54,3 +54,4 @@ import { Directive, forwardRef, Input } from '@angular/core';

_createValidator() {
let /** @type {?} */ maxSize = null;
/** @type {?} */
let maxSize = null;
if (!IsNullOrEmpty(this.maxsize)) {

@@ -62,3 +63,4 @@ maxSize = typeof this.maxsize === 'string' ? parseInt(this.maxsize, 10) : this.maxsize;

}
const /** @type {?} */ minSize = typeof this.minsize === 'string' ? parseInt(this.minsize, 10) : this.minsize;
/** @type {?} */
const minSize = typeof this.minsize === 'string' ? parseInt(this.minsize, 10) : this.minsize;
this.validator = FileUploadValidators.sizeRange({ maxSize, minSize });

@@ -89,3 +91,3 @@ }

};
function FileSizeValidator_tsickle_Closure_declarations() {
if (false) {
/** @type {?} */

@@ -161,3 +163,3 @@ FileSizeValidator.prototype.filesize;

};
function FilesLimitValidator_tsickle_Closure_declarations() {
if (false) {
/** @type {?} */

@@ -231,3 +233,3 @@ FilesLimitValidator.prototype.fileslimit;

};
function FilesAcceptValidator_tsickle_Closure_declarations() {
if (false) {
/** @type {?} */

@@ -240,3 +242,2 @@ FilesAcceptValidator.prototype.accept;

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validators.directive.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["directives/validators.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, forwardRef, Input, OnChanges, SimpleChanges } from '@angular/core';\r\nimport { NG_VALIDATORS, Validator, AbstractControl } from '@angular/forms';\r\nimport { ValidationErrors, ValidatorFn, FileUploadValidators } from './../helpers/validators.class';\r\nimport { IsNullOrEmpty } from './../helpers/helpers.class';\r\n\r\n\r\n/**\r\n * A Directive that adds the `filesize` validator to controls marked with the\r\n * `filesize` attribute.\r\n *\r\n * ### Example\r\n *\r\n * ```\r\n * <file-upload name=\"files\" ngModel filesize=\"830000\"></file-upload>\r\n * <file-upload name=\"files\" ngModel [filesize]=\"830000\"></file-upload>\r\n * <file-upload name=\"files\" ngModel minSize=\"0\" max=\"6200\"></file-upload>\r\n * ```\r\n *\r\n */\r\n@Directive({\r\n    selector: `[filesize][formControlName],[filesize][formControl],[filesize][ngModel],\r\n    [minsize][formControlName],[minsize][formControl],[minsize][ngModel],\r\n    [maxsize][formControlName],[maxsize][formControl],[maxsize][ngModel]`,\r\n    providers: [{\r\n        provide: NG_VALIDATORS,\r\n        useExisting: forwardRef(() => FileSizeValidator),\r\n        multi: true\r\n    }],\r\n    host: {\r\n        '[attr.filesize]': 'filesize ? filesize : null',\r\n        '[attr.minsize]': 'minsize ? minsize : null',\r\n        '[attr.maxsize]': 'maxsize ? maxsize : null'\r\n    }\r\n})\r\nexport class FileSizeValidator implements Validator, OnChanges {\r\n    \r\n    @Input()\r\n    private filesize: string|number;\r\n\r\n    @Input()\r\n    private minsize: string|number;\r\n    \r\n    @Input()\r\n    private maxsize: string|number;\r\n\r\n    private validator: ValidatorFn;\r\n\r\n    private onChange: () => void;\r\n  \r\n    public ngOnChanges(changes: SimpleChanges): void {\r\n        if ('filesize' in changes \r\n            || 'maxsize' in changes \r\n            || 'minsize' in changes) {\r\n          this._createValidator();\r\n          if (this.onChange) this.onChange();\r\n        }\r\n    }\r\n\r\n    public validate(c: AbstractControl): ValidationErrors|null {\r\n        return this.validator(c);\r\n    }\r\n  \r\n    public registerOnValidatorChange(fn: () => void): void {\r\n        this.onChange = fn; \r\n    }\r\n\r\n    private _createValidator(): void {\r\n        let maxSize = null;        \r\n        if (!IsNullOrEmpty(this.maxsize)) {\r\n            maxSize = typeof this.maxsize === 'string' ? parseInt(this.maxsize, 10) : this.maxsize;\r\n        } else if(!IsNullOrEmpty(this.filesize)) {\r\n            maxSize = typeof this.filesize === 'string' ? parseInt(this.filesize, 10) : this.filesize;\r\n        }\r\n\r\n        const minSize = typeof this.minsize === 'string' ? parseInt(this.minsize, 10) : this.minsize;\r\n\r\n        this.validator = FileUploadValidators.sizeRange({ maxSize, minSize });\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * A Directive that adds the `fileslimit` validator to controls marked with the\r\n * `fileslimit` attribute.\r\n *\r\n * ### Example\r\n *\r\n * ```\r\n * <file-upload name=\"files\" ngModel fileslimit=\"2\"></file-upload>\r\n * <file-upload name=\"files\" ngModel [fileslimit]=\"2\"></file-upload>\r\n * ```\r\n *\r\n */\r\n@Directive({\r\n    selector: '[fileslimit][formControlName],[fileslimit][formControl],[fileslimit][ngModel]',\r\n    providers: [{\r\n        provide: NG_VALIDATORS,\r\n        useExisting: forwardRef(() => FilesLimitValidator),\r\n        multi: true\r\n    }],\r\n    host: {'[attr.fileslimit]': 'fileslimit ? fileslimit : null'}\r\n})\r\nexport class FilesLimitValidator implements Validator, OnChanges {\r\n    \r\n    @Input()\r\n    private fileslimit: string|number;\r\n\r\n    private validator: ValidatorFn;\r\n\r\n    private onChange: () => void;\r\n  \r\n    public ngOnChanges(changes: SimpleChanges): void {\r\n        if ('fileslimit' in changes) {\r\n          this._createValidator();\r\n          if (this.onChange) this.onChange();\r\n        }\r\n    }\r\n\r\n    public validate(c: AbstractControl): ValidationErrors|null {\r\n        return this.fileslimit != null ? this.validator(c) : null;\r\n    }\r\n  \r\n    public registerOnValidatorChange(fn: () => void): void {\r\n        this.onChange = fn; \r\n    }\r\n\r\n    private _createValidator(): void {\r\n        this.validator = FileUploadValidators.filesLimit(typeof this.fileslimit === 'string' ? parseInt(this.fileslimit, 10) : this.fileslimit);\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * A Directive that adds the `accept` validator to controls marked with the\r\n * `accept` attribute.\r\n *\r\n * ### Example\r\n *\r\n * ```\r\n * <file-upload name=\"files\" ngModel accept=\"file_extension|audio/*|video/*|image/*|media_type\"></file-upload>\r\n * <file-upload name=\"files\" ngModel [accept]=\"file_extension|audio/*|video/*|image/*|media_type\"></file-upload>\r\n * ```\r\n * \r\n * To specify more than one value, separate the values with a comma (e.g. <file-upload accept=\"audio/*,video/*,image/*\"></file-upload>.\r\n *\r\n */\r\n@Directive({\r\n    selector: '[accept][formControlName],[accept][formControl],[accept][ngModel]',\r\n    providers: [{\r\n        provide: NG_VALIDATORS,\r\n        useExisting: forwardRef(() => FilesLimitValidator),\r\n        multi: true\r\n    }],\r\n    host: {'[attr.accept]': 'accept ? accept : null'}\r\n})\r\nexport class FilesAcceptValidator implements Validator, OnChanges {\r\n    \r\n    @Input()\r\n    private accept: string;\r\n\r\n    private validator: ValidatorFn;\r\n\r\n    private onChange: () => void;\r\n  \r\n    public ngOnChanges(changes: SimpleChanges): void {\r\n        if ('accept' in changes) {\r\n          this._createValidator();\r\n          if (this.onChange) this.onChange();\r\n        }\r\n    }\r\n\r\n    public validate(c: AbstractControl): ValidationErrors|null {\r\n        return this.accept != null ? this.validator(c) : null;\r\n    }\r\n  \r\n    public registerOnValidatorChange(fn: () => void): void {\r\n        this.onChange = fn; \r\n    }\r\n\r\n    private _createValidator(): void {\r\n        this.validator = FileUploadValidators.accept(this.accept.split(','));\r\n    }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validators.directive.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["directives/validators.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, forwardRef, Input, OnChanges, SimpleChanges } from '@angular/core';\r\nimport { NG_VALIDATORS, Validator, AbstractControl } from '@angular/forms';\r\nimport { ValidationErrors, ValidatorFn, FileUploadValidators } from './../helpers/validators.class';\r\nimport { IsNullOrEmpty } from './../helpers/helpers.class';\r\n\r\n\r\n/**\r\n * A Directive that adds the `filesize` validator to controls marked with the\r\n * `filesize` attribute.\r\n *\r\n * ### Example\r\n *\r\n * ```\r\n * <file-upload name=\"files\" ngModel filesize=\"830000\"></file-upload>\r\n * <file-upload name=\"files\" ngModel [filesize]=\"830000\"></file-upload>\r\n * <file-upload name=\"files\" ngModel minSize=\"0\" max=\"6200\"></file-upload>\r\n * ```\r\n *\r\n */\r\n@Directive({\r\n    selector: `[filesize][formControlName],[filesize][formControl],[filesize][ngModel],\r\n    [minsize][formControlName],[minsize][formControl],[minsize][ngModel],\r\n    [maxsize][formControlName],[maxsize][formControl],[maxsize][ngModel]`,\r\n    providers: [{\r\n        provide: NG_VALIDATORS,\r\n        useExisting: forwardRef(() => FileSizeValidator),\r\n        multi: true\r\n    }],\r\n    host: {\r\n        '[attr.filesize]': 'filesize ? filesize : null',\r\n        '[attr.minsize]': 'minsize ? minsize : null',\r\n        '[attr.maxsize]': 'maxsize ? maxsize : null'\r\n    }\r\n})\r\nexport class FileSizeValidator implements Validator, OnChanges {\r\n    \r\n    @Input()\r\n    public filesize: string|number;\r\n\r\n    @Input()\r\n    public minsize: string|number;\r\n    \r\n    @Input()\r\n    public maxsize: string|number;\r\n\r\n    private validator: ValidatorFn;\r\n\r\n    private onChange: () => void;\r\n  \r\n    public ngOnChanges(changes: SimpleChanges): void {\r\n        if ('filesize' in changes \r\n            || 'maxsize' in changes \r\n            || 'minsize' in changes) {\r\n          this._createValidator();\r\n          if (this.onChange) this.onChange();\r\n        }\r\n    }\r\n\r\n    public validate(c: AbstractControl): ValidationErrors|null {\r\n        return this.validator(c);\r\n    }\r\n  \r\n    public registerOnValidatorChange(fn: () => void): void {\r\n        this.onChange = fn; \r\n    }\r\n\r\n    private _createValidator(): void {\r\n        let maxSize = null;        \r\n        if (!IsNullOrEmpty(this.maxsize)) {\r\n            maxSize = typeof this.maxsize === 'string' ? parseInt(this.maxsize, 10) : this.maxsize;\r\n        } else if(!IsNullOrEmpty(this.filesize)) {\r\n            maxSize = typeof this.filesize === 'string' ? parseInt(this.filesize, 10) : this.filesize;\r\n        }\r\n\r\n        const minSize = typeof this.minsize === 'string' ? parseInt(this.minsize, 10) : this.minsize;\r\n\r\n        this.validator = FileUploadValidators.sizeRange({ maxSize, minSize });\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * A Directive that adds the `fileslimit` validator to controls marked with the\r\n * `fileslimit` attribute.\r\n *\r\n * ### Example\r\n *\r\n * ```\r\n * <file-upload name=\"files\" ngModel fileslimit=\"2\"></file-upload>\r\n * <file-upload name=\"files\" ngModel [fileslimit]=\"2\"></file-upload>\r\n * ```\r\n *\r\n */\r\n@Directive({\r\n    selector: '[fileslimit][formControlName],[fileslimit][formControl],[fileslimit][ngModel]',\r\n    providers: [{\r\n        provide: NG_VALIDATORS,\r\n        useExisting: forwardRef(() => FilesLimitValidator),\r\n        multi: true\r\n    }],\r\n    host: {'[attr.fileslimit]': 'fileslimit ? fileslimit : null'}\r\n})\r\nexport class FilesLimitValidator implements Validator, OnChanges {\r\n    \r\n    @Input()\r\n    public fileslimit: string|number;\r\n\r\n    private validator: ValidatorFn;\r\n\r\n    private onChange: () => void;\r\n  \r\n    public ngOnChanges(changes: SimpleChanges): void {\r\n        if ('fileslimit' in changes) {\r\n          this._createValidator();\r\n          if (this.onChange) this.onChange();\r\n        }\r\n    }\r\n\r\n    public validate(c: AbstractControl): ValidationErrors|null {\r\n        return this.fileslimit != null ? this.validator(c) : null;\r\n    }\r\n  \r\n    public registerOnValidatorChange(fn: () => void): void {\r\n        this.onChange = fn; \r\n    }\r\n\r\n    private _createValidator(): void {\r\n        this.validator = FileUploadValidators.filesLimit(typeof this.fileslimit === 'string' ? parseInt(this.fileslimit, 10) : this.fileslimit);\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * A Directive that adds the `accept` validator to controls marked with the\r\n * `accept` attribute.\r\n *\r\n * ### Example\r\n *\r\n * ```\r\n * <file-upload name=\"files\" ngModel accept=\"file_extension|audio/*|video/*|image/*|media_type\"></file-upload>\r\n * <file-upload name=\"files\" ngModel [accept]=\"file_extension|audio/*|video/*|image/*|media_type\"></file-upload>\r\n * ```\r\n * \r\n * To specify more than one value, separate the values with a comma (e.g. <file-upload accept=\"audio/*,video/*,image/*\"></file-upload>.\r\n *\r\n */\r\n@Directive({\r\n    selector: '[accept][formControlName],[accept][formControl],[accept][ngModel]',\r\n    providers: [{\r\n        provide: NG_VALIDATORS,\r\n        useExisting: forwardRef(() => FilesLimitValidator),\r\n        multi: true\r\n    }],\r\n    host: {'[attr.accept]': 'accept ? accept : null'}\r\n})\r\nexport class FilesAcceptValidator implements Validator, OnChanges {\r\n    \r\n    @Input()\r\n    public accept: string;\r\n\r\n    private validator: ValidatorFn;\r\n\r\n    private onChange: () => void;\r\n  \r\n    public ngOnChanges(changes: SimpleChanges): void {\r\n        if ('accept' in changes) {\r\n          this._createValidator();\r\n          if (this.onChange) this.onChange();\r\n        }\r\n    }\r\n\r\n    public validate(c: AbstractControl): ValidationErrors|null {\r\n        return this.accept != null ? this.validator(c) : null;\r\n    }\r\n  \r\n    public registerOnValidatorChange(fn: () => void): void {\r\n        this.onChange = fn; \r\n    }\r\n\r\n    private _createValidator(): void {\r\n        this.validator = FileUploadValidators.accept(this.accept.split(','));\r\n    }\r\n}\r\n"]}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/
/*
* l10n
*
* By Ivan Pintar, http://www.pintar-ivan.com
* Licensed under the MIT License
* See https://github.com/pIvan/file-upload/blob/master/README.md
*/
import { NgModule, Injector } from '@angular/core';

@@ -21,5 +28,5 @@ import { ReactiveFormsModule, FormsModule } from '@angular/forms';

constructor(injector) {
this.injector = injector;
// const fileUploadElement = createCustomElement(FileUploadComponent, { injector });
// customElements.define('file-upload', fileUploadElement);
this.injector = injector;
}

@@ -63,7 +70,6 @@ /**

];
function FileUploadModule_tsickle_Closure_declarations() {
if (false) {
/** @type {?} */
FileUploadModule.prototype.injector;
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQGlwbGFiL25neC1maWxlLXVwbG9hZC8iLCJzb3VyY2VzIjpbImZpbGUtdXBsb2FkLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBT0EsT0FBTyxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUN6RSxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSw4Q0FBOEMsQ0FBQztBQUMzRixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUNsRixPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUV2RixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsbUJBQW1CLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUdqSCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM1RCxPQUFPLEVBQUUsb0JBQW9CLEVBQWlDLE1BQU0sNEJBQTRCLENBQUM7QUFDakcsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBK0I3RCxNQUFNOzs7O0lBRUYsWUFBb0IsUUFBa0I7OztRQUFsQixhQUFRLEdBQVIsUUFBUSxDQUFVO0tBR3JDOzs7O0lBRUQsYUFBYSxNQUFLOzs7WUFwQ3JCLFFBQVEsU0FBQztnQkFDTixPQUFPLEVBQUU7b0JBQ0wsWUFBWTtvQkFDWixtQkFBbUI7b0JBQ25CLFdBQVc7aUJBQ2Q7Z0JBQ0QsWUFBWSxFQUFFO29CQUNWLG1CQUFtQjtvQkFDbkIsMkJBQTJCO29CQUMzQix1QkFBdUI7b0JBRXZCLDRCQUE0QjtvQkFFNUIsaUJBQWlCO29CQUNqQixtQkFBbUI7b0JBQ25CLG9CQUFvQjtpQkFDdkI7Z0JBQ0QsT0FBTyxFQUFFO29CQUNMLG1CQUFtQjtvQkFDbkIsNEJBQTRCO29CQUU1QixpQkFBaUI7b0JBQ2pCLG1CQUFtQjtvQkFDbkIsb0JBQW9CO2lCQUN2QjtnQkFDRCxlQUFlLEVBQUU7b0JBQ2IsbUJBQW1CO2lCQUN0QjthQUNKOzs7O1lBNUNrQixRQUFRIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogbDEwblxyXG4gKiBcclxuICogQnkgSXZhbiBQaW50YXIsIGh0dHA6Ly93d3cucGludGFyLWl2YW4uY29tXHJcbiAqIExpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZVxyXG4gKiBTZWUgaHR0cHM6Ly9naXRodWIuY29tL3BJdmFuL2ZpbGUtdXBsb2FkL2Jsb2IvbWFzdGVyL1JFQURNRS5tZFxyXG4gKi9cclxuaW1wb3J0IHsgTmdNb2R1bGUsIEluamVjdG9yIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFJlYWN0aXZlRm9ybXNNb2R1bGUsIEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5cclxuaW1wb3J0IHsgRmlsZVVwbG9hZENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9maWxlLXVwbG9hZC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBGaWxlVXBsb2FkTGlzdEl0ZW1Db21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvZmlsZS11cGxvYWQtbGlzdC1pdGVtLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEZpbGVVcGxvYWRJY29uQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2ZpbGUtdXBsb2FkLWljb24uY29tcG9uZW50JztcclxuaW1wb3J0IHsgRmlsZVVwbG9hZEF0dHJpYnV0ZUNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9maWxlLXVwbG9hZC1hdHRyLmNvbXBvbmVudCc7XHJcblxyXG5pbXBvcnQgeyBGaWxlU2l6ZVZhbGlkYXRvciwgRmlsZXNMaW1pdFZhbGlkYXRvciwgRmlsZXNBY2NlcHRWYWxpZGF0b3IgfSBmcm9tICcuL2RpcmVjdGl2ZXMvdmFsaWRhdG9ycy5kaXJlY3RpdmUnO1xyXG5cclxuXHJcbmV4cG9ydCB7IEZpbGVVcGxvYWRDb250cm9sIH0gZnJvbSAnLi9oZWxwZXJzL2NvbnRyb2wuY2xhc3MnO1xyXG5leHBvcnQgeyBGaWxlVXBsb2FkVmFsaWRhdG9ycywgVmFsaWRhdGlvbkVycm9ycywgVmFsaWRhdG9yRm4gfSBmcm9tICcuL2hlbHBlcnMvdmFsaWRhdG9ycy5jbGFzcyc7XHJcbmV4cG9ydCB7IEZpbGVVcGxvYWRUeXBlcyB9IGZyb20gJy4vaGVscGVycy9maWxlLXR5cGVzLmNsYXNzJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgICBpbXBvcnRzOiBbXHJcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXHJcbiAgICAgICAgRm9ybXNNb2R1bGVcclxuICAgIF0sXHJcbiAgICBkZWNsYXJhdGlvbnM6IFtcclxuICAgICAgICBGaWxlVXBsb2FkQ29tcG9uZW50LFxyXG4gICAgICAgIEZpbGVVcGxvYWRMaXN0SXRlbUNvbXBvbmVudCxcclxuICAgICAgICBGaWxlVXBsb2FkSWNvbkNvbXBvbmVudCxcclxuXHJcbiAgICAgICAgRmlsZVVwbG9hZEF0dHJpYnV0ZUNvbXBvbmVudCxcclxuXHJcbiAgICAgICAgRmlsZVNpemVWYWxpZGF0b3IsXHJcbiAgICAgICAgRmlsZXNMaW1pdFZhbGlkYXRvcixcclxuICAgICAgICBGaWxlc0FjY2VwdFZhbGlkYXRvclxyXG4gICAgXSxcclxuICAgIGV4cG9ydHM6IFtcclxuICAgICAgICBGaWxlVXBsb2FkQ29tcG9uZW50LFxyXG4gICAgICAgIEZpbGVVcGxvYWRBdHRyaWJ1dGVDb21wb25lbnQsXHJcblxyXG4gICAgICAgIEZpbGVTaXplVmFsaWRhdG9yLFxyXG4gICAgICAgIEZpbGVzTGltaXRWYWxpZGF0b3IsXHJcbiAgICAgICAgRmlsZXNBY2NlcHRWYWxpZGF0b3JcclxuICAgIF0sXHJcbiAgICBlbnRyeUNvbXBvbmVudHM6IFtcclxuICAgICAgICBGaWxlVXBsb2FkQ29tcG9uZW50XHJcbiAgICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBGaWxlVXBsb2FkTW9kdWxlIHtcclxuXHJcbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGluamVjdG9yOiBJbmplY3Rvcikge1xyXG4gICAgICAgIC8vIGNvbnN0IGZpbGVVcGxvYWRFbGVtZW50ID0gY3JlYXRlQ3VzdG9tRWxlbWVudChGaWxlVXBsb2FkQ29tcG9uZW50LCB7IGluamVjdG9yIH0pO1xyXG4gICAgICAgIC8vIGN1c3RvbUVsZW1lbnRzLmRlZmluZSgnZmlsZS11cGxvYWQnLCBmaWxlVXBsb2FkRWxlbWVudCk7XHJcbiAgICB9XHJcblxyXG4gICAgbmdEb0Jvb3RzdHJhcCgpIHt9XHJcbn0iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQGlwbGFiL25neC1maWxlLXVwbG9hZC8iLCJzb3VyY2VzIjpbImZpbGUtdXBsb2FkLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQU9BLE9BQU8sRUFBRSxRQUFRLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25ELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFL0MsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDekUsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sOENBQThDLENBQUM7QUFDM0YsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDbEYsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFFdkYsT0FBTyxFQUFFLGlCQUFpQixFQUFFLG1CQUFtQixFQUFFLG9CQUFvQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFHakgsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDNUQsT0FBTyxFQUFFLG9CQUFvQixFQUFpQyxNQUFNLDRCQUE0QixDQUFDO0FBQ2pHLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQStCN0QsTUFBTSxPQUFPLGdCQUFnQjs7OztJQUV6QixZQUFvQixRQUFrQjtRQUFsQixhQUFRLEdBQVIsUUFBUSxDQUFVO1FBQ2xDLG9GQUFvRjtRQUNwRiwyREFBMkQ7SUFDL0QsQ0FBQzs7OztJQUVELGFBQWEsS0FBSSxDQUFDOzs7WUFwQ3JCLFFBQVEsU0FBQztnQkFDTixPQUFPLEVBQUU7b0JBQ0wsWUFBWTtvQkFDWixtQkFBbUI7b0JBQ25CLFdBQVc7aUJBQ2Q7Z0JBQ0QsWUFBWSxFQUFFO29CQUNWLG1CQUFtQjtvQkFDbkIsMkJBQTJCO29CQUMzQix1QkFBdUI7b0JBRXZCLDRCQUE0QjtvQkFFNUIsaUJBQWlCO29CQUNqQixtQkFBbUI7b0JBQ25CLG9CQUFvQjtpQkFDdkI7Z0JBQ0QsT0FBTyxFQUFFO29CQUNMLG1CQUFtQjtvQkFDbkIsNEJBQTRCO29CQUU1QixpQkFBaUI7b0JBQ2pCLG1CQUFtQjtvQkFDbkIsb0JBQW9CO2lCQUN2QjtnQkFDRCxlQUFlLEVBQUU7b0JBQ2IsbUJBQW1CO2lCQUN0QjthQUNKOzs7O1lBNUNrQixRQUFROzs7O0lBK0NYLG9DQUEwQiIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIGwxMG5cclxuICogXHJcbiAqIEJ5IEl2YW4gUGludGFyLCBodHRwOi8vd3d3LnBpbnRhci1pdmFuLmNvbVxyXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2VcclxuICogU2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9wSXZhbi9maWxlLXVwbG9hZC9ibG9iL21hc3Rlci9SRUFETUUubWRcclxuICovXHJcbmltcG9ydCB7IE5nTW9kdWxlLCBJbmplY3RvciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBSZWFjdGl2ZUZvcm1zTW9kdWxlLCBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuXHJcbmltcG9ydCB7IEZpbGVVcGxvYWRDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvZmlsZS11cGxvYWQuY29tcG9uZW50JztcclxuaW1wb3J0IHsgRmlsZVVwbG9hZExpc3RJdGVtQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2ZpbGUtdXBsb2FkLWxpc3QtaXRlbS5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBGaWxlVXBsb2FkSWNvbkNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9maWxlLXVwbG9hZC1pY29uLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEZpbGVVcGxvYWRBdHRyaWJ1dGVDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvZmlsZS11cGxvYWQtYXR0ci5jb21wb25lbnQnO1xyXG5cclxuaW1wb3J0IHsgRmlsZVNpemVWYWxpZGF0b3IsIEZpbGVzTGltaXRWYWxpZGF0b3IsIEZpbGVzQWNjZXB0VmFsaWRhdG9yIH0gZnJvbSAnLi9kaXJlY3RpdmVzL3ZhbGlkYXRvcnMuZGlyZWN0aXZlJztcclxuXHJcblxyXG5leHBvcnQgeyBGaWxlVXBsb2FkQ29udHJvbCB9IGZyb20gJy4vaGVscGVycy9jb250cm9sLmNsYXNzJztcclxuZXhwb3J0IHsgRmlsZVVwbG9hZFZhbGlkYXRvcnMsIFZhbGlkYXRpb25FcnJvcnMsIFZhbGlkYXRvckZuIH0gZnJvbSAnLi9oZWxwZXJzL3ZhbGlkYXRvcnMuY2xhc3MnO1xyXG5leHBvcnQgeyBGaWxlVXBsb2FkVHlwZXMgfSBmcm9tICcuL2hlbHBlcnMvZmlsZS10eXBlcy5jbGFzcyc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgaW1wb3J0czogW1xyXG4gICAgICAgIENvbW1vbk1vZHVsZSxcclxuICAgICAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxyXG4gICAgICAgIEZvcm1zTW9kdWxlXHJcbiAgICBdLFxyXG4gICAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICAgICAgRmlsZVVwbG9hZENvbXBvbmVudCxcclxuICAgICAgICBGaWxlVXBsb2FkTGlzdEl0ZW1Db21wb25lbnQsXHJcbiAgICAgICAgRmlsZVVwbG9hZEljb25Db21wb25lbnQsXHJcblxyXG4gICAgICAgIEZpbGVVcGxvYWRBdHRyaWJ1dGVDb21wb25lbnQsXHJcblxyXG4gICAgICAgIEZpbGVTaXplVmFsaWRhdG9yLFxyXG4gICAgICAgIEZpbGVzTGltaXRWYWxpZGF0b3IsXHJcbiAgICAgICAgRmlsZXNBY2NlcHRWYWxpZGF0b3JcclxuICAgIF0sXHJcbiAgICBleHBvcnRzOiBbXHJcbiAgICAgICAgRmlsZVVwbG9hZENvbXBvbmVudCxcclxuICAgICAgICBGaWxlVXBsb2FkQXR0cmlidXRlQ29tcG9uZW50LFxyXG5cclxuICAgICAgICBGaWxlU2l6ZVZhbGlkYXRvcixcclxuICAgICAgICBGaWxlc0xpbWl0VmFsaWRhdG9yLFxyXG4gICAgICAgIEZpbGVzQWNjZXB0VmFsaWRhdG9yXHJcbiAgICBdLFxyXG4gICAgZW50cnlDb21wb25lbnRzOiBbXHJcbiAgICAgICAgRmlsZVVwbG9hZENvbXBvbmVudFxyXG4gICAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgRmlsZVVwbG9hZE1vZHVsZSB7XHJcblxyXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBpbmplY3RvcjogSW5qZWN0b3IpIHtcclxuICAgICAgICAvLyBjb25zdCBmaWxlVXBsb2FkRWxlbWVudCA9IGNyZWF0ZUN1c3RvbUVsZW1lbnQoRmlsZVVwbG9hZENvbXBvbmVudCwgeyBpbmplY3RvciB9KTtcclxuICAgICAgICAvLyBjdXN0b21FbGVtZW50cy5kZWZpbmUoJ2ZpbGUtdXBsb2FkJywgZmlsZVVwbG9hZEVsZW1lbnQpO1xyXG4gICAgfVxyXG5cclxuICAgIG5nRG9Cb290c3RyYXAoKSB7fVxyXG59Il19
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/

@@ -14,5 +14,5 @@ import { BehaviorSubject, Subject } from 'rxjs';

export { STATUS };
STATUS[STATUS.INVALID] = "INVALID";
STATUS[STATUS.VALID] = "VALID";
STATUS[STATUS.DISABLED] = "DISABLED";
STATUS[STATUS.INVALID] = 'INVALID';
STATUS[STATUS.VALID] = 'VALID';
STATUS[STATUS.DISABLED] = 'DISABLED';
export class FileUploadControl {

@@ -48,9 +48,11 @@ /**

* set functions that determines the synchronous validity of this control.
* @template THIS
* @this {THIS}
* @param {?} newValidators
* @return {?}
* @return {THIS}
*/
setValidators(newValidators) {
this.defineValidators(newValidators);
this.validate();
return this;
(/** @type {?} */ (this)).defineValidators(newValidators);
(/** @type {?} */ (this)).validate();
return (/** @type {?} */ (this));
}

@@ -67,28 +69,34 @@ /**

/**
* @template THIS
* @this {THIS}
* @param {?} file
* @return {?}
* @return {THIS}
*/
addFile(file) {
this.files.add(file);
this.valueChanges.next(Array.from(this.files.values()));
this.validate();
return this;
(/** @type {?} */ (this)).files.add(file);
(/** @type {?} */ (this)).valueChanges.next(Array.from((/** @type {?} */ (this)).files.values()));
(/** @type {?} */ (this)).validate();
return (/** @type {?} */ (this));
}
/**
* @template THIS
* @this {THIS}
* @param {?} file
* @return {?}
* @return {THIS}
*/
removeFile(file) {
this.files.delete(file);
this.valueChanges.next(Array.from(this.files.values()));
this.validate();
return this;
(/** @type {?} */ (this)).files.delete(file);
(/** @type {?} */ (this)).valueChanges.next(Array.from((/** @type {?} */ (this)).files.values()));
(/** @type {?} */ (this)).validate();
return (/** @type {?} */ (this));
}
/**
* @template THIS
* @this {THIS}
* @param {?} files
* @return {?}
* @return {THIS}
*/
addFiles(files) {
this.addMultipleFiles(Array.from(files));
return this;
(/** @type {?} */ (this)).addMultipleFiles(Array.from(files));
return (/** @type {?} */ (this));
}

@@ -140,9 +148,11 @@ /**

/**
* @template THIS
* @this {THIS}
* @param {?} files
* @return {?}
* @return {THIS}
*/
setValue(files) {
this.files.clear();
(/** @type {?} */ (this)).files.clear();
if (files instanceof Array) {
this.addMultipleFiles(files);
(/** @type {?} */ (this)).addMultipleFiles(files);
}

@@ -152,12 +162,14 @@ else {

}
return this;
return (/** @type {?} */ (this));
}
/**
* reset the control
* @return {?}
* @template THIS
* @this {THIS}
* @return {THIS}
*/
clear() {
this.files.clear();
this.valueChanges.next(Array.from(this.files.values()));
return this;
(/** @type {?} */ (this)).files.clear();
(/** @type {?} */ (this)).valueChanges.next(Array.from((/** @type {?} */ (this)).files.values()));
return (/** @type {?} */ (this));
}

@@ -171,9 +183,11 @@ /**

/**
* @template THIS
* @this {THIS}
* @param {?=} isVisible
* @return {?}
* @return {THIS}
*/
setListVisibility(isVisible = true) {
this.listVisible = isVisible;
this.listVisibilityChanges.next(this.listVisible);
return this;
(/** @type {?} */ (this)).listVisible = isVisible;
(/** @type {?} */ (this)).listVisibilityChanges.next((/** @type {?} */ (this)).listVisible);
return (/** @type {?} */ (this));
}

@@ -187,20 +201,24 @@ /**

/**
* @template THIS
* @this {THIS}
* @param {?=} isEnabled
* @return {?}
* @return {THIS}
*/
enable(isEnabled = true) {
this.status = isEnabled ? STATUS.VALID : STATUS.DISABLED;
this.validate();
this.statusChanged.next(this.status);
return this;
(/** @type {?} */ (this)).status = isEnabled ? STATUS.VALID : STATUS.DISABLED;
(/** @type {?} */ (this)).validate();
(/** @type {?} */ (this)).statusChanged.next((/** @type {?} */ (this)).status);
return (/** @type {?} */ (this));
}
/**
* @template THIS
* @this {THIS}
* @param {?=} isDisabled
* @return {?}
* @return {THIS}
*/
disable(isDisabled = true) {
this.status = isDisabled ? STATUS.DISABLED : STATUS.VALID;
this.validate();
this.statusChanged.next(this.status);
return this;
(/** @type {?} */ (this)).status = isDisabled ? STATUS.DISABLED : STATUS.VALID;
(/** @type {?} */ (this)).validate();
(/** @type {?} */ (this)).statusChanged.next((/** @type {?} */ (this)).status);
return (/** @type {?} */ (this));
}

@@ -212,3 +230,4 @@ /**

if (this.status !== STATUS.DISABLED) {
const /** @type {?} */ currentState = this.valid;
/** @type {?} */
const currentState = this.valid;
this.errors = this.validators.map((validator) => validator(this)).filter((isInvalid) => isInvalid);

@@ -224,3 +243,3 @@ if (currentState !== this.valid) {

}
function FileUploadControl_tsickle_Closure_declarations() {
if (false) {
/** @type {?} */

@@ -257,3 +276,2 @@ FileUploadControl.prototype.files;

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"control.class.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["helpers/control.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { BehaviorSubject, Subject, Observable } from 'rxjs';\r\nimport { ValidatorFn, ValidationErrors } from './validators.class';\r\nimport { IsNullOrEmpty } from './helpers.class';\r\n\r\nexport enum STATUS {\r\n    INVALID,\r\n    VALID,\r\n    DISABLED\r\n}\r\n\r\nexport class FileUploadControl {\r\n\r\n    private files: Set<File> = new Set();\r\n\r\n    private listVisible = true;\r\n\r\n    private status: STATUS = STATUS.VALID;\r\n\r\n    private errors: Array<{[key: string]: any}> = [];\r\n\r\n    private validators: Array<ValidatorFn> = [];\r\n\r\n    private statusChanged: Subject<STATUS> = new Subject();\r\n\r\n    /**\r\n     * track status `VALID`, `INVALID` or `DISABLED`\r\n     */\r\n    public statusChanges: Observable<STATUS> = this.statusChanged.asObservable();\r\n\r\n    /**\r\n     * emit an event every time the value of the control\r\n     * changes.\r\n     * Initially returns last value\r\n     */\r\n    public readonly valueChanges: BehaviorSubject<Array<File>> = new BehaviorSubject([]);\r\n\r\n    /**\r\n     * @internal\r\n     * used to trigger layout change for list visibility\r\n     */\r\n    public readonly listVisibilityChanges: BehaviorSubject<boolean> = new BehaviorSubject(this.listVisible);\r\n\r\n    constructor(validators?: ValidatorFn|Array<ValidatorFn>) {\r\n        this.defineValidators(validators);\r\n    }\r\n\r\n    /**\r\n     * set functions that determines the synchronous validity of this control.\r\n     */\r\n    public setValidators(newValidators: ValidatorFn|Array<ValidatorFn>): this {\r\n        this.defineValidators(newValidators);\r\n        this.validate();\r\n        return this;\r\n    }\r\n\r\n    private defineValidators(validators: ValidatorFn|Array<ValidatorFn>): void {\r\n        if (!IsNullOrEmpty(validators)) {\r\n            this.validators = Array.isArray(validators) ? [...validators] : [validators];\r\n        }\r\n    }\r\n\r\n    public addFile(file: File): this {\r\n        this.files.add(file);\r\n        this.valueChanges.next(Array.from(this.files.values()));\r\n        this.validate();\r\n        return this;\r\n    }\r\n\r\n    public removeFile(file: File): this {\r\n        this.files.delete(file);\r\n        this.valueChanges.next(Array.from(this.files.values()));\r\n        this.validate();\r\n        return this;\r\n    }\r\n\r\n    public addFiles(files: FileList): this {\r\n        this.addMultipleFiles(Array.from(files));\r\n        return this;\r\n    }\r\n\r\n    /** \r\n     * @internal \r\n     * used to prevent valueChanges emit more times\r\n     * when multiple files are uploaded\r\n     */\r\n    private addMultipleFiles(files: Array<File>): void {\r\n        files.forEach(file => this.files.add(file));\r\n        this.valueChanges.next(Array.from(this.files.values()));\r\n        this.validate();\r\n    }\r\n\r\n    public get valid(): boolean {\r\n        return this.errors.length === 0 && this.status !== STATUS.DISABLED;\r\n    }\r\n\r\n    public get invalid(): boolean {\r\n        return this.errors.length > 0 || this.status === STATUS.DISABLED\r\n    }\r\n\r\n    public getError(): Array<ValidationErrors> {\r\n        return this.errors;\r\n    }\r\n\r\n    /**\r\n     * number of uploaded files\r\n     */\r\n    public get size(): number {\r\n        return this.files.size;\r\n    }\r\n\r\n    /**\r\n     * return list of Files\r\n     */\r\n    public get value(): Array<File> {\r\n        return Array.from(this.files.values());\r\n    }\r\n\r\n    public setValue(files: Array<File>): this {\r\n        this.files.clear();\r\n\r\n        if(files instanceof Array) {\r\n            this.addMultipleFiles(files);\r\n        } else {\r\n            throw Error(`FormControl.setValue was provided with wrong argument type, ${files} was provided instead Array<File>`);\r\n        }\r\n\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * reset the control\r\n     */\r\n    public clear(): this {\r\n        this.files.clear();\r\n        this.valueChanges.next(Array.from(this.files.values()));\r\n        return this;\r\n    }\r\n\r\n    public get isListVisible(): boolean {\r\n        return this.listVisible;\r\n    }\r\n\r\n    public setListVisibility(isVisible: boolean = true): this {\r\n        this.listVisible = isVisible;\r\n        this.listVisibilityChanges.next(this.listVisible);\r\n        return this;\r\n    }\r\n\r\n    public get disabled() {\r\n        return this.status === STATUS.DISABLED;\r\n    }\r\n\r\n    public enable(isEnabled: boolean = true): this {\r\n        this.status = isEnabled ? STATUS.VALID : STATUS.DISABLED;\r\n        this.validate();\r\n        this.statusChanged.next(this.status);\r\n        return this;\r\n    }\r\n\r\n    public disable(isDisabled: boolean = true): this {\r\n        this.status = isDisabled ? STATUS.DISABLED : STATUS.VALID;\r\n        this.validate();\r\n        this.statusChanged.next(this.status);\r\n        return this;\r\n    }\r\n\r\n    private validate(): void {\r\n        if (this.status !== STATUS.DISABLED) {\r\n            const currentState = this.valid;\r\n            this.errors = this.validators.map((validator) => validator(this)).filter((isInvalid) => isInvalid);\r\n\r\n            if (currentState !== this.valid) {\r\n                this.statusChanged.next(this.valid ? STATUS.VALID : STATUS.INVALID);\r\n            }\r\n        } else {\r\n            this.errors.length = 0;\r\n        }\r\n    }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"control.class.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["helpers/control.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { BehaviorSubject, Subject, Observable } from 'rxjs';\r\nimport { ValidatorFn, ValidationErrors } from './validators.class';\r\nimport { IsNullOrEmpty } from './helpers.class';\r\n\r\nexport enum STATUS {\r\n    INVALID,\r\n    VALID,\r\n    DISABLED\r\n}\r\n\r\nexport class FileUploadControl {\r\n\r\n    private files: Set<File> = new Set();\r\n\r\n    private listVisible = true;\r\n\r\n    private status: STATUS = STATUS.VALID;\r\n\r\n    private errors: Array<{[key: string]: any}> = [];\r\n\r\n    private validators: Array<ValidatorFn> = [];\r\n\r\n    private statusChanged: Subject<STATUS> = new Subject();\r\n\r\n    /**\r\n     * track status `VALID`, `INVALID` or `DISABLED`\r\n     */\r\n    public statusChanges: Observable<STATUS> = this.statusChanged.asObservable();\r\n\r\n    /**\r\n     * emit an event every time the value of the control\r\n     * changes.\r\n     * Initially returns last value\r\n     */\r\n    public readonly valueChanges: BehaviorSubject<Array<File>> = new BehaviorSubject([]);\r\n\r\n    /**\r\n     * @internal\r\n     * used to trigger layout change for list visibility\r\n     */\r\n    public readonly listVisibilityChanges: BehaviorSubject<boolean> = new BehaviorSubject(this.listVisible);\r\n\r\n    constructor(validators?: ValidatorFn|Array<ValidatorFn>) {\r\n        this.defineValidators(validators);\r\n    }\r\n\r\n    /**\r\n     * set functions that determines the synchronous validity of this control.\r\n     */\r\n    public setValidators(newValidators: ValidatorFn|Array<ValidatorFn>): this {\r\n        this.defineValidators(newValidators);\r\n        this.validate();\r\n        return this;\r\n    }\r\n\r\n    private defineValidators(validators: ValidatorFn|Array<ValidatorFn>): void {\r\n        if (!IsNullOrEmpty(validators)) {\r\n            this.validators = Array.isArray(validators) ? [...validators] : [validators];\r\n        }\r\n    }\r\n\r\n    public addFile(file: File): this {\r\n        this.files.add(file);\r\n        this.valueChanges.next(Array.from(this.files.values()));\r\n        this.validate();\r\n        return this;\r\n    }\r\n\r\n    public removeFile(file: File): this {\r\n        this.files.delete(file);\r\n        this.valueChanges.next(Array.from(this.files.values()));\r\n        this.validate();\r\n        return this;\r\n    }\r\n\r\n    public addFiles(files: FileList): this {\r\n        this.addMultipleFiles(Array.from(files));\r\n        return this;\r\n    }\r\n\r\n    /** \r\n     * @internal \r\n     * used to prevent valueChanges emit more times\r\n     * when multiple files are uploaded\r\n     */\r\n    private addMultipleFiles(files: Array<File>): void {\r\n        files.forEach(file => this.files.add(file));\r\n        this.valueChanges.next(Array.from(this.files.values()));\r\n        this.validate();\r\n    }\r\n\r\n    public get valid(): boolean {\r\n        return this.errors.length === 0 && this.status !== STATUS.DISABLED;\r\n    }\r\n\r\n    public get invalid(): boolean {\r\n        return this.errors.length > 0 || this.status === STATUS.DISABLED\r\n    }\r\n\r\n    public getError(): Array<ValidationErrors> {\r\n        return this.errors;\r\n    }\r\n\r\n    /**\r\n     * number of uploaded files\r\n     */\r\n    public get size(): number {\r\n        return this.files.size;\r\n    }\r\n\r\n    /**\r\n     * return list of Files\r\n     */\r\n    public get value(): Array<File> {\r\n        return Array.from(this.files.values());\r\n    }\r\n\r\n    public setValue(files: Array<File>): this {\r\n        this.files.clear();\r\n\r\n        if(files instanceof Array) {\r\n            this.addMultipleFiles(files);\r\n        } else {\r\n            throw Error(`FormControl.setValue was provided with wrong argument type, ${files} was provided instead Array<File>`);\r\n        }\r\n\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * reset the control\r\n     */\r\n    public clear(): this {\r\n        this.files.clear();\r\n        this.valueChanges.next(Array.from(this.files.values()));\r\n        return this;\r\n    }\r\n\r\n    public get isListVisible(): boolean {\r\n        return this.listVisible;\r\n    }\r\n\r\n    public setListVisibility(isVisible: boolean = true): this {\r\n        this.listVisible = isVisible;\r\n        this.listVisibilityChanges.next(this.listVisible);\r\n        return this;\r\n    }\r\n\r\n    public get disabled() {\r\n        return this.status === STATUS.DISABLED;\r\n    }\r\n\r\n    public enable(isEnabled: boolean = true): this {\r\n        this.status = isEnabled ? STATUS.VALID : STATUS.DISABLED;\r\n        this.validate();\r\n        this.statusChanged.next(this.status);\r\n        return this;\r\n    }\r\n\r\n    public disable(isDisabled: boolean = true): this {\r\n        this.status = isDisabled ? STATUS.DISABLED : STATUS.VALID;\r\n        this.validate();\r\n        this.statusChanged.next(this.status);\r\n        return this;\r\n    }\r\n\r\n    private validate(): void {\r\n        if (this.status !== STATUS.DISABLED) {\r\n            const currentState = this.valid;\r\n            this.errors = this.validators.map((validator) => validator(this)).filter((isInvalid) => isInvalid);\r\n\r\n            if (currentState !== this.valid) {\r\n                this.statusChanged.next(this.valid ? STATUS.VALID : STATUS.INVALID);\r\n            }\r\n        } else {\r\n            this.errors.length = 0;\r\n        }\r\n    }\r\n}\r\n"]}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/

@@ -21,15 +21,15 @@ /** @enum {number} */

};
FileAccess[FileAccess.None] = "None";
FileAccess[FileAccess.Read] = "Read";
FileAccess[FileAccess.Write] = "Write";
FileAccess[FileAccess.ReadWrite] = "ReadWrite";
FileAccess[FileAccess.Execute] = "Execute";
FileAccess[FileAccess.ReadWriteExecute] = "ReadWriteExecute";
FileAccess[FileAccess.ExecuteRead] = "ExecuteRead";
FileAccess[FileAccess.r] = "r";
FileAccess[FileAccess.w] = "w";
FileAccess[FileAccess.x] = "x";
FileAccess[FileAccess.rw] = "rw";
FileAccess[FileAccess.rwx] = "rwx";
FileAccess[FileAccess.xr] = "xr";
FileAccess[FileAccess.None] = 'None';
FileAccess[FileAccess.Read] = 'Read';
FileAccess[FileAccess.Write] = 'Write';
FileAccess[FileAccess.ReadWrite] = 'ReadWrite';
FileAccess[FileAccess.Execute] = 'Execute';
FileAccess[FileAccess.ReadWriteExecute] = 'ReadWriteExecute';
FileAccess[FileAccess.ExecuteRead] = 'ExecuteRead';
FileAccess[FileAccess.r] = 'r';
FileAccess[FileAccess.w] = 'w';
FileAccess[FileAccess.x] = 'x';
FileAccess[FileAccess.rw] = 'rw';
FileAccess[FileAccess.rwx] = 'rwx';
FileAccess[FileAccess.xr] = 'xr';
/** @enum {string} */

@@ -98,8 +98,7 @@ const FileUploadTypes = {

zip: 'application/zip',
"3gp": 'video/3gpp',
"3g2": 'video/3gpp2',
"7z": 'application/x-7z-compressed',
'3gp': 'video/3gpp',
'3g2': 'video/3gpp2',
'7z': 'application/x-7z-compressed',
};
export { FileUploadTypes };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS10eXBlcy5jbGFzcy5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BpcGxhYi9uZ3gtZmlsZS11cGxvYWQvIiwic291cmNlcyI6WyJoZWxwZXJzL2ZpbGUtdHlwZXMuY2xhc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7U0F3QlUsV0FBVztTQUNYLHVCQUF1QjtTQUN2QiwwQkFBMEI7U0FDMUIsaUJBQWlCO1NBQ2pCLDhCQUE4QjtTQUM5QiwwQkFBMEI7U0FDMUIsV0FBVztRQUNaLG9CQUFvQjtTQUNuQixxQkFBcUI7U0FDckIsbUJBQW1CO1NBQ25CLFVBQVU7U0FDVixVQUFVO1NBQ1Ysb0JBQW9CO1VBQ25CLHlFQUF5RTtTQUMxRSwrQkFBK0I7VUFDOUIsc0JBQXNCO1FBQ3hCLHdCQUF3QjtTQUN2QixXQUFXO1VBQ1YsV0FBVztTQUNaLGNBQWM7U0FDZCxlQUFlO1NBQ2YsMEJBQTBCO1NBQzFCLFlBQVk7UUFDYix3QkFBd0I7VUFDdEIsa0JBQWtCO1VBQ2xCLFlBQVk7VUFDWixZQUFZO1VBQ1oscUNBQXFDO1NBQ3RDLGlEQUFpRDtTQUNqRCxnREFBZ0Q7U0FDaEQseUNBQXlDO1NBQ3pDLFdBQVc7U0FDWCxXQUFXO1NBQ1gsaUJBQWlCO1NBQ2pCLFVBQVU7U0FDVixXQUFXO1NBQ1gsaUJBQWlCO1NBQ2pCLCtCQUErQjtVQUM5QiwyRUFBMkU7U0FDNUUsMkVBQTJFO1NBQzNFLGlCQUFpQjtRQUNsQixrQkFBa0I7U0FDakIsZUFBZTtTQUNmLCtCQUErQjtTQUMvQixtQkFBbUI7VUFDbEIsWUFBWTtRQUNkLHdCQUF3QjtTQUN2QixVQUFVO1NBQ1YsdUJBQXVCO1NBQ3ZCLFdBQVc7VUFDVixZQUFZO1VBQ1osWUFBWTtVQUNaLFlBQVk7VUFDWixXQUFXO1dBQ1YsWUFBWTtXQUNaLHVCQUF1QjtTQUN6QiwwQkFBMEI7VUFDekIsbUVBQW1FO1NBQ3BFLGlCQUFpQjtTQUNqQixpQ0FBaUM7U0FDakMsaUJBQWlCO1dBQ2YsWUFBWTtXQUNaLGFBQWE7VUFDZCw2QkFBNkIiLCJzb3VyY2VzQ29udGVudCI6WyJcclxuLy8gLW93bmVyLWdyb3VwLW90aGVycy1cclxuLy8gLXJ3eHJ3eHJ3eCA9IDA3NzdcclxuZW51bSBGaWxlQWNjZXNzIHtcclxuICAgIE5vbmUsXHJcbiAgICBSZWFkID0gMSA8PCAyLFxyXG4gICAgV3JpdGUgPSAxIDw8IDEsXHJcbiAgICBSZWFkV3JpdGUgID0gUmVhZCB8IFdyaXRlLFxyXG4gICAgRXhlY3V0ZSA9IDEgPDwgMCxcclxuICAgIFJlYWRXcml0ZUV4ZWN1dGUgPSBSZWFkV3JpdGUgfCBFeGVjdXRlLFxyXG4gICAgRXhlY3V0ZVJlYWQgPSBFeGVjdXRlIHwgUmVhZCxcclxuICAgIHIgPSBSZWFkLFxyXG4gICAgdyA9IFdyaXRlLFxyXG4gICAgeCA9IEV4ZWN1dGUsXHJcbiAgICBydyA9IFJlYWRXcml0ZSxcclxuICAgIHJ3eCA9IFJlYWRXcml0ZUV4ZWN1dGUsXHJcbiAgICB4ciA9IEV4ZWN1dGVSZWFkXHJcbn1cclxuXHJcbi8qKlxyXG4gKiBUaGlzIHRhYmxlIGxpc3RzIHNvbWUgaW1wb3J0YW50IE1JTUUgdHlwZXMgZm9yIHRoZSBXZWIgY29waWVkIGZyb21cclxuICogaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvSFRUUC9CYXNpY3Nfb2ZfSFRUUC9NSU1FX3R5cGVzL0NvbXBsZXRlX2xpc3Rfb2ZfTUlNRV90eXBlc1xyXG4gKi9cclxuZXhwb3J0IGVudW0gRmlsZVVwbG9hZFR5cGVzIHtcclxuICAgIGFhYyA9ICdhdWRpby9hYWMnLFxyXG4gICAgYWJ3ID0gJ2FwcGxpY2F0aW9uL3gtYWJpd29yZCcsXHJcbiAgICBhcmMgPSAnYXBwbGljYXRpb24vb2N0ZXQtc3RyZWFtJyxcclxuICAgIGF2aSA9ICd2aWRlby94LW1zdmlkZW8nLFxyXG4gICAgYXp3ID0gJ2FwcGxpY2F0aW9uL3ZuZC5hbWF6b24uZWJvb2snLFxyXG4gICAgYmluID0gJ2FwcGxpY2F0aW9uL29jdGV0LXN0cmVhbScsXHJcbiAgICBibXAgPSAnaW1hZ2UvYm1wJyxcclxuICAgIGJ6ID0gJ2FwcGxpY2F0aW9uL3gtYnppcCcsXHJcbiAgICBiejIgPSAnYXBwbGljYXRpb24veC1iemlwMicsXHJcbiAgICBjc2ggPSAnYXBwbGljYXRpb24veC1jc2gnLFxyXG4gICAgY3NzID0gJ3RleHQvY3NzJyxcclxuICAgIGNzdiA9ICd0ZXh0L2NzdicsXHJcbiAgICBkb2MgPSAnYXBwbGljYXRpb24vbXN3b3JkJyxcclxuICAgIGRvY3ggPSAnYXBwbGljYXRpb24vdm5kLm9wZW54bWxmb3JtYXRzLW9mZmljZWRvY3VtZW50LndvcmRwcm9jZXNzaW5nbWwuZG9jdW1lbnQnLFxyXG4gICAgZW90ID0gJ2FwcGxpY2F0aW9uL3ZuZC5tcy1mb250b2JqZWN0JyxcclxuICAgIGVwdWIgPSAnYXBwbGljYXRpb24vZXB1Yit6aXAnLFxyXG4gICAgZXMgPSAnYXBwbGljYXRpb24vZWNtYXNjcmlwdCcsXHJcbiAgICBnaWYgPSAnaW1hZ2UvZ2lmJyxcclxuICAgIGh0bWwgPSAndGV4dC9odG1sJyxcclxuICAgIGljbyA9ICdpbWFnZS94LWljb24nLFxyXG4gICAgaWNzID0gJ3RleHQvY2FsZW5kYXInLFxyXG4gICAgamFyID0gJ2FwcGxpY2F0aW9uL2phdmEtYXJjaGl2ZScsXHJcbiAgICBqcGcgPSAnaW1hZ2UvanBlZycsXHJcbiAgICBqcyA9ICdhcHBsaWNhdGlvbi9qYXZhc2NyaXB0JyxcclxuICAgIGpzb24gPSAnYXBwbGljYXRpb24vanNvbicsXHJcbiAgICBtaWRpID0gJ2F1ZGlvL21pZGknLFxyXG4gICAgbXBlZyA9ICd2aWRlby9tcGVnJyxcclxuICAgIG1wa2cgPSAnYXBwbGljYXRpb24vdm5kLmFwcGxlLmluc3RhbGxlcit4bWwnLFxyXG4gICAgb2RwID0gJ2FwcGxpY2F0aW9uL3ZuZC5vYXNpcy5vcGVuZG9jdW1lbnQucHJlc2VudGF0aW9uJyxcclxuICAgIG9kcyA9ICdhcHBsaWNhdGlvbi92bmQub2FzaXMub3BlbmRvY3VtZW50LnNwcmVhZHNoZWV0JyxcclxuICAgIG9kdCA9ICdhcHBsaWNhdGlvbi92bmQub2FzaXMub3BlbmRvY3VtZW50LnRleHQnLFxyXG4gICAgb2dhID0gJ2F1ZGlvL29nZycsXHJcbiAgICBvZ3YgPSAndmlkZW8vb2dnJyxcclxuICAgIG9neCA9ICdhcHBsaWNhdGlvbi9vZ2cnLFxyXG4gICAgb3RmID0gJ2ZvbnQvb3RmJyxcclxuICAgIHBuZyA9ICdpbWFnZS9wbmcnLFxyXG4gICAgcGRmID0gJ2FwcGxpY2F0aW9uL3BkZicsXHJcbiAgICBwcHQgPSAnYXBwbGljYXRpb24vdm5kLm1zLXBvd2VycG9pbnQnLFxyXG4gICAgcHB0eCA9ICdhcHBsaWNhdGlvbi92bmQub3BlbnhtbGZvcm1hdHMtb2ZmaWNlZG9jdW1lbnQucHJlc2VudGF0aW9ubWwucHJlc2VudGF0aW9uJyxcclxuICAgIHJhciA9ICdhcHBsaWNhdGlvbi92bmQub3BlbnhtbGZvcm1hdHMtb2ZmaWNlZG9jdW1lbnQucHJlc2VudGF0aW9ubWwucHJlc2VudGF0aW9uJyxcclxuICAgIHJ0ZiA9ICdhcHBsaWNhdGlvbi9ydGYnLFxyXG4gICAgc2ggPSAnYXBwbGljYXRpb24veC1zaCcsXHJcbiAgICBzdmcgPSAnaW1hZ2Uvc3ZnK3htbCcsXHJcbiAgICBzd2YgPSAnYXBwbGljYXRpb24veC1zaG9ja3dhdmUtZmxhc2gnLFxyXG4gICAgdGFyID0gJ2FwcGxpY2F0aW9uL3gtdGFyJyxcclxuICAgIHRpZmYgPSAnaW1hZ2UvdGlmZicsXHJcbiAgICB0cyA9ICdhcHBsaWNhdGlvbi90eXBlc2NyaXB0JyxcclxuICAgIHR0ZiA9ICdmb250L3R0ZicsXHJcbiAgICB2c2QgPSAnYXBwbGljYXRpb24vdm5kLnZpc2lvJyxcclxuICAgIHdhdiA9ICdhdWRpby93YXYnLFxyXG4gICAgd2ViYSA9ICdhdWRpby93ZWJtJyxcclxuICAgIHdlYm0gPSAndmlkZW8vd2VibScsXHJcbiAgICB3ZWJwID0gJ2ltYWdlL3dlYnAnLFxyXG4gICAgd29mZiA9ICdmb250L3dvZmYnLFxyXG4gICAgd29mZjIgPSAnZm9udC93b2ZmMicsXHJcbiAgICB4aHRtbCA9ICdhcHBsaWNhdGlvbi94aHRtbCt4bWwnLFxyXG4gICAgeGxzID0gJ2FwcGxpY2F0aW9uL3ZuZC5tcy1leGNlbCcsXHJcbiAgICB4bHN4ID0gJ2FwcGxpY2F0aW9uL3ZuZC5vcGVueG1sZm9ybWF0cy1vZmZpY2Vkb2N1bWVudC5zcHJlYWRzaGVldG1sLnNoZWV0JyxcclxuICAgIHhtbCA9ICdhcHBsaWNhdGlvbi94bWwnLFxyXG4gICAgeHVsID0gJ2FwcGxpY2F0aW9uL3ZuZC5tb3ppbGxhLnh1bCt4bWwnLFxyXG4gICAgemlwID0gJ2FwcGxpY2F0aW9uL3ppcCcsXHJcbiAgICAnM2dwJyA9ICd2aWRlby8zZ3BwJyxcclxuICAgICczZzInID0gJ3ZpZGVvLzNncHAyJyxcclxuICAgICc3eicgPSAnYXBwbGljYXRpb24veC03ei1jb21wcmVzc2VkJ1xyXG59XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS10eXBlcy5jbGFzcy5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BpcGxhYi9uZ3gtZmlsZS11cGxvYWQvIiwic291cmNlcyI6WyJoZWxwZXJzL2ZpbGUtdHlwZXMuY2xhc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0lBSUksT0FBSTtJQUNKLE9BQWE7SUFDYixRQUFjO0lBQ2QsWUFBeUI7SUFDekIsVUFBZ0I7SUFDaEIsbUJBQXNDO0lBQ3RDLGNBQTRCO0lBQzVCLElBQVE7SUFDUixJQUFTO0lBQ1QsSUFBVztJQUNYLEtBQWM7SUFDZCxNQUFzQjtJQUN0QixLQUFnQjs7Ozs7Ozs7Ozs7Ozs7Ozs7SUFRaEIsS0FBTSxXQUFXO0lBQ2pCLEtBQU0sdUJBQXVCO0lBQzdCLEtBQU0sMEJBQTBCO0lBQ2hDLEtBQU0saUJBQWlCO0lBQ3ZCLEtBQU0sOEJBQThCO0lBQ3BDLEtBQU0sMEJBQTBCO0lBQ2hDLEtBQU0sV0FBVztJQUNqQixJQUFLLG9CQUFvQjtJQUN6QixLQUFNLHFCQUFxQjtJQUMzQixLQUFNLG1CQUFtQjtJQUN6QixLQUFNLFVBQVU7SUFDaEIsS0FBTSxVQUFVO0lBQ2hCLEtBQU0sb0JBQW9CO0lBQzFCLE1BQU8seUVBQXlFO0lBQ2hGLEtBQU0sK0JBQStCO0lBQ3JDLE1BQU8sc0JBQXNCO0lBQzdCLElBQUssd0JBQXdCO0lBQzdCLEtBQU0sV0FBVztJQUNqQixNQUFPLFdBQVc7SUFDbEIsS0FBTSxjQUFjO0lBQ3BCLEtBQU0sZUFBZTtJQUNyQixLQUFNLDBCQUEwQjtJQUNoQyxLQUFNLFlBQVk7SUFDbEIsSUFBSyx3QkFBd0I7SUFDN0IsTUFBTyxrQkFBa0I7SUFDekIsTUFBTyxZQUFZO0lBQ25CLE1BQU8sWUFBWTtJQUNuQixNQUFPLHFDQUFxQztJQUM1QyxLQUFNLGlEQUFpRDtJQUN2RCxLQUFNLGdEQUFnRDtJQUN0RCxLQUFNLHlDQUF5QztJQUMvQyxLQUFNLFdBQVc7SUFDakIsS0FBTSxXQUFXO0lBQ2pCLEtBQU0saUJBQWlCO0lBQ3ZCLEtBQU0sVUFBVTtJQUNoQixLQUFNLFdBQVc7SUFDakIsS0FBTSxpQkFBaUI7SUFDdkIsS0FBTSwrQkFBK0I7SUFDckMsTUFBTywyRUFBMkU7SUFDbEYsS0FBTSwyRUFBMkU7SUFDakYsS0FBTSxpQkFBaUI7SUFDdkIsSUFBSyxrQkFBa0I7SUFDdkIsS0FBTSxlQUFlO0lBQ3JCLEtBQU0sK0JBQStCO0lBQ3JDLEtBQU0sbUJBQW1CO0lBQ3pCLE1BQU8sWUFBWTtJQUNuQixJQUFLLHdCQUF3QjtJQUM3QixLQUFNLFVBQVU7SUFDaEIsS0FBTSx1QkFBdUI7SUFDN0IsS0FBTSxXQUFXO0lBQ2pCLE1BQU8sWUFBWTtJQUNuQixNQUFPLFlBQVk7SUFDbkIsTUFBTyxZQUFZO0lBQ25CLE1BQU8sV0FBVztJQUNsQixPQUFRLFlBQVk7SUFDcEIsT0FBUSx1QkFBdUI7SUFDL0IsS0FBTSwwQkFBMEI7SUFDaEMsTUFBTyxtRUFBbUU7SUFDMUUsS0FBTSxpQkFBaUI7SUFDdkIsS0FBTSxpQ0FBaUM7SUFDdkMsS0FBTSxpQkFBaUI7SUFDdkIsT0FBUSxZQUFZO0lBQ3BCLE9BQVEsYUFBYTtJQUNyQixNQUFPLDZCQUE2QiIsInNvdXJjZXNDb250ZW50IjpbIlxyXG4vLyAtb3duZXItZ3JvdXAtb3RoZXJzLVxyXG4vLyAtcnd4cnd4cnd4ID0gMDc3N1xyXG5lbnVtIEZpbGVBY2Nlc3Mge1xyXG4gICAgTm9uZSxcclxuICAgIFJlYWQgPSAxIDw8IDIsXHJcbiAgICBXcml0ZSA9IDEgPDwgMSxcclxuICAgIFJlYWRXcml0ZSAgPSBSZWFkIHwgV3JpdGUsXHJcbiAgICBFeGVjdXRlID0gMSA8PCAwLFxyXG4gICAgUmVhZFdyaXRlRXhlY3V0ZSA9IFJlYWRXcml0ZSB8IEV4ZWN1dGUsXHJcbiAgICBFeGVjdXRlUmVhZCA9IEV4ZWN1dGUgfCBSZWFkLFxyXG4gICAgciA9IFJlYWQsXHJcbiAgICB3ID0gV3JpdGUsXHJcbiAgICB4ID0gRXhlY3V0ZSxcclxuICAgIHJ3ID0gUmVhZFdyaXRlLFxyXG4gICAgcnd4ID0gUmVhZFdyaXRlRXhlY3V0ZSxcclxuICAgIHhyID0gRXhlY3V0ZVJlYWRcclxufVxyXG5cclxuLyoqXHJcbiAqIFRoaXMgdGFibGUgbGlzdHMgc29tZSBpbXBvcnRhbnQgTUlNRSB0eXBlcyBmb3IgdGhlIFdlYiBjb3BpZWQgZnJvbVxyXG4gKiBodHRwczovL2RldmVsb3Blci5tb3ppbGxhLm9yZy9lbi1VUy9kb2NzL1dlYi9IVFRQL0Jhc2ljc19vZl9IVFRQL01JTUVfdHlwZXMvQ29tcGxldGVfbGlzdF9vZl9NSU1FX3R5cGVzXHJcbiAqL1xyXG5leHBvcnQgZW51bSBGaWxlVXBsb2FkVHlwZXMge1xyXG4gICAgYWFjID0gJ2F1ZGlvL2FhYycsXHJcbiAgICBhYncgPSAnYXBwbGljYXRpb24veC1hYml3b3JkJyxcclxuICAgIGFyYyA9ICdhcHBsaWNhdGlvbi9vY3RldC1zdHJlYW0nLFxyXG4gICAgYXZpID0gJ3ZpZGVvL3gtbXN2aWRlbycsXHJcbiAgICBhencgPSAnYXBwbGljYXRpb24vdm5kLmFtYXpvbi5lYm9vaycsXHJcbiAgICBiaW4gPSAnYXBwbGljYXRpb24vb2N0ZXQtc3RyZWFtJyxcclxuICAgIGJtcCA9ICdpbWFnZS9ibXAnLFxyXG4gICAgYnogPSAnYXBwbGljYXRpb24veC1iemlwJyxcclxuICAgIGJ6MiA9ICdhcHBsaWNhdGlvbi94LWJ6aXAyJyxcclxuICAgIGNzaCA9ICdhcHBsaWNhdGlvbi94LWNzaCcsXHJcbiAgICBjc3MgPSAndGV4dC9jc3MnLFxyXG4gICAgY3N2ID0gJ3RleHQvY3N2JyxcclxuICAgIGRvYyA9ICdhcHBsaWNhdGlvbi9tc3dvcmQnLFxyXG4gICAgZG9jeCA9ICdhcHBsaWNhdGlvbi92bmQub3BlbnhtbGZvcm1hdHMtb2ZmaWNlZG9jdW1lbnQud29yZHByb2Nlc3NpbmdtbC5kb2N1bWVudCcsXHJcbiAgICBlb3QgPSAnYXBwbGljYXRpb24vdm5kLm1zLWZvbnRvYmplY3QnLFxyXG4gICAgZXB1YiA9ICdhcHBsaWNhdGlvbi9lcHViK3ppcCcsXHJcbiAgICBlcyA9ICdhcHBsaWNhdGlvbi9lY21hc2NyaXB0JyxcclxuICAgIGdpZiA9ICdpbWFnZS9naWYnLFxyXG4gICAgaHRtbCA9ICd0ZXh0L2h0bWwnLFxyXG4gICAgaWNvID0gJ2ltYWdlL3gtaWNvbicsXHJcbiAgICBpY3MgPSAndGV4dC9jYWxlbmRhcicsXHJcbiAgICBqYXIgPSAnYXBwbGljYXRpb24vamF2YS1hcmNoaXZlJyxcclxuICAgIGpwZyA9ICdpbWFnZS9qcGVnJyxcclxuICAgIGpzID0gJ2FwcGxpY2F0aW9uL2phdmFzY3JpcHQnLFxyXG4gICAganNvbiA9ICdhcHBsaWNhdGlvbi9qc29uJyxcclxuICAgIG1pZGkgPSAnYXVkaW8vbWlkaScsXHJcbiAgICBtcGVnID0gJ3ZpZGVvL21wZWcnLFxyXG4gICAgbXBrZyA9ICdhcHBsaWNhdGlvbi92bmQuYXBwbGUuaW5zdGFsbGVyK3htbCcsXHJcbiAgICBvZHAgPSAnYXBwbGljYXRpb24vdm5kLm9hc2lzLm9wZW5kb2N1bWVudC5wcmVzZW50YXRpb24nLFxyXG4gICAgb2RzID0gJ2FwcGxpY2F0aW9uL3ZuZC5vYXNpcy5vcGVuZG9jdW1lbnQuc3ByZWFkc2hlZXQnLFxyXG4gICAgb2R0ID0gJ2FwcGxpY2F0aW9uL3ZuZC5vYXNpcy5vcGVuZG9jdW1lbnQudGV4dCcsXHJcbiAgICBvZ2EgPSAnYXVkaW8vb2dnJyxcclxuICAgIG9ndiA9ICd2aWRlby9vZ2cnLFxyXG4gICAgb2d4ID0gJ2FwcGxpY2F0aW9uL29nZycsXHJcbiAgICBvdGYgPSAnZm9udC9vdGYnLFxyXG4gICAgcG5nID0gJ2ltYWdlL3BuZycsXHJcbiAgICBwZGYgPSAnYXBwbGljYXRpb24vcGRmJyxcclxuICAgIHBwdCA9ICdhcHBsaWNhdGlvbi92bmQubXMtcG93ZXJwb2ludCcsXHJcbiAgICBwcHR4ID0gJ2FwcGxpY2F0aW9uL3ZuZC5vcGVueG1sZm9ybWF0cy1vZmZpY2Vkb2N1bWVudC5wcmVzZW50YXRpb25tbC5wcmVzZW50YXRpb24nLFxyXG4gICAgcmFyID0gJ2FwcGxpY2F0aW9uL3ZuZC5vcGVueG1sZm9ybWF0cy1vZmZpY2Vkb2N1bWVudC5wcmVzZW50YXRpb25tbC5wcmVzZW50YXRpb24nLFxyXG4gICAgcnRmID0gJ2FwcGxpY2F0aW9uL3J0ZicsXHJcbiAgICBzaCA9ICdhcHBsaWNhdGlvbi94LXNoJyxcclxuICAgIHN2ZyA9ICdpbWFnZS9zdmcreG1sJyxcclxuICAgIHN3ZiA9ICdhcHBsaWNhdGlvbi94LXNob2Nrd2F2ZS1mbGFzaCcsXHJcbiAgICB0YXIgPSAnYXBwbGljYXRpb24veC10YXInLFxyXG4gICAgdGlmZiA9ICdpbWFnZS90aWZmJyxcclxuICAgIHRzID0gJ2FwcGxpY2F0aW9uL3R5cGVzY3JpcHQnLFxyXG4gICAgdHRmID0gJ2ZvbnQvdHRmJyxcclxuICAgIHZzZCA9ICdhcHBsaWNhdGlvbi92bmQudmlzaW8nLFxyXG4gICAgd2F2ID0gJ2F1ZGlvL3dhdicsXHJcbiAgICB3ZWJhID0gJ2F1ZGlvL3dlYm0nLFxyXG4gICAgd2VibSA9ICd2aWRlby93ZWJtJyxcclxuICAgIHdlYnAgPSAnaW1hZ2Uvd2VicCcsXHJcbiAgICB3b2ZmID0gJ2ZvbnQvd29mZicsXHJcbiAgICB3b2ZmMiA9ICdmb250L3dvZmYyJyxcclxuICAgIHhodG1sID0gJ2FwcGxpY2F0aW9uL3hodG1sK3htbCcsXHJcbiAgICB4bHMgPSAnYXBwbGljYXRpb24vdm5kLm1zLWV4Y2VsJyxcclxuICAgIHhsc3ggPSAnYXBwbGljYXRpb24vdm5kLm9wZW54bWxmb3JtYXRzLW9mZmljZWRvY3VtZW50LnNwcmVhZHNoZWV0bWwuc2hlZXQnLFxyXG4gICAgeG1sID0gJ2FwcGxpY2F0aW9uL3htbCcsXHJcbiAgICB4dWwgPSAnYXBwbGljYXRpb24vdm5kLm1vemlsbGEueHVsK3htbCcsXHJcbiAgICB6aXAgPSAnYXBwbGljYXRpb24vemlwJyxcclxuICAgICczZ3AnID0gJ3ZpZGVvLzNncHAnLFxyXG4gICAgJzNnMicgPSAndmlkZW8vM2dwcDInLFxyXG4gICAgJzd6JyA9ICdhcHBsaWNhdGlvbi94LTd6LWNvbXByZXNzZWQnXHJcbn1cclxuIl19
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/

@@ -12,3 +12,2 @@ /**

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscGVycy5jbGFzcy5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BpcGxhYi9uZ3gtZmlsZS11cGxvYWQvIiwic291cmNlcyI6WyJoZWxwZXJzL2hlbHBlcnMuY2xhc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFBQSxNQUFNLHdCQUF3QixLQUFVO0lBQ3BDLE1BQU0sQ0FBQyxLQUFLLElBQUksSUFBSSxJQUFJLEtBQUssQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFDO0NBQzlDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGZ1bmN0aW9uIElzTnVsbE9yRW1wdHkodmFsdWU6IGFueSk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIHZhbHVlID09IG51bGwgfHwgdmFsdWUubGVuZ3RoID09PSAwO1xyXG59Il19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscGVycy5jbGFzcy5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BpcGxhYi9uZ3gtZmlsZS11cGxvYWQvIiwic291cmNlcyI6WyJoZWxwZXJzL2hlbHBlcnMuY2xhc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFBQSxNQUFNLFVBQVUsYUFBYSxDQUFDLEtBQVU7SUFDcEMsT0FBTyxLQUFLLElBQUksSUFBSSxJQUFJLEtBQUssQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFDO0FBQy9DLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZnVuY3Rpb24gSXNOdWxsT3JFbXB0eSh2YWx1ZTogYW55KTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdmFsdWUgPT0gbnVsbCB8fCB2YWx1ZS5sZW5ndGggPT09IDA7XHJcbn0iXX0=
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/

@@ -10,7 +10,2 @@ import { IsNullOrEmpty } from './helpers.class';

export function ValidationErrors() { }
function ValidationErrors_tsickle_Closure_declarations() {
/* TODO: handle strange member:
[key: string]: any;
*/
}
/**

@@ -20,11 +15,7 @@ * @record

export function ValidatorFn() { }
function ValidatorFn_tsickle_Closure_declarations() {
/* TODO: handle strange member:
(c: AbstractControl | FileUploadControl): ValidationErrors | null;
*/
}
/**
* function used to check file size
* @type {?}
*/
const /** @type {?} */ checkFileSize = (file, maxSize, minSize = 0) => {
const checkFileSize = (file, maxSize, minSize = 0) => {
return (!IsNullOrEmpty(maxSize) && file.size > maxSize) || file.size < minSize ?

@@ -34,3 +25,4 @@ { maxSize, minSize, actual: file.size, file } : null;

const ɵ0 = checkFileSize;
const /** @type {?} */ FILE_EXT_REG = /(^[.]\w*)$/gm;
/** @type {?} */
const FILE_EXT_REG = /(^[.]\w*)$/gm;
/**

@@ -41,8 +33,12 @@ * function used to check file type

* file_extension|audio/*|video/*|image/*|media_type
* @type {?}
*/
const /** @type {?} */ checkFileType = (file, allowedTypes) => {
const /** @type {?} */ fileExtension = file.name.slice((file.name.lastIndexOf(".") - 1 >>> 0) + 1);
let /** @type {?} */ isValid = false;
for (let /** @type {?} */ i = 0; i < allowedTypes.length; i++) {
let /** @type {?} */ type = allowedTypes[i];
const checkFileType = (file, allowedTypes) => {
/** @type {?} */
const fileExtension = file.name.slice((file.name.lastIndexOf(".") - 1 >>> 0) + 1);
/** @type {?} */
let isValid = false;
for (let i = 0; i < allowedTypes.length; i++) {
/** @type {?} */
let type = allowedTypes[i];
isValid = FILE_EXT_REG.test(type) ? type === fileExtension : new RegExp(type).test(file.type);

@@ -57,8 +53,12 @@ if (isValid) {

const ɵ1 = checkFileType;
const /** @type {?} */ checkValueType = (value) => {
/** @type {?} */
const checkValueType = (value) => {
if (!Array.isArray(value)) {
throw Error(`FormControl.setValue was provided with wrong argument type, ${value} was provided instead Array<File>`);
}
};
}
// @dynamic
;
const ɵ2 = checkValueType;
// @dynamic
export class FileUploadValidators {

@@ -74,3 +74,4 @@ /**

return (control) => {
const /** @type {?} */ files = control.value;
/** @type {?} */
const files = control.value;
if (IsNullOrEmpty(files)) {

@@ -80,3 +81,4 @@ return null;

checkValueType(files);
const /** @type {?} */ toLargeFiles = files.map((file) => checkFileSize(file, maxSize))
/** @type {?} */
const toLargeFiles = files.map((file) => checkFileSize(file, maxSize))
.filter((error) => error);

@@ -95,3 +97,4 @@ return toLargeFiles.length > 0 ?

return (control) => {
const /** @type {?} */ files = control.value;
/** @type {?} */
const files = control.value;
if (IsNullOrEmpty(files)) {

@@ -101,3 +104,4 @@ return null;

checkValueType(files);
const /** @type {?} */ sizeMismatch = files.map((file) => checkFileSize(file, maxSize, minSize))
/** @type {?} */
const sizeMismatch = files.map((file) => checkFileSize(file, maxSize, minSize))
.filter((error) => error);

@@ -116,3 +120,4 @@ return sizeMismatch.length > 0 ?

return (control) => {
const /** @type {?} */ files = control.value;
/** @type {?} */
const files = control.value;
if (IsNullOrEmpty(files)) {

@@ -146,3 +151,4 @@ return null;

return (control) => {
const /** @type {?} */ files = control.value;
/** @type {?} */
const files = control.value;
if (IsNullOrEmpty(files)) {

@@ -152,3 +158,4 @@ return null;

checkValueType(files);
const /** @type {?} */ notAllowedFiles = files.map((file) => checkFileType(file, allowedFileTypes))
/** @type {?} */
const notAllowedFiles = files.map((file) => checkFileType(file, allowedFileTypes))
.filter((error) => error);

@@ -161,3 +168,2 @@ return notAllowedFiles.length > 0 ?

export { ɵ0, ɵ1, ɵ2 };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validators.class.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["helpers/validators.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl } from '@angular/forms';\r\nimport { IsNullOrEmpty } from './helpers.class';\r\nimport { FileUploadControl } from './control.class';\r\n\r\nexport interface ValidationErrors {\r\n    [key: string]: any;\r\n}\r\n\r\nexport interface ValidatorFn {\r\n    (c: AbstractControl | FileUploadControl): ValidationErrors | null;\r\n}\r\n\r\n/**\r\n * function used to check file size\r\n */\r\nconst checkFileSize = (file: File, maxSize: number, minSize: number = 0): ValidationErrors | null => {\r\n    return (!IsNullOrEmpty(maxSize) && file.size > maxSize) || file.size < minSize ?\r\n        {maxSize, minSize, actual: file.size, file} : null;\r\n}\r\n\r\nconst FILE_EXT_REG = /(^[.]\\w*)$/gm;\r\n/**\r\n * function used to check file type\r\n * \r\n * #### allowedTypes\r\n * file_extension|audio/*|video/*|image/*|media_type\r\n */\r\nconst checkFileType = (file: File, allowedTypes: Array<string>): ValidationErrors | null => {\r\n    const fileExtension = file.name.slice((file.name.lastIndexOf(\".\") - 1 >>> 0) + 1);\r\n    let isValid = false;\r\n    for(let i = 0; i < allowedTypes.length; i++ ) {\r\n        let type = allowedTypes[i];\r\n\r\n        isValid = FILE_EXT_REG.test(type) ? type === fileExtension : new RegExp(type).test(file.type);\r\n        if(isValid) {\r\n            break;\r\n        }\r\n    }\r\n\r\n    return isValid ?\r\n            null : {allowedTypes, actual: file.type, file};\r\n}\r\n\r\nconst checkValueType = (value: any ): void => {\r\n    if (!Array.isArray(value)) {\r\n        throw Error(`FormControl.setValue was provided with wrong argument type, ${value} was provided instead Array<File>`);\r\n    }\r\n}\r\n\r\n// @dynamic\r\nexport class FileUploadValidators {\r\n\r\n    /**\r\n     * Validator that requires controls to have a file maximum size length.\r\n     * Compare the File size in bytes\r\n     * @dynamic\r\n     */\r\n    public static fileSize(maxSize: number): ValidatorFn {\r\n        return (control: AbstractControl | FileUploadControl): {fileSize: Array<ValidationErrors>} => {\r\n            const files: Array<File> = control.value;\r\n            if (IsNullOrEmpty(files)) { return null; }\r\n            checkValueType(files);\r\n\r\n            const toLargeFiles = files.map((file) => checkFileSize(file, maxSize))\r\n                                        .filter((error) => error);\r\n\r\n            return toLargeFiles.length > 0 ?\r\n                    {'fileSize': toLargeFiles} : null;\r\n        };\r\n    }\r\n\r\n    /**\r\n     * Compare the File size in bytes with max and min size limits\r\n     * @dynamic\r\n     */\r\n    public static sizeRange({ minSize, maxSize }: { minSize?: number; maxSize?: number }): ValidatorFn {\r\n        return (control: AbstractControl | FileUploadControl): {sizeRange: Array<ValidationErrors>} => {\r\n            const files: Array<File> = control.value;\r\n            if (IsNullOrEmpty(files)) { return null; }\r\n            checkValueType(files);\r\n\r\n            const sizeMismatch = files.map((file) => checkFileSize(file, maxSize, minSize))\r\n                                        .filter((error) => error);\r\n\r\n            return sizeMismatch.length > 0 ?\r\n                    {'sizeRange': sizeMismatch} : null;\r\n        };\r\n    }\r\n\r\n    /**\r\n     * validator that requires control to have limit on files number\r\n     * @dynamic\r\n     */\r\n    public static filesLimit(numFiles: number): ValidatorFn {\r\n        return (control: AbstractControl | FileUploadControl): ValidationErrors => {\r\n            const files: Array<File> = control.value;\r\n            if (IsNullOrEmpty(files)) { return null; }\r\n            checkValueType(files);\r\n\r\n            return files.length > numFiles ?\r\n                {'filesLimit': {'max': numFiles, 'actual': files.length}} : null;\r\n        };\r\n    }\r\n\r\n    /**\r\n     * validator that requires control to have limit on media types\r\n     * \r\n     * ##### Allowed media types are\r\n     * \r\n     * - file_extension - a file extension starting with the STOP character, \r\n     * e.g: .gif, .jpg, .png, .doc\r\n     * - audio/* -        All sound files are accepted\r\n     * - video/* -        All video files are accepted\r\n     * - image/* -        All image files are accepted\r\n     * - media_type -     A valid media type, with no parameters. Look at [IANA Media Types](https://www.iana.org/assignments/media-types/media-types.xhtml) for a complete list of standard media types\r\n     * \r\n     * #### Example\r\n     * `FileUploadValidators.accept([file_extension, audio/*, video/*, image/*, media_type])`\r\n     * @dynamic\r\n     */\r\n    public static accept(allowedFileTypes: Array<string>) {\r\n        return (control: AbstractControl | FileUploadControl): ValidationErrors => {\r\n            const files: Array<File> = control.value;\r\n            if (IsNullOrEmpty(files)) { return null; }\r\n            checkValueType(files);\r\n\r\n            const notAllowedFiles = files.map((file) => checkFileType(file, allowedFileTypes))\r\n                                        .filter((error) => error);\r\n\r\n            return notAllowedFiles.length > 0 ?\r\n                {'fileTypes': notAllowedFiles} : null;\r\n        };\r\n    }\r\n\r\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validators.class.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["helpers/validators.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl } from '@angular/forms';\r\nimport { IsNullOrEmpty } from './helpers.class';\r\nimport { FileUploadControl } from './control.class';\r\n\r\nexport interface ValidationErrors {\r\n    [key: string]: any;\r\n}\r\n\r\nexport interface ValidatorFn {\r\n    (c: AbstractControl | FileUploadControl): ValidationErrors | null;\r\n}\r\n\r\n/**\r\n * function used to check file size\r\n */\r\nconst checkFileSize = (file: File, maxSize: number, minSize: number = 0): ValidationErrors | null => {\r\n    return (!IsNullOrEmpty(maxSize) && file.size > maxSize) || file.size < minSize ?\r\n        {maxSize, minSize, actual: file.size, file} : null;\r\n}\r\n\r\nconst FILE_EXT_REG = /(^[.]\\w*)$/gm;\r\n/**\r\n * function used to check file type\r\n * \r\n * #### allowedTypes\r\n * file_extension|audio/*|video/*|image/*|media_type\r\n */\r\nconst checkFileType = (file: File, allowedTypes: Array<string>): ValidationErrors | null => {\r\n    const fileExtension = file.name.slice((file.name.lastIndexOf(\".\") - 1 >>> 0) + 1);\r\n    let isValid = false;\r\n    for(let i = 0; i < allowedTypes.length; i++ ) {\r\n        let type = allowedTypes[i];\r\n\r\n        isValid = FILE_EXT_REG.test(type) ? type === fileExtension : new RegExp(type).test(file.type);\r\n        if(isValid) {\r\n            break;\r\n        }\r\n    }\r\n\r\n    return isValid ?\r\n            null : {allowedTypes, actual: file.type, file};\r\n}\r\n\r\nconst checkValueType = (value: any ): void => {\r\n    if (!Array.isArray(value)) {\r\n        throw Error(`FormControl.setValue was provided with wrong argument type, ${value} was provided instead Array<File>`);\r\n    }\r\n}\r\n\r\n// @dynamic\r\nexport class FileUploadValidators {\r\n\r\n    /**\r\n     * Validator that requires controls to have a file maximum size length.\r\n     * Compare the File size in bytes\r\n     * @dynamic\r\n     */\r\n    public static fileSize(maxSize: number): ValidatorFn {\r\n        return (control: AbstractControl | FileUploadControl): {fileSize: Array<ValidationErrors>} => {\r\n            const files: Array<File> = control.value;\r\n            if (IsNullOrEmpty(files)) { return null; }\r\n            checkValueType(files);\r\n\r\n            const toLargeFiles = files.map((file) => checkFileSize(file, maxSize))\r\n                                        .filter((error) => error);\r\n\r\n            return toLargeFiles.length > 0 ?\r\n                    {'fileSize': toLargeFiles} : null;\r\n        };\r\n    }\r\n\r\n    /**\r\n     * Compare the File size in bytes with max and min size limits\r\n     * @dynamic\r\n     */\r\n    public static sizeRange({ minSize, maxSize }: { minSize?: number; maxSize?: number }): ValidatorFn {\r\n        return (control: AbstractControl | FileUploadControl): {sizeRange: Array<ValidationErrors>} => {\r\n            const files: Array<File> = control.value;\r\n            if (IsNullOrEmpty(files)) { return null; }\r\n            checkValueType(files);\r\n\r\n            const sizeMismatch = files.map((file) => checkFileSize(file, maxSize, minSize))\r\n                                        .filter((error) => error);\r\n\r\n            return sizeMismatch.length > 0 ?\r\n                    {'sizeRange': sizeMismatch} : null;\r\n        };\r\n    }\r\n\r\n    /**\r\n     * validator that requires control to have limit on files number\r\n     * @dynamic\r\n     */\r\n    public static filesLimit(numFiles: number): ValidatorFn {\r\n        return (control: AbstractControl | FileUploadControl): ValidationErrors => {\r\n            const files: Array<File> = control.value;\r\n            if (IsNullOrEmpty(files)) { return null; }\r\n            checkValueType(files);\r\n\r\n            return files.length > numFiles ?\r\n                {'filesLimit': {'max': numFiles, 'actual': files.length}} : null;\r\n        };\r\n    }\r\n\r\n    /**\r\n     * validator that requires control to have limit on media types\r\n     * \r\n     * ##### Allowed media types are\r\n     * \r\n     * - file_extension - a file extension starting with the STOP character, \r\n     * e.g: .gif, .jpg, .png, .doc\r\n     * - audio/* -        All sound files are accepted\r\n     * - video/* -        All video files are accepted\r\n     * - image/* -        All image files are accepted\r\n     * - media_type -     A valid media type, with no parameters. Look at [IANA Media Types](https://www.iana.org/assignments/media-types/media-types.xhtml) for a complete list of standard media types\r\n     * \r\n     * #### Example\r\n     * `FileUploadValidators.accept([file_extension, audio/*, video/*, image/*, media_type])`\r\n     * @dynamic\r\n     */\r\n    public static accept(allowedFileTypes: Array<string>) {\r\n        return (control: AbstractControl | FileUploadControl): ValidationErrors => {\r\n            const files: Array<File> = control.value;\r\n            if (IsNullOrEmpty(files)) { return null; }\r\n            checkValueType(files);\r\n\r\n            const notAllowedFiles = files.map((file) => checkFileType(file, allowedFileTypes))\r\n                                        .filter((error) => error);\r\n\r\n            return notAllowedFiles.length > 0 ?\r\n                {'fileTypes': notAllowedFiles} : null;\r\n        };\r\n    }\r\n\r\n}"]}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/

@@ -15,3 +15,2 @@ /**

export { FileUploadService as ɵb } from './services/file-upload.service';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXBsYWItbmd4LWZpbGUtdXBsb2FkLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQGlwbGFiL25neC1maWxlLXVwbG9hZC8iLCJzb3VyY2VzIjpbImlwbGFiLW5neC1maWxlLXVwbG9hZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBSUEsMkZBQWMsY0FBYyxDQUFDO0FBRTdCLE9BQU8sRUFBQyw0QkFBNEIsSUFBSSxFQUFFLEVBQUMsTUFBTSx5Q0FBeUMsQ0FBQztBQUMzRixPQUFPLEVBQUMsdUJBQXVCLElBQUksRUFBRSxFQUFDLE1BQU0seUNBQXlDLENBQUM7QUFDdEYsT0FBTyxFQUFDLDJCQUEyQixJQUFJLEVBQUUsRUFBQyxNQUFNLDhDQUE4QyxDQUFDO0FBQy9GLE9BQU8sRUFBQyxtQkFBbUIsSUFBSSxFQUFFLEVBQUMsTUFBTSxvQ0FBb0MsQ0FBQztBQUM3RSxPQUFPLEVBQUMsaUJBQWlCLElBQUksRUFBRSxFQUFDLG9CQUFvQixJQUFJLEVBQUUsRUFBQyxtQkFBbUIsSUFBSSxFQUFFLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUMvSCxPQUFPLEVBQUMsaUJBQWlCLElBQUksRUFBRSxFQUFDLE1BQU0sZ0NBQWdDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljX2FwaSc7XG5cbmV4cG9ydCB7RmlsZVVwbG9hZEF0dHJpYnV0ZUNvbXBvbmVudCBhcyDJtWV9IGZyb20gJy4vY29tcG9uZW50cy9maWxlLXVwbG9hZC1hdHRyLmNvbXBvbmVudCc7XG5leHBvcnQge0ZpbGVVcGxvYWRJY29uQ29tcG9uZW50IGFzIMm1ZH0gZnJvbSAnLi9jb21wb25lbnRzL2ZpbGUtdXBsb2FkLWljb24uY29tcG9uZW50JztcbmV4cG9ydCB7RmlsZVVwbG9hZExpc3RJdGVtQ29tcG9uZW50IGFzIMm1Y30gZnJvbSAnLi9jb21wb25lbnRzL2ZpbGUtdXBsb2FkLWxpc3QtaXRlbS5jb21wb25lbnQnO1xuZXhwb3J0IHtGaWxlVXBsb2FkQ29tcG9uZW50IGFzIMm1YX0gZnJvbSAnLi9jb21wb25lbnRzL2ZpbGUtdXBsb2FkLmNvbXBvbmVudCc7XG5leHBvcnQge0ZpbGVTaXplVmFsaWRhdG9yIGFzIMm1ZixGaWxlc0FjY2VwdFZhbGlkYXRvciBhcyDJtWgsRmlsZXNMaW1pdFZhbGlkYXRvciBhcyDJtWd9IGZyb20gJy4vZGlyZWN0aXZlcy92YWxpZGF0b3JzLmRpcmVjdGl2ZSc7XG5leHBvcnQge0ZpbGVVcGxvYWRTZXJ2aWNlIGFzIMm1Yn0gZnJvbSAnLi9zZXJ2aWNlcy9maWxlLXVwbG9hZC5zZXJ2aWNlJzsiXX0=
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/
export { FileUploadControl, FileUploadValidators, FileUploadTypes, FileUploadModule } from './file-upload.module';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BpcGxhYi9uZ3gtZmlsZS11cGxvYWQvIiwic291cmNlcyI6WyJwdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7QUFBQSwyRkFBYyxzQkFBc0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZmlsZS11cGxvYWQubW9kdWxlJzsiXX0=
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/

@@ -19,3 +19,4 @@ import { Injectable, Renderer2 } from '@angular/core';

isFileDragDropAvailable() {
const /** @type {?} */ div = this.renderer.createElement('div');
/** @type {?} */
const div = this.renderer.createElement('div');
return (('draggable' in div) || ('ondragstart' in div && 'ondrop' in div)) && FormData && !!FileReader;

@@ -52,3 +53,3 @@ }

];
function FileUploadService_tsickle_Closure_declarations() {
if (false) {
/** @type {?} */

@@ -59,3 +60,2 @@ FileUploadService.prototype.extensions;

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BpcGxhYi9uZ3gtZmlsZS11cGxvYWQvIiwic291cmNlcyI6WyJzZXJ2aWNlcy9maWxlLXVwbG9hZC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN0RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFHaEUsTUFBTTs7OztJQUlGLFlBQW9CLFFBQW1CO1FBQW5CLGFBQVEsR0FBUixRQUFRLENBQVc7MEJBRm1CLENBQUMsT0FBTyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDO0tBR3BGOzs7O0lBRU0sdUJBQXVCO1FBQzFCLHVCQUFNLEdBQUcsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMvQyxNQUFNLENBQUMsQ0FBQyxDQUFDLFdBQVcsSUFBSSxHQUFHLENBQUMsSUFBSSxDQUFDLGFBQWEsSUFBSSxHQUFHLElBQUksUUFBUSxJQUFJLEdBQUcsQ0FBQyxDQUFDLElBQUksUUFBUSxJQUFJLENBQUMsQ0FBQyxVQUFVLENBQUM7Ozs7Ozs7SUFJcEcsYUFBYSxDQUFDLElBQVksRUFBRSxpQkFBeUIsQ0FBQztRQUN6RCxFQUFFLENBQUMsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ2QsSUFBSSxHQUFHLENBQUMsQ0FBQztTQUNaO1FBRUQsRUFBRSxDQUFDLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxDQUFDLENBQUM7WUFDZCxNQUFNLENBQUMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksR0FBRyxHQUFHLENBQUMsR0FBRyxHQUFHLElBQUksSUFBSSxDQUFDLFVBQVUsQ0FBQyxjQUFjLENBQUMsRUFBRSxDQUFDO1NBQy9FO1FBRUQsTUFBTSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxHQUFHLElBQUksRUFBRSxjQUFjLEdBQUcsQ0FBQyxDQUFDLENBQUM7Ozs7OztJQUd4RCxXQUFXLENBQUMsSUFBVTtRQUN6QixNQUFNLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLGVBQWUsQ0FBQyxHQUFHLENBQUMsS0FBSyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7Ozs7WUEzQjdGLFVBQVU7Ozs7WUFIVSxTQUFTIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSwgUmVuZGVyZXIyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEZpbGVVcGxvYWRUeXBlcyB9IGZyb20gJy4vLi4vaGVscGVycy9maWxlLXR5cGVzLmNsYXNzJztcclxuXHJcbkBJbmplY3RhYmxlKClcclxuZXhwb3J0IGNsYXNzIEZpbGVVcGxvYWRTZXJ2aWNlIHtcclxuXHJcbiAgICBwcml2YXRlIGV4dGVuc2lvbnM6IEFycmF5PCdieXRlcycgfCAnS0InIHwgJ01CJyB8ICdHQic+ID0gWydieXRlcycsICdLQicsICdNQicsICdHQiddXHJcblxyXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSByZW5kZXJlcjogUmVuZGVyZXIyKSB7XHJcbiAgICB9XHJcblxyXG4gICAgcHVibGljIGlzRmlsZURyYWdEcm9wQXZhaWxhYmxlKCk6IGJvb2xlYW4ge1xyXG4gICAgICAgIGNvbnN0IGRpdiA9IHRoaXMucmVuZGVyZXIuY3JlYXRlRWxlbWVudCgnZGl2Jyk7XHJcbiAgICAgICAgcmV0dXJuICgoJ2RyYWdnYWJsZScgaW4gZGl2KSB8fCAoJ29uZHJhZ3N0YXJ0JyBpbiBkaXYgJiYgJ29uZHJvcCcgaW4gZGl2KSkgJiYgRm9ybURhdGEgJiYgISFGaWxlUmVhZGVyO1xyXG4gICAgfVxyXG5cclxuXHJcbiAgICBwdWJsaWMgY2FsY3VsYXRlU2l6ZShzaXplOiBudW1iZXIsIGV4dGVuc2lvbkluZGV4OiBudW1iZXIgPSAwKTogc3RyaW5nIHtcclxuICAgICAgICBpZiAoaXNOYU4oc2l6ZSkpIHtcclxuICAgICAgICAgICAgc2l6ZSA9IDA7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICBpZiAoc2l6ZSA8IDEwMjQpIHtcclxuICAgICAgICAgICAgcmV0dXJuIGAke01hdGgucm91bmQoc2l6ZSAqIDEwMCkgLyAxMDB9ICR7dGhpcy5leHRlbnNpb25zW2V4dGVuc2lvbkluZGV4XX1gO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgcmV0dXJuIHRoaXMuY2FsY3VsYXRlU2l6ZShzaXplIC8gMTAyNCwgZXh0ZW5zaW9uSW5kZXggKyAxKTtcclxuICAgIH1cclxuXHJcbiAgICBwdWJsaWMgZ2V0RmlsZVR5cGUoZmlsZTogRmlsZSk6IHN0cmluZyB7XHJcbiAgICAgICAgcmV0dXJuIE9iamVjdC5rZXlzKEZpbGVVcGxvYWRUeXBlcykuZmluZCgoa2V5KSA9PiBGaWxlVXBsb2FkVHlwZXNba2V5XSA9PT0gZmlsZS50eXBlKTtcclxuICAgIH1cclxufSJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BpcGxhYi9uZ3gtZmlsZS11cGxvYWQvIiwic291cmNlcyI6WyJzZXJ2aWNlcy9maWxlLXVwbG9hZC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN0RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFHaEUsTUFBTSxPQUFPLGlCQUFpQjs7OztJQUkxQixZQUFvQixRQUFtQjtRQUFuQixhQUFRLEdBQVIsUUFBUSxDQUFXO1FBRi9CLGVBQVUsR0FBd0MsQ0FBQyxPQUFPLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQTtJQUdyRixDQUFDOzs7O0lBRU0sdUJBQXVCOztjQUNwQixHQUFHLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDO1FBQzlDLE9BQU8sQ0FBQyxDQUFDLFdBQVcsSUFBSSxHQUFHLENBQUMsSUFBSSxDQUFDLGFBQWEsSUFBSSxHQUFHLElBQUksUUFBUSxJQUFJLEdBQUcsQ0FBQyxDQUFDLElBQUksUUFBUSxJQUFJLENBQUMsQ0FBQyxVQUFVLENBQUM7SUFDM0csQ0FBQzs7Ozs7O0lBR00sYUFBYSxDQUFDLElBQVksRUFBRSxpQkFBeUIsQ0FBQztRQUN6RCxJQUFJLEtBQUssQ0FBQyxJQUFJLENBQUMsRUFBRTtZQUNiLElBQUksR0FBRyxDQUFDLENBQUM7U0FDWjtRQUVELElBQUksSUFBSSxHQUFHLElBQUksRUFBRTtZQUNiLE9BQU8sR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksR0FBRyxHQUFHLENBQUMsR0FBRyxHQUFHLElBQUksSUFBSSxDQUFDLFVBQVUsQ0FBQyxjQUFjLENBQUMsRUFBRSxDQUFDO1NBQy9FO1FBRUQsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksR0FBRyxJQUFJLEVBQUUsY0FBYyxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQy9ELENBQUM7Ozs7O0lBRU0sV0FBVyxDQUFDLElBQVU7UUFDekIsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsZUFBZSxDQUFDLEdBQUcsQ0FBQyxLQUFLLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUMxRixDQUFDOzs7WUE1QkosVUFBVTs7OztZQUhVLFNBQVM7Ozs7SUFNMUIsdUNBQXFGOztJQUV6RSxxQ0FBMkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBSZW5kZXJlcjIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRmlsZVVwbG9hZFR5cGVzIH0gZnJvbSAnLi8uLi9oZWxwZXJzL2ZpbGUtdHlwZXMuY2xhc3MnO1xyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgRmlsZVVwbG9hZFNlcnZpY2Uge1xyXG5cclxuICAgIHByaXZhdGUgZXh0ZW5zaW9uczogQXJyYXk8J2J5dGVzJyB8ICdLQicgfCAnTUInIHwgJ0dCJz4gPSBbJ2J5dGVzJywgJ0tCJywgJ01CJywgJ0dCJ11cclxuXHJcbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlbmRlcmVyOiBSZW5kZXJlcjIpIHtcclxuICAgIH1cclxuXHJcbiAgICBwdWJsaWMgaXNGaWxlRHJhZ0Ryb3BBdmFpbGFibGUoKTogYm9vbGVhbiB7XHJcbiAgICAgICAgY29uc3QgZGl2ID0gdGhpcy5yZW5kZXJlci5jcmVhdGVFbGVtZW50KCdkaXYnKTtcclxuICAgICAgICByZXR1cm4gKCgnZHJhZ2dhYmxlJyBpbiBkaXYpIHx8ICgnb25kcmFnc3RhcnQnIGluIGRpdiAmJiAnb25kcm9wJyBpbiBkaXYpKSAmJiBGb3JtRGF0YSAmJiAhIUZpbGVSZWFkZXI7XHJcbiAgICB9XHJcblxyXG5cclxuICAgIHB1YmxpYyBjYWxjdWxhdGVTaXplKHNpemU6IG51bWJlciwgZXh0ZW5zaW9uSW5kZXg6IG51bWJlciA9IDApOiBzdHJpbmcge1xyXG4gICAgICAgIGlmIChpc05hTihzaXplKSkge1xyXG4gICAgICAgICAgICBzaXplID0gMDtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIGlmIChzaXplIDwgMTAyNCkge1xyXG4gICAgICAgICAgICByZXR1cm4gYCR7TWF0aC5yb3VuZChzaXplICogMTAwKSAvIDEwMH0gJHt0aGlzLmV4dGVuc2lvbnNbZXh0ZW5zaW9uSW5kZXhdfWA7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICByZXR1cm4gdGhpcy5jYWxjdWxhdGVTaXplKHNpemUgLyAxMDI0LCBleHRlbnNpb25JbmRleCArIDEpO1xyXG4gICAgfVxyXG5cclxuICAgIHB1YmxpYyBnZXRGaWxlVHlwZShmaWxlOiBGaWxlKTogc3RyaW5nIHtcclxuICAgICAgICByZXR1cm4gT2JqZWN0LmtleXMoRmlsZVVwbG9hZFR5cGVzKS5maW5kKChrZXkpID0+IEZpbGVVcGxvYWRUeXBlc1trZXldID09PSBmaWxlLnR5cGUpO1xyXG4gICAgfVxyXG59Il19
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/

@@ -135,2 +135,5 @@ import { Input, ElementRef, HostListener, Renderer2, HostBinding, Inject, ViewChild, ContentChild, TemplateRef, Component } from '@angular/core';

* on file over add class name
*/
/**
* on file over add class name
* @param {?} event

@@ -149,2 +152,5 @@ * @return {?}

* on mouse out remove class name
*/
/**
* on mouse out remove class name
* @param {?} event

@@ -173,3 +179,4 @@ * @return {?}

}
var /** @type {?} */ files = event.dataTransfer.files;
/** @type {?} */
var files = event.dataTransfer.files;
this.control.addFiles(files);

@@ -206,3 +213,3 @@ this.onTouch();

export { FileUploadAttributeComponent };
function FileUploadAttributeComponent_tsickle_Closure_declarations() {
if (false) {
/** @type {?} */

@@ -229,3 +236,2 @@ FileUploadAttributeComponent.prototype.control;

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload-attr.component.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["components/file-upload-attr.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Input,\r\n    OnInit,\r\n    ElementRef,\r\n    HostListener,\r\n    Renderer2,\r\n    OnDestroy,\r\n    HostBinding,\r\n    Inject,\r\n    ViewChild,\r\n    ContentChild,\r\n    TemplateRef,\r\n    Component,\r\n    AfterViewInit\r\n} from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\n\r\nimport { FileUploadControl } from '../helpers/control.class';\r\nimport { IsNullOrEmpty } from '../helpers/helpers.class';\r\nimport { FileUploadService } from '../services/file-upload.service';\r\nimport { DRAGOVER, TOUCHED } from './file-upload.component';\r\nimport { Subscription } from 'rxjs';\r\n\r\n\r\n@Component({\r\n    selector: `[file-drop-zone]`,\r\n    template: `\r\n        <ng-content></ng-content>\r\n        <div #overlay class=\"overlay\" *ngIf=\"fileUploadService.isFileDragDropAvailable()\">\r\n\r\n            <div class=\"upload-input\">\r\n                <ng-container *ngTemplateOutlet=\"templateRef ? templateRef : defaultTemplate\"></ng-container>\r\n\r\n                <ng-template #defaultTemplate>\r\n                    <div class=\"icon\">\r\n                        <svg viewBox=\"0 0 96 96\">\r\n                            <g>\r\n                                <path d=\"M62.8,68.1c0-0.6-0.2-1.1-0.6-1.5c-0.4-0.4-0.9-0.6-1.5-0.6s-1.1,0.2-1.5,0.6\r\n                                    c-0.4,0.4-0.6,0.9-0.6,1.5c0,0.6,0.2,1.1,0.6,1.5c0.4,0.4,0.9,0.6,1.5,0.6s1.1-0.2,1.5-0.6S62.8,68.7,62.8,68.1z M71.3,68.1\r\n                                    c0-0.6-0.2-1.1-0.6-1.5c-0.4-0.4-0.9-0.6-1.5-0.6c-0.6,0-1.1,0.2-1.5,0.6C67.2,67,67,67.5,67,68.1c0,0.6,0.2,1.1,0.6,1.5\r\n                                    s0.9,0.6,1.5,0.6c0.6,0,1.1-0.2,1.5-0.6C71.1,69.2,71.3,68.7,71.3,68.1z M75.5,60.7v10.6c0,0.9-0.3,1.6-0.9,2.2\r\n                                    c-0.6,0.6-1.4,0.9-2.2,0.9H23.7c-0.9,0-1.6-0.3-2.2-0.9c-0.6-0.6-0.9-1.4-0.9-2.2V60.7c0-0.9,0.3-1.6,0.9-2.2\r\n                                    c0.6-0.6,1.4-0.9,2.2-0.9h14.1c0.5,1.2,1.2,2.2,2.3,3c1.1,0.8,2.3,1.2,3.7,1.2h8.5c1.3,0,2.6-0.4,3.7-1.2c1.1-0.8,1.9-1.8,2.3-3\r\n                                    h14.1c0.9,0,1.6,0.3,2.2,0.9C75.2,59.1,75.5,59.8,75.5,60.7z M64.8,39.3c-0.4,0.9-1,1.3-2,1.3h-8.5v14.8c0,0.6-0.2,1.1-0.6,1.5\r\n                                    c-0.4,0.4-0.9,0.6-1.5,0.6h-8.5c-0.6,0-1.1-0.2-1.5-0.6c-0.4-0.4-0.6-0.9-0.6-1.5V40.6h-8.5c-0.9,0-1.6-0.4-2-1.3\r\n                                    c-0.4-0.9-0.2-1.6,0.5-2.3l14.8-14.8c0.4-0.4,0.9-0.6,1.5-0.6s1.1,0.2,1.5,0.6L64.3,37C65,37.7,65.1,38.4,64.8,39.3z\"/>\r\n                            </g>\r\n                        </svg>\r\n                    </div>\r\n                \r\n                    <div class=\"upload-text\">\r\n                        <b>Drop</b> it here\r\n                    </div>\r\n                </ng-template>\r\n            </div>\r\n        </div>\r\n    `,\r\n    styles: [`:host{position:relative;display:block}:host .overlay{display:none;background:rgba(255,255,255,.8);outline:#92b0b3 dashed 2px;outline-offset:-10px;position:absolute;top:0;left:0;right:0;bottom:0}:host(.dragover:not(.disabled)) .overlay{display:block}.icon{height:35px;width:35px;border:1px solid #eaeaea;border-radius:4px;margin:0 auto 10px}:host /deep/ .icon svg{fill:#80a9d2}.upload-input{pointer-events:none;cursor:pointer;display:inline-block;color:#80a9d2;position:absolute;top:50%;left:50%;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);transition:all .15s ease-in-out}`],\r\n    providers: [ \r\n        FileUploadService\r\n    ]\r\n})\r\nexport class FileUploadAttributeComponent implements OnInit, AfterViewInit, OnDestroy {\r\n\r\n    @Input()\r\n    public control: FileUploadControl = null;\r\n\r\n    @ViewChild('overlay')\r\n    public overlay: ElementRef<HTMLDivElement>;\r\n\r\n    @ContentChild('placeholder')\r\n    public templateRef: TemplateRef<any> = null;\r\n\r\n    private hooks: Array<Function> = [];\r\n\r\n    private subscriptions: Array<Subscription> = [];\r\n\r\n    constructor(\r\n        public fileUploadService: FileUploadService,\r\n        private hostElementRef: ElementRef,\r\n        private renderer: Renderer2,\r\n        @Inject(DOCUMENT) private document\r\n    ) {}\r\n\r\n    public ngOnInit() {\r\n        if (IsNullOrEmpty(this.control)) {\r\n            this.control = new FileUploadControl();\r\n        }\r\n    }\r\n\r\n    public ngAfterViewInit(): void {\r\n        if (this.fileUploadService.isFileDragDropAvailable()) {\r\n            this.setEvents();\r\n            this.checkAndMarkAsDisabled();\r\n        }\r\n    }\r\n\r\n    public ngOnDestroy(): void {\r\n        this.hooks.forEach((hook) => hook());\r\n        this.hooks.length = 0;\r\n        this.subscriptions.forEach((subscription) => subscription.unsubscribe());\r\n        this.subscriptions.length = 0;\r\n    }\r\n\r\n    @HostBinding('class.has-files')\r\n    public get hasFiles(): boolean {\r\n        return this.control.isListVisible && this.control.size > 0;\r\n    }\r\n\r\n    @HostBinding('class.ng-invalid')\r\n    public get isInvalid(): boolean {\r\n        return !this.control.disabled && this.control.invalid;\r\n    }\r\n\r\n    private setEvents(): void {\r\n        ['drag', 'dragstart', 'dragend', 'dragover', 'dragenter', 'dragleave', 'drop'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.document, eventName, (event: any) => this.preventDragEvents(event))\r\n            );\r\n        });\r\n\r\n        ['dragover', 'dragenter'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.hostElementRef.nativeElement, eventName, (event: any) => this.onDragOver(event))\r\n            );\r\n        });\r\n\r\n        ['dragleave', 'dragend', 'drop'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.hostElementRef.nativeElement, eventName, (event: any) => {\r\n                    if(this.control.disabled && eventName === 'dragleave' || eventName !== 'dragleave') {\r\n                        this.onDragLeave(event);\r\n                    }\r\n                })\r\n            );\r\n        });\r\n\r\n        ['dragleave'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.overlay.nativeElement, eventName, (event: any) => this.onDragLeave(event))\r\n            );\r\n        });\r\n\r\n        this.subscriptions.push(\r\n            this.control.statusChanges.subscribe((status) => this.checkAndMarkAsDisabled())\r\n        );\r\n    }\r\n\r\n    private checkAndMarkAsDisabled(): void {\r\n        if (this.control.disabled) {\r\n            this.renderer.addClass(this.hostElementRef.nativeElement, 'disabled');\r\n        } else {\r\n            this.renderer.removeClass(this.hostElementRef.nativeElement, 'disabled');\r\n        }\r\n    }\r\n\r\n    private preventDragEvents(event: DragEvent): void {\r\n        event.preventDefault();\r\n        event.stopPropagation();\r\n    }\r\n\r\n    /**\r\n     * on file over add class name\r\n     */\r\n    private onDragOver(event: DragEvent): void {\r\n        this.renderer.addClass(this.hostElementRef.nativeElement, DRAGOVER);\r\n    }\r\n\r\n    /**\r\n     * on mouse out remove class name\r\n     */\r\n    private onDragLeave(event: DragEvent): void {\r\n        this.renderer.removeClass(this.hostElementRef.nativeElement, DRAGOVER);\r\n    }\r\n\r\n    @HostListener('drop', ['$event'])\r\n    public onDrop(event: DragEvent): void {\r\n        if (this.control.disabled) {\r\n            return;\r\n        }\r\n        const files = event.dataTransfer.files;\r\n        this.control.addFiles(files);\r\n        this.onTouch();\r\n    }\r\n\r\n    private onTouch: () => void = () => {\r\n        this.renderer.addClass(this.hostElementRef.nativeElement, TOUCHED);\r\n    };\r\n\r\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload-attr.component.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["components/file-upload-attr.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EACH,KAAK,EAEL,UAAU,EACV,YAAY,EACZ,SAAS,EAET,WAAW,EACX,MAAM,EACN,SAAS,EACT,YAAY,EACZ,WAAW,EACX,SAAS,EAEZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAE3C,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;AACpE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAC;AAI5D;IAqDI,sCACW,iBAAoC,EACnC,cAA0B,EAC1B,QAAmB,EACD,QAAQ;QAJtC,iBAKI;QAJO,sBAAiB,GAAjB,iBAAiB,CAAmB;QACnC,mBAAc,GAAd,cAAc,CAAY;QAC1B,aAAQ,GAAR,QAAQ,CAAW;QACD,aAAQ,GAAR,QAAQ,CAAA;QAhB/B,YAAO,GAAsB,IAAI,CAAC;QAMlC,gBAAW,GAAqB,IAAI,CAAC;QAEpC,UAAK,GAAoB,EAAE,CAAC;QAE5B,kBAAa,GAAwB,EAAE,CAAC;QA8GxC,YAAO,GAAe;YAC1B,KAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAI,CAAC,cAAc,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;QACvE,CAAC,CAAC;IAzGC,CAAC;;;;IAEG,+CAAQ;;;IAAf;QACI,IAAI,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YAC7B,IAAI,CAAC,OAAO,GAAG,IAAI,iBAAiB,EAAE,CAAC;SAC1C;IACL,CAAC;;;;IAEM,sDAAe;;;IAAtB;QACI,IAAI,IAAI,CAAC,iBAAiB,CAAC,uBAAuB,EAAE,EAAE;YAClD,IAAI,CAAC,SAAS,EAAE,CAAC;YACjB,IAAI,CAAC,sBAAsB,EAAE,CAAC;SACjC;IACL,CAAC;;;;IAEM,kDAAW;;;IAAlB;QACI,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,UAAC,IAAI,IAAK,OAAA,IAAI,EAAE,EAAN,CAAM,CAAC,CAAC;QACrC,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;QACtB,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,UAAC,YAAY,IAAK,OAAA,YAAY,CAAC,WAAW,EAAE,EAA1B,CAA0B,CAAC,CAAC;QACzE,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC;IAClC,CAAC;IAED,sBACW,kDAAQ;;;;QADnB;YAEI,OAAO,IAAI,CAAC,OAAO,CAAC,aAAa,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,GAAG,CAAC,CAAC;QAC/D,CAAC;;;OAAA;IAED,sBACW,mDAAS;;;;QADpB;YAEI,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC;QAC1D,CAAC;;;OAAA;;;;IAEO,gDAAS;;;IAAjB;QAAA,iBAgCC;QA/BG,CAAC,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,CAAC,CAAC,OAAO,CAAC,UAAC,SAAS;YAC7F,KAAI,CAAC,KAAK,CAAC,IAAI,CACX,KAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAI,CAAC,QAAQ,EAAE,SAAS,EAAE,UAAC,KAAU,IAAK,OAAA,KAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,EAA7B,CAA6B,CAAC,CAChG,CAAC;QACN,CAAC,CAAC,CAAC;QAEH,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC,OAAO,CAAC,UAAC,SAAS;YACxC,KAAI,CAAC,KAAK,CAAC,IAAI,CACX,KAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAI,CAAC,cAAc,CAAC,aAAa,EAAE,SAAS,EAAE,UAAC,KAAU,IAAK,OAAA,KAAI,CAAC,UAAU,CAAC,KAAK,CAAC,EAAtB,CAAsB,CAAC,CAC7G,CAAC;QACN,CAAC,CAAC,CAAC;QAEH,CAAC,WAAW,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC,OAAO,CAAC,UAAC,SAAS;YAC/C,KAAI,CAAC,KAAK,CAAC,IAAI,CACX,KAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAI,CAAC,cAAc,CAAC,aAAa,EAAE,SAAS,EAAE,UAAC,KAAU;gBAC1E,IAAG,KAAI,CAAC,OAAO,CAAC,QAAQ,IAAI,SAAS,KAAK,WAAW,IAAI,SAAS,KAAK,WAAW,EAAE;oBAChF,KAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;iBAC3B;YACL,CAAC,CAAC,CACL,CAAC;QACN,CAAC,CAAC,CAAC;QAEH,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,UAAC,SAAS;YAC5B,KAAI,CAAC,KAAK,CAAC,IAAI,CACX,KAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAI,CAAC,OAAO,CAAC,aAAa,EAAE,SAAS,EAAE,UAAC,KAAU,IAAK,OAAA,KAAI,CAAC,WAAW,CAAC,KAAK,CAAC,EAAvB,CAAuB,CAAC,CACvG,CAAC;QACN,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,aAAa,CAAC,IAAI,CACnB,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,SAAS,CAAC,UAAC,MAAM,IAAK,OAAA,KAAI,CAAC,sBAAsB,EAAE,EAA7B,CAA6B,CAAC,CAClF,CAAC;IACN,CAAC;;;;IAEO,6DAAsB;;;IAA9B;QACI,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE;YACvB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,UAAU,CAAC,CAAC;SACzE;aAAM;YACH,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,UAAU,CAAC,CAAC;SAC5E;IACL,CAAC;;;;;IAEO,wDAAiB;;;;IAAzB,UAA0B,KAAgB;QACtC,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;IAC5B,CAAC;IAED;;OAEG;;;;;;IACK,iDAAU;;;;;IAAlB,UAAmB,KAAgB;QAC/B,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;IACxE,CAAC;IAED;;OAEG;;;;;;IACK,kDAAW;;;;;IAAnB,UAAoB,KAAgB;QAChC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;IAC3E,CAAC;;;;;IAGM,6CAAM;;;;IADb,UACc,KAAgB;QAC1B,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE;YACvB,OAAO;SACV;;YACK,KAAK,GAAG,KAAK,CAAC,YAAY,CAAC,KAAK;QACtC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QAC7B,IAAI,CAAC,OAAO,EAAE,CAAC;IACnB,CAAC;;gBA/JJ,SAAS,SAAC;oBACP,QAAQ,EAAE,kBAAkB;oBAC5B,QAAQ,EAAE,mkEA8BT;oBACD,MAAM,EAAE,CAAC,ulBAAulB,CAAC;oBACjmB,SAAS,EAAE;wBACP,iBAAiB;qBACpB;iBACJ;;;;gBA1CQ,iBAAiB;gBAhBtB,UAAU;gBAEV,SAAS;gDA4EJ,MAAM,SAAC,QAAQ;;;0BAjBnB,KAAK;0BAGL,SAAS,SAAC,SAAS;8BAGnB,YAAY,SAAC,aAAa;2BAkC1B,WAAW,SAAC,iBAAiB;4BAK7B,WAAW,SAAC,kBAAkB;yBAkE9B,YAAY,SAAC,MAAM,EAAE,CAAC,QAAQ,CAAC;;IAcpC,mCAAC;CAAA,AArKD,IAqKC;SA/HY,4BAA4B;;;IAErC,+CACyC;;IAEzC,+CAC2C;;IAE3C,mDAC4C;;IAE5C,6CAAoC;;IAEpC,qDAAgD;;IA8GhD,+CAEE;;IA7GE,yDAA2C;;IAC3C,sDAAkC;;IAClC,gDAA2B;;IAC3B,gDAAkC","sourcesContent":["import {\r\n    Input,\r\n    OnInit,\r\n    ElementRef,\r\n    HostListener,\r\n    Renderer2,\r\n    OnDestroy,\r\n    HostBinding,\r\n    Inject,\r\n    ViewChild,\r\n    ContentChild,\r\n    TemplateRef,\r\n    Component,\r\n    AfterViewInit\r\n} from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\n\r\nimport { FileUploadControl } from '../helpers/control.class';\r\nimport { IsNullOrEmpty } from '../helpers/helpers.class';\r\nimport { FileUploadService } from '../services/file-upload.service';\r\nimport { DRAGOVER, TOUCHED } from './file-upload.component';\r\nimport { Subscription } from 'rxjs';\r\n\r\n\r\n@Component({\r\n    selector: `[file-drop-zone]`,\r\n    template: `\r\n        <ng-content></ng-content>\r\n        <div #overlay class=\"overlay\" *ngIf=\"fileUploadService.isFileDragDropAvailable()\">\r\n\r\n            <div class=\"upload-input\">\r\n                <ng-container *ngTemplateOutlet=\"templateRef ? templateRef : defaultTemplate\"></ng-container>\r\n\r\n                <ng-template #defaultTemplate>\r\n                    <div class=\"icon\">\r\n                        <svg viewBox=\"0 0 96 96\">\r\n                            <g>\r\n                                <path d=\"M62.8,68.1c0-0.6-0.2-1.1-0.6-1.5c-0.4-0.4-0.9-0.6-1.5-0.6s-1.1,0.2-1.5,0.6\r\n                                    c-0.4,0.4-0.6,0.9-0.6,1.5c0,0.6,0.2,1.1,0.6,1.5c0.4,0.4,0.9,0.6,1.5,0.6s1.1-0.2,1.5-0.6S62.8,68.7,62.8,68.1z M71.3,68.1\r\n                                    c0-0.6-0.2-1.1-0.6-1.5c-0.4-0.4-0.9-0.6-1.5-0.6c-0.6,0-1.1,0.2-1.5,0.6C67.2,67,67,67.5,67,68.1c0,0.6,0.2,1.1,0.6,1.5\r\n                                    s0.9,0.6,1.5,0.6c0.6,0,1.1-0.2,1.5-0.6C71.1,69.2,71.3,68.7,71.3,68.1z M75.5,60.7v10.6c0,0.9-0.3,1.6-0.9,2.2\r\n                                    c-0.6,0.6-1.4,0.9-2.2,0.9H23.7c-0.9,0-1.6-0.3-2.2-0.9c-0.6-0.6-0.9-1.4-0.9-2.2V60.7c0-0.9,0.3-1.6,0.9-2.2\r\n                                    c0.6-0.6,1.4-0.9,2.2-0.9h14.1c0.5,1.2,1.2,2.2,2.3,3c1.1,0.8,2.3,1.2,3.7,1.2h8.5c1.3,0,2.6-0.4,3.7-1.2c1.1-0.8,1.9-1.8,2.3-3\r\n                                    h14.1c0.9,0,1.6,0.3,2.2,0.9C75.2,59.1,75.5,59.8,75.5,60.7z M64.8,39.3c-0.4,0.9-1,1.3-2,1.3h-8.5v14.8c0,0.6-0.2,1.1-0.6,1.5\r\n                                    c-0.4,0.4-0.9,0.6-1.5,0.6h-8.5c-0.6,0-1.1-0.2-1.5-0.6c-0.4-0.4-0.6-0.9-0.6-1.5V40.6h-8.5c-0.9,0-1.6-0.4-2-1.3\r\n                                    c-0.4-0.9-0.2-1.6,0.5-2.3l14.8-14.8c0.4-0.4,0.9-0.6,1.5-0.6s1.1,0.2,1.5,0.6L64.3,37C65,37.7,65.1,38.4,64.8,39.3z\"/>\r\n                            </g>\r\n                        </svg>\r\n                    </div>\r\n                \r\n                    <div class=\"upload-text\">\r\n                        <b>Drop</b> it here\r\n                    </div>\r\n                </ng-template>\r\n            </div>\r\n        </div>\r\n    `,\r\n    styles: [`:host{position:relative;display:block}:host .overlay{display:none;background:rgba(255,255,255,.8);outline:#92b0b3 dashed 2px;outline-offset:-10px;position:absolute;top:0;left:0;right:0;bottom:0}:host(.dragover:not(.disabled)) .overlay{display:block}.icon{height:35px;width:35px;border:1px solid #eaeaea;border-radius:4px;margin:0 auto 10px}:host /deep/ .icon svg{fill:#80a9d2}.upload-input{pointer-events:none;cursor:pointer;display:inline-block;color:#80a9d2;position:absolute;top:50%;left:50%;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);transition:all .15s ease-in-out}`],\r\n    providers: [ \r\n        FileUploadService\r\n    ]\r\n})\r\nexport class FileUploadAttributeComponent implements OnInit, AfterViewInit, OnDestroy {\r\n\r\n    @Input()\r\n    public control: FileUploadControl = null;\r\n\r\n    @ViewChild('overlay')\r\n    public overlay: ElementRef<HTMLDivElement>;\r\n\r\n    @ContentChild('placeholder')\r\n    public templateRef: TemplateRef<any> = null;\r\n\r\n    private hooks: Array<Function> = [];\r\n\r\n    private subscriptions: Array<Subscription> = [];\r\n\r\n    constructor(\r\n        public fileUploadService: FileUploadService,\r\n        private hostElementRef: ElementRef,\r\n        private renderer: Renderer2,\r\n        @Inject(DOCUMENT) private document\r\n    ) {}\r\n\r\n    public ngOnInit() {\r\n        if (IsNullOrEmpty(this.control)) {\r\n            this.control = new FileUploadControl();\r\n        }\r\n    }\r\n\r\n    public ngAfterViewInit(): void {\r\n        if (this.fileUploadService.isFileDragDropAvailable()) {\r\n            this.setEvents();\r\n            this.checkAndMarkAsDisabled();\r\n        }\r\n    }\r\n\r\n    public ngOnDestroy(): void {\r\n        this.hooks.forEach((hook) => hook());\r\n        this.hooks.length = 0;\r\n        this.subscriptions.forEach((subscription) => subscription.unsubscribe());\r\n        this.subscriptions.length = 0;\r\n    }\r\n\r\n    @HostBinding('class.has-files')\r\n    public get hasFiles(): boolean {\r\n        return this.control.isListVisible && this.control.size > 0;\r\n    }\r\n\r\n    @HostBinding('class.ng-invalid')\r\n    public get isInvalid(): boolean {\r\n        return !this.control.disabled && this.control.invalid;\r\n    }\r\n\r\n    private setEvents(): void {\r\n        ['drag', 'dragstart', 'dragend', 'dragover', 'dragenter', 'dragleave', 'drop'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.document, eventName, (event: any) => this.preventDragEvents(event))\r\n            );\r\n        });\r\n\r\n        ['dragover', 'dragenter'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.hostElementRef.nativeElement, eventName, (event: any) => this.onDragOver(event))\r\n            );\r\n        });\r\n\r\n        ['dragleave', 'dragend', 'drop'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.hostElementRef.nativeElement, eventName, (event: any) => {\r\n                    if(this.control.disabled && eventName === 'dragleave' || eventName !== 'dragleave') {\r\n                        this.onDragLeave(event);\r\n                    }\r\n                })\r\n            );\r\n        });\r\n\r\n        ['dragleave'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.overlay.nativeElement, eventName, (event: any) => this.onDragLeave(event))\r\n            );\r\n        });\r\n\r\n        this.subscriptions.push(\r\n            this.control.statusChanges.subscribe((status) => this.checkAndMarkAsDisabled())\r\n        );\r\n    }\r\n\r\n    private checkAndMarkAsDisabled(): void {\r\n        if (this.control.disabled) {\r\n            this.renderer.addClass(this.hostElementRef.nativeElement, 'disabled');\r\n        } else {\r\n            this.renderer.removeClass(this.hostElementRef.nativeElement, 'disabled');\r\n        }\r\n    }\r\n\r\n    private preventDragEvents(event: DragEvent): void {\r\n        event.preventDefault();\r\n        event.stopPropagation();\r\n    }\r\n\r\n    /**\r\n     * on file over add class name\r\n     */\r\n    private onDragOver(event: DragEvent): void {\r\n        this.renderer.addClass(this.hostElementRef.nativeElement, DRAGOVER);\r\n    }\r\n\r\n    /**\r\n     * on mouse out remove class name\r\n     */\r\n    private onDragLeave(event: DragEvent): void {\r\n        this.renderer.removeClass(this.hostElementRef.nativeElement, DRAGOVER);\r\n    }\r\n\r\n    @HostListener('drop', ['$event'])\r\n    public onDrop(event: DragEvent): void {\r\n        if (this.control.disabled) {\r\n            return;\r\n        }\r\n        const files = event.dataTransfer.files;\r\n        this.control.addFiles(files);\r\n        this.onTouch();\r\n    }\r\n\r\n    private onTouch: () => void = () => {\r\n        this.renderer.addClass(this.hostElementRef.nativeElement, TOUCHED);\r\n    };\r\n\r\n}"]}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/

@@ -70,3 +70,3 @@ import { Component, Input } from '@angular/core';

export { FileUploadIconComponent };
function FileUploadIconComponent_tsickle_Closure_declarations() {
if (false) {
/** @type {?} */

@@ -79,3 +79,2 @@ FileUploadIconComponent.prototype.file;

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload-icon.component.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["components/file-upload-icon.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,mCAAmC,CAAC;;IAqFlE,iCAAoB,iBAAoC;QAApC,sBAAiB,GAAjB,iBAAiB,CAAmB;wBAF9B,SAAS;KAGlC;;;;IAEM,0CAAQ;;;;QACX,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;;;;;;IAG3D,wCAAM;;;;cAAC,IAA0C;QACpD,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;YACX,KAAK,MAAM;gBACP,MAAM,CAAC,IAAI,CAAC,QAAQ,KAAK,MAAM,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK;oBACtD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI;oBACjD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK;oBAClD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM;oBACnD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK;oBAClD,IAAI,CAAC,QAAQ,KAAK,MAAM,CAAC;YACjC,KAAK,OAAO;gBACR,MAAM,CAAC,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM;oBACtD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK;oBAClD,IAAI,CAAC,QAAQ,KAAK,MAAM,CAAC;YACjC,KAAK,OAAO;gBACR,MAAM,CAAC,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK;oBACrD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK;oBAClD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM;oBACnD,IAAI,CAAC,QAAQ,KAAK,KAAK,CAAC;YAChC,KAAK,OAAO;gBACR,MAAM,CAAC,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM;oBACtD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM;oBACnD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK,CAAC;SAC9D;;;gBA/GR,SAAS,SAAC;oBACP,QAAQ,EAAE,kBAAkB;oBAC5B,QAAQ,EAAE,siLAsEE;oBACZ,MAAM,EAAE,CAAC,wFAAwF,CAAC;iBACrG;;;;gBA7EQ,iBAAiB;;;uBAgFrB,KAAK;;kCAjFV;;SA+Ea,uBAAuB","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\r\nimport { FileUploadService } from './../services/file-upload.service';\r\n\r\n\r\n@Component({\r\n    selector: `file-upload-icon`,\r\n    template: `\r\n\r\n<ng-container [ngSwitch]=\"true\">\r\n\r\n    <svg *ngSwitchDefault viewBox=\"0 0 96 96\">\r\n        <g>\r\n            <path d=\"M71.4,30.7c0.6,0.6,1.2,1.5,1.6,2.5c0.4,1.1,0.7,2.1,0.7,2.9v38.6c0,0.9-0.3,1.7-0.9,2.3\r\n                S71.4,78,70.5,78h-45c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V21.2c0-0.9,0.3-1.7,0.9-2.3c0.6-0.6,1.4-0.9,2.3-0.9h30\r\n                c0.9,0,1.9,0.2,2.9,0.7c1.1,0.4,1.9,1,2.5,1.6L71.4,30.7z M56.6,22.6v12.6h12.6c-0.2-0.6-0.5-1.1-0.7-1.4L57.9,23.3\r\n                C57.7,23,57.2,22.8,56.6,22.6z M69.4,73.7V39.4H55.5c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V22.3H26.6v51.4H69.4z\"/>\r\n        </g>\r\n    </svg>\r\n\r\n    <svg *ngSwitchCase=\"isIcon('image')\" viewBox=\"0 0 96 96\">\r\n        <g>\r\n            <path d=\"M71.4,30.7c0.6,0.6,1.2,1.5,1.6,2.5c0.4,1.1,0.7,2.1,0.7,2.9v38.6c0,0.9-0.3,1.7-0.9,2.3\r\n                S71.4,78,70.5,78h-45c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V21.2c0-0.9,0.3-1.7,0.9-2.3c0.6-0.6,1.4-0.9,2.3-0.9h30\r\n                c0.9,0,1.9,0.2,2.9,0.7c1.1,0.4,1.9,1,2.5,1.6L71.4,30.7z M56.6,22.6v12.6h12.6c-0.2-0.6-0.5-1.1-0.7-1.4L57.9,23.3\r\n                C57.7,23,57.2,22.8,56.6,22.6z M69.4,73.7V39.4H55.5c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V22.3H26.6v51.4H69.4z\r\n                M65.1,58.7v10.7H30.9V63l6.4-6.4l4.3,4.3L54.4,48L65.1,58.7z M37.3,52.3c-1.8,0-3.3-0.6-4.6-1.9c-1.3-1.2-1.9-2.8-1.9-4.6\r\n                c0-1.8,0.6-3.3,1.9-4.6c1.3-1.2,2.8-1.9,4.6-1.9s3.3,0.6,4.6,1.9c1.3,1.3,1.9,2.8,1.9,4.6c0,1.8-0.6,3.3-1.9,4.6\r\n                C40.6,51.7,39.1,52.3,37.3,52.3z\"/>\r\n        </g>\r\n    </svg>\r\n\r\n    <svg *ngSwitchCase=\"isIcon('audio')\" viewBox=\"0 0 96 96\">\r\n        <g>\r\n            <path d=\"M71.4,30.7c0.6,0.6,1.2,1.5,1.6,2.5c0.4,1.1,0.7,2.1,0.7,2.9v38.6c0,0.9-0.3,1.7-0.9,2.3\r\n                S71.4,78,70.5,78h-45c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V21.2c0-0.9,0.3-1.7,0.9-2.3c0.6-0.6,1.4-0.9,2.3-0.9h30\r\n                c0.9,0,1.9,0.2,2.9,0.7c1.1,0.4,1.9,1,2.5,1.6L71.4,30.7z M56.6,22.6v12.6h12.6c-0.2-0.6-0.5-1.1-0.7-1.4L57.9,23.3\r\n                C57.7,23,57.2,22.8,56.6,22.6z M69.4,73.7V39.4H55.5c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V22.3H26.6v51.4H69.4z\r\n                M43,46.5c0.4,0.2,0.7,0.5,0.7,1v18.2c0,0.5-0.2,0.8-0.7,1c-0.2,0-0.3,0.1-0.4,0.1c-0.3,0-0.5-0.1-0.8-0.3l-5.6-5.6h-4.4\r\n                c-0.3,0-0.6-0.1-0.8-0.3c-0.2-0.2-0.3-0.5-0.3-0.8v-6.4c0-0.3,0.1-0.6,0.3-0.8c0.2-0.2,0.5-0.3,0.8-0.3h4.4l5.6-5.6\r\n                C42.2,46.4,42.6,46.3,43,46.5z M57,69.5c0.7,0,1.3-0.3,1.7-0.8c2.9-3.5,4.3-7.6,4.3-12.2s-1.4-8.6-4.3-12.2\r\n                c-0.4-0.5-0.8-0.7-1.4-0.8c-0.6-0.1-1.1,0.1-1.6,0.5c-0.5,0.4-0.7,0.9-0.8,1.5c-0.1,0.6,0.1,1.1,0.5,1.6c2.2,2.7,3.3,5.9,3.3,9.4\r\n                c0,3.5-1.1,6.7-3.3,9.4c-0.4,0.5-0.5,1-0.5,1.6c0.1,0.6,0.3,1.1,0.8,1.4C56.1,69.4,56.5,69.5,57,69.5z M49.9,64.6\r\n                c0.6,0,1.1-0.2,1.6-0.7c1.9-2.1,2.9-4.5,2.9-7.3s-1-5.3-2.9-7.3c-0.4-0.4-0.9-0.6-1.5-0.7c-0.6,0-1.1,0.2-1.5,0.6s-0.6,0.9-0.7,1.5\r\n                c0,0.6,0.2,1.1,0.6,1.6c1.2,1.3,1.7,2.7,1.7,4.4c0,1.7-0.6,3.1-1.7,4.4c-0.4,0.4-0.6,1-0.6,1.6c0,0.6,0.2,1.1,0.7,1.5\r\n                C48.9,64.4,49.4,64.6,49.9,64.6z\"/>\r\n        </g>\r\n    </svg>\r\n\r\n    <svg *ngSwitchCase=\"isIcon('text')\" viewBox=\"0 0 96 96\">\r\n        <g>\r\n            <path d=\"M71.4,30.7c0.6,0.6,1.2,1.5,1.6,2.5c0.4,1.1,0.7,2.1,0.7,2.9v38.6c0,0.9-0.3,1.7-0.9,2.3\r\n                S71.4,78,70.5,78h-45c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V21.2c0-0.9,0.3-1.7,0.9-2.3c0.6-0.6,1.4-0.9,2.3-0.9h30\r\n                c0.9,0,1.9,0.2,2.9,0.7c1.1,0.4,1.9,1,2.5,1.6L71.4,30.7z M56.6,22.6v12.6h12.6c-0.2-0.6-0.5-1.1-0.7-1.4L57.9,23.3\r\n                C57.7,23,57.2,22.8,56.6,22.6z M69.4,73.7V39.4H55.5c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V22.3H26.6v51.4H69.4z\r\n                M35.1,44.8c0-0.3,0.1-0.6,0.3-0.8c0.2-0.2,0.5-0.3,0.8-0.3h23.6c0.3,0,0.6,0.1,0.8,0.3c0.2,0.2,0.3,0.5,0.3,0.8v2.1\r\n                c0,0.3-0.1,0.6-0.3,0.8c-0.2,0.2-0.5,0.3-0.8,0.3H36.2c-0.3,0-0.6-0.1-0.8-0.3c-0.2-0.2-0.3-0.5-0.3-0.8V44.8z M59.8,52.3\r\n                c0.3,0,0.6,0.1,0.8,0.3c0.2,0.2,0.3,0.5,0.3,0.8v2.1c0,0.3-0.1,0.6-0.3,0.8c-0.2,0.2-0.5,0.3-0.8,0.3H36.2c-0.3,0-0.6-0.1-0.8-0.3\r\n                c-0.2-0.2-0.3-0.5-0.3-0.8v-2.1c0-0.3,0.1-0.6,0.3-0.8c0.2-0.2,0.5-0.3,0.8-0.3H59.8z M59.8,60.9c0.3,0,0.6,0.1,0.8,0.3\r\n                c0.2,0.2,0.3,0.5,0.3,0.8v2.1c0,0.3-0.1,0.6-0.3,0.8c-0.2,0.2-0.5,0.3-0.8,0.3H36.2c-0.3,0-0.6-0.1-0.8-0.3\r\n                c-0.2-0.2-0.3-0.5-0.3-0.8v-2.1c0-0.3,0.1-0.6,0.3-0.8c0.2-0.2,0.5-0.3,0.8-0.3H59.8z\"/>\r\n        </g>\r\n    </svg>\r\n\r\n    <svg *ngSwitchCase=\"isIcon('video')\" viewBox=\"0 0 96 96\">\r\n        <g>\r\n            <path d=\"M71.4,30.7c0.6,0.6,1.2,1.5,1.6,2.5c0.4,1.1,0.7,2.1,0.7,2.9v38.6c0,0.9-0.3,1.7-0.9,2.3\r\n                S71.4,78,70.5,78h-45c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V21.2c0-0.9,0.3-1.7,0.9-2.3c0.6-0.6,1.4-0.9,2.3-0.9h30\r\n                c0.9,0,1.9,0.2,2.9,0.7c1.1,0.4,1.9,1,2.5,1.6L71.4,30.7z M56.6,22.6v12.6h12.6c-0.2-0.6-0.5-1.1-0.7-1.4L57.9,23.3\r\n                C57.7,23,57.2,22.8,56.6,22.6z M69.4,73.7V39.4H55.5c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V22.3H26.6v51.4H69.4z\r\n                M48,43.7c1.2,0,2.2,0.4,3,1.3c0.8,0.8,1.3,1.9,1.3,3v12.9c0,1.2-0.4,2.2-1.3,3c-0.8,0.8-1.9,1.3-3,1.3H35.1c-1.2,0-2.2-0.4-3-1.3\r\n                c-0.8-0.8-1.3-1.9-1.3-3V48c0-1.2,0.4-2.2,1.3-3c0.8-0.8,1.9-1.3,3-1.3H48z M64.5,43.8c0.4,0.2,0.7,0.5,0.7,1v19.3\r\n                c0,0.5-0.2,0.8-0.7,1c-0.2,0-0.3,0.1-0.4,0.1c-0.3,0-0.6-0.1-0.8-0.3l-8.9-8.9v-3l8.9-8.9c0.2-0.2,0.5-0.3,0.8-0.3\r\n                C64.2,43.7,64.3,43.7,64.5,43.8z\"/>\r\n        </g>\r\n    </svg>\r\n\r\n</ng-container>`,\r\n    styles: [`:host{display:block;border:1px solid #eaeaea;border-radius:4px}:host svg{fill:#909293}`]\r\n})\r\nexport class FileUploadIconComponent implements OnInit {\r\n\r\n    @Input()\r\n    public file: File;\r\n\r\n    public fileType: string = 'unknown';\r\n\r\n    constructor(private fileUploadService: FileUploadService) {\r\n    }\r\n\r\n    public ngOnInit(): void {\r\n        this.fileType = this.fileUploadService.getFileType(this.file);\r\n    }\r\n\r\n    public isIcon(type: 'text' | 'audio' | 'video' | 'image'): boolean {\r\n        switch (type) {\r\n            case 'text':\r\n                return this.fileType === 'html' || this.fileType === 'css' ||\r\n                    this.fileType === 'csv' || this.fileType === 'js' ||\r\n                    this.fileType === 'pdf' || this.fileType === 'ppt' ||\r\n                    this.fileType === 'xls' || this.fileType === 'xlsx' ||\r\n                    this.fileType === 'xml' || this.fileType === 'doc' ||\r\n                    this.fileType === 'docx';\r\n            case 'audio':\r\n                return this.fileType === 'aac' || this.fileType === 'midi' ||\r\n                    this.fileType === 'oga' || this.fileType === 'wav' ||\r\n                    this.fileType === 'weba';\r\n            case 'image':\r\n                return this.fileType === 'png' || this.fileType === 'bmp' ||\r\n                    this.fileType === 'gif' || this.fileType === 'jpg' ||\r\n                    this.fileType === 'svg' || this.fileType === 'webp' ||\r\n                    this.fileType === 'ico';\r\n            case 'video':\r\n                return this.fileType === 'avi' || this.fileType === 'mpeg' ||\r\n                    this.fileType === 'ogv' || this.fileType === 'webm' ||\r\n                    this.fileType === '3gp' || this.fileType === '3g2';\r\n        }\r\n    }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload-icon.component.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["components/file-upload-icon.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,mCAAmC,CAAC;AAGtE;IAkFI,iCAAoB,iBAAoC;QAApC,sBAAiB,GAAjB,iBAAiB,CAAmB;QAFjD,aAAQ,GAAW,SAAS,CAAC;IAGpC,CAAC;;;;IAEM,0CAAQ;;;IAAf;QACI,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAClE,CAAC;;;;;IAEM,wCAAM;;;;IAAb,UAAc,IAA0C;QACpD,QAAQ,IAAI,EAAE;YACV,KAAK,MAAM;gBACP,OAAO,IAAI,CAAC,QAAQ,KAAK,MAAM,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK;oBACtD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI;oBACjD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK;oBAClD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM;oBACnD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK;oBAClD,IAAI,CAAC,QAAQ,KAAK,MAAM,CAAC;YACjC,KAAK,OAAO;gBACR,OAAO,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM;oBACtD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK;oBAClD,IAAI,CAAC,QAAQ,KAAK,MAAM,CAAC;YACjC,KAAK,OAAO;gBACR,OAAO,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK;oBACrD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK;oBAClD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM;oBACnD,IAAI,CAAC,QAAQ,KAAK,KAAK,CAAC;YAChC,KAAK,OAAO;gBACR,OAAO,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM;oBACtD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM;oBACnD,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK,CAAC;SAC9D;IACL,CAAC;;gBAhHJ,SAAS,SAAC;oBACP,QAAQ,EAAE,kBAAkB;oBAC5B,QAAQ,EAAE,siLAsEE;oBACZ,MAAM,EAAE,CAAC,wFAAwF,CAAC;iBACrG;;;;gBA7EQ,iBAAiB;;;uBAgFrB,KAAK;;IAoCV,8BAAC;CAAA,AAjHD,IAiHC;SAtCY,uBAAuB;;;IAEhC,uCACkB;;IAElB,2CAAoC;;IAExB,oDAA4C","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\r\nimport { FileUploadService } from './../services/file-upload.service';\r\n\r\n\r\n@Component({\r\n    selector: `file-upload-icon`,\r\n    template: `\r\n\r\n<ng-container [ngSwitch]=\"true\">\r\n\r\n    <svg *ngSwitchDefault viewBox=\"0 0 96 96\">\r\n        <g>\r\n            <path d=\"M71.4,30.7c0.6,0.6,1.2,1.5,1.6,2.5c0.4,1.1,0.7,2.1,0.7,2.9v38.6c0,0.9-0.3,1.7-0.9,2.3\r\n                S71.4,78,70.5,78h-45c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V21.2c0-0.9,0.3-1.7,0.9-2.3c0.6-0.6,1.4-0.9,2.3-0.9h30\r\n                c0.9,0,1.9,0.2,2.9,0.7c1.1,0.4,1.9,1,2.5,1.6L71.4,30.7z M56.6,22.6v12.6h12.6c-0.2-0.6-0.5-1.1-0.7-1.4L57.9,23.3\r\n                C57.7,23,57.2,22.8,56.6,22.6z M69.4,73.7V39.4H55.5c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V22.3H26.6v51.4H69.4z\"/>\r\n        </g>\r\n    </svg>\r\n\r\n    <svg *ngSwitchCase=\"isIcon('image')\" viewBox=\"0 0 96 96\">\r\n        <g>\r\n            <path d=\"M71.4,30.7c0.6,0.6,1.2,1.5,1.6,2.5c0.4,1.1,0.7,2.1,0.7,2.9v38.6c0,0.9-0.3,1.7-0.9,2.3\r\n                S71.4,78,70.5,78h-45c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V21.2c0-0.9,0.3-1.7,0.9-2.3c0.6-0.6,1.4-0.9,2.3-0.9h30\r\n                c0.9,0,1.9,0.2,2.9,0.7c1.1,0.4,1.9,1,2.5,1.6L71.4,30.7z M56.6,22.6v12.6h12.6c-0.2-0.6-0.5-1.1-0.7-1.4L57.9,23.3\r\n                C57.7,23,57.2,22.8,56.6,22.6z M69.4,73.7V39.4H55.5c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V22.3H26.6v51.4H69.4z\r\n                M65.1,58.7v10.7H30.9V63l6.4-6.4l4.3,4.3L54.4,48L65.1,58.7z M37.3,52.3c-1.8,0-3.3-0.6-4.6-1.9c-1.3-1.2-1.9-2.8-1.9-4.6\r\n                c0-1.8,0.6-3.3,1.9-4.6c1.3-1.2,2.8-1.9,4.6-1.9s3.3,0.6,4.6,1.9c1.3,1.3,1.9,2.8,1.9,4.6c0,1.8-0.6,3.3-1.9,4.6\r\n                C40.6,51.7,39.1,52.3,37.3,52.3z\"/>\r\n        </g>\r\n    </svg>\r\n\r\n    <svg *ngSwitchCase=\"isIcon('audio')\" viewBox=\"0 0 96 96\">\r\n        <g>\r\n            <path d=\"M71.4,30.7c0.6,0.6,1.2,1.5,1.6,2.5c0.4,1.1,0.7,2.1,0.7,2.9v38.6c0,0.9-0.3,1.7-0.9,2.3\r\n                S71.4,78,70.5,78h-45c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V21.2c0-0.9,0.3-1.7,0.9-2.3c0.6-0.6,1.4-0.9,2.3-0.9h30\r\n                c0.9,0,1.9,0.2,2.9,0.7c1.1,0.4,1.9,1,2.5,1.6L71.4,30.7z M56.6,22.6v12.6h12.6c-0.2-0.6-0.5-1.1-0.7-1.4L57.9,23.3\r\n                C57.7,23,57.2,22.8,56.6,22.6z M69.4,73.7V39.4H55.5c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V22.3H26.6v51.4H69.4z\r\n                M43,46.5c0.4,0.2,0.7,0.5,0.7,1v18.2c0,0.5-0.2,0.8-0.7,1c-0.2,0-0.3,0.1-0.4,0.1c-0.3,0-0.5-0.1-0.8-0.3l-5.6-5.6h-4.4\r\n                c-0.3,0-0.6-0.1-0.8-0.3c-0.2-0.2-0.3-0.5-0.3-0.8v-6.4c0-0.3,0.1-0.6,0.3-0.8c0.2-0.2,0.5-0.3,0.8-0.3h4.4l5.6-5.6\r\n                C42.2,46.4,42.6,46.3,43,46.5z M57,69.5c0.7,0,1.3-0.3,1.7-0.8c2.9-3.5,4.3-7.6,4.3-12.2s-1.4-8.6-4.3-12.2\r\n                c-0.4-0.5-0.8-0.7-1.4-0.8c-0.6-0.1-1.1,0.1-1.6,0.5c-0.5,0.4-0.7,0.9-0.8,1.5c-0.1,0.6,0.1,1.1,0.5,1.6c2.2,2.7,3.3,5.9,3.3,9.4\r\n                c0,3.5-1.1,6.7-3.3,9.4c-0.4,0.5-0.5,1-0.5,1.6c0.1,0.6,0.3,1.1,0.8,1.4C56.1,69.4,56.5,69.5,57,69.5z M49.9,64.6\r\n                c0.6,0,1.1-0.2,1.6-0.7c1.9-2.1,2.9-4.5,2.9-7.3s-1-5.3-2.9-7.3c-0.4-0.4-0.9-0.6-1.5-0.7c-0.6,0-1.1,0.2-1.5,0.6s-0.6,0.9-0.7,1.5\r\n                c0,0.6,0.2,1.1,0.6,1.6c1.2,1.3,1.7,2.7,1.7,4.4c0,1.7-0.6,3.1-1.7,4.4c-0.4,0.4-0.6,1-0.6,1.6c0,0.6,0.2,1.1,0.7,1.5\r\n                C48.9,64.4,49.4,64.6,49.9,64.6z\"/>\r\n        </g>\r\n    </svg>\r\n\r\n    <svg *ngSwitchCase=\"isIcon('text')\" viewBox=\"0 0 96 96\">\r\n        <g>\r\n            <path d=\"M71.4,30.7c0.6,0.6,1.2,1.5,1.6,2.5c0.4,1.1,0.7,2.1,0.7,2.9v38.6c0,0.9-0.3,1.7-0.9,2.3\r\n                S71.4,78,70.5,78h-45c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V21.2c0-0.9,0.3-1.7,0.9-2.3c0.6-0.6,1.4-0.9,2.3-0.9h30\r\n                c0.9,0,1.9,0.2,2.9,0.7c1.1,0.4,1.9,1,2.5,1.6L71.4,30.7z M56.6,22.6v12.6h12.6c-0.2-0.6-0.5-1.1-0.7-1.4L57.9,23.3\r\n                C57.7,23,57.2,22.8,56.6,22.6z M69.4,73.7V39.4H55.5c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V22.3H26.6v51.4H69.4z\r\n                M35.1,44.8c0-0.3,0.1-0.6,0.3-0.8c0.2-0.2,0.5-0.3,0.8-0.3h23.6c0.3,0,0.6,0.1,0.8,0.3c0.2,0.2,0.3,0.5,0.3,0.8v2.1\r\n                c0,0.3-0.1,0.6-0.3,0.8c-0.2,0.2-0.5,0.3-0.8,0.3H36.2c-0.3,0-0.6-0.1-0.8-0.3c-0.2-0.2-0.3-0.5-0.3-0.8V44.8z M59.8,52.3\r\n                c0.3,0,0.6,0.1,0.8,0.3c0.2,0.2,0.3,0.5,0.3,0.8v2.1c0,0.3-0.1,0.6-0.3,0.8c-0.2,0.2-0.5,0.3-0.8,0.3H36.2c-0.3,0-0.6-0.1-0.8-0.3\r\n                c-0.2-0.2-0.3-0.5-0.3-0.8v-2.1c0-0.3,0.1-0.6,0.3-0.8c0.2-0.2,0.5-0.3,0.8-0.3H59.8z M59.8,60.9c0.3,0,0.6,0.1,0.8,0.3\r\n                c0.2,0.2,0.3,0.5,0.3,0.8v2.1c0,0.3-0.1,0.6-0.3,0.8c-0.2,0.2-0.5,0.3-0.8,0.3H36.2c-0.3,0-0.6-0.1-0.8-0.3\r\n                c-0.2-0.2-0.3-0.5-0.3-0.8v-2.1c0-0.3,0.1-0.6,0.3-0.8c0.2-0.2,0.5-0.3,0.8-0.3H59.8z\"/>\r\n        </g>\r\n    </svg>\r\n\r\n    <svg *ngSwitchCase=\"isIcon('video')\" viewBox=\"0 0 96 96\">\r\n        <g>\r\n            <path d=\"M71.4,30.7c0.6,0.6,1.2,1.5,1.6,2.5c0.4,1.1,0.7,2.1,0.7,2.9v38.6c0,0.9-0.3,1.7-0.9,2.3\r\n                S71.4,78,70.5,78h-45c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V21.2c0-0.9,0.3-1.7,0.9-2.3c0.6-0.6,1.4-0.9,2.3-0.9h30\r\n                c0.9,0,1.9,0.2,2.9,0.7c1.1,0.4,1.9,1,2.5,1.6L71.4,30.7z M56.6,22.6v12.6h12.6c-0.2-0.6-0.5-1.1-0.7-1.4L57.9,23.3\r\n                C57.7,23,57.2,22.8,56.6,22.6z M69.4,73.7V39.4H55.5c-0.9,0-1.7-0.3-2.3-0.9c-0.6-0.6-0.9-1.4-0.9-2.3V22.3H26.6v51.4H69.4z\r\n                M48,43.7c1.2,0,2.2,0.4,3,1.3c0.8,0.8,1.3,1.9,1.3,3v12.9c0,1.2-0.4,2.2-1.3,3c-0.8,0.8-1.9,1.3-3,1.3H35.1c-1.2,0-2.2-0.4-3-1.3\r\n                c-0.8-0.8-1.3-1.9-1.3-3V48c0-1.2,0.4-2.2,1.3-3c0.8-0.8,1.9-1.3,3-1.3H48z M64.5,43.8c0.4,0.2,0.7,0.5,0.7,1v19.3\r\n                c0,0.5-0.2,0.8-0.7,1c-0.2,0-0.3,0.1-0.4,0.1c-0.3,0-0.6-0.1-0.8-0.3l-8.9-8.9v-3l8.9-8.9c0.2-0.2,0.5-0.3,0.8-0.3\r\n                C64.2,43.7,64.3,43.7,64.5,43.8z\"/>\r\n        </g>\r\n    </svg>\r\n\r\n</ng-container>`,\r\n    styles: [`:host{display:block;border:1px solid #eaeaea;border-radius:4px}:host svg{fill:#909293}`]\r\n})\r\nexport class FileUploadIconComponent implements OnInit {\r\n\r\n    @Input()\r\n    public file: File;\r\n\r\n    public fileType: string = 'unknown';\r\n\r\n    constructor(private fileUploadService: FileUploadService) {\r\n    }\r\n\r\n    public ngOnInit(): void {\r\n        this.fileType = this.fileUploadService.getFileType(this.file);\r\n    }\r\n\r\n    public isIcon(type: 'text' | 'audio' | 'video' | 'image'): boolean {\r\n        switch (type) {\r\n            case 'text':\r\n                return this.fileType === 'html' || this.fileType === 'css' ||\r\n                    this.fileType === 'csv' || this.fileType === 'js' ||\r\n                    this.fileType === 'pdf' || this.fileType === 'ppt' ||\r\n                    this.fileType === 'xls' || this.fileType === 'xlsx' ||\r\n                    this.fileType === 'xml' || this.fileType === 'doc' ||\r\n                    this.fileType === 'docx';\r\n            case 'audio':\r\n                return this.fileType === 'aac' || this.fileType === 'midi' ||\r\n                    this.fileType === 'oga' || this.fileType === 'wav' ||\r\n                    this.fileType === 'weba';\r\n            case 'image':\r\n                return this.fileType === 'png' || this.fileType === 'bmp' ||\r\n                    this.fileType === 'gif' || this.fileType === 'jpg' ||\r\n                    this.fileType === 'svg' || this.fileType === 'webp' ||\r\n                    this.fileType === 'ico';\r\n            case 'video':\r\n                return this.fileType === 'avi' || this.fileType === 'mpeg' ||\r\n                    this.fileType === 'ogv' || this.fileType === 'webm' ||\r\n                    this.fileType === '3gp' || this.fileType === '3g2';\r\n        }\r\n    }\r\n}\r\n"]}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/

@@ -53,3 +53,3 @@ import { Component, Input } from '@angular/core';

export { FileUploadListItemComponent };
function FileUploadListItemComponent_tsickle_Closure_declarations() {
if (false) {
/** @type {?} */

@@ -64,3 +64,2 @@ FileUploadListItemComponent.prototype.index;

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQtbGlzdC1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BpcGxhYi9uZ3gtZmlsZS11cGxvYWQvIiwic291cmNlcyI6WyJjb21wb25lbnRzL2ZpbGUtdXBsb2FkLWxpc3QtaXRlbS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQy9ELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDOztJQXVDbEUscUNBQW9CLGlCQUFvQztRQUFwQyxzQkFBaUIsR0FBakIsaUJBQWlCLENBQW1CO0tBQ3ZEOzs7OztJQUVNLGdEQUFVOzs7O2NBQUMsSUFBVTtRQUN4QixJQUFJLENBQUMsT0FBTyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQzs7Ozs7O0lBRzNCLG1EQUFhOzs7O2NBQUMsSUFBWTtRQUM5QixNQUFNLENBQUMsSUFBSSxDQUFDLGlCQUFpQixDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQzs7O2dCQTdDeEQsU0FBUyxTQUFDO29CQUNQLFFBQVEsRUFBRSx1QkFBdUI7b0JBQ2pDLFFBQVEsRUFBRSxpbkRBcUJUO29CQUNELE1BQU0sRUFBRSxDQUFDLHlWQUF1VixDQUFDO2lCQUNwVzs7OztnQkEzQlEsaUJBQWlCOzs7d0JBOEJyQixLQUFLO3VCQUdMLEtBQUs7MEJBR0wsS0FBSzs7c0NBdENWOztTQThCYSwyQkFBMkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEZpbGVVcGxvYWRDb250cm9sIH0gZnJvbSAnLi8uLi9oZWxwZXJzL2NvbnRyb2wuY2xhc3MnO1xyXG5pbXBvcnQgeyBGaWxlVXBsb2FkU2VydmljZSB9IGZyb20gJy4vLi4vc2VydmljZXMvZmlsZS11cGxvYWQuc2VydmljZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiBgZmlsZS11cGxvYWQtbGlzdC1pdGVtYCxcclxuICAgIHRlbXBsYXRlOiBgXHJcbiAgICA8ZmlsZS11cGxvYWQtaWNvbiBbZmlsZV09XCJmaWxlXCI+PC9maWxlLXVwbG9hZC1pY29uPlxyXG4gICAgPGRpdiBjbGFzcz1cImZpbGUtaW5mb1wiPlxyXG4gICAgICAgIDxzcGFuIGNsYXNzPVwiZmlsZS1uYW1lXCI+e3sgZmlsZS5uYW1lIH19PC9zcGFuPiAoe3sgY2FsY3VsYXRlU2l6ZSggZmlsZS5zaXplICkgfX0pXHJcbiAgICA8L2Rpdj5cclxuICAgIDxkaXYgY2xhc3M9XCJmaWxlLWJ1dHRvbnNcIj5cclxuICAgICAgICA8c3BhbiBjbGFzcz1cInJlbW92ZS1idG5cIiAoY2xpY2spPVwicmVtb3ZlRmlsZShmaWxlKVwiPlxyXG4gICAgICAgIDxzdmcgdmlld0JveD1cIjAgMCA5NiA5NlwiPlxyXG4gICAgICAgICAgICA8Zz5cclxuICAgICAgICAgICAgICAgIDxwYXRoIGQ9XCJNNDAuNSw2Ni44VjM5LjNjMC0wLjQtMC4xLTAuNy0wLjQtMC45UzM5LjYsMzgsMzkuMywzOGgtMi41Yy0wLjQsMC0wLjcsMC4xLTAuOSwwLjRcclxuICAgICAgICAgICAgICAgICAgICBzLTAuNCwwLjUtMC40LDAuOXYyNy41YzAsMC40LDAuMSwwLjcsMC40LDAuOXMwLjUsMC40LDAuOSwwLjRoMi41YzAuNCwwLDAuNy0wLjEsMC45LTAuNFM0MC41LDY3LjEsNDAuNSw2Ni44eiBNNTAuNSw2Ni44VjM5LjNcclxuICAgICAgICAgICAgICAgICAgICBjMC0wLjQtMC4xLTAuNy0wLjQtMC45UzQ5LjYsMzgsNDkuMywzOGgtMi41Yy0wLjQsMC0wLjcsMC4xLTAuOSwwLjRzLTAuNCwwLjUtMC40LDAuOXYyNy41YzAsMC40LDAuMSwwLjcsMC40LDAuOXMwLjUsMC40LDAuOSwwLjRcclxuICAgICAgICAgICAgICAgICAgICBoMi41YzAuNCwwLDAuNy0wLjEsMC45LTAuNFM1MC41LDY3LjEsNTAuNSw2Ni44eiBNNjAuNSw2Ni44VjM5LjNjMC0wLjQtMC4xLTAuNy0wLjQtMC45UzU5LjYsMzgsNTkuMywzOGgtMi41XHJcbiAgICAgICAgICAgICAgICAgICAgYy0wLjQsMC0wLjcsMC4xLTAuOSwwLjRzLTAuNCwwLjUtMC40LDAuOXYyNy41YzAsMC40LDAuMSwwLjcsMC40LDAuOXMwLjUsMC40LDAuOSwwLjRoMi41YzAuNCwwLDAuNy0wLjEsMC45LTAuNFxyXG4gICAgICAgICAgICAgICAgICAgIFM2MC41LDY3LjEsNjAuNSw2Ni44eiBNMzkuMywyOGgxNy41bC0xLjktNC42Yy0wLjItMC4yLTAuNC0wLjQtMC43LTAuNEg0MS44Yy0wLjMsMC4xLTAuNSwwLjItMC43LDAuNEwzOS4zLDI4eiBNNzUuNSwyOS4zdjIuNVxyXG4gICAgICAgICAgICAgICAgICAgIGMwLDAuNC0wLjEsMC43LTAuNCwwLjlTNzQuNiwzMyw3NC4zLDMzaC0zLjh2MzdjMCwyLjItMC42LDQtMS44LDUuNlM2Niw3OCw2NC4zLDc4SDMxLjhjLTEuNywwLTMuMi0wLjgtNC40LTIuM3MtMS44LTMuNC0xLjgtNS41XHJcbiAgICAgICAgICAgICAgICAgICAgVjMzaC0zLjhjLTAuNCwwLTAuNy0wLjEtMC45LTAuNHMtMC40LTAuNS0wLjQtMC45di0yLjVjMC0wLjQsMC4xLTAuNywwLjQtMC45czAuNS0wLjQsMC45LTAuNGgxMi4xbDIuNy02LjVjMC40LTEsMS4xLTEuOCwyLjEtMi41XHJcbiAgICAgICAgICAgICAgICAgICAgczItMSwzLjEtMWgxMi41YzEsMCwyLjEsMC4zLDMuMSwxczEuNywxLjUsMi4xLDIuNWwyLjcsNi41aDEyLjFjMC40LDAsMC43LDAuMSwwLjksMC40Uzc1LjUsMjguOSw3NS41LDI5LjN6XCIvPlxyXG4gICAgICAgICAgICA8L2c+XHJcbiAgICAgICAgPC9zdmc+IFJlbW92ZTwvc3Bhbj5cclxuICAgIDwvZGl2PlxyXG4gICAgYCxcclxuICAgIHN0eWxlczogW2A6aG9zdHtkaXNwbGF5OmJsb2NrO2ZvbnQtc2l6ZToxNHB4O2NvbG9yOiM2NDY0NjR9Omhvc3Q6YWZ0ZXJ7Y2xlYXI6Ym90aDtjb250ZW50OlwiXFxcXDBBMFwiO2Rpc3BsYXk6YmxvY2s7aGVpZ2h0OjA7bGluZS1oZWlnaHQ6MDt2aXNpYmlsaXR5OmhpZGRlbjt6b29tOjF9ZmlsZS11cGxvYWQtaWNvbntmbG9hdDpsZWZ0O3dpZHRoOjMwcHg7aGVpZ2h0OjM2cHg7bWFyZ2luOjAgMTBweCAwIDB9LnJlbW92ZS1idG57Zm9udC1zaXplOjEycHg7Y3Vyc29yOnBvaW50ZXJ9LnJlbW92ZS1idG4gc3Zne2Rpc3BsYXk6aW5saW5lLWJsb2NrO3ZlcnRpY2FsLWFsaWduOi0yMCU7aGVpZ2h0OjE4cHg7d2lkdGg6MThweH1gXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgRmlsZVVwbG9hZExpc3RJdGVtQ29tcG9uZW50IHtcclxuXHJcbiAgICBASW5wdXQoKVxyXG4gICAgcHVibGljIGluZGV4OiBudW1iZXI7XHJcblxyXG4gICAgQElucHV0KClcclxuICAgIHB1YmxpYyBmaWxlOiBGaWxlO1xyXG5cclxuICAgIEBJbnB1dCgpXHJcbiAgICBwdWJsaWMgY29udHJvbDogRmlsZVVwbG9hZENvbnRyb2w7XHJcblxyXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBmaWxlVXBsb2FkU2VydmljZTogRmlsZVVwbG9hZFNlcnZpY2UpIHtcclxuICAgIH1cclxuXHJcbiAgICBwdWJsaWMgcmVtb3ZlRmlsZShmaWxlOiBGaWxlKTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5jb250cm9sLnJlbW92ZUZpbGUoZmlsZSk7XHJcbiAgICB9XHJcblxyXG4gICAgcHVibGljIGNhbGN1bGF0ZVNpemUoc2l6ZTogbnVtYmVyKTogc3RyaW5nIHtcclxuICAgICAgIHJldHVybiB0aGlzLmZpbGVVcGxvYWRTZXJ2aWNlLmNhbGN1bGF0ZVNpemUoc2l6ZSk7XHJcbiAgICB9XHJcbn0iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQtbGlzdC1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BpcGxhYi9uZ3gtZmlsZS11cGxvYWQvIiwic291cmNlcyI6WyJjb21wb25lbnRzL2ZpbGUtdXBsb2FkLWxpc3QtaXRlbS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQy9ELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBRXRFO0lBcUNJLHFDQUFvQixpQkFBb0M7UUFBcEMsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFtQjtJQUN4RCxDQUFDOzs7OztJQUVNLGdEQUFVOzs7O0lBQWpCLFVBQWtCLElBQVU7UUFDeEIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDbEMsQ0FBQzs7Ozs7SUFFTSxtREFBYTs7OztJQUFwQixVQUFxQixJQUFZO1FBQzlCLE9BQU8sSUFBSSxDQUFDLGlCQUFpQixDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNyRCxDQUFDOztnQkE5Q0osU0FBUyxTQUFDO29CQUNQLFFBQVEsRUFBRSx1QkFBdUI7b0JBQ2pDLFFBQVEsRUFBRSxpbkRBcUJUO29CQUNELE1BQU0sRUFBRSxDQUFDLHlWQUF1VixDQUFDO2lCQUNwVzs7OztnQkEzQlEsaUJBQWlCOzs7d0JBOEJyQixLQUFLO3VCQUdMLEtBQUs7MEJBR0wsS0FBSzs7SUFhVixrQ0FBQztDQUFBLEFBL0NELElBK0NDO1NBckJZLDJCQUEyQjs7O0lBRXBDLDRDQUNxQjs7SUFFckIsMkNBQ2tCOztJQUVsQiw4Q0FDa0M7O0lBRXRCLHdEQUE0QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRmlsZVVwbG9hZENvbnRyb2wgfSBmcm9tICcuLy4uL2hlbHBlcnMvY29udHJvbC5jbGFzcyc7XHJcbmltcG9ydCB7IEZpbGVVcGxvYWRTZXJ2aWNlIH0gZnJvbSAnLi8uLi9zZXJ2aWNlcy9maWxlLXVwbG9hZC5zZXJ2aWNlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6IGBmaWxlLXVwbG9hZC1saXN0LWl0ZW1gLFxyXG4gICAgdGVtcGxhdGU6IGBcclxuICAgIDxmaWxlLXVwbG9hZC1pY29uIFtmaWxlXT1cImZpbGVcIj48L2ZpbGUtdXBsb2FkLWljb24+XHJcbiAgICA8ZGl2IGNsYXNzPVwiZmlsZS1pbmZvXCI+XHJcbiAgICAgICAgPHNwYW4gY2xhc3M9XCJmaWxlLW5hbWVcIj57eyBmaWxlLm5hbWUgfX08L3NwYW4+ICh7eyBjYWxjdWxhdGVTaXplKCBmaWxlLnNpemUgKSB9fSlcclxuICAgIDwvZGl2PlxyXG4gICAgPGRpdiBjbGFzcz1cImZpbGUtYnV0dG9uc1wiPlxyXG4gICAgICAgIDxzcGFuIGNsYXNzPVwicmVtb3ZlLWJ0blwiIChjbGljayk9XCJyZW1vdmVGaWxlKGZpbGUpXCI+XHJcbiAgICAgICAgPHN2ZyB2aWV3Qm94PVwiMCAwIDk2IDk2XCI+XHJcbiAgICAgICAgICAgIDxnPlxyXG4gICAgICAgICAgICAgICAgPHBhdGggZD1cIk00MC41LDY2LjhWMzkuM2MwLTAuNC0wLjEtMC43LTAuNC0wLjlTMzkuNiwzOCwzOS4zLDM4aC0yLjVjLTAuNCwwLTAuNywwLjEtMC45LDAuNFxyXG4gICAgICAgICAgICAgICAgICAgIHMtMC40LDAuNS0wLjQsMC45djI3LjVjMCwwLjQsMC4xLDAuNywwLjQsMC45czAuNSwwLjQsMC45LDAuNGgyLjVjMC40LDAsMC43LTAuMSwwLjktMC40UzQwLjUsNjcuMSw0MC41LDY2Ljh6IE01MC41LDY2LjhWMzkuM1xyXG4gICAgICAgICAgICAgICAgICAgIGMwLTAuNC0wLjEtMC43LTAuNC0wLjlTNDkuNiwzOCw0OS4zLDM4aC0yLjVjLTAuNCwwLTAuNywwLjEtMC45LDAuNHMtMC40LDAuNS0wLjQsMC45djI3LjVjMCwwLjQsMC4xLDAuNywwLjQsMC45czAuNSwwLjQsMC45LDAuNFxyXG4gICAgICAgICAgICAgICAgICAgIGgyLjVjMC40LDAsMC43LTAuMSwwLjktMC40UzUwLjUsNjcuMSw1MC41LDY2Ljh6IE02MC41LDY2LjhWMzkuM2MwLTAuNC0wLjEtMC43LTAuNC0wLjlTNTkuNiwzOCw1OS4zLDM4aC0yLjVcclxuICAgICAgICAgICAgICAgICAgICBjLTAuNCwwLTAuNywwLjEtMC45LDAuNHMtMC40LDAuNS0wLjQsMC45djI3LjVjMCwwLjQsMC4xLDAuNywwLjQsMC45czAuNSwwLjQsMC45LDAuNGgyLjVjMC40LDAsMC43LTAuMSwwLjktMC40XHJcbiAgICAgICAgICAgICAgICAgICAgUzYwLjUsNjcuMSw2MC41LDY2Ljh6IE0zOS4zLDI4aDE3LjVsLTEuOS00LjZjLTAuMi0wLjItMC40LTAuNC0wLjctMC40SDQxLjhjLTAuMywwLjEtMC41LDAuMi0wLjcsMC40TDM5LjMsMjh6IE03NS41LDI5LjN2Mi41XHJcbiAgICAgICAgICAgICAgICAgICAgYzAsMC40LTAuMSwwLjctMC40LDAuOVM3NC42LDMzLDc0LjMsMzNoLTMuOHYzN2MwLDIuMi0wLjYsNC0xLjgsNS42UzY2LDc4LDY0LjMsNzhIMzEuOGMtMS43LDAtMy4yLTAuOC00LjQtMi4zcy0xLjgtMy40LTEuOC01LjVcclxuICAgICAgICAgICAgICAgICAgICBWMzNoLTMuOGMtMC40LDAtMC43LTAuMS0wLjktMC40cy0wLjQtMC41LTAuNC0wLjl2LTIuNWMwLTAuNCwwLjEtMC43LDAuNC0wLjlzMC41LTAuNCwwLjktMC40aDEyLjFsMi43LTYuNWMwLjQtMSwxLjEtMS44LDIuMS0yLjVcclxuICAgICAgICAgICAgICAgICAgICBzMi0xLDMuMS0xaDEyLjVjMSwwLDIuMSwwLjMsMy4xLDFzMS43LDEuNSwyLjEsMi41bDIuNyw2LjVoMTIuMWMwLjQsMCwwLjcsMC4xLDAuOSwwLjRTNzUuNSwyOC45LDc1LjUsMjkuM3pcIi8+XHJcbiAgICAgICAgICAgIDwvZz5cclxuICAgICAgICA8L3N2Zz4gUmVtb3ZlPC9zcGFuPlxyXG4gICAgPC9kaXY+XHJcbiAgICBgLFxyXG4gICAgc3R5bGVzOiBbYDpob3N0e2Rpc3BsYXk6YmxvY2s7Zm9udC1zaXplOjE0cHg7Y29sb3I6IzY0NjQ2NH06aG9zdDphZnRlcntjbGVhcjpib3RoO2NvbnRlbnQ6XCJcXFxcMEEwXCI7ZGlzcGxheTpibG9jaztoZWlnaHQ6MDtsaW5lLWhlaWdodDowO3Zpc2liaWxpdHk6aGlkZGVuO3pvb206MX1maWxlLXVwbG9hZC1pY29ue2Zsb2F0OmxlZnQ7d2lkdGg6MzBweDtoZWlnaHQ6MzZweDttYXJnaW46MCAxMHB4IDAgMH0ucmVtb3ZlLWJ0bntmb250LXNpemU6MTJweDtjdXJzb3I6cG9pbnRlcn0ucmVtb3ZlLWJ0biBzdmd7ZGlzcGxheTppbmxpbmUtYmxvY2s7dmVydGljYWwtYWxpZ246LTIwJTtoZWlnaHQ6MThweDt3aWR0aDoxOHB4fWBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBGaWxlVXBsb2FkTGlzdEl0ZW1Db21wb25lbnQge1xyXG5cclxuICAgIEBJbnB1dCgpXHJcbiAgICBwdWJsaWMgaW5kZXg6IG51bWJlcjtcclxuXHJcbiAgICBASW5wdXQoKVxyXG4gICAgcHVibGljIGZpbGU6IEZpbGU7XHJcblxyXG4gICAgQElucHV0KClcclxuICAgIHB1YmxpYyBjb250cm9sOiBGaWxlVXBsb2FkQ29udHJvbDtcclxuXHJcbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGZpbGVVcGxvYWRTZXJ2aWNlOiBGaWxlVXBsb2FkU2VydmljZSkge1xyXG4gICAgfVxyXG5cclxuICAgIHB1YmxpYyByZW1vdmVGaWxlKGZpbGU6IEZpbGUpOiB2b2lkIHtcclxuICAgICAgICB0aGlzLmNvbnRyb2wucmVtb3ZlRmlsZShmaWxlKTtcclxuICAgIH1cclxuXHJcbiAgICBwdWJsaWMgY2FsY3VsYXRlU2l6ZShzaXplOiBudW1iZXIpOiBzdHJpbmcge1xyXG4gICAgICAgcmV0dXJuIHRoaXMuZmlsZVVwbG9hZFNlcnZpY2UuY2FsY3VsYXRlU2l6ZShzaXplKTtcclxuICAgIH1cclxufSJdfQ==
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/

@@ -11,4 +11,6 @@ import { Component, Input, ElementRef, HostListener, Renderer2, HostBinding, Inject, TemplateRef, ViewChild, ChangeDetectionStrategy, ContentChild, forwardRef, ChangeDetectorRef } from '@angular/core';

import { FileUploadService } from './../services/file-upload.service';
export var /** @type {?} */ DRAGOVER = 'dragover';
export var /** @type {?} */ TOUCHED = 'ng-touched';
/** @type {?} */
export var DRAGOVER = 'dragover';
/** @type {?} */
export var TOUCHED = 'ng-touched';
var FileUploadComponent = /** @class */ (function () {

@@ -133,2 +135,5 @@ function FileUploadComponent(fileUploadService, hostElementRef, renderer, document, cdr) {

* on file over add class name
*/
/**
* on file over add class name
* @param {?} event

@@ -147,2 +152,5 @@ * @return {?}

* on mouse out remove class name
*/
/**
* on mouse out remove class name
* @param {?} event

@@ -171,3 +179,4 @@ * @return {?}

}
var /** @type {?} */ files = event.dataTransfer.files;
/** @type {?} */
var files = event.dataTransfer.files;
this.control.addFiles(files);

@@ -185,3 +194,4 @@ this.onTouch();

function (event) {
var /** @type {?} */ input = /** @type {?} */ ((event.target));
/** @type {?} */
var input = (/** @type {?} */ ((event.target)));
if (!this.control.disabled) {

@@ -204,2 +214,5 @@ this.control.addFiles(input.files);

* ControlValueAccessor implementation
*/
/**
* ControlValueAccessor implementation
* @return {?}

@@ -217,2 +230,5 @@ */

* model -> view changes
*/
/**
* model -> view changes
* @param {?} files

@@ -234,2 +250,6 @@ * @return {?}

* to update view -> model
*/
/**
* register function which will be called on UI change
* to update view -> model
* @param {?} fn

@@ -305,3 +325,3 @@ * @return {?}

export { FileUploadComponent };
function FileUploadComponent_tsickle_Closure_declarations() {
if (false) {
/** @type {?} */

@@ -336,3 +356,2 @@ FileUploadComponent.prototype.control;

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload.component.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["components/file-upload.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Component,\r\n    Input,\r\n    OnInit,\r\n    ElementRef,\r\n    HostListener,\r\n    Renderer2,\r\n    OnDestroy,\r\n    HostBinding,\r\n    Inject,\r\n    TemplateRef,\r\n    ViewChild,\r\n    ChangeDetectionStrategy,\r\n    ContentChild,\r\n    forwardRef,\r\n    ChangeDetectorRef\r\n} from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\r\n\r\nimport { FileUploadControl } from './../helpers/control.class';\r\nimport { IsNullOrEmpty } from './../helpers/helpers.class';\r\nimport { FileUploadService } from './../services/file-upload.service';\r\nimport { Subscription } from 'rxjs';\r\n\r\nexport const DRAGOVER = 'dragover';\r\nexport const TOUCHED = 'ng-touched';\r\n\r\n@Component({\r\n    selector: `file-upload`,\r\n    template: `<label class=\"upload-input\">\r\n\r\n    <ng-container *ngTemplateOutlet=\"templateRef ? templateRef : defaultTemplate; context: templateContext\"></ng-container>\r\n\r\n    <ng-template #defaultTemplate let-isFileDragDropAvailable=\"isFileDragDropAvailable\">\r\n        <div class=\"icon\">\r\n            <svg viewBox=\"0 0 96 96\">\r\n                <g>\r\n                    <path d=\"M62.8,68.1c0-0.6-0.2-1.1-0.6-1.5c-0.4-0.4-0.9-0.6-1.5-0.6s-1.1,0.2-1.5,0.6\r\n                        c-0.4,0.4-0.6,0.9-0.6,1.5c0,0.6,0.2,1.1,0.6,1.5c0.4,0.4,0.9,0.6,1.5,0.6s1.1-0.2,1.5-0.6S62.8,68.7,62.8,68.1z M71.3,68.1\r\n                        c0-0.6-0.2-1.1-0.6-1.5c-0.4-0.4-0.9-0.6-1.5-0.6c-0.6,0-1.1,0.2-1.5,0.6C67.2,67,67,67.5,67,68.1c0,0.6,0.2,1.1,0.6,1.5\r\n                        s0.9,0.6,1.5,0.6c0.6,0,1.1-0.2,1.5-0.6C71.1,69.2,71.3,68.7,71.3,68.1z M75.5,60.7v10.6c0,0.9-0.3,1.6-0.9,2.2\r\n                        c-0.6,0.6-1.4,0.9-2.2,0.9H23.7c-0.9,0-1.6-0.3-2.2-0.9c-0.6-0.6-0.9-1.4-0.9-2.2V60.7c0-0.9,0.3-1.6,0.9-2.2\r\n                        c0.6-0.6,1.4-0.9,2.2-0.9h14.1c0.5,1.2,1.2,2.2,2.3,3c1.1,0.8,2.3,1.2,3.7,1.2h8.5c1.3,0,2.6-0.4,3.7-1.2c1.1-0.8,1.9-1.8,2.3-3\r\n                        h14.1c0.9,0,1.6,0.3,2.2,0.9C75.2,59.1,75.5,59.8,75.5,60.7z M64.8,39.3c-0.4,0.9-1,1.3-2,1.3h-8.5v14.8c0,0.6-0.2,1.1-0.6,1.5\r\n                        c-0.4,0.4-0.9,0.6-1.5,0.6h-8.5c-0.6,0-1.1-0.2-1.5-0.6c-0.4-0.4-0.6-0.9-0.6-1.5V40.6h-8.5c-0.9,0-1.6-0.4-2-1.3\r\n                        c-0.4-0.9-0.2-1.6,0.5-2.3l14.8-14.8c0.4-0.4,0.9-0.6,1.5-0.6s1.1,0.2,1.5,0.6L64.3,37C65,37.7,65.1,38.4,64.8,39.3z\"/>\r\n                </g>\r\n            </svg>\r\n        </div>\r\n    \r\n        <div class=\"upload-text\">\r\n            <ng-container *ngIf=\"isFileDragDropAvailable; else isNotDragDropAvailable\">\r\n                <b>Drag and drop</b> files<br> or click here\r\n            </ng-container>\r\n            <ng-template #isNotDragDropAvailable>\r\n                <b>Click here</b> to<br> choose a files\r\n            </ng-template>\r\n        </div>\r\n    </ng-template>\r\n\r\n    <input #inputRef type=\"file\" class=\"files-input\" multiple (change)=\"onInputChange($event)\">\r\n</label>\r\n\r\n<div class=\"upload-list\" *ngIf=\"(control.listVisibilityChanges | async) && control.size > 0\">\r\n    <ng-template ngFor let-file let-i=\"index\" [ngForOf]=\"control.valueChanges | async\">\r\n        <ng-container *ngTemplateOutlet=\"listItem ? listItem : defaultItemTemplate; context: { $implicit: file, file: file, index: i, control: control }\"></ng-container>\r\n    </ng-template>\r\n    \r\n    <ng-template #defaultItemTemplate let-i=\"index\" let-file=\"file\" let-control=\"control\">\r\n        <file-upload-list-item  [index]=\"i\" [file]=\"file\" [control]=\"control\"></file-upload-list-item>\r\n    </ng-template>\r\n</div>`,\r\n    styles: [`:host,:host>*{box-sizing:border-box}:host{overflow:hidden;display:block;background:#fafafa;padding:20px 66px 20px 20px;min-height:140px;outline:#92b0b3 dashed 1px;outline-offset:-10px;position:relative}:host(.dragover){outline-width:2px}:host(.disabled){opacity:.5;cursor:no-drop}.files-input{width:.1px;height:.1px;opacity:0;position:absolute;left:-100%;top:-100%;overflow:hidden}.icon{height:35px;width:35px;border:1px solid #eaeaea;border-radius:4px;float:left;margin-right:20px}:host(.has-files) .icon{margin:0}.icon svg{fill:#909293}.upload-input:after{clear:both;content:\"\\\\0A0\";display:block;height:0;line-height:0;visibility:hidden;zoom:1}.upload-input{cursor:pointer;display:inline-block;color:#646464;position:absolute;top:50%;left:50%;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);transition:all .15s ease-in-out}:host(.disabled) .upload-input{cursor:not-allowed}:host(.has-files) .upload-input{top:20px;left:100%;margin-left:-20px;-webkit-transform:translate(-100%,0);transform:translate(-100%,0);text-align:center}.upload-text{overflow:hidden;width:auto}:host(.has-files) .upload-text{display:none}:host(.dragover:not(.disabled)) .upload-input,:host(:not(.disabled)) .upload-input:hover{color:#80a9d2}:host(.dragover:not(.disabled)) .icon svg,:host(:not(.disabled)) .upload-input:hover svg{fill:#80a9d2}:host(:not(.disabled)) .upload-input:hover .icon{border-color:#80a9d2}file-upload-list-item{padding:10px 0 0}file-upload-list-item:first-child{padding:0}`],\r\n    providers: [ \r\n        FileUploadService,\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: forwardRef(() => FileUploadComponent),\r\n            multi: true\r\n        }\r\n    ],\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class FileUploadComponent implements OnInit, OnDestroy, ControlValueAccessor {\r\n\r\n    @Input()\r\n    public control: FileUploadControl = null;\r\n\r\n    @ContentChild('placeholder')\r\n    public templateRef: TemplateRef<any> = null;\r\n\r\n    @ContentChild('item')\r\n    public listItem: TemplateRef<any> = null;\r\n\r\n    @ViewChild('inputRef')\r\n    public input: ElementRef<HTMLInputElement>;\r\n\r\n    public templateContext = {\r\n        $implicit: this.fileUploadService.isFileDragDropAvailable(),\r\n        isFileDragDropAvailable: this.fileUploadService.isFileDragDropAvailable()\r\n    };\r\n\r\n    private hooks: Array<Function> = [];\r\n\r\n    private subscriptions: Array<Subscription> = [];\r\n\r\n    constructor(\r\n        public fileUploadService: FileUploadService,\r\n        private hostElementRef: ElementRef,\r\n        private renderer: Renderer2,\r\n        @Inject(DOCUMENT) private document,\r\n        private cdr: ChangeDetectorRef\r\n    ) {}\r\n\r\n    public ngOnInit() {\r\n        if (IsNullOrEmpty(this.control)) {\r\n            this.control = new FileUploadControl();\r\n        }\r\n\r\n        this.setEvents();\r\n        this.checkAndMarkAsDisabled();\r\n        this.connectToForm();\r\n    }\r\n\r\n    public ngOnDestroy(): void {\r\n        this.cdr.detach();\r\n        this.hooks.forEach((hook) => hook());\r\n        this.hooks.length = 0;\r\n        this.subscriptions.forEach((subscription) => subscription.unsubscribe());\r\n        this.subscriptions.length = 0;\r\n    }\r\n\r\n    @HostBinding('class.has-files')\r\n    public get hasFiles(): boolean {\r\n        return this.control.isListVisible && this.control.size > 0;\r\n    }\r\n\r\n    @HostBinding('class.ng-invalid')\r\n    public get isInvalid(): boolean {\r\n        return !this.control.disabled && this.control.invalid;\r\n    }\r\n\r\n    private setEvents(): void {\r\n        ['drag', 'dragstart', 'dragend', 'dragover', 'dragenter', 'dragleave', 'drop'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.document, eventName, (event: any) => this.preventDragEvents(event))\r\n            );\r\n        });\r\n\r\n        ['dragover', 'dragenter'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.hostElementRef.nativeElement, eventName, (event: any) => this.onDragOver(event))\r\n            );\r\n        });\r\n\r\n        ['dragleave', 'dragend', 'drop'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.hostElementRef.nativeElement, eventName, (event: any) => this.onDragLeave(event))\r\n            );\r\n        });\r\n\r\n        this.subscriptions.push(\r\n            this.control.statusChanges.subscribe((status) => this.checkAndMarkAsDisabled())\r\n        );\r\n\r\n        this.subscriptions.push(\r\n            this.control.valueChanges.subscribe((files) => this.cdr.markForCheck())\r\n        );\r\n    }\r\n\r\n    private checkAndMarkAsDisabled(): void {\r\n        if (this.control.disabled) {\r\n            this.renderer.addClass(this.hostElementRef.nativeElement, 'disabled');\r\n            this.renderer.setProperty(this.input.nativeElement, 'disabled', true);\r\n        } else {\r\n            this.renderer.removeClass(this.hostElementRef.nativeElement, 'disabled');\r\n            this.renderer.setProperty(this.input.nativeElement, 'disabled', false);\r\n        }\r\n    }\r\n\r\n    private preventDragEvents(event: DragEvent): void {\r\n        event.preventDefault();\r\n        event.stopPropagation();\r\n    }\r\n\r\n    /**\r\n     * on file over add class name\r\n     */\r\n    private onDragOver(event: DragEvent): void {\r\n        this.renderer.addClass(this.hostElementRef.nativeElement, DRAGOVER);\r\n    }\r\n\r\n    /**\r\n     * on mouse out remove class name\r\n     */\r\n    private onDragLeave(event: DragEvent): void {\r\n        this.renderer.removeClass(this.hostElementRef.nativeElement, DRAGOVER);\r\n    }\r\n\r\n    @HostListener('drop', ['$event'])\r\n    public onDrop(event: DragEvent): void {\r\n        if (this.control.disabled) {\r\n            return;\r\n        }\r\n        const files = event.dataTransfer.files;\r\n        this.control.addFiles(files);\r\n        this.onTouch();\r\n    }\r\n\r\n    public onInputChange(event: Event): void {\r\n        const input = (event.target) as HTMLInputElement;\r\n\r\n        if (!this.control.disabled) {\r\n            this.control.addFiles(input.files);\r\n        }\r\n        this.clearInputEl();\r\n        this.onTouch();\r\n    }\r\n\r\n    private clearInputEl(): void {\r\n        this.input.nativeElement.value = null;\r\n    }\r\n\r\n    /**\r\n     * ControlValueAccessor implementation\r\n     */\r\n    private connectToForm(): void {\r\n        this.subscriptions.push(\r\n            this.control.valueChanges.subscribe((v) => this.onChange(v))\r\n        );\r\n    }\r\n\r\n     /**\r\n      * model -> view changes\r\n      */\r\n    public writeValue(files: any): void {\r\n        if (!IsNullOrEmpty(files)) {\r\n            this.control.setValue(files);\r\n        }\r\n    }\r\n\r\n    private onChange: (v: Array<File>) => void = () => {};\r\n\r\n    /**\r\n     * register function which will be called on UI change\r\n     * to update view -> model\r\n     */\r\n    public registerOnChange(fn: (v: Array<File>) => void): void {\r\n        this.onChange = fn;\r\n    }\r\n\r\n    private onTouch: () => void = () => {\r\n        this.renderer.addClass(this.hostElementRef.nativeElement, TOUCHED);\r\n    };\r\n\r\n    public registerOnTouched(fn: any): void {\r\n        this.onTouch = fn;\r\n    }\r\n\r\n    public setDisabledState(isDisabled: boolean): void {\r\n        this.control.disable(isDisabled);\r\n    }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload.component.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["components/file-upload.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Component,\r\n    Input,\r\n    OnInit,\r\n    ElementRef,\r\n    HostListener,\r\n    Renderer2,\r\n    OnDestroy,\r\n    HostBinding,\r\n    Inject,\r\n    TemplateRef,\r\n    ViewChild,\r\n    ChangeDetectionStrategy,\r\n    ContentChild,\r\n    forwardRef,\r\n    ChangeDetectorRef\r\n} from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\r\n\r\nimport { FileUploadControl } from './../helpers/control.class';\r\nimport { IsNullOrEmpty } from './../helpers/helpers.class';\r\nimport { FileUploadService } from './../services/file-upload.service';\r\nimport { Subscription } from 'rxjs';\r\n\r\nexport const DRAGOVER = 'dragover';\r\nexport const TOUCHED = 'ng-touched';\r\n\r\n@Component({\r\n    selector: `file-upload`,\r\n    template: `<label class=\"upload-input\">\r\n\r\n    <ng-container *ngTemplateOutlet=\"templateRef ? templateRef : defaultTemplate; context: templateContext\"></ng-container>\r\n\r\n    <ng-template #defaultTemplate let-isFileDragDropAvailable=\"isFileDragDropAvailable\">\r\n        <div class=\"icon\">\r\n            <svg viewBox=\"0 0 96 96\">\r\n                <g>\r\n                    <path d=\"M62.8,68.1c0-0.6-0.2-1.1-0.6-1.5c-0.4-0.4-0.9-0.6-1.5-0.6s-1.1,0.2-1.5,0.6\r\n                        c-0.4,0.4-0.6,0.9-0.6,1.5c0,0.6,0.2,1.1,0.6,1.5c0.4,0.4,0.9,0.6,1.5,0.6s1.1-0.2,1.5-0.6S62.8,68.7,62.8,68.1z M71.3,68.1\r\n                        c0-0.6-0.2-1.1-0.6-1.5c-0.4-0.4-0.9-0.6-1.5-0.6c-0.6,0-1.1,0.2-1.5,0.6C67.2,67,67,67.5,67,68.1c0,0.6,0.2,1.1,0.6,1.5\r\n                        s0.9,0.6,1.5,0.6c0.6,0,1.1-0.2,1.5-0.6C71.1,69.2,71.3,68.7,71.3,68.1z M75.5,60.7v10.6c0,0.9-0.3,1.6-0.9,2.2\r\n                        c-0.6,0.6-1.4,0.9-2.2,0.9H23.7c-0.9,0-1.6-0.3-2.2-0.9c-0.6-0.6-0.9-1.4-0.9-2.2V60.7c0-0.9,0.3-1.6,0.9-2.2\r\n                        c0.6-0.6,1.4-0.9,2.2-0.9h14.1c0.5,1.2,1.2,2.2,2.3,3c1.1,0.8,2.3,1.2,3.7,1.2h8.5c1.3,0,2.6-0.4,3.7-1.2c1.1-0.8,1.9-1.8,2.3-3\r\n                        h14.1c0.9,0,1.6,0.3,2.2,0.9C75.2,59.1,75.5,59.8,75.5,60.7z M64.8,39.3c-0.4,0.9-1,1.3-2,1.3h-8.5v14.8c0,0.6-0.2,1.1-0.6,1.5\r\n                        c-0.4,0.4-0.9,0.6-1.5,0.6h-8.5c-0.6,0-1.1-0.2-1.5-0.6c-0.4-0.4-0.6-0.9-0.6-1.5V40.6h-8.5c-0.9,0-1.6-0.4-2-1.3\r\n                        c-0.4-0.9-0.2-1.6,0.5-2.3l14.8-14.8c0.4-0.4,0.9-0.6,1.5-0.6s1.1,0.2,1.5,0.6L64.3,37C65,37.7,65.1,38.4,64.8,39.3z\"/>\r\n                </g>\r\n            </svg>\r\n        </div>\r\n    \r\n        <div class=\"upload-text\">\r\n            <ng-container *ngIf=\"isFileDragDropAvailable; else isNotDragDropAvailable\">\r\n                <b>Drag and drop</b> files<br> or click here\r\n            </ng-container>\r\n            <ng-template #isNotDragDropAvailable>\r\n                <b>Click here</b> to<br> choose a files\r\n            </ng-template>\r\n        </div>\r\n    </ng-template>\r\n\r\n    <input #inputRef type=\"file\" class=\"files-input\" multiple (change)=\"onInputChange($event)\">\r\n</label>\r\n\r\n<div class=\"upload-list\" *ngIf=\"(control.listVisibilityChanges | async) && control.size > 0\">\r\n    <ng-template ngFor let-file let-i=\"index\" [ngForOf]=\"control.valueChanges | async\">\r\n        <ng-container *ngTemplateOutlet=\"listItem ? listItem : defaultItemTemplate; context: { $implicit: file, file: file, index: i, control: control }\"></ng-container>\r\n    </ng-template>\r\n    \r\n    <ng-template #defaultItemTemplate let-i=\"index\" let-file=\"file\" let-control=\"control\">\r\n        <file-upload-list-item  [index]=\"i\" [file]=\"file\" [control]=\"control\"></file-upload-list-item>\r\n    </ng-template>\r\n</div>`,\r\n    styles: [`:host,:host>*{box-sizing:border-box}:host{overflow:hidden;display:block;background:#fafafa;padding:20px 66px 20px 20px;min-height:140px;outline:#92b0b3 dashed 1px;outline-offset:-10px;position:relative}:host(.dragover){outline-width:2px}:host(.disabled){opacity:.5;cursor:no-drop}.files-input{width:.1px;height:.1px;opacity:0;position:absolute;left:-100%;top:-100%;overflow:hidden}.icon{height:35px;width:35px;border:1px solid #eaeaea;border-radius:4px;float:left;margin-right:20px}:host(.has-files) .icon{margin:0}.icon svg{fill:#909293}.upload-input:after{clear:both;content:\"\\\\0A0\";display:block;height:0;line-height:0;visibility:hidden;zoom:1}.upload-input{cursor:pointer;display:inline-block;color:#646464;position:absolute;top:50%;left:50%;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);transition:all .15s ease-in-out}:host(.disabled) .upload-input{cursor:not-allowed}:host(.has-files) .upload-input{top:20px;left:100%;margin-left:-20px;-webkit-transform:translate(-100%,0);transform:translate(-100%,0);text-align:center}.upload-text{overflow:hidden;width:auto}:host(.has-files) .upload-text{display:none}:host(.dragover:not(.disabled)) .upload-input,:host(:not(.disabled)) .upload-input:hover{color:#80a9d2}:host(.dragover:not(.disabled)) .icon svg,:host(:not(.disabled)) .upload-input:hover svg{fill:#80a9d2}:host(:not(.disabled)) .upload-input:hover .icon{border-color:#80a9d2}file-upload-list-item{padding:10px 0 0}file-upload-list-item:first-child{padding:0}`],\r\n    providers: [ \r\n        FileUploadService,\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: forwardRef(() => FileUploadComponent),\r\n            multi: true\r\n        }\r\n    ],\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class FileUploadComponent implements OnInit, OnDestroy, ControlValueAccessor {\r\n\r\n    @Input()\r\n    public control: FileUploadControl = null;\r\n\r\n    @ContentChild('placeholder')\r\n    public templateRef: TemplateRef<any> = null;\r\n\r\n    @ContentChild('item')\r\n    public listItem: TemplateRef<any> = null;\r\n\r\n    @ViewChild('inputRef')\r\n    public input: ElementRef<HTMLInputElement>;\r\n\r\n    public templateContext = {\r\n        $implicit: this.fileUploadService.isFileDragDropAvailable(),\r\n        isFileDragDropAvailable: this.fileUploadService.isFileDragDropAvailable()\r\n    };\r\n\r\n    private hooks: Array<Function> = [];\r\n\r\n    private subscriptions: Array<Subscription> = [];\r\n\r\n    constructor(\r\n        public fileUploadService: FileUploadService,\r\n        private hostElementRef: ElementRef,\r\n        private renderer: Renderer2,\r\n        @Inject(DOCUMENT) private document,\r\n        private cdr: ChangeDetectorRef\r\n    ) {}\r\n\r\n    public ngOnInit() {\r\n        if (IsNullOrEmpty(this.control)) {\r\n            this.control = new FileUploadControl();\r\n        }\r\n\r\n        this.setEvents();\r\n        this.checkAndMarkAsDisabled();\r\n        this.connectToForm();\r\n    }\r\n\r\n    public ngOnDestroy(): void {\r\n        this.cdr.detach();\r\n        this.hooks.forEach((hook) => hook());\r\n        this.hooks.length = 0;\r\n        this.subscriptions.forEach((subscription) => subscription.unsubscribe());\r\n        this.subscriptions.length = 0;\r\n    }\r\n\r\n    @HostBinding('class.has-files')\r\n    public get hasFiles(): boolean {\r\n        return this.control.isListVisible && this.control.size > 0;\r\n    }\r\n\r\n    @HostBinding('class.ng-invalid')\r\n    public get isInvalid(): boolean {\r\n        return !this.control.disabled && this.control.invalid;\r\n    }\r\n\r\n    private setEvents(): void {\r\n        ['drag', 'dragstart', 'dragend', 'dragover', 'dragenter', 'dragleave', 'drop'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.document, eventName, (event: any) => this.preventDragEvents(event))\r\n            );\r\n        });\r\n\r\n        ['dragover', 'dragenter'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.hostElementRef.nativeElement, eventName, (event: any) => this.onDragOver(event))\r\n            );\r\n        });\r\n\r\n        ['dragleave', 'dragend', 'drop'].forEach((eventName) => {\r\n            this.hooks.push(\r\n                this.renderer.listen(this.hostElementRef.nativeElement, eventName, (event: any) => this.onDragLeave(event))\r\n            );\r\n        });\r\n\r\n        this.subscriptions.push(\r\n            this.control.statusChanges.subscribe((status) => this.checkAndMarkAsDisabled())\r\n        );\r\n\r\n        this.subscriptions.push(\r\n            this.control.valueChanges.subscribe((files) => this.cdr.markForCheck())\r\n        );\r\n    }\r\n\r\n    private checkAndMarkAsDisabled(): void {\r\n        if (this.control.disabled) {\r\n            this.renderer.addClass(this.hostElementRef.nativeElement, 'disabled');\r\n            this.renderer.setProperty(this.input.nativeElement, 'disabled', true);\r\n        } else {\r\n            this.renderer.removeClass(this.hostElementRef.nativeElement, 'disabled');\r\n            this.renderer.setProperty(this.input.nativeElement, 'disabled', false);\r\n        }\r\n    }\r\n\r\n    private preventDragEvents(event: DragEvent): void {\r\n        event.preventDefault();\r\n        event.stopPropagation();\r\n    }\r\n\r\n    /**\r\n     * on file over add class name\r\n     */\r\n    private onDragOver(event: DragEvent): void {\r\n        this.renderer.addClass(this.hostElementRef.nativeElement, DRAGOVER);\r\n    }\r\n\r\n    /**\r\n     * on mouse out remove class name\r\n     */\r\n    private onDragLeave(event: DragEvent): void {\r\n        this.renderer.removeClass(this.hostElementRef.nativeElement, DRAGOVER);\r\n    }\r\n\r\n    @HostListener('drop', ['$event'])\r\n    public onDrop(event: DragEvent): void {\r\n        if (this.control.disabled) {\r\n            return;\r\n        }\r\n        const files = event.dataTransfer.files;\r\n        this.control.addFiles(files);\r\n        this.onTouch();\r\n    }\r\n\r\n    public onInputChange(event: Event): void {\r\n        const input = (event.target) as HTMLInputElement;\r\n\r\n        if (!this.control.disabled) {\r\n            this.control.addFiles(input.files);\r\n        }\r\n        this.clearInputEl();\r\n        this.onTouch();\r\n    }\r\n\r\n    private clearInputEl(): void {\r\n        this.input.nativeElement.value = null;\r\n    }\r\n\r\n    /**\r\n     * ControlValueAccessor implementation\r\n     */\r\n    private connectToForm(): void {\r\n        this.subscriptions.push(\r\n            this.control.valueChanges.subscribe((v) => this.onChange(v))\r\n        );\r\n    }\r\n\r\n     /**\r\n      * model -> view changes\r\n      */\r\n    public writeValue(files: any): void {\r\n        if (!IsNullOrEmpty(files)) {\r\n            this.control.setValue(files);\r\n        }\r\n    }\r\n\r\n    private onChange: (v: Array<File>) => void = () => {};\r\n\r\n    /**\r\n     * register function which will be called on UI change\r\n     * to update view -> model\r\n     */\r\n    public registerOnChange(fn: (v: Array<File>) => void): void {\r\n        this.onChange = fn;\r\n    }\r\n\r\n    private onTouch: () => void = () => {\r\n        this.renderer.addClass(this.hostElementRef.nativeElement, TOUCHED);\r\n    };\r\n\r\n    public registerOnTouched(fn: any): void {\r\n        this.onTouch = fn;\r\n    }\r\n\r\n    public setDisabledState(isDisabled: boolean): void {\r\n        this.control.disable(isDisabled);\r\n    }\r\n}\r\n"]}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/

@@ -71,3 +71,4 @@ import { Directive, forwardRef, Input } from '@angular/core';

function () {
var /** @type {?} */ maxSize = null;
/** @type {?} */
var maxSize = null;
if (!IsNullOrEmpty(this.maxsize)) {

@@ -79,3 +80,4 @@ maxSize = typeof this.maxsize === 'string' ? parseInt(this.maxsize, 10) : this.maxsize;

}
var /** @type {?} */ minSize = typeof this.minsize === 'string' ? parseInt(this.minsize, 10) : this.minsize;
/** @type {?} */
var minSize = typeof this.minsize === 'string' ? parseInt(this.minsize, 10) : this.minsize;
this.validator = FileUploadValidators.sizeRange({ maxSize: maxSize, minSize: minSize });

@@ -106,3 +108,3 @@ };

export { FileSizeValidator };
function FileSizeValidator_tsickle_Closure_declarations() {
if (false) {
/** @type {?} */

@@ -197,3 +199,3 @@ FileSizeValidator.prototype.filesize;

export { FilesLimitValidator };
function FilesLimitValidator_tsickle_Closure_declarations() {
if (false) {
/** @type {?} */

@@ -286,3 +288,3 @@ FilesLimitValidator.prototype.fileslimit;

export { FilesAcceptValidator };
function FilesAcceptValidator_tsickle_Closure_declarations() {
if (false) {
/** @type {?} */

@@ -295,3 +297,2 @@ FilesAcceptValidator.prototype.accept;

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validators.directive.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["directives/validators.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, forwardRef, Input, OnChanges, SimpleChanges } from '@angular/core';\r\nimport { NG_VALIDATORS, Validator, AbstractControl } from '@angular/forms';\r\nimport { ValidationErrors, ValidatorFn, FileUploadValidators } from './../helpers/validators.class';\r\nimport { IsNullOrEmpty } from './../helpers/helpers.class';\r\n\r\n\r\n/**\r\n * A Directive that adds the `filesize` validator to controls marked with the\r\n * `filesize` attribute.\r\n *\r\n * ### Example\r\n *\r\n * ```\r\n * <file-upload name=\"files\" ngModel filesize=\"830000\"></file-upload>\r\n * <file-upload name=\"files\" ngModel [filesize]=\"830000\"></file-upload>\r\n * <file-upload name=\"files\" ngModel minSize=\"0\" max=\"6200\"></file-upload>\r\n * ```\r\n *\r\n */\r\n@Directive({\r\n    selector: `[filesize][formControlName],[filesize][formControl],[filesize][ngModel],\r\n    [minsize][formControlName],[minsize][formControl],[minsize][ngModel],\r\n    [maxsize][formControlName],[maxsize][formControl],[maxsize][ngModel]`,\r\n    providers: [{\r\n        provide: NG_VALIDATORS,\r\n        useExisting: forwardRef(() => FileSizeValidator),\r\n        multi: true\r\n    }],\r\n    host: {\r\n        '[attr.filesize]': 'filesize ? filesize : null',\r\n        '[attr.minsize]': 'minsize ? minsize : null',\r\n        '[attr.maxsize]': 'maxsize ? maxsize : null'\r\n    }\r\n})\r\nexport class FileSizeValidator implements Validator, OnChanges {\r\n    \r\n    @Input()\r\n    private filesize: string|number;\r\n\r\n    @Input()\r\n    private minsize: string|number;\r\n    \r\n    @Input()\r\n    private maxsize: string|number;\r\n\r\n    private validator: ValidatorFn;\r\n\r\n    private onChange: () => void;\r\n  \r\n    public ngOnChanges(changes: SimpleChanges): void {\r\n        if ('filesize' in changes \r\n            || 'maxsize' in changes \r\n            || 'minsize' in changes) {\r\n          this._createValidator();\r\n          if (this.onChange) this.onChange();\r\n        }\r\n    }\r\n\r\n    public validate(c: AbstractControl): ValidationErrors|null {\r\n        return this.validator(c);\r\n    }\r\n  \r\n    public registerOnValidatorChange(fn: () => void): void {\r\n        this.onChange = fn; \r\n    }\r\n\r\n    private _createValidator(): void {\r\n        let maxSize = null;        \r\n        if (!IsNullOrEmpty(this.maxsize)) {\r\n            maxSize = typeof this.maxsize === 'string' ? parseInt(this.maxsize, 10) : this.maxsize;\r\n        } else if(!IsNullOrEmpty(this.filesize)) {\r\n            maxSize = typeof this.filesize === 'string' ? parseInt(this.filesize, 10) : this.filesize;\r\n        }\r\n\r\n        const minSize = typeof this.minsize === 'string' ? parseInt(this.minsize, 10) : this.minsize;\r\n\r\n        this.validator = FileUploadValidators.sizeRange({ maxSize, minSize });\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * A Directive that adds the `fileslimit` validator to controls marked with the\r\n * `fileslimit` attribute.\r\n *\r\n * ### Example\r\n *\r\n * ```\r\n * <file-upload name=\"files\" ngModel fileslimit=\"2\"></file-upload>\r\n * <file-upload name=\"files\" ngModel [fileslimit]=\"2\"></file-upload>\r\n * ```\r\n *\r\n */\r\n@Directive({\r\n    selector: '[fileslimit][formControlName],[fileslimit][formControl],[fileslimit][ngModel]',\r\n    providers: [{\r\n        provide: NG_VALIDATORS,\r\n        useExisting: forwardRef(() => FilesLimitValidator),\r\n        multi: true\r\n    }],\r\n    host: {'[attr.fileslimit]': 'fileslimit ? fileslimit : null'}\r\n})\r\nexport class FilesLimitValidator implements Validator, OnChanges {\r\n    \r\n    @Input()\r\n    private fileslimit: string|number;\r\n\r\n    private validator: ValidatorFn;\r\n\r\n    private onChange: () => void;\r\n  \r\n    public ngOnChanges(changes: SimpleChanges): void {\r\n        if ('fileslimit' in changes) {\r\n          this._createValidator();\r\n          if (this.onChange) this.onChange();\r\n        }\r\n    }\r\n\r\n    public validate(c: AbstractControl): ValidationErrors|null {\r\n        return this.fileslimit != null ? this.validator(c) : null;\r\n    }\r\n  \r\n    public registerOnValidatorChange(fn: () => void): void {\r\n        this.onChange = fn; \r\n    }\r\n\r\n    private _createValidator(): void {\r\n        this.validator = FileUploadValidators.filesLimit(typeof this.fileslimit === 'string' ? parseInt(this.fileslimit, 10) : this.fileslimit);\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * A Directive that adds the `accept` validator to controls marked with the\r\n * `accept` attribute.\r\n *\r\n * ### Example\r\n *\r\n * ```\r\n * <file-upload name=\"files\" ngModel accept=\"file_extension|audio/*|video/*|image/*|media_type\"></file-upload>\r\n * <file-upload name=\"files\" ngModel [accept]=\"file_extension|audio/*|video/*|image/*|media_type\"></file-upload>\r\n * ```\r\n * \r\n * To specify more than one value, separate the values with a comma (e.g. <file-upload accept=\"audio/*,video/*,image/*\"></file-upload>.\r\n *\r\n */\r\n@Directive({\r\n    selector: '[accept][formControlName],[accept][formControl],[accept][ngModel]',\r\n    providers: [{\r\n        provide: NG_VALIDATORS,\r\n        useExisting: forwardRef(() => FilesLimitValidator),\r\n        multi: true\r\n    }],\r\n    host: {'[attr.accept]': 'accept ? accept : null'}\r\n})\r\nexport class FilesAcceptValidator implements Validator, OnChanges {\r\n    \r\n    @Input()\r\n    private accept: string;\r\n\r\n    private validator: ValidatorFn;\r\n\r\n    private onChange: () => void;\r\n  \r\n    public ngOnChanges(changes: SimpleChanges): void {\r\n        if ('accept' in changes) {\r\n          this._createValidator();\r\n          if (this.onChange) this.onChange();\r\n        }\r\n    }\r\n\r\n    public validate(c: AbstractControl): ValidationErrors|null {\r\n        return this.accept != null ? this.validator(c) : null;\r\n    }\r\n  \r\n    public registerOnValidatorChange(fn: () => void): void {\r\n        this.onChange = fn; \r\n    }\r\n\r\n    private _createValidator(): void {\r\n        this.validator = FileUploadValidators.accept(this.accept.split(','));\r\n    }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validators.directive.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["directives/validators.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, forwardRef, Input, OnChanges, SimpleChanges } from '@angular/core';\r\nimport { NG_VALIDATORS, Validator, AbstractControl } from '@angular/forms';\r\nimport { ValidationErrors, ValidatorFn, FileUploadValidators } from './../helpers/validators.class';\r\nimport { IsNullOrEmpty } from './../helpers/helpers.class';\r\n\r\n\r\n/**\r\n * A Directive that adds the `filesize` validator to controls marked with the\r\n * `filesize` attribute.\r\n *\r\n * ### Example\r\n *\r\n * ```\r\n * <file-upload name=\"files\" ngModel filesize=\"830000\"></file-upload>\r\n * <file-upload name=\"files\" ngModel [filesize]=\"830000\"></file-upload>\r\n * <file-upload name=\"files\" ngModel minSize=\"0\" max=\"6200\"></file-upload>\r\n * ```\r\n *\r\n */\r\n@Directive({\r\n    selector: `[filesize][formControlName],[filesize][formControl],[filesize][ngModel],\r\n    [minsize][formControlName],[minsize][formControl],[minsize][ngModel],\r\n    [maxsize][formControlName],[maxsize][formControl],[maxsize][ngModel]`,\r\n    providers: [{\r\n        provide: NG_VALIDATORS,\r\n        useExisting: forwardRef(() => FileSizeValidator),\r\n        multi: true\r\n    }],\r\n    host: {\r\n        '[attr.filesize]': 'filesize ? filesize : null',\r\n        '[attr.minsize]': 'minsize ? minsize : null',\r\n        '[attr.maxsize]': 'maxsize ? maxsize : null'\r\n    }\r\n})\r\nexport class FileSizeValidator implements Validator, OnChanges {\r\n    \r\n    @Input()\r\n    public filesize: string|number;\r\n\r\n    @Input()\r\n    public minsize: string|number;\r\n    \r\n    @Input()\r\n    public maxsize: string|number;\r\n\r\n    private validator: ValidatorFn;\r\n\r\n    private onChange: () => void;\r\n  \r\n    public ngOnChanges(changes: SimpleChanges): void {\r\n        if ('filesize' in changes \r\n            || 'maxsize' in changes \r\n            || 'minsize' in changes) {\r\n          this._createValidator();\r\n          if (this.onChange) this.onChange();\r\n        }\r\n    }\r\n\r\n    public validate(c: AbstractControl): ValidationErrors|null {\r\n        return this.validator(c);\r\n    }\r\n  \r\n    public registerOnValidatorChange(fn: () => void): void {\r\n        this.onChange = fn; \r\n    }\r\n\r\n    private _createValidator(): void {\r\n        let maxSize = null;        \r\n        if (!IsNullOrEmpty(this.maxsize)) {\r\n            maxSize = typeof this.maxsize === 'string' ? parseInt(this.maxsize, 10) : this.maxsize;\r\n        } else if(!IsNullOrEmpty(this.filesize)) {\r\n            maxSize = typeof this.filesize === 'string' ? parseInt(this.filesize, 10) : this.filesize;\r\n        }\r\n\r\n        const minSize = typeof this.minsize === 'string' ? parseInt(this.minsize, 10) : this.minsize;\r\n\r\n        this.validator = FileUploadValidators.sizeRange({ maxSize, minSize });\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * A Directive that adds the `fileslimit` validator to controls marked with the\r\n * `fileslimit` attribute.\r\n *\r\n * ### Example\r\n *\r\n * ```\r\n * <file-upload name=\"files\" ngModel fileslimit=\"2\"></file-upload>\r\n * <file-upload name=\"files\" ngModel [fileslimit]=\"2\"></file-upload>\r\n * ```\r\n *\r\n */\r\n@Directive({\r\n    selector: '[fileslimit][formControlName],[fileslimit][formControl],[fileslimit][ngModel]',\r\n    providers: [{\r\n        provide: NG_VALIDATORS,\r\n        useExisting: forwardRef(() => FilesLimitValidator),\r\n        multi: true\r\n    }],\r\n    host: {'[attr.fileslimit]': 'fileslimit ? fileslimit : null'}\r\n})\r\nexport class FilesLimitValidator implements Validator, OnChanges {\r\n    \r\n    @Input()\r\n    public fileslimit: string|number;\r\n\r\n    private validator: ValidatorFn;\r\n\r\n    private onChange: () => void;\r\n  \r\n    public ngOnChanges(changes: SimpleChanges): void {\r\n        if ('fileslimit' in changes) {\r\n          this._createValidator();\r\n          if (this.onChange) this.onChange();\r\n        }\r\n    }\r\n\r\n    public validate(c: AbstractControl): ValidationErrors|null {\r\n        return this.fileslimit != null ? this.validator(c) : null;\r\n    }\r\n  \r\n    public registerOnValidatorChange(fn: () => void): void {\r\n        this.onChange = fn; \r\n    }\r\n\r\n    private _createValidator(): void {\r\n        this.validator = FileUploadValidators.filesLimit(typeof this.fileslimit === 'string' ? parseInt(this.fileslimit, 10) : this.fileslimit);\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * A Directive that adds the `accept` validator to controls marked with the\r\n * `accept` attribute.\r\n *\r\n * ### Example\r\n *\r\n * ```\r\n * <file-upload name=\"files\" ngModel accept=\"file_extension|audio/*|video/*|image/*|media_type\"></file-upload>\r\n * <file-upload name=\"files\" ngModel [accept]=\"file_extension|audio/*|video/*|image/*|media_type\"></file-upload>\r\n * ```\r\n * \r\n * To specify more than one value, separate the values with a comma (e.g. <file-upload accept=\"audio/*,video/*,image/*\"></file-upload>.\r\n *\r\n */\r\n@Directive({\r\n    selector: '[accept][formControlName],[accept][formControl],[accept][ngModel]',\r\n    providers: [{\r\n        provide: NG_VALIDATORS,\r\n        useExisting: forwardRef(() => FilesLimitValidator),\r\n        multi: true\r\n    }],\r\n    host: {'[attr.accept]': 'accept ? accept : null'}\r\n})\r\nexport class FilesAcceptValidator implements Validator, OnChanges {\r\n    \r\n    @Input()\r\n    public accept: string;\r\n\r\n    private validator: ValidatorFn;\r\n\r\n    private onChange: () => void;\r\n  \r\n    public ngOnChanges(changes: SimpleChanges): void {\r\n        if ('accept' in changes) {\r\n          this._createValidator();\r\n          if (this.onChange) this.onChange();\r\n        }\r\n    }\r\n\r\n    public validate(c: AbstractControl): ValidationErrors|null {\r\n        return this.accept != null ? this.validator(c) : null;\r\n    }\r\n  \r\n    public registerOnValidatorChange(fn: () => void): void {\r\n        this.onChange = fn; \r\n    }\r\n\r\n    private _createValidator(): void {\r\n        this.validator = FileUploadValidators.accept(this.accept.split(','));\r\n    }\r\n}\r\n"]}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/
/*
* l10n
*
* By Ivan Pintar, http://www.pintar-ivan.com
* Licensed under the MIT License
* See https://github.com/pIvan/file-upload/blob/master/README.md
*/
import { NgModule, Injector } from '@angular/core';

@@ -18,5 +25,5 @@ import { ReactiveFormsModule, FormsModule } from '@angular/forms';

function FileUploadModule(injector) {
this.injector = injector;
// const fileUploadElement = createCustomElement(FileUploadComponent, { injector });
// customElements.define('file-upload', fileUploadElement);
this.injector = injector;
}

@@ -65,7 +72,6 @@ /**

export { FileUploadModule };
function FileUploadModule_tsickle_Closure_declarations() {
if (false) {
/** @type {?} */
FileUploadModule.prototype.injector;
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQGlwbGFiL25neC1maWxlLXVwbG9hZC8iLCJzb3VyY2VzIjpbImZpbGUtdXBsb2FkLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBT0EsT0FBTyxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUN6RSxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSw4Q0FBOEMsQ0FBQztBQUMzRixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUNsRixPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUV2RixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsbUJBQW1CLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUdqSCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM1RCxPQUFPLEVBQUUsb0JBQW9CLEVBQWlDLE1BQU0sNEJBQTRCLENBQUM7QUFDakcsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDRCQUE0QixDQUFDOztJQWlDekQsMEJBQW9CLFFBQWtCOzs7UUFBbEIsYUFBUSxHQUFSLFFBQVEsQ0FBVTtLQUdyQzs7OztJQUVELHdDQUFhOzs7SUFBYixlQUFrQjs7Z0JBcENyQixRQUFRLFNBQUM7b0JBQ04sT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osbUJBQW1CO3dCQUNuQixXQUFXO3FCQUNkO29CQUNELFlBQVksRUFBRTt3QkFDVixtQkFBbUI7d0JBQ25CLDJCQUEyQjt3QkFDM0IsdUJBQXVCO3dCQUV2Qiw0QkFBNEI7d0JBRTVCLGlCQUFpQjt3QkFDakIsbUJBQW1CO3dCQUNuQixvQkFBb0I7cUJBQ3ZCO29CQUNELE9BQU8sRUFBRTt3QkFDTCxtQkFBbUI7d0JBQ25CLDRCQUE0Qjt3QkFFNUIsaUJBQWlCO3dCQUNqQixtQkFBbUI7d0JBQ25CLG9CQUFvQjtxQkFDdkI7b0JBQ0QsZUFBZSxFQUFFO3dCQUNiLG1CQUFtQjtxQkFDdEI7aUJBQ0o7Ozs7Z0JBNUNrQixRQUFROzsyQkFQM0I7O1NBb0RhLGdCQUFnQiIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIGwxMG5cclxuICogXHJcbiAqIEJ5IEl2YW4gUGludGFyLCBodHRwOi8vd3d3LnBpbnRhci1pdmFuLmNvbVxyXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2VcclxuICogU2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9wSXZhbi9maWxlLXVwbG9hZC9ibG9iL21hc3Rlci9SRUFETUUubWRcclxuICovXHJcbmltcG9ydCB7IE5nTW9kdWxlLCBJbmplY3RvciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBSZWFjdGl2ZUZvcm1zTW9kdWxlLCBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuXHJcbmltcG9ydCB7IEZpbGVVcGxvYWRDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvZmlsZS11cGxvYWQuY29tcG9uZW50JztcclxuaW1wb3J0IHsgRmlsZVVwbG9hZExpc3RJdGVtQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2ZpbGUtdXBsb2FkLWxpc3QtaXRlbS5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBGaWxlVXBsb2FkSWNvbkNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9maWxlLXVwbG9hZC1pY29uLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEZpbGVVcGxvYWRBdHRyaWJ1dGVDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvZmlsZS11cGxvYWQtYXR0ci5jb21wb25lbnQnO1xyXG5cclxuaW1wb3J0IHsgRmlsZVNpemVWYWxpZGF0b3IsIEZpbGVzTGltaXRWYWxpZGF0b3IsIEZpbGVzQWNjZXB0VmFsaWRhdG9yIH0gZnJvbSAnLi9kaXJlY3RpdmVzL3ZhbGlkYXRvcnMuZGlyZWN0aXZlJztcclxuXHJcblxyXG5leHBvcnQgeyBGaWxlVXBsb2FkQ29udHJvbCB9IGZyb20gJy4vaGVscGVycy9jb250cm9sLmNsYXNzJztcclxuZXhwb3J0IHsgRmlsZVVwbG9hZFZhbGlkYXRvcnMsIFZhbGlkYXRpb25FcnJvcnMsIFZhbGlkYXRvckZuIH0gZnJvbSAnLi9oZWxwZXJzL3ZhbGlkYXRvcnMuY2xhc3MnO1xyXG5leHBvcnQgeyBGaWxlVXBsb2FkVHlwZXMgfSBmcm9tICcuL2hlbHBlcnMvZmlsZS10eXBlcy5jbGFzcyc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgaW1wb3J0czogW1xyXG4gICAgICAgIENvbW1vbk1vZHVsZSxcclxuICAgICAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxyXG4gICAgICAgIEZvcm1zTW9kdWxlXHJcbiAgICBdLFxyXG4gICAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICAgICAgRmlsZVVwbG9hZENvbXBvbmVudCxcclxuICAgICAgICBGaWxlVXBsb2FkTGlzdEl0ZW1Db21wb25lbnQsXHJcbiAgICAgICAgRmlsZVVwbG9hZEljb25Db21wb25lbnQsXHJcblxyXG4gICAgICAgIEZpbGVVcGxvYWRBdHRyaWJ1dGVDb21wb25lbnQsXHJcblxyXG4gICAgICAgIEZpbGVTaXplVmFsaWRhdG9yLFxyXG4gICAgICAgIEZpbGVzTGltaXRWYWxpZGF0b3IsXHJcbiAgICAgICAgRmlsZXNBY2NlcHRWYWxpZGF0b3JcclxuICAgIF0sXHJcbiAgICBleHBvcnRzOiBbXHJcbiAgICAgICAgRmlsZVVwbG9hZENvbXBvbmVudCxcclxuICAgICAgICBGaWxlVXBsb2FkQXR0cmlidXRlQ29tcG9uZW50LFxyXG5cclxuICAgICAgICBGaWxlU2l6ZVZhbGlkYXRvcixcclxuICAgICAgICBGaWxlc0xpbWl0VmFsaWRhdG9yLFxyXG4gICAgICAgIEZpbGVzQWNjZXB0VmFsaWRhdG9yXHJcbiAgICBdLFxyXG4gICAgZW50cnlDb21wb25lbnRzOiBbXHJcbiAgICAgICAgRmlsZVVwbG9hZENvbXBvbmVudFxyXG4gICAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgRmlsZVVwbG9hZE1vZHVsZSB7XHJcblxyXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBpbmplY3RvcjogSW5qZWN0b3IpIHtcclxuICAgICAgICAvLyBjb25zdCBmaWxlVXBsb2FkRWxlbWVudCA9IGNyZWF0ZUN1c3RvbUVsZW1lbnQoRmlsZVVwbG9hZENvbXBvbmVudCwgeyBpbmplY3RvciB9KTtcclxuICAgICAgICAvLyBjdXN0b21FbGVtZW50cy5kZWZpbmUoJ2ZpbGUtdXBsb2FkJywgZmlsZVVwbG9hZEVsZW1lbnQpO1xyXG4gICAgfVxyXG5cclxuICAgIG5nRG9Cb290c3RyYXAoKSB7fVxyXG59Il19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQGlwbGFiL25neC1maWxlLXVwbG9hZC8iLCJzb3VyY2VzIjpbImZpbGUtdXBsb2FkLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQU9BLE9BQU8sRUFBRSxRQUFRLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25ELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFL0MsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDekUsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sOENBQThDLENBQUM7QUFDM0YsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDbEYsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFFdkYsT0FBTyxFQUFFLGlCQUFpQixFQUFFLG1CQUFtQixFQUFFLG9CQUFvQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFHakgsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDNUQsT0FBTyxFQUFFLG9CQUFvQixFQUFpQyxNQUFNLDRCQUE0QixDQUFDO0FBQ2pHLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUU3RDtJQStCSSwwQkFBb0IsUUFBa0I7UUFBbEIsYUFBUSxHQUFSLFFBQVEsQ0FBVTtRQUNsQyxvRkFBb0Y7UUFDcEYsMkRBQTJEO0lBQy9ELENBQUM7Ozs7SUFFRCx3Q0FBYTs7O0lBQWIsY0FBaUIsQ0FBQzs7Z0JBcENyQixRQUFRLFNBQUM7b0JBQ04sT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osbUJBQW1CO3dCQUNuQixXQUFXO3FCQUNkO29CQUNELFlBQVksRUFBRTt3QkFDVixtQkFBbUI7d0JBQ25CLDJCQUEyQjt3QkFDM0IsdUJBQXVCO3dCQUV2Qiw0QkFBNEI7d0JBRTVCLGlCQUFpQjt3QkFDakIsbUJBQW1CO3dCQUNuQixvQkFBb0I7cUJBQ3ZCO29CQUNELE9BQU8sRUFBRTt3QkFDTCxtQkFBbUI7d0JBQ25CLDRCQUE0Qjt3QkFFNUIsaUJBQWlCO3dCQUNqQixtQkFBbUI7d0JBQ25CLG9CQUFvQjtxQkFDdkI7b0JBQ0QsZUFBZSxFQUFFO3dCQUNiLG1CQUFtQjtxQkFDdEI7aUJBQ0o7Ozs7Z0JBNUNrQixRQUFROztJQXFEM0IsdUJBQUM7Q0FBQSxBQXJDRCxJQXFDQztTQVJZLGdCQUFnQjs7O0lBRWIsb0NBQTBCIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogbDEwblxyXG4gKiBcclxuICogQnkgSXZhbiBQaW50YXIsIGh0dHA6Ly93d3cucGludGFyLWl2YW4uY29tXHJcbiAqIExpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZVxyXG4gKiBTZWUgaHR0cHM6Ly9naXRodWIuY29tL3BJdmFuL2ZpbGUtdXBsb2FkL2Jsb2IvbWFzdGVyL1JFQURNRS5tZFxyXG4gKi9cclxuaW1wb3J0IHsgTmdNb2R1bGUsIEluamVjdG9yIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFJlYWN0aXZlRm9ybXNNb2R1bGUsIEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5cclxuaW1wb3J0IHsgRmlsZVVwbG9hZENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9maWxlLXVwbG9hZC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBGaWxlVXBsb2FkTGlzdEl0ZW1Db21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvZmlsZS11cGxvYWQtbGlzdC1pdGVtLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEZpbGVVcGxvYWRJY29uQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2ZpbGUtdXBsb2FkLWljb24uY29tcG9uZW50JztcclxuaW1wb3J0IHsgRmlsZVVwbG9hZEF0dHJpYnV0ZUNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9maWxlLXVwbG9hZC1hdHRyLmNvbXBvbmVudCc7XHJcblxyXG5pbXBvcnQgeyBGaWxlU2l6ZVZhbGlkYXRvciwgRmlsZXNMaW1pdFZhbGlkYXRvciwgRmlsZXNBY2NlcHRWYWxpZGF0b3IgfSBmcm9tICcuL2RpcmVjdGl2ZXMvdmFsaWRhdG9ycy5kaXJlY3RpdmUnO1xyXG5cclxuXHJcbmV4cG9ydCB7IEZpbGVVcGxvYWRDb250cm9sIH0gZnJvbSAnLi9oZWxwZXJzL2NvbnRyb2wuY2xhc3MnO1xyXG5leHBvcnQgeyBGaWxlVXBsb2FkVmFsaWRhdG9ycywgVmFsaWRhdGlvbkVycm9ycywgVmFsaWRhdG9yRm4gfSBmcm9tICcuL2hlbHBlcnMvdmFsaWRhdG9ycy5jbGFzcyc7XHJcbmV4cG9ydCB7IEZpbGVVcGxvYWRUeXBlcyB9IGZyb20gJy4vaGVscGVycy9maWxlLXR5cGVzLmNsYXNzJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgICBpbXBvcnRzOiBbXHJcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXHJcbiAgICAgICAgRm9ybXNNb2R1bGVcclxuICAgIF0sXHJcbiAgICBkZWNsYXJhdGlvbnM6IFtcclxuICAgICAgICBGaWxlVXBsb2FkQ29tcG9uZW50LFxyXG4gICAgICAgIEZpbGVVcGxvYWRMaXN0SXRlbUNvbXBvbmVudCxcclxuICAgICAgICBGaWxlVXBsb2FkSWNvbkNvbXBvbmVudCxcclxuXHJcbiAgICAgICAgRmlsZVVwbG9hZEF0dHJpYnV0ZUNvbXBvbmVudCxcclxuXHJcbiAgICAgICAgRmlsZVNpemVWYWxpZGF0b3IsXHJcbiAgICAgICAgRmlsZXNMaW1pdFZhbGlkYXRvcixcclxuICAgICAgICBGaWxlc0FjY2VwdFZhbGlkYXRvclxyXG4gICAgXSxcclxuICAgIGV4cG9ydHM6IFtcclxuICAgICAgICBGaWxlVXBsb2FkQ29tcG9uZW50LFxyXG4gICAgICAgIEZpbGVVcGxvYWRBdHRyaWJ1dGVDb21wb25lbnQsXHJcblxyXG4gICAgICAgIEZpbGVTaXplVmFsaWRhdG9yLFxyXG4gICAgICAgIEZpbGVzTGltaXRWYWxpZGF0b3IsXHJcbiAgICAgICAgRmlsZXNBY2NlcHRWYWxpZGF0b3JcclxuICAgIF0sXHJcbiAgICBlbnRyeUNvbXBvbmVudHM6IFtcclxuICAgICAgICBGaWxlVXBsb2FkQ29tcG9uZW50XHJcbiAgICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBGaWxlVXBsb2FkTW9kdWxlIHtcclxuXHJcbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGluamVjdG9yOiBJbmplY3Rvcikge1xyXG4gICAgICAgIC8vIGNvbnN0IGZpbGVVcGxvYWRFbGVtZW50ID0gY3JlYXRlQ3VzdG9tRWxlbWVudChGaWxlVXBsb2FkQ29tcG9uZW50LCB7IGluamVjdG9yIH0pO1xyXG4gICAgICAgIC8vIGN1c3RvbUVsZW1lbnRzLmRlZmluZSgnZmlsZS11cGxvYWQnLCBmaWxlVXBsb2FkRWxlbWVudCk7XHJcbiAgICB9XHJcblxyXG4gICAgbmdEb0Jvb3RzdHJhcCgpIHt9XHJcbn0iXX0=
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/

@@ -15,5 +15,5 @@ import * as tslib_1 from "tslib";

export { STATUS };
STATUS[STATUS.INVALID] = "INVALID";
STATUS[STATUS.VALID] = "VALID";
STATUS[STATUS.DISABLED] = "DISABLED";
STATUS[STATUS.INVALID] = 'INVALID';
STATUS[STATUS.VALID] = 'VALID';
STATUS[STATUS.DISABLED] = 'DISABLED';
var FileUploadControl = /** @class */ (function () {

@@ -46,14 +46,21 @@ function FileUploadControl(validators) {

* set functions that determines the synchronous validity of this control.
*/
/**
* set functions that determines the synchronous validity of this control.
* @template THIS
* @this {THIS}
* @param {?} newValidators
* @return {?}
* @return {THIS}
*/
FileUploadControl.prototype.setValidators = /**
* set functions that determines the synchronous validity of this control.
* @template THIS
* @this {THIS}
* @param {?} newValidators
* @return {?}
* @return {THIS}
*/
function (newValidators) {
this.defineValidators(newValidators);
this.validate();
return this;
(/** @type {?} */ (this)).defineValidators(newValidators);
(/** @type {?} */ (this)).validate();
return (/** @type {?} */ (this));
};

@@ -74,42 +81,59 @@ /**

/**
* @template THIS
* @this {THIS}
* @param {?} file
* @return {?}
* @return {THIS}
*/
FileUploadControl.prototype.addFile = /**
* @template THIS
* @this {THIS}
* @param {?} file
* @return {?}
* @return {THIS}
*/
function (file) {
this.files.add(file);
this.valueChanges.next(Array.from(this.files.values()));
this.validate();
return this;
(/** @type {?} */ (this)).files.add(file);
(/** @type {?} */ (this)).valueChanges.next(Array.from((/** @type {?} */ (this)).files.values()));
(/** @type {?} */ (this)).validate();
return (/** @type {?} */ (this));
};
/**
* @template THIS
* @this {THIS}
* @param {?} file
* @return {?}
* @return {THIS}
*/
FileUploadControl.prototype.removeFile = /**
* @template THIS
* @this {THIS}
* @param {?} file
* @return {?}
* @return {THIS}
*/
function (file) {
this.files.delete(file);
this.valueChanges.next(Array.from(this.files.values()));
this.validate();
return this;
(/** @type {?} */ (this)).files.delete(file);
(/** @type {?} */ (this)).valueChanges.next(Array.from((/** @type {?} */ (this)).files.values()));
(/** @type {?} */ (this)).validate();
return (/** @type {?} */ (this));
};
/**
* @template THIS
* @this {THIS}
* @param {?} files
* @return {?}
* @return {THIS}
*/
FileUploadControl.prototype.addFiles = /**
* @template THIS
* @this {THIS}
* @param {?} files
* @return {?}
* @return {THIS}
*/
function (files) {
this.addMultipleFiles(Array.from(files));
return this;
(/** @type {?} */ (this)).addMultipleFiles(Array.from(files));
return (/** @type {?} */ (this));
};
/**
* @internal
* used to prevent valueChanges emit more times
* when multiple files are uploaded
*/
/**
* \@internal

@@ -164,2 +188,5 @@ * used to prevent valueChanges emit more times

Object.defineProperty(FileUploadControl.prototype, "size", {
/**
* number of uploaded files
*/
get: /**

@@ -176,2 +203,5 @@ * number of uploaded files

Object.defineProperty(FileUploadControl.prototype, "value", {
/**
* return list of Files
*/
get: /**

@@ -188,13 +218,17 @@ * return list of Files

/**
* @template THIS
* @this {THIS}
* @param {?} files
* @return {?}
* @return {THIS}
*/
FileUploadControl.prototype.setValue = /**
* @template THIS
* @this {THIS}
* @param {?} files
* @return {?}
* @return {THIS}
*/
function (files) {
this.files.clear();
(/** @type {?} */ (this)).files.clear();
if (files instanceof Array) {
this.addMultipleFiles(files);
(/** @type {?} */ (this)).addMultipleFiles(files);
}

@@ -204,16 +238,23 @@ else {

}
return this;
return (/** @type {?} */ (this));
};
/**
* reset the control
* @return {?}
*/
/**
* reset the control
* @template THIS
* @this {THIS}
* @return {THIS}
*/
FileUploadControl.prototype.clear = /**
* reset the control
* @return {?}
* @template THIS
* @this {THIS}
* @return {THIS}
*/
function () {
this.files.clear();
this.valueChanges.next(Array.from(this.files.values()));
return this;
(/** @type {?} */ (this)).files.clear();
(/** @type {?} */ (this)).valueChanges.next(Array.from((/** @type {?} */ (this)).files.values()));
return (/** @type {?} */ (this));
};

@@ -231,14 +272,18 @@ Object.defineProperty(FileUploadControl.prototype, "isListVisible", {

/**
* @template THIS
* @this {THIS}
* @param {?=} isVisible
* @return {?}
* @return {THIS}
*/
FileUploadControl.prototype.setListVisibility = /**
* @template THIS
* @this {THIS}
* @param {?=} isVisible
* @return {?}
* @return {THIS}
*/
function (isVisible) {
if (isVisible === void 0) { isVisible = true; }
this.listVisible = isVisible;
this.listVisibilityChanges.next(this.listVisible);
return this;
(/** @type {?} */ (this)).listVisible = isVisible;
(/** @type {?} */ (this)).listVisibilityChanges.next((/** @type {?} */ (this)).listVisible);
return (/** @type {?} */ (this));
};

@@ -256,30 +301,38 @@ Object.defineProperty(FileUploadControl.prototype, "disabled", {

/**
* @template THIS
* @this {THIS}
* @param {?=} isEnabled
* @return {?}
* @return {THIS}
*/
FileUploadControl.prototype.enable = /**
* @template THIS
* @this {THIS}
* @param {?=} isEnabled
* @return {?}
* @return {THIS}
*/
function (isEnabled) {
if (isEnabled === void 0) { isEnabled = true; }
this.status = isEnabled ? STATUS.VALID : STATUS.DISABLED;
this.validate();
this.statusChanged.next(this.status);
return this;
(/** @type {?} */ (this)).status = isEnabled ? STATUS.VALID : STATUS.DISABLED;
(/** @type {?} */ (this)).validate();
(/** @type {?} */ (this)).statusChanged.next((/** @type {?} */ (this)).status);
return (/** @type {?} */ (this));
};
/**
* @template THIS
* @this {THIS}
* @param {?=} isDisabled
* @return {?}
* @return {THIS}
*/
FileUploadControl.prototype.disable = /**
* @template THIS
* @this {THIS}
* @param {?=} isDisabled
* @return {?}
* @return {THIS}
*/
function (isDisabled) {
if (isDisabled === void 0) { isDisabled = true; }
this.status = isDisabled ? STATUS.DISABLED : STATUS.VALID;
this.validate();
this.statusChanged.next(this.status);
return this;
(/** @type {?} */ (this)).status = isDisabled ? STATUS.DISABLED : STATUS.VALID;
(/** @type {?} */ (this)).validate();
(/** @type {?} */ (this)).statusChanged.next((/** @type {?} */ (this)).status);
return (/** @type {?} */ (this));
};

@@ -295,3 +348,4 @@ /**

if (this.status !== STATUS.DISABLED) {
var /** @type {?} */ currentState = this.valid;
/** @type {?} */
var currentState = this.valid;
this.errors = this.validators.map(function (validator) { return validator(_this); }).filter(function (isInvalid) { return isInvalid; });

@@ -309,3 +363,3 @@ if (currentState !== this.valid) {

export { FileUploadControl };
function FileUploadControl_tsickle_Closure_declarations() {
if (false) {
/** @type {?} */

@@ -342,3 +396,2 @@ FileUploadControl.prototype.files;

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"control.class.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["helpers/control.class.ts"],"names":[],"mappings":";;;;;AAAA,OAAO,EAAE,eAAe,EAAE,OAAO,EAAc,MAAM,MAAM,CAAC;AAE5D,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;;;;;;;;;;;AAQhD,IAAA;IAgCI,2BAAY,UAA2C;qBA9B5B,IAAI,GAAG,EAAE;2BAEd,IAAI;sBAED,MAAM,CAAC,KAAK;sBAES,EAAE;0BAEP,EAAE;6BAEF,IAAI,OAAO,EAAE;;;;6BAKX,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE;;;;;;4BAOf,IAAI,eAAe,CAAC,EAAE,CAAC;;;;;qCAMlB,IAAI,eAAe,CAAC,IAAI,CAAC,WAAW,CAAC;QAGnG,IAAI,CAAC,gBAAgB,CAAC,UAAU,CAAC,CAAC;KACrC;;;;;;IAKM,yCAAa;;;;;cAAC,aAA6C;QAC9D,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC;QACrC,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,MAAM,CAAC,IAAI,CAAC;;;;;;IAGR,4CAAgB;;;;cAAC,UAA0C;QAC/D,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YAC7B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,kBAAK,UAAU,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC;SAChF;;;;;;IAGE,mCAAO;;;;cAAC,IAAU;QACrB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACrB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QACxD,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,MAAM,CAAC,IAAI,CAAC;;;;;;IAGT,sCAAU;;;;cAAC,IAAU;QACxB,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACxB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QACxD,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,MAAM,CAAC,IAAI,CAAC;;;;;;IAGT,oCAAQ;;;;cAAC,KAAe;QAC3B,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;QACzC,MAAM,CAAC,IAAI,CAAC;;;;;;;;;IAQR,4CAAgB;;;;;;;cAAC,KAAkB;;QACvC,KAAK,CAAC,OAAO,CAAC,UAAA,IAAI,IAAI,OAAA,KAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAApB,CAAoB,CAAC,CAAC;QAC5C,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QACxD,IAAI,CAAC,QAAQ,EAAE,CAAC;;0BAGT,oCAAK;;;;;YACZ,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,KAAK,CAAC,IAAI,IAAI,CAAC,MAAM,KAAK,MAAM,CAAC,QAAQ,CAAC;;;;;0BAG5D,sCAAO;;;;;YACd,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,MAAM,KAAK,MAAM,CAAC,QAAQ,CAAA;;;;;;;;IAG7D,oCAAQ;;;;QACX,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC;;0BAMZ,mCAAI;;;;;;YACX,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;;;;;0BAMhB,oCAAK;;;;;;YACZ,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC;;;;;;;;;IAGpC,oCAAQ;;;;cAAC,KAAkB;QAC9B,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;QAEnB,EAAE,CAAA,CAAC,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC;YACxB,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;SAChC;QAAC,IAAI,CAAC,CAAC;YACJ,MAAM,KAAK,CAAC,iEAA+D,KAAK,sCAAmC,CAAC,CAAC;SACxH;QAED,MAAM,CAAC,IAAI,CAAC;;;;;;IAMT,iCAAK;;;;;QACR,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;QACnB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QACxD,MAAM,CAAC,IAAI,CAAC;;0BAGL,4CAAa;;;;;YACpB,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC;;;;;;;;;IAGrB,6CAAiB;;;;cAAC,SAAyB;QAAzB,0BAAA,EAAA,gBAAyB;QAC9C,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC;QAC7B,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAClD,MAAM,CAAC,IAAI,CAAC;;0BAGL,uCAAQ;;;;;YACf,MAAM,CAAC,IAAI,CAAC,MAAM,KAAK,MAAM,CAAC,QAAQ,CAAC;;;;;;;;;IAGpC,kCAAM;;;;cAAC,SAAyB;QAAzB,0BAAA,EAAA,gBAAyB;QACnC,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC;QACzD,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACrC,MAAM,CAAC,IAAI,CAAC;;;;;;IAGT,mCAAO;;;;cAAC,UAA0B;QAA1B,2BAAA,EAAA,iBAA0B;QACrC,IAAI,CAAC,MAAM,GAAG,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;QAC1D,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACrC,MAAM,CAAC,IAAI,CAAC;;;;;IAGR,oCAAQ;;;;;QACZ,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,KAAK,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC;YAClC,qBAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC;YAChC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,UAAC,SAAS,IAAK,OAAA,SAAS,CAAC,KAAI,CAAC,EAAf,CAAe,CAAC,CAAC,MAAM,CAAC,UAAC,SAAS,IAAK,OAAA,SAAS,EAAT,CAAS,CAAC,CAAC;YAEnG,EAAE,CAAC,CAAC,YAAY,KAAK,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;gBAC9B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;aACvE;SACJ;QAAC,IAAI,CAAC,CAAC;YACJ,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;SAC1B;;4BAhLT;IAkLC,CAAA;AAxKD,6BAwKC","sourcesContent":["import { BehaviorSubject, Subject, Observable } from 'rxjs';\r\nimport { ValidatorFn, ValidationErrors } from './validators.class';\r\nimport { IsNullOrEmpty } from './helpers.class';\r\n\r\nexport enum STATUS {\r\n    INVALID,\r\n    VALID,\r\n    DISABLED\r\n}\r\n\r\nexport class FileUploadControl {\r\n\r\n    private files: Set<File> = new Set();\r\n\r\n    private listVisible = true;\r\n\r\n    private status: STATUS = STATUS.VALID;\r\n\r\n    private errors: Array<{[key: string]: any}> = [];\r\n\r\n    private validators: Array<ValidatorFn> = [];\r\n\r\n    private statusChanged: Subject<STATUS> = new Subject();\r\n\r\n    /**\r\n     * track status `VALID`, `INVALID` or `DISABLED`\r\n     */\r\n    public statusChanges: Observable<STATUS> = this.statusChanged.asObservable();\r\n\r\n    /**\r\n     * emit an event every time the value of the control\r\n     * changes.\r\n     * Initially returns last value\r\n     */\r\n    public readonly valueChanges: BehaviorSubject<Array<File>> = new BehaviorSubject([]);\r\n\r\n    /**\r\n     * @internal\r\n     * used to trigger layout change for list visibility\r\n     */\r\n    public readonly listVisibilityChanges: BehaviorSubject<boolean> = new BehaviorSubject(this.listVisible);\r\n\r\n    constructor(validators?: ValidatorFn|Array<ValidatorFn>) {\r\n        this.defineValidators(validators);\r\n    }\r\n\r\n    /**\r\n     * set functions that determines the synchronous validity of this control.\r\n     */\r\n    public setValidators(newValidators: ValidatorFn|Array<ValidatorFn>): this {\r\n        this.defineValidators(newValidators);\r\n        this.validate();\r\n        return this;\r\n    }\r\n\r\n    private defineValidators(validators: ValidatorFn|Array<ValidatorFn>): void {\r\n        if (!IsNullOrEmpty(validators)) {\r\n            this.validators = Array.isArray(validators) ? [...validators] : [validators];\r\n        }\r\n    }\r\n\r\n    public addFile(file: File): this {\r\n        this.files.add(file);\r\n        this.valueChanges.next(Array.from(this.files.values()));\r\n        this.validate();\r\n        return this;\r\n    }\r\n\r\n    public removeFile(file: File): this {\r\n        this.files.delete(file);\r\n        this.valueChanges.next(Array.from(this.files.values()));\r\n        this.validate();\r\n        return this;\r\n    }\r\n\r\n    public addFiles(files: FileList): this {\r\n        this.addMultipleFiles(Array.from(files));\r\n        return this;\r\n    }\r\n\r\n    /** \r\n     * @internal \r\n     * used to prevent valueChanges emit more times\r\n     * when multiple files are uploaded\r\n     */\r\n    private addMultipleFiles(files: Array<File>): void {\r\n        files.forEach(file => this.files.add(file));\r\n        this.valueChanges.next(Array.from(this.files.values()));\r\n        this.validate();\r\n    }\r\n\r\n    public get valid(): boolean {\r\n        return this.errors.length === 0 && this.status !== STATUS.DISABLED;\r\n    }\r\n\r\n    public get invalid(): boolean {\r\n        return this.errors.length > 0 || this.status === STATUS.DISABLED\r\n    }\r\n\r\n    public getError(): Array<ValidationErrors> {\r\n        return this.errors;\r\n    }\r\n\r\n    /**\r\n     * number of uploaded files\r\n     */\r\n    public get size(): number {\r\n        return this.files.size;\r\n    }\r\n\r\n    /**\r\n     * return list of Files\r\n     */\r\n    public get value(): Array<File> {\r\n        return Array.from(this.files.values());\r\n    }\r\n\r\n    public setValue(files: Array<File>): this {\r\n        this.files.clear();\r\n\r\n        if(files instanceof Array) {\r\n            this.addMultipleFiles(files);\r\n        } else {\r\n            throw Error(`FormControl.setValue was provided with wrong argument type, ${files} was provided instead Array<File>`);\r\n        }\r\n\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * reset the control\r\n     */\r\n    public clear(): this {\r\n        this.files.clear();\r\n        this.valueChanges.next(Array.from(this.files.values()));\r\n        return this;\r\n    }\r\n\r\n    public get isListVisible(): boolean {\r\n        return this.listVisible;\r\n    }\r\n\r\n    public setListVisibility(isVisible: boolean = true): this {\r\n        this.listVisible = isVisible;\r\n        this.listVisibilityChanges.next(this.listVisible);\r\n        return this;\r\n    }\r\n\r\n    public get disabled() {\r\n        return this.status === STATUS.DISABLED;\r\n    }\r\n\r\n    public enable(isEnabled: boolean = true): this {\r\n        this.status = isEnabled ? STATUS.VALID : STATUS.DISABLED;\r\n        this.validate();\r\n        this.statusChanged.next(this.status);\r\n        return this;\r\n    }\r\n\r\n    public disable(isDisabled: boolean = true): this {\r\n        this.status = isDisabled ? STATUS.DISABLED : STATUS.VALID;\r\n        this.validate();\r\n        this.statusChanged.next(this.status);\r\n        return this;\r\n    }\r\n\r\n    private validate(): void {\r\n        if (this.status !== STATUS.DISABLED) {\r\n            const currentState = this.valid;\r\n            this.errors = this.validators.map((validator) => validator(this)).filter((isInvalid) => isInvalid);\r\n\r\n            if (currentState !== this.valid) {\r\n                this.statusChanged.next(this.valid ? STATUS.VALID : STATUS.INVALID);\r\n            }\r\n        } else {\r\n            this.errors.length = 0;\r\n        }\r\n    }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"control.class.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["helpers/control.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { BehaviorSubject, Subject, Observable } from 'rxjs';\r\nimport { ValidatorFn, ValidationErrors } from './validators.class';\r\nimport { IsNullOrEmpty } from './helpers.class';\r\n\r\nexport enum STATUS {\r\n    INVALID,\r\n    VALID,\r\n    DISABLED\r\n}\r\n\r\nexport class FileUploadControl {\r\n\r\n    private files: Set<File> = new Set();\r\n\r\n    private listVisible = true;\r\n\r\n    private status: STATUS = STATUS.VALID;\r\n\r\n    private errors: Array<{[key: string]: any}> = [];\r\n\r\n    private validators: Array<ValidatorFn> = [];\r\n\r\n    private statusChanged: Subject<STATUS> = new Subject();\r\n\r\n    /**\r\n     * track status `VALID`, `INVALID` or `DISABLED`\r\n     */\r\n    public statusChanges: Observable<STATUS> = this.statusChanged.asObservable();\r\n\r\n    /**\r\n     * emit an event every time the value of the control\r\n     * changes.\r\n     * Initially returns last value\r\n     */\r\n    public readonly valueChanges: BehaviorSubject<Array<File>> = new BehaviorSubject([]);\r\n\r\n    /**\r\n     * @internal\r\n     * used to trigger layout change for list visibility\r\n     */\r\n    public readonly listVisibilityChanges: BehaviorSubject<boolean> = new BehaviorSubject(this.listVisible);\r\n\r\n    constructor(validators?: ValidatorFn|Array<ValidatorFn>) {\r\n        this.defineValidators(validators);\r\n    }\r\n\r\n    /**\r\n     * set functions that determines the synchronous validity of this control.\r\n     */\r\n    public setValidators(newValidators: ValidatorFn|Array<ValidatorFn>): this {\r\n        this.defineValidators(newValidators);\r\n        this.validate();\r\n        return this;\r\n    }\r\n\r\n    private defineValidators(validators: ValidatorFn|Array<ValidatorFn>): void {\r\n        if (!IsNullOrEmpty(validators)) {\r\n            this.validators = Array.isArray(validators) ? [...validators] : [validators];\r\n        }\r\n    }\r\n\r\n    public addFile(file: File): this {\r\n        this.files.add(file);\r\n        this.valueChanges.next(Array.from(this.files.values()));\r\n        this.validate();\r\n        return this;\r\n    }\r\n\r\n    public removeFile(file: File): this {\r\n        this.files.delete(file);\r\n        this.valueChanges.next(Array.from(this.files.values()));\r\n        this.validate();\r\n        return this;\r\n    }\r\n\r\n    public addFiles(files: FileList): this {\r\n        this.addMultipleFiles(Array.from(files));\r\n        return this;\r\n    }\r\n\r\n    /** \r\n     * @internal \r\n     * used to prevent valueChanges emit more times\r\n     * when multiple files are uploaded\r\n     */\r\n    private addMultipleFiles(files: Array<File>): void {\r\n        files.forEach(file => this.files.add(file));\r\n        this.valueChanges.next(Array.from(this.files.values()));\r\n        this.validate();\r\n    }\r\n\r\n    public get valid(): boolean {\r\n        return this.errors.length === 0 && this.status !== STATUS.DISABLED;\r\n    }\r\n\r\n    public get invalid(): boolean {\r\n        return this.errors.length > 0 || this.status === STATUS.DISABLED\r\n    }\r\n\r\n    public getError(): Array<ValidationErrors> {\r\n        return this.errors;\r\n    }\r\n\r\n    /**\r\n     * number of uploaded files\r\n     */\r\n    public get size(): number {\r\n        return this.files.size;\r\n    }\r\n\r\n    /**\r\n     * return list of Files\r\n     */\r\n    public get value(): Array<File> {\r\n        return Array.from(this.files.values());\r\n    }\r\n\r\n    public setValue(files: Array<File>): this {\r\n        this.files.clear();\r\n\r\n        if(files instanceof Array) {\r\n            this.addMultipleFiles(files);\r\n        } else {\r\n            throw Error(`FormControl.setValue was provided with wrong argument type, ${files} was provided instead Array<File>`);\r\n        }\r\n\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * reset the control\r\n     */\r\n    public clear(): this {\r\n        this.files.clear();\r\n        this.valueChanges.next(Array.from(this.files.values()));\r\n        return this;\r\n    }\r\n\r\n    public get isListVisible(): boolean {\r\n        return this.listVisible;\r\n    }\r\n\r\n    public setListVisibility(isVisible: boolean = true): this {\r\n        this.listVisible = isVisible;\r\n        this.listVisibilityChanges.next(this.listVisible);\r\n        return this;\r\n    }\r\n\r\n    public get disabled() {\r\n        return this.status === STATUS.DISABLED;\r\n    }\r\n\r\n    public enable(isEnabled: boolean = true): this {\r\n        this.status = isEnabled ? STATUS.VALID : STATUS.DISABLED;\r\n        this.validate();\r\n        this.statusChanged.next(this.status);\r\n        return this;\r\n    }\r\n\r\n    public disable(isDisabled: boolean = true): this {\r\n        this.status = isDisabled ? STATUS.DISABLED : STATUS.VALID;\r\n        this.validate();\r\n        this.statusChanged.next(this.status);\r\n        return this;\r\n    }\r\n\r\n    private validate(): void {\r\n        if (this.status !== STATUS.DISABLED) {\r\n            const currentState = this.valid;\r\n            this.errors = this.validators.map((validator) => validator(this)).filter((isInvalid) => isInvalid);\r\n\r\n            if (currentState !== this.valid) {\r\n                this.statusChanged.next(this.valid ? STATUS.VALID : STATUS.INVALID);\r\n            }\r\n        } else {\r\n            this.errors.length = 0;\r\n        }\r\n    }\r\n}\r\n"]}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/

@@ -21,15 +21,15 @@ /** @enum {number} */

};
FileAccess[FileAccess.None] = "None";
FileAccess[FileAccess.Read] = "Read";
FileAccess[FileAccess.Write] = "Write";
FileAccess[FileAccess.ReadWrite] = "ReadWrite";
FileAccess[FileAccess.Execute] = "Execute";
FileAccess[FileAccess.ReadWriteExecute] = "ReadWriteExecute";
FileAccess[FileAccess.ExecuteRead] = "ExecuteRead";
FileAccess[FileAccess.r] = "r";
FileAccess[FileAccess.w] = "w";
FileAccess[FileAccess.x] = "x";
FileAccess[FileAccess.rw] = "rw";
FileAccess[FileAccess.rwx] = "rwx";
FileAccess[FileAccess.xr] = "xr";
FileAccess[FileAccess.None] = 'None';
FileAccess[FileAccess.Read] = 'Read';
FileAccess[FileAccess.Write] = 'Write';
FileAccess[FileAccess.ReadWrite] = 'ReadWrite';
FileAccess[FileAccess.Execute] = 'Execute';
FileAccess[FileAccess.ReadWriteExecute] = 'ReadWriteExecute';
FileAccess[FileAccess.ExecuteRead] = 'ExecuteRead';
FileAccess[FileAccess.r] = 'r';
FileAccess[FileAccess.w] = 'w';
FileAccess[FileAccess.x] = 'x';
FileAccess[FileAccess.rw] = 'rw';
FileAccess[FileAccess.rwx] = 'rwx';
FileAccess[FileAccess.xr] = 'xr';
/** @enum {string} */

@@ -98,8 +98,7 @@ var FileUploadTypes = {

zip: 'application/zip',
"3gp": 'video/3gpp',
"3g2": 'video/3gpp2',
"7z": 'application/x-7z-compressed',
'3gp': 'video/3gpp',
'3g2': 'video/3gpp2',
'7z': 'application/x-7z-compressed',
};
export { FileUploadTypes };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS10eXBlcy5jbGFzcy5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BpcGxhYi9uZ3gtZmlsZS11cGxvYWQvIiwic291cmNlcyI6WyJoZWxwZXJzL2ZpbGUtdHlwZXMuY2xhc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7U0F3QlUsV0FBVztTQUNYLHVCQUF1QjtTQUN2QiwwQkFBMEI7U0FDMUIsaUJBQWlCO1NBQ2pCLDhCQUE4QjtTQUM5QiwwQkFBMEI7U0FDMUIsV0FBVztRQUNaLG9CQUFvQjtTQUNuQixxQkFBcUI7U0FDckIsbUJBQW1CO1NBQ25CLFVBQVU7U0FDVixVQUFVO1NBQ1Ysb0JBQW9CO1VBQ25CLHlFQUF5RTtTQUMxRSwrQkFBK0I7VUFDOUIsc0JBQXNCO1FBQ3hCLHdCQUF3QjtTQUN2QixXQUFXO1VBQ1YsV0FBVztTQUNaLGNBQWM7U0FDZCxlQUFlO1NBQ2YsMEJBQTBCO1NBQzFCLFlBQVk7UUFDYix3QkFBd0I7VUFDdEIsa0JBQWtCO1VBQ2xCLFlBQVk7VUFDWixZQUFZO1VBQ1oscUNBQXFDO1NBQ3RDLGlEQUFpRDtTQUNqRCxnREFBZ0Q7U0FDaEQseUNBQXlDO1NBQ3pDLFdBQVc7U0FDWCxXQUFXO1NBQ1gsaUJBQWlCO1NBQ2pCLFVBQVU7U0FDVixXQUFXO1NBQ1gsaUJBQWlCO1NBQ2pCLCtCQUErQjtVQUM5QiwyRUFBMkU7U0FDNUUsMkVBQTJFO1NBQzNFLGlCQUFpQjtRQUNsQixrQkFBa0I7U0FDakIsZUFBZTtTQUNmLCtCQUErQjtTQUMvQixtQkFBbUI7VUFDbEIsWUFBWTtRQUNkLHdCQUF3QjtTQUN2QixVQUFVO1NBQ1YsdUJBQXVCO1NBQ3ZCLFdBQVc7VUFDVixZQUFZO1VBQ1osWUFBWTtVQUNaLFlBQVk7VUFDWixXQUFXO1dBQ1YsWUFBWTtXQUNaLHVCQUF1QjtTQUN6QiwwQkFBMEI7VUFDekIsbUVBQW1FO1NBQ3BFLGlCQUFpQjtTQUNqQixpQ0FBaUM7U0FDakMsaUJBQWlCO1dBQ2YsWUFBWTtXQUNaLGFBQWE7VUFDZCw2QkFBNkIiLCJzb3VyY2VzQ29udGVudCI6WyJcclxuLy8gLW93bmVyLWdyb3VwLW90aGVycy1cclxuLy8gLXJ3eHJ3eHJ3eCA9IDA3NzdcclxuZW51bSBGaWxlQWNjZXNzIHtcclxuICAgIE5vbmUsXHJcbiAgICBSZWFkID0gMSA8PCAyLFxyXG4gICAgV3JpdGUgPSAxIDw8IDEsXHJcbiAgICBSZWFkV3JpdGUgID0gUmVhZCB8IFdyaXRlLFxyXG4gICAgRXhlY3V0ZSA9IDEgPDwgMCxcclxuICAgIFJlYWRXcml0ZUV4ZWN1dGUgPSBSZWFkV3JpdGUgfCBFeGVjdXRlLFxyXG4gICAgRXhlY3V0ZVJlYWQgPSBFeGVjdXRlIHwgUmVhZCxcclxuICAgIHIgPSBSZWFkLFxyXG4gICAgdyA9IFdyaXRlLFxyXG4gICAgeCA9IEV4ZWN1dGUsXHJcbiAgICBydyA9IFJlYWRXcml0ZSxcclxuICAgIHJ3eCA9IFJlYWRXcml0ZUV4ZWN1dGUsXHJcbiAgICB4ciA9IEV4ZWN1dGVSZWFkXHJcbn1cclxuXHJcbi8qKlxyXG4gKiBUaGlzIHRhYmxlIGxpc3RzIHNvbWUgaW1wb3J0YW50IE1JTUUgdHlwZXMgZm9yIHRoZSBXZWIgY29waWVkIGZyb21cclxuICogaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvSFRUUC9CYXNpY3Nfb2ZfSFRUUC9NSU1FX3R5cGVzL0NvbXBsZXRlX2xpc3Rfb2ZfTUlNRV90eXBlc1xyXG4gKi9cclxuZXhwb3J0IGVudW0gRmlsZVVwbG9hZFR5cGVzIHtcclxuICAgIGFhYyA9ICdhdWRpby9hYWMnLFxyXG4gICAgYWJ3ID0gJ2FwcGxpY2F0aW9uL3gtYWJpd29yZCcsXHJcbiAgICBhcmMgPSAnYXBwbGljYXRpb24vb2N0ZXQtc3RyZWFtJyxcclxuICAgIGF2aSA9ICd2aWRlby94LW1zdmlkZW8nLFxyXG4gICAgYXp3ID0gJ2FwcGxpY2F0aW9uL3ZuZC5hbWF6b24uZWJvb2snLFxyXG4gICAgYmluID0gJ2FwcGxpY2F0aW9uL29jdGV0LXN0cmVhbScsXHJcbiAgICBibXAgPSAnaW1hZ2UvYm1wJyxcclxuICAgIGJ6ID0gJ2FwcGxpY2F0aW9uL3gtYnppcCcsXHJcbiAgICBiejIgPSAnYXBwbGljYXRpb24veC1iemlwMicsXHJcbiAgICBjc2ggPSAnYXBwbGljYXRpb24veC1jc2gnLFxyXG4gICAgY3NzID0gJ3RleHQvY3NzJyxcclxuICAgIGNzdiA9ICd0ZXh0L2NzdicsXHJcbiAgICBkb2MgPSAnYXBwbGljYXRpb24vbXN3b3JkJyxcclxuICAgIGRvY3ggPSAnYXBwbGljYXRpb24vdm5kLm9wZW54bWxmb3JtYXRzLW9mZmljZWRvY3VtZW50LndvcmRwcm9jZXNzaW5nbWwuZG9jdW1lbnQnLFxyXG4gICAgZW90ID0gJ2FwcGxpY2F0aW9uL3ZuZC5tcy1mb250b2JqZWN0JyxcclxuICAgIGVwdWIgPSAnYXBwbGljYXRpb24vZXB1Yit6aXAnLFxyXG4gICAgZXMgPSAnYXBwbGljYXRpb24vZWNtYXNjcmlwdCcsXHJcbiAgICBnaWYgPSAnaW1hZ2UvZ2lmJyxcclxuICAgIGh0bWwgPSAndGV4dC9odG1sJyxcclxuICAgIGljbyA9ICdpbWFnZS94LWljb24nLFxyXG4gICAgaWNzID0gJ3RleHQvY2FsZW5kYXInLFxyXG4gICAgamFyID0gJ2FwcGxpY2F0aW9uL2phdmEtYXJjaGl2ZScsXHJcbiAgICBqcGcgPSAnaW1hZ2UvanBlZycsXHJcbiAgICBqcyA9ICdhcHBsaWNhdGlvbi9qYXZhc2NyaXB0JyxcclxuICAgIGpzb24gPSAnYXBwbGljYXRpb24vanNvbicsXHJcbiAgICBtaWRpID0gJ2F1ZGlvL21pZGknLFxyXG4gICAgbXBlZyA9ICd2aWRlby9tcGVnJyxcclxuICAgIG1wa2cgPSAnYXBwbGljYXRpb24vdm5kLmFwcGxlLmluc3RhbGxlcit4bWwnLFxyXG4gICAgb2RwID0gJ2FwcGxpY2F0aW9uL3ZuZC5vYXNpcy5vcGVuZG9jdW1lbnQucHJlc2VudGF0aW9uJyxcclxuICAgIG9kcyA9ICdhcHBsaWNhdGlvbi92bmQub2FzaXMub3BlbmRvY3VtZW50LnNwcmVhZHNoZWV0JyxcclxuICAgIG9kdCA9ICdhcHBsaWNhdGlvbi92bmQub2FzaXMub3BlbmRvY3VtZW50LnRleHQnLFxyXG4gICAgb2dhID0gJ2F1ZGlvL29nZycsXHJcbiAgICBvZ3YgPSAndmlkZW8vb2dnJyxcclxuICAgIG9neCA9ICdhcHBsaWNhdGlvbi9vZ2cnLFxyXG4gICAgb3RmID0gJ2ZvbnQvb3RmJyxcclxuICAgIHBuZyA9ICdpbWFnZS9wbmcnLFxyXG4gICAgcGRmID0gJ2FwcGxpY2F0aW9uL3BkZicsXHJcbiAgICBwcHQgPSAnYXBwbGljYXRpb24vdm5kLm1zLXBvd2VycG9pbnQnLFxyXG4gICAgcHB0eCA9ICdhcHBsaWNhdGlvbi92bmQub3BlbnhtbGZvcm1hdHMtb2ZmaWNlZG9jdW1lbnQucHJlc2VudGF0aW9ubWwucHJlc2VudGF0aW9uJyxcclxuICAgIHJhciA9ICdhcHBsaWNhdGlvbi92bmQub3BlbnhtbGZvcm1hdHMtb2ZmaWNlZG9jdW1lbnQucHJlc2VudGF0aW9ubWwucHJlc2VudGF0aW9uJyxcclxuICAgIHJ0ZiA9ICdhcHBsaWNhdGlvbi9ydGYnLFxyXG4gICAgc2ggPSAnYXBwbGljYXRpb24veC1zaCcsXHJcbiAgICBzdmcgPSAnaW1hZ2Uvc3ZnK3htbCcsXHJcbiAgICBzd2YgPSAnYXBwbGljYXRpb24veC1zaG9ja3dhdmUtZmxhc2gnLFxyXG4gICAgdGFyID0gJ2FwcGxpY2F0aW9uL3gtdGFyJyxcclxuICAgIHRpZmYgPSAnaW1hZ2UvdGlmZicsXHJcbiAgICB0cyA9ICdhcHBsaWNhdGlvbi90eXBlc2NyaXB0JyxcclxuICAgIHR0ZiA9ICdmb250L3R0ZicsXHJcbiAgICB2c2QgPSAnYXBwbGljYXRpb24vdm5kLnZpc2lvJyxcclxuICAgIHdhdiA9ICdhdWRpby93YXYnLFxyXG4gICAgd2ViYSA9ICdhdWRpby93ZWJtJyxcclxuICAgIHdlYm0gPSAndmlkZW8vd2VibScsXHJcbiAgICB3ZWJwID0gJ2ltYWdlL3dlYnAnLFxyXG4gICAgd29mZiA9ICdmb250L3dvZmYnLFxyXG4gICAgd29mZjIgPSAnZm9udC93b2ZmMicsXHJcbiAgICB4aHRtbCA9ICdhcHBsaWNhdGlvbi94aHRtbCt4bWwnLFxyXG4gICAgeGxzID0gJ2FwcGxpY2F0aW9uL3ZuZC5tcy1leGNlbCcsXHJcbiAgICB4bHN4ID0gJ2FwcGxpY2F0aW9uL3ZuZC5vcGVueG1sZm9ybWF0cy1vZmZpY2Vkb2N1bWVudC5zcHJlYWRzaGVldG1sLnNoZWV0JyxcclxuICAgIHhtbCA9ICdhcHBsaWNhdGlvbi94bWwnLFxyXG4gICAgeHVsID0gJ2FwcGxpY2F0aW9uL3ZuZC5tb3ppbGxhLnh1bCt4bWwnLFxyXG4gICAgemlwID0gJ2FwcGxpY2F0aW9uL3ppcCcsXHJcbiAgICAnM2dwJyA9ICd2aWRlby8zZ3BwJyxcclxuICAgICczZzInID0gJ3ZpZGVvLzNncHAyJyxcclxuICAgICc3eicgPSAnYXBwbGljYXRpb24veC03ei1jb21wcmVzc2VkJ1xyXG59XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS10eXBlcy5jbGFzcy5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BpcGxhYi9uZ3gtZmlsZS11cGxvYWQvIiwic291cmNlcyI6WyJoZWxwZXJzL2ZpbGUtdHlwZXMuY2xhc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0lBSUksT0FBSTtJQUNKLE9BQWE7SUFDYixRQUFjO0lBQ2QsWUFBeUI7SUFDekIsVUFBZ0I7SUFDaEIsbUJBQXNDO0lBQ3RDLGNBQTRCO0lBQzVCLElBQVE7SUFDUixJQUFTO0lBQ1QsSUFBVztJQUNYLEtBQWM7SUFDZCxNQUFzQjtJQUN0QixLQUFnQjs7Ozs7Ozs7Ozs7Ozs7Ozs7SUFRaEIsS0FBTSxXQUFXO0lBQ2pCLEtBQU0sdUJBQXVCO0lBQzdCLEtBQU0sMEJBQTBCO0lBQ2hDLEtBQU0saUJBQWlCO0lBQ3ZCLEtBQU0sOEJBQThCO0lBQ3BDLEtBQU0sMEJBQTBCO0lBQ2hDLEtBQU0sV0FBVztJQUNqQixJQUFLLG9CQUFvQjtJQUN6QixLQUFNLHFCQUFxQjtJQUMzQixLQUFNLG1CQUFtQjtJQUN6QixLQUFNLFVBQVU7SUFDaEIsS0FBTSxVQUFVO0lBQ2hCLEtBQU0sb0JBQW9CO0lBQzFCLE1BQU8seUVBQXlFO0lBQ2hGLEtBQU0sK0JBQStCO0lBQ3JDLE1BQU8sc0JBQXNCO0lBQzdCLElBQUssd0JBQXdCO0lBQzdCLEtBQU0sV0FBVztJQUNqQixNQUFPLFdBQVc7SUFDbEIsS0FBTSxjQUFjO0lBQ3BCLEtBQU0sZUFBZTtJQUNyQixLQUFNLDBCQUEwQjtJQUNoQyxLQUFNLFlBQVk7SUFDbEIsSUFBSyx3QkFBd0I7SUFDN0IsTUFBTyxrQkFBa0I7SUFDekIsTUFBTyxZQUFZO0lBQ25CLE1BQU8sWUFBWTtJQUNuQixNQUFPLHFDQUFxQztJQUM1QyxLQUFNLGlEQUFpRDtJQUN2RCxLQUFNLGdEQUFnRDtJQUN0RCxLQUFNLHlDQUF5QztJQUMvQyxLQUFNLFdBQVc7SUFDakIsS0FBTSxXQUFXO0lBQ2pCLEtBQU0saUJBQWlCO0lBQ3ZCLEtBQU0sVUFBVTtJQUNoQixLQUFNLFdBQVc7SUFDakIsS0FBTSxpQkFBaUI7SUFDdkIsS0FBTSwrQkFBK0I7SUFDckMsTUFBTywyRUFBMkU7SUFDbEYsS0FBTSwyRUFBMkU7SUFDakYsS0FBTSxpQkFBaUI7SUFDdkIsSUFBSyxrQkFBa0I7SUFDdkIsS0FBTSxlQUFlO0lBQ3JCLEtBQU0sK0JBQStCO0lBQ3JDLEtBQU0sbUJBQW1CO0lBQ3pCLE1BQU8sWUFBWTtJQUNuQixJQUFLLHdCQUF3QjtJQUM3QixLQUFNLFVBQVU7SUFDaEIsS0FBTSx1QkFBdUI7SUFDN0IsS0FBTSxXQUFXO0lBQ2pCLE1BQU8sWUFBWTtJQUNuQixNQUFPLFlBQVk7SUFDbkIsTUFBTyxZQUFZO0lBQ25CLE1BQU8sV0FBVztJQUNsQixPQUFRLFlBQVk7SUFDcEIsT0FBUSx1QkFBdUI7SUFDL0IsS0FBTSwwQkFBMEI7SUFDaEMsTUFBTyxtRUFBbUU7SUFDMUUsS0FBTSxpQkFBaUI7SUFDdkIsS0FBTSxpQ0FBaUM7SUFDdkMsS0FBTSxpQkFBaUI7SUFDdkIsT0FBUSxZQUFZO0lBQ3BCLE9BQVEsYUFBYTtJQUNyQixNQUFPLDZCQUE2QiIsInNvdXJjZXNDb250ZW50IjpbIlxyXG4vLyAtb3duZXItZ3JvdXAtb3RoZXJzLVxyXG4vLyAtcnd4cnd4cnd4ID0gMDc3N1xyXG5lbnVtIEZpbGVBY2Nlc3Mge1xyXG4gICAgTm9uZSxcclxuICAgIFJlYWQgPSAxIDw8IDIsXHJcbiAgICBXcml0ZSA9IDEgPDwgMSxcclxuICAgIFJlYWRXcml0ZSAgPSBSZWFkIHwgV3JpdGUsXHJcbiAgICBFeGVjdXRlID0gMSA8PCAwLFxyXG4gICAgUmVhZFdyaXRlRXhlY3V0ZSA9IFJlYWRXcml0ZSB8IEV4ZWN1dGUsXHJcbiAgICBFeGVjdXRlUmVhZCA9IEV4ZWN1dGUgfCBSZWFkLFxyXG4gICAgciA9IFJlYWQsXHJcbiAgICB3ID0gV3JpdGUsXHJcbiAgICB4ID0gRXhlY3V0ZSxcclxuICAgIHJ3ID0gUmVhZFdyaXRlLFxyXG4gICAgcnd4ID0gUmVhZFdyaXRlRXhlY3V0ZSxcclxuICAgIHhyID0gRXhlY3V0ZVJlYWRcclxufVxyXG5cclxuLyoqXHJcbiAqIFRoaXMgdGFibGUgbGlzdHMgc29tZSBpbXBvcnRhbnQgTUlNRSB0eXBlcyBmb3IgdGhlIFdlYiBjb3BpZWQgZnJvbVxyXG4gKiBodHRwczovL2RldmVsb3Blci5tb3ppbGxhLm9yZy9lbi1VUy9kb2NzL1dlYi9IVFRQL0Jhc2ljc19vZl9IVFRQL01JTUVfdHlwZXMvQ29tcGxldGVfbGlzdF9vZl9NSU1FX3R5cGVzXHJcbiAqL1xyXG5leHBvcnQgZW51bSBGaWxlVXBsb2FkVHlwZXMge1xyXG4gICAgYWFjID0gJ2F1ZGlvL2FhYycsXHJcbiAgICBhYncgPSAnYXBwbGljYXRpb24veC1hYml3b3JkJyxcclxuICAgIGFyYyA9ICdhcHBsaWNhdGlvbi9vY3RldC1zdHJlYW0nLFxyXG4gICAgYXZpID0gJ3ZpZGVvL3gtbXN2aWRlbycsXHJcbiAgICBhencgPSAnYXBwbGljYXRpb24vdm5kLmFtYXpvbi5lYm9vaycsXHJcbiAgICBiaW4gPSAnYXBwbGljYXRpb24vb2N0ZXQtc3RyZWFtJyxcclxuICAgIGJtcCA9ICdpbWFnZS9ibXAnLFxyXG4gICAgYnogPSAnYXBwbGljYXRpb24veC1iemlwJyxcclxuICAgIGJ6MiA9ICdhcHBsaWNhdGlvbi94LWJ6aXAyJyxcclxuICAgIGNzaCA9ICdhcHBsaWNhdGlvbi94LWNzaCcsXHJcbiAgICBjc3MgPSAndGV4dC9jc3MnLFxyXG4gICAgY3N2ID0gJ3RleHQvY3N2JyxcclxuICAgIGRvYyA9ICdhcHBsaWNhdGlvbi9tc3dvcmQnLFxyXG4gICAgZG9jeCA9ICdhcHBsaWNhdGlvbi92bmQub3BlbnhtbGZvcm1hdHMtb2ZmaWNlZG9jdW1lbnQud29yZHByb2Nlc3NpbmdtbC5kb2N1bWVudCcsXHJcbiAgICBlb3QgPSAnYXBwbGljYXRpb24vdm5kLm1zLWZvbnRvYmplY3QnLFxyXG4gICAgZXB1YiA9ICdhcHBsaWNhdGlvbi9lcHViK3ppcCcsXHJcbiAgICBlcyA9ICdhcHBsaWNhdGlvbi9lY21hc2NyaXB0JyxcclxuICAgIGdpZiA9ICdpbWFnZS9naWYnLFxyXG4gICAgaHRtbCA9ICd0ZXh0L2h0bWwnLFxyXG4gICAgaWNvID0gJ2ltYWdlL3gtaWNvbicsXHJcbiAgICBpY3MgPSAndGV4dC9jYWxlbmRhcicsXHJcbiAgICBqYXIgPSAnYXBwbGljYXRpb24vamF2YS1hcmNoaXZlJyxcclxuICAgIGpwZyA9ICdpbWFnZS9qcGVnJyxcclxuICAgIGpzID0gJ2FwcGxpY2F0aW9uL2phdmFzY3JpcHQnLFxyXG4gICAganNvbiA9ICdhcHBsaWNhdGlvbi9qc29uJyxcclxuICAgIG1pZGkgPSAnYXVkaW8vbWlkaScsXHJcbiAgICBtcGVnID0gJ3ZpZGVvL21wZWcnLFxyXG4gICAgbXBrZyA9ICdhcHBsaWNhdGlvbi92bmQuYXBwbGUuaW5zdGFsbGVyK3htbCcsXHJcbiAgICBvZHAgPSAnYXBwbGljYXRpb24vdm5kLm9hc2lzLm9wZW5kb2N1bWVudC5wcmVzZW50YXRpb24nLFxyXG4gICAgb2RzID0gJ2FwcGxpY2F0aW9uL3ZuZC5vYXNpcy5vcGVuZG9jdW1lbnQuc3ByZWFkc2hlZXQnLFxyXG4gICAgb2R0ID0gJ2FwcGxpY2F0aW9uL3ZuZC5vYXNpcy5vcGVuZG9jdW1lbnQudGV4dCcsXHJcbiAgICBvZ2EgPSAnYXVkaW8vb2dnJyxcclxuICAgIG9ndiA9ICd2aWRlby9vZ2cnLFxyXG4gICAgb2d4ID0gJ2FwcGxpY2F0aW9uL29nZycsXHJcbiAgICBvdGYgPSAnZm9udC9vdGYnLFxyXG4gICAgcG5nID0gJ2ltYWdlL3BuZycsXHJcbiAgICBwZGYgPSAnYXBwbGljYXRpb24vcGRmJyxcclxuICAgIHBwdCA9ICdhcHBsaWNhdGlvbi92bmQubXMtcG93ZXJwb2ludCcsXHJcbiAgICBwcHR4ID0gJ2FwcGxpY2F0aW9uL3ZuZC5vcGVueG1sZm9ybWF0cy1vZmZpY2Vkb2N1bWVudC5wcmVzZW50YXRpb25tbC5wcmVzZW50YXRpb24nLFxyXG4gICAgcmFyID0gJ2FwcGxpY2F0aW9uL3ZuZC5vcGVueG1sZm9ybWF0cy1vZmZpY2Vkb2N1bWVudC5wcmVzZW50YXRpb25tbC5wcmVzZW50YXRpb24nLFxyXG4gICAgcnRmID0gJ2FwcGxpY2F0aW9uL3J0ZicsXHJcbiAgICBzaCA9ICdhcHBsaWNhdGlvbi94LXNoJyxcclxuICAgIHN2ZyA9ICdpbWFnZS9zdmcreG1sJyxcclxuICAgIHN3ZiA9ICdhcHBsaWNhdGlvbi94LXNob2Nrd2F2ZS1mbGFzaCcsXHJcbiAgICB0YXIgPSAnYXBwbGljYXRpb24veC10YXInLFxyXG4gICAgdGlmZiA9ICdpbWFnZS90aWZmJyxcclxuICAgIHRzID0gJ2FwcGxpY2F0aW9uL3R5cGVzY3JpcHQnLFxyXG4gICAgdHRmID0gJ2ZvbnQvdHRmJyxcclxuICAgIHZzZCA9ICdhcHBsaWNhdGlvbi92bmQudmlzaW8nLFxyXG4gICAgd2F2ID0gJ2F1ZGlvL3dhdicsXHJcbiAgICB3ZWJhID0gJ2F1ZGlvL3dlYm0nLFxyXG4gICAgd2VibSA9ICd2aWRlby93ZWJtJyxcclxuICAgIHdlYnAgPSAnaW1hZ2Uvd2VicCcsXHJcbiAgICB3b2ZmID0gJ2ZvbnQvd29mZicsXHJcbiAgICB3b2ZmMiA9ICdmb250L3dvZmYyJyxcclxuICAgIHhodG1sID0gJ2FwcGxpY2F0aW9uL3hodG1sK3htbCcsXHJcbiAgICB4bHMgPSAnYXBwbGljYXRpb24vdm5kLm1zLWV4Y2VsJyxcclxuICAgIHhsc3ggPSAnYXBwbGljYXRpb24vdm5kLm9wZW54bWxmb3JtYXRzLW9mZmljZWRvY3VtZW50LnNwcmVhZHNoZWV0bWwuc2hlZXQnLFxyXG4gICAgeG1sID0gJ2FwcGxpY2F0aW9uL3htbCcsXHJcbiAgICB4dWwgPSAnYXBwbGljYXRpb24vdm5kLm1vemlsbGEueHVsK3htbCcsXHJcbiAgICB6aXAgPSAnYXBwbGljYXRpb24vemlwJyxcclxuICAgICczZ3AnID0gJ3ZpZGVvLzNncHAnLFxyXG4gICAgJzNnMicgPSAndmlkZW8vM2dwcDInLFxyXG4gICAgJzd6JyA9ICdhcHBsaWNhdGlvbi94LTd6LWNvbXByZXNzZWQnXHJcbn1cclxuIl19
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/

@@ -12,3 +12,2 @@ /**

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscGVycy5jbGFzcy5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BpcGxhYi9uZ3gtZmlsZS11cGxvYWQvIiwic291cmNlcyI6WyJoZWxwZXJzL2hlbHBlcnMuY2xhc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFBQSxNQUFNLHdCQUF3QixLQUFVO0lBQ3BDLE1BQU0sQ0FBQyxLQUFLLElBQUksSUFBSSxJQUFJLEtBQUssQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFDO0NBQzlDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGZ1bmN0aW9uIElzTnVsbE9yRW1wdHkodmFsdWU6IGFueSk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIHZhbHVlID09IG51bGwgfHwgdmFsdWUubGVuZ3RoID09PSAwO1xyXG59Il19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscGVycy5jbGFzcy5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BpcGxhYi9uZ3gtZmlsZS11cGxvYWQvIiwic291cmNlcyI6WyJoZWxwZXJzL2hlbHBlcnMuY2xhc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFBQSxNQUFNLFVBQVUsYUFBYSxDQUFDLEtBQVU7SUFDcEMsT0FBTyxLQUFLLElBQUksSUFBSSxJQUFJLEtBQUssQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFDO0FBQy9DLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZnVuY3Rpb24gSXNOdWxsT3JFbXB0eSh2YWx1ZTogYW55KTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdmFsdWUgPT0gbnVsbCB8fCB2YWx1ZS5sZW5ndGggPT09IDA7XHJcbn0iXX0=
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/

@@ -10,7 +10,2 @@ import { IsNullOrEmpty } from './helpers.class';

export function ValidationErrors() { }
function ValidationErrors_tsickle_Closure_declarations() {
/* TODO: handle strange member:
[key: string]: any;
*/
}
/**

@@ -20,11 +15,7 @@ * @record

export function ValidatorFn() { }
function ValidatorFn_tsickle_Closure_declarations() {
/* TODO: handle strange member:
(c: AbstractControl | FileUploadControl): ValidationErrors | null;
*/
}
/**
* function used to check file size
* @type {?}
*/
var /** @type {?} */ checkFileSize = function (file, maxSize, minSize) {
var checkFileSize = function (file, maxSize, minSize) {
if (minSize === void 0) { minSize = 0; }

@@ -35,3 +26,4 @@ return (!IsNullOrEmpty(maxSize) && file.size > maxSize) || file.size < minSize ?

var ɵ0 = checkFileSize;
var /** @type {?} */ FILE_EXT_REG = /(^[.]\w*)$/gm;
/** @type {?} */
var FILE_EXT_REG = /(^[.]\w*)$/gm;
/**

@@ -42,8 +34,12 @@ * function used to check file type

* file_extension|audio/*|video/*|image/*|media_type
* @type {?}
*/
var /** @type {?} */ checkFileType = function (file, allowedTypes) {
var /** @type {?} */ fileExtension = file.name.slice((file.name.lastIndexOf(".") - 1 >>> 0) + 1);
var /** @type {?} */ isValid = false;
for (var /** @type {?} */ i = 0; i < allowedTypes.length; i++) {
var /** @type {?} */ type = allowedTypes[i];
var checkFileType = function (file, allowedTypes) {
/** @type {?} */
var fileExtension = file.name.slice((file.name.lastIndexOf(".") - 1 >>> 0) + 1);
/** @type {?} */
var isValid = false;
for (var i = 0; i < allowedTypes.length; i++) {
/** @type {?} */
var type = allowedTypes[i];
isValid = FILE_EXT_REG.test(type) ? type === fileExtension : new RegExp(type).test(file.type);

@@ -58,9 +54,15 @@ if (isValid) {

var ɵ1 = checkFileType;
var /** @type {?} */ checkValueType = function (value) {
/** @type {?} */
var checkValueType = function (value) {
if (!Array.isArray(value)) {
throw Error("FormControl.setValue was provided with wrong argument type, " + value + " was provided instead Array<File>");
}
};
}
// @dynamic
;
var ɵ2 = checkValueType;
var FileUploadValidators = /** @class */ (function () {
// @dynamic
var
// @dynamic
FileUploadValidators = /** @class */ (function () {
function FileUploadValidators() {

@@ -71,2 +73,7 @@ }

* Compare the File size in bytes
* @dynamic
*/
/**
* Validator that requires controls to have a file maximum size length.
* Compare the File size in bytes
* \@dynamic

@@ -85,3 +92,4 @@ * @param {?} maxSize

return function (control) {
var /** @type {?} */ files = control.value;
/** @type {?} */
var files = control.value;
if (IsNullOrEmpty(files)) {

@@ -91,3 +99,4 @@ return null;

checkValueType(files);
var /** @type {?} */ toLargeFiles = files.map(function (file) { return checkFileSize(file, maxSize); })
/** @type {?} */
var toLargeFiles = files.map(function (file) { return checkFileSize(file, maxSize); })
.filter(function (error) { return error; });

@@ -100,2 +109,6 @@ return toLargeFiles.length > 0 ?

* Compare the File size in bytes with max and min size limits
* @dynamic
*/
/**
* Compare the File size in bytes with max and min size limits
* \@dynamic

@@ -114,3 +127,4 @@ * @param {?} __0

return function (control) {
var /** @type {?} */ files = control.value;
/** @type {?} */
var files = control.value;
if (IsNullOrEmpty(files)) {

@@ -120,3 +134,4 @@ return null;

checkValueType(files);
var /** @type {?} */ sizeMismatch = files.map(function (file) { return checkFileSize(file, maxSize, minSize); })
/** @type {?} */
var sizeMismatch = files.map(function (file) { return checkFileSize(file, maxSize, minSize); })
.filter(function (error) { return error; });

@@ -129,2 +144,6 @@ return sizeMismatch.length > 0 ?

* validator that requires control to have limit on files number
* @dynamic
*/
/**
* validator that requires control to have limit on files number
* \@dynamic

@@ -142,3 +161,4 @@ * @param {?} numFiles

return function (control) {
var /** @type {?} */ files = control.value;
/** @type {?} */
var files = control.value;
if (IsNullOrEmpty(files)) {

@@ -166,2 +186,18 @@ return null;

* `FileUploadValidators.accept([file_extension, audio/*, video/*, image/*, media_type])`
* @dynamic
*/
/**
* validator that requires control to have limit on media types
*
* ##### Allowed media types are
*
* - file_extension - a file extension starting with the STOP character,
* e.g: .gif, .jpg, .png, .doc
* - audio/* - All sound files are accepted
* - video/* - All video files are accepted
* - image/* - All image files are accepted
* - media_type - A valid media type, with no parameters. Look at [IANA Media Types](https://www.iana.org/assignments/media-types/media-types.xhtml) for a complete list of standard media types
*
* #### Example
* `FileUploadValidators.accept([file_extension, audio/*, video/*, image/*, media_type])`
* \@dynamic

@@ -191,3 +227,4 @@ * @param {?} allowedFileTypes

return function (control) {
var /** @type {?} */ files = control.value;
/** @type {?} */
var files = control.value;
if (IsNullOrEmpty(files)) {

@@ -197,3 +234,4 @@ return null;

checkValueType(files);
var /** @type {?} */ notAllowedFiles = files.map(function (file) { return checkFileType(file, allowedFileTypes); })
/** @type {?} */
var notAllowedFiles = files.map(function (file) { return checkFileType(file, allowedFileTypes); })
.filter(function (error) { return error; });

@@ -206,5 +244,5 @@ return notAllowedFiles.length > 0 ?

}());
// @dynamic
export { FileUploadValidators };
export { ɵ0, ɵ1, ɵ2 };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validators.class.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["helpers/validators.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl } from '@angular/forms';\r\nimport { IsNullOrEmpty } from './helpers.class';\r\nimport { FileUploadControl } from './control.class';\r\n\r\nexport interface ValidationErrors {\r\n    [key: string]: any;\r\n}\r\n\r\nexport interface ValidatorFn {\r\n    (c: AbstractControl | FileUploadControl): ValidationErrors | null;\r\n}\r\n\r\n/**\r\n * function used to check file size\r\n */\r\nconst checkFileSize = (file: File, maxSize: number, minSize: number = 0): ValidationErrors | null => {\r\n    return (!IsNullOrEmpty(maxSize) && file.size > maxSize) || file.size < minSize ?\r\n        {maxSize, minSize, actual: file.size, file} : null;\r\n}\r\n\r\nconst FILE_EXT_REG = /(^[.]\\w*)$/gm;\r\n/**\r\n * function used to check file type\r\n * \r\n * #### allowedTypes\r\n * file_extension|audio/*|video/*|image/*|media_type\r\n */\r\nconst checkFileType = (file: File, allowedTypes: Array<string>): ValidationErrors | null => {\r\n    const fileExtension = file.name.slice((file.name.lastIndexOf(\".\") - 1 >>> 0) + 1);\r\n    let isValid = false;\r\n    for(let i = 0; i < allowedTypes.length; i++ ) {\r\n        let type = allowedTypes[i];\r\n\r\n        isValid = FILE_EXT_REG.test(type) ? type === fileExtension : new RegExp(type).test(file.type);\r\n        if(isValid) {\r\n            break;\r\n        }\r\n    }\r\n\r\n    return isValid ?\r\n            null : {allowedTypes, actual: file.type, file};\r\n}\r\n\r\nconst checkValueType = (value: any ): void => {\r\n    if (!Array.isArray(value)) {\r\n        throw Error(`FormControl.setValue was provided with wrong argument type, ${value} was provided instead Array<File>`);\r\n    }\r\n}\r\n\r\n// @dynamic\r\nexport class FileUploadValidators {\r\n\r\n    /**\r\n     * Validator that requires controls to have a file maximum size length.\r\n     * Compare the File size in bytes\r\n     * @dynamic\r\n     */\r\n    public static fileSize(maxSize: number): ValidatorFn {\r\n        return (control: AbstractControl | FileUploadControl): {fileSize: Array<ValidationErrors>} => {\r\n            const files: Array<File> = control.value;\r\n            if (IsNullOrEmpty(files)) { return null; }\r\n            checkValueType(files);\r\n\r\n            const toLargeFiles = files.map((file) => checkFileSize(file, maxSize))\r\n                                        .filter((error) => error);\r\n\r\n            return toLargeFiles.length > 0 ?\r\n                    {'fileSize': toLargeFiles} : null;\r\n        };\r\n    }\r\n\r\n    /**\r\n     * Compare the File size in bytes with max and min size limits\r\n     * @dynamic\r\n     */\r\n    public static sizeRange({ minSize, maxSize }: { minSize?: number; maxSize?: number }): ValidatorFn {\r\n        return (control: AbstractControl | FileUploadControl): {sizeRange: Array<ValidationErrors>} => {\r\n            const files: Array<File> = control.value;\r\n            if (IsNullOrEmpty(files)) { return null; }\r\n            checkValueType(files);\r\n\r\n            const sizeMismatch = files.map((file) => checkFileSize(file, maxSize, minSize))\r\n                                        .filter((error) => error);\r\n\r\n            return sizeMismatch.length > 0 ?\r\n                    {'sizeRange': sizeMismatch} : null;\r\n        };\r\n    }\r\n\r\n    /**\r\n     * validator that requires control to have limit on files number\r\n     * @dynamic\r\n     */\r\n    public static filesLimit(numFiles: number): ValidatorFn {\r\n        return (control: AbstractControl | FileUploadControl): ValidationErrors => {\r\n            const files: Array<File> = control.value;\r\n            if (IsNullOrEmpty(files)) { return null; }\r\n            checkValueType(files);\r\n\r\n            return files.length > numFiles ?\r\n                {'filesLimit': {'max': numFiles, 'actual': files.length}} : null;\r\n        };\r\n    }\r\n\r\n    /**\r\n     * validator that requires control to have limit on media types\r\n     * \r\n     * ##### Allowed media types are\r\n     * \r\n     * - file_extension - a file extension starting with the STOP character, \r\n     * e.g: .gif, .jpg, .png, .doc\r\n     * - audio/* -        All sound files are accepted\r\n     * - video/* -        All video files are accepted\r\n     * - image/* -        All image files are accepted\r\n     * - media_type -     A valid media type, with no parameters. Look at [IANA Media Types](https://www.iana.org/assignments/media-types/media-types.xhtml) for a complete list of standard media types\r\n     * \r\n     * #### Example\r\n     * `FileUploadValidators.accept([file_extension, audio/*, video/*, image/*, media_type])`\r\n     * @dynamic\r\n     */\r\n    public static accept(allowedFileTypes: Array<string>) {\r\n        return (control: AbstractControl | FileUploadControl): ValidationErrors => {\r\n            const files: Array<File> = control.value;\r\n            if (IsNullOrEmpty(files)) { return null; }\r\n            checkValueType(files);\r\n\r\n            const notAllowedFiles = files.map((file) => checkFileType(file, allowedFileTypes))\r\n                                        .filter((error) => error);\r\n\r\n            return notAllowedFiles.length > 0 ?\r\n                {'fileTypes': notAllowedFiles} : null;\r\n        };\r\n    }\r\n\r\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validators.class.js","sourceRoot":"ng://@iplab/ngx-file-upload/","sources":["helpers/validators.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl } from '@angular/forms';\r\nimport { IsNullOrEmpty } from './helpers.class';\r\nimport { FileUploadControl } from './control.class';\r\n\r\nexport interface ValidationErrors {\r\n    [key: string]: any;\r\n}\r\n\r\nexport interface ValidatorFn {\r\n    (c: AbstractControl | FileUploadControl): ValidationErrors | null;\r\n}\r\n\r\n/**\r\n * function used to check file size\r\n */\r\nconst checkFileSize = (file: File, maxSize: number, minSize: number = 0): ValidationErrors | null => {\r\n    return (!IsNullOrEmpty(maxSize) && file.size > maxSize) || file.size < minSize ?\r\n        {maxSize, minSize, actual: file.size, file} : null;\r\n}\r\n\r\nconst FILE_EXT_REG = /(^[.]\\w*)$/gm;\r\n/**\r\n * function used to check file type\r\n * \r\n * #### allowedTypes\r\n * file_extension|audio/*|video/*|image/*|media_type\r\n */\r\nconst checkFileType = (file: File, allowedTypes: Array<string>): ValidationErrors | null => {\r\n    const fileExtension = file.name.slice((file.name.lastIndexOf(\".\") - 1 >>> 0) + 1);\r\n    let isValid = false;\r\n    for(let i = 0; i < allowedTypes.length; i++ ) {\r\n        let type = allowedTypes[i];\r\n\r\n        isValid = FILE_EXT_REG.test(type) ? type === fileExtension : new RegExp(type).test(file.type);\r\n        if(isValid) {\r\n            break;\r\n        }\r\n    }\r\n\r\n    return isValid ?\r\n            null : {allowedTypes, actual: file.type, file};\r\n}\r\n\r\nconst checkValueType = (value: any ): void => {\r\n    if (!Array.isArray(value)) {\r\n        throw Error(`FormControl.setValue was provided with wrong argument type, ${value} was provided instead Array<File>`);\r\n    }\r\n}\r\n\r\n// @dynamic\r\nexport class FileUploadValidators {\r\n\r\n    /**\r\n     * Validator that requires controls to have a file maximum size length.\r\n     * Compare the File size in bytes\r\n     * @dynamic\r\n     */\r\n    public static fileSize(maxSize: number): ValidatorFn {\r\n        return (control: AbstractControl | FileUploadControl): {fileSize: Array<ValidationErrors>} => {\r\n            const files: Array<File> = control.value;\r\n            if (IsNullOrEmpty(files)) { return null; }\r\n            checkValueType(files);\r\n\r\n            const toLargeFiles = files.map((file) => checkFileSize(file, maxSize))\r\n                                        .filter((error) => error);\r\n\r\n            return toLargeFiles.length > 0 ?\r\n                    {'fileSize': toLargeFiles} : null;\r\n        };\r\n    }\r\n\r\n    /**\r\n     * Compare the File size in bytes with max and min size limits\r\n     * @dynamic\r\n     */\r\n    public static sizeRange({ minSize, maxSize }: { minSize?: number; maxSize?: number }): ValidatorFn {\r\n        return (control: AbstractControl | FileUploadControl): {sizeRange: Array<ValidationErrors>} => {\r\n            const files: Array<File> = control.value;\r\n            if (IsNullOrEmpty(files)) { return null; }\r\n            checkValueType(files);\r\n\r\n            const sizeMismatch = files.map((file) => checkFileSize(file, maxSize, minSize))\r\n                                        .filter((error) => error);\r\n\r\n            return sizeMismatch.length > 0 ?\r\n                    {'sizeRange': sizeMismatch} : null;\r\n        };\r\n    }\r\n\r\n    /**\r\n     * validator that requires control to have limit on files number\r\n     * @dynamic\r\n     */\r\n    public static filesLimit(numFiles: number): ValidatorFn {\r\n        return (control: AbstractControl | FileUploadControl): ValidationErrors => {\r\n            const files: Array<File> = control.value;\r\n            if (IsNullOrEmpty(files)) { return null; }\r\n            checkValueType(files);\r\n\r\n            return files.length > numFiles ?\r\n                {'filesLimit': {'max': numFiles, 'actual': files.length}} : null;\r\n        };\r\n    }\r\n\r\n    /**\r\n     * validator that requires control to have limit on media types\r\n     * \r\n     * ##### Allowed media types are\r\n     * \r\n     * - file_extension - a file extension starting with the STOP character, \r\n     * e.g: .gif, .jpg, .png, .doc\r\n     * - audio/* -        All sound files are accepted\r\n     * - video/* -        All video files are accepted\r\n     * - image/* -        All image files are accepted\r\n     * - media_type -     A valid media type, with no parameters. Look at [IANA Media Types](https://www.iana.org/assignments/media-types/media-types.xhtml) for a complete list of standard media types\r\n     * \r\n     * #### Example\r\n     * `FileUploadValidators.accept([file_extension, audio/*, video/*, image/*, media_type])`\r\n     * @dynamic\r\n     */\r\n    public static accept(allowedFileTypes: Array<string>) {\r\n        return (control: AbstractControl | FileUploadControl): ValidationErrors => {\r\n            const files: Array<File> = control.value;\r\n            if (IsNullOrEmpty(files)) { return null; }\r\n            checkValueType(files);\r\n\r\n            const notAllowedFiles = files.map((file) => checkFileType(file, allowedFileTypes))\r\n                                        .filter((error) => error);\r\n\r\n            return notAllowedFiles.length > 0 ?\r\n                {'fileTypes': notAllowedFiles} : null;\r\n        };\r\n    }\r\n\r\n}"]}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/

@@ -15,3 +15,2 @@ /**

export { FileUploadService as ɵb } from './services/file-upload.service';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXBsYWItbmd4LWZpbGUtdXBsb2FkLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQGlwbGFiL25neC1maWxlLXVwbG9hZC8iLCJzb3VyY2VzIjpbImlwbGFiLW5neC1maWxlLXVwbG9hZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBSUEsMkZBQWMsY0FBYyxDQUFDO0FBRTdCLE9BQU8sRUFBQyw0QkFBNEIsSUFBSSxFQUFFLEVBQUMsTUFBTSx5Q0FBeUMsQ0FBQztBQUMzRixPQUFPLEVBQUMsdUJBQXVCLElBQUksRUFBRSxFQUFDLE1BQU0seUNBQXlDLENBQUM7QUFDdEYsT0FBTyxFQUFDLDJCQUEyQixJQUFJLEVBQUUsRUFBQyxNQUFNLDhDQUE4QyxDQUFDO0FBQy9GLE9BQU8sRUFBQyxtQkFBbUIsSUFBSSxFQUFFLEVBQUMsTUFBTSxvQ0FBb0MsQ0FBQztBQUM3RSxPQUFPLEVBQUMsaUJBQWlCLElBQUksRUFBRSxFQUFDLG9CQUFvQixJQUFJLEVBQUUsRUFBQyxtQkFBbUIsSUFBSSxFQUFFLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUMvSCxPQUFPLEVBQUMsaUJBQWlCLElBQUksRUFBRSxFQUFDLE1BQU0sZ0NBQWdDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljX2FwaSc7XG5cbmV4cG9ydCB7RmlsZVVwbG9hZEF0dHJpYnV0ZUNvbXBvbmVudCBhcyDJtWV9IGZyb20gJy4vY29tcG9uZW50cy9maWxlLXVwbG9hZC1hdHRyLmNvbXBvbmVudCc7XG5leHBvcnQge0ZpbGVVcGxvYWRJY29uQ29tcG9uZW50IGFzIMm1ZH0gZnJvbSAnLi9jb21wb25lbnRzL2ZpbGUtdXBsb2FkLWljb24uY29tcG9uZW50JztcbmV4cG9ydCB7RmlsZVVwbG9hZExpc3RJdGVtQ29tcG9uZW50IGFzIMm1Y30gZnJvbSAnLi9jb21wb25lbnRzL2ZpbGUtdXBsb2FkLWxpc3QtaXRlbS5jb21wb25lbnQnO1xuZXhwb3J0IHtGaWxlVXBsb2FkQ29tcG9uZW50IGFzIMm1YX0gZnJvbSAnLi9jb21wb25lbnRzL2ZpbGUtdXBsb2FkLmNvbXBvbmVudCc7XG5leHBvcnQge0ZpbGVTaXplVmFsaWRhdG9yIGFzIMm1ZixGaWxlc0FjY2VwdFZhbGlkYXRvciBhcyDJtWgsRmlsZXNMaW1pdFZhbGlkYXRvciBhcyDJtWd9IGZyb20gJy4vZGlyZWN0aXZlcy92YWxpZGF0b3JzLmRpcmVjdGl2ZSc7XG5leHBvcnQge0ZpbGVVcGxvYWRTZXJ2aWNlIGFzIMm1Yn0gZnJvbSAnLi9zZXJ2aWNlcy9maWxlLXVwbG9hZC5zZXJ2aWNlJzsiXX0=
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/
export { FileUploadControl, FileUploadValidators, FileUploadTypes, FileUploadModule } from './file-upload.module';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BpcGxhYi9uZ3gtZmlsZS11cGxvYWQvIiwic291cmNlcyI6WyJwdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7QUFBQSwyRkFBYyxzQkFBc0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZmlsZS11cGxvYWQubW9kdWxlJzsiXX0=
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/

@@ -19,3 +19,4 @@ import { Injectable, Renderer2 } from '@angular/core';

function () {
var /** @type {?} */ div = this.renderer.createElement('div');
/** @type {?} */
var div = this.renderer.createElement('div');
return (('draggable' in div) || ('ondragstart' in div && 'ondrop' in div)) && FormData && !!FileReader;

@@ -64,3 +65,3 @@ };

export { FileUploadService };
function FileUploadService_tsickle_Closure_declarations() {
if (false) {
/** @type {?} */

@@ -71,3 +72,2 @@ FileUploadService.prototype.extensions;

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BpcGxhYi9uZ3gtZmlsZS11cGxvYWQvIiwic291cmNlcyI6WyJzZXJ2aWNlcy9maWxlLXVwbG9hZC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN0RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sK0JBQStCLENBQUM7O0lBTzVELDJCQUFvQixRQUFtQjtRQUFuQixhQUFRLEdBQVIsUUFBUSxDQUFXOzBCQUZtQixDQUFDLE9BQU8sRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQztLQUdwRjs7OztJQUVNLG1EQUF1Qjs7OztRQUMxQixxQkFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDL0MsTUFBTSxDQUFDLENBQUMsQ0FBQyxXQUFXLElBQUksR0FBRyxDQUFDLElBQUksQ0FBQyxhQUFhLElBQUksR0FBRyxJQUFJLFFBQVEsSUFBSSxHQUFHLENBQUMsQ0FBQyxJQUFJLFFBQVEsSUFBSSxDQUFDLENBQUMsVUFBVSxDQUFDOzs7Ozs7O0lBSXBHLHlDQUFhOzs7OztjQUFDLElBQVksRUFBRSxjQUEwQjtRQUExQiwrQkFBQSxFQUFBLGtCQUEwQjtRQUN6RCxFQUFFLENBQUMsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ2QsSUFBSSxHQUFHLENBQUMsQ0FBQztTQUNaO1FBRUQsRUFBRSxDQUFDLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxDQUFDLENBQUM7WUFDZCxNQUFNLENBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLEdBQUcsR0FBRyxDQUFDLEdBQUcsR0FBRyxTQUFJLElBQUksQ0FBQyxVQUFVLENBQUMsY0FBYyxDQUFHLENBQUM7U0FDL0U7UUFFRCxNQUFNLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLEdBQUcsSUFBSSxFQUFFLGNBQWMsR0FBRyxDQUFDLENBQUMsQ0FBQzs7Ozs7O0lBR3hELHVDQUFXOzs7O2NBQUMsSUFBVTtRQUN6QixNQUFNLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQyxJQUFJLENBQUMsVUFBQyxHQUFHLElBQUssT0FBQSxlQUFlLENBQUMsR0FBRyxDQUFDLEtBQUssSUFBSSxDQUFDLElBQUksRUFBbEMsQ0FBa0MsQ0FBQyxDQUFDOzs7Z0JBM0I3RixVQUFVOzs7O2dCQUhVLFNBQVM7OzRCQUE5Qjs7U0FJYSxpQkFBaUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBSZW5kZXJlcjIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRmlsZVVwbG9hZFR5cGVzIH0gZnJvbSAnLi8uLi9oZWxwZXJzL2ZpbGUtdHlwZXMuY2xhc3MnO1xyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgRmlsZVVwbG9hZFNlcnZpY2Uge1xyXG5cclxuICAgIHByaXZhdGUgZXh0ZW5zaW9uczogQXJyYXk8J2J5dGVzJyB8ICdLQicgfCAnTUInIHwgJ0dCJz4gPSBbJ2J5dGVzJywgJ0tCJywgJ01CJywgJ0dCJ11cclxuXHJcbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlbmRlcmVyOiBSZW5kZXJlcjIpIHtcclxuICAgIH1cclxuXHJcbiAgICBwdWJsaWMgaXNGaWxlRHJhZ0Ryb3BBdmFpbGFibGUoKTogYm9vbGVhbiB7XHJcbiAgICAgICAgY29uc3QgZGl2ID0gdGhpcy5yZW5kZXJlci5jcmVhdGVFbGVtZW50KCdkaXYnKTtcclxuICAgICAgICByZXR1cm4gKCgnZHJhZ2dhYmxlJyBpbiBkaXYpIHx8ICgnb25kcmFnc3RhcnQnIGluIGRpdiAmJiAnb25kcm9wJyBpbiBkaXYpKSAmJiBGb3JtRGF0YSAmJiAhIUZpbGVSZWFkZXI7XHJcbiAgICB9XHJcblxyXG5cclxuICAgIHB1YmxpYyBjYWxjdWxhdGVTaXplKHNpemU6IG51bWJlciwgZXh0ZW5zaW9uSW5kZXg6IG51bWJlciA9IDApOiBzdHJpbmcge1xyXG4gICAgICAgIGlmIChpc05hTihzaXplKSkge1xyXG4gICAgICAgICAgICBzaXplID0gMDtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIGlmIChzaXplIDwgMTAyNCkge1xyXG4gICAgICAgICAgICByZXR1cm4gYCR7TWF0aC5yb3VuZChzaXplICogMTAwKSAvIDEwMH0gJHt0aGlzLmV4dGVuc2lvbnNbZXh0ZW5zaW9uSW5kZXhdfWA7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICByZXR1cm4gdGhpcy5jYWxjdWxhdGVTaXplKHNpemUgLyAxMDI0LCBleHRlbnNpb25JbmRleCArIDEpO1xyXG4gICAgfVxyXG5cclxuICAgIHB1YmxpYyBnZXRGaWxlVHlwZShmaWxlOiBGaWxlKTogc3RyaW5nIHtcclxuICAgICAgICByZXR1cm4gT2JqZWN0LmtleXMoRmlsZVVwbG9hZFR5cGVzKS5maW5kKChrZXkpID0+IEZpbGVVcGxvYWRUeXBlc1trZXldID09PSBmaWxlLnR5cGUpO1xyXG4gICAgfVxyXG59Il19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BpcGxhYi9uZ3gtZmlsZS11cGxvYWQvIiwic291cmNlcyI6WyJzZXJ2aWNlcy9maWxlLXVwbG9hZC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN0RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFFaEU7SUFLSSwyQkFBb0IsUUFBbUI7UUFBbkIsYUFBUSxHQUFSLFFBQVEsQ0FBVztRQUYvQixlQUFVLEdBQXdDLENBQUMsT0FBTyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLENBQUE7SUFHckYsQ0FBQzs7OztJQUVNLG1EQUF1Qjs7O0lBQTlCOztZQUNVLEdBQUcsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUM7UUFDOUMsT0FBTyxDQUFDLENBQUMsV0FBVyxJQUFJLEdBQUcsQ0FBQyxJQUFJLENBQUMsYUFBYSxJQUFJLEdBQUcsSUFBSSxRQUFRLElBQUksR0FBRyxDQUFDLENBQUMsSUFBSSxRQUFRLElBQUksQ0FBQyxDQUFDLFVBQVUsQ0FBQztJQUMzRyxDQUFDOzs7Ozs7SUFHTSx5Q0FBYTs7Ozs7SUFBcEIsVUFBcUIsSUFBWSxFQUFFLGNBQTBCO1FBQTFCLCtCQUFBLEVBQUEsa0JBQTBCO1FBQ3pELElBQUksS0FBSyxDQUFDLElBQUksQ0FBQyxFQUFFO1lBQ2IsSUFBSSxHQUFHLENBQUMsQ0FBQztTQUNaO1FBRUQsSUFBSSxJQUFJLEdBQUcsSUFBSSxFQUFFO1lBQ2IsT0FBVSxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksR0FBRyxHQUFHLENBQUMsR0FBRyxHQUFHLFNBQUksSUFBSSxDQUFDLFVBQVUsQ0FBQyxjQUFjLENBQUcsQ0FBQztTQUMvRTtRQUVELE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLEdBQUcsSUFBSSxFQUFFLGNBQWMsR0FBRyxDQUFDLENBQUMsQ0FBQztJQUMvRCxDQUFDOzs7OztJQUVNLHVDQUFXOzs7O0lBQWxCLFVBQW1CLElBQVU7UUFDekIsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDLElBQUksQ0FBQyxVQUFDLEdBQUcsSUFBSyxPQUFBLGVBQWUsQ0FBQyxHQUFHLENBQUMsS0FBSyxJQUFJLENBQUMsSUFBSSxFQUFsQyxDQUFrQyxDQUFDLENBQUM7SUFDMUYsQ0FBQzs7Z0JBNUJKLFVBQVU7Ozs7Z0JBSFUsU0FBUzs7SUFnQzlCLHdCQUFDO0NBQUEsQUE3QkQsSUE2QkM7U0E1QlksaUJBQWlCOzs7SUFFMUIsdUNBQXFGOztJQUV6RSxxQ0FBMkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBSZW5kZXJlcjIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRmlsZVVwbG9hZFR5cGVzIH0gZnJvbSAnLi8uLi9oZWxwZXJzL2ZpbGUtdHlwZXMuY2xhc3MnO1xyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgRmlsZVVwbG9hZFNlcnZpY2Uge1xyXG5cclxuICAgIHByaXZhdGUgZXh0ZW5zaW9uczogQXJyYXk8J2J5dGVzJyB8ICdLQicgfCAnTUInIHwgJ0dCJz4gPSBbJ2J5dGVzJywgJ0tCJywgJ01CJywgJ0dCJ11cclxuXHJcbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlbmRlcmVyOiBSZW5kZXJlcjIpIHtcclxuICAgIH1cclxuXHJcbiAgICBwdWJsaWMgaXNGaWxlRHJhZ0Ryb3BBdmFpbGFibGUoKTogYm9vbGVhbiB7XHJcbiAgICAgICAgY29uc3QgZGl2ID0gdGhpcy5yZW5kZXJlci5jcmVhdGVFbGVtZW50KCdkaXYnKTtcclxuICAgICAgICByZXR1cm4gKCgnZHJhZ2dhYmxlJyBpbiBkaXYpIHx8ICgnb25kcmFnc3RhcnQnIGluIGRpdiAmJiAnb25kcm9wJyBpbiBkaXYpKSAmJiBGb3JtRGF0YSAmJiAhIUZpbGVSZWFkZXI7XHJcbiAgICB9XHJcblxyXG5cclxuICAgIHB1YmxpYyBjYWxjdWxhdGVTaXplKHNpemU6IG51bWJlciwgZXh0ZW5zaW9uSW5kZXg6IG51bWJlciA9IDApOiBzdHJpbmcge1xyXG4gICAgICAgIGlmIChpc05hTihzaXplKSkge1xyXG4gICAgICAgICAgICBzaXplID0gMDtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIGlmIChzaXplIDwgMTAyNCkge1xyXG4gICAgICAgICAgICByZXR1cm4gYCR7TWF0aC5yb3VuZChzaXplICogMTAwKSAvIDEwMH0gJHt0aGlzLmV4dGVuc2lvbnNbZXh0ZW5zaW9uSW5kZXhdfWA7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICByZXR1cm4gdGhpcy5jYWxjdWxhdGVTaXplKHNpemUgLyAxMDI0LCBleHRlbnNpb25JbmRleCArIDEpO1xyXG4gICAgfVxyXG5cclxuICAgIHB1YmxpYyBnZXRGaWxlVHlwZShmaWxlOiBGaWxlKTogc3RyaW5nIHtcclxuICAgICAgICByZXR1cm4gT2JqZWN0LmtleXMoRmlsZVVwbG9hZFR5cGVzKS5maW5kKChrZXkpID0+IEZpbGVVcGxvYWRUeXBlc1trZXldID09PSBmaWxlLnR5cGUpO1xyXG4gICAgfVxyXG59Il19

@@ -6,3 +6,3 @@ import { BehaviorSubject, Observable } from 'rxjs';

VALID = 1,
DISABLED = 2,
DISABLED = 2
}

@@ -36,3 +36,3 @@ export declare class FileUploadControl {

setValidators(newValidators: ValidatorFn | Array<ValidatorFn>): this;
private defineValidators(validators);
private defineValidators;
addFile(file: File): this;

@@ -46,3 +46,3 @@ removeFile(file: File): this;

*/
private addMultipleFiles(files);
private addMultipleFiles;
readonly valid: boolean;

@@ -69,3 +69,3 @@ readonly invalid: boolean;

disable(isDisabled?: boolean): this;
private validate();
private validate;
}

@@ -69,3 +69,3 @@ /**

'3g2' = "video/3gpp2",
'7z' = "application/x-7z-compressed",
'7z' = "application/x-7z-compressed"
}

@@ -20,3 +20,3 @@ import { AbstractControl } from '@angular/forms';

*/
static sizeRange({minSize, maxSize}: {
static sizeRange({ minSize, maxSize }: {
minSize?: number;

@@ -23,0 +23,0 @@ maxSize?: number;

@@ -6,3 +6,3 @@ {

"bugs": "https://github.com/pIvan/file-upload/issues",
"version": "1.1.1",
"version": "1.1.2",
"author": "Ivan Pintar",

@@ -29,33 +29,23 @@ "license": "MIT",

"peerDependencies": {
"@angular/animations": "^6.0.7",
"@angular/common": "^6.0.7",
"@angular/compiler": "^6.0.7",
"@angular/core": "^6.0.7",
"@angular/forms": "^6.0.7",
"@angular/http": "^6.0.7",
"@angular/platform-browser": "^6.0.7",
"@angular/platform-browser-dynamic": "^6.0.7",
"@angular/router": "^6.0.7",
"core-js": "^2.5.4",
"rxjs": "^6.0.0",
"zone.js": "^0.8.26"
},
"devDependencies": {
"@angular/animations": "^6.0.7",
"@angular/common": "^6.0.7",
"@angular/compiler": "^6.0.7",
"@angular/core": "^6.0.7",
"@angular/forms": "^6.0.7",
"@angular/http": "^6.0.7",
"@angular/platform-browser": "^6.0.7",
"@angular/platform-browser-dynamic": "^6.0.7",
"@angular/router": "^6.0.7",
"@angular/animations": "^7.0.3",
"@angular/common": "^7.0.3",
"@angular/compiler": "^7.0.3",
"@angular/core": "^7.0.3",
"@angular/forms": "^7.0.3",
"@angular/http": "^7.0.3",
"@angular/platform-browser": "^7.0.3",
"@angular/platform-browser-dynamic": "^7.0.3",
"@angular/router": "^7.0.3",
"core-js": "^2.5.4",
"rxjs": "^6.0.0",
"rxjs": "^6.3.3",
"zone.js": "^0.8.26",
"@angular/compiler-cli": "^6.0.7",
"@angular/compiler-cli": "^7.0.3",
"@angular-devkit/build-angular": "~0.6.8",
"typescript": "~2.7.2",
"@angular/cli": "~6.0.8",
"@angular/language-service": "^6.0.7",
"typescript": "~3.1.6",
"@angular/cli": "~7.0.5",
"@angular/language-service": "^7.0.3",
"@types/jasmine": "~2.8.6",

@@ -76,2 +66,3 @@ "@types/jasminewd2": "~2.0.3",

"ng-packagr": "^3.0.0",
"tsickle": "^0.33.1",
"bootstrap": "4.0.0-alpha.6",

@@ -78,0 +69,0 @@ "google-code-prettify": "1.0.5"

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 too big to display

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

SocketSocket SOC 2 Logo

Product

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

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc