fundamental-ngx
Version:
SAP Fiori Fundamentals, implemented in Angular
280 lines • 17.1 kB
JavaScript
/**
* @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"]}