cloud-ide-core 1.0.1 → 1.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +49 -10
- package/fesm2022/{cloud-ide-core-general-master-type.component-B26auJZw.mjs → cloud-ide-core-general-master-type.component-BNYoP_bS.mjs} +132 -134
- package/fesm2022/{cloud-ide-core-general-master-type.component-B26auJZw.mjs.map → cloud-ide-core-general-master-type.component-BNYoP_bS.mjs.map} +1 -1
- package/fesm2022/{cloud-ide-core-general-master-type.service-Ab64Jjps.mjs → cloud-ide-core-general-master-type.service-8JWTVijZ.mjs} +7 -7
- package/fesm2022/{cloud-ide-core-general-master-type.service-Ab64Jjps.mjs.map → cloud-ide-core-general-master-type.service-8JWTVijZ.mjs.map} +1 -1
- package/fesm2022/{cloud-ide-core-general-master.component-B6llTVoV.mjs → cloud-ide-core-general-master.component-CFGGHinl.mjs} +152 -154
- package/fesm2022/{cloud-ide-core-general-master.component-B6llTVoV.mjs.map → cloud-ide-core-general-master.component-CFGGHinl.mjs.map} +1 -1
- package/fesm2022/{cloud-ide-core-page-form.component-CaEca3mB.mjs → cloud-ide-core-page-form.component-vfE-LkTS.mjs} +25 -25
- package/fesm2022/{cloud-ide-core-page-form.component-CaEca3mB.mjs.map → cloud-ide-core-page-form.component-vfE-LkTS.mjs.map} +1 -1
- package/fesm2022/cloud-ide-core.mjs +1113 -1110
- package/fesm2022/cloud-ide-core.mjs.map +1 -1
- package/index.d.ts +1736 -3
- package/package.json +3 -5
- package/esm2022/cloud-ide-core.mjs +0 -5
- package/esm2022/lib/cloud-ide-core.component.mjs +0 -19
- package/esm2022/lib/cloud-ide-core.routes.mjs +0 -137
- package/esm2022/lib/cloud-ide-core.service.mjs +0 -14
- package/esm2022/lib/core/department-management/components/department-list/department-list.component.mjs +0 -768
- package/esm2022/lib/core/department-management/index.mjs +0 -5
- package/esm2022/lib/core/department-management/services/department-management.service.mjs +0 -187
- package/esm2022/lib/core/designation-management/components/designation-list/designation-list.component.mjs +0 -1122
- package/esm2022/lib/core/designation-management/index.mjs +0 -5
- package/esm2022/lib/core/designation-management/services/designation-management.service.mjs +0 -194
- package/esm2022/lib/core/general-master-management/components/general-master/general-master.component.mjs +0 -738
- package/esm2022/lib/core/general-master-management/components/general-master-type/general-master-type.component.mjs +0 -608
- package/esm2022/lib/core/general-master-management/services/general-master-type.service.mjs +0 -203
- package/esm2022/lib/core/general-master-management/services/general-master.service.mjs +0 -166
- package/esm2022/lib/core/grade-level-management/components/grade-level-list/grade-level-list.component.mjs +0 -794
- package/esm2022/lib/core/grade-level-management/index.mjs +0 -5
- package/esm2022/lib/core/grade-level-management/services/grade-level-management.service.mjs +0 -172
- package/esm2022/lib/core/menu-management/components/menu-list/menu-list.component.mjs +0 -1135
- package/esm2022/lib/core/menu-management/index.mjs +0 -10
- package/esm2022/lib/core/menu-management/interfaces/menu-item.interface.mjs +0 -11
- package/esm2022/lib/core/menu-management/mock-data/menu-items.json +0 -311
- package/esm2022/lib/core/menu-management/services/menu-management.service.mjs +0 -230
- package/esm2022/lib/core/page-management/components/page-controls/page-controls.component.mjs +0 -483
- package/esm2022/lib/core/page-management/components/page-form/page-form.component.mjs +0 -212
- package/esm2022/lib/core/page-management/components/page-list/page-list.component.mjs +0 -393
- package/esm2022/lib/core/page-management/components/page-theme/page-theme.component.mjs +0 -767
- package/esm2022/lib/core/page-management/index.mjs +0 -10
- package/esm2022/lib/core/page-management/services/page-controls.service.mjs +0 -136
- package/esm2022/lib/core/page-management/services/page-management.service.mjs +0 -98
- package/esm2022/lib/core/page-management/services/page-theme.service.mjs +0 -107
- package/esm2022/public-api.mjs +0 -17
- package/lib/cloud-ide-core.component.d.ts +0 -5
- package/lib/cloud-ide-core.routes.d.ts +0 -2
- package/lib/cloud-ide-core.service.d.ts +0 -6
- package/lib/core/department-management/components/department-list/department-list.component.d.ts +0 -178
- package/lib/core/department-management/index.d.ts +0 -2
- package/lib/core/department-management/services/department-management.service.d.ts +0 -68
- package/lib/core/designation-management/components/designation-list/designation-list.component.d.ts +0 -242
- package/lib/core/designation-management/index.d.ts +0 -2
- package/lib/core/designation-management/services/designation-management.service.d.ts +0 -69
- package/lib/core/general-master-management/components/general-master/general-master.component.d.ts +0 -167
- package/lib/core/general-master-management/components/general-master-type/general-master-type.component.d.ts +0 -129
- package/lib/core/general-master-management/services/general-master-type.service.d.ts +0 -75
- package/lib/core/general-master-management/services/general-master.service.d.ts +0 -62
- package/lib/core/grade-level-management/components/grade-level-list/grade-level-list.component.d.ts +0 -199
- package/lib/core/grade-level-management/index.d.ts +0 -2
- package/lib/core/grade-level-management/services/grade-level-management.service.d.ts +0 -69
- package/lib/core/menu-management/components/menu-list/menu-list.component.d.ts +0 -278
- package/lib/core/menu-management/index.d.ts +0 -3
- package/lib/core/menu-management/interfaces/menu-item.interface.d.ts +0 -30
- package/lib/core/menu-management/services/menu-management.service.d.ts +0 -85
- package/lib/core/page-management/components/page-controls/page-controls.component.d.ts +0 -126
- package/lib/core/page-management/components/page-form/page-form.component.d.ts +0 -35
- package/lib/core/page-management/components/page-list/page-list.component.d.ts +0 -91
- package/lib/core/page-management/components/page-theme/page-theme.component.d.ts +0 -189
- package/lib/core/page-management/index.d.ts +0 -6
- package/lib/core/page-management/services/page-controls.service.d.ts +0 -54
- package/lib/core/page-management/services/page-management.service.d.ts +0 -42
- package/lib/core/page-management/services/page-theme.service.d.ts +0 -43
- package/public-api.d.ts +0 -8
|
@@ -1,767 +0,0 @@
|
|
|
1
|
-
import { Component, signal, computed, viewChild, DestroyRef, inject } 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 { PageThemeService } from '../../services/page-theme.service';
|
|
7
|
-
import { AppStateHelperService } from 'cloud-ide-layout';
|
|
8
|
-
import { CideEleButtonComponent, CideEleDataGridComponent, CideIconComponent, CideInputComponent, CideSelectComponent, CideTextareaComponent, CideEleDropdownComponent, CideEleJsonEditorComponent, CideSelectOptionComponent } 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/common";
|
|
12
|
-
import * as i2 from "@angular/forms";
|
|
13
|
-
export class PageThemeComponent {
|
|
14
|
-
constructor() {
|
|
15
|
-
// Dependency injection
|
|
16
|
-
this.destroyRef = inject(DestroyRef);
|
|
17
|
-
this.themeService = inject(PageThemeService);
|
|
18
|
-
this.appState = inject(AppStateHelperService);
|
|
19
|
-
this.fb = inject(NonNullableFormBuilder);
|
|
20
|
-
this.router = inject(Router);
|
|
21
|
-
this.route = inject(ActivatedRoute);
|
|
22
|
-
// Modern ViewChild signals for template renderers (Angular 20 approach)
|
|
23
|
-
this.themeDetailsRendererTemplate = viewChild.required('themeDetailsRendererTemplate');
|
|
24
|
-
this.themeStatusRendererTemplate = viewChild.required('themeStatusRendererTemplate');
|
|
25
|
-
this.actionsDropdownRendererTemplate = viewChild.required('actionsDropdownRendererTemplate');
|
|
26
|
-
// Make Math available in template
|
|
27
|
-
this.Math = Math;
|
|
28
|
-
// Signals for reactive state management
|
|
29
|
-
this.themes = signal([]);
|
|
30
|
-
this.loading = signal(false);
|
|
31
|
-
this.error = signal(null);
|
|
32
|
-
this.selectedItems = signal([]);
|
|
33
|
-
this.searchTerm = signal('');
|
|
34
|
-
// Derived list filtered by searchTerm
|
|
35
|
-
this.filteredThemes = computed(() => {
|
|
36
|
-
const q = (this.searchTerm() || '').toLowerCase().trim();
|
|
37
|
-
const items = this.themes() || [];
|
|
38
|
-
if (!q)
|
|
39
|
-
return items;
|
|
40
|
-
return items.filter(t => {
|
|
41
|
-
const title = (t.sytm_title || '').toLowerCase();
|
|
42
|
-
const code = (t.sytm_theme_code || '').toLowerCase();
|
|
43
|
-
const desc = (t.sytm_desc || '').toLowerCase();
|
|
44
|
-
return title.includes(q) || code.includes(q) || desc.includes(q);
|
|
45
|
-
});
|
|
46
|
-
});
|
|
47
|
-
// Page information
|
|
48
|
-
this.pageId = signal('');
|
|
49
|
-
this.pageTitle = signal('');
|
|
50
|
-
// Form state
|
|
51
|
-
this.isEditMode = signal(false);
|
|
52
|
-
this.editingThemeId = signal(null);
|
|
53
|
-
this.retrievedTheme = signal(null);
|
|
54
|
-
// Pagination signals
|
|
55
|
-
this.currentPage = signal(1);
|
|
56
|
-
this.pageSize = signal(10);
|
|
57
|
-
this.totalItems = signal(0);
|
|
58
|
-
// Modern reactive forms with signals
|
|
59
|
-
this.themeForm = this.fb.group({
|
|
60
|
-
sytm_title: ['', [Validators.required]],
|
|
61
|
-
sytm_desc: [''],
|
|
62
|
-
sytm_theme_code: ['', [Validators.required]],
|
|
63
|
-
sytm_preview_id_fm: [''],
|
|
64
|
-
sytm_sub_title: [''],
|
|
65
|
-
sytm_configuration: ['{}'],
|
|
66
|
-
sytm_entity_id_syen: [''],
|
|
67
|
-
sytm_isselected: [false],
|
|
68
|
-
sytm_layout: this.fb.group({
|
|
69
|
-
sytm_layout_sidebar: this.fb.group({ status: [true] }),
|
|
70
|
-
sytm_layout_header: this.fb.group({ status: [true] }),
|
|
71
|
-
sytm_layout_footer: this.fb.group({ status: [false] }),
|
|
72
|
-
sytm_layout_breadcrumb: this.fb.group({ status: [true] }),
|
|
73
|
-
sytm_layout_console: this.fb.group({ status: [false] }),
|
|
74
|
-
sytm_layout_request: this.fb.group({ status: [false] }),
|
|
75
|
-
sytm_layout_drawer: this.fb.array([])
|
|
76
|
-
}),
|
|
77
|
-
sytm_isactive: [true]
|
|
78
|
-
});
|
|
79
|
-
// Computed values
|
|
80
|
-
this.isFormDirty = computed(() => this.themeForm.dirty);
|
|
81
|
-
// Multi-select options for layout sections
|
|
82
|
-
this.layoutOptions = [
|
|
83
|
-
{ value: 'sidebar', label: 'Sidebar' },
|
|
84
|
-
{ value: 'header', label: 'Header' },
|
|
85
|
-
{ value: 'footer', label: 'Footer' },
|
|
86
|
-
{ value: 'breadcrumb', label: 'Breadcrumb' },
|
|
87
|
-
{ value: 'console', label: 'Console' },
|
|
88
|
-
{ value: 'request', label: 'Request' }
|
|
89
|
-
];
|
|
90
|
-
// Grid configuration signal
|
|
91
|
-
this.gridConfig = signal({
|
|
92
|
-
id: 'theme-list-grid',
|
|
93
|
-
title: '',
|
|
94
|
-
subtitle: '',
|
|
95
|
-
columns: [
|
|
96
|
-
{
|
|
97
|
-
key: 'details',
|
|
98
|
-
header: 'Theme Details',
|
|
99
|
-
type: 'custom',
|
|
100
|
-
width: 'auto',
|
|
101
|
-
truncate: true,
|
|
102
|
-
align: 'left',
|
|
103
|
-
renderer: 'themeDetailsRenderer'
|
|
104
|
-
},
|
|
105
|
-
{
|
|
106
|
-
key: 'sytm_theme_code',
|
|
107
|
-
header: 'Theme Code',
|
|
108
|
-
type: 'text',
|
|
109
|
-
width: '150px',
|
|
110
|
-
truncate: true,
|
|
111
|
-
align: 'left'
|
|
112
|
-
},
|
|
113
|
-
{
|
|
114
|
-
key: 'sytm_isactive',
|
|
115
|
-
header: 'Status',
|
|
116
|
-
type: 'custom',
|
|
117
|
-
width: '100px',
|
|
118
|
-
truncate: false,
|
|
119
|
-
align: 'center',
|
|
120
|
-
renderer: 'themeStatusRenderer'
|
|
121
|
-
},
|
|
122
|
-
{
|
|
123
|
-
key: 'actions',
|
|
124
|
-
header: '',
|
|
125
|
-
type: 'custom',
|
|
126
|
-
width: '120px',
|
|
127
|
-
truncate: false,
|
|
128
|
-
align: 'center',
|
|
129
|
-
renderer: 'actionsDropdownRenderer'
|
|
130
|
-
}
|
|
131
|
-
],
|
|
132
|
-
data: [],
|
|
133
|
-
trackBy: '_id',
|
|
134
|
-
pagination: {
|
|
135
|
-
enabled: true,
|
|
136
|
-
pageSize: 10,
|
|
137
|
-
pageSizeOptions: [10, 25, 50, 100],
|
|
138
|
-
showQuickJump: true,
|
|
139
|
-
showPageInfo: true,
|
|
140
|
-
showRefresh: true
|
|
141
|
-
},
|
|
142
|
-
search: {
|
|
143
|
-
enabled: true,
|
|
144
|
-
placeholder: 'Search themes...',
|
|
145
|
-
searchableColumns: ['sytm_title', 'sytm_desc', 'sytm_theme_code'],
|
|
146
|
-
debounceMs: 300
|
|
147
|
-
},
|
|
148
|
-
loading: {
|
|
149
|
-
useDefer: true,
|
|
150
|
-
skeletonRows: 5,
|
|
151
|
-
showOverlay: false
|
|
152
|
-
},
|
|
153
|
-
scroll: {
|
|
154
|
-
enabled: true,
|
|
155
|
-
maxHeight: '',
|
|
156
|
-
minHeight: '',
|
|
157
|
-
stickyHeader: true,
|
|
158
|
-
virtualScroll: false,
|
|
159
|
-
rowHeight: 50
|
|
160
|
-
},
|
|
161
|
-
responsive: true,
|
|
162
|
-
striped: false,
|
|
163
|
-
bordered: true,
|
|
164
|
-
compact: false,
|
|
165
|
-
tableClass: 'tw-table-fixed tw-w-full tw-rounded-none'
|
|
166
|
-
});
|
|
167
|
-
// Action handlers for grid
|
|
168
|
-
this.actionHandlers = {
|
|
169
|
-
onEdit: (item) => this.editTheme(item),
|
|
170
|
-
onDelete: (item) => this.deleteTheme(item),
|
|
171
|
-
onToggleStatus: (item) => this.toggleThemeStatus(item)
|
|
172
|
-
};
|
|
173
|
-
// ===== Drawer (sytm_layout_drawer) helpers =====
|
|
174
|
-
this.drawerConfigOptions = [
|
|
175
|
-
{ value: 'drawer_notes', label: 'Drawer Notes' },
|
|
176
|
-
{ value: 'drawer_theme', label: 'Drawer Theme' }
|
|
177
|
-
];
|
|
178
|
-
}
|
|
179
|
-
// Helper to resolve preview image URL safely
|
|
180
|
-
getPreviewUrl(theme) {
|
|
181
|
-
const id = theme?.sytm_preview_id_fm || '';
|
|
182
|
-
if (!id)
|
|
183
|
-
return '';
|
|
184
|
-
const svcUnknown = this.themeService;
|
|
185
|
-
const hasGetPreviewUrl = (svc) => typeof svc === 'object' && svc !== null &&
|
|
186
|
-
'getPreviewUrl' in svc &&
|
|
187
|
-
typeof svc['getPreviewUrl'] === 'function';
|
|
188
|
-
if (hasGetPreviewUrl(svcUnknown)) {
|
|
189
|
-
return svcUnknown.getPreviewUrl(id);
|
|
190
|
-
}
|
|
191
|
-
return '';
|
|
192
|
-
}
|
|
193
|
-
// Input handler to avoid $any casts in template
|
|
194
|
-
onGallerySearchInput(event) {
|
|
195
|
-
const target = event.target;
|
|
196
|
-
this.searchTerm.set(target?.value ?? '');
|
|
197
|
-
}
|
|
198
|
-
// Read enabled selections from form values
|
|
199
|
-
enabledLayoutSelections() {
|
|
200
|
-
const layout = this.themeForm.get('sytm_layout');
|
|
201
|
-
if (!layout)
|
|
202
|
-
return [];
|
|
203
|
-
const selections = [];
|
|
204
|
-
const getBool = (path) => Boolean(this.themeForm.get(path)?.value);
|
|
205
|
-
if (getBool('sytm_layout.sytm_layout_sidebar.status'))
|
|
206
|
-
selections.push('sidebar');
|
|
207
|
-
if (getBool('sytm_layout.sytm_layout_header.status'))
|
|
208
|
-
selections.push('header');
|
|
209
|
-
if (getBool('sytm_layout.sytm_layout_footer.status'))
|
|
210
|
-
selections.push('footer');
|
|
211
|
-
if (getBool('sytm_layout.sytm_layout_breadcrumb.status'))
|
|
212
|
-
selections.push('breadcrumb');
|
|
213
|
-
if (getBool('sytm_layout.sytm_layout_console.status'))
|
|
214
|
-
selections.push('console');
|
|
215
|
-
if (getBool('sytm_layout.sytm_layout_request.status'))
|
|
216
|
-
selections.push('request');
|
|
217
|
-
return selections;
|
|
218
|
-
}
|
|
219
|
-
// Update form booleans from multi-select change
|
|
220
|
-
onEnabledLayoutChange(values) {
|
|
221
|
-
const setBool = (path, val) => this.themeForm.get(path)?.setValue(val);
|
|
222
|
-
const selected = new Set(values);
|
|
223
|
-
setBool('sytm_layout.sytm_layout_sidebar.status', selected.has('sidebar'));
|
|
224
|
-
setBool('sytm_layout.sytm_layout_header.status', selected.has('header'));
|
|
225
|
-
setBool('sytm_layout.sytm_layout_footer.status', selected.has('footer'));
|
|
226
|
-
setBool('sytm_layout.sytm_layout_breadcrumb.status', selected.has('breadcrumb'));
|
|
227
|
-
setBool('sytm_layout.sytm_layout_console.status', selected.has('console'));
|
|
228
|
-
setBool('sytm_layout.sytm_layout_request.status', selected.has('request'));
|
|
229
|
-
}
|
|
230
|
-
ngOnInit() {
|
|
231
|
-
this.initializeComponent();
|
|
232
|
-
}
|
|
233
|
-
/**
|
|
234
|
-
* Initialize component
|
|
235
|
-
*/
|
|
236
|
-
initializeComponent() {
|
|
237
|
-
// Get page information from route
|
|
238
|
-
this.route.params.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(params => {
|
|
239
|
-
console.log('🔍 Query params:', params);
|
|
240
|
-
const queryParams = params['query'];
|
|
241
|
-
const queryData = generateObjectFromString(queryParams);
|
|
242
|
-
this.pageId.set(queryData?.sypg_id || '');
|
|
243
|
-
this.pageTitle.set(queryData?.sypg_title || '');
|
|
244
|
-
if (this.pageId()) {
|
|
245
|
-
this.loadThemes();
|
|
246
|
-
this.setupFormSubscriptions();
|
|
247
|
-
}
|
|
248
|
-
else {
|
|
249
|
-
this.error.set('No page ID provided');
|
|
250
|
-
}
|
|
251
|
-
});
|
|
252
|
-
}
|
|
253
|
-
/**
|
|
254
|
-
* Load themes from API
|
|
255
|
-
*/
|
|
256
|
-
loadThemes() {
|
|
257
|
-
this.loading.set(true);
|
|
258
|
-
this.error.set(null);
|
|
259
|
-
const request = {
|
|
260
|
-
sytm_page_id_sypg: this.pageId()
|
|
261
|
-
};
|
|
262
|
-
this.themeService.getThemeList(request)
|
|
263
|
-
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
264
|
-
.subscribe({
|
|
265
|
-
next: (response) => {
|
|
266
|
-
if (response.success) {
|
|
267
|
-
this.themes.set(response.data || []);
|
|
268
|
-
this.totalItems.set(response.total || 0);
|
|
269
|
-
this.updateGridData();
|
|
270
|
-
}
|
|
271
|
-
else {
|
|
272
|
-
this.error.set(response.message || 'Failed to load themes');
|
|
273
|
-
}
|
|
274
|
-
this.loading.set(false);
|
|
275
|
-
},
|
|
276
|
-
error: (error) => {
|
|
277
|
-
console.error('Error loading themes:', error);
|
|
278
|
-
this.error.set('Failed to load themes. Please try again.');
|
|
279
|
-
this.loading.set(false);
|
|
280
|
-
}
|
|
281
|
-
});
|
|
282
|
-
}
|
|
283
|
-
/**
|
|
284
|
-
* Setup form subscriptions
|
|
285
|
-
*/
|
|
286
|
-
setupFormSubscriptions() {
|
|
287
|
-
// Watch for form changes to enable/disable save button
|
|
288
|
-
this.themeForm.valueChanges
|
|
289
|
-
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
290
|
-
.subscribe(() => {
|
|
291
|
-
// Form validation is handled by computed signals
|
|
292
|
-
});
|
|
293
|
-
}
|
|
294
|
-
/**
|
|
295
|
-
* Update grid data
|
|
296
|
-
*/
|
|
297
|
-
updateGridData() {
|
|
298
|
-
this.gridConfig.update(config => ({
|
|
299
|
-
...config,
|
|
300
|
-
data: this.themes()
|
|
301
|
-
}));
|
|
302
|
-
}
|
|
303
|
-
/**
|
|
304
|
-
* Get custom renderers for grid
|
|
305
|
-
*/
|
|
306
|
-
/**
|
|
307
|
-
* Get template renderers for grid
|
|
308
|
-
*/
|
|
309
|
-
getTemplateRenderers() {
|
|
310
|
-
return {
|
|
311
|
-
themeDetailsRenderer: this.themeDetailsRendererTemplate(),
|
|
312
|
-
themeStatusRenderer: this.themeStatusRendererTemplate(),
|
|
313
|
-
actionsDropdownRenderer: this.actionsDropdownRendererTemplate()
|
|
314
|
-
};
|
|
315
|
-
}
|
|
316
|
-
/**
|
|
317
|
-
* Handle grid events
|
|
318
|
-
*/
|
|
319
|
-
onGridEvent(event) {
|
|
320
|
-
switch (event.type) {
|
|
321
|
-
case 'pageChange':
|
|
322
|
-
if (event.data && typeof event.data === 'object' && 'pageIndex' in event.data && 'pageSize' in event.data) {
|
|
323
|
-
this.currentPage.set(event.data['pageIndex']);
|
|
324
|
-
this.pageSize.set(event.data['pageSize']);
|
|
325
|
-
this.loadThemes();
|
|
326
|
-
}
|
|
327
|
-
break;
|
|
328
|
-
case 'search':
|
|
329
|
-
if (event.data && typeof event.data === 'string') {
|
|
330
|
-
this.searchTerm.set(event.data);
|
|
331
|
-
this.currentPage.set(1);
|
|
332
|
-
this.loadThemes();
|
|
333
|
-
}
|
|
334
|
-
break;
|
|
335
|
-
case 'refresh':
|
|
336
|
-
this.loadThemes();
|
|
337
|
-
break;
|
|
338
|
-
case 'action':
|
|
339
|
-
// Handle action events if needed
|
|
340
|
-
console.log('Action event:', event);
|
|
341
|
-
break;
|
|
342
|
-
case 'rowClick':
|
|
343
|
-
// Handle row click events if needed
|
|
344
|
-
console.log('Row click event:', event);
|
|
345
|
-
break;
|
|
346
|
-
case 'sort':
|
|
347
|
-
// Handle sort events if needed
|
|
348
|
-
console.log('Sort event:', event);
|
|
349
|
-
break;
|
|
350
|
-
case 'export':
|
|
351
|
-
// Handle export events if needed
|
|
352
|
-
console.log('Export event:', event);
|
|
353
|
-
break;
|
|
354
|
-
case 'rowReorder':
|
|
355
|
-
// Handle row reorder events if needed
|
|
356
|
-
console.log('Row reorder event:', event);
|
|
357
|
-
break;
|
|
358
|
-
}
|
|
359
|
-
}
|
|
360
|
-
/**
|
|
361
|
-
* Create new theme
|
|
362
|
-
*/
|
|
363
|
-
createTheme() {
|
|
364
|
-
if (!this.themeForm.valid) {
|
|
365
|
-
this.markFormAsTouched();
|
|
366
|
-
return;
|
|
367
|
-
}
|
|
368
|
-
const formValue = this.themeForm.getRawValue();
|
|
369
|
-
const newTheme = {
|
|
370
|
-
sytm_title: formValue.sytm_title,
|
|
371
|
-
sytm_desc: formValue.sytm_desc,
|
|
372
|
-
sytm_theme_code: formValue.sytm_theme_code,
|
|
373
|
-
sytm_preview_id_fm: formValue.sytm_preview_id_fm,
|
|
374
|
-
sytm_page_id_sypg: this.pageId(),
|
|
375
|
-
sytm_configuration: JSON.parse(formValue.sytm_configuration),
|
|
376
|
-
sytm_sub_title: formValue.sytm_sub_title,
|
|
377
|
-
sytm_entity_id_syen: formValue.sytm_entity_id_syen || this.appState.getActiveEntityId(),
|
|
378
|
-
sytm_isselected: Boolean(formValue.sytm_isselected),
|
|
379
|
-
sytm_layout: {
|
|
380
|
-
sytm_layout_sidebar: { status: Boolean(formValue.sytm_layout.sytm_layout_sidebar.status) },
|
|
381
|
-
sytm_layout_header: { status: Boolean(formValue.sytm_layout.sytm_layout_header.status) },
|
|
382
|
-
sytm_layout_footer: { status: Boolean(formValue.sytm_layout.sytm_layout_footer.status) },
|
|
383
|
-
sytm_layout_breadcrumb: { status: Boolean(formValue.sytm_layout.sytm_layout_breadcrumb.status) },
|
|
384
|
-
sytm_layout_console: { status: Boolean(formValue.sytm_layout.sytm_layout_console.status) },
|
|
385
|
-
sytm_layout_request: { status: Boolean(formValue.sytm_layout.sytm_layout_request.status) },
|
|
386
|
-
sytm_layout_drawer: formValue.sytm_layout.sytm_layout_drawer
|
|
387
|
-
},
|
|
388
|
-
sytm_isactive: formValue.sytm_isactive
|
|
389
|
-
};
|
|
390
|
-
this.loading.set(true);
|
|
391
|
-
this.themeService.createTheme(newTheme)
|
|
392
|
-
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
393
|
-
.subscribe({
|
|
394
|
-
next: (response) => {
|
|
395
|
-
if (response.success) {
|
|
396
|
-
this.resetForm();
|
|
397
|
-
this.loadThemes();
|
|
398
|
-
console.log('✅ Theme created successfully');
|
|
399
|
-
}
|
|
400
|
-
else {
|
|
401
|
-
console.error('❌ Failed to create theme:', response.message);
|
|
402
|
-
}
|
|
403
|
-
this.loading.set(false);
|
|
404
|
-
},
|
|
405
|
-
error: (error) => {
|
|
406
|
-
console.error('Error creating theme:', error);
|
|
407
|
-
console.error('❌ Failed to create theme. Please try again.');
|
|
408
|
-
this.loading.set(false);
|
|
409
|
-
}
|
|
410
|
-
});
|
|
411
|
-
}
|
|
412
|
-
/**
|
|
413
|
-
* Update existing theme
|
|
414
|
-
*/
|
|
415
|
-
updateTheme() {
|
|
416
|
-
if (!this.themeForm.valid || !this.editingThemeId()) {
|
|
417
|
-
this.markFormAsTouched();
|
|
418
|
-
return;
|
|
419
|
-
}
|
|
420
|
-
const formValue = this.themeForm.getRawValue();
|
|
421
|
-
const updatedTheme = {
|
|
422
|
-
_id: this.editingThemeId() || '',
|
|
423
|
-
sytm_title: formValue.sytm_title,
|
|
424
|
-
sytm_desc: formValue.sytm_desc,
|
|
425
|
-
sytm_theme_code: formValue.sytm_theme_code,
|
|
426
|
-
sytm_preview_id_fm: formValue.sytm_preview_id_fm,
|
|
427
|
-
sytm_page_id_sypg: this.pageId(),
|
|
428
|
-
sytm_configuration: JSON.parse(formValue.sytm_configuration),
|
|
429
|
-
sytm_sub_title: formValue.sytm_sub_title,
|
|
430
|
-
sytm_entity_id_syen: formValue.sytm_entity_id_syen || this.appState.getActiveEntityId(),
|
|
431
|
-
sytm_isselected: Boolean(formValue.sytm_isselected),
|
|
432
|
-
sytm_layout: {
|
|
433
|
-
sytm_layout_sidebar: { status: Boolean(formValue.sytm_layout.sytm_layout_sidebar.status) },
|
|
434
|
-
sytm_layout_header: { status: Boolean(formValue.sytm_layout.sytm_layout_header.status) },
|
|
435
|
-
sytm_layout_footer: { status: Boolean(formValue.sytm_layout.sytm_layout_footer.status) },
|
|
436
|
-
sytm_layout_breadcrumb: { status: Boolean(formValue.sytm_layout.sytm_layout_breadcrumb.status) },
|
|
437
|
-
sytm_layout_console: { status: Boolean(formValue.sytm_layout.sytm_layout_console.status) },
|
|
438
|
-
sytm_layout_request: { status: Boolean(formValue.sytm_layout.sytm_layout_request.status) },
|
|
439
|
-
sytm_layout_drawer: formValue.sytm_layout.sytm_layout_drawer
|
|
440
|
-
},
|
|
441
|
-
sytm_isactive: formValue.sytm_isactive
|
|
442
|
-
};
|
|
443
|
-
this.loading.set(true);
|
|
444
|
-
this.themeService.updateTheme(updatedTheme)
|
|
445
|
-
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
446
|
-
.subscribe({
|
|
447
|
-
next: (response) => {
|
|
448
|
-
if (response.success) {
|
|
449
|
-
this.resetForm();
|
|
450
|
-
this.loadThemes();
|
|
451
|
-
console.log('✅ Theme updated successfully');
|
|
452
|
-
}
|
|
453
|
-
else {
|
|
454
|
-
console.error('❌ Failed to update theme:', response.message);
|
|
455
|
-
}
|
|
456
|
-
this.loading.set(false);
|
|
457
|
-
},
|
|
458
|
-
error: (error) => {
|
|
459
|
-
console.error('Error updating theme:', error);
|
|
460
|
-
console.error('❌ Failed to update theme. Please try again.');
|
|
461
|
-
this.loading.set(false);
|
|
462
|
-
}
|
|
463
|
-
});
|
|
464
|
-
}
|
|
465
|
-
/**
|
|
466
|
-
* Edit theme
|
|
467
|
-
*/
|
|
468
|
-
editTheme(theme) {
|
|
469
|
-
this.isEditMode.set(true);
|
|
470
|
-
this.editingThemeId.set(theme._id || null);
|
|
471
|
-
this.retrievedTheme.set(theme);
|
|
472
|
-
this.themeForm.patchValue({
|
|
473
|
-
sytm_title: theme.sytm_title || '',
|
|
474
|
-
sytm_desc: theme.sytm_desc || '',
|
|
475
|
-
sytm_theme_code: theme.sytm_theme_code || '',
|
|
476
|
-
sytm_preview_id_fm: theme.sytm_preview_id_fm || '',
|
|
477
|
-
sytm_sub_title: theme.sytm_sub_title || '',
|
|
478
|
-
sytm_configuration: JSON.stringify(theme.sytm_configuration || {}, null, 2),
|
|
479
|
-
sytm_entity_id_syen: theme.sytm_entity_id_syen || this.appState.getActiveEntityId(),
|
|
480
|
-
sytm_isselected: theme.sytm_isselected ?? false,
|
|
481
|
-
sytm_layout: {
|
|
482
|
-
sytm_layout_sidebar: { status: theme.sytm_layout?.sytm_layout_sidebar?.status ?? true },
|
|
483
|
-
sytm_layout_header: { status: theme.sytm_layout?.sytm_layout_header?.status ?? true },
|
|
484
|
-
sytm_layout_footer: { status: theme.sytm_layout?.sytm_layout_footer?.status ?? false },
|
|
485
|
-
sytm_layout_breadcrumb: { status: theme.sytm_layout?.sytm_layout_breadcrumb?.status ?? true },
|
|
486
|
-
sytm_layout_console: { status: theme.sytm_layout?.sytm_layout_console?.status ?? false },
|
|
487
|
-
sytm_layout_request: { status: theme.sytm_layout?.sytm_layout_request?.status ?? false },
|
|
488
|
-
sytm_layout_drawer: theme.sytm_layout?.sytm_layout_drawer || []
|
|
489
|
-
},
|
|
490
|
-
sytm_isactive: theme.sytm_isactive ?? true
|
|
491
|
-
});
|
|
492
|
-
// Rebuild drawer array controls from data
|
|
493
|
-
while (this.drawerArray.length) {
|
|
494
|
-
this.drawerArray.removeAt(0);
|
|
495
|
-
}
|
|
496
|
-
(theme.sytm_layout?.sytm_layout_drawer || []).forEach(d => {
|
|
497
|
-
this.drawerArray.push(this.createDrawerGroup({
|
|
498
|
-
syth_status: d?.syth_status ?? true,
|
|
499
|
-
syth_config_syco_for: d?.syth_config_syco_for ?? 'drawer_notes'
|
|
500
|
-
}));
|
|
501
|
-
});
|
|
502
|
-
this.themeForm.markAsPristine();
|
|
503
|
-
}
|
|
504
|
-
/**
|
|
505
|
-
* Delete theme
|
|
506
|
-
*/
|
|
507
|
-
deleteTheme(theme) {
|
|
508
|
-
if (confirm(`Are you sure you want to delete the theme "${theme.sytm_title}"?`)) {
|
|
509
|
-
this.loading.set(true);
|
|
510
|
-
this.themeService.deleteTheme(theme._id || '')
|
|
511
|
-
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
512
|
-
.subscribe({
|
|
513
|
-
next: (response) => {
|
|
514
|
-
if (response.success) {
|
|
515
|
-
this.loadThemes();
|
|
516
|
-
console.log('✅ Theme deleted successfully');
|
|
517
|
-
}
|
|
518
|
-
else {
|
|
519
|
-
console.error('❌ Failed to delete theme:', response.message);
|
|
520
|
-
}
|
|
521
|
-
this.loading.set(false);
|
|
522
|
-
},
|
|
523
|
-
error: (error) => {
|
|
524
|
-
console.error('Error deleting theme:', error);
|
|
525
|
-
console.error('❌ Failed to delete theme. Please try again.');
|
|
526
|
-
this.loading.set(false);
|
|
527
|
-
}
|
|
528
|
-
});
|
|
529
|
-
}
|
|
530
|
-
}
|
|
531
|
-
/**
|
|
532
|
-
* Toggle theme status
|
|
533
|
-
*/
|
|
534
|
-
toggleThemeStatus(theme) {
|
|
535
|
-
this.loading.set(true);
|
|
536
|
-
this.themeService.toggleThemeStatus({ sytm_id: theme._id || '', sytm_isactive: !theme.sytm_isactive })
|
|
537
|
-
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
538
|
-
.subscribe({
|
|
539
|
-
next: (response) => {
|
|
540
|
-
if (response.success) {
|
|
541
|
-
this.loadThemes();
|
|
542
|
-
console.log(`✅ Theme ${theme.sytm_isactive ? 'deactivated' : 'activated'} successfully`);
|
|
543
|
-
}
|
|
544
|
-
else {
|
|
545
|
-
console.error('❌ Failed to toggle theme status:', response.message);
|
|
546
|
-
}
|
|
547
|
-
this.loading.set(false);
|
|
548
|
-
},
|
|
549
|
-
error: (error) => {
|
|
550
|
-
console.error('Error toggling theme status:', error);
|
|
551
|
-
console.error('❌ Failed to toggle theme status. Please try again.');
|
|
552
|
-
this.loading.set(false);
|
|
553
|
-
}
|
|
554
|
-
});
|
|
555
|
-
}
|
|
556
|
-
/**
|
|
557
|
-
* Save theme (create or update)
|
|
558
|
-
*/
|
|
559
|
-
saveTheme() {
|
|
560
|
-
if (this.isEditMode()) {
|
|
561
|
-
this.updateTheme();
|
|
562
|
-
}
|
|
563
|
-
else {
|
|
564
|
-
this.createTheme();
|
|
565
|
-
}
|
|
566
|
-
}
|
|
567
|
-
/**
|
|
568
|
-
* Cancel form
|
|
569
|
-
*/
|
|
570
|
-
cancelForm() {
|
|
571
|
-
this.resetForm();
|
|
572
|
-
}
|
|
573
|
-
/**
|
|
574
|
-
* Go back to page list
|
|
575
|
-
*/
|
|
576
|
-
goBack() {
|
|
577
|
-
this.router.navigate(['/core/page']);
|
|
578
|
-
}
|
|
579
|
-
/**
|
|
580
|
-
* Reset form
|
|
581
|
-
*/
|
|
582
|
-
resetForm() {
|
|
583
|
-
this.themeForm.reset({
|
|
584
|
-
sytm_title: '',
|
|
585
|
-
sytm_desc: '',
|
|
586
|
-
sytm_theme_code: '',
|
|
587
|
-
sytm_preview_id_fm: '',
|
|
588
|
-
sytm_sub_title: '',
|
|
589
|
-
sytm_configuration: '{}',
|
|
590
|
-
sytm_entity_id_syen: '',
|
|
591
|
-
sytm_isselected: false,
|
|
592
|
-
sytm_layout: {
|
|
593
|
-
sytm_layout_sidebar: { status: true },
|
|
594
|
-
sytm_layout_header: { status: true },
|
|
595
|
-
sytm_layout_footer: { status: false },
|
|
596
|
-
sytm_layout_breadcrumb: { status: true },
|
|
597
|
-
sytm_layout_console: { status: false },
|
|
598
|
-
sytm_layout_request: { status: false },
|
|
599
|
-
sytm_layout_drawer: []
|
|
600
|
-
},
|
|
601
|
-
sytm_isactive: true
|
|
602
|
-
});
|
|
603
|
-
// Explicitly clear the FormArray for drawers
|
|
604
|
-
while (this.drawerArray.length) {
|
|
605
|
-
this.drawerArray.removeAt(0);
|
|
606
|
-
}
|
|
607
|
-
this.isEditMode.set(false);
|
|
608
|
-
this.editingThemeId.set(null);
|
|
609
|
-
this.retrievedTheme.set(null);
|
|
610
|
-
this.themeForm.markAsPristine();
|
|
611
|
-
this.themeForm.markAsUntouched();
|
|
612
|
-
}
|
|
613
|
-
/**
|
|
614
|
-
* Mark form as touched to trigger validation display
|
|
615
|
-
*/
|
|
616
|
-
markFormAsTouched() {
|
|
617
|
-
Object.keys(this.themeForm.controls).forEach(key => {
|
|
618
|
-
const control = this.themeForm.get(key);
|
|
619
|
-
control?.markAsTouched();
|
|
620
|
-
});
|
|
621
|
-
}
|
|
622
|
-
/**
|
|
623
|
-
* Get dropdown items for actions
|
|
624
|
-
*/
|
|
625
|
-
getActionDropdownItems(theme) {
|
|
626
|
-
return [
|
|
627
|
-
{
|
|
628
|
-
id: 'edit',
|
|
629
|
-
label: 'Edit',
|
|
630
|
-
icon: 'edit',
|
|
631
|
-
disabled: false
|
|
632
|
-
},
|
|
633
|
-
{
|
|
634
|
-
id: 'toggle',
|
|
635
|
-
label: theme.sytm_isactive ? 'Deactivate' : 'Activate',
|
|
636
|
-
icon: theme.sytm_isactive ? 'block' : 'check_circle',
|
|
637
|
-
disabled: false
|
|
638
|
-
},
|
|
639
|
-
{
|
|
640
|
-
id: 'delete',
|
|
641
|
-
label: 'Delete',
|
|
642
|
-
icon: 'delete',
|
|
643
|
-
disabled: false
|
|
644
|
-
}
|
|
645
|
-
];
|
|
646
|
-
}
|
|
647
|
-
/**
|
|
648
|
-
* Handle dropdown item click
|
|
649
|
-
* This method handles clicks on dropdown menu items in the actions column
|
|
650
|
-
*/
|
|
651
|
-
onDropdownItemClick(item, row) {
|
|
652
|
-
console.log('🔵 onDropdownItemClick called with:', item, row);
|
|
653
|
-
switch (item.id) {
|
|
654
|
-
case 'edit':
|
|
655
|
-
console.log('🔵 Calling editTheme with:', row);
|
|
656
|
-
this.editTheme(row);
|
|
657
|
-
break;
|
|
658
|
-
case 'toggle':
|
|
659
|
-
console.log('🔵 Calling toggleThemeStatus with:', row);
|
|
660
|
-
this.toggleThemeStatus(row);
|
|
661
|
-
break;
|
|
662
|
-
case 'delete':
|
|
663
|
-
console.log('🔵 Calling deleteTheme with:', row);
|
|
664
|
-
this.deleteTheme(row);
|
|
665
|
-
break;
|
|
666
|
-
default:
|
|
667
|
-
console.log('🔵 Unknown action:', item.id);
|
|
668
|
-
}
|
|
669
|
-
// Close all dropdowns after action
|
|
670
|
-
this.closeAllDropdowns();
|
|
671
|
-
}
|
|
672
|
-
/**
|
|
673
|
-
* Close all dropdowns
|
|
674
|
-
*/
|
|
675
|
-
closeAllDropdowns() {
|
|
676
|
-
// Close all dropdowns by clicking outside
|
|
677
|
-
const event = new MouseEvent('click', { bubbles: true });
|
|
678
|
-
document.dispatchEvent(event);
|
|
679
|
-
}
|
|
680
|
-
get drawerArray() {
|
|
681
|
-
return this.themeForm.get('sytm_layout.sytm_layout_drawer');
|
|
682
|
-
}
|
|
683
|
-
createDrawerGroup(drawer) {
|
|
684
|
-
return this.fb.group({
|
|
685
|
-
syth_status: [drawer?.syth_status ?? true],
|
|
686
|
-
syth_config_syco_for: [drawer?.syth_config_syco_for ?? 'drawer_notes']
|
|
687
|
-
});
|
|
688
|
-
}
|
|
689
|
-
addDrawer() {
|
|
690
|
-
this.drawerArray.push(this.createDrawerGroup());
|
|
691
|
-
this.themeForm.markAsDirty();
|
|
692
|
-
}
|
|
693
|
-
removeDrawer(index) {
|
|
694
|
-
if (index >= 0 && index < this.drawerArray.length) {
|
|
695
|
-
this.drawerArray.removeAt(index);
|
|
696
|
-
this.themeForm.markAsDirty();
|
|
697
|
-
}
|
|
698
|
-
}
|
|
699
|
-
/**
|
|
700
|
-
* Set selected theme (only one can be selected per page)
|
|
701
|
-
*/
|
|
702
|
-
setSelectedTheme(theme) {
|
|
703
|
-
if (!theme || theme.sytm_isselected)
|
|
704
|
-
return; // already selected
|
|
705
|
-
const previouslySelected = this.themes().find(t => t.sytm_isselected && t._id !== theme._id);
|
|
706
|
-
// Disable previous selection (best-effort)
|
|
707
|
-
if (previouslySelected) {
|
|
708
|
-
const disablePayload = {
|
|
709
|
-
_id: previouslySelected._id || '',
|
|
710
|
-
sytm_title: previouslySelected.sytm_title || '',
|
|
711
|
-
sytm_desc: previouslySelected.sytm_desc || '',
|
|
712
|
-
sytm_theme_code: previouslySelected.sytm_theme_code || '',
|
|
713
|
-
sytm_preview_id_fm: previouslySelected.sytm_preview_id_fm || '',
|
|
714
|
-
sytm_page_id_sypg: this.pageId(),
|
|
715
|
-
sytm_configuration: previouslySelected.sytm_configuration || {},
|
|
716
|
-
sytm_sub_title: previouslySelected.sytm_sub_title || '',
|
|
717
|
-
sytm_entity_id_syen: previouslySelected.sytm_entity_id_syen || this.appState.getActiveEntityId(),
|
|
718
|
-
sytm_isselected: false,
|
|
719
|
-
sytm_layout: previouslySelected.sytm_layout,
|
|
720
|
-
sytm_isactive: previouslySelected.sytm_isactive ?? true
|
|
721
|
-
};
|
|
722
|
-
this.themeService.updateTheme(disablePayload).pipe(takeUntilDestroyed(this.destroyRef)).subscribe({ next: () => { }, error: () => { } });
|
|
723
|
-
}
|
|
724
|
-
// Enable current selection
|
|
725
|
-
const enablePayload = {
|
|
726
|
-
_id: theme._id || '',
|
|
727
|
-
sytm_title: theme.sytm_title || '',
|
|
728
|
-
sytm_desc: theme.sytm_desc || '',
|
|
729
|
-
sytm_theme_code: theme.sytm_theme_code || '',
|
|
730
|
-
sytm_preview_id_fm: theme.sytm_preview_id_fm || '',
|
|
731
|
-
sytm_page_id_sypg: this.pageId(),
|
|
732
|
-
sytm_configuration: theme.sytm_configuration || {},
|
|
733
|
-
sytm_sub_title: theme.sytm_sub_title || '',
|
|
734
|
-
sytm_entity_id_syen: theme.sytm_entity_id_syen || this.appState.getActiveEntityId(),
|
|
735
|
-
sytm_isselected: true,
|
|
736
|
-
sytm_layout: theme.sytm_layout,
|
|
737
|
-
sytm_isactive: theme.sytm_isactive ?? true
|
|
738
|
-
};
|
|
739
|
-
this.loading.set(true);
|
|
740
|
-
this.themeService.updateTheme(enablePayload)
|
|
741
|
-
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
742
|
-
.subscribe({
|
|
743
|
-
next: () => { this.loadThemes(); this.loading.set(false); },
|
|
744
|
-
error: () => { this.loading.set(false); }
|
|
745
|
-
});
|
|
746
|
-
}
|
|
747
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: PageThemeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
748
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: PageThemeComponent, isStandalone: true, selector: "cide-core-app-page-theme", viewQueries: [{ propertyName: "themeDetailsRendererTemplate", first: true, predicate: ["themeDetailsRendererTemplate"], descendants: true, isSignal: true }, { propertyName: "themeStatusRendererTemplate", first: true, predicate: ["themeStatusRendererTemplate"], descendants: true, isSignal: true }, { propertyName: "actionsDropdownRendererTemplate", first: true, predicate: ["actionsDropdownRendererTemplate"], descendants: true, isSignal: true }], ngImport: i0, template: "<!-- Page Theme Container -->\r\n<div class=\"tw-flex tw-h-full tw-w-full\">\r\n \r\n <!-- Left: Form and header (60%) -->\r\n <div class=\"tw-w-full lg:tw-w-3/5 tw-flex tw-flex-col tw-border-r tw-border-gray-200\">\r\n\r\n <!-- Header Section -->\r\n <div class=\"tw-px-6 tw-py-3 tw-border-b tw-border-gray-200 tw-bg-gray-50\">\r\n <div class=\"tw-flex tw-flex-col sm:tw-flex-row tw-justify-between tw-items-start sm:tw-items-center tw-space-y-3 sm:tw-space-y-0\">\r\n\r\n <!-- Title and Back Button -->\r\n <div class=\"tw-flex tw-items-center tw-space-x-4\">\r\n <button cideEleButton variant=\"ghost\" size=\"sm\" (click)=\"goBack()\" class=\"tw-text-gray-600 hover:tw-text-gray-900\">\r\n <cide-ele-icon class=\"tw-w-4 tw-h-4\">arrow_back</cide-ele-icon>\r\n </button>\r\n <div class=\"tw-flex tw-items-center tw-space-x-2\">\r\n <cide-ele-icon class=\"tw-text-blue-600 tw-w-5 tw-h-5\">palette</cide-ele-icon>\r\n <div>\r\n <h5 class=\"tw-text-base tw-font-medium tw-text-gray-900 tw-m-0\">Theme Management</h5>\r\n <p class=\"tw-text-sm tw-text-gray-500 tw-m-0\">Page: {{ pageTitle() }}</p>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Error Message -->\r\n @if (error()) {\r\n <div class=\"tw-mt-4 tw-p-4 tw-bg-red-50 tw-border tw-border-red-200 tw-rounded-md\">\r\n <div class=\"tw-flex tw-items-start\">\r\n <cide-ele-icon name=\"error\" class=\"tw-text-red-400 tw-w-5 tw-h-5 tw-mt-0.5 tw-flex-shrink-0\"></cide-ele-icon>\r\n <div class=\"tw-ml-3\">\r\n <h3 class=\"tw-text-sm tw-font-medium tw-text-red-800 tw-m-0\">Error</h3>\r\n <p class=\"tw-text-sm tw-text-red-700 tw-mt-1 tw-m-0\">{{ error() }}</p>\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n </div>\r\n\r\n <!-- Quick Add/Edit Form Section -->\r\n <div class=\"tw-px-6 tw-py-4 tw-bg-white tw-overflow-auto\">\r\n <div class=\"tw-flex tw-items-center tw-justify-between tw-mb-3\">\r\n <div class=\"tw-flex tw-items-center tw-space-x-3\">\r\n <cide-ele-icon class=\"tw-text-blue-600 tw-w-5 tw-h-5\">{{ isEditMode() ? 'edit' : 'add' }}</cide-ele-icon>\r\n <h6 class=\"tw-text-sm tw-font-medium tw-text-gray-900 tw-m-0\">{{ isEditMode() ? 'Edit Theme' : 'Quick Add Theme' }}</h6>\r\n </div>\r\n </div>\r\n\r\n <!-- Form (kept as-is) -->\r\n <form [formGroup]=\"themeForm\" (ngSubmit)=\"saveTheme()\" class=\"tw-space-y-4\">\r\n <div class=\"tw-grid tw-grid-cols-1 md:tw-grid-cols-2 lg:tw-grid-cols-3 tw-gap-4\">\r\n <!-- Theme Title -->\r\n <div class=\"tw-space-y-2\">\r\n <cide-ele-input id=\"sytm_title\" formControlName=\"sytm_title\" placeholder=\"Enter theme title\" label=\"Theme Title*\" size=\"sm\"></cide-ele-input>\r\n </div>\r\n <!-- Theme Code -->\r\n <div class=\"tw-space-y-2\">\r\n <cide-ele-input id=\"sytm_theme_code\" formControlName=\"sytm_theme_code\" placeholder=\"Enter theme code\" label=\"Theme Code*\" size=\"sm\"></cide-ele-input>\r\n </div>\r\n <!-- Status -->\r\n <div class=\"tw-space-y-2\">\r\n <cide-ele-input\r\n id=\"sytm_isactive_cb\"\r\n type=\"checkbox\"\r\n label=\"Active\"\r\n size=\"sm\"\r\n formControlName=\"sytm_isactive\">\r\n </cide-ele-input>\r\n </div>\r\n <!-- Sub Title -->\r\n <div class=\"tw-space-y-2\">\r\n <cide-ele-input id=\"sytm_sub_title\" formControlName=\"sytm_sub_title\" placeholder=\"Enter sub title\" label=\"Sub Title\" size=\"sm\"></cide-ele-input>\r\n </div>\r\n <!-- Preview ID -->\r\n <div class=\"tw-space-y-2\">\r\n <cide-ele-input id=\"sytm_preview_id_fm\" formControlName=\"sytm_preview_id_fm\" placeholder=\"Enter preview image ID\" label=\"Preview Image ID\" size=\"sm\"></cide-ele-input>\r\n </div>\r\n <!-- Description -->\r\n <div class=\"tw-space-y-2 md:tw-col-span-2\">\r\n <cide-ele-textarea id=\"sytm_desc\" formControlName=\"sytm_desc\" placeholder=\"Enter theme description\" rows=\"2\" label=\"Description\" size=\"sm\"></cide-ele-textarea>\r\n </div>\r\n <!-- Configuration JSON -->\r\n <div class=\"tw-space-y-2 md:tw-col-span-3\">\r\n <cide-ele-json-editor label=\"Configuration JSON\" formControlName=\"sytm_configuration\" [required]=\"true\" [config]=\"{\r\n showLineNumbers: true,\r\n autoFormat: true,\r\n validateOnChange: true,\r\n minHeight: 150,\r\n maxHeight: 300,\r\n placeholder: 'Enter theme configuration JSON...'\r\n }\" helperText=\"Enter valid JSON configuration for the theme\"></cide-ele-json-editor>\r\n </div>\r\n <!-- Layout Configuration + Selection: right-side checkbox list -->\r\n <div class=\"lg:tw-col-span-1 tw-space-y-2\">\r\n <div class=\"tw-text-sm tw-font-medium tw-text-gray-700\">Layout & Selection</div>\r\n <!-- Selected toggle -->\r\n <div class=\"tw-bg-white tw-border tw-border-gray-200 tw-rounded-md tw-px-3 tw-py-2\">\r\n <cide-ele-input\r\n id=\"sytm_isselected\"\r\n type=\"checkbox\"\r\n label=\"Selected (Default)\"\r\n size=\"sm\"\r\n formControlName=\"sytm_isselected\">\r\n </cide-ele-input>\r\n </div>\r\n <div formGroupName=\"sytm_layout\" class=\"tw-bg-white tw-border tw-border-gray-200 tw-rounded-md tw-divide-y tw-overflow-hidden\">\r\n <!-- Sidebar -->\r\n <div class=\"tw-px-3 tw-py-2\" formGroupName=\"sytm_layout_sidebar\">\r\n <cide-ele-input id=\"layout_sidebar_status\" type=\"checkbox\" label=\"Sidebar\" size=\"sm\" formControlName=\"status\"></cide-ele-input>\r\n </div>\r\n <!-- Header -->\r\n <div class=\"tw-px-3 tw-py-2\" formGroupName=\"sytm_layout_header\">\r\n <cide-ele-input id=\"layout_header_status\" type=\"checkbox\" label=\"Header\" size=\"sm\" formControlName=\"status\"></cide-ele-input>\r\n </div>\r\n <!-- Footer -->\r\n <div class=\"tw-px-3 tw-py-2\" formGroupName=\"sytm_layout_footer\">\r\n <cide-ele-input id=\"layout_footer_status\" type=\"checkbox\" label=\"Footer\" size=\"sm\" formControlName=\"status\"></cide-ele-input>\r\n </div>\r\n <!-- Breadcrumb -->\r\n <div class=\"tw-px-3 tw-py-2\" formGroupName=\"sytm_layout_breadcrumb\">\r\n <cide-ele-input id=\"layout_breadcrumb_status\" type=\"checkbox\" label=\"Breadcrumb\" size=\"sm\" formControlName=\"status\"></cide-ele-input>\r\n </div>\r\n <!-- Console -->\r\n <div class=\"tw-px-3 tw-py-2\" formGroupName=\"sytm_layout_console\">\r\n <cide-ele-input id=\"layout_console_status\" type=\"checkbox\" label=\"Console\" size=\"sm\" formControlName=\"status\"></cide-ele-input>\r\n </div>\r\n <!-- Request -->\r\n <div class=\"tw-px-3 tw-py-2\" formGroupName=\"sytm_layout_request\">\r\n <cide-ele-input id=\"layout_request_status\" type=\"checkbox\" label=\"Request\" size=\"sm\" formControlName=\"status\"></cide-ele-input>\r\n </div>\r\n </div>\r\n <p class=\"tw-text-xs tw-text-gray-500 tw-pt-1\">Toggle active sections. Only one theme can be selected as default. More options can be added here later.</p>\r\n </div>\r\n <!-- Drawer Configuration -->\r\n <div class=\"tw-space-y-2 md:tw-col-span-3\">\r\n <div class=\"tw-flex tw-items-center tw-justify-between\">\r\n <div class=\"tw-text-sm tw-font-medium tw-text-gray-700\">Drawers</div>\r\n <button cideEleButton type=\"button\" size=\"xs\" variant=\"outline\" (click)=\"addDrawer()\">\r\n Add Drawer\r\n </button>\r\n </div>\r\n\r\n <div formGroupName=\"sytm_layout\">\r\n <div class=\"tw-space-y-2\" formArrayName=\"sytm_layout_drawer\">\r\n <div *ngFor=\"let drawerGrp of drawerArray.controls; let i = index\" [formGroupName]=\"i\" class=\"tw-border tw-border-gray-200 tw-rounded-md tw-p-3 tw-flex tw-items-center tw-gap-3\">\r\n <cide-ele-input id=\"drawer_active_{{i}}\" type=\"checkbox\" label=\"Active\" size=\"sm\" formControlName=\"syth_status\"></cide-ele-input>\r\n <div class=\"tw-flex-1\">\r\n <cide-ele-select\r\n id=\"drawer_config_{{i}}\"\r\n label=\"Drawer For\"\r\n size=\"sm\"\r\n [options]=\"drawerConfigOptions\"\r\n formControlName=\"syth_config_syco_for\">\r\n </cide-ele-select>\r\n </div>\r\n <button cideEleButton type=\"button\" size=\"xs\" variant=\"ghost\" (click)=\"removeDrawer(i)\">\r\n <cide-ele-icon class=\"tw-w-4 tw-h-4\">delete</cide-ele-icon>\r\n </button>\r\n </div>\r\n <p class=\"tw-text-xs tw-text-gray-500\">Configure multiple drawers as needed.</p>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Form Actions -->\r\n <div class=\"tw-flex tw-flex-col tw-gap-2 tw-pt-4 tw-border-t tw-border-gray-200\">\r\n <div class=\"tw-flex tw-items-center tw-justify-end tw-space-x-3\">\r\n <button cideEleButton type=\"button\" variant=\"outline\" (click)=\"cancelForm()\" [disabled]=\"loading()\">Cancel</button>\r\n <button cideEleButton type=\"submit\" variant=\"primary\" leftIcon=\"add\" [disabled]=\"!themeForm.valid || loading()\" [loading]=\"loading()\">\r\n {{ isEditMode() ? 'Update Theme' : 'Create Theme' }}\r\n </button>\r\n </div>\r\n </div>\r\n </form>\r\n </div>\r\n </div>\r\n\r\n <!-- Right: Theme gallery (40%) -->\r\n <div class=\"tw-hidden lg:tw-flex tw-w-2/5 tw-flex-col\">\r\n <!-- (Header consolidated above) -->\r\n\r\n <!-- Gallery list -->\r\n <div class=\"tw-flex-1 tw-overflow-auto tw-bg-gray-50\">\r\n <div class=\"tw-grid tw-grid-cols-1 md:tw-grid-cols-2 tw-gap-3 tw-p-4\">\r\n @for (theme of filteredThemes(); track theme._id) {\r\n <div class=\"tw-rounded-md tw-transition tw-cursor-pointer tw-relative\"\r\n [ngClass]=\"theme.sytm_isselected\r\n ? 'tw-border tw-border-blue-500 tw-ring-2 tw-ring-blue-200 tw-bg-blue-50/50'\r\n : 'tw-bg-white tw-border tw-border-gray-200 hover:tw-shadow-sm'\"\r\n (click)=\"editTheme(theme)\"\r\n role=\"button\"\r\n tabindex=\"0\"\r\n [attr.aria-selected]=\"theme.sytm_isselected ? 'true' : 'false'\"\r\n [attr.aria-label]=\"'Edit theme ' + (theme.sytm_title || theme.sytm_theme_code)\"\r\n (keydown.enter)=\"editTheme(theme)\"\r\n (keydown.space)=\"$event.preventDefault(); editTheme(theme)\">\r\n\r\n <!-- Selected badge -->\r\n <div *ngIf=\"theme.sytm_isselected\"\r\n class=\"tw-absolute tw-top-2 tw-right-2 tw-flex tw-items-center tw-justify-center tw-w-6 tw-h-6 tw-rounded-full tw-bg-blue-600 tw-text-white\">\r\n <cide-ele-icon class=\"tw-w-4 tw-h-4\">check</cide-ele-icon>\r\n </div>\r\n \r\n <div class=\"tw-aspect-[16/9] tw-bg-gray-100 tw-rounded-t-md tw-overflow-hidden tw-flex tw-items-center tw-justify-center\">\r\n @if (getPreviewUrl(theme)) {\r\n <img [src]=\"getPreviewUrl(theme)\" class=\"tw-w-full tw-h-full tw-object-cover\" alt=\"Preview\" />\r\n } @else {\r\n <div class=\"tw-text-gray-400 tw-text-xs\">No preview</div>\r\n }\r\n </div>\r\n <div class=\"tw-p-3 tw-space-y-1\">\r\n <div class=\"tw-text-sm tw-font-medium tw-text-gray-900 tw-truncate\" [title]=\"theme.sytm_title\">{{ theme.sytm_title || 'Untitled Theme' }}</div>\r\n <div class=\"tw-text-xs tw-text-gray-500 tw-truncate\" [title]=\"theme.sytm_theme_code\">{{ theme.sytm_theme_code }}</div>\r\n <div class=\"tw-flex tw-items-center tw-justify-between tw-pt-1\">\r\n <span class=\"tw-inline-flex tw-items-center tw-gap-1 tw-text-xs\" [ngClass]=\"theme.sytm_isactive ? 'tw-text-green-700' : 'tw-text-red-700'\">\r\n <span class=\"tw-w-1.5 tw-h-1.5 tw-rounded-full\" [ngClass]=\"theme.sytm_isactive ? 'tw-bg-green-500' : 'tw-bg-red-500'\"></span>\r\n {{ theme.sytm_isactive ? 'Active' : 'Inactive' }}\r\n </span>\r\n <div class=\"tw-flex tw-items-center tw-gap-1\">\r\n <!-- Set Selected Button - Clear and Simple -->\r\n @if (theme.sytm_isselected) {\r\n <span class=\"tw-inline-flex tw-items-center tw-gap-1 tw-px-2 tw-py-1 tw-bg-green-100 tw-text-green-800 tw-rounded-md tw-text-xs tw-font-medium\">\r\n <cide-ele-icon class=\"tw-w-3 tw-h-3\">check</cide-ele-icon>\r\n Selected\r\n </span>\r\n } @else {\r\n <button cideEleButton \r\n variant=\"outline\" \r\n size=\"xs\"\r\n (click)=\"$event.stopPropagation(); setSelectedTheme(theme)\"\r\n [attr.aria-label]=\"'Select ' + (theme.sytm_title || theme.sytm_theme_code) + ' theme'\"\r\n class=\"tw-text-xs\">\r\n Select\r\n </button>\r\n }\r\n <button cideEleButton variant=\"ghost\" size=\"xs\" (click)=\"$event.stopPropagation(); editTheme(theme)\"\r\n [attr.aria-label]=\"'Edit theme ' + (theme.sytm_title || theme.sytm_theme_code)\">\r\n <cide-ele-icon class=\"tw-w-4 tw-h-4\">edit</cide-ele-icon>\r\n </button>\r\n <button cideEleButton variant=\"ghost\" size=\"xs\" (click)=\"$event.stopPropagation(); deleteTheme(theme)\"\r\n [attr.aria-label]=\"'Delete theme ' + (theme.sytm_title || theme.sytm_theme_code)\">\r\n <cide-ele-icon class=\"tw-w-4 tw-h-4\">delete</cide-ele-icon>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n\r\n @if (!loading() && filteredThemes().length === 0) {\r\n <div class=\"tw-col-span-full tw-text-center tw-text-xs tw-text-gray-500 tw-py-8\">No themes found</div>\r\n }\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<!-- \r\n Angular Template References for Grid Renderers (Best Practice)\r\n \r\n These ng-template elements represent the Angular best practice for custom rendering.\r\n They provide:\r\n - Type safety with template context\r\n - Component lifecycle integration\r\n - Change detection optimization\r\n - Proper event handling\r\n - Accessibility features\r\n \r\n Note: Current data grid uses string renderers for compatibility.\r\n Templates are maintained for future component enhancement.\r\n-->\r\n\r\n<!-- Theme Details Renderer Template -->\r\n<ng-template #themeDetailsRendererTemplate let-row=\"row\" let-value=\"value\">\r\n <div class=\"tw-flex tw-items-center tw-min-w-0\">\r\n <!-- Theme Icon -->\r\n <div class=\"tw-flex-shrink-0\">\r\n <cide-ele-icon \r\n class=\"tw-text-purple-600\" \r\n size=\"xs\">\r\n palette\r\n </cide-ele-icon>\r\n </div>\r\n \r\n <!-- Theme Details -->\r\n <div class=\"tw-ml-3 tw-min-w-0 tw-flex-1\">\r\n <div class=\"tw-text-sm tw-font-medium tw-text-gray-900 tw-truncate\" \r\n [title]=\"row.sytm_title\">\r\n {{ row.sytm_title || 'Untitled' }}\r\n </div>\r\n @if (row.sytm_desc) {\r\n <div class=\"tw-text-xs tw-text-gray-500 tw-truncate\" \r\n [title]=\"row.sytm_desc\">\r\n {{ row.sytm_desc }}\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n<!-- Theme Status Renderer Template -->\r\n<ng-template #themeStatusRendererTemplate let-row=\"row\" let-value=\"value\">\r\n <span class=\"tw-inline-flex tw-items-center tw-px-2.5 tw-py-0.5 tw-rounded-full tw-text-xs tw-font-medium tw-whitespace-nowrap\"\r\n [ngClass]=\"row.sytm_isactive ? 'tw-bg-green-100 tw-text-green-800' : 'tw-bg-red-100 tw-text-red-800'\">\r\n {{ row.sytm_isactive ? 'Active' : 'Inactive' }}\r\n </span>\r\n</ng-template>\r\n\r\n<!-- Actions Dropdown Renderer Template -->\r\n<ng-template #actionsDropdownRendererTemplate let-row=\"row\" let-value=\"value\">\r\n <cide-ele-dropdown \r\n [items]=\"getActionDropdownItems(row)\"\r\n [config]=\"{ triggerIcon: 'more_vert', triggerSize: 'sm' }\"\r\n (itemClick)=\"onDropdownItemClick($event, row)\">\r\n </cide-ele-dropdown>\r\n</ng-template> ", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i2.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "directive", type: i2.FormArrayName, selector: "[formArrayName]", inputs: ["formArrayName"] }, { 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: CideSelectComponent, selector: "cide-ele-select", inputs: ["label", "labelHide", "placeholder", "helperText", "errorText", "required", "disabled", "id", "ngModel", "size", "fill", "labelPlacement", "labelDir", "leadingIcon", "trailingIcon", "clearInput", "options", "multiple", "searchable", "showSearchInput", "loading"], outputs: ["ngModelChange", "change", "searchChange"] }, { 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: CideIconComponent, selector: "cide-ele-icon", inputs: ["size", "type", "toolTip"] }, { kind: "component", type: CideEleDropdownComponent, selector: "cide-ele-dropdown", inputs: ["items", "config", "triggerTemplate", "menuTemplate"], outputs: ["itemClick", "dropdownToggle"] }, { kind: "component", type: CideEleJsonEditorComponent, selector: "cide-ele-json-editor", inputs: ["label", "helperText", "required", "disabled", "showCharacterCount", "config"], outputs: ["valueChange", "objectChange", "errorsChange", "validChange"] }] }); }
|
|
749
|
-
}
|
|
750
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: PageThemeComponent, decorators: [{
|
|
751
|
-
type: Component,
|
|
752
|
-
args: [{ selector: 'cide-core-app-page-theme', standalone: true, imports: [
|
|
753
|
-
CommonModule,
|
|
754
|
-
ReactiveFormsModule,
|
|
755
|
-
FormsModule,
|
|
756
|
-
CideEleDataGridComponent,
|
|
757
|
-
CideEleButtonComponent,
|
|
758
|
-
CideInputComponent,
|
|
759
|
-
CideSelectComponent,
|
|
760
|
-
CideTextareaComponent,
|
|
761
|
-
CideIconComponent,
|
|
762
|
-
CideEleDropdownComponent,
|
|
763
|
-
CideEleJsonEditorComponent,
|
|
764
|
-
CideSelectOptionComponent
|
|
765
|
-
], template: "<!-- Page Theme Container -->\r\n<div class=\"tw-flex tw-h-full tw-w-full\">\r\n \r\n <!-- Left: Form and header (60%) -->\r\n <div class=\"tw-w-full lg:tw-w-3/5 tw-flex tw-flex-col tw-border-r tw-border-gray-200\">\r\n\r\n <!-- Header Section -->\r\n <div class=\"tw-px-6 tw-py-3 tw-border-b tw-border-gray-200 tw-bg-gray-50\">\r\n <div class=\"tw-flex tw-flex-col sm:tw-flex-row tw-justify-between tw-items-start sm:tw-items-center tw-space-y-3 sm:tw-space-y-0\">\r\n\r\n <!-- Title and Back Button -->\r\n <div class=\"tw-flex tw-items-center tw-space-x-4\">\r\n <button cideEleButton variant=\"ghost\" size=\"sm\" (click)=\"goBack()\" class=\"tw-text-gray-600 hover:tw-text-gray-900\">\r\n <cide-ele-icon class=\"tw-w-4 tw-h-4\">arrow_back</cide-ele-icon>\r\n </button>\r\n <div class=\"tw-flex tw-items-center tw-space-x-2\">\r\n <cide-ele-icon class=\"tw-text-blue-600 tw-w-5 tw-h-5\">palette</cide-ele-icon>\r\n <div>\r\n <h5 class=\"tw-text-base tw-font-medium tw-text-gray-900 tw-m-0\">Theme Management</h5>\r\n <p class=\"tw-text-sm tw-text-gray-500 tw-m-0\">Page: {{ pageTitle() }}</p>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Error Message -->\r\n @if (error()) {\r\n <div class=\"tw-mt-4 tw-p-4 tw-bg-red-50 tw-border tw-border-red-200 tw-rounded-md\">\r\n <div class=\"tw-flex tw-items-start\">\r\n <cide-ele-icon name=\"error\" class=\"tw-text-red-400 tw-w-5 tw-h-5 tw-mt-0.5 tw-flex-shrink-0\"></cide-ele-icon>\r\n <div class=\"tw-ml-3\">\r\n <h3 class=\"tw-text-sm tw-font-medium tw-text-red-800 tw-m-0\">Error</h3>\r\n <p class=\"tw-text-sm tw-text-red-700 tw-mt-1 tw-m-0\">{{ error() }}</p>\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n </div>\r\n\r\n <!-- Quick Add/Edit Form Section -->\r\n <div class=\"tw-px-6 tw-py-4 tw-bg-white tw-overflow-auto\">\r\n <div class=\"tw-flex tw-items-center tw-justify-between tw-mb-3\">\r\n <div class=\"tw-flex tw-items-center tw-space-x-3\">\r\n <cide-ele-icon class=\"tw-text-blue-600 tw-w-5 tw-h-5\">{{ isEditMode() ? 'edit' : 'add' }}</cide-ele-icon>\r\n <h6 class=\"tw-text-sm tw-font-medium tw-text-gray-900 tw-m-0\">{{ isEditMode() ? 'Edit Theme' : 'Quick Add Theme' }}</h6>\r\n </div>\r\n </div>\r\n\r\n <!-- Form (kept as-is) -->\r\n <form [formGroup]=\"themeForm\" (ngSubmit)=\"saveTheme()\" class=\"tw-space-y-4\">\r\n <div class=\"tw-grid tw-grid-cols-1 md:tw-grid-cols-2 lg:tw-grid-cols-3 tw-gap-4\">\r\n <!-- Theme Title -->\r\n <div class=\"tw-space-y-2\">\r\n <cide-ele-input id=\"sytm_title\" formControlName=\"sytm_title\" placeholder=\"Enter theme title\" label=\"Theme Title*\" size=\"sm\"></cide-ele-input>\r\n </div>\r\n <!-- Theme Code -->\r\n <div class=\"tw-space-y-2\">\r\n <cide-ele-input id=\"sytm_theme_code\" formControlName=\"sytm_theme_code\" placeholder=\"Enter theme code\" label=\"Theme Code*\" size=\"sm\"></cide-ele-input>\r\n </div>\r\n <!-- Status -->\r\n <div class=\"tw-space-y-2\">\r\n <cide-ele-input\r\n id=\"sytm_isactive_cb\"\r\n type=\"checkbox\"\r\n label=\"Active\"\r\n size=\"sm\"\r\n formControlName=\"sytm_isactive\">\r\n </cide-ele-input>\r\n </div>\r\n <!-- Sub Title -->\r\n <div class=\"tw-space-y-2\">\r\n <cide-ele-input id=\"sytm_sub_title\" formControlName=\"sytm_sub_title\" placeholder=\"Enter sub title\" label=\"Sub Title\" size=\"sm\"></cide-ele-input>\r\n </div>\r\n <!-- Preview ID -->\r\n <div class=\"tw-space-y-2\">\r\n <cide-ele-input id=\"sytm_preview_id_fm\" formControlName=\"sytm_preview_id_fm\" placeholder=\"Enter preview image ID\" label=\"Preview Image ID\" size=\"sm\"></cide-ele-input>\r\n </div>\r\n <!-- Description -->\r\n <div class=\"tw-space-y-2 md:tw-col-span-2\">\r\n <cide-ele-textarea id=\"sytm_desc\" formControlName=\"sytm_desc\" placeholder=\"Enter theme description\" rows=\"2\" label=\"Description\" size=\"sm\"></cide-ele-textarea>\r\n </div>\r\n <!-- Configuration JSON -->\r\n <div class=\"tw-space-y-2 md:tw-col-span-3\">\r\n <cide-ele-json-editor label=\"Configuration JSON\" formControlName=\"sytm_configuration\" [required]=\"true\" [config]=\"{\r\n showLineNumbers: true,\r\n autoFormat: true,\r\n validateOnChange: true,\r\n minHeight: 150,\r\n maxHeight: 300,\r\n placeholder: 'Enter theme configuration JSON...'\r\n }\" helperText=\"Enter valid JSON configuration for the theme\"></cide-ele-json-editor>\r\n </div>\r\n <!-- Layout Configuration + Selection: right-side checkbox list -->\r\n <div class=\"lg:tw-col-span-1 tw-space-y-2\">\r\n <div class=\"tw-text-sm tw-font-medium tw-text-gray-700\">Layout & Selection</div>\r\n <!-- Selected toggle -->\r\n <div class=\"tw-bg-white tw-border tw-border-gray-200 tw-rounded-md tw-px-3 tw-py-2\">\r\n <cide-ele-input\r\n id=\"sytm_isselected\"\r\n type=\"checkbox\"\r\n label=\"Selected (Default)\"\r\n size=\"sm\"\r\n formControlName=\"sytm_isselected\">\r\n </cide-ele-input>\r\n </div>\r\n <div formGroupName=\"sytm_layout\" class=\"tw-bg-white tw-border tw-border-gray-200 tw-rounded-md tw-divide-y tw-overflow-hidden\">\r\n <!-- Sidebar -->\r\n <div class=\"tw-px-3 tw-py-2\" formGroupName=\"sytm_layout_sidebar\">\r\n <cide-ele-input id=\"layout_sidebar_status\" type=\"checkbox\" label=\"Sidebar\" size=\"sm\" formControlName=\"status\"></cide-ele-input>\r\n </div>\r\n <!-- Header -->\r\n <div class=\"tw-px-3 tw-py-2\" formGroupName=\"sytm_layout_header\">\r\n <cide-ele-input id=\"layout_header_status\" type=\"checkbox\" label=\"Header\" size=\"sm\" formControlName=\"status\"></cide-ele-input>\r\n </div>\r\n <!-- Footer -->\r\n <div class=\"tw-px-3 tw-py-2\" formGroupName=\"sytm_layout_footer\">\r\n <cide-ele-input id=\"layout_footer_status\" type=\"checkbox\" label=\"Footer\" size=\"sm\" formControlName=\"status\"></cide-ele-input>\r\n </div>\r\n <!-- Breadcrumb -->\r\n <div class=\"tw-px-3 tw-py-2\" formGroupName=\"sytm_layout_breadcrumb\">\r\n <cide-ele-input id=\"layout_breadcrumb_status\" type=\"checkbox\" label=\"Breadcrumb\" size=\"sm\" formControlName=\"status\"></cide-ele-input>\r\n </div>\r\n <!-- Console -->\r\n <div class=\"tw-px-3 tw-py-2\" formGroupName=\"sytm_layout_console\">\r\n <cide-ele-input id=\"layout_console_status\" type=\"checkbox\" label=\"Console\" size=\"sm\" formControlName=\"status\"></cide-ele-input>\r\n </div>\r\n <!-- Request -->\r\n <div class=\"tw-px-3 tw-py-2\" formGroupName=\"sytm_layout_request\">\r\n <cide-ele-input id=\"layout_request_status\" type=\"checkbox\" label=\"Request\" size=\"sm\" formControlName=\"status\"></cide-ele-input>\r\n </div>\r\n </div>\r\n <p class=\"tw-text-xs tw-text-gray-500 tw-pt-1\">Toggle active sections. Only one theme can be selected as default. More options can be added here later.</p>\r\n </div>\r\n <!-- Drawer Configuration -->\r\n <div class=\"tw-space-y-2 md:tw-col-span-3\">\r\n <div class=\"tw-flex tw-items-center tw-justify-between\">\r\n <div class=\"tw-text-sm tw-font-medium tw-text-gray-700\">Drawers</div>\r\n <button cideEleButton type=\"button\" size=\"xs\" variant=\"outline\" (click)=\"addDrawer()\">\r\n Add Drawer\r\n </button>\r\n </div>\r\n\r\n <div formGroupName=\"sytm_layout\">\r\n <div class=\"tw-space-y-2\" formArrayName=\"sytm_layout_drawer\">\r\n <div *ngFor=\"let drawerGrp of drawerArray.controls; let i = index\" [formGroupName]=\"i\" class=\"tw-border tw-border-gray-200 tw-rounded-md tw-p-3 tw-flex tw-items-center tw-gap-3\">\r\n <cide-ele-input id=\"drawer_active_{{i}}\" type=\"checkbox\" label=\"Active\" size=\"sm\" formControlName=\"syth_status\"></cide-ele-input>\r\n <div class=\"tw-flex-1\">\r\n <cide-ele-select\r\n id=\"drawer_config_{{i}}\"\r\n label=\"Drawer For\"\r\n size=\"sm\"\r\n [options]=\"drawerConfigOptions\"\r\n formControlName=\"syth_config_syco_for\">\r\n </cide-ele-select>\r\n </div>\r\n <button cideEleButton type=\"button\" size=\"xs\" variant=\"ghost\" (click)=\"removeDrawer(i)\">\r\n <cide-ele-icon class=\"tw-w-4 tw-h-4\">delete</cide-ele-icon>\r\n </button>\r\n </div>\r\n <p class=\"tw-text-xs tw-text-gray-500\">Configure multiple drawers as needed.</p>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Form Actions -->\r\n <div class=\"tw-flex tw-flex-col tw-gap-2 tw-pt-4 tw-border-t tw-border-gray-200\">\r\n <div class=\"tw-flex tw-items-center tw-justify-end tw-space-x-3\">\r\n <button cideEleButton type=\"button\" variant=\"outline\" (click)=\"cancelForm()\" [disabled]=\"loading()\">Cancel</button>\r\n <button cideEleButton type=\"submit\" variant=\"primary\" leftIcon=\"add\" [disabled]=\"!themeForm.valid || loading()\" [loading]=\"loading()\">\r\n {{ isEditMode() ? 'Update Theme' : 'Create Theme' }}\r\n </button>\r\n </div>\r\n </div>\r\n </form>\r\n </div>\r\n </div>\r\n\r\n <!-- Right: Theme gallery (40%) -->\r\n <div class=\"tw-hidden lg:tw-flex tw-w-2/5 tw-flex-col\">\r\n <!-- (Header consolidated above) -->\r\n\r\n <!-- Gallery list -->\r\n <div class=\"tw-flex-1 tw-overflow-auto tw-bg-gray-50\">\r\n <div class=\"tw-grid tw-grid-cols-1 md:tw-grid-cols-2 tw-gap-3 tw-p-4\">\r\n @for (theme of filteredThemes(); track theme._id) {\r\n <div class=\"tw-rounded-md tw-transition tw-cursor-pointer tw-relative\"\r\n [ngClass]=\"theme.sytm_isselected\r\n ? 'tw-border tw-border-blue-500 tw-ring-2 tw-ring-blue-200 tw-bg-blue-50/50'\r\n : 'tw-bg-white tw-border tw-border-gray-200 hover:tw-shadow-sm'\"\r\n (click)=\"editTheme(theme)\"\r\n role=\"button\"\r\n tabindex=\"0\"\r\n [attr.aria-selected]=\"theme.sytm_isselected ? 'true' : 'false'\"\r\n [attr.aria-label]=\"'Edit theme ' + (theme.sytm_title || theme.sytm_theme_code)\"\r\n (keydown.enter)=\"editTheme(theme)\"\r\n (keydown.space)=\"$event.preventDefault(); editTheme(theme)\">\r\n\r\n <!-- Selected badge -->\r\n <div *ngIf=\"theme.sytm_isselected\"\r\n class=\"tw-absolute tw-top-2 tw-right-2 tw-flex tw-items-center tw-justify-center tw-w-6 tw-h-6 tw-rounded-full tw-bg-blue-600 tw-text-white\">\r\n <cide-ele-icon class=\"tw-w-4 tw-h-4\">check</cide-ele-icon>\r\n </div>\r\n \r\n <div class=\"tw-aspect-[16/9] tw-bg-gray-100 tw-rounded-t-md tw-overflow-hidden tw-flex tw-items-center tw-justify-center\">\r\n @if (getPreviewUrl(theme)) {\r\n <img [src]=\"getPreviewUrl(theme)\" class=\"tw-w-full tw-h-full tw-object-cover\" alt=\"Preview\" />\r\n } @else {\r\n <div class=\"tw-text-gray-400 tw-text-xs\">No preview</div>\r\n }\r\n </div>\r\n <div class=\"tw-p-3 tw-space-y-1\">\r\n <div class=\"tw-text-sm tw-font-medium tw-text-gray-900 tw-truncate\" [title]=\"theme.sytm_title\">{{ theme.sytm_title || 'Untitled Theme' }}</div>\r\n <div class=\"tw-text-xs tw-text-gray-500 tw-truncate\" [title]=\"theme.sytm_theme_code\">{{ theme.sytm_theme_code }}</div>\r\n <div class=\"tw-flex tw-items-center tw-justify-between tw-pt-1\">\r\n <span class=\"tw-inline-flex tw-items-center tw-gap-1 tw-text-xs\" [ngClass]=\"theme.sytm_isactive ? 'tw-text-green-700' : 'tw-text-red-700'\">\r\n <span class=\"tw-w-1.5 tw-h-1.5 tw-rounded-full\" [ngClass]=\"theme.sytm_isactive ? 'tw-bg-green-500' : 'tw-bg-red-500'\"></span>\r\n {{ theme.sytm_isactive ? 'Active' : 'Inactive' }}\r\n </span>\r\n <div class=\"tw-flex tw-items-center tw-gap-1\">\r\n <!-- Set Selected Button - Clear and Simple -->\r\n @if (theme.sytm_isselected) {\r\n <span class=\"tw-inline-flex tw-items-center tw-gap-1 tw-px-2 tw-py-1 tw-bg-green-100 tw-text-green-800 tw-rounded-md tw-text-xs tw-font-medium\">\r\n <cide-ele-icon class=\"tw-w-3 tw-h-3\">check</cide-ele-icon>\r\n Selected\r\n </span>\r\n } @else {\r\n <button cideEleButton \r\n variant=\"outline\" \r\n size=\"xs\"\r\n (click)=\"$event.stopPropagation(); setSelectedTheme(theme)\"\r\n [attr.aria-label]=\"'Select ' + (theme.sytm_title || theme.sytm_theme_code) + ' theme'\"\r\n class=\"tw-text-xs\">\r\n Select\r\n </button>\r\n }\r\n <button cideEleButton variant=\"ghost\" size=\"xs\" (click)=\"$event.stopPropagation(); editTheme(theme)\"\r\n [attr.aria-label]=\"'Edit theme ' + (theme.sytm_title || theme.sytm_theme_code)\">\r\n <cide-ele-icon class=\"tw-w-4 tw-h-4\">edit</cide-ele-icon>\r\n </button>\r\n <button cideEleButton variant=\"ghost\" size=\"xs\" (click)=\"$event.stopPropagation(); deleteTheme(theme)\"\r\n [attr.aria-label]=\"'Delete theme ' + (theme.sytm_title || theme.sytm_theme_code)\">\r\n <cide-ele-icon class=\"tw-w-4 tw-h-4\">delete</cide-ele-icon>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n\r\n @if (!loading() && filteredThemes().length === 0) {\r\n <div class=\"tw-col-span-full tw-text-center tw-text-xs tw-text-gray-500 tw-py-8\">No themes found</div>\r\n }\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<!-- \r\n Angular Template References for Grid Renderers (Best Practice)\r\n \r\n These ng-template elements represent the Angular best practice for custom rendering.\r\n They provide:\r\n - Type safety with template context\r\n - Component lifecycle integration\r\n - Change detection optimization\r\n - Proper event handling\r\n - Accessibility features\r\n \r\n Note: Current data grid uses string renderers for compatibility.\r\n Templates are maintained for future component enhancement.\r\n-->\r\n\r\n<!-- Theme Details Renderer Template -->\r\n<ng-template #themeDetailsRendererTemplate let-row=\"row\" let-value=\"value\">\r\n <div class=\"tw-flex tw-items-center tw-min-w-0\">\r\n <!-- Theme Icon -->\r\n <div class=\"tw-flex-shrink-0\">\r\n <cide-ele-icon \r\n class=\"tw-text-purple-600\" \r\n size=\"xs\">\r\n palette\r\n </cide-ele-icon>\r\n </div>\r\n \r\n <!-- Theme Details -->\r\n <div class=\"tw-ml-3 tw-min-w-0 tw-flex-1\">\r\n <div class=\"tw-text-sm tw-font-medium tw-text-gray-900 tw-truncate\" \r\n [title]=\"row.sytm_title\">\r\n {{ row.sytm_title || 'Untitled' }}\r\n </div>\r\n @if (row.sytm_desc) {\r\n <div class=\"tw-text-xs tw-text-gray-500 tw-truncate\" \r\n [title]=\"row.sytm_desc\">\r\n {{ row.sytm_desc }}\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n<!-- Theme Status Renderer Template -->\r\n<ng-template #themeStatusRendererTemplate let-row=\"row\" let-value=\"value\">\r\n <span class=\"tw-inline-flex tw-items-center tw-px-2.5 tw-py-0.5 tw-rounded-full tw-text-xs tw-font-medium tw-whitespace-nowrap\"\r\n [ngClass]=\"row.sytm_isactive ? 'tw-bg-green-100 tw-text-green-800' : 'tw-bg-red-100 tw-text-red-800'\">\r\n {{ row.sytm_isactive ? 'Active' : 'Inactive' }}\r\n </span>\r\n</ng-template>\r\n\r\n<!-- Actions Dropdown Renderer Template -->\r\n<ng-template #actionsDropdownRendererTemplate let-row=\"row\" let-value=\"value\">\r\n <cide-ele-dropdown \r\n [items]=\"getActionDropdownItems(row)\"\r\n [config]=\"{ triggerIcon: 'more_vert', triggerSize: 'sm' }\"\r\n (itemClick)=\"onDropdownItemClick($event, row)\">\r\n </cide-ele-dropdown>\r\n</ng-template> " }]
|
|
766
|
-
}] });
|
|
767
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-theme.component.js","sourceRoot":"","sources":["../../../../../../../../projects/cloud-ide-core/src/lib/core/page-management/components/page-theme/page-theme.component.ts","../../../../../../../../projects/cloud-ide-core/src/lib/core/page-management/components/page-theme/page-theme.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, signal, computed, viewChild, TemplateRef, DestroyRef, inject, OnInit } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { Validators, ReactiveFormsModule, NonNullableFormBuilder, FormsModule, FormArray, FormGroup } from '@angular/forms';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\n\nimport { PageThemeService } from '../../services/page-theme.service';\nimport { AppStateHelperService } from 'cloud-ide-layout';\nimport { CideEleButtonComponent, CideEleDataGridComponent, CideIconComponent, CideInputComponent, CideSelectComponent, CideTextareaComponent, GridConfiguration, GridEvent, CideEleDropdownComponent, DropdownItem, CideEleJsonEditorComponent, CideSelectOptionComponent } from 'cloud-ide-element';\nimport { TemplateContext } from 'cloud-ide-element';\nimport { ICoreSytm, MSystemPagesThemeInsertUpdatePayload, ICoreSythDrawer, MSystemPagesTheme, generateObjectFromString } from 'cloud-ide-lms-model';\n\n@Component({\n  selector: 'cide-core-app-page-theme',\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    FormsModule,\n    CideEleDataGridComponent,\n    CideEleButtonComponent,\n    CideInputComponent,\n    CideSelectComponent,\n    CideTextareaComponent,\n    CideIconComponent,\n    CideEleDropdownComponent,\n    CideEleJsonEditorComponent,\n    CideSelectOptionComponent\n],\n  templateUrl: './page-theme.component.html',\n  styleUrls: []\n})\nexport class PageThemeComponent implements OnInit {\n  // Dependency injection\n  private destroyRef = inject(DestroyRef);\n  private themeService = inject(PageThemeService);\n  private appState = inject(AppStateHelperService);\n  private fb = inject(NonNullableFormBuilder);\n  private router = inject(Router);\n  private route = inject(ActivatedRoute);\n\n  // Modern ViewChild signals for template renderers (Angular 20 approach)\n  themeDetailsRendererTemplate = viewChild.required<TemplateRef<TemplateContext<Record<string, unknown>>>>('themeDetailsRendererTemplate');\n  themeStatusRendererTemplate = viewChild.required<TemplateRef<TemplateContext<Record<string, unknown>>>>('themeStatusRendererTemplate');\n  actionsDropdownRendererTemplate = viewChild.required<TemplateRef<TemplateContext<Record<string, unknown>>>>('actionsDropdownRendererTemplate');\n\n  // Make Math available in template\n  Math = Math;\n\n  // Signals for reactive state management\n  themes = signal<ICoreSytm[]>([]);\n  loading = signal(false);\n  error = signal<string | null>(null);\n  selectedItems = signal<string[]>([]);\n  searchTerm = signal('');\n\n  // Derived list filtered by searchTerm\n  filteredThemes = computed(() => {\n    const q = (this.searchTerm() || '').toLowerCase().trim();\n    const items = this.themes() || [];\n    if (!q) return items;\n    return items.filter(t => {\n      const title = (t.sytm_title || '').toLowerCase();\n      const code = (t.sytm_theme_code || '').toLowerCase();\n      const desc = (t.sytm_desc || '').toLowerCase();\n      return title.includes(q) || code.includes(q) || desc.includes(q);\n    });\n  });\n\n  // Helper to resolve preview image URL safely\n  getPreviewUrl(theme: ICoreSytm): string {\n    const id = theme?.sytm_preview_id_fm || '';\n    if (!id) return '';\n\n    type WithPreviewUrl = { getPreviewUrl: (pid: string) => string };\n    const svcUnknown: unknown = this.themeService;\n\n    const hasGetPreviewUrl = (svc: unknown): svc is WithPreviewUrl =>\n      typeof svc === 'object' && svc !== null &&\n      'getPreviewUrl' in (svc as Record<string, unknown>) &&\n      typeof (svc as Record<string, unknown>)['getPreviewUrl'] === 'function';\n\n    if (hasGetPreviewUrl(svcUnknown)) {\n      return svcUnknown.getPreviewUrl(id);\n    }\n    return '';\n  }\n\n  // Input handler to avoid $any casts in template\n  onGallerySearchInput(event: Event): void {\n    const target = event.target as HTMLInputElement | null;\n    this.searchTerm.set(target?.value ?? '');\n  }\n\n  // Page information\n  pageId = signal<string>('');\n  pageTitle = signal<string>('');\n\n  // Form state\n  isEditMode = signal(false);\n  editingThemeId = signal<string | null>(null);\n  retrievedTheme = signal<ICoreSytm | null>(null);\n\n  // Pagination signals\n  currentPage = signal(1);\n  pageSize = signal(10);\n  totalItems = signal(0);\n\n  // Modern reactive forms with signals\n  themeForm = this.fb.group({\n    sytm_title: ['', [Validators.required]],\n    sytm_desc: [''],\n    sytm_theme_code: ['', [Validators.required]],\n    sytm_preview_id_fm: [''],\n    sytm_sub_title: [''],\n    sytm_configuration: ['{}'],\n    sytm_entity_id_syen: [''],\n    sytm_isselected: [false],\n    sytm_layout: this.fb.group({\n      sytm_layout_sidebar: this.fb.group({ status: [true] }),\n      sytm_layout_header: this.fb.group({ status: [true] }),\n      sytm_layout_footer: this.fb.group({ status: [false] }),\n      sytm_layout_breadcrumb: this.fb.group({ status: [true] }),\n      sytm_layout_console: this.fb.group({ status: [false] }),\n      sytm_layout_request: this.fb.group({ status: [false] }),\n      sytm_layout_drawer: this.fb.array([] as ICoreSythDrawer[])\n    }),\n    sytm_isactive: [true]\n  });\n\n  // Computed values\n  isFormDirty = computed(() => this.themeForm.dirty);\n\n  // Multi-select options for layout sections\n  layoutOptions = [\n    { value: 'sidebar', label: 'Sidebar' },\n    { value: 'header', label: 'Header' },\n    { value: 'footer', label: 'Footer' },\n    { value: 'breadcrumb', label: 'Breadcrumb' },\n    { value: 'console', label: 'Console' },\n    { value: 'request', label: 'Request' }\n  ] as const;\n\n  // Read enabled selections from form values\n  enabledLayoutSelections(): string[] {\n    const layout = this.themeForm.get('sytm_layout');\n    if (!layout) return [];\n    const selections: string[] = [];\n\n    const getBool = (path: string) => Boolean(this.themeForm.get(path)?.value);\n\n    if (getBool('sytm_layout.sytm_layout_sidebar.status')) selections.push('sidebar');\n    if (getBool('sytm_layout.sytm_layout_header.status')) selections.push('header');\n    if (getBool('sytm_layout.sytm_layout_footer.status')) selections.push('footer');\n    if (getBool('sytm_layout.sytm_layout_breadcrumb.status')) selections.push('breadcrumb');\n    if (getBool('sytm_layout.sytm_layout_console.status')) selections.push('console');\n    if (getBool('sytm_layout.sytm_layout_request.status')) selections.push('request');\n\n    return selections;\n  }\n\n  // Update form booleans from multi-select change\n  onEnabledLayoutChange(values: string[]): void {\n    const setBool = (path: string, val: boolean) => this.themeForm.get(path)?.setValue(val);\n\n    const selected = new Set(values);\n    setBool('sytm_layout.sytm_layout_sidebar.status', selected.has('sidebar'));\n    setBool('sytm_layout.sytm_layout_header.status', selected.has('header'));\n    setBool('sytm_layout.sytm_layout_footer.status', selected.has('footer'));\n    setBool('sytm_layout.sytm_layout_breadcrumb.status', selected.has('breadcrumb'));\n    setBool('sytm_layout.sytm_layout_console.status', selected.has('console'));\n    setBool('sytm_layout.sytm_layout_request.status', selected.has('request'));\n  }\n\n  // Grid configuration signal\n  gridConfig = signal<GridConfiguration<ICoreSytm>>({\n    id: 'theme-list-grid',\n    title: '',\n    subtitle: '',\n    columns: [\n      {\n        key: 'details',\n        header: 'Theme Details',\n        type: 'custom',\n        width: 'auto',\n        truncate: true,\n        align: 'left',\n        renderer: 'themeDetailsRenderer'\n      },\n      {\n        key: 'sytm_theme_code',\n        header: 'Theme Code',\n        type: 'text',\n        width: '150px',\n        truncate: true,\n        align: 'left'\n      },\n      {\n        key: 'sytm_isactive',\n        header: 'Status',\n        type: 'custom',\n        width: '100px',\n        truncate: false,\n        align: 'center',\n        renderer: 'themeStatusRenderer'\n      },\n      {\n        key: 'actions',\n        header: '',\n        type: 'custom',\n        width: '120px',\n        truncate: false,\n        align: 'center',\n        renderer: 'actionsDropdownRenderer'\n      }\n    ],\n    data: [],\n    trackBy: '_id',\n    pagination: {\n      enabled: true,\n      pageSize: 10,\n      pageSizeOptions: [10, 25, 50, 100],\n      showQuickJump: true,\n      showPageInfo: true,\n      showRefresh: true\n    },\n    search: {\n      enabled: true,\n      placeholder: 'Search themes...',\n      searchableColumns: ['sytm_title', 'sytm_desc', 'sytm_theme_code'],\n      debounceMs: 300\n    },\n    loading: {\n      useDefer: true,\n      skeletonRows: 5,\n      showOverlay: false\n    },\n    scroll: {\n      enabled: true,\n      maxHeight: '',\n      minHeight: '',\n      stickyHeader: true,\n      virtualScroll: false,\n      rowHeight: 50\n    },\n    responsive: true,\n    striped: false,\n    bordered: true,\n    compact: false,\n    tableClass: 'tw-table-fixed tw-w-full tw-rounded-none'\n  });\n\n  // Action handlers for grid\n  actionHandlers = {\n    onEdit: (item: ICoreSytm) => this.editTheme(item),\n    onDelete: (item: ICoreSytm) => this.deleteTheme(item),\n    onToggleStatus: (item: ICoreSytm) => this.toggleThemeStatus(item)\n  };\n\n  ngOnInit(): void {\n    this.initializeComponent();\n  }\n\n  /**\n   * Initialize component\n   */\n  private initializeComponent(): void {\n    // Get page information from route\n    this.route.params.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(params => {\n      console.log('🔍 Query params:', params);\n      const queryParams = params['query'];\n      const queryData = generateObjectFromString(queryParams);\n\n      this.pageId.set(queryData?.sypg_id || '');\n      this.pageTitle.set(queryData?.sypg_title || '');\n\n      if (this.pageId()) {\n        this.loadThemes();\n        this.setupFormSubscriptions();\n      } else {\n        this.error.set('No page ID provided');\n      }\n    });\n  }\n\n  /**\n   * Load themes from API\n   */\n  private loadThemes(): void {\n    this.loading.set(true);\n    this.error.set(null);\n\n    const request: MSystemPagesTheme = {\n      sytm_page_id_sypg: this.pageId()\n    };\n\n    this.themeService.getThemeList(request)\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe({\n        next: (response) => {\n          if (response.success) {\n            this.themes.set(response.data || []);\n            this.totalItems.set(response.total || 0);\n            this.updateGridData();\n          } else {\n            this.error.set(response.message || 'Failed to load themes');\n          }\n          this.loading.set(false);\n        },\n        error: (error) => {\n          console.error('Error loading themes:', error);\n          this.error.set('Failed to load themes. Please try again.');\n          this.loading.set(false);\n        }\n      });\n  }\n\n  /**\n   * Setup form subscriptions\n   */\n  private setupFormSubscriptions(): void {\n    // Watch for form changes to enable/disable save button\n    this.themeForm.valueChanges\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe(() => {\n        // Form validation is handled by computed signals\n      });\n  }\n\n  /**\n   * Update grid data\n   */\n  private updateGridData(): void {\n    this.gridConfig.update(config => ({\n      ...config,\n      data: this.themes()\n    }));\n  }\n\n  /**\n   * Get custom renderers for grid\n   */\n\n\n  /**\n   * Get template renderers for grid\n   */\n  getTemplateRenderers(): Record<string, TemplateRef<TemplateContext>> {\n    return {\n      themeDetailsRenderer: this.themeDetailsRendererTemplate(),\n      themeStatusRenderer: this.themeStatusRendererTemplate(),\n      actionsDropdownRenderer: this.actionsDropdownRendererTemplate()\n    };\n  }\n\n  /**\n   * Handle grid events\n   */\n  onGridEvent(event: GridEvent<ICoreSytm>): void {\n    switch (event.type) {\n      case 'pageChange':\n        if (event.data && typeof event.data === 'object' && 'pageIndex' in event.data && 'pageSize' in event.data) {\n          this.currentPage.set(event.data['pageIndex'] as number);\n          this.pageSize.set(event.data['pageSize'] as number);\n          this.loadThemes();\n        }\n        break;\n      case 'search':\n        if (event.data && typeof event.data === 'string') {\n          this.searchTerm.set(event.data);\n          this.currentPage.set(1);\n          this.loadThemes();\n        }\n        break;\n      case 'refresh':\n        this.loadThemes();\n        break;\n      case 'action':\n        // Handle action events if needed\n        console.log('Action event:', event);\n        break;\n      case 'rowClick':\n        // Handle row click events if needed\n        console.log('Row click event:', event);\n        break;\n      case 'sort':\n        // Handle sort events if needed\n        console.log('Sort event:', event);\n        break;\n      case 'export':\n        // Handle export events if needed\n        console.log('Export event:', event);\n        break;\n      case 'rowReorder':\n        // Handle row reorder events if needed\n        console.log('Row reorder event:', event);\n        break;\n    }\n  }\n\n  /**\n   * Create new theme\n   */\n  createTheme(): void {\n    if (!this.themeForm.valid) {\n      this.markFormAsTouched();\n      return;\n    }\n\n    const formValue = this.themeForm.getRawValue();\n    const newTheme: MSystemPagesThemeInsertUpdatePayload = {\n      sytm_title: formValue.sytm_title,\n      sytm_desc: formValue.sytm_desc,\n      sytm_theme_code: formValue.sytm_theme_code,\n      sytm_preview_id_fm: formValue.sytm_preview_id_fm,\n      sytm_page_id_sypg: this.pageId(),\n      sytm_configuration: JSON.parse(formValue.sytm_configuration),\n      sytm_sub_title: formValue.sytm_sub_title,\n      sytm_entity_id_syen: formValue.sytm_entity_id_syen || this.appState.getActiveEntityId(),\n      sytm_isselected: Boolean(formValue.sytm_isselected),\n      sytm_layout: {\n        sytm_layout_sidebar: { status: Boolean(formValue.sytm_layout.sytm_layout_sidebar.status) },\n        sytm_layout_header: { status: Boolean(formValue.sytm_layout.sytm_layout_header.status) },\n        sytm_layout_footer: { status: Boolean(formValue.sytm_layout.sytm_layout_footer.status) },\n        sytm_layout_breadcrumb: { status: Boolean(formValue.sytm_layout.sytm_layout_breadcrumb.status) },\n        sytm_layout_console: { status: Boolean(formValue.sytm_layout.sytm_layout_console.status) },\n        sytm_layout_request: { status: Boolean(formValue.sytm_layout.sytm_layout_request.status) },\n        sytm_layout_drawer: formValue.sytm_layout.sytm_layout_drawer as ICoreSythDrawer[]\n      },\n      sytm_isactive: formValue.sytm_isactive\n    };\n\n    this.loading.set(true);\n    this.themeService.createTheme(newTheme)\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe({\n        next: (response) => {\n          if (response.success) {\n            this.resetForm();\n            this.loadThemes();\n            console.log('✅ Theme created successfully');\n          } else {\n            console.error('❌ Failed to create theme:', response.message);\n          }\n          this.loading.set(false);\n        },\n        error: (error) => {\n          console.error('Error creating theme:', error);\n          console.error('❌ Failed to create theme. Please try again.');\n          this.loading.set(false);\n        }\n      });\n  }\n\n  /**\n   * Update existing theme\n   */\n  updateTheme(): void {\n    if (!this.themeForm.valid || !this.editingThemeId()) {\n      this.markFormAsTouched();\n      return;\n    }\n\n    const formValue = this.themeForm.getRawValue();\n    const updatedTheme: MSystemPagesThemeInsertUpdatePayload = {\n      _id: this.editingThemeId() || '',\n      sytm_title: formValue.sytm_title,\n      sytm_desc: formValue.sytm_desc,\n      sytm_theme_code: formValue.sytm_theme_code,\n      sytm_preview_id_fm: formValue.sytm_preview_id_fm,\n      sytm_page_id_sypg: this.pageId(),\n      sytm_configuration: JSON.parse(formValue.sytm_configuration),\n      sytm_sub_title: formValue.sytm_sub_title,\n      sytm_entity_id_syen: formValue.sytm_entity_id_syen || this.appState.getActiveEntityId(),\n      sytm_isselected: Boolean(formValue.sytm_isselected),\n      sytm_layout: {\n        sytm_layout_sidebar: { status: Boolean(formValue.sytm_layout.sytm_layout_sidebar.status) },\n        sytm_layout_header: { status: Boolean(formValue.sytm_layout.sytm_layout_header.status) },\n        sytm_layout_footer: { status: Boolean(formValue.sytm_layout.sytm_layout_footer.status) },\n        sytm_layout_breadcrumb: { status: Boolean(formValue.sytm_layout.sytm_layout_breadcrumb.status) },\n        sytm_layout_console: { status: Boolean(formValue.sytm_layout.sytm_layout_console.status) },\n        sytm_layout_request: { status: Boolean(formValue.sytm_layout.sytm_layout_request.status) },\n        sytm_layout_drawer: formValue.sytm_layout.sytm_layout_drawer as ICoreSythDrawer[]\n      },\n      sytm_isactive: formValue.sytm_isactive\n    };\n\n    this.loading.set(true);\n    this.themeService.updateTheme(updatedTheme)\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe({\n        next: (response) => {\n          if (response.success) {\n            this.resetForm();\n            this.loadThemes();\n            console.log('✅ Theme updated successfully');\n          } else {\n            console.error('❌ Failed to update theme:', response.message);\n          }\n          this.loading.set(false);\n        },\n        error: (error) => {\n          console.error('Error updating theme:', error);\n          console.error('❌ Failed to update theme. Please try again.');\n          this.loading.set(false);\n        }\n      });\n  }\n\n  /**\n   * Edit theme\n   */\n  editTheme(theme: ICoreSytm): void {\n    this.isEditMode.set(true);\n    this.editingThemeId.set(theme._id || null);\n    this.retrievedTheme.set(theme);\n\n    this.themeForm.patchValue({\n      sytm_title: theme.sytm_title || '',\n      sytm_desc: theme.sytm_desc || '',\n      sytm_theme_code: theme.sytm_theme_code || '',\n      sytm_preview_id_fm: theme.sytm_preview_id_fm || '',\n      sytm_sub_title: theme.sytm_sub_title || '',\n      sytm_configuration: JSON.stringify(theme.sytm_configuration || {}, null, 2),\n      sytm_entity_id_syen: theme.sytm_entity_id_syen || this.appState.getActiveEntityId(),\n      sytm_isselected: theme.sytm_isselected ?? false,\n      sytm_layout: {\n        sytm_layout_sidebar: { status: theme.sytm_layout?.sytm_layout_sidebar?.status ?? true },\n        sytm_layout_header: { status: theme.sytm_layout?.sytm_layout_header?.status ?? true },\n        sytm_layout_footer: { status: theme.sytm_layout?.sytm_layout_footer?.status ?? false },\n        sytm_layout_breadcrumb: { status: theme.sytm_layout?.sytm_layout_breadcrumb?.status ?? true },\n        sytm_layout_console: { status: theme.sytm_layout?.sytm_layout_console?.status ?? false },\n        sytm_layout_request: { status: theme.sytm_layout?.sytm_layout_request?.status ?? false },\n        sytm_layout_drawer: theme.sytm_layout?.sytm_layout_drawer || []\n      },\n      sytm_isactive: theme.sytm_isactive ?? true\n    });\n\n    // Rebuild drawer array controls from data\n    while (this.drawerArray.length) {\n      this.drawerArray.removeAt(0);\n    }\n    (theme.sytm_layout?.sytm_layout_drawer || []).forEach(d => {\n      this.drawerArray.push(this.createDrawerGroup({\n        syth_status: d?.syth_status ?? true,\n        syth_config_syco_for: d?.syth_config_syco_for ?? 'drawer_notes'\n      }));\n    });\n\n    this.themeForm.markAsPristine();\n  }\n\n  /**\n   * Delete theme\n   */\n  deleteTheme(theme: ICoreSytm): void {\n    if (confirm(`Are you sure you want to delete the theme \"${theme.sytm_title}\"?`)) {\n      this.loading.set(true);\n      this.themeService.deleteTheme(theme._id || '')\n        .pipe(takeUntilDestroyed(this.destroyRef))\n        .subscribe({\n          next: (response) => {\n            if (response.success) {\n              this.loadThemes();\n              console.log('✅ Theme deleted successfully');\n            } else {\n              console.error('❌ Failed to delete theme:', response.message);\n            }\n            this.loading.set(false);\n          },\n          error: (error) => {\n            console.error('Error deleting theme:', error);\n            console.error('❌ Failed to delete theme. Please try again.');\n            this.loading.set(false);\n          }\n        });\n    }\n  }\n\n  /**\n   * Toggle theme status\n   */\n  toggleThemeStatus(theme: ICoreSytm): void {\n    this.loading.set(true);\n    this.themeService.toggleThemeStatus({ sytm_id: theme._id || '', sytm_isactive: !theme.sytm_isactive })\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe({\n        next: (response) => {\n          if (response.success) {\n            this.loadThemes();\n            console.log(`✅ Theme ${theme.sytm_isactive ? 'deactivated' : 'activated'} successfully`);\n          } else {\n            console.error('❌ Failed to toggle theme status:', response.message);\n          }\n          this.loading.set(false);\n        },\n        error: (error) => {\n          console.error('Error toggling theme status:', error);\n          console.error('❌ Failed to toggle theme status. Please try again.');\n          this.loading.set(false);\n        }\n      });\n  }\n\n  /**\n   * Save theme (create or update)\n   */\n  saveTheme(): void {\n    if (this.isEditMode()) {\n      this.updateTheme();\n    } else {\n      this.createTheme();\n    }\n  }\n\n  /**\n   * Cancel form\n   */\n  cancelForm(): void {\n    this.resetForm();\n  }\n\n  /**\n   * Go back to page list\n   */\n  goBack(): void {\n    this.router.navigate(['/core/page']);\n  }\n\n  /**\n   * Reset form\n   */\n  private resetForm(): void {\n    this.themeForm.reset({\n      sytm_title: '',\n      sytm_desc: '',\n      sytm_theme_code: '',\n      sytm_preview_id_fm: '',\n      sytm_sub_title: '',\n      sytm_configuration: '{}',\n      sytm_entity_id_syen: '',\n      sytm_isselected: false,\n      sytm_layout: {\n        sytm_layout_sidebar: { status: true },\n        sytm_layout_header: { status: true },\n        sytm_layout_footer: { status: false },\n        sytm_layout_breadcrumb: { status: true },\n        sytm_layout_console: { status: false },\n        sytm_layout_request: { status: false },\n        sytm_layout_drawer: [] as ICoreSythDrawer[]\n      },\n      sytm_isactive: true\n    });\n\n    // Explicitly clear the FormArray for drawers\n    while (this.drawerArray.length) {\n      this.drawerArray.removeAt(0);\n    }\n\n    this.isEditMode.set(false);\n    this.editingThemeId.set(null);\n    this.retrievedTheme.set(null);\n    this.themeForm.markAsPristine();\n    this.themeForm.markAsUntouched();\n  }\n\n  /**\n   * Mark form as touched to trigger validation display\n   */\n  private markFormAsTouched(): void {\n    Object.keys(this.themeForm.controls).forEach(key => {\n      const control = this.themeForm.get(key);\n      control?.markAsTouched();\n    });\n  }\n\n  /**\n   * Get dropdown items for actions\n   */\n  getActionDropdownItems(theme: ICoreSytm): DropdownItem[] {\n    return [\n      {\n        id: 'edit',\n        label: 'Edit',\n        icon: 'edit',\n        disabled: false\n      },\n      {\n        id: 'toggle',\n        label: theme.sytm_isactive ? 'Deactivate' : 'Activate',\n        icon: theme.sytm_isactive ? 'block' : 'check_circle',\n        disabled: false\n      },\n      {\n        id: 'delete',\n        label: 'Delete',\n        icon: 'delete',\n        disabled: false\n      }\n    ];\n  }\n\n  /**\n   * Handle dropdown item click\n   * This method handles clicks on dropdown menu items in the actions column\n   */\n  onDropdownItemClick(item: DropdownItem, row: ICoreSytm): void {\n    console.log('🔵 onDropdownItemClick called with:', item, row);\n\n    switch (item.id) {\n      case 'edit':\n        console.log('🔵 Calling editTheme with:', row);\n        this.editTheme(row);\n        break;\n      case 'toggle':\n        console.log('🔵 Calling toggleThemeStatus with:', row);\n        this.toggleThemeStatus(row);\n        break;\n      case 'delete':\n        console.log('🔵 Calling deleteTheme with:', row);\n        this.deleteTheme(row);\n        break;\n      default:\n        console.log('🔵 Unknown action:', item.id);\n    }\n\n    // Close all dropdowns after action\n    this.closeAllDropdowns();\n  }\n\n  /**\n   * Close all dropdowns\n   */\n  private closeAllDropdowns(): void {\n    // Close all dropdowns by clicking outside\n    const event = new MouseEvent('click', { bubbles: true });\n    document.dispatchEvent(event);\n  }\n\n  // ===== Drawer (sytm_layout_drawer) helpers =====\n  drawerConfigOptions = [\n    { value: 'drawer_notes', label: 'Drawer Notes' },\n    { value: 'drawer_theme', label: 'Drawer Theme' }\n  ];\n\n  get drawerArray(): FormArray<FormGroup> {\n    return this.themeForm.get('sytm_layout.sytm_layout_drawer') as unknown as FormArray<FormGroup>;\n  }\n\n  private createDrawerGroup(drawer?: Partial<ICoreSythDrawer>): FormGroup {\n    return this.fb.group({\n      syth_status: [drawer?.syth_status ?? true],\n      syth_config_syco_for: [drawer?.syth_config_syco_for ?? 'drawer_notes']\n    }) as unknown as FormGroup;\n  }\n\n  addDrawer(): void {\n    this.drawerArray.push(this.createDrawerGroup());\n    this.themeForm.markAsDirty();\n  }\n\n  removeDrawer(index: number): void {\n    if (index >= 0 && index < this.drawerArray.length) {\n      this.drawerArray.removeAt(index);\n      this.themeForm.markAsDirty();\n    }\n  }\n\n  /**\n   * Set selected theme (only one can be selected per page)\n   */\n  setSelectedTheme(theme: ICoreSytm): void {\n    if (!theme || theme.sytm_isselected) return; // already selected\n\n    const previouslySelected = this.themes().find(t => t.sytm_isselected && t._id !== theme._id);\n\n    // Disable previous selection (best-effort)\n    if (previouslySelected) {\n      const disablePayload: MSystemPagesThemeInsertUpdatePayload = {\n        _id: previouslySelected._id || '',\n        sytm_title: previouslySelected.sytm_title || '',\n        sytm_desc: previouslySelected.sytm_desc || '',\n        sytm_theme_code: previouslySelected.sytm_theme_code || '',\n        sytm_preview_id_fm: previouslySelected.sytm_preview_id_fm || '',\n        sytm_page_id_sypg: this.pageId(),\n        sytm_configuration: previouslySelected.sytm_configuration || {},\n        sytm_sub_title: previouslySelected.sytm_sub_title || '',\n        sytm_entity_id_syen: previouslySelected.sytm_entity_id_syen || this.appState.getActiveEntityId(),\n        sytm_isselected: false,\n        sytm_layout: previouslySelected.sytm_layout,\n        sytm_isactive: previouslySelected.sytm_isactive ?? true\n      };\n      this.themeService.updateTheme(disablePayload).pipe(takeUntilDestroyed(this.destroyRef)).subscribe({ next: () => {}, error: () => {} });\n    }\n\n    // Enable current selection\n    const enablePayload: MSystemPagesThemeInsertUpdatePayload = {\n      _id: theme._id || '',\n      sytm_title: theme.sytm_title || '',\n      sytm_desc: theme.sytm_desc || '',\n      sytm_theme_code: theme.sytm_theme_code || '',\n      sytm_preview_id_fm: theme.sytm_preview_id_fm || '',\n      sytm_page_id_sypg: this.pageId(),\n      sytm_configuration: theme.sytm_configuration || {},\n      sytm_sub_title: theme.sytm_sub_title || '',\n      sytm_entity_id_syen: theme.sytm_entity_id_syen || this.appState.getActiveEntityId(),\n      sytm_isselected: true,\n      sytm_layout: theme.sytm_layout,\n      sytm_isactive: theme.sytm_isactive ?? true\n    };\n\n    this.loading.set(true);\n    this.themeService.updateTheme(enablePayload)\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe({\n        next: () => { this.loadThemes(); this.loading.set(false); },\n        error: () => { this.loading.set(false); }\n      });\n  }\n}","<!-- Page Theme Container -->\r\n<div class=\"tw-flex tw-h-full tw-w-full\">\r\n  \r\n  <!-- Left: Form and header (60%) -->\r\n  <div class=\"tw-w-full lg:tw-w-3/5 tw-flex tw-flex-col tw-border-r tw-border-gray-200\">\r\n\r\n  <!-- Header Section -->\r\n    <div class=\"tw-px-6 tw-py-3 tw-border-b tw-border-gray-200 tw-bg-gray-50\">\r\n      <div class=\"tw-flex tw-flex-col sm:tw-flex-row tw-justify-between tw-items-start sm:tw-items-center tw-space-y-3 sm:tw-space-y-0\">\r\n\r\n      <!-- Title and Back Button -->\r\n      <div class=\"tw-flex tw-items-center tw-space-x-4\">\r\n          <button cideEleButton variant=\"ghost\" size=\"sm\" (click)=\"goBack()\" class=\"tw-text-gray-600 hover:tw-text-gray-900\">\r\n          <cide-ele-icon class=\"tw-w-4 tw-h-4\">arrow_back</cide-ele-icon>\r\n        </button>\r\n        <div class=\"tw-flex tw-items-center tw-space-x-2\">\r\n          <cide-ele-icon class=\"tw-text-blue-600 tw-w-5 tw-h-5\">palette</cide-ele-icon>\r\n          <div>\r\n            <h5 class=\"tw-text-base tw-font-medium tw-text-gray-900 tw-m-0\">Theme Management</h5>\r\n            <p class=\"tw-text-sm tw-text-gray-500 tw-m-0\">Page: {{ pageTitle() }}</p>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n    <!-- Error Message -->\r\n    @if (error()) {\r\n    <div class=\"tw-mt-4 tw-p-4 tw-bg-red-50 tw-border tw-border-red-200 tw-rounded-md\">\r\n      <div class=\"tw-flex tw-items-start\">\r\n        <cide-ele-icon name=\"error\" class=\"tw-text-red-400 tw-w-5 tw-h-5 tw-mt-0.5 tw-flex-shrink-0\"></cide-ele-icon>\r\n        <div class=\"tw-ml-3\">\r\n          <h3 class=\"tw-text-sm tw-font-medium tw-text-red-800 tw-m-0\">Error</h3>\r\n          <p class=\"tw-text-sm tw-text-red-700 tw-mt-1 tw-m-0\">{{ error() }}</p>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    }\r\n  </div>\r\n\r\n    <!-- Quick Add/Edit Form Section -->\r\n    <div class=\"tw-px-6 tw-py-4 tw-bg-white tw-overflow-auto\">\r\n    <div class=\"tw-flex tw-items-center tw-justify-between tw-mb-3\">\r\n      <div class=\"tw-flex tw-items-center tw-space-x-3\">\r\n        <cide-ele-icon class=\"tw-text-blue-600 tw-w-5 tw-h-5\">{{ isEditMode() ? 'edit' : 'add' }}</cide-ele-icon>\r\n        <h6 class=\"tw-text-sm tw-font-medium tw-text-gray-900 tw-m-0\">{{ isEditMode() ? 'Edit Theme' : 'Quick Add Theme' }}</h6>\r\n      </div>\r\n    </div>\r\n\r\n      <!-- Form (kept as-is) -->\r\n    <form [formGroup]=\"themeForm\" (ngSubmit)=\"saveTheme()\" class=\"tw-space-y-4\">\r\n      <div class=\"tw-grid tw-grid-cols-1 md:tw-grid-cols-2 lg:tw-grid-cols-3 tw-gap-4\">\r\n        <!-- Theme Title -->\r\n        <div class=\"tw-space-y-2\">\r\n            <cide-ele-input id=\"sytm_title\" formControlName=\"sytm_title\" placeholder=\"Enter theme title\" label=\"Theme Title*\" size=\"sm\"></cide-ele-input>\r\n        </div>\r\n        <!-- Theme Code -->\r\n        <div class=\"tw-space-y-2\">\r\n            <cide-ele-input id=\"sytm_theme_code\" formControlName=\"sytm_theme_code\" placeholder=\"Enter theme code\" label=\"Theme Code*\" size=\"sm\"></cide-ele-input>\r\n        </div>\r\n        <!-- Status -->\r\n        <div class=\"tw-space-y-2\">\r\n            <cide-ele-input\r\n              id=\"sytm_isactive_cb\"\r\n              type=\"checkbox\"\r\n              label=\"Active\"\r\n            size=\"sm\"\r\n              formControlName=\"sytm_isactive\">\r\n            </cide-ele-input>\r\n        </div>\r\n        <!-- Sub Title -->\r\n        <div class=\"tw-space-y-2\">\r\n            <cide-ele-input id=\"sytm_sub_title\" formControlName=\"sytm_sub_title\" placeholder=\"Enter sub title\" label=\"Sub Title\" size=\"sm\"></cide-ele-input>\r\n        </div>\r\n        <!-- Preview ID -->\r\n        <div class=\"tw-space-y-2\">\r\n            <cide-ele-input id=\"sytm_preview_id_fm\" formControlName=\"sytm_preview_id_fm\" placeholder=\"Enter preview image ID\" label=\"Preview Image ID\" size=\"sm\"></cide-ele-input>\r\n        </div>\r\n        <!-- Description -->\r\n        <div class=\"tw-space-y-2 md:tw-col-span-2\">\r\n            <cide-ele-textarea id=\"sytm_desc\" formControlName=\"sytm_desc\" placeholder=\"Enter theme description\" rows=\"2\" label=\"Description\" size=\"sm\"></cide-ele-textarea>\r\n        </div>\r\n                 <!-- Configuration JSON -->\r\n         <div class=\"tw-space-y-2 md:tw-col-span-3\">\r\n            <cide-ele-json-editor label=\"Configuration JSON\" formControlName=\"sytm_configuration\" [required]=\"true\" [config]=\"{\r\n               showLineNumbers: true,\r\n               autoFormat: true,\r\n               validateOnChange: true,\r\n               minHeight: 150,\r\n               maxHeight: 300,\r\n               placeholder: 'Enter theme configuration JSON...'\r\n              }\" helperText=\"Enter valid JSON configuration for the theme\"></cide-ele-json-editor>\r\n         </div>\r\n          <!-- Layout Configuration + Selection: right-side checkbox list -->\r\n          <div class=\"lg:tw-col-span-1 tw-space-y-2\">\r\n            <div class=\"tw-text-sm tw-font-medium tw-text-gray-700\">Layout & Selection</div>\r\n            <!-- Selected toggle -->\r\n            <div class=\"tw-bg-white tw-border tw-border-gray-200 tw-rounded-md tw-px-3 tw-py-2\">\r\n              <cide-ele-input\r\n                id=\"sytm_isselected\"\r\n                type=\"checkbox\"\r\n                label=\"Selected (Default)\"\r\n                  size=\"sm\"\r\n                formControlName=\"sytm_isselected\">\r\n              </cide-ele-input>\r\n              </div>\r\n            <div formGroupName=\"sytm_layout\" class=\"tw-bg-white tw-border tw-border-gray-200 tw-rounded-md tw-divide-y tw-overflow-hidden\">\r\n              <!-- Sidebar -->\r\n              <div class=\"tw-px-3 tw-py-2\" formGroupName=\"sytm_layout_sidebar\">\r\n                <cide-ele-input id=\"layout_sidebar_status\" type=\"checkbox\" label=\"Sidebar\" size=\"sm\" formControlName=\"status\"></cide-ele-input>\r\n            </div>\r\n            <!-- Header -->\r\n              <div class=\"tw-px-3 tw-py-2\" formGroupName=\"sytm_layout_header\">\r\n                <cide-ele-input id=\"layout_header_status\" type=\"checkbox\" label=\"Header\" size=\"sm\" formControlName=\"status\"></cide-ele-input>\r\n              </div>\r\n              <!-- Footer -->\r\n              <div class=\"tw-px-3 tw-py-2\" formGroupName=\"sytm_layout_footer\">\r\n                <cide-ele-input id=\"layout_footer_status\" type=\"checkbox\" label=\"Footer\" size=\"sm\" formControlName=\"status\"></cide-ele-input>\r\n              </div>\r\n              <!-- Breadcrumb -->\r\n              <div class=\"tw-px-3 tw-py-2\" formGroupName=\"sytm_layout_breadcrumb\">\r\n                <cide-ele-input id=\"layout_breadcrumb_status\" type=\"checkbox\" label=\"Breadcrumb\" size=\"sm\" formControlName=\"status\"></cide-ele-input>\r\n              </div>\r\n              <!-- Console -->\r\n              <div class=\"tw-px-3 tw-py-2\" formGroupName=\"sytm_layout_console\">\r\n                <cide-ele-input id=\"layout_console_status\" type=\"checkbox\" label=\"Console\" size=\"sm\" formControlName=\"status\"></cide-ele-input>\r\n            </div>\r\n              <!-- Request -->\r\n              <div class=\"tw-px-3 tw-py-2\" formGroupName=\"sytm_layout_request\">\r\n                <cide-ele-input id=\"layout_request_status\" type=\"checkbox\" label=\"Request\" size=\"sm\" formControlName=\"status\"></cide-ele-input>\r\n              </div>\r\n            </div>\r\n            <p class=\"tw-text-xs tw-text-gray-500 tw-pt-1\">Toggle active sections. Only one theme can be selected as default. More options can be added here later.</p>\r\n              </div>\r\n          <!-- Drawer Configuration -->\r\n          <div class=\"tw-space-y-2 md:tw-col-span-3\">\r\n            <div class=\"tw-flex tw-items-center tw-justify-between\">\r\n              <div class=\"tw-text-sm tw-font-medium tw-text-gray-700\">Drawers</div>\r\n              <button cideEleButton type=\"button\" size=\"xs\" variant=\"outline\" (click)=\"addDrawer()\">\r\n                Add Drawer\r\n              </button>\r\n            </div>\r\n\r\n            <div formGroupName=\"sytm_layout\">\r\n              <div class=\"tw-space-y-2\" formArrayName=\"sytm_layout_drawer\">\r\n                <div *ngFor=\"let drawerGrp of drawerArray.controls; let i = index\" [formGroupName]=\"i\" class=\"tw-border tw-border-gray-200 tw-rounded-md tw-p-3 tw-flex tw-items-center tw-gap-3\">\r\n                  <cide-ele-input id=\"drawer_active_{{i}}\" type=\"checkbox\" label=\"Active\" size=\"sm\" formControlName=\"syth_status\"></cide-ele-input>\r\n                  <div class=\"tw-flex-1\">\r\n                <cide-ele-select\r\n                      id=\"drawer_config_{{i}}\"\r\n                      label=\"Drawer For\"\r\n                  size=\"sm\"\r\n                      [options]=\"drawerConfigOptions\"\r\n                      formControlName=\"syth_config_syco_for\">\r\n                </cide-ele-select>\r\n              </div>\r\n                  <button cideEleButton type=\"button\" size=\"xs\" variant=\"ghost\" (click)=\"removeDrawer(i)\">\r\n                    <cide-ele-icon class=\"tw-w-4 tw-h-4\">delete</cide-ele-icon>\r\n                  </button>\r\n            </div>\r\n                <p class=\"tw-text-xs tw-text-gray-500\">Configure multiple drawers as needed.</p>\r\n              </div>\r\n            </div>\r\n          </div>\r\n      </div>\r\n\r\n      <!-- Form Actions -->\r\n        <div class=\"tw-flex tw-flex-col tw-gap-2 tw-pt-4 tw-border-t tw-border-gray-200\">\r\n          <div class=\"tw-flex tw-items-center tw-justify-end tw-space-x-3\">\r\n            <button cideEleButton type=\"button\" variant=\"outline\" (click)=\"cancelForm()\" [disabled]=\"loading()\">Cancel</button>\r\n            <button cideEleButton type=\"submit\" variant=\"primary\" leftIcon=\"add\" [disabled]=\"!themeForm.valid || loading()\" [loading]=\"loading()\">\r\n          {{ isEditMode() ? 'Update Theme' : 'Create Theme' }}\r\n        </button>\r\n          </div>\r\n      </div>\r\n    </form>\r\n    </div>\r\n  </div>\r\n\r\n  <!-- Right: Theme gallery (40%) -->\r\n  <div class=\"tw-hidden lg:tw-flex tw-w-2/5 tw-flex-col\">\r\n    <!-- (Header consolidated above) -->\r\n\r\n    <!-- Gallery list -->\r\n    <div class=\"tw-flex-1 tw-overflow-auto tw-bg-gray-50\">\r\n      <div class=\"tw-grid tw-grid-cols-1 md:tw-grid-cols-2 tw-gap-3 tw-p-4\">\r\n        @for (theme of filteredThemes(); track theme._id) {\r\n          <div class=\"tw-rounded-md tw-transition tw-cursor-pointer tw-relative\"\r\n               [ngClass]=\"theme.sytm_isselected\r\n                 ? 'tw-border tw-border-blue-500 tw-ring-2 tw-ring-blue-200 tw-bg-blue-50/50'\r\n                 : 'tw-bg-white tw-border tw-border-gray-200 hover:tw-shadow-sm'\"\r\n               (click)=\"editTheme(theme)\"\r\n               role=\"button\"\r\n               tabindex=\"0\"\r\n               [attr.aria-selected]=\"theme.sytm_isselected ? 'true' : 'false'\"\r\n               [attr.aria-label]=\"'Edit theme ' + (theme.sytm_title || theme.sytm_theme_code)\"\r\n               (keydown.enter)=\"editTheme(theme)\"\r\n               (keydown.space)=\"$event.preventDefault(); editTheme(theme)\">\r\n\r\n            <!-- Selected badge -->\r\n            <div *ngIf=\"theme.sytm_isselected\"\r\n                 class=\"tw-absolute tw-top-2 tw-right-2 tw-flex tw-items-center tw-justify-center tw-w-6 tw-h-6 tw-rounded-full tw-bg-blue-600 tw-text-white\">\r\n              <cide-ele-icon class=\"tw-w-4 tw-h-4\">check</cide-ele-icon>\r\n            </div>\r\n \r\n            <div class=\"tw-aspect-[16/9] tw-bg-gray-100 tw-rounded-t-md tw-overflow-hidden tw-flex tw-items-center tw-justify-center\">\r\n              @if (getPreviewUrl(theme)) {\r\n                <img [src]=\"getPreviewUrl(theme)\" class=\"tw-w-full tw-h-full tw-object-cover\" alt=\"Preview\" />\r\n              } @else {\r\n                <div class=\"tw-text-gray-400 tw-text-xs\">No preview</div>\r\n              }\r\n            </div>\r\n            <div class=\"tw-p-3 tw-space-y-1\">\r\n              <div class=\"tw-text-sm tw-font-medium tw-text-gray-900 tw-truncate\" [title]=\"theme.sytm_title\">{{ theme.sytm_title || 'Untitled Theme' }}</div>\r\n              <div class=\"tw-text-xs tw-text-gray-500 tw-truncate\" [title]=\"theme.sytm_theme_code\">{{ theme.sytm_theme_code }}</div>\r\n              <div class=\"tw-flex tw-items-center tw-justify-between tw-pt-1\">\r\n                <span class=\"tw-inline-flex tw-items-center tw-gap-1 tw-text-xs\" [ngClass]=\"theme.sytm_isactive ? 'tw-text-green-700' : 'tw-text-red-700'\">\r\n                  <span class=\"tw-w-1.5 tw-h-1.5 tw-rounded-full\" [ngClass]=\"theme.sytm_isactive ? 'tw-bg-green-500' : 'tw-bg-red-500'\"></span>\r\n                  {{ theme.sytm_isactive ? 'Active' : 'Inactive' }}\r\n                </span>\r\n                <div class=\"tw-flex tw-items-center tw-gap-1\">\r\n                  <!-- Set Selected Button - Clear and Simple -->\r\n                  @if (theme.sytm_isselected) {\r\n                    <span class=\"tw-inline-flex tw-items-center tw-gap-1 tw-px-2 tw-py-1 tw-bg-green-100 tw-text-green-800 tw-rounded-md tw-text-xs tw-font-medium\">\r\n                      <cide-ele-icon class=\"tw-w-3 tw-h-3\">check</cide-ele-icon>\r\n                      Selected\r\n                    </span>\r\n                  } @else {\r\n                    <button cideEleButton \r\n                            variant=\"outline\" \r\n                            size=\"xs\"\r\n                            (click)=\"$event.stopPropagation(); setSelectedTheme(theme)\"\r\n                            [attr.aria-label]=\"'Select ' + (theme.sytm_title || theme.sytm_theme_code) + ' theme'\"\r\n                            class=\"tw-text-xs\">\r\n                      Select\r\n                    </button>\r\n                  }\r\n                  <button cideEleButton variant=\"ghost\" size=\"xs\" (click)=\"$event.stopPropagation(); editTheme(theme)\"\r\n                          [attr.aria-label]=\"'Edit theme ' + (theme.sytm_title || theme.sytm_theme_code)\">\r\n                    <cide-ele-icon class=\"tw-w-4 tw-h-4\">edit</cide-ele-icon>\r\n                  </button>\r\n                  <button cideEleButton variant=\"ghost\" size=\"xs\" (click)=\"$event.stopPropagation(); deleteTheme(theme)\"\r\n                          [attr.aria-label]=\"'Delete theme ' + (theme.sytm_title || theme.sytm_theme_code)\">\r\n                    <cide-ele-icon class=\"tw-w-4 tw-h-4\">delete</cide-ele-icon>\r\n                  </button>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        }\r\n\r\n        @if (!loading() && filteredThemes().length === 0) {\r\n          <div class=\"tw-col-span-full tw-text-center tw-text-xs tw-text-gray-500 tw-py-8\">No themes found</div>\r\n        }\r\n  </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<!-- \r\n  Angular Template References for Grid Renderers (Best Practice)\r\n  \r\n  These ng-template elements represent the Angular best practice for custom rendering.\r\n  They provide:\r\n  - Type safety with template context\r\n  - Component lifecycle integration\r\n  - Change detection optimization\r\n  - Proper event handling\r\n  - Accessibility features\r\n  \r\n  Note: Current data grid uses string renderers for compatibility.\r\n  Templates are maintained for future component enhancement.\r\n-->\r\n\r\n<!-- Theme Details Renderer Template -->\r\n<ng-template #themeDetailsRendererTemplate let-row=\"row\" let-value=\"value\">\r\n  <div class=\"tw-flex tw-items-center tw-min-w-0\">\r\n    <!-- Theme Icon -->\r\n    <div class=\"tw-flex-shrink-0\">\r\n      <cide-ele-icon \r\n        class=\"tw-text-purple-600\" \r\n        size=\"xs\">\r\n        palette\r\n      </cide-ele-icon>\r\n    </div>\r\n    \r\n    <!-- Theme Details -->\r\n    <div class=\"tw-ml-3 tw-min-w-0 tw-flex-1\">\r\n      <div class=\"tw-text-sm tw-font-medium tw-text-gray-900 tw-truncate\" \r\n           [title]=\"row.sytm_title\">\r\n        {{ row.sytm_title || 'Untitled' }}\r\n      </div>\r\n      @if (row.sytm_desc) {\r\n        <div class=\"tw-text-xs tw-text-gray-500 tw-truncate\" \r\n             [title]=\"row.sytm_desc\">\r\n          {{ row.sytm_desc }}\r\n        </div>\r\n      }\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<!-- Theme Status Renderer Template -->\r\n<ng-template #themeStatusRendererTemplate let-row=\"row\" let-value=\"value\">\r\n  <span class=\"tw-inline-flex tw-items-center tw-px-2.5 tw-py-0.5 tw-rounded-full tw-text-xs tw-font-medium tw-whitespace-nowrap\"\r\n        [ngClass]=\"row.sytm_isactive ? 'tw-bg-green-100 tw-text-green-800' : 'tw-bg-red-100 tw-text-red-800'\">\r\n    {{ row.sytm_isactive ? 'Active' : 'Inactive' }}\r\n  </span>\r\n</ng-template>\r\n\r\n<!-- Actions Dropdown Renderer Template -->\r\n<ng-template #actionsDropdownRendererTemplate let-row=\"row\" let-value=\"value\">\r\n  <cide-ele-dropdown \r\n    [items]=\"getActionDropdownItems(row)\"\r\n    [config]=\"{ triggerIcon: 'more_vert', triggerSize: 'sm' }\"\r\n    (itemClick)=\"onDropdownItemClick($event, row)\">\r\n  </cide-ele-dropdown>\r\n</ng-template> "]}
|