@agnos-ui/angular-bootstrap 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +15 -0
- package/agnos-ui-angular.module.d.ts +16 -0
- package/components/accordion/accordion.component.d.ts +239 -0
- package/components/accordion/accordion.d.ts +11 -0
- package/components/accordion/index.d.ts +2 -0
- package/components/alert/alert.component.d.ts +95 -0
- package/components/alert/alert.d.ts +7 -0
- package/components/alert/index.d.ts +2 -0
- package/components/modal/index.d.ts +3 -0
- package/components/modal/modal.component.d.ts +164 -0
- package/components/modal/modal.d.ts +9 -0
- package/components/modal/modal.service.d.ts +13 -0
- package/components/pagination/index.d.ts +2 -0
- package/components/pagination/pagination.component.d.ts +252 -0
- package/components/pagination/pagination.d.ts +8 -0
- package/components/progressbar/index.d.ts +2 -0
- package/components/progressbar/progressbar.component.d.ts +77 -0
- package/components/progressbar/progressbar.d.ts +7 -0
- package/components/rating/index.d.ts +2 -0
- package/components/rating/rating.component.d.ts +95 -0
- package/components/rating/rating.d.ts +6 -0
- package/components/select/index.d.ts +2 -0
- package/components/select/select.component.d.ts +107 -0
- package/components/select/select.d.ts +8 -0
- package/components/slider/index.d.ts +2 -0
- package/components/slider/slider.component.d.ts +130 -0
- package/components/slider/slider.d.ts +9 -0
- package/components/toast/index.d.ts +2 -0
- package/components/toast/toast.component.d.ts +106 -0
- package/components/toast/toast.d.ts +7 -0
- package/config.d.ts +18 -0
- package/esm2022/agnos-ui-angular-bootstrap.mjs +5 -0
- package/esm2022/agnos-ui-angular.module.mjs +151 -0
- package/esm2022/components/accordion/accordion.component.mjs +579 -0
- package/esm2022/components/accordion/accordion.mjs +4 -0
- package/esm2022/components/accordion/index.mjs +3 -0
- package/esm2022/components/alert/alert.component.mjs +230 -0
- package/esm2022/components/alert/alert.mjs +4 -0
- package/esm2022/components/alert/index.mjs +3 -0
- package/esm2022/components/modal/index.mjs +4 -0
- package/esm2022/components/modal/modal.component.mjs +423 -0
- package/esm2022/components/modal/modal.mjs +4 -0
- package/esm2022/components/modal/modal.service.mjs +47 -0
- package/esm2022/components/pagination/index.mjs +3 -0
- package/esm2022/components/pagination/pagination.component.mjs +581 -0
- package/esm2022/components/pagination/pagination.mjs +4 -0
- package/esm2022/components/progressbar/index.mjs +3 -0
- package/esm2022/components/progressbar/progressbar.component.mjs +180 -0
- package/esm2022/components/progressbar/progressbar.mjs +4 -0
- package/esm2022/components/rating/index.mjs +3 -0
- package/esm2022/components/rating/rating.component.mjs +185 -0
- package/esm2022/components/rating/rating.mjs +4 -0
- package/esm2022/components/select/index.mjs +3 -0
- package/esm2022/components/select/select.component.mjs +280 -0
- package/esm2022/components/select/select.mjs +4 -0
- package/esm2022/components/slider/index.mjs +3 -0
- package/esm2022/components/slider/slider.component.mjs +443 -0
- package/esm2022/components/slider/slider.mjs +4 -0
- package/esm2022/components/toast/index.mjs +3 -0
- package/esm2022/components/toast/toast.component.mjs +284 -0
- package/esm2022/components/toast/toast.mjs +4 -0
- package/esm2022/config.mjs +5 -0
- package/esm2022/index.mjs +27 -0
- package/fesm2022/agnos-ui-angular-bootstrap.mjs +3382 -0
- package/fesm2022/agnos-ui-angular-bootstrap.mjs.map +1 -0
- package/index.d.ts +33 -0
- package/package.json +48 -0
|
@@ -0,0 +1,423 @@
|
|
|
1
|
+
import { BaseWidgetDirective, ComponentTemplate, SlotDefaultDirective, SlotDirective, UseDirective, UseMultiDirective, auBooleanAttribute, } from '@agnos-ui/angular-headless';
|
|
2
|
+
import { createModal } from './modal';
|
|
3
|
+
import { writable } from '@amadeus-it-group/tansu';
|
|
4
|
+
import { ChangeDetectionStrategy, Component, ContentChild, Directive, EventEmitter, Input, Output, TemplateRef, ViewChild, inject, } from '@angular/core';
|
|
5
|
+
import { callWidgetFactory } from '../../config';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
const _c0 = ["header"];
|
|
8
|
+
const _c1 = ["structure"];
|
|
9
|
+
const _c2 = (a0, a1) => ({ state: a0, widget: a1 });
|
|
10
|
+
function ModalDefaultSlotsComponent_ng_template_0_ng_template_1_Template(rf, ctx) { }
|
|
11
|
+
function ModalDefaultSlotsComponent_ng_template_0_Conditional_2_Template(rf, ctx) { if (rf & 1) {
|
|
12
|
+
i0.ɵɵelement(0, "button", 6);
|
|
13
|
+
} if (rf & 2) {
|
|
14
|
+
const widget_r1 = i0.ɵɵnextContext().widget;
|
|
15
|
+
i0.ɵɵproperty("auUse", widget_r1.directives.closeButtonDirective);
|
|
16
|
+
} }
|
|
17
|
+
function ModalDefaultSlotsComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) {
|
|
18
|
+
i0.ɵɵelementStart(0, "h5", 4);
|
|
19
|
+
i0.ɵɵtemplate(1, ModalDefaultSlotsComponent_ng_template_0_ng_template_1_Template, 0, 0, "ng-template", 5);
|
|
20
|
+
i0.ɵɵelementEnd();
|
|
21
|
+
i0.ɵɵtemplate(2, ModalDefaultSlotsComponent_ng_template_0_Conditional_2_Template, 1, 1, "button", 6);
|
|
22
|
+
} if (rf & 2) {
|
|
23
|
+
const state_r2 = ctx.state;
|
|
24
|
+
const widget_r1 = ctx.widget;
|
|
25
|
+
i0.ɵɵadvance();
|
|
26
|
+
i0.ɵɵproperty("auSlot", state_r2.slotTitle)("auSlotProps", i0.ɵɵpureFunction2(3, _c2, state_r2, widget_r1));
|
|
27
|
+
i0.ɵɵadvance();
|
|
28
|
+
i0.ɵɵconditional(2, state_r2.closeButton ? 2 : -1);
|
|
29
|
+
} }
|
|
30
|
+
function ModalDefaultSlotsComponent_ng_template_2_Conditional_0_ng_template_1_Template(rf, ctx) { }
|
|
31
|
+
function ModalDefaultSlotsComponent_ng_template_2_Conditional_0_Template(rf, ctx) { if (rf & 1) {
|
|
32
|
+
i0.ɵɵelementStart(0, "div", 7);
|
|
33
|
+
i0.ɵɵtemplate(1, ModalDefaultSlotsComponent_ng_template_2_Conditional_0_ng_template_1_Template, 0, 0, "ng-template", 5);
|
|
34
|
+
i0.ɵɵelementEnd();
|
|
35
|
+
} if (rf & 2) {
|
|
36
|
+
const ctx_r2 = i0.ɵɵnextContext();
|
|
37
|
+
const state_r4 = ctx_r2.state;
|
|
38
|
+
const widget_r5 = ctx_r2.widget;
|
|
39
|
+
i0.ɵɵadvance();
|
|
40
|
+
i0.ɵɵproperty("auSlot", state_r4.slotHeader)("auSlotProps", i0.ɵɵpureFunction2(2, _c2, state_r4, widget_r5));
|
|
41
|
+
} }
|
|
42
|
+
function ModalDefaultSlotsComponent_ng_template_2_ng_template_2_Template(rf, ctx) { }
|
|
43
|
+
function ModalDefaultSlotsComponent_ng_template_2_Conditional_3_ng_template_1_Template(rf, ctx) { }
|
|
44
|
+
function ModalDefaultSlotsComponent_ng_template_2_Conditional_3_Template(rf, ctx) { if (rf & 1) {
|
|
45
|
+
i0.ɵɵelementStart(0, "div", 9);
|
|
46
|
+
i0.ɵɵtemplate(1, ModalDefaultSlotsComponent_ng_template_2_Conditional_3_ng_template_1_Template, 0, 0, "ng-template", 5);
|
|
47
|
+
i0.ɵɵelementEnd();
|
|
48
|
+
} if (rf & 2) {
|
|
49
|
+
const ctx_r2 = i0.ɵɵnextContext();
|
|
50
|
+
const state_r4 = ctx_r2.state;
|
|
51
|
+
const widget_r5 = ctx_r2.widget;
|
|
52
|
+
i0.ɵɵadvance();
|
|
53
|
+
i0.ɵɵproperty("auSlot", state_r4.slotFooter)("auSlotProps", i0.ɵɵpureFunction2(2, _c2, state_r4, widget_r5));
|
|
54
|
+
} }
|
|
55
|
+
function ModalDefaultSlotsComponent_ng_template_2_Template(rf, ctx) { if (rf & 1) {
|
|
56
|
+
i0.ɵɵtemplate(0, ModalDefaultSlotsComponent_ng_template_2_Conditional_0_Template, 2, 5, "div", 7);
|
|
57
|
+
i0.ɵɵelementStart(1, "div", 8);
|
|
58
|
+
i0.ɵɵtemplate(2, ModalDefaultSlotsComponent_ng_template_2_ng_template_2_Template, 0, 0, "ng-template", 5);
|
|
59
|
+
i0.ɵɵelementEnd();
|
|
60
|
+
i0.ɵɵtemplate(3, ModalDefaultSlotsComponent_ng_template_2_Conditional_3_Template, 2, 5, "div", 9);
|
|
61
|
+
} if (rf & 2) {
|
|
62
|
+
const state_r4 = ctx.state;
|
|
63
|
+
const widget_r5 = ctx.widget;
|
|
64
|
+
i0.ɵɵconditional(0, state_r4.slotTitle ? 0 : -1);
|
|
65
|
+
i0.ɵɵadvance(2);
|
|
66
|
+
i0.ɵɵproperty("auSlot", state_r4.slotDefault)("auSlotProps", i0.ɵɵpureFunction2(4, _c2, state_r4, widget_r5));
|
|
67
|
+
i0.ɵɵadvance();
|
|
68
|
+
i0.ɵɵconditional(3, state_r4.slotFooter ? 3 : -1);
|
|
69
|
+
} }
|
|
70
|
+
const _c3 = ["auModal", ""];
|
|
71
|
+
const _c4 = ["*"];
|
|
72
|
+
const _c5 = (a0, a1) => [a0, a1];
|
|
73
|
+
function ModalComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) {
|
|
74
|
+
i0.ɵɵprojection(0);
|
|
75
|
+
} }
|
|
76
|
+
function ModalComponent_Conditional_1_Template(rf, ctx) { if (rf & 1) {
|
|
77
|
+
i0.ɵɵelement(0, "div", 1);
|
|
78
|
+
} if (rf & 2) {
|
|
79
|
+
const ctx_r0 = i0.ɵɵnextContext();
|
|
80
|
+
i0.ɵɵproperty("auUseMulti", i0.ɵɵpureFunction2(1, _c5, ctx_r0.widget.directives.backdropPortalDirective, ctx_r0.widget.directives.backdropDirective));
|
|
81
|
+
} }
|
|
82
|
+
function ModalComponent_Conditional_2_ng_template_3_Template(rf, ctx) { }
|
|
83
|
+
function ModalComponent_Conditional_2_Template(rf, ctx) { if (rf & 1) {
|
|
84
|
+
i0.ɵɵelementStart(0, "div", 2)(1, "div")(2, "div", 3);
|
|
85
|
+
i0.ɵɵtemplate(3, ModalComponent_Conditional_2_ng_template_3_Template, 0, 0, "ng-template", 4);
|
|
86
|
+
i0.ɵɵelementEnd()()();
|
|
87
|
+
} if (rf & 2) {
|
|
88
|
+
const ctx_r0 = i0.ɵɵnextContext();
|
|
89
|
+
i0.ɵɵproperty("auUseMulti", i0.ɵɵpureFunction2(6, _c5, ctx_r0.widget.directives.modalPortalDirective, ctx_r0.widget.directives.modalDirective));
|
|
90
|
+
i0.ɵɵadvance();
|
|
91
|
+
i0.ɵɵclassMapInterpolate1("modal-dialog ", ctx_r0.state().fullscreen ? "modal-fullscreen" : "", "");
|
|
92
|
+
i0.ɵɵadvance(2);
|
|
93
|
+
i0.ɵɵproperty("auSlot", ctx_r0.state().slotStructure)("auSlotProps", i0.ɵɵpureFunction2(9, _c2, ctx_r0.state(), ctx_r0.widget));
|
|
94
|
+
} }
|
|
95
|
+
/**
|
|
96
|
+
* Directive to provide the slot structure for the modal widget.
|
|
97
|
+
*/
|
|
98
|
+
export class ModalStructureDirective {
|
|
99
|
+
constructor() {
|
|
100
|
+
this.templateRef = inject((TemplateRef));
|
|
101
|
+
}
|
|
102
|
+
static ngTemplateContextGuard(dir, context) {
|
|
103
|
+
return true;
|
|
104
|
+
}
|
|
105
|
+
static { this.ɵfac = function ModalStructureDirective_Factory(t) { return new (t || ModalStructureDirective)(); }; }
|
|
106
|
+
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ModalStructureDirective, selectors: [["ng-template", "auModalStructure", ""]], standalone: true }); }
|
|
107
|
+
}
|
|
108
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ModalStructureDirective, [{
|
|
109
|
+
type: Directive,
|
|
110
|
+
args: [{ selector: 'ng-template[auModalStructure]', standalone: true }]
|
|
111
|
+
}], null, null); })();
|
|
112
|
+
/**
|
|
113
|
+
* Directive to provide the slot header for the modal widget.
|
|
114
|
+
*/
|
|
115
|
+
export class ModalHeaderDirective {
|
|
116
|
+
constructor() {
|
|
117
|
+
this.templateRef = inject((TemplateRef));
|
|
118
|
+
}
|
|
119
|
+
static ngTemplateContextGuard(_dir, context) {
|
|
120
|
+
return true;
|
|
121
|
+
}
|
|
122
|
+
static { this.ɵfac = function ModalHeaderDirective_Factory(t) { return new (t || ModalHeaderDirective)(); }; }
|
|
123
|
+
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ModalHeaderDirective, selectors: [["ng-template", "auModalHeader", ""]], standalone: true }); }
|
|
124
|
+
}
|
|
125
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ModalHeaderDirective, [{
|
|
126
|
+
type: Directive,
|
|
127
|
+
args: [{ selector: 'ng-template[auModalHeader]', standalone: true }]
|
|
128
|
+
}], null, null); })();
|
|
129
|
+
/**
|
|
130
|
+
* Directive to provide the slot title for the modal widget.
|
|
131
|
+
*/
|
|
132
|
+
export class ModalTitleDirective {
|
|
133
|
+
constructor() {
|
|
134
|
+
this.templateRef = inject((TemplateRef));
|
|
135
|
+
}
|
|
136
|
+
static ngTemplateContextGuard(_dir, context) {
|
|
137
|
+
return true;
|
|
138
|
+
}
|
|
139
|
+
static { this.ɵfac = function ModalTitleDirective_Factory(t) { return new (t || ModalTitleDirective)(); }; }
|
|
140
|
+
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ModalTitleDirective, selectors: [["ng-template", "auModalTitle", ""]], standalone: true }); }
|
|
141
|
+
}
|
|
142
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ModalTitleDirective, [{
|
|
143
|
+
type: Directive,
|
|
144
|
+
args: [{ selector: 'ng-template[auModalTitle]', standalone: true }]
|
|
145
|
+
}], null, null); })();
|
|
146
|
+
/**
|
|
147
|
+
* Directive to provide the default slot for the modal widget.
|
|
148
|
+
*/
|
|
149
|
+
export class ModalBodyDirective {
|
|
150
|
+
constructor() {
|
|
151
|
+
this.templateRef = inject((TemplateRef));
|
|
152
|
+
}
|
|
153
|
+
static ngTemplateContextGuard(_dir, context) {
|
|
154
|
+
return true;
|
|
155
|
+
}
|
|
156
|
+
static { this.ɵfac = function ModalBodyDirective_Factory(t) { return new (t || ModalBodyDirective)(); }; }
|
|
157
|
+
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ModalBodyDirective, selectors: [["ng-template", "auModalBody", ""]], standalone: true }); }
|
|
158
|
+
}
|
|
159
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ModalBodyDirective, [{
|
|
160
|
+
type: Directive,
|
|
161
|
+
args: [{ selector: 'ng-template[auModalBody]', standalone: true }]
|
|
162
|
+
}], null, null); })();
|
|
163
|
+
/**
|
|
164
|
+
* Directive to provide the slot footer for the modal widget.
|
|
165
|
+
*/
|
|
166
|
+
export class ModalFooterDirective {
|
|
167
|
+
constructor() {
|
|
168
|
+
this.templateRef = inject((TemplateRef));
|
|
169
|
+
}
|
|
170
|
+
static ngTemplateContextGuard(_dir, context) {
|
|
171
|
+
return true;
|
|
172
|
+
}
|
|
173
|
+
static { this.ɵfac = function ModalFooterDirective_Factory(t) { return new (t || ModalFooterDirective)(); }; }
|
|
174
|
+
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ModalFooterDirective, selectors: [["ng-template", "auModalFooter", ""]], standalone: true }); }
|
|
175
|
+
}
|
|
176
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ModalFooterDirective, [{
|
|
177
|
+
type: Directive,
|
|
178
|
+
args: [{ selector: 'ng-template[auModalFooter]', standalone: true }]
|
|
179
|
+
}], null, null); })();
|
|
180
|
+
/**
|
|
181
|
+
* Component containing the default slots for the modal.
|
|
182
|
+
*/
|
|
183
|
+
export class ModalDefaultSlotsComponent {
|
|
184
|
+
static { this.ɵfac = function ModalDefaultSlotsComponent_Factory(t) { return new (t || ModalDefaultSlotsComponent)(); }; }
|
|
185
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ModalDefaultSlotsComponent, selectors: [["ng-component"]], viewQuery: function ModalDefaultSlotsComponent_Query(rf, ctx) { if (rf & 1) {
|
|
186
|
+
i0.ɵɵviewQuery(_c0, 7);
|
|
187
|
+
i0.ɵɵviewQuery(_c1, 7);
|
|
188
|
+
} if (rf & 2) {
|
|
189
|
+
let _t;
|
|
190
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.header = _t.first);
|
|
191
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.structure = _t.first);
|
|
192
|
+
} }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 4, vars: 0, consts: [["header", ""], ["structure", ""], ["auModalHeader", ""], ["auModalStructure", ""], [1, "modal-title"], [3, "auSlot", "auSlotProps"], [1, "btn-close", 3, "auUse"], [1, "modal-header"], [1, "modal-body"], [1, "modal-footer"]], template: function ModalDefaultSlotsComponent_Template(rf, ctx) { if (rf & 1) {
|
|
193
|
+
i0.ɵɵtemplate(0, ModalDefaultSlotsComponent_ng_template_0_Template, 3, 6, "ng-template", 2, 0, i0.ɵɵtemplateRefExtractor)(2, ModalDefaultSlotsComponent_ng_template_2_Template, 4, 7, "ng-template", 3, 1, i0.ɵɵtemplateRefExtractor);
|
|
194
|
+
} }, dependencies: [SlotDirective, ModalHeaderDirective, ModalStructureDirective, UseDirective], encapsulation: 2, changeDetection: 0 }); }
|
|
195
|
+
}
|
|
196
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ModalDefaultSlotsComponent, [{
|
|
197
|
+
type: Component,
|
|
198
|
+
args: [{
|
|
199
|
+
standalone: true,
|
|
200
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
201
|
+
imports: [SlotDirective, ModalHeaderDirective, ModalStructureDirective, UseDirective],
|
|
202
|
+
template: `
|
|
203
|
+
<ng-template auModalHeader #header let-state="state" let-widget="widget">
|
|
204
|
+
<h5 class="modal-title">
|
|
205
|
+
<ng-template [auSlot]="state.slotTitle" [auSlotProps]="{state, widget}"></ng-template>
|
|
206
|
+
</h5>
|
|
207
|
+
@if (state.closeButton) {
|
|
208
|
+
<button class="btn-close" [auUse]="widget.directives.closeButtonDirective"></button>
|
|
209
|
+
}
|
|
210
|
+
</ng-template>
|
|
211
|
+
<ng-template auModalStructure #structure let-state="state" let-widget="widget">
|
|
212
|
+
@if (state.slotTitle) {
|
|
213
|
+
<div class="modal-header">
|
|
214
|
+
<ng-template [auSlot]="state.slotHeader" [auSlotProps]="{state, widget}"></ng-template>
|
|
215
|
+
</div>
|
|
216
|
+
}
|
|
217
|
+
<div class="modal-body">
|
|
218
|
+
<ng-template [auSlot]="state.slotDefault" [auSlotProps]="{state, widget}"></ng-template>
|
|
219
|
+
</div>
|
|
220
|
+
@if (state.slotFooter) {
|
|
221
|
+
<div class="modal-footer">
|
|
222
|
+
<ng-template [auSlot]="state.slotFooter" [auSlotProps]="{state, widget}"></ng-template>
|
|
223
|
+
</div>
|
|
224
|
+
}
|
|
225
|
+
</ng-template>
|
|
226
|
+
`,
|
|
227
|
+
}]
|
|
228
|
+
}], null, { header: [{
|
|
229
|
+
type: ViewChild,
|
|
230
|
+
args: ['header', { static: true }]
|
|
231
|
+
}], structure: [{
|
|
232
|
+
type: ViewChild,
|
|
233
|
+
args: ['structure', { static: true }]
|
|
234
|
+
}] }); })();
|
|
235
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ModalDefaultSlotsComponent, { className: "ModalDefaultSlotsComponent", filePath: "components/modal/modal.component.ts", lineNumber: 117 }); })();
|
|
236
|
+
/**
|
|
237
|
+
* Default slot for modal header.
|
|
238
|
+
*/
|
|
239
|
+
export const modalDefaultSlotHeader = new ComponentTemplate(ModalDefaultSlotsComponent, 'header');
|
|
240
|
+
/**
|
|
241
|
+
* Default slot for modal structure.
|
|
242
|
+
*/
|
|
243
|
+
export const modalDefaultSlotStructure = new ComponentTemplate(ModalDefaultSlotsComponent, 'structure');
|
|
244
|
+
const defaultConfig = {
|
|
245
|
+
slotHeader: modalDefaultSlotHeader,
|
|
246
|
+
slotStructure: modalDefaultSlotStructure,
|
|
247
|
+
};
|
|
248
|
+
/**
|
|
249
|
+
* Modal component.
|
|
250
|
+
*/
|
|
251
|
+
export class ModalComponent extends BaseWidgetDirective {
|
|
252
|
+
constructor() {
|
|
253
|
+
super(...arguments);
|
|
254
|
+
/**
|
|
255
|
+
* Event to be triggered when the visible property changes.
|
|
256
|
+
*/
|
|
257
|
+
this.visibleChange = new EventEmitter();
|
|
258
|
+
/**
|
|
259
|
+
* Event to be triggered when the modal is about to be closed (i.e. the close method was called).
|
|
260
|
+
*/
|
|
261
|
+
this.beforeClose = new EventEmitter();
|
|
262
|
+
/**
|
|
263
|
+
* Event to be triggered when the transition is completed and the modal is not visible.
|
|
264
|
+
*/
|
|
265
|
+
this.hidden = new EventEmitter();
|
|
266
|
+
/**
|
|
267
|
+
* Event to be triggered when the transition is completed and the modal is visible.
|
|
268
|
+
*/
|
|
269
|
+
this.shown = new EventEmitter();
|
|
270
|
+
this.defaultSlots = writable(defaultConfig);
|
|
271
|
+
this._widget = callWidgetFactory({
|
|
272
|
+
factory: createModal,
|
|
273
|
+
widgetName: 'modal',
|
|
274
|
+
defaultConfig: this.defaultSlots,
|
|
275
|
+
events: {
|
|
276
|
+
onShown: () => this.shown.emit(),
|
|
277
|
+
onHidden: () => this.hidden.emit(),
|
|
278
|
+
onBeforeClose: (event) => this.beforeClose.emit(event),
|
|
279
|
+
onVisibleChange: (event) => this.visibleChange.emit(event),
|
|
280
|
+
},
|
|
281
|
+
});
|
|
282
|
+
}
|
|
283
|
+
ngAfterContentChecked() {
|
|
284
|
+
this._widget.patchSlots({
|
|
285
|
+
slotDefault: this.slotDefaultFromContent?.templateRef,
|
|
286
|
+
slotFooter: this.slotFooterFromContent?.templateRef,
|
|
287
|
+
slotHeader: this.slotHeaderFromContent?.templateRef,
|
|
288
|
+
slotStructure: this.slotStructureFromContent?.templateRef,
|
|
289
|
+
slotTitle: this.slotTitleFromContent?.templateRef,
|
|
290
|
+
});
|
|
291
|
+
}
|
|
292
|
+
static { this.ɵfac = /*@__PURE__*/ (() => { let ɵModalComponent_BaseFactory; return function ModalComponent_Factory(t) { return (ɵModalComponent_BaseFactory || (ɵModalComponent_BaseFactory = i0.ɵɵgetInheritedFactory(ModalComponent)))(t || ModalComponent); }; })(); }
|
|
293
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ModalComponent, selectors: [["", "auModal", ""]], contentQueries: function ModalComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
|
|
294
|
+
i0.ɵɵcontentQuery(dirIndex, ModalStructureDirective, 5);
|
|
295
|
+
i0.ɵɵcontentQuery(dirIndex, ModalHeaderDirective, 5);
|
|
296
|
+
i0.ɵɵcontentQuery(dirIndex, ModalTitleDirective, 5);
|
|
297
|
+
i0.ɵɵcontentQuery(dirIndex, ModalBodyDirective, 5);
|
|
298
|
+
i0.ɵɵcontentQuery(dirIndex, ModalFooterDirective, 5);
|
|
299
|
+
} if (rf & 2) {
|
|
300
|
+
let _t;
|
|
301
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotStructureFromContent = _t.first);
|
|
302
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotHeaderFromContent = _t.first);
|
|
303
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotTitleFromContent = _t.first);
|
|
304
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotDefaultFromContent = _t.first);
|
|
305
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotFooterFromContent = _t.first);
|
|
306
|
+
} }, inputs: { animated: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auAnimated", "animated", 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"], fullscreen: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auFullscreen", "fullscreen", auBooleanAttribute], 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"], [1, "modal-backdrop", 3, "auUseMulti"], [1, "modal", "d-block", 3, "auUseMulti"], [1, "modal-content"], [3, "auSlot", "auSlotProps"]], template: function ModalComponent_Template(rf, ctx) { if (rf & 1) {
|
|
307
|
+
i0.ɵɵprojectionDef();
|
|
308
|
+
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, 12, "div", 2);
|
|
309
|
+
} if (rf & 2) {
|
|
310
|
+
i0.ɵɵproperty("auSlotDefault", ctx.defaultSlots);
|
|
311
|
+
i0.ɵɵadvance();
|
|
312
|
+
i0.ɵɵconditional(1, !ctx.state().backdropHidden ? 1 : -1);
|
|
313
|
+
i0.ɵɵadvance();
|
|
314
|
+
i0.ɵɵconditional(2, !ctx.state().hidden ? 2 : -1);
|
|
315
|
+
} }, dependencies: [UseMultiDirective, SlotDirective, SlotDefaultDirective], encapsulation: 2, changeDetection: 0 }); }
|
|
316
|
+
}
|
|
317
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ModalComponent, [{
|
|
318
|
+
type: Component,
|
|
319
|
+
args: [{
|
|
320
|
+
selector: '[auModal]',
|
|
321
|
+
standalone: true,
|
|
322
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
323
|
+
imports: [UseMultiDirective, SlotDirective, SlotDefaultDirective],
|
|
324
|
+
template: `
|
|
325
|
+
<ng-template [auSlotDefault]="defaultSlots"><ng-content></ng-content></ng-template>
|
|
326
|
+
@if (!state().backdropHidden) {
|
|
327
|
+
<div class="modal-backdrop" [auUseMulti]="[widget.directives.backdropPortalDirective, widget.directives.backdropDirective]"></div>
|
|
328
|
+
}
|
|
329
|
+
@if (!state().hidden) {
|
|
330
|
+
<div class="modal d-block" [auUseMulti]="[widget.directives.modalPortalDirective, widget.directives.modalDirective]">
|
|
331
|
+
<div class="modal-dialog {{ state().fullscreen ? 'modal-fullscreen' : '' }}">
|
|
332
|
+
<div class="modal-content">
|
|
333
|
+
<ng-template [auSlot]="state().slotStructure" [auSlotProps]="{state: state(), widget}"></ng-template>
|
|
334
|
+
</div>
|
|
335
|
+
</div>
|
|
336
|
+
</div>
|
|
337
|
+
}
|
|
338
|
+
`,
|
|
339
|
+
}]
|
|
340
|
+
}], null, { animated: [{
|
|
341
|
+
type: Input,
|
|
342
|
+
args: [{ alias: 'auAnimated', transform: auBooleanAttribute }]
|
|
343
|
+
}], backdropTransition: [{
|
|
344
|
+
type: Input,
|
|
345
|
+
args: ['auBackdropTransition']
|
|
346
|
+
}], modalTransition: [{
|
|
347
|
+
type: Input,
|
|
348
|
+
args: ['auModalTransition']
|
|
349
|
+
}], visible: [{
|
|
350
|
+
type: Input,
|
|
351
|
+
args: [{ alias: 'auVisible', transform: auBooleanAttribute }]
|
|
352
|
+
}], backdrop: [{
|
|
353
|
+
type: Input,
|
|
354
|
+
args: [{ alias: 'auBackdrop', transform: auBooleanAttribute }]
|
|
355
|
+
}], closeOnOutsideClick: [{
|
|
356
|
+
type: Input,
|
|
357
|
+
args: [{ alias: 'auCloseOnOutsideClick', transform: auBooleanAttribute }]
|
|
358
|
+
}], container: [{
|
|
359
|
+
type: Input,
|
|
360
|
+
args: ['auContainer']
|
|
361
|
+
}], ariaCloseButtonLabel: [{
|
|
362
|
+
type: Input,
|
|
363
|
+
args: ['auAriaCloseButtonLabel']
|
|
364
|
+
}], backdropClass: [{
|
|
365
|
+
type: Input,
|
|
366
|
+
args: ['auBackdropClass']
|
|
367
|
+
}], closeButton: [{
|
|
368
|
+
type: Input,
|
|
369
|
+
args: [{ alias: 'auCloseButton', transform: auBooleanAttribute }]
|
|
370
|
+
}], className: [{
|
|
371
|
+
type: Input,
|
|
372
|
+
args: ['auClassName']
|
|
373
|
+
}], fullscreen: [{
|
|
374
|
+
type: Input,
|
|
375
|
+
args: [{ alias: 'auFullscreen', transform: auBooleanAttribute }]
|
|
376
|
+
}], slotStructure: [{
|
|
377
|
+
type: Input,
|
|
378
|
+
args: ['auSlotStructure']
|
|
379
|
+
}], slotStructureFromContent: [{
|
|
380
|
+
type: ContentChild,
|
|
381
|
+
args: [ModalStructureDirective, { static: false }]
|
|
382
|
+
}], slotHeader: [{
|
|
383
|
+
type: Input,
|
|
384
|
+
args: ['auSlotHeader']
|
|
385
|
+
}], slotHeaderFromContent: [{
|
|
386
|
+
type: ContentChild,
|
|
387
|
+
args: [ModalHeaderDirective, { static: false }]
|
|
388
|
+
}], slotTitle: [{
|
|
389
|
+
type: Input,
|
|
390
|
+
args: ['auSlotTitle']
|
|
391
|
+
}], slotTitleFromContent: [{
|
|
392
|
+
type: ContentChild,
|
|
393
|
+
args: [ModalTitleDirective, { static: false }]
|
|
394
|
+
}], slotDefault: [{
|
|
395
|
+
type: Input,
|
|
396
|
+
args: ['auSlotDefault']
|
|
397
|
+
}], slotDefaultFromContent: [{
|
|
398
|
+
type: ContentChild,
|
|
399
|
+
args: [ModalBodyDirective, { static: false }]
|
|
400
|
+
}], slotFooter: [{
|
|
401
|
+
type: Input,
|
|
402
|
+
args: ['auSlotFooter']
|
|
403
|
+
}], slotFooterFromContent: [{
|
|
404
|
+
type: ContentChild,
|
|
405
|
+
args: [ModalFooterDirective, { static: false }]
|
|
406
|
+
}], contentData: [{
|
|
407
|
+
type: Input,
|
|
408
|
+
args: ['auContentData']
|
|
409
|
+
}], visibleChange: [{
|
|
410
|
+
type: Output,
|
|
411
|
+
args: ['auVisibleChange']
|
|
412
|
+
}], beforeClose: [{
|
|
413
|
+
type: Output,
|
|
414
|
+
args: ['auBeforeClose']
|
|
415
|
+
}], hidden: [{
|
|
416
|
+
type: Output,
|
|
417
|
+
args: ['auHidden']
|
|
418
|
+
}], shown: [{
|
|
419
|
+
type: Output,
|
|
420
|
+
args: ['auShown']
|
|
421
|
+
}] }); })();
|
|
422
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ModalComponent, { className: "ModalComponent", filePath: "components/modal/modal.component.ts", lineNumber: 161 }); })();
|
|
423
|
+
//# 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 {SlotContent, TransitionFn} from '@agnos-ui/angular-headless';\nimport {\n\tBaseWidgetDirective,\n\tComponentTemplate,\n\tSlotDefaultDirective,\n\tSlotDirective,\n\tUseDirective,\n\tUseMultiDirective,\n\tauBooleanAttribute,\n} from '@agnos-ui/angular-headless';\nimport type {ModalContext, ModalProps, ModalWidget, ModalBeforeCloseEvent} from './modal';\nimport {createModal} from './modal';\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';\nimport {callWidgetFactory} from '../../config';\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, UseDirective],\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 class=\"btn-close\" [auUse]=\"widget.directives.closeButtonDirective\"></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: [UseMultiDirective, 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\" [auUseMulti]=\"[widget.directives.backdropPortalDirective, widget.directives.backdropDirective]\"></div>\n\t\t}\n\t\t@if (!state().hidden) {\n\t\t\t<div class=\"modal d-block\" [auUseMulti]=\"[widget.directives.modalPortalDirective, widget.directives.modalDirective]\">\n\t\t\t\t<div class=\"modal-dialog {{ state().fullscreen ? 'modal-fullscreen' : '' }}\">\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: 'auAnimated', transform: auBooleanAttribute}) animated: 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/**\n\t * Option to create a fullscreen modal, according to the bootstrap documentation.\n\t */\n\t@Input({alias: 'auFullscreen', transform: auBooleanAttribute}) fullscreen: boolean | 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\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"]}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { createModal as coreCreateModal } from '@agnos-ui/core-bootstrap/components/modal';
|
|
2
|
+
export * from '@agnos-ui/core-bootstrap/components/modal';
|
|
3
|
+
export const createModal = coreCreateModal;
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9tb2RhbC9tb2RhbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUMsV0FBVyxJQUFJLGVBQWUsRUFBQyxNQUFNLDJDQUEyQyxDQUFDO0FBRXpGLGNBQWMsMkNBQTJDLENBQUM7QUFNMUQsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUF3RSxlQUFzQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge0FkYXB0V2lkZ2V0U2xvdHMsIFdpZGdldFByb3BzLCBXaWRnZXRTdGF0ZSwgQWRhcHRTbG90Q29udGVudFByb3BzLCBQcm9wc0NvbmZpZ30gZnJvbSAnQGFnbm9zLXVpL2FuZ3VsYXItaGVhZGxlc3MnO1xuaW1wb3J0IHtjcmVhdGVNb2RhbCBhcyBjb3JlQ3JlYXRlTW9kYWx9IGZyb20gJ0BhZ25vcy11aS9jb3JlLWJvb3RzdHJhcC9jb21wb25lbnRzL21vZGFsJztcblxuZXhwb3J0ICogZnJvbSAnQGFnbm9zLXVpL2NvcmUtYm9vdHN0cmFwL2NvbXBvbmVudHMvbW9kYWwnO1xuXG5leHBvcnQgaW50ZXJmYWNlIE1vZGFsV2lkZ2V0PERhdGE+IGV4dGVuZHMgQWRhcHRXaWRnZXRTbG90czxpbXBvcnQoJ0BhZ25vcy11aS9jb3JlLWJvb3RzdHJhcC9jb21wb25lbnRzL21vZGFsJykuTW9kYWxXaWRnZXQ8RGF0YT4+IHt9XG5leHBvcnQgdHlwZSBNb2RhbFByb3BzPERhdGE+ID0gV2lkZ2V0UHJvcHM8TW9kYWxXaWRnZXQ8RGF0YT4+O1xuZXhwb3J0IHR5cGUgTW9kYWxTdGF0ZTxEYXRhPiA9IFdpZGdldFN0YXRlPE1vZGFsV2lkZ2V0PERhdGE+PjtcbmV4cG9ydCBpbnRlcmZhY2UgTW9kYWxDb250ZXh0PERhdGE+IGV4dGVuZHMgQWRhcHRTbG90Q29udGVudFByb3BzPGltcG9ydCgnQGFnbm9zLXVpL2NvcmUtYm9vdHN0cmFwL2NvbXBvbmVudHMvbW9kYWwnKS5Nb2RhbENvbnRleHQ8RGF0YT4+IHt9XG5leHBvcnQgY29uc3QgY3JlYXRlTW9kYWw6IDxEYXRhPihjb25maWc/OiBQcm9wc0NvbmZpZzxNb2RhbFByb3BzPERhdGE+PikgPT4gTW9kYWxXaWRnZXQ8RGF0YT4gPSBjb3JlQ3JlYXRlTW9kYWwgYXMgYW55O1xuIl19
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { ApplicationRef, createComponent, EnvironmentInjector, EventEmitter, inject, Injectable, Injector } from '@angular/core';
|
|
2
|
+
import { ModalComponent } from './modal.component';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class ModalService {
|
|
5
|
+
constructor() {
|
|
6
|
+
this._injector = inject(Injector);
|
|
7
|
+
this._applicationRef = inject(ApplicationRef);
|
|
8
|
+
}
|
|
9
|
+
async open(options, { injector = this._injector } = {}) {
|
|
10
|
+
const component = createComponent(ModalComponent, {
|
|
11
|
+
environmentInjector: injector.get(EnvironmentInjector),
|
|
12
|
+
elementInjector: injector,
|
|
13
|
+
});
|
|
14
|
+
const subscriptions = [];
|
|
15
|
+
try {
|
|
16
|
+
for (const prop of Object.keys(options)) {
|
|
17
|
+
const value = options[prop];
|
|
18
|
+
if (prop.startsWith('on')) {
|
|
19
|
+
const eventName = `${prop[2].toLowerCase()}${prop.substring(3)}`;
|
|
20
|
+
const eventEmitter = component.instance[eventName];
|
|
21
|
+
if (eventEmitter instanceof EventEmitter) {
|
|
22
|
+
subscriptions.push(eventEmitter.subscribe(value));
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
component.setInput(`au${prop.substring(0, 1).toUpperCase()}${prop.substring(1)}`, value);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
this._applicationRef.attachView(component.hostView);
|
|
30
|
+
await component.instance._widget.initialized;
|
|
31
|
+
return await component.instance.api.open();
|
|
32
|
+
}
|
|
33
|
+
finally {
|
|
34
|
+
component.destroy();
|
|
35
|
+
for (const subscription of subscriptions) {
|
|
36
|
+
subscription.unsubscribe();
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
static { this.ɵfac = function ModalService_Factory(t) { return new (t || ModalService)(); }; }
|
|
41
|
+
static { this.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: ModalService, factory: ModalService.ɵfac, providedIn: 'root' }); }
|
|
42
|
+
}
|
|
43
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ModalService, [{
|
|
44
|
+
type: Injectable,
|
|
45
|
+
args: [{ providedIn: 'root' }]
|
|
46
|
+
}], null, null); })();
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL21vZGFsL21vZGFsLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFDLGNBQWMsRUFBRSxlQUFlLEVBQUUsbUJBQW1CLEVBQUUsWUFBWSxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRS9ILE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSxtQkFBbUIsQ0FBQzs7QUFPakQsTUFBTSxPQUFPLFlBQVk7SUFEekI7UUFFa0IsY0FBUyxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUM3QixvQkFBZSxHQUFHLE1BQU0sQ0FBQyxjQUFjLENBQUMsQ0FBQztLQStCMUQ7SUE3QkEsS0FBSyxDQUFDLElBQUksQ0FBTyxPQUFrQyxFQUFFLEVBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxTQUFTLEtBQTZCLEVBQUU7UUFDN0csTUFBTSxTQUFTLEdBQUcsZUFBZSxDQUFDLGNBQWMsRUFBRTtZQUNqRCxtQkFBbUIsRUFBRSxRQUFRLENBQUMsR0FBRyxDQUFDLG1CQUFtQixDQUFDO1lBQ3RELGVBQWUsRUFBRSxRQUFRO1NBQ3pCLENBQUMsQ0FBQztRQUNILE1BQU0sYUFBYSxHQUFtQixFQUFFLENBQUM7UUFDekMsSUFBSSxDQUFDO1lBQ0osS0FBSyxNQUFNLElBQUksSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBd0MsRUFBRSxDQUFDO2dCQUNoRixNQUFNLEtBQUssR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7Z0JBQzVCLElBQUksSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDO29CQUMzQixNQUFNLFNBQVMsR0FBRyxHQUFHLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxXQUFXLEVBQUUsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7b0JBQ2pFLE1BQU0sWUFBWSxHQUFJLFNBQVMsQ0FBQyxRQUFnQixDQUFDLFNBQVMsQ0FBQyxDQUFDO29CQUM1RCxJQUFJLFlBQVksWUFBWSxZQUFZLEVBQUUsQ0FBQzt3QkFDMUMsYUFBYSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7b0JBQ25ELENBQUM7Z0JBQ0YsQ0FBQztxQkFBTSxDQUFDO29CQUNQLFNBQVMsQ0FBQyxRQUFRLENBQUMsS0FBSyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxXQUFXLEVBQUUsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsS0FBSyxDQUFDLENBQUM7Z0JBQzFGLENBQUM7WUFDRixDQUFDO1lBQ0QsSUFBSSxDQUFDLGVBQWUsQ0FBQyxVQUFVLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBQ3BELE1BQU0sU0FBUyxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDO1lBQzdDLE9BQU8sTUFBTSxTQUFTLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUM1QyxDQUFDO2dCQUFTLENBQUM7WUFDVixTQUFTLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDcEIsS0FBSyxNQUFNLFlBQVksSUFBSSxhQUFhLEVBQUUsQ0FBQztnQkFDMUMsWUFBWSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQzVCLENBQUM7UUFDRixDQUFDO0lBQ0YsQ0FBQzs2RUFoQ1csWUFBWTt1RUFBWixZQUFZLFdBQVosWUFBWSxtQkFEQSxNQUFNOztpRkFDbEIsWUFBWTtjQUR4QixVQUFVO2VBQUMsRUFBQyxVQUFVLEVBQUUsTUFBTSxFQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge01vZGFsUHJvcHN9IGZyb20gJy4vbW9kYWwnO1xuaW1wb3J0IHtBcHBsaWNhdGlvblJlZiwgY3JlYXRlQ29tcG9uZW50LCBFbnZpcm9ubWVudEluamVjdG9yLCBFdmVudEVtaXR0ZXIsIGluamVjdCwgSW5qZWN0YWJsZSwgSW5qZWN0b3J9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHR5cGUge1N1YnNjcmlwdGlvbn0gZnJvbSAncnhqcyc7XG5pbXBvcnQge01vZGFsQ29tcG9uZW50fSBmcm9tICcuL21vZGFsLmNvbXBvbmVudCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgTW9kYWxTZXJ2aWNlT3Blbk9wdGlvbnMge1xuXHRpbmplY3Rvcj86IEluamVjdG9yO1xufVxuXG5ASW5qZWN0YWJsZSh7cHJvdmlkZWRJbjogJ3Jvb3QnfSlcbmV4cG9ydCBjbGFzcyBNb2RhbFNlcnZpY2Uge1xuXHRwcml2YXRlIHJlYWRvbmx5IF9pbmplY3RvciA9IGluamVjdChJbmplY3Rvcik7XG5cdHByaXZhdGUgcmVhZG9ubHkgX2FwcGxpY2F0aW9uUmVmID0gaW5qZWN0KEFwcGxpY2F0aW9uUmVmKTtcblxuXHRhc3luYyBvcGVuPERhdGE+KG9wdGlvbnM6IFBhcnRpYWw8TW9kYWxQcm9wczxEYXRhPj4sIHtpbmplY3RvciA9IHRoaXMuX2luamVjdG9yfTogTW9kYWxTZXJ2aWNlT3Blbk9wdGlvbnMgPSB7fSk6IFByb21pc2U8YW55PiB7XG5cdFx0Y29uc3QgY29tcG9uZW50ID0gY3JlYXRlQ29tcG9uZW50KE1vZGFsQ29tcG9uZW50LCB7XG5cdFx0XHRlbnZpcm9ubWVudEluamVjdG9yOiBpbmplY3Rvci5nZXQoRW52aXJvbm1lbnRJbmplY3RvciksXG5cdFx0XHRlbGVtZW50SW5qZWN0b3I6IGluamVjdG9yLFxuXHRcdH0pO1xuXHRcdGNvbnN0IHN1YnNjcmlwdGlvbnM6IFN1YnNjcmlwdGlvbltdID0gW107XG5cdFx0dHJ5IHtcblx0XHRcdGZvciAoY29uc3QgcHJvcCBvZiBPYmplY3Qua2V5cyhvcHRpb25zKSBhcyAoc3RyaW5nICYga2V5b2YgTW9kYWxQcm9wczxEYXRhPilbXSkge1xuXHRcdFx0XHRjb25zdCB2YWx1ZSA9IG9wdGlvbnNbcHJvcF07XG5cdFx0XHRcdGlmIChwcm9wLnN0YXJ0c1dpdGgoJ29uJykpIHtcblx0XHRcdFx0XHRjb25zdCBldmVudE5hbWUgPSBgJHtwcm9wWzJdLnRvTG93ZXJDYXNlKCl9JHtwcm9wLnN1YnN0cmluZygzKX1gO1xuXHRcdFx0XHRcdGNvbnN0IGV2ZW50RW1pdHRlciA9IChjb21wb25lbnQuaW5zdGFuY2UgYXMgYW55KVtldmVudE5hbWVdO1xuXHRcdFx0XHRcdGlmIChldmVudEVtaXR0ZXIgaW5zdGFuY2VvZiBFdmVudEVtaXR0ZXIpIHtcblx0XHRcdFx0XHRcdHN1YnNjcmlwdGlvbnMucHVzaChldmVudEVtaXR0ZXIuc3Vic2NyaWJlKHZhbHVlKSk7XG5cdFx0XHRcdFx0fVxuXHRcdFx0XHR9IGVsc2Uge1xuXHRcdFx0XHRcdGNvbXBvbmVudC5zZXRJbnB1dChgYXUke3Byb3Auc3Vic3RyaW5nKDAsIDEpLnRvVXBwZXJDYXNlKCl9JHtwcm9wLnN1YnN0cmluZygxKX1gLCB2YWx1ZSk7XG5cdFx0XHRcdH1cblx0XHRcdH1cblx0XHRcdHRoaXMuX2FwcGxpY2F0aW9uUmVmLmF0dGFjaFZpZXcoY29tcG9uZW50Lmhvc3RWaWV3KTtcblx0XHRcdGF3YWl0IGNvbXBvbmVudC5pbnN0YW5jZS5fd2lkZ2V0LmluaXRpYWxpemVkO1xuXHRcdFx0cmV0dXJuIGF3YWl0IGNvbXBvbmVudC5pbnN0YW5jZS5hcGkub3BlbigpO1xuXHRcdH0gZmluYWxseSB7XG5cdFx0XHRjb21wb25lbnQuZGVzdHJveSgpO1xuXHRcdFx0Zm9yIChjb25zdCBzdWJzY3JpcHRpb24gb2Ygc3Vic2NyaXB0aW9ucykge1xuXHRcdFx0XHRzdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKTtcblx0XHRcdH1cblx0XHR9XG5cdH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from './pagination.component';
|
|
2
|
+
export * from './pagination';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9wYWdpbmF0aW9uL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3BhZ2luYXRpb24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vcGFnaW5hdGlvbic7XG4iXX0=
|