gentics-ui-core
Version:
This is the common core framework for the Gentics CMS and Mesh UI, and other Angular applications.
191 lines • 23.3 kB
JavaScript
import { ChangeDetectorRef, Component, EventEmitter, Input, Optional, Output, Self } from '@angular/core';
import { merge as observableMerge } from 'rxjs';
import { FileDropArea } from '../file-drop-area/file-drop-area.directive';
import { matchesMimeType } from '../file-drop-area/matches-mime-type';
import * as i0 from "@angular/core";
import * as i1 from "../file-drop-area/file-drop-area.directive";
import * as i2 from "../button/button.component";
/**
* A file picker component.
*
* ```html
* <gtx-file-picker (fileSelect)="uploadFiles($event)"></gtx-file-picker>
* ```
*/
export class FilePicker {
constructor(dropArea, cd) {
this.dropArea = dropArea;
this.cd = cd;
/**
* Sets the file picker button to be auto-focused. Handled by `AutofocusDirective`.
*/
this.autofocus = false;
/**
* Sets the type of the button. Forwarded to the Button component.
*/
this.type = 'primary';
/**
* Triggered when a file / files are selected via the file picker.
*/
this.fileSelect = new EventEmitter();
/**
* Triggered when a file / files are selected but do not fit the "accept" option.
*/
this.fileSelectReject = new EventEmitter();
this.inputAccept = '*';
this._icon = false;
this._size = 'regular';
this._flat = false;
this._accept = '*';
this._disabled = false;
this._multiple = true;
this._subscriptions = [];
}
/**
* Set to a non-false value to disable the file picker. Defaults to `false` if absent.
*/
get disabled() {
return this._disabled;
}
set disabled(value) {
let newValue = value !== false && value !== 'false';
if (newValue != this._disabled) {
this._disabled = newValue;
this.setDropAreaOptions();
}
}
/**
* Set to a falsy value to disable picking multiple files at once. Defaults to `true` if absent.
*/
get multiple() {
return this._multiple;
}
set multiple(value) {
let newValue = value !== false && value !== 'false';
if (newValue != this._multiple) {
this._multiple = newValue;
this.setDropAreaOptions();
}
}
/**
* Provides feedback for accepted file types, if supported by the browser. Defaults to `"*"`.
*/
get accept() {
return this._accept;
}
set accept(value) {
let usedValue = value == undefined ? '*' : value;
if (usedValue !== this._accept) {
this._accept = usedValue;
this.inputAccept = usedValue.replace(/,/g, ';');
this.setDropAreaOptions();
}
}
/**
* Button size - "small", "regular" or "large". Forwarded to the Button component.
*/
get size() {
return this._size;
}
set size(val) {
this._size = val == undefined ? 'regular' : val;
}
/**
* Display the button as a flat button or not. Forwarded to the Button component.
*/
get flat() {
return this._flat;
}
set flat(val) {
this._flat = val != undefined && val !== false;
}
/**
* Icon button without text. Forwarded to the Button component.
*/
get icon() {
return this._icon;
}
set icon(val) {
this._icon = val !== false && val !== 'false';
}
ngOnInit() {
if (this.dropArea) {
this.setDropAreaOptions();
this._subscriptions = [
observableMerge(this.dropArea.pageDragEnter, this.dropArea.pageDragLeave, this.dropArea.fileDragEnter, this.dropArea.fileDragLeave).subscribe(() => this.cd.markForCheck()),
this.dropArea.fileDrop.subscribe((files) => {
this.fileSelect.emit(files);
}),
this.dropArea.fileDropReject.subscribe((files) => {
this.fileSelectReject.emit(files);
})
];
}
}
ngOnDestroy() {
this._subscriptions.forEach(s => s.unsubscribe());
}
onChange(event, input) {
let files = input && input.files;
if (files && files.length) {
let accepted = [];
let rejected = [];
Array.from(files).forEach(file => {
if (matchesMimeType(file.type, this._accept)) {
accepted.push(file);
}
else {
rejected.push(file);
}
});
// Remove the Files from the input
input.value = '';
if (accepted.length > 0) {
this.fileSelect.emit(accepted);
}
if (rejected.length > 0) {
this.fileSelectReject.emit(rejected);
}
}
}
setDropAreaOptions() {
if (this.dropArea) {
let options = Object.assign({}, this.dropArea.options || {});
options.accept = this._accept;
options.disabled = this._disabled;
options.multiple = this._multiple;
this.dropArea.options = options;
}
}
}
/** @nocollapse */ FilePicker.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: FilePicker, deps: [{ token: i1.FileDropArea, optional: true, self: true }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
/** @nocollapse */ FilePicker.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: FilePicker, selector: "gtx-file-picker", inputs: { autofocus: "autofocus", disabled: "disabled", multiple: "multiple", accept: "accept", size: "size", flat: "flat", type: "type", icon: "icon" }, outputs: { fileSelect: "fileSelect", fileSelectReject: "fileSelectReject" }, ngImport: i0, template: "<div class=\"hidden-file-wrapper\">\n <input type=\"file\" class=\"hidden-file-input\"\n tabindex=\"-1\"\n [accept]=\"inputAccept\"\n [disabled]=\"disabled\"\n [multiple]=\"multiple\"\n (change)=\"onChange($event, fileInput)\"\n #fileInput\n />\n</div>\n<gtx-button (click)=\"!disabled && fileInput.click()\" [disabled]=\"disabled\"\n [size]=\"size\" [icon]=\"icon\"\n [type]=\"dropArea?.pageDragHovered ? 'success' : type\"\n [flat]=\"flat || dropArea?.dragHovered\">\n <ng-content></ng-content>\n</gtx-button>\n", components: [{ type: i2.Button, selector: "gtx-button", inputs: ["autofocus", "size", "type", "flat", "icon", "disabled", "submit"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: FilePicker, decorators: [{
type: Component,
args: [{ selector: 'gtx-file-picker', template: "<div class=\"hidden-file-wrapper\">\n <input type=\"file\" class=\"hidden-file-input\"\n tabindex=\"-1\"\n [accept]=\"inputAccept\"\n [disabled]=\"disabled\"\n [multiple]=\"multiple\"\n (change)=\"onChange($event, fileInput)\"\n #fileInput\n />\n</div>\n<gtx-button (click)=\"!disabled && fileInput.click()\" [disabled]=\"disabled\"\n [size]=\"size\" [icon]=\"icon\"\n [type]=\"dropArea?.pageDragHovered ? 'success' : type\"\n [flat]=\"flat || dropArea?.dragHovered\">\n <ng-content></ng-content>\n</gtx-button>\n" }]
}], ctorParameters: function () { return [{ type: i1.FileDropArea, decorators: [{
type: Optional
}, {
type: Self
}] }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { autofocus: [{
type: Input
}], disabled: [{
type: Input
}], multiple: [{
type: Input
}], accept: [{
type: Input
}], size: [{
type: Input
}], flat: [{
type: Input
}], type: [{
type: Input
}], icon: [{
type: Input
}], fileSelect: [{
type: Output
}], fileSelectReject: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-picker.component.js","sourceRoot":"","sources":["../../../../../src/components/file-picker/file-picker.component.ts","../../../../../src/components/file-picker/file-picker.tpl.html"],"names":[],"mappings":"AAAA,OAAO,EACH,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,KAAK,EAGL,QAAQ,EACR,MAAM,EACN,IAAI,EACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,KAAK,IAAI,eAAe,EAAe,MAAM,MAAM,CAAC;AAE5D,OAAO,EAAC,YAAY,EAAuB,MAAM,4CAA4C,CAAC;AAC9F,OAAO,EAAC,eAAe,EAAC,MAAM,qCAAqC,CAAC;;;;AAEpE;;;;;;GAMG;AAKH,MAAM,OAAO,UAAU;IAyGnB,YAAuC,QAAsB,EACzC,EAAqB;QADF,aAAQ,GAAR,QAAQ,CAAc;QACzC,OAAE,GAAF,EAAE,CAAmB;QAzGzC;;WAEG;QACM,cAAS,GAAY,KAAK,CAAC;QAiEpC;;WAEG;QACM,SAAI,GAA8D,SAAS,CAAC;QAYrF;;WAEG;QACO,eAAU,GAAG,IAAI,YAAY,EAAU,CAAC;QAElD;;WAEG;QACO,qBAAgB,GAAG,IAAI,YAAY,EAAU,CAAC;QAGxD,gBAAW,GAAW,GAAG,CAAC;QAClB,UAAK,GAAY,KAAK,CAAC;QACvB,UAAK,GAAkC,SAAS,CAAC;QACjD,UAAK,GAAG,KAAK,CAAC;QACd,YAAO,GAAW,GAAG,CAAC;QACtB,cAAS,GAAG,KAAK,CAAC;QAClB,cAAS,GAAG,IAAI,CAAC;QACjB,mBAAc,GAAmB,EAAE,CAAC;IAIC,CAAC;IApG9C;;OAEG;IACH,IAAa,QAAQ;QACjB,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IACD,IAAI,QAAQ,CAAC,KAAc;QACvB,IAAI,QAAQ,GAAG,KAAK,KAAK,KAAK,IAAU,KAAK,KAAK,OAAO,CAAC;QAC1D,IAAI,QAAQ,IAAI,IAAI,CAAC,SAAS,EAAE;YAC5B,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;YAC1B,IAAI,CAAC,kBAAkB,EAAE,CAAC;SAC7B;IACL,CAAC;IAED;;OAEG;IACH,IAAa,QAAQ;QACjB,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IACD,IAAI,QAAQ,CAAC,KAAc;QACvB,IAAI,QAAQ,GAAG,KAAK,KAAK,KAAK,IAAU,KAAK,KAAK,OAAO,CAAC;QAC1D,IAAI,QAAQ,IAAI,IAAI,CAAC,SAAS,EAAE;YAC5B,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;YAC1B,IAAI,CAAC,kBAAkB,EAAE,CAAC;SAC7B;IACL,CAAC;IAED;;OAEG;IACH,IAAa,MAAM;QACf,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IACD,IAAI,MAAM,CAAC,KAAa;QACpB,IAAI,SAAS,GAAG,KAAK,IAAI,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC;QACjD,IAAI,SAAS,KAAK,IAAI,CAAC,OAAO,EAAE;YAC5B,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;YACzB,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;YAChD,IAAI,CAAC,kBAAkB,EAAE,CAAC;SAC7B;IACL,CAAC;IAED;;OAEG;IACH,IAAa,IAAI;QACb,OAAO,IAAI,CAAC,KAAK,CAAC;IACtB,CAAC;IACD,IAAI,IAAI,CAAC,GAAkC;QACvC,IAAI,CAAC,KAAK,GAAG,GAAG,IAAI,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC;IACpD,CAAC;IAED;;OAEG;IACH,IAAa,IAAI;QACb,OAAO,IAAI,CAAC,KAAK,CAAC;IACtB,CAAC;IACD,IAAI,IAAI,CAAC,GAAY;QACjB,IAAI,CAAC,KAAK,GAAG,GAAG,IAAI,SAAS,IAAI,GAAG,KAAK,KAAK,CAAC;IACnD,CAAC;IAOD;;OAEG;IACH,IAAc,IAAI;QACd,OAAO,IAAI,CAAC,KAAK,CAAC;IACtB,CAAC;IACD,IAAI,IAAI,CAAC,GAAY;QACjB,IAAI,CAAC,KAAK,GAAG,GAAG,KAAK,KAAK,IAAU,GAAG,KAAK,OAAO,CAAC;IACxD,CAAC;IA0BD,QAAQ;QACJ,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC1B,IAAI,CAAC,cAAc,GAAG;gBAClB,eAAe,CACX,IAAI,CAAC,QAAQ,CAAC,aAAa,EAC3B,IAAI,CAAC,QAAQ,CAAC,aAAa,EAC3B,IAAI,CAAC,QAAQ,CAAC,aAAa,EAC3B,IAAI,CAAC,QAAQ,CAAC,aAAa,CAC9B,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;gBAEzC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,KAAa,EAAE,EAAE;oBAC/C,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAChC,CAAC,CAAC;gBAEF,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC,KAAa,EAAE,EAAE;oBACrD,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBACtC,CAAC,CAAC;aACL,CAAC;SACL;IACL,CAAC;IAED,WAAW;QACP,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;IACtD,CAAC;IAED,QAAQ,CAAC,KAAY,EAAE,KAAuB;QAC1C,IAAI,KAAK,GAAG,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC;QACjC,IAAI,KAAK,IAAI,KAAK,CAAC,MAAM,EAAE;YACvB,IAAI,QAAQ,GAAW,EAAE,CAAC;YAC1B,IAAI,QAAQ,GAAW,EAAE,CAAC;YAC1B,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;gBAC7B,IAAI,eAAe,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,EAAE;oBAC1C,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;iBACvB;qBAAM;oBACH,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;iBACvB;YACL,CAAC,CAAC,CAAC;YAEH,kCAAkC;YAClC,KAAK,CAAC,KAAK,GAAG,EAAE,CAAC;YAEjB,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;gBACrB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAClC;YACD,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;gBACrB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aACxC;SACJ;IACL,CAAC;IAEO,kBAAkB;QACtB,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,IAAI,OAAO,GAAyB,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC;YACnF,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC;YAC9B,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC;YAClC,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC;YAClC,IAAI,CAAC,QAAQ,CAAC,OAAO,GAAG,OAAO,CAAC;SACnC;IACL,CAAC;;0HAvKQ,UAAU;8GAAV,UAAU,8RC3BvB,ulBAgBA;2FDWa,UAAU;kBAJtB,SAAS;+BACI,iBAAiB;;0BA4Gd,QAAQ;;0BAAI,IAAI;4EArGpB,SAAS;sBAAjB,KAAK;gBAKO,QAAQ;sBAApB,KAAK;gBAcO,QAAQ;sBAApB,KAAK;gBAcO,MAAM;sBAAlB,KAAK;gBAeO,IAAI;sBAAhB,KAAK;gBAUO,IAAI;sBAAhB,KAAK;gBAUG,IAAI;sBAAZ,KAAK;gBAKQ,IAAI;sBAAjB,KAAK;gBAUI,UAAU;sBAAnB,MAAM;gBAKG,gBAAgB;sBAAzB,MAAM","sourcesContent":["import {\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    Input,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Output,\n    Self\n} from '@angular/core';\nimport {merge as observableMerge, Subscription} from 'rxjs';\n\nimport {FileDropArea, IFileDropAreaOptions} from '../file-drop-area/file-drop-area.directive';\nimport {matchesMimeType} from '../file-drop-area/matches-mime-type';\n\n/**\n * A file picker component.\n *\n * ```html\n * <gtx-file-picker (fileSelect)=\"uploadFiles($event)\"></gtx-file-picker>\n * ```\n */\n@Component({\n    selector: 'gtx-file-picker',\n    templateUrl: './file-picker.tpl.html'\n})\nexport class FilePicker implements OnInit, OnDestroy {\n    /**\n     * Sets the file picker button to be auto-focused. Handled by `AutofocusDirective`.\n     */\n    @Input() autofocus: boolean = false;\n\n    /**\n     * Set to a non-false value to disable the file picker. Defaults to `false` if absent.\n     */\n    @Input() get disabled(): boolean {\n        return this._disabled;\n    }\n    set disabled(value: boolean) {\n        let newValue = value !== false && <any> value !== 'false';\n        if (newValue != this._disabled) {\n            this._disabled = newValue;\n            this.setDropAreaOptions();\n        }\n    }\n\n    /**\n     * Set to a falsy value to disable picking multiple files at once. Defaults to `true` if absent.\n     */\n    @Input() get multiple(): boolean {\n        return this._multiple;\n    }\n    set multiple(value: boolean) {\n        let newValue = value !== false && <any> value !== 'false';\n        if (newValue != this._multiple) {\n            this._multiple = newValue;\n            this.setDropAreaOptions();\n        }\n    }\n\n    /**\n     * Provides feedback for accepted file types, if supported by the browser. Defaults to `\"*\"`.\n     */\n    @Input() get accept(): string {\n        return this._accept;\n    }\n    set accept(value: string) {\n        let usedValue = value == undefined ? '*' : value;\n        if (usedValue !== this._accept) {\n            this._accept = usedValue;\n            this.inputAccept = usedValue.replace(/,/g, ';');\n            this.setDropAreaOptions();\n        }\n    }\n\n    /**\n     * Button size - \"small\", \"regular\" or \"large\". Forwarded to the Button component.\n     */\n    @Input() get size(): 'small' | 'regular' | 'large' {\n        return this._size;\n    }\n    set size(val: 'small' | 'regular' | 'large') {\n        this._size = val == undefined ? 'regular' : val;\n    }\n\n    /**\n     * Display the button as a flat button or not. Forwarded to the Button component.\n     */\n    @Input() get flat(): boolean {\n        return this._flat;\n    }\n    set flat(val: boolean) {\n        this._flat = val != undefined && val !== false;\n    }\n\n    /**\n     * Sets the type of the button. Forwarded to the Button component.\n     */\n    @Input() type: 'primary' | 'secondary' | 'success' | 'warning' | 'alert' = 'primary';\n\n    /**\n     * Icon button without text. Forwarded to the Button component.\n     */\n    @Input()  get icon(): boolean {\n        return this._icon;\n    }\n    set icon(val: boolean) {\n        this._icon = val !== false && <any> val !== 'false';\n    }\n\n    /**\n     * Triggered when a file / files are selected via the file picker.\n     */\n    @Output() fileSelect = new EventEmitter<File[]>();\n\n    /**\n     * Triggered when a file / files are selected but do not fit the \"accept\" option.\n     */\n    @Output() fileSelectReject = new EventEmitter<File[]>();\n\n\n    inputAccept: string = '*';\n    private _icon: boolean = false;\n    private _size: 'small' | 'regular' | 'large' = 'regular';\n    private _flat = false;\n    private _accept: string = '*';\n    private _disabled = false;\n    private _multiple = true;\n    private _subscriptions: Subscription[] = [];\n\n\n    constructor(@Optional() @Self() public dropArea: FileDropArea,\n                private cd: ChangeDetectorRef) { }\n\n    ngOnInit(): void {\n        if (this.dropArea) {\n            this.setDropAreaOptions();\n            this._subscriptions = [\n                observableMerge(\n                    this.dropArea.pageDragEnter,\n                    this.dropArea.pageDragLeave,\n                    this.dropArea.fileDragEnter,\n                    this.dropArea.fileDragLeave\n                ).subscribe(() => this.cd.markForCheck()),\n\n                this.dropArea.fileDrop.subscribe((files: File[]) => {\n                    this.fileSelect.emit(files);\n                }),\n\n                this.dropArea.fileDropReject.subscribe((files: File[]) => {\n                    this.fileSelectReject.emit(files);\n                })\n            ];\n        }\n    }\n\n    ngOnDestroy(): void {\n        this._subscriptions.forEach(s => s.unsubscribe());\n    }\n\n    onChange(event: Event, input: HTMLInputElement): void {\n        let files = input && input.files;\n        if (files && files.length) {\n            let accepted: File[] = [];\n            let rejected: File[] = [];\n            Array.from(files).forEach(file => {\n                if (matchesMimeType(file.type, this._accept)) {\n                    accepted.push(file);\n                } else {\n                    rejected.push(file);\n                }\n            });\n\n            // Remove the Files from the input\n            input.value = '';\n\n            if (accepted.length > 0) {\n                this.fileSelect.emit(accepted);\n            }\n            if (rejected.length > 0) {\n                this.fileSelectReject.emit(rejected);\n            }\n        }\n    }\n\n    private setDropAreaOptions(): void {\n        if (this.dropArea) {\n            let options: IFileDropAreaOptions = Object.assign({}, this.dropArea.options || {});\n            options.accept = this._accept;\n            options.disabled = this._disabled;\n            options.multiple = this._multiple;\n            this.dropArea.options = options;\n        }\n    }\n}\n","<div class=\"hidden-file-wrapper\">\n    <input type=\"file\" class=\"hidden-file-input\"\n        tabindex=\"-1\"\n        [accept]=\"inputAccept\"\n        [disabled]=\"disabled\"\n        [multiple]=\"multiple\"\n        (change)=\"onChange($event, fileInput)\"\n        #fileInput\n    />\n</div>\n<gtx-button (click)=\"!disabled && fileInput.click()\" [disabled]=\"disabled\"\n            [size]=\"size\" [icon]=\"icon\"\n            [type]=\"dropArea?.pageDragHovered ? 'success' : type\"\n            [flat]=\"flat || dropArea?.dragHovered\">\n    <ng-content></ng-content>\n</gtx-button>\n"]}