@masterteam/delegations 0.0.1

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.
@@ -0,0 +1,2 @@
1
+ /*! tailwindcss v4.1.18 | MIT License | https://tailwindcss.com */
2
+ @layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-space-y-reverse:0;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-red-700:oklch(50.5% .213 27.518);--color-green-700:oklch(52.7% .154 150.069);--color-slate-900:oklch(20.8% .042 265.755);--spacing:.25rem;--text-xl:1.25rem;--text-xl--line-height:calc(1.75/1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2/1.5);--font-weight-semibold:600;--tracking-tight:-.025em;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.\!absolute{position:absolute!important}.static{position:static}.mx-1{margin-inline:calc(var(--spacing)*1)}.my-4{margin-block:calc(var(--spacing)*4)}.mt-5{margin-top:calc(var(--spacing)*5)}.mt-7{margin-top:calc(var(--spacing)*7)}.flex{display:flex}.\!w-100{width:calc(var(--spacing)*100)!important}.\!w-\[50rem\]{width:50rem!important}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-start{justify-content:flex-start}.gap-2{gap:calc(var(--spacing)*2)}.gap-3{gap:calc(var(--spacing)*3)}:where(.space-y-1>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*1)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*1)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*4)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*4)*calc(1 - var(--tw-space-y-reverse)))}.p-4{padding:calc(var(--spacing)*4)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.text-green-700{color:var(--color-green-700)}.text-red-700{color:var(--color-red-700)}.text-slate-900{color:var(--color-slate-900)}.\!shadow-none{--tw-shadow:0 0 #0000!important;box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)!important}}@keyframes enter{0%{opacity:var(--p-enter-opacity,1);transform:translate3d(var(--p-enter-translate-x,0),var(--p-enter-translate-y,0),0)scale3d(var(--p-enter-scale,1),var(--p-enter-scale,1),var(--p-enter-scale,1))rotate(var(--p-enter-rotate,0))}}@keyframes leave{to{opacity:var(--p-leave-opacity,1);transform:translate3d(var(--p-leave-translate-x,0),var(--p-leave-translate-y,0),0)scale3d(var(--p-leave-scale,1),var(--p-leave-scale,1),var(--p-leave-scale,1))rotate(var(--p-leave-rotate,0))}}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}
@@ -0,0 +1,34 @@
1
+ {
2
+ "delegations": {
3
+ "delegations": "التفويضات",
4
+ "all": "الكل",
5
+ "active": "نشط",
6
+ "inactive": "غير نشط",
7
+ "add-delegation": "إضافة تفويض",
8
+ "edit-delegation": "تعديل التفويض",
9
+ "create": "إنشاء",
10
+ "update": "تحديث",
11
+ "status": "الحالة",
12
+ "originally-assigned-to": "المسند إليه الأصلي",
13
+ "delegated-to": "المفوض إليه",
14
+ "start-date": "تاريخ البداية",
15
+ "end-date": "تاريخ النهاية",
16
+ "days": "الأيام",
17
+ "actions": "الإجراءات",
18
+ "description": "الوصف",
19
+ "delegation-date-from": "تاريخ التفويض من",
20
+ "delegation-date-to": "تاريخ التفويض إلى",
21
+ "delete-message": "هل أنت متأكد من حذف هذا التفويض؟",
22
+ "delegation-days-apply": "ما هي الأيام التي سيتم تطبيق التفويض عليها",
23
+ "full-range": "النطاق الكامل",
24
+ "specific-days": "أيام محددة",
25
+ "active-delegation": "تفعيل التفويض",
26
+ "sunday": "الأحد",
27
+ "monday": "الاثنين",
28
+ "tuesday": "الثلاثاء",
29
+ "wednesday": "الأربعاء",
30
+ "thursday": "الخميس",
31
+ "friday": "الجمعة",
32
+ "saturday": "السبت"
33
+ }
34
+ }
@@ -0,0 +1,34 @@
1
+ {
2
+ "delegations": {
3
+ "delegations": "Delegations",
4
+ "all": "All",
5
+ "active": "Active",
6
+ "inactive": "Inactive",
7
+ "add-delegation": "Add Delegation",
8
+ "edit-delegation": "Edit Delegation",
9
+ "create": "Create",
10
+ "update": "Update",
11
+ "status": "Status",
12
+ "originally-assigned-to": "Originally Assigned To",
13
+ "delegated-to": "Delegated To",
14
+ "start-date": "Start Date",
15
+ "end-date": "End Date",
16
+ "days": "Days",
17
+ "actions": "Actions",
18
+ "description": "Description",
19
+ "delegation-date-from": "Delegation Date From",
20
+ "delegation-date-to": "Delegation Date To",
21
+ "delete-message": "Are you sure you want to delete this delegation?",
22
+ "delegation-days-apply": "What days will the delegation apply",
23
+ "full-range": "Full range",
24
+ "specific-days": "Specific Days",
25
+ "active-delegation": "Active Delegation",
26
+ "sunday": "Sunday",
27
+ "monday": "Monday",
28
+ "tuesday": "Tuesday",
29
+ "wednesday": "Wednesday",
30
+ "thursday": "Thursday",
31
+ "friday": "Friday",
32
+ "saturday": "Saturday"
33
+ }
34
+ }
@@ -0,0 +1,714 @@
1
+ import * as i0 from '@angular/core';
2
+ import { inject, Component, Injectable, computed, input, signal, effect, viewChild, linkedSignal } from '@angular/core';
3
+ import { Router, RouterOutlet } from '@angular/router';
4
+ import { TranslocoDirective, TranslocoService, TranslocoPipe } from '@jsverse/transloco';
5
+ import { Page } from '@masterteam/components/page';
6
+ import * as i1$1 from '@angular/common';
7
+ import { CommonModule } from '@angular/common';
8
+ import { Table } from '@masterteam/components/table';
9
+ import * as i1 from 'primeng/skeleton';
10
+ import { SkeletonModule } from 'primeng/skeleton';
11
+ import { Action, Selector, State, Store, select } from '@ngxs/store';
12
+ import { HttpClient, HttpContext } from '@angular/common/http';
13
+ import { CrudStateBase, handleApiRequest, REQUEST_CONTEXT, UserSearchFieldConfig, TextareaFieldConfig, DateFieldConfig, RadioButtonFieldConfig, MultiSelectFieldConfig, ToggleFieldConfig, ValidatorConfig } from '@masterteam/components';
14
+ import { Avatar } from '@masterteam/components/avatar';
15
+ import { ModalService } from '@masterteam/components/modal';
16
+ import * as i2 from '@angular/forms';
17
+ import { FormControl, ReactiveFormsModule } from '@angular/forms';
18
+ import { toSignal } from '@angular/core/rxjs-interop';
19
+ import { DynamicForm } from '@masterteam/forms/dynamic-form';
20
+ import { Button } from '@masterteam/components/button';
21
+ import { ModalRef, DialogService } from '@masterteam/components/dialog';
22
+ import { finalize } from 'rxjs';
23
+ import { Breadcrumb } from '@masterteam/components/breadcrumb';
24
+ import { Icon } from '@masterteam/icons';
25
+
26
+ class Delegations {
27
+ router = inject(Router);
28
+ goBack() {
29
+ this.router.navigate(['control-panel/product-settings']);
30
+ }
31
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.3", ngImport: i0, type: Delegations, deps: [], target: i0.ɵɵFactoryTarget.Component });
32
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "21.0.3", type: Delegations, isStandalone: true, selector: "mt-delegations", ngImport: i0, template: "<ng-container *transloco=\"let t\">\r\n <mt-page\r\n [title]=\"t('delegations.delegations')\"\r\n [avatarIcon]=\"'custom.hierarchy-structure'\"\r\n [avatarStyle]=\"{\r\n '--p-avatar-background': 'var(--p-indigo-50)',\r\n '--p-avatar-color': 'var(--p-indigo-700)',\r\n }\"\r\n (backButtonClick)=\"goBack()\"\r\n backButton\r\n >\r\n <router-outlet />\r\n </mt-page>\r\n</ng-container>\r\n", styles: [""], dependencies: [{ kind: "component", type: Page, selector: "mt-page", inputs: ["backButton", "backButtonIcon", "avatarIcon", "avatarStyle", "avatarShape", "title", "tabs", "activeTab", "contentClass", "contentId"], outputs: ["backButtonClick", "tabChange"] }, { kind: "directive", type: RouterOutlet, selector: "router-outlet", inputs: ["name", "routerOutletData"], outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }] });
33
+ }
34
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.3", ngImport: i0, type: Delegations, decorators: [{
35
+ type: Component,
36
+ args: [{ selector: 'mt-delegations', imports: [Page, RouterOutlet, TranslocoDirective], template: "<ng-container *transloco=\"let t\">\r\n <mt-page\r\n [title]=\"t('delegations.delegations')\"\r\n [avatarIcon]=\"'custom.hierarchy-structure'\"\r\n [avatarStyle]=\"{\r\n '--p-avatar-background': 'var(--p-indigo-50)',\r\n '--p-avatar-color': 'var(--p-indigo-700)',\r\n }\"\r\n (backButtonClick)=\"goBack()\"\r\n backButton\r\n >\r\n <router-outlet />\r\n </mt-page>\r\n</ng-container>\r\n" }]
37
+ }] });
38
+
39
+ var DelegationsActionKey;
40
+ (function (DelegationsActionKey) {
41
+ DelegationsActionKey["GetDelegations"] = "getDelegations";
42
+ DelegationsActionKey["AddDelegation"] = "addDelegation";
43
+ DelegationsActionKey["UpdateDelegation"] = "updateDelegation";
44
+ DelegationsActionKey["DeleteDelegation"] = "deleteDelegation";
45
+ DelegationsActionKey["GetDelegationForm"] = "getDelegationForm";
46
+ })(DelegationsActionKey || (DelegationsActionKey = {}));
47
+
48
+ class GetDelegations {
49
+ static type = '[Delegations] Get Delegations';
50
+ }
51
+ class AddDelegation {
52
+ delegation;
53
+ static type = '[Delegations] Add Delegation';
54
+ constructor(delegation) {
55
+ this.delegation = delegation;
56
+ }
57
+ }
58
+ class UpdateDelegation {
59
+ id;
60
+ delegation;
61
+ static type = '[Delegations] Update Delegation';
62
+ constructor(id, delegation) {
63
+ this.id = id;
64
+ this.delegation = delegation;
65
+ }
66
+ }
67
+ class DeleteDelegation {
68
+ id;
69
+ static type = '[Delegations] Delete Delegation';
70
+ constructor(id) {
71
+ this.id = id;
72
+ }
73
+ }
74
+ class GetDelegation {
75
+ id;
76
+ static type = '[Delegations] Get Delegation';
77
+ constructor(id) {
78
+ this.id = id;
79
+ }
80
+ }
81
+ class ClearSelectedDelegation {
82
+ static type = '[Delegations] Clear Selected Delegation';
83
+ }
84
+
85
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
86
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
87
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
88
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
89
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
90
+ };
91
+ let DelegationsState = class DelegationsState extends CrudStateBase {
92
+ http = inject(HttpClient);
93
+ // ============================================================================
94
+ // Selectors - Individual data selectors for fine-grained reactivity
95
+ // ============================================================================
96
+ static getAllDelegations(state) {
97
+ return state.allDelegations;
98
+ }
99
+ static getSelectedDelegation(state) {
100
+ return state.selectedDelegation;
101
+ }
102
+ // ============================================================================
103
+ // Loading/Error Slice Selectors - REQUIRED for optimal performance
104
+ // ============================================================================
105
+ static getLoadingActive(state) {
106
+ return state.loadingActive;
107
+ }
108
+ static getErrors(state) {
109
+ return state.errors;
110
+ }
111
+ // ============================================================================
112
+ // CRUD Actions
113
+ // ============================================================================
114
+ getDelegations(ctx) {
115
+ const req$ = this.http.get('identity/delegations/all');
116
+ return handleApiRequest({
117
+ ctx,
118
+ key: DelegationsActionKey.GetDelegations,
119
+ request$: req$,
120
+ onSuccess: (response) => ({
121
+ allDelegations: response.data ?? [],
122
+ }),
123
+ });
124
+ }
125
+ getDelegation(ctx, { id }) {
126
+ const req$ = this.http.get(`identity/delegations/${id}`);
127
+ return handleApiRequest({
128
+ ctx,
129
+ key: DelegationsActionKey.GetDelegationForm,
130
+ request$: req$,
131
+ onSuccess: (response) => ({
132
+ selectedDelegation: response.data ?? null,
133
+ }),
134
+ });
135
+ }
136
+ addDelegation(ctx, { delegation }) {
137
+ const req$ = this.http.post('identity/delegations', delegation);
138
+ return this.create(ctx, {
139
+ key: DelegationsActionKey.AddDelegation,
140
+ request$: req$,
141
+ stateProperty: (state) => state.allDelegations,
142
+ });
143
+ }
144
+ updateDelegation(ctx, { id, delegation }) {
145
+ const req$ = this.http.put(`identity/delegations/${id}`, delegation);
146
+ return this.update(ctx, {
147
+ key: DelegationsActionKey.UpdateDelegation,
148
+ request$: req$,
149
+ uniqueKey: 'id',
150
+ id,
151
+ stateProperty: (state) => state.allDelegations,
152
+ });
153
+ }
154
+ deleteDelegation(ctx, { id }) {
155
+ const req$ = this.http.delete(`identity/delegations/${id}`);
156
+ return this.delete(ctx, {
157
+ key: DelegationsActionKey.DeleteDelegation,
158
+ request$: req$,
159
+ uniqueKey: 'id',
160
+ id,
161
+ stateProperty: (state) => state.allDelegations,
162
+ });
163
+ }
164
+ clearSelectedDelegation(ctx) {
165
+ ctx.patchState({ selectedDelegation: null });
166
+ }
167
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.3", ngImport: i0, type: DelegationsState, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
168
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "21.0.3", ngImport: i0, type: DelegationsState });
169
+ };
170
+ __decorate([
171
+ Action(GetDelegations)
172
+ ], DelegationsState.prototype, "getDelegations", null);
173
+ __decorate([
174
+ Action(GetDelegation)
175
+ ], DelegationsState.prototype, "getDelegation", null);
176
+ __decorate([
177
+ Action(AddDelegation)
178
+ ], DelegationsState.prototype, "addDelegation", null);
179
+ __decorate([
180
+ Action(UpdateDelegation)
181
+ ], DelegationsState.prototype, "updateDelegation", null);
182
+ __decorate([
183
+ Action(DeleteDelegation)
184
+ ], DelegationsState.prototype, "deleteDelegation", null);
185
+ __decorate([
186
+ Action(ClearSelectedDelegation)
187
+ ], DelegationsState.prototype, "clearSelectedDelegation", null);
188
+ __decorate([
189
+ Selector()
190
+ ], DelegationsState, "getAllDelegations", null);
191
+ __decorate([
192
+ Selector()
193
+ ], DelegationsState, "getSelectedDelegation", null);
194
+ __decorate([
195
+ Selector()
196
+ ], DelegationsState, "getLoadingActive", null);
197
+ __decorate([
198
+ Selector()
199
+ ], DelegationsState, "getErrors", null);
200
+ DelegationsState = __decorate([
201
+ State({
202
+ name: 'delegations',
203
+ defaults: {
204
+ allDelegations: [],
205
+ selectedDelegation: null,
206
+ loadingActive: [],
207
+ errors: {},
208
+ },
209
+ })
210
+ ], DelegationsState);
211
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.3", ngImport: i0, type: DelegationsState, decorators: [{
212
+ type: Injectable
213
+ }], propDecorators: { getDelegations: [], getDelegation: [], addDelegation: [], updateDelegation: [], deleteDelegation: [], clearSelectedDelegation: [] } });
214
+
215
+ class DelegationsFacade {
216
+ store = inject(Store);
217
+ // ============================================================================
218
+ // Data Selectors - Memoized by NGXS (fine-grained reactivity)
219
+ // ============================================================================
220
+ allDelegations = select(DelegationsState.getAllDelegations);
221
+ selectedDelegation = select(DelegationsState.getSelectedDelegation);
222
+ // ============================================================================
223
+ // Loading/Error Slices - Memoized by NGXS
224
+ // ============================================================================
225
+ loadingActive = select(DelegationsState.getLoadingActive);
226
+ errors = select(DelegationsState.getErrors);
227
+ // ============================================================================
228
+ // Loading Signals - Computed from slice (minimal reactivity)
229
+ // ============================================================================
230
+ isLoadingDelegations = computed(() => this.loadingActive().includes(DelegationsActionKey.GetDelegations), ...(ngDevMode ? [{ debugName: "isLoadingDelegations" }] : []));
231
+ isLoadingDelegation = computed(() => this.loadingActive().includes(DelegationsActionKey.GetDelegationForm), ...(ngDevMode ? [{ debugName: "isLoadingDelegation" }] : []));
232
+ isAddingDelegation = computed(() => this.loadingActive().includes(DelegationsActionKey.AddDelegation), ...(ngDevMode ? [{ debugName: "isAddingDelegation" }] : []));
233
+ isUpdatingDelegation = computed(() => this.loadingActive().includes(DelegationsActionKey.UpdateDelegation), ...(ngDevMode ? [{ debugName: "isUpdatingDelegation" }] : []));
234
+ isDeletingDelegation = computed(() => this.loadingActive().includes(DelegationsActionKey.DeleteDelegation), ...(ngDevMode ? [{ debugName: "isDeletingDelegation" }] : []));
235
+ // ============================================================================
236
+ // Error Signals - Computed from slice (minimal reactivity)
237
+ // ============================================================================
238
+ delegationsError = computed(() => this.errors()[DelegationsActionKey.GetDelegations] ?? null, ...(ngDevMode ? [{ debugName: "delegationsError" }] : []));
239
+ delegationError = computed(() => this.errors()[DelegationsActionKey.GetDelegationForm] ?? null, ...(ngDevMode ? [{ debugName: "delegationError" }] : []));
240
+ addDelegationError = computed(() => this.errors()[DelegationsActionKey.AddDelegation] ?? null, ...(ngDevMode ? [{ debugName: "addDelegationError" }] : []));
241
+ updateDelegationError = computed(() => this.errors()[DelegationsActionKey.UpdateDelegation] ?? null, ...(ngDevMode ? [{ debugName: "updateDelegationError" }] : []));
242
+ deleteDelegationError = computed(() => this.errors()[DelegationsActionKey.DeleteDelegation] ?? null, ...(ngDevMode ? [{ debugName: "deleteDelegationError" }] : []));
243
+ // ============================================================================
244
+ // Derived Data - Computed from data selectors
245
+ // ============================================================================
246
+ activeDelegations = computed(() => this.allDelegations().filter((d) => d.isActive === true), ...(ngDevMode ? [{ debugName: "activeDelegations" }] : []));
247
+ inactiveDelegations = computed(() => this.allDelegations().filter((d) => d.isActive === false), ...(ngDevMode ? [{ debugName: "inactiveDelegations" }] : []));
248
+ // ============================================================================
249
+ // Action Dispatchers
250
+ // ============================================================================
251
+ getDelegations() {
252
+ return this.store.dispatch(new GetDelegations());
253
+ }
254
+ addDelegation(delegation) {
255
+ return this.store.dispatch(new AddDelegation(delegation));
256
+ }
257
+ updateDelegation(id, delegation) {
258
+ return this.store.dispatch(new UpdateDelegation(id, delegation));
259
+ }
260
+ deleteDelegation(id) {
261
+ return this.store.dispatch(new DeleteDelegation(id));
262
+ }
263
+ loadDelegation(id) {
264
+ return this.store.dispatch(new GetDelegation(id));
265
+ }
266
+ clearSelectedDelegation() {
267
+ return this.store.dispatch(new ClearSelectedDelegation());
268
+ }
269
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.3", ngImport: i0, type: DelegationsFacade, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
270
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "21.0.3", ngImport: i0, type: DelegationsFacade, providedIn: 'root' });
271
+ }
272
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.3", ngImport: i0, type: DelegationsFacade, decorators: [{
273
+ type: Injectable,
274
+ args: [{ providedIn: 'root' }]
275
+ }] });
276
+
277
+ class DelegationForm {
278
+ modal = inject(ModalService);
279
+ ref = inject(ModalRef);
280
+ delegationForEdit = input(null, ...(ngDevMode ? [{ debugName: "delegationForEdit" }] : []));
281
+ translocoService = inject(TranslocoService);
282
+ facade = inject(DelegationsFacade);
283
+ selectedDelegation = this.facade.selectedDelegation;
284
+ delegationFormControl = new FormControl();
285
+ formValue = toSignal(this.delegationFormControl.valueChanges);
286
+ getDelegationFormLoading = this.facade.isLoadingDelegation;
287
+ isAddingDelegation = this.facade.isAddingDelegation;
288
+ isUpdatingDelegation = this.facade.isUpdatingDelegation;
289
+ context = new HttpContext().set(REQUEST_CONTEXT, {
290
+ useBaseUrl: true,
291
+ });
292
+ isDelegatingToSelf = computed(() => {
293
+ const formValue = this.formValue();
294
+ const fromId = formValue.delegateFrom?.userId || formValue.delegateFrom;
295
+ const toId = formValue.delegateTo?.userId || formValue.delegateTo;
296
+ return fromId === toId;
297
+ }, ...(ngDevMode ? [{ debugName: "isDelegatingToSelf" }] : []));
298
+ specificDaysOptions = signal([
299
+ {
300
+ label: this.translocoService.translate('delegations.sunday'),
301
+ value: 0,
302
+ },
303
+ {
304
+ label: this.translocoService.translate('delegations.monday'),
305
+ value: 1,
306
+ },
307
+ {
308
+ label: this.translocoService.translate('delegations.tuesday'),
309
+ value: 2,
310
+ },
311
+ {
312
+ label: this.translocoService.translate('delegations.wednesday'),
313
+ value: 3,
314
+ },
315
+ {
316
+ label: this.translocoService.translate('delegations.thursday'),
317
+ value: 4,
318
+ },
319
+ {
320
+ label: this.translocoService.translate('delegations.friday'),
321
+ value: 5,
322
+ },
323
+ {
324
+ label: this.translocoService.translate('delegations.saturday'),
325
+ value: 6,
326
+ },
327
+ ], ...(ngDevMode ? [{ debugName: "specificDaysOptions" }] : []));
328
+ delegationFormConfig = computed(() => ({
329
+ sections: [
330
+ {
331
+ key: 'delegationFormConfig',
332
+ type: 'header',
333
+ order: 1,
334
+ fields: [
335
+ new UserSearchFieldConfig({
336
+ key: 'delegateFrom',
337
+ label: this.translocoService.translate('delegations.originally-assigned-to'),
338
+ apiUrl: 'Identity/users',
339
+ context: this.context,
340
+ validators: [ValidatorConfig.required()],
341
+ order: 1,
342
+ colSpan: 6,
343
+ disabled: !!this.delegationForEdit()?.id,
344
+ }),
345
+ new UserSearchFieldConfig({
346
+ key: 'delegateTo',
347
+ label: this.translocoService.translate('delegations.delegated-to'),
348
+ apiUrl: 'Identity/users',
349
+ context: this.context,
350
+ validators: [ValidatorConfig.required()],
351
+ order: 2,
352
+ colSpan: 6,
353
+ disabled: !!this.delegationForEdit()?.id,
354
+ }),
355
+ new TextareaFieldConfig({
356
+ key: 'description',
357
+ label: this.translocoService.translate('delegations.description'),
358
+ placeholder: this.translocoService.translate('delegations.description'),
359
+ colSpan: 12,
360
+ order: 3,
361
+ }),
362
+ new DateFieldConfig({
363
+ key: 'delegateFromDateTime',
364
+ label: this.translocoService.translate('delegations.delegation-date-from'),
365
+ placeholder: this.translocoService.translate('delegations.delegation-date-from'),
366
+ validators: [ValidatorConfig.required()],
367
+ showTime: true,
368
+ colSpan: 6,
369
+ order: 4,
370
+ }),
371
+ new DateFieldConfig({
372
+ key: 'delegateToDateTime',
373
+ label: this.translocoService.translate('delegations.delegation-date-to'),
374
+ placeholder: this.translocoService.translate('delegations.delegation-date-to'),
375
+ validators: [ValidatorConfig.required()],
376
+ showTime: true,
377
+ colSpan: 6,
378
+ order: 5,
379
+ }),
380
+ new RadioButtonFieldConfig({
381
+ key: 'delegationDaysType',
382
+ label: this.translocoService.translate('delegations.delegation-days-apply'),
383
+ options: [
384
+ {
385
+ label: this.translocoService.translate('delegations.full-range'),
386
+ value: 'FullRange',
387
+ },
388
+ {
389
+ label: this.translocoService.translate('delegations.specific-days'),
390
+ value: 'SpecificDays',
391
+ },
392
+ ],
393
+ optionLabel: 'label',
394
+ optionValue: 'value',
395
+ validators: [ValidatorConfig.required()],
396
+ colSpan: 12,
397
+ order: 6,
398
+ }),
399
+ new MultiSelectFieldConfig({
400
+ key: 'specificDays',
401
+ label: this.translocoService.translate('delegations.specific-days'),
402
+ options: this.specificDaysOptions(),
403
+ optionLabel: 'label',
404
+ optionValue: 'value',
405
+ maxSelectedLabels: 7,
406
+ relations: [
407
+ {
408
+ key: 'delegationDaysType',
409
+ value: 'SpecificDays',
410
+ action: 'show',
411
+ },
412
+ ],
413
+ colSpan: 12,
414
+ order: 7,
415
+ }),
416
+ new ToggleFieldConfig({
417
+ key: 'isActive',
418
+ label: this.translocoService.translate('delegations.active-delegation'),
419
+ cssClass: 'mt-5 !w-100',
420
+ order: 8,
421
+ }),
422
+ ],
423
+ },
424
+ ],
425
+ }), ...(ngDevMode ? [{ debugName: "delegationFormConfig" }] : []));
426
+ constructor() {
427
+ effect(() => {
428
+ const delegationId = this.delegationForEdit()?.id;
429
+ if (this.selectedDelegation() && delegationId) {
430
+ const delegation = this.selectedDelegation();
431
+ const data = {
432
+ delegateFrom: delegation?.delegateFrom,
433
+ delegateTo: delegation?.delegateTo,
434
+ description: delegation?.description,
435
+ delegateFromDateTime: delegation?.delegateFromDateTime?.actualValue
436
+ ? new Date(delegation.delegateFromDateTime.actualValue)
437
+ : undefined,
438
+ delegateToDateTime: delegation?.delegateToDateTime?.actualValue
439
+ ? new Date(delegation.delegateToDateTime.actualValue)
440
+ : undefined,
441
+ delegationDaysType: delegation?.delegationDaysType || 'FullRange',
442
+ specificDays: delegation?.specificDays || [],
443
+ isActive: delegation?.isActive ?? false,
444
+ };
445
+ this.delegationFormControl.patchValue(data);
446
+ }
447
+ else {
448
+ this.delegationFormControl.reset({
449
+ delegationDaysType: 'FullRange',
450
+ isActive: true,
451
+ });
452
+ }
453
+ });
454
+ }
455
+ ngOnInit() {
456
+ const delegationId = this.delegationForEdit()?.id;
457
+ if (delegationId) {
458
+ this.facade.loadDelegation(delegationId);
459
+ }
460
+ }
461
+ onSubmit() {
462
+ if (!this.delegationFormControl.valid) {
463
+ return;
464
+ }
465
+ const formValue = this.delegationFormControl.value;
466
+ const payload = {
467
+ delegateFrom: formValue?.delegateFrom?.userId || formValue?.delegateFrom,
468
+ delegateTo: formValue?.delegateTo?.userId || formValue?.delegateTo,
469
+ description: formValue?.description,
470
+ delegateFromDateTime: formValue?.delegateFromDateTime,
471
+ delegateToDateTime: formValue?.delegateToDateTime,
472
+ delegationDaysType: formValue?.delegationDaysType || 'FullRange',
473
+ specificDays: formValue?.delegationDaysType === 'SpecificDays'
474
+ ? formValue?.specificDays || []
475
+ : undefined,
476
+ isActive: formValue?.isActive ?? false,
477
+ };
478
+ const delegationId = this.delegationForEdit()?.id;
479
+ if (delegationId) {
480
+ this.facade.updateDelegation(delegationId, payload).subscribe({
481
+ next: () => {
482
+ this.ref.close(true);
483
+ },
484
+ error: () => { },
485
+ });
486
+ }
487
+ else {
488
+ this.facade.addDelegation(payload).subscribe({
489
+ next: () => {
490
+ this.ref.close(true);
491
+ },
492
+ error: () => { },
493
+ });
494
+ }
495
+ }
496
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.3", ngImport: i0, type: DelegationForm, deps: [], target: i0.ɵɵFactoryTarget.Component });
497
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.0.3", type: DelegationForm, isStandalone: true, selector: "mt-delegation-form", inputs: { delegationForEdit: { classPropertyName: "delegationForEdit", publicName: "delegationForEdit", isSignal: true, isRequired: false, transformFunction: null } }, providers: [DialogService], ngImport: i0, template: "<ng-container *transloco=\"let t; prefix: 'delegations'\">\r\n <div [class]=\"'flex flex-col gap-3 p-4 ' + modal.contentClass\">\r\n @if (getDelegationFormLoading()) {\r\n <p-skeleton class=\"my-4 mt-7\" height=\"3rem\" />\r\n <p-skeleton class=\"my-4\" height=\"3rem\" />\r\n <p-skeleton class=\"my-4\" height=\"6rem\" />\r\n <p-skeleton class=\"my-4\" height=\"3rem\" />\r\n } @else {\r\n <mt-dynamic-form\r\n [formConfig]=\"delegationFormConfig()\"\r\n [formControl]=\"delegationFormControl\"\r\n />\r\n }\r\n </div>\r\n\r\n <div [class]=\"modal.footerClass\">\r\n <mt-button\r\n [label]=\"'cancel' | transloco\"\r\n severity=\"secondary\"\r\n variant=\"outlined\"\r\n (click)=\"ref.close()\"\r\n />\r\n <mt-button\r\n [label]=\"delegationForEdit() ? t('update') : t('create')\"\r\n [loading]=\"isAddingDelegation() || isUpdatingDelegation()\"\r\n [disabled]=\"!delegationFormControl.valid || isDelegatingToSelf()\"\r\n (click)=\"onSubmit()\"\r\n />\r\n </div>\r\n</ng-container>\r\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: Button, selector: "mt-button", inputs: ["icon", "label", "tooltip", "class", "type", "styleClass", "severity", "badge", "variant", "badgeSeverity", "size", "iconPos", "autofocus", "fluid", "raised", "rounded", "text", "plain", "outlined", "link", "disabled", "loading", "pInputs"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }, { kind: "ngmodule", type: SkeletonModule }, { kind: "component", type: i1.Skeleton, selector: "p-skeleton", inputs: ["styleClass", "shape", "animation", "borderRadius", "size", "width", "height"] }, { kind: "component", type: DynamicForm, selector: "mt-dynamic-form", inputs: ["formConfig"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "pipe", type: TranslocoPipe, name: "transloco" }] });
498
+ }
499
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.3", ngImport: i0, type: DelegationForm, decorators: [{
500
+ type: Component,
501
+ args: [{ selector: 'mt-delegation-form', standalone: true, imports: [
502
+ CommonModule,
503
+ Button,
504
+ TranslocoDirective,
505
+ SkeletonModule,
506
+ DynamicForm,
507
+ ReactiveFormsModule,
508
+ TranslocoPipe,
509
+ ], providers: [DialogService], template: "<ng-container *transloco=\"let t; prefix: 'delegations'\">\r\n <div [class]=\"'flex flex-col gap-3 p-4 ' + modal.contentClass\">\r\n @if (getDelegationFormLoading()) {\r\n <p-skeleton class=\"my-4 mt-7\" height=\"3rem\" />\r\n <p-skeleton class=\"my-4\" height=\"3rem\" />\r\n <p-skeleton class=\"my-4\" height=\"6rem\" />\r\n <p-skeleton class=\"my-4\" height=\"3rem\" />\r\n } @else {\r\n <mt-dynamic-form\r\n [formConfig]=\"delegationFormConfig()\"\r\n [formControl]=\"delegationFormControl\"\r\n />\r\n }\r\n </div>\r\n\r\n <div [class]=\"modal.footerClass\">\r\n <mt-button\r\n [label]=\"'cancel' | transloco\"\r\n severity=\"secondary\"\r\n variant=\"outlined\"\r\n (click)=\"ref.close()\"\r\n />\r\n <mt-button\r\n [label]=\"delegationForEdit() ? t('update') : t('create')\"\r\n [loading]=\"isAddingDelegation() || isUpdatingDelegation()\"\r\n [disabled]=\"!delegationFormControl.valid || isDelegatingToSelf()\"\r\n (click)=\"onSubmit()\"\r\n />\r\n </div>\r\n</ng-container>\r\n" }]
510
+ }], ctorParameters: () => [], propDecorators: { delegationForEdit: [{ type: i0.Input, args: [{ isSignal: true, alias: "delegationForEdit", required: false }] }] } });
511
+
512
+ class DelegationsList {
513
+ statusCol = viewChild.required('statusCol');
514
+ userCol = viewChild.required('userCol');
515
+ userCol2 = viewChild.required('userCol2');
516
+ daysCol = viewChild.required('daysCol');
517
+ startDate = viewChild.required('startDate');
518
+ endDate = viewChild.required('endDate');
519
+ facade = inject(DelegationsFacade);
520
+ modal = inject(ModalService);
521
+ translocoService = inject(TranslocoService);
522
+ breadcrumbItems = linkedSignal(() => [
523
+ {
524
+ label: '',
525
+ icon: 'general.home-line',
526
+ routerLink: '/control-panel/workspaces',
527
+ },
528
+ {
529
+ label: this.translocoService.translate('product-settings.product-settings'),
530
+ routerLink: '/control-panel/product-settings',
531
+ },
532
+ {
533
+ label: this.translocoService.translate('delegations.delegations'),
534
+ },
535
+ ], ...(ngDevMode ? [{ debugName: "breadcrumbItems" }] : []));
536
+ delegations = computed(() => {
537
+ const tab = this.activeTab();
538
+ const all = this.allDelegations();
539
+ const activeDelegations = this.activeDelegations();
540
+ const inactiveDelegations = this.inactiveDelegations();
541
+ switch (tab) {
542
+ case 'active':
543
+ return activeDelegations;
544
+ case 'inactive':
545
+ return inactiveDelegations;
546
+ case 'all':
547
+ default:
548
+ return all;
549
+ }
550
+ }, ...(ngDevMode ? [{ debugName: "delegations" }] : []));
551
+ tabs = signal([
552
+ {
553
+ label: this.translocoService.translate('delegations.all'),
554
+ value: 'all',
555
+ },
556
+ {
557
+ label: this.translocoService.translate('delegations.active'),
558
+ value: 'active',
559
+ },
560
+ {
561
+ label: this.translocoService.translate('delegations.inactive'),
562
+ value: 'inactive',
563
+ },
564
+ ], ...(ngDevMode ? [{ debugName: "tabs" }] : []));
565
+ activeTab = signal('all', ...(ngDevMode ? [{ debugName: "activeTab" }] : []));
566
+ tableActions = signal([
567
+ {
568
+ icon: 'general.plus',
569
+ label: this.translocoService.translate('delegations.add-delegation'),
570
+ color: 'primary',
571
+ action: () => {
572
+ this.addDelegationDialog();
573
+ },
574
+ },
575
+ ], ...(ngDevMode ? [{ debugName: "tableActions" }] : []));
576
+ deletingRowIds = signal([], ...(ngDevMode ? [{ debugName: "deletingRowIds" }] : []));
577
+ rowActions = signal([
578
+ {
579
+ icon: 'custom.pencil',
580
+ tooltip: this.translocoService.translate('edit'),
581
+ color: 'primary',
582
+ action: (row) => {
583
+ this.facade.clearSelectedDelegation();
584
+ this.addDelegationDialog(row);
585
+ },
586
+ },
587
+ {
588
+ icon: 'general.trash-01',
589
+ tooltip: this.translocoService.translate('delete'),
590
+ color: 'danger',
591
+ variant: 'outlined',
592
+ action: (row) => {
593
+ this.deletingRowIds.update((ids) => [...ids, row.id]);
594
+ this.facade
595
+ .deleteDelegation(row.id)
596
+ .pipe(finalize(() => {
597
+ this.deletingRowIds.update((ids) => ids.filter((id) => id !== row.id));
598
+ }))
599
+ .subscribe();
600
+ },
601
+ confirmation: {
602
+ type: 'popup',
603
+ confirmationType: 'delete',
604
+ },
605
+ loading: (row) => this.deletingRowIds().includes(row.id),
606
+ },
607
+ ], ...(ngDevMode ? [{ debugName: "rowActions" }] : []));
608
+ tableColumns = linkedSignal(() => [
609
+ {
610
+ key: 'isActive',
611
+ label: this.translocoService.translate('delegations.status'),
612
+ type: 'custom',
613
+ customCellTpl: this.statusCol(),
614
+ filterConfig: {
615
+ type: 'select',
616
+ label: this.translocoService.translate('delegations.status'),
617
+ options: [
618
+ {
619
+ label: this.translocoService.translate('delegations.active'),
620
+ value: true,
621
+ },
622
+ {
623
+ label: this.translocoService.translate('delegations.inactive'),
624
+ value: false,
625
+ },
626
+ ],
627
+ },
628
+ },
629
+ {
630
+ key: 'delegateFrom.displayName',
631
+ label: this.translocoService.translate('delegations.originally-assigned-to'),
632
+ type: 'custom',
633
+ customCellTpl: this.userCol(),
634
+ },
635
+ {
636
+ key: 'delegateTo.displayName',
637
+ label: this.translocoService.translate('delegations.delegated-to'),
638
+ type: 'custom',
639
+ customCellTpl: this.userCol2(),
640
+ },
641
+ {
642
+ key: 'delegateFromDateTime.actualValue',
643
+ label: this.translocoService.translate('delegations.start-date'),
644
+ type: 'custom',
645
+ customCellTpl: this.startDate(),
646
+ filterConfig: {
647
+ type: 'date',
648
+ label: this.translocoService.translate('delegations.start-date'),
649
+ },
650
+ },
651
+ {
652
+ key: 'delegateToDateTime.actualValue',
653
+ label: this.translocoService.translate('delegations.end-date'),
654
+ type: 'custom',
655
+ customCellTpl: this.endDate(),
656
+ filterConfig: {
657
+ type: 'date',
658
+ label: this.translocoService.translate('delegations.end-date'),
659
+ },
660
+ },
661
+ {
662
+ key: 'days',
663
+ label: this.translocoService.translate('delegations.days'),
664
+ type: 'custom',
665
+ customCellTpl: this.daysCol(),
666
+ },
667
+ ], ...(ngDevMode ? [{ debugName: "tableColumns" }] : []));
668
+ loading = this.facade.isLoadingDelegations;
669
+ allDelegations = this.facade.allDelegations;
670
+ activeDelegations = this.facade.activeDelegations;
671
+ inactiveDelegations = this.facade.inactiveDelegations;
672
+ ngOnInit() {
673
+ this.facade.getDelegations();
674
+ }
675
+ addDelegationDialog(delegation = null) {
676
+ const modalType = delegation ? 'drawer' : 'dialog';
677
+ this.modal.openModal(DelegationForm, modalType, {
678
+ header: delegation
679
+ ? this.translocoService.translate('delegations.edit-delegation')
680
+ : this.translocoService.translate('delegations.add-delegation'),
681
+ styleClass: '!w-[50rem] !absolute !shadow-none',
682
+ position: modalType === 'drawer' ? 'end' : '',
683
+ appendTo: modalType === 'drawer' ? 'page-content' : 'body',
684
+ dismissableMask: true,
685
+ dismissible: true,
686
+ inputValues: {
687
+ delegationForEdit: delegation,
688
+ },
689
+ });
690
+ }
691
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.0.3", ngImport: i0, type: DelegationsList, deps: [], target: i0.ɵɵFactoryTarget.Component });
692
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "21.0.3", type: DelegationsList, isStandalone: true, selector: "mt-delegations-list", viewQueries: [{ propertyName: "statusCol", first: true, predicate: ["statusCol"], descendants: true, isSignal: true }, { propertyName: "userCol", first: true, predicate: ["userCol"], descendants: true, isSignal: true }, { propertyName: "userCol2", first: true, predicate: ["userCol2"], descendants: true, isSignal: true }, { propertyName: "daysCol", first: true, predicate: ["daysCol"], descendants: true, isSignal: true }, { propertyName: "startDate", first: true, predicate: ["startDate"], descendants: true, isSignal: true }, { propertyName: "endDate", first: true, predicate: ["endDate"], descendants: true, isSignal: true }], ngImport: i0, template: "<ng-container *transloco=\"let t; prefix: 'delegations'\">\r\n <div class=\"space-y-4\">\r\n <div class=\"flex items-center justify-between\">\r\n <div class=\"space-y-1\">\r\n <h1 class=\"text-xl font-semibold text-slate-900 tracking-tight\">\r\n {{ t(\"delegations\") }}\r\n </h1>\r\n <mt-breadcrumb\r\n [items]=\"breadcrumbItems()\"\r\n [styleClass]=\"'flex justify-start mx-1'\"\r\n ></mt-breadcrumb>\r\n </div>\r\n </div>\r\n <ng-template #statusCol let-row>\r\n <span\r\n class=\"flex items-center gap-2 text-md\"\r\n [class]=\"row.isActive ? 'text-green-700 ' : 'text-red-700 '\"\r\n >\r\n <mt-icon\r\n class=\"text-2xl\"\r\n [icon]=\"row.isActive ? 'media.play-circle' : 'media.pause-circle'\"\r\n ></mt-icon>\r\n {{ row.isActive ? t(\"active\") : t(\"inactive\") }}\r\n </span>\r\n </ng-template>\r\n\r\n <ng-template #userCol let-row>\r\n <div class=\"flex items-center gap-2\">\r\n <mt-avatar [icon]=\"'custom.user-pp'\"></mt-avatar>\r\n {{ row.delegateFrom?.displayName }}\r\n </div>\r\n </ng-template>\r\n <ng-template #userCol2 let-row>\r\n <div class=\"flex items-center gap-2\">\r\n <mt-avatar [icon]=\"'custom.user-pp'\"></mt-avatar>\r\n {{ row.delegateTo?.displayName }}\r\n </div>\r\n </ng-template>\r\n\r\n <ng-template #daysCol let-row>\r\n <div>{{ row.dayCounts }} {{ t(\"days\") }}</div>\r\n </ng-template>\r\n\r\n <ng-template #startDate let-row>\r\n <div>{{ row.delegateFromDateTime.actualValue | date: \"short\" }}</div>\r\n </ng-template>\r\n <ng-template #endDate let-row>\r\n <div>{{ row.delegateToDateTime.actualValue | date: \"short\" }}</div>\r\n </ng-template>\r\n\r\n <mt-table\r\n [tabs]=\"tabs()\"\r\n [(activeTab)]=\"activeTab\"\r\n [data]=\"delegations()\"\r\n [columns]=\"tableColumns()\"\r\n [actions]=\"tableActions()\"\r\n [rowActions]=\"rowActions()\"\r\n [generalSearch]=\"true\"\r\n [showFilters]=\"true\"\r\n [loading]=\"loading()\"\r\n >\r\n </mt-table>\r\n </div>\r\n</ng-container>\r\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: SkeletonModule }, { kind: "component", type: Table, selector: "mt-table", inputs: ["filters", "data", "columns", "rowActions", "size", "showGridlines", "stripedRows", "selectableRows", "generalSearch", "showFilters", "loading", "updating", "lazy", "lazyTotalRecords", "reorderableColumns", "reorderableRows", "dataKey", "exportable", "exportFilename", "tabs", "tabsOptionLabel", "tabsOptionValue", "activeTab", "actions", "paginatorPosition", "pageSize", "currentPage", "first", "filterTerm"], outputs: ["selectionChange", "cellChange", "lazyLoad", "columnReorder", "rowReorder", "filtersChange", "activeTabChange", "onTabChange", "pageSizeChange", "currentPageChange", "firstChange", "filterTermChange"] }, { kind: "component", type: Avatar, selector: "mt-avatar", inputs: ["label", "icon", "image", "styleClass", "size", "shape", "badge", "badgeSize", "badgeSeverity"], outputs: ["onImageError"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }, { kind: "component", type: Breadcrumb, selector: "mt-breadcrumb", inputs: ["items", "styleClass"], outputs: ["onItemClick"] }, { kind: "component", type: Icon, selector: "mt-icon", inputs: ["icon"] }, { kind: "pipe", type: i1$1.DatePipe, name: "date" }] });
693
+ }
694
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.0.3", ngImport: i0, type: DelegationsList, decorators: [{
695
+ type: Component,
696
+ args: [{ selector: 'mt-delegations-list', standalone: true, imports: [
697
+ CommonModule,
698
+ SkeletonModule,
699
+ Table,
700
+ Avatar,
701
+ TranslocoDirective,
702
+ Breadcrumb,
703
+ Icon,
704
+ ], template: "<ng-container *transloco=\"let t; prefix: 'delegations'\">\r\n <div class=\"space-y-4\">\r\n <div class=\"flex items-center justify-between\">\r\n <div class=\"space-y-1\">\r\n <h1 class=\"text-xl font-semibold text-slate-900 tracking-tight\">\r\n {{ t(\"delegations\") }}\r\n </h1>\r\n <mt-breadcrumb\r\n [items]=\"breadcrumbItems()\"\r\n [styleClass]=\"'flex justify-start mx-1'\"\r\n ></mt-breadcrumb>\r\n </div>\r\n </div>\r\n <ng-template #statusCol let-row>\r\n <span\r\n class=\"flex items-center gap-2 text-md\"\r\n [class]=\"row.isActive ? 'text-green-700 ' : 'text-red-700 '\"\r\n >\r\n <mt-icon\r\n class=\"text-2xl\"\r\n [icon]=\"row.isActive ? 'media.play-circle' : 'media.pause-circle'\"\r\n ></mt-icon>\r\n {{ row.isActive ? t(\"active\") : t(\"inactive\") }}\r\n </span>\r\n </ng-template>\r\n\r\n <ng-template #userCol let-row>\r\n <div class=\"flex items-center gap-2\">\r\n <mt-avatar [icon]=\"'custom.user-pp'\"></mt-avatar>\r\n {{ row.delegateFrom?.displayName }}\r\n </div>\r\n </ng-template>\r\n <ng-template #userCol2 let-row>\r\n <div class=\"flex items-center gap-2\">\r\n <mt-avatar [icon]=\"'custom.user-pp'\"></mt-avatar>\r\n {{ row.delegateTo?.displayName }}\r\n </div>\r\n </ng-template>\r\n\r\n <ng-template #daysCol let-row>\r\n <div>{{ row.dayCounts }} {{ t(\"days\") }}</div>\r\n </ng-template>\r\n\r\n <ng-template #startDate let-row>\r\n <div>{{ row.delegateFromDateTime.actualValue | date: \"short\" }}</div>\r\n </ng-template>\r\n <ng-template #endDate let-row>\r\n <div>{{ row.delegateToDateTime.actualValue | date: \"short\" }}</div>\r\n </ng-template>\r\n\r\n <mt-table\r\n [tabs]=\"tabs()\"\r\n [(activeTab)]=\"activeTab\"\r\n [data]=\"delegations()\"\r\n [columns]=\"tableColumns()\"\r\n [actions]=\"tableActions()\"\r\n [rowActions]=\"rowActions()\"\r\n [generalSearch]=\"true\"\r\n [showFilters]=\"true\"\r\n [loading]=\"loading()\"\r\n >\r\n </mt-table>\r\n </div>\r\n</ng-container>\r\n" }]
705
+ }], propDecorators: { statusCol: [{ type: i0.ViewChild, args: ['statusCol', { isSignal: true }] }], userCol: [{ type: i0.ViewChild, args: ['userCol', { isSignal: true }] }], userCol2: [{ type: i0.ViewChild, args: ['userCol2', { isSignal: true }] }], daysCol: [{ type: i0.ViewChild, args: ['daysCol', { isSignal: true }] }], startDate: [{ type: i0.ViewChild, args: ['startDate', { isSignal: true }] }], endDate: [{ type: i0.ViewChild, args: ['endDate', { isSignal: true }] }] } });
706
+
707
+ // store/index.ts
708
+
709
+ /**
710
+ * Generated bundle index. Do not edit.
711
+ */
712
+
713
+ export { AddDelegation, ClearSelectedDelegation, DelegationForm, Delegations, DelegationsActionKey, DelegationsFacade, DelegationsList, DelegationsState, DeleteDelegation, GetDelegation, GetDelegations, UpdateDelegation };
714
+ //# sourceMappingURL=masterteam-delegations.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"masterteam-delegations.mjs","sources":["../../../../packages/masterteam/delegations/src/lib/delegations/delegations.ts","../../../../packages/masterteam/delegations/src/lib/delegations/delegations.html","../../../../packages/masterteam/delegations/src/store/delegations/delegations.model.ts","../../../../packages/masterteam/delegations/src/store/delegations/delegations.actions.ts","../../../../packages/masterteam/delegations/src/store/delegations/delegations.state.ts","../../../../packages/masterteam/delegations/src/store/delegations/delegations.facade.ts","../../../../packages/masterteam/delegations/src/lib/delegations/delegation-form/delegation-form.ts","../../../../packages/masterteam/delegations/src/lib/delegations/delegation-form/delegation-form.html","../../../../packages/masterteam/delegations/src/lib/delegations/delegations-list/delegations-list.ts","../../../../packages/masterteam/delegations/src/lib/delegations/delegations-list/delegations-list.html","../../../../packages/masterteam/delegations/src/store/index.ts","../../../../packages/masterteam/delegations/src/masterteam-delegations.ts"],"sourcesContent":["import { Component, inject } from '@angular/core';\r\nimport { Router, RouterOutlet } from '@angular/router';\r\nimport { TranslocoDirective } from '@jsverse/transloco';\r\nimport { Page } from '@masterteam/components/page';\r\n\r\n@Component({\r\n selector: 'mt-delegations',\r\n imports: [Page, RouterOutlet, TranslocoDirective],\r\n templateUrl: './delegations.html',\r\n styleUrl: './delegations.css',\r\n})\r\nexport default class Delegations {\r\n private readonly router = inject(Router);\r\n\r\n goBack() {\r\n this.router.navigate(['control-panel/product-settings']);\r\n }\r\n}\r\n","<ng-container *transloco=\"let t\">\r\n <mt-page\r\n [title]=\"t('delegations.delegations')\"\r\n [avatarIcon]=\"'custom.hierarchy-structure'\"\r\n [avatarStyle]=\"{\r\n '--p-avatar-background': 'var(--p-indigo-50)',\r\n '--p-avatar-color': 'var(--p-indigo-700)',\r\n }\"\r\n (backButtonClick)=\"goBack()\"\r\n backButton\r\n >\r\n <router-outlet />\r\n </mt-page>\r\n</ng-container>\r\n","import { LoadingStateShape } from '../utils/state-helpers';\r\n\r\nexport interface DelegationUser {\r\n id: string;\r\n userId: string;\r\n displayName: string;\r\n mobile: string;\r\n userName: string;\r\n email: string;\r\n photo: string;\r\n}\r\n\r\nexport interface DelegationDateTime {\r\n displayValue: string;\r\n actualValue: string;\r\n}\r\n\r\nexport interface Delegation {\r\n id?: number;\r\n delegateFrom?: DelegationUser;\r\n delegateTo?: DelegationUser;\r\n delegateFromDateTime?: DelegationDateTime;\r\n delegateToDateTime?: DelegationDateTime;\r\n delegationStatus?: boolean;\r\n isActive?: boolean;\r\n description?: string;\r\n delegationDaysType?: 'fullRange' | 'specificDays';\r\n specificDays?: number[];\r\n}\r\n\r\nexport interface DelegationFormData {\r\n delegateTo: string;\r\n delegateFromDateTime: string;\r\n delegateToDateTime: string;\r\n delegateFrom: string;\r\n description?: string;\r\n delegationDaysType?: 'fullRange' | 'specificDays';\r\n specificDays?: number[];\r\n isActive?: boolean;\r\n}\r\n\r\nexport enum DelegationsActionKey {\r\n GetDelegations = 'getDelegations',\r\n AddDelegation = 'addDelegation',\r\n UpdateDelegation = 'updateDelegation',\r\n DeleteDelegation = 'deleteDelegation',\r\n GetDelegationForm = 'getDelegationForm',\r\n}\r\n\r\nexport interface DelegationsStateModel extends LoadingStateShape<DelegationsActionKey> {\r\n allDelegations: Delegation[];\r\n selectedDelegation: Delegation | null;\r\n}\r\n","import { DelegationFormData } from './delegations.model';\r\n\r\nexport class GetDelegations {\r\n static readonly type = '[Delegations] Get Delegations';\r\n}\r\n\r\nexport class AddDelegation {\r\n static readonly type = '[Delegations] Add Delegation';\r\n constructor(public delegation: DelegationFormData) {}\r\n}\r\n\r\nexport class UpdateDelegation {\r\n static readonly type = '[Delegations] Update Delegation';\r\n constructor(\r\n public id: number,\r\n public delegation: DelegationFormData,\r\n ) {}\r\n}\r\n\r\nexport class DeleteDelegation {\r\n static readonly type = '[Delegations] Delete Delegation';\r\n constructor(public id: number) {}\r\n}\r\n\r\nexport class GetDelegation {\r\n static readonly type = '[Delegations] Get Delegation';\r\n constructor(public id: number) {}\r\n}\r\n\r\nexport class ClearSelectedDelegation {\r\n static readonly type = '[Delegations] Clear Selected Delegation';\r\n}\r\n","import { State, Action, StateContext, Selector } from '@ngxs/store';\r\nimport {\r\n GetDelegations,\r\n AddDelegation,\r\n UpdateDelegation,\r\n DeleteDelegation,\r\n GetDelegation,\r\n ClearSelectedDelegation,\r\n} from './delegations.actions';\r\nimport {\r\n Delegation,\r\n DelegationsActionKey,\r\n DelegationsStateModel,\r\n} from './delegations.model';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { inject, Injectable } from '@angular/core';\r\nimport { Response } from './api.model';\r\nimport { CrudStateBase, handleApiRequest } from '@masterteam/components';\r\n\r\n@State<DelegationsStateModel>({\r\n name: 'delegations',\r\n defaults: {\r\n allDelegations: [],\r\n selectedDelegation: null,\r\n loadingActive: [],\r\n errors: {},\r\n },\r\n})\r\n@Injectable()\r\nexport class DelegationsState extends CrudStateBase<\r\n Delegation,\r\n DelegationsStateModel,\r\n DelegationsActionKey\r\n> {\r\n private http = inject(HttpClient);\r\n\r\n // ============================================================================\r\n // Selectors - Individual data selectors for fine-grained reactivity\r\n // ============================================================================\r\n\r\n @Selector()\r\n static getAllDelegations(state: DelegationsStateModel): Delegation[] {\r\n return state.allDelegations;\r\n }\r\n\r\n @Selector()\r\n static getSelectedDelegation(\r\n state: DelegationsStateModel,\r\n ): Delegation | null {\r\n return state.selectedDelegation;\r\n }\r\n\r\n // ============================================================================\r\n // Loading/Error Slice Selectors - REQUIRED for optimal performance\r\n // ============================================================================\r\n\r\n @Selector()\r\n static getLoadingActive(state: DelegationsStateModel): string[] {\r\n return state.loadingActive;\r\n }\r\n\r\n @Selector()\r\n static getErrors(\r\n state: DelegationsStateModel,\r\n ): Record<string, string | null> {\r\n return state.errors;\r\n }\r\n\r\n // ============================================================================\r\n // CRUD Actions\r\n // ============================================================================\r\n\r\n @Action(GetDelegations)\r\n getDelegations(ctx: StateContext<DelegationsStateModel>) {\r\n const req$ = this.http.get<Response<Delegation[]>>(\r\n 'identity/delegations/all',\r\n );\r\n\r\n return handleApiRequest({\r\n ctx,\r\n key: DelegationsActionKey.GetDelegations,\r\n request$: req$,\r\n onSuccess: (response) => ({\r\n allDelegations: response.data ?? [],\r\n }),\r\n });\r\n }\r\n\r\n @Action(GetDelegation)\r\n getDelegation(\r\n ctx: StateContext<DelegationsStateModel>,\r\n { id }: GetDelegation,\r\n ) {\r\n const req$ = this.http.get<Response<Delegation>>(\r\n `identity/delegations/${id}`,\r\n );\r\n\r\n return handleApiRequest({\r\n ctx,\r\n key: DelegationsActionKey.GetDelegationForm,\r\n request$: req$,\r\n onSuccess: (response) => ({\r\n selectedDelegation: response.data ?? null,\r\n }),\r\n });\r\n }\r\n\r\n @Action(AddDelegation)\r\n addDelegation(\r\n ctx: StateContext<DelegationsStateModel>,\r\n { delegation }: AddDelegation,\r\n ) {\r\n const req$ = this.http.post<Response<Delegation>>(\r\n 'identity/delegations',\r\n delegation,\r\n );\r\n\r\n return this.create(ctx, {\r\n key: DelegationsActionKey.AddDelegation,\r\n request$: req$,\r\n stateProperty: (state) => state.allDelegations,\r\n });\r\n }\r\n\r\n @Action(UpdateDelegation)\r\n updateDelegation(\r\n ctx: StateContext<DelegationsStateModel>,\r\n { id, delegation }: UpdateDelegation,\r\n ) {\r\n const req$ = this.http.put<Response<Delegation>>(\r\n `identity/delegations/${id}`,\r\n delegation,\r\n );\r\n\r\n return this.update(ctx, {\r\n key: DelegationsActionKey.UpdateDelegation,\r\n request$: req$,\r\n uniqueKey: 'id',\r\n id,\r\n stateProperty: (state) => state.allDelegations,\r\n });\r\n }\r\n\r\n @Action(DeleteDelegation)\r\n deleteDelegation(\r\n ctx: StateContext<DelegationsStateModel>,\r\n { id }: DeleteDelegation,\r\n ) {\r\n const req$ = this.http.delete<Response<void>>(`identity/delegations/${id}`);\r\n\r\n return this.delete(ctx, {\r\n key: DelegationsActionKey.DeleteDelegation,\r\n request$: req$,\r\n uniqueKey: 'id',\r\n id,\r\n stateProperty: (state) => state.allDelegations,\r\n });\r\n }\r\n\r\n @Action(ClearSelectedDelegation)\r\n clearSelectedDelegation(ctx: StateContext<DelegationsStateModel>) {\r\n ctx.patchState({ selectedDelegation: null });\r\n }\r\n}\r\n","import { Injectable, computed, inject } from '@angular/core';\r\nimport { Store, select } from '@ngxs/store';\r\nimport {\r\n AddDelegation,\r\n DeleteDelegation,\r\n GetDelegation,\r\n GetDelegations,\r\n UpdateDelegation,\r\n ClearSelectedDelegation,\r\n} from './delegations.actions';\r\nimport { DelegationsActionKey, DelegationFormData } from './delegations.model';\r\nimport { DelegationsState } from './delegations.state';\r\n\r\n@Injectable({ providedIn: 'root' })\r\nexport class DelegationsFacade {\r\n private readonly store = inject(Store);\r\n\r\n // ============================================================================\r\n // Data Selectors - Memoized by NGXS (fine-grained reactivity)\r\n // ============================================================================\r\n readonly allDelegations = select(DelegationsState.getAllDelegations);\r\n readonly selectedDelegation = select(DelegationsState.getSelectedDelegation);\r\n\r\n // ============================================================================\r\n // Loading/Error Slices - Memoized by NGXS\r\n // ============================================================================\r\n private readonly loadingActive = select(DelegationsState.getLoadingActive);\r\n private readonly errors = select(DelegationsState.getErrors);\r\n\r\n // ============================================================================\r\n // Loading Signals - Computed from slice (minimal reactivity)\r\n // ============================================================================\r\n readonly isLoadingDelegations = computed(() =>\r\n this.loadingActive().includes(DelegationsActionKey.GetDelegations),\r\n );\r\n readonly isLoadingDelegation = computed(() =>\r\n this.loadingActive().includes(DelegationsActionKey.GetDelegationForm),\r\n );\r\n readonly isAddingDelegation = computed(() =>\r\n this.loadingActive().includes(DelegationsActionKey.AddDelegation),\r\n );\r\n readonly isUpdatingDelegation = computed(() =>\r\n this.loadingActive().includes(DelegationsActionKey.UpdateDelegation),\r\n );\r\n readonly isDeletingDelegation = computed(() =>\r\n this.loadingActive().includes(DelegationsActionKey.DeleteDelegation),\r\n );\r\n\r\n // ============================================================================\r\n // Error Signals - Computed from slice (minimal reactivity)\r\n // ============================================================================\r\n readonly delegationsError = computed(\r\n () => this.errors()[DelegationsActionKey.GetDelegations] ?? null,\r\n );\r\n readonly delegationError = computed(\r\n () => this.errors()[DelegationsActionKey.GetDelegationForm] ?? null,\r\n );\r\n readonly addDelegationError = computed(\r\n () => this.errors()[DelegationsActionKey.AddDelegation] ?? null,\r\n );\r\n readonly updateDelegationError = computed(\r\n () => this.errors()[DelegationsActionKey.UpdateDelegation] ?? null,\r\n );\r\n readonly deleteDelegationError = computed(\r\n () => this.errors()[DelegationsActionKey.DeleteDelegation] ?? null,\r\n );\r\n\r\n // ============================================================================\r\n // Derived Data - Computed from data selectors\r\n // ============================================================================\r\n readonly activeDelegations = computed(() =>\r\n this.allDelegations().filter((d) => d.isActive === true),\r\n );\r\n\r\n readonly inactiveDelegations = computed(() =>\r\n this.allDelegations().filter((d) => d.isActive === false),\r\n );\r\n\r\n // ============================================================================\r\n // Action Dispatchers\r\n // ============================================================================\r\n\r\n getDelegations() {\r\n return this.store.dispatch(new GetDelegations());\r\n }\r\n\r\n addDelegation(delegation: DelegationFormData) {\r\n return this.store.dispatch(new AddDelegation(delegation));\r\n }\r\n\r\n updateDelegation(id: number, delegation: DelegationFormData) {\r\n return this.store.dispatch(new UpdateDelegation(id, delegation));\r\n }\r\n\r\n deleteDelegation(id: number) {\r\n return this.store.dispatch(new DeleteDelegation(id));\r\n }\r\n\r\n loadDelegation(id: number) {\r\n return this.store.dispatch(new GetDelegation(id));\r\n }\r\n\r\n clearSelectedDelegation() {\r\n return this.store.dispatch(new ClearSelectedDelegation());\r\n }\r\n}\r\n","import {\r\n Component,\r\n inject,\r\n OnInit,\r\n effect,\r\n input,\r\n computed,\r\n signal,\r\n} from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormControl, ReactiveFormsModule } from '@angular/forms';\r\nimport { toSignal } from '@angular/core/rxjs-interop';\r\nimport { DynamicForm } from '@masterteam/forms/dynamic-form';\r\nimport { Button } from '@masterteam/components/button';\r\nimport { SkeletonModule } from 'primeng/skeleton';\r\n\r\n// Masterteam dialog\r\nimport { DialogService, ModalRef } from '@masterteam/components/dialog';\r\nimport {\r\n DynamicFormConfig,\r\n TextareaFieldConfig,\r\n ValidatorConfig,\r\n RadioButtonFieldConfig,\r\n MultiSelectFieldConfig,\r\n ToggleFieldConfig,\r\n} from '@masterteam/components';\r\nimport {\r\n Delegation,\r\n DelegationsFacade,\r\n DelegationFormData,\r\n} from '../../../store/delegations';\r\nimport { UserSearchFieldConfig } from '@masterteam/components';\r\nimport {\r\n TranslocoDirective,\r\n TranslocoPipe,\r\n TranslocoService,\r\n} from '@jsverse/transloco';\r\nimport { HttpContext } from '@angular/common/http';\r\nimport { REQUEST_CONTEXT } from '@masterteam/components';\r\nimport { ModalService } from '@masterteam/components/modal';\r\nimport { DateFieldConfig } from '@masterteam/components';\r\n\r\n@Component({\r\n selector: 'mt-delegation-form',\r\n templateUrl: './delegation-form.html',\r\n styleUrls: ['./delegation-form.css'],\r\n standalone: true,\r\n imports: [\r\n CommonModule,\r\n Button,\r\n TranslocoDirective,\r\n SkeletonModule,\r\n DynamicForm,\r\n ReactiveFormsModule,\r\n TranslocoPipe,\r\n ],\r\n providers: [DialogService],\r\n})\r\nexport default class DelegationForm implements OnInit {\r\n modal = inject(ModalService);\r\n ref: ModalRef = inject(ModalRef);\r\n delegationForEdit = input<Delegation | null>(null);\r\n private readonly translocoService = inject(TranslocoService);\r\n private readonly facade = inject(DelegationsFacade);\r\n selectedDelegation = this.facade.selectedDelegation;\r\n delegationFormControl = new FormControl();\r\n formValue = toSignal(this.delegationFormControl.valueChanges);\r\n getDelegationFormLoading = this.facade.isLoadingDelegation;\r\n isAddingDelegation = this.facade.isAddingDelegation;\r\n isUpdatingDelegation = this.facade.isUpdatingDelegation;\r\n context = new HttpContext().set(REQUEST_CONTEXT, {\r\n useBaseUrl: true,\r\n });\r\n\r\n isDelegatingToSelf = computed(() => {\r\n const formValue = this.formValue();\r\n const fromId = formValue.delegateFrom?.userId || formValue.delegateFrom;\r\n const toId = formValue.delegateTo?.userId || formValue.delegateTo;\r\n return fromId === toId;\r\n });\r\n\r\n specificDaysOptions = signal([\r\n {\r\n label: this.translocoService.translate('delegations.sunday'),\r\n value: 0,\r\n },\r\n {\r\n label: this.translocoService.translate('delegations.monday'),\r\n value: 1,\r\n },\r\n {\r\n label: this.translocoService.translate('delegations.tuesday'),\r\n value: 2,\r\n },\r\n {\r\n label: this.translocoService.translate('delegations.wednesday'),\r\n value: 3,\r\n },\r\n {\r\n label: this.translocoService.translate('delegations.thursday'),\r\n value: 4,\r\n },\r\n {\r\n label: this.translocoService.translate('delegations.friday'),\r\n value: 5,\r\n },\r\n {\r\n label: this.translocoService.translate('delegations.saturday'),\r\n value: 6,\r\n },\r\n ]);\r\n\r\n delegationFormConfig = computed<DynamicFormConfig>(() => ({\r\n sections: [\r\n {\r\n key: 'delegationFormConfig',\r\n type: 'header',\r\n order: 1,\r\n fields: [\r\n new UserSearchFieldConfig({\r\n key: 'delegateFrom',\r\n label: this.translocoService.translate(\r\n 'delegations.originally-assigned-to',\r\n ),\r\n apiUrl: 'Identity/users',\r\n context: this.context,\r\n validators: [ValidatorConfig.required()],\r\n order: 1,\r\n colSpan: 6,\r\n disabled: !!this.delegationForEdit()?.id,\r\n }),\r\n new UserSearchFieldConfig({\r\n key: 'delegateTo',\r\n label: this.translocoService.translate('delegations.delegated-to'),\r\n apiUrl: 'Identity/users',\r\n context: this.context,\r\n validators: [ValidatorConfig.required()],\r\n order: 2,\r\n colSpan: 6,\r\n disabled: !!this.delegationForEdit()?.id,\r\n }),\r\n new TextareaFieldConfig({\r\n key: 'description',\r\n label: this.translocoService.translate('delegations.description'),\r\n placeholder: this.translocoService.translate(\r\n 'delegations.description',\r\n ),\r\n colSpan: 12,\r\n order: 3,\r\n }),\r\n new DateFieldConfig({\r\n key: 'delegateFromDateTime',\r\n label: this.translocoService.translate(\r\n 'delegations.delegation-date-from',\r\n ),\r\n placeholder: this.translocoService.translate(\r\n 'delegations.delegation-date-from',\r\n ),\r\n validators: [ValidatorConfig.required()],\r\n showTime: true,\r\n colSpan: 6,\r\n order: 4,\r\n }),\r\n new DateFieldConfig({\r\n key: 'delegateToDateTime',\r\n label: this.translocoService.translate(\r\n 'delegations.delegation-date-to',\r\n ),\r\n placeholder: this.translocoService.translate(\r\n 'delegations.delegation-date-to',\r\n ),\r\n validators: [ValidatorConfig.required()],\r\n showTime: true,\r\n colSpan: 6,\r\n order: 5,\r\n }),\r\n new RadioButtonFieldConfig({\r\n key: 'delegationDaysType',\r\n label: this.translocoService.translate(\r\n 'delegations.delegation-days-apply',\r\n ),\r\n options: [\r\n {\r\n label: this.translocoService.translate(\r\n 'delegations.full-range',\r\n ),\r\n value: 'FullRange',\r\n },\r\n {\r\n label: this.translocoService.translate(\r\n 'delegations.specific-days',\r\n ),\r\n value: 'SpecificDays',\r\n },\r\n ],\r\n optionLabel: 'label',\r\n optionValue: 'value',\r\n validators: [ValidatorConfig.required()],\r\n colSpan: 12,\r\n order: 6,\r\n }),\r\n new MultiSelectFieldConfig({\r\n key: 'specificDays',\r\n label: this.translocoService.translate('delegations.specific-days'),\r\n options: this.specificDaysOptions(),\r\n optionLabel: 'label',\r\n optionValue: 'value',\r\n maxSelectedLabels: 7,\r\n relations: [\r\n {\r\n key: 'delegationDaysType',\r\n value: 'SpecificDays',\r\n action: 'show',\r\n },\r\n ],\r\n colSpan: 12,\r\n order: 7,\r\n }),\r\n new ToggleFieldConfig({\r\n key: 'isActive',\r\n label: this.translocoService.translate(\r\n 'delegations.active-delegation',\r\n ),\r\n cssClass: 'mt-5 !w-100',\r\n order: 8,\r\n }),\r\n ],\r\n },\r\n ],\r\n }));\r\n\r\n constructor() {\r\n effect(() => {\r\n const delegationId = this.delegationForEdit()?.id;\r\n if (this.selectedDelegation() && delegationId) {\r\n const delegation = this.selectedDelegation();\r\n const data = {\r\n delegateFrom: delegation?.delegateFrom,\r\n delegateTo: delegation?.delegateTo,\r\n description: delegation?.description,\r\n delegateFromDateTime: delegation?.delegateFromDateTime?.actualValue\r\n ? new Date(delegation.delegateFromDateTime.actualValue)\r\n : undefined,\r\n delegateToDateTime: delegation?.delegateToDateTime?.actualValue\r\n ? new Date(delegation.delegateToDateTime.actualValue)\r\n : undefined,\r\n delegationDaysType: delegation?.delegationDaysType || 'FullRange',\r\n specificDays: delegation?.specificDays || [],\r\n isActive: delegation?.isActive ?? false,\r\n };\r\n this.delegationFormControl.patchValue(data);\r\n } else {\r\n this.delegationFormControl.reset({\r\n delegationDaysType: 'FullRange',\r\n isActive: true,\r\n });\r\n }\r\n });\r\n }\r\n\r\n ngOnInit(): void {\r\n const delegationId = this.delegationForEdit()?.id;\r\n if (delegationId) {\r\n this.facade.loadDelegation(delegationId);\r\n }\r\n }\r\n\r\n onSubmit() {\r\n if (!this.delegationFormControl.valid) {\r\n return;\r\n }\r\n\r\n const formValue = this.delegationFormControl.value;\r\n const payload: DelegationFormData = {\r\n delegateFrom: formValue?.delegateFrom?.userId || formValue?.delegateFrom,\r\n delegateTo: formValue?.delegateTo?.userId || formValue?.delegateTo,\r\n description: formValue?.description,\r\n delegateFromDateTime: formValue?.delegateFromDateTime,\r\n delegateToDateTime: formValue?.delegateToDateTime,\r\n delegationDaysType: formValue?.delegationDaysType || 'FullRange',\r\n specificDays:\r\n formValue?.delegationDaysType === 'SpecificDays'\r\n ? formValue?.specificDays || []\r\n : undefined,\r\n isActive: formValue?.isActive ?? false,\r\n };\r\n\r\n const delegationId = this.delegationForEdit()?.id;\r\n if (delegationId) {\r\n this.facade.updateDelegation(delegationId, payload).subscribe({\r\n next: () => {\r\n this.ref.close(true);\r\n },\r\n error: () => {},\r\n });\r\n } else {\r\n this.facade.addDelegation(payload).subscribe({\r\n next: () => {\r\n this.ref.close(true);\r\n },\r\n error: () => {},\r\n });\r\n }\r\n }\r\n}\r\n","<ng-container *transloco=\"let t; prefix: 'delegations'\">\r\n <div [class]=\"'flex flex-col gap-3 p-4 ' + modal.contentClass\">\r\n @if (getDelegationFormLoading()) {\r\n <p-skeleton class=\"my-4 mt-7\" height=\"3rem\" />\r\n <p-skeleton class=\"my-4\" height=\"3rem\" />\r\n <p-skeleton class=\"my-4\" height=\"6rem\" />\r\n <p-skeleton class=\"my-4\" height=\"3rem\" />\r\n } @else {\r\n <mt-dynamic-form\r\n [formConfig]=\"delegationFormConfig()\"\r\n [formControl]=\"delegationFormControl\"\r\n />\r\n }\r\n </div>\r\n\r\n <div [class]=\"modal.footerClass\">\r\n <mt-button\r\n [label]=\"'cancel' | transloco\"\r\n severity=\"secondary\"\r\n variant=\"outlined\"\r\n (click)=\"ref.close()\"\r\n />\r\n <mt-button\r\n [label]=\"delegationForEdit() ? t('update') : t('create')\"\r\n [loading]=\"isAddingDelegation() || isUpdatingDelegation()\"\r\n [disabled]=\"!delegationFormControl.valid || isDelegatingToSelf()\"\r\n (click)=\"onSubmit()\"\r\n />\r\n </div>\r\n</ng-container>\r\n","import { CommonModule } from '@angular/common';\r\nimport {\r\n Component,\r\n computed,\r\n inject,\r\n linkedSignal,\r\n OnInit,\r\n signal,\r\n TemplateRef,\r\n viewChild,\r\n} from '@angular/core';\r\nimport { ColumnDef, Table, TableAction } from '@masterteam/components/table';\r\nimport { SkeletonModule } from 'primeng/skeleton';\r\nimport { DelegationsFacade } from '../../../store/delegations';\r\nimport { Avatar } from '@masterteam/components/avatar';\r\nimport { TranslocoDirective, TranslocoService } from '@jsverse/transloco';\r\nimport { ModalService } from '@masterteam/components/modal';\r\nimport DelegationForm from '../delegation-form/delegation-form';\r\nimport { finalize } from 'rxjs';\r\nimport { Breadcrumb } from '@masterteam/components/breadcrumb';\r\nimport { Icon } from '@masterteam/icons';\r\n\r\n@Component({\r\n selector: 'mt-delegations-list',\r\n styleUrl: './delegations-list.css',\r\n templateUrl: './delegations-list.html',\r\n standalone: true,\r\n imports: [\r\n CommonModule,\r\n SkeletonModule,\r\n Table,\r\n Avatar,\r\n TranslocoDirective,\r\n Breadcrumb,\r\n Icon,\r\n ],\r\n})\r\nexport default class DelegationsList implements OnInit {\r\n statusCol = viewChild.required<TemplateRef<any>>('statusCol');\r\n userCol = viewChild.required<TemplateRef<any>>('userCol');\r\n userCol2 = viewChild.required<TemplateRef<any>>('userCol2');\r\n daysCol = viewChild.required<TemplateRef<any>>('daysCol');\r\n startDate = viewChild.required<TemplateRef<any>>('startDate');\r\n endDate = viewChild.required<TemplateRef<any>>('endDate');\r\n\r\n private readonly facade = inject(DelegationsFacade);\r\n readonly modal: ModalService = inject(ModalService);\r\n private readonly translocoService = inject(TranslocoService);\r\n\r\n breadcrumbItems = linkedSignal(() => [\r\n {\r\n label: '',\r\n icon: 'general.home-line',\r\n routerLink: '/control-panel/workspaces',\r\n },\r\n {\r\n label: this.translocoService.translate(\r\n 'product-settings.product-settings',\r\n ),\r\n routerLink: '/control-panel/product-settings',\r\n },\r\n {\r\n label: this.translocoService.translate('delegations.delegations'),\r\n },\r\n ]);\r\n\r\n delegations = computed(() => {\r\n const tab = this.activeTab();\r\n const all = this.allDelegations();\r\n const activeDelegations = this.activeDelegations();\r\n const inactiveDelegations = this.inactiveDelegations();\r\n\r\n switch (tab) {\r\n case 'active':\r\n return activeDelegations;\r\n case 'inactive':\r\n return inactiveDelegations;\r\n case 'all':\r\n default:\r\n return all;\r\n }\r\n });\r\n\r\n tabs = signal([\r\n {\r\n label: this.translocoService.translate('delegations.all'),\r\n value: 'all',\r\n },\r\n {\r\n label: this.translocoService.translate('delegations.active'),\r\n value: 'active',\r\n },\r\n {\r\n label: this.translocoService.translate('delegations.inactive'),\r\n value: 'inactive',\r\n },\r\n ]);\r\n activeTab = signal<string>('all');\r\n tableActions = signal<TableAction[]>([\r\n {\r\n icon: 'general.plus',\r\n label: this.translocoService.translate('delegations.add-delegation'),\r\n color: 'primary',\r\n action: () => {\r\n this.addDelegationDialog();\r\n },\r\n },\r\n ]);\r\n\r\n deletingRowIds = signal<any[]>([]);\r\n rowActions = signal<TableAction[]>([\r\n {\r\n icon: 'custom.pencil',\r\n tooltip: this.translocoService.translate('edit'),\r\n color: 'primary',\r\n action: (row: any) => {\r\n this.facade.clearSelectedDelegation();\r\n this.addDelegationDialog(row);\r\n },\r\n },\r\n {\r\n icon: 'general.trash-01',\r\n tooltip: this.translocoService.translate('delete'),\r\n color: 'danger',\r\n variant: 'outlined',\r\n action: (row: any) => {\r\n this.deletingRowIds.update((ids) => [...ids, row.id]);\r\n this.facade\r\n .deleteDelegation(row.id)\r\n .pipe(\r\n finalize(() => {\r\n this.deletingRowIds.update((ids) =>\r\n ids.filter((id) => id !== row.id),\r\n );\r\n }),\r\n )\r\n .subscribe();\r\n },\r\n confirmation: {\r\n type: 'popup',\r\n confirmationType: 'delete',\r\n },\r\n loading: (row: any) => this.deletingRowIds().includes(row.id),\r\n },\r\n ]);\r\n\r\n tableColumns = linkedSignal<ColumnDef[]>(() => [\r\n {\r\n key: 'isActive',\r\n label: this.translocoService.translate('delegations.status'),\r\n type: 'custom',\r\n customCellTpl: this.statusCol(),\r\n filterConfig: {\r\n type: 'select',\r\n label: this.translocoService.translate('delegations.status'),\r\n options: [\r\n {\r\n label: this.translocoService.translate('delegations.active'),\r\n value: true,\r\n },\r\n {\r\n label: this.translocoService.translate('delegations.inactive'),\r\n value: false,\r\n },\r\n ],\r\n },\r\n },\r\n {\r\n key: 'delegateFrom.displayName',\r\n label: this.translocoService.translate(\r\n 'delegations.originally-assigned-to',\r\n ),\r\n type: 'custom',\r\n customCellTpl: this.userCol(),\r\n },\r\n {\r\n key: 'delegateTo.displayName',\r\n label: this.translocoService.translate('delegations.delegated-to'),\r\n type: 'custom',\r\n customCellTpl: this.userCol2(),\r\n },\r\n {\r\n key: 'delegateFromDateTime.actualValue',\r\n label: this.translocoService.translate('delegations.start-date'),\r\n type: 'custom',\r\n customCellTpl: this.startDate(),\r\n filterConfig: {\r\n type: 'date',\r\n label: this.translocoService.translate('delegations.start-date'),\r\n },\r\n },\r\n {\r\n key: 'delegateToDateTime.actualValue',\r\n label: this.translocoService.translate('delegations.end-date'),\r\n type: 'custom',\r\n customCellTpl: this.endDate(),\r\n filterConfig: {\r\n type: 'date',\r\n label: this.translocoService.translate('delegations.end-date'),\r\n },\r\n },\r\n {\r\n key: 'days',\r\n label: this.translocoService.translate('delegations.days'),\r\n type: 'custom',\r\n customCellTpl: this.daysCol(),\r\n },\r\n ]);\r\n\r\n loading = this.facade.isLoadingDelegations;\r\n private allDelegations = this.facade.allDelegations;\r\n private activeDelegations = this.facade.activeDelegations;\r\n private inactiveDelegations = this.facade.inactiveDelegations;\r\n\r\n ngOnInit(): void {\r\n this.facade.getDelegations();\r\n }\r\n\r\n addDelegationDialog(delegation: any | null = null) {\r\n const modalType: 'drawer' | 'dialog' = delegation ? 'drawer' : 'dialog';\r\n this.modal.openModal(DelegationForm, modalType, {\r\n header: delegation\r\n ? this.translocoService.translate('delegations.edit-delegation')\r\n : this.translocoService.translate('delegations.add-delegation'),\r\n styleClass: '!w-[50rem] !absolute !shadow-none',\r\n position: modalType === 'drawer' ? 'end' : '',\r\n appendTo: modalType === 'drawer' ? 'page-content' : 'body',\r\n dismissableMask: true,\r\n dismissible: true,\r\n inputValues: {\r\n delegationForEdit: delegation,\r\n },\r\n });\r\n }\r\n}\r\n","<ng-container *transloco=\"let t; prefix: 'delegations'\">\r\n <div class=\"space-y-4\">\r\n <div class=\"flex items-center justify-between\">\r\n <div class=\"space-y-1\">\r\n <h1 class=\"text-xl font-semibold text-slate-900 tracking-tight\">\r\n {{ t(\"delegations\") }}\r\n </h1>\r\n <mt-breadcrumb\r\n [items]=\"breadcrumbItems()\"\r\n [styleClass]=\"'flex justify-start mx-1'\"\r\n ></mt-breadcrumb>\r\n </div>\r\n </div>\r\n <ng-template #statusCol let-row>\r\n <span\r\n class=\"flex items-center gap-2 text-md\"\r\n [class]=\"row.isActive ? 'text-green-700 ' : 'text-red-700 '\"\r\n >\r\n <mt-icon\r\n class=\"text-2xl\"\r\n [icon]=\"row.isActive ? 'media.play-circle' : 'media.pause-circle'\"\r\n ></mt-icon>\r\n {{ row.isActive ? t(\"active\") : t(\"inactive\") }}\r\n </span>\r\n </ng-template>\r\n\r\n <ng-template #userCol let-row>\r\n <div class=\"flex items-center gap-2\">\r\n <mt-avatar [icon]=\"'custom.user-pp'\"></mt-avatar>\r\n {{ row.delegateFrom?.displayName }}\r\n </div>\r\n </ng-template>\r\n <ng-template #userCol2 let-row>\r\n <div class=\"flex items-center gap-2\">\r\n <mt-avatar [icon]=\"'custom.user-pp'\"></mt-avatar>\r\n {{ row.delegateTo?.displayName }}\r\n </div>\r\n </ng-template>\r\n\r\n <ng-template #daysCol let-row>\r\n <div>{{ row.dayCounts }} {{ t(\"days\") }}</div>\r\n </ng-template>\r\n\r\n <ng-template #startDate let-row>\r\n <div>{{ row.delegateFromDateTime.actualValue | date: \"short\" }}</div>\r\n </ng-template>\r\n <ng-template #endDate let-row>\r\n <div>{{ row.delegateToDateTime.actualValue | date: \"short\" }}</div>\r\n </ng-template>\r\n\r\n <mt-table\r\n [tabs]=\"tabs()\"\r\n [(activeTab)]=\"activeTab\"\r\n [data]=\"delegations()\"\r\n [columns]=\"tableColumns()\"\r\n [actions]=\"tableActions()\"\r\n [rowActions]=\"rowActions()\"\r\n [generalSearch]=\"true\"\r\n [showFilters]=\"true\"\r\n [loading]=\"loading()\"\r\n >\r\n </mt-table>\r\n </div>\r\n</ng-container>\r\n","// store/index.ts\r\nexport * from './delegations';\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":["i1"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAWc,MAAO,WAAW,CAAA;AACb,IAAA,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC;IAExC,MAAM,GAAA;QACJ,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,gCAAgC,CAAC,CAAC;IAC1D;uGALmB,WAAW,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA;AAAX,IAAA,OAAA,IAAA,GAAA,EAAA,CAAA,oBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,IAAA,EAAA,WAAW,0ECXhC,uaAcA,EAAA,MAAA,EAAA,CAAA,EAAA,CAAA,EAAA,YAAA,EAAA,CAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EDPY,IAAI,EAAA,QAAA,EAAA,SAAA,EAAA,MAAA,EAAA,CAAA,YAAA,EAAA,gBAAA,EAAA,YAAA,EAAA,aAAA,EAAA,aAAA,EAAA,OAAA,EAAA,MAAA,EAAA,WAAA,EAAA,cAAA,EAAA,WAAA,CAAA,EAAA,OAAA,EAAA,CAAA,iBAAA,EAAA,WAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAE,YAAY,+KAAE,kBAAkB,EAAA,QAAA,EAAA,aAAA,EAAA,MAAA,EAAA,CAAA,WAAA,EAAA,iBAAA,EAAA,gBAAA,EAAA,eAAA,EAAA,iBAAA,EAAA,eAAA,EAAA,qBAAA,CAAA,EAAA,CAAA,EAAA,CAAA;;2FAI7B,WAAW,EAAA,UAAA,EAAA,CAAA;kBAN/B,SAAS;AACE,YAAA,IAAA,EAAA,CAAA,EAAA,QAAA,EAAA,gBAAgB,WACjB,CAAC,IAAI,EAAE,YAAY,EAAE,kBAAkB,CAAC,EAAA,QAAA,EAAA,uaAAA,EAAA;;;IEkCvC;AAAZ,CAAA,UAAY,oBAAoB,EAAA;AAC9B,IAAA,oBAAA,CAAA,gBAAA,CAAA,GAAA,gBAAiC;AACjC,IAAA,oBAAA,CAAA,eAAA,CAAA,GAAA,eAA+B;AAC/B,IAAA,oBAAA,CAAA,kBAAA,CAAA,GAAA,kBAAqC;AACrC,IAAA,oBAAA,CAAA,kBAAA,CAAA,GAAA,kBAAqC;AACrC,IAAA,oBAAA,CAAA,mBAAA,CAAA,GAAA,mBAAuC;AACzC,CAAC,EANW,oBAAoB,KAApB,oBAAoB,GAAA,EAAA,CAAA,CAAA;;MCvCnB,cAAc,CAAA;AACzB,IAAA,OAAgB,IAAI,GAAG,+BAA+B;;MAG3C,aAAa,CAAA;AAEL,IAAA,UAAA;AADnB,IAAA,OAAgB,IAAI,GAAG,8BAA8B;AACrD,IAAA,WAAA,CAAmB,UAA8B,EAAA;QAA9B,IAAA,CAAA,UAAU,GAAV,UAAU;IAAuB;;MAGzC,gBAAgB,CAAA;AAGlB,IAAA,EAAA;AACA,IAAA,UAAA;AAHT,IAAA,OAAgB,IAAI,GAAG,iCAAiC;IACxD,WAAA,CACS,EAAU,EACV,UAA8B,EAAA;QAD9B,IAAA,CAAA,EAAE,GAAF,EAAE;QACF,IAAA,CAAA,UAAU,GAAV,UAAU;IAChB;;MAGQ,gBAAgB,CAAA;AAER,IAAA,EAAA;AADnB,IAAA,OAAgB,IAAI,GAAG,iCAAiC;AACxD,IAAA,WAAA,CAAmB,EAAU,EAAA;QAAV,IAAA,CAAA,EAAE,GAAF,EAAE;IAAW;;MAGrB,aAAa,CAAA;AAEL,IAAA,EAAA;AADnB,IAAA,OAAgB,IAAI,GAAG,8BAA8B;AACrD,IAAA,WAAA,CAAmB,EAAU,EAAA;QAAV,IAAA,CAAA,EAAE,GAAF,EAAE;IAAW;;MAGrB,uBAAuB,CAAA;AAClC,IAAA,OAAgB,IAAI,GAAG,yCAAyC;;;;;;;;;ACD3D,IAAM,gBAAgB,GAAtB,MAAM,gBAAiB,SAAQ,aAIrC,CAAA;AACS,IAAA,IAAI,GAAG,MAAM,CAAC,UAAU,CAAC;;;;AAO1B,IAAP,OAAO,iBAAiB,CAAC,KAA4B,EAAA;QACnD,OAAO,KAAK,CAAC,cAAc;IAC7B;AAGO,IAAP,OAAO,qBAAqB,CAC1B,KAA4B,EAAA;QAE5B,OAAO,KAAK,CAAC,kBAAkB;IACjC;;;;AAOO,IAAP,OAAO,gBAAgB,CAAC,KAA4B,EAAA;QAClD,OAAO,KAAK,CAAC,aAAa;IAC5B;AAGO,IAAP,OAAO,SAAS,CACd,KAA4B,EAAA;QAE5B,OAAO,KAAK,CAAC,MAAM;IACrB;;;;AAOA,IAAA,cAAc,CAAC,GAAwC,EAAA;QACrD,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CACxB,0BAA0B,CAC3B;AAED,QAAA,OAAO,gBAAgB,CAAC;YACtB,GAAG;YACH,GAAG,EAAE,oBAAoB,CAAC,cAAc;AACxC,YAAA,QAAQ,EAAE,IAAI;AACd,YAAA,SAAS,EAAE,CAAC,QAAQ,MAAM;AACxB,gBAAA,cAAc,EAAE,QAAQ,CAAC,IAAI,IAAI,EAAE;aACpC,CAAC;AACH,SAAA,CAAC;IACJ;AAGA,IAAA,aAAa,CACX,GAAwC,EACxC,EAAE,EAAE,EAAiB,EAAA;AAErB,QAAA,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CACxB,CAAA,qBAAA,EAAwB,EAAE,CAAA,CAAE,CAC7B;AAED,QAAA,OAAO,gBAAgB,CAAC;YACtB,GAAG;YACH,GAAG,EAAE,oBAAoB,CAAC,iBAAiB;AAC3C,YAAA,QAAQ,EAAE,IAAI;AACd,YAAA,SAAS,EAAE,CAAC,QAAQ,MAAM;AACxB,gBAAA,kBAAkB,EAAE,QAAQ,CAAC,IAAI,IAAI,IAAI;aAC1C,CAAC;AACH,SAAA,CAAC;IACJ;AAGA,IAAA,aAAa,CACX,GAAwC,EACxC,EAAE,UAAU,EAAiB,EAAA;AAE7B,QAAA,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CACzB,sBAAsB,EACtB,UAAU,CACX;AAED,QAAA,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE;YACtB,GAAG,EAAE,oBAAoB,CAAC,aAAa;AACvC,YAAA,QAAQ,EAAE,IAAI;YACd,aAAa,EAAE,CAAC,KAAK,KAAK,KAAK,CAAC,cAAc;AAC/C,SAAA,CAAC;IACJ;AAGA,IAAA,gBAAgB,CACd,GAAwC,EACxC,EAAE,EAAE,EAAE,UAAU,EAAoB,EAAA;AAEpC,QAAA,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CACxB,CAAA,qBAAA,EAAwB,EAAE,CAAA,CAAE,EAC5B,UAAU,CACX;AAED,QAAA,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE;YACtB,GAAG,EAAE,oBAAoB,CAAC,gBAAgB;AAC1C,YAAA,QAAQ,EAAE,IAAI;AACd,YAAA,SAAS,EAAE,IAAI;YACf,EAAE;YACF,aAAa,EAAE,CAAC,KAAK,KAAK,KAAK,CAAC,cAAc;AAC/C,SAAA,CAAC;IACJ;AAGA,IAAA,gBAAgB,CACd,GAAwC,EACxC,EAAE,EAAE,EAAoB,EAAA;AAExB,QAAA,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAiB,CAAA,qBAAA,EAAwB,EAAE,CAAA,CAAE,CAAC;AAE3E,QAAA,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE;YACtB,GAAG,EAAE,oBAAoB,CAAC,gBAAgB;AAC1C,YAAA,QAAQ,EAAE,IAAI;AACd,YAAA,SAAS,EAAE,IAAI;YACf,EAAE;YACF,aAAa,EAAE,CAAC,KAAK,KAAK,KAAK,CAAC,cAAc;AAC/C,SAAA,CAAC;IACJ;AAGA,IAAA,uBAAuB,CAAC,GAAwC,EAAA;QAC9D,GAAG,CAAC,UAAU,CAAC,EAAE,kBAAkB,EAAE,IAAI,EAAE,CAAC;IAC9C;uGArIW,gBAAgB,EAAA,IAAA,EAAA,IAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,UAAA,EAAA,CAAA;2GAAhB,gBAAgB,EAAA,CAAA;;AA4C3B,UAAA,CAAA;IADC,MAAM,CAAC,cAAc;AAcrB,CAAA,EAAA,gBAAA,CAAA,SAAA,EAAA,gBAAA,EAAA,IAAA,CAAA;AAGD,UAAA,CAAA;IADC,MAAM,CAAC,aAAa;AAiBpB,CAAA,EAAA,gBAAA,CAAA,SAAA,EAAA,eAAA,EAAA,IAAA,CAAA;AAGD,UAAA,CAAA;IADC,MAAM,CAAC,aAAa;AAepB,CAAA,EAAA,gBAAA,CAAA,SAAA,EAAA,eAAA,EAAA,IAAA,CAAA;AAGD,UAAA,CAAA;IADC,MAAM,CAAC,gBAAgB;AAiBvB,CAAA,EAAA,gBAAA,CAAA,SAAA,EAAA,kBAAA,EAAA,IAAA,CAAA;AAGD,UAAA,CAAA;IADC,MAAM,CAAC,gBAAgB;AAcvB,CAAA,EAAA,gBAAA,CAAA,SAAA,EAAA,kBAAA,EAAA,IAAA,CAAA;AAGD,UAAA,CAAA;IADC,MAAM,CAAC,uBAAuB;AAG9B,CAAA,EAAA,gBAAA,CAAA,SAAA,EAAA,yBAAA,EAAA,IAAA,CAAA;AAzHM,UAAA,CAAA;AADN,IAAA,QAAQ;AAGR,CAAA,EAAA,gBAAA,EAAA,mBAAA,EAAA,IAAA,CAAA;AAGM,UAAA,CAAA;AADN,IAAA,QAAQ;AAKR,CAAA,EAAA,gBAAA,EAAA,uBAAA,EAAA,IAAA,CAAA;AAOM,UAAA,CAAA;AADN,IAAA,QAAQ;AAGR,CAAA,EAAA,gBAAA,EAAA,kBAAA,EAAA,IAAA,CAAA;AAGM,UAAA,CAAA;AADN,IAAA,QAAQ;AAKR,CAAA,EAAA,gBAAA,EAAA,WAAA,EAAA,IAAA,CAAA;AArCU,gBAAgB,GAAA,UAAA,CAAA;AAV5B,IAAA,KAAK,CAAwB;AAC5B,QAAA,IAAI,EAAE,aAAa;AACnB,QAAA,QAAQ,EAAE;AACR,YAAA,cAAc,EAAE,EAAE;AAClB,YAAA,kBAAkB,EAAE,IAAI;AACxB,YAAA,aAAa,EAAE,EAAE;AACjB,YAAA,MAAM,EAAE,EAAE;AACX,SAAA;KACF;AAEY,CAAA,EAAA,gBAAgB,CAsI5B;2FAtIY,gBAAgB,EAAA,UAAA,EAAA,CAAA;kBAD5B;;;MCdY,iBAAiB,CAAA;AACX,IAAA,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC;;;;AAK7B,IAAA,cAAc,GAAG,MAAM,CAAC,gBAAgB,CAAC,iBAAiB,CAAC;AAC3D,IAAA,kBAAkB,GAAG,MAAM,CAAC,gBAAgB,CAAC,qBAAqB,CAAC;;;;AAK3D,IAAA,aAAa,GAAG,MAAM,CAAC,gBAAgB,CAAC,gBAAgB,CAAC;AACzD,IAAA,MAAM,GAAG,MAAM,CAAC,gBAAgB,CAAC,SAAS,CAAC;;;;AAKnD,IAAA,oBAAoB,GAAG,QAAQ,CAAC,MACvC,IAAI,CAAC,aAAa,EAAE,CAAC,QAAQ,CAAC,oBAAoB,CAAC,cAAc,CAAC,gEACnE;AACQ,IAAA,mBAAmB,GAAG,QAAQ,CAAC,MACtC,IAAI,CAAC,aAAa,EAAE,CAAC,QAAQ,CAAC,oBAAoB,CAAC,iBAAiB,CAAC,+DACtE;AACQ,IAAA,kBAAkB,GAAG,QAAQ,CAAC,MACrC,IAAI,CAAC,aAAa,EAAE,CAAC,QAAQ,CAAC,oBAAoB,CAAC,aAAa,CAAC,8DAClE;AACQ,IAAA,oBAAoB,GAAG,QAAQ,CAAC,MACvC,IAAI,CAAC,aAAa,EAAE,CAAC,QAAQ,CAAC,oBAAoB,CAAC,gBAAgB,CAAC,gEACrE;AACQ,IAAA,oBAAoB,GAAG,QAAQ,CAAC,MACvC,IAAI,CAAC,aAAa,EAAE,CAAC,QAAQ,CAAC,oBAAoB,CAAC,gBAAgB,CAAC,gEACrE;;;;AAKQ,IAAA,gBAAgB,GAAG,QAAQ,CAClC,MAAM,IAAI,CAAC,MAAM,EAAE,CAAC,oBAAoB,CAAC,cAAc,CAAC,IAAI,IAAI,4DACjE;AACQ,IAAA,eAAe,GAAG,QAAQ,CACjC,MAAM,IAAI,CAAC,MAAM,EAAE,CAAC,oBAAoB,CAAC,iBAAiB,CAAC,IAAI,IAAI,2DACpE;AACQ,IAAA,kBAAkB,GAAG,QAAQ,CACpC,MAAM,IAAI,CAAC,MAAM,EAAE,CAAC,oBAAoB,CAAC,aAAa,CAAC,IAAI,IAAI,8DAChE;AACQ,IAAA,qBAAqB,GAAG,QAAQ,CACvC,MAAM,IAAI,CAAC,MAAM,EAAE,CAAC,oBAAoB,CAAC,gBAAgB,CAAC,IAAI,IAAI,iEACnE;AACQ,IAAA,qBAAqB,GAAG,QAAQ,CACvC,MAAM,IAAI,CAAC,MAAM,EAAE,CAAC,oBAAoB,CAAC,gBAAgB,CAAC,IAAI,IAAI,iEACnE;;;;IAKQ,iBAAiB,GAAG,QAAQ,CAAC,MACpC,IAAI,CAAC,cAAc,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,QAAQ,KAAK,IAAI,CAAC,EAAA,IAAA,SAAA,GAAA,CAAA,EAAA,SAAA,EAAA,mBAAA,EAAA,CAAA,GAAA,EAAA,CAAA,CACzD;IAEQ,mBAAmB,GAAG,QAAQ,CAAC,MACtC,IAAI,CAAC,cAAc,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,QAAQ,KAAK,KAAK,CAAC,EAAA,IAAA,SAAA,GAAA,CAAA,EAAA,SAAA,EAAA,qBAAA,EAAA,CAAA,GAAA,EAAA,CAAA,CAC1D;;;;IAMD,cAAc,GAAA;QACZ,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,cAAc,EAAE,CAAC;IAClD;AAEA,IAAA,aAAa,CAAC,UAA8B,EAAA;AAC1C,QAAA,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,aAAa,CAAC,UAAU,CAAC,CAAC;IAC3D;IAEA,gBAAgB,CAAC,EAAU,EAAE,UAA8B,EAAA;AACzD,QAAA,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,gBAAgB,CAAC,EAAE,EAAE,UAAU,CAAC,CAAC;IAClE;AAEA,IAAA,gBAAgB,CAAC,EAAU,EAAA;AACzB,QAAA,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,gBAAgB,CAAC,EAAE,CAAC,CAAC;IACtD;AAEA,IAAA,cAAc,CAAC,EAAU,EAAA;AACvB,QAAA,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,aAAa,CAAC,EAAE,CAAC,CAAC;IACnD;IAEA,uBAAuB,GAAA;QACrB,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,uBAAuB,EAAE,CAAC;IAC3D;uGA1FW,iBAAiB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,UAAA,EAAA,CAAA;AAAjB,IAAA,OAAA,KAAA,GAAA,EAAA,CAAA,qBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,QAAA,EAAA,EAAA,EAAA,IAAA,EAAA,iBAAiB,cADJ,MAAM,EAAA,CAAA;;2FACnB,iBAAiB,EAAA,UAAA,EAAA,CAAA;kBAD7B,UAAU;mBAAC,EAAE,UAAU,EAAE,MAAM,EAAE;;;AC6CpB,MAAO,cAAc,CAAA;AACjC,IAAA,KAAK,GAAG,MAAM,CAAC,YAAY,CAAC;AAC5B,IAAA,GAAG,GAAa,MAAM,CAAC,QAAQ,CAAC;AAChC,IAAA,iBAAiB,GAAG,KAAK,CAAoB,IAAI,6DAAC;AACjC,IAAA,gBAAgB,GAAG,MAAM,CAAC,gBAAgB,CAAC;AAC3C,IAAA,MAAM,GAAG,MAAM,CAAC,iBAAiB,CAAC;AACnD,IAAA,kBAAkB,GAAG,IAAI,CAAC,MAAM,CAAC,kBAAkB;AACnD,IAAA,qBAAqB,GAAG,IAAI,WAAW,EAAE;IACzC,SAAS,GAAG,QAAQ,CAAC,IAAI,CAAC,qBAAqB,CAAC,YAAY,CAAC;AAC7D,IAAA,wBAAwB,GAAG,IAAI,CAAC,MAAM,CAAC,mBAAmB;AAC1D,IAAA,kBAAkB,GAAG,IAAI,CAAC,MAAM,CAAC,kBAAkB;AACnD,IAAA,oBAAoB,GAAG,IAAI,CAAC,MAAM,CAAC,oBAAoB;IACvD,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC,GAAG,CAAC,eAAe,EAAE;AAC/C,QAAA,UAAU,EAAE,IAAI;AACjB,KAAA,CAAC;AAEF,IAAA,kBAAkB,GAAG,QAAQ,CAAC,MAAK;AACjC,QAAA,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE;QAClC,MAAM,MAAM,GAAG,SAAS,CAAC,YAAY,EAAE,MAAM,IAAI,SAAS,CAAC,YAAY;QACvE,MAAM,IAAI,GAAG,SAAS,CAAC,UAAU,EAAE,MAAM,IAAI,SAAS,CAAC,UAAU;QACjE,OAAO,MAAM,KAAK,IAAI;AACxB,IAAA,CAAC,8DAAC;IAEF,mBAAmB,GAAG,MAAM,CAAC;AAC3B,QAAA;YACE,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,oBAAoB,CAAC;AAC5D,YAAA,KAAK,EAAE,CAAC;AACT,SAAA;AACD,QAAA;YACE,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,oBAAoB,CAAC;AAC5D,YAAA,KAAK,EAAE,CAAC;AACT,SAAA;AACD,QAAA;YACE,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,qBAAqB,CAAC;AAC7D,YAAA,KAAK,EAAE,CAAC;AACT,SAAA;AACD,QAAA;YACE,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,uBAAuB,CAAC;AAC/D,YAAA,KAAK,EAAE,CAAC;AACT,SAAA;AACD,QAAA;YACE,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,sBAAsB,CAAC;AAC9D,YAAA,KAAK,EAAE,CAAC;AACT,SAAA;AACD,QAAA;YACE,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,oBAAoB,CAAC;AAC5D,YAAA,KAAK,EAAE,CAAC;AACT,SAAA;AACD,QAAA;YACE,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,sBAAsB,CAAC;AAC9D,YAAA,KAAK,EAAE,CAAC;AACT,SAAA;AACF,KAAA,EAAA,IAAA,SAAA,GAAA,CAAA,EAAA,SAAA,EAAA,qBAAA,EAAA,CAAA,GAAA,EAAA,CAAA,CAAC;AAEF,IAAA,oBAAoB,GAAG,QAAQ,CAAoB,OAAO;AACxD,QAAA,QAAQ,EAAE;AACR,YAAA;AACE,gBAAA,GAAG,EAAE,sBAAsB;AAC3B,gBAAA,IAAI,EAAE,QAAQ;AACd,gBAAA,KAAK,EAAE,CAAC;AACR,gBAAA,MAAM,EAAE;AACN,oBAAA,IAAI,qBAAqB,CAAC;AACxB,wBAAA,GAAG,EAAE,cAAc;wBACnB,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CACpC,oCAAoC,CACrC;AACD,wBAAA,MAAM,EAAE,gBAAgB;wBACxB,OAAO,EAAE,IAAI,CAAC,OAAO;AACrB,wBAAA,UAAU,EAAE,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;AACxC,wBAAA,KAAK,EAAE,CAAC;AACR,wBAAA,OAAO,EAAE,CAAC;wBACV,QAAQ,EAAE,CAAC,CAAC,IAAI,CAAC,iBAAiB,EAAE,EAAE,EAAE;qBACzC,CAAC;AACF,oBAAA,IAAI,qBAAqB,CAAC;AACxB,wBAAA,GAAG,EAAE,YAAY;wBACjB,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,0BAA0B,CAAC;AAClE,wBAAA,MAAM,EAAE,gBAAgB;wBACxB,OAAO,EAAE,IAAI,CAAC,OAAO;AACrB,wBAAA,UAAU,EAAE,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;AACxC,wBAAA,KAAK,EAAE,CAAC;AACR,wBAAA,OAAO,EAAE,CAAC;wBACV,QAAQ,EAAE,CAAC,CAAC,IAAI,CAAC,iBAAiB,EAAE,EAAE,EAAE;qBACzC,CAAC;AACF,oBAAA,IAAI,mBAAmB,CAAC;AACtB,wBAAA,GAAG,EAAE,aAAa;wBAClB,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,yBAAyB,CAAC;wBACjE,WAAW,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAC1C,yBAAyB,CAC1B;AACD,wBAAA,OAAO,EAAE,EAAE;AACX,wBAAA,KAAK,EAAE,CAAC;qBACT,CAAC;AACF,oBAAA,IAAI,eAAe,CAAC;AAClB,wBAAA,GAAG,EAAE,sBAAsB;wBAC3B,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CACpC,kCAAkC,CACnC;wBACD,WAAW,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAC1C,kCAAkC,CACnC;AACD,wBAAA,UAAU,EAAE,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;AACxC,wBAAA,QAAQ,EAAE,IAAI;AACd,wBAAA,OAAO,EAAE,CAAC;AACV,wBAAA,KAAK,EAAE,CAAC;qBACT,CAAC;AACF,oBAAA,IAAI,eAAe,CAAC;AAClB,wBAAA,GAAG,EAAE,oBAAoB;wBACzB,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CACpC,gCAAgC,CACjC;wBACD,WAAW,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAC1C,gCAAgC,CACjC;AACD,wBAAA,UAAU,EAAE,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;AACxC,wBAAA,QAAQ,EAAE,IAAI;AACd,wBAAA,OAAO,EAAE,CAAC;AACV,wBAAA,KAAK,EAAE,CAAC;qBACT,CAAC;AACF,oBAAA,IAAI,sBAAsB,CAAC;AACzB,wBAAA,GAAG,EAAE,oBAAoB;wBACzB,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CACpC,mCAAmC,CACpC;AACD,wBAAA,OAAO,EAAE;AACP,4BAAA;gCACE,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CACpC,wBAAwB,CACzB;AACD,gCAAA,KAAK,EAAE,WAAW;AACnB,6BAAA;AACD,4BAAA;gCACE,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CACpC,2BAA2B,CAC5B;AACD,gCAAA,KAAK,EAAE,cAAc;AACtB,6BAAA;AACF,yBAAA;AACD,wBAAA,WAAW,EAAE,OAAO;AACpB,wBAAA,WAAW,EAAE,OAAO;AACpB,wBAAA,UAAU,EAAE,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;AACxC,wBAAA,OAAO,EAAE,EAAE;AACX,wBAAA,KAAK,EAAE,CAAC;qBACT,CAAC;AACF,oBAAA,IAAI,sBAAsB,CAAC;AACzB,wBAAA,GAAG,EAAE,cAAc;wBACnB,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,2BAA2B,CAAC;AACnE,wBAAA,OAAO,EAAE,IAAI,CAAC,mBAAmB,EAAE;AACnC,wBAAA,WAAW,EAAE,OAAO;AACpB,wBAAA,WAAW,EAAE,OAAO;AACpB,wBAAA,iBAAiB,EAAE,CAAC;AACpB,wBAAA,SAAS,EAAE;AACT,4BAAA;AACE,gCAAA,GAAG,EAAE,oBAAoB;AACzB,gCAAA,KAAK,EAAE,cAAc;AACrB,gCAAA,MAAM,EAAE,MAAM;AACf,6BAAA;AACF,yBAAA;AACD,wBAAA,OAAO,EAAE,EAAE;AACX,wBAAA,KAAK,EAAE,CAAC;qBACT,CAAC;AACF,oBAAA,IAAI,iBAAiB,CAAC;AACpB,wBAAA,GAAG,EAAE,UAAU;wBACf,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CACpC,+BAA+B,CAChC;AACD,wBAAA,QAAQ,EAAE,aAAa;AACvB,wBAAA,KAAK,EAAE,CAAC;qBACT,CAAC;AACH,iBAAA;AACF,aAAA;AACF,SAAA;AACF,KAAA,CAAC,gEAAC;AAEH,IAAA,WAAA,GAAA;QACE,MAAM,CAAC,MAAK;YACV,MAAM,YAAY,GAAG,IAAI,CAAC,iBAAiB,EAAE,EAAE,EAAE;AACjD,YAAA,IAAI,IAAI,CAAC,kBAAkB,EAAE,IAAI,YAAY,EAAE;AAC7C,gBAAA,MAAM,UAAU,GAAG,IAAI,CAAC,kBAAkB,EAAE;AAC5C,gBAAA,MAAM,IAAI,GAAG;oBACX,YAAY,EAAE,UAAU,EAAE,YAAY;oBACtC,UAAU,EAAE,UAAU,EAAE,UAAU;oBAClC,WAAW,EAAE,UAAU,EAAE,WAAW;AACpC,oBAAA,oBAAoB,EAAE,UAAU,EAAE,oBAAoB,EAAE;0BACpD,IAAI,IAAI,CAAC,UAAU,CAAC,oBAAoB,CAAC,WAAW;AACtD,0BAAE,SAAS;AACb,oBAAA,kBAAkB,EAAE,UAAU,EAAE,kBAAkB,EAAE;0BAChD,IAAI,IAAI,CAAC,UAAU,CAAC,kBAAkB,CAAC,WAAW;AACpD,0BAAE,SAAS;AACb,oBAAA,kBAAkB,EAAE,UAAU,EAAE,kBAAkB,IAAI,WAAW;AACjE,oBAAA,YAAY,EAAE,UAAU,EAAE,YAAY,IAAI,EAAE;AAC5C,oBAAA,QAAQ,EAAE,UAAU,EAAE,QAAQ,IAAI,KAAK;iBACxC;AACD,gBAAA,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,IAAI,CAAC;YAC7C;iBAAO;AACL,gBAAA,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC;AAC/B,oBAAA,kBAAkB,EAAE,WAAW;AAC/B,oBAAA,QAAQ,EAAE,IAAI;AACf,iBAAA,CAAC;YACJ;AACF,QAAA,CAAC,CAAC;IACJ;IAEA,QAAQ,GAAA;QACN,MAAM,YAAY,GAAG,IAAI,CAAC,iBAAiB,EAAE,EAAE,EAAE;QACjD,IAAI,YAAY,EAAE;AAChB,YAAA,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,YAAY,CAAC;QAC1C;IACF;IAEA,QAAQ,GAAA;AACN,QAAA,IAAI,CAAC,IAAI,CAAC,qBAAqB,CAAC,KAAK,EAAE;YACrC;QACF;AAEA,QAAA,MAAM,SAAS,GAAG,IAAI,CAAC,qBAAqB,CAAC,KAAK;AAClD,QAAA,MAAM,OAAO,GAAuB;YAClC,YAAY,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,IAAI,SAAS,EAAE,YAAY;YACxE,UAAU,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,IAAI,SAAS,EAAE,UAAU;YAClE,WAAW,EAAE,SAAS,EAAE,WAAW;YACnC,oBAAoB,EAAE,SAAS,EAAE,oBAAoB;YACrD,kBAAkB,EAAE,SAAS,EAAE,kBAAkB;AACjD,YAAA,kBAAkB,EAAE,SAAS,EAAE,kBAAkB,IAAI,WAAW;AAChE,YAAA,YAAY,EACV,SAAS,EAAE,kBAAkB,KAAK;AAChC,kBAAE,SAAS,EAAE,YAAY,IAAI;AAC7B,kBAAE,SAAS;AACf,YAAA,QAAQ,EAAE,SAAS,EAAE,QAAQ,IAAI,KAAK;SACvC;QAED,MAAM,YAAY,GAAG,IAAI,CAAC,iBAAiB,EAAE,EAAE,EAAE;QACjD,IAAI,YAAY,EAAE;YAChB,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC,SAAS,CAAC;gBAC5D,IAAI,EAAE,MAAK;AACT,oBAAA,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC;gBACtB,CAAC;AACD,gBAAA,KAAK,EAAE,MAAK,EAAE,CAAC;AAChB,aAAA,CAAC;QACJ;aAAO;YACL,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC;gBAC3C,IAAI,EAAE,MAAK;AACT,oBAAA,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC;gBACtB,CAAC;AACD,gBAAA,KAAK,EAAE,MAAK,EAAE,CAAC;AAChB,aAAA,CAAC;QACJ;IACF;uGArPmB,cAAc,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA;AAAd,IAAA,OAAA,IAAA,GAAA,EAAA,CAAA,oBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,IAAA,EAAA,cAAc,yOAFtB,CAAC,aAAa,CAAC,EAAA,QAAA,EAAA,EAAA,EAAA,QAAA,ECxD5B,ykCA8BA,yDDkBI,YAAY,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EACZ,MAAM,EAAA,QAAA,EAAA,WAAA,EAAA,MAAA,EAAA,CAAA,MAAA,EAAA,OAAA,EAAA,SAAA,EAAA,OAAA,EAAA,MAAA,EAAA,YAAA,EAAA,UAAA,EAAA,OAAA,EAAA,SAAA,EAAA,eAAA,EAAA,MAAA,EAAA,SAAA,EAAA,WAAA,EAAA,OAAA,EAAA,QAAA,EAAA,SAAA,EAAA,MAAA,EAAA,OAAA,EAAA,UAAA,EAAA,MAAA,EAAA,UAAA,EAAA,SAAA,EAAA,SAAA,CAAA,EAAA,OAAA,EAAA,CAAA,SAAA,EAAA,SAAA,EAAA,QAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EACN,kBAAkB,+LAClB,cAAc,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,QAAA,EAAA,QAAA,EAAA,YAAA,EAAA,MAAA,EAAA,CAAA,YAAA,EAAA,OAAA,EAAA,WAAA,EAAA,cAAA,EAAA,MAAA,EAAA,OAAA,EAAA,QAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EACd,WAAW,EAAA,QAAA,EAAA,iBAAA,EAAA,MAAA,EAAA,CAAA,YAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EACX,mBAAmB,qTACnB,aAAa,EAAA,IAAA,EAAA,WAAA,EAAA,CAAA,EAAA,CAAA;;2FAII,cAAc,EAAA,UAAA,EAAA,CAAA;kBAhBlC,SAAS;+BACE,oBAAoB,EAAA,UAAA,EAGlB,IAAI,EAAA,OAAA,EACP;wBACP,YAAY;wBACZ,MAAM;wBACN,kBAAkB;wBAClB,cAAc;wBACd,WAAW;wBACX,mBAAmB;wBACnB,aAAa;qBACd,EAAA,SAAA,EACU,CAAC,aAAa,CAAC,EAAA,QAAA,EAAA,ykCAAA,EAAA;;;AEnBd,MAAO,eAAe,CAAA;AAClC,IAAA,SAAS,GAAG,SAAS,CAAC,QAAQ,CAAmB,WAAW,CAAC;AAC7D,IAAA,OAAO,GAAG,SAAS,CAAC,QAAQ,CAAmB,SAAS,CAAC;AACzD,IAAA,QAAQ,GAAG,SAAS,CAAC,QAAQ,CAAmB,UAAU,CAAC;AAC3D,IAAA,OAAO,GAAG,SAAS,CAAC,QAAQ,CAAmB,SAAS,CAAC;AACzD,IAAA,SAAS,GAAG,SAAS,CAAC,QAAQ,CAAmB,WAAW,CAAC;AAC7D,IAAA,OAAO,GAAG,SAAS,CAAC,QAAQ,CAAmB,SAAS,CAAC;AAExC,IAAA,MAAM,GAAG,MAAM,CAAC,iBAAiB,CAAC;AAC1C,IAAA,KAAK,GAAiB,MAAM,CAAC,YAAY,CAAC;AAClC,IAAA,gBAAgB,GAAG,MAAM,CAAC,gBAAgB,CAAC;AAE5D,IAAA,eAAe,GAAG,YAAY,CAAC,MAAM;AACnC,QAAA;AACE,YAAA,KAAK,EAAE,EAAE;AACT,YAAA,IAAI,EAAE,mBAAmB;AACzB,YAAA,UAAU,EAAE,2BAA2B;AACxC,SAAA;AACD,QAAA;YACE,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CACpC,mCAAmC,CACpC;AACD,YAAA,UAAU,EAAE,iCAAiC;AAC9C,SAAA;AACD,QAAA;YACE,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,yBAAyB,CAAC;AAClE,SAAA;AACF,KAAA,EAAA,IAAA,SAAA,GAAA,CAAA,EAAA,SAAA,EAAA,iBAAA,EAAA,CAAA,GAAA,EAAA,CAAA,CAAC;AAEF,IAAA,WAAW,GAAG,QAAQ,CAAC,MAAK;AAC1B,QAAA,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,EAAE;AAC5B,QAAA,MAAM,GAAG,GAAG,IAAI,CAAC,cAAc,EAAE;AACjC,QAAA,MAAM,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,EAAE;AAClD,QAAA,MAAM,mBAAmB,GAAG,IAAI,CAAC,mBAAmB,EAAE;QAEtD,QAAQ,GAAG;AACT,YAAA,KAAK,QAAQ;AACX,gBAAA,OAAO,iBAAiB;AAC1B,YAAA,KAAK,UAAU;AACb,gBAAA,OAAO,mBAAmB;AAC5B,YAAA,KAAK,KAAK;AACV,YAAA;AACE,gBAAA,OAAO,GAAG;;AAEhB,IAAA,CAAC,uDAAC;IAEF,IAAI,GAAG,MAAM,CAAC;AACZ,QAAA;YACE,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,iBAAiB,CAAC;AACzD,YAAA,KAAK,EAAE,KAAK;AACb,SAAA;AACD,QAAA;YACE,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,oBAAoB,CAAC;AAC5D,YAAA,KAAK,EAAE,QAAQ;AAChB,SAAA;AACD,QAAA;YACE,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,sBAAsB,CAAC;AAC9D,YAAA,KAAK,EAAE,UAAU;AAClB,SAAA;AACF,KAAA,EAAA,IAAA,SAAA,GAAA,CAAA,EAAA,SAAA,EAAA,MAAA,EAAA,CAAA,GAAA,EAAA,CAAA,CAAC;AACF,IAAA,SAAS,GAAG,MAAM,CAAS,KAAK,qDAAC;IACjC,YAAY,GAAG,MAAM,CAAgB;AACnC,QAAA;AACE,YAAA,IAAI,EAAE,cAAc;YACpB,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,4BAA4B,CAAC;AACpE,YAAA,KAAK,EAAE,SAAS;YAChB,MAAM,EAAE,MAAK;gBACX,IAAI,CAAC,mBAAmB,EAAE;YAC5B,CAAC;AACF,SAAA;AACF,KAAA,EAAA,IAAA,SAAA,GAAA,CAAA,EAAA,SAAA,EAAA,cAAA,EAAA,CAAA,GAAA,EAAA,CAAA,CAAC;AAEF,IAAA,cAAc,GAAG,MAAM,CAAQ,EAAE,0DAAC;IAClC,UAAU,GAAG,MAAM,CAAgB;AACjC,QAAA;AACE,YAAA,IAAI,EAAE,eAAe;YACrB,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,MAAM,CAAC;AAChD,YAAA,KAAK,EAAE,SAAS;AAChB,YAAA,MAAM,EAAE,CAAC,GAAQ,KAAI;AACnB,gBAAA,IAAI,CAAC,MAAM,CAAC,uBAAuB,EAAE;AACrC,gBAAA,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC;YAC/B,CAAC;AACF,SAAA;AACD,QAAA;AACE,YAAA,IAAI,EAAE,kBAAkB;YACxB,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,QAAQ,CAAC;AAClD,YAAA,KAAK,EAAE,QAAQ;AACf,YAAA,OAAO,EAAE,UAAU;AACnB,YAAA,MAAM,EAAE,CAAC,GAAQ,KAAI;AACnB,gBAAA,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,GAAG,KAAK,CAAC,GAAG,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC;AACrD,gBAAA,IAAI,CAAC;AACF,qBAAA,gBAAgB,CAAC,GAAG,CAAC,EAAE;AACvB,qBAAA,IAAI,CACH,QAAQ,CAAC,MAAK;oBACZ,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,GAAG,KAC7B,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,KAAK,EAAE,KAAK,GAAG,CAAC,EAAE,CAAC,CAClC;AACH,gBAAA,CAAC,CAAC;AAEH,qBAAA,SAAS,EAAE;YAChB,CAAC;AACD,YAAA,YAAY,EAAE;AACZ,gBAAA,IAAI,EAAE,OAAO;AACb,gBAAA,gBAAgB,EAAE,QAAQ;AAC3B,aAAA;AACD,YAAA,OAAO,EAAE,CAAC,GAAQ,KAAK,IAAI,CAAC,cAAc,EAAE,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;AAC9D,SAAA;AACF,KAAA,EAAA,IAAA,SAAA,GAAA,CAAA,EAAA,SAAA,EAAA,YAAA,EAAA,CAAA,GAAA,EAAA,CAAA,CAAC;AAEF,IAAA,YAAY,GAAG,YAAY,CAAc,MAAM;AAC7C,QAAA;AACE,YAAA,GAAG,EAAE,UAAU;YACf,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,oBAAoB,CAAC;AAC5D,YAAA,IAAI,EAAE,QAAQ;AACd,YAAA,aAAa,EAAE,IAAI,CAAC,SAAS,EAAE;AAC/B,YAAA,YAAY,EAAE;AACZ,gBAAA,IAAI,EAAE,QAAQ;gBACd,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,oBAAoB,CAAC;AAC5D,gBAAA,OAAO,EAAE;AACP,oBAAA;wBACE,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,oBAAoB,CAAC;AAC5D,wBAAA,KAAK,EAAE,IAAI;AACZ,qBAAA;AACD,oBAAA;wBACE,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,sBAAsB,CAAC;AAC9D,wBAAA,KAAK,EAAE,KAAK;AACb,qBAAA;AACF,iBAAA;AACF,aAAA;AACF,SAAA;AACD,QAAA;AACE,YAAA,GAAG,EAAE,0BAA0B;YAC/B,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CACpC,oCAAoC,CACrC;AACD,YAAA,IAAI,EAAE,QAAQ;AACd,YAAA,aAAa,EAAE,IAAI,CAAC,OAAO,EAAE;AAC9B,SAAA;AACD,QAAA;AACE,YAAA,GAAG,EAAE,wBAAwB;YAC7B,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,0BAA0B,CAAC;AAClE,YAAA,IAAI,EAAE,QAAQ;AACd,YAAA,aAAa,EAAE,IAAI,CAAC,QAAQ,EAAE;AAC/B,SAAA;AACD,QAAA;AACE,YAAA,GAAG,EAAE,kCAAkC;YACvC,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,wBAAwB,CAAC;AAChE,YAAA,IAAI,EAAE,QAAQ;AACd,YAAA,aAAa,EAAE,IAAI,CAAC,SAAS,EAAE;AAC/B,YAAA,YAAY,EAAE;AACZ,gBAAA,IAAI,EAAE,MAAM;gBACZ,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,wBAAwB,CAAC;AACjE,aAAA;AACF,SAAA;AACD,QAAA;AACE,YAAA,GAAG,EAAE,gCAAgC;YACrC,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,sBAAsB,CAAC;AAC9D,YAAA,IAAI,EAAE,QAAQ;AACd,YAAA,aAAa,EAAE,IAAI,CAAC,OAAO,EAAE;AAC7B,YAAA,YAAY,EAAE;AACZ,gBAAA,IAAI,EAAE,MAAM;gBACZ,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,sBAAsB,CAAC;AAC/D,aAAA;AACF,SAAA;AACD,QAAA;AACE,YAAA,GAAG,EAAE,MAAM;YACX,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,kBAAkB,CAAC;AAC1D,YAAA,IAAI,EAAE,QAAQ;AACd,YAAA,aAAa,EAAE,IAAI,CAAC,OAAO,EAAE;AAC9B,SAAA;AACF,KAAA,EAAA,IAAA,SAAA,GAAA,CAAA,EAAA,SAAA,EAAA,cAAA,EAAA,CAAA,GAAA,EAAA,CAAA,CAAC;AAEF,IAAA,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,oBAAoB;AAClC,IAAA,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC,cAAc;AAC3C,IAAA,iBAAiB,GAAG,IAAI,CAAC,MAAM,CAAC,iBAAiB;AACjD,IAAA,mBAAmB,GAAG,IAAI,CAAC,MAAM,CAAC,mBAAmB;IAE7D,QAAQ,GAAA;AACN,QAAA,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE;IAC9B;IAEA,mBAAmB,CAAC,aAAyB,IAAI,EAAA;QAC/C,MAAM,SAAS,GAAwB,UAAU,GAAG,QAAQ,GAAG,QAAQ;QACvE,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,cAAc,EAAE,SAAS,EAAE;AAC9C,YAAA,MAAM,EAAE;kBACJ,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,6BAA6B;kBAC7D,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,4BAA4B,CAAC;AACjE,YAAA,UAAU,EAAE,mCAAmC;YAC/C,QAAQ,EAAE,SAAS,KAAK,QAAQ,GAAG,KAAK,GAAG,EAAE;YAC7C,QAAQ,EAAE,SAAS,KAAK,QAAQ,GAAG,cAAc,GAAG,MAAM;AAC1D,YAAA,eAAe,EAAE,IAAI;AACrB,YAAA,WAAW,EAAE,IAAI;AACjB,YAAA,WAAW,EAAE;AACX,gBAAA,iBAAiB,EAAE,UAAU;AAC9B,aAAA;AACF,SAAA,CAAC;IACJ;uGApMmB,eAAe,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA;AAAf,IAAA,OAAA,IAAA,GAAA,EAAA,CAAA,oBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,IAAA,EAAA,eAAe,EAAA,YAAA,EAAA,IAAA,EAAA,QAAA,EAAA,qBAAA,EAAA,WAAA,EAAA,CAAA,EAAA,YAAA,EAAA,WAAA,EAAA,KAAA,EAAA,IAAA,EAAA,SAAA,EAAA,CAAA,WAAA,CAAA,EAAA,WAAA,EAAA,IAAA,EAAA,QAAA,EAAA,IAAA,EAAA,EAAA,EAAA,YAAA,EAAA,SAAA,EAAA,KAAA,EAAA,IAAA,EAAA,SAAA,EAAA,CAAA,SAAA,CAAA,EAAA,WAAA,EAAA,IAAA,EAAA,QAAA,EAAA,IAAA,EAAA,EAAA,EAAA,YAAA,EAAA,UAAA,EAAA,KAAA,EAAA,IAAA,EAAA,SAAA,EAAA,CAAA,UAAA,CAAA,EAAA,WAAA,EAAA,IAAA,EAAA,QAAA,EAAA,IAAA,EAAA,EAAA,EAAA,YAAA,EAAA,SAAA,EAAA,KAAA,EAAA,IAAA,EAAA,SAAA,EAAA,CAAA,SAAA,CAAA,EAAA,WAAA,EAAA,IAAA,EAAA,QAAA,EAAA,IAAA,EAAA,EAAA,EAAA,YAAA,EAAA,WAAA,EAAA,KAAA,EAAA,IAAA,EAAA,SAAA,EAAA,CAAA,WAAA,CAAA,EAAA,WAAA,EAAA,IAAA,EAAA,QAAA,EAAA,IAAA,EAAA,EAAA,EAAA,YAAA,EAAA,SAAA,EAAA,KAAA,EAAA,IAAA,EAAA,SAAA,EAAA,CAAA,SAAA,CAAA,EAAA,WAAA,EAAA,IAAA,EAAA,QAAA,EAAA,IAAA,EAAA,CAAA,EAAA,QAAA,EAAA,EAAA,EAAA,QAAA,ECrCpC,srEAgEA,EAAA,MAAA,EAAA,CAAA,EAAA,CAAA,EAAA,YAAA,EAAA,CAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EDpCI,YAAY,8BACZ,cAAc,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EACd,KAAK,EAAA,QAAA,EAAA,UAAA,EAAA,MAAA,EAAA,CAAA,SAAA,EAAA,MAAA,EAAA,SAAA,EAAA,YAAA,EAAA,MAAA,EAAA,eAAA,EAAA,aAAA,EAAA,gBAAA,EAAA,eAAA,EAAA,aAAA,EAAA,SAAA,EAAA,UAAA,EAAA,MAAA,EAAA,kBAAA,EAAA,oBAAA,EAAA,iBAAA,EAAA,SAAA,EAAA,YAAA,EAAA,gBAAA,EAAA,MAAA,EAAA,iBAAA,EAAA,iBAAA,EAAA,WAAA,EAAA,SAAA,EAAA,mBAAA,EAAA,UAAA,EAAA,aAAA,EAAA,OAAA,EAAA,YAAA,CAAA,EAAA,OAAA,EAAA,CAAA,iBAAA,EAAA,YAAA,EAAA,UAAA,EAAA,eAAA,EAAA,YAAA,EAAA,eAAA,EAAA,iBAAA,EAAA,aAAA,EAAA,gBAAA,EAAA,mBAAA,EAAA,aAAA,EAAA,kBAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EACL,MAAM,EAAA,QAAA,EAAA,WAAA,EAAA,MAAA,EAAA,CAAA,OAAA,EAAA,MAAA,EAAA,OAAA,EAAA,YAAA,EAAA,MAAA,EAAA,OAAA,EAAA,OAAA,EAAA,WAAA,EAAA,eAAA,CAAA,EAAA,OAAA,EAAA,CAAA,cAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EACN,kBAAkB,EAAA,QAAA,EAAA,aAAA,EAAA,MAAA,EAAA,CAAA,WAAA,EAAA,iBAAA,EAAA,gBAAA,EAAA,eAAA,EAAA,iBAAA,EAAA,eAAA,EAAA,qBAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAClB,UAAU,qHACV,IAAI,EAAA,QAAA,EAAA,SAAA,EAAA,MAAA,EAAA,CAAA,MAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,MAAA,EAAA,IAAA,EAAAA,IAAA,CAAA,QAAA,EAAA,IAAA,EAAA,MAAA,EAAA,CAAA,EAAA,CAAA;;2FAGa,eAAe,EAAA,UAAA,EAAA,CAAA;kBAfnC,SAAS;+BACE,qBAAqB,EAAA,UAAA,EAGnB,IAAI,EAAA,OAAA,EACP;wBACP,YAAY;wBACZ,cAAc;wBACd,KAAK;wBACL,MAAM;wBACN,kBAAkB;wBAClB,UAAU;wBACV,IAAI;AACL,qBAAA,EAAA,QAAA,EAAA,srEAAA,EAAA;uEAGgD,WAAW,EAAA,EAAA,QAAA,EAAA,IAAA,EAAA,CAAA,EAAA,CAAA,EAAA,OAAA,EAAA,CAAA,EAAA,IAAA,EAAA,EAAA,CAAA,SAAA,EAAA,IAAA,EAAA,CACb,SAAS,EAAA,EAAA,QAAA,EAAA,IAAA,EAAA,CAAA,EAAA,CAAA,EAAA,QAAA,EAAA,CAAA,EAAA,IAAA,EAAA,EAAA,CAAA,SAAA,EAAA,IAAA,EAAA,CACR,UAAU,iEACX,SAAS,EAAA,EAAA,QAAA,EAAA,IAAA,EAAA,CAAA,EAAA,CAAA,EAAA,SAAA,EAAA,CAAA,EAAA,IAAA,EAAA,EAAA,CAAA,SAAA,EAAA,IAAA,EAAA,CACP,WAAW,EAAA,EAAA,QAAA,EAAA,IAAA,EAAA,CAAA,EAAA,CAAA,EAAA,OAAA,EAAA,CAAA,EAAA,IAAA,EAAA,EAAA,CAAA,SAAA,EAAA,IAAA,EAAA,CACb,SAAS,EAAA,EAAA,QAAA,EAAA,IAAA,EAAA,CAAA,EAAA,CAAA,EAAA,EAAA,CAAA;;AE3C1D;;ACAA;;AAEG;;;;"}
package/package.json ADDED
@@ -0,0 +1,48 @@
1
+ {
2
+ "name": "@masterteam/delegations",
3
+ "version": "0.0.1",
4
+ "publishConfig": {
5
+ "directory": "../../../dist/masterteam/delegations",
6
+ "linkDirectory": false,
7
+ "access": "public"
8
+ },
9
+ "peerDependencies": {
10
+ "@angular/common": "^21.0.3",
11
+ "@angular/core": "^21.0.3",
12
+ "@angular/forms": "^21.0.3",
13
+ "@angular/cdk": "^21.0.2",
14
+ "@primeuix/themes": "^2.0.2",
15
+ "@tailwindcss/postcss": "^4.1.17",
16
+ "@jsverse/transloco": "^8.0.2",
17
+ "postcss": "^8.5.6",
18
+ "primeng": "21.0.1",
19
+ "rxjs": "^7.8.2",
20
+ "tailwindcss": "^4.1.17",
21
+ "tailwindcss-primeui": "^0.6.1",
22
+ "@ngxs/store": "^20.1.0",
23
+ "@masterteam/components": "^0.0.84",
24
+ "@masterteam/forms": "^0.0.35",
25
+ "@masterteam/icons": "^0.0.12"
26
+ },
27
+ "sideEffects": false,
28
+ "exports": {
29
+ "./assets/delegations.css": {
30
+ "style": "./assets/delegations.css"
31
+ },
32
+ "./assets/i18n/*.json": {
33
+ "default": "./assets/i18n/*.json"
34
+ },
35
+ "./package.json": {
36
+ "default": "./package.json"
37
+ },
38
+ ".": {
39
+ "types": "./types/masterteam-delegations.d.ts",
40
+ "default": "./fesm2022/masterteam-delegations.mjs"
41
+ }
42
+ },
43
+ "module": "fesm2022/masterteam-delegations.mjs",
44
+ "typings": "types/masterteam-delegations.d.ts",
45
+ "dependencies": {
46
+ "tslib": "^2.8.1"
47
+ }
48
+ }
@@ -0,0 +1,226 @@
1
+ import * as _angular_core from '@angular/core';
2
+ import { OnInit, TemplateRef } from '@angular/core';
3
+ import * as _masterteam_delegations from '@masterteam/delegations';
4
+ import { TableAction, ColumnDef } from '@masterteam/components/table';
5
+ import { ModalService } from '@masterteam/components/modal';
6
+ import { FormControl } from '@angular/forms';
7
+ import { ModalRef } from '@masterteam/components/dialog';
8
+ import * as _masterteam_components from '@masterteam/components';
9
+ import { CrudStateBase, DynamicFormConfig } from '@masterteam/components';
10
+ import { HttpContext } from '@angular/common/http';
11
+ import * as rxjs from 'rxjs';
12
+ import { StateContext } from '@ngxs/store';
13
+
14
+ declare class Delegations {
15
+ private readonly router;
16
+ goBack(): void;
17
+ static ɵfac: _angular_core.ɵɵFactoryDeclaration<Delegations, never>;
18
+ static ɵcmp: _angular_core.ɵɵComponentDeclaration<Delegations, "mt-delegations", never, {}, {}, never, never, true, never>;
19
+ }
20
+
21
+ declare class DelegationsList implements OnInit {
22
+ statusCol: _angular_core.Signal<TemplateRef<any>>;
23
+ userCol: _angular_core.Signal<TemplateRef<any>>;
24
+ userCol2: _angular_core.Signal<TemplateRef<any>>;
25
+ daysCol: _angular_core.Signal<TemplateRef<any>>;
26
+ startDate: _angular_core.Signal<TemplateRef<any>>;
27
+ endDate: _angular_core.Signal<TemplateRef<any>>;
28
+ private readonly facade;
29
+ readonly modal: ModalService;
30
+ private readonly translocoService;
31
+ breadcrumbItems: _angular_core.WritableSignal<({
32
+ label: string;
33
+ icon: string;
34
+ routerLink: string;
35
+ } | {
36
+ label: string;
37
+ routerLink: string;
38
+ icon?: undefined;
39
+ } | {
40
+ label: string;
41
+ icon?: undefined;
42
+ routerLink?: undefined;
43
+ })[]>;
44
+ delegations: _angular_core.Signal<_masterteam_delegations.Delegation[]>;
45
+ tabs: _angular_core.WritableSignal<{
46
+ label: string;
47
+ value: string;
48
+ }[]>;
49
+ activeTab: _angular_core.WritableSignal<string>;
50
+ tableActions: _angular_core.WritableSignal<TableAction[]>;
51
+ deletingRowIds: _angular_core.WritableSignal<any[]>;
52
+ rowActions: _angular_core.WritableSignal<TableAction[]>;
53
+ tableColumns: _angular_core.WritableSignal<ColumnDef[]>;
54
+ loading: _angular_core.Signal<boolean>;
55
+ private allDelegations;
56
+ private activeDelegations;
57
+ private inactiveDelegations;
58
+ ngOnInit(): void;
59
+ addDelegationDialog(delegation?: any | null): void;
60
+ static ɵfac: _angular_core.ɵɵFactoryDeclaration<DelegationsList, never>;
61
+ static ɵcmp: _angular_core.ɵɵComponentDeclaration<DelegationsList, "mt-delegations-list", never, {}, {}, never, never, true, never>;
62
+ }
63
+
64
+ interface LoadingStateShape<L extends string = string> {
65
+ loadingActive: L[];
66
+ errors: Partial<Record<L, string>>;
67
+ }
68
+
69
+ interface DelegationUser {
70
+ id: string;
71
+ userId: string;
72
+ displayName: string;
73
+ mobile: string;
74
+ userName: string;
75
+ email: string;
76
+ photo: string;
77
+ }
78
+ interface DelegationDateTime {
79
+ displayValue: string;
80
+ actualValue: string;
81
+ }
82
+ interface Delegation {
83
+ id?: number;
84
+ delegateFrom?: DelegationUser;
85
+ delegateTo?: DelegationUser;
86
+ delegateFromDateTime?: DelegationDateTime;
87
+ delegateToDateTime?: DelegationDateTime;
88
+ delegationStatus?: boolean;
89
+ isActive?: boolean;
90
+ description?: string;
91
+ delegationDaysType?: 'fullRange' | 'specificDays';
92
+ specificDays?: number[];
93
+ }
94
+ interface DelegationFormData {
95
+ delegateTo: string;
96
+ delegateFromDateTime: string;
97
+ delegateToDateTime: string;
98
+ delegateFrom: string;
99
+ description?: string;
100
+ delegationDaysType?: 'fullRange' | 'specificDays';
101
+ specificDays?: number[];
102
+ isActive?: boolean;
103
+ }
104
+ declare enum DelegationsActionKey {
105
+ GetDelegations = "getDelegations",
106
+ AddDelegation = "addDelegation",
107
+ UpdateDelegation = "updateDelegation",
108
+ DeleteDelegation = "deleteDelegation",
109
+ GetDelegationForm = "getDelegationForm"
110
+ }
111
+ interface DelegationsStateModel extends LoadingStateShape<DelegationsActionKey> {
112
+ allDelegations: Delegation[];
113
+ selectedDelegation: Delegation | null;
114
+ }
115
+
116
+ declare class GetDelegations {
117
+ static readonly type = "[Delegations] Get Delegations";
118
+ }
119
+ declare class AddDelegation {
120
+ delegation: DelegationFormData;
121
+ static readonly type = "[Delegations] Add Delegation";
122
+ constructor(delegation: DelegationFormData);
123
+ }
124
+ declare class UpdateDelegation {
125
+ id: number;
126
+ delegation: DelegationFormData;
127
+ static readonly type = "[Delegations] Update Delegation";
128
+ constructor(id: number, delegation: DelegationFormData);
129
+ }
130
+ declare class DeleteDelegation {
131
+ id: number;
132
+ static readonly type = "[Delegations] Delete Delegation";
133
+ constructor(id: number);
134
+ }
135
+ declare class GetDelegation {
136
+ id: number;
137
+ static readonly type = "[Delegations] Get Delegation";
138
+ constructor(id: number);
139
+ }
140
+ declare class ClearSelectedDelegation {
141
+ static readonly type = "[Delegations] Clear Selected Delegation";
142
+ }
143
+
144
+ interface Response<T> {
145
+ endpoint: string;
146
+ status: number;
147
+ code: number;
148
+ locale: string;
149
+ message?: string | null;
150
+ errors?: any | null;
151
+ data: T;
152
+ cacheSession?: string;
153
+ }
154
+
155
+ declare class DelegationsState extends CrudStateBase<Delegation, DelegationsStateModel, DelegationsActionKey> {
156
+ private http;
157
+ static getAllDelegations(state: DelegationsStateModel): Delegation[];
158
+ static getSelectedDelegation(state: DelegationsStateModel): Delegation | null;
159
+ static getLoadingActive(state: DelegationsStateModel): string[];
160
+ static getErrors(state: DelegationsStateModel): Record<string, string | null>;
161
+ getDelegations(ctx: StateContext<DelegationsStateModel>): rxjs.Observable<Response<Delegation[]>>;
162
+ getDelegation(ctx: StateContext<DelegationsStateModel>, { id }: GetDelegation): rxjs.Observable<Response<Delegation>>;
163
+ addDelegation(ctx: StateContext<DelegationsStateModel>, { delegation }: AddDelegation): rxjs.Observable<_masterteam_components.Response<Delegation>>;
164
+ updateDelegation(ctx: StateContext<DelegationsStateModel>, { id, delegation }: UpdateDelegation): rxjs.Observable<_masterteam_components.Response<Delegation>>;
165
+ deleteDelegation(ctx: StateContext<DelegationsStateModel>, { id }: DeleteDelegation): rxjs.Observable<_masterteam_components.Response<void>>;
166
+ clearSelectedDelegation(ctx: StateContext<DelegationsStateModel>): void;
167
+ static ɵfac: _angular_core.ɵɵFactoryDeclaration<DelegationsState, never>;
168
+ static ɵprov: _angular_core.ɵɵInjectableDeclaration<DelegationsState>;
169
+ }
170
+
171
+ declare class DelegationsFacade {
172
+ private readonly store;
173
+ readonly allDelegations: _angular_core.Signal<_masterteam_delegations.Delegation[]>;
174
+ readonly selectedDelegation: _angular_core.Signal<_masterteam_delegations.Delegation | null>;
175
+ private readonly loadingActive;
176
+ private readonly errors;
177
+ readonly isLoadingDelegations: _angular_core.Signal<boolean>;
178
+ readonly isLoadingDelegation: _angular_core.Signal<boolean>;
179
+ readonly isAddingDelegation: _angular_core.Signal<boolean>;
180
+ readonly isUpdatingDelegation: _angular_core.Signal<boolean>;
181
+ readonly isDeletingDelegation: _angular_core.Signal<boolean>;
182
+ readonly delegationsError: _angular_core.Signal<string | null>;
183
+ readonly delegationError: _angular_core.Signal<string | null>;
184
+ readonly addDelegationError: _angular_core.Signal<string | null>;
185
+ readonly updateDelegationError: _angular_core.Signal<string | null>;
186
+ readonly deleteDelegationError: _angular_core.Signal<string | null>;
187
+ readonly activeDelegations: _angular_core.Signal<_masterteam_delegations.Delegation[]>;
188
+ readonly inactiveDelegations: _angular_core.Signal<_masterteam_delegations.Delegation[]>;
189
+ getDelegations(): rxjs.Observable<void>;
190
+ addDelegation(delegation: DelegationFormData): rxjs.Observable<void>;
191
+ updateDelegation(id: number, delegation: DelegationFormData): rxjs.Observable<void>;
192
+ deleteDelegation(id: number): rxjs.Observable<void>;
193
+ loadDelegation(id: number): rxjs.Observable<void>;
194
+ clearSelectedDelegation(): rxjs.Observable<void>;
195
+ static ɵfac: _angular_core.ɵɵFactoryDeclaration<DelegationsFacade, never>;
196
+ static ɵprov: _angular_core.ɵɵInjectableDeclaration<DelegationsFacade>;
197
+ }
198
+
199
+ declare class DelegationForm implements OnInit {
200
+ modal: ModalService;
201
+ ref: ModalRef;
202
+ delegationForEdit: _angular_core.InputSignal<Delegation | null>;
203
+ private readonly translocoService;
204
+ private readonly facade;
205
+ selectedDelegation: _angular_core.Signal<Delegation | null>;
206
+ delegationFormControl: FormControl<any>;
207
+ formValue: _angular_core.Signal<any>;
208
+ getDelegationFormLoading: _angular_core.Signal<boolean>;
209
+ isAddingDelegation: _angular_core.Signal<boolean>;
210
+ isUpdatingDelegation: _angular_core.Signal<boolean>;
211
+ context: HttpContext;
212
+ isDelegatingToSelf: _angular_core.Signal<boolean>;
213
+ specificDaysOptions: _angular_core.WritableSignal<{
214
+ label: string;
215
+ value: number;
216
+ }[]>;
217
+ delegationFormConfig: _angular_core.Signal<DynamicFormConfig>;
218
+ constructor();
219
+ ngOnInit(): void;
220
+ onSubmit(): void;
221
+ static ɵfac: _angular_core.ɵɵFactoryDeclaration<DelegationForm, never>;
222
+ static ɵcmp: _angular_core.ɵɵComponentDeclaration<DelegationForm, "mt-delegation-form", never, { "delegationForEdit": { "alias": "delegationForEdit"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
223
+ }
224
+
225
+ export { AddDelegation, ClearSelectedDelegation, DelegationForm, Delegations, DelegationsActionKey, DelegationsFacade, DelegationsList, DelegationsState, DeleteDelegation, GetDelegation, GetDelegations, UpdateDelegation };
226
+ export type { Delegation, DelegationDateTime, DelegationFormData, DelegationUser, DelegationsStateModel };