@agorapulse/ui-components 18.0.35 → 18.0.36
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/agorapulse-ui-components-18.0.36.tgz +0 -0
- package/directives/checkbox.directive.d.ts +60 -0
- package/directives/public_api.d.ts +1 -0
- package/esm2022/directives/checkbox.directive.mjs +442 -0
- package/esm2022/directives/public_api.mjs +2 -1
- package/esm2022/index.mjs +2 -2
- package/esm2022/nav-selector/nav-selector-category/nav-selector-category.component.mjs +3 -3
- package/esm2022/nav-selector/nav-selector-group/nav-selector-group.component.mjs +3 -3
- package/esm2022/nav-selector/nav-selector-leaf/nav-selector-leaf.component.mjs +3 -3
- package/esm2022/nav-selector/nav-selector-leaf-details/nav-selector-leaf-details.component.mjs +3 -3
- package/esm2022/nav-selector/utils/nav-selector.filter.mjs +2 -2
- package/esm2022/nav-selector/utils/nav-selector.merger.mjs +2 -2
- package/fesm2022/agorapulse-ui-components-directives.mjs +442 -3
- package/fesm2022/agorapulse-ui-components-directives.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components-nav-selector.mjs +10 -10
- package/fesm2022/agorapulse-ui-components-nav-selector.mjs.map +1 -1
- package/fesm2022/agorapulse-ui-components.mjs +1 -1
- package/fesm2022/agorapulse-ui-components.mjs.map +1 -1
- package/index.d.ts +1 -1
- package/package.json +1 -1
- package/agorapulse-ui-components-18.0.35.tgz +0 -0
|
Binary file
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { EventEmitter, OnDestroy, OnInit } from '@angular/core';
|
|
2
|
+
import { ControlValueAccessor } from '@angular/forms';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare const AP_CHECKBOX_DIRECTIVE_CONTROL_VALUE_ACCESSOR: {
|
|
5
|
+
provide: import("@angular/core").InjectionToken<readonly ControlValueAccessor[]>;
|
|
6
|
+
useExisting: import("@angular/core").Type<any>;
|
|
7
|
+
multi: boolean;
|
|
8
|
+
};
|
|
9
|
+
export declare class CheckboxDirective implements ControlValueAccessor, OnInit, OnDestroy {
|
|
10
|
+
private readonly symbolRegistry;
|
|
11
|
+
private readonly elementRef;
|
|
12
|
+
private readonly renderer;
|
|
13
|
+
private readonly viewContainer;
|
|
14
|
+
ariaLabel?: string;
|
|
15
|
+
ariaLabelledby?: string;
|
|
16
|
+
ariaDescribedby?: string;
|
|
17
|
+
disabled: boolean;
|
|
18
|
+
set indeterminate(indeterminate: boolean);
|
|
19
|
+
get indeterminate(): boolean;
|
|
20
|
+
set checked(checked: boolean);
|
|
21
|
+
get checked(): boolean;
|
|
22
|
+
required: boolean;
|
|
23
|
+
set name(name: string);
|
|
24
|
+
get name(): string;
|
|
25
|
+
readonly change: EventEmitter<boolean>;
|
|
26
|
+
private _checked;
|
|
27
|
+
private _indeterminate;
|
|
28
|
+
private _name;
|
|
29
|
+
private _controlValueAccessorChangeFn;
|
|
30
|
+
private _onTouched;
|
|
31
|
+
private listeners;
|
|
32
|
+
private styleElement;
|
|
33
|
+
private wrapper;
|
|
34
|
+
private checkmarkContainer;
|
|
35
|
+
private indeterminateContainer;
|
|
36
|
+
private symbolComponent?;
|
|
37
|
+
ngOnInit(): void;
|
|
38
|
+
ngOnDestroy(): void;
|
|
39
|
+
private createCheckboxStructure;
|
|
40
|
+
private createOverlayContainer;
|
|
41
|
+
private createCheckmarkSymbol;
|
|
42
|
+
private createIndeterminateBar;
|
|
43
|
+
private updateCheckmarkVisibility;
|
|
44
|
+
private setupEventListeners;
|
|
45
|
+
private applyCheckboxStyles;
|
|
46
|
+
onBlur(): void;
|
|
47
|
+
private onValueChange;
|
|
48
|
+
writeValue(value: boolean): void;
|
|
49
|
+
registerOnChange(fn: (value: boolean) => void): void;
|
|
50
|
+
registerOnTouched(fn: () => void): void;
|
|
51
|
+
setDisabledState(isDisabled: boolean): void;
|
|
52
|
+
validate(): false | {
|
|
53
|
+
invalid: boolean;
|
|
54
|
+
};
|
|
55
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<CheckboxDirective, never>;
|
|
56
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<CheckboxDirective, "input[type=\"checkbox\"][apCheckbox]", never, { "ariaLabel": { "alias": "aria-label"; "required": false; }; "ariaLabelledby": { "alias": "aria-labelledby"; "required": false; }; "ariaDescribedby": { "alias": "aria-describedby"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "indeterminate": { "alias": "indeterminate"; "required": false; }; "checked": { "alias": "checked"; "required": false; }; "required": { "alias": "required"; "required": false; }; "name": { "alias": "name"; "required": true; }; }, { "change": "change"; }, never, never, true, never>;
|
|
57
|
+
static ngAcceptInputType_disabled: unknown;
|
|
58
|
+
static ngAcceptInputType_indeterminate: unknown;
|
|
59
|
+
static ngAcceptInputType_required: unknown;
|
|
60
|
+
}
|
|
@@ -0,0 +1,442 @@
|
|
|
1
|
+
import { apCheck, SymbolComponent, SymbolRegistry } from '@agorapulse/ui-symbol';
|
|
2
|
+
import { booleanAttribute, Directive, ElementRef, EventEmitter, forwardRef, inject, Input, Output, Renderer2, ViewContainerRef, } from '@angular/core';
|
|
3
|
+
import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export const AP_CHECKBOX_DIRECTIVE_CONTROL_VALUE_ACCESSOR = {
|
|
6
|
+
provide: NG_VALUE_ACCESSOR,
|
|
7
|
+
useExisting: forwardRef(() => CheckboxDirective),
|
|
8
|
+
multi: true,
|
|
9
|
+
};
|
|
10
|
+
/*
|
|
11
|
+
Host bindings is important here:
|
|
12
|
+
- This provides encapsulation and reactivity regardless of how the directive is used in templates.
|
|
13
|
+
- It guarantees that properties like checked, disabled, required, and ARIA attributes always reflect
|
|
14
|
+
only the directive's logic, not just consumer bindings.
|
|
15
|
+
- So we need to have host bindings for all the properties that we want to control.
|
|
16
|
+
- We could also use @HostListener.
|
|
17
|
+
*/
|
|
18
|
+
export class CheckboxDirective {
|
|
19
|
+
symbolRegistry = inject(SymbolRegistry);
|
|
20
|
+
elementRef = inject((ElementRef));
|
|
21
|
+
renderer = inject(Renderer2);
|
|
22
|
+
viewContainer = inject(ViewContainerRef);
|
|
23
|
+
ariaLabel;
|
|
24
|
+
ariaLabelledby;
|
|
25
|
+
ariaDescribedby;
|
|
26
|
+
disabled = false;
|
|
27
|
+
set indeterminate(indeterminate) {
|
|
28
|
+
if (indeterminate) {
|
|
29
|
+
this._checked = false;
|
|
30
|
+
}
|
|
31
|
+
this._indeterminate = indeterminate;
|
|
32
|
+
const input = this.elementRef.nativeElement;
|
|
33
|
+
if (input) {
|
|
34
|
+
input.indeterminate = indeterminate;
|
|
35
|
+
}
|
|
36
|
+
// Only update visibility if containers are ready
|
|
37
|
+
if (this.checkmarkContainer && this.indeterminateContainer) {
|
|
38
|
+
this.updateCheckmarkVisibility();
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
get indeterminate() {
|
|
42
|
+
return this._indeterminate;
|
|
43
|
+
}
|
|
44
|
+
set checked(checked) {
|
|
45
|
+
this._checked = checked;
|
|
46
|
+
// Only update visibility if containers are ready
|
|
47
|
+
if (this.checkmarkContainer && this.indeterminateContainer) {
|
|
48
|
+
this.updateCheckmarkVisibility();
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
get checked() {
|
|
52
|
+
return this._checked;
|
|
53
|
+
}
|
|
54
|
+
required = false;
|
|
55
|
+
set name(name) {
|
|
56
|
+
this._name = name;
|
|
57
|
+
}
|
|
58
|
+
get name() {
|
|
59
|
+
return this._name;
|
|
60
|
+
}
|
|
61
|
+
// eslint-disable-next-line @angular-eslint/no-output-native
|
|
62
|
+
change = new EventEmitter();
|
|
63
|
+
_checked = false;
|
|
64
|
+
_indeterminate = false;
|
|
65
|
+
_name = '';
|
|
66
|
+
_controlValueAccessorChangeFn = () => { };
|
|
67
|
+
_onTouched = () => { };
|
|
68
|
+
listeners = [];
|
|
69
|
+
styleElement;
|
|
70
|
+
wrapper;
|
|
71
|
+
checkmarkContainer;
|
|
72
|
+
indeterminateContainer;
|
|
73
|
+
symbolComponent;
|
|
74
|
+
ngOnInit() {
|
|
75
|
+
this.symbolRegistry.registerSymbols([apCheck]);
|
|
76
|
+
this.createCheckboxStructure();
|
|
77
|
+
this.setupEventListeners();
|
|
78
|
+
}
|
|
79
|
+
ngOnDestroy() {
|
|
80
|
+
this.listeners.forEach(unlisten => unlisten());
|
|
81
|
+
if (this.styleElement && this.styleElement.parentNode) {
|
|
82
|
+
this.styleElement.parentNode.removeChild(this.styleElement);
|
|
83
|
+
}
|
|
84
|
+
if (this.symbolComponent) {
|
|
85
|
+
this.symbolComponent.destroy();
|
|
86
|
+
}
|
|
87
|
+
if (this.checkmarkContainer && this.checkmarkContainer.parentNode) {
|
|
88
|
+
this.checkmarkContainer.parentNode.removeChild(this.checkmarkContainer);
|
|
89
|
+
}
|
|
90
|
+
if (this.indeterminateContainer && this.indeterminateContainer.parentNode) {
|
|
91
|
+
this.indeterminateContainer.parentNode.removeChild(this.indeterminateContainer);
|
|
92
|
+
}
|
|
93
|
+
// Move input back out of wrapper and remove wrapper
|
|
94
|
+
if (this.wrapper && this.wrapper.parentNode) {
|
|
95
|
+
const input = this.elementRef.nativeElement;
|
|
96
|
+
this.renderer.insertBefore(this.wrapper.parentNode, input, this.wrapper);
|
|
97
|
+
this.wrapper.parentNode.removeChild(this.wrapper);
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
createCheckboxStructure() {
|
|
101
|
+
const input = this.elementRef.nativeElement;
|
|
102
|
+
const parent = input.parentElement;
|
|
103
|
+
// Hot take - Input doesn't need positioning since it will be wrapped
|
|
104
|
+
// Make input's parent use inline-flex for alignment
|
|
105
|
+
if (parent) {
|
|
106
|
+
this.renderer.setStyle(parent, 'display', 'inline-flex');
|
|
107
|
+
this.renderer.setStyle(parent, 'align-items', 'center');
|
|
108
|
+
this.renderer.setStyle(parent, 'gap', 'var(--ref-spacing-xxs)');
|
|
109
|
+
}
|
|
110
|
+
this.renderer.addClass(input, 'ap-checkbox-styled');
|
|
111
|
+
this.checkmarkContainer = this.createOverlayContainer('ap-checkbox-checkmark');
|
|
112
|
+
this.wrapper = this.renderer.createElement('span');
|
|
113
|
+
this.renderer.setStyle(this.wrapper, 'position', 'relative');
|
|
114
|
+
this.renderer.setStyle(this.wrapper, 'display', 'inline-flex');
|
|
115
|
+
this.renderer.setStyle(this.wrapper, 'align-items', 'center');
|
|
116
|
+
this.renderer.setStyle(this.wrapper, 'vertical-align', 'middle');
|
|
117
|
+
this.renderer.insertBefore(parent, this.wrapper, input);
|
|
118
|
+
this.renderer.appendChild(this.wrapper, input);
|
|
119
|
+
this.renderer.appendChild(this.wrapper, this.checkmarkContainer);
|
|
120
|
+
this.indeterminateContainer = this.createOverlayContainer('ap-checkbox-indeterminate');
|
|
121
|
+
this.renderer.appendChild(this.wrapper, this.indeterminateContainer);
|
|
122
|
+
this.createCheckmarkSymbol();
|
|
123
|
+
this.createIndeterminateBar();
|
|
124
|
+
this.applyCheckboxStyles();
|
|
125
|
+
this.updateCheckmarkVisibility();
|
|
126
|
+
}
|
|
127
|
+
createOverlayContainer(className) {
|
|
128
|
+
const container = this.renderer.createElement('span');
|
|
129
|
+
this.renderer.addClass(container, className);
|
|
130
|
+
this.renderer.setStyle(container, 'position', 'absolute');
|
|
131
|
+
this.renderer.setStyle(container, 'top', '50%');
|
|
132
|
+
this.renderer.setStyle(container, 'left', '50%');
|
|
133
|
+
this.renderer.setStyle(container, 'transform', 'translate(-50%, -50%)');
|
|
134
|
+
this.renderer.setStyle(container, 'width', 'auto');
|
|
135
|
+
this.renderer.setStyle(container, 'height', 'auto');
|
|
136
|
+
this.renderer.setStyle(container, 'display', 'flex');
|
|
137
|
+
this.renderer.setStyle(container, 'justify-content', 'center');
|
|
138
|
+
this.renderer.setStyle(container, 'align-items', 'center');
|
|
139
|
+
this.renderer.setStyle(container, 'pointer-events', 'none');
|
|
140
|
+
this.renderer.setStyle(container, 'opacity', '0');
|
|
141
|
+
this.renderer.setStyle(container, 'z-index', '1');
|
|
142
|
+
return container;
|
|
143
|
+
}
|
|
144
|
+
createCheckmarkSymbol() {
|
|
145
|
+
// Create the symbol component
|
|
146
|
+
this.symbolComponent = this.viewContainer.createComponent(SymbolComponent);
|
|
147
|
+
// Set inputs using setInput method for signal-based inputs
|
|
148
|
+
this.symbolComponent.setInput('symbolId', 'check');
|
|
149
|
+
this.symbolComponent.setInput('color', 'white');
|
|
150
|
+
this.symbolComponent.setInput('size', 10);
|
|
151
|
+
// Append the symbol to our checkmark container
|
|
152
|
+
this.renderer.appendChild(this.checkmarkContainer, this.symbolComponent.location.nativeElement);
|
|
153
|
+
}
|
|
154
|
+
createIndeterminateBar() {
|
|
155
|
+
// Create the indeterminate bar element exactly like the component
|
|
156
|
+
const bar = this.renderer.createElement('span');
|
|
157
|
+
this.renderer.setStyle(bar, 'height', '1.5px');
|
|
158
|
+
this.renderer.setStyle(bar, 'background', 'var(--ref-color-white)');
|
|
159
|
+
this.renderer.setStyle(bar, 'width', '8px');
|
|
160
|
+
// Append the bar to the indeterminate container
|
|
161
|
+
this.renderer.appendChild(this.indeterminateContainer, bar);
|
|
162
|
+
}
|
|
163
|
+
updateCheckmarkVisibility() {
|
|
164
|
+
if (this.checkmarkContainer) {
|
|
165
|
+
const opacity = this._checked && !this._indeterminate ? '1' : '0';
|
|
166
|
+
this.renderer.setStyle(this.checkmarkContainer, 'opacity', opacity);
|
|
167
|
+
}
|
|
168
|
+
if (this.indeterminateContainer) {
|
|
169
|
+
const opacity = this._indeterminate && !this._checked ? '1' : '0';
|
|
170
|
+
this.renderer.setStyle(this.indeterminateContainer, 'opacity', opacity);
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
setupEventListeners() {
|
|
174
|
+
const input = this.elementRef.nativeElement;
|
|
175
|
+
// Input change listener (native checkbox change)
|
|
176
|
+
const changeListener = this.renderer.listen(input, 'change', () => {
|
|
177
|
+
this.onValueChange();
|
|
178
|
+
});
|
|
179
|
+
this.listeners.push(changeListener);
|
|
180
|
+
// Listen for label clicks to ensure focus is maintained
|
|
181
|
+
const parent = input.parentElement;
|
|
182
|
+
if (parent) {
|
|
183
|
+
const labelClickListener = this.renderer.listen(parent, 'click', (event) => {
|
|
184
|
+
const target = event.target;
|
|
185
|
+
// If clicking on a label that targets our input, ensure focus
|
|
186
|
+
if (target.tagName === 'LABEL' && target.getAttribute('for') === this.name) {
|
|
187
|
+
// Small delay to ensure the label click is processed first
|
|
188
|
+
setTimeout(() => {
|
|
189
|
+
input.focus();
|
|
190
|
+
}, 0);
|
|
191
|
+
}
|
|
192
|
+
});
|
|
193
|
+
this.listeners.push(labelClickListener);
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
applyCheckboxStyles() {
|
|
197
|
+
// Style the input directly without moving DOM elements
|
|
198
|
+
const styles = `
|
|
199
|
+
/* Complete reset and custom styling for our checkbox */
|
|
200
|
+
input[type="checkbox"].ap-checkbox-styled {
|
|
201
|
+
/* Targeted reset of problematic properties */
|
|
202
|
+
appearance: none !important;
|
|
203
|
+
-webkit-appearance: none !important;
|
|
204
|
+
-moz-appearance: none !important;
|
|
205
|
+
|
|
206
|
+
/* Our custom styling - use !important to override any global styles */
|
|
207
|
+
display: inline-block !important;
|
|
208
|
+
width: 16px !important;
|
|
209
|
+
height: 16px !important;
|
|
210
|
+
min-width: 16px !important;
|
|
211
|
+
min-height: 16px !important;
|
|
212
|
+
margin: 0 !important;
|
|
213
|
+
padding: 0 !important;
|
|
214
|
+
border: 1px solid var(--ref-color-grey-60);
|
|
215
|
+
border-radius: var(--sys-border-radius-sm);
|
|
216
|
+
background: var(--ref-color-white);
|
|
217
|
+
background-color: var(--ref-color-white);
|
|
218
|
+
box-sizing: border-box;
|
|
219
|
+
position: relative;
|
|
220
|
+
cursor: pointer;
|
|
221
|
+
vertical-align: middle;
|
|
222
|
+
|
|
223
|
+
/* Ensure no other styles can interfere */
|
|
224
|
+
box-shadow: none;
|
|
225
|
+
text-decoration: none;
|
|
226
|
+
font: inherit;
|
|
227
|
+
color: inherit;
|
|
228
|
+
letter-spacing: normal;
|
|
229
|
+
word-spacing: normal;
|
|
230
|
+
text-transform: none;
|
|
231
|
+
text-indent: 0;
|
|
232
|
+
text-shadow: none;
|
|
233
|
+
text-align: start;
|
|
234
|
+
}
|
|
235
|
+
|
|
236
|
+
/* Hover state */
|
|
237
|
+
input[type="checkbox"].ap-checkbox-styled:hover {
|
|
238
|
+
border-color: var(--ref-color-grey-80);
|
|
239
|
+
}
|
|
240
|
+
|
|
241
|
+
/* Active/pressed state */
|
|
242
|
+
input[type="checkbox"].ap-checkbox-styled:active {
|
|
243
|
+
border-color: var(--ref-color-grey-100);
|
|
244
|
+
}
|
|
245
|
+
|
|
246
|
+
/* Checked state */
|
|
247
|
+
input[type="checkbox"].ap-checkbox-styled:checked {
|
|
248
|
+
background: var(--ref-color-electric-blue-100);
|
|
249
|
+
border-color: var(--ref-color-electric-blue-100);
|
|
250
|
+
}
|
|
251
|
+
|
|
252
|
+
/* Checked hover state */
|
|
253
|
+
input[type="checkbox"].ap-checkbox-styled:checked:hover {
|
|
254
|
+
background: var(--ref-color-electric-blue-80);
|
|
255
|
+
border-color: var(--ref-color-electric-blue-100);
|
|
256
|
+
}
|
|
257
|
+
|
|
258
|
+
/* Checked active/pressed state */
|
|
259
|
+
input[type="checkbox"].ap-checkbox-styled:checked:active {
|
|
260
|
+
background: var(--ref-color-electric-blue-60);
|
|
261
|
+
border-color: var(--ref-color-electric-blue-100);
|
|
262
|
+
}
|
|
263
|
+
|
|
264
|
+
/* Indeterminate state */
|
|
265
|
+
input[type="checkbox"].ap-checkbox-styled:indeterminate {
|
|
266
|
+
background: var(--ref-color-electric-blue-100);
|
|
267
|
+
border-color: var(--ref-color-electric-blue-100);
|
|
268
|
+
}
|
|
269
|
+
|
|
270
|
+
/* Disabled state */
|
|
271
|
+
input[type="checkbox"].ap-checkbox-styled:disabled {
|
|
272
|
+
border-color: var(--ref-color-grey-20);
|
|
273
|
+
background: var(--ref-color-grey-10);
|
|
274
|
+
cursor: default;
|
|
275
|
+
}
|
|
276
|
+
|
|
277
|
+
input[type="checkbox"].ap-checkbox-styled:disabled:checked {
|
|
278
|
+
background: var(--ref-color-grey-20);
|
|
279
|
+
}
|
|
280
|
+
|
|
281
|
+
/* Focus state - only show on hover-capable devices like the component */
|
|
282
|
+
@media (hover: hover) {
|
|
283
|
+
input[type="checkbox"].ap-checkbox-styled:focus:not(.disabled) {
|
|
284
|
+
outline: 3px solid var(--ref-color-electric-blue-100) !important;
|
|
285
|
+
outline-offset: 1px !important;
|
|
286
|
+
}
|
|
287
|
+
}
|
|
288
|
+
|
|
289
|
+
/* Label styling - targets labels that follow our wrapper containing styled checkboxes */
|
|
290
|
+
span:has(input[type="checkbox"].ap-checkbox-styled) + label {
|
|
291
|
+
display: flex;
|
|
292
|
+
align-items: center;
|
|
293
|
+
font-family: var(--comp-forms-label-font-family);
|
|
294
|
+
font-size: var(--comp-forms-label-size);
|
|
295
|
+
font-weight: var(--comp-forms-label-font-weight);
|
|
296
|
+
line-height: var(--comp-forms-label-line-height);
|
|
297
|
+
color: var(--comp-forms-label-text-color);
|
|
298
|
+
}
|
|
299
|
+
|
|
300
|
+
/* Empty label styling */
|
|
301
|
+
span:has(input[type="checkbox"].ap-checkbox-styled) + label:empty {
|
|
302
|
+
display: none;
|
|
303
|
+
}
|
|
304
|
+
|
|
305
|
+
/* Disabled label styling */
|
|
306
|
+
span:has(input[type="checkbox"].ap-checkbox-styled:disabled) + label {
|
|
307
|
+
color: var(--ref-color-grey-60);
|
|
308
|
+
}
|
|
309
|
+
|
|
310
|
+
/* Label hover styling */
|
|
311
|
+
span:has(input[type="checkbox"].ap-checkbox-styled) + label:hover:not(.disabled) {
|
|
312
|
+
cursor: pointer;
|
|
313
|
+
}
|
|
314
|
+
|
|
315
|
+
/* Disabled label hover */
|
|
316
|
+
span:has(input[type="checkbox"].ap-checkbox-styled:disabled) + label:hover {
|
|
317
|
+
cursor: default;
|
|
318
|
+
}
|
|
319
|
+
`;
|
|
320
|
+
// Create and append style element
|
|
321
|
+
this.styleElement = this.renderer.createElement('style');
|
|
322
|
+
this.renderer.appendChild(this.styleElement, this.renderer.createText(styles));
|
|
323
|
+
this.renderer.appendChild(document.head, this.styleElement);
|
|
324
|
+
}
|
|
325
|
+
onBlur() {
|
|
326
|
+
this._onTouched();
|
|
327
|
+
}
|
|
328
|
+
onValueChange() {
|
|
329
|
+
if (!this.disabled) {
|
|
330
|
+
const input = this.elementRef.nativeElement;
|
|
331
|
+
if (this._indeterminate) {
|
|
332
|
+
// When indeterminate, clicking should go to checked state
|
|
333
|
+
this._checked = true;
|
|
334
|
+
this._indeterminate = false;
|
|
335
|
+
input.checked = true;
|
|
336
|
+
input.indeterminate = false;
|
|
337
|
+
}
|
|
338
|
+
else {
|
|
339
|
+
// Normal toggle behavior
|
|
340
|
+
this._checked = input.checked;
|
|
341
|
+
}
|
|
342
|
+
this.updateCheckmarkVisibility();
|
|
343
|
+
this.change.emit(this._checked);
|
|
344
|
+
this._controlValueAccessorChangeFn(this._checked);
|
|
345
|
+
}
|
|
346
|
+
}
|
|
347
|
+
// ControlValueAccessor implementation
|
|
348
|
+
writeValue(value) {
|
|
349
|
+
this._checked = value;
|
|
350
|
+
const input = this.elementRef.nativeElement;
|
|
351
|
+
input.checked = value;
|
|
352
|
+
// Ensure indeterminate state is properly set
|
|
353
|
+
input.indeterminate = this._indeterminate;
|
|
354
|
+
this.updateCheckmarkVisibility();
|
|
355
|
+
}
|
|
356
|
+
registerOnChange(fn) {
|
|
357
|
+
this._controlValueAccessorChangeFn = fn;
|
|
358
|
+
}
|
|
359
|
+
registerOnTouched(fn) {
|
|
360
|
+
this._onTouched = fn;
|
|
361
|
+
}
|
|
362
|
+
setDisabledState(isDisabled) {
|
|
363
|
+
this.disabled = isDisabled;
|
|
364
|
+
const input = this.elementRef.nativeElement;
|
|
365
|
+
input.disabled = isDisabled;
|
|
366
|
+
}
|
|
367
|
+
validate() {
|
|
368
|
+
const isNotValid = !this._checked && this.required;
|
|
369
|
+
return (isNotValid && {
|
|
370
|
+
invalid: true,
|
|
371
|
+
});
|
|
372
|
+
}
|
|
373
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: CheckboxDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
374
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.2.9", type: CheckboxDirective, isStandalone: true, selector: "input[type=\"checkbox\"][apCheckbox]", inputs: { ariaLabel: ["aria-label", "ariaLabel"], ariaLabelledby: ["aria-labelledby", "ariaLabelledby"], ariaDescribedby: ["aria-describedby", "ariaDescribedby"], disabled: ["disabled", "disabled", booleanAttribute], indeterminate: ["indeterminate", "indeterminate", booleanAttribute], checked: "checked", required: ["required", "required", booleanAttribute], name: "name" }, outputs: { change: "change" }, host: { listeners: { "blur": "onBlur()" }, properties: { "disabled": "disabled", "required": "required", "checked": "checked", "attr.aria-label": "ariaLabel", "attr.aria-labelledby": "ariaLabelledby", "attr.aria-describedby": "ariaDescribedby", "attr.data-test": "name", "id": "name" } }, providers: [
|
|
375
|
+
AP_CHECKBOX_DIRECTIVE_CONTROL_VALUE_ACCESSOR,
|
|
376
|
+
{
|
|
377
|
+
provide: NG_VALIDATORS,
|
|
378
|
+
useExisting: CheckboxDirective,
|
|
379
|
+
multi: true,
|
|
380
|
+
},
|
|
381
|
+
], ngImport: i0 });
|
|
382
|
+
}
|
|
383
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: CheckboxDirective, decorators: [{
|
|
384
|
+
type: Directive,
|
|
385
|
+
args: [{
|
|
386
|
+
selector: 'input[type="checkbox"][apCheckbox]',
|
|
387
|
+
standalone: true,
|
|
388
|
+
providers: [
|
|
389
|
+
AP_CHECKBOX_DIRECTIVE_CONTROL_VALUE_ACCESSOR,
|
|
390
|
+
{
|
|
391
|
+
provide: NG_VALIDATORS,
|
|
392
|
+
useExisting: CheckboxDirective,
|
|
393
|
+
multi: true,
|
|
394
|
+
},
|
|
395
|
+
],
|
|
396
|
+
host: {
|
|
397
|
+
'(blur)': 'onBlur()',
|
|
398
|
+
'[disabled]': 'disabled',
|
|
399
|
+
'[required]': 'required',
|
|
400
|
+
'[checked]': 'checked',
|
|
401
|
+
'[attr.aria-label]': 'ariaLabel',
|
|
402
|
+
'[attr.aria-labelledby]': 'ariaLabelledby',
|
|
403
|
+
'[attr.aria-describedby]': 'ariaDescribedby',
|
|
404
|
+
'[attr.data-test]': 'name',
|
|
405
|
+
'[id]': 'name',
|
|
406
|
+
},
|
|
407
|
+
}]
|
|
408
|
+
}], propDecorators: { ariaLabel: [{
|
|
409
|
+
type: Input,
|
|
410
|
+
args: ['aria-label']
|
|
411
|
+
}], ariaLabelledby: [{
|
|
412
|
+
type: Input,
|
|
413
|
+
args: ['aria-labelledby']
|
|
414
|
+
}], ariaDescribedby: [{
|
|
415
|
+
type: Input,
|
|
416
|
+
args: ['aria-describedby']
|
|
417
|
+
}], disabled: [{
|
|
418
|
+
type: Input,
|
|
419
|
+
args: [{
|
|
420
|
+
transform: booleanAttribute,
|
|
421
|
+
}]
|
|
422
|
+
}], indeterminate: [{
|
|
423
|
+
type: Input,
|
|
424
|
+
args: [{
|
|
425
|
+
transform: booleanAttribute,
|
|
426
|
+
}]
|
|
427
|
+
}], checked: [{
|
|
428
|
+
type: Input
|
|
429
|
+
}], required: [{
|
|
430
|
+
type: Input,
|
|
431
|
+
args: [{
|
|
432
|
+
transform: booleanAttribute,
|
|
433
|
+
}]
|
|
434
|
+
}], name: [{
|
|
435
|
+
type: Input,
|
|
436
|
+
args: [{
|
|
437
|
+
required: true,
|
|
438
|
+
}]
|
|
439
|
+
}], change: [{
|
|
440
|
+
type: Output
|
|
441
|
+
}] } });
|
|
442
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.directive.js","sourceRoot":"","sources":["../../../../libs/ui-components/directives/src/checkbox.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { apCheck, SymbolComponent, SymbolRegistry } from '@agorapulse/ui-symbol';\nimport {\n    booleanAttribute,\n    ComponentRef,\n    Directive,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    inject,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    Renderer2,\n    ViewContainerRef,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nexport const AP_CHECKBOX_DIRECTIVE_CONTROL_VALUE_ACCESSOR = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => CheckboxDirective),\n    multi: true,\n};\n\n/*\n    Host bindings is important here:\n    - This provides encapsulation and reactivity regardless of how the directive is used in templates.\n    - It guarantees that properties like checked, disabled, required, and ARIA attributes always reflect\n    only the directive's logic, not just consumer bindings.\n    - So we need to have host bindings for all the properties that we want to control.\n    - We could also use @HostListener.\n*/\n@Directive({\n    selector: 'input[type=\"checkbox\"][apCheckbox]',\n    standalone: true,\n    providers: [\n        AP_CHECKBOX_DIRECTIVE_CONTROL_VALUE_ACCESSOR,\n        {\n            provide: NG_VALIDATORS,\n            useExisting: CheckboxDirective,\n            multi: true,\n        },\n    ],\n    host: {\n        '(blur)': 'onBlur()',\n        '[disabled]': 'disabled',\n        '[required]': 'required',\n        '[checked]': 'checked',\n        '[attr.aria-label]': 'ariaLabel',\n        '[attr.aria-labelledby]': 'ariaLabelledby',\n        '[attr.aria-describedby]': 'ariaDescribedby',\n        '[attr.data-test]': 'name',\n        '[id]': 'name',\n    },\n})\nexport class CheckboxDirective implements ControlValueAccessor, OnInit, OnDestroy {\n    private readonly symbolRegistry = inject(SymbolRegistry);\n    private readonly elementRef = inject(ElementRef<HTMLInputElement>);\n    private readonly renderer = inject(Renderer2);\n    private readonly viewContainer = inject(ViewContainerRef);\n\n    @Input('aria-label') ariaLabel?: string;\n    @Input('aria-labelledby') ariaLabelledby?: string;\n    @Input('aria-describedby') ariaDescribedby?: string;\n    \n    @Input({\n        transform: booleanAttribute,\n    })\n    disabled = false;\n    \n    @Input({\n        transform: booleanAttribute,\n    })\n    set indeterminate(indeterminate: boolean) {\n        if (indeterminate) {\n            this._checked = false;\n        }\n        this._indeterminate = indeterminate;\n        const input = this.elementRef.nativeElement;\n        if (input) {\n            input.indeterminate = indeterminate;\n        }\n        // Only update visibility if containers are ready\n        if (this.checkmarkContainer && this.indeterminateContainer) {\n            this.updateCheckmarkVisibility();\n        }\n    }\n\n    get indeterminate(): boolean {\n        return this._indeterminate;\n    }\n\n    @Input() \n    set checked(checked: boolean) {\n        this._checked = checked;\n        // Only update visibility if containers are ready\n        if (this.checkmarkContainer && this.indeterminateContainer) {\n            this.updateCheckmarkVisibility();\n        }\n    }\n    \n    get checked(): boolean {\n        return this._checked;\n    }\n\n    @Input({\n        transform: booleanAttribute,\n    })\n    required = false;\n\n    @Input({\n        required: true,\n    })\n    set name(name: string) {\n        this._name = name;\n    }\n    get name(): string {\n        return this._name;\n    }\n\n    // eslint-disable-next-line @angular-eslint/no-output-native\n    @Output() readonly change: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n    private _checked = false;\n    private _indeterminate = false;\n    private _name = '';\n    private _controlValueAccessorChangeFn: (value: boolean) => void = () => {};\n    private _onTouched: () => void = () => {};\n    \n    private listeners: (() => void)[] = [];\n    private styleElement!: HTMLStyleElement;\n    private wrapper!: HTMLElement;\n    private checkmarkContainer!: HTMLElement;\n    private indeterminateContainer!: HTMLElement;\n    private symbolComponent?: ComponentRef<SymbolComponent>;\n\n    ngOnInit() {\n        this.symbolRegistry.registerSymbols([apCheck]);\n        this.createCheckboxStructure();\n        this.setupEventListeners();\n    }\n\n    ngOnDestroy(): void {\n        this.listeners.forEach(unlisten => unlisten());\n        if (this.styleElement && this.styleElement.parentNode) {\n            this.styleElement.parentNode.removeChild(this.styleElement);\n        }\n        if (this.symbolComponent) {\n            this.symbolComponent.destroy();\n        }\n        if (this.checkmarkContainer && this.checkmarkContainer.parentNode) {\n            this.checkmarkContainer.parentNode.removeChild(this.checkmarkContainer);\n        }\n        if (this.indeterminateContainer && this.indeterminateContainer.parentNode) {\n            this.indeterminateContainer.parentNode.removeChild(this.indeterminateContainer);\n        }\n        // Move input back out of wrapper and remove wrapper\n        if (this.wrapper && this.wrapper.parentNode) {\n            const input = this.elementRef.nativeElement;\n            this.renderer.insertBefore(this.wrapper.parentNode, input, this.wrapper);\n            this.wrapper.parentNode.removeChild(this.wrapper);\n        }\n    }\n\n    private createCheckboxStructure(): void {\n        const input = this.elementRef.nativeElement;\n        const parent = input.parentElement;\n        \n        // Hot take - Input doesn't need positioning since it will be wrapped\n        \n        // Make input's parent use inline-flex for alignment\n        if (parent) {\n            this.renderer.setStyle(parent, 'display', 'inline-flex');\n            this.renderer.setStyle(parent, 'align-items', 'center');\n            this.renderer.setStyle(parent, 'gap', 'var(--ref-spacing-xxs)');\n        }\n        \n        this.renderer.addClass(input, 'ap-checkbox-styled');\n        \n        this.checkmarkContainer = this.createOverlayContainer('ap-checkbox-checkmark');\n        \n        this.wrapper = this.renderer.createElement('span');\n        this.renderer.setStyle(this.wrapper, 'position', 'relative');\n        this.renderer.setStyle(this.wrapper, 'display', 'inline-flex');\n        this.renderer.setStyle(this.wrapper, 'align-items', 'center');\n        this.renderer.setStyle(this.wrapper, 'vertical-align', 'middle');\n        \n        this.renderer.insertBefore(parent, this.wrapper, input);\n        this.renderer.appendChild(this.wrapper, input);\n        \n        this.renderer.appendChild(this.wrapper, this.checkmarkContainer);\n        \n        this.indeterminateContainer = this.createOverlayContainer('ap-checkbox-indeterminate');\n        \n        this.renderer.appendChild(this.wrapper, this.indeterminateContainer);\n        \n        this.createCheckmarkSymbol();\n        this.createIndeterminateBar();\n        \n        this.applyCheckboxStyles();\n        \n        this.updateCheckmarkVisibility();\n    }\n\n    private createOverlayContainer(className: string): HTMLElement {\n        const container = this.renderer.createElement('span');\n        this.renderer.addClass(container, className);\n        this.renderer.setStyle(container, 'position', 'absolute');\n        this.renderer.setStyle(container, 'top', '50%'); \n        this.renderer.setStyle(container, 'left', '50%');   \n        this.renderer.setStyle(container, 'transform', 'translate(-50%, -50%)');\n        this.renderer.setStyle(container, 'width', 'auto'); \n        this.renderer.setStyle(container, 'height', 'auto'); \n        this.renderer.setStyle(container, 'display', 'flex');\n        this.renderer.setStyle(container, 'justify-content', 'center');\n        this.renderer.setStyle(container, 'align-items', 'center');\n        this.renderer.setStyle(container, 'pointer-events', 'none');\n        this.renderer.setStyle(container, 'opacity', '0');\n        this.renderer.setStyle(container, 'z-index', '1');\n        return container;\n    }\n\n    private createCheckmarkSymbol(): void {\n        // Create the symbol component\n        this.symbolComponent = this.viewContainer.createComponent(SymbolComponent);\n        \n        // Set inputs using setInput method for signal-based inputs\n        this.symbolComponent.setInput('symbolId', 'check');\n        this.symbolComponent.setInput('color', 'white');\n        this.symbolComponent.setInput('size', 10);\n        \n        // Append the symbol to our checkmark container\n        this.renderer.appendChild(this.checkmarkContainer, this.symbolComponent.location.nativeElement);\n    }\n\n    private createIndeterminateBar(): void {\n        // Create the indeterminate bar element exactly like the component\n        const bar = this.renderer.createElement('span');\n        this.renderer.setStyle(bar, 'height', '1.5px');\n        this.renderer.setStyle(bar, 'background', 'var(--ref-color-white)');\n        this.renderer.setStyle(bar, 'width', '8px');\n        \n        // Append the bar to the indeterminate container\n        this.renderer.appendChild(this.indeterminateContainer, bar);\n    }\n\n    private updateCheckmarkVisibility(): void {\n        if (this.checkmarkContainer) {\n            const opacity = this._checked && !this._indeterminate ? '1' : '0';\n            this.renderer.setStyle(this.checkmarkContainer, 'opacity', opacity);\n        }\n        if (this.indeterminateContainer) {\n            const opacity = this._indeterminate && !this._checked ? '1' : '0';\n            this.renderer.setStyle(this.indeterminateContainer, 'opacity', opacity);\n        }\n    }\n\n    private setupEventListeners(): void {\n        const input = this.elementRef.nativeElement;\n        \n        // Input change listener (native checkbox change)\n        const changeListener = this.renderer.listen(input, 'change', () => {\n            this.onValueChange();\n        });\n        this.listeners.push(changeListener);\n        \n        // Listen for label clicks to ensure focus is maintained\n        const parent = input.parentElement;\n        if (parent) {\n            const labelClickListener = this.renderer.listen(parent, 'click', (event: MouseEvent) => {\n                const target = event.target as HTMLElement;\n                // If clicking on a label that targets our input, ensure focus\n                if (target.tagName === 'LABEL' && target.getAttribute('for') === this.name) {\n                    // Small delay to ensure the label click is processed first\n                    setTimeout(() => {\n                        input.focus();\n                    }, 0);\n                }\n            });\n            this.listeners.push(labelClickListener);\n        }\n    }\n\n    private applyCheckboxStyles(): void {\n        // Style the input directly without moving DOM elements\n        const styles = `\n            /* Complete reset and custom styling for our checkbox */\n            input[type=\"checkbox\"].ap-checkbox-styled {\n                /* Targeted reset of problematic properties */\n                appearance: none !important;\n                -webkit-appearance: none !important;\n                -moz-appearance: none !important;\n                \n                /* Our custom styling - use !important to override any global styles */\n                display: inline-block !important;\n                width: 16px !important;\n                height: 16px !important;\n                min-width: 16px !important;\n                min-height: 16px !important;\n                margin: 0 !important;\n                padding: 0 !important;\n                border: 1px solid var(--ref-color-grey-60);\n                border-radius: var(--sys-border-radius-sm);\n                background: var(--ref-color-white);\n                background-color: var(--ref-color-white);\n                box-sizing: border-box;\n                position: relative;\n                cursor: pointer;\n                vertical-align: middle;\n                \n                /* Ensure no other styles can interfere */\n                box-shadow: none;\n                text-decoration: none;\n                font: inherit;\n                color: inherit;\n                letter-spacing: normal;\n                word-spacing: normal;\n                text-transform: none;\n                text-indent: 0;\n                text-shadow: none;\n                text-align: start;\n            }\n            \n            /* Hover state */\n            input[type=\"checkbox\"].ap-checkbox-styled:hover {\n                border-color: var(--ref-color-grey-80);\n            }\n            \n            /* Active/pressed state */\n            input[type=\"checkbox\"].ap-checkbox-styled:active {\n                border-color: var(--ref-color-grey-100);\n            }\n            \n            /* Checked state */\n            input[type=\"checkbox\"].ap-checkbox-styled:checked {\n                background: var(--ref-color-electric-blue-100);\n                border-color: var(--ref-color-electric-blue-100);\n            }\n            \n            /* Checked hover state */\n            input[type=\"checkbox\"].ap-checkbox-styled:checked:hover {\n                background: var(--ref-color-electric-blue-80);\n                border-color: var(--ref-color-electric-blue-100);\n            }\n            \n            /* Checked active/pressed state */\n            input[type=\"checkbox\"].ap-checkbox-styled:checked:active {\n                background: var(--ref-color-electric-blue-60);\n                border-color: var(--ref-color-electric-blue-100);\n            }\n            \n            /* Indeterminate state */\n            input[type=\"checkbox\"].ap-checkbox-styled:indeterminate {\n                background: var(--ref-color-electric-blue-100);\n                border-color: var(--ref-color-electric-blue-100);\n            }\n            \n            /* Disabled state */\n            input[type=\"checkbox\"].ap-checkbox-styled:disabled {\n                border-color: var(--ref-color-grey-20);\n                background: var(--ref-color-grey-10);\n                cursor: default;\n            }\n            \n            input[type=\"checkbox\"].ap-checkbox-styled:disabled:checked {\n                background: var(--ref-color-grey-20);\n            }\n            \n            /* Focus state - only show on hover-capable devices like the component */\n            @media (hover: hover) {\n                input[type=\"checkbox\"].ap-checkbox-styled:focus:not(.disabled) {\n                    outline: 3px solid var(--ref-color-electric-blue-100) !important;\n                    outline-offset: 1px !important;\n                }\n            }\n            \n            /* Label styling - targets labels that follow our wrapper containing styled checkboxes */\n            span:has(input[type=\"checkbox\"].ap-checkbox-styled) + label {\n                display: flex;\n                align-items: center;\n                font-family: var(--comp-forms-label-font-family);\n                font-size: var(--comp-forms-label-size);\n                font-weight: var(--comp-forms-label-font-weight);\n                line-height: var(--comp-forms-label-line-height);\n                color: var(--comp-forms-label-text-color);\n            }\n            \n            /* Empty label styling */\n            span:has(input[type=\"checkbox\"].ap-checkbox-styled) + label:empty {\n                display: none;\n            }\n            \n            /* Disabled label styling */\n            span:has(input[type=\"checkbox\"].ap-checkbox-styled:disabled) + label {\n                color: var(--ref-color-grey-60);\n            }\n            \n            /* Label hover styling */\n            span:has(input[type=\"checkbox\"].ap-checkbox-styled) + label:hover:not(.disabled) {\n                cursor: pointer;\n            }\n            \n            /* Disabled label hover */\n            span:has(input[type=\"checkbox\"].ap-checkbox-styled:disabled) + label:hover {\n                cursor: default;\n            }\n        `;\n        \n        // Create and append style element\n        this.styleElement = this.renderer.createElement('style');\n        this.renderer.appendChild(this.styleElement, this.renderer.createText(styles));\n        this.renderer.appendChild(document.head, this.styleElement);\n    }\n\n\n    onBlur(): void {\n        this._onTouched();\n    }\n\n    private onValueChange(): void {\n        if (!this.disabled) {\n            const input = this.elementRef.nativeElement;\n            \n            if (this._indeterminate) {\n                // When indeterminate, clicking should go to checked state\n                this._checked = true;\n                this._indeterminate = false;\n                input.checked = true;\n                input.indeterminate = false;\n            } else {\n                // Normal toggle behavior\n                this._checked = input.checked;\n            }\n            \n            this.updateCheckmarkVisibility();\n            this.change.emit(this._checked);\n            this._controlValueAccessorChangeFn(this._checked);\n        }\n    }\n\n\n    // ControlValueAccessor implementation\n    writeValue(value: boolean): void {\n        this._checked = value;\n        const input = this.elementRef.nativeElement;\n        input.checked = value;\n        // Ensure indeterminate state is properly set\n        input.indeterminate = this._indeterminate;\n        this.updateCheckmarkVisibility();\n    }\n\n    registerOnChange(fn: (value: boolean) => void): void {\n        this._controlValueAccessorChangeFn = fn;\n    }\n\n    registerOnTouched(fn: () => void): void {\n        this._onTouched = fn;\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n        const input = this.elementRef.nativeElement;\n        input.disabled = isDisabled;\n    }\n\n    validate() {\n        const isNotValid = !this._checked && this.required;\n        return (\n            isNotValid && {\n                invalid: true,\n            }\n        );\n    }\n}"]}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
export * from './autosize-textarea.directive';
|
|
2
2
|
export * from './base-button.directive';
|
|
3
|
+
export * from './checkbox.directive';
|
|
3
4
|
export * from './default-image.directive';
|
|
4
5
|
export * from './ellipsis.directive';
|
|
5
6
|
export * from './equal-validator.directive';
|
|
6
7
|
export * from './frozen-gif.directive';
|
|
7
8
|
export * from './multi-style-text.directive';
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYnMvdWktY29tcG9uZW50cy9kaXJlY3RpdmVzL3NyYy9wdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyw4QkFBOEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYXV0b3NpemUtdGV4dGFyZWEuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vYmFzZS1idXR0b24uZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vY2hlY2tib3guZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZGVmYXVsdC1pbWFnZS5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9lbGxpcHNpcy5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9lcXVhbC12YWxpZGF0b3IuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZnJvemVuLWdpZi5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9tdWx0aS1zdHlsZS10ZXh0LmRpcmVjdGl2ZSc7XG4iXX0=
|