UNPKG

ngx-slice-kit

Version:

[![npm version](https://badge.fury.io/js/ngx-slice-kit.svg)](https://badge.fury.io/js/ngx-slice-kit)

224 lines 33.6 kB
import { Component, EventEmitter, forwardRef, HostBinding, Inject, Input, Output, PLATFORM_ID, ViewChild } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { DOCUMENT, isPlatformServer } from '@angular/common'; import * as i0 from "@angular/core"; import * as i1 from "../dropdown.service"; import * as i2 from "../options.service"; import * as i3 from "@angular/common"; import * as i4 from "../../buttons/icon/icon.component"; export class SelectComponent { constructor(document, platformId, dropdownService, optionsService) { this.document = document; this.platformId = platformId; this.dropdownService = dropdownService; this.optionsService = optionsService; this.options = []; this.label = ''; this.placeholder = ''; this.small = false; this.multi = false; this.enableNullValue = false; this.caption = ''; this.focusEvent = new EventEmitter(); this.blurEvent = new EventEmitter(); this.resultEvent = new EventEmitter(); this.error = undefined; } set required(val) { this.req = val === '' || val === true; } get required() { return this.req; } get isDisabled() { return this.disabled; } getOptions() { return [...this.options].map(o => { o.selected = this.multi ? this.currentValues?.has(o) : this.currentValue === o; return o; }); } isInactive() { return this.multi ? !this.currentValues?.size : !this.currentValue; } hasValuesToDrop() { return this.enableNullValue && !this.isInactive(); } onOpen(ev) { this.isOpen = true; this.emitFocus(); } onClose(ev) { this.isOpen = false; this.emitBlur(); } emitBlur() { if (this.focused) { this.focused = false; this.blurEvent.emit(); } } emitFocus() { if (!this.focused) { this.focused = true; this.focusEvent.emit(); } } selected() { if (this.multi) { const selectedOptions = []; this.currentValues?.forEach(o => { selectedOptions.push(o.label); }); return selectedOptions.length ? selectedOptions.join(', ') : ''; } else { return this.currentValue?.label; } } onResult(option) { this.onTouched(); if (this.multi) { this.addValue(option); } else { this.writeValue(option); } } writeValue(val) { if (val?.size > 0) { this.currentValues = val; const multipleResult = this.options.filter(o => this.currentValues.has(o)); this.onChange(multipleResult); this.resultEvent.emit(multipleResult); } else { this.currentValue = val; this.onChange(val); this.resultEvent.emit(this.currentValue); } } addValue(o) { const alreadySelected = this.currentValues.has(o); o.selected = !alreadySelected; alreadySelected ? this.currentValues.delete(o) : this.currentValues.add(o); this.writeValue(this.currentValues); } clearValue(e) { e.stopPropagation(); this.multi ? this.currentValues?.clear() : this.currentValue = undefined; this.writeValue(undefined); } onChange(value) { } onTouched() { } registerOnChange(fn) { this.onChange = fn; } registerOnTouched(fn) { this.onTouched = fn; } setDisabledState(isDisabled) { this.disabled = isDisabled; } showDropdown() { if (isPlatformServer(this.platformId)) { return; } if (this.isOpen) { return; } this.onOpen(); this.optionsService.options = this.getOptions(); const opts = { triggerRect: this.selectElem.nativeElement.getBoundingClientRect(), fitWidth: true, multi: this.multi, parentElem: this.selectElem.nativeElement, }; this.dropdownService.showDropdown(opts).subscribe(res => { this.onClose(); // this.optionsService.options = null; if (res) { this.onResult(res); } }); } ngOnInit() { if (this.multi) { this.enableNullValue = true; this.currentValues = new Set(); } } ngOnDestroy() { this.blurEvent.complete(); this.focusEvent.complete(); this.resultEvent.complete(); } } SelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: SelectComponent, deps: [{ token: DOCUMENT }, { token: PLATFORM_ID }, { token: i1.DropdownService }, { token: i2.OptionsService }], target: i0.ɵɵFactoryTarget.Component }); SelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.3", type: SelectComponent, selector: "sdk-select", inputs: { required: "required", options: "options", label: "label", placeholder: "placeholder", disabled: "disabled", small: "small", multi: "multi", enableNullValue: "enableNullValue", icon: "icon", caption: "caption", error: "error", isDisabled: "isDisabled" }, outputs: { focusEvent: "focusEvent", blurEvent: "blurEvent", resultEvent: "resultEvent" }, host: { properties: { "class.invalid": "this.error", "class.disabled": "this.isDisabled" } }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => SelectComponent), multi: true } ], viewQueries: [{ propertyName: "selectElem", first: true, predicate: ["select"], descendants: true, static: true }], ngImport: i0, template: "<label class=\"sdk-select-label\"\n [class.active]=\"!!(currentValue || currentValues?.size)\"\n [class.small]=\"small\">\n {{label}}\n <span *ngIf=\"required\" class=\"sdk-select-label-required-mark\">&nbsp;*</span>\n</label>\n\n<div class=\"sdk-select\" #select (click)=\"showDropdown()\">\n <div class=\"sdk-select-wrap\" [ngClass]=\"{small: small, active: isOpen, invalid: error}\">\n <span class=\"sdk-select-icon\" *ngIf=\"icon\">\n <sdk-icon [icon]=\"icon\" [size]=\"small ? 16 : 24\"></sdk-icon>\n </span>\n <p class=\"sdk-select-value\" title=\"{{selected()}}\">\n {{selected()}}\n <span class=\"inactive\" *ngIf=\"isInactive()\">{{placeholder}}</span>\n </p>\n <span class=\"sdk-select-icon actions\">\n <ng-container *ngIf=\"!hasValuesToDrop()\">\n <div class=\"interface-icon-wrap icon-chevron\" [class.active]=\"isOpen\">\n <sdk-icon icon=\"chevron_down\" [size]=\"24\" [inline]=\"true\"></sdk-icon>\n </div>\n </ng-container>\n <ng-container *ngIf=\"hasValuesToDrop()\">\n <div class=\"interface-icon-wrap icon-clear\">\n <sdk-icon icon=\"close\" [size]=\"16\" [inline]=\"true\" (click)=\"clearValue($event)\"></sdk-icon>\n </div>\n </ng-container>\n </span>\n </div>\n</div>\n\n<div class=\"sdk-caption\" *ngIf=\"caption\">\n {{caption}}\n</div>\n<div class=\"sdk-error\" *ngIf=\"error\">\n <sdk-icon icon=\"alert\" color=\"var(--warn)\" size=\"12\"></sdk-icon>\n {{error ? error : ''}}\n</div>\n\n\n", styles: [":host{display:flex;min-width:160px;width:100%;flex-direction:column;position:relative}:host.invalid{animation:shake .4s}:host.disabled{opacity:.6;pointer-events:none;cursor:default}.sdk-select-label{color:var(--base-a50);transition:all .2s;font-size:17px;margin-bottom:2px}.sdk-select-label.small{font-size:15px}.sdk-select-label.active{color:var(--base-a90)}.sdk-select-label-required-mark{color:var(--warn)}.sdk-select{position:relative;background-color:var(--background-a90);border-radius:8px;overflow:hidden}.sdk-select-wrap{display:flex;align-items:center;padding:10px 16px;height:44px;cursor:pointer;border-radius:8px;border-color:var(--regular-a50);border-width:1px;border-style:solid}.sdk-select-wrap.invalid{transition:all .2s ease;border-color:var(--warn);background-color:var(--warn-a20-rgb)}.sdk-select-wrap.small{padding:5px 12px;height:32px}.sdk-select-wrap.small .sdk-select-value{font-size:15px}.sdk-select-wrap.small .sdk-select-icon{margin-right:4px}.sdk-select-wrap.active{transition:border-color .2s ease;border-color:var(--regular-a100)}.sdk-select-wrap .sdk-select-icon{margin-right:8px}.sdk-select-wrap .sdk-select-icon.actions{margin-right:0;margin-left:8px}.sdk-select-value{flex-basis:100%;color:var(--base-a90);width:100%;font-size:17px;font-weight:400;line-height:24px;outline:none;border:none;transition:all .4s;font-family:Inter,sans-serif;overflow:hidden;white-space:nowrap;-ms-text-overflow:ellipsis;text-overflow:ellipsis}.sdk-select-value .inactive{color:var(--base-a50)}.interface-icon-wrap{transition:all .2s}.interface-icon-wrap:hover{opacity:.8}.interface-icon-wrap.icon-chevron{height:24px;width:24px}.interface-icon-wrap.active{transform:scaleY(-1)}.interface-icon-wrap.icon-clear{height:16px;width:16px}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.IconComponent, selector: "sdk-icon", inputs: ["icon", "image", "inline", "size", "color"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: SelectComponent, decorators: [{ type: Component, args: [{ selector: 'sdk-select', providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => SelectComponent), multi: true } ], template: "<label class=\"sdk-select-label\"\n [class.active]=\"!!(currentValue || currentValues?.size)\"\n [class.small]=\"small\">\n {{label}}\n <span *ngIf=\"required\" class=\"sdk-select-label-required-mark\">&nbsp;*</span>\n</label>\n\n<div class=\"sdk-select\" #select (click)=\"showDropdown()\">\n <div class=\"sdk-select-wrap\" [ngClass]=\"{small: small, active: isOpen, invalid: error}\">\n <span class=\"sdk-select-icon\" *ngIf=\"icon\">\n <sdk-icon [icon]=\"icon\" [size]=\"small ? 16 : 24\"></sdk-icon>\n </span>\n <p class=\"sdk-select-value\" title=\"{{selected()}}\">\n {{selected()}}\n <span class=\"inactive\" *ngIf=\"isInactive()\">{{placeholder}}</span>\n </p>\n <span class=\"sdk-select-icon actions\">\n <ng-container *ngIf=\"!hasValuesToDrop()\">\n <div class=\"interface-icon-wrap icon-chevron\" [class.active]=\"isOpen\">\n <sdk-icon icon=\"chevron_down\" [size]=\"24\" [inline]=\"true\"></sdk-icon>\n </div>\n </ng-container>\n <ng-container *ngIf=\"hasValuesToDrop()\">\n <div class=\"interface-icon-wrap icon-clear\">\n <sdk-icon icon=\"close\" [size]=\"16\" [inline]=\"true\" (click)=\"clearValue($event)\"></sdk-icon>\n </div>\n </ng-container>\n </span>\n </div>\n</div>\n\n<div class=\"sdk-caption\" *ngIf=\"caption\">\n {{caption}}\n</div>\n<div class=\"sdk-error\" *ngIf=\"error\">\n <sdk-icon icon=\"alert\" color=\"var(--warn)\" size=\"12\"></sdk-icon>\n {{error ? error : ''}}\n</div>\n\n\n", styles: [":host{display:flex;min-width:160px;width:100%;flex-direction:column;position:relative}:host.invalid{animation:shake .4s}:host.disabled{opacity:.6;pointer-events:none;cursor:default}.sdk-select-label{color:var(--base-a50);transition:all .2s;font-size:17px;margin-bottom:2px}.sdk-select-label.small{font-size:15px}.sdk-select-label.active{color:var(--base-a90)}.sdk-select-label-required-mark{color:var(--warn)}.sdk-select{position:relative;background-color:var(--background-a90);border-radius:8px;overflow:hidden}.sdk-select-wrap{display:flex;align-items:center;padding:10px 16px;height:44px;cursor:pointer;border-radius:8px;border-color:var(--regular-a50);border-width:1px;border-style:solid}.sdk-select-wrap.invalid{transition:all .2s ease;border-color:var(--warn);background-color:var(--warn-a20-rgb)}.sdk-select-wrap.small{padding:5px 12px;height:32px}.sdk-select-wrap.small .sdk-select-value{font-size:15px}.sdk-select-wrap.small .sdk-select-icon{margin-right:4px}.sdk-select-wrap.active{transition:border-color .2s ease;border-color:var(--regular-a100)}.sdk-select-wrap .sdk-select-icon{margin-right:8px}.sdk-select-wrap .sdk-select-icon.actions{margin-right:0;margin-left:8px}.sdk-select-value{flex-basis:100%;color:var(--base-a90);width:100%;font-size:17px;font-weight:400;line-height:24px;outline:none;border:none;transition:all .4s;font-family:Inter,sans-serif;overflow:hidden;white-space:nowrap;-ms-text-overflow:ellipsis;text-overflow:ellipsis}.sdk-select-value .inactive{color:var(--base-a50)}.interface-icon-wrap{transition:all .2s}.interface-icon-wrap:hover{opacity:.8}.interface-icon-wrap.icon-chevron{height:24px;width:24px}.interface-icon-wrap.active{transform:scaleY(-1)}.interface-icon-wrap.icon-clear{height:16px;width:16px}\n"] }] }], ctorParameters: function () { return [{ type: undefined, decorators: [{ type: Inject, args: [DOCUMENT] }] }, { type: undefined, decorators: [{ type: Inject, args: [PLATFORM_ID] }] }, { type: i1.DropdownService }, { type: i2.OptionsService }]; }, propDecorators: { required: [{ type: Input }], selectElem: [{ type: ViewChild, args: ['select', { static: true }] }], options: [{ type: Input }], label: [{ type: Input }], placeholder: [{ type: Input }], disabled: [{ type: Input }], small: [{ type: Input }], multi: [{ type: Input }], enableNullValue: [{ type: Input }], icon: [{ type: Input }], caption: [{ type: Input }], focusEvent: [{ type: Output }], blurEvent: [{ type: Output }], resultEvent: [{ type: Output }], error: [{ type: Input }, { type: HostBinding, args: ['class.invalid'] }], isDisabled: [{ type: Input }, { type: HostBinding, args: ['class.disabled'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../libs/ngx-slice-kit/src/lib/dropdowns/select/select.component.ts","../../../../../../libs/ngx-slice-kit/src/lib/dropdowns/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    Inject,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    PLATFORM_ID,\n    ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { DOCUMENT, isPlatformServer } from '@angular/common';\nimport { OptionModel } from '../dropdown-option.model';\nimport { DropdownOptions } from '../dropdown.model';\nimport { DropdownService } from '../dropdown.service';\nimport { OptionsService } from '../options.service';\n\n@Component({\n    selector: 'sdk-select',\n    templateUrl: './select.component.html',\n    styleUrls: ['./select.component.scss'],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => SelectComponent),\n            multi: true\n        }\n    ]\n})\nexport class SelectComponent implements ControlValueAccessor, OnInit, OnDestroy {\n    private req: boolean;\n\n    @Input() public set required(val: any) {\n        this.req = val === '' || val === true;\n    }\n\n    public get required(): any {\n        return this.req;\n    }\n\n    @ViewChild('select', {static: true}) public selectElem: ElementRef;\n\n    @Input() public options: OptionModel[] = [];\n    @Input() public label = '';\n    @Input() public placeholder = '';\n    @Input() public disabled: boolean;\n    @Input() public small: boolean = false;\n    @Input() public multi: boolean = false;\n    @Input() public enableNullValue: boolean = false;\n    @Input() public icon: string;\n    @Input() public caption: string = '';\n\n    @Output() public focusEvent: EventEmitter<any> = new EventEmitter();\n    @Output() public blurEvent: EventEmitter<any> = new EventEmitter();\n    @Output() public resultEvent: EventEmitter<any> = new EventEmitter();\n\n    @Input() @HostBinding('class.invalid')\n    public error: string = undefined;\n\n    @Input() @HostBinding('class.disabled')\n    public get isDisabled(): boolean {\n        return this.disabled;\n    }\n\n    public isOpen: boolean;\n    public focused: boolean;\n    public currentValue: OptionModel;\n    public currentValues: Set<OptionModel>;\n\n    constructor(\n        @Inject(DOCUMENT) private document: any,\n        @Inject(PLATFORM_ID) private platformId: any,\n        private dropdownService: DropdownService,\n        private optionsService: OptionsService,\n    ) {\n    }\n\n    public getOptions(): OptionModel[] {\n        return [...this.options].map(o => {\n            o.selected = this.multi ? this.currentValues?.has(o) : this.currentValue === o;\n            return o;\n        });\n    }\n\n    public isInactive(): boolean {\n        return this.multi ? !this.currentValues?.size : !this.currentValue;\n    }\n\n    public hasValuesToDrop(): boolean {\n        return this.enableNullValue && !this.isInactive();\n    }\n\n    public onOpen(ev?): void {\n        this.isOpen = true;\n        this.emitFocus();\n    }\n\n    public onClose(ev?): void {\n        this.isOpen = false;\n        this.emitBlur();\n    }\n\n    public emitBlur(): void {\n        if (this.focused) {\n            this.focused = false;\n            this.blurEvent.emit();\n        }\n    }\n\n    public emitFocus(): void {\n        if (!this.focused) {\n            this.focused = true;\n            this.focusEvent.emit();\n        }\n    }\n\n    public selected(): string {\n        if (this.multi) {\n            const selectedOptions = [];\n            this.currentValues?.forEach(o => {\n                selectedOptions.push(o.label);\n            });\n            return selectedOptions.length ? selectedOptions.join(', ') : '';\n        } else {\n            return this.currentValue?.label;\n        }\n    }\n\n    public onResult(option: OptionModel): void {\n        this.onTouched();\n        if (this.multi) {\n            this.addValue(option);\n        } else {\n            this.writeValue(option);\n        }\n    }\n\n    public writeValue(val): void {\n        if (val?.size > 0) {\n            this.currentValues = val;\n            const multipleResult = this.options.filter(o => this.currentValues.has(o));\n            this.onChange(multipleResult);\n            this.resultEvent.emit(multipleResult);\n        } else {\n            this.currentValue = val;\n            this.onChange(val);\n            this.resultEvent.emit(this.currentValue);\n        }\n    }\n\n    public addValue(o: OptionModel): void {\n        const alreadySelected = this.currentValues.has(o);\n        o.selected = !alreadySelected;\n        alreadySelected ? this.currentValues.delete(o) : this.currentValues.add(o);\n        this.writeValue(this.currentValues);\n    }\n\n    public clearValue(e): void {\n        e.stopPropagation();\n        this.multi ? this.currentValues?.clear() : this.currentValue = undefined;\n        this.writeValue(undefined);\n    }\n\n    public onChange(value): void {\n    }\n\n    public onTouched(): void {\n    }\n\n    public registerOnChange(fn: any): void {\n        this.onChange = fn;\n    }\n\n    public registerOnTouched(fn: any): void {\n        this.onTouched = fn;\n    }\n\n    public setDisabledState?(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n    }\n\n    public showDropdown(): void {\n        if (isPlatformServer(this.platformId)) {\n            return;\n        }\n\n        if (this.isOpen) {\n            return;\n        }\n        this.onOpen();\n        this.optionsService.options = this.getOptions();\n\n        const opts: DropdownOptions = {\n            triggerRect: this.selectElem.nativeElement.getBoundingClientRect(),\n            fitWidth: true,\n            multi: this.multi,\n            parentElem: this.selectElem.nativeElement,\n        };\n\n        this.dropdownService.showDropdown(opts).subscribe(res => {\n            this.onClose();\n            // this.optionsService.options = null;\n            if (res) {\n                this.onResult(res);\n            }\n        });\n    }\n\n    public ngOnInit(): void {\n        if (this.multi) {\n            this.enableNullValue = true;\n            this.currentValues = new Set<OptionModel>();\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this.blurEvent.complete();\n        this.focusEvent.complete();\n        this.resultEvent.complete();\n    }\n}\n","<label class=\"sdk-select-label\"\n       [class.active]=\"!!(currentValue || currentValues?.size)\"\n       [class.small]=\"small\">\n    {{label}}\n    <span *ngIf=\"required\" class=\"sdk-select-label-required-mark\">&nbsp;*</span>\n</label>\n\n<div class=\"sdk-select\" #select (click)=\"showDropdown()\">\n    <div class=\"sdk-select-wrap\" [ngClass]=\"{small: small, active: isOpen, invalid: error}\">\n        <span class=\"sdk-select-icon\" *ngIf=\"icon\">\n            <sdk-icon [icon]=\"icon\" [size]=\"small ? 16 : 24\"></sdk-icon>\n        </span>\n        <p class=\"sdk-select-value\" title=\"{{selected()}}\">\n            {{selected()}}\n            <span class=\"inactive\" *ngIf=\"isInactive()\">{{placeholder}}</span>\n        </p>\n        <span class=\"sdk-select-icon actions\">\n            <ng-container *ngIf=\"!hasValuesToDrop()\">\n                <div class=\"interface-icon-wrap icon-chevron\" [class.active]=\"isOpen\">\n                    <sdk-icon icon=\"chevron_down\" [size]=\"24\" [inline]=\"true\"></sdk-icon>\n                </div>\n            </ng-container>\n            <ng-container *ngIf=\"hasValuesToDrop()\">\n                <div class=\"interface-icon-wrap icon-clear\">\n                    <sdk-icon icon=\"close\" [size]=\"16\" [inline]=\"true\" (click)=\"clearValue($event)\"></sdk-icon>\n                </div>\n            </ng-container>\n        </span>\n    </div>\n</div>\n\n<div class=\"sdk-caption\" *ngIf=\"caption\">\n    {{caption}}\n</div>\n<div class=\"sdk-error\" *ngIf=\"error\">\n    <sdk-icon icon=\"alert\" color=\"var(--warn)\" size=\"12\"></sdk-icon>\n    {{error ? error : ''}}\n</div>\n\n\n"]}