UNPKG

@taiga-ui/kit

Version:

Taiga UI Angular main components kit

89 lines 21.8 kB
import { NgIf } from '@angular/common'; import { ChangeDetectionStrategy, Component, computed, inject, Input, signal, ViewEncapsulation, } from '@angular/core'; import { FormsModule } from '@angular/forms'; import { MaskitoDirective } from '@maskito/angular'; import { maskitoAddOnFocusPlugin, maskitoPrefixPostprocessorGenerator, maskitoRemoveOnBlurPlugin, } from '@maskito/kit'; import { tuiAsControl, TuiControl } from '@taiga-ui/cdk/classes'; import { tuiFallbackValueProvider } from '@taiga-ui/cdk/tokens'; import { tuiInjectElement } from '@taiga-ui/cdk/utils/dom'; import { tuiDirectiveBinding } from '@taiga-ui/cdk/utils/miscellaneous'; import { TuiTextfieldContent, TuiWithTextfield } from '@taiga-ui/core/components/textfield'; import { TuiIcons } from '@taiga-ui/core/directives/icons'; import { TuiSlider, tuiSliderOptionsProvider } from '@taiga-ui/kit/components/slider'; import { tuiMaskito } from '@taiga-ui/kit/utils'; import { TUI_INPUT_COLOR_OPTIONS } from './input-color.options'; import * as i0 from "@angular/core"; import * as i1 from "@maskito/angular"; import * as i2 from "@taiga-ui/core/components/textfield"; import * as i3 from "@angular/forms"; import * as i4 from "@taiga-ui/kit/components/slider"; const REGEX = /[0-9a-fA-F]/; class TuiInputColor extends TuiControl { constructor() { super(...arguments); this.options = inject(TUI_INPUT_COLOR_OPTIONS); this.el = tuiInjectElement(); this.list = this.el.getAttribute('list'); this.format = signal(this.options.format); this.align = signal(this.options.align); this.icon = tuiDirectiveBinding(TuiIcons, 'iconStart', computed(() => this.align() === 'left' ? '"data:image/svg+xml;utf8,<svg xmlns=http://www.w3.org/2000/svg></svg>"' : ''), {}); this.maskito = tuiMaskito(computed((length = this.format().length * 2) => ({ mask: ['#', ...Array.from({ length }).fill(REGEX)], postprocessors: [maskitoPrefixPostprocessorGenerator('#')], plugins: [maskitoAddOnFocusPlugin('#'), maskitoRemoveOnBlurPlugin('#')], overwriteMode: 'replace', }))); this.filled = computed(() => this.format() === 'hex' ? this.value().length === 7 : this.value().length === 9); this.opacity = computed(() => this.filled() && this.format() === 'hexa' ? Number.parseInt(this.value().slice(-2), 16) : 255); } set alignSetter(align) { this.align.set(align); } set formatSetter(mode) { this.format.set(mode); } onInput(value) { this.onChange(this.format() === 'hex' ? value : `${value}${toHex(this.opacity())}`); } onOpacity(opacity) { const value = this.filled() ? this.value().slice(0, 7) : '#000000'; this.onChange(`${value}${toHex(opacity)}`); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputColor, deps: null, target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputColor, isStandalone: true, selector: "input[tuiInputColor]", inputs: { alignSetter: ["align", "alignSetter"], formatSetter: ["format", "formatSetter"] }, host: { attributes: { "ngSkipHydration": "true", "inputmode": "numeric", "spellcheck": "false" }, listeners: { "input": "onChange($event.target.value)" }, properties: { "disabled": "disabled()", "value": "value()", "attr.list": "null" } }, providers: [ tuiAsControl(TuiInputColor), tuiFallbackValueProvider(''), tuiSliderOptionsProvider({ trackColor: 'transparent' }), ], usesInheritance: true, hostDirectives: [{ directive: i1.MaskitoDirective }, { directive: i2.TuiWithTextfield }], ngImport: i0, template: "<ng-container *tuiTextfieldContent>\n <input\n #input\n tabindex=\"-1\"\n type=\"color\"\n class=\"tui-input-color_picker\"\n [attr.list]=\"list\"\n [class.tui-input-color_left]=\"align() === 'left'\"\n [disabled]=\"!interactive()\"\n [style.--t-opacity]=\"filled() ? opacity() / 255 : 0\"\n [value]=\"value().length > 6 ? value().slice(0, 7) : ''\"\n (input)=\"onInput(input.value)\"\n />\n <input\n *ngIf=\"format() === 'hexa' && interactive()\"\n max=\"255\"\n tuiSlider\n type=\"range\"\n [ngModel]=\"opacity()\"\n [ngModelOptions]=\"{standalone: true}\"\n (ngModelChange)=\"onOpacity($event)\"\n (pointerdown.stop)=\"el.focus()\"\n />\n</ng-container>\n", styles: [".tui-input-color_picker.tui-input-color_picker{position:relative;font-size:1rem;inline-size:calc(var(--t-height) / 2);block-size:calc(var(--t-height) / 2);border:none;border-radius:100%;padding:0!important;overflow:hidden;cursor:pointer;background:repeating-conic-gradient(var(--tui-border-normal) 0% 25%,transparent 0% 50%);box-shadow:0 0 0 1px var(--tui-border-normal)}.tui-input-color_picker.tui-input-color_picker:disabled{cursor:default}tui-textfield[data-size=s] .tui-input-color_picker{margin-inline-end:.25rem}tui-textfield[data-size=l] .tui-input-color_picker{margin-inline-end:-.25rem}.tui-input-color_picker.tui-input-color_left{position:absolute;top:50%;left:calc(var(--t-height) / 4);inset-inline-start:calc(var(--t-height) / 4);transform:translateY(-50%)}.tui-input-color_picker::-webkit-color-swatch-wrapper{padding:0}.tui-input-color_picker::-webkit-color-swatch{border:none;opacity:var(--t-opacity)}.tui-input-color_picker::-moz-color-swatch{border:none;opacity:var(--t-opacity)}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.RangeValueAccessor, selector: "input[type=range][formControlName],input[type=range][formControl],input[type=range][ngModel]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.TuiSliderComponent, selector: "input[type=range][tuiSlider]", inputs: ["size", "segments"] }, { kind: "directive", type: TuiTextfieldContent, selector: "ng-template[tuiTextfieldContent]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); } } export { TuiInputColor }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputColor, decorators: [{ type: Component, args: [{ standalone: true, selector: 'input[tuiInputColor]', imports: [FormsModule, NgIf, TuiSlider, TuiTextfieldContent], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [ tuiAsControl(TuiInputColor), tuiFallbackValueProvider(''), tuiSliderOptionsProvider({ trackColor: 'transparent' }), ], hostDirectives: [MaskitoDirective, TuiWithTextfield], host: { ngSkipHydration: 'true', inputmode: 'numeric', spellcheck: 'false', '[disabled]': 'disabled()', '[value]': 'value()', '[attr.list]': 'null', '(input)': 'onChange($event.target.value)', }, template: "<ng-container *tuiTextfieldContent>\n <input\n #input\n tabindex=\"-1\"\n type=\"color\"\n class=\"tui-input-color_picker\"\n [attr.list]=\"list\"\n [class.tui-input-color_left]=\"align() === 'left'\"\n [disabled]=\"!interactive()\"\n [style.--t-opacity]=\"filled() ? opacity() / 255 : 0\"\n [value]=\"value().length > 6 ? value().slice(0, 7) : ''\"\n (input)=\"onInput(input.value)\"\n />\n <input\n *ngIf=\"format() === 'hexa' && interactive()\"\n max=\"255\"\n tuiSlider\n type=\"range\"\n [ngModel]=\"opacity()\"\n [ngModelOptions]=\"{standalone: true}\"\n (ngModelChange)=\"onOpacity($event)\"\n (pointerdown.stop)=\"el.focus()\"\n />\n</ng-container>\n", styles: [".tui-input-color_picker.tui-input-color_picker{position:relative;font-size:1rem;inline-size:calc(var(--t-height) / 2);block-size:calc(var(--t-height) / 2);border:none;border-radius:100%;padding:0!important;overflow:hidden;cursor:pointer;background:repeating-conic-gradient(var(--tui-border-normal) 0% 25%,transparent 0% 50%);box-shadow:0 0 0 1px var(--tui-border-normal)}.tui-input-color_picker.tui-input-color_picker:disabled{cursor:default}tui-textfield[data-size=s] .tui-input-color_picker{margin-inline-end:.25rem}tui-textfield[data-size=l] .tui-input-color_picker{margin-inline-end:-.25rem}.tui-input-color_picker.tui-input-color_left{position:absolute;top:50%;left:calc(var(--t-height) / 4);inset-inline-start:calc(var(--t-height) / 4);transform:translateY(-50%)}.tui-input-color_picker::-webkit-color-swatch-wrapper{padding:0}.tui-input-color_picker::-webkit-color-swatch{border:none;opacity:var(--t-opacity)}.tui-input-color_picker::-moz-color-swatch{border:none;opacity:var(--t-opacity)}\n"] }] }], propDecorators: { alignSetter: [{ type: Input, args: ['align'] }], formatSetter: [{ type: Input, args: ['format'] }] } }); function toHex(value) { return value.toString(16).padStart(2, '0'); } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-color.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-color/input-color.component.ts","../../../../../projects/kit/components/input-color/input-color.template.html"],"names":[],"mappings":"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","sourcesContent":["import {NgIf} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    inject,\n    Input,\n    signal,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {FormsModule} from '@angular/forms';\nimport {MaskitoDirective} from '@maskito/angular';\nimport {\n    maskitoAddOnFocusPlugin,\n    maskitoPrefixPostprocessorGenerator,\n    maskitoRemoveOnBlurPlugin,\n} from '@maskito/kit';\nimport {tuiAsControl, TuiControl} from '@taiga-ui/cdk/classes';\nimport {tuiFallbackValueProvider} from '@taiga-ui/cdk/tokens';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiDirectiveBinding} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TuiTextfieldContent, TuiWithTextfield} from '@taiga-ui/core/components/textfield';\nimport {TuiIcons} from '@taiga-ui/core/directives/icons';\nimport {type TuiHorizontalDirection} from '@taiga-ui/core/types';\nimport {TuiSlider, tuiSliderOptionsProvider} from '@taiga-ui/kit/components/slider';\nimport {tuiMaskito} from '@taiga-ui/kit/utils';\n\nimport {TUI_INPUT_COLOR_OPTIONS, type TuiInputColorOptions} from './input-color.options';\n\nconst REGEX = /[0-9a-fA-F]/;\n\n@Component({\n    standalone: true,\n    selector: 'input[tuiInputColor]',\n    imports: [FormsModule, NgIf, TuiSlider, TuiTextfieldContent],\n    templateUrl: './input-color.template.html',\n    styleUrls: ['./input-color.style.less'],\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsControl(TuiInputColor),\n        tuiFallbackValueProvider(''),\n        tuiSliderOptionsProvider({trackColor: 'transparent'}),\n    ],\n    hostDirectives: [MaskitoDirective, TuiWithTextfield],\n    host: {\n        ngSkipHydration: 'true',\n        inputmode: 'numeric',\n        spellcheck: 'false',\n        '[disabled]': 'disabled()',\n        '[value]': 'value()',\n        '[attr.list]': 'null',\n        '(input)': 'onChange($event.target.value)',\n    },\n})\nexport class TuiInputColor extends TuiControl<string> {\n    protected readonly options = inject(TUI_INPUT_COLOR_OPTIONS);\n    protected readonly el = tuiInjectElement<HTMLInputElement>();\n    protected readonly list = this.el.getAttribute('list');\n    protected readonly format = signal(this.options.format);\n    protected readonly align = signal<TuiHorizontalDirection>(this.options.align);\n\n    protected readonly icon = tuiDirectiveBinding(\n        TuiIcons,\n        'iconStart',\n        computed(() =>\n            this.align() === 'left'\n                ? '\"data:image/svg+xml;utf8,<svg xmlns=http://www.w3.org/2000/svg></svg>\"'\n                : '',\n        ),\n        {},\n    );\n\n    protected readonly maskito = tuiMaskito(\n        computed((length = this.format().length * 2) => ({\n            mask: ['#', ...Array.from<RegExp>({length}).fill(REGEX)],\n            postprocessors: [maskitoPrefixPostprocessorGenerator('#')],\n            plugins: [maskitoAddOnFocusPlugin('#'), maskitoRemoveOnBlurPlugin('#')],\n            overwriteMode: 'replace',\n        })),\n    );\n\n    protected readonly filled = computed(() =>\n        this.format() === 'hex' ? this.value().length === 7 : this.value().length === 9,\n    );\n\n    protected readonly opacity = computed(() =>\n        this.filled() && this.format() === 'hexa'\n            ? Number.parseInt(this.value().slice(-2), 16)\n            : 255,\n    );\n\n    @Input('align')\n    public set alignSetter(align: TuiInputColorOptions['align']) {\n        this.align.set(align);\n    }\n\n    @Input('format')\n    public set formatSetter(mode: TuiInputColorOptions['format']) {\n        this.format.set(mode);\n    }\n\n    protected onInput(value: string): void {\n        this.onChange(\n            this.format() === 'hex' ? value : `${value}${toHex(this.opacity())}`,\n        );\n    }\n\n    protected onOpacity(opacity: number): void {\n        const value = this.filled() ? this.value().slice(0, 7) : '#000000';\n\n        this.onChange(`${value}${toHex(opacity)}`);\n    }\n}\n\nfunction toHex(value: number): string {\n    return value.toString(16).padStart(2, '0');\n}\n","<ng-container *tuiTextfieldContent>\n    <input\n        #input\n        tabindex=\"-1\"\n        type=\"color\"\n        class=\"tui-input-color_picker\"\n        [attr.list]=\"list\"\n        [class.tui-input-color_left]=\"align() === 'left'\"\n        [disabled]=\"!interactive()\"\n        [style.--t-opacity]=\"filled() ? opacity() / 255 : 0\"\n        [value]=\"value().length > 6 ? value().slice(0, 7) : ''\"\n        (input)=\"onInput(input.value)\"\n    />\n    <input\n        *ngIf=\"format() === 'hexa' && interactive()\"\n        max=\"255\"\n        tuiSlider\n        type=\"range\"\n        [ngModel]=\"opacity()\"\n        [ngModelOptions]=\"{standalone: true}\"\n        (ngModelChange)=\"onOpacity($event)\"\n        (pointerdown.stop)=\"el.focus()\"\n    />\n</ng-container>\n"]}