@agnos-ui/angular
Version:
Bootstrap-based widget library for Angular.
441 lines • 46.7 kB
JavaScript
import { __decorate } from "tslib";
import { BaseWidgetDirective, CachedProperty, ComponentTemplate, SlotDefaultDirective, SlotDirective, UseDirective, auBooleanAttribute, callWidgetFactory, createModal, 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 = ["header"];
const _c1 = ["structure"];
function ModalDefaultSlotsComponent_ng_template_0_ng_template_1_Template(rf, ctx) { }
function ModalDefaultSlotsComponent_ng_template_0_Conditional_2_Template(rf, ctx) { if (rf & 1) {
const _r10 = i0.ɵɵgetCurrentView();
i0.ɵɵelementStart(0, "button", 7);
i0.ɵɵlistener("click", function ModalDefaultSlotsComponent_ng_template_0_Conditional_2_Template_button_click_0_listener($event) { i0.ɵɵrestoreView(_r10); const widget_r5 = i0.ɵɵnextContext().widget; return i0.ɵɵresetView(widget_r5.actions.closeButtonClick($event)); });
i0.ɵɵelementEnd();
} if (rf & 2) {
const state_r4 = i0.ɵɵnextContext().state;
i0.ɵɵattribute("aria-label", state_r4.ariaCloseButtonLabel);
} }
const _c2 = (a0, a1) => ({ state: a0, widget: a1 });
function ModalDefaultSlotsComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵelementStart(0, "h5", 4);
i0.ɵɵtemplate(1, ModalDefaultSlotsComponent_ng_template_0_ng_template_1_Template, 0, 0, "ng-template", 5);
i0.ɵɵelementEnd();
i0.ɵɵtemplate(2, ModalDefaultSlotsComponent_ng_template_0_Conditional_2_Template, 1, 1, "button", 6);
} if (rf & 2) {
const state_r4 = ctx.state;
const widget_r5 = ctx.widget;
i0.ɵɵadvance();
i0.ɵɵproperty("auSlot", state_r4.slotTitle)("auSlotProps", i0.ɵɵpureFunction2(3, _c2, state_r4, widget_r5));
i0.ɵɵadvance();
i0.ɵɵconditional(2, state_r4.closeButton ? 2 : -1);
} }
function ModalDefaultSlotsComponent_ng_template_2_Conditional_0_ng_template_1_Template(rf, ctx) { }
function ModalDefaultSlotsComponent_ng_template_2_Conditional_0_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵelementStart(0, "div", 11);
i0.ɵɵtemplate(1, ModalDefaultSlotsComponent_ng_template_2_Conditional_0_ng_template_1_Template, 0, 0, "ng-template", 5);
i0.ɵɵelementEnd();
} if (rf & 2) {
const ctx_r18 = i0.ɵɵnextContext();
const state_r12 = ctx_r18.state;
const widget_r13 = ctx_r18.widget;
i0.ɵɵadvance();
i0.ɵɵproperty("auSlot", state_r12.slotHeader)("auSlotProps", i0.ɵɵpureFunction2(2, _c2, state_r12, widget_r13));
} }
function ModalDefaultSlotsComponent_ng_template_2_ng_template_2_Template(rf, ctx) { }
function ModalDefaultSlotsComponent_ng_template_2_Conditional_3_ng_template_1_Template(rf, ctx) { }
function ModalDefaultSlotsComponent_ng_template_2_Conditional_3_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵelementStart(0, "div", 12);
i0.ɵɵtemplate(1, ModalDefaultSlotsComponent_ng_template_2_Conditional_3_ng_template_1_Template, 0, 0, "ng-template", 5);
i0.ɵɵelementEnd();
} if (rf & 2) {
const ctx_r20 = i0.ɵɵnextContext();
const state_r12 = ctx_r20.state;
const widget_r13 = ctx_r20.widget;
i0.ɵɵadvance();
i0.ɵɵproperty("auSlot", state_r12.slotFooter)("auSlotProps", i0.ɵɵpureFunction2(2, _c2, state_r12, widget_r13));
} }
function ModalDefaultSlotsComponent_ng_template_2_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵtemplate(0, ModalDefaultSlotsComponent_ng_template_2_Conditional_0_Template, 2, 5, "div", 8);
i0.ɵɵelementStart(1, "div", 9);
i0.ɵɵtemplate(2, ModalDefaultSlotsComponent_ng_template_2_ng_template_2_Template, 0, 0, "ng-template", 5);
i0.ɵɵelementEnd();
i0.ɵɵtemplate(3, ModalDefaultSlotsComponent_ng_template_2_Conditional_3_Template, 2, 5, "div", 10);
} if (rf & 2) {
const state_r12 = ctx.state;
const widget_r13 = ctx.widget;
i0.ɵɵconditional(0, state_r12.slotTitle ? 0 : -1);
i0.ɵɵadvance(2);
i0.ɵɵproperty("auSlot", state_r12.slotDefault)("auSlotProps", i0.ɵɵpureFunction2(4, _c2, state_r12, widget_r13));
i0.ɵɵadvance();
i0.ɵɵconditional(3, state_r12.slotFooter ? 3 : -1);
} }
const _c3 = ["auModal", ""];
function ModalComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵprojection(0);
} }
function ModalComponent_Conditional_1_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵelement(0, "div", 2);
} if (rf & 2) {
const ctx_r1 = i0.ɵɵnextContext();
i0.ɵɵclassMapInterpolate1("modal-backdrop ", ctx_r1.state().backdropClass, "");
i0.ɵɵproperty("auUse", ctx_r1.backdropDirective);
} }
function ModalComponent_Conditional_2_ng_template_3_Template(rf, ctx) { }
function ModalComponent_Conditional_2_Template(rf, ctx) { if (rf & 1) {
const _r5 = i0.ɵɵgetCurrentView();
i0.ɵɵelementStart(0, "div", 3);
i0.ɵɵlistener("click", function ModalComponent_Conditional_2_Template_div_click_0_listener($event) { i0.ɵɵrestoreView(_r5); const ctx_r4 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r4.widget.actions.modalClick($event)); });
i0.ɵɵelementStart(1, "div", 4)(2, "div", 5);
i0.ɵɵtemplate(3, ModalComponent_Conditional_2_ng_template_3_Template, 0, 0, "ng-template", 6);
i0.ɵɵelementEnd()()();
} if (rf & 2) {
const ctx_r2 = i0.ɵɵnextContext();
i0.ɵɵclassMapInterpolate1("modal d-block ", ctx_r2.state().className, "");
i0.ɵɵproperty("auUse", ctx_r2.modalDirective);
i0.ɵɵadvance(3);
i0.ɵɵproperty("auSlot", ctx_r2.state().slotStructure)("auSlotProps", i0.ɵɵpureFunction2(6, _c2, ctx_r2.state(), ctx_r2.widget));
} }
const _c4 = ["*"];
/**
* Directive to provide the slot structure for the modal widget.
*/
export class ModalStructureDirective {
constructor() {
this.templateRef = inject((TemplateRef));
}
static ngTemplateContextGuard(dir, context) {
return true;
}
static { this.ɵfac = function ModalStructureDirective_Factory(t) { return new (t || ModalStructureDirective)(); }; }
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ModalStructureDirective, selectors: [["ng-template", "auModalStructure", ""]], standalone: true }); }
}
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ModalStructureDirective, [{
type: Directive,
args: [{ selector: 'ng-template[auModalStructure]', standalone: true }]
}], null, null); })();
/**
* Directive to provide the slot header for the modal widget.
*/
export class ModalHeaderDirective {
constructor() {
this.templateRef = inject((TemplateRef));
}
static ngTemplateContextGuard(_dir, context) {
return true;
}
static { this.ɵfac = function ModalHeaderDirective_Factory(t) { return new (t || ModalHeaderDirective)(); }; }
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ModalHeaderDirective, selectors: [["ng-template", "auModalHeader", ""]], standalone: true }); }
}
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ModalHeaderDirective, [{
type: Directive,
args: [{ selector: 'ng-template[auModalHeader]', standalone: true }]
}], null, null); })();
/**
* Directive to provide the slot title for the modal widget.
*/
export class ModalTitleDirective {
constructor() {
this.templateRef = inject((TemplateRef));
}
static ngTemplateContextGuard(_dir, context) {
return true;
}
static { this.ɵfac = function ModalTitleDirective_Factory(t) { return new (t || ModalTitleDirective)(); }; }
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ModalTitleDirective, selectors: [["ng-template", "auModalTitle", ""]], standalone: true }); }
}
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ModalTitleDirective, [{
type: Directive,
args: [{ selector: 'ng-template[auModalTitle]', standalone: true }]
}], null, null); })();
/**
* Directive to provide the default slot for the modal widget.
*/
export class ModalBodyDirective {
constructor() {
this.templateRef = inject((TemplateRef));
}
static ngTemplateContextGuard(_dir, context) {
return true;
}
static { this.ɵfac = function ModalBodyDirective_Factory(t) { return new (t || ModalBodyDirective)(); }; }
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ModalBodyDirective, selectors: [["ng-template", "auModalBody", ""]], standalone: true }); }
}
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ModalBodyDirective, [{
type: Directive,
args: [{ selector: 'ng-template[auModalBody]', standalone: true }]
}], null, null); })();
/**
* Directive to provide the slot footer for the modal widget.
*/
export class ModalFooterDirective {
constructor() {
this.templateRef = inject((TemplateRef));
}
static ngTemplateContextGuard(_dir, context) {
return true;
}
static { this.ɵfac = function ModalFooterDirective_Factory(t) { return new (t || ModalFooterDirective)(); }; }
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ModalFooterDirective, selectors: [["ng-template", "auModalFooter", ""]], standalone: true }); }
}
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ModalFooterDirective, [{
type: Directive,
args: [{ selector: 'ng-template[auModalFooter]', standalone: true }]
}], null, null); })();
/**
* Component containing the default slots for the modal.
*/
export class ModalDefaultSlotsComponent {
static { this.ɵfac = function ModalDefaultSlotsComponent_Factory(t) { return new (t || ModalDefaultSlotsComponent)(); }; }
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ModalDefaultSlotsComponent, selectors: [["ng-component"]], viewQuery: function ModalDefaultSlotsComponent_Query(rf, ctx) { if (rf & 1) {
i0.ɵɵviewQuery(_c0, 7);
i0.ɵɵviewQuery(_c1, 7);
} if (rf & 2) {
let _t;
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.header = _t.first);
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.structure = _t.first);
} }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 4, vars: 0, consts: [["auModalHeader", ""], ["header", ""], ["auModalStructure", ""], ["structure", ""], [1, "modal-title"], [3, "auSlot", "auSlotProps"], ["type", "button", "class", "btn-close"], ["type", "button", 1, "btn-close", 3, "click"], ["class", "modal-header"], [1, "modal-body"], ["class", "modal-footer"], [1, "modal-header"], [1, "modal-footer"]], template: function ModalDefaultSlotsComponent_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵtemplate(0, ModalDefaultSlotsComponent_ng_template_0_Template, 3, 6, "ng-template", 0, 1, i0.ɵɵtemplateRefExtractor)(2, ModalDefaultSlotsComponent_ng_template_2_Template, 4, 7, "ng-template", 2, 3, i0.ɵɵtemplateRefExtractor);
} }, dependencies: [SlotDirective, ModalHeaderDirective, ModalStructureDirective], encapsulation: 2, changeDetection: 0 }); }
}
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ModalDefaultSlotsComponent, [{
type: Component,
args: [{
standalone: true,
changeDetection: ChangeDetectionStrategy.OnPush,
imports: [SlotDirective, ModalHeaderDirective, ModalStructureDirective],
template: `
<ng-template auModalHeader #header let-state="state" let-widget="widget">
<h5 class="modal-title">
<ng-template [auSlot]="state.slotTitle" [auSlotProps]="{state, widget}"></ng-template>
</h5>
(state.closeButton) {
<button
type="button"
class="btn-close"
[attr.aria-label]="state.ariaCloseButtonLabel"
(click)="widget.actions.closeButtonClick($event)"
></button>
}
</ng-template>
<ng-template auModalStructure #structure let-state="state" let-widget="widget">
(state.slotTitle) {
<div class="modal-header">
<ng-template [auSlot]="state.slotHeader" [auSlotProps]="{state, widget}"></ng-template>
</div>
}
<div class="modal-body">
<ng-template [auSlot]="state.slotDefault" [auSlotProps]="{state, widget}"></ng-template>
</div>
(state.slotFooter) {
<div class="modal-footer">
<ng-template [auSlot]="state.slotFooter" [auSlotProps]="{state, widget}"></ng-template>
</div>
}
</ng-template>
`,
}]
}], null, { header: [{
type: ViewChild,
args: ['header', { static: true }]
}], structure: [{
type: ViewChild,
args: ['structure', { static: true }]
}] }); })();
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ModalDefaultSlotsComponent, { className: "ModalDefaultSlotsComponent", filePath: "components/modal/modal.component.ts", lineNumber: 122 }); })();
/**
* Default slot for modal header.
*/
export const modalDefaultSlotHeader = new ComponentTemplate(ModalDefaultSlotsComponent, 'header');
/**
* Default slot for modal structure.
*/
export const modalDefaultSlotStructure = new ComponentTemplate(ModalDefaultSlotsComponent, 'structure');
const defaultConfig = {
slotHeader: modalDefaultSlotHeader,
slotStructure: modalDefaultSlotStructure,
};
/**
* Modal component.
*/
export class ModalComponent extends BaseWidgetDirective {
constructor() {
super(...arguments);
/**
* Event to be triggered when the visible property changes.
*/
this.visibleChange = new EventEmitter();
/**
* Event to be triggered when the modal is about to be closed (i.e. the close method was called).
*/
this.beforeClose = new EventEmitter();
/**
* Event to be triggered when the transition is completed and the modal is not visible.
*/
this.hidden = new EventEmitter();
/**
* Event to be triggered when the transition is completed and the modal is visible.
*/
this.shown = new EventEmitter();
this.defaultSlots = writable(defaultConfig);
this._widget = callWidgetFactory({
factory: createModal,
widgetName: 'modal',
defaultConfig: this.defaultSlots,
events: {
onShown: () => this.shown.emit(),
onHidden: () => this.hidden.emit(),
onBeforeClose: (event) => this.beforeClose.emit(event),
onVisibleChange: (event) => this.visibleChange.emit(event),
},
});
}
get modalDirective() {
return mergeDirectives(this._widget.directives.modalPortalDirective, this._widget.directives.modalDirective);
}
get backdropDirective() {
return mergeDirectives(this._widget.directives.backdropPortalDirective, this._widget.directives.backdropDirective);
}
ngAfterContentChecked() {
this._widget.patchSlots({
slotDefault: this.slotDefaultFromContent?.templateRef,
slotFooter: this.slotFooterFromContent?.templateRef,
slotHeader: this.slotHeaderFromContent?.templateRef,
slotStructure: this.slotStructureFromContent?.templateRef,
slotTitle: this.slotTitleFromContent?.templateRef,
});
}
static { this.ɵfac = /*@__PURE__*/ (() => { let ɵModalComponent_BaseFactory; return function ModalComponent_Factory(t) { return (ɵModalComponent_BaseFactory || (ɵModalComponent_BaseFactory = i0.ɵɵgetInheritedFactory(ModalComponent)))(t || ModalComponent); }; })(); }
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ModalComponent, selectors: [["", "auModal", ""]], contentQueries: function ModalComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
i0.ɵɵcontentQuery(dirIndex, ModalStructureDirective, 5);
i0.ɵɵcontentQuery(dirIndex, ModalHeaderDirective, 5);
i0.ɵɵcontentQuery(dirIndex, ModalTitleDirective, 5);
i0.ɵɵcontentQuery(dirIndex, ModalBodyDirective, 5);
i0.ɵɵcontentQuery(dirIndex, ModalFooterDirective, 5);
} if (rf & 2) {
let _t;
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotStructureFromContent = _t.first);
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotHeaderFromContent = _t.first);
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotTitleFromContent = _t.first);
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotDefaultFromContent = _t.first);
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotFooterFromContent = _t.first);
} }, inputs: { animation: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auAnimation", "animation", auBooleanAttribute], backdropTransition: [i0.ɵɵInputFlags.None, "auBackdropTransition", "backdropTransition"], modalTransition: [i0.ɵɵInputFlags.None, "auModalTransition", "modalTransition"], visible: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auVisible", "visible", auBooleanAttribute], backdrop: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auBackdrop", "backdrop", auBooleanAttribute], closeOnOutsideClick: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auCloseOnOutsideClick", "closeOnOutsideClick", auBooleanAttribute], container: [i0.ɵɵInputFlags.None, "auContainer", "container"], ariaCloseButtonLabel: [i0.ɵɵInputFlags.None, "auAriaCloseButtonLabel", "ariaCloseButtonLabel"], backdropClass: [i0.ɵɵInputFlags.None, "auBackdropClass", "backdropClass"], closeButton: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auCloseButton", "closeButton", auBooleanAttribute], className: [i0.ɵɵInputFlags.None, "auClassName", "className"], slotStructure: [i0.ɵɵInputFlags.None, "auSlotStructure", "slotStructure"], slotHeader: [i0.ɵɵInputFlags.None, "auSlotHeader", "slotHeader"], slotTitle: [i0.ɵɵInputFlags.None, "auSlotTitle", "slotTitle"], slotDefault: [i0.ɵɵInputFlags.None, "auSlotDefault", "slotDefault"], slotFooter: [i0.ɵɵInputFlags.None, "auSlotFooter", "slotFooter"], contentData: [i0.ɵɵInputFlags.None, "auContentData", "contentData"] }, outputs: { visibleChange: "auVisibleChange", beforeClose: "auBeforeClose", hidden: "auHidden", shown: "auShown" }, standalone: true, features: [i0.ɵɵInputTransformsFeature, i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], attrs: _c3, ngContentSelectors: _c4, decls: 3, vars: 3, consts: [[3, "auSlotDefault"], [3, "class", "auUse"], [3, "auUse"], [3, "auUse", "click"], [1, "modal-dialog"], [1, "modal-content"], [3, "auSlot", "auSlotProps"]], template: function ModalComponent_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵprojectionDef();
i0.ɵɵtemplate(0, ModalComponent_ng_template_0_Template, 1, 0, "ng-template", 0)(1, ModalComponent_Conditional_1_Template, 1, 4, "div", 1)(2, ModalComponent_Conditional_2_Template, 4, 9, "div", 1);
} if (rf & 2) {
i0.ɵɵproperty("auSlotDefault", ctx.defaultSlots);
i0.ɵɵadvance();
i0.ɵɵconditional(1, !ctx.state().backdropHidden ? 1 : -1);
i0.ɵɵadvance();
i0.ɵɵconditional(2, !ctx.state().hidden ? 2 : -1);
} }, dependencies: [UseDirective, SlotDirective, SlotDefaultDirective], encapsulation: 2, changeDetection: 0 }); }
}
__decorate([
CachedProperty
], ModalComponent.prototype, "modalDirective", null);
__decorate([
CachedProperty
], ModalComponent.prototype, "backdropDirective", null);
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ModalComponent, [{
type: Component,
args: [{
selector: '[auModal]',
standalone: true,
changeDetection: ChangeDetectionStrategy.OnPush,
imports: [UseDirective, SlotDirective, SlotDefaultDirective],
template: `
<ng-template [auSlotDefault]="defaultSlots"><ng-content></ng-content></ng-template>
(!state().backdropHidden) {
<div class="modal-backdrop {{ state().backdropClass }}" [auUse]="backdropDirective"></div>
}
(!state().hidden) {
<div class="modal d-block {{ state().className }}" [auUse]="modalDirective" (click)="widget.actions.modalClick($event)">
<div class="modal-dialog">
<div class="modal-content">
<ng-template [auSlot]="state().slotStructure" [auSlotProps]="{state: state(), widget}"></ng-template>
</div>
</div>
</div>
}
`,
}]
}], null, { animation: [{
type: Input,
args: [{ alias: 'auAnimation', transform: auBooleanAttribute }]
}], backdropTransition: [{
type: Input,
args: ['auBackdropTransition']
}], modalTransition: [{
type: Input,
args: ['auModalTransition']
}], visible: [{
type: Input,
args: [{ alias: 'auVisible', transform: auBooleanAttribute }]
}], backdrop: [{
type: Input,
args: [{ alias: 'auBackdrop', transform: auBooleanAttribute }]
}], closeOnOutsideClick: [{
type: Input,
args: [{ alias: 'auCloseOnOutsideClick', transform: auBooleanAttribute }]
}], container: [{
type: Input,
args: ['auContainer']
}], ariaCloseButtonLabel: [{
type: Input,
args: ['auAriaCloseButtonLabel']
}], backdropClass: [{
type: Input,
args: ['auBackdropClass']
}], closeButton: [{
type: Input,
args: [{ alias: 'auCloseButton', transform: auBooleanAttribute }]
}], className: [{
type: Input,
args: ['auClassName']
}], slotStructure: [{
type: Input,
args: ['auSlotStructure']
}], slotStructureFromContent: [{
type: ContentChild,
args: [ModalStructureDirective, { static: false }]
}], slotHeader: [{
type: Input,
args: ['auSlotHeader']
}], slotHeaderFromContent: [{
type: ContentChild,
args: [ModalHeaderDirective, { static: false }]
}], slotTitle: [{
type: Input,
args: ['auSlotTitle']
}], slotTitleFromContent: [{
type: ContentChild,
args: [ModalTitleDirective, { static: false }]
}], slotDefault: [{
type: Input,
args: ['auSlotDefault']
}], slotDefaultFromContent: [{
type: ContentChild,
args: [ModalBodyDirective, { static: false }]
}], slotFooter: [{
type: Input,
args: ['auSlotFooter']
}], slotFooterFromContent: [{
type: ContentChild,
args: [ModalFooterDirective, { static: false }]
}], contentData: [{
type: Input,
args: ['auContentData']
}], visibleChange: [{
type: Output,
args: ['auVisibleChange']
}], beforeClose: [{
type: Output,
args: ['auBeforeClose']
}], hidden: [{
type: Output,
args: ['auHidden']
}], shown: [{
type: Output,
args: ['auShown']
}], modalDirective: [], backdropDirective: [] }); })();
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ModalComponent, { className: "ModalComponent", filePath: "components/modal/modal.component.ts", lineNumber: 166 }); })();
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../src/components/modal/modal.component.ts"],"names":[],"mappings":"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","sourcesContent":["import type {ModalBeforeCloseEvent, ModalContext, ModalProps, ModalWidget, SlotContent, TransitionFn} from '@agnos-ui/angular-headless';\nimport {\n\tBaseWidgetDirective,\n\tCachedProperty,\n\tComponentTemplate,\n\tSlotDefaultDirective,\n\tSlotDirective,\n\tUseDirective,\n\tauBooleanAttribute,\n\tcallWidgetFactory,\n\tcreateModal,\n\tmergeDirectives,\n} from '@agnos-ui/angular-headless';\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/**\n * Directive to provide the slot structure for the modal widget.\n */\n@Directive({selector: 'ng-template[auModalStructure]', standalone: true})\nexport class ModalStructureDirective<Data> {\n\tpublic templateRef = inject(TemplateRef<ModalContext<Data>>);\n\tstatic ngTemplateContextGuard<Data>(dir: ModalStructureDirective<Data>, context: unknown): context is ModalContext<Data> {\n\t\treturn true;\n\t}\n}\n\n/**\n * Directive to provide the slot header for the modal widget.\n */\n@Directive({selector: 'ng-template[auModalHeader]', standalone: true})\nexport class ModalHeaderDirective<Data> {\n\tpublic templateRef = inject(TemplateRef<ModalContext<Data>>);\n\tstatic ngTemplateContextGuard<Data>(_dir: ModalHeaderDirective<Data>, context: unknown): context is ModalContext<Data> {\n\t\treturn true;\n\t}\n}\n\n/**\n * Directive to provide the slot title for the modal widget.\n */\n@Directive({selector: 'ng-template[auModalTitle]', standalone: true})\nexport class ModalTitleDirective<Data> {\n\tpublic templateRef = inject(TemplateRef<ModalContext<Data>>);\n\tstatic ngTemplateContextGuard<Data>(_dir: ModalTitleDirective<Data>, context: unknown): context is ModalContext<Data> {\n\t\treturn true;\n\t}\n}\n\n/**\n * Directive to provide the default slot for the modal widget.\n */\n@Directive({selector: 'ng-template[auModalBody]', standalone: true})\nexport class ModalBodyDirective<Data> {\n\tpublic templateRef = inject(TemplateRef<ModalContext<Data>>);\n\tstatic ngTemplateContextGuard<Data>(_dir: ModalBodyDirective<Data>, context: unknown): context is ModalContext<Data> {\n\t\treturn true;\n\t}\n}\n\n/**\n * Directive to provide the slot footer for the modal widget.\n */\n@Directive({selector: 'ng-template[auModalFooter]', standalone: true})\nexport class ModalFooterDirective<Data> {\n\tpublic templateRef = inject(TemplateRef<ModalContext<Data>>);\n\tstatic ngTemplateContextGuard<Data>(_dir: ModalFooterDirective<Data>, context: unknown): context is ModalContext<Data> {\n\t\treturn true;\n\t}\n}\n\n/**\n * Component containing the default slots for the modal.\n */\n@Component({\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [SlotDirective, ModalHeaderDirective, ModalStructureDirective],\n\ttemplate: `\n\t\t<ng-template auModalHeader #header let-state=\"state\" let-widget=\"widget\">\n\t\t\t<h5 class=\"modal-title\">\n\t\t\t\t<ng-template [auSlot]=\"state.slotTitle\" [auSlotProps]=\"{state, widget}\"></ng-template>\n\t\t\t</h5>\n\t\t\t@if (state.closeButton) {\n\t\t\t\t<button\n\t\t\t\t\ttype=\"button\"\n\t\t\t\t\tclass=\"btn-close\"\n\t\t\t\t\t[attr.aria-label]=\"state.ariaCloseButtonLabel\"\n\t\t\t\t\t(click)=\"widget.actions.closeButtonClick($event)\"\n\t\t\t\t></button>\n\t\t\t}\n\t\t</ng-template>\n\t\t<ng-template auModalStructure #structure let-state=\"state\" let-widget=\"widget\">\n\t\t\t@if (state.slotTitle) {\n\t\t\t\t<div class=\"modal-header\">\n\t\t\t\t\t<ng-template [auSlot]=\"state.slotHeader\" [auSlotProps]=\"{state, widget}\"></ng-template>\n\t\t\t\t</div>\n\t\t\t}\n\t\t\t<div class=\"modal-body\">\n\t\t\t\t<ng-template [auSlot]=\"state.slotDefault\" [auSlotProps]=\"{state, widget}\"></ng-template>\n\t\t\t</div>\n\t\t\t@if (state.slotFooter) {\n\t\t\t\t<div class=\"modal-footer\">\n\t\t\t\t\t<ng-template [auSlot]=\"state.slotFooter\" [auSlotProps]=\"{state, widget}\"></ng-template>\n\t\t\t\t</div>\n\t\t\t}\n\t\t</ng-template>\n\t`,\n})\nexport class ModalDefaultSlotsComponent<Data> {\n\t@ViewChild('header', {static: true}) header: TemplateRef<ModalContext<Data>>;\n\t@ViewChild('structure', {static: true}) structure: TemplateRef<ModalContext<Data>>;\n}\n\n/**\n * Default slot for modal header.\n */\nexport const modalDefaultSlotHeader = new ComponentTemplate(ModalDefaultSlotsComponent, 'header');\n\n/**\n * Default slot for modal structure.\n */\nexport const modalDefaultSlotStructure = new ComponentTemplate(ModalDefaultSlotsComponent, 'structure');\n\nconst defaultConfig: Partial<ModalProps<any>> = {\n\tslotHeader: modalDefaultSlotHeader,\n\tslotStructure: modalDefaultSlotStructure,\n};\n\n/**\n * Modal component.\n */\n@Component({\n\tselector: '[auModal]',\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [UseDirective, SlotDirective, SlotDefaultDirective],\n\ttemplate: `\n\t\t<ng-template [auSlotDefault]=\"defaultSlots\"><ng-content></ng-content></ng-template>\n\t\t@if (!state().backdropHidden) {\n\t\t\t<div class=\"modal-backdrop {{ state().backdropClass }}\" [auUse]=\"backdropDirective\"></div>\n\t\t}\n\t\t@if (!state().hidden) {\n\t\t\t<div class=\"modal d-block {{ state().className }}\" [auUse]=\"modalDirective\" (click)=\"widget.actions.modalClick($event)\">\n\t\t\t\t<div class=\"modal-dialog\">\n\t\t\t\t\t<div class=\"modal-content\">\n\t\t\t\t\t\t<ng-template [auSlot]=\"state().slotStructure\" [auSlotProps]=\"{state: state(), widget}\"></ng-template>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t}\n\t`,\n})\nexport class ModalComponent<Data> extends BaseWidgetDirective<ModalWidget<Data>> implements AfterContentChecked {\n\t/**\n\t * Whether the modal and its backdrop (if present) should be animated when shown or hidden.\n\t */\n\t@Input({alias: 'auAnimation', transform: auBooleanAttribute}) animation: boolean | undefined;\n\n\t/**\n\t * The transition to use for the backdrop behind the modal (if present).\n\t */\n\t@Input('auBackdropTransition') backdropTransition: TransitionFn | undefined;\n\n\t/**\n\t * The transition to use for the modal.\n\t */\n\t@Input('auModalTransition') modalTransition: TransitionFn | undefined;\n\n\t/**\n\t * Whether the modal should be visible when the transition is completed.\n\t */\n\t@Input({alias: 'auVisible', transform: auBooleanAttribute}) visible: boolean | undefined;\n\n\t/**\n\t * Whether a backdrop should be created behind the modal.\n\t */\n\t@Input({alias: 'auBackdrop', transform: auBooleanAttribute}) backdrop: boolean | undefined;\n\n\t/**\n\t * Whether the modal should be closed when clicking on the viewport outside the modal.\n\t */\n\t@Input({alias: 'auCloseOnOutsideClick', transform: auBooleanAttribute}) closeOnOutsideClick: boolean | undefined;\n\n\t/**\n\t * Which element should contain the modal and backdrop DOM elements.\n\t * If it is not null, the modal and backdrop DOM elements are moved to the specified container.\n\t * Otherwise, they stay where the widget is located.\n\t */\n\t@Input('auContainer') container: HTMLElement | null | undefined;\n\n\t/**\n\t * Value of the aria-label attribute to put on the close button.\n\t */\n\t@Input('auAriaCloseButtonLabel') ariaCloseButtonLabel: string | undefined;\n\n\t/**\n\t * Classes to add on the backdrop DOM element.\n\t */\n\t@Input('auBackdropClass') backdropClass: string | undefined;\n\n\t/**\n\t * Whether to display the close button.\n\t */\n\t@Input({alias: 'auCloseButton', transform: auBooleanAttribute}) closeButton: boolean | undefined;\n\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\t@Input('auSlotStructure') slotStructure: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalStructureDirective, {static: false})\n\tslotStructureFromContent: ModalStructureDirective<Data> | null;\n\n\t@Input('auSlotHeader') slotHeader: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalHeaderDirective, {static: false})\n\tslotHeaderFromContent: ModalHeaderDirective<Data> | null;\n\n\t@Input('auSlotTitle') slotTitle: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalTitleDirective, {static: false})\n\tslotTitleFromContent: ModalTitleDirective<Data> | null;\n\n\t@Input('auSlotDefault') slotDefault: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalBodyDirective, {static: false})\n\tslotDefaultFromContent: ModalBodyDirective<Data> | null;\n\n\t@Input('auSlotFooter') slotFooter: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalFooterDirective, {static: false})\n\tslotFooterFromContent: ModalFooterDirective<Data> | null;\n\n\t/**\n\t * Data to use in content slots\n\t */\n\t@Input('auContentData') contentData: Data | undefined;\n\n\t/**\n\t * Event to be triggered when the visible property changes.\n\t */\n\t@Output('auVisibleChange') visibleChange = new EventEmitter<boolean>();\n\n\t/**\n\t * Event to be triggered when the modal is about to be closed (i.e. the close method was called).\n\t */\n\t@Output('auBeforeClose') beforeClose = new EventEmitter<ModalBeforeCloseEvent>();\n\n\t/**\n\t * Event to be triggered when the transition is completed and the modal is not visible.\n\t */\n\t@Output('auHidden') hidden = new EventEmitter<void>();\n\n\t/**\n\t * Event to be triggered when the transition is completed and the modal is visible.\n\t */\n\t@Output('auShown') shown = new EventEmitter<void>();\n\n\treadonly defaultSlots = writable(defaultConfig);\n\n\treadonly _widget = callWidgetFactory<ModalWidget<Data>>({\n\t\tfactory: createModal,\n\t\twidgetName: 'modal',\n\t\tdefaultConfig: this.defaultSlots,\n\t\tevents: {\n\t\t\tonShown: () => this.shown.emit(),\n\t\t\tonHidden: () => this.hidden.emit(),\n\t\t\tonBeforeClose: (event) => this.beforeClose.emit(event),\n\t\t\tonVisibleChange: (event) => this.visibleChange.emit(event),\n\t\t},\n\t});\n\n\t@CachedProperty\n\tget modalDirective() {\n\t\treturn mergeDirectives(this._widget.directives.modalPortalDirective, this._widget.directives.modalDirective);\n\t}\n\n\t@CachedProperty\n\tget backdropDirective() {\n\t\treturn mergeDirectives(this._widget.directives.backdropPortalDirective, this._widget.directives.backdropDirective);\n\t}\n\n\tngAfterContentChecked(): void {\n\t\tthis._widget.patchSlots({\n\t\t\tslotDefault: this.slotDefaultFromContent?.templateRef,\n\t\t\tslotFooter: this.slotFooterFromContent?.templateRef,\n\t\t\tslotHeader: this.slotHeaderFromContent?.templateRef,\n\t\t\tslotStructure: this.slotStructureFromContent?.templateRef,\n\t\t\tslotTitle: this.slotTitleFromContent?.templateRef,\n\t\t});\n\t}\n}\n"]}