@agnos-ui/angular
Version:
Bootstrap-based widget library for Angular.
228 lines (227 loc) • 26.5 kB
JavaScript
import { BaseWidgetDirective, ComponentTemplate, SlotDefaultDirective, SlotDirective, UseDirective, auBooleanAttribute, callWidgetFactory, createAlert, } 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 AlertDefaultSlotsComponent_ng_template_0_ng_template_1_Template(rf, ctx) { }
function AlertDefaultSlotsComponent_ng_template_0_Conditional_2_Template(rf, ctx) { if (rf & 1) {
const _r8 = i0.ɵɵgetCurrentView();
i0.ɵɵelementStart(0, "button", 5);
i0.ɵɵlistener("click", function AlertDefaultSlotsComponent_ng_template_0_Conditional_2_Template_button_click_0_listener() { i0.ɵɵrestoreView(_r8); 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);
} }
const _c1 = (a0, a1) => ({ state: a0, widget: a1 });
function AlertDefaultSlotsComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵelementStart(0, "div", 2);
i0.ɵɵtemplate(1, AlertDefaultSlotsComponent_ng_template_0_ng_template_1_Template, 0, 0, "ng-template", 3);
i0.ɵɵelementEnd();
i0.ɵɵtemplate(2, AlertDefaultSlotsComponent_ng_template_0_Conditional_2_Template, 1, 1, "button", 4);
} if (rf & 2) {
const state_r2 = ctx.state;
const widget_r3 = ctx.widget;
i0.ɵɵadvance();
i0.ɵɵproperty("auSlot", state_r2.slotDefault)("auSlotProps", i0.ɵɵpureFunction2(3, _c1, state_r2, widget_r3));
i0.ɵɵadvance();
i0.ɵɵconditional(2, state_r2.dismissible ? 2 : -1);
} }
const _c2 = ["auAlert", ""];
function AlertComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵprojection(0);
} }
function AlertComponent_Conditional_1_ng_template_1_Template(rf, ctx) { }
function AlertComponent_Conditional_1_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵelementStart(0, "div", 2);
i0.ɵɵtemplate(1, AlertComponent_Conditional_1_ng_template_1_Template, 0, 0, "ng-template", 3);
i0.ɵɵelementEnd();
} if (rf & 2) {
const ctx_r1 = i0.ɵɵnextContext();
i0.ɵɵclassMapInterpolate3("au-alert alert alert-", ctx_r1.state().type, " ", ctx_r1.state().className, " ", ctx_r1.state().dismissible ? "alert-dismissible" : "", "");
i0.ɵɵproperty("auUse", ctx_r1.widget.directives.transitionDirective);
i0.ɵɵadvance();
i0.ɵɵproperty("auSlot", ctx_r1.state().slotStructure)("auSlotProps", i0.ɵɵpureFunction2(8, _c1, ctx_r1.state(), ctx_r1.widget));
} }
const _c3 = ["*"];
export class AlertBodyDirective {
constructor() {
this.templateRef = inject((TemplateRef));
}
static ngTemplateContextGuard(dir, context) {
return true;
}
static { this.ɵfac = function AlertBodyDirective_Factory(t) { return new (t || AlertBodyDirective)(); }; }
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: AlertBodyDirective, selectors: [["ng-template", "auAlertBody", ""]], standalone: true }); }
}
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(AlertBodyDirective, [{
type: Directive,
args: [{ selector: 'ng-template[auAlertBody]', standalone: true }]
}], null, null); })();
export class AlertStructureDirective {
constructor() {
this.templateRef = inject((TemplateRef));
}
static ngTemplateContextGuard(dir, context) {
return true;
}
static { this.ɵfac = function AlertStructureDirective_Factory(t) { return new (t || AlertStructureDirective)(); }; }
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: AlertStructureDirective, selectors: [["ng-template", "auAlertStructure", ""]], standalone: true }); }
}
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(AlertStructureDirective, [{
type: Directive,
args: [{ selector: 'ng-template[auAlertStructure]', standalone: true }]
}], null, null); })();
export class AlertDefaultSlotsComponent {
static { this.ɵfac = function AlertDefaultSlotsComponent_Factory(t) { return new (t || AlertDefaultSlotsComponent)(); }; }
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: AlertDefaultSlotsComponent, selectors: [["ng-component"]], viewQuery: function AlertDefaultSlotsComponent_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: [["auAlertStructure", ""], ["structure", ""], [1, "alert-body"], [3, "auSlot", "auSlotProps"], ["type", "button", "class", "btn-close"], ["type", "button", 1, "btn-close", 3, "click"]], template: function AlertDefaultSlotsComponent_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵtemplate(0, AlertDefaultSlotsComponent_ng_template_0_Template, 3, 6, "ng-template", 0, 1, i0.ɵɵtemplateRefExtractor);
} }, dependencies: [SlotDirective, AlertStructureDirective], encapsulation: 2, changeDetection: 0 }); }
}
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(AlertDefaultSlotsComponent, [{
type: Component,
args: [{
standalone: true,
changeDetection: ChangeDetectionStrategy.OnPush,
imports: [SlotDirective, AlertStructureDirective],
template: ` <ng-template auAlertStructure #structure let-state="state" let-widget="widget">
<div class="alert-body">
<ng-template [auSlot]="state.slotDefault" [auSlotProps]="{state, widget}"></ng-template>
</div>
@if (state.dismissible) {
<button type="button" class="btn-close" (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(AlertDefaultSlotsComponent, { className: "AlertDefaultSlotsComponent", filePath: "components/alert/alert.component.ts", lineNumber: 55 }); })();
export const alertDefaultSlotStructure = new ComponentTemplate(AlertDefaultSlotsComponent, 'structure');
const defaultConfig = {
slotStructure: alertDefaultSlotStructure,
};
export class AlertComponent 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: createAlert,
widgetName: 'alert',
defaultConfig: this.defaultSlots,
events: {
onVisibleChange: (event) => this.visibleChange.emit(event),
onShown: () => this.shown.emit(),
onHidden: () => this.hidden.emit(),
},
});
}
ngAfterContentChecked() {
this._widget.patchSlots({
slotDefault: this.slotDefaultFromContent?.templateRef,
slotStructure: this.slotStructureFromContent?.templateRef,
});
}
static { this.ɵfac = /*@__PURE__*/ (() => { let ɵAlertComponent_BaseFactory; return function AlertComponent_Factory(t) { return (ɵAlertComponent_BaseFactory || (ɵAlertComponent_BaseFactory = i0.ɵɵgetInheritedFactory(AlertComponent)))(t || AlertComponent); }; })(); }
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: AlertComponent, selectors: [["", "auAlert", ""]], contentQueries: function AlertComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
i0.ɵɵcontentQuery(dirIndex, AlertBodyDirective, 5);
i0.ɵɵcontentQuery(dirIndex, AlertStructureDirective, 5);
} if (rf & 2) {
let _t;
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotDefaultFromContent = _t.first);
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotStructureFromContent = _t.first);
} }, inputs: { type: [i0.ɵɵInputFlags.None, "auType", "type"], 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], ariaCloseButtonLabel: [i0.ɵɵInputFlags.None, "auAriaCloseButtonLabel", "ariaCloseButtonLabel"], slotDefault: [i0.ɵɵInputFlags.None, "auSlotDefault", "slotDefault"], slotStructure: [i0.ɵɵInputFlags.None, "auSlotStructure", "slotStructure"], 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", 3, "auUse", "class"], ["role", "alert", 3, "auUse"], [3, "auSlot", "auSlotProps"]], template: function AlertComponent_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵprojectionDef();
i0.ɵɵtemplate(0, AlertComponent_ng_template_0_Template, 1, 0, "ng-template", 0)(1, AlertComponent_Conditional_1_Template, 2, 11, "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 }); }
}
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(AlertComponent, [{
type: Component,
args: [{
selector: '[auAlert]',
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]="widget.directives.transitionDirective"
class="au-alert alert alert-{{ state().type }} {{ state().className }} {{ state().dismissible ? 'alert-dismissible' : '' }}"
role="alert"
>
<ng-template [auSlot]="state().slotStructure" [auSlotProps]="{state: state(), widget}"></ng-template>
</div>
}`,
}]
}], null, { type: [{
type: Input,
args: ['auType']
}], 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 }]
}], ariaCloseButtonLabel: [{
type: Input,
args: ['auAriaCloseButtonLabel']
}], slotDefault: [{
type: Input,
args: ['auSlotDefault']
}], slotDefaultFromContent: [{
type: ContentChild,
args: [AlertBodyDirective, { static: false }]
}], slotStructure: [{
type: Input,
args: ['auSlotStructure']
}], slotStructureFromContent: [{
type: ContentChild,
args: [AlertStructureDirective, { static: false }]
}], visibleChange: [{
type: Output,
args: ['auVisibleChange']
}], hidden: [{
type: Output,
args: ['auHidden']
}], shown: [{
type: Output,
args: ['auShown']
}], className: [{
type: Input,
args: ['auClassName']
}] }); })();
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(AlertComponent, { className: "AlertComponent", filePath: "components/alert/alert.component.ts", lineNumber: 85 }); })();
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alert.component.js","sourceRoot":"","sources":["../../../../src/components/alert/alert.component.ts"],"names":[],"mappings":"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","sourcesContent":["import type {AlertContext, AlertProps, AlertWidget, SlotContent, TransitionFn} from '@agnos-ui/angular-headless';\nimport {\n\tBaseWidgetDirective,\n\tComponentTemplate,\n\tSlotDefaultDirective,\n\tSlotDirective,\n\tUseDirective,\n\tauBooleanAttribute,\n\tcallWidgetFactory,\n\tcreateAlert,\n} from '@agnos-ui/angular-headless';\nimport {type WritableSignal, 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[auAlertBody]', standalone: true})\nexport class AlertBodyDirective {\n\tpublic templateRef = inject(TemplateRef<AlertContext>);\n\tstatic ngTemplateContextGuard(dir: AlertBodyDirective, context: unknown): context is AlertContext {\n\t\treturn true;\n\t}\n}\n\n@Directive({selector: 'ng-template[auAlertStructure]', standalone: true})\nexport class AlertStructureDirective {\n\tpublic templateRef = inject(TemplateRef<AlertContext>);\n\tstatic ngTemplateContextGuard(dir: AlertStructureDirective, context: unknown): context is AlertContext {\n\t\treturn true;\n\t}\n}\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [SlotDirective, AlertStructureDirective],\n\ttemplate: ` <ng-template auAlertStructure #structure let-state=\"state\" let-widget=\"widget\">\n\t\t<div class=\"alert-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) {\n\t\t\t<button type=\"button\" class=\"btn-close\" (click)=\"widget.api.close()\" [attr.aria-label]=\"state.ariaCloseButtonLabel\"></button>\n\t\t}\n\t</ng-template>`,\n})\nexport class AlertDefaultSlotsComponent {\n\t@ViewChild('structure', {static: true}) structure: TemplateRef<AlertContext>;\n}\n\nexport const alertDefaultSlotStructure = new ComponentTemplate(AlertDefaultSlotsComponent, 'structure');\n\nexport type PartialAlertProps = Partial<AlertProps>;\nconst defaultConfig: PartialAlertProps = {\n\tslotStructure: alertDefaultSlotStructure,\n};\n\n@Component({\n\tselector: '[auAlert]',\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\n\t\t@if (!state().hidden) {\n\t\t\t<div\n\t\t\t\t[auUse]=\"widget.directives.transitionDirective\"\n\t\t\t\tclass=\"au-alert alert alert-{{ state().type }} {{ state().className }} {{ state().dismissible ? 'alert-dismissible' : '' }}\"\n\t\t\t\trole=\"alert\"\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 AlertComponent extends BaseWidgetDirective<AlertWidget> implements AfterContentChecked {\n\t/**\n\t * Type of the alert.\n\t * There are the following types: 'success', 'info', 'warning', 'danger', 'primary', 'secondary', 'light' and 'dark'.\n\t */\n\t@Input('auType')\n\ttype: string | undefined;\n\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 * Accessibility close button label\n\t */\n\t@Input('auAriaCloseButtonLabel') ariaCloseButtonLabel: string | undefined;\n\n\t@Input('auSlotDefault') slotDefault: SlotContent<AlertContext>;\n\t@ContentChild(AlertBodyDirective, {static: false})\n\tslotDefaultFromContent: AlertBodyDirective | null;\n\n\t@Input('auSlotStructure') slotStructure: SlotContent<AlertContext>;\n\t@ContentChild(AlertStructureDirective, {static: false}) slotStructureFromContent: AlertStructureDirective | 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<PartialAlertProps> = 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: createAlert,\n\t\twidgetName: 'alert',\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\tngAfterContentChecked(): void {\n\t\tthis._widget.patchSlots({\n\t\t\tslotDefault: this.slotDefaultFromContent?.templateRef,\n\t\t\tslotStructure: this.slotStructureFromContent?.templateRef,\n\t\t});\n\t}\n}\n"]}