UNPKG

@taiga-ui/kit

Version:
114 lines • 14.7 kB
import { __decorate, __extends, __param } from "tslib"; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, forwardRef, HostBinding, Inject, Input, Optional, QueryList, Self, ViewChildren, } from '@angular/core'; import { NgControl } from '@angular/forms'; import { AbstractTuiNullableControl, ALWAYS_FALSE_HANDLER, EMPTY_QUERY, isNativeFocusedIn, TUI_DEFAULT_IDENTITY_MATCHER, TUI_FOCUSABLE_ITEM_ACCESSOR, tuiDefaultProp, } from '@taiga-ui/cdk'; import { TuiRadioLabeledComponent } from '@taiga-ui/kit/components/radio-labeled'; var TuiRadioListComponent = /** @class */ (function (_super) { __extends(TuiRadioListComponent, _super); function TuiRadioListComponent(control, changeDetectorRef, elementRef) { var _this = _super.call(this, control, changeDetectorRef) || this; _this.elementRef = elementRef; _this.items = []; _this.size = 'm'; _this.identityMatcher = TUI_DEFAULT_IDENTITY_MATCHER; _this.orientation = "vertical" /* Vertical */; // @bad TODO: Remove & { index: number } _this.itemContent = function (_a) { var $implicit = _a.$implicit; return String($implicit); }; _this.disabledItemHandler = ALWAYS_FALSE_HANDLER; _this.radioButtons = EMPTY_QUERY; return _this; } TuiRadioListComponent_1 = TuiRadioListComponent; Object.defineProperty(TuiRadioListComponent.prototype, "nativeFocusableElement", { get: function () { var focusableRadioButton = this.radioButtons.find(function (radioButton) { return radioButton.nativeFocusableElement !== null; }); return focusableRadioButton ? focusableRadioButton.nativeFocusableElement : null; }, enumerable: true, configurable: true }); Object.defineProperty(TuiRadioListComponent.prototype, "focused", { get: function () { return isNativeFocusedIn(this.elementRef.nativeElement); }, enumerable: true, configurable: true }); TuiRadioListComponent.prototype.computeId = function (index) { return this.id + "-" + index; }; TuiRadioListComponent.prototype.itemIsDisabled = function (item) { return this.disabledItemHandler(item); }; TuiRadioListComponent.prototype.getContentContext = function (item, index, active) { return { $implicit: item, index: index, active: active }; }; TuiRadioListComponent.prototype.onModelChange = function (value) { this.updateValue(value); }; TuiRadioListComponent.prototype.itemIsActive = function (item) { return this.value === null ? item === null : this.identityMatcher(this.value, item); }; var TuiRadioListComponent_1; TuiRadioListComponent.ctorParameters = function () { return [ { type: NgControl, decorators: [{ type: Optional }, { type: Self }, { type: Inject, args: [NgControl,] }] }, { type: ChangeDetectorRef, decorators: [{ type: Inject, args: [ChangeDetectorRef,] }] }, { type: ElementRef, decorators: [{ type: Inject, args: [ElementRef,] }] } ]; }; __decorate([ Input(), tuiDefaultProp() ], TuiRadioListComponent.prototype, "items", void 0); __decorate([ Input(), HostBinding('attr.data-tui-host-size'), tuiDefaultProp() ], TuiRadioListComponent.prototype, "size", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiRadioListComponent.prototype, "identityMatcher", void 0); __decorate([ Input(), HostBinding('attr.data-tui-host-orientation'), tuiDefaultProp() ], TuiRadioListComponent.prototype, "orientation", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiRadioListComponent.prototype, "itemContent", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiRadioListComponent.prototype, "disabledItemHandler", void 0); __decorate([ ViewChildren(TuiRadioLabeledComponent) ], TuiRadioListComponent.prototype, "radioButtons", void 0); TuiRadioListComponent = TuiRadioListComponent_1 = __decorate([ Component({ selector: 'tui-radio-list', template: "<tui-radio-group class=\"group\">\n <tui-radio-labeled\n *ngFor=\"let item of items; index as index\"\n class=\"item\"\n [readOnly]=\"readOnly\"\n [nativeId]=\"computeId(index)\"\n [disabled]=\"disabled\"\n [item]=\"item\"\n [size]=\"size\"\n [pseudoInvalid]=\"computedInvalid\"\n [pseudoDisabled]=\"itemIsDisabled(item)\"\n [ngModel]=\"value\"\n (ngModelChange)=\"onModelChange($event)\"\n >\n <div\n polymorpheus-outlet\n [content]=\"itemContent\"\n [context]=\"getContentContext(item, index, itemIsActive(item))\"\n ></div>\n </tui-radio-labeled>\n</tui-radio-group>\n", changeDetection: ChangeDetectionStrategy.OnPush, providers: [ { provide: TUI_FOCUSABLE_ITEM_ACCESSOR, useExisting: forwardRef(function () { return TuiRadioListComponent_1; }), }, ], styles: [":host{display:block}:host._readonly{pointer-events:none}:host[data-tui-host-orientation=horizontal] .group{display:flex;justify-content:inherit}:host[data-tui-host-orientation=horizontal] .item:nth-child(n+2){margin-left:24px}:host[data-tui-host-orientation=vertical] .item:nth-child(n+2){margin-top:12px}:host[data-tui-host-size='l'][data-tui-host-orientation=horizontal] .item:nth-child(n+2){margin-left:40px}:host[data-tui-host-size='l'][data-tui-host-orientation=vertical] .item:nth-child(n+2){margin-top:16px}"] }), __param(0, Optional()), __param(0, Self()), __param(0, Inject(NgControl)), __param(1, Inject(ChangeDetectorRef)), __param(2, Inject(ElementRef)) ], TuiRadioListComponent); return TuiRadioListComponent; }(AbstractTuiNullableControl)); export { TuiRadioListComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-list.component.js","sourceRoot":"ng://@taiga-ui/kit/components/radio-list/","sources":["radio-list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    forwardRef,\n    HostBinding,\n    Inject,\n    Input,\n    Optional,\n    QueryList,\n    Self,\n    ViewChildren,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {\n    AbstractTuiNullableControl,\n    ALWAYS_FALSE_HANDLER,\n    EMPTY_QUERY,\n    isNativeFocusedIn,\n    TUI_DEFAULT_IDENTITY_MATCHER,\n    TUI_FOCUSABLE_ITEM_ACCESSOR,\n    TuiBooleanHandler,\n    tuiDefaultProp,\n    TuiIdentityMatcher,\n    TuiNativeFocusableElement,\n} from '@taiga-ui/cdk';\nimport {TuiOrientation, TuiSizeL, TuiValueContentContext} from '@taiga-ui/core';\nimport {TuiRadioLabeledComponent} from '@taiga-ui/kit/components/radio-labeled';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\n\n@Component({\n    selector: 'tui-radio-list',\n    templateUrl: './radio-list.template.html',\n    styleUrls: ['./radio-list.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: TUI_FOCUSABLE_ITEM_ACCESSOR,\n            useExisting: forwardRef(() => TuiRadioListComponent),\n        },\n    ],\n})\nexport class TuiRadioListComponent<T> extends AbstractTuiNullableControl<T> {\n    @Input()\n    @tuiDefaultProp()\n    items: ReadonlyArray<T> = [];\n\n    @Input()\n    @HostBinding('attr.data-tui-host-size')\n    @tuiDefaultProp()\n    size: TuiSizeL = 'm';\n\n    @Input()\n    @tuiDefaultProp()\n    identityMatcher: TuiIdentityMatcher<T> = TUI_DEFAULT_IDENTITY_MATCHER;\n\n    @Input()\n    @HostBinding('attr.data-tui-host-orientation')\n    @tuiDefaultProp()\n    orientation: TuiOrientation = TuiOrientation.Vertical;\n\n    // @bad TODO: Remove & { index: number }\n    @Input()\n    @tuiDefaultProp()\n    itemContent: PolymorpheusContent<TuiValueContentContext<T> & {index: number}> = ({\n        $implicit,\n    }) => String($implicit);\n\n    @Input()\n    @tuiDefaultProp()\n    disabledItemHandler: TuiBooleanHandler<T> = ALWAYS_FALSE_HANDLER;\n\n    @ViewChildren(TuiRadioLabeledComponent)\n    private readonly radioButtons: QueryList<TuiRadioLabeledComponent<{}>> = EMPTY_QUERY;\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) changeDetectorRef: ChangeDetectorRef,\n        @Inject(ElementRef) private readonly elementRef: ElementRef<HTMLElement>,\n    ) {\n        super(control, changeDetectorRef);\n    }\n\n    get nativeFocusableElement(): TuiNativeFocusableElement | null {\n        const focusableRadioButton = this.radioButtons.find(\n            radioButton => radioButton.nativeFocusableElement !== null,\n        );\n\n        return focusableRadioButton ? focusableRadioButton.nativeFocusableElement : null;\n    }\n\n    get focused(): boolean {\n        return isNativeFocusedIn(this.elementRef.nativeElement);\n    }\n\n    computeId(index: number): string {\n        return `${this.id}-${index}`;\n    }\n\n    itemIsDisabled(item: T): boolean {\n        return this.disabledItemHandler(item);\n    }\n\n    getContentContext(\n        item: T,\n        index: number,\n        active: boolean,\n    ): TuiValueContentContext<T> & {index: number} {\n        return {$implicit: item, index, active};\n    }\n\n    onModelChange(value: T) {\n        this.updateValue(value);\n    }\n\n    itemIsActive(item: T): boolean {\n        return this.value === null\n            ? item === null\n            : this.identityMatcher(this.value, item);\n    }\n}\n"]}