UNPKG

@taiga-ui/kit

Version:

Taiga UI Angular main components kit

71 lines 16.2 kB
import { NgForOf } from '@angular/common'; import { ChangeDetectionStrategy, Component, computed, inject, Input, ViewChildren, ViewEncapsulation, } from '@angular/core'; import { FormsModule, NgControl, Validators } from '@angular/forms'; import { tuiAsControl, TuiControl } from '@taiga-ui/cdk/classes'; import { EMPTY_QUERY, TUI_DEFAULT_IDENTITY_MATCHER, TUI_FALSE_HANDLER, } from '@taiga-ui/cdk/constants'; import { TuiValidator } from '@taiga-ui/cdk/directives/validator'; import { TuiIdService } from '@taiga-ui/cdk/services'; import { TuiRadio } from '@taiga-ui/kit/components/radio'; import { PolymorpheusOutlet, PolymorpheusTemplate } from '@taiga-ui/polymorpheus'; import * as i0 from "@angular/core"; import * as i1 from "@angular/forms"; import * as i2 from "@taiga-ui/kit/components/radio"; const ERROR = () => ({ error: 'Invalid' }); class TuiRadioList extends TuiControl { constructor() { super(...arguments); this.controls = EMPTY_QUERY; this.id = inject(TuiIdService).generate(); this.validator = computed(() => this.invalid() ? ERROR : Validators.nullValidator); this.items = []; this.size = 'm'; this.identityMatcher = TUI_DEFAULT_IDENTITY_MATCHER; this.disabledItemHandler = TUI_FALSE_HANDLER; this.itemContent = ({ $implicit }) => String($implicit); } get name() { return `${this.control.name}-${this.id}`; } onFocusOut() { this.controls.forEach((control) => control.control?.markAsTouched()); if (!this.touched()) { this.onTouched(); } } itemIsActive(item) { return this.value() === null ? item === null : this.identityMatcher(this.value(), item); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiRadioList, deps: null, target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiRadioList, isStandalone: true, selector: "tui-radio-list", inputs: { items: "items", size: "size", identityMatcher: "identityMatcher", disabledItemHandler: "disabledItemHandler", itemContent: "itemContent" }, host: { listeners: { "focusout": "onFocusOut()" }, properties: { "attr.data-size": "size" } }, providers: [tuiAsControl(TuiRadioList)], viewQueries: [{ propertyName: "controls", predicate: NgControl, descendants: true }], usesInheritance: true, ngImport: i0, template: "<label\n *ngFor=\"let item of items; index as index\"\n class=\"t-item\"\n [class.t-item_disabled]=\"disabled() || disabledItemHandler(item)\"\n>\n <input\n tuiRadio\n type=\"radio\"\n [disabled]=\"disabled() || disabledItemHandler(item)\"\n [identityMatcher]=\"identityMatcher\"\n [name]=\"name\"\n [ngModel]=\"value()\"\n [ngModelOptions]=\"{standalone: true}\"\n [size]=\"size\"\n [tuiValidator]=\"validator()\"\n [value]=\"item\"\n (ngModelChange)=\"onChange($event)\"\n />\n <ng-container *polymorpheusOutlet=\"itemContent as text; context: {$implicit: item, active: itemIsActive(item)}\">\n {{ text }}\n </ng-container>\n</label>\n", styles: ["tui-radio-list{display:flex;flex-direction:column;align-items:flex-start;gap:.75rem 1.5rem;font:var(--tui-font-text-m)}tui-radio-list[data-size=s],tui-radio-list[data-size=s] [tuiTitle]{font:var(--tui-font-text-ui-s)}tui-radio-list[data-size=s] [tuiSubtitle],tui-radio-list[data-size=s] [tuiTitle] [tuiSubtitle]{font:var(--tui-font-text-xs)}tui-radio-list[data-size=s]>.t-item,tui-radio-list[data-size=s] [tuiTitle]>.t-item{gap:.5rem}tui-radio-list [tuiTitle]{font:var(--tui-font-text-m)}tui-radio-list [tuiSubtitle]{color:var(--tui-text-tertiary)}tui-radio-list>.t-item{display:flex;gap:.75rem}tui-radio-list>.t-item_disabled{opacity:var(--tui-disabled-opacity)}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.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: i1.RadioControlValueAccessor, selector: "input[type=radio][formControlName],input[type=radio][formControl],input[type=radio][ngModel]", inputs: ["name", "formControlName", "value"] }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: PolymorpheusOutlet, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { kind: "component", type: i2.TuiRadioComponent, selector: "input[type=\"radio\"][tuiRadio]", inputs: ["size"] }, { kind: "directive", type: i2.TuiRadioDirective, selector: "input[type=\"radio\"][tuiRadio][identityMatcher]", inputs: ["identityMatcher"] }, { kind: "directive", type: TuiValidator, selector: "[tuiValidator]", inputs: ["tuiValidator"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); } } export { TuiRadioList }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiRadioList, decorators: [{ type: Component, args: [{ standalone: true, selector: 'tui-radio-list', imports: [ FormsModule, NgForOf, PolymorpheusOutlet, PolymorpheusTemplate, TuiRadio, TuiValidator, ], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [tuiAsControl(TuiRadioList)], host: { '[attr.data-size]': 'size', '(focusout)': 'onFocusOut()', }, template: "<label\n *ngFor=\"let item of items; index as index\"\n class=\"t-item\"\n [class.t-item_disabled]=\"disabled() || disabledItemHandler(item)\"\n>\n <input\n tuiRadio\n type=\"radio\"\n [disabled]=\"disabled() || disabledItemHandler(item)\"\n [identityMatcher]=\"identityMatcher\"\n [name]=\"name\"\n [ngModel]=\"value()\"\n [ngModelOptions]=\"{standalone: true}\"\n [size]=\"size\"\n [tuiValidator]=\"validator()\"\n [value]=\"item\"\n (ngModelChange)=\"onChange($event)\"\n />\n <ng-container *polymorpheusOutlet=\"itemContent as text; context: {$implicit: item, active: itemIsActive(item)}\">\n {{ text }}\n </ng-container>\n</label>\n", styles: ["tui-radio-list{display:flex;flex-direction:column;align-items:flex-start;gap:.75rem 1.5rem;font:var(--tui-font-text-m)}tui-radio-list[data-size=s],tui-radio-list[data-size=s] [tuiTitle]{font:var(--tui-font-text-ui-s)}tui-radio-list[data-size=s] [tuiSubtitle],tui-radio-list[data-size=s] [tuiTitle] [tuiSubtitle]{font:var(--tui-font-text-xs)}tui-radio-list[data-size=s]>.t-item,tui-radio-list[data-size=s] [tuiTitle]>.t-item{gap:.5rem}tui-radio-list [tuiTitle]{font:var(--tui-font-text-m)}tui-radio-list [tuiSubtitle]{color:var(--tui-text-tertiary)}tui-radio-list>.t-item{display:flex;gap:.75rem}tui-radio-list>.t-item_disabled{opacity:var(--tui-disabled-opacity)}\n"] }] }], propDecorators: { controls: [{ type: ViewChildren, args: [NgControl] }], items: [{ type: Input }], size: [{ type: Input }], identityMatcher: [{ type: Input }], disabledItemHandler: [{ type: Input }], itemContent: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-list.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/radio-list/radio-list.component.ts","../../../../../projects/kit/components/radio-list/radio-list.template.html"],"names":[],"mappings":"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","sourcesContent":["import {NgForOf} from '@angular/common';\nimport type {QueryList} from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    inject,\n    Input,\n    ViewChildren,\n    ViewEncapsulation,\n} from '@angular/core';\nimport type {ValidatorFn} from '@angular/forms';\nimport {FormsModule, NgControl, Validators} from '@angular/forms';\nimport {tuiAsControl, TuiControl} from '@taiga-ui/cdk/classes';\nimport {\n    EMPTY_QUERY,\n    TUI_DEFAULT_IDENTITY_MATCHER,\n    TUI_FALSE_HANDLER,\n} from '@taiga-ui/cdk/constants';\nimport {TuiValidator} from '@taiga-ui/cdk/directives/validator';\nimport {TuiIdService} from '@taiga-ui/cdk/services';\nimport type {TuiBooleanHandler, TuiIdentityMatcher} from '@taiga-ui/cdk/types';\nimport type {TuiSizeS, TuiValueContentContext} from '@taiga-ui/core/types';\nimport {TuiRadio} from '@taiga-ui/kit/components/radio';\nimport type {PolymorpheusContent} from '@taiga-ui/polymorpheus';\nimport {PolymorpheusOutlet, PolymorpheusTemplate} from '@taiga-ui/polymorpheus';\n\nconst ERROR: ValidatorFn = () => ({error: 'Invalid'});\n\n@Component({\n    standalone: true,\n    selector: 'tui-radio-list',\n    imports: [\n        FormsModule,\n        NgForOf,\n        PolymorpheusOutlet,\n        PolymorpheusTemplate,\n        TuiRadio,\n        TuiValidator,\n    ],\n    templateUrl: './radio-list.template.html',\n    styleUrls: ['./radio-list.style.less'],\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [tuiAsControl(TuiRadioList)],\n    host: {\n        '[attr.data-size]': 'size',\n        '(focusout)': 'onFocusOut()',\n    },\n})\nexport class TuiRadioList<T> extends TuiControl<T> {\n    @ViewChildren(NgControl)\n    private readonly controls: QueryList<NgControl> = EMPTY_QUERY;\n\n    private readonly id = inject(TuiIdService).generate();\n\n    protected validator = computed(() =>\n        this.invalid() ? ERROR : Validators.nullValidator,\n    );\n\n    @Input()\n    public items: readonly T[] = [];\n\n    @Input()\n    public size: TuiSizeS = 'm';\n\n    @Input()\n    public identityMatcher: TuiIdentityMatcher<T> = TUI_DEFAULT_IDENTITY_MATCHER;\n\n    @Input()\n    public disabledItemHandler: TuiBooleanHandler<T> = TUI_FALSE_HANDLER;\n\n    @Input()\n    public itemContent: PolymorpheusContent<TuiValueContentContext<T>> = ({$implicit}) =>\n        String($implicit);\n\n    protected get name(): string {\n        return `${this.control.name}-${this.id}`;\n    }\n\n    protected onFocusOut(): void {\n        this.controls.forEach((control) => control.control?.markAsTouched());\n\n        if (!this.touched()) {\n            this.onTouched();\n        }\n    }\n\n    protected itemIsActive(item: T): boolean {\n        return this.value() === null\n            ? item === null\n            : this.identityMatcher(this.value(), item);\n    }\n}\n","<label\n    *ngFor=\"let item of items; index as index\"\n    class=\"t-item\"\n    [class.t-item_disabled]=\"disabled() || disabledItemHandler(item)\"\n>\n    <input\n        tuiRadio\n        type=\"radio\"\n        [disabled]=\"disabled() || disabledItemHandler(item)\"\n        [identityMatcher]=\"identityMatcher\"\n        [name]=\"name\"\n        [ngModel]=\"value()\"\n        [ngModelOptions]=\"{standalone: true}\"\n        [size]=\"size\"\n        [tuiValidator]=\"validator()\"\n        [value]=\"item\"\n        (ngModelChange)=\"onChange($event)\"\n    />\n    <ng-container *polymorpheusOutlet=\"itemContent as text; context: {$implicit: item, active: itemIsActive(item)}\">\n        {{ text }}\n    </ng-container>\n</label>\n"]}