UNPKG

@taiga-ui/layout

Version:

A package with Taiga UI layout components

97 lines 15.4 kB
import { ChangeDetectionStrategy, Component, inject, TemplateRef, ViewChild, } from '@angular/core'; import { TuiActiveZone } from '@taiga-ui/cdk/directives/active-zone'; import { TuiAnimated } from '@taiga-ui/cdk/directives/animated'; import { tuiIsHTMLElement } from '@taiga-ui/cdk/utils/dom'; import { tuiButtonOptionsProvider } from '@taiga-ui/core/components/button'; import { TuiScrollbar } from '@taiga-ui/core/components/scrollbar'; import { TUI_DROPDOWN_COMPONENT, tuiDropdown, TuiDropdownDirective, TuiDropdownOpen, TuiWithDropdownOpen, } from '@taiga-ui/core/directives/dropdown'; import { TuiIcons } from '@taiga-ui/core/directives/icons'; import { TUI_ANIMATIONS_SPEED, TUI_COMMON_ICONS, TUI_ICON_END, } from '@taiga-ui/core/tokens'; import { tuiToAnimationOptions } from '@taiga-ui/core/utils/miscellaneous'; import { TUI_LAYOUT_ICONS } from '@taiga-ui/layout/tokens'; import { PolymorpheusOutlet } from '@taiga-ui/polymorpheus'; import * as i0 from "@angular/core"; import * as i1 from "@taiga-ui/cdk/directives/active-zone"; import * as i2 from "@taiga-ui/cdk/directives/animated"; import * as i3 from "@taiga-ui/core/directives/dropdown"; class TuiDrawerComponent { constructor() { this.directive = inject(TuiDropdownDirective); this.animation = tuiToAnimationOptions(inject(TUI_ANIMATIONS_SPEED)); this.top = tuiIsHTMLElement(this.directive.el.offsetParent) && tuiIsHTMLElement(this.directive.el.offsetParent.offsetParent) ? this.directive.el.offsetParent.getBoundingClientRect().bottom - Math.max(this.directive.el.offsetParent.offsetParent.getBoundingClientRect().top, 0) : 0; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiDrawerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiDrawerComponent, isStandalone: true, selector: "ng-component", host: { attributes: { "tuiTheme": "dark" }, properties: { "style.top.px": "top" } }, hostDirectives: [{ directive: i1.TuiActiveZone }, { directive: i2.TuiAnimated }], ngImport: i0, template: ` <tui-scrollbar [style.height.%]="100"> <ng-container *polymorpheusOutlet="directive.content" /> </tui-scrollbar> `, isInline: true, styles: [":host{position:fixed;left:0;right:0;bottom:0;background:var(--tui-theme-color, #000);inline-size:14.375rem;color:var(--tui-text-primary);pointer-events:auto;--tui-from: translateX(-100%)}:host.tui-enter,:host.tui-leave{animation-name:tuiSlide}:host ::ng-deep tui-data-list [tuiOption]{justify-content:flex-start;gap:.75rem;margin:0;font:var(--tui-font-text-ui-s);font-weight:700}:host ::ng-deep tui-data-list tui-opt-group:before{font:var(--tui-font-text-xs);text-transform:uppercase;color:var(--tui-text-tertiary)}\n"], dependencies: [{ kind: "directive", type: PolymorpheusOutlet, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { kind: "component", type: TuiScrollbar, selector: "tui-scrollbar", inputs: ["hidden"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiDrawerComponent, decorators: [{ type: Component, args: [{ standalone: true, imports: [PolymorpheusOutlet, TuiScrollbar], template: ` <tui-scrollbar [style.height.%]="100"> <ng-container *polymorpheusOutlet="directive.content" /> </tui-scrollbar> `, changeDetection: ChangeDetectionStrategy.OnPush, hostDirectives: [TuiActiveZone, TuiAnimated], host: { tuiTheme: 'dark', '[style.top.px]': 'top', }, styles: [":host{position:fixed;left:0;right:0;bottom:0;background:var(--tui-theme-color, #000);inline-size:14.375rem;color:var(--tui-text-primary);pointer-events:auto;--tui-from: translateX(-100%)}:host.tui-enter,:host.tui-leave{animation-name:tuiSlide}:host ::ng-deep tui-data-list [tuiOption]{justify-content:flex-start;gap:.75rem;margin:0;font:var(--tui-font-text-ui-s);font-weight:700}:host ::ng-deep tui-data-list tui-opt-group:before{font:var(--tui-font-text-xs);text-transform:uppercase;color:var(--tui-text-tertiary)}\n"] }] }] }); class TuiDrawerDirective { constructor() { this.x = inject(TUI_COMMON_ICONS).close; this.icons = inject(TuiIcons); this.dropdown = tuiDropdown(null); this.open = inject(TuiDropdownOpen); } ngDoCheck() { this.icons.iconStart.set(this.open.tuiDropdownOpen ? this.x : ''); } set template(template) { this.dropdown.set(template); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiDrawerDirective, deps: [], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiDrawerDirective, isStandalone: true, selector: "[tuiIconButton][tuiNavigationDrawer]", providers: [ tuiButtonOptionsProvider({ appearance: 'secondary-grayscale' }), { provide: TUI_ICON_END, useFactory: () => inject(TUI_LAYOUT_ICONS).grid, }, { provide: TUI_DROPDOWN_COMPONENT, useValue: TuiDrawerComponent, }, ], viewQueries: [{ propertyName: "template", first: true, predicate: TemplateRef, descendants: true }], hostDirectives: [{ directive: i3.TuiDropdownDirective }, { directive: i3.TuiWithDropdownOpen }], ngImport: i0, template: '<ng-template><ng-content /></ng-template>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); } } export { TuiDrawerDirective }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiDrawerDirective, decorators: [{ type: Component, args: [{ standalone: true, // TODO: move to host directives selector: '[tuiIconButton][tuiNavigationDrawer]', template: '<ng-template><ng-content /></ng-template>', changeDetection: ChangeDetectionStrategy.OnPush, providers: [ tuiButtonOptionsProvider({ appearance: 'secondary-grayscale' }), { provide: TUI_ICON_END, useFactory: () => inject(TUI_LAYOUT_ICONS).grid, }, { provide: TUI_DROPDOWN_COMPONENT, useValue: TuiDrawerComponent, }, ], hostDirectives: [TuiDropdownDirective, TuiWithDropdownOpen], }] }], propDecorators: { template: [{ type: ViewChild, args: [TemplateRef] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer.component.js","sourceRoot":"","sources":["../../../../../projects/layout/components/navigation/drawer.component.ts"],"names":[],"mappings":"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","sourcesContent":["import type {DoCheck} from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    inject,\n    TemplateRef,\n    ViewChild,\n} from '@angular/core';\nimport {TuiActiveZone} from '@taiga-ui/cdk/directives/active-zone';\nimport {TuiAnimated} from '@taiga-ui/cdk/directives/animated';\nimport {tuiIsHTMLElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiButtonOptionsProvider} from '@taiga-ui/core/components/button';\nimport {TuiScrollbar} from '@taiga-ui/core/components/scrollbar';\nimport {\n    TUI_DROPDOWN_COMPONENT,\n    tuiDropdown,\n    TuiDropdownDirective,\n    TuiDropdownOpen,\n    TuiWithDropdownOpen,\n} from '@taiga-ui/core/directives/dropdown';\nimport {TuiIcons} from '@taiga-ui/core/directives/icons';\nimport {\n    TUI_ANIMATIONS_SPEED,\n    TUI_COMMON_ICONS,\n    TUI_ICON_END,\n} from '@taiga-ui/core/tokens';\nimport {tuiToAnimationOptions} from '@taiga-ui/core/utils/miscellaneous';\nimport {TUI_LAYOUT_ICONS} from '@taiga-ui/layout/tokens';\nimport type {PolymorpheusContent} from '@taiga-ui/polymorpheus';\nimport {PolymorpheusOutlet} from '@taiga-ui/polymorpheus';\n\n@Component({\n    standalone: true,\n    imports: [PolymorpheusOutlet, TuiScrollbar],\n    template: `\n        <tui-scrollbar [style.height.%]=\"100\">\n            <ng-container *polymorpheusOutlet=\"directive.content\" />\n        </tui-scrollbar>\n    `,\n    styleUrls: ['./drawer.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    hostDirectives: [TuiActiveZone, TuiAnimated],\n    host: {\n        tuiTheme: 'dark',\n        '[style.top.px]': 'top',\n    },\n})\nclass TuiDrawerComponent {\n    protected readonly directive = inject(TuiDropdownDirective);\n    protected readonly animation = tuiToAnimationOptions(inject(TUI_ANIMATIONS_SPEED));\n    protected readonly top =\n        tuiIsHTMLElement(this.directive.el.offsetParent) &&\n        tuiIsHTMLElement(this.directive.el.offsetParent.offsetParent)\n            ? this.directive.el.offsetParent.getBoundingClientRect().bottom -\n              Math.max(\n                  this.directive.el.offsetParent.offsetParent.getBoundingClientRect().top,\n                  0,\n              )\n            : 0;\n}\n\n@Component({\n    standalone: true,\n    // TODO: move to host directives\n    selector: '[tuiIconButton][tuiNavigationDrawer]',\n    template: '<ng-template><ng-content /></ng-template>',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiButtonOptionsProvider({appearance: 'secondary-grayscale'}),\n        {\n            provide: TUI_ICON_END,\n            useFactory: () => inject(TUI_LAYOUT_ICONS).grid,\n        },\n        {\n            provide: TUI_DROPDOWN_COMPONENT,\n            useValue: TuiDrawerComponent,\n        },\n    ],\n    hostDirectives: [TuiDropdownDirective, TuiWithDropdownOpen],\n})\nexport class TuiDrawerDirective implements DoCheck {\n    private readonly x = inject(TUI_COMMON_ICONS).close;\n    private readonly icons = inject(TuiIcons);\n    private readonly dropdown = tuiDropdown(null);\n    private readonly open = inject(TuiDropdownOpen);\n\n    public ngDoCheck(): void {\n        this.icons.iconStart.set(this.open.tuiDropdownOpen ? this.x : '');\n    }\n\n    @ViewChild(TemplateRef)\n    protected set template(template: PolymorpheusContent) {\n        this.dropdown.set(template);\n    }\n}\n"]}