@covalent/core
Version:
Core Teradata UI Platform for layouts, icons, custom components and themes. This should be added as a dependency for any project that wants to use layouts, icons and themes for Angular Material.
1 lines • 116 kB
Source Map (JSON)
{"version":3,"file":"covalent-core-file.mjs","sources":["../tmp-esm2022/file/directives/file-select.directive.js","../tmp-esm2022/file/directives/file-drop.directive.js","../tmp-esm2022/file/file-input/file-input.component.js","../tmp-esm2022/file/file-upload/file-upload.component.js","../tmp-esm2022/file/services/file.service.js","../tmp-esm2022/file/file.module.js","../tmp-esm2022/file/covalent-core-file.js"],"sourcesContent":["import { Directive, Input, Output, EventEmitter, inject } from '@angular/core';\nimport { HostListener, HostBinding } from '@angular/core';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { NgModel } from '@angular/forms';\nimport * as i0 from \"@angular/core\";\nexport class TdFileSelectDirective {\n model = inject(NgModel, { optional: true, host: true });\n _multiple = false;\n /**\n * multiple?: boolean\n * Sets whether multiple files can be selected at once in host element, or just a single file.\n * Can also be 'multiple' native attribute.\n */\n set multiple(multiple) {\n this._multiple = coerceBooleanProperty(multiple);\n }\n /**\n * fileSelect?: function\n * Event emitted when a file or files are selected in host [HTMLInputElement].\n * Emits a [FileList | File] object.\n * Alternative to not use [(ngModel)].\n */\n fileSelect = new EventEmitter();\n /**\n * Binds native 'multiple' attribute if [multiple] property is 'true'.\n */\n get multipleBinding() {\n return this._multiple ? '' : undefined;\n }\n /**\n * Listens to 'change' host event to get [HTMLInputElement] files.\n * Emits the 'fileSelect' event with a [FileList] or [File] depending if 'multiple' attr exists in host.\n * Uses [(ngModel)] if declared, instead of emitting 'fileSelect' event.\n */\n onChange(event) {\n if (event.target instanceof HTMLInputElement) {\n const fileInputEl = event.target;\n const files = fileInputEl.files || new FileList();\n if (files.length) {\n const value = this._multiple\n ? files.length > 1\n ? files\n : files[0]\n : files[0];\n this.model\n ? this.model.update.emit(value)\n : this.fileSelect.emit(value);\n }\n }\n }\n static ɵfac = function TdFileSelectDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || TdFileSelectDirective)(); };\n static ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: TdFileSelectDirective, selectors: [[\"\", \"tdFileSelect\", \"\"]], hostVars: 1, hostBindings: function TdFileSelectDirective_HostBindings(rf, ctx) { if (rf & 1) {\n i0.ɵɵlistener(\"change\", function TdFileSelectDirective_change_HostBindingHandler($event) { return ctx.onChange($event); });\n } if (rf & 2) {\n i0.ɵɵattribute(\"multiple\", ctx.multipleBinding);\n } }, inputs: { multiple: \"multiple\" }, outputs: { fileSelect: \"fileSelect\" } });\n}\n(() => { (typeof ngDevMode === \"undefined\" || ngDevMode) && i0.ɵsetClassMetadata(TdFileSelectDirective, [{\n type: Directive,\n args: [{\n selector: '[tdFileSelect]',\n }]\n }], null, { multiple: [{\n type: Input\n }], fileSelect: [{\n type: Output\n }], multipleBinding: [{\n type: HostBinding,\n args: ['attr.multiple']\n }], onChange: [{\n type: HostListener,\n args: ['change', ['$event']]\n }] }); })();\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1zZWxlY3QuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL2ZpbGUvc3JjL2RpcmVjdGl2ZXMvZmlsZS1zZWxlY3QuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQy9FLE9BQU8sRUFBRSxZQUFZLEVBQUUsV0FBVyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzlELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7QUFLekMsTUFBTSxPQUFPLHFCQUFxQjtJQUN4QixLQUFLLEdBQUcsTUFBTSxDQUFDLE9BQU8sRUFBRSxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7SUFFeEQsU0FBUyxHQUFHLEtBQUssQ0FBQztJQUUxQjs7OztPQUlHO0lBQ0gsSUFDSSxRQUFRLENBQUMsUUFBMEI7UUFDckMsSUFBSSxDQUFDLFNBQVMsR0FBRyxxQkFBcUIsQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUNuRCxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDTyxVQUFVLEdBQWtDLElBQUksWUFBWSxFQUVuRSxDQUFDO0lBRUo7O09BRUc7SUFDSCxJQUNJLGVBQWU7UUFDakIsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQztJQUN6QyxDQUFDO0lBRUQ7Ozs7T0FJRztJQUVILFFBQVEsQ0FBQyxLQUFZO1FBQ25CLElBQUksS0FBSyxDQUFDLE1BQU0sWUFBWSxnQkFBZ0IsRUFBRSxDQUFDO1lBQzdDLE1BQU0sV0FBVyxHQUFxQixLQUFLLENBQUMsTUFBTSxDQUFDO1lBQ25ELE1BQU0sS0FBSyxHQUFhLFdBQVcsQ0FBQyxLQUFLLElBQUksSUFBSSxRQUFRLEVBQUUsQ0FBQztZQUM1RCxJQUFJLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQztnQkFDakIsTUFBTSxLQUFLLEdBQW9CLElBQUksQ0FBQyxTQUFTO29CQUMzQyxDQUFDLENBQUMsS0FBSyxDQUFDLE1BQU0sR0FBRyxDQUFDO3dCQUNoQixDQUFDLENBQUMsS0FBSzt3QkFDUCxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztvQkFDWixDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO2dCQUNiLElBQUksQ0FBQyxLQUFLO29CQUNSLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDO29CQUMvQixDQUFDLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDbEMsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDOytHQXREVSxxQkFBcUI7NkRBQXJCLHFCQUFxQjtZQUFyQixrR0FBQSxvQkFBZ0IsSUFBSzs7Ozs7aUZBQXJCLHFCQUFxQjtjQUhqQyxTQUFTO2VBQUM7Z0JBQ1QsUUFBUSxFQUFFLGdCQUFnQjthQUMzQjtnQkFZSyxRQUFRO2tCQURYLEtBQUs7WUFXSSxVQUFVO2tCQUFuQixNQUFNO1lBUUgsZUFBZTtrQkFEbEIsV0FBVzttQkFBQyxlQUFlO1lBVzVCLFFBQVE7a0JBRFAsWUFBWTttQkFBQyxRQUFRLEVBQUUsQ0FBQyxRQUFRLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIElucHV0LCBPdXRwdXQsIEV2ZW50RW1pdHRlciwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBIb3N0TGlzdGVuZXIsIEhvc3RCaW5kaW5nIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBjb2VyY2VCb29sZWFuUHJvcGVydHkgfSBmcm9tICdAYW5ndWxhci9jZGsvY29lcmNpb24nO1xuaW1wb3J0IHsgTmdNb2RlbCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW3RkRmlsZVNlbGVjdF0nLFxufSlcbmV4cG9ydCBjbGFzcyBUZEZpbGVTZWxlY3REaXJlY3RpdmUge1xuICBwcml2YXRlIG1vZGVsID0gaW5qZWN0KE5nTW9kZWwsIHsgb3B0aW9uYWw6IHRydWUsIGhvc3Q6IHRydWUgfSk7XG5cbiAgcHJpdmF0ZSBfbXVsdGlwbGUgPSBmYWxzZTtcblxuICAvKipcbiAgICogbXVsdGlwbGU/OiBib29sZWFuXG4gICAqIFNldHMgd2hldGhlciBtdWx0aXBsZSBmaWxlcyBjYW4gYmUgc2VsZWN0ZWQgYXQgb25jZSBpbiBob3N0IGVsZW1lbnQsIG9yIGp1c3QgYSBzaW5nbGUgZmlsZS5cbiAgICogQ2FuIGFsc28gYmUgJ211bHRpcGxlJyBuYXRpdmUgYXR0cmlidXRlLlxuICAgKi9cbiAgQElucHV0KClcbiAgc2V0IG11bHRpcGxlKG11bHRpcGxlOiBib29sZWFuIHwgc3RyaW5nKSB7XG4gICAgdGhpcy5fbXVsdGlwbGUgPSBjb2VyY2VCb29sZWFuUHJvcGVydHkobXVsdGlwbGUpO1xuICB9XG5cbiAgLyoqXG4gICAqIGZpbGVTZWxlY3Q/OiBmdW5jdGlvblxuICAgKiBFdmVudCBlbWl0dGVkIHdoZW4gYSBmaWxlIG9yIGZpbGVzIGFyZSBzZWxlY3RlZCBpbiBob3N0IFtIVE1MSW5wdXRFbGVtZW50XS5cbiAgICogRW1pdHMgYSBbRmlsZUxpc3QgfCBGaWxlXSBvYmplY3QuXG4gICAqIEFsdGVybmF0aXZlIHRvIG5vdCB1c2UgWyhuZ01vZGVsKV0uXG4gICAqL1xuICBAT3V0cHV0KCkgZmlsZVNlbGVjdDogRXZlbnRFbWl0dGVyPEZpbGVMaXN0IHwgRmlsZT4gPSBuZXcgRXZlbnRFbWl0dGVyPFxuICAgIEZpbGVMaXN0IHwgRmlsZVxuICA+KCk7XG5cbiAgLyoqXG4gICAqIEJpbmRzIG5hdGl2ZSAnbXVsdGlwbGUnIGF0dHJpYnV0ZSBpZiBbbXVsdGlwbGVdIHByb3BlcnR5IGlzICd0cnVlJy5cbiAgICovXG4gIEBIb3N0QmluZGluZygnYXR0ci5tdWx0aXBsZScpXG4gIGdldCBtdWx0aXBsZUJpbmRpbmcoKTogc3RyaW5nIHwgdW5kZWZpbmVkIHtcbiAgICByZXR1cm4gdGhpcy5fbXVsdGlwbGUgPyAnJyA6IHVuZGVmaW5lZDtcbiAgfVxuXG4gIC8qKlxuICAgKiBMaXN0ZW5zIHRvICdjaGFuZ2UnIGhvc3QgZXZlbnQgdG8gZ2V0IFtIVE1MSW5wdXRFbGVtZW50XSBmaWxlcy5cbiAgICogRW1pdHMgdGhlICdmaWxlU2VsZWN0JyBldmVudCB3aXRoIGEgW0ZpbGVMaXN0XSBvciBbRmlsZV0gZGVwZW5kaW5nIGlmICdtdWx0aXBsZScgYXR0ciBleGlzdHMgaW4gaG9zdC5cbiAgICogVXNlcyBbKG5nTW9kZWwpXSBpZiBkZWNsYXJlZCwgaW5zdGVhZCBvZiBlbWl0dGluZyAnZmlsZVNlbGVjdCcgZXZlbnQuXG4gICAqL1xuICBASG9zdExpc3RlbmVyKCdjaGFuZ2UnLCBbJyRldmVudCddKVxuICBvbkNoYW5nZShldmVudDogRXZlbnQpOiB2b2lkIHtcbiAgICBpZiAoZXZlbnQudGFyZ2V0IGluc3RhbmNlb2YgSFRNTElucHV0RWxlbWVudCkge1xuICAgICAgY29uc3QgZmlsZUlucHV0RWw6IEhUTUxJbnB1dEVsZW1lbnQgPSBldmVudC50YXJnZXQ7XG4gICAgICBjb25zdCBmaWxlczogRmlsZUxpc3QgPSBmaWxlSW5wdXRFbC5maWxlcyB8fCBuZXcgRmlsZUxpc3QoKTtcbiAgICAgIGlmIChmaWxlcy5sZW5ndGgpIHtcbiAgICAgICAgY29uc3QgdmFsdWU6IEZpbGVMaXN0IHwgRmlsZSA9IHRoaXMuX211bHRpcGxlXG4gICAgICAgICAgPyBmaWxlcy5sZW5ndGggPiAxXG4gICAgICAgICAgICA/IGZpbGVzXG4gICAgICAgICAgICA6IGZpbGVzWzBdXG4gICAgICAgICAgOiBmaWxlc1swXTtcbiAgICAgICAgdGhpcy5tb2RlbFxuICAgICAgICAgID8gdGhpcy5tb2RlbC51cGRhdGUuZW1pdCh2YWx1ZSlcbiAgICAgICAgICA6IHRoaXMuZmlsZVNlbGVjdC5lbWl0KHZhbHVlKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cbn1cbiJdfQ==","import { Directive, Input, Output, EventEmitter, HostListener, HostBinding, ElementRef, Renderer2, NgZone, inject, } from '@angular/core';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport * as i0 from \"@angular/core\";\nexport class TdFileDropBase {\n}\nexport class TdFileDropDirective {\n _renderer = inject(Renderer2);\n _element = inject(ElementRef);\n _ngZone = inject(NgZone);\n _multiple = false;\n _dragenterListener;\n _dragleaveListener;\n _dragoverListener;\n /**\n * multiple?: boolean\n * Sets whether multiple files can be dropped at once in host element, or just a single file.\n * Can also be 'multiple' native attribute.\n */\n set multiple(multiple) {\n this._multiple = coerceBooleanProperty(multiple);\n }\n disabled = false;\n /**\n * fileDrop?: function\n * Event emitted when a file or files are dropped in host element after being validated.\n * Emits a [FileList | File] object.\n */\n fileDrop = new EventEmitter();\n /**\n * Binds native 'multiple' attribute if [multiple] property is 'true'.\n */\n get multipleBinding() {\n return this._multiple ? '' : undefined;\n }\n /**\n * Binds native 'disabled' attribute if [disabled] property is 'true'.\n */\n get disabledBinding() {\n return this.disabled ? '' : undefined;\n }\n ngOnInit() {\n this._ngZone.runOutsideAngular(() => {\n // Listens to 'dragenter' host event to add animation class 'drop-zone' which can be overriden in host.\n // Stops event propagation and default action from browser for 'dragenter' event.\n this._dragenterListener = this._renderer.listen(this._element.nativeElement, 'dragenter', (event) => {\n if (!this.disabled) {\n this._renderer.addClass(this._element.nativeElement, 'drop-zone');\n }\n this._stopEvent(event);\n });\n // Listens to 'dragleave' host event to remove animation class 'drop-zone'.\n // Stops event propagation and default action from browser for 'dragleave' event.\n this._dragleaveListener = this._renderer.listen(this._element.nativeElement, 'dragleave', (event) => {\n this._renderer.removeClass(this._element.nativeElement, 'drop-zone');\n this._stopEvent(event);\n });\n // Listens to 'dragover' host event to validate transfer items.\n // Checks if 'multiple' attr exists in host to allow multiple file drops.\n // Stops event propagation and default action from browser for 'dragover' event.\n this._dragoverListener = this._renderer.listen(this._element.nativeElement, 'dragover', (event) => {\n const transfer = event.dataTransfer || new DataTransfer();\n transfer.dropEffect = this._typeCheck(transfer.types);\n if (this.disabled ||\n (!this._multiple &&\n ((transfer.items && transfer.items.length > 1) ||\n transfer.mozItemCount > 1))) {\n transfer.dropEffect = 'none';\n }\n else {\n transfer.dropEffect = 'copy';\n }\n this._stopEvent(event);\n });\n });\n }\n ngOnDestroy() {\n this._dragenterListener?.();\n this._dragleaveListener?.();\n this._dragoverListener?.();\n }\n /**\n * Listens to 'drop' host event to get validated transfer items.\n * Emits the 'fileDrop' event with a [FileList] or [File] depending if 'multiple' attr exists in host.\n * Stops event propagation and default action from browser for 'drop' event.\n */\n onDrop(event) {\n if (!this.disabled) {\n const transfer = event.dataTransfer ?? new DataTransfer();\n const files = transfer.files;\n if (files.length) {\n const value = this._multiple\n ? files.length > 1\n ? files\n : files[0]\n : files[0];\n this.fileDrop.emit(value);\n }\n }\n this._renderer.removeClass(this._element.nativeElement, 'drop-zone');\n this._stopEvent(event);\n }\n /**\n * Validates if the transfer item types are 'Files'.\n */\n _typeCheck(types) {\n let dropEffect = 'none';\n if (types &&\n ((types.contains && types.contains('Files')) ||\n (types.indexOf && types.indexOf('Files') !== -1))) {\n dropEffect = 'copy';\n }\n return dropEffect;\n }\n _stopEvent(event) {\n event.preventDefault();\n event.stopPropagation();\n }\n static ɵfac = function TdFileDropDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || TdFileDropDirective)(); };\n static ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: TdFileDropDirective, selectors: [[\"\", \"tdFileDrop\", \"\"]], hostVars: 2, hostBindings: function TdFileDropDirective_HostBindings(rf, ctx) { if (rf & 1) {\n i0.ɵɵlistener(\"drop\", function TdFileDropDirective_drop_HostBindingHandler($event) { return ctx.onDrop($event); });\n } if (rf & 2) {\n i0.ɵɵattribute(\"multiple\", ctx.multipleBinding)(\"disabled\", ctx.disabledBinding);\n } }, inputs: { multiple: \"multiple\", disabled: \"disabled\" }, outputs: { fileDrop: \"fileDrop\" } });\n}\n(() => { (typeof ngDevMode === \"undefined\" || ngDevMode) && i0.ɵsetClassMetadata(TdFileDropDirective, [{\n type: Directive,\n args: [{ selector: '[tdFileDrop]' }]\n }], null, { multiple: [{\n type: Input\n }], disabled: [{\n type: Input\n }], fileDrop: [{\n type: Output\n }], multipleBinding: [{\n type: HostBinding,\n args: ['attr.multiple']\n }], disabledBinding: [{\n type: HostBinding,\n args: ['attr.disabled']\n }], onDrop: [{\n type: HostListener,\n args: ['drop', ['$event']]\n }] }); })();\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-drop.directive.js","sourceRoot":"","sources":["../../../../../../libs/angular/file/src/directives/file-drop.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,KAAK,EACL,MAAM,EACN,YAAY,EACZ,YAAY,EACZ,WAAW,EACX,UAAU,EACV,SAAS,EAGT,MAAM,EACN,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;;AAE9D,MAAM,OAAO,cAAc;CAAG;AAG9B,MAAM,OAAO,mBAAmB;IACtB,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;IAC9B,QAAQ,GAAG,MAAM,CAA0B,UAAU,CAAC,CAAC;IACvD,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;IAEzB,SAAS,GAAG,KAAK,CAAC;IAClB,kBAAkB,CAAgB;IAClC,kBAAkB,CAAgB;IAClC,iBAAiB,CAAgB;IAEzC;;;;OAIG;IACH,IACI,QAAQ,CAAC,QAA0B;QACrC,IAAI,CAAC,SAAS,GAAG,qBAAqB,CAAC,QAAQ,CAAC,CAAC;IACnD,CAAC;IAEQ,QAAQ,GAAI,KAAK,CAAC;IAE3B;;;;OAIG;IACO,QAAQ,GAAkC,IAAI,YAAY,EAEjE,CAAC;IAEJ;;OAEG;IACH,IACI,eAAe;QACjB,OAAO,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;IACzC,CAAC;IAED;;OAEG;IACH,IACI,eAAe;QACjB,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;IACxC,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,GAAG,EAAE;YAClC,uGAAuG;YACvG,iFAAiF;YACjF,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAC7C,IAAI,CAAC,QAAQ,CAAC,aAAa,EAC3B,WAAW,EACX,CAAC,KAAY,EAAE,EAAE;gBACf,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;oBACnB,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,aAAa,EAAE,WAAW,CAAC,CAAC;gBACpE,CAAC;gBACD,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;YACzB,CAAC,CACF,CAAC;YAEF,2EAA2E;YAC3E,iFAAiF;YACjF,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAC7C,IAAI,CAAC,QAAQ,CAAC,aAAa,EAC3B,WAAW,EACX,CAAC,KAAY,EAAE,EAAE;gBACf,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,aAAa,EAAE,WAAW,CAAC,CAAC;gBACrE,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;YACzB,CAAC,CACF,CAAC;YAEF,+DAA+D;YAC/D,yEAAyE;YACzE,gFAAgF;YAChF,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAC5C,IAAI,CAAC,QAAQ,CAAC,aAAa,EAC3B,UAAU,EACV,CAAC,KAAgB,EAAE,EAAE;gBACnB,MAAM,QAAQ,GACZ,KAAK,CAAC,YAAY,IAAI,IAAI,YAAY,EAAE,CAAC;gBAC3C,QAAQ,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;gBACtD,IACE,IAAI,CAAC,QAAQ;oBACb,CAAC,CAAC,IAAI,CAAC,SAAS;wBACd,CAAC,CAAC,QAAQ,CAAC,KAAK,IAAI,QAAQ,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;4BACtC,QAAS,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC,EACtC,CAAC;oBACD,QAAQ,CAAC,UAAU,GAAG,MAAM,CAAC;gBAC/B,CAAC;qBAAM,CAAC;oBACN,QAAQ,CAAC,UAAU,GAAG,MAAM,CAAC;gBAC/B,CAAC;gBACD,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;YACzB,CAAC,CACF,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAED,WAAW;QACT,IAAI,CAAC,kBAAkB,EAAE,EAAE,CAAC;QAC5B,IAAI,CAAC,kBAAkB,EAAE,EAAE,CAAC;QAC5B,IAAI,CAAC,iBAAiB,EAAE,EAAE,CAAC;IAC7B,CAAC;IAED;;;;OAIG;IAEH,MAAM,CAAC,KAAY;QACjB,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,MAAM,QAAQ,GACA,KAAM,CAAC,YAAY,IAAI,IAAI,YAAY,EAAE,CAAC;YACxD,MAAM,KAAK,GAAa,QAAQ,CAAC,KAAK,CAAC;YACvC,IAAI,KAAK,CAAC,MAAM,EAAE,CAAC;gBACjB,MAAM,KAAK,GAAoB,IAAI,CAAC,SAAS;oBAC3C,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC;wBAChB,CAAC,CAAC,KAAK;wBACP,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;oBACZ,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;gBACb,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC5B,CAAC;QACH,CAAC;QACD,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,aAAa,EAAE,WAAW,CAAC,CAAC;QACrE,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;IAED;;OAEG;IACK,UAAU,CAChB,KAA4C;QAE5C,IAAI,UAAU,GAAsC,MAAM,CAAC;QAC3D,IACE,KAAK;YACL,CAAC,CAAO,KAAM,CAAC,QAAQ,IAAU,KAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;gBACxD,CAAO,KAAM,CAAC,OAAO,IAAU,KAAM,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EACjE,CAAC;YACD,UAAU,GAAG,MAAM,CAAC;QACtB,CAAC;QAED,OAAO,UAAU,CAAC;IACpB,CAAC;IAEO,UAAU,CAAC,KAAY;QAC7B,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;IAC1B,CAAC;6GAtJU,mBAAmB;6DAAnB,mBAAmB;YAAnB,4FAAA,kBAAc,IAAK;;;;;iFAAnB,mBAAmB;cAD/B,SAAS;eAAC,EAAE,QAAQ,EAAE,cAAc,EAAE;gBAiBjC,QAAQ;kBADX,KAAK;YAKG,QAAQ;kBAAhB,KAAK;YAOI,QAAQ;kBAAjB,MAAM;YAQH,eAAe;kBADlB,WAAW;mBAAC,eAAe;YASxB,eAAe;kBADlB,WAAW;mBAAC,eAAe;YAqE5B,MAAM;kBADL,YAAY;mBAAC,MAAM,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {\n  Directive,\n  Input,\n  Output,\n  EventEmitter,\n  HostListener,\n  HostBinding,\n  ElementRef,\n  Renderer2,\n  OnInit,\n  OnDestroy,\n  NgZone,\n  inject,\n} from '@angular/core';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\n\nexport class TdFileDropBase {}\n\n@Directive({ selector: '[tdFileDrop]' })\nexport class TdFileDropDirective implements OnInit, OnDestroy {\n  private _renderer = inject(Renderer2);\n  private _element = inject<ElementRef<HTMLElement>>(ElementRef);\n  private _ngZone = inject(NgZone);\n\n  private _multiple = false;\n  private _dragenterListener?: VoidFunction;\n  private _dragleaveListener?: VoidFunction;\n  private _dragoverListener?: VoidFunction;\n\n  /**\n   * multiple?: boolean\n   * Sets whether multiple files can be dropped at once in host element, or just a single file.\n   * Can also be 'multiple' native attribute.\n   */\n  @Input()\n  set multiple(multiple: boolean | string) {\n    this._multiple = coerceBooleanProperty(multiple);\n  }\n\n  @Input() disabled? = false;\n\n  /**\n   * fileDrop?: function\n   * Event emitted when a file or files are dropped in host element after being validated.\n   * Emits a [FileList | File] object.\n   */\n  @Output() fileDrop: EventEmitter<FileList | File> = new EventEmitter<\n    FileList | File\n  >();\n\n  /**\n   * Binds native 'multiple' attribute if [multiple] property is 'true'.\n   */\n  @HostBinding('attr.multiple')\n  get multipleBinding(): string | undefined {\n    return this._multiple ? '' : undefined;\n  }\n\n  /**\n   * Binds native 'disabled' attribute if [disabled] property is 'true'.\n   */\n  @HostBinding('attr.disabled')\n  get disabledBinding(): string | undefined {\n    return this.disabled ? '' : undefined;\n  }\n\n  ngOnInit(): void {\n    this._ngZone.runOutsideAngular(() => {\n      // Listens to 'dragenter' host event to add animation class 'drop-zone' which can be overriden in host.\n      // Stops event propagation and default action from browser for 'dragenter' event.\n      this._dragenterListener = this._renderer.listen(\n        this._element.nativeElement,\n        'dragenter',\n        (event: Event) => {\n          if (!this.disabled) {\n            this._renderer.addClass(this._element.nativeElement, 'drop-zone');\n          }\n          this._stopEvent(event);\n        },\n      );\n\n      // Listens to 'dragleave' host event to remove animation class 'drop-zone'.\n      // Stops event propagation and default action from browser for 'dragleave' event.\n      this._dragleaveListener = this._renderer.listen(\n        this._element.nativeElement,\n        'dragleave',\n        (event: Event) => {\n          this._renderer.removeClass(this._element.nativeElement, 'drop-zone');\n          this._stopEvent(event);\n        },\n      );\n\n      // Listens to 'dragover' host event to validate transfer items.\n      // Checks if 'multiple' attr exists in host to allow multiple file drops.\n      // Stops event propagation and default action from browser for 'dragover' event.\n      this._dragoverListener = this._renderer.listen(\n        this._element.nativeElement,\n        'dragover',\n        (event: DragEvent) => {\n          const transfer: DataTransfer =\n            event.dataTransfer || new DataTransfer();\n          transfer.dropEffect = this._typeCheck(transfer.types);\n          if (\n            this.disabled ||\n            (!this._multiple &&\n              ((transfer.items && transfer.items.length > 1) ||\n                (<any>transfer).mozItemCount > 1))\n          ) {\n            transfer.dropEffect = 'none';\n          } else {\n            transfer.dropEffect = 'copy';\n          }\n          this._stopEvent(event);\n        },\n      );\n    });\n  }\n\n  ngOnDestroy(): void {\n    this._dragenterListener?.();\n    this._dragleaveListener?.();\n    this._dragoverListener?.();\n  }\n\n  /**\n   * Listens to 'drop' host event to get validated transfer items.\n   * Emits the 'fileDrop' event with a [FileList] or [File] depending if 'multiple' attr exists in host.\n   * Stops event propagation and default action from browser for 'drop' event.\n   */\n  @HostListener('drop', ['$event'])\n  onDrop(event: Event): void {\n    if (!this.disabled) {\n      const transfer: DataTransfer =\n        (<DragEvent>event).dataTransfer ?? new DataTransfer();\n      const files: FileList = transfer.files;\n      if (files.length) {\n        const value: FileList | File = this._multiple\n          ? files.length > 1\n            ? files\n            : files[0]\n          : files[0];\n        this.fileDrop.emit(value);\n      }\n    }\n    this._renderer.removeClass(this._element.nativeElement, 'drop-zone');\n    this._stopEvent(event);\n  }\n\n  /**\n   * Validates if the transfer item types are 'Files'.\n   */\n  private _typeCheck(\n    types: ReadonlyArray<string> | DOMStringList,\n  ): 'none' | 'copy' | 'link' | 'move' {\n    let dropEffect: 'none' | 'copy' | 'link' | 'move' = 'none';\n    if (\n      types &&\n      (((<any>types).contains && (<any>types).contains('Files')) ||\n        ((<any>types).indexOf && (<any>types).indexOf('Files') !== -1))\n    ) {\n      dropEffect = 'copy';\n    }\n\n    return dropEffect;\n  }\n\n  private _stopEvent(event: Event): void {\n    event.preventDefault();\n    event.stopPropagation();\n  }\n}\n"]}","import { Component, Directive, Input, Output, EventEmitter, ChangeDetectionStrategy, ViewChild, ElementRef, Renderer2, TemplateRef, ViewContainerRef, ChangeDetectorRef, forwardRef, NgZone, inject, } from '@angular/core';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { TemplatePortalDirective } from '@angular/cdk/portal';\nimport { ENTER } from '@angular/cdk/keycodes';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { fromEvent, merge, Subject } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\nimport { mixinControlValueAccessor, mixinDisabled, } from '@covalent/core/common';\nimport { MatButtonModule } from '@angular/material/button';\nimport { TdFileDropDirective } from '../directives/file-drop.directive';\nimport { TdFileSelectDirective } from '../directives/file-select.directive';\nimport * as i0 from \"@angular/core\";\nimport * as i1 from \"@angular/material/button\";\nconst _c0 = [\"fileInputButton\"];\nconst _c1 = [\"fileInput\"];\nconst _c2 = [\"*\"];\nexport class TdFileInputLabelDirective extends TemplatePortalDirective {\n constructor() {\n const templateRef = inject(TemplateRef);\n const viewContainerRef = inject(ViewContainerRef);\n super(templateRef, viewContainerRef);\n }\n static ɵfac = function TdFileInputLabelDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || TdFileInputLabelDirective)(); };\n static ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: TdFileInputLabelDirective, selectors: [[\"ng-template\", \"tdFileInputLabel\", \"\"]], features: [i0.ɵɵInheritDefinitionFeature] });\n}\n(() => { (typeof ngDevMode === \"undefined\" || ngDevMode) && i0.ɵsetClassMetadata(TdFileInputLabelDirective, [{\n type: Directive,\n args: [{\n selector: '[tdFileInputLabel]ng-template',\n }]\n }], () => [], null); })();\nexport class TdFileInputBase {\n _changeDetectorRef;\n constructor(_changeDetectorRef) {\n this._changeDetectorRef = _changeDetectorRef;\n }\n}\nexport const _TdFileInputMixinBase = mixinControlValueAccessor(mixinDisabled(TdFileInputBase));\nexport class TdFileInputComponent extends _TdFileInputMixinBase {\n _ngZone = inject(NgZone);\n _renderer = inject(Renderer2);\n _multiple = false;\n /** The native `<button class=\"td-file-input\"></button>` element */\n _inputButton;\n /** The native `<input type=\"file\"> element */\n _inputElement;\n get inputElement() {\n return this._inputElement.nativeElement;\n }\n /**\n * color?: 'accent' | 'primary' | 'warn'\n * Sets button color. Uses same color palette accepted as [MatButton].\n */\n color;\n /**\n * multiple?: boolean\n * Sets if multiple files can be dropped/selected at once in [TdFileInputComponent].\n */\n set multiple(multiple) {\n this._multiple = coerceBooleanProperty(multiple);\n }\n get multiple() {\n return this._multiple;\n }\n /**\n * accept?: string\n * Sets files accepted when opening the file browser dialog.\n * Same as 'accept' attribute in <input/> element.\n */\n accept;\n /**\n * select?: function\n * Event emitted a file is selected\n * Emits a [File | FileList] object.\n */\n selectFile = new EventEmitter();\n _destroy$ = new Subject();\n constructor() {\n const _changeDetectorRef = inject(ChangeDetectorRef);\n super(_changeDetectorRef);\n }\n ngOnInit() {\n this._ngZone.runOutsideAngular(() => {\n merge(fromEvent(this._inputButton.nativeElement, 'click'), fromEvent(this._inputButton.nativeElement, 'keyup').pipe(filter((event) => event.keyCode === ENTER)))\n .pipe(takeUntil(this._destroy$))\n .subscribe(() => this._inputElement.nativeElement.click());\n });\n }\n ngOnDestroy() {\n this._destroy$.next();\n }\n /**\n * Method executed when a file is selected.\n */\n handleSelect(files) {\n this.writeValue(files);\n this.selectFile.emit(files);\n }\n /**\n * Used to clear the selected files from the [TdFileInputComponent].\n */\n clear() {\n this.writeValue(undefined);\n this._renderer.setProperty(this.inputElement, 'value', '');\n }\n /** Method executed when the disabled value changes */\n onDisabledChange(v) {\n if (v) {\n this.clear();\n }\n }\n /**\n * Sets disable to the component. Implemented as part of ControlValueAccessor.\n */\n setDisabledState(isDisabled) {\n this.disabled = isDisabled;\n }\n static ɵfac = function TdFileInputComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || TdFileInputComponent)(); };\n static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: TdFileInputComponent, selectors: [[\"td-file-input\"]], viewQuery: function TdFileInputComponent_Query(rf, ctx) { if (rf & 1) {\n i0.ɵɵviewQuery(_c0, 7, ElementRef);\n i0.ɵɵviewQuery(_c1, 7);\n } if (rf & 2) {\n let _t;\n i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx._inputButton = _t.first);\n i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx._inputElement = _t.first);\n } }, inputs: { disabled: \"disabled\", value: \"value\", color: \"color\", multiple: \"multiple\", accept: \"accept\" }, outputs: { selectFile: \"selectFile\" }, features: [i0.ɵɵProvidersFeature([\n {\n provide: NG_VALUE_ACCESSOR,\n useExisting: forwardRef(() => TdFileInputComponent),\n multi: true,\n },\n ]), i0.ɵɵInheritDefinitionFeature], ngContentSelectors: _c2, decls: 5, vars: 6, consts: [[\"fileInputButton\", \"\"], [\"fileInput\", \"\"], [\"mat-stroked-button\", \"\", \"type\", \"button\", \"tdFileDrop\", \"\", 1, \"td-file-input\", 3, \"fileDrop\", \"color\", \"multiple\", \"disabled\"], [\"type\", \"file\", \"tdFileSelect\", \"\", 1, \"td-file-input-hidden\", 3, \"fileSelect\", \"multiple\", \"disabled\"]], template: function TdFileInputComponent_Template(rf, ctx) { if (rf & 1) {\n const _r1 = i0.ɵɵgetCurrentView();\n i0.ɵɵprojectionDef();\n i0.ɵɵelementStart(0, \"button\", 2, 0);\n i0.ɵɵlistener(\"fileDrop\", function TdFileInputComponent_Template_button_fileDrop_0_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.handleSelect($event)); });\n i0.ɵɵprojection(2);\n i0.ɵɵelementEnd();\n i0.ɵɵelementStart(3, \"input\", 3, 1);\n i0.ɵɵlistener(\"fileSelect\", function TdFileInputComponent_Template_input_fileSelect_3_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.handleSelect($event)); });\n i0.ɵɵelementEnd();\n } if (rf & 2) {\n i0.ɵɵproperty(\"color\", ctx.color)(\"multiple\", ctx.multiple)(\"disabled\", ctx.disabled);\n i0.ɵɵadvance(3);\n i0.ɵɵproperty(\"multiple\", ctx.multiple)(\"disabled\", ctx.disabled);\n i0.ɵɵattribute(\"accept\", ctx.accept);\n } }, dependencies: [MatButtonModule, i1.MatButton, TdFileDropDirective, TdFileSelectDirective], styles: [\"[_nghost-%COMP%] .td-file-input[_ngcontent-%COMP%]{padding-left:8px;padding-right:8px}[_nghost-%COMP%] input.td-file-input-hidden[_ngcontent-%COMP%]{display:none}[_nghost-%COMP%] .mdc-button__label{display:flex;align-items:center}[_nghost-%COMP%] .drop-zone[_ngcontent-%COMP%]{border-radius:3px}[_nghost-%COMP%] .drop-zone[_ngcontent-%COMP%] *[_ngcontent-%COMP%]{pointer-events:none}\"], changeDetection: 0 });\n}\n(() => { (typeof ngDevMode === \"undefined\" || ngDevMode) && i0.ɵsetClassMetadata(TdFileInputComponent, [{\n type: Component,\n args: [{ changeDetection: ChangeDetectionStrategy.OnPush, providers: [\n {\n provide: NG_VALUE_ACCESSOR,\n useExisting: forwardRef(() => TdFileInputComponent),\n multi: true,\n },\n ], selector: 'td-file-input', inputs: ['disabled', 'value'], imports: [MatButtonModule, TdFileDropDirective, TdFileSelectDirective], template: \"<button\\n #fileInputButton\\n mat-stroked-button\\n class=\\\"td-file-input\\\"\\n type=\\\"button\\\"\\n [color]=\\\"color\\\"\\n [multiple]=\\\"multiple\\\"\\n [disabled]=\\\"disabled\\\"\\n (fileDrop)=\\\"handleSelect($event)\\\"\\n tdFileDrop\\n>\\n <ng-content></ng-content>\\n</button>\\n<input\\n #fileInput\\n class=\\\"td-file-input-hidden\\\"\\n type=\\\"file\\\"\\n [attr.accept]=\\\"accept\\\"\\n (fileSelect)=\\\"handleSelect($event)\\\"\\n [multiple]=\\\"multiple\\\"\\n [disabled]=\\\"disabled\\\"\\n tdFileSelect\\n/>\\n\", styles: [\":host .td-file-input{padding-left:8px;padding-right:8px}:host input.td-file-input-hidden{display:none}:host ::ng-deep .mdc-button__label{display:flex;align-items:center}:host .drop-zone{border-radius:3px}:host .drop-zone *{pointer-events:none}\\n\"] }]\n }], () => [], { _inputButton: [{\n type: ViewChild,\n args: ['fileInputButton', { static: true, read: ElementRef }]\n }], _inputElement: [{\n type: ViewChild,\n args: ['fileInput', { static: true }]\n }], color: [{\n type: Input\n }], multiple: [{\n type: Input\n }], accept: [{\n type: Input\n }], selectFile: [{\n type: Output\n }] }); })();\n(() => { (typeof ngDevMode === \"undefined\" || ngDevMode) && i0.ɵsetClassDebugInfo(TdFileInputComponent, { className: \"TdFileInputComponent\", filePath: \"file-input/file-input.component.ts\", lineNumber: 72 }); })();\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-input.component.js","sourceRoot":"","sources":["../../../../../../libs/angular/file/src/file-input/file-input.component.ts","../../../../../../libs/angular/file/src/file-input/file-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Directive,\n  Input,\n  Output,\n  EventEmitter,\n  ChangeDetectionStrategy,\n  ViewChild,\n  ElementRef,\n  Renderer2,\n  TemplateRef,\n  ViewContainerRef,\n  ChangeDetectorRef,\n  forwardRef,\n  OnInit,\n  OnDestroy,\n  NgZone,\n  inject,\n} from '@angular/core';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { TemplatePortalDirective } from '@angular/cdk/portal';\nimport { ENTER } from '@angular/cdk/keycodes';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { fromEvent, merge, Subject } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\nimport {\n  ICanDisable,\n  IControlValueAccessor,\n  mixinControlValueAccessor,\n  mixinDisabled,\n} from '@covalent/core/common';\nimport { MatButtonModule } from '@angular/material/button';\nimport { TdFileDropDirective } from '../directives/file-drop.directive';\nimport { TdFileSelectDirective } from '../directives/file-select.directive';\n\n@Directive({\n  selector: '[tdFileInputLabel]ng-template',\n})\nexport class TdFileInputLabelDirective extends TemplatePortalDirective {\n  constructor() {\n    const templateRef = inject<TemplateRef<unknown>>(TemplateRef);\n    const viewContainerRef = inject(ViewContainerRef);\n\n    super(templateRef, viewContainerRef);\n  }\n}\n\nexport class TdFileInputBase {\n  constructor(public _changeDetectorRef: ChangeDetectorRef) {}\n}\n\nexport const _TdFileInputMixinBase = mixinControlValueAccessor(\n  mixinDisabled(TdFileInputBase),\n);\n\n@Component({\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => TdFileInputComponent),\n      multi: true,\n    },\n  ],\n  selector: 'td-file-input',\n  // eslint-disable-next-line @angular-eslint/no-inputs-metadata-property\n  inputs: ['disabled', 'value'],\n  styleUrls: ['./file-input.component.scss'],\n  templateUrl: './file-input.component.html',\n  imports: [MatButtonModule, TdFileDropDirective, TdFileSelectDirective],\n})\nexport class TdFileInputComponent\n  extends _TdFileInputMixinBase\n  implements OnInit, OnDestroy, IControlValueAccessor, ICanDisable\n{\n  private _ngZone = inject(NgZone);\n  private _renderer = inject(Renderer2);\n\n  private _multiple = false;\n\n  /** The native `<button class=\"td-file-input\"></button>` element */\n  @ViewChild('fileInputButton', { static: true, read: ElementRef })\n  _inputButton!: ElementRef<HTMLElement>;\n\n  /** The native `<input type=\"file\"> element */\n  @ViewChild('fileInput', { static: true })\n  _inputElement!: ElementRef<HTMLInputElement>;\n  get inputElement(): HTMLInputElement {\n    return this._inputElement.nativeElement;\n  }\n\n  /**\n   * color?: 'accent' | 'primary' | 'warn'\n   * Sets button color. Uses same color palette accepted as [MatButton].\n   */\n  @Input() color?: 'accent' | 'primary' | 'warn';\n\n  /**\n   * multiple?: boolean\n   * Sets if multiple files can be dropped/selected at once in [TdFileInputComponent].\n   */\n  @Input()\n  set multiple(multiple: boolean | string) {\n    this._multiple = coerceBooleanProperty(multiple);\n  }\n  get multiple(): boolean {\n    return this._multiple;\n  }\n\n  /**\n   * accept?: string\n   * Sets files accepted when opening the file browser dialog.\n   * Same as 'accept' attribute in <input/> element.\n   */\n  @Input() accept?: string;\n\n  /**\n   * select?: function\n   * Event emitted a file is selected\n   * Emits a [File | FileList] object.\n   */\n  @Output() selectFile: EventEmitter<File | FileList> = new EventEmitter<\n    File | FileList\n  >();\n\n  private _destroy$ = new Subject<void>();\n\n  constructor() {\n    const _changeDetectorRef = inject(ChangeDetectorRef);\n\n    super(_changeDetectorRef);\n  }\n\n  ngOnInit(): void {\n    this._ngZone.runOutsideAngular(() => {\n      merge(\n        fromEvent(this._inputButton.nativeElement, 'click'),\n        fromEvent<KeyboardEvent>(this._inputButton.nativeElement, 'keyup').pipe(\n          filter((event) => event.keyCode === ENTER),\n        ),\n      )\n        .pipe(takeUntil(this._destroy$))\n        .subscribe(() => this._inputElement.nativeElement.click());\n    });\n  }\n\n  ngOnDestroy(): void {\n    this._destroy$.next();\n  }\n\n  /**\n   * Method executed when a file is selected.\n   */\n  handleSelect(files: File | FileList): void {\n    this.writeValue(files);\n    this.selectFile.emit(files);\n  }\n\n  /**\n   * Used to clear the selected files from the [TdFileInputComponent].\n   */\n  clear(): void {\n    this.writeValue(undefined);\n    this._renderer.setProperty(this.inputElement, 'value', '');\n  }\n\n  /** Method executed when the disabled value changes */\n  override onDisabledChange(v: boolean): void {\n    if (v) {\n      this.clear();\n    }\n  }\n  /**\n   * Sets disable to the component. Implemented as part of ControlValueAccessor.\n   */\n  override setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n}\n","<button\n  #fileInputButton\n  mat-stroked-button\n  class=\"td-file-input\"\n  type=\"button\"\n  [color]=\"color\"\n  [multiple]=\"multiple\"\n  [disabled]=\"disabled\"\n  (fileDrop)=\"handleSelect($event)\"\n  tdFileDrop\n>\n  <ng-content></ng-content>\n</button>\n<input\n  #fileInput\n  class=\"td-file-input-hidden\"\n  type=\"file\"\n  [attr.accept]=\"accept\"\n  (fileSelect)=\"handleSelect($event)\"\n  [multiple]=\"multiple\"\n  [disabled]=\"disabled\"\n  tdFileSelect\n/>\n"]}","import { Component, Input, Output, EventEmitter, ChangeDetectionStrategy, ViewChild, ContentChild, ChangeDetectorRef, forwardRef, inject, } from '@angular/core';\nimport { coer