UNPKG

@agnos-ui/angular

Version:

Bootstrap-based widget library for Angular.

302 lines 34 kB
import { __decorate } from "tslib"; import { BaseWidgetDirective, CachedProperty, ComponentTemplate, SlotDefaultDirective, SlotDirective, UseDirective, auBooleanAttribute, auNumberAttribute, callWidgetFactory, createToast, mergeDirectives, } from '@agnos-ui/angular-headless'; import { writable } from '@amadeus-it-group/tansu'; import { ChangeDetectionStrategy, Component, ContentChild, Directive, EventEmitter, Input, Output, TemplateRef, ViewChild, inject, } from '@angular/core'; import * as i0 from "@angular/core"; const _c0 = ["structure"]; function ToastDefaultSlotsComponent_ng_template_0_Conditional_0_ng_template_1_Template(rf, ctx) { } function ToastDefaultSlotsComponent_ng_template_0_Conditional_0_Conditional_2_Template(rf, ctx) { if (rf & 1) { const _r11 = i0.ɵɵgetCurrentView(); i0.ɵɵelementStart(0, "button", 8); i0.ɵɵlistener("click", function ToastDefaultSlotsComponent_ng_template_0_Conditional_0_Conditional_2_Template_button_click_0_listener() { i0.ɵɵrestoreView(_r11); const widget_r3 = i0.ɵɵnextContext(2).widget; return i0.ɵɵresetView(widget_r3.api.close()); }); i0.ɵɵelementEnd(); } if (rf & 2) { const state_r2 = i0.ɵɵnextContext(2).state; i0.ɵɵattribute("aria-label", state_r2.ariaCloseButtonLabel); } } const _c1 = (a0, a1) => ({ state: a0, widget: a1 }); function ToastDefaultSlotsComponent_ng_template_0_Conditional_0_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelementStart(0, "div", 6); i0.ɵɵtemplate(1, ToastDefaultSlotsComponent_ng_template_0_Conditional_0_ng_template_1_Template, 0, 0, "ng-template", 4)(2, ToastDefaultSlotsComponent_ng_template_0_Conditional_0_Conditional_2_Template, 1, 1, "button", 7); i0.ɵɵelementEnd(); } if (rf & 2) { const ctx_r13 = i0.ɵɵnextContext(); const state_r2 = ctx_r13.state; const widget_r3 = ctx_r13.widget; i0.ɵɵadvance(); i0.ɵɵproperty("auSlot", state_r2.slotHeader)("auSlotProps", i0.ɵɵpureFunction2(3, _c1, state_r2, widget_r3)); i0.ɵɵadvance(); i0.ɵɵconditional(2, state_r2.dismissible ? 2 : -1); } } function ToastDefaultSlotsComponent_ng_template_0_ng_template_2_Template(rf, ctx) { } function ToastDefaultSlotsComponent_ng_template_0_Conditional_3_Template(rf, ctx) { if (rf & 1) { const _r16 = i0.ɵɵgetCurrentView(); i0.ɵɵelementStart(0, "button", 9); i0.ɵɵlistener("click", function ToastDefaultSlotsComponent_ng_template_0_Conditional_3_Template_button_click_0_listener() { i0.ɵɵrestoreView(_r16); const widget_r3 = i0.ɵɵnextContext().widget; return i0.ɵɵresetView(widget_r3.api.close()); }); i0.ɵɵelementEnd(); } if (rf & 2) { const state_r2 = i0.ɵɵnextContext().state; i0.ɵɵattribute("aria-label", state_r2.ariaCloseButtonLabel); } } function ToastDefaultSlotsComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) { i0.ɵɵtemplate(0, ToastDefaultSlotsComponent_ng_template_0_Conditional_0_Template, 3, 6, "div", 2); i0.ɵɵelementStart(1, "div", 3); i0.ɵɵtemplate(2, ToastDefaultSlotsComponent_ng_template_0_ng_template_2_Template, 0, 0, "ng-template", 4); i0.ɵɵelementEnd(); i0.ɵɵtemplate(3, ToastDefaultSlotsComponent_ng_template_0_Conditional_3_Template, 1, 1, "button", 5); } if (rf & 2) { const state_r2 = ctx.state; const widget_r3 = ctx.widget; i0.ɵɵconditional(0, state_r2.slotHeader ? 0 : -1); i0.ɵɵadvance(2); i0.ɵɵproperty("auSlot", state_r2.slotDefault)("auSlotProps", i0.ɵɵpureFunction2(4, _c1, state_r2, widget_r3)); i0.ɵɵadvance(); i0.ɵɵconditional(3, state_r2.dismissible && !state_r2.slotHeader ? 3 : -1); } } const _c2 = ["auToast", ""]; function ToastComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) { i0.ɵɵprojection(0); } } function ToastComponent_Conditional_1_ng_template_1_Template(rf, ctx) { } function ToastComponent_Conditional_1_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelementStart(0, "div", 2); i0.ɵɵtemplate(1, ToastComponent_Conditional_1_ng_template_1_Template, 0, 0, "ng-template", 3); i0.ɵɵelementEnd(); } if (rf & 2) { const ctx_r1 = i0.ɵɵnextContext(); i0.ɵɵclassMapInterpolate1("au-toast toast ", ctx_r1.state().className, ""); i0.ɵɵclassProp("d-flex", !ctx_r1.state().slotHeader)("toast-dismissible", ctx_r1.state().dismissible); i0.ɵɵproperty("auUse", ctx_r1.toastDirective); i0.ɵɵadvance(); i0.ɵɵproperty("auSlot", ctx_r1.state().slotStructure)("auSlotProps", i0.ɵɵpureFunction2(10, _c1, ctx_r1.state(), ctx_r1.widget)); } } const _c3 = ["*"]; export class ToastBodyDirective { constructor() { this.templateRef = inject((TemplateRef)); } static ngTemplateContextGuard(dir, context) { return true; } static { this.ɵfac = function ToastBodyDirective_Factory(t) { return new (t || ToastBodyDirective)(); }; } static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ToastBodyDirective, selectors: [["ng-template", "auToastBody", ""]], standalone: true }); } } (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ToastBodyDirective, [{ type: Directive, args: [{ selector: 'ng-template[auToastBody]', standalone: true }] }], null, null); })(); export class ToastStructureDirective { constructor() { this.templateRef = inject((TemplateRef)); } static ngTemplateContextGuard(dir, context) { return true; } static { this.ɵfac = function ToastStructureDirective_Factory(t) { return new (t || ToastStructureDirective)(); }; } static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ToastStructureDirective, selectors: [["ng-template", "auToastStructure", ""]], standalone: true }); } } (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ToastStructureDirective, [{ type: Directive, args: [{ selector: 'ng-template[auToastStructure]', standalone: true }] }], null, null); })(); export class ToastHeaderDirective { constructor() { this.templateRef = inject((TemplateRef)); } static ngTemplateContextGuard(dir, context) { return true; } static { this.ɵfac = function ToastHeaderDirective_Factory(t) { return new (t || ToastHeaderDirective)(); }; } static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ToastHeaderDirective, selectors: [["ng-template", "auToastHeader", ""]], standalone: true }); } } (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ToastHeaderDirective, [{ type: Directive, args: [{ selector: 'ng-template[auToastHeader]', standalone: true }] }], null, null); })(); export class ToastDefaultSlotsComponent { static { this.ɵfac = function ToastDefaultSlotsComponent_Factory(t) { return new (t || ToastDefaultSlotsComponent)(); }; } static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ToastDefaultSlotsComponent, selectors: [["ng-component"]], viewQuery: function ToastDefaultSlotsComponent_Query(rf, ctx) { if (rf & 1) { i0.ɵɵviewQuery(_c0, 7); } if (rf & 2) { let _t; i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.structure = _t.first); } }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 2, vars: 0, consts: [["auToastStructure", ""], ["structure", ""], ["class", "toast-header"], [1, "toast-body"], [3, "auSlot", "auSlotProps"], ["type", "button", "class", "btn-close btn-close-white me-2 m-auto"], [1, "toast-header"], ["type", "button", "class", "btn-close me-0 ms-auto"], ["type", "button", 1, "btn-close", "me-0", "ms-auto", 3, "click"], ["type", "button", 1, "btn-close", "btn-close-white", "me-2", "m-auto", 3, "click"]], template: function ToastDefaultSlotsComponent_Template(rf, ctx) { if (rf & 1) { i0.ɵɵtemplate(0, ToastDefaultSlotsComponent_ng_template_0_Template, 4, 7, "ng-template", 0, 1, i0.ɵɵtemplateRefExtractor); } }, dependencies: [SlotDirective, ToastStructureDirective], encapsulation: 2, changeDetection: 0 }); } } (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ToastDefaultSlotsComponent, [{ type: Component, args: [{ standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [SlotDirective, ToastStructureDirective], template: ` <ng-template auToastStructure #structure let-state="state" let-widget="widget"> @if (state.slotHeader) { <div class="toast-header"> <ng-template [auSlot]="state.slotHeader" [auSlotProps]="{state, widget}"></ng-template> @if (state.dismissible) { <button type="button" class="btn-close me-0 ms-auto" (click)="widget.api.close()" [attr.aria-label]="state.ariaCloseButtonLabel"></button> } </div> } <div class="toast-body"> <ng-template [auSlot]="state.slotDefault" [auSlotProps]="{state, widget}"></ng-template> </div> @if (state.dismissible && !state.slotHeader) { <button type="button" class="btn-close btn-close-white me-2 m-auto" (click)="widget.api.close()" [attr.aria-label]="state.ariaCloseButtonLabel" ></button> } </ng-template>`, }] }], null, { structure: [{ type: ViewChild, args: ['structure', { static: true }] }] }); })(); (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ToastDefaultSlotsComponent, { className: "ToastDefaultSlotsComponent", filePath: "components/toast/toast.component.ts", lineNumber: 80 }); })(); export const toastDefaultSlotStructure = new ComponentTemplate(ToastDefaultSlotsComponent, 'structure'); const defaultConfig = { slotStructure: toastDefaultSlotStructure, }; export class ToastComponent extends BaseWidgetDirective { constructor() { super(...arguments); /** * Callback called when the alert visibility changed. */ this.visibleChange = new EventEmitter(); /** * Callback called when the alert is hidden. */ this.hidden = new EventEmitter(); /** * Callback called when the alert is shown. */ this.shown = new EventEmitter(); this.defaultSlots = writable(defaultConfig); this._widget = callWidgetFactory({ factory: createToast, widgetName: 'toast', defaultConfig: this.defaultSlots, events: { onVisibleChange: (event) => this.visibleChange.emit(event), onShown: () => this.shown.emit(), onHidden: () => this.hidden.emit(), }, }); } get toastDirective() { return mergeDirectives(this._widget.directives.autohideDirective, this._widget.directives.transitionDirective); } ngAfterContentChecked() { this._widget.patchSlots({ slotDefault: this.slotDefaultFromContent?.templateRef, slotStructure: this.slotStructureFromContent?.templateRef, slotHeader: this.slotHeaderFromContent?.templateRef, }); } static { this.ɵfac = /*@__PURE__*/ (() => { let ɵToastComponent_BaseFactory; return function ToastComponent_Factory(t) { returnToastComponent_BaseFactory || (ɵToastComponent_BaseFactory = i0.ɵɵgetInheritedFactory(ToastComponent)))(t || ToastComponent); }; })(); } static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ToastComponent, selectors: [["", "auToast", ""]], contentQueries: function ToastComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) { i0.ɵɵcontentQuery(dirIndex, ToastBodyDirective, 5); i0.ɵɵcontentQuery(dirIndex, ToastStructureDirective, 5); i0.ɵɵcontentQuery(dirIndex, ToastHeaderDirective, 5); } if (rf & 2) { let _t; i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotDefaultFromContent = _t.first); i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotStructureFromContent = _t.first); i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotHeaderFromContent = _t.first); } }, inputs: { dismissible: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auDismissible", "dismissible", auBooleanAttribute], transition: [i0.ɵɵInputFlags.None, "auTransition", "transition"], visible: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auVisible", "visible", auBooleanAttribute], animationOnInit: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auAnimationOnInit", "animationOnInit", auBooleanAttribute], animation: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auAnimation", "animation", auBooleanAttribute], autohide: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auAutohide", "autohide", auBooleanAttribute], delay: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auDelay", "delay", auNumberAttribute], ariaCloseButtonLabel: [i0.ɵɵInputFlags.None, "auAriaCloseButtonLabel", "ariaCloseButtonLabel"], slotDefault: [i0.ɵɵInputFlags.None, "auSlotDefault", "slotDefault"], slotStructure: [i0.ɵɵInputFlags.None, "auSlotStructure", "slotStructure"], slotHeader: [i0.ɵɵInputFlags.None, "auSlotHeader", "slotHeader"], className: [i0.ɵɵInputFlags.None, "auClassName", "className"] }, outputs: { visibleChange: "auVisibleChange", hidden: "auHidden", shown: "auShown" }, standalone: true, features: [i0.ɵɵInputTransformsFeature, i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], attrs: _c2, ngContentSelectors: _c3, decls: 2, vars: 2, consts: [[3, "auSlotDefault"], ["role", "alert", "aria-atomic", "true", 3, "auUse", "class", "d-flex", "toast-dismissible"], ["role", "alert", "aria-atomic", "true", 3, "auUse"], [3, "auSlot", "auSlotProps"]], template: function ToastComponent_Template(rf, ctx) { if (rf & 1) { i0.ɵɵprojectionDef(); i0.ɵɵtemplate(0, ToastComponent_ng_template_0_Template, 1, 0, "ng-template", 0)(1, ToastComponent_Conditional_1_Template, 2, 13, "div", 1); } if (rf & 2) { i0.ɵɵproperty("auSlotDefault", ctx.defaultSlots); i0.ɵɵadvance(); i0.ɵɵconditional(1, !ctx.state().hidden ? 1 : -1); } }, dependencies: [SlotDirective, UseDirective, SlotDefaultDirective], encapsulation: 2, changeDetection: 0 }); } } __decorate([ CachedProperty ], ToastComponent.prototype, "toastDirective", null); (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ToastComponent, [{ type: Component, args: [{ selector: '[auToast]', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [SlotDirective, UseDirective, SlotDefaultDirective], template: ` <ng-template [auSlotDefault]="defaultSlots"> <ng-content></ng-content> </ng-template> @if (!state().hidden) { <div [auUse]="toastDirective" class="au-toast toast {{ state().className }}" [class.d-flex]="!state().slotHeader" [class.toast-dismissible]="state().dismissible" role="alert" aria-atomic="true" > <ng-template [auSlot]="state().slotStructure" [auSlotProps]="{state: state(), widget}"></ng-template> </div> }`, }] }], null, { dismissible: [{ type: Input, args: [{ alias: 'auDismissible', transform: auBooleanAttribute }] }], transition: [{ type: Input, args: ['auTransition'] }], visible: [{ type: Input, args: [{ alias: 'auVisible', transform: auBooleanAttribute }] }], animationOnInit: [{ type: Input, args: [{ alias: 'auAnimationOnInit', transform: auBooleanAttribute }] }], animation: [{ type: Input, args: [{ alias: 'auAnimation', transform: auBooleanAttribute }] }], autohide: [{ type: Input, args: [{ alias: 'auAutohide', transform: auBooleanAttribute }] }], delay: [{ type: Input, args: [{ alias: 'auDelay', transform: auNumberAttribute }] }], ariaCloseButtonLabel: [{ type: Input, args: ['auAriaCloseButtonLabel'] }], slotDefault: [{ type: Input, args: ['auSlotDefault'] }], slotDefaultFromContent: [{ type: ContentChild, args: [ToastBodyDirective, { static: false }] }], slotStructure: [{ type: Input, args: ['auSlotStructure'] }], slotStructureFromContent: [{ type: ContentChild, args: [ToastStructureDirective, { static: false }] }], slotHeader: [{ type: Input, args: ['auSlotHeader'] }], slotHeaderFromContent: [{ type: ContentChild, args: [ToastHeaderDirective, { static: false }] }], visibleChange: [{ type: Output, args: ['auVisibleChange'] }], hidden: [{ type: Output, args: ['auHidden'] }], shown: [{ type: Output, args: ['auShown'] }], className: [{ type: Input, args: ['auClassName'] }], toastDirective: [] }); })(); (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ToastComponent, { className: "ToastComponent", filePath: "components/toast/toast.component.ts", lineNumber: 111 }); })(); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast.component.js","sourceRoot":"","sources":["../../../../src/components/toast/toast.component.ts"],"names":[],"mappings":"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","sourcesContent":["import type {SlotContent, ToastContext, ToastProps, ToastWidget, TransitionFn} from '@agnos-ui/angular-headless';\nimport {\n\tBaseWidgetDirective,\n\tCachedProperty,\n\tComponentTemplate,\n\tSlotDefaultDirective,\n\tSlotDirective,\n\tUseDirective,\n\tauBooleanAttribute,\n\tauNumberAttribute,\n\tcallWidgetFactory,\n\tcreateToast,\n\tmergeDirectives,\n} from '@agnos-ui/angular-headless';\nimport type {WritableSignal} from '@amadeus-it-group/tansu';\nimport {writable} from '@amadeus-it-group/tansu';\nimport type {AfterContentChecked} from '@angular/core';\nimport {\n\tChangeDetectionStrategy,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tEventEmitter,\n\tInput,\n\tOutput,\n\tTemplateRef,\n\tViewChild,\n\tinject,\n} from '@angular/core';\n\n@Directive({selector: 'ng-template[auToastBody]', standalone: true})\nexport class ToastBodyDirective {\n\tpublic templateRef = inject(TemplateRef<ToastContext>);\n\tstatic ngTemplateContextGuard(dir: ToastBodyDirective, context: unknown): context is ToastContext {\n\t\treturn true;\n\t}\n}\n\n@Directive({selector: 'ng-template[auToastStructure]', standalone: true})\nexport class ToastStructureDirective {\n\tpublic templateRef = inject(TemplateRef<ToastContext>);\n\tstatic ngTemplateContextGuard(dir: ToastStructureDirective, context: unknown): context is ToastContext {\n\t\treturn true;\n\t}\n}\n\n@Directive({selector: 'ng-template[auToastHeader]', standalone: true})\nexport class ToastHeaderDirective {\n\tpublic templateRef = inject(TemplateRef<ToastContext>);\n\tstatic ngTemplateContextGuard(dir: ToastHeaderDirective, context: unknown): context is ToastContext {\n\t\treturn true;\n\t}\n}\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [SlotDirective, ToastStructureDirective],\n\ttemplate: ` <ng-template auToastStructure #structure let-state=\"state\" let-widget=\"widget\">\n\t\t@if (state.slotHeader) {\n\t\t\t<div class=\"toast-header\">\n\t\t\t\t<ng-template [auSlot]=\"state.slotHeader\" [auSlotProps]=\"{state, widget}\"></ng-template>\n\t\t\t\t@if (state.dismissible) {\n\t\t\t\t\t<button type=\"button\" class=\"btn-close me-0 ms-auto\" (click)=\"widget.api.close()\" [attr.aria-label]=\"state.ariaCloseButtonLabel\"></button>\n\t\t\t\t}\n\t\t\t</div>\n\t\t}\n\t\t<div class=\"toast-body\">\n\t\t\t<ng-template [auSlot]=\"state.slotDefault\" [auSlotProps]=\"{state, widget}\"></ng-template>\n\t\t</div>\n\t\t@if (state.dismissible && !state.slotHeader) {\n\t\t\t<button\n\t\t\t\ttype=\"button\"\n\t\t\t\tclass=\"btn-close btn-close-white me-2 m-auto\"\n\t\t\t\t(click)=\"widget.api.close()\"\n\t\t\t\t[attr.aria-label]=\"state.ariaCloseButtonLabel\"\n\t\t\t></button>\n\t\t}\n\t</ng-template>`,\n})\nexport class ToastDefaultSlotsComponent {\n\t@ViewChild('structure', {static: true}) structure: TemplateRef<ToastContext>;\n}\n\nexport const toastDefaultSlotStructure = new ComponentTemplate(ToastDefaultSlotsComponent, 'structure');\n\nconst defaultConfig: Partial<ToastProps> = {\n\tslotStructure: toastDefaultSlotStructure,\n};\n\n@Component({\n\tselector: '[auToast]',\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [SlotDirective, UseDirective, SlotDefaultDirective],\n\ttemplate: ` <ng-template [auSlotDefault]=\"defaultSlots\">\n\t\t\t<ng-content></ng-content>\n\t\t</ng-template>\n\t\t@if (!state().hidden) {\n\t\t\t<div\n\t\t\t\t[auUse]=\"toastDirective\"\n\t\t\t\tclass=\"au-toast toast {{ state().className }}\"\n\t\t\t\t[class.d-flex]=\"!state().slotHeader\"\n\t\t\t\t[class.toast-dismissible]=\"state().dismissible\"\n\t\t\t\trole=\"alert\"\n\t\t\t\taria-atomic=\"true\"\n\t\t\t>\n\t\t\t\t<ng-template [auSlot]=\"state().slotStructure\" [auSlotProps]=\"{state: state(), widget}\"></ng-template>\n\t\t\t</div>\n\t\t}`,\n})\nexport class ToastComponent extends BaseWidgetDirective<ToastWidget> implements AfterContentChecked {\n\t/**\n\t * If `true`, alert can be dismissed by the user.\n\t * The close button (×) will be displayed and you can be notified of the event with the (close) output.\n\t */\n\t@Input({alias: 'auDismissible', transform: auBooleanAttribute})\n\tdismissible: boolean | undefined;\n\n\t/**\n\t * The transition function will be executed when the alert is displayed or hidden.\n\t *\n\t * Depending on the value of CommonAlertProps.animationOnInit, the animation can be optionally skipped during the showing process.\n\t */\n\t@Input('auTransition')\n\ttransition: TransitionFn | undefined;\n\n\t/**\n\t * If `true` the alert is visible to the user\n\t */\n\t@Input({alias: 'auVisible', transform: auBooleanAttribute})\n\tvisible: boolean | undefined;\n\n\t/**\n\t * If `true`, alert opening will be animated.\n\t *\n\t * Animation is triggered  when the `.open()` function is called\n\t * or the visible prop is changed\n\t */\n\t@Input({alias: 'auAnimationOnInit', transform: auBooleanAttribute})\n\tanimationOnInit: boolean | undefined;\n\n\t/**\n\t * If `true`, alert closing will be animated.\n\t *\n\t * Animation is triggered  when clicked on the close button (×),\n\t * via the `.close()` function or the visible prop is changed\n\t */\n\t@Input({alias: 'auAnimation', transform: auBooleanAttribute})\n\tanimation: boolean | undefined;\n\n\t/**\n\t * If `true` automatically hides the toast after the delay.\n\t */\n\t@Input({alias: 'auAutohide', transform: auBooleanAttribute})\n\tautohide: boolean | undefined;\n\n\t/**\n\t * Delay in milliseconds before hiding the toast.\n\t */\n\t@Input({alias: 'auDelay', transform: auNumberAttribute})\n\tdelay: number | undefined;\n\n\t/**\n\t * Accessibility close button label\n\t */\n\t@Input('auAriaCloseButtonLabel') ariaCloseButtonLabel: string | undefined;\n\n\t@Input('auSlotDefault') slotDefault: SlotContent<ToastContext>;\n\t@ContentChild(ToastBodyDirective, {static: false})\n\tslotDefaultFromContent: ToastBodyDirective | null;\n\n\t@Input('auSlotStructure') slotStructure: SlotContent<ToastContext>;\n\t@ContentChild(ToastStructureDirective, {static: false}) slotStructureFromContent: ToastStructureDirective | undefined;\n\n\t@Input('auSlotHeader') slotHeader: SlotContent<ToastContext>;\n\t@ContentChild(ToastHeaderDirective, {static: false}) slotHeaderFromContent: ToastHeaderDirective | undefined;\n\n\t/**\n\t * Callback called when the alert visibility changed.\n\t */\n\t@Output('auVisibleChange') visibleChange = new EventEmitter<boolean>();\n\n\t/**\n\t * Callback called when the alert is hidden.\n\t */\n\t@Output('auHidden') hidden = new EventEmitter<void>();\n\n\t/**\n\t * Callback called when the alert is shown.\n\t */\n\t@Output('auShown') shown = new EventEmitter<void>();\n\n\treadonly defaultSlots: WritableSignal<Partial<ToastProps>> = writable(defaultConfig);\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t */\n\t@Input('auClassName') className: string | undefined;\n\n\treadonly _widget = callWidgetFactory({\n\t\tfactory: createToast,\n\t\twidgetName: 'toast',\n\t\tdefaultConfig: this.defaultSlots,\n\t\tevents: {\n\t\t\tonVisibleChange: (event) => this.visibleChange.emit(event),\n\t\t\tonShown: () => this.shown.emit(),\n\t\t\tonHidden: () => this.hidden.emit(),\n\t\t},\n\t});\n\n\t@CachedProperty\n\tget toastDirective() {\n\t\treturn mergeDirectives(this._widget.directives.autohideDirective, this._widget.directives.transitionDirective);\n\t}\n\n\tngAfterContentChecked(): void {\n\t\tthis._widget.patchSlots({\n\t\t\tslotDefault: this.slotDefaultFromContent?.templateRef,\n\t\t\tslotStructure: this.slotStructureFromContent?.templateRef,\n\t\t\tslotHeader: this.slotHeaderFromContent?.templateRef,\n\t\t});\n\t}\n}\n"]}