@taiga-ui/layout
Version:
A package with Taiga UI layout components
97 lines • 15.3 kB
JavaScript
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 {\n    ChangeDetectionStrategy,\n    Component,\n    type DoCheck,\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, 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"]}