cloud-ide-core 1.0.1 → 1.0.4

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.
Files changed (73) hide show
  1. package/README.md +49 -10
  2. package/fesm2022/{cloud-ide-core-general-master-type.component-B26auJZw.mjs → cloud-ide-core-general-master-type.component-OPaXxAXW.mjs} +133 -135
  3. package/fesm2022/{cloud-ide-core-general-master-type.component-B26auJZw.mjs.map → cloud-ide-core-general-master-type.component-OPaXxAXW.mjs.map} +1 -1
  4. package/fesm2022/{cloud-ide-core-general-master-type.service-Ab64Jjps.mjs → cloud-ide-core-general-master-type.service-8JWTVijZ.mjs} +7 -7
  5. package/fesm2022/{cloud-ide-core-general-master-type.service-Ab64Jjps.mjs.map → cloud-ide-core-general-master-type.service-8JWTVijZ.mjs.map} +1 -1
  6. package/fesm2022/{cloud-ide-core-general-master.component-B6llTVoV.mjs → cloud-ide-core-general-master.component-BEHWqXvF.mjs} +153 -155
  7. package/fesm2022/{cloud-ide-core-general-master.component-B6llTVoV.mjs.map → cloud-ide-core-general-master.component-BEHWqXvF.mjs.map} +1 -1
  8. package/fesm2022/{cloud-ide-core-page-form.component-CaEca3mB.mjs → cloud-ide-core-page-form.component-BatglsBU.mjs} +26 -26
  9. package/fesm2022/{cloud-ide-core-page-form.component-CaEca3mB.mjs.map → cloud-ide-core-page-form.component-BatglsBU.mjs.map} +1 -1
  10. package/fesm2022/cloud-ide-core.mjs +5089 -1116
  11. package/fesm2022/cloud-ide-core.mjs.map +1 -1
  12. package/index.d.ts +2111 -3
  13. package/package.json +3 -5
  14. package/esm2022/cloud-ide-core.mjs +0 -5
  15. package/esm2022/lib/cloud-ide-core.component.mjs +0 -19
  16. package/esm2022/lib/cloud-ide-core.routes.mjs +0 -137
  17. package/esm2022/lib/cloud-ide-core.service.mjs +0 -14
  18. package/esm2022/lib/core/department-management/components/department-list/department-list.component.mjs +0 -768
  19. package/esm2022/lib/core/department-management/index.mjs +0 -5
  20. package/esm2022/lib/core/department-management/services/department-management.service.mjs +0 -187
  21. package/esm2022/lib/core/designation-management/components/designation-list/designation-list.component.mjs +0 -1122
  22. package/esm2022/lib/core/designation-management/index.mjs +0 -5
  23. package/esm2022/lib/core/designation-management/services/designation-management.service.mjs +0 -194
  24. package/esm2022/lib/core/general-master-management/components/general-master/general-master.component.mjs +0 -738
  25. package/esm2022/lib/core/general-master-management/components/general-master-type/general-master-type.component.mjs +0 -608
  26. package/esm2022/lib/core/general-master-management/services/general-master-type.service.mjs +0 -203
  27. package/esm2022/lib/core/general-master-management/services/general-master.service.mjs +0 -166
  28. package/esm2022/lib/core/grade-level-management/components/grade-level-list/grade-level-list.component.mjs +0 -794
  29. package/esm2022/lib/core/grade-level-management/index.mjs +0 -5
  30. package/esm2022/lib/core/grade-level-management/services/grade-level-management.service.mjs +0 -172
  31. package/esm2022/lib/core/menu-management/components/menu-list/menu-list.component.mjs +0 -1135
  32. package/esm2022/lib/core/menu-management/index.mjs +0 -10
  33. package/esm2022/lib/core/menu-management/interfaces/menu-item.interface.mjs +0 -11
  34. package/esm2022/lib/core/menu-management/mock-data/menu-items.json +0 -311
  35. package/esm2022/lib/core/menu-management/services/menu-management.service.mjs +0 -230
  36. package/esm2022/lib/core/page-management/components/page-controls/page-controls.component.mjs +0 -483
  37. package/esm2022/lib/core/page-management/components/page-form/page-form.component.mjs +0 -212
  38. package/esm2022/lib/core/page-management/components/page-list/page-list.component.mjs +0 -393
  39. package/esm2022/lib/core/page-management/components/page-theme/page-theme.component.mjs +0 -767
  40. package/esm2022/lib/core/page-management/index.mjs +0 -10
  41. package/esm2022/lib/core/page-management/services/page-controls.service.mjs +0 -136
  42. package/esm2022/lib/core/page-management/services/page-management.service.mjs +0 -98
  43. package/esm2022/lib/core/page-management/services/page-theme.service.mjs +0 -107
  44. package/esm2022/public-api.mjs +0 -17
  45. package/lib/cloud-ide-core.component.d.ts +0 -5
  46. package/lib/cloud-ide-core.routes.d.ts +0 -2
  47. package/lib/cloud-ide-core.service.d.ts +0 -6
  48. package/lib/core/department-management/components/department-list/department-list.component.d.ts +0 -178
  49. package/lib/core/department-management/index.d.ts +0 -2
  50. package/lib/core/department-management/services/department-management.service.d.ts +0 -68
  51. package/lib/core/designation-management/components/designation-list/designation-list.component.d.ts +0 -242
  52. package/lib/core/designation-management/index.d.ts +0 -2
  53. package/lib/core/designation-management/services/designation-management.service.d.ts +0 -69
  54. package/lib/core/general-master-management/components/general-master/general-master.component.d.ts +0 -167
  55. package/lib/core/general-master-management/components/general-master-type/general-master-type.component.d.ts +0 -129
  56. package/lib/core/general-master-management/services/general-master-type.service.d.ts +0 -75
  57. package/lib/core/general-master-management/services/general-master.service.d.ts +0 -62
  58. package/lib/core/grade-level-management/components/grade-level-list/grade-level-list.component.d.ts +0 -199
  59. package/lib/core/grade-level-management/index.d.ts +0 -2
  60. package/lib/core/grade-level-management/services/grade-level-management.service.d.ts +0 -69
  61. package/lib/core/menu-management/components/menu-list/menu-list.component.d.ts +0 -278
  62. package/lib/core/menu-management/index.d.ts +0 -3
  63. package/lib/core/menu-management/interfaces/menu-item.interface.d.ts +0 -30
  64. package/lib/core/menu-management/services/menu-management.service.d.ts +0 -85
  65. package/lib/core/page-management/components/page-controls/page-controls.component.d.ts +0 -126
  66. package/lib/core/page-management/components/page-form/page-form.component.d.ts +0 -35
  67. package/lib/core/page-management/components/page-list/page-list.component.d.ts +0 -91
  68. package/lib/core/page-management/components/page-theme/page-theme.component.d.ts +0 -189
  69. package/lib/core/page-management/index.d.ts +0 -6
  70. package/lib/core/page-management/services/page-controls.service.d.ts +0 -54
  71. package/lib/core/page-management/services/page-management.service.d.ts +0 -42
  72. package/lib/core/page-management/services/page-theme.service.d.ts +0 -43
  73. package/public-api.d.ts +0 -8
@@ -1,1122 +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 { Router } from '@angular/router';
5
- import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
6
- import { DesignationManagementService } from '../../services/designation-management.service';
7
- import { GradeLevelManagementService } from '../../../grade-level-management/services/grade-level-management.service';
8
- import { DepartmentManagementService } from '../../../department-management/services/department-management.service';
9
- import { AppStateHelperService } from 'cloud-ide-layout';
10
- import { CideEleButtonComponent, CideEleDataGridComponent, CideIconComponent, CideInputComponent, CideSelectComponent, CideTextareaComponent, CideEleDropdownComponent } from 'cloud-ide-element';
11
- import * as i0 from "@angular/core";
12
- import * as i1 from "@angular/common";
13
- import * as i2 from "@angular/forms";
14
- export class DesignationListComponent {
15
- /**
16
- * Get template renderers for data grid
17
- */
18
- getTemplateRenderers() {
19
- return this.templateRenderers();
20
- }
21
- /**
22
- * Get custom renderers adapted for current data grid compatibility
23
- */
24
- getCustomRenderers() {
25
- return {};
26
- }
27
- // Modern constructor with effects for initialization
28
- constructor() {
29
- // Dependency injection
30
- this.destroyRef = inject(DestroyRef);
31
- this.designationService = inject(DesignationManagementService);
32
- this.gradeLevelService = inject(GradeLevelManagementService);
33
- this.departmentService = inject(DepartmentManagementService);
34
- this.appState = inject(AppStateHelperService);
35
- this.fb = inject(NonNullableFormBuilder);
36
- this.router = inject(Router);
37
- // Modern ViewChild signals for template renderers (Angular 20 approach)
38
- this.designationDetailsRendererTemplate = viewChild.required('designationDetailsRendererTemplate');
39
- this.designationStatusRendererTemplate = viewChild.required('designationStatusRendererTemplate');
40
- this.actionsDropdownRendererTemplate = viewChild.required('actionsDropdownRendererTemplate');
41
- // Make Math available in template
42
- this.Math = Math;
43
- // Signals for reactive state management
44
- this.designations = signal([]);
45
- this.departments = signal([]);
46
- this.gradeLevels = signal([]);
47
- this.loading = signal(false);
48
- this.error = signal(null);
49
- this.selectedItems = signal([]);
50
- this.searchTerm = signal('');
51
- // Modern reactive forms with signals
52
- this.selectedParentDesignation = signal(null);
53
- this.selectedParentDepartment = signal(null);
54
- // Retrieved designation data
55
- this.retrievedDesignation = signal(null);
56
- // Edit mode flag
57
- this.isEditMode = signal(false);
58
- // Server-side pagination state
59
- this.currentPage = signal(1);
60
- this.pageSize = signal(10);
61
- this.totalItems = signal(0);
62
- // Modern reactive form with typed controls
63
- this.quickAddForm = this.fb.group({
64
- sydsg_name: this.fb.control('', [Validators.required, Validators.minLength(1), Validators.maxLength(100)]),
65
- sydsg_code: this.fb.control('', [Validators.required, Validators.minLength(1), Validators.maxLength(20)]),
66
- sydsg_description: this.fb.control('', [Validators.maxLength(400)]),
67
- sydsg_prent_id_desg: this.fb.control(''),
68
- sydsg_department_id_sydpt: this.fb.control('', [Validators.required]),
69
- sydsg_grade_level_id_sydsgl: this.fb.control('', [Validators.required]),
70
- sydsg_isactive: this.fb.control(true, [Validators.required]),
71
- desg_entity_id_syen: this.fb.control(this.appState.getActiveEntityId() || '', [Validators.required])
72
- });
73
- // Grid configuration signal
74
- this.gridConfig = signal({
75
- id: 'designation-list-grid',
76
- title: '',
77
- subtitle: '',
78
- columns: [
79
- {
80
- key: 'details',
81
- header: 'Department/Designation',
82
- type: 'custom',
83
- width: 'auto',
84
- truncate: true,
85
- align: 'left',
86
- renderer: 'designationDetailsRenderer'
87
- },
88
- {
89
- key: 'code',
90
- header: 'Code',
91
- type: 'text',
92
- width: '120px',
93
- truncate: true,
94
- align: 'left'
95
- },
96
- {
97
- key: 'grade_level',
98
- header: 'Grade Level',
99
- type: 'text',
100
- width: '120px',
101
- truncate: true,
102
- align: 'left'
103
- },
104
- {
105
- key: 'status',
106
- header: 'Status',
107
- type: 'custom',
108
- width: '100px',
109
- truncate: false,
110
- align: 'center',
111
- renderer: 'designationStatusRenderer'
112
- },
113
- {
114
- key: 'actions',
115
- header: '',
116
- type: 'custom',
117
- width: '60px',
118
- truncate: false,
119
- align: 'center',
120
- renderer: 'actionsDropdownRenderer'
121
- }
122
- ],
123
- data: [],
124
- trackBy: '_id',
125
- tree: {
126
- enabled: true,
127
- primaryKey: '_id',
128
- foreignKey: 'parentId',
129
- childrenKey: 'children',
130
- levelKey: 'level',
131
- expandedKey: 'expanded',
132
- hasChildrenKey: 'hasChildren'
133
- },
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 departments and designations...',
145
- searchableColumns: ['name', 'code', 'description'],
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
- onRefresh: 'onDesignationRefresh'
167
- });
168
- // Template renderers using Angular best practices
169
- this.templateRenderers = computed(() => ({
170
- designationDetailsRenderer: this.designationDetailsRendererTemplate(),
171
- designationStatusRenderer: this.designationStatusRendererTemplate(),
172
- actionsDropdownRenderer: this.actionsDropdownRendererTemplate()
173
- }));
174
- // Mixed renderers (templates + string functions)
175
- this.customRenderers = computed(() => ({
176
- ...this.templateRenderers()
177
- }));
178
- // Action handlers for grid actions
179
- this.actionHandlers = {
180
- onEditDesignation: (row) => this.editDesignation(row._id || ''),
181
- onToggleDesignation: (row) => this.toggleDesignationStatus(row._id || ''),
182
- onDeleteDesignation: (row) => this.deleteDesignation(row._id || ''),
183
- onDesignationRowClick: (row) => this.onDesignationRowClick(row),
184
- onDesignationRefresh: () => this.onDesignationRefresh(),
185
- onAddChild: (row) => this.onAddChild(row)
186
- };
187
- // Computed properties
188
- this.filteredItems = computed(() => {
189
- const items = this.designations();
190
- const search = this.searchTerm()?.toLowerCase();
191
- if (!search)
192
- return items;
193
- return items.filter(item => {
194
- return item.sydsg_name?.toLowerCase().includes(search) ||
195
- item.sydsg_code?.toLowerCase().includes(search) ||
196
- item.sydsg_description?.toLowerCase().includes(search);
197
- });
198
- });
199
- this.hasSelection = computed(() => this.selectedItems().length > 0);
200
- // Pagination computed properties
201
- this.totalPages = computed(() => Math.ceil(this.totalItems() / this.pageSize()));
202
- this.hasNextPage = computed(() => this.currentPage() < this.totalPages());
203
- this.hasPreviousPage = computed(() => this.currentPage() > 1);
204
- // Grade level options for dropdown
205
- this.gradeLevelOptions = computed(() => {
206
- return this.gradeLevels().map(gradeLevel => ({
207
- value: gradeLevel._id || '',
208
- label: gradeLevel.sydsgl_name || 'Unknown'
209
- }));
210
- });
211
- // Department options for dropdown
212
- this.departmentOptions = computed(() => {
213
- return this.departments().map(department => ({
214
- value: department._id || '',
215
- label: department.sydept_name || 'Unknown'
216
- }));
217
- });
218
- this.initializeComponent();
219
- this.destroyRef.onDestroy(() => {
220
- this.cleanupEventListeners();
221
- });
222
- }
223
- /**
224
- * Initialize component with modern patterns
225
- */
226
- initializeComponent() {
227
- console.log('DesignationListComponent initialized with modern Angular patterns');
228
- this.loadDepartments();
229
- this.loadGradeLevels();
230
- this.loadDesignations();
231
- this.setupEventListeners();
232
- this.exposeGlobalFunctions();
233
- }
234
- /**
235
- * Setup event listeners for dropdown interactions
236
- */
237
- setupEventListeners() {
238
- document.addEventListener('click', this.handleClickOutside.bind(this));
239
- document.addEventListener('click', this.handleDropdownAction.bind(this));
240
- }
241
- /**
242
- * Cleanup event listeners
243
- */
244
- cleanupEventListeners() {
245
- document.removeEventListener('click', this.handleClickOutside.bind(this));
246
- document.removeEventListener('click', this.handleDropdownAction.bind(this));
247
- }
248
- /**
249
- * Expose global functions for dropdown interactions
250
- */
251
- exposeGlobalFunctions() {
252
- if (typeof window !== 'undefined') {
253
- window.toggleDropdown = this.toggleDropdown.bind(this);
254
- window.handleDesignationAction = this.handleDesignationAction.bind(this);
255
- }
256
- }
257
- /**
258
- * Load designations from service
259
- */
260
- loadDesignations() {
261
- console.log('🚀 DesignationListComponent.loadDesignations() called');
262
- this.loading.set(true);
263
- this.error.set(null);
264
- const requestBody = {
265
- total: this.totalItems(),
266
- pageIndex: this.currentPage(),
267
- pageSize: this.pageSize(),
268
- query: this.searchTerm()
269
- };
270
- console.log('📋 Request body:', requestBody);
271
- if (!this.designationService) {
272
- console.error('❌ DesignationService is not available');
273
- this.error.set('Designation service is not available');
274
- this.loading.set(false);
275
- return;
276
- }
277
- this.designationService.getDesignationList(requestBody)
278
- .pipe(takeUntilDestroyed(this.destroyRef))
279
- .subscribe({
280
- next: (response) => {
281
- console.log('📥 DesignationListComponent received response:', response);
282
- if (response?.success) {
283
- console.log('✅ Response successful, setting designations:', response.data);
284
- const designationData = response?.data || [];
285
- this.designations.set(designationData);
286
- this.totalItems.set(response.total || 0);
287
- // Update grid data with hierarchical structure
288
- this.updateGridData(designationData);
289
- }
290
- else {
291
- console.error('❌ Response was not successful:', response);
292
- this.error.set('Failed to load designations');
293
- }
294
- },
295
- error: (err) => {
296
- console.error('❌ DesignationListComponent error:', err);
297
- this.error.set(err.message || 'An error occurred while loading designations');
298
- },
299
- complete: () => {
300
- console.log('DesignationListComponent loadDesignations completed');
301
- this.loading.set(false);
302
- }
303
- });
304
- }
305
- /**
306
- * Load departments from service
307
- */
308
- loadDepartments() {
309
- console.log('🚀 DesignationListComponent.loadDepartments() called');
310
- if (!this.departmentService) {
311
- console.error('❌ DepartmentService is not available');
312
- return;
313
- }
314
- const requestBody = {
315
- total: 0,
316
- pageIndex: 1,
317
- pageSize: 1000, // Load all departments
318
- query: ''
319
- };
320
- this.departmentService.getDepartmentList(requestBody)
321
- .pipe(takeUntilDestroyed(this.destroyRef))
322
- .subscribe({
323
- next: (response) => {
324
- console.log('📥 DesignationListComponent received departments response:', response);
325
- if (response?.success) {
326
- console.log('✅ Departments loaded successfully:', response.data);
327
- const departmentData = response?.data || [];
328
- this.departments.set(departmentData);
329
- // Update grid data after loading departments
330
- this.updateGridData(this.designations());
331
- }
332
- else {
333
- console.error('❌ Failed to load departments:', response);
334
- }
335
- },
336
- error: (err) => {
337
- console.error('❌ Error loading departments:', err);
338
- }
339
- });
340
- }
341
- /**
342
- * Load grade levels from service
343
- */
344
- loadGradeLevels() {
345
- console.log('🚀 DesignationListComponent.loadGradeLevels() called');
346
- if (!this.gradeLevelService) {
347
- console.error('❌ GradeLevelService is not available');
348
- return;
349
- }
350
- const requestBody = {
351
- pageIndex: 1,
352
- pageSize: 100 // Load all grade levels for dropdown
353
- };
354
- this.gradeLevelService.getGradeLevelList(requestBody)
355
- .pipe(takeUntilDestroyed(this.destroyRef))
356
- .subscribe({
357
- next: (response) => {
358
- console.log('📥 Grade levels response:', response);
359
- if (response?.success) {
360
- console.log('✅ Grade levels loaded successfully:', response.data);
361
- const gradeLevelData = response?.data || [];
362
- this.gradeLevels.set(gradeLevelData);
363
- // Update grid data if designations are already loaded
364
- if (this.designations().length > 0) {
365
- this.updateGridData(this.designations());
366
- }
367
- }
368
- else {
369
- console.error('❌ Failed to load grade levels:', response);
370
- }
371
- },
372
- error: (err) => {
373
- console.error('❌ Error loading grade levels:', err);
374
- }
375
- });
376
- }
377
- /**
378
- * Build hierarchical tree structure from departments and designations
379
- */
380
- buildHierarchicalData() {
381
- const departments = this.departments();
382
- const designations = this.designations();
383
- console.log('🔍 Building hierarchical data with:', {
384
- departments: departments.length,
385
- designations: designations.length
386
- });
387
- // First, build department hierarchy
388
- const departmentNodes = this.buildDepartmentHierarchy(departments);
389
- // Then, add designations under their respective departments
390
- this.addDesignationsToDepartments(departmentNodes, designations);
391
- // Add orphaned designations at root level
392
- const orphanedDesignations = designations.filter(designation => !departments.some(dept => dept._id === designation.sydsg_department_id_sydpt));
393
- console.log(`🏷️ Found ${orphanedDesignations.length} orphaned designations`);
394
- orphanedDesignations.forEach(designation => {
395
- console.log(`👔 Adding orphaned designation: ${designation.sydsg_name}`);
396
- const designationNode = {
397
- _id: designation._id || '',
398
- name: designation.sydsg_name || '',
399
- code: designation.sydsg_code || '',
400
- description: designation.sydsg_description || '',
401
- type: 'designation',
402
- level: 0,
403
- expanded: false,
404
- hasChildren: false,
405
- children: [],
406
- status: designation.sydsg_isactive ?? true,
407
- grade_level: this.getGradeLevelName(designation.sydsg_grade_level_id_sydsgl || ''),
408
- parentId: null
409
- };
410
- departmentNodes.push(designationNode);
411
- });
412
- console.log('✅ Final hierarchical data:', departmentNodes);
413
- return departmentNodes;
414
- }
415
- /**
416
- * Build department hierarchy with parent-child relationships
417
- */
418
- buildDepartmentHierarchy(departments) {
419
- const departmentMap = new Map();
420
- const rootDepartments = [];
421
- // First pass: create all department nodes
422
- departments.forEach(department => {
423
- console.log(`🏢 Creating department node: ${department.sydept_name} (${department._id})`);
424
- const departmentNode = {
425
- _id: `dept_${department._id || ''}`,
426
- name: department.sydept_name || '',
427
- code: department.sydept_code || '',
428
- description: department.sydept_description || '',
429
- type: 'department',
430
- level: 0, // Will be updated based on hierarchy
431
- expanded: true,
432
- hasChildren: false,
433
- children: [],
434
- status: department.sydept_isactive ?? true,
435
- grade_level: 'N/A',
436
- parentId: department.sydept_department_id_sydept ? `dept_${department.sydept_department_id_sydept}` : null
437
- };
438
- departmentMap.set(departmentNode._id, departmentNode);
439
- });
440
- // Second pass: build parent-child relationships
441
- departments.forEach(department => {
442
- const departmentNode = departmentMap.get(`dept_${department._id || ''}`);
443
- if (!departmentNode)
444
- return;
445
- if (department.sydept_department_id_sydept) {
446
- // This department has a parent
447
- const parentNode = departmentMap.get(`dept_${department.sydept_department_id_sydept}`);
448
- if (parentNode) {
449
- parentNode.children.push(departmentNode);
450
- parentNode.hasChildren = true;
451
- departmentNode.level = parentNode.level + 1;
452
- console.log(`📁 Added ${department.sydept_name} as child of ${parentNode.name} (level ${departmentNode.level})`);
453
- }
454
- else {
455
- // Parent not found, treat as root
456
- rootDepartments.push(departmentNode);
457
- console.log(`🏢 Added ${department.sydept_name} as root (parent not found)`);
458
- }
459
- }
460
- else {
461
- // This is a root department
462
- rootDepartments.push(departmentNode);
463
- console.log(`🏢 Added ${department.sydept_name} as root department`);
464
- }
465
- });
466
- console.log(`✅ Built department hierarchy with ${rootDepartments.length} root departments`);
467
- return rootDepartments;
468
- }
469
- /**
470
- * Add designations to their respective departments in the hierarchy
471
- */
472
- addDesignationsToDepartments(departmentNodes, designations) {
473
- const addDesignationsToNode = (node) => {
474
- // Find designations for this department
475
- const departmentId = node._id.replace('dept_', '');
476
- const departmentDesignations = designations.filter(designation => designation.sydsg_department_id_sydpt === departmentId);
477
- console.log(`📋 Found ${departmentDesignations.length} designations for department ${node.name}`);
478
- if (departmentDesignations.length > 0) {
479
- node.hasChildren = true;
480
- // Add designations as children
481
- departmentDesignations.forEach(designation => {
482
- console.log(`👔 Adding designation: ${designation.sydsg_name} under ${node.name}`);
483
- const designationNode = {
484
- _id: designation._id || '',
485
- name: designation.sydsg_name || '',
486
- code: designation.sydsg_code || '',
487
- description: designation.sydsg_description || '',
488
- type: 'designation',
489
- level: node.level + 1,
490
- expanded: false,
491
- hasChildren: false,
492
- children: [],
493
- status: designation.sydsg_isactive ?? true,
494
- grade_level: this.getGradeLevelName(designation.sydsg_grade_level_id_sydsgl || ''),
495
- parentId: node._id
496
- };
497
- node.children.push(designationNode);
498
- });
499
- }
500
- // Recursively process child departments
501
- node.children.forEach(child => {
502
- if (child.type === 'department') {
503
- addDesignationsToNode(child);
504
- }
505
- });
506
- };
507
- // Process all root departments
508
- departmentNodes.forEach(node => {
509
- if (node.type === 'department') {
510
- addDesignationsToNode(node);
511
- }
512
- });
513
- }
514
- /**
515
- * Get grade level name by ID
516
- */
517
- getGradeLevelName(gradeLevelId) {
518
- console.log('🔍 getGradeLevelName called with ID:', gradeLevelId);
519
- console.log('📚 Available grade levels:', this.gradeLevels());
520
- const gradeLevel = this.gradeLevels().find(gl => gl._id === gradeLevelId);
521
- console.log('🎯 Found grade level:', gradeLevel);
522
- const result = gradeLevel ? (gradeLevel.sydsgl_name || 'N/A') : 'N/A';
523
- console.log('✅ Returning grade level name:', result);
524
- return result;
525
- }
526
- /**
527
- * Update grid data with hierarchical structure
528
- */
529
- updateGridData(designations) {
530
- console.log('🔄 updateGridData called with:', designations);
531
- console.log('📚 Current grade levels:', this.gradeLevels());
532
- console.log('🏢 Current departments:', this.departments());
533
- const hierarchicalData = this.buildHierarchicalData();
534
- // Flatten the hierarchical data for the grid component
535
- const flattenedData = this.flattenHierarchicalData(hierarchicalData);
536
- console.log('📊 Flattened data for grid:', flattenedData);
537
- this.gridConfig.update(config => {
538
- const newConfig = {
539
- ...config,
540
- data: flattenedData
541
- };
542
- console.log('⚙️ Updated grid config with flattened data:', flattenedData);
543
- return newConfig;
544
- });
545
- }
546
- /**
547
- * Flatten hierarchical data for grid display
548
- */
549
- flattenHierarchicalData(nodes) {
550
- const flattened = [];
551
- const flattenNode = (node) => {
552
- flattened.push(node);
553
- if (node.children && node.children.length > 0) {
554
- node.children.forEach(child => flattenNode(child));
555
- }
556
- };
557
- nodes.forEach(node => flattenNode(node));
558
- return flattened;
559
- }
560
- /**
561
- * Handle grid events
562
- */
563
- onGridEvent(event) {
564
- console.log('onGridEvent', event);
565
- switch (event.type) {
566
- case 'search':
567
- this.searchTerm.set(event.data);
568
- this.currentPage.set(1);
569
- this.loadDesignations();
570
- break;
571
- case 'pageChange': {
572
- const pageData = event.data;
573
- if (pageData) {
574
- this.currentPage.set(pageData.page);
575
- this.pageSize.set(pageData.pageSize);
576
- this.loadDesignations();
577
- }
578
- else {
579
- const page = event.data;
580
- if (page) {
581
- this.currentPage.set(page);
582
- this.loadDesignations();
583
- }
584
- }
585
- break;
586
- }
587
- case 'refresh':
588
- this.onDesignationRefresh();
589
- break;
590
- case 'rowClick':
591
- this.onDesignationRowClick(event.data);
592
- break;
593
- case 'action':
594
- if (event.action?.key === 'edit') {
595
- this.editDesignation(event.data);
596
- }
597
- else if (event.action?.key === 'toggle') {
598
- this.toggleDesignationStatus(event.data);
599
- }
600
- else if (event.action?.key === 'delete') {
601
- this.deleteDesignation(event.data);
602
- }
603
- break;
604
- }
605
- }
606
- /**
607
- * Handle designation refresh
608
- */
609
- onDesignationRefresh() {
610
- this.loadDesignations();
611
- }
612
- /**
613
- * Handle designation row click
614
- */
615
- onDesignationRowClick(designation) {
616
- this.editDesignation(designation._id || '');
617
- }
618
- /**
619
- * Navigate to edit designation form
620
- */
621
- editDesignation(itemId) {
622
- console.log('🔵 editDesignation called with:', itemId);
623
- this.isEditMode.set(true);
624
- this.getDesignationById(itemId);
625
- }
626
- /**
627
- * Get designation by ID using the API
628
- */
629
- getDesignationById(itemId) {
630
- console.log('🔵 getDesignationById called with:', itemId);
631
- this.loading.set(true);
632
- this.designationService.getDesignationById(itemId)
633
- .pipe(takeUntilDestroyed(this.destroyRef))
634
- .subscribe({
635
- next: (response) => {
636
- if (response.success) {
637
- console.log('✅ Designation retrieved successfully:', response.data);
638
- let designation = null;
639
- designation = response.data || null;
640
- this.retrievedDesignation.set(designation);
641
- if (this.isEditMode() && designation) {
642
- this.populateFormForEdit(designation);
643
- }
644
- }
645
- else {
646
- this.error.set('Failed to retrieve designation');
647
- }
648
- },
649
- error: (err) => {
650
- this.error.set(err.message || 'An error occurred while retrieving the designation');
651
- },
652
- complete: () => {
653
- this.loading.set(false);
654
- }
655
- });
656
- }
657
- /**
658
- * Populate form with designation data for editing
659
- */
660
- populateFormForEdit(designation) {
661
- console.log('🔵 populateFormForEdit called with:', designation);
662
- this.quickAddForm.patchValue({
663
- sydsg_name: designation.sydsg_name || '',
664
- sydsg_code: designation.sydsg_code || '',
665
- sydsg_description: designation.sydsg_description || '',
666
- sydsg_prent_id_desg: designation.sydsg_prent_id_desg || '',
667
- sydsg_department_id_sydpt: designation.sydsg_department_id_sydpt || '',
668
- sydsg_grade_level_id_sydsgl: designation.sydsg_grade_level_id_sydsgl || '',
669
- sydsg_isactive: designation.sydsg_isactive ?? true,
670
- desg_entity_id_syen: designation.desg_entity_id_syen || ''
671
- });
672
- if (designation.sydsg_prent_id_desg) {
673
- const parentDesignation = this.designations().find(item => item._id === designation.sydsg_prent_id_desg);
674
- if (parentDesignation) {
675
- this.selectedParentDesignation.set(parentDesignation);
676
- }
677
- }
678
- if (designation.sydsg_department_id_sydpt) {
679
- const parentDepartment = this.departments().find(item => item._id === designation.sydsg_department_id_sydpt);
680
- if (parentDepartment) {
681
- this.selectedParentDepartment.set(parentDepartment);
682
- }
683
- }
684
- console.log('✅ Form populated for editing:', this.quickAddForm.value);
685
- }
686
- /**
687
- * Delete designation
688
- */
689
- deleteDesignation(itemId) {
690
- console.log('🔵 deleteDesignation called with:', itemId);
691
- if (confirm('Are you sure you want to delete this designation?')) {
692
- this.loading.set(true);
693
- this.designationService.deleteDesignation(itemId)
694
- .pipe(takeUntilDestroyed(this.destroyRef))
695
- .subscribe({
696
- next: (response) => {
697
- if (response.success) {
698
- this.loadDesignations();
699
- }
700
- else {
701
- this.error.set('Failed to delete designation');
702
- }
703
- },
704
- error: (err) => {
705
- this.error.set(err.message || 'An error occurred while deleting the designation');
706
- },
707
- complete: () => {
708
- this.loading.set(false);
709
- }
710
- });
711
- }
712
- }
713
- /**
714
- * Toggle designation status
715
- */
716
- toggleDesignationStatus(itemId) {
717
- console.log('🔵 toggleDesignationStatus called with:', itemId);
718
- this.loading.set(true);
719
- this.designationService.toggleDesignationStatus(itemId)
720
- .pipe(takeUntilDestroyed(this.destroyRef))
721
- .subscribe({
722
- next: (response) => {
723
- if (response.success) {
724
- this.loadDesignations();
725
- }
726
- else {
727
- this.error.set('Failed to toggle designation status');
728
- }
729
- },
730
- error: (err) => {
731
- this.error.set(err.message || 'An error occurred while toggling status');
732
- },
733
- complete: () => {
734
- this.loading.set(false);
735
- }
736
- });
737
- }
738
- /**
739
- * Quick add or update designation using reactive form
740
- */
741
- quickAddDesignation() {
742
- if (this.quickAddForm.invalid) {
743
- console.log('❌ Form is invalid:', this.quickAddForm.errors);
744
- return;
745
- }
746
- const formValue = this.quickAddForm.value;
747
- // Create payload according to MDesignationInsertUpdatePayload model
748
- const designation = {
749
- _id: this.retrievedDesignation()?._id || '',
750
- sydsg_name: formValue.sydsg_name,
751
- sydsg_code: formValue.sydsg_code,
752
- sydsg_description: formValue.sydsg_description || '',
753
- sydsg_prent_id_desg: formValue.sydsg_prent_id_desg || undefined,
754
- sydsg_department_id_sydpt: formValue.sydsg_department_id_sydpt,
755
- sydsg_grade_level_id_sydsgl: formValue.sydsg_grade_level_id_sydsgl,
756
- sydsg_isactive: formValue.sydsg_isactive,
757
- desg_entity_id_syen: formValue.desg_entity_id_syen
758
- };
759
- // Validate required fields according to model
760
- if (!designation.sydsg_name || !designation.sydsg_code || !designation.sydsg_department_id_sydpt ||
761
- !designation.sydsg_grade_level_id_sydsgl || !designation.desg_entity_id_syen) {
762
- this.error.set('Please fill in all required fields');
763
- return;
764
- }
765
- if (this.isEditMode() && this.retrievedDesignation()) {
766
- const itemId = this.retrievedDesignation()?._id;
767
- if (itemId) {
768
- console.log('🔵 Updating designation:', itemId, designation);
769
- this.designationService.updateDesignation(itemId, designation).subscribe({
770
- next: (response) => {
771
- if (response.success) {
772
- console.log('✅ Designation updated successfully');
773
- this.resetQuickAddForm();
774
- this.isEditMode.set(false);
775
- this.retrievedDesignation.set(null);
776
- this.loadDesignations();
777
- }
778
- else {
779
- this.error.set(response.message || 'Failed to update designation');
780
- }
781
- },
782
- error: (err) => {
783
- console.error('❌ Error updating designation:', err);
784
- this.error.set(err.message || 'Failed to update designation');
785
- }
786
- });
787
- }
788
- }
789
- else {
790
- console.log('🔵 Creating new designation:', designation);
791
- this.designationService.createDesignation(designation).subscribe({
792
- next: (response) => {
793
- if (response.success) {
794
- console.log('✅ Designation created successfully');
795
- this.resetQuickAddForm();
796
- this.loadDesignations();
797
- }
798
- else {
799
- this.error.set(response.message || 'Failed to create designation');
800
- }
801
- },
802
- error: (err) => {
803
- console.error('❌ Error creating designation:', err);
804
- this.error.set(err.message || 'Failed to create designation');
805
- }
806
- });
807
- }
808
- }
809
- /**
810
- * Reset the quick add form to default values
811
- */
812
- resetQuickAddForm() {
813
- this.selectedParentDesignation.set(null);
814
- this.selectedParentDepartment.set(null);
815
- this.isEditMode.set(false);
816
- this.retrievedDesignation.set(null);
817
- this.quickAddForm.reset({
818
- sydsg_name: '',
819
- sydsg_code: '',
820
- sydsg_description: '',
821
- sydsg_prent_id_desg: '',
822
- sydsg_department_id_sydpt: '',
823
- sydsg_grade_level_id_sydsgl: '',
824
- sydsg_isactive: true,
825
- desg_entity_id_syen: this.appState.getActiveEntityId() || ''
826
- });
827
- // Clear any previous errors
828
- this.error.set(null);
829
- }
830
- /**
831
- * Handle adding a child designation
832
- */
833
- onAddChild(parentItem) {
834
- console.log('🔵 onAddChild called with:', parentItem);
835
- console.log('🔵 Parent name:', parentItem.sydsg_name);
836
- // Clear edit mode and retrieved item when adding a child
837
- this.isEditMode.set(false);
838
- this.retrievedDesignation.set(null);
839
- // Set the selected parent item first using signal
840
- this.selectedParentDesignation.set(parentItem);
841
- console.log('🔵 selectedParentDesignation set to:', this.selectedParentDesignation());
842
- // Update form with parent context (don't call resetQuickAddForm as it clears the parent)
843
- this.quickAddForm.patchValue({
844
- sydsg_name: '',
845
- sydsg_code: '',
846
- sydsg_description: '',
847
- sydsg_prent_id_desg: parentItem._id,
848
- sydsg_department_id_sydpt: parentItem.sydsg_department_id_sydpt || '', // Inherit department from parent
849
- sydsg_grade_level_id_sydsgl: '',
850
- sydsg_isactive: true,
851
- desg_entity_id_syen: this.appState.getActiveEntityId() || ''
852
- });
853
- // If parent has a department, set it as selected
854
- if (parentItem.sydsg_department_id_sydpt) {
855
- const parentDepartment = this.departments().find(d => d._id === parentItem.sydsg_department_id_sydpt);
856
- if (parentDepartment) {
857
- this.selectedParentDepartment.set(parentDepartment);
858
- }
859
- }
860
- console.log('🔵 Form updated, parent should be visible:', this.selectedParentDesignation()?.sydsg_name);
861
- }
862
- /**
863
- * Clear selected parent designation
864
- */
865
- clearSelectedParent() {
866
- this.selectedParentDesignation.set(null);
867
- this.quickAddForm.patchValue({
868
- sydsg_prent_id_desg: ''
869
- });
870
- }
871
- /**
872
- * Clear selected parent department
873
- */
874
- clearSelectedParentDepartment() {
875
- this.selectedParentDepartment.set(null);
876
- this.quickAddForm.patchValue({
877
- sydsg_department_id_sydpt: ''
878
- });
879
- }
880
- /**
881
- * Handle department selection
882
- */
883
- onDepartmentSelect(department) {
884
- console.log('🔵 onDepartmentSelect called with:', department);
885
- this.selectedParentDepartment.set(department);
886
- this.quickAddForm.patchValue({
887
- sydsg_department_id_sydpt: department._id
888
- });
889
- }
890
- /**
891
- * Handle click outside dropdown
892
- */
893
- handleClickOutside(event) {
894
- const target = event.target;
895
- if (!target?.closest('[data-dropdown]') && !target?.closest('[data-action="more-actions"]')) {
896
- document.querySelectorAll('[data-dropdown]').forEach((el) => {
897
- const dropdown = el;
898
- dropdown.classList.add('tw-hidden');
899
- });
900
- document.querySelectorAll('[data-action="more-actions"]').forEach((el) => {
901
- const button = el;
902
- button.setAttribute('aria-expanded', 'false');
903
- });
904
- }
905
- }
906
- /**
907
- * Handle dropdown action clicks
908
- */
909
- handleDropdownAction(event) {
910
- const target = event.target;
911
- const actionButton = target.closest('[data-action]');
912
- if (actionButton) {
913
- const action = actionButton.getAttribute('data-action');
914
- const itemId = actionButton.getAttribute('data-item-id');
915
- if (action && itemId) {
916
- event.preventDefault();
917
- event.stopPropagation();
918
- const dropdown = actionButton.closest('[data-dropdown]');
919
- if (dropdown) {
920
- dropdown.classList.add('tw-hidden');
921
- }
922
- switch (action) {
923
- case 'edit':
924
- this.editDesignation(itemId);
925
- break;
926
- case 'toggle':
927
- this.toggleDesignationStatus(itemId);
928
- break;
929
- case 'delete':
930
- this.deleteDesignation(itemId);
931
- break;
932
- }
933
- }
934
- }
935
- }
936
- /**
937
- * Toggle dropdown visibility
938
- */
939
- toggleDropdown(itemId) {
940
- document.querySelectorAll('.dropdown-menu').forEach(menu => {
941
- if (menu.getAttribute('data-dropdown') !== itemId) {
942
- menu.classList.add('tw-hidden');
943
- }
944
- });
945
- const dropdown = document.querySelector(`[data-dropdown="${itemId}"]`);
946
- if (dropdown) {
947
- dropdown.classList.toggle('tw-hidden');
948
- }
949
- }
950
- /**
951
- * Handle designation action clicks
952
- */
953
- handleDesignationAction(action, itemId) {
954
- const item = this.designations().find(item => item._id === itemId);
955
- if (!item)
956
- return;
957
- const dropdown = document.querySelector(`[data-dropdown="${itemId}"]`);
958
- if (dropdown) {
959
- dropdown.classList.add('tw-hidden');
960
- }
961
- switch (action) {
962
- case 'edit':
963
- this.editDesignation(itemId);
964
- break;
965
- case 'toggle':
966
- this.toggleDesignationStatus(itemId);
967
- break;
968
- case 'delete':
969
- this.deleteDesignation(itemId);
970
- break;
971
- }
972
- }
973
- /**
974
- * Get status display
975
- */
976
- getStatusDisplay(isActive) {
977
- return isActive ? 'Active' : 'Inactive';
978
- }
979
- /**
980
- * Get status class for styling
981
- */
982
- getStatusClass(isActive) {
983
- return isActive ? 'tw-bg-green-100 tw-text-green-800' : 'tw-bg-red-100 tw-text-red-800';
984
- }
985
- /**
986
- * Generate dropdown items for designation actions
987
- */
988
- getDropdownItems(row) {
989
- // Handle hierarchical data structure
990
- if (row.type === 'department') {
991
- return [
992
- {
993
- id: 'addDesignation',
994
- label: 'Add Designation',
995
- icon: 'add',
996
- iconColor: 'tw-text-blue-400',
997
- textColor: 'tw-text-blue-600',
998
- hoverBgColor: 'hover:tw-bg-blue-50'
999
- }
1000
- ];
1001
- }
1002
- else {
1003
- // For designations
1004
- return [
1005
- {
1006
- id: 'edit',
1007
- label: 'Edit',
1008
- icon: 'edit',
1009
- iconColor: 'tw-text-gray-400',
1010
- textColor: 'tw-text-gray-700',
1011
- hoverBgColor: 'hover:tw-bg-gray-100'
1012
- },
1013
- {
1014
- id: 'addChild',
1015
- label: 'Add Child',
1016
- icon: 'add',
1017
- iconColor: 'tw-text-blue-400',
1018
- textColor: 'tw-text-blue-600',
1019
- hoverBgColor: 'hover:tw-bg-blue-50'
1020
- },
1021
- {
1022
- id: 'toggle',
1023
- label: row.status ? 'Deactivate' : 'Activate',
1024
- icon: 'power_settings_new',
1025
- iconColor: 'tw-text-gray-400',
1026
- textColor: 'tw-text-gray-700',
1027
- hoverBgColor: 'hover:tw-bg-gray-100'
1028
- },
1029
- {
1030
- id: 'delete',
1031
- label: 'Delete',
1032
- icon: 'delete',
1033
- iconColor: 'tw-text-red-400',
1034
- textColor: 'tw-text-red-600',
1035
- hoverBgColor: 'hover:tw-bg-red-50'
1036
- }
1037
- ];
1038
- }
1039
- }
1040
- /**
1041
- * Handle dropdown item click
1042
- */
1043
- onDropdownItemClick(item, row) {
1044
- console.log('🔵 onDropdownItemClick called with:', item, row);
1045
- switch (item.id) {
1046
- case 'edit':
1047
- if (row.type === 'designation') {
1048
- this.editDesignation(row._id);
1049
- }
1050
- break;
1051
- case 'addChild':
1052
- if (row.type === 'designation') {
1053
- // Find the original designation object
1054
- const designation = this.designations().find(d => d._id === row._id);
1055
- if (designation) {
1056
- this.onAddChild(designation);
1057
- }
1058
- }
1059
- break;
1060
- case 'addDesignation':
1061
- if (row.type === 'department') {
1062
- // Extract department ID from the prefixed ID
1063
- const departmentId = row._id.replace('dept_', '');
1064
- const department = this.departments().find(d => d._id === departmentId);
1065
- if (department) {
1066
- console.log('🔵 Adding designation to department:', department.sydept_name);
1067
- this.onDepartmentSelect(department);
1068
- // Reset form to add mode
1069
- this.isEditMode.set(false);
1070
- this.retrievedDesignation.set(null);
1071
- this.selectedParentDesignation.set(null);
1072
- this.resetQuickAddForm();
1073
- }
1074
- }
1075
- break;
1076
- case 'toggle':
1077
- if (row.type === 'designation') {
1078
- this.toggleDesignationStatus(row._id);
1079
- }
1080
- break;
1081
- case 'delete':
1082
- if (row.type === 'designation') {
1083
- this.deleteDesignation(row._id);
1084
- }
1085
- break;
1086
- default:
1087
- console.log('🔵 Unknown action:', item.id);
1088
- }
1089
- this.closeAllDropdowns();
1090
- }
1091
- /**
1092
- * Close all dropdowns
1093
- */
1094
- closeAllDropdowns() {
1095
- const event = new MouseEvent('click', { bubbles: true });
1096
- document.dispatchEvent(event);
1097
- }
1098
- /**
1099
- * Track by function for ngFor
1100
- */
1101
- trackByItemId(index, item) {
1102
- return item._id || '';
1103
- }
1104
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: DesignationListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
1105
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: DesignationListComponent, isStandalone: true, selector: "cide-core-app-designation-list", viewQueries: [{ propertyName: "designationDetailsRendererTemplate", first: true, predicate: ["designationDetailsRendererTemplate"], descendants: true, isSignal: true }, { propertyName: "designationStatusRendererTemplate", first: true, predicate: ["designationStatusRendererTemplate"], descendants: true, isSignal: true }, { propertyName: "actionsDropdownRendererTemplate", first: true, predicate: ["actionsDropdownRendererTemplate"], descendants: true, isSignal: true }], ngImport: i0, template: "<!-- Designation List Container -->\n<div class=\"tw-table tw-w-full tw-h-full\">\n\n <!-- Quick Add Form Section -->\n <div class=\"tw-table-row tw-h-0\">\n <div class=\"tw-table-cell tw-px-6 tw-py-4 tw-border-b tw-border-gray-200 tw-bg-white\">\n <div class=\"tw-flex tw-items-center tw-justify-between tw-mb-0\">\n <div class=\"tw-flex tw-items-center tw-space-x-3 tw-mb-3\">\n <cide-ele-icon class=\"tw-text-blue-600 tw-w-5 tw-h-5\">{{ isEditMode() ? 'edit' : 'add' }}</cide-ele-icon>\n <h6 class=\"tw-text-sm tw-font-medium tw-text-gray-900 tw-m-0\">{{ isEditMode() ? 'Edit Designation' : 'Quick Add Designation' }}</h6>\n </div>\n @if (selectedParentDesignation()) {\n <div class=\"tw-flex tw-items-center tw-space-x-3 tw-bg-blue-50 tw-border tw-border-blue-200 tw-px-4 tw-py-1 tw-rounded-lg\">\n <cide-ele-icon class=\"tw-text-blue-600 tw-w-4 tw-h-4\">account_tree</cide-ele-icon>\n <div class=\"tw-flex tw-items-center tw-space-x-2\">\n <span class=\"tw-text-sm tw-text-blue-600 tw-font-medium\">{{ isEditMode() ? 'Parent:' : 'Creating child under:' }}</span>\n <span class=\"tw-text-sm tw-text-blue-800 tw-font-semibold\">{{ selectedParentDesignation()?.sydsg_name }}</span>\n </div>\n <button \n cideEleButton \n variant=\"ghost\" \n size=\"xs\" \n type=\"button\" \n (click)=\"clearSelectedParent()\" \n class=\"tw-text-blue-400 hover:tw-text-blue-600\">\n <svg class=\"tw-w-4 tw-h-4\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M6 18L18 6M6 6l12 12\"/>\n </svg>\n </button>\n </div>\n }\n @if (selectedParentDepartment()) {\n <div class=\"tw-flex tw-items-center tw-space-x-3 tw-bg-green-50 tw-border tw-border-green-200 tw-px-4 tw-py-1 tw-rounded-lg\">\n <cide-ele-icon class=\"tw-text-green-600 tw-w-4 tw-h-4\">business</cide-ele-icon>\n <div class=\"tw-flex tw-items-center tw-space-x-2\">\n <span class=\"tw-text-sm tw-text-green-600 tw-font-medium\">{{ isEditMode() ? 'Department:' : 'Department:' }}</span>\n <span class=\"tw-text-sm tw-text-green-800 tw-font-semibold\">{{ selectedParentDepartment()?.sydept_name }}</span>\n </div>\n <button \n cideEleButton \n variant=\"ghost\" \n size=\"xs\" \n type=\"button\" \n (click)=\"clearSelectedParentDepartment()\" \n class=\"tw-text-green-400 hover:tw-text-green-600\">\n <svg class=\"tw-w-4 tw-h-4\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M6 18L18 6M6 6l12 12\"/>\n </svg>\n </button>\n </div>\n }\n </div>\n \n <form [formGroup]=\"quickAddForm\" (ngSubmit)=\"quickAddDesignation()\">\n <!-- First Row -->\n <div class=\"tw-grid tw-grid-cols-1 md:tw-grid-cols-2 lg:tw-grid-cols-5 tw-gap-3 tw-mb-3\">\n <!-- Designation Name -->\n <div>\n <cide-ele-input \n id=\"sydsg_name\" \n label=\"Name*\" \n formControlName=\"sydsg_name\"\n placeholder=\"Designation name\"\n size=\"sm\">\n </cide-ele-input>\n </div>\n \n <!-- Designation Code -->\n <div>\n <cide-ele-input \n id=\"sydsg_code\" \n label=\"Code*\" \n formControlName=\"sydsg_code\"\n placeholder=\"DESG001\"\n size=\"sm\">\n </cide-ele-input>\n </div>\n \n <!-- Grade Level -->\n <div>\n <cide-ele-select \n id=\"sydsg_grade_level_id_sydsgl\"\n label=\"Grade Level*\" \n [options]=\"gradeLevelOptions()\" \n formControlName=\"sydsg_grade_level_id_sydsgl\"\n placeholder=\"Select grade level\"\n size=\"sm\">\n </cide-ele-select>\n </div>\n \n <!-- Department -->\n <div>\n <cide-ele-select \n id=\"sydsg_department_id_sydpt\"\n label=\"Department*\" \n [options]=\"departmentOptions()\" \n formControlName=\"sydsg_department_id_sydpt\"\n placeholder=\"Select department\"\n size=\"sm\">\n </cide-ele-select>\n </div>\n \n <!-- Active Status -->\n <div class=\"tw-flex tw-flex-col tw-justify-end\">\n <cide-ele-input \n id=\"sydsg_isactive\"\n type=\"checkbox\"\n label=\"Active\"\n formControlName=\"sydsg_isactive\"\n size=\"sm\">\n </cide-ele-input>\n </div>\n </div>\n \n <!-- Second Row -->\n <div class=\"tw-grid tw-grid-cols-1 md:tw-grid-cols-2 lg:tw-grid-cols-4 tw-gap-3 tw-items-end\">\n <!-- Description -->\n <div>\n <cide-ele-textarea \n id=\"sydsg_description\" \n label=\"Description\" \n formControlName=\"sydsg_description\"\n placeholder=\"Designation description\"\n rows=\"2\"\n size=\"sm\">\n </cide-ele-textarea>\n </div>\n \n <!-- Entity ID (Hidden) -->\n <div class=\"tw-hidden\">\n <cide-ele-input \n id=\"desg_entity_id_syen\" \n label=\"Entity ID*\" \n formControlName=\"desg_entity_id_syen\"\n placeholder=\"Entity ID\"\n size=\"sm\">\n </cide-ele-input>\n </div>\n \n <!-- Action Buttons -->\n <div class=\"tw-flex tw-flex-col tw-justify-end\">\n <div class=\"tw-flex tw-space-x-2\">\n <button \n cideEleButton \n variant=\"primary\" \n size=\"sm\" \n type=\"submit\"\n [disabled]=\"quickAddForm.invalid\"\n class=\"tw-px-2 tw-py-1 tw-w-20\">\n <cide-ele-icon size=\"xs\" class=\"tw-w-4 tw-h-4 tw-mr-1\">{{ isEditMode() ? 'edit' : 'add' }}</cide-ele-icon>\n {{ isEditMode() ? 'Update' : 'Add' }}\n </button>\n <button \n cideEleButton \n variant=\"outline\" \n size=\"sm\" \n type=\"button\"\n (click)=\"resetQuickAddForm()\"\n class=\"tw-px-2 tw-py-1 tw-w-16\">\n <cide-ele-icon size=\"xs\" class=\"tw-w-4 tw-h-4 tw-mr-1\">refresh</cide-ele-icon>\n Reset\n </button>\n </div>\n </div>\n </div>\n </form>\n </div>\n </div>\n\n\n\n <!-- Header Section with Filters -->\n <div class=\"tw-table-row tw-h-0\">\n <div class=\"tw-table-cell tw-px-6 tw-py-3 tw-border-b tw-border-gray-200 tw-bg-gray-50\">\n <div\n 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\">\n\n <!-- Title -->\n <div class=\"tw-flex tw-items-center tw-space-x-2\">\n <cide-ele-icon class=\"tw-text-blue-600 tw-w-5 tw-h-5\">work</cide-ele-icon>\n <h5 class=\"tw-text-base tw-font-medium tw-text-gray-900 tw-m-0\">Designation Management</h5>\n </div>\n\n <!-- Actions -->\n <div\n class=\"tw-flex tw-flex-col sm:tw-flex-row tw-items-start sm:tw-items-center tw-space-y-3 sm:tw-space-y-0 sm:tw-space-x-3\">\n <!-- Search functionality is handled by the data grid -->\n </div>\n </div>\n\n <!-- Error Message -->\n @if (error()) {\n <div class=\"tw-mt-4 tw-p-4 tw-bg-red-50 tw-border tw-border-red-200 tw-rounded-md\">\n <div class=\"tw-flex tw-items-start\">\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>\n <div class=\"tw-ml-3\">\n <h3 class=\"tw-text-sm tw-font-medium tw-text-red-800 tw-m-0\">Error</h3>\n <p class=\"tw-text-sm tw-text-red-700 tw-mt-1 tw-m-0\">{{ error() }}</p>\n </div>\n </div>\n </div>\n }\n </div>\n </div>\n\n <!-- Main Content Area -->\n <div class=\"tw-table-row\">\n <div class=\"tw-table-cell tw-h-full tw-relative\">\n \n <!-- Data Grid Component -->\n <div class=\"tw-h-full tw-overflow-auto\">\n \n <cide-ele-data-grid \n [config]=\"gridConfig()\" \n [templateRenderers]=\"getTemplateRenderers()\"\n [actionHandlers]=\"actionHandlers\"\n [serverSidePagination]=\"true\" \n [totalServerItems]=\"totalItems()\" \n [currentServerPage]=\"currentPage()\"\n [currentServerPageSize]=\"pageSize()\" \n (gridEvent)=\"onGridEvent($event)\">\n </cide-ele-data-grid>\n </div>\n\n </div>\n </div>\n\n</div>\n\n<!-- Designation Details Renderer Template -->\n<ng-template #designationDetailsRendererTemplate let-row=\"row\" let-value=\"value\">\n <div class=\"tw-flex tw-items-center tw-min-w-0\">\n <!-- Dynamic Icon based on type -->\n <div class=\"tw-flex-shrink-0\">\n <cide-ele-icon \n [class]=\"row.type === 'department' ? 'tw-text-green-500' : 'tw-text-blue-500'\" \n size=\"xs\">\n {{ row.type === 'department' ? 'business' : 'work' }}\n </cide-ele-icon>\n </div>\n \n <!-- Details -->\n <div class=\"tw-ml-3 tw-min-w-0 tw-flex-1\">\n <div class=\"tw-flex tw-items-center tw-space-x-2\">\n <div class=\"tw-text-sm tw-font-medium tw-text-gray-900 tw-truncate\" \n [title]=\"row.name\">\n {{ row.name || 'Untitled' }}\n </div>\n @if (row.type === 'department') {\n <span class=\"tw-inline-flex tw-items-center tw-px-2 tw-py-0.5 tw-rounded-full tw-text-xs tw-font-medium tw-bg-green-100 tw-text-green-800\">\n Department\n </span>\n }\n </div>\n @if (row.description) {\n <div class=\"tw-text-xs tw-text-gray-500 tw-truncate\" \n [title]=\"row.description\">\n {{ row.description }}\n </div>\n }\n </div>\n </div>\n</ng-template>\n\n<!-- Designation Status Renderer Template -->\n<ng-template #designationStatusRendererTemplate let-row=\"row\" let-value=\"value\">\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\"\n [ngClass]=\"getStatusClass(row.status)\">\n {{ getStatusDisplay(row.status) }}\n </span>\n</ng-template>\n\n<!-- Actions Dropdown Renderer Template -->\n<ng-template #actionsDropdownRendererTemplate let-row=\"row\" let-value=\"value\">\n <cide-ele-dropdown \n [items]=\"getDropdownItems(row)\"\n [config]=\"{ triggerIcon: 'more_vert', triggerSize: 'sm' }\"\n (itemClick)=\"onDropdownItemClick($event, row)\">\n </cide-ele-dropdown>\n</ng-template> ", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { 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.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: FormsModule }, { kind: "component", type: CideEleDataGridComponent, selector: "cide-ele-data-grid", inputs: ["config", "customRenderers", "templateRenderers", "customFormatters", "actionHandlers", "serverSidePagination", "totalServerItems", "currentServerPage", "currentServerPageSize", "dragDropEnabled"], outputs: ["gridEvent"] }, { 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"] }] }); }
1106
- }
1107
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: DesignationListComponent, decorators: [{
1108
- type: Component,
1109
- args: [{ selector: 'cide-core-app-designation-list', standalone: true, imports: [
1110
- CommonModule,
1111
- ReactiveFormsModule,
1112
- FormsModule,
1113
- CideEleDataGridComponent,
1114
- CideEleButtonComponent,
1115
- CideInputComponent,
1116
- CideSelectComponent,
1117
- CideTextareaComponent,
1118
- CideIconComponent,
1119
- CideEleDropdownComponent
1120
- ], template: "<!-- Designation List Container -->\n<div class=\"tw-table tw-w-full tw-h-full\">\n\n <!-- Quick Add Form Section -->\n <div class=\"tw-table-row tw-h-0\">\n <div class=\"tw-table-cell tw-px-6 tw-py-4 tw-border-b tw-border-gray-200 tw-bg-white\">\n <div class=\"tw-flex tw-items-center tw-justify-between tw-mb-0\">\n <div class=\"tw-flex tw-items-center tw-space-x-3 tw-mb-3\">\n <cide-ele-icon class=\"tw-text-blue-600 tw-w-5 tw-h-5\">{{ isEditMode() ? 'edit' : 'add' }}</cide-ele-icon>\n <h6 class=\"tw-text-sm tw-font-medium tw-text-gray-900 tw-m-0\">{{ isEditMode() ? 'Edit Designation' : 'Quick Add Designation' }}</h6>\n </div>\n @if (selectedParentDesignation()) {\n <div class=\"tw-flex tw-items-center tw-space-x-3 tw-bg-blue-50 tw-border tw-border-blue-200 tw-px-4 tw-py-1 tw-rounded-lg\">\n <cide-ele-icon class=\"tw-text-blue-600 tw-w-4 tw-h-4\">account_tree</cide-ele-icon>\n <div class=\"tw-flex tw-items-center tw-space-x-2\">\n <span class=\"tw-text-sm tw-text-blue-600 tw-font-medium\">{{ isEditMode() ? 'Parent:' : 'Creating child under:' }}</span>\n <span class=\"tw-text-sm tw-text-blue-800 tw-font-semibold\">{{ selectedParentDesignation()?.sydsg_name }}</span>\n </div>\n <button \n cideEleButton \n variant=\"ghost\" \n size=\"xs\" \n type=\"button\" \n (click)=\"clearSelectedParent()\" \n class=\"tw-text-blue-400 hover:tw-text-blue-600\">\n <svg class=\"tw-w-4 tw-h-4\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M6 18L18 6M6 6l12 12\"/>\n </svg>\n </button>\n </div>\n }\n @if (selectedParentDepartment()) {\n <div class=\"tw-flex tw-items-center tw-space-x-3 tw-bg-green-50 tw-border tw-border-green-200 tw-px-4 tw-py-1 tw-rounded-lg\">\n <cide-ele-icon class=\"tw-text-green-600 tw-w-4 tw-h-4\">business</cide-ele-icon>\n <div class=\"tw-flex tw-items-center tw-space-x-2\">\n <span class=\"tw-text-sm tw-text-green-600 tw-font-medium\">{{ isEditMode() ? 'Department:' : 'Department:' }}</span>\n <span class=\"tw-text-sm tw-text-green-800 tw-font-semibold\">{{ selectedParentDepartment()?.sydept_name }}</span>\n </div>\n <button \n cideEleButton \n variant=\"ghost\" \n size=\"xs\" \n type=\"button\" \n (click)=\"clearSelectedParentDepartment()\" \n class=\"tw-text-green-400 hover:tw-text-green-600\">\n <svg class=\"tw-w-4 tw-h-4\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n <path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M6 18L18 6M6 6l12 12\"/>\n </svg>\n </button>\n </div>\n }\n </div>\n \n <form [formGroup]=\"quickAddForm\" (ngSubmit)=\"quickAddDesignation()\">\n <!-- First Row -->\n <div class=\"tw-grid tw-grid-cols-1 md:tw-grid-cols-2 lg:tw-grid-cols-5 tw-gap-3 tw-mb-3\">\n <!-- Designation Name -->\n <div>\n <cide-ele-input \n id=\"sydsg_name\" \n label=\"Name*\" \n formControlName=\"sydsg_name\"\n placeholder=\"Designation name\"\n size=\"sm\">\n </cide-ele-input>\n </div>\n \n <!-- Designation Code -->\n <div>\n <cide-ele-input \n id=\"sydsg_code\" \n label=\"Code*\" \n formControlName=\"sydsg_code\"\n placeholder=\"DESG001\"\n size=\"sm\">\n </cide-ele-input>\n </div>\n \n <!-- Grade Level -->\n <div>\n <cide-ele-select \n id=\"sydsg_grade_level_id_sydsgl\"\n label=\"Grade Level*\" \n [options]=\"gradeLevelOptions()\" \n formControlName=\"sydsg_grade_level_id_sydsgl\"\n placeholder=\"Select grade level\"\n size=\"sm\">\n </cide-ele-select>\n </div>\n \n <!-- Department -->\n <div>\n <cide-ele-select \n id=\"sydsg_department_id_sydpt\"\n label=\"Department*\" \n [options]=\"departmentOptions()\" \n formControlName=\"sydsg_department_id_sydpt\"\n placeholder=\"Select department\"\n size=\"sm\">\n </cide-ele-select>\n </div>\n \n <!-- Active Status -->\n <div class=\"tw-flex tw-flex-col tw-justify-end\">\n <cide-ele-input \n id=\"sydsg_isactive\"\n type=\"checkbox\"\n label=\"Active\"\n formControlName=\"sydsg_isactive\"\n size=\"sm\">\n </cide-ele-input>\n </div>\n </div>\n \n <!-- Second Row -->\n <div class=\"tw-grid tw-grid-cols-1 md:tw-grid-cols-2 lg:tw-grid-cols-4 tw-gap-3 tw-items-end\">\n <!-- Description -->\n <div>\n <cide-ele-textarea \n id=\"sydsg_description\" \n label=\"Description\" \n formControlName=\"sydsg_description\"\n placeholder=\"Designation description\"\n rows=\"2\"\n size=\"sm\">\n </cide-ele-textarea>\n </div>\n \n <!-- Entity ID (Hidden) -->\n <div class=\"tw-hidden\">\n <cide-ele-input \n id=\"desg_entity_id_syen\" \n label=\"Entity ID*\" \n formControlName=\"desg_entity_id_syen\"\n placeholder=\"Entity ID\"\n size=\"sm\">\n </cide-ele-input>\n </div>\n \n <!-- Action Buttons -->\n <div class=\"tw-flex tw-flex-col tw-justify-end\">\n <div class=\"tw-flex tw-space-x-2\">\n <button \n cideEleButton \n variant=\"primary\" \n size=\"sm\" \n type=\"submit\"\n [disabled]=\"quickAddForm.invalid\"\n class=\"tw-px-2 tw-py-1 tw-w-20\">\n <cide-ele-icon size=\"xs\" class=\"tw-w-4 tw-h-4 tw-mr-1\">{{ isEditMode() ? 'edit' : 'add' }}</cide-ele-icon>\n {{ isEditMode() ? 'Update' : 'Add' }}\n </button>\n <button \n cideEleButton \n variant=\"outline\" \n size=\"sm\" \n type=\"button\"\n (click)=\"resetQuickAddForm()\"\n class=\"tw-px-2 tw-py-1 tw-w-16\">\n <cide-ele-icon size=\"xs\" class=\"tw-w-4 tw-h-4 tw-mr-1\">refresh</cide-ele-icon>\n Reset\n </button>\n </div>\n </div>\n </div>\n </form>\n </div>\n </div>\n\n\n\n <!-- Header Section with Filters -->\n <div class=\"tw-table-row tw-h-0\">\n <div class=\"tw-table-cell tw-px-6 tw-py-3 tw-border-b tw-border-gray-200 tw-bg-gray-50\">\n <div\n 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\">\n\n <!-- Title -->\n <div class=\"tw-flex tw-items-center tw-space-x-2\">\n <cide-ele-icon class=\"tw-text-blue-600 tw-w-5 tw-h-5\">work</cide-ele-icon>\n <h5 class=\"tw-text-base tw-font-medium tw-text-gray-900 tw-m-0\">Designation Management</h5>\n </div>\n\n <!-- Actions -->\n <div\n class=\"tw-flex tw-flex-col sm:tw-flex-row tw-items-start sm:tw-items-center tw-space-y-3 sm:tw-space-y-0 sm:tw-space-x-3\">\n <!-- Search functionality is handled by the data grid -->\n </div>\n </div>\n\n <!-- Error Message -->\n @if (error()) {\n <div class=\"tw-mt-4 tw-p-4 tw-bg-red-50 tw-border tw-border-red-200 tw-rounded-md\">\n <div class=\"tw-flex tw-items-start\">\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>\n <div class=\"tw-ml-3\">\n <h3 class=\"tw-text-sm tw-font-medium tw-text-red-800 tw-m-0\">Error</h3>\n <p class=\"tw-text-sm tw-text-red-700 tw-mt-1 tw-m-0\">{{ error() }}</p>\n </div>\n </div>\n </div>\n }\n </div>\n </div>\n\n <!-- Main Content Area -->\n <div class=\"tw-table-row\">\n <div class=\"tw-table-cell tw-h-full tw-relative\">\n \n <!-- Data Grid Component -->\n <div class=\"tw-h-full tw-overflow-auto\">\n \n <cide-ele-data-grid \n [config]=\"gridConfig()\" \n [templateRenderers]=\"getTemplateRenderers()\"\n [actionHandlers]=\"actionHandlers\"\n [serverSidePagination]=\"true\" \n [totalServerItems]=\"totalItems()\" \n [currentServerPage]=\"currentPage()\"\n [currentServerPageSize]=\"pageSize()\" \n (gridEvent)=\"onGridEvent($event)\">\n </cide-ele-data-grid>\n </div>\n\n </div>\n </div>\n\n</div>\n\n<!-- Designation Details Renderer Template -->\n<ng-template #designationDetailsRendererTemplate let-row=\"row\" let-value=\"value\">\n <div class=\"tw-flex tw-items-center tw-min-w-0\">\n <!-- Dynamic Icon based on type -->\n <div class=\"tw-flex-shrink-0\">\n <cide-ele-icon \n [class]=\"row.type === 'department' ? 'tw-text-green-500' : 'tw-text-blue-500'\" \n size=\"xs\">\n {{ row.type === 'department' ? 'business' : 'work' }}\n </cide-ele-icon>\n </div>\n \n <!-- Details -->\n <div class=\"tw-ml-3 tw-min-w-0 tw-flex-1\">\n <div class=\"tw-flex tw-items-center tw-space-x-2\">\n <div class=\"tw-text-sm tw-font-medium tw-text-gray-900 tw-truncate\" \n [title]=\"row.name\">\n {{ row.name || 'Untitled' }}\n </div>\n @if (row.type === 'department') {\n <span class=\"tw-inline-flex tw-items-center tw-px-2 tw-py-0.5 tw-rounded-full tw-text-xs tw-font-medium tw-bg-green-100 tw-text-green-800\">\n Department\n </span>\n }\n </div>\n @if (row.description) {\n <div class=\"tw-text-xs tw-text-gray-500 tw-truncate\" \n [title]=\"row.description\">\n {{ row.description }}\n </div>\n }\n </div>\n </div>\n</ng-template>\n\n<!-- Designation Status Renderer Template -->\n<ng-template #designationStatusRendererTemplate let-row=\"row\" let-value=\"value\">\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\"\n [ngClass]=\"getStatusClass(row.status)\">\n {{ getStatusDisplay(row.status) }}\n </span>\n</ng-template>\n\n<!-- Actions Dropdown Renderer Template -->\n<ng-template #actionsDropdownRendererTemplate let-row=\"row\" let-value=\"value\">\n <cide-ele-dropdown \n [items]=\"getDropdownItems(row)\"\n [config]=\"{ triggerIcon: 'more_vert', triggerSize: 'sm' }\"\n (itemClick)=\"onDropdownItemClick($event, row)\">\n </cide-ele-dropdown>\n</ng-template> " }]
1121
- }], ctorParameters: () => [] });
1122
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"designation-list.component.js","sourceRoot":"","sources":["../../../../../../../../projects/cloud-ide-core/src/lib/core/designation-management/components/designation-list/designation-list.component.ts","../../../../../../../../projects/cloud-ide-core/src/lib/core/designation-management/components/designation-list/designation-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, signal, computed, viewChild, TemplateRef, DestroyRef, inject } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { Validators, ReactiveFormsModule, NonNullableFormBuilder, FormsModule } from '@angular/forms';\nimport { Router } from '@angular/router';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ICoreSydsg, ICoreSydsgl, ICoreSydept } from 'cloud-ide-lms-model';\nimport { DesignationManagementService } from '../../services/designation-management.service';\nimport { GradeLevelManagementService } from '../../../grade-level-management/services/grade-level-management.service';\nimport { DepartmentManagementService } from '../../../department-management/services/department-management.service';\nimport { AppStateHelperService } from 'cloud-ide-layout';\nimport { CideEleButtonComponent, CideEleDataGridComponent, CideIconComponent, CideInputComponent, CideSelectComponent, CideTextareaComponent, GridConfiguration, GridEvent, CideEleDropdownComponent, DropdownItem } from 'cloud-ide-element';\nimport { TemplateContext } from 'cloud-ide-element';\n\ninterface HierarchicalNode {\n  _id: string;\n  name: string;\n  code: string;\n  description: string;\n  type: 'department' | 'designation';\n  level: number;\n  expanded: boolean;\n  hasChildren: boolean;\n  children: HierarchicalNode[];\n  status: boolean;\n  grade_level: string;\n  parentId: string | null;\n}\n\n@Component({\n  selector: 'cide-core-app-designation-list',\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  ],\n  templateUrl: './designation-list.component.html',\n  styleUrls: []\n})\nexport class DesignationListComponent {\n  // Dependency injection\n  private destroyRef = inject(DestroyRef);\n  private designationService = inject(DesignationManagementService);\n  private gradeLevelService = inject(GradeLevelManagementService);\n  private departmentService = inject(DepartmentManagementService);\n  private appState = inject(AppStateHelperService);\n  private fb = inject(NonNullableFormBuilder);\n  private router = inject(Router);\n\n  // Modern ViewChild signals for template renderers (Angular 20 approach)\n  designationDetailsRendererTemplate = viewChild.required<TemplateRef<TemplateContext<Record<string, unknown>>>>('designationDetailsRendererTemplate');\n  designationStatusRendererTemplate = viewChild.required<TemplateRef<TemplateContext<Record<string, unknown>>>>('designationStatusRendererTemplate');\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  designations = signal<ICoreSydsg[]>([]);\n  departments = signal<ICoreSydept[]>([]);\n  gradeLevels = signal<ICoreSydsgl[]>([]);\n  loading = signal(false);\n  error = signal<string | null>(null);\n  selectedItems = signal<string[]>([]);\n  searchTerm = signal('');\n\n  // Modern reactive forms with signals\n  selectedParentDesignation = signal<ICoreSydsg | null>(null);\n  selectedParentDepartment = signal<ICoreSydept | null>(null);\n\n  // Retrieved designation data\n  retrievedDesignation = signal<ICoreSydsg | null>(null);\n\n  // Edit mode flag\n  isEditMode = signal(false);\n\n  // Server-side pagination state\n  currentPage = signal(1);\n  pageSize = signal(10);\n  totalItems = signal(0);\n\n  // Modern reactive form with typed controls\n  quickAddForm = this.fb.group({\n    sydsg_name: this.fb.control('', [Validators.required, Validators.minLength(1), Validators.maxLength(100)]),\n    sydsg_code: this.fb.control('', [Validators.required, Validators.minLength(1), Validators.maxLength(20)]),\n    sydsg_description: this.fb.control('', [Validators.maxLength(400)]),\n    sydsg_prent_id_desg: this.fb.control(''),\n    sydsg_department_id_sydpt: this.fb.control('', [Validators.required]),\n    sydsg_grade_level_id_sydsgl: this.fb.control('', [Validators.required]),\n    sydsg_isactive: this.fb.control(true, [Validators.required]),\n    desg_entity_id_syen: this.fb.control(this.appState.getActiveEntityId() || '', [Validators.required])\n  });\n\n  // Grid configuration signal\n  gridConfig = signal<GridConfiguration<ICoreSydsg>>({\n    id: 'designation-list-grid',\n    title: '',\n    subtitle: '',\n    columns: [\n      {\n        key: 'details',\n        header: 'Department/Designation',\n        type: 'custom',\n        width: 'auto',\n        truncate: true,\n        align: 'left',\n        renderer: 'designationDetailsRenderer'\n      },\n      {\n        key: 'code',\n        header: 'Code',\n        type: 'text',\n        width: '120px',\n        truncate: true,\n        align: 'left'\n      },\n      {\n        key: 'grade_level',\n        header: 'Grade Level',\n        type: 'text',\n        width: '120px',\n        truncate: true,\n        align: 'left'\n      },\n      {\n        key: 'status',\n        header: 'Status',\n        type: 'custom',\n        width: '100px',\n        truncate: false,\n        align: 'center',\n        renderer: 'designationStatusRenderer'\n      },\n      {\n        key: 'actions',\n        header: '',\n        type: 'custom',\n        width: '60px',\n        truncate: false,\n        align: 'center',\n        renderer: 'actionsDropdownRenderer'\n      }\n    ],\n    data: [],\n    trackBy: '_id',\n    tree: {\n      enabled: true,\n      primaryKey: '_id',\n      foreignKey: 'parentId',\n      childrenKey: 'children',\n      levelKey: 'level',\n      expandedKey: 'expanded',\n      hasChildrenKey: 'hasChildren'\n    },\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 departments and designations...',\n      searchableColumns: ['name', 'code', 'description'],\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    onRefresh: 'onDesignationRefresh'\n  });\n\n  // Template renderers using Angular best practices\n  templateRenderers = computed((): Record<string, TemplateRef<TemplateContext>> => ({\n    designationDetailsRenderer: this.designationDetailsRendererTemplate(),\n    designationStatusRenderer: this.designationStatusRendererTemplate(),\n    actionsDropdownRenderer: this.actionsDropdownRendererTemplate()\n  }));\n\n  /**\n   * Get template renderers for data grid\n   */\n  getTemplateRenderers(): Record<string, TemplateRef<TemplateContext>> {\n    return this.templateRenderers();\n  }\n\n  // Mixed renderers (templates + string functions)\n  customRenderers = computed(() => ({\n    ...this.templateRenderers()\n  }));\n\n  /**\n   * Get custom renderers adapted for current data grid compatibility\n   */\n  getCustomRenderers(): Record<string, (value: unknown, row: ICoreSydsg) => string> {\n    return {};\n  }\n\n  // Action handlers for grid actions\n  actionHandlers = {\n    onEditDesignation: (row: ICoreSydsg) => this.editDesignation(row._id || ''),\n    onToggleDesignation: (row: ICoreSydsg) => this.toggleDesignationStatus(row._id || ''),\n    onDeleteDesignation: (row: ICoreSydsg) => this.deleteDesignation(row._id || ''),\n    onDesignationRowClick: (row: ICoreSydsg) => this.onDesignationRowClick(row),\n    onDesignationRefresh: () => this.onDesignationRefresh(),\n    onAddChild: (row: ICoreSydsg) => this.onAddChild(row)\n  };\n\n  // Computed properties\n  filteredItems = computed(() => {\n    const items = this.designations();\n    const search = this.searchTerm()?.toLowerCase();\n\n    if (!search) return items;\n\n    return items.filter(item => {\n      return item.sydsg_name?.toLowerCase().includes(search) ||\n        item.sydsg_code?.toLowerCase().includes(search) ||\n        item.sydsg_description?.toLowerCase().includes(search);\n    });\n  });\n\n  hasSelection = computed(() => this.selectedItems().length > 0);\n\n  // Pagination computed properties\n  totalPages = computed(() => Math.ceil(this.totalItems() / this.pageSize()));\n  hasNextPage = computed(() => this.currentPage() < this.totalPages());\n  hasPreviousPage = computed(() => this.currentPage() > 1);\n\n  // Grade level options for dropdown\n  gradeLevelOptions = computed(() => {\n    return this.gradeLevels().map(gradeLevel => ({\n      value: gradeLevel._id || '',\n      label: gradeLevel.sydsgl_name || 'Unknown'\n    }));\n  });\n\n  // Department options for dropdown\n  departmentOptions = computed(() => {\n    return this.departments().map(department => ({\n      value: department._id || '',\n      label: department.sydept_name || 'Unknown'\n    }));\n  });\n\n  // Modern constructor with effects for initialization\n  constructor() {\n    this.initializeComponent();\n    this.destroyRef.onDestroy(() => {\n      this.cleanupEventListeners();\n    });\n  }\n\n  /**\n   * Initialize component with modern patterns\n   */\n  private initializeComponent(): void {\n    console.log('DesignationListComponent initialized with modern Angular patterns');\n    this.loadDepartments();\n    this.loadGradeLevels();\n    this.loadDesignations();\n    this.setupEventListeners();\n    this.exposeGlobalFunctions();\n  }\n\n  /**\n   * Setup event listeners for dropdown interactions\n   */\n  private setupEventListeners(): void {\n    document.addEventListener('click', this.handleClickOutside.bind(this));\n    document.addEventListener('click', this.handleDropdownAction.bind(this));\n  }\n\n  /**\n   * Cleanup event listeners\n   */\n  private cleanupEventListeners(): void {\n    document.removeEventListener('click', this.handleClickOutside.bind(this));\n    document.removeEventListener('click', this.handleDropdownAction.bind(this));\n  }\n\n  /**\n   * Expose global functions for dropdown interactions\n   */\n  private exposeGlobalFunctions(): void {\n    if (typeof window !== 'undefined') {\n      (window as unknown as { toggleDropdown: (id: string) => void }).toggleDropdown = this.toggleDropdown.bind(this);\n      (window as unknown as { handleDesignationAction: (action: string, id: string) => void }).handleDesignationAction = this.handleDesignationAction.bind(this);\n    }\n  }\n\n  /**\n   * Load designations from service\n   */\n  loadDesignations(): void {\n    console.log('🚀 DesignationListComponent.loadDesignations() called');\n    this.loading.set(true);\n    this.error.set(null);\n\n    const requestBody = {\n      total: this.totalItems(),\n      pageIndex: this.currentPage(),\n      pageSize: this.pageSize(),\n      query: this.searchTerm()\n    };\n    console.log('📋 Request body:', requestBody);\n\n    if (!this.designationService) {\n      console.error('❌ DesignationService is not available');\n      this.error.set('Designation service is not available');\n      this.loading.set(false);\n      return;\n    }\n\n    this.designationService.getDesignationList(requestBody)\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe({\n        next: (response) => {\n          console.log('📥 DesignationListComponent received response:', response);\n          if (response?.success) {\n            console.log('✅ Response successful, setting designations:', response.data);\n            const designationData = response?.data || [];\n            this.designations.set(designationData);\n            this.totalItems.set(response.total || 0);\n            // Update grid data with hierarchical structure\n            this.updateGridData(designationData);\n          } else {\n            console.error('❌ Response was not successful:', response);\n            this.error.set('Failed to load designations');\n          }\n        },\n        error: (err) => {\n          console.error('❌ DesignationListComponent error:', err);\n          this.error.set(err.message || 'An error occurred while loading designations');\n        },\n        complete: () => {\n          console.log('DesignationListComponent loadDesignations completed');\n          this.loading.set(false);\n        }\n      });\n  }\n\n  /**\n   * Load departments from service\n   */\n  loadDepartments(): void {\n    console.log('🚀 DesignationListComponent.loadDepartments() called');\n\n    if (!this.departmentService) {\n      console.error('❌ DepartmentService is not available');\n      return;\n    }\n\n    const requestBody = {\n      total: 0,\n      pageIndex: 1,\n      pageSize: 1000, // Load all departments\n      query: ''\n    };\n\n    this.departmentService.getDepartmentList(requestBody)\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe({\n        next: (response) => {\n          console.log('📥 DesignationListComponent received departments response:', response);\n          if (response?.success) {\n            console.log('✅ Departments loaded successfully:', response.data);\n            const departmentData = response?.data || [];\n            this.departments.set(departmentData);\n            // Update grid data after loading departments\n            this.updateGridData(this.designations());\n          } else {\n            console.error('❌ Failed to load departments:', response);\n          }\n        },\n        error: (err) => {\n          console.error('❌ Error loading departments:', err);\n        }\n      });\n  }\n\n  /**\n   * Load grade levels from service\n   */\n  loadGradeLevels(): void {\n    console.log('🚀 DesignationListComponent.loadGradeLevels() called');\n\n    if (!this.gradeLevelService) {\n      console.error('❌ GradeLevelService is not available');\n      return;\n    }\n\n    const requestBody = {\n      pageIndex: 1,\n      pageSize: 100 // Load all grade levels for dropdown\n    };\n\n    this.gradeLevelService.getGradeLevelList(requestBody)\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe({\n        next: (response) => {\n          console.log('📥 Grade levels response:', response);\n          if (response?.success) {\n            console.log('✅ Grade levels loaded successfully:', response.data);\n            const gradeLevelData = response?.data || [];\n            this.gradeLevels.set(gradeLevelData);\n            // Update grid data if designations are already loaded\n            if (this.designations().length > 0) {\n              this.updateGridData(this.designations());\n            }\n          } else {\n            console.error('❌ Failed to load grade levels:', response);\n          }\n        },\n        error: (err) => {\n          console.error('❌ Error loading grade levels:', err);\n        }\n      });\n  }\n\n  /**\n   * Build hierarchical tree structure from departments and designations\n   */\n  private buildHierarchicalData(): HierarchicalNode[] {\n    const departments = this.departments();\n    const designations = this.designations();\n    \n    console.log('🔍 Building hierarchical data with:', {\n      departments: departments.length,\n      designations: designations.length\n    });\n    \n    // First, build department hierarchy\n    const departmentNodes = this.buildDepartmentHierarchy(departments);\n    \n    // Then, add designations under their respective departments\n    this.addDesignationsToDepartments(departmentNodes, designations);\n    \n    // Add orphaned designations at root level\n    const orphanedDesignations = designations.filter(designation => \n      !departments.some(dept => dept._id === designation.sydsg_department_id_sydpt)\n    );\n    \n    console.log(`🏷️ Found ${orphanedDesignations.length} orphaned designations`);\n    \n    orphanedDesignations.forEach(designation => {\n      console.log(`👔 Adding orphaned designation: ${designation.sydsg_name}`);\n      \n      const designationNode: HierarchicalNode = {\n        _id: designation._id || '',\n        name: designation.sydsg_name || '',\n        code: designation.sydsg_code || '',\n        description: designation.sydsg_description || '',\n        type: 'designation',\n        level: 0,\n        expanded: false,\n        hasChildren: false,\n        children: [],\n        status: designation.sydsg_isactive ?? true,\n        grade_level: this.getGradeLevelName(designation.sydsg_grade_level_id_sydsgl || ''),\n        parentId: null\n      };\n      \n      departmentNodes.push(designationNode);\n    });\n    \n    console.log('✅ Final hierarchical data:', departmentNodes);\n    return departmentNodes;\n  }\n\n  /**\n   * Build department hierarchy with parent-child relationships\n   */\n  private buildDepartmentHierarchy(departments: ICoreSydept[]): HierarchicalNode[] {\n    const departmentMap = new Map<string, HierarchicalNode>();\n    const rootDepartments: HierarchicalNode[] = [];\n    \n    // First pass: create all department nodes\n    departments.forEach(department => {\n      console.log(`🏢 Creating department node: ${department.sydept_name} (${department._id})`);\n      \n      const departmentNode: HierarchicalNode = {\n        _id: `dept_${department._id || ''}`,\n        name: department.sydept_name || '',\n        code: department.sydept_code || '',\n        description: department.sydept_description || '',\n        type: 'department',\n        level: 0, // Will be updated based on hierarchy\n        expanded: true,\n        hasChildren: false,\n        children: [],\n        status: department.sydept_isactive ?? true,\n        grade_level: 'N/A',\n        parentId: department.sydept_department_id_sydept ? `dept_${department.sydept_department_id_sydept}` : null\n      };\n      \n      departmentMap.set(departmentNode._id, departmentNode);\n    });\n    \n    // Second pass: build parent-child relationships\n    departments.forEach(department => {\n      const departmentNode = departmentMap.get(`dept_${department._id || ''}`);\n      if (!departmentNode) return;\n      \n      if (department.sydept_department_id_sydept) {\n        // This department has a parent\n        const parentNode = departmentMap.get(`dept_${department.sydept_department_id_sydept}`);\n        if (parentNode) {\n          parentNode.children.push(departmentNode);\n          parentNode.hasChildren = true;\n          departmentNode.level = parentNode.level + 1;\n          console.log(`📁 Added ${department.sydept_name} as child of ${parentNode.name} (level ${departmentNode.level})`);\n        } else {\n          // Parent not found, treat as root\n          rootDepartments.push(departmentNode);\n          console.log(`🏢 Added ${department.sydept_name} as root (parent not found)`);\n        }\n      } else {\n        // This is a root department\n        rootDepartments.push(departmentNode);\n        console.log(`🏢 Added ${department.sydept_name} as root department`);\n      }\n    });\n    \n    console.log(`✅ Built department hierarchy with ${rootDepartments.length} root departments`);\n    return rootDepartments;\n  }\n\n  /**\n   * Add designations to their respective departments in the hierarchy\n   */\n  private addDesignationsToDepartments(departmentNodes: HierarchicalNode[], designations: ICoreSydsg[]): void {\n    const addDesignationsToNode = (node: HierarchicalNode) => {\n      // Find designations for this department\n      const departmentId = node._id.replace('dept_', '');\n      const departmentDesignations = designations.filter(designation => \n        designation.sydsg_department_id_sydpt === departmentId\n      );\n      \n      console.log(`📋 Found ${departmentDesignations.length} designations for department ${node.name}`);\n      \n      if (departmentDesignations.length > 0) {\n        node.hasChildren = true;\n        \n        // Add designations as children\n        departmentDesignations.forEach(designation => {\n          console.log(`👔 Adding designation: ${designation.sydsg_name} under ${node.name}`);\n          \n          const designationNode: HierarchicalNode = {\n            _id: designation._id || '',\n            name: designation.sydsg_name || '',\n            code: designation.sydsg_code || '',\n            description: designation.sydsg_description || '',\n            type: 'designation',\n            level: node.level + 1,\n            expanded: false,\n            hasChildren: false,\n            children: [],\n            status: designation.sydsg_isactive ?? true,\n            grade_level: this.getGradeLevelName(designation.sydsg_grade_level_id_sydsgl || ''),\n            parentId: node._id\n          };\n          \n          node.children.push(designationNode);\n        });\n      }\n      \n      // Recursively process child departments\n      node.children.forEach(child => {\n        if (child.type === 'department') {\n          addDesignationsToNode(child);\n        }\n      });\n    };\n    \n    // Process all root departments\n    departmentNodes.forEach(node => {\n      if (node.type === 'department') {\n        addDesignationsToNode(node);\n      }\n    });\n  }\n\n  /**\n   * Get grade level name by ID\n   */\n  private getGradeLevelName(gradeLevelId: string): string {\n    console.log('🔍 getGradeLevelName called with ID:', gradeLevelId);\n    console.log('📚 Available grade levels:', this.gradeLevels());\n    \n    const gradeLevel = this.gradeLevels().find(gl => gl._id === gradeLevelId);\n    console.log('🎯 Found grade level:', gradeLevel);\n    \n    const result = gradeLevel ? (gradeLevel.sydsgl_name || 'N/A') : 'N/A';\n    console.log('✅ Returning grade level name:', result);\n    return result;\n  }\n\n  /**\n   * Update grid data with hierarchical structure\n   */\n  private updateGridData(designations: ICoreSydsg[]): void {\n    console.log('🔄 updateGridData called with:', designations);\n    console.log('📚 Current grade levels:', this.gradeLevels());\n    console.log('🏢 Current departments:', this.departments());\n    \n    const hierarchicalData = this.buildHierarchicalData();\n    \n    // Flatten the hierarchical data for the grid component\n    const flattenedData = this.flattenHierarchicalData(hierarchicalData);\n    \n    console.log('📊 Flattened data for grid:', flattenedData);\n    \n    this.gridConfig.update(config => {\n      const newConfig = {\n        ...config,\n        data: flattenedData\n      };\n      console.log('⚙️ Updated grid config with flattened data:', flattenedData);\n      return newConfig;\n    });\n  }\n\n  /**\n   * Flatten hierarchical data for grid display\n   */\n  private flattenHierarchicalData(nodes: HierarchicalNode[]): HierarchicalNode[] {\n    const flattened: HierarchicalNode[] = [];\n    \n    const flattenNode = (node: HierarchicalNode) => {\n      flattened.push(node);\n      if (node.children && node.children.length > 0) {\n        node.children.forEach(child => flattenNode(child));\n      }\n    };\n    \n    nodes.forEach(node => flattenNode(node));\n    return flattened;\n  }\n\n  /**\n   * Handle grid events\n   */\n  onGridEvent(event: GridEvent<ICoreSydsg>): void {\n    console.log('onGridEvent', event);\n    switch (event.type) {\n      case 'search':\n        this.searchTerm.set(event.data as string);\n        this.currentPage.set(1);\n        this.loadDesignations();\n        break;\n      case 'pageChange': {\n        const pageData = event.data as { page: number; pageSize: number };\n        if (pageData) {\n          this.currentPage.set(pageData.page);\n          this.pageSize.set(pageData.pageSize);\n          this.loadDesignations();\n        } else {\n          const page = event.data as number;\n          if (page) {\n            this.currentPage.set(page);\n            this.loadDesignations();\n          }\n        }\n        break;\n      }\n      case 'refresh':\n        this.onDesignationRefresh();\n        break;\n      case 'rowClick':\n        this.onDesignationRowClick(event.data as ICoreSydsg);\n        break;\n      case 'action':\n        if (event.action?.key === 'edit') {\n          this.editDesignation(event.data as string);\n        } else if (event.action?.key === 'toggle') {\n          this.toggleDesignationStatus(event.data as string);\n        } else if (event.action?.key === 'delete') {\n          this.deleteDesignation(event.data as string);\n        }\n        break;\n    }\n  }\n\n  /**\n   * Handle designation refresh\n   */\n  onDesignationRefresh(): void {\n    this.loadDesignations();\n  }\n\n  /**\n   * Handle designation row click\n   */\n  onDesignationRowClick(designation: ICoreSydsg): void {\n    this.editDesignation(designation._id || '');\n  }\n\n  /**\n   * Navigate to edit designation form\n   */\n  editDesignation(itemId: string): void {\n    console.log('🔵 editDesignation called with:', itemId);\n    this.isEditMode.set(true);\n    this.getDesignationById(itemId);\n  }\n\n  /**\n   * Get designation by ID using the API\n   */\n  getDesignationById(itemId: string): void {\n    console.log('🔵 getDesignationById called with:', itemId);\n    this.loading.set(true);\n\n    this.designationService.getDesignationById(itemId)\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe({\n        next: (response) => {\n          if (response.success) {\n            console.log('✅ Designation retrieved successfully:', response.data);\n            let designation: ICoreSydsg | null = null;\n            designation = response.data || null;\n\n            this.retrievedDesignation.set(designation);\n\n            if (this.isEditMode() && designation) {\n              this.populateFormForEdit(designation);\n            }\n          } else {\n            this.error.set('Failed to retrieve designation');\n          }\n        },\n        error: (err) => {\n          this.error.set(err.message || 'An error occurred while retrieving the designation');\n        },\n        complete: () => {\n          this.loading.set(false);\n        }\n      });\n  }\n\n  /**\n   * Populate form with designation data for editing\n   */\n  populateFormForEdit(designation: ICoreSydsg): void {\n    console.log('🔵 populateFormForEdit called with:', designation);\n\n    this.quickAddForm.patchValue({\n      sydsg_name: designation.sydsg_name || '',\n      sydsg_code: designation.sydsg_code || '',\n      sydsg_description: designation.sydsg_description || '',\n      sydsg_prent_id_desg: designation.sydsg_prent_id_desg || '',\n      sydsg_department_id_sydpt: designation.sydsg_department_id_sydpt || '',\n      sydsg_grade_level_id_sydsgl: designation.sydsg_grade_level_id_sydsgl || '',\n      sydsg_isactive: designation.sydsg_isactive ?? true,\n      desg_entity_id_syen: designation.desg_entity_id_syen || ''\n    });\n\n    if (designation.sydsg_prent_id_desg) {\n      const parentDesignation = this.designations().find(item => item._id === designation.sydsg_prent_id_desg);\n      if (parentDesignation) {\n        this.selectedParentDesignation.set(parentDesignation);\n      }\n    }\n\n    if (designation.sydsg_department_id_sydpt) {\n      const parentDepartment = this.departments().find(item => item._id === designation.sydsg_department_id_sydpt);\n      if (parentDepartment) {\n        this.selectedParentDepartment.set(parentDepartment);\n      }\n    }\n\n    console.log('✅ Form populated for editing:', this.quickAddForm.value);\n  }\n\n  /**\n   * Delete designation\n   */\n  deleteDesignation(itemId: string): void {\n    console.log('🔵 deleteDesignation called with:', itemId);\n    if (confirm('Are you sure you want to delete this designation?')) {\n      this.loading.set(true);\n\n      this.designationService.deleteDesignation(itemId)\n        .pipe(takeUntilDestroyed(this.destroyRef))\n        .subscribe({\n          next: (response) => {\n            if (response.success) {\n              this.loadDesignations();\n            } else {\n              this.error.set('Failed to delete designation');\n            }\n          },\n          error: (err) => {\n            this.error.set(err.message || 'An error occurred while deleting the designation');\n          },\n          complete: () => {\n            this.loading.set(false);\n          }\n        });\n    }\n  }\n\n  /**\n   * Toggle designation status\n   */\n  toggleDesignationStatus(itemId: string): void {\n    console.log('🔵 toggleDesignationStatus called with:', itemId);\n    this.loading.set(true);\n\n    this.designationService.toggleDesignationStatus(itemId)\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe({\n        next: (response) => {\n          if (response.success) {\n            this.loadDesignations();\n          } else {\n            this.error.set('Failed to toggle designation status');\n          }\n        },\n        error: (err) => {\n          this.error.set(err.message || 'An error occurred while toggling status');\n        },\n        complete: () => {\n          this.loading.set(false);\n        }\n      });\n  }\n\n  /**\n   * Quick add or update designation using reactive form\n   */\n  quickAddDesignation() {\n    if (this.quickAddForm.invalid) {\n      console.log('❌ Form is invalid:', this.quickAddForm.errors);\n      return;\n    }\n\n    const formValue = this.quickAddForm.value;\n\n    // Create payload according to MDesignationInsertUpdatePayload model\n    const designation: Partial<ICoreSydsg> = {\n      _id: this.retrievedDesignation()?._id || '',\n      sydsg_name: formValue.sydsg_name,\n      sydsg_code: formValue.sydsg_code,\n      sydsg_description: formValue.sydsg_description || '',\n      sydsg_prent_id_desg: formValue.sydsg_prent_id_desg || undefined,\n      sydsg_department_id_sydpt: formValue.sydsg_department_id_sydpt,\n      sydsg_grade_level_id_sydsgl: formValue.sydsg_grade_level_id_sydsgl,\n      sydsg_isactive: formValue.sydsg_isactive,\n      desg_entity_id_syen: formValue.desg_entity_id_syen\n    };\n\n    // Validate required fields according to model\n    if (!designation.sydsg_name || !designation.sydsg_code || !designation.sydsg_department_id_sydpt || \n        !designation.sydsg_grade_level_id_sydsgl || !designation.desg_entity_id_syen) {\n      this.error.set('Please fill in all required fields');\n      return;\n    }\n\n    if (this.isEditMode() && this.retrievedDesignation()) {\n      const itemId = this.retrievedDesignation()?._id;\n      if (itemId) {\n        console.log('🔵 Updating designation:', itemId, designation);\n        this.designationService.updateDesignation(itemId, designation).subscribe({\n          next: (response) => {\n            if (response.success) {\n              console.log('✅ Designation updated successfully');\n              this.resetQuickAddForm();\n              this.isEditMode.set(false);\n              this.retrievedDesignation.set(null);\n              this.loadDesignations();\n            } else {\n              this.error.set(response.message || 'Failed to update designation');\n            }\n          },\n          error: (err) => {\n            console.error('❌ Error updating designation:', err);\n            this.error.set(err.message || 'Failed to update designation');\n          }\n        });\n      }\n    } else {\n      console.log('🔵 Creating new designation:', designation);\n      this.designationService.createDesignation(designation).subscribe({\n        next: (response) => {\n          if (response.success) {\n            console.log('✅ Designation created successfully');\n            this.resetQuickAddForm();\n            this.loadDesignations();\n          } else {\n            this.error.set(response.message || 'Failed to create designation');\n          }\n        },\n        error: (err) => {\n          console.error('❌ Error creating designation:', err);\n          this.error.set(err.message || 'Failed to create designation');\n        }\n      });\n    }\n  }\n\n  /**\n   * Reset the quick add form to default values\n   */\n  resetQuickAddForm(): void {\n    this.selectedParentDesignation.set(null);\n    this.selectedParentDepartment.set(null);\n    this.isEditMode.set(false);\n    this.retrievedDesignation.set(null);\n\n    this.quickAddForm.reset({\n      sydsg_name: '',\n      sydsg_code: '',\n      sydsg_description: '',\n      sydsg_prent_id_desg: '',\n      sydsg_department_id_sydpt: '',\n      sydsg_grade_level_id_sydsgl: '',\n      sydsg_isactive: true,\n      desg_entity_id_syen: this.appState.getActiveEntityId() || ''\n    });\n\n    // Clear any previous errors\n    this.error.set(null);\n  }\n\n  /**\n   * Handle adding a child designation\n   */\n  onAddChild(parentItem: ICoreSydsg): void {\n    console.log('🔵 onAddChild called with:', parentItem);\n    console.log('🔵 Parent name:', parentItem.sydsg_name);\n\n    // Clear edit mode and retrieved item when adding a child\n    this.isEditMode.set(false);\n    this.retrievedDesignation.set(null);\n\n    // Set the selected parent item first using signal\n    this.selectedParentDesignation.set(parentItem);\n    console.log('🔵 selectedParentDesignation set to:', this.selectedParentDesignation());\n\n    // Update form with parent context (don't call resetQuickAddForm as it clears the parent)\n    this.quickAddForm.patchValue({\n      sydsg_name: '',\n      sydsg_code: '',\n      sydsg_description: '',\n      sydsg_prent_id_desg: parentItem._id,\n      sydsg_department_id_sydpt: parentItem.sydsg_department_id_sydpt || '', // Inherit department from parent\n      sydsg_grade_level_id_sydsgl: '',\n      sydsg_isactive: true,\n      desg_entity_id_syen: this.appState.getActiveEntityId() || ''\n    });\n\n    // If parent has a department, set it as selected\n    if (parentItem.sydsg_department_id_sydpt) {\n      const parentDepartment = this.departments().find(d => d._id === parentItem.sydsg_department_id_sydpt);\n      if (parentDepartment) {\n        this.selectedParentDepartment.set(parentDepartment);\n      }\n    }\n\n    console.log('🔵 Form updated, parent should be visible:', this.selectedParentDesignation()?.sydsg_name);\n  }\n\n  /**\n   * Clear selected parent designation\n   */\n  clearSelectedParent() {\n    this.selectedParentDesignation.set(null);\n    this.quickAddForm.patchValue({\n      sydsg_prent_id_desg: ''\n    });\n  }\n\n  /**\n   * Clear selected parent department\n   */\n  clearSelectedParentDepartment() {\n    this.selectedParentDepartment.set(null);\n    this.quickAddForm.patchValue({\n      sydsg_department_id_sydpt: ''\n    });\n  }\n\n  /**\n   * Handle department selection\n   */\n  onDepartmentSelect(department: ICoreSydept): void {\n    console.log('🔵 onDepartmentSelect called with:', department);\n    this.selectedParentDepartment.set(department);\n    this.quickAddForm.patchValue({\n      sydsg_department_id_sydpt: department._id\n    });\n  }\n\n  /**\n   * Handle click outside dropdown\n   */\n  private handleClickOutside(event: Event): void {\n    const target = event.target as HTMLElement;\n\n    if (!target?.closest('[data-dropdown]') && !target?.closest('[data-action=\"more-actions\"]')) {\n      document.querySelectorAll('[data-dropdown]').forEach((el: Element) => {\n        const dropdown = el as HTMLElement;\n        dropdown.classList.add('tw-hidden');\n      });\n\n      document.querySelectorAll('[data-action=\"more-actions\"]').forEach((el: Element) => {\n        const button = el as HTMLElement;\n        button.setAttribute('aria-expanded', 'false');\n      });\n    }\n  }\n\n  /**\n   * Handle dropdown action clicks\n   */\n  private handleDropdownAction(event: Event): void {\n    const target = event.target as HTMLElement;\n    const actionButton = target.closest('[data-action]') as HTMLElement;\n\n    if (actionButton) {\n      const action = actionButton.getAttribute('data-action');\n      const itemId = actionButton.getAttribute('data-item-id');\n\n      if (action && itemId) {\n        event.preventDefault();\n        event.stopPropagation();\n\n        const dropdown = actionButton.closest('[data-dropdown]') as HTMLElement;\n        if (dropdown) {\n          dropdown.classList.add('tw-hidden');\n        }\n\n        switch (action) {\n          case 'edit':\n            this.editDesignation(itemId);\n            break;\n          case 'toggle':\n            this.toggleDesignationStatus(itemId);\n            break;\n          case 'delete':\n            this.deleteDesignation(itemId);\n            break;\n        }\n      }\n    }\n  }\n\n  /**\n   * Toggle dropdown visibility\n   */\n  toggleDropdown(itemId: string) {\n    document.querySelectorAll('.dropdown-menu').forEach(menu => {\n      if (menu.getAttribute('data-dropdown') !== itemId) {\n        menu.classList.add('tw-hidden');\n      }\n    });\n\n    const dropdown = document.querySelector(`[data-dropdown=\"${itemId}\"]`);\n    if (dropdown) {\n      dropdown.classList.toggle('tw-hidden');\n    }\n  }\n\n  /**\n   * Handle designation action clicks\n   */\n  handleDesignationAction(action: string, itemId: string) {\n    const item = this.designations().find(item => item._id === itemId);\n    if (!item) return;\n\n    const dropdown = document.querySelector(`[data-dropdown=\"${itemId}\"]`);\n    if (dropdown) {\n      dropdown.classList.add('tw-hidden');\n    }\n\n    switch (action) {\n      case 'edit':\n        this.editDesignation(itemId);\n        break;\n      case 'toggle':\n        this.toggleDesignationStatus(itemId);\n        break;\n      case 'delete':\n        this.deleteDesignation(itemId);\n        break;\n    }\n  }\n\n  /**\n   * Get status display\n   */\n  getStatusDisplay(isActive: boolean): string {\n    return isActive ? 'Active' : 'Inactive';\n  }\n\n  /**\n   * Get status class for styling\n   */\n  getStatusClass(isActive: boolean): string {\n    return isActive ? 'tw-bg-green-100 tw-text-green-800' : 'tw-bg-red-100 tw-text-red-800';\n  }\n\n  /**\n   * Generate dropdown items for designation actions\n   */\n  getDropdownItems(row: HierarchicalNode): DropdownItem[] {\n    // Handle hierarchical data structure\n    if (row.type === 'department') {\n      return [\n        {\n          id: 'addDesignation',\n          label: 'Add Designation',\n          icon: 'add',\n          iconColor: 'tw-text-blue-400',\n          textColor: 'tw-text-blue-600',\n          hoverBgColor: 'hover:tw-bg-blue-50'\n        }\n      ];\n    } else {\n      // For designations\n      return [\n        {\n          id: 'edit',\n          label: 'Edit',\n          icon: 'edit',\n          iconColor: 'tw-text-gray-400',\n          textColor: 'tw-text-gray-700',\n          hoverBgColor: 'hover:tw-bg-gray-100'\n        },\n        {\n          id: 'addChild',\n          label: 'Add Child',\n          icon: 'add',\n          iconColor: 'tw-text-blue-400',\n          textColor: 'tw-text-blue-600',\n          hoverBgColor: 'hover:tw-bg-blue-50'\n        },\n        {\n          id: 'toggle',\n          label: row.status ? 'Deactivate' : 'Activate',\n          icon: 'power_settings_new',\n          iconColor: 'tw-text-gray-400',\n          textColor: 'tw-text-gray-700',\n          hoverBgColor: 'hover:tw-bg-gray-100'\n        },\n        {\n          id: 'delete',\n          label: 'Delete',\n          icon: 'delete',\n          iconColor: 'tw-text-red-400',\n          textColor: 'tw-text-red-600',\n          hoverBgColor: 'hover:tw-bg-red-50'\n        }\n      ];\n    }\n  }\n\n  /**\n   * Handle dropdown item click\n   */\n  onDropdownItemClick(item: DropdownItem, row: HierarchicalNode): void {\n    console.log('🔵 onDropdownItemClick called with:', item, row);\n\n    switch (item.id) {\n      case 'edit':\n        if (row.type === 'designation') {\n          this.editDesignation(row._id);\n        }\n        break;\n      case 'addChild':\n        if (row.type === 'designation') {\n          // Find the original designation object\n          const designation = this.designations().find(d => d._id === row._id);\n          if (designation) {\n            this.onAddChild(designation);\n          }\n        }\n        break;\n      case 'addDesignation':\n        if (row.type === 'department') {\n          // Extract department ID from the prefixed ID\n          const departmentId = row._id.replace('dept_', '');\n          const department = this.departments().find(d => d._id === departmentId);\n          if (department) {\n            console.log('🔵 Adding designation to department:', department.sydept_name);\n            this.onDepartmentSelect(department);\n            // Reset form to add mode\n            this.isEditMode.set(false);\n            this.retrievedDesignation.set(null);\n            this.selectedParentDesignation.set(null);\n            this.resetQuickAddForm();\n          }\n        }\n        break;\n      case 'toggle':\n        if (row.type === 'designation') {\n          this.toggleDesignationStatus(row._id);\n        }\n        break;\n      case 'delete':\n        if (row.type === 'designation') {\n          this.deleteDesignation(row._id);\n        }\n        break;\n      default:\n        console.log('🔵 Unknown action:', item.id);\n    }\n\n    this.closeAllDropdowns();\n  }\n\n  /**\n   * Close all dropdowns\n   */\n  private closeAllDropdowns(): void {\n    const event = new MouseEvent('click', { bubbles: true });\n    document.dispatchEvent(event);\n  }\n\n  /**\n   * Track by function for ngFor\n   */\n  trackByItemId(index: number, item: ICoreSydsg): string {\n    return item._id || '';\n  }\n} ","<!-- Designation List Container -->\n<div class=\"tw-table tw-w-full tw-h-full\">\n\n  <!-- Quick Add Form Section -->\n  <div class=\"tw-table-row tw-h-0\">\n    <div class=\"tw-table-cell tw-px-6 tw-py-4 tw-border-b tw-border-gray-200 tw-bg-white\">\n    <div class=\"tw-flex tw-items-center tw-justify-between tw-mb-0\">\n      <div class=\"tw-flex tw-items-center tw-space-x-3 tw-mb-3\">\n        <cide-ele-icon class=\"tw-text-blue-600 tw-w-5 tw-h-5\">{{ isEditMode() ? 'edit' : 'add' }}</cide-ele-icon>\n        <h6 class=\"tw-text-sm tw-font-medium tw-text-gray-900 tw-m-0\">{{ isEditMode() ? 'Edit Designation' : 'Quick Add Designation' }}</h6>\n      </div>\n      @if (selectedParentDesignation()) {\n        <div class=\"tw-flex tw-items-center tw-space-x-3 tw-bg-blue-50 tw-border tw-border-blue-200 tw-px-4 tw-py-1 tw-rounded-lg\">\n          <cide-ele-icon class=\"tw-text-blue-600 tw-w-4 tw-h-4\">account_tree</cide-ele-icon>\n          <div class=\"tw-flex tw-items-center tw-space-x-2\">\n            <span class=\"tw-text-sm tw-text-blue-600 tw-font-medium\">{{ isEditMode() ? 'Parent:' : 'Creating child under:' }}</span>\n            <span class=\"tw-text-sm tw-text-blue-800 tw-font-semibold\">{{ selectedParentDesignation()?.sydsg_name }}</span>\n          </div>\n          <button \n            cideEleButton \n            variant=\"ghost\" \n            size=\"xs\" \n            type=\"button\" \n            (click)=\"clearSelectedParent()\" \n            class=\"tw-text-blue-400 hover:tw-text-blue-600\">\n            <svg class=\"tw-w-4 tw-h-4\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n              <path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M6 18L18 6M6 6l12 12\"/>\n            </svg>\n          </button>\n        </div>\n      }\n      @if (selectedParentDepartment()) {\n        <div class=\"tw-flex tw-items-center tw-space-x-3 tw-bg-green-50 tw-border tw-border-green-200 tw-px-4 tw-py-1 tw-rounded-lg\">\n          <cide-ele-icon class=\"tw-text-green-600 tw-w-4 tw-h-4\">business</cide-ele-icon>\n          <div class=\"tw-flex tw-items-center tw-space-x-2\">\n            <span class=\"tw-text-sm tw-text-green-600 tw-font-medium\">{{ isEditMode() ? 'Department:' : 'Department:' }}</span>\n            <span class=\"tw-text-sm tw-text-green-800 tw-font-semibold\">{{ selectedParentDepartment()?.sydept_name }}</span>\n          </div>\n          <button \n            cideEleButton \n            variant=\"ghost\" \n            size=\"xs\" \n            type=\"button\" \n            (click)=\"clearSelectedParentDepartment()\" \n            class=\"tw-text-green-400 hover:tw-text-green-600\">\n            <svg class=\"tw-w-4 tw-h-4\" fill=\"none\" stroke=\"currentColor\" viewBox=\"0 0 24 24\">\n              <path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M6 18L18 6M6 6l12 12\"/>\n            </svg>\n          </button>\n        </div>\n      }\n    </div>\n    \n    <form [formGroup]=\"quickAddForm\" (ngSubmit)=\"quickAddDesignation()\">\n    <!-- First Row -->\n    <div class=\"tw-grid tw-grid-cols-1 md:tw-grid-cols-2 lg:tw-grid-cols-5 tw-gap-3 tw-mb-3\">\n      <!-- Designation Name -->\n      <div>\n        <cide-ele-input \n          id=\"sydsg_name\" \n          label=\"Name*\" \n          formControlName=\"sydsg_name\"\n          placeholder=\"Designation name\"\n          size=\"sm\">\n        </cide-ele-input>\n      </div>\n      \n      <!-- Designation Code -->\n      <div>\n        <cide-ele-input \n          id=\"sydsg_code\" \n          label=\"Code*\" \n          formControlName=\"sydsg_code\"\n          placeholder=\"DESG001\"\n          size=\"sm\">\n        </cide-ele-input>\n      </div>\n      \n      <!-- Grade Level -->\n      <div>\n        <cide-ele-select \n          id=\"sydsg_grade_level_id_sydsgl\"\n          label=\"Grade Level*\" \n          [options]=\"gradeLevelOptions()\" \n          formControlName=\"sydsg_grade_level_id_sydsgl\"\n          placeholder=\"Select grade level\"\n          size=\"sm\">\n        </cide-ele-select>\n      </div>\n      \n      <!-- Department -->\n      <div>\n        <cide-ele-select \n          id=\"sydsg_department_id_sydpt\"\n          label=\"Department*\" \n          [options]=\"departmentOptions()\" \n          formControlName=\"sydsg_department_id_sydpt\"\n          placeholder=\"Select department\"\n          size=\"sm\">\n        </cide-ele-select>\n      </div>\n      \n      <!-- Active Status -->\n      <div class=\"tw-flex tw-flex-col tw-justify-end\">\n        <cide-ele-input \n          id=\"sydsg_isactive\"\n          type=\"checkbox\"\n          label=\"Active\"\n          formControlName=\"sydsg_isactive\"\n          size=\"sm\">\n        </cide-ele-input>\n      </div>\n    </div>\n    \n    <!-- Second Row -->\n    <div class=\"tw-grid tw-grid-cols-1 md:tw-grid-cols-2 lg:tw-grid-cols-4 tw-gap-3 tw-items-end\">\n      <!-- Description -->\n      <div>\n        <cide-ele-textarea \n          id=\"sydsg_description\" \n          label=\"Description\" \n          formControlName=\"sydsg_description\"\n          placeholder=\"Designation description\"\n          rows=\"2\"\n          size=\"sm\">\n        </cide-ele-textarea>\n      </div>\n      \n      <!-- Entity ID (Hidden) -->\n      <div class=\"tw-hidden\">\n        <cide-ele-input \n          id=\"desg_entity_id_syen\" \n          label=\"Entity ID*\" \n          formControlName=\"desg_entity_id_syen\"\n          placeholder=\"Entity ID\"\n          size=\"sm\">\n        </cide-ele-input>\n      </div>\n      \n      <!-- Action Buttons -->\n      <div class=\"tw-flex tw-flex-col tw-justify-end\">\n        <div class=\"tw-flex tw-space-x-2\">\n          <button \n            cideEleButton \n            variant=\"primary\" \n            size=\"sm\" \n            type=\"submit\"\n            [disabled]=\"quickAddForm.invalid\"\n            class=\"tw-px-2 tw-py-1 tw-w-20\">\n            <cide-ele-icon size=\"xs\" class=\"tw-w-4 tw-h-4 tw-mr-1\">{{ isEditMode() ? 'edit' : 'add' }}</cide-ele-icon>\n            {{ isEditMode() ? 'Update' : 'Add' }}\n          </button>\n          <button \n            cideEleButton \n            variant=\"outline\" \n            size=\"sm\" \n            type=\"button\"\n            (click)=\"resetQuickAddForm()\"\n            class=\"tw-px-2 tw-py-1 tw-w-16\">\n            <cide-ele-icon size=\"xs\" class=\"tw-w-4 tw-h-4 tw-mr-1\">refresh</cide-ele-icon>\n            Reset\n          </button>\n        </div>\n      </div>\n    </div>\n    </form>\n    </div>\n  </div>\n\n\n\n  <!-- Header Section with Filters -->\n  <div class=\"tw-table-row tw-h-0\">\n    <div class=\"tw-table-cell tw-px-6 tw-py-3 tw-border-b tw-border-gray-200 tw-bg-gray-50\">\n    <div\n      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\">\n\n      <!-- Title -->\n      <div class=\"tw-flex tw-items-center tw-space-x-2\">\n        <cide-ele-icon class=\"tw-text-blue-600 tw-w-5 tw-h-5\">work</cide-ele-icon>\n        <h5 class=\"tw-text-base tw-font-medium tw-text-gray-900 tw-m-0\">Designation Management</h5>\n      </div>\n\n      <!-- Actions -->\n      <div\n        class=\"tw-flex tw-flex-col sm:tw-flex-row tw-items-start sm:tw-items-center tw-space-y-3 sm:tw-space-y-0 sm:tw-space-x-3\">\n        <!-- Search functionality is handled by the data grid -->\n      </div>\n    </div>\n\n    <!-- Error Message -->\n    @if (error()) {\n    <div class=\"tw-mt-4 tw-p-4 tw-bg-red-50 tw-border tw-border-red-200 tw-rounded-md\">\n      <div class=\"tw-flex tw-items-start\">\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>\n        <div class=\"tw-ml-3\">\n          <h3 class=\"tw-text-sm tw-font-medium tw-text-red-800 tw-m-0\">Error</h3>\n          <p class=\"tw-text-sm tw-text-red-700 tw-mt-1 tw-m-0\">{{ error() }}</p>\n        </div>\n      </div>\n    </div>\n    }\n    </div>\n  </div>\n\n  <!-- Main Content Area -->\n  <div class=\"tw-table-row\">\n    <div class=\"tw-table-cell tw-h-full tw-relative\">\n  \n  <!-- Data Grid Component -->\n  <div class=\"tw-h-full tw-overflow-auto\">\n    \n    <cide-ele-data-grid \n      [config]=\"gridConfig()\" \n      [templateRenderers]=\"getTemplateRenderers()\"\n      [actionHandlers]=\"actionHandlers\"\n      [serverSidePagination]=\"true\" \n      [totalServerItems]=\"totalItems()\" \n      [currentServerPage]=\"currentPage()\"\n      [currentServerPageSize]=\"pageSize()\" \n      (gridEvent)=\"onGridEvent($event)\">\n    </cide-ele-data-grid>\n  </div>\n\n    </div>\n  </div>\n\n</div>\n\n<!-- Designation Details Renderer Template -->\n<ng-template #designationDetailsRendererTemplate let-row=\"row\" let-value=\"value\">\n  <div class=\"tw-flex tw-items-center tw-min-w-0\">\n    <!-- Dynamic Icon based on type -->\n    <div class=\"tw-flex-shrink-0\">\n      <cide-ele-icon \n        [class]=\"row.type === 'department' ? 'tw-text-green-500' : 'tw-text-blue-500'\" \n        size=\"xs\">\n        {{ row.type === 'department' ? 'business' : 'work' }}\n      </cide-ele-icon>\n    </div>\n    \n    <!-- Details -->\n    <div class=\"tw-ml-3 tw-min-w-0 tw-flex-1\">\n      <div class=\"tw-flex tw-items-center tw-space-x-2\">\n        <div class=\"tw-text-sm tw-font-medium tw-text-gray-900 tw-truncate\" \n             [title]=\"row.name\">\n          {{ row.name || 'Untitled' }}\n        </div>\n        @if (row.type === 'department') {\n          <span class=\"tw-inline-flex tw-items-center tw-px-2 tw-py-0.5 tw-rounded-full tw-text-xs tw-font-medium tw-bg-green-100 tw-text-green-800\">\n            Department\n          </span>\n        }\n      </div>\n      @if (row.description) {\n        <div class=\"tw-text-xs tw-text-gray-500 tw-truncate\" \n             [title]=\"row.description\">\n          {{ row.description }}\n        </div>\n      }\n    </div>\n  </div>\n</ng-template>\n\n<!-- Designation Status Renderer Template -->\n<ng-template #designationStatusRendererTemplate let-row=\"row\" let-value=\"value\">\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\"\n        [ngClass]=\"getStatusClass(row.status)\">\n    {{ getStatusDisplay(row.status) }}\n  </span>\n</ng-template>\n\n<!-- Actions Dropdown Renderer Template -->\n<ng-template #actionsDropdownRendererTemplate let-row=\"row\" let-value=\"value\">\n  <cide-ele-dropdown \n    [items]=\"getDropdownItems(row)\"\n    [config]=\"{ triggerIcon: 'more_vert', triggerSize: 'sm' }\"\n    (itemClick)=\"onDropdownItemClick($event, row)\">\n  </cide-ele-dropdown>\n</ng-template> "]}