UNPKG

fundamental-ngx

Version:

SAP Fiori Fundamentals, implemented in Angular

280 lines 17.1 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ElementRef, EventEmitter, forwardRef, Input, Output, ViewChild } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; /** * Tool to facilitate the input of files from the user. * It supports drag and drop, multiple input, max file size and more. * The drag events make it very easy to create and style elements like a dropzone. */ var FileInputComponent = /** @class */ (function () { function FileInputComponent() { /** * \@Input Whether the file input is disabled. */ this.disabled = false; /** * \@Input Whether the file input should accept multiple files. */ this.multiple = true; /** * \@Input Whether the file input accepts drag and dropped files. */ this.dragndrop = true; /** * \@Output Event fired when files are selected. Passed object is the array of files selected. */ this.onSelect = new EventEmitter(); /** * \@Output Event fired when some invalid files are selected. Passed object is the array of invalid files. */ this.onInvalidFiles = new EventEmitter(); /** * \@Output Event fired when the dragged file enters the component boundaries. */ this.onDragEnter = new EventEmitter(); /** * \@Output Event fired when the dragged file exits the component boundaries. */ this.onDragLeave = new EventEmitter(); /** * @hidden */ this.onChange = (/** * @return {?} */ function () { }); /** * @hidden */ this.onTouched = (/** * @return {?} */ function () { }); } /** @hidden */ /** * @hidden * @param {?} fn * @return {?} */ FileInputComponent.prototype.registerOnChange = /** * @hidden * @param {?} fn * @return {?} */ function (fn) { this.onChange = fn; }; /** @hidden */ /** * @hidden * @param {?} fn * @return {?} */ FileInputComponent.prototype.registerOnTouched = /** * @hidden * @param {?} fn * @return {?} */ function (fn) { this.onTouched = fn; }; /** @hidden */ /** * @hidden * @param {?} isDisabled * @return {?} */ FileInputComponent.prototype.setDisabledState = /** * @hidden * @param {?} isDisabled * @return {?} */ function (isDisabled) { this.disabled = isDisabled; }; /** @hidden */ /** * @hidden * @param {?} files * @return {?} */ FileInputComponent.prototype.writeValue = /** * @hidden * @param {?} files * @return {?} */ function (files) { // not needed - should be handled by user. }; /** @hidden */ /** * @hidden * @param {?} event * @return {?} */ FileInputComponent.prototype.selectHandler = /** * @hidden * @param {?} event * @return {?} */ function (event) { var _this = this; if (this.maxFileSize) { /** @type {?} */ var valid_files_1 = []; /** @type {?} */ var invalid_files_1 = []; event.forEach((/** * @param {?} file * @return {?} */ function (file) { if (file.size < _this.maxFileSize) { valid_files_1.push(file); } else { invalid_files_1.push(file); } })); if (valid_files_1.length > 0) { this.onChange(valid_files_1); this.onSelect.emit(valid_files_1); } if (invalid_files_1.length > 0) { this.onInvalidFiles.emit(invalid_files_1); } } else { this.onChange(event); this.onSelect.emit(event); } }; /** * Opens the file selector. */ /** * Opens the file selector. * @return {?} */ FileInputComponent.prototype.open = /** * Opens the file selector. * @return {?} */ function () { this.inputRef.nativeElement.click(); }; /** * Clears the files from the input. */ /** * Clears the files from the input. * @return {?} */ FileInputComponent.prototype.clear = /** * Clears the files from the input. * @return {?} */ function () { this.inputRef.nativeElement.value = ''; this.onChange([]); }; FileInputComponent.decorators = [ { type: Component, args: [{ selector: 'fd-file-input', template: "<div style=\"display: block\"\n fdFileDragnDrop\n [accept]=\"accept\"\n [dragndrop]=\"dragndrop\"\n [disabled]=\"disabled\"\n [multiple]=\"multiple\"\n (onFileChange)=\"selectHandler($event)\"\n (onInvalidFiles)=\"onInvalidFiles.emit($event)\"\n (onDragEnter)=\"onDragEnter.emit()\"\n (onDragLeave)=\"onDragLeave.emit()\">\n <ng-content></ng-content>\n</div>\n<input #input\n class=\"hidden-file-input\"\n type=\"file\"\n [attr.accept]=\"accept\"\n (onFileSelect)=\"selectHandler($event)\"\n [multiple]=\"multiple\"\n [disabled]=\"disabled\"\n fdFileSelect>\n\n", host: { '(blur)': 'onTouched()' }, providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((/** * @return {?} */ function () { return FileInputComponent; })), multi: true, }], styles: [":host{display:inline-block}input.hidden-file-input{display:none}"] }] } ]; FileInputComponent.propDecorators = { inputRef: [{ type: ViewChild, args: ['input',] }], disabled: [{ type: Input }], multiple: [{ type: Input }], accept: [{ type: Input }], dragndrop: [{ type: Input }], maxFileSize: [{ type: Input }], onSelect: [{ type: Output }], onInvalidFiles: [{ type: Output }], onDragEnter: [{ type: Output }], onDragLeave: [{ type: Output }] }; return FileInputComponent; }()); export { FileInputComponent }; if (false) { /** * @hidden * @type {?} */ FileInputComponent.prototype.inputRef; /** * \@Input Whether the file input is disabled. * @type {?} */ FileInputComponent.prototype.disabled; /** * \@Input Whether the file input should accept multiple files. * @type {?} */ FileInputComponent.prototype.multiple; /** * \@Input Accepted file extensions. Format: `'.png,.jpg'`. * @type {?} */ FileInputComponent.prototype.accept; /** * \@Input Whether the file input accepts drag and dropped files. * @type {?} */ FileInputComponent.prototype.dragndrop; /** * \@Input Max file size in bytes that the input will accept. * @type {?} */ FileInputComponent.prototype.maxFileSize; /** * \@Output Event fired when files are selected. Passed object is the array of files selected. * @type {?} */ FileInputComponent.prototype.onSelect; /** * \@Output Event fired when some invalid files are selected. Passed object is the array of invalid files. * @type {?} */ FileInputComponent.prototype.onInvalidFiles; /** * \@Output Event fired when the dragged file enters the component boundaries. * @type {?} */ FileInputComponent.prototype.onDragEnter; /** * \@Output Event fired when the dragged file exits the component boundaries. * @type {?} */ FileInputComponent.prototype.onDragLeave; /** * @hidden * @type {?} */ FileInputComponent.prototype.onChange; /** * @hidden * @type {?} */ FileInputComponent.prototype.onTouched; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-input.component.js","sourceRoot":"ng://fundamental-ngx/","sources":["lib/file-input/file-input.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, forwardRef, Input, Output, ViewChild } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n/**\n * Tool to facilitate the input of files from the user.\n * It supports drag and drop, multiple input, max file size and more.\n * The drag events make it very easy to create and style elements like a dropzone.\n */\n@Component({\n    selector: 'fd-file-input',\n    templateUrl: './file-input.component.html',\n    styleUrls: ['./file-input.component.scss'],\n    host: {\n        '(blur)': 'onTouched()'\n    },\n    providers: [{\n        provide: NG_VALUE_ACCESSOR,\n        useExisting: forwardRef(() => FileInputComponent),\n        multi: true,\n    }],\n})\nexport class FileInputComponent implements ControlValueAccessor {\n\n    /** @hidden */\n    @ViewChild('input')\n    inputRef: ElementRef;\n\n    /** @Input Whether the file input is disabled. */\n    @Input()\n    disabled: boolean = false;\n\n    /** @Input Whether the file input should accept multiple files. */\n    @Input()\n    multiple: boolean = true;\n\n    /** @Input Accepted file extensions. Format: `'.png,.jpg'`. */\n    @Input()\n    accept: string;\n\n    /** @Input Whether the file input accepts drag and dropped files. */\n    @Input()\n    dragndrop: boolean = true;\n\n    /** @Input Max file size in bytes that the input will accept. */\n    @Input()\n    maxFileSize: number;\n\n    /** @Output Event fired when files are selected. Passed object is the array of files selected. */\n    @Output()\n    onSelect: EventEmitter<File[]> = new EventEmitter<File[]>();\n\n    /** @Output Event fired when some invalid files are selected. Passed object is the array of invalid files. */\n    @Output()\n    onInvalidFiles: EventEmitter<File[]> = new EventEmitter<File[]>();\n\n    /** @Output Event fired when the dragged file enters the component boundaries. */\n    @Output()\n    onDragEnter: EventEmitter<null> = new EventEmitter<null>();\n\n    /** @Output Event fired when the dragged file exits the component boundaries. */\n    @Output()\n    onDragLeave: EventEmitter<null> = new EventEmitter<null>();\n\n    /** @hidden */\n    onChange: Function = () => {};\n\n    /** @hidden */\n    onTouched: Function = () => {};\n\n    /** @hidden */\n    registerOnChange(fn: any): void {\n        this.onChange = fn;\n    }\n\n    /** @hidden */\n    registerOnTouched(fn: any): void {\n        this.onTouched = fn;\n    }\n\n    /** @hidden */\n    setDisabledState(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n    }\n\n    /** @hidden */\n    writeValue(files: File[]): void {\n        // not needed - should be handled by user.\n    }\n\n    /** @hidden */\n    selectHandler(event: File[]) {\n        if (this.maxFileSize) {\n            const valid_files: File[] = [];\n            const invalid_files: File[] = [];\n            event.forEach(file => {\n                if (file.size < this.maxFileSize) {\n                    valid_files.push(file);\n                } else {\n                    invalid_files.push(file);\n                }\n            });\n            if (valid_files.length > 0) {\n                this.onChange(valid_files);\n                this.onSelect.emit(valid_files);\n            }\n            if (invalid_files.length > 0) {\n                this.onInvalidFiles.emit(invalid_files);\n            }\n        } else {\n            this.onChange(event);\n            this.onSelect.emit(event);\n        }\n    }\n\n    /**\n     * Opens the file selector.\n     */\n    public open(): void {\n        this.inputRef.nativeElement.click();\n    }\n\n    /**\n     * Clears the files from the input.\n     */\n    public clear(): void {\n        this.inputRef.nativeElement.value = '';\n        this.onChange([]);\n    }\n\n}\n"]}