cloud-ide-core 0.0.1 → 1.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.
- package/esm2022/lib/cloud-ide-core.routes.mjs +137 -0
- package/esm2022/lib/core/general-master-management/components/general-master/general-master.component.mjs +738 -0
- package/esm2022/lib/core/general-master-management/components/general-master-type/general-master-type.component.mjs +608 -0
- package/esm2022/lib/core/general-master-management/services/general-master-type.service.mjs +203 -0
- package/esm2022/lib/core/general-master-management/services/general-master.service.mjs +166 -0
- package/esm2022/lib/core/page-management/components/page-form/page-form.component.mjs +212 -0
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/cloud-ide-core-general-master-type.component-B26auJZw.mjs +611 -0
- package/fesm2022/cloud-ide-core-general-master-type.component-B26auJZw.mjs.map +1 -0
- package/fesm2022/cloud-ide-core-general-master-type.service-Ab64Jjps.mjs +206 -0
- package/fesm2022/cloud-ide-core-general-master-type.service-Ab64Jjps.mjs.map +1 -0
- package/fesm2022/cloud-ide-core-general-master.component-B6llTVoV.mjs +903 -0
- package/fesm2022/cloud-ide-core-general-master.component-B6llTVoV.mjs.map +1 -0
- package/fesm2022/cloud-ide-core-page-form.component-CaEca3mB.mjs +215 -0
- package/fesm2022/cloud-ide-core-page-form.component-CaEca3mB.mjs.map +1 -0
- package/fesm2022/cloud-ide-core.mjs +173 -1
- package/fesm2022/cloud-ide-core.mjs.map +1 -1
- package/lib/cloud-ide-core.routes.d.ts +2 -0
- package/lib/core/general-master-management/components/general-master/general-master.component.d.ts +167 -0
- package/lib/core/general-master-management/components/general-master-type/general-master-type.component.d.ts +129 -0
- package/lib/core/general-master-management/services/general-master-type.service.d.ts +75 -0
- package/lib/core/general-master-management/services/general-master.service.d.ts +62 -0
- package/lib/core/page-management/components/page-form/page-form.component.d.ts +35 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
|
@@ -0,0 +1,212 @@
|
|
|
1
|
+
import { Component, signal, computed, inject, DestroyRef } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { Validators, ReactiveFormsModule, NonNullableFormBuilder, FormsModule } from '@angular/forms';
|
|
4
|
+
import { ActivatedRoute, Router } from '@angular/router';
|
|
5
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
6
|
+
import { PageManagementService } from '../../services/page-management.service';
|
|
7
|
+
import { AppStateHelperService } from 'cloud-ide-layout';
|
|
8
|
+
import { CideEleButtonComponent, CideInputComponent, CideSelectComponent, CideTextareaComponent, CideIconComponent, CideEleFileInputComponent, CideEleJsonEditorComponent } from 'cloud-ide-element';
|
|
9
|
+
import { generateObjectFromString } from 'cloud-ide-lms-model';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "@angular/forms";
|
|
12
|
+
export class PageFormComponent {
|
|
13
|
+
constructor() {
|
|
14
|
+
this.destroyRef = inject(DestroyRef);
|
|
15
|
+
this.pageService = inject(PageManagementService);
|
|
16
|
+
this.appState = inject(AppStateHelperService);
|
|
17
|
+
this.fb = inject(NonNullableFormBuilder);
|
|
18
|
+
this.router = inject(Router);
|
|
19
|
+
this.route = inject(ActivatedRoute);
|
|
20
|
+
this.loading = signal(false);
|
|
21
|
+
this.error = signal(null);
|
|
22
|
+
this.success = signal(null);
|
|
23
|
+
// Page information
|
|
24
|
+
this.pageId = signal(null);
|
|
25
|
+
this.isEditMode = signal(false);
|
|
26
|
+
this.pageForm = this.fb.group({
|
|
27
|
+
sypg_title: ['', [Validators.required, Validators.maxLength(100)]],
|
|
28
|
+
sypg_desc: ['', [Validators.maxLength(255)]],
|
|
29
|
+
sypg_page_code: ['', [Validators.required, Validators.maxLength(40), Validators.pattern(/^[a-zA-Z0-9_]+$/)]],
|
|
30
|
+
sypg_configuration: ['{}', [Validators.required]],
|
|
31
|
+
sypg_isactive: [true]
|
|
32
|
+
});
|
|
33
|
+
// Computed values
|
|
34
|
+
this.isFormDirty = computed(() => this.pageForm.dirty);
|
|
35
|
+
this.setupFormSubscriptions();
|
|
36
|
+
}
|
|
37
|
+
ngOnInit() {
|
|
38
|
+
// Check for page ID in query parameters
|
|
39
|
+
this.checkForPageId();
|
|
40
|
+
}
|
|
41
|
+
// Check for page ID in query parameters
|
|
42
|
+
checkForPageId() {
|
|
43
|
+
console.log('🔍 Checking for page ID in query parameters', this.route.params);
|
|
44
|
+
this.route.params.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(params => {
|
|
45
|
+
console.log('🔍 Query params:', params);
|
|
46
|
+
// Check for pageId, id, or page parameter
|
|
47
|
+
const queryParams = params['query'];
|
|
48
|
+
const queryData = generateObjectFromString(queryParams);
|
|
49
|
+
// If pageId is an object string (from generateStringFromObject), try to parse it
|
|
50
|
+
const pageId = queryData.sypg_id;
|
|
51
|
+
if (pageId) {
|
|
52
|
+
console.log('🔍 Page ID found in query params:', pageId);
|
|
53
|
+
this.pageId.set(pageId);
|
|
54
|
+
this.isEditMode.set(true);
|
|
55
|
+
this.loadPageData(pageId);
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
console.log('🆕 No page ID found - creating new page');
|
|
59
|
+
this.isEditMode.set(false);
|
|
60
|
+
this.pageId.set(null);
|
|
61
|
+
}
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
// Load page data for editing
|
|
65
|
+
loadPageData(pageId) {
|
|
66
|
+
this.loading.set(true);
|
|
67
|
+
this.error.set(null);
|
|
68
|
+
console.log('📥 Loading page data for ID:', pageId);
|
|
69
|
+
this.pageService.getPageById(pageId).pipe(takeUntilDestroyed(this.destroyRef)).subscribe({
|
|
70
|
+
next: (response) => {
|
|
71
|
+
console.log('✅ Page data loaded:', response);
|
|
72
|
+
if (response?.success && response?.data) {
|
|
73
|
+
const pageData = response.data;
|
|
74
|
+
if (pageData) {
|
|
75
|
+
this.populateFormWithPageData(pageData);
|
|
76
|
+
this.success.set('Page data loaded successfully');
|
|
77
|
+
}
|
|
78
|
+
else {
|
|
79
|
+
this.error.set('Page data not found');
|
|
80
|
+
console.error('❌ Page data not found in response:', response);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
else {
|
|
84
|
+
this.error.set('Failed to load page data');
|
|
85
|
+
console.error('❌ Page data response invalid:', response);
|
|
86
|
+
}
|
|
87
|
+
this.loading.set(false);
|
|
88
|
+
},
|
|
89
|
+
error: (err) => {
|
|
90
|
+
console.error('❌ Failed to load page data:', err);
|
|
91
|
+
let errorMessage = 'Failed to load page data.';
|
|
92
|
+
if (err?.error?.message) {
|
|
93
|
+
errorMessage = err.error.message;
|
|
94
|
+
}
|
|
95
|
+
else if (err?.message) {
|
|
96
|
+
errorMessage = err.message;
|
|
97
|
+
}
|
|
98
|
+
else if (err?.status === 404) {
|
|
99
|
+
errorMessage = 'Page not found.';
|
|
100
|
+
}
|
|
101
|
+
else if (err?.status === 500) {
|
|
102
|
+
errorMessage = 'Server error. Please try again later.';
|
|
103
|
+
}
|
|
104
|
+
this.error.set(errorMessage);
|
|
105
|
+
this.loading.set(false);
|
|
106
|
+
}
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
// Populate form with page data
|
|
110
|
+
populateFormWithPageData(pageData) {
|
|
111
|
+
try {
|
|
112
|
+
console.log('📝 Populating form with page data:', pageData);
|
|
113
|
+
const formData = {
|
|
114
|
+
sypg_title: pageData.sypg_title || '',
|
|
115
|
+
sypg_desc: pageData.sypg_desc || '',
|
|
116
|
+
sypg_page_code: pageData.sypg_page_code || '',
|
|
117
|
+
sypg_configuration: pageData.sypg_configuration ? JSON.stringify(pageData.sypg_configuration) : '{}',
|
|
118
|
+
sypg_isactive: pageData.sypg_isactive !== undefined ? pageData.sypg_isactive : true
|
|
119
|
+
};
|
|
120
|
+
// Patch the form with the page data
|
|
121
|
+
this.pageForm.patchValue(formData, { emitEvent: false });
|
|
122
|
+
console.log('✅ Form populated successfully');
|
|
123
|
+
}
|
|
124
|
+
catch (error) {
|
|
125
|
+
console.error('💥 Error populating form with page data:', error);
|
|
126
|
+
this.error.set('Error loading page data into form');
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
setupFormSubscriptions() {
|
|
130
|
+
// Watch for form changes to enable/disable save button
|
|
131
|
+
this.pageForm.valueChanges
|
|
132
|
+
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
133
|
+
.subscribe(() => {
|
|
134
|
+
// Form validation is handled by computed signals
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
// Form submission
|
|
138
|
+
savePage() {
|
|
139
|
+
if (!this.pageForm.valid) {
|
|
140
|
+
this.markFormAsTouched();
|
|
141
|
+
return;
|
|
142
|
+
}
|
|
143
|
+
const formValue = this.pageForm.getRawValue();
|
|
144
|
+
const pageData = {
|
|
145
|
+
_id: this.pageId() || '',
|
|
146
|
+
sypg_title: formValue.sypg_title,
|
|
147
|
+
sypg_desc: formValue.sypg_desc,
|
|
148
|
+
sypg_page_code: formValue.sypg_page_code,
|
|
149
|
+
sypg_configuration: formValue.sypg_configuration,
|
|
150
|
+
sypg_isactive: formValue.sypg_isactive
|
|
151
|
+
};
|
|
152
|
+
this.loading.set(true);
|
|
153
|
+
this.error.set(null);
|
|
154
|
+
this.pageService.createOrUpdatePage(pageData)
|
|
155
|
+
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
156
|
+
.subscribe({
|
|
157
|
+
next: (response) => {
|
|
158
|
+
if (response.success) {
|
|
159
|
+
this.success.set(this.isEditMode() ? 'Page updated successfully' : 'Page created successfully');
|
|
160
|
+
console.log('✅ Page saved successfully');
|
|
161
|
+
// Navigate back to page list after a short delay
|
|
162
|
+
setTimeout(() => {
|
|
163
|
+
this.router.navigate(['/control-panel/page']);
|
|
164
|
+
}, 1500);
|
|
165
|
+
}
|
|
166
|
+
else {
|
|
167
|
+
this.error.set(response.message || 'Failed to save page');
|
|
168
|
+
console.error('❌ Failed to save page:', response.message);
|
|
169
|
+
}
|
|
170
|
+
this.loading.set(false);
|
|
171
|
+
},
|
|
172
|
+
error: (error) => {
|
|
173
|
+
console.error('❌ Error saving page:', error);
|
|
174
|
+
this.error.set('Failed to save page. Please try again.');
|
|
175
|
+
this.loading.set(false);
|
|
176
|
+
}
|
|
177
|
+
});
|
|
178
|
+
}
|
|
179
|
+
// Cancel form
|
|
180
|
+
cancelForm() {
|
|
181
|
+
this.router.navigate(['/control-panel/page']);
|
|
182
|
+
}
|
|
183
|
+
// Go back to page list
|
|
184
|
+
goBack() {
|
|
185
|
+
this.router.navigate(['/control-panel/page']);
|
|
186
|
+
}
|
|
187
|
+
// Mark form as touched to trigger validation display
|
|
188
|
+
markFormAsTouched() {
|
|
189
|
+
Object.keys(this.pageForm.controls).forEach(key => {
|
|
190
|
+
const control = this.pageForm.get(key);
|
|
191
|
+
control?.markAsTouched();
|
|
192
|
+
});
|
|
193
|
+
}
|
|
194
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: PageFormComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
195
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: PageFormComponent, isStandalone: true, selector: "cide-core-page-form", ngImport: i0, template: "<div class=\"page-form-fullscreen\">\n <div class=\"page-form-container\">\n <form class=\"page-form\" [formGroup]=\"pageForm\" [class.loading]=\"loading()\" (ngSubmit)=\"savePage()\">\n \n <!-- Header Section -->\n <div class=\"form-header\">\n <h2 class=\"form-title\">{{ isEditMode() ? 'Edit Page' : 'Create Page' }}</h2>\n <p class=\"form-subtitle\">\n {{ isEditMode() ? 'Update page information and configuration' : 'Create a new page with configuration' }}\n </p>\n </div>\n\n <!-- Success and Error Messages -->\n @if (success()) {\n <div class=\"alert alert-success\">\n <svg class=\"alert-icon\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M5 13l4 4L19 7\"></path>\n </svg>\n {{ success() }}\n </div>\n }\n @if (error()) {\n <div class=\"alert alert-error\">\n <svg class=\"alert-icon\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M6 18L18 6M6 6l12 12\"></path>\n </svg>\n {{ error() }}\n </div>\n }\n\n <!-- Form Content -->\n <div class=\"form-section\">\n <div class=\"grid grid-2 gap-md lg-grid-2 md-grid-1\">\n <cide-ele-input \n id=\"sypg_title\"\n label=\"Page Title *\" \n formControlName=\"sypg_title\"\n placeholder=\"Enter page title\"\n size=\"md\">\n </cide-ele-input>\n \n <cide-ele-input \n id=\"sypg_page_code\"\n label=\"Page Code *\" \n formControlName=\"sypg_page_code\"\n placeholder=\"Enter page code (alphanumeric and underscore only)\"\n size=\"md\">\n </cide-ele-input>\n </div>\n\n <div class=\"grid grid-1 gap-md\">\n <cide-ele-textarea \n id=\"sypg_desc\"\n label=\"Page Description\" \n formControlName=\"sypg_desc\"\n placeholder=\"Enter page description\"\n [rows]=\"3\"\n size=\"md\">\n </cide-ele-textarea>\n </div>\n\n <div class=\"grid grid-1 gap-md\">\n <cide-ele-json-editor\n id=\"sypg_configuration\"\n label=\"Configuration JSON *\"\n formControlName=\"sypg_configuration\"\n placeholder='{\"key\": \"value\"}'>\n </cide-ele-json-editor>\n </div>\n\n <div class=\"grid grid-1 gap-sm\">\n <cide-ele-input\n id=\"sypg_isactive\"\n type=\"checkbox\"\n formControlName=\"sypg_isactive\"\n label=\"Active Status\"\n size=\"sm\">\n </cide-ele-input>\n </div>\n </div>\n\n <!-- Form Actions -->\n <div class=\"form-actions\">\n <button cideEleButton\n type=\"button\" \n variant=\"secondary\" \n (click)=\"cancelForm()\" \n leftIcon=\"close\"\n [disabled]=\"loading()\">\n Cancel\n </button>\n \n <button cideEleButton\n type=\"submit\" \n variant=\"primary\" \n [disabled]=\"loading() || !pageForm.valid\"\n [loading]=\"loading()\"\n leftIcon=\"save\">\n {{ isEditMode() ? 'Update Page' : 'Create Page' }}\n </button>\n </div>\n </form>\n </div>\n</div>\n", styles: [".page-form-container{background:transparent;padding:1rem;width:100%;box-sizing:border-box}.page-form{max-width:1200px;margin:0 auto;background:transparent;border:none;box-shadow:none;width:100%}.page-form.loading{opacity:.6;pointer-events:none}.form-header{background:transparent;color:#1f2937;padding:1.25rem 0;text-align:left}.form-header .form-title{font-size:1.5rem;font-weight:700;margin:0 0 .25rem;color:#1f2937}.form-header .form-subtitle{font-size:.95rem;opacity:.7;margin:0;font-weight:400;color:#6b7280}.form-section{padding:1.25rem 0;border-bottom:none;margin-bottom:1.5rem}.form-section:last-of-type{margin-bottom:0}.grid{display:grid;gap:1rem;margin-bottom:.75rem;transition:all .3s ease}.grid:last-child{margin-bottom:0}.grid.grid-1{grid-template-columns:1fr}.grid.grid-2{grid-template-columns:repeat(2,1fr)}.grid.grid-3{grid-template-columns:repeat(3,1fr)}.grid.grid-4{grid-template-columns:repeat(4,1fr)}.grid.gap-sm{gap:.5rem}.grid.gap-md{gap:1rem}.grid.gap-lg{gap:1.5rem}.grid.gap-xl{gap:2rem}@media (max-width: 1199px) and (min-width: 992px){.grid.lg-grid-1{grid-template-columns:1fr}.grid.lg-grid-2{grid-template-columns:repeat(2,1fr)}.grid.lg-grid-3{grid-template-columns:repeat(3,1fr)}}@media (max-width: 991px) and (min-width: 768px){.grid.md-grid-1{grid-template-columns:1fr}.grid.md-grid-2{grid-template-columns:repeat(2,1fr)}.grid.md-grid-3{grid-template-columns:repeat(3,1fr)}}@media (max-width: 1024px){.grid.grid-4:not([class*=lg-grid]):not([class*=md-grid]){grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.grid{gap:.75rem}.grid.grid-2:not([class*=sm-grid]):not([class*=xs-grid]),.grid.grid-3:not([class*=sm-grid]):not([class*=xs-grid]),.grid.grid-4:not([class*=sm-grid]):not([class*=xs-grid]){grid-template-columns:1fr}.grid.gap-lg{gap:1rem}.grid.gap-xl{gap:1.25rem}}@media (max-width: 480px){.grid{gap:.5rem}.grid:not([class*=xs-grid]){grid-template-columns:1fr!important}.grid.gap-md{gap:.75rem}.grid.gap-lg,.grid.gap-xl{gap:1rem}}.checkbox-field{margin:.25rem 0}.checkbox-label{display:flex;flex-direction:column;gap:.25rem;cursor:pointer;padding:.75rem 0;background:transparent;border:none;border-radius:0;transition:all .2s ease}.checkbox-label:hover{background:#667eea05}.checkbox-label .checkbox-input{width:1rem;height:1rem;accent-color:#667eea;border-radius:3px;margin-bottom:.125rem}.checkbox-label .checkbox-text{font-weight:600;color:#374151;font-size:.875rem}.checkbox-label .checkbox-description{font-size:.75rem;color:#6b7280;margin-top:.125rem}.alert{display:flex;align-items:center;gap:.5rem;padding:.75rem 0;margin:1rem 0;border-radius:0;font-weight:500;font-size:.875rem;border-left:3px solid}.alert .alert-icon{width:1rem;height:1rem;flex-shrink:0}.alert.alert-success{background:#dcfce74d;border-left-color:#22c55e;color:#166534}.alert.alert-error{background:#fef2f24d;border-left-color:#ef4444;color:#dc2626}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 0;background:#fff;border-top:1px solid #e5e7eb;margin-top:2rem;position:sticky;bottom:0}@media (max-width: 640px){.form-actions{flex-direction:column-reverse}}cide-ele-input,cide-ele-select,cide-ele-textarea,cide-ele-json-editor{transition:all .2s ease}@media (max-width: 768px){.page-form-container{padding:.75rem}.form-header{padding:1rem 0}.form-header .form-title{font-size:1.25rem}.form-header .form-subtitle{font-size:.875rem}.form-section{padding:1rem 0}.form-actions{padding:1rem 0;margin-top:1.5rem}}@media (max-width: 480px){.page-form-container{padding:.25rem}.form-header,.form-section{padding:.75rem 0}.form-actions{padding:.75rem 0;margin-top:1rem}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: FormsModule }, { kind: "component", type: CideEleButtonComponent, selector: "button[cideEleButton], a[cideEleButton]", inputs: ["label", "variant", "size", "type", "shape", "elevation", "disabled", "id", "loading", "fullWidth", "leftIcon", "rightIcon", "customClass", "tooltip", "ariaLabel", "testId", "routerLink", "routerExtras", "preventDoubleClick", "animated"], outputs: ["btnClick", "doubleClick"] }, { kind: "component", type: CideInputComponent, selector: "cide-ele-input", inputs: ["fill", "label", "labelHide", "disabled", "clearInput", "labelPlacement", "labelDir", "placeholder", "leadingIcon", "trailingIcon", "helperText", "helperTextCollapse", "hideHelperAndErrorText", "errorText", "maxlength", "minlength", "required", "autocapitalize", "autocomplete", "type", "width", "id", "ngModel", "option", "min", "max", "size"], outputs: ["ngModelChange"] }, { kind: "component", type: CideTextareaComponent, selector: "cide-ele-textarea", inputs: ["label", "labelHide", "placeholder", "helperText", "errorText", "required", "disabled", "minlength", "maxlength", "rows", "id", "ngModel", "size", "fill", "labelPlacement", "labelDir", "leadingIcon", "trailingIcon", "clearInput"], outputs: ["ngModelChange"] }, { kind: "component", type: CideEleJsonEditorComponent, selector: "cide-ele-json-editor", inputs: ["label", "helperText", "required", "disabled", "showCharacterCount", "config"], outputs: ["valueChange", "objectChange", "errorsChange", "validChange"] }] }); }
|
|
196
|
+
}
|
|
197
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: PageFormComponent, decorators: [{
|
|
198
|
+
type: Component,
|
|
199
|
+
args: [{ selector: 'cide-core-page-form', standalone: true, imports: [
|
|
200
|
+
CommonModule,
|
|
201
|
+
ReactiveFormsModule,
|
|
202
|
+
FormsModule,
|
|
203
|
+
CideEleButtonComponent,
|
|
204
|
+
CideInputComponent,
|
|
205
|
+
CideSelectComponent,
|
|
206
|
+
CideTextareaComponent,
|
|
207
|
+
CideIconComponent,
|
|
208
|
+
CideEleFileInputComponent,
|
|
209
|
+
CideEleJsonEditorComponent
|
|
210
|
+
], template: "<div class=\"page-form-fullscreen\">\n <div class=\"page-form-container\">\n <form class=\"page-form\" [formGroup]=\"pageForm\" [class.loading]=\"loading()\" (ngSubmit)=\"savePage()\">\n \n <!-- Header Section -->\n <div class=\"form-header\">\n <h2 class=\"form-title\">{{ isEditMode() ? 'Edit Page' : 'Create Page' }}</h2>\n <p class=\"form-subtitle\">\n {{ isEditMode() ? 'Update page information and configuration' : 'Create a new page with configuration' }}\n </p>\n </div>\n\n <!-- Success and Error Messages -->\n @if (success()) {\n <div class=\"alert alert-success\">\n <svg class=\"alert-icon\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M5 13l4 4L19 7\"></path>\n </svg>\n {{ success() }}\n </div>\n }\n @if (error()) {\n <div class=\"alert alert-error\">\n <svg class=\"alert-icon\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M6 18L18 6M6 6l12 12\"></path>\n </svg>\n {{ error() }}\n </div>\n }\n\n <!-- Form Content -->\n <div class=\"form-section\">\n <div class=\"grid grid-2 gap-md lg-grid-2 md-grid-1\">\n <cide-ele-input \n id=\"sypg_title\"\n label=\"Page Title *\" \n formControlName=\"sypg_title\"\n placeholder=\"Enter page title\"\n size=\"md\">\n </cide-ele-input>\n \n <cide-ele-input \n id=\"sypg_page_code\"\n label=\"Page Code *\" \n formControlName=\"sypg_page_code\"\n placeholder=\"Enter page code (alphanumeric and underscore only)\"\n size=\"md\">\n </cide-ele-input>\n </div>\n\n <div class=\"grid grid-1 gap-md\">\n <cide-ele-textarea \n id=\"sypg_desc\"\n label=\"Page Description\" \n formControlName=\"sypg_desc\"\n placeholder=\"Enter page description\"\n [rows]=\"3\"\n size=\"md\">\n </cide-ele-textarea>\n </div>\n\n <div class=\"grid grid-1 gap-md\">\n <cide-ele-json-editor\n id=\"sypg_configuration\"\n label=\"Configuration JSON *\"\n formControlName=\"sypg_configuration\"\n placeholder='{\"key\": \"value\"}'>\n </cide-ele-json-editor>\n </div>\n\n <div class=\"grid grid-1 gap-sm\">\n <cide-ele-input\n id=\"sypg_isactive\"\n type=\"checkbox\"\n formControlName=\"sypg_isactive\"\n label=\"Active Status\"\n size=\"sm\">\n </cide-ele-input>\n </div>\n </div>\n\n <!-- Form Actions -->\n <div class=\"form-actions\">\n <button cideEleButton\n type=\"button\" \n variant=\"secondary\" \n (click)=\"cancelForm()\" \n leftIcon=\"close\"\n [disabled]=\"loading()\">\n Cancel\n </button>\n \n <button cideEleButton\n type=\"submit\" \n variant=\"primary\" \n [disabled]=\"loading() || !pageForm.valid\"\n [loading]=\"loading()\"\n leftIcon=\"save\">\n {{ isEditMode() ? 'Update Page' : 'Create Page' }}\n </button>\n </div>\n </form>\n </div>\n</div>\n", styles: [".page-form-container{background:transparent;padding:1rem;width:100%;box-sizing:border-box}.page-form{max-width:1200px;margin:0 auto;background:transparent;border:none;box-shadow:none;width:100%}.page-form.loading{opacity:.6;pointer-events:none}.form-header{background:transparent;color:#1f2937;padding:1.25rem 0;text-align:left}.form-header .form-title{font-size:1.5rem;font-weight:700;margin:0 0 .25rem;color:#1f2937}.form-header .form-subtitle{font-size:.95rem;opacity:.7;margin:0;font-weight:400;color:#6b7280}.form-section{padding:1.25rem 0;border-bottom:none;margin-bottom:1.5rem}.form-section:last-of-type{margin-bottom:0}.grid{display:grid;gap:1rem;margin-bottom:.75rem;transition:all .3s ease}.grid:last-child{margin-bottom:0}.grid.grid-1{grid-template-columns:1fr}.grid.grid-2{grid-template-columns:repeat(2,1fr)}.grid.grid-3{grid-template-columns:repeat(3,1fr)}.grid.grid-4{grid-template-columns:repeat(4,1fr)}.grid.gap-sm{gap:.5rem}.grid.gap-md{gap:1rem}.grid.gap-lg{gap:1.5rem}.grid.gap-xl{gap:2rem}@media (max-width: 1199px) and (min-width: 992px){.grid.lg-grid-1{grid-template-columns:1fr}.grid.lg-grid-2{grid-template-columns:repeat(2,1fr)}.grid.lg-grid-3{grid-template-columns:repeat(3,1fr)}}@media (max-width: 991px) and (min-width: 768px){.grid.md-grid-1{grid-template-columns:1fr}.grid.md-grid-2{grid-template-columns:repeat(2,1fr)}.grid.md-grid-3{grid-template-columns:repeat(3,1fr)}}@media (max-width: 1024px){.grid.grid-4:not([class*=lg-grid]):not([class*=md-grid]){grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.grid{gap:.75rem}.grid.grid-2:not([class*=sm-grid]):not([class*=xs-grid]),.grid.grid-3:not([class*=sm-grid]):not([class*=xs-grid]),.grid.grid-4:not([class*=sm-grid]):not([class*=xs-grid]){grid-template-columns:1fr}.grid.gap-lg{gap:1rem}.grid.gap-xl{gap:1.25rem}}@media (max-width: 480px){.grid{gap:.5rem}.grid:not([class*=xs-grid]){grid-template-columns:1fr!important}.grid.gap-md{gap:.75rem}.grid.gap-lg,.grid.gap-xl{gap:1rem}}.checkbox-field{margin:.25rem 0}.checkbox-label{display:flex;flex-direction:column;gap:.25rem;cursor:pointer;padding:.75rem 0;background:transparent;border:none;border-radius:0;transition:all .2s ease}.checkbox-label:hover{background:#667eea05}.checkbox-label .checkbox-input{width:1rem;height:1rem;accent-color:#667eea;border-radius:3px;margin-bottom:.125rem}.checkbox-label .checkbox-text{font-weight:600;color:#374151;font-size:.875rem}.checkbox-label .checkbox-description{font-size:.75rem;color:#6b7280;margin-top:.125rem}.alert{display:flex;align-items:center;gap:.5rem;padding:.75rem 0;margin:1rem 0;border-radius:0;font-weight:500;font-size:.875rem;border-left:3px solid}.alert .alert-icon{width:1rem;height:1rem;flex-shrink:0}.alert.alert-success{background:#dcfce74d;border-left-color:#22c55e;color:#166534}.alert.alert-error{background:#fef2f24d;border-left-color:#ef4444;color:#dc2626}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 0;background:#fff;border-top:1px solid #e5e7eb;margin-top:2rem;position:sticky;bottom:0}@media (max-width: 640px){.form-actions{flex-direction:column-reverse}}cide-ele-input,cide-ele-select,cide-ele-textarea,cide-ele-json-editor{transition:all .2s ease}@media (max-width: 768px){.page-form-container{padding:.75rem}.form-header{padding:1rem 0}.form-header .form-title{font-size:1.25rem}.form-header .form-subtitle{font-size:.875rem}.form-section{padding:1rem 0}.form-actions{padding:1rem 0;margin-top:1.5rem}}@media (max-width: 480px){.page-form-container{padding:.25rem}.form-header,.form-section{padding:.75rem 0}.form-actions{padding:.75rem 0;margin-top:1rem}}\n"] }]
|
|
211
|
+
}], ctorParameters: () => [] });
|
|
212
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-form.component.js","sourceRoot":"","sources":["../../../../../../../../projects/cloud-ide-core/src/lib/core/page-management/components/page-form/page-form.component.ts","../../../../../../../../projects/cloud-ide-core/src/lib/core/page-management/components/page-form/page-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, signal, computed, inject, OnInit, DestroyRef } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { Validators, ReactiveFormsModule, NonNullableFormBuilder, FormsModule } from '@angular/forms';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\n\nimport { PageManagementService } from '../../services/page-management.service';\nimport { AppStateHelperService } from 'cloud-ide-layout';\nimport { CideEleButtonComponent, CideInputComponent, CideSelectComponent, CideTextareaComponent, CideIconComponent, CideEleFileInputComponent, CideEleJsonEditorComponent } from 'cloud-ide-element';\nimport { ICoreSypg, MSystemPagesInsertUpdatePayload, generateObjectFromString, systemPagesByIdControllerResponse, systemPagesInsertUpdateControllerResponse } from 'cloud-ide-lms-model';\n\n@Component({\n  selector: 'cide-core-page-form',\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    FormsModule,\n    CideEleButtonComponent,\n    CideInputComponent,\n    CideSelectComponent,\n    CideTextareaComponent,\n    CideIconComponent,\n    CideEleFileInputComponent,\n    CideEleJsonEditorComponent\n  ],\n  templateUrl: './page-form.component.html',\n  styleUrls: ['./page-form.component.scss']\n})\nexport class PageFormComponent implements OnInit {\n  private destroyRef = inject(DestroyRef);\n  private pageService = inject(PageManagementService);\n  private appState = inject(AppStateHelperService);\n  private fb = inject(NonNullableFormBuilder);\n  private router = inject(Router);\n  private route = inject(ActivatedRoute);\n\n  loading = signal(false);\n  error = signal<string | null>(null);\n  success = signal<string | null>(null);\n\n  // Page information\n  pageId = signal<string | null>(null);\n  isEditMode = signal(false);\n\n  pageForm = this.fb.group({\n    sypg_title: ['', [Validators.required, Validators.maxLength(100)]],\n    sypg_desc: ['', [Validators.maxLength(255)]],\n    sypg_page_code: ['', [Validators.required, Validators.maxLength(40), Validators.pattern(/^[a-zA-Z0-9_]+$/)]],\n    sypg_configuration: ['{}', [Validators.required]],\n    sypg_isactive: [true]\n  });\n\n  constructor() {\n    this.setupFormSubscriptions();\n  }\n\n  ngOnInit(): void {\n    // Check for page ID in query parameters\n    this.checkForPageId();\n  }\n\n\n\n  // Check for page ID in query parameters\n  private checkForPageId() {\n    console.log('🔍 Checking for page ID in query parameters', this.route.params);\n    this.route.params.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(params => {\n      console.log('🔍 Query params:', params);\n      // Check for pageId, id, or page parameter\n      const queryParams = params['query'];\n      const queryData = generateObjectFromString(queryParams);\n\n      // If pageId is an object string (from generateStringFromObject), try to parse it\n      const pageId = queryData.sypg_id;\n      if (pageId) {\n        console.log('🔍 Page ID found in query params:', pageId);\n        this.pageId.set(pageId);\n        this.isEditMode.set(true);\n        this.loadPageData(pageId);\n      } else {\n        console.log('🆕 No page ID found - creating new page');\n        this.isEditMode.set(false);\n        this.pageId.set(null);\n      }\n    });\n  }\n\n  // Load page data for editing\n  private loadPageData(pageId: string) {\n    this.loading.set(true);\n    this.error.set(null);\n\n    console.log('📥 Loading page data for ID:', pageId);\n\n    this.pageService.getPageById(pageId).pipe(\n      takeUntilDestroyed(this.destroyRef)\n    ).subscribe({\n      next: (response: systemPagesByIdControllerResponse) => {\n        console.log('✅ Page data loaded:', response);\n        \n        if (response?.success && response?.data) {\n          const pageData = response.data;\n          if (pageData) {\n            this.populateFormWithPageData(pageData);\n            this.success.set('Page data loaded successfully');\n          } else {\n            this.error.set('Page data not found');\n            console.error('❌ Page data not found in response:', response);\n          }\n        } else {\n          this.error.set('Failed to load page data');\n          console.error('❌ Page data response invalid:', response);\n        }\n        this.loading.set(false);\n      },\n      error: (err) => {\n        console.error('❌ Failed to load page data:', err);\n        \n        let errorMessage = 'Failed to load page data.';\n        \n        if (err?.error?.message) {\n          errorMessage = err.error.message;\n        } else if (err?.message) {\n          errorMessage = err.message;\n        } else if (err?.status === 404) {\n          errorMessage = 'Page not found.';\n        } else if (err?.status === 500) {\n          errorMessage = 'Server error. Please try again later.';\n        }\n        \n        this.error.set(errorMessage);\n        this.loading.set(false);\n      }\n    });\n  }\n\n  // Populate form with page data\n  private populateFormWithPageData(pageData: ICoreSypg) {\n    try {\n      console.log('📝 Populating form with page data:', pageData);\n\n      const formData = {\n        sypg_title: pageData.sypg_title || '',\n        sypg_desc: pageData.sypg_desc || '',\n        sypg_page_code: pageData.sypg_page_code || '',\n        sypg_configuration: pageData.sypg_configuration ? JSON.stringify(pageData.sypg_configuration) : '{}',\n        sypg_isactive: pageData.sypg_isactive !== undefined ? pageData.sypg_isactive : true\n      };\n\n      // Patch the form with the page data\n      this.pageForm.patchValue(formData, { emitEvent: false });\n\n      console.log('✅ Form populated successfully');\n    } catch (error) {\n      console.error('💥 Error populating form with page data:', error);\n      this.error.set('Error loading page data into form');\n    }\n  }\n\n  private setupFormSubscriptions(): void {\n    // Watch for form changes to enable/disable save button\n    this.pageForm.valueChanges\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe(() => {\n        // Form validation is handled by computed signals\n      });\n  }\n\n  // Computed values\n\n  isFormDirty = computed(() => this.pageForm.dirty);\n\n  // Form submission\n  savePage(): void {\n    if (!this.pageForm.valid) {\n      this.markFormAsTouched();\n      return;\n    }\n\n    const formValue = this.pageForm.getRawValue();\n    \n    const pageData: MSystemPagesInsertUpdatePayload = {\n      _id: this.pageId() || '',\n      sypg_title: formValue.sypg_title,\n      sypg_desc: formValue.sypg_desc,\n      sypg_page_code: formValue.sypg_page_code,\n      sypg_configuration: formValue.sypg_configuration,\n      sypg_isactive: formValue.sypg_isactive\n    };\n\n    this.loading.set(true);\n    this.error.set(null);\n\n        this.pageService.createOrUpdatePage(pageData)\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe({\n        next: (response: systemPagesInsertUpdateControllerResponse) => {\n          if (response.success) {\n            this.success.set(this.isEditMode() ? 'Page updated successfully' : 'Page created successfully');\n            console.log('✅ Page saved successfully');\n            // Navigate back to page list after a short delay\n            setTimeout(() => {\n              this.router.navigate(['/control-panel/page']);\n            }, 1500);\n          } else {\n            this.error.set(response.message || 'Failed to save page');\n            console.error('❌ Failed to save page:', response.message);\n          }\n          this.loading.set(false);\n        },\n        error: (error) => {\n          console.error('❌ Error saving page:', error);\n          this.error.set('Failed to save page. Please try again.');\n          this.loading.set(false);\n        }\n      });\n  }\n\n  // Cancel form\n  cancelForm(): void {\n    this.router.navigate(['/control-panel/page']);\n  }\n\n  // Go back to page list\n  goBack(): void {\n    this.router.navigate(['/control-panel/page']);\n  }\n\n  // Mark form as touched to trigger validation display\n  private markFormAsTouched(): void {\n    Object.keys(this.pageForm.controls).forEach(key => {\n      const control = this.pageForm.get(key);\n      control?.markAsTouched();\n    });\n  }\n}\n","<div class=\"page-form-fullscreen\">\n  <div class=\"page-form-container\">\n    <form class=\"page-form\" [formGroup]=\"pageForm\" [class.loading]=\"loading()\" (ngSubmit)=\"savePage()\">\n      \n      <!-- Header Section -->\n      <div class=\"form-header\">\n        <h2 class=\"form-title\">{{ isEditMode() ? 'Edit Page' : 'Create Page' }}</h2>\n        <p class=\"form-subtitle\">\n          {{ isEditMode() ? 'Update page information and configuration' : 'Create a new page with configuration' }}\n        </p>\n      </div>\n\n      <!-- Success and Error Messages -->\n      @if (success()) {\n        <div class=\"alert alert-success\">\n          <svg class=\"alert-icon\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n            <path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M5 13l4 4L19 7\"></path>\n          </svg>\n          {{ success() }}\n        </div>\n      }\n      @if (error()) {\n        <div class=\"alert alert-error\">\n          <svg class=\"alert-icon\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n            <path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M6 18L18 6M6 6l12 12\"></path>\n          </svg>\n          {{ error() }}\n        </div>\n      }\n\n      <!-- Form Content -->\n      <div class=\"form-section\">\n        <div class=\"grid grid-2 gap-md lg-grid-2 md-grid-1\">\n          <cide-ele-input \n            id=\"sypg_title\"\n            label=\"Page Title *\" \n            formControlName=\"sypg_title\"\n            placeholder=\"Enter page title\"\n            size=\"md\">\n          </cide-ele-input>\n          \n          <cide-ele-input \n            id=\"sypg_page_code\"\n            label=\"Page Code *\" \n            formControlName=\"sypg_page_code\"\n            placeholder=\"Enter page code (alphanumeric and underscore only)\"\n            size=\"md\">\n          </cide-ele-input>\n        </div>\n\n        <div class=\"grid grid-1 gap-md\">\n          <cide-ele-textarea \n            id=\"sypg_desc\"\n            label=\"Page Description\" \n            formControlName=\"sypg_desc\"\n            placeholder=\"Enter page description\"\n            [rows]=\"3\"\n            size=\"md\">\n          </cide-ele-textarea>\n        </div>\n\n        <div class=\"grid grid-1 gap-md\">\n          <cide-ele-json-editor\n            id=\"sypg_configuration\"\n            label=\"Configuration JSON *\"\n            formControlName=\"sypg_configuration\"\n            placeholder='{\"key\": \"value\"}'>\n          </cide-ele-json-editor>\n        </div>\n\n        <div class=\"grid grid-1 gap-sm\">\n          <cide-ele-input\n            id=\"sypg_isactive\"\n            type=\"checkbox\"\n            formControlName=\"sypg_isactive\"\n            label=\"Active Status\"\n            size=\"sm\">\n          </cide-ele-input>\n        </div>\n      </div>\n\n      <!-- Form Actions -->\n      <div class=\"form-actions\">\n        <button cideEleButton\n          type=\"button\" \n          variant=\"secondary\" \n          (click)=\"cancelForm()\" \n          leftIcon=\"close\"\n          [disabled]=\"loading()\">\n          Cancel\n        </button>\n        \n        <button cideEleButton\n          type=\"submit\" \n          variant=\"primary\" \n          [disabled]=\"loading() || !pageForm.valid\"\n          [loading]=\"loading()\"\n          leftIcon=\"save\">\n          {{ isEditMode() ? 'Update Page' : 'Create Page' }}\n        </button>\n      </div>\n    </form>\n  </div>\n</div>\n"]}
|
package/esm2022/public-api.mjs
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
/*
|
|
2
2
|
* Public API Surface of cloud-ide-core
|
|
3
3
|
*/
|
|
4
|
+
export * from './lib/cloud-ide-core.routes';
|
|
4
5
|
export * from './lib/cloud-ide-core.service';
|
|
5
6
|
export * from './lib/cloud-ide-core.component';
|
|
6
7
|
// Menu Management Module
|
|
@@ -13,4 +14,4 @@ export * from './lib/core/designation-management';
|
|
|
13
14
|
export * from './lib/core/grade-level-management';
|
|
14
15
|
// Page Management Components
|
|
15
16
|
export * from './lib/core/page-management';
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2Nsb3VkLWlkZS1jb3JlL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBQ0gsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsZ0NBQWdDLENBQUM7QUFFL0MseUJBQXlCO0FBQ3pCLGNBQWMsNEJBQTRCLENBQUM7QUFFM0MsK0JBQStCO0FBQy9CLGNBQWMsa0NBQWtDLENBQUM7QUFFakQsZ0NBQWdDO0FBQ2hDLGNBQWMsbUNBQW1DLENBQUM7QUFFbEQsZ0NBQWdDO0FBQ2hDLGNBQWMsbUNBQW1DLENBQUM7QUFFbEQsNkJBQTZCO0FBQzdCLGNBQWMsNEJBQTRCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIGNsb3VkLWlkZS1jb3JlXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vbGliL2Nsb3VkLWlkZS1jb3JlLnJvdXRlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jbG91ZC1pZGUtY29yZS5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Nsb3VkLWlkZS1jb3JlLmNvbXBvbmVudCc7XG5cbi8vIE1lbnUgTWFuYWdlbWVudCBNb2R1bGVcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvcmUvbWVudS1tYW5hZ2VtZW50JztcblxuLy8gRGVwYXJ0bWVudCBNYW5hZ2VtZW50IE1vZHVsZVxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29yZS9kZXBhcnRtZW50LW1hbmFnZW1lbnQnO1xuXG4vLyBEZXNpZ25hdGlvbiBNYW5hZ2VtZW50IE1vZHVsZVxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29yZS9kZXNpZ25hdGlvbi1tYW5hZ2VtZW50JztcblxuLy8gR3JhZGUgTGV2ZWwgTWFuYWdlbWVudCBNb2R1bGVcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvcmUvZ3JhZGUtbGV2ZWwtbWFuYWdlbWVudCc7XG5cbi8vIFBhZ2UgTWFuYWdlbWVudCBDb21wb25lbnRzXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb3JlL3BhZ2UtbWFuYWdlbWVudCc7XG4iXX0=
|