@agnos-ui/angular-bootstrap 0.4.4 → 0.5.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 +2 -2
- package/agnos-ui-angular.module.d.ts +2 -1
- package/components/accordion/accordion.component.d.ts +40 -18
- package/components/accordion/accordion.gen.d.ts +37 -9
- package/components/alert/alert.component.d.ts +29 -17
- package/components/alert/alert.gen.d.ts +21 -2
- package/components/collapse/collapse.component.d.ts +79 -0
- package/components/collapse/collapse.gen.d.ts +146 -0
- package/components/collapse/index.d.ts +2 -0
- package/components/modal/modal.component.d.ts +13 -19
- package/components/modal/modal.gen.d.ts +35 -18
- package/components/modal/modal.service.d.ts +5 -1
- package/components/pagination/pagination.component.d.ts +20 -15
- package/components/pagination/pagination.gen.d.ts +49 -29
- package/components/progressbar/progressbar.component.d.ts +32 -16
- package/components/progressbar/progressbar.gen.d.ts +21 -4
- package/components/rating/rating.component.d.ts +11 -4
- package/components/rating/rating.gen.d.ts +25 -17
- package/components/select/select.component.d.ts +24 -4
- package/components/select/select.gen.d.ts +41 -25
- package/components/slider/slider.component.d.ts +32 -23
- package/components/slider/slider.gen.d.ts +54 -33
- package/components/toast/toast.component.d.ts +29 -17
- package/components/toast/toast.gen.d.ts +22 -2
- package/config.d.ts +16 -5
- package/config.gen.d.ts +5 -0
- package/esm2022/agnos-ui-angular.module.mjs +12 -5
- package/esm2022/components/accordion/accordion.component.mjs +165 -134
- package/esm2022/components/accordion/accordion.gen.mjs +1 -1
- package/esm2022/components/alert/alert.component.mjs +90 -65
- package/esm2022/components/alert/alert.gen.mjs +1 -1
- package/esm2022/components/collapse/collapse.component.mjs +89 -0
- package/esm2022/components/collapse/collapse.gen.mjs +15 -0
- package/esm2022/components/collapse/index.mjs +3 -0
- package/esm2022/components/modal/modal.component.mjs +111 -99
- package/esm2022/components/modal/modal.gen.mjs +1 -1
- package/esm2022/components/modal/modal.service.mjs +7 -5
- package/esm2022/components/pagination/pagination.component.mjs +138 -123
- package/esm2022/components/pagination/pagination.gen.mjs +1 -1
- package/esm2022/components/progressbar/progressbar.component.mjs +94 -55
- package/esm2022/components/progressbar/progressbar.gen.mjs +1 -1
- package/esm2022/components/rating/rating.component.mjs +41 -35
- package/esm2022/components/rating/rating.gen.mjs +1 -1
- package/esm2022/components/select/select.component.mjs +103 -118
- package/esm2022/components/select/select.gen.mjs +1 -1
- package/esm2022/components/slider/slider.component.mjs +126 -111
- package/esm2022/components/slider/slider.gen.mjs +1 -1
- package/esm2022/components/toast/toast.component.mjs +106 -81
- package/esm2022/components/toast/toast.gen.mjs +1 -1
- package/esm2022/config.gen.mjs +1 -1
- package/esm2022/config.mjs +17 -1
- package/esm2022/index.mjs +2 -1
- package/fesm2022/agnos-ui-angular-bootstrap.mjs +1085 -806
- package/fesm2022/agnos-ui-angular-bootstrap.mjs.map +1 -1
- package/index.d.ts +8 -7
- package/package.json +9 -8
|
@@ -1,18 +1,17 @@
|
|
|
1
|
-
import { BaseWidgetDirective, ComponentTemplate,
|
|
1
|
+
import { BaseWidgetDirective, ComponentTemplate, SlotDirective, UseDirective, UseMultiDirective, auBooleanAttribute } from '@agnos-ui/angular-headless';
|
|
2
2
|
import { createModal } from './modal.gen';
|
|
3
|
-
import { writable } from '@amadeus-it-group/tansu';
|
|
4
3
|
import { ChangeDetectionStrategy, Component, ContentChild, Directive, EventEmitter, Input, Output, TemplateRef, ViewChild, inject, } from '@angular/core';
|
|
5
4
|
import { callWidgetFactory } from '../../config';
|
|
6
5
|
import * as i0 from "@angular/core";
|
|
7
6
|
const _c0 = ["header"];
|
|
8
7
|
const _c1 = ["structure"];
|
|
9
|
-
const _c2 = (a0, a1) => ({ state: a0,
|
|
8
|
+
const _c2 = (a0, a1, a2) => ({ state: a0, api: a1, directives: a2 });
|
|
10
9
|
function ModalDefaultSlotsComponent_ng_template_0_ng_template_1_Template(rf, ctx) { }
|
|
11
10
|
function ModalDefaultSlotsComponent_ng_template_0_Conditional_2_Template(rf, ctx) { if (rf & 1) {
|
|
12
11
|
i0.ɵɵelement(0, "button", 6);
|
|
13
12
|
} if (rf & 2) {
|
|
14
|
-
const
|
|
15
|
-
i0.ɵɵproperty("auUse",
|
|
13
|
+
const directives_r1 = i0.ɵɵnextContext().directives;
|
|
14
|
+
i0.ɵɵproperty("auUse", directives_r1.closeButtonDirective);
|
|
16
15
|
} }
|
|
17
16
|
function ModalDefaultSlotsComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) {
|
|
18
17
|
i0.ɵɵelementStart(0, "h5", 4);
|
|
@@ -21,11 +20,12 @@ function ModalDefaultSlotsComponent_ng_template_0_Template(rf, ctx) { if (rf & 1
|
|
|
21
20
|
i0.ɵɵtemplate(2, ModalDefaultSlotsComponent_ng_template_0_Conditional_2_Template, 1, 1, "button", 6);
|
|
22
21
|
} if (rf & 2) {
|
|
23
22
|
const state_r2 = ctx.state;
|
|
24
|
-
const
|
|
23
|
+
const api_r3 = ctx.api;
|
|
24
|
+
const directives_r1 = ctx.directives;
|
|
25
25
|
i0.ɵɵadvance();
|
|
26
|
-
i0.ɵɵproperty("auSlot", state_r2.title)("auSlotProps", i0.ɵɵ
|
|
26
|
+
i0.ɵɵproperty("auSlot", state_r2.title())("auSlotProps", i0.ɵɵpureFunction3(3, _c2, state_r2, api_r3, directives_r1));
|
|
27
27
|
i0.ɵɵadvance();
|
|
28
|
-
i0.ɵɵconditional(state_r2.closeButton ? 2 : -1);
|
|
28
|
+
i0.ɵɵconditional(state_r2.closeButton() ? 2 : -1);
|
|
29
29
|
} }
|
|
30
30
|
function ModalDefaultSlotsComponent_ng_template_2_Conditional_0_ng_template_1_Template(rf, ctx) { }
|
|
31
31
|
function ModalDefaultSlotsComponent_ng_template_2_Conditional_0_Template(rf, ctx) { if (rf & 1) {
|
|
@@ -33,11 +33,12 @@ function ModalDefaultSlotsComponent_ng_template_2_Conditional_0_Template(rf, ctx
|
|
|
33
33
|
i0.ɵɵtemplate(1, ModalDefaultSlotsComponent_ng_template_2_Conditional_0_ng_template_1_Template, 0, 0, "ng-template", 5);
|
|
34
34
|
i0.ɵɵelementEnd();
|
|
35
35
|
} if (rf & 2) {
|
|
36
|
-
const
|
|
37
|
-
const
|
|
38
|
-
const
|
|
36
|
+
const ctx_r3 = i0.ɵɵnextContext();
|
|
37
|
+
const state_r5 = ctx_r3.state;
|
|
38
|
+
const api_r6 = ctx_r3.api;
|
|
39
|
+
const directives_r7 = ctx_r3.directives;
|
|
39
40
|
i0.ɵɵadvance();
|
|
40
|
-
i0.ɵɵproperty("auSlot",
|
|
41
|
+
i0.ɵɵproperty("auSlot", state_r5.header())("auSlotProps", i0.ɵɵpureFunction3(2, _c2, state_r5, api_r6, directives_r7));
|
|
41
42
|
} }
|
|
42
43
|
function ModalDefaultSlotsComponent_ng_template_2_ng_template_2_Template(rf, ctx) { }
|
|
43
44
|
function ModalDefaultSlotsComponent_ng_template_2_Conditional_3_ng_template_1_Template(rf, ctx) { }
|
|
@@ -46,63 +47,67 @@ function ModalDefaultSlotsComponent_ng_template_2_Conditional_3_Template(rf, ctx
|
|
|
46
47
|
i0.ɵɵtemplate(1, ModalDefaultSlotsComponent_ng_template_2_Conditional_3_ng_template_1_Template, 0, 0, "ng-template", 5);
|
|
47
48
|
i0.ɵɵelementEnd();
|
|
48
49
|
} if (rf & 2) {
|
|
49
|
-
const
|
|
50
|
-
const
|
|
51
|
-
const
|
|
50
|
+
const ctx_r3 = i0.ɵɵnextContext();
|
|
51
|
+
const state_r5 = ctx_r3.state;
|
|
52
|
+
const api_r6 = ctx_r3.api;
|
|
53
|
+
const directives_r7 = ctx_r3.directives;
|
|
52
54
|
i0.ɵɵadvance();
|
|
53
|
-
i0.ɵɵproperty("auSlot",
|
|
55
|
+
i0.ɵɵproperty("auSlot", state_r5.footer())("auSlotProps", i0.ɵɵpureFunction3(2, _c2, state_r5, api_r6, directives_r7));
|
|
54
56
|
} }
|
|
55
57
|
function ModalDefaultSlotsComponent_ng_template_2_Template(rf, ctx) { if (rf & 1) {
|
|
56
|
-
i0.ɵɵtemplate(0, ModalDefaultSlotsComponent_ng_template_2_Conditional_0_Template, 2,
|
|
58
|
+
i0.ɵɵtemplate(0, ModalDefaultSlotsComponent_ng_template_2_Conditional_0_Template, 2, 6, "div", 7);
|
|
57
59
|
i0.ɵɵelementStart(1, "div", 8);
|
|
58
60
|
i0.ɵɵtemplate(2, ModalDefaultSlotsComponent_ng_template_2_ng_template_2_Template, 0, 0, "ng-template", 5);
|
|
59
61
|
i0.ɵɵelementEnd();
|
|
60
|
-
i0.ɵɵtemplate(3, ModalDefaultSlotsComponent_ng_template_2_Conditional_3_Template, 2,
|
|
62
|
+
i0.ɵɵtemplate(3, ModalDefaultSlotsComponent_ng_template_2_Conditional_3_Template, 2, 6, "div", 9);
|
|
61
63
|
} if (rf & 2) {
|
|
62
|
-
const
|
|
63
|
-
const
|
|
64
|
-
|
|
64
|
+
const state_r5 = ctx.state;
|
|
65
|
+
const api_r6 = ctx.api;
|
|
66
|
+
const directives_r7 = ctx.directives;
|
|
67
|
+
i0.ɵɵconditional(state_r5.title() ? 0 : -1);
|
|
65
68
|
i0.ɵɵadvance(2);
|
|
66
|
-
i0.ɵɵproperty("auSlot",
|
|
69
|
+
i0.ɵɵproperty("auSlot", state_r5.children())("auSlotProps", i0.ɵɵpureFunction3(4, _c2, state_r5, api_r6, directives_r7));
|
|
67
70
|
i0.ɵɵadvance();
|
|
68
|
-
i0.ɵɵconditional(
|
|
71
|
+
i0.ɵɵconditional(state_r5.footer() ? 3 : -1);
|
|
69
72
|
} }
|
|
70
|
-
const _c3 = ["
|
|
71
|
-
const _c4 = ["
|
|
72
|
-
const _c5 =
|
|
73
|
+
const _c3 = ["content"];
|
|
74
|
+
const _c4 = ["auModal", ""];
|
|
75
|
+
const _c5 = ["*"];
|
|
76
|
+
const _c6 = (a0, a1) => [a0, a1];
|
|
73
77
|
function ModalComponent_ng_template_0_Template(rf, ctx) { if (rf & 1) {
|
|
74
78
|
i0.ɵɵprojection(0);
|
|
75
79
|
} }
|
|
76
|
-
function
|
|
80
|
+
function ModalComponent_Conditional_2_Template(rf, ctx) { if (rf & 1) {
|
|
77
81
|
i0.ɵɵelement(0, "div", 1);
|
|
78
82
|
} if (rf & 2) {
|
|
79
83
|
const ctx_r0 = i0.ɵɵnextContext();
|
|
80
|
-
i0.ɵɵproperty("auUseMulti", i0.ɵɵpureFunction2(1,
|
|
84
|
+
i0.ɵɵproperty("auUseMulti", i0.ɵɵpureFunction2(1, _c6, ctx_r0.directives.backdropPortalDirective, ctx_r0.directives.backdropDirective));
|
|
81
85
|
} }
|
|
82
|
-
function
|
|
83
|
-
function
|
|
86
|
+
function ModalComponent_Conditional_3_ng_template_3_Template(rf, ctx) { }
|
|
87
|
+
function ModalComponent_Conditional_3_Template(rf, ctx) { if (rf & 1) {
|
|
84
88
|
i0.ɵɵelementStart(0, "div", 2)(1, "div")(2, "div", 3);
|
|
85
|
-
i0.ɵɵtemplate(3,
|
|
89
|
+
i0.ɵɵtemplate(3, ModalComponent_Conditional_3_ng_template_3_Template, 0, 0, "ng-template", 4);
|
|
86
90
|
i0.ɵɵelementEnd()()();
|
|
87
91
|
} if (rf & 2) {
|
|
88
92
|
const ctx_r0 = i0.ɵɵnextContext();
|
|
89
|
-
i0.ɵɵproperty("auUseMulti", i0.ɵɵpureFunction2(6,
|
|
93
|
+
i0.ɵɵproperty("auUseMulti", i0.ɵɵpureFunction2(6, _c6, ctx_r0.directives.modalPortalDirective, ctx_r0.directives.modalDirective));
|
|
90
94
|
i0.ɵɵadvance();
|
|
91
|
-
i0.ɵɵclassMapInterpolate1("modal-dialog ", ctx_r0.state()
|
|
95
|
+
i0.ɵɵclassMapInterpolate1("modal-dialog ", ctx_r0.state.fullscreen() ? "modal-fullscreen" : "", "");
|
|
92
96
|
i0.ɵɵadvance(2);
|
|
93
|
-
i0.ɵɵproperty("auSlot", ctx_r0.state
|
|
97
|
+
i0.ɵɵproperty("auSlot", ctx_r0.state.structure())("auSlotProps", i0.ɵɵpureFunction3(9, _c2, ctx_r0.state, ctx_r0.api, ctx_r0.directives));
|
|
94
98
|
} }
|
|
95
99
|
/**
|
|
96
100
|
* Directive to provide the slot structure for the modal widget.
|
|
101
|
+
* This directive provides a template reference for the {@link ModalContext<Data>}.
|
|
97
102
|
*/
|
|
98
103
|
export class ModalStructureDirective {
|
|
99
104
|
constructor() {
|
|
100
105
|
this.templateRef = inject((TemplateRef));
|
|
101
106
|
}
|
|
102
|
-
static ngTemplateContextGuard(
|
|
107
|
+
static ngTemplateContextGuard(_dir, context) {
|
|
103
108
|
return true;
|
|
104
109
|
}
|
|
105
|
-
static { this.ɵfac = function ModalStructureDirective_Factory(
|
|
110
|
+
static { this.ɵfac = function ModalStructureDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ModalStructureDirective)(); }; }
|
|
106
111
|
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ModalStructureDirective, selectors: [["ng-template", "auModalStructure", ""]], standalone: true }); }
|
|
107
112
|
}
|
|
108
113
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ModalStructureDirective, [{
|
|
@@ -111,6 +116,7 @@ export class ModalStructureDirective {
|
|
|
111
116
|
}], null, null); })();
|
|
112
117
|
/**
|
|
113
118
|
* Directive to provide the slot header for the modal widget.
|
|
119
|
+
* This directive provides a template reference for the {@link ModalContext<Data>}.
|
|
114
120
|
*/
|
|
115
121
|
export class ModalHeaderDirective {
|
|
116
122
|
constructor() {
|
|
@@ -119,7 +125,7 @@ export class ModalHeaderDirective {
|
|
|
119
125
|
static ngTemplateContextGuard(_dir, context) {
|
|
120
126
|
return true;
|
|
121
127
|
}
|
|
122
|
-
static { this.ɵfac = function ModalHeaderDirective_Factory(
|
|
128
|
+
static { this.ɵfac = function ModalHeaderDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ModalHeaderDirective)(); }; }
|
|
123
129
|
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ModalHeaderDirective, selectors: [["ng-template", "auModalHeader", ""]], standalone: true }); }
|
|
124
130
|
}
|
|
125
131
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ModalHeaderDirective, [{
|
|
@@ -128,6 +134,7 @@ export class ModalHeaderDirective {
|
|
|
128
134
|
}], null, null); })();
|
|
129
135
|
/**
|
|
130
136
|
* Directive to provide the slot title for the modal widget.
|
|
137
|
+
* This directive provides a template reference for the {@link ModalContext<Data>}.
|
|
131
138
|
*/
|
|
132
139
|
export class ModalTitleDirective {
|
|
133
140
|
constructor() {
|
|
@@ -136,7 +143,7 @@ export class ModalTitleDirective {
|
|
|
136
143
|
static ngTemplateContextGuard(_dir, context) {
|
|
137
144
|
return true;
|
|
138
145
|
}
|
|
139
|
-
static { this.ɵfac = function ModalTitleDirective_Factory(
|
|
146
|
+
static { this.ɵfac = function ModalTitleDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ModalTitleDirective)(); }; }
|
|
140
147
|
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ModalTitleDirective, selectors: [["ng-template", "auModalTitle", ""]], standalone: true }); }
|
|
141
148
|
}
|
|
142
149
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ModalTitleDirective, [{
|
|
@@ -145,6 +152,7 @@ export class ModalTitleDirective {
|
|
|
145
152
|
}], null, null); })();
|
|
146
153
|
/**
|
|
147
154
|
* Directive to provide the default slot for the modal widget.
|
|
155
|
+
* This directive provides a template reference for the {@link ModalContext<Data>}.
|
|
148
156
|
*/
|
|
149
157
|
export class ModalBodyDirective {
|
|
150
158
|
constructor() {
|
|
@@ -153,7 +161,7 @@ export class ModalBodyDirective {
|
|
|
153
161
|
static ngTemplateContextGuard(_dir, context) {
|
|
154
162
|
return true;
|
|
155
163
|
}
|
|
156
|
-
static { this.ɵfac = function ModalBodyDirective_Factory(
|
|
164
|
+
static { this.ɵfac = function ModalBodyDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ModalBodyDirective)(); }; }
|
|
157
165
|
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ModalBodyDirective, selectors: [["ng-template", "auModalBody", ""]], standalone: true }); }
|
|
158
166
|
}
|
|
159
167
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ModalBodyDirective, [{
|
|
@@ -162,6 +170,7 @@ export class ModalBodyDirective {
|
|
|
162
170
|
}], null, null); })();
|
|
163
171
|
/**
|
|
164
172
|
* Directive to provide the slot footer for the modal widget.
|
|
173
|
+
* This directive provides a template reference for the {@link ModalContext<Data>}.
|
|
165
174
|
*/
|
|
166
175
|
export class ModalFooterDirective {
|
|
167
176
|
constructor() {
|
|
@@ -170,7 +179,7 @@ export class ModalFooterDirective {
|
|
|
170
179
|
static ngTemplateContextGuard(_dir, context) {
|
|
171
180
|
return true;
|
|
172
181
|
}
|
|
173
|
-
static { this.ɵfac = function ModalFooterDirective_Factory(
|
|
182
|
+
static { this.ɵfac = function ModalFooterDirective_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ModalFooterDirective)(); }; }
|
|
174
183
|
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ModalFooterDirective, selectors: [["ng-template", "auModalFooter", ""]], standalone: true }); }
|
|
175
184
|
}
|
|
176
185
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ModalFooterDirective, [{
|
|
@@ -180,8 +189,8 @@ export class ModalFooterDirective {
|
|
|
180
189
|
/**
|
|
181
190
|
* Component containing the default slots for the modal.
|
|
182
191
|
*/
|
|
183
|
-
|
|
184
|
-
static { this.ɵfac = function ModalDefaultSlotsComponent_Factory(
|
|
192
|
+
class ModalDefaultSlotsComponent {
|
|
193
|
+
static { this.ɵfac = function ModalDefaultSlotsComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ModalDefaultSlotsComponent)(); }; }
|
|
185
194
|
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ModalDefaultSlotsComponent, selectors: [["ng-component"]], viewQuery: function ModalDefaultSlotsComponent_Query(rf, ctx) { if (rf & 1) {
|
|
186
195
|
i0.ɵɵviewQuery(_c0, 7);
|
|
187
196
|
i0.ɵɵviewQuery(_c1, 7);
|
|
@@ -190,7 +199,7 @@ export class ModalDefaultSlotsComponent {
|
|
|
190
199
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.header = _t.first);
|
|
191
200
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.structure = _t.first);
|
|
192
201
|
} }, 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,
|
|
202
|
+
i0.ɵɵtemplate(0, ModalDefaultSlotsComponent_ng_template_0_Template, 3, 7, "ng-template", 2, 0, i0.ɵɵtemplateRefExtractor)(2, ModalDefaultSlotsComponent_ng_template_2_Template, 4, 8, "ng-template", 3, 1, i0.ɵɵtemplateRefExtractor);
|
|
194
203
|
} }, dependencies: [SlotDirective, ModalHeaderDirective, ModalStructureDirective, UseDirective], encapsulation: 2, changeDetection: 0 }); }
|
|
195
204
|
}
|
|
196
205
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ModalDefaultSlotsComponent, [{
|
|
@@ -200,26 +209,26 @@ export class ModalDefaultSlotsComponent {
|
|
|
200
209
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
201
210
|
imports: [SlotDirective, ModalHeaderDirective, ModalStructureDirective, UseDirective],
|
|
202
211
|
template: `
|
|
203
|
-
<ng-template auModalHeader #header let-state="state" let-
|
|
212
|
+
<ng-template auModalHeader #header let-state="state" let-api="api" let-directives="directives">
|
|
204
213
|
<h5 class="modal-title">
|
|
205
|
-
<ng-template [auSlot]="state.title" [auSlotProps]="{state,
|
|
214
|
+
<ng-template [auSlot]="state.title()" [auSlotProps]="{state, api, directives}"></ng-template>
|
|
206
215
|
</h5>
|
|
207
|
-
@if (state.closeButton) {
|
|
208
|
-
<button class="btn-close" [auUse]="
|
|
216
|
+
@if (state.closeButton()) {
|
|
217
|
+
<button class="btn-close" [auUse]="directives.closeButtonDirective"></button>
|
|
209
218
|
}
|
|
210
219
|
</ng-template>
|
|
211
|
-
<ng-template auModalStructure #structure let-state="state" let-
|
|
212
|
-
@if (state.title) {
|
|
220
|
+
<ng-template auModalStructure #structure let-state="state" let-api="api" let-directives="directives">
|
|
221
|
+
@if (state.title()) {
|
|
213
222
|
<div class="modal-header">
|
|
214
|
-
<ng-template [auSlot]="state.header" [auSlotProps]="{state,
|
|
223
|
+
<ng-template [auSlot]="state.header()" [auSlotProps]="{state, api, directives}"></ng-template>
|
|
215
224
|
</div>
|
|
216
225
|
}
|
|
217
226
|
<div class="modal-body">
|
|
218
|
-
<ng-template [auSlot]="state.children" [auSlotProps]="{state,
|
|
227
|
+
<ng-template [auSlot]="state.children()" [auSlotProps]="{state, api, directives}"></ng-template>
|
|
219
228
|
</div>
|
|
220
|
-
@if (state.footer) {
|
|
229
|
+
@if (state.footer()) {
|
|
221
230
|
<div class="modal-footer">
|
|
222
|
-
<ng-template [auSlot]="state.footer" [auSlotProps]="{state,
|
|
231
|
+
<ng-template [auSlot]="state.footer()" [auSlotProps]="{state, api, directives}"></ng-template>
|
|
223
232
|
</div>
|
|
224
233
|
}
|
|
225
234
|
</ng-template>
|
|
@@ -232,7 +241,7 @@ export class ModalDefaultSlotsComponent {
|
|
|
232
241
|
type: ViewChild,
|
|
233
242
|
args: ['structure', { static: true }]
|
|
234
243
|
}] }); })();
|
|
235
|
-
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ModalDefaultSlotsComponent, { className: "ModalDefaultSlotsComponent", filePath: "components/modal/modal.component.ts", lineNumber:
|
|
244
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ModalDefaultSlotsComponent, { className: "ModalDefaultSlotsComponent", filePath: "components/modal/modal.component.ts", lineNumber: 112 }); })();
|
|
236
245
|
/**
|
|
237
246
|
* Default slot for modal header.
|
|
238
247
|
*/
|
|
@@ -241,16 +250,33 @@ export const modalDefaultSlotHeader = new ComponentTemplate(ModalDefaultSlotsCom
|
|
|
241
250
|
* Default slot for modal structure.
|
|
242
251
|
*/
|
|
243
252
|
export const modalDefaultSlotStructure = new ComponentTemplate(ModalDefaultSlotsComponent, 'structure');
|
|
244
|
-
const defaultConfig = {
|
|
245
|
-
header: modalDefaultSlotHeader,
|
|
246
|
-
structure: modalDefaultSlotStructure,
|
|
247
|
-
};
|
|
248
253
|
/**
|
|
249
254
|
* Modal component.
|
|
250
255
|
*/
|
|
251
256
|
export class ModalComponent extends BaseWidgetDirective {
|
|
252
257
|
constructor() {
|
|
253
|
-
super(
|
|
258
|
+
super(callWidgetFactory({
|
|
259
|
+
factory: createModal,
|
|
260
|
+
widgetName: 'modal',
|
|
261
|
+
defaultConfig: {
|
|
262
|
+
header: modalDefaultSlotHeader,
|
|
263
|
+
structure: modalDefaultSlotStructure,
|
|
264
|
+
},
|
|
265
|
+
events: {
|
|
266
|
+
onShown: () => this.shown.emit(),
|
|
267
|
+
onHidden: () => this.hidden.emit(),
|
|
268
|
+
onBeforeClose: (event) => this.beforeClose.emit(event),
|
|
269
|
+
onVisibleChange: (event) => this.visibleChange.emit(event),
|
|
270
|
+
},
|
|
271
|
+
slotTemplates: () => ({
|
|
272
|
+
children: this.slotDefaultFromContent?.templateRef,
|
|
273
|
+
footer: this.slotFooterFromContent?.templateRef,
|
|
274
|
+
header: this.slotHeaderFromContent?.templateRef,
|
|
275
|
+
structure: this.slotStructureFromContent?.templateRef,
|
|
276
|
+
title: this.slotTitleFromContent?.templateRef,
|
|
277
|
+
}),
|
|
278
|
+
slotChildren: () => this.slotChildren,
|
|
279
|
+
}));
|
|
254
280
|
/**
|
|
255
281
|
* Event to be triggered when the visible property changes.
|
|
256
282
|
*
|
|
@@ -292,29 +318,8 @@ export class ModalComponent extends BaseWidgetDirective {
|
|
|
292
318
|
* ```
|
|
293
319
|
*/
|
|
294
320
|
this.shown = new EventEmitter();
|
|
295
|
-
this.defaultSlots = writable(defaultConfig);
|
|
296
|
-
this._widget = callWidgetFactory({
|
|
297
|
-
factory: createModal,
|
|
298
|
-
widgetName: 'modal',
|
|
299
|
-
defaultConfig: this.defaultSlots,
|
|
300
|
-
events: {
|
|
301
|
-
onShown: () => this.shown.emit(),
|
|
302
|
-
onHidden: () => this.hidden.emit(),
|
|
303
|
-
onBeforeClose: (event) => this.beforeClose.emit(event),
|
|
304
|
-
onVisibleChange: (event) => this.visibleChange.emit(event),
|
|
305
|
-
},
|
|
306
|
-
});
|
|
307
|
-
}
|
|
308
|
-
ngAfterContentChecked() {
|
|
309
|
-
this._widget.patchSlots({
|
|
310
|
-
children: this.slotDefaultFromContent?.templateRef,
|
|
311
|
-
footer: this.slotFooterFromContent?.templateRef,
|
|
312
|
-
header: this.slotHeaderFromContent?.templateRef,
|
|
313
|
-
structure: this.slotStructureFromContent?.templateRef,
|
|
314
|
-
title: this.slotTitleFromContent?.templateRef,
|
|
315
|
-
});
|
|
316
321
|
}
|
|
317
|
-
static { this.ɵfac =
|
|
322
|
+
static { this.ɵfac = function ModalComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ModalComponent)(); }; }
|
|
318
323
|
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ModalComponent, selectors: [["", "auModal", ""]], contentQueries: function ModalComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
|
|
319
324
|
i0.ɵɵcontentQuery(dirIndex, ModalStructureDirective, 5);
|
|
320
325
|
i0.ɵɵcontentQuery(dirIndex, ModalHeaderDirective, 5);
|
|
@@ -328,16 +333,20 @@ export class ModalComponent extends BaseWidgetDirective {
|
|
|
328
333
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotTitleFromContent = _t.first);
|
|
329
334
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotDefaultFromContent = _t.first);
|
|
330
335
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotFooterFromContent = _t.first);
|
|
331
|
-
} },
|
|
336
|
+
} }, viewQuery: function ModalComponent_Query(rf, ctx) { if (rf & 1) {
|
|
337
|
+
i0.ɵɵviewQuery(_c3, 7);
|
|
338
|
+
} if (rf & 2) {
|
|
339
|
+
let _t;
|
|
340
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotChildren = _t.first);
|
|
341
|
+
} }, inputs: { animated: [2, "auAnimated", "animated", auBooleanAttribute], backdropTransition: [0, "auBackdropTransition", "backdropTransition"], modalTransition: [0, "auModalTransition", "modalTransition"], visible: [2, "auVisible", "visible", auBooleanAttribute], backdrop: [2, "auBackdrop", "backdrop", auBooleanAttribute], closeOnOutsideClick: [2, "auCloseOnOutsideClick", "closeOnOutsideClick", auBooleanAttribute], container: [0, "auContainer", "container"], ariaCloseButtonLabel: [0, "auAriaCloseButtonLabel", "ariaCloseButtonLabel"], backdropClass: [0, "auBackdropClass", "backdropClass"], closeButton: [2, "auCloseButton", "closeButton", auBooleanAttribute], className: [0, "auClassName", "className"], fullscreen: [2, "auFullscreen", "fullscreen", auBooleanAttribute], structure: [0, "auStructure", "structure"], header: [0, "auHeader", "header"], title: [0, "auTitle", "title"], children: [0, "auChildren", "children"], footer: [0, "auFooter", "footer"], contentData: [0, "auContentData", "contentData"] }, outputs: { visibleChange: "auVisibleChange", beforeClose: "auBeforeClose", hidden: "auHidden", shown: "auShown" }, standalone: true, features: [i0.ɵɵInputTransformsFeature, i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], attrs: _c4, ngContentSelectors: _c5, decls: 4, vars: 2, consts: [["content", ""], [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) {
|
|
332
342
|
i0.ɵɵprojectionDef();
|
|
333
|
-
i0.ɵɵtemplate(0, ModalComponent_ng_template_0_Template, 1, 0, "ng-template", 0)(
|
|
343
|
+
i0.ɵɵtemplate(0, ModalComponent_ng_template_0_Template, 1, 0, "ng-template", null, 0, i0.ɵɵtemplateRefExtractor)(2, ModalComponent_Conditional_2_Template, 1, 4, "div", 1)(3, ModalComponent_Conditional_3_Template, 4, 13, "div", 2);
|
|
334
344
|
} if (rf & 2) {
|
|
335
|
-
i0.ɵɵ
|
|
336
|
-
i0.ɵɵ
|
|
337
|
-
i0.ɵɵconditional(!ctx.state().backdropHidden ? 1 : -1);
|
|
345
|
+
i0.ɵɵadvance(2);
|
|
346
|
+
i0.ɵɵconditional(!ctx.state.backdropHidden() ? 2 : -1);
|
|
338
347
|
i0.ɵɵadvance();
|
|
339
|
-
i0.ɵɵconditional(!ctx.state()
|
|
340
|
-
} }, dependencies: [UseMultiDirective, SlotDirective
|
|
348
|
+
i0.ɵɵconditional(!ctx.state.hidden() ? 3 : -1);
|
|
349
|
+
} }, dependencies: [UseMultiDirective, SlotDirective], encapsulation: 2, changeDetection: 0 }); }
|
|
341
350
|
}
|
|
342
351
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ModalComponent, [{
|
|
343
352
|
type: Component,
|
|
@@ -345,24 +354,24 @@ export class ModalComponent extends BaseWidgetDirective {
|
|
|
345
354
|
selector: '[auModal]',
|
|
346
355
|
standalone: true,
|
|
347
356
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
348
|
-
imports: [UseMultiDirective, SlotDirective
|
|
357
|
+
imports: [UseMultiDirective, SlotDirective],
|
|
349
358
|
template: `
|
|
350
|
-
<ng-template
|
|
351
|
-
@if (!state
|
|
352
|
-
<div class="modal-backdrop" [auUseMulti]="[
|
|
359
|
+
<ng-template #content><ng-content></ng-content></ng-template>
|
|
360
|
+
@if (!state.backdropHidden()) {
|
|
361
|
+
<div class="modal-backdrop" [auUseMulti]="[directives.backdropPortalDirective, directives.backdropDirective]"></div>
|
|
353
362
|
}
|
|
354
|
-
@if (!state
|
|
355
|
-
<div class="modal d-block" [auUseMulti]="[
|
|
356
|
-
<div class="modal-dialog {{ state()
|
|
363
|
+
@if (!state.hidden()) {
|
|
364
|
+
<div class="modal d-block" [auUseMulti]="[directives.modalPortalDirective, directives.modalDirective]">
|
|
365
|
+
<div class="modal-dialog {{ state.fullscreen() ? 'modal-fullscreen' : '' }}">
|
|
357
366
|
<div class="modal-content">
|
|
358
|
-
<ng-template [auSlot]="state()
|
|
367
|
+
<ng-template [auSlot]="state.structure()" [auSlotProps]="{state, api, directives}"></ng-template>
|
|
359
368
|
</div>
|
|
360
369
|
</div>
|
|
361
370
|
</div>
|
|
362
371
|
}
|
|
363
372
|
`,
|
|
364
373
|
}]
|
|
365
|
-
}],
|
|
374
|
+
}], () => [], { animated: [{
|
|
366
375
|
type: Input,
|
|
367
376
|
args: [{ alias: 'auAnimated', transform: auBooleanAttribute }]
|
|
368
377
|
}], backdropTransition: [{
|
|
@@ -443,6 +452,9 @@ export class ModalComponent extends BaseWidgetDirective {
|
|
|
443
452
|
}], shown: [{
|
|
444
453
|
type: Output,
|
|
445
454
|
args: ['auShown']
|
|
455
|
+
}], slotChildren: [{
|
|
456
|
+
type: ViewChild,
|
|
457
|
+
args: ['content', { static: true }]
|
|
446
458
|
}] }); })();
|
|
447
|
-
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ModalComponent, { className: "ModalComponent", filePath: "components/modal/modal.component.ts", lineNumber:
|
|
448
|
-
//# 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\tContentAsSlotDirective,\n\tSlotDirective,\n\tUseDirective,\n\tUseMultiDirective,\n\tauBooleanAttribute,\n} from '@agnos-ui/angular-headless';\nimport type {ModalContext, ModalProps, ModalWidget, ModalBeforeCloseEvent} from './modal.gen';\nimport {createModal} from './modal.gen';\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.title\" [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.title) {\n\t\t\t\t<div class=\"modal-header\">\n\t\t\t\t\t<ng-template [auSlot]=\"state.header\" [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.children\" [auSlotProps]=\"{state, widget}\"></ng-template>\n\t\t\t</div>\n\t\t\t@if (state.footer) {\n\t\t\t\t<div class=\"modal-footer\">\n\t\t\t\t\t<ng-template [auSlot]=\"state.footer\" [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\theader: modalDefaultSlotHeader,\n\tstructure: modalDefaultSlotStructure,\n};\n\n/**\n * Modal component.\n */\n@Component({\n\tselector: '[auModal]',\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [UseMultiDirective, SlotDirective, ContentAsSlotDirective],\n\ttemplate: `\n\t\t<ng-template [auContentAsSlot]=\"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().structure\" [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 * @defaultValue `true`\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 * @defaultValue `fadeTransition`\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 * @defaultValue `fadeTransition`\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 * @defaultValue `false`\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 * @defaultValue `true`\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 * @defaultValue `true`\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 * @defaultValue\n\t * ```ts\n\t * typeof window !== 'undefined' ? document.body : null\n\t * ```\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 * @defaultValue `'Close'`\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 * @defaultValue `''`\n\t */\n\t@Input('auBackdropClass') backdropClass: string | undefined;\n\n\t/**\n\t * Whether to display the close button.\n\t *\n\t * @defaultValue `true`\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 * @defaultValue `''`\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 * @defaultValue `false`\n\t */\n\t@Input({alias: 'auFullscreen', transform: auBooleanAttribute}) fullscreen: boolean | undefined;\n\n\t/**\n\t * Structure of the modal.\n\t * The default structure uses {@link ModalProps.header|header}, {@link ModalProps.children|children} and {@link ModalProps.footer|footer}.\n\t */\n\t@Input('auStructure') structure: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalStructureDirective, {static: false})\n\tslotStructureFromContent: ModalStructureDirective<Data> | undefined;\n\n\t/**\n\t * Header of the modal. The default header includes {@link ModalProps.title|title}.\n\t */\n\t@Input('auHeader') header: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalHeaderDirective, {static: false})\n\tslotHeaderFromContent: ModalHeaderDirective<Data> | undefined;\n\n\t/**\n\t * Title of the modal.\n\t */\n\t@Input('auTitle') title: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalTitleDirective, {static: false})\n\tslotTitleFromContent: ModalTitleDirective<Data> | undefined;\n\n\t/**\n\t * Body of the modal.\n\t */\n\t@Input('auChildren') children: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalBodyDirective, {static: false})\n\tslotDefaultFromContent: ModalBodyDirective<Data> | undefined;\n\n\t/**\n\t * Footer of the modal.\n\t */\n\t@Input('auFooter') footer: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalFooterDirective, {static: false})\n\tslotFooterFromContent: ModalFooterDirective<Data> | undefined;\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 * @param visible - new value of the visible propery\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\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 {@link ModalApi.close|close} method was called).\n\t *\n\t * @param event - event giving access to the argument given to the {@link ModalApi.close|close} method and allowing\n\t * to cancel the close process.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\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 * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\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 * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\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\tchildren: this.slotDefaultFromContent?.templateRef,\n\t\t\tfooter: this.slotFooterFromContent?.templateRef,\n\t\t\theader: this.slotHeaderFromContent?.templateRef,\n\t\t\tstructure: this.slotStructureFromContent?.templateRef,\n\t\t\ttitle: this.slotTitleFromContent?.templateRef,\n\t\t} as any);\n\t}\n}\n"]}
|
|
459
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ModalComponent, { className: "ModalComponent", filePath: "components/modal/modal.component.ts", lineNumber: 151 }); })();
|
|
460
|
+
//# 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 {BaseWidgetDirective, ComponentTemplate, SlotDirective, UseDirective, UseMultiDirective, auBooleanAttribute} from '@agnos-ui/angular-headless';\nimport type {ModalContext, ModalWidget, ModalBeforeCloseEvent} from './modal.gen';\nimport {createModal} from './modal.gen';\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 * This directive provides a template reference for the {@link ModalContext<Data>}.\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 * This directive provides a template reference for the {@link ModalContext<Data>}.\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 * This directive provides a template reference for the {@link ModalContext<Data>}.\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 * This directive provides a template reference for the {@link ModalContext<Data>}.\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 * This directive provides a template reference for the {@link ModalContext<Data>}.\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-api=\"api\" let-directives=\"directives\">\n\t\t\t<h5 class=\"modal-title\">\n\t\t\t\t<ng-template [auSlot]=\"state.title()\" [auSlotProps]=\"{state, api, directives}\"></ng-template>\n\t\t\t</h5>\n\t\t\t@if (state.closeButton()) {\n\t\t\t\t<button class=\"btn-close\" [auUse]=\"directives.closeButtonDirective\"></button>\n\t\t\t}\n\t\t</ng-template>\n\t\t<ng-template auModalStructure #structure let-state=\"state\" let-api=\"api\" let-directives=\"directives\">\n\t\t\t@if (state.title()) {\n\t\t\t\t<div class=\"modal-header\">\n\t\t\t\t\t<ng-template [auSlot]=\"state.header()\" [auSlotProps]=\"{state, api, directives}\"></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.children()\" [auSlotProps]=\"{state, api, directives}\"></ng-template>\n\t\t\t</div>\n\t\t\t@if (state.footer()) {\n\t\t\t\t<div class=\"modal-footer\">\n\t\t\t\t\t<ng-template [auSlot]=\"state.footer()\" [auSlotProps]=\"{state, api, directives}\"></ng-template>\n\t\t\t\t</div>\n\t\t\t}\n\t\t</ng-template>\n\t`,\n})\nclass 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: SlotContent<ModalContext<any>> = new ComponentTemplate(ModalDefaultSlotsComponent, 'header');\n\n/**\n * Default slot for modal structure.\n */\nexport const modalDefaultSlotStructure: SlotContent<ModalContext<any>> = new ComponentTemplate(ModalDefaultSlotsComponent, 'structure');\n\n/**\n * Modal component.\n */\n@Component({\n\tselector: '[auModal]',\n\tstandalone: true,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [UseMultiDirective, SlotDirective],\n\ttemplate: `\n\t\t<ng-template #content><ng-content></ng-content></ng-template>\n\t\t@if (!state.backdropHidden()) {\n\t\t\t<div class=\"modal-backdrop\" [auUseMulti]=\"[directives.backdropPortalDirective, directives.backdropDirective]\"></div>\n\t\t}\n\t\t@if (!state.hidden()) {\n\t\t\t<div class=\"modal d-block\" [auUseMulti]=\"[directives.modalPortalDirective, 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.structure()\" [auSlotProps]=\"{state, api, directives}\"></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>> {\n\t/**\n\t * Whether the modal and its backdrop (if present) should be animated when shown or hidden.\n\t *\n\t * @defaultValue `true`\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 * @defaultValue `fadeTransition`\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 * @defaultValue `fadeTransition`\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 * @defaultValue `false`\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 * @defaultValue `true`\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 * @defaultValue `true`\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 * @defaultValue\n\t * ```ts\n\t * typeof window !== 'undefined' ? document.body : null\n\t * ```\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 * @defaultValue `'Close'`\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 * @defaultValue `''`\n\t */\n\t@Input('auBackdropClass') backdropClass: string | undefined;\n\n\t/**\n\t * Whether to display the close button.\n\t *\n\t * @defaultValue `true`\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 * @defaultValue `''`\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 * @defaultValue `false`\n\t */\n\t@Input({alias: 'auFullscreen', transform: auBooleanAttribute}) fullscreen: boolean | undefined;\n\n\t/**\n\t * Structure of the modal.\n\t * The default structure uses {@link ModalProps.header|header}, {@link ModalProps.children|children} and {@link ModalProps.footer|footer}.\n\t */\n\t@Input('auStructure') structure: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalStructureDirective, {static: false})\n\tslotStructureFromContent: ModalStructureDirective<Data> | undefined;\n\n\t/**\n\t * Header of the modal. The default header includes {@link ModalProps.title|title}.\n\t */\n\t@Input('auHeader') header: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalHeaderDirective, {static: false})\n\tslotHeaderFromContent: ModalHeaderDirective<Data> | undefined;\n\n\t/**\n\t * Title of the modal.\n\t */\n\t@Input('auTitle') title: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalTitleDirective, {static: false})\n\tslotTitleFromContent: ModalTitleDirective<Data> | undefined;\n\n\t/**\n\t * Body of the modal.\n\t */\n\t@Input('auChildren') children: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalBodyDirective, {static: false})\n\tslotDefaultFromContent: ModalBodyDirective<Data> | undefined;\n\n\t/**\n\t * Footer of the modal.\n\t */\n\t@Input('auFooter') footer: SlotContent<ModalContext<Data>>;\n\t@ContentChild(ModalFooterDirective, {static: false})\n\tslotFooterFromContent: ModalFooterDirective<Data> | undefined;\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 * @param visible - new value of the visible propery\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\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 {@link ModalApi.close|close} method was called).\n\t *\n\t * @param event - event giving access to the argument given to the {@link ModalApi.close|close} method and allowing\n\t * to cancel the close process.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\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 * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\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 * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\t@Output('auShown') shown = new EventEmitter<void>();\n\n\t@ViewChild('content', {static: true})\n\tslotChildren?: TemplateRef<void>;\n\n\tconstructor() {\n\t\tsuper(\n\t\t\tcallWidgetFactory<ModalWidget<Data>>({\n\t\t\t\tfactory: createModal,\n\t\t\t\twidgetName: 'modal',\n\t\t\t\tdefaultConfig: {\n\t\t\t\t\theader: modalDefaultSlotHeader,\n\t\t\t\t\tstructure: modalDefaultSlotStructure,\n\t\t\t\t},\n\t\t\t\tevents: {\n\t\t\t\t\tonShown: () => this.shown.emit(),\n\t\t\t\t\tonHidden: () => this.hidden.emit(),\n\t\t\t\t\tonBeforeClose: (event) => this.beforeClose.emit(event),\n\t\t\t\t\tonVisibleChange: (event) => this.visibleChange.emit(event),\n\t\t\t\t},\n\t\t\t\tslotTemplates: () =>\n\t\t\t\t\t({\n\t\t\t\t\t\tchildren: this.slotDefaultFromContent?.templateRef,\n\t\t\t\t\t\tfooter: this.slotFooterFromContent?.templateRef,\n\t\t\t\t\t\theader: this.slotHeaderFromContent?.templateRef,\n\t\t\t\t\t\tstructure: this.slotStructureFromContent?.templateRef,\n\t\t\t\t\t\ttitle: this.slotTitleFromContent?.templateRef,\n\t\t\t\t\t}) as any,\n\t\t\t\tslotChildren: () => this.slotChildren,\n\t\t\t}),\n\t\t);\n\t}\n}\n"]}
|
|
@@ -24,4 +24,4 @@ export { export_modalOutsideClick as modalOutsideClick };
|
|
|
24
24
|
*/
|
|
25
25
|
const export_modalCloseButtonClick = modalCloseButtonClick;
|
|
26
26
|
export { export_modalCloseButtonClick as modalCloseButtonClick };
|
|
27
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.gen.js","sourceRoot":"","sources":["../../../../src/components/modal/modal.gen.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,qBAAqB,EAAE,WAAW,EAAE,iBAAiB,EAAE,qBAAqB,EAAC,MAAM,2CAA2C,CAAC;AAIvI;;;GAGG;AACH,MAAM,4BAA4B,GAA0B,qBAA4B,CAAC;AACzF,OAAO,EAAC,4BAA4B,IAAI,qBAAqB,EAAC,CAAC;AAmV/D;;;;GAIG;AACH,MAAM,kBAAkB,GAAwE,WAAkB,CAAC;AACnH,OAAO,EAAC,kBAAkB,IAAI,WAAW,EAAC,CAAC;AAI3C;;;GAGG;AACH,MAAM,wBAAwB,GAA6B,iBAAwB,CAAC;AACpF,OAAO,EAAC,wBAAwB,IAAI,iBAAiB,EAAC,CAAC;AAIvD;;;GAGG;AACH,MAAM,4BAA4B,GAAiC,qBAA4B,CAAC;AAChG,OAAO,EAAC,4BAA4B,IAAI,qBAAqB,EAAC,CAAC","sourcesContent":["import {getModalDefaultConfig, createModal, modalOutsideClick, modalCloseButtonClick} from '@agnos-ui/core-bootstrap/components/modal';\nimport type {WidgetSlotContext, SlotContent, TransitionFn, Widget, PropsConfig, Directive} from '@agnos-ui/angular-headless';\n\n\n/**\n * Retrieve a shallow copy of the default modal config\n * @returns the default modal config\n */\nconst export_getModalDefaultConfig: () => ModalProps<any> = getModalDefaultConfig as any;\nexport {export_getModalDefaultConfig as getModalDefaultConfig};\n\n\n\nexport type ModalContext<Data> = WidgetSlotContext<ModalWidget<Data>>;\n\nexport interface ModalState<Data> {\n\t\n\t/**\n\t * Whether the backdrop is fully hidden. This can be true either because {@link ModalProps.backdrop|backdrop} is false or\n\t * because {@link ModalProps.visible|visible} is false and there is no current transition.\n\t */\n\tbackdropHidden: boolean;\n\t\n\n\t/**\n\t * Whether the modal is fully hidden.\n\t */\n\thidden: boolean;\n\t\n\n\t/**\n\t * Whether there is an active transition to either display or hide the modal.\n\t */\n\ttransitioning: boolean;\n\t\n\n\t/**\n\t * DOM element of the modal.\n\t */\n\tmodalElement: HTMLElement | null;\n\t\n\t/**\n\t * Value of the aria-label attribute to put on the close button.\n\t *\n\t * @defaultValue `'Close'`\n\t */\n\tariaCloseButtonLabel: string;\n\t\n\n\t/**\n\t * Classes to add on the backdrop DOM element.\n\t *\n\t * @defaultValue `''`\n\t */\n\tbackdropClass: string;\n\t\n\n\t/**\n\t * Whether to display the close button.\n\t *\n\t * @defaultValue `true`\n\t */\n\tcloseButton: boolean;\n\t\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 * @defaultValue\n\t * ```ts\n\t * typeof window !== 'undefined' ? document.body : null\n\t * ```\n\t */\n\tcontainer: HTMLElement | null;\n\t\n\n\t/**\n\t * Whether the modal should be visible when the transition is completed.\n\t *\n\t * @defaultValue `false`\n\t */\n\tvisible: boolean;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * Data to use in content slots\n\t */\n\tcontentData: Data;\n\t\n\t/**\n\t * Body of the modal.\n\t */\n\tchildren: SlotContent<ModalContext<Data>>;\n\t\n\n\t/**\n\t * Footer of the modal.\n\t */\n\tfooter: SlotContent<ModalContext<Data>>;\n\t\n\n\t/**\n\t * Header of the modal. The default header includes {@link ModalProps.title|title}.\n\t */\n\theader: SlotContent<ModalContext<Data>>;\n\t\n\n\t/**\n\t * Structure of the modal.\n\t * The default structure uses {@link ModalProps.header|header}, {@link ModalProps.children|children} and {@link ModalProps.footer|footer}.\n\t */\n\tstructure: SlotContent<ModalContext<Data>>;\n\t\n\n\t/**\n\t * Title of the modal.\n\t */\n\ttitle: SlotContent<ModalContext<Data>>;\n\t\n\t/**\n\t * Option to create a fullscreen modal, according to the bootstrap documentation.\n\t *\n\t * @defaultValue `false`\n\t */\n\tfullscreen: boolean;\n}\n\nexport interface ModalProps<Data> {\n\t\n\t/**\n\t * The transition to use for the backdrop behind the modal (if present).\n\t *\n\t * @defaultValue `fadeTransition`\n\t */\n\tbackdropTransition: TransitionFn;\n\t\n\n\t/**\n\t * The transition to use for the modal.\n\t *\n\t * @defaultValue `fadeTransition`\n\t */\n\tmodalTransition: TransitionFn;\n\t\n\t/**\n\t * Whether the modal and its backdrop (if present) should be animated when shown or hidden.\n\t *\n\t * @defaultValue `true`\n\t */\n\tanimated: boolean;\n\t\n\n\t/**\n\t * Whether a backdrop should be created behind the modal.\n\t *\n\t * @defaultValue `true`\n\t */\n\tbackdrop: boolean;\n\t\n\n\t/**\n\t * Whether the modal should be closed when clicking on the viewport outside the modal.\n\t *\n\t * @defaultValue `true`\n\t */\n\tcloseOnOutsideClick: boolean;\n\t\n\n\t/**\n\t * Event to be triggered when the modal is about to be closed (i.e. the {@link ModalApi.close|close} method was called).\n\t *\n\t * @param event - event giving access to the argument given to the {@link ModalApi.close|close} method and allowing\n\t * to cancel the close process.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonBeforeClose: (event: ModalBeforeCloseEvent) => void;\n\t\n\n\t/**\n\t * Event to be triggered when the visible property changes.\n\t *\n\t * @param visible - new value of the visible propery\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonVisibleChange: (visible: boolean) => void;\n\t\n\n\t/**\n\t * Event to be triggered when the transition is completed and the modal is not visible.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonHidden: () => void;\n\t\n\n\t/**\n\t * Event to be triggered when the transition is completed and the modal is visible.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonShown: () => void;\n\t\n\t/**\n\t * Value of the aria-label attribute to put on the close button.\n\t *\n\t * @defaultValue `'Close'`\n\t */\n\tariaCloseButtonLabel: string;\n\t\n\n\t/**\n\t * Classes to add on the backdrop DOM element.\n\t *\n\t * @defaultValue `''`\n\t */\n\tbackdropClass: string;\n\t\n\n\t/**\n\t * Whether to display the close button.\n\t *\n\t * @defaultValue `true`\n\t */\n\tcloseButton: boolean;\n\t\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 * @defaultValue\n\t * ```ts\n\t * typeof window !== 'undefined' ? document.body : null\n\t * ```\n\t */\n\tcontainer: HTMLElement | null;\n\t\n\n\t/**\n\t * Whether the modal should be visible when the transition is completed.\n\t *\n\t * @defaultValue `false`\n\t */\n\tvisible: boolean;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * Data to use in content slots\n\t */\n\tcontentData: Data;\n\t\n\t/**\n\t * Body of the modal.\n\t */\n\tchildren: SlotContent<ModalContext<Data>>;\n\t\n\n\t/**\n\t * Footer of the modal.\n\t */\n\tfooter: SlotContent<ModalContext<Data>>;\n\t\n\n\t/**\n\t * Header of the modal. The default header includes {@link ModalProps.title|title}.\n\t */\n\theader: SlotContent<ModalContext<Data>>;\n\t\n\n\t/**\n\t * Structure of the modal.\n\t * The default structure uses {@link ModalProps.header|header}, {@link ModalProps.children|children} and {@link ModalProps.footer|footer}.\n\t */\n\tstructure: SlotContent<ModalContext<Data>>;\n\t\n\n\t/**\n\t * Title of the modal.\n\t */\n\ttitle: SlotContent<ModalContext<Data>>;\n\t\n\t/**\n\t * Option to create a fullscreen modal, according to the bootstrap documentation.\n\t *\n\t * @defaultValue `false`\n\t */\n\tfullscreen: boolean;\n}\n\nexport interface ModalApi<Data> {\n\t\n\t/**\n\t * Method to change some modal properties.\n\t */\n\tpatch: ModalWidget<Data>['patch'];\n\t\n\t/**\n\t * Closes the modal with the given result.\n\t *\n\t * @param result - result of the modal, as passed in the {@link ModalBeforeCloseEvent.result|result} property of the event passed to the\n\t * {@link ModalProps.onBeforeClose|onBeforeClose} event handler (and possibly changed by it) and resolved by the promise returned by the {@link ModalApi.open|open} method.\n\t */\n\tclose(result?: any): void;\n\t\n\n\t/**\n\t * Opens the modal and returns a promise that is resolved when the modal is closed.\n\t * The resolved value is the result passed to the {@link ModalApi.close|close} method and possibly changed by the\n\t * {@link ModalProps.onBeforeClose|onBeforeClose} event handler\n\t */\n\topen(): Promise<any>;\n}\n\n\n\nexport type ModalWidget<Data> = Widget<ModalProps<Data>, ModalState<Data>, ModalApi<Data>, ModalActions, ModalDirectives>;\n\n\n\n/**\n * Creates a new modal widget instance.\n * @param config - config of the modal, either as a store or as an object containing values or stores.\n * @returns a new modal widget instance\n */\nconst export_createModal: <Data>(config?: PropsConfig<ModalProps<Data>>) => ModalWidget<Data> = createModal as any;\nexport {export_createModal as createModal};\n\n\n\n/**\n * Value present in the {@link ModalBeforeCloseEvent.result|result} property of the {@link ModalProps.onBeforeClose|onBeforeClose} event\n * and returned by the {@link ModalApi.open|open} method, when the modal is closed by a click inside the viewport but outside the modal.\n */\nconst export_modalOutsideClick: typeof modalOutsideClick = modalOutsideClick as any;\nexport {export_modalOutsideClick as modalOutsideClick};\n\n\n\n/**\n * Value present in the {@link ModalBeforeCloseEvent.result|result} property of the {@link ModalProps.onBeforeClose|onBeforeClose} event\n * and returned by the {@link ModalApi.open|open} method, when the modal is closed by a click on the close button.\n */\nconst export_modalCloseButtonClick: typeof modalCloseButtonClick = modalCloseButtonClick as any;\nexport {export_modalCloseButtonClick as modalCloseButtonClick};\n\nexport interface ModalBeforeCloseEvent {\n\t\n\t/**\n\t * Result of the modal, which is the value passed to the {@link ModalApi.close|close} method\n\t * and later resolved by the promise returned by the {@link ModalApi.open|open} method.\n\t * If needed, it can be changed from the {@link ModalProps.onBeforeClose|onBeforeClose} event handler.\n\t */\n\tresult: any;\n\t\n\n\t/**\n\t * Whether to cancel the close of the modal.\n\t * It can be changed from the {@link ModalProps.onBeforeClose|onBeforeClose} event handler.\n\t */\n\tcancel: boolean;\n}\n\nexport interface ModalActions {\n\t\n\t/**\n\t * Action to be called when the user clicks on the close button. It closes the modal with the {@link modalCloseButtonClick} result.\n\t * @param event - mouse event\n\t */\n\tcloseButtonClick(event: Pick<MouseEvent, never>): void;\n\t\n\n\t/**\n\t * Action to be called when the user clicks on the modal DOM element (which is supposed to have the size of the full viewport).\n\t * If the click is not done on a descendant of the modal DOM element, it is considered to be done outside the modal\n\t * and, depending on the value of the {@link ModalProps.closeOnOutsideClick|closeOnOutsideClick} prop, the modal is or isn't closed\n\t * (with the {@link modalOutsideClick} result).\n\t * @param event - mouse event\n\t */\n\tmodalClick(event: Pick<MouseEvent, 'target' | 'currentTarget'>): void;\n}\n\nexport interface ModalDirectives {\n\t\n\t/**\n\t * Directive to put on the modal DOM element.\n\t */\n\tmodalDirective: Directive;\n\t\n\n\t/**\n\t * Directive to put on the backdrop DOM element.\n\t */\n\tbackdropDirective: Directive;\n\t\n\n\t/**\n\t * Portal directive to put on the modal DOM element.\n\t */\n\tmodalPortalDirective: Directive;\n\t\n\n\t/**\n\t * Portal directive to put on the backdrop DOM element.\n\t */\n\tbackdropPortalDirective: Directive;\n\t\n\n\t/**\n\t * Directive that adds all the necessary attributes to the close button\n\t */\n\tcloseButtonDirective: Directive;\n\t\n\t/**\n\t * Directive to apply to the dialog element when using the native [HTMLDialogElement](https://developer.mozilla.org/en-US/docs/Web/API/HTMLDialogElement)\n\t */\n\tdialogDirective: Directive;\n}\n\n"]}
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.gen.js","sourceRoot":"","sources":["../../../../src/components/modal/modal.gen.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,qBAAqB,EAAE,WAAW,EAAE,iBAAiB,EAAE,qBAAqB,EAAC,MAAM,2CAA2C,CAAC;AAIvI;;;GAGG;AACH,MAAM,4BAA4B,GAA0B,qBAA4B,CAAC;AACzF,OAAO,EAAC,4BAA4B,IAAI,qBAAqB,EAAC,CAAC;AA4W/D;;;;GAIG;AACH,MAAM,kBAAkB,GAAwE,WAAkB,CAAC;AACnH,OAAO,EAAC,kBAAkB,IAAI,WAAW,EAAC,CAAC;AAI3C;;;GAGG;AACH,MAAM,wBAAwB,GAA6B,iBAAwB,CAAC;AACpF,OAAO,EAAC,wBAAwB,IAAI,iBAAiB,EAAC,CAAC;AAIvD;;;GAGG;AACH,MAAM,4BAA4B,GAAiC,qBAA4B,CAAC;AAChG,OAAO,EAAC,4BAA4B,IAAI,qBAAqB,EAAC,CAAC","sourcesContent":["import {getModalDefaultConfig, createModal, modalOutsideClick, modalCloseButtonClick} from '@agnos-ui/core-bootstrap/components/modal';\nimport type {WidgetSlotContext, SlotContent, TransitionFn, Widget, PropsConfig, Directive} from '@agnos-ui/angular-headless';\n\n\n/**\n * Retrieve a shallow copy of the default modal config\n * @returns the default modal config\n */\nconst export_getModalDefaultConfig: () => ModalProps<any> = getModalDefaultConfig as any;\nexport {export_getModalDefaultConfig as getModalDefaultConfig};\n\n\n\n/**\n * Represents the context for a modal component.\n *\n * @template Data - The type of data associated with the modal.\n */\nexport interface ModalContext<Data> extends WidgetSlotContext<ModalWidget<Data>> {}\n\n/**\n * Represents the state of a modal component.\n *\n * @template Data - The type of the data associated with the modal.\n */\nexport interface ModalState<Data> {\n\t\n\t/**\n\t * Whether the backdrop is fully hidden. This can be true either because {@link ModalProps.backdrop|backdrop} is false or\n\t * because {@link ModalProps.visible|visible} is false and there is no current transition.\n\t */\n\tbackdropHidden: boolean;\n\t\n\n\t/**\n\t * Whether the modal is fully hidden.\n\t */\n\thidden: boolean;\n\t\n\n\t/**\n\t * Whether there is an active transition to either display or hide the modal.\n\t */\n\ttransitioning: boolean;\n\t\n\n\t/**\n\t * DOM element of the modal.\n\t */\n\tmodalElement: HTMLElement | null;\n\t\n\t/**\n\t * Value of the aria-label attribute to put on the close button.\n\t *\n\t * @defaultValue `'Close'`\n\t */\n\tariaCloseButtonLabel: string;\n\t\n\n\t/**\n\t * Classes to add on the backdrop DOM element.\n\t *\n\t * @defaultValue `''`\n\t */\n\tbackdropClass: string;\n\t\n\n\t/**\n\t * Whether to display the close button.\n\t *\n\t * @defaultValue `true`\n\t */\n\tcloseButton: boolean;\n\t\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 * @defaultValue\n\t * ```ts\n\t * typeof window !== 'undefined' ? document.body : null\n\t * ```\n\t */\n\tcontainer: HTMLElement | null;\n\t\n\n\t/**\n\t * Whether the modal should be visible when the transition is completed.\n\t *\n\t * @defaultValue `false`\n\t */\n\tvisible: boolean;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * Data to use in content slots\n\t */\n\tcontentData: Data;\n\t\n\t/**\n\t * Body of the modal.\n\t */\n\tchildren: SlotContent<ModalContext<Data>>;\n\t\n\n\t/**\n\t * Footer of the modal.\n\t */\n\tfooter: SlotContent<ModalContext<Data>>;\n\t\n\n\t/**\n\t * Header of the modal. The default header includes {@link ModalProps.title|title}.\n\t */\n\theader: SlotContent<ModalContext<Data>>;\n\t\n\n\t/**\n\t * Structure of the modal.\n\t * The default structure uses {@link ModalProps.header|header}, {@link ModalProps.children|children} and {@link ModalProps.footer|footer}.\n\t */\n\tstructure: SlotContent<ModalContext<Data>>;\n\t\n\n\t/**\n\t * Title of the modal.\n\t */\n\ttitle: SlotContent<ModalContext<Data>>;\n\t\n\t/**\n\t * Option to create a fullscreen modal, according to the bootstrap documentation.\n\t *\n\t * @defaultValue `false`\n\t */\n\tfullscreen: boolean;\n}\n\n/**\n * Interface representing the properties for a modal component.\n *\n * @template Data - The type of data that the modal will handle.\n */\nexport interface ModalProps<Data> {\n\t\n\t/**\n\t * The transition to use for the backdrop behind the modal (if present).\n\t *\n\t * @defaultValue `fadeTransition`\n\t */\n\tbackdropTransition: TransitionFn;\n\t\n\n\t/**\n\t * The transition to use for the modal.\n\t *\n\t * @defaultValue `fadeTransition`\n\t */\n\tmodalTransition: TransitionFn;\n\t\n\t/**\n\t * Whether the modal and its backdrop (if present) should be animated when shown or hidden.\n\t *\n\t * @defaultValue `true`\n\t */\n\tanimated: boolean;\n\t\n\n\t/**\n\t * Whether a backdrop should be created behind the modal.\n\t *\n\t * @defaultValue `true`\n\t */\n\tbackdrop: boolean;\n\t\n\n\t/**\n\t * Whether the modal should be closed when clicking on the viewport outside the modal.\n\t *\n\t * @defaultValue `true`\n\t */\n\tcloseOnOutsideClick: boolean;\n\t\n\n\t/**\n\t * Event to be triggered when the modal is about to be closed (i.e. the {@link ModalApi.close|close} method was called).\n\t *\n\t * @param event - event giving access to the argument given to the {@link ModalApi.close|close} method and allowing\n\t * to cancel the close process.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonBeforeClose: (event: ModalBeforeCloseEvent) => void;\n\t\n\n\t/**\n\t * Event to be triggered when the visible property changes.\n\t *\n\t * @param visible - new value of the visible propery\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonVisibleChange: (visible: boolean) => void;\n\t\n\n\t/**\n\t * Event to be triggered when the transition is completed and the modal is not visible.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonHidden: () => void;\n\t\n\n\t/**\n\t * Event to be triggered when the transition is completed and the modal is visible.\n\t *\n\t * @defaultValue\n\t * ```ts\n\t * () => {}\n\t * ```\n\t */\n\tonShown: () => void;\n\t\n\t/**\n\t * Value of the aria-label attribute to put on the close button.\n\t *\n\t * @defaultValue `'Close'`\n\t */\n\tariaCloseButtonLabel: string;\n\t\n\n\t/**\n\t * Classes to add on the backdrop DOM element.\n\t *\n\t * @defaultValue `''`\n\t */\n\tbackdropClass: string;\n\t\n\n\t/**\n\t * Whether to display the close button.\n\t *\n\t * @defaultValue `true`\n\t */\n\tcloseButton: boolean;\n\t\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 * @defaultValue\n\t * ```ts\n\t * typeof window !== 'undefined' ? document.body : null\n\t * ```\n\t */\n\tcontainer: HTMLElement | null;\n\t\n\n\t/**\n\t * Whether the modal should be visible when the transition is completed.\n\t *\n\t * @defaultValue `false`\n\t */\n\tvisible: boolean;\n\t\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t *\n\t * @defaultValue `''`\n\t */\n\tclassName: string;\n\t\n\t/**\n\t * Data to use in content slots\n\t */\n\tcontentData: Data;\n\t\n\t/**\n\t * Body of the modal.\n\t */\n\tchildren: SlotContent<ModalContext<Data>>;\n\t\n\n\t/**\n\t * Footer of the modal.\n\t */\n\tfooter: SlotContent<ModalContext<Data>>;\n\t\n\n\t/**\n\t * Header of the modal. The default header includes {@link ModalProps.title|title}.\n\t */\n\theader: SlotContent<ModalContext<Data>>;\n\t\n\n\t/**\n\t * Structure of the modal.\n\t * The default structure uses {@link ModalProps.header|header}, {@link ModalProps.children|children} and {@link ModalProps.footer|footer}.\n\t */\n\tstructure: SlotContent<ModalContext<Data>>;\n\t\n\n\t/**\n\t * Title of the modal.\n\t */\n\ttitle: SlotContent<ModalContext<Data>>;\n\t\n\t/**\n\t * Option to create a fullscreen modal, according to the bootstrap documentation.\n\t *\n\t * @defaultValue `false`\n\t */\n\tfullscreen: boolean;\n}\n\n/**\n * Interface representing the API for a modal component.\n *\n * @template Data - The type of data associated with the modal.\n */\nexport interface ModalApi<Data> {\n\t\n\t/**\n\t * Method to change some modal properties.\n\t */\n\tpatch: ModalWidget<Data>['patch'];\n\t\n\t/**\n\t * Closes the modal with the given result.\n\t *\n\t * @param result - result of the modal, as passed in the {@link ModalBeforeCloseEvent.result|result} property of the event passed to the\n\t * {@link ModalProps.onBeforeClose|onBeforeClose} event handler (and possibly changed by it) and resolved by the promise returned by the {@link ModalApi.open|open} method.\n\t */\n\tclose(result?: any): void;\n\t\n\n\t/**\n\t * Opens the modal and returns a promise that is resolved when the modal is closed.\n\t * The resolved value is the result passed to the {@link ModalApi.close|close} method and possibly changed by the\n\t * {@link ModalProps.onBeforeClose|onBeforeClose} event handler\n\t */\n\topen(): Promise<any>;\n}\n\n\n\n/**\n * Represents a modal widget with specific data type.\n *\n * @template Data - The type of data that the modal widget will handle.\n */\nexport type ModalWidget<Data> = Widget<ModalProps<Data>, ModalState<Data>, ModalApi<Data>, ModalDirectives>;\n\n\n\n/**\n * Creates a new modal widget instance.\n * @param config - config of the modal, either as a store or as an object containing values or stores.\n * @returns a new modal widget instance\n */\nconst export_createModal: <Data>(config?: PropsConfig<ModalProps<Data>>) => ModalWidget<Data> = createModal as any;\nexport {export_createModal as createModal};\n\n\n\n/**\n * Value present in the {@link ModalBeforeCloseEvent.result|result} property of the {@link ModalProps.onBeforeClose|onBeforeClose} event\n * and returned by the {@link ModalApi.open|open} method, when the modal is closed by a click inside the viewport but outside the modal.\n */\nconst export_modalOutsideClick: typeof modalOutsideClick = modalOutsideClick as any;\nexport {export_modalOutsideClick as modalOutsideClick};\n\n\n\n/**\n * Value present in the {@link ModalBeforeCloseEvent.result|result} property of the {@link ModalProps.onBeforeClose|onBeforeClose} event\n * and returned by the {@link ModalApi.open|open} method, when the modal is closed by a click on the close button.\n */\nconst export_modalCloseButtonClick: typeof modalCloseButtonClick = modalCloseButtonClick as any;\nexport {export_modalCloseButtonClick as modalCloseButtonClick};\n\n/**\n * Type of the parameter of {@link ModalProps.onBeforeClose|onBeforeClose}.\n */\nexport interface ModalBeforeCloseEvent {\n\t\n\t/**\n\t * Result of the modal, which is the value passed to the {@link ModalApi.close|close} method\n\t * and later resolved by the promise returned by the {@link ModalApi.open|open} method.\n\t * If needed, it can be changed from the {@link ModalProps.onBeforeClose|onBeforeClose} event handler.\n\t */\n\tresult: any;\n\t\n\n\t/**\n\t * Whether to cancel the close of the modal.\n\t * It can be changed from the {@link ModalProps.onBeforeClose|onBeforeClose} event handler.\n\t */\n\tcancel: boolean;\n}\n\n/**\n * Directives of the modal widget.\n */\nexport interface ModalDirectives {\n\t\n\t/**\n\t * Directive to put on the modal DOM element.\n\t */\n\tmodalDirective: Directive;\n\t\n\n\t/**\n\t * Directive to put on the backdrop DOM element.\n\t */\n\tbackdropDirective: Directive;\n\t\n\n\t/**\n\t * Portal directive to put on the modal DOM element.\n\t */\n\tmodalPortalDirective: Directive;\n\t\n\n\t/**\n\t * Portal directive to put on the backdrop DOM element.\n\t */\n\tbackdropPortalDirective: Directive;\n\t\n\n\t/**\n\t * Directive that adds all the necessary attributes to the close button\n\t */\n\tcloseButtonDirective: Directive;\n\t\n\t/**\n\t * Directive to apply to the dialog element when using the native {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLDialogElement | HTMLDialogElement}\n\t */\n\tdialogDirective: Directive;\n}\n\n"]}
|