@semantic-components/ui 0.0.1 → 0.0.10
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 +6 -0
- package/components/date-picker/date-picker.component.d.ts +30 -2
- package/components/date-picker/index.d.ts +1 -0
- package/components/date-picker/inline-date-picker.component.d.ts +23 -0
- package/components/date-picker/month-days.component.d.ts +11 -0
- package/components/date-picker/month-year-header.component.d.ts +7 -0
- package/components/date-picker/week-days-names.component.d.ts +11 -0
- package/components/dropdown/dropdown-divider.component.d.ts +5 -0
- package/components/dropdown/dropdown-item.component.d.ts +6 -0
- package/components/dropdown/dropdown.component.d.ts +5 -0
- package/components/dropdown/index.d.ts +3 -0
- package/components/editor/editor.component.d.ts +1 -1
- package/components/nav/index.d.ts +3 -0
- package/components/nav/nav-item-dropdown.component.d.ts +5 -0
- package/components/nav/nav-item.component.d.ts +5 -0
- package/components/nav/nav.component.d.ts +5 -0
- package/components/select/index.d.ts +2 -0
- package/components/select/select-option.component.d.ts +7 -0
- package/components/select/select.component.d.ts +55 -0
- package/components/tooltip/tooltip.component.d.ts +1 -1
- package/esm2022/components/date-picker/date-picker.component.mjs +181 -8
- package/esm2022/components/date-picker/index.mjs +2 -1
- package/esm2022/components/date-picker/inline-date-picker.component.mjs +185 -0
- package/esm2022/components/date-picker/month-days.component.mjs +69 -0
- package/esm2022/components/date-picker/month-year-header.component.mjs +124 -0
- package/esm2022/components/date-picker/week-days-names.component.mjs +37 -0
- package/esm2022/components/dropdown/dropdown-divider.component.mjs +16 -0
- package/esm2022/components/dropdown/dropdown-item.component.mjs +33 -0
- package/esm2022/components/dropdown/dropdown.component.mjs +85 -0
- package/esm2022/components/dropdown/index.mjs +4 -0
- package/esm2022/components/editor/editor.component.mjs +4 -4
- package/esm2022/components/nav/index.mjs +4 -0
- package/esm2022/components/nav/nav-item-dropdown.component.mjs +148 -0
- package/esm2022/components/nav/nav-item.component.mjs +16 -0
- package/esm2022/components/nav/nav.component.mjs +16 -0
- package/esm2022/components/select/index.mjs +3 -0
- package/esm2022/components/select/select-option.component.mjs +28 -0
- package/esm2022/components/select/select.component.mjs +252 -0
- package/esm2022/components/tooltip/tooltip.component.mjs +4 -4
- package/esm2022/index.mjs +4 -2
- package/fesm2022/semantic-components-ui.mjs +1132 -559
- package/fesm2022/semantic-components-ui.mjs.map +1 -1
- package/index.d.ts +3 -1
- package/package.json +7 -3
- package/components/navbar/index.d.ts +0 -1
- package/components/navbar/navbar.component.d.ts +0 -5
- package/esm2022/components/navbar/index.mjs +0 -2
- package/esm2022/components/navbar/navbar.component.mjs +0 -566
|
@@ -1,16 +1,16 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, ViewEncapsulation } from '@angular/core';
|
|
2
1
|
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, ViewEncapsulation } from '@angular/core';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export class EditorComponent {
|
|
5
5
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: EditorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
6
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.11", type: EditorComponent, isStandalone: true, selector: "
|
|
6
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.11", type: EditorComponent, isStandalone: true, selector: "sc-editor", ngImport: i0, template: `
|
|
7
7
|
<p>editor works!</p>
|
|
8
8
|
`, isInline: true, styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
9
9
|
}
|
|
10
10
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: EditorComponent, decorators: [{
|
|
11
11
|
type: Component,
|
|
12
|
-
args: [{ selector: '
|
|
12
|
+
args: [{ selector: 'sc-editor', standalone: true, imports: [CommonModule], template: `
|
|
13
13
|
<p>editor works!</p>
|
|
14
14
|
`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush }]
|
|
15
15
|
}] });
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdG9yLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWkvc3JjL2NvbXBvbmVudHMvZWRpdG9yL2VkaXRvci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBYXRGLE1BQU0sT0FBTyxlQUFlO3dHQUFmLGVBQWU7NEZBQWYsZUFBZSxxRUFQaEI7O0dBRVQseUVBSFMsWUFBWTs7NEZBUVgsZUFBZTtrQkFYM0IsU0FBUzsrQkFDRSxXQUFXLGNBQ1QsSUFBSSxXQUNQLENBQUMsWUFBWSxDQUFDLFlBQ2I7O0dBRVQsaUJBRWMsaUJBQWlCLENBQUMsSUFBSSxtQkFDcEIsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzYy1lZGl0b3InLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgdGVtcGxhdGU6IGBcbiAgICA8cD5lZGl0b3Igd29ya3MhPC9wPlxuICBgLFxuICBzdHlsZXM6IGBgLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgRWRpdG9yQ29tcG9uZW50IHt9XG4iXX0=
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export * from './nav.component';
|
|
2
|
+
export * from './nav-item.component';
|
|
3
|
+
export * from './nav-item-dropdown.component';
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL3NyYy9jb21wb25lbnRzL25hdi9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYywrQkFBK0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbmF2LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL25hdi1pdGVtLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL25hdi1pdGVtLWRyb3Bkb3duLmNvbXBvbmVudCc7XG4iXX0=
|
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, ViewEncapsulation } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class NavItemDropdownComponent {
|
|
5
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: NavItemDropdownComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
6
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.11", type: NavItemDropdownComponent, isStandalone: true, selector: "sc-nav-item-dropdown", ngImport: i0, template: `
|
|
7
|
+
<li>
|
|
8
|
+
<button
|
|
9
|
+
class="flex w-full items-center justify-between rounded px-3 py-2 text-gray-900 hover:bg-gray-100 md:w-auto md:border-0 md:p-0 md:hover:bg-transparent md:hover:text-blue-700 dark:border-gray-700 dark:text-white dark:hover:bg-gray-700 dark:focus:text-white md:dark:hover:bg-transparent md:dark:hover:text-blue-500"
|
|
10
|
+
id="dropdownNavbarLink"
|
|
11
|
+
data-dropdown-toggle="dropdownNavbar"
|
|
12
|
+
>
|
|
13
|
+
Dropdown
|
|
14
|
+
<svg
|
|
15
|
+
class="ms-2.5 size-2.5"
|
|
16
|
+
aria-hidden="true"
|
|
17
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
18
|
+
fill="none"
|
|
19
|
+
viewBox="0 0 10 6"
|
|
20
|
+
>
|
|
21
|
+
<path
|
|
22
|
+
stroke="currentColor"
|
|
23
|
+
stroke-linecap="round"
|
|
24
|
+
stroke-linejoin="round"
|
|
25
|
+
stroke-width="2"
|
|
26
|
+
d="m1 1 4 4 4-4"
|
|
27
|
+
/>
|
|
28
|
+
</svg>
|
|
29
|
+
</button>
|
|
30
|
+
<!-- Dropdown menu -->
|
|
31
|
+
<div
|
|
32
|
+
class="z-10 hidden w-44 divide-y divide-gray-100 rounded-lg bg-white font-normal shadow dark:divide-gray-600 dark:bg-gray-700"
|
|
33
|
+
id="dropdownNavbar"
|
|
34
|
+
>
|
|
35
|
+
<ul
|
|
36
|
+
class="py-2 text-sm text-gray-700 dark:text-gray-400"
|
|
37
|
+
aria-labelledby="dropdownLargeButton"
|
|
38
|
+
>
|
|
39
|
+
<li>
|
|
40
|
+
<a
|
|
41
|
+
class="block px-4 py-2 hover:bg-gray-100 dark:hover:bg-gray-600 dark:hover:text-white"
|
|
42
|
+
href="javascript:void(0)"
|
|
43
|
+
>
|
|
44
|
+
Dashboard
|
|
45
|
+
</a>
|
|
46
|
+
</li>
|
|
47
|
+
<li>
|
|
48
|
+
<a
|
|
49
|
+
class="block px-4 py-2 hover:bg-gray-100 dark:hover:bg-gray-600 dark:hover:text-white"
|
|
50
|
+
href="javascript:void(0)"
|
|
51
|
+
>
|
|
52
|
+
Settings
|
|
53
|
+
</a>
|
|
54
|
+
</li>
|
|
55
|
+
<li>
|
|
56
|
+
<a
|
|
57
|
+
class="block px-4 py-2 hover:bg-gray-100 dark:hover:bg-gray-600 dark:hover:text-white"
|
|
58
|
+
href="javascript:void(0)"
|
|
59
|
+
>
|
|
60
|
+
Earnings
|
|
61
|
+
</a>
|
|
62
|
+
</li>
|
|
63
|
+
</ul>
|
|
64
|
+
<div class="py-1">
|
|
65
|
+
<a
|
|
66
|
+
class="block px-4 py-2 text-sm text-gray-700 hover:bg-gray-100 dark:text-gray-200 dark:hover:bg-gray-600 dark:hover:text-white"
|
|
67
|
+
href="javascript:void(0)"
|
|
68
|
+
>
|
|
69
|
+
Sign out
|
|
70
|
+
</a>
|
|
71
|
+
</div>
|
|
72
|
+
</div>
|
|
73
|
+
</li>
|
|
74
|
+
`, isInline: true, styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
75
|
+
}
|
|
76
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: NavItemDropdownComponent, decorators: [{
|
|
77
|
+
type: Component,
|
|
78
|
+
args: [{ selector: 'sc-nav-item-dropdown', standalone: true, imports: [CommonModule], template: `
|
|
79
|
+
<li>
|
|
80
|
+
<button
|
|
81
|
+
class="flex w-full items-center justify-between rounded px-3 py-2 text-gray-900 hover:bg-gray-100 md:w-auto md:border-0 md:p-0 md:hover:bg-transparent md:hover:text-blue-700 dark:border-gray-700 dark:text-white dark:hover:bg-gray-700 dark:focus:text-white md:dark:hover:bg-transparent md:dark:hover:text-blue-500"
|
|
82
|
+
id="dropdownNavbarLink"
|
|
83
|
+
data-dropdown-toggle="dropdownNavbar"
|
|
84
|
+
>
|
|
85
|
+
Dropdown
|
|
86
|
+
<svg
|
|
87
|
+
class="ms-2.5 size-2.5"
|
|
88
|
+
aria-hidden="true"
|
|
89
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
90
|
+
fill="none"
|
|
91
|
+
viewBox="0 0 10 6"
|
|
92
|
+
>
|
|
93
|
+
<path
|
|
94
|
+
stroke="currentColor"
|
|
95
|
+
stroke-linecap="round"
|
|
96
|
+
stroke-linejoin="round"
|
|
97
|
+
stroke-width="2"
|
|
98
|
+
d="m1 1 4 4 4-4"
|
|
99
|
+
/>
|
|
100
|
+
</svg>
|
|
101
|
+
</button>
|
|
102
|
+
<!-- Dropdown menu -->
|
|
103
|
+
<div
|
|
104
|
+
class="z-10 hidden w-44 divide-y divide-gray-100 rounded-lg bg-white font-normal shadow dark:divide-gray-600 dark:bg-gray-700"
|
|
105
|
+
id="dropdownNavbar"
|
|
106
|
+
>
|
|
107
|
+
<ul
|
|
108
|
+
class="py-2 text-sm text-gray-700 dark:text-gray-400"
|
|
109
|
+
aria-labelledby="dropdownLargeButton"
|
|
110
|
+
>
|
|
111
|
+
<li>
|
|
112
|
+
<a
|
|
113
|
+
class="block px-4 py-2 hover:bg-gray-100 dark:hover:bg-gray-600 dark:hover:text-white"
|
|
114
|
+
href="javascript:void(0)"
|
|
115
|
+
>
|
|
116
|
+
Dashboard
|
|
117
|
+
</a>
|
|
118
|
+
</li>
|
|
119
|
+
<li>
|
|
120
|
+
<a
|
|
121
|
+
class="block px-4 py-2 hover:bg-gray-100 dark:hover:bg-gray-600 dark:hover:text-white"
|
|
122
|
+
href="javascript:void(0)"
|
|
123
|
+
>
|
|
124
|
+
Settings
|
|
125
|
+
</a>
|
|
126
|
+
</li>
|
|
127
|
+
<li>
|
|
128
|
+
<a
|
|
129
|
+
class="block px-4 py-2 hover:bg-gray-100 dark:hover:bg-gray-600 dark:hover:text-white"
|
|
130
|
+
href="javascript:void(0)"
|
|
131
|
+
>
|
|
132
|
+
Earnings
|
|
133
|
+
</a>
|
|
134
|
+
</li>
|
|
135
|
+
</ul>
|
|
136
|
+
<div class="py-1">
|
|
137
|
+
<a
|
|
138
|
+
class="block px-4 py-2 text-sm text-gray-700 hover:bg-gray-100 dark:text-gray-200 dark:hover:bg-gray-600 dark:hover:text-white"
|
|
139
|
+
href="javascript:void(0)"
|
|
140
|
+
>
|
|
141
|
+
Sign out
|
|
142
|
+
</a>
|
|
143
|
+
</div>
|
|
144
|
+
</div>
|
|
145
|
+
</li>
|
|
146
|
+
`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush }]
|
|
147
|
+
}] });
|
|
148
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2LWl0ZW0tZHJvcGRvd24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91aS9zcmMvY29tcG9uZW50cy9uYXYvbmF2LWl0ZW0tZHJvcGRvd24uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDOztBQStFdEYsTUFBTSxPQUFPLHdCQUF3Qjt3R0FBeEIsd0JBQXdCOzRGQUF4Qix3QkFBd0IsZ0ZBekV6Qjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FvRVQseUVBckVTLFlBQVk7OzRGQTBFWCx3QkFBd0I7a0JBN0VwQyxTQUFTOytCQUNFLHNCQUFzQixjQUNwQixJQUFJLFdBQ1AsQ0FBQyxZQUFZLENBQUMsWUFDYjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FvRVQsaUJBRWMsaUJBQWlCLENBQUMsSUFBSSxtQkFDcEIsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzYy1uYXYtaXRlbS1kcm9wZG93bicsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxsaT5cbiAgICAgIDxidXR0b25cbiAgICAgICAgY2xhc3M9XCJmbGV4IHctZnVsbCBpdGVtcy1jZW50ZXIganVzdGlmeS1iZXR3ZWVuIHJvdW5kZWQgcHgtMyBweS0yIHRleHQtZ3JheS05MDAgaG92ZXI6YmctZ3JheS0xMDAgbWQ6dy1hdXRvIG1kOmJvcmRlci0wIG1kOnAtMCBtZDpob3ZlcjpiZy10cmFuc3BhcmVudCBtZDpob3Zlcjp0ZXh0LWJsdWUtNzAwIGRhcms6Ym9yZGVyLWdyYXktNzAwIGRhcms6dGV4dC13aGl0ZSBkYXJrOmhvdmVyOmJnLWdyYXktNzAwIGRhcms6Zm9jdXM6dGV4dC13aGl0ZSBtZDpkYXJrOmhvdmVyOmJnLXRyYW5zcGFyZW50IG1kOmRhcms6aG92ZXI6dGV4dC1ibHVlLTUwMFwiXG4gICAgICAgIGlkPVwiZHJvcGRvd25OYXZiYXJMaW5rXCJcbiAgICAgICAgZGF0YS1kcm9wZG93bi10b2dnbGU9XCJkcm9wZG93bk5hdmJhclwiXG4gICAgICA+XG4gICAgICAgIERyb3Bkb3duXG4gICAgICAgIDxzdmdcbiAgICAgICAgICBjbGFzcz1cIm1zLTIuNSBzaXplLTIuNVwiXG4gICAgICAgICAgYXJpYS1oaWRkZW49XCJ0cnVlXCJcbiAgICAgICAgICB4bWxucz1cImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnXCJcbiAgICAgICAgICBmaWxsPVwibm9uZVwiXG4gICAgICAgICAgdmlld0JveD1cIjAgMCAxMCA2XCJcbiAgICAgICAgPlxuICAgICAgICAgIDxwYXRoXG4gICAgICAgICAgICBzdHJva2U9XCJjdXJyZW50Q29sb3JcIlxuICAgICAgICAgICAgc3Ryb2tlLWxpbmVjYXA9XCJyb3VuZFwiXG4gICAgICAgICAgICBzdHJva2UtbGluZWpvaW49XCJyb3VuZFwiXG4gICAgICAgICAgICBzdHJva2Utd2lkdGg9XCIyXCJcbiAgICAgICAgICAgIGQ9XCJtMSAxIDQgNCA0LTRcIlxuICAgICAgICAgIC8+XG4gICAgICAgIDwvc3ZnPlxuICAgICAgPC9idXR0b24+XG4gICAgICA8IS0tIERyb3Bkb3duIG1lbnUgLS0+XG4gICAgICA8ZGl2XG4gICAgICAgIGNsYXNzPVwiei0xMCBoaWRkZW4gdy00NCBkaXZpZGUteSBkaXZpZGUtZ3JheS0xMDAgcm91bmRlZC1sZyBiZy13aGl0ZSBmb250LW5vcm1hbCBzaGFkb3cgZGFyazpkaXZpZGUtZ3JheS02MDAgZGFyazpiZy1ncmF5LTcwMFwiXG4gICAgICAgIGlkPVwiZHJvcGRvd25OYXZiYXJcIlxuICAgICAgPlxuICAgICAgICA8dWxcbiAgICAgICAgICBjbGFzcz1cInB5LTIgdGV4dC1zbSB0ZXh0LWdyYXktNzAwIGRhcms6dGV4dC1ncmF5LTQwMFwiXG4gICAgICAgICAgYXJpYS1sYWJlbGxlZGJ5PVwiZHJvcGRvd25MYXJnZUJ1dHRvblwiXG4gICAgICAgID5cbiAgICAgICAgICA8bGk+XG4gICAgICAgICAgICA8YVxuICAgICAgICAgICAgICBjbGFzcz1cImJsb2NrIHB4LTQgcHktMiBob3ZlcjpiZy1ncmF5LTEwMCBkYXJrOmhvdmVyOmJnLWdyYXktNjAwIGRhcms6aG92ZXI6dGV4dC13aGl0ZVwiXG4gICAgICAgICAgICAgIGhyZWY9XCJqYXZhc2NyaXB0OnZvaWQoMClcIlxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICBEYXNoYm9hcmRcbiAgICAgICAgICAgIDwvYT5cbiAgICAgICAgICA8L2xpPlxuICAgICAgICAgIDxsaT5cbiAgICAgICAgICAgIDxhXG4gICAgICAgICAgICAgIGNsYXNzPVwiYmxvY2sgcHgtNCBweS0yIGhvdmVyOmJnLWdyYXktMTAwIGRhcms6aG92ZXI6YmctZ3JheS02MDAgZGFyazpob3Zlcjp0ZXh0LXdoaXRlXCJcbiAgICAgICAgICAgICAgaHJlZj1cImphdmFzY3JpcHQ6dm9pZCgwKVwiXG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIFNldHRpbmdzXG4gICAgICAgICAgICA8L2E+XG4gICAgICAgICAgPC9saT5cbiAgICAgICAgICA8bGk+XG4gICAgICAgICAgICA8YVxuICAgICAgICAgICAgICBjbGFzcz1cImJsb2NrIHB4LTQgcHktMiBob3ZlcjpiZy1ncmF5LTEwMCBkYXJrOmhvdmVyOmJnLWdyYXktNjAwIGRhcms6aG92ZXI6dGV4dC13aGl0ZVwiXG4gICAgICAgICAgICAgIGhyZWY9XCJqYXZhc2NyaXB0OnZvaWQoMClcIlxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICBFYXJuaW5nc1xuICAgICAgICAgICAgPC9hPlxuICAgICAgICAgIDwvbGk+XG4gICAgICAgIDwvdWw+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJweS0xXCI+XG4gICAgICAgICAgPGFcbiAgICAgICAgICAgIGNsYXNzPVwiYmxvY2sgcHgtNCBweS0yIHRleHQtc20gdGV4dC1ncmF5LTcwMCBob3ZlcjpiZy1ncmF5LTEwMCBkYXJrOnRleHQtZ3JheS0yMDAgZGFyazpob3ZlcjpiZy1ncmF5LTYwMCBkYXJrOmhvdmVyOnRleHQtd2hpdGVcIlxuICAgICAgICAgICAgaHJlZj1cImphdmFzY3JpcHQ6dm9pZCgwKVwiXG4gICAgICAgICAgPlxuICAgICAgICAgICAgU2lnbiBvdXRcbiAgICAgICAgICA8L2E+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgPC9saT5cbiAgYCxcbiAgc3R5bGVzOiBgYCxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIE5hdkl0ZW1Ecm9wZG93bkNvbXBvbmVudCB7fVxuIl19
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, ViewEncapsulation } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class NavItemComponent {
|
|
5
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: NavItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
6
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.11", type: NavItemComponent, isStandalone: true, selector: "sc-nav-item", ngImport: i0, template: `
|
|
7
|
+
<p>nav-item works!</p>
|
|
8
|
+
`, isInline: true, styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
9
|
+
}
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: NavItemComponent, decorators: [{
|
|
11
|
+
type: Component,
|
|
12
|
+
args: [{ selector: 'sc-nav-item', standalone: true, imports: [CommonModule], template: `
|
|
13
|
+
<p>nav-item works!</p>
|
|
14
|
+
`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush }]
|
|
15
|
+
}] });
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2LWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91aS9zcmMvY29tcG9uZW50cy9uYXYvbmF2LWl0ZW0uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDOztBQWF0RixNQUFNLE9BQU8sZ0JBQWdCO3dHQUFoQixnQkFBZ0I7NEZBQWhCLGdCQUFnQix1RUFQakI7O0dBRVQseUVBSFMsWUFBWTs7NEZBUVgsZ0JBQWdCO2tCQVg1QixTQUFTOytCQUNFLGFBQWEsY0FDWCxJQUFJLFdBQ1AsQ0FBQyxZQUFZLENBQUMsWUFDYjs7R0FFVCxpQkFFYyxpQkFBaUIsQ0FBQyxJQUFJLG1CQUNwQix1QkFBdUIsQ0FBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NjLW5hdi1pdGVtJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIHRlbXBsYXRlOiBgXG4gICAgPHA+bmF2LWl0ZW0gd29ya3MhPC9wPlxuICBgLFxuICBzdHlsZXM6IGBgLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgTmF2SXRlbUNvbXBvbmVudCB7fVxuIl19
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, ViewEncapsulation } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class NavComponent {
|
|
5
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: NavComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
6
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.11", type: NavComponent, isStandalone: true, selector: "sc-nav", ngImport: i0, template: `
|
|
7
|
+
<p>nav works!</p>
|
|
8
|
+
`, isInline: true, styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
9
|
+
}
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: NavComponent, decorators: [{
|
|
11
|
+
type: Component,
|
|
12
|
+
args: [{ selector: 'sc-nav', standalone: true, imports: [CommonModule], template: `
|
|
13
|
+
<p>nav works!</p>
|
|
14
|
+
`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush }]
|
|
15
|
+
}] });
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWkvc3JjL2NvbXBvbmVudHMvbmF2L25hdi5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBYXRGLE1BQU0sT0FBTyxZQUFZO3dHQUFaLFlBQVk7NEZBQVosWUFBWSxrRUFQYjs7R0FFVCx5RUFIUyxZQUFZOzs0RkFRWCxZQUFZO2tCQVh4QixTQUFTOytCQUNFLFFBQVEsY0FDTixJQUFJLFdBQ1AsQ0FBQyxZQUFZLENBQUMsWUFDYjs7R0FFVCxpQkFFYyxpQkFBaUIsQ0FBQyxJQUFJLG1CQUNwQix1QkFBdUIsQ0FBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NjLW5hdicsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxwPm5hdiB3b3JrcyE8L3A+XG4gIGAsXG4gIHN0eWxlczogYGAsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBOYXZDb21wb25lbnQge31cbiJdfQ==
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from './select.component';
|
|
2
|
+
export * from './select-option.component';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL3NyYy9jb21wb25lbnRzL3NlbGVjdC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsMkJBQTJCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3NlbGVjdC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9zZWxlY3Qtb3B0aW9uLmNvbXBvbmVudCc7XG4iXX0=
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, HostBinding, Input, ViewEncapsulation, } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class SelectOptionComponent {
|
|
5
|
+
value;
|
|
6
|
+
disabled = false;
|
|
7
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: SelectOptionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
8
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.11", type: SelectOptionComponent, isStandalone: true, selector: "sc-select-option", inputs: { value: "value", disabled: "disabled" }, host: { attributes: { "role": "listbox" }, properties: { "attr.aria-label": "value", "class.disabled": "this.disabled" } }, ngImport: i0, template: `
|
|
9
|
+
<ng-content></ng-content>
|
|
10
|
+
`, isInline: true, styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
11
|
+
}
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: SelectOptionComponent, decorators: [{
|
|
13
|
+
type: Component,
|
|
14
|
+
args: [{ selector: 'sc-select-option', standalone: true, imports: [CommonModule], template: `
|
|
15
|
+
<ng-content></ng-content>
|
|
16
|
+
`, host: {
|
|
17
|
+
role: 'listbox',
|
|
18
|
+
'[attr.aria-label]': 'value',
|
|
19
|
+
}, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush }]
|
|
20
|
+
}], propDecorators: { value: [{
|
|
21
|
+
type: Input
|
|
22
|
+
}], disabled: [{
|
|
23
|
+
type: HostBinding,
|
|
24
|
+
args: ['class.disabled']
|
|
25
|
+
}, {
|
|
26
|
+
type: Input
|
|
27
|
+
}] } });
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LW9wdGlvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL3NyYy9jb21wb25lbnRzL3NlbGVjdC9zZWxlY3Qtb3B0aW9uLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsV0FBVyxFQUNYLEtBQUssRUFDTCxpQkFBaUIsR0FDbEIsTUFBTSxlQUFlLENBQUM7O0FBaUJ2QixNQUFNLE9BQU8scUJBQXFCO0lBRXpCLEtBQUssQ0FBTztJQUlaLFFBQVEsR0FBRyxLQUFLLENBQUM7d0dBTmIscUJBQXFCOzRGQUFyQixxQkFBcUIsMFBBWHRCOztHQUVULHlFQUhTLFlBQVk7OzRGQVlYLHFCQUFxQjtrQkFmakMsU0FBUzsrQkFDRSxrQkFBa0IsY0FDaEIsSUFBSSxXQUNQLENBQUMsWUFBWSxDQUFDLFlBQ2I7O0dBRVQsUUFFSzt3QkFDSixJQUFJLEVBQUUsU0FBUzt3QkFDZixtQkFBbUIsRUFBRSxPQUFPO3FCQUM3QixpQkFDYyxpQkFBaUIsQ0FBQyxJQUFJLG1CQUNwQix1QkFBdUIsQ0FBQyxNQUFNOzhCQUl4QyxLQUFLO3NCQURYLEtBQUs7Z0JBS0MsUUFBUTtzQkFGZCxXQUFXO3VCQUFDLGdCQUFnQjs7c0JBQzVCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgSG9zdEJpbmRpbmcsXG4gIElucHV0LFxuICBWaWV3RW5jYXBzdWxhdGlvbixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NjLXNlbGVjdC1vcHRpb24nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgdGVtcGxhdGU6IGBcbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gIGAsXG4gIHN0eWxlczogYGAsXG4gIGhvc3Q6IHtcbiAgICByb2xlOiAnbGlzdGJveCcsXG4gICAgJ1thdHRyLmFyaWEtbGFiZWxdJzogJ3ZhbHVlJyxcbiAgfSxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIFNlbGVjdE9wdGlvbkNvbXBvbmVudCB7XG4gIEBJbnB1dCgpXG4gIHB1YmxpYyB2YWx1ZSE6IGFueTtcblxuICBASG9zdEJpbmRpbmcoJ2NsYXNzLmRpc2FibGVkJylcbiAgQElucHV0KClcbiAgcHVibGljIGRpc2FibGVkID0gZmFsc2U7XG59XG4iXX0=
|
|
@@ -0,0 +1,252 @@
|
|
|
1
|
+
import { Overlay, OverlayConfig } from '@angular/cdk/overlay';
|
|
2
|
+
import { CdkPortal, PortalModule } from '@angular/cdk/portal';
|
|
3
|
+
import { CommonModule } from '@angular/common';
|
|
4
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChildren, ElementRef, EventEmitter, Input, Output, QueryList, ViewChild, ViewEncapsulation, forwardRef, } from '@angular/core';
|
|
5
|
+
import { NG_VALIDATORS, NG_VALUE_ACCESSOR, } from '@angular/forms';
|
|
6
|
+
import { DomSanitizer } from '@angular/platform-browser';
|
|
7
|
+
import { noop } from 'rxjs';
|
|
8
|
+
import { SelectOptionComponent } from './select-option.component';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
import * as i1 from "@angular/platform-browser";
|
|
11
|
+
import * as i2 from "@angular/cdk/overlay";
|
|
12
|
+
import * as i3 from "@angular/common";
|
|
13
|
+
import * as i4 from "@angular/cdk/portal";
|
|
14
|
+
export class SelectComponent {
|
|
15
|
+
cd;
|
|
16
|
+
domSanitizer;
|
|
17
|
+
overlay;
|
|
18
|
+
// eslint-disable-next-line @angular-eslint/no-input-rename
|
|
19
|
+
inputId = '';
|
|
20
|
+
label = '';
|
|
21
|
+
placeholder = '';
|
|
22
|
+
required = false;
|
|
23
|
+
disabled = false;
|
|
24
|
+
error = false;
|
|
25
|
+
multiple = false;
|
|
26
|
+
search = false;
|
|
27
|
+
ariaLabel = '';
|
|
28
|
+
ariaLabelledby = '';
|
|
29
|
+
// eslint-disable-next-line @angular-eslint/no-output-native
|
|
30
|
+
change = new EventEmitter();
|
|
31
|
+
select;
|
|
32
|
+
contentTemplate;
|
|
33
|
+
options;
|
|
34
|
+
displayText;
|
|
35
|
+
displayX = false;
|
|
36
|
+
//private readonly selectedOption: SelectOptionComponent;
|
|
37
|
+
showing = false;
|
|
38
|
+
showPlaceholder = true;
|
|
39
|
+
overlayRef;
|
|
40
|
+
constructor(cd, domSanitizer, overlay) {
|
|
41
|
+
this.cd = cd;
|
|
42
|
+
this.domSanitizer = domSanitizer;
|
|
43
|
+
this.overlay = overlay;
|
|
44
|
+
}
|
|
45
|
+
onChangeFn = (_) => noop();
|
|
46
|
+
onTouchedFn = () => noop();
|
|
47
|
+
registerOnChange(fn) {
|
|
48
|
+
this.onChangeFn = fn;
|
|
49
|
+
}
|
|
50
|
+
registerOnTouched(fn) {
|
|
51
|
+
this.onTouchedFn = fn;
|
|
52
|
+
}
|
|
53
|
+
validate(control) {
|
|
54
|
+
return null;
|
|
55
|
+
}
|
|
56
|
+
ngOnInit() {
|
|
57
|
+
if (!this.displayText) {
|
|
58
|
+
this.displayText = this.domSanitizer.bypassSecurityTrustHtml(this.placeholder);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
62
|
+
writeValue(obj) { }
|
|
63
|
+
onTouched() {
|
|
64
|
+
this.onTouchedFn();
|
|
65
|
+
}
|
|
66
|
+
mainSelectClasses() {
|
|
67
|
+
return {
|
|
68
|
+
mainSelect: true,
|
|
69
|
+
error: this.error,
|
|
70
|
+
disabled: this.disabled,
|
|
71
|
+
placeholder: this.showPlaceholder,
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
onDropMenuIconClick(event) {
|
|
75
|
+
if (!this.disabled) {
|
|
76
|
+
event.stopPropagation();
|
|
77
|
+
this.select.nativeElement.focus();
|
|
78
|
+
this.select.nativeElement.click();
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
onKeyDown(event) {
|
|
82
|
+
console.log('onKeyDown');
|
|
83
|
+
}
|
|
84
|
+
showDropdown() {
|
|
85
|
+
this.overlayRef = this.overlay.create(this.getOverlayConfig());
|
|
86
|
+
this.overlayRef.attach(this.contentTemplate);
|
|
87
|
+
this.syncWidth();
|
|
88
|
+
this.overlayRef.backdropClick().subscribe(() => this.hide());
|
|
89
|
+
this.showing = true;
|
|
90
|
+
}
|
|
91
|
+
hide() {
|
|
92
|
+
this.overlayRef.detach();
|
|
93
|
+
this.showing = false;
|
|
94
|
+
}
|
|
95
|
+
syncWidth() {
|
|
96
|
+
if (!this.overlayRef) {
|
|
97
|
+
return;
|
|
98
|
+
}
|
|
99
|
+
const refRectWidth = this.select.nativeElement.getBoundingClientRect().width;
|
|
100
|
+
this.overlayRef.updateSize({ width: refRectWidth });
|
|
101
|
+
}
|
|
102
|
+
getOverlayConfig() {
|
|
103
|
+
const positionStrategy = this.overlay
|
|
104
|
+
.position()
|
|
105
|
+
.flexibleConnectedTo(this.select.nativeElement)
|
|
106
|
+
.withPush(true)
|
|
107
|
+
.withPositions([
|
|
108
|
+
{
|
|
109
|
+
originX: 'start',
|
|
110
|
+
originY: 'bottom',
|
|
111
|
+
overlayX: 'start',
|
|
112
|
+
overlayY: 'top',
|
|
113
|
+
offsetY: 4,
|
|
114
|
+
},
|
|
115
|
+
{
|
|
116
|
+
originX: 'start',
|
|
117
|
+
originY: 'top',
|
|
118
|
+
overlayX: 'start',
|
|
119
|
+
overlayY: 'bottom',
|
|
120
|
+
offsetY: -4,
|
|
121
|
+
},
|
|
122
|
+
]);
|
|
123
|
+
const scrollStrategy = this.overlay.scrollStrategies.reposition();
|
|
124
|
+
return new OverlayConfig({
|
|
125
|
+
positionStrategy: positionStrategy,
|
|
126
|
+
scrollStrategy: scrollStrategy,
|
|
127
|
+
hasBackdrop: true,
|
|
128
|
+
backdropClass: 'cdk-overlay-transparent-backdrop',
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: SelectComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.DomSanitizer }, { token: i2.Overlay }], target: i0.ɵɵFactoryTarget.Component });
|
|
132
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.11", type: SelectComponent, isStandalone: true, selector: "sc-select", inputs: { inputId: ["id", "inputId"], label: "label", placeholder: "placeholder", required: "required", disabled: "disabled", error: "error", multiple: "multiple", search: "search", ariaLabel: ["aria-label", "ariaLabel"], ariaLabelledby: ["aria-labelledby", "ariaLabelledby"] }, outputs: { change: "change" }, providers: [
|
|
133
|
+
{
|
|
134
|
+
provide: NG_VALUE_ACCESSOR,
|
|
135
|
+
useExisting: forwardRef(() => SelectComponent),
|
|
136
|
+
multi: true,
|
|
137
|
+
},
|
|
138
|
+
{
|
|
139
|
+
provide: NG_VALIDATORS,
|
|
140
|
+
multi: true,
|
|
141
|
+
useExisting: SelectComponent,
|
|
142
|
+
},
|
|
143
|
+
], queries: [{ propertyName: "options", predicate: SelectOptionComponent }], viewQueries: [{ propertyName: "select", first: true, predicate: ["select"], descendants: true }, { propertyName: "contentTemplate", first: true, predicate: CdkPortal, descendants: true }], ngImport: i0, template: `
|
|
144
|
+
<div class="" [class.required]="required">
|
|
145
|
+
@if (label.length > 0) {
|
|
146
|
+
<p class="" [class.error]="error">{{ label }}</p>
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
<div
|
|
150
|
+
#select
|
|
151
|
+
[ngClass]="mainSelectClasses()"
|
|
152
|
+
[attr.id]="inputId"
|
|
153
|
+
[attr.aria-label]="ariaLabel || null"
|
|
154
|
+
[attr.aria-labelledby]="ariaLabelledby || null"
|
|
155
|
+
[attr.aria-multiselectable]="false"
|
|
156
|
+
[innerHTML]="displayText"
|
|
157
|
+
(click)="showDropdown()"
|
|
158
|
+
(keydown)="onKeyDown($event)"
|
|
159
|
+
(blur)="onTouched()"
|
|
160
|
+
role="listbox"
|
|
161
|
+
tabindex="{{ this.disabled ? -1 : 0 }}"
|
|
162
|
+
></div>
|
|
163
|
+
<button class="" (click)="onDropMenuIconClick($event)">test</button>
|
|
164
|
+
<ng-template class="dropdown" #overlayTemplate="cdkPortal" cdk-portal>
|
|
165
|
+
<div class="">
|
|
166
|
+
<button class="" (keydown)="onKeyDown($event)">
|
|
167
|
+
<ng-content />
|
|
168
|
+
</button>
|
|
169
|
+
</div>
|
|
170
|
+
</ng-template>
|
|
171
|
+
</div>
|
|
172
|
+
`, isInline: true, styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: PortalModule }, { kind: "directive", type: i4.TemplatePortalDirective, selector: "[cdk-portal], [portal]", exportAs: ["cdkPortal"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
173
|
+
}
|
|
174
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: SelectComponent, decorators: [{
|
|
175
|
+
type: Component,
|
|
176
|
+
args: [{ selector: 'sc-select', standalone: true, imports: [CommonModule, PortalModule], template: `
|
|
177
|
+
<div class="" [class.required]="required">
|
|
178
|
+
@if (label.length > 0) {
|
|
179
|
+
<p class="" [class.error]="error">{{ label }}</p>
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
<div
|
|
183
|
+
#select
|
|
184
|
+
[ngClass]="mainSelectClasses()"
|
|
185
|
+
[attr.id]="inputId"
|
|
186
|
+
[attr.aria-label]="ariaLabel || null"
|
|
187
|
+
[attr.aria-labelledby]="ariaLabelledby || null"
|
|
188
|
+
[attr.aria-multiselectable]="false"
|
|
189
|
+
[innerHTML]="displayText"
|
|
190
|
+
(click)="showDropdown()"
|
|
191
|
+
(keydown)="onKeyDown($event)"
|
|
192
|
+
(blur)="onTouched()"
|
|
193
|
+
role="listbox"
|
|
194
|
+
tabindex="{{ this.disabled ? -1 : 0 }}"
|
|
195
|
+
></div>
|
|
196
|
+
<button class="" (click)="onDropMenuIconClick($event)">test</button>
|
|
197
|
+
<ng-template class="dropdown" #overlayTemplate="cdkPortal" cdk-portal>
|
|
198
|
+
<div class="">
|
|
199
|
+
<button class="" (keydown)="onKeyDown($event)">
|
|
200
|
+
<ng-content />
|
|
201
|
+
</button>
|
|
202
|
+
</div>
|
|
203
|
+
</ng-template>
|
|
204
|
+
</div>
|
|
205
|
+
`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
206
|
+
{
|
|
207
|
+
provide: NG_VALUE_ACCESSOR,
|
|
208
|
+
useExisting: forwardRef(() => SelectComponent),
|
|
209
|
+
multi: true,
|
|
210
|
+
},
|
|
211
|
+
{
|
|
212
|
+
provide: NG_VALIDATORS,
|
|
213
|
+
multi: true,
|
|
214
|
+
useExisting: SelectComponent,
|
|
215
|
+
},
|
|
216
|
+
] }]
|
|
217
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.DomSanitizer }, { type: i2.Overlay }], propDecorators: { inputId: [{
|
|
218
|
+
type: Input,
|
|
219
|
+
args: ['id']
|
|
220
|
+
}], label: [{
|
|
221
|
+
type: Input
|
|
222
|
+
}], placeholder: [{
|
|
223
|
+
type: Input
|
|
224
|
+
}], required: [{
|
|
225
|
+
type: Input
|
|
226
|
+
}], disabled: [{
|
|
227
|
+
type: Input
|
|
228
|
+
}], error: [{
|
|
229
|
+
type: Input
|
|
230
|
+
}], multiple: [{
|
|
231
|
+
type: Input
|
|
232
|
+
}], search: [{
|
|
233
|
+
type: Input
|
|
234
|
+
}], ariaLabel: [{
|
|
235
|
+
type: Input,
|
|
236
|
+
args: ['aria-label']
|
|
237
|
+
}], ariaLabelledby: [{
|
|
238
|
+
type: Input,
|
|
239
|
+
args: ['aria-labelledby']
|
|
240
|
+
}], change: [{
|
|
241
|
+
type: Output
|
|
242
|
+
}], select: [{
|
|
243
|
+
type: ViewChild,
|
|
244
|
+
args: ['select']
|
|
245
|
+
}], contentTemplate: [{
|
|
246
|
+
type: ViewChild,
|
|
247
|
+
args: [CdkPortal]
|
|
248
|
+
}], options: [{
|
|
249
|
+
type: ContentChildren,
|
|
250
|
+
args: [SelectOptionComponent]
|
|
251
|
+
}] } });
|
|
252
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../libs/ui/src/components/select/select.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { CdkPortal, PortalModule } from '@angular/cdk/portal';\nimport { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  QueryList,\n  ViewChild,\n  ViewEncapsulation,\n  forwardRef,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ValidationErrors,\n  Validator,\n} from '@angular/forms';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\n\nimport { noop } from 'rxjs';\n\nimport { SelectOptionComponent } from './select-option.component';\n\nexport interface CustomSelectEvent {\n  source: SelectComponent;\n  selected: any;\n}\n\n@Component({\n  selector: 'sc-select',\n  standalone: true,\n  imports: [CommonModule, PortalModule],\n  template: `\n    <div class=\"\" [class.required]=\"required\">\n      @if (label.length > 0) {\n        <p class=\"\" [class.error]=\"error\">{{ label }}</p>\n      }\n\n      <div\n        #select\n        [ngClass]=\"mainSelectClasses()\"\n        [attr.id]=\"inputId\"\n        [attr.aria-label]=\"ariaLabel || null\"\n        [attr.aria-labelledby]=\"ariaLabelledby || null\"\n        [attr.aria-multiselectable]=\"false\"\n        [innerHTML]=\"displayText\"\n        (click)=\"showDropdown()\"\n        (keydown)=\"onKeyDown($event)\"\n        (blur)=\"onTouched()\"\n        role=\"listbox\"\n        tabindex=\"{{ this.disabled ? -1 : 0 }}\"\n      ></div>\n      <button class=\"\" (click)=\"onDropMenuIconClick($event)\">test</button>\n      <ng-template class=\"dropdown\" #overlayTemplate=\"cdkPortal\" cdk-portal>\n        <div class=\"\">\n          <button class=\"\" (keydown)=\"onKeyDown($event)\">\n            <ng-content />\n          </button>\n        </div>\n      </ng-template>\n    </div>\n  `,\n  styles: ``,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => SelectComponent),\n      multi: true,\n    },\n    {\n      provide: NG_VALIDATORS,\n      multi: true,\n      useExisting: SelectComponent,\n    },\n  ],\n})\nexport class SelectComponent implements OnInit, ControlValueAccessor, Validator {\n  // eslint-disable-next-line @angular-eslint/no-input-rename\n  @Input('id') public inputId = '';\n\n  @Input() public label = '';\n  @Input() public placeholder = '';\n\n  @Input() public required = false;\n  @Input() public disabled = false;\n  @Input() public error = false;\n  @Input() public multiple = false;\n  @Input() public search = false;\n\n  @Input('aria-label') public ariaLabel = '';\n  @Input('aria-labelledby') public ariaLabelledby = '';\n\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  @Output() readonly change = new EventEmitter<CustomSelectEvent>();\n\n  @ViewChild('select') public select!: ElementRef;\n  @ViewChild(CdkPortal) public contentTemplate!: CdkPortal;\n\n  @ContentChildren(SelectOptionComponent)\n  public options!: QueryList<SelectOptionComponent>;\n\n  public displayText!: SafeHtml;\n  public displayX = false;\n\n  //private readonly selectedOption: SelectOptionComponent;\n  private showing = false;\n  private readonly showPlaceholder = true;\n  private overlayRef!: OverlayRef;\n\n  constructor(\n    private readonly cd: ChangeDetectorRef,\n    private readonly domSanitizer: DomSanitizer,\n    private readonly overlay: Overlay,\n  ) {}\n\n  public onChangeFn: any = (_: any) => noop();\n\n  public onTouchedFn: any = () => noop();\n\n  public registerOnChange(fn: any): void {\n    this.onChangeFn = fn;\n  }\n\n  public registerOnTouched(fn: any): void {\n    this.onTouchedFn = fn;\n  }\n\n  public validate(control: AbstractControl): ValidationErrors | null {\n    return null;\n  }\n\n  public ngOnInit(): void {\n    if (!this.displayText) {\n      this.displayText = this.domSanitizer.bypassSecurityTrustHtml(this.placeholder);\n    }\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  public writeValue(obj: any): void {}\n\n  public onTouched(): void {\n    this.onTouchedFn();\n  }\n\n  public mainSelectClasses(): { [key: string]: any } {\n    return {\n      mainSelect: true,\n      error: this.error,\n      disabled: this.disabled,\n      placeholder: this.showPlaceholder,\n    };\n  }\n\n  public onDropMenuIconClick(event: UIEvent): void {\n    if (!this.disabled) {\n      event.stopPropagation();\n      this.select.nativeElement.focus();\n      this.select.nativeElement.click();\n    }\n  }\n\n  public onKeyDown(event: KeyboardEvent): void {\n    console.log('onKeyDown');\n  }\n\n  public showDropdown(): void {\n    this.overlayRef = this.overlay.create(this.getOverlayConfig());\n    this.overlayRef.attach(this.contentTemplate);\n    this.syncWidth();\n    this.overlayRef.backdropClick().subscribe(() => this.hide());\n    this.showing = true;\n  }\n\n  private hide(): void {\n    this.overlayRef.detach();\n    this.showing = false;\n  }\n\n  private syncWidth(): void {\n    if (!this.overlayRef) {\n      return;\n    }\n\n    const refRectWidth = this.select.nativeElement.getBoundingClientRect().width;\n    this.overlayRef.updateSize({ width: refRectWidth });\n  }\n\n  private getOverlayConfig(): OverlayConfig {\n    const positionStrategy = this.overlay\n      .position()\n      .flexibleConnectedTo(this.select.nativeElement)\n      .withPush(true)\n      .withPositions([\n        {\n          originX: 'start',\n          originY: 'bottom',\n          overlayX: 'start',\n          overlayY: 'top',\n          offsetY: 4,\n        },\n        {\n          originX: 'start',\n          originY: 'top',\n          overlayX: 'start',\n          overlayY: 'bottom',\n          offsetY: -4,\n        },\n      ]);\n\n    const scrollStrategy = this.overlay.scrollStrategies.reposition();\n    return new OverlayConfig({\n      positionStrategy: positionStrategy,\n      scrollStrategy: scrollStrategy,\n      hasBackdrop: true,\n      backdropClass: 'cdk-overlay-transparent-backdrop',\n    });\n  }\n}\n"]}
|
|
@@ -1,16 +1,16 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, ViewEncapsulation } from '@angular/core';
|
|
2
1
|
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, ViewEncapsulation } from '@angular/core';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export class TooltipComponent {
|
|
5
5
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: TooltipComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
6
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.11", type: TooltipComponent, isStandalone: true, selector: "
|
|
6
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.11", type: TooltipComponent, isStandalone: true, selector: "sc-tooltip", ngImport: i0, template: `
|
|
7
7
|
<p>tooltip works!</p>
|
|
8
8
|
`, isInline: true, styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
9
9
|
}
|
|
10
10
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: TooltipComponent, decorators: [{
|
|
11
11
|
type: Component,
|
|
12
|
-
args: [{ selector: '
|
|
12
|
+
args: [{ selector: 'sc-tooltip', standalone: true, imports: [CommonModule], template: `
|
|
13
13
|
<p>tooltip works!</p>
|
|
14
14
|
`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush }]
|
|
15
15
|
}] });
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL3NyYy9jb21wb25lbnRzL3Rvb2x0aXAvdG9vbHRpcC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBYXRGLE1BQU0sT0FBTyxnQkFBZ0I7d0dBQWhCLGdCQUFnQjs0RkFBaEIsZ0JBQWdCLHNFQVBqQjs7R0FFVCx5RUFIUyxZQUFZOzs0RkFRWCxnQkFBZ0I7a0JBWDVCLFNBQVM7K0JBQ0UsWUFBWSxjQUNWLElBQUksV0FDUCxDQUFDLFlBQVksQ0FBQyxZQUNiOztHQUVULGlCQUVjLGlCQUFpQixDQUFDLElBQUksbUJBQ3BCLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnc2MtdG9vbHRpcCcsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxwPnRvb2x0aXAgd29ya3MhPC9wPlxuICBgLFxuICBzdHlsZXM6IGBgLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgVG9vbHRpcENvbXBvbmVudCB7fVxuIl19
|
package/esm2022/index.mjs
CHANGED
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
export * from './components/date-picker';
|
|
2
|
+
export * from './components/dropdown';
|
|
2
3
|
export * from './components/editor';
|
|
3
|
-
export * from './components/
|
|
4
|
+
export * from './components/nav';
|
|
4
5
|
export * from './components/tooltip';
|
|
5
|
-
|
|
6
|
+
export * from './components/select';
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL3VpL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyxxQkFBcUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9kYXRlLXBpY2tlcic7XG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMvZHJvcGRvd24nO1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL2VkaXRvcic7XG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMvbmF2JztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy90b29sdGlwJztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9zZWxlY3QnO1xuIl19
|