UNPKG

fundamental-ngx

Version:

SAP Fundamentals, implemented in Angular

225 lines 15.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Directive, EventEmitter, HostListener, Input, Output } from '@angular/core'; /** * Directive that handles the drag and drop feature of the file input. */ var FileDragndropDirective = /** @class */ (function () { function FileDragndropDirective() { /** * Whether multiple files can be dropped at once. */ this.multiple = true; /** * Whether selecting of new files is disabled. */ this.disabled = false; /** * Whether drag and drop is enabled. Disables this directive. */ this.dragndrop = true; /** * Event emitted when files are selected. Passes back an array of files. */ this.onFileChange = new EventEmitter(); /** * Event emitted when invalid files are selected. Passes back an array of files. */ this.onInvalidFiles = new EventEmitter(); /** * Event emitted when the dragged file enters the dropzone. */ this.onDragEnter = new EventEmitter(); /** * Event emitted when the dragged file exits the dropzone. */ this.onDragLeave = new EventEmitter(); this.elementStateCounter = 0; } /** @hidden */ /** * @hidden * @param {?} event * @return {?} */ FileDragndropDirective.prototype.onDragover = /** * @hidden * @param {?} event * @return {?} */ function (event) { if (this.dragndrop) { event.preventDefault(); event.stopPropagation(); } }; /** @hidden */ /** * @hidden * @return {?} */ FileDragndropDirective.prototype.onDragenter = /** * @hidden * @return {?} */ function () { ++this.elementStateCounter; if (this.dragndrop && this.elementStateCounter === 1) { this.onDragEnter.emit(); } }; /** @hidden */ /** * @hidden * @param {?} event * @return {?} */ FileDragndropDirective.prototype.onDragleave = /** * @hidden * @param {?} event * @return {?} */ function (event) { --this.elementStateCounter; if (this.dragndrop && this.elementStateCounter === 0) { event.preventDefault(); event.stopPropagation(); this.onDragLeave.emit(); } }; /** @hidden */ /** * @hidden * @param {?} event * @return {?} */ FileDragndropDirective.prototype.onDrop = /** * @hidden * @param {?} event * @return {?} */ function (event) { this.elementStateCounter = 0; if (!this.dragndrop || this.disabled) { return; } event.preventDefault(); event.stopPropagation(); /** @type {?} */ var rawFiles = event.dataTransfer.files; /** @type {?} */ var files = Array.from(rawFiles); if (!this.multiple && files.length > 1) { this.onInvalidFiles.emit(files); return; } /** @type {?} */ var valid_files = []; /** @type {?} */ var invalid_files = []; if (files.length > 0) { if (!this.accept) { files.forEach((/** * @param {?} file * @return {?} */ function (file) { valid_files.push(file); })); } else { /** @type {?} */ var allowed_extensions_1 = this.accept.toLocaleLowerCase().replace(/[\s.]/g, '').split(','); files.forEach((/** * @param {?} file * @return {?} */ function (file) { /** @type {?} */ var ext = file.name.split('.')[file.name.split('.').length - 1]; if (allowed_extensions_1.lastIndexOf(ext) !== -1) { valid_files.push(file); } else { invalid_files.push(file); } })); } this.onFileChange.emit(valid_files); if (invalid_files.length > 0) { this.onInvalidFiles.emit(invalid_files); } } }; FileDragndropDirective.decorators = [ { type: Directive, args: [{ selector: '[fdFileDragnDrop]' },] } ]; FileDragndropDirective.propDecorators = { multiple: [{ type: Input }], accept: [{ type: Input }], disabled: [{ type: Input }], dragndrop: [{ type: Input }], onFileChange: [{ type: Output }], onInvalidFiles: [{ type: Output }], onDragEnter: [{ type: Output }], onDragLeave: [{ type: Output }], onDragover: [{ type: HostListener, args: ['dragover', ['$event'],] }], onDragenter: [{ type: HostListener, args: ['dragenter', [],] }], onDragleave: [{ type: HostListener, args: ['dragleave', ['$event'],] }], onDrop: [{ type: HostListener, args: ['drop', ['$event'],] }] }; return FileDragndropDirective; }()); export { FileDragndropDirective }; if (false) { /** * Whether multiple files can be dropped at once. * @type {?} */ FileDragndropDirective.prototype.multiple; /** * Accepted file extensions. Format: `'.png,.jpg'`. * @type {?} */ FileDragndropDirective.prototype.accept; /** * Whether selecting of new files is disabled. * @type {?} */ FileDragndropDirective.prototype.disabled; /** * Whether drag and drop is enabled. Disables this directive. * @type {?} */ FileDragndropDirective.prototype.dragndrop; /** * Event emitted when files are selected. Passes back an array of files. * @type {?} */ FileDragndropDirective.prototype.onFileChange; /** * Event emitted when invalid files are selected. Passes back an array of files. * @type {?} */ FileDragndropDirective.prototype.onInvalidFiles; /** * Event emitted when the dragged file enters the dropzone. * @type {?} */ FileDragndropDirective.prototype.onDragEnter; /** * Event emitted when the dragged file exits the dropzone. * @type {?} */ FileDragndropDirective.prototype.onDragLeave; /** * @type {?} * @private */ FileDragndropDirective.prototype.elementStateCounter; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-dragndrop.directive.js","sourceRoot":"ng://fundamental-ngx/","sources":["lib/file-input/directives/file-dragndrop.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, EventEmitter, HostListener, Input, Output } from '@angular/core';\n\n/**\n * Directive that handles the drag and drop feature of the file input.\n */\n@Directive({\n    selector: '[fdFileDragnDrop]'\n})\nexport class FileDragndropDirective {\n\n    /** Whether multiple files can be dropped at once. */\n    @Input()\n    multiple: boolean = true;\n\n    /** Accepted file extensions. Format: `'.png,.jpg'`. */\n    @Input()\n    accept: string;\n\n    /** Whether selecting of new files is disabled. */\n    @Input()\n    disabled: boolean = false;\n\n    /** Whether drag and drop is enabled. Disables this directive. */\n    @Input()\n    dragndrop: boolean = true;\n\n    /** Event emitted when files are selected. Passes back an array of files. */\n    @Output()\n    readonly onFileChange: EventEmitter<File[]> = new EventEmitter<File[]>();\n\n    /** Event emitted when invalid files are selected. Passes back an array of files. */\n    @Output()\n    readonly onInvalidFiles: EventEmitter<File[]> = new EventEmitter<File[]>();\n\n    /** Event emitted when the dragged file enters the dropzone. */\n    @Output()\n    readonly onDragEnter: EventEmitter<void> = new EventEmitter<void>();\n\n    /** Event emitted when the dragged file exits the dropzone. */\n    @Output()\n    readonly onDragLeave: EventEmitter<void> = new EventEmitter<void>();\n\n    private elementStateCounter: number = 0;\n\n    /** @hidden */\n    @HostListener('dragover', ['$event'])\n    public onDragover(event) {\n        if (this.dragndrop) {\n            event.preventDefault();\n            event.stopPropagation();\n        }\n    }\n\n    /** @hidden */\n    @HostListener('dragenter', [])\n    public onDragenter() {\n        ++this.elementStateCounter;\n        if (this.dragndrop && this.elementStateCounter === 1) {\n            this.onDragEnter.emit();\n        }\n    }\n\n    /** @hidden */\n    @HostListener('dragleave', ['$event'])\n    public onDragleave(event) {\n        --this.elementStateCounter;\n        if (this.dragndrop && this.elementStateCounter === 0) {\n            event.preventDefault();\n            event.stopPropagation();\n            this.onDragLeave.emit();\n        }\n    }\n\n    /** @hidden */\n    @HostListener('drop', ['$event'])\n    public onDrop(event) {\n        this.elementStateCounter = 0;\n\n        if (!this.dragndrop || this.disabled) {\n            return;\n        }\n\n        event.preventDefault();\n        event.stopPropagation();\n\n        const rawFiles = event.dataTransfer.files;\n        const files: File[] = Array.from(rawFiles);\n\n        if (!this.multiple && files.length > 1) {\n            this.onInvalidFiles.emit(files);\n            return;\n        }\n\n        const valid_files: File[] = [];\n        const invalid_files: File[] = [];\n        if (files.length > 0) {\n            if (!this.accept) {\n                files.forEach((file: File) => {\n                    valid_files.push(file);\n                });\n            } else {\n                const allowed_extensions = this.accept.toLocaleLowerCase().replace(/[\\s.]/g, '').split(',');\n                files.forEach((file: File) => {\n                    const ext = file.name.split('.')[file.name.split('.').length - 1];\n                    if (allowed_extensions.lastIndexOf(ext) !== -1) {\n                        valid_files.push(file);\n                    } else {\n                        invalid_files.push(file);\n                    }\n                });\n            }\n            this.onFileChange.emit(valid_files);\n            if (invalid_files.length > 0) {\n                this.onInvalidFiles.emit(invalid_files);\n            }\n        }\n    }\n}\n"]}