cloud-ide-core 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (53) hide show
  1. package/README.md +24 -0
  2. package/esm2022/cloud-ide-core.mjs +5 -0
  3. package/esm2022/lib/cloud-ide-core.component.mjs +19 -0
  4. package/esm2022/lib/cloud-ide-core.service.mjs +14 -0
  5. package/esm2022/lib/core/department-management/components/department-list/department-list.component.mjs +768 -0
  6. package/esm2022/lib/core/department-management/index.mjs +5 -0
  7. package/esm2022/lib/core/department-management/services/department-management.service.mjs +187 -0
  8. package/esm2022/lib/core/designation-management/components/designation-list/designation-list.component.mjs +1122 -0
  9. package/esm2022/lib/core/designation-management/index.mjs +5 -0
  10. package/esm2022/lib/core/designation-management/services/designation-management.service.mjs +194 -0
  11. package/esm2022/lib/core/grade-level-management/components/grade-level-list/grade-level-list.component.mjs +794 -0
  12. package/esm2022/lib/core/grade-level-management/index.mjs +5 -0
  13. package/esm2022/lib/core/grade-level-management/services/grade-level-management.service.mjs +172 -0
  14. package/esm2022/lib/core/menu-management/components/menu-list/menu-list.component.mjs +1135 -0
  15. package/esm2022/lib/core/menu-management/index.mjs +10 -0
  16. package/esm2022/lib/core/menu-management/interfaces/menu-item.interface.mjs +11 -0
  17. package/esm2022/lib/core/menu-management/mock-data/menu-items.json +311 -0
  18. package/esm2022/lib/core/menu-management/services/menu-management.service.mjs +230 -0
  19. package/esm2022/lib/core/page-management/components/page-controls/page-controls.component.mjs +483 -0
  20. package/esm2022/lib/core/page-management/components/page-list/page-list.component.mjs +393 -0
  21. package/esm2022/lib/core/page-management/components/page-theme/page-theme.component.mjs +767 -0
  22. package/esm2022/lib/core/page-management/index.mjs +10 -0
  23. package/esm2022/lib/core/page-management/services/page-controls.service.mjs +136 -0
  24. package/esm2022/lib/core/page-management/services/page-management.service.mjs +98 -0
  25. package/esm2022/lib/core/page-management/services/page-theme.service.mjs +107 -0
  26. package/esm2022/public-api.mjs +16 -0
  27. package/fesm2022/cloud-ide-core.mjs +6859 -0
  28. package/fesm2022/cloud-ide-core.mjs.map +1 -0
  29. package/index.d.ts +5 -0
  30. package/lib/cloud-ide-core.component.d.ts +5 -0
  31. package/lib/cloud-ide-core.service.d.ts +6 -0
  32. package/lib/core/department-management/components/department-list/department-list.component.d.ts +178 -0
  33. package/lib/core/department-management/index.d.ts +2 -0
  34. package/lib/core/department-management/services/department-management.service.d.ts +68 -0
  35. package/lib/core/designation-management/components/designation-list/designation-list.component.d.ts +242 -0
  36. package/lib/core/designation-management/index.d.ts +2 -0
  37. package/lib/core/designation-management/services/designation-management.service.d.ts +69 -0
  38. package/lib/core/grade-level-management/components/grade-level-list/grade-level-list.component.d.ts +199 -0
  39. package/lib/core/grade-level-management/index.d.ts +2 -0
  40. package/lib/core/grade-level-management/services/grade-level-management.service.d.ts +69 -0
  41. package/lib/core/menu-management/components/menu-list/menu-list.component.d.ts +278 -0
  42. package/lib/core/menu-management/index.d.ts +3 -0
  43. package/lib/core/menu-management/interfaces/menu-item.interface.d.ts +30 -0
  44. package/lib/core/menu-management/services/menu-management.service.d.ts +85 -0
  45. package/lib/core/page-management/components/page-controls/page-controls.component.d.ts +126 -0
  46. package/lib/core/page-management/components/page-list/page-list.component.d.ts +91 -0
  47. package/lib/core/page-management/components/page-theme/page-theme.component.d.ts +189 -0
  48. package/lib/core/page-management/index.d.ts +6 -0
  49. package/lib/core/page-management/services/page-controls.service.d.ts +54 -0
  50. package/lib/core/page-management/services/page-management.service.d.ts +42 -0
  51. package/lib/core/page-management/services/page-theme.service.d.ts +43 -0
  52. package/package.json +25 -0
  53. package/public-api.d.ts +7 -0
@@ -0,0 +1,768 @@
1
+ import { Component, signal, computed, viewChild, DestroyRef, inject } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { ReactiveFormsModule, NonNullableFormBuilder, FormsModule } from '@angular/forms';
4
+ import { Router } from '@angular/router';
5
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
6
+ import { DepartmentManagementService } from '../../services/department-management.service';
7
+ import { AppStateHelperService } from 'cloud-ide-layout';
8
+ import { CideEleButtonComponent, CideEleDataGridComponent, CideIconComponent, CideInputComponent, CideTextareaComponent, CideEleDropdownComponent, ConfirmationService, NotificationService, CideEleGlobalNotificationsComponent } from 'cloud-ide-element';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "@angular/common";
11
+ import * as i2 from "@angular/forms";
12
+ export class DepartmentListComponent {
13
+ /**
14
+ * Get template renderers for data grid
15
+ */
16
+ getTemplateRenderers() {
17
+ return this.templateRenderers();
18
+ }
19
+ /**
20
+ * Get custom renderers adapted for current data grid compatibility
21
+ */
22
+ getCustomRenderers() {
23
+ return {};
24
+ }
25
+ // Modern constructor with effects for initialization
26
+ constructor() {
27
+ // Dependency injection
28
+ this.destroyRef = inject(DestroyRef);
29
+ this.departmentService = inject(DepartmentManagementService);
30
+ this.appState = inject(AppStateHelperService);
31
+ this.fb = inject(NonNullableFormBuilder);
32
+ this.router = inject(Router);
33
+ this.confirmationService = inject(ConfirmationService);
34
+ this.notificationService = inject(NotificationService);
35
+ // Modern ViewChild signals for template renderers (Angular 20 approach)
36
+ this.departmentDetailsRendererTemplate = viewChild.required('departmentDetailsRendererTemplate');
37
+ this.departmentStatusRendererTemplate = viewChild.required('departmentStatusRendererTemplate');
38
+ this.actionsDropdownRendererTemplate = viewChild.required('actionsDropdownRendererTemplate');
39
+ // Make Math available in template
40
+ this.Math = Math;
41
+ // Signals for reactive state management
42
+ this.departments = signal([]);
43
+ this.loading = signal(false);
44
+ this.error = signal(null);
45
+ this.selectedItems = signal([]);
46
+ this.searchTerm = signal('');
47
+ // Modern reactive forms with signals
48
+ this.selectedParentDepartment = signal(null);
49
+ // Retrieved department data
50
+ this.retrievedDepartment = signal(null);
51
+ // Edit mode flag
52
+ this.isEditMode = signal(false);
53
+ // Server-side pagination state
54
+ this.currentPage = signal(1);
55
+ this.pageSize = signal(10);
56
+ this.totalItems = signal(0);
57
+ // Modern reactive form with typed controls
58
+ this.quickAddForm = this.fb.group({
59
+ sydept_code: this.fb.control('', []),
60
+ sydept_name: this.fb.control('', []),
61
+ sydept_description: this.fb.control('', []),
62
+ sydept_isactive: this.fb.control(true, []),
63
+ sydept_department_id_sydept: this.fb.control(''),
64
+ sydept_entity_id_syen: this.fb.control(this.appState.getActiveEntityId() || '', [])
65
+ });
66
+ // Grid configuration signal
67
+ this.gridConfig = signal({
68
+ id: 'department-list-grid',
69
+ title: '',
70
+ subtitle: '',
71
+ columns: [
72
+ {
73
+ key: 'details',
74
+ header: 'Department',
75
+ type: 'custom',
76
+ width: 'auto',
77
+ truncate: true,
78
+ align: 'left',
79
+ renderer: 'departmentDetailsRenderer'
80
+ },
81
+ {
82
+ key: 'sydept_code',
83
+ header: 'Code',
84
+ type: 'text',
85
+ width: '120px',
86
+ truncate: true,
87
+ align: 'left'
88
+ },
89
+ {
90
+ key: 'sydept_isactive',
91
+ header: 'Status',
92
+ type: 'custom',
93
+ width: '100px',
94
+ truncate: false,
95
+ align: 'center',
96
+ renderer: 'departmentStatusRenderer'
97
+ },
98
+ {
99
+ key: 'actions',
100
+ header: '',
101
+ type: 'custom',
102
+ width: '60px',
103
+ truncate: false,
104
+ align: 'center',
105
+ renderer: 'actionsDropdownRenderer'
106
+ }
107
+ ],
108
+ data: [],
109
+ tree: {
110
+ enabled: true,
111
+ primaryKey: '_id',
112
+ foreignKey: 'sydept_department_id_sydept',
113
+ childrenKey: 'children',
114
+ levelKey: 'level',
115
+ expandedKey: 'expanded',
116
+ hasChildrenKey: 'hasChildren'
117
+ },
118
+ trackBy: '_id',
119
+ pagination: {
120
+ enabled: false,
121
+ pageSize: 10,
122
+ pageSizeOptions: [10, 25, 50, 100],
123
+ showQuickJump: true,
124
+ showPageInfo: true,
125
+ showRefresh: true
126
+ },
127
+ search: {
128
+ enabled: true,
129
+ placeholder: 'Search departments...',
130
+ searchableColumns: ['sydept_name', 'sydept_code', 'sydept_description'],
131
+ debounceMs: 300
132
+ },
133
+ loading: {
134
+ useDefer: true,
135
+ skeletonRows: 5,
136
+ showOverlay: false
137
+ },
138
+ scroll: {
139
+ enabled: true,
140
+ maxHeight: '',
141
+ minHeight: '',
142
+ stickyHeader: true,
143
+ virtualScroll: false,
144
+ rowHeight: 50
145
+ },
146
+ responsive: true,
147
+ striped: false,
148
+ bordered: true,
149
+ compact: false,
150
+ tableClass: 'tw-table-fixed tw-w-full tw-rounded-none',
151
+ onRefresh: 'onDepartmentRefresh'
152
+ });
153
+ // Template renderers using Angular best practices
154
+ this.templateRenderers = computed(() => ({
155
+ departmentDetailsRenderer: this.departmentDetailsRendererTemplate(),
156
+ departmentStatusRenderer: this.departmentStatusRendererTemplate(),
157
+ actionsDropdownRenderer: this.actionsDropdownRendererTemplate()
158
+ }));
159
+ // Mixed renderers (templates + string functions)
160
+ this.customRenderers = computed(() => ({
161
+ ...this.templateRenderers()
162
+ }));
163
+ // Action handlers for grid actions
164
+ this.actionHandlers = {
165
+ onEditDepartment: (row) => this.editDepartment(row._id || ''),
166
+ onToggleDepartment: (row) => this.toggleDepartmentStatus(row._id || ''),
167
+ onDeleteDepartment: (row) => this.deleteDepartment(row._id || ''),
168
+ onDepartmentRowClick: (row) => this.onDepartmentRowClick(row),
169
+ onDepartmentRefresh: () => this.onDepartmentRefresh(),
170
+ onAddChild: (row) => this.onAddChild(row)
171
+ };
172
+ // Computed properties
173
+ this.filteredItems = computed(() => {
174
+ const items = this.departments();
175
+ const search = this.searchTerm()?.toLowerCase();
176
+ if (!search)
177
+ return items;
178
+ return items.filter(item => {
179
+ return item.sydept_name?.toLowerCase().includes(search) ||
180
+ item.sydept_code?.toLowerCase().includes(search) ||
181
+ item.sydept_description?.toLowerCase().includes(search);
182
+ });
183
+ });
184
+ this.hasSelection = computed(() => this.selectedItems().length > 0);
185
+ // Pagination computed properties
186
+ this.totalPages = computed(() => Math.ceil(this.totalItems() / this.pageSize()));
187
+ this.hasNextPage = computed(() => this.currentPage() < this.totalPages());
188
+ this.hasPreviousPage = computed(() => this.currentPage() > 1);
189
+ this.initializeComponent();
190
+ this.destroyRef.onDestroy(() => {
191
+ this.cleanupEventListeners();
192
+ });
193
+ }
194
+ /**
195
+ * Initialize component with modern patterns
196
+ */
197
+ initializeComponent() {
198
+ console.log('DepartmentListComponent initialized with modern Angular patterns');
199
+ this.loadDepartments();
200
+ this.setupEventListeners();
201
+ this.exposeGlobalFunctions();
202
+ }
203
+ /**
204
+ * Setup event listeners for dropdown interactions
205
+ */
206
+ setupEventListeners() {
207
+ document.addEventListener('click', this.handleClickOutside.bind(this));
208
+ document.addEventListener('click', this.handleDropdownAction.bind(this));
209
+ }
210
+ /**
211
+ * Cleanup event listeners
212
+ */
213
+ cleanupEventListeners() {
214
+ document.removeEventListener('click', this.handleClickOutside.bind(this));
215
+ document.removeEventListener('click', this.handleDropdownAction.bind(this));
216
+ }
217
+ /**
218
+ * Expose global functions for dropdown interactions
219
+ */
220
+ exposeGlobalFunctions() {
221
+ if (typeof window !== 'undefined') {
222
+ window.toggleDropdown = this.toggleDropdown.bind(this);
223
+ window.handleDepartmentAction = this.handleDepartmentAction.bind(this);
224
+ }
225
+ }
226
+ /**
227
+ * Load departments from service
228
+ */
229
+ loadDepartments() {
230
+ console.log('🚀 DepartmentListComponent.loadDepartments() called');
231
+ this.loading.set(true);
232
+ this.error.set(null);
233
+ const requestBody = {
234
+ total: this.totalItems(),
235
+ pageIndex: this.currentPage(),
236
+ pageSize: this.pageSize(),
237
+ query: this.searchTerm()
238
+ };
239
+ console.log('📋 Request body:', requestBody);
240
+ if (!this.departmentService) {
241
+ console.error('❌ DepartmentService is not available');
242
+ this.error.set('Department service is not available');
243
+ this.loading.set(false);
244
+ return;
245
+ }
246
+ this.departmentService.getDepartmentList(requestBody)
247
+ .pipe(takeUntilDestroyed(this.destroyRef))
248
+ .subscribe({
249
+ next: (response) => {
250
+ console.log('📥 DepartmentListComponent received response:', response);
251
+ if (response?.success) {
252
+ console.log('✅ Response successful, setting departments:', response.data);
253
+ const departmentData = response?.data || [];
254
+ this.departments.set(departmentData);
255
+ this.totalItems.set(response.total || 0);
256
+ this.updateGridData(departmentData);
257
+ }
258
+ else {
259
+ console.error('❌ Response was not successful:', response);
260
+ this.error.set('Failed to load departments');
261
+ }
262
+ },
263
+ error: (err) => {
264
+ console.error('❌ DepartmentListComponent error:', err);
265
+ this.error.set(err.message || 'An error occurred while loading departments');
266
+ },
267
+ complete: () => {
268
+ console.log('DepartmentListComponent loadDepartments completed');
269
+ this.loading.set(false);
270
+ }
271
+ });
272
+ }
273
+ /**
274
+ * Update grid data
275
+ */
276
+ updateGridData(departments) {
277
+ console.log('🔄 updateGridData called with:', departments);
278
+ this.gridConfig.update(config => {
279
+ const newConfig = {
280
+ ...config,
281
+ data: departments
282
+ };
283
+ console.log('⚙️ Updated grid config with departments');
284
+ return newConfig;
285
+ });
286
+ }
287
+ /**
288
+ * Handle grid events
289
+ */
290
+ onGridEvent(event) {
291
+ console.log('onGridEvent', event);
292
+ switch (event.type) {
293
+ case 'search':
294
+ this.searchTerm.set(event.data);
295
+ this.currentPage.set(1);
296
+ this.loadDepartments();
297
+ break;
298
+ case 'pageChange': {
299
+ const pageData = event.data;
300
+ if (pageData) {
301
+ this.currentPage.set(pageData.page);
302
+ this.pageSize.set(pageData.pageSize);
303
+ this.loadDepartments();
304
+ }
305
+ else {
306
+ const page = event.data;
307
+ if (page) {
308
+ this.currentPage.set(page);
309
+ this.loadDepartments();
310
+ }
311
+ }
312
+ break;
313
+ }
314
+ case 'refresh':
315
+ this.onDepartmentRefresh();
316
+ break;
317
+ case 'rowClick':
318
+ this.onDepartmentRowClick(event.data);
319
+ break;
320
+ case 'action':
321
+ if (event.action?.key === 'edit') {
322
+ this.editDepartment(event.data);
323
+ }
324
+ else if (event.action?.key === 'toggle') {
325
+ this.toggleDepartmentStatus(event.data);
326
+ }
327
+ else if (event.action?.key === 'delete') {
328
+ this.deleteDepartment(event.data);
329
+ }
330
+ break;
331
+ }
332
+ }
333
+ /**
334
+ * Handle department refresh
335
+ */
336
+ onDepartmentRefresh() {
337
+ this.loadDepartments();
338
+ }
339
+ /**
340
+ * Handle department row click
341
+ */
342
+ onDepartmentRowClick(department) {
343
+ this.editDepartment(department._id || '');
344
+ }
345
+ /**
346
+ * Navigate to edit department form
347
+ */
348
+ editDepartment(itemId) {
349
+ console.log('🔵 editDepartment called with:', itemId);
350
+ this.isEditMode.set(true);
351
+ this.getDepartmentById(itemId);
352
+ }
353
+ /**
354
+ * Get department by ID using the API
355
+ */
356
+ getDepartmentById(itemId) {
357
+ console.log('🔵 getDepartmentById called with:', itemId);
358
+ this.loading.set(true);
359
+ this.departmentService.getDepartmentById(itemId)
360
+ .pipe(takeUntilDestroyed(this.destroyRef))
361
+ .subscribe({
362
+ next: (response) => {
363
+ if (response.success) {
364
+ console.log('✅ Department retrieved successfully:', response.data);
365
+ let department = null;
366
+ department = response.data || null;
367
+ this.retrievedDepartment.set(department);
368
+ if (this.isEditMode() && department) {
369
+ this.populateFormForEdit(department);
370
+ }
371
+ }
372
+ else {
373
+ this.error.set('Failed to retrieve department');
374
+ }
375
+ },
376
+ error: (err) => {
377
+ this.error.set(err.message || 'An error occurred while retrieving the department');
378
+ },
379
+ complete: () => {
380
+ this.loading.set(false);
381
+ }
382
+ });
383
+ }
384
+ /**
385
+ * Populate form with department data for editing
386
+ */
387
+ populateFormForEdit(department) {
388
+ console.log('🔵 populateFormForEdit called with:', department);
389
+ this.quickAddForm.patchValue({
390
+ sydept_code: department.sydept_code || '',
391
+ sydept_name: department.sydept_name || '',
392
+ sydept_description: department.sydept_description || '',
393
+ sydept_isactive: department.sydept_isactive ?? true,
394
+ sydept_department_id_sydept: department.sydept_department_id_sydept || '',
395
+ sydept_entity_id_syen: department.sydept_entity_id_syen || ''
396
+ });
397
+ if (department.sydept_department_id_sydept) {
398
+ const parentDepartment = this.departments().find(item => item._id === department.sydept_department_id_sydept);
399
+ if (parentDepartment) {
400
+ this.selectedParentDepartment.set(parentDepartment);
401
+ }
402
+ }
403
+ console.log('✅ Form populated for editing:', this.quickAddForm.value);
404
+ }
405
+ /**
406
+ * Delete department
407
+ */
408
+ async deleteDepartment(itemId) {
409
+ console.log('🔵 deleteDepartment called with:', itemId);
410
+ // Find the department name for better confirmation message
411
+ const department = this.departments().find(d => d._id === itemId);
412
+ const departmentName = department?.sydept_name || 'this department';
413
+ try {
414
+ const confirmed = await this.confirmationService.confirmDelete(departmentName);
415
+ if (confirmed) {
416
+ this.loading.set(true);
417
+ this.departmentService.deleteDepartment(itemId)
418
+ .pipe(takeUntilDestroyed(this.destroyRef))
419
+ .subscribe({
420
+ next: (response) => {
421
+ if (response.success) {
422
+ this.notificationService.success(`Department "${departmentName}" deleted successfully`);
423
+ this.loadDepartments();
424
+ }
425
+ else {
426
+ this.notificationService.error('Failed to delete department');
427
+ }
428
+ },
429
+ error: (err) => {
430
+ this.notificationService.error(err.message || 'An error occurred while deleting the department');
431
+ },
432
+ complete: () => {
433
+ this.loading.set(false);
434
+ }
435
+ });
436
+ }
437
+ }
438
+ catch (error) {
439
+ console.log('User cancelled deletion');
440
+ }
441
+ }
442
+ /**
443
+ * Toggle department status
444
+ */
445
+ toggleDepartmentStatus(itemId) {
446
+ console.log('🔵 toggleDepartmentStatus called with:', itemId);
447
+ // Find the department for better notification message
448
+ const department = this.departments().find(d => d._id === itemId);
449
+ const departmentName = department?.sydept_name || 'department';
450
+ const newStatus = department?.sydept_isactive ? 'inactive' : 'active';
451
+ this.loading.set(true);
452
+ this.departmentService.toggleDepartmentStatus({ sydept_id: itemId })
453
+ .pipe(takeUntilDestroyed(this.destroyRef))
454
+ .subscribe({
455
+ next: (response) => {
456
+ if (response.success) {
457
+ this.notificationService.success(`Department "${departmentName}" ${newStatus} successfully`);
458
+ this.loadDepartments();
459
+ }
460
+ else {
461
+ this.notificationService.error('Failed to toggle department status');
462
+ }
463
+ },
464
+ error: (err) => {
465
+ this.notificationService.error(err.message || 'An error occurred while toggling status');
466
+ },
467
+ complete: () => {
468
+ this.loading.set(false);
469
+ }
470
+ });
471
+ }
472
+ /**
473
+ * Quick add or update department using reactive form
474
+ */
475
+ quickAddDepartment() {
476
+ if (this.quickAddForm.invalid)
477
+ return;
478
+ const formValue = this.quickAddForm.value;
479
+ const department = {
480
+ _id: this.retrievedDepartment()?._id || '',
481
+ sydept_code: formValue.sydept_code,
482
+ sydept_name: formValue.sydept_name,
483
+ sydept_description: formValue.sydept_description || '',
484
+ sydept_isactive: formValue.sydept_isactive,
485
+ sydept_department_id_sydept: formValue.sydept_department_id_sydept || undefined,
486
+ sydept_entity_id_syen: formValue.sydept_entity_id_syen
487
+ };
488
+ if (this.isEditMode() && this.retrievedDepartment()) {
489
+ const itemId = this.retrievedDepartment()?._id;
490
+ if (itemId) {
491
+ console.log('🔵 Updating department:', itemId);
492
+ this.departmentService.updateDepartment(itemId, department).subscribe({
493
+ next: (response) => {
494
+ if (response.success) {
495
+ console.log('✅ Department updated successfully');
496
+ this.notificationService.success(`Department "${department.sydept_name}" updated successfully`);
497
+ this.resetQuickAddForm();
498
+ this.isEditMode.set(false);
499
+ this.retrievedDepartment.set(null);
500
+ this.loadDepartments();
501
+ }
502
+ else {
503
+ this.notificationService.error('Failed to update department');
504
+ }
505
+ },
506
+ error: (err) => {
507
+ this.notificationService.error(err.message || 'Failed to update department');
508
+ }
509
+ });
510
+ }
511
+ }
512
+ else {
513
+ console.log('🔵 Creating new department');
514
+ this.departmentService.createDepartment(department).subscribe({
515
+ next: (response) => {
516
+ if (response.success) {
517
+ console.log('✅ Department created successfully');
518
+ this.notificationService.success(`Department "${department.sydept_name}" created successfully`);
519
+ this.resetQuickAddForm();
520
+ this.loadDepartments();
521
+ }
522
+ else {
523
+ this.notificationService.error('Failed to create department');
524
+ }
525
+ },
526
+ error: (err) => {
527
+ this.notificationService.error(err.message || 'Failed to create department');
528
+ }
529
+ });
530
+ }
531
+ }
532
+ /**
533
+ * Reset the quick add form to default values
534
+ */
535
+ resetQuickAddForm() {
536
+ this.selectedParentDepartment.set(null);
537
+ this.isEditMode.set(false);
538
+ this.retrievedDepartment.set(null);
539
+ this.quickAddForm.reset({
540
+ sydept_code: '',
541
+ sydept_name: '',
542
+ sydept_description: '',
543
+ sydept_isactive: true,
544
+ sydept_department_id_sydept: '',
545
+ sydept_entity_id_syen: this.appState.getActiveEntityId() || ''
546
+ });
547
+ }
548
+ /**
549
+ * Handle adding a child department
550
+ */
551
+ onAddChild(parentItem) {
552
+ console.log('🔵 onAddChild called with:', parentItem);
553
+ console.log('🔵 Parent name:', parentItem.sydept_name);
554
+ // Clear edit mode and retrieved item when adding a child
555
+ this.isEditMode.set(false);
556
+ this.retrievedDepartment.set(null);
557
+ // Set the selected parent item first using signal
558
+ this.selectedParentDepartment.set(parentItem);
559
+ console.log('🔵 selectedParentDepartment set to:', this.selectedParentDepartment());
560
+ // Update form with parent context (don't call resetQuickAddForm as it clears the parent)
561
+ this.quickAddForm.patchValue({
562
+ sydept_code: '',
563
+ sydept_name: '',
564
+ sydept_description: '',
565
+ sydept_isactive: true,
566
+ sydept_department_id_sydept: parentItem._id,
567
+ sydept_entity_id_syen: this.appState.getActiveEntityId() || ''
568
+ });
569
+ console.log('🔵 Form updated, parent should be visible:', this.selectedParentDepartment()?.sydept_name);
570
+ }
571
+ /**
572
+ * Clear selected parent department
573
+ */
574
+ clearSelectedParent() {
575
+ this.selectedParentDepartment.set(null);
576
+ this.quickAddForm.patchValue({
577
+ sydept_department_id_sydept: ''
578
+ });
579
+ }
580
+ /**
581
+ * Handle click outside dropdown
582
+ */
583
+ handleClickOutside(event) {
584
+ const target = event.target;
585
+ if (!target?.closest('[data-dropdown]') && !target?.closest('[data-action="more-actions"]')) {
586
+ document.querySelectorAll('[data-dropdown]').forEach((el) => {
587
+ const dropdown = el;
588
+ dropdown.classList.add('tw-hidden');
589
+ });
590
+ document.querySelectorAll('[data-action="more-actions"]').forEach((el) => {
591
+ const button = el;
592
+ button.setAttribute('aria-expanded', 'false');
593
+ });
594
+ }
595
+ }
596
+ /**
597
+ * Handle dropdown action clicks
598
+ */
599
+ handleDropdownAction(event) {
600
+ const target = event.target;
601
+ const actionButton = target.closest('[data-action]');
602
+ if (actionButton) {
603
+ const action = actionButton.getAttribute('data-action');
604
+ const itemId = actionButton.getAttribute('data-item-id');
605
+ if (action && itemId) {
606
+ event.preventDefault();
607
+ event.stopPropagation();
608
+ const dropdown = actionButton.closest('[data-dropdown]');
609
+ if (dropdown) {
610
+ dropdown.classList.add('tw-hidden');
611
+ }
612
+ switch (action) {
613
+ case 'edit':
614
+ this.editDepartment(itemId);
615
+ break;
616
+ case 'toggle':
617
+ this.toggleDepartmentStatus(itemId);
618
+ break;
619
+ case 'delete':
620
+ this.deleteDepartment(itemId);
621
+ break;
622
+ }
623
+ }
624
+ }
625
+ }
626
+ /**
627
+ * Toggle dropdown visibility
628
+ */
629
+ toggleDropdown(itemId) {
630
+ document.querySelectorAll('.dropdown-menu').forEach(menu => {
631
+ if (menu.getAttribute('data-dropdown') !== itemId) {
632
+ menu.classList.add('tw-hidden');
633
+ }
634
+ });
635
+ const dropdown = document.querySelector(`[data-dropdown="${itemId}"]`);
636
+ if (dropdown) {
637
+ dropdown.classList.toggle('tw-hidden');
638
+ }
639
+ }
640
+ /**
641
+ * Handle department action clicks
642
+ */
643
+ handleDepartmentAction(action, itemId) {
644
+ const item = this.departments().find(item => item._id === itemId);
645
+ if (!item)
646
+ return;
647
+ const dropdown = document.querySelector(`[data-dropdown="${itemId}"]`);
648
+ if (dropdown) {
649
+ dropdown.classList.add('tw-hidden');
650
+ }
651
+ switch (action) {
652
+ case 'edit':
653
+ this.editDepartment(itemId);
654
+ break;
655
+ case 'toggle':
656
+ this.toggleDepartmentStatus(itemId);
657
+ break;
658
+ case 'delete':
659
+ this.deleteDepartment(itemId);
660
+ break;
661
+ }
662
+ }
663
+ /**
664
+ * Get status display
665
+ */
666
+ getStatusDisplay(isActive) {
667
+ return isActive ? 'Active' : 'Inactive';
668
+ }
669
+ /**
670
+ * Get status class for styling
671
+ */
672
+ getStatusClass(isActive) {
673
+ return isActive ? 'tw-bg-green-100 tw-text-green-800' : 'tw-bg-red-100 tw-text-red-800';
674
+ }
675
+ /**
676
+ * Generate dropdown items for department actions
677
+ */
678
+ getDropdownItems(row) {
679
+ return [
680
+ {
681
+ id: 'edit',
682
+ label: 'Edit',
683
+ icon: 'edit',
684
+ iconColor: 'tw-text-gray-400',
685
+ textColor: 'tw-text-gray-700',
686
+ hoverBgColor: 'hover:tw-bg-gray-100'
687
+ },
688
+ {
689
+ id: 'addChild',
690
+ label: 'Add Child',
691
+ icon: 'add',
692
+ iconColor: 'tw-text-blue-400',
693
+ textColor: 'tw-text-blue-600',
694
+ hoverBgColor: 'hover:tw-bg-blue-50'
695
+ },
696
+ {
697
+ id: 'toggle',
698
+ label: row.sydept_isactive ? 'Deactivate' : 'Activate',
699
+ icon: 'power_settings_new',
700
+ iconColor: 'tw-text-gray-400',
701
+ textColor: 'tw-text-gray-700',
702
+ hoverBgColor: 'hover:tw-bg-gray-100'
703
+ },
704
+ {
705
+ id: 'delete',
706
+ label: 'Delete',
707
+ icon: 'delete',
708
+ iconColor: 'tw-text-red-400',
709
+ textColor: 'tw-text-red-600',
710
+ hoverBgColor: 'hover:tw-bg-red-50'
711
+ }
712
+ ];
713
+ }
714
+ /**
715
+ * Handle dropdown item click
716
+ */
717
+ onDropdownItemClick(item, row) {
718
+ console.log('🔵 onDropdownItemClick called with:', item, row);
719
+ switch (item.id) {
720
+ case 'edit':
721
+ this.editDepartment(row._id || '');
722
+ break;
723
+ case 'addChild':
724
+ this.onAddChild(row);
725
+ break;
726
+ case 'toggle':
727
+ this.toggleDepartmentStatus(row._id || '');
728
+ break;
729
+ case 'delete':
730
+ this.deleteDepartment(row._id || '');
731
+ break;
732
+ default:
733
+ console.log('🔵 Unknown action:', item.id);
734
+ }
735
+ this.closeAllDropdowns();
736
+ }
737
+ /**
738
+ * Close all dropdowns
739
+ */
740
+ closeAllDropdowns() {
741
+ const event = new MouseEvent('click', { bubbles: true });
742
+ document.dispatchEvent(event);
743
+ }
744
+ /**
745
+ * Track by function for ngFor
746
+ */
747
+ trackByItemId(index, item) {
748
+ return item._id || '';
749
+ }
750
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: DepartmentListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
751
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: DepartmentListComponent, isStandalone: true, selector: "cide-core-app-department-list", viewQueries: [{ propertyName: "departmentDetailsRendererTemplate", first: true, predicate: ["departmentDetailsRendererTemplate"], descendants: true, isSignal: true }, { propertyName: "departmentStatusRendererTemplate", first: true, predicate: ["departmentStatusRendererTemplate"], descendants: true, isSignal: true }, { propertyName: "actionsDropdownRendererTemplate", first: true, predicate: ["actionsDropdownRendererTemplate"], descendants: true, isSignal: true }], ngImport: i0, template: "<!-- Department List Container -->\n<div class=\"tw-table tw-w-full tw-h-full\">\n\n<!-- Global Notifications -->\n<cide-ele-global-notifications></cide-ele-global-notifications>\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 Department' : 'Quick Add Department' }}</h6>\n </div>\n @if (selectedParentDepartment()) {\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\">{{ selectedParentDepartment()?.sydept_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 </div>\n \n <form [formGroup]=\"quickAddForm\" (ngSubmit)=\"quickAddDepartment()\">\n <!-- First Row -->\n <div class=\"tw-grid tw-grid-cols-1 md:tw-grid-cols-2 lg:tw-grid-cols-4 tw-gap-3 tw-mb-3\">\n <!-- Department Code -->\n <div>\n <cide-ele-input \n id=\"sydept_code\" \n label=\"Code*\" \n formControlName=\"sydept_code\"\n placeholder=\"DEPT001\"\n size=\"sm\">\n </cide-ele-input>\n </div>\n \n <!-- Department Name -->\n <div>\n <cide-ele-input \n id=\"sydept_name\" \n label=\"Name*\" \n formControlName=\"sydept_name\"\n placeholder=\"Department name\"\n size=\"sm\">\n </cide-ele-input>\n </div>\n \n\n \n <!-- Active Status -->\n <div class=\"tw-flex tw-flex-col tw-justify-end\">\n <cide-ele-input \n id=\"sydept_isactive\"\n type=\"checkbox\"\n label=\"Active\"\n formControlName=\"sydept_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=\"sydept_description\" \n label=\"Description\" \n formControlName=\"sydept_description\"\n placeholder=\"Department description\"\n rows=\"2\"\n size=\"sm\">\n </cide-ele-textarea>\n </div>\n \n\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 <!-- 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\">business</cide-ele-icon>\n <h5 class=\"tw-text-base tw-font-medium tw-text-gray-900 tw-m-0\">Department 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<!-- Department Details Renderer Template -->\n<ng-template #departmentDetailsRendererTemplate let-row=\"row\" let-value=\"value\">\n <div class=\"tw-flex tw-items-center tw-min-w-0\">\n <!-- Department Icon -->\n <div class=\"tw-flex-shrink-0\">\n <cide-ele-icon \n class=\"tw-text-gray-400\" \n size=\"xs\">\n business\n </cide-ele-icon>\n </div>\n \n <!-- Department Details -->\n <div class=\"tw-ml-3 tw-min-w-0 tw-flex-1\">\n <div class=\"tw-text-sm tw-font-medium tw-text-gray-900 tw-truncate\" \n [title]=\"row.sydept_name\">\n {{ row.sydept_name || 'Untitled' }}\n </div>\n @if (row.sydept_description) {\n <div class=\"tw-text-xs tw-text-gray-500 tw-truncate\" \n [title]=\"row.sydept_description\">\n {{ row.sydept_description }}\n </div>\n }\n </div>\n </div>\n</ng-template>\n\n<!-- Department Status Renderer Template -->\n<ng-template #departmentStatusRendererTemplate 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.sydept_isactive)\">\n {{ getStatusDisplay(row.sydept_isactive) }}\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: CideTextareaComponent, selector: "cide-ele-textarea", inputs: ["label", "labelHide", "placeholder", "helperText", "errorText", "required", "disabled", "minlength", "maxlength", "rows", "id", "ngModel", "size", "fill", "labelPlacement", "labelDir", "leadingIcon", "trailingIcon", "clearInput"], outputs: ["ngModelChange"] }, { kind: "component", type: CideIconComponent, selector: "cide-ele-icon", inputs: ["size", "type", "toolTip"] }, { kind: "component", type: CideEleDropdownComponent, selector: "cide-ele-dropdown", inputs: ["items", "config", "triggerTemplate", "menuTemplate"], outputs: ["itemClick", "dropdownToggle"] }, { kind: "component", type: CideEleGlobalNotificationsComponent, selector: "cide-ele-global-notifications" }] }); }
752
+ }
753
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: DepartmentListComponent, decorators: [{
754
+ type: Component,
755
+ args: [{ selector: 'cide-core-app-department-list', standalone: true, imports: [
756
+ CommonModule,
757
+ ReactiveFormsModule,
758
+ FormsModule,
759
+ CideEleDataGridComponent,
760
+ CideEleButtonComponent,
761
+ CideInputComponent,
762
+ CideTextareaComponent,
763
+ CideIconComponent,
764
+ CideEleDropdownComponent,
765
+ CideEleGlobalNotificationsComponent
766
+ ], template: "<!-- Department List Container -->\n<div class=\"tw-table tw-w-full tw-h-full\">\n\n<!-- Global Notifications -->\n<cide-ele-global-notifications></cide-ele-global-notifications>\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 Department' : 'Quick Add Department' }}</h6>\n </div>\n @if (selectedParentDepartment()) {\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\">{{ selectedParentDepartment()?.sydept_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 </div>\n \n <form [formGroup]=\"quickAddForm\" (ngSubmit)=\"quickAddDepartment()\">\n <!-- First Row -->\n <div class=\"tw-grid tw-grid-cols-1 md:tw-grid-cols-2 lg:tw-grid-cols-4 tw-gap-3 tw-mb-3\">\n <!-- Department Code -->\n <div>\n <cide-ele-input \n id=\"sydept_code\" \n label=\"Code*\" \n formControlName=\"sydept_code\"\n placeholder=\"DEPT001\"\n size=\"sm\">\n </cide-ele-input>\n </div>\n \n <!-- Department Name -->\n <div>\n <cide-ele-input \n id=\"sydept_name\" \n label=\"Name*\" \n formControlName=\"sydept_name\"\n placeholder=\"Department name\"\n size=\"sm\">\n </cide-ele-input>\n </div>\n \n\n \n <!-- Active Status -->\n <div class=\"tw-flex tw-flex-col tw-justify-end\">\n <cide-ele-input \n id=\"sydept_isactive\"\n type=\"checkbox\"\n label=\"Active\"\n formControlName=\"sydept_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=\"sydept_description\" \n label=\"Description\" \n formControlName=\"sydept_description\"\n placeholder=\"Department description\"\n rows=\"2\"\n size=\"sm\">\n </cide-ele-textarea>\n </div>\n \n\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 <!-- 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\">business</cide-ele-icon>\n <h5 class=\"tw-text-base tw-font-medium tw-text-gray-900 tw-m-0\">Department 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<!-- Department Details Renderer Template -->\n<ng-template #departmentDetailsRendererTemplate let-row=\"row\" let-value=\"value\">\n <div class=\"tw-flex tw-items-center tw-min-w-0\">\n <!-- Department Icon -->\n <div class=\"tw-flex-shrink-0\">\n <cide-ele-icon \n class=\"tw-text-gray-400\" \n size=\"xs\">\n business\n </cide-ele-icon>\n </div>\n \n <!-- Department Details -->\n <div class=\"tw-ml-3 tw-min-w-0 tw-flex-1\">\n <div class=\"tw-text-sm tw-font-medium tw-text-gray-900 tw-truncate\" \n [title]=\"row.sydept_name\">\n {{ row.sydept_name || 'Untitled' }}\n </div>\n @if (row.sydept_description) {\n <div class=\"tw-text-xs tw-text-gray-500 tw-truncate\" \n [title]=\"row.sydept_description\">\n {{ row.sydept_description }}\n </div>\n }\n </div>\n </div>\n</ng-template>\n\n<!-- Department Status Renderer Template -->\n<ng-template #departmentStatusRendererTemplate 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.sydept_isactive)\">\n {{ getStatusDisplay(row.sydept_isactive) }}\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> " }]
767
+ }], ctorParameters: () => [] });
768
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"department-list.component.js","sourceRoot":"","sources":["../../../../../../../../projects/cloud-ide-core/src/lib/core/department-management/components/department-list/department-list.component.ts","../../../../../../../../projects/cloud-ide-core/src/lib/core/department-management/components/department-list/department-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 { ReactiveFormsModule, NonNullableFormBuilder, FormsModule } from '@angular/forms';\nimport { Router } from '@angular/router';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ICoreSydept } from 'cloud-ide-lms-model';\nimport { DepartmentManagementService } from '../../services/department-management.service';\nimport { AppStateHelperService } from 'cloud-ide-layout';\nimport { CideEleButtonComponent, CideEleDataGridComponent, CideIconComponent, CideInputComponent, CideTextareaComponent, GridConfiguration, GridEvent, CideEleDropdownComponent, DropdownItem, ConfirmationService, NotificationService, CideEleGlobalNotificationsComponent } from 'cloud-ide-element';\nimport { TemplateContext } from 'cloud-ide-element';\n\n@Component({\n  selector: 'cide-core-app-department-list',\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    FormsModule,\n    CideEleDataGridComponent,\n    CideEleButtonComponent,\n    CideInputComponent,\n    CideTextareaComponent,\n    CideIconComponent,\n    CideEleDropdownComponent,\n    CideEleGlobalNotificationsComponent\n  ],\n  templateUrl: './department-list.component.html',\n  styleUrls: []\n})\nexport class DepartmentListComponent {\n  // Dependency injection\n  private destroyRef = inject(DestroyRef);\n  private departmentService = inject(DepartmentManagementService);\n  private appState = inject(AppStateHelperService);\n  private fb = inject(NonNullableFormBuilder);\n  private router = inject(Router);\n  private confirmationService = inject(ConfirmationService);\n  private notificationService = inject(NotificationService);\n\n  // Modern ViewChild signals for template renderers (Angular 20 approach)\n  departmentDetailsRendererTemplate = viewChild.required<TemplateRef<TemplateContext<Record<string, unknown>>>>('departmentDetailsRendererTemplate');\n  departmentStatusRendererTemplate = viewChild.required<TemplateRef<TemplateContext<Record<string, unknown>>>>('departmentStatusRendererTemplate');\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  departments = signal<ICoreSydept[]>([]);\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  selectedParentDepartment = signal<ICoreSydept | null>(null);\n\n  // Retrieved department data\n  retrievedDepartment = signal<ICoreSydept | 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    sydept_code: this.fb.control('', []),\n    sydept_name: this.fb.control('', []),\n    sydept_description: this.fb.control('', []),\n    sydept_isactive: this.fb.control(true, []),\n    sydept_department_id_sydept: this.fb.control(''),\n    sydept_entity_id_syen: this.fb.control(this.appState.getActiveEntityId() || '', [])\n  });\n\n  // Grid configuration signal\n  gridConfig = signal<GridConfiguration<ICoreSydept>>({\n    id: 'department-list-grid',\n    title: '',\n    subtitle: '',\n    columns: [\n      {\n        key: 'details',\n        header: 'Department',\n        type: 'custom',\n        width: 'auto',\n        truncate: true,\n        align: 'left',\n        renderer: 'departmentDetailsRenderer'\n      },\n      {\n        key: 'sydept_code',\n        header: 'Code',\n        type: 'text',\n        width: '120px',\n        truncate: true,\n        align: 'left'\n      },\n      {\n        key: 'sydept_isactive',\n        header: 'Status',\n        type: 'custom',\n        width: '100px',\n        truncate: false,\n        align: 'center',\n        renderer: 'departmentStatusRenderer'\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    tree: {\n      enabled: true,\n      primaryKey: '_id',\n      foreignKey: 'sydept_department_id_sydept',\n      childrenKey: 'children',\n      levelKey: 'level',\n      expandedKey: 'expanded',\n      hasChildrenKey: 'hasChildren'\n    },\n    trackBy: '_id',\n    pagination: {\n      enabled: false,\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...',\n      searchableColumns: ['sydept_name', 'sydept_code', 'sydept_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: 'onDepartmentRefresh'\n  });\n\n  // Template renderers using Angular best practices\n  templateRenderers = computed((): Record<string, TemplateRef<TemplateContext>> => ({\n    departmentDetailsRenderer: this.departmentDetailsRendererTemplate(),\n    departmentStatusRenderer: this.departmentStatusRendererTemplate(),\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: ICoreSydept) => string> {\n    return {};\n  }\n\n  // Action handlers for grid actions\n  actionHandlers = {\n    onEditDepartment: (row: ICoreSydept) => this.editDepartment(row._id || ''),\n    onToggleDepartment: (row: ICoreSydept) => this.toggleDepartmentStatus(row._id || ''),\n    onDeleteDepartment: (row: ICoreSydept) => this.deleteDepartment(row._id || ''),\n    onDepartmentRowClick: (row: ICoreSydept) => this.onDepartmentRowClick(row),\n    onDepartmentRefresh: () => this.onDepartmentRefresh(),\n    onAddChild: (row: ICoreSydept) => this.onAddChild(row)\n  };\n\n  // Computed properties\n  filteredItems = computed(() => {\n    const items = this.departments();\n    const search = this.searchTerm()?.toLowerCase();\n\n    if (!search) return items;\n\n    return items.filter(item => {\n      return item.sydept_name?.toLowerCase().includes(search) ||\n        item.sydept_code?.toLowerCase().includes(search) ||\n        item.sydept_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  // 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('DepartmentListComponent initialized with modern Angular patterns');\n    this.loadDepartments();\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 { handleDepartmentAction: (action: string, id: string) => void }).handleDepartmentAction = this.handleDepartmentAction.bind(this);\n    }\n  }\n\n  /**\n   * Load departments from service\n   */\n  loadDepartments(): void {\n    console.log('🚀 DepartmentListComponent.loadDepartments() 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.departmentService) {\n      console.error('❌ DepartmentService is not available');\n      this.error.set('Department service is not available');\n      this.loading.set(false);\n      return;\n    }\n\n    this.departmentService.getDepartmentList(requestBody)\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe({\n        next: (response) => {\n          console.log('📥 DepartmentListComponent received response:', response);\n          if (response?.success) {\n            console.log('✅ Response successful, setting departments:', response.data);\n            const departmentData = response?.data || [];\n            this.departments.set(departmentData);\n            this.totalItems.set(response.total || 0);\n            this.updateGridData(departmentData);\n          } else {\n            console.error('❌ Response was not successful:', response);\n            this.error.set('Failed to load departments');\n          }\n        },\n        error: (err) => {\n          console.error('❌ DepartmentListComponent error:', err);\n          this.error.set(err.message || 'An error occurred while loading departments');\n        },\n        complete: () => {\n          console.log('DepartmentListComponent loadDepartments completed');\n          this.loading.set(false);\n        }\n      });\n  }\n\n  /**\n   * Update grid data\n   */\n  private updateGridData(departments: ICoreSydept[]): void {\n    console.log('🔄 updateGridData called with:', departments);\n    \n    this.gridConfig.update(config => {\n      const newConfig = {\n        ...config,\n        data: departments\n      };\n      console.log('⚙️ Updated grid config with departments');\n      return newConfig;\n    });\n  }\n\n  /**\n   * Handle grid events\n   */\n  onGridEvent(event: GridEvent<ICoreSydept>): 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.loadDepartments();\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.loadDepartments();\n        } else {\n          const page = event.data as number;\n          if (page) {\n            this.currentPage.set(page);\n            this.loadDepartments();\n          }\n        }\n        break;\n      }\n      case 'refresh':\n        this.onDepartmentRefresh();\n        break;\n      case 'rowClick':\n        this.onDepartmentRowClick(event.data as ICoreSydept);\n        break;\n      case 'action':\n        if (event.action?.key === 'edit') {\n          this.editDepartment(event.data as string);\n        } else if (event.action?.key === 'toggle') {\n          this.toggleDepartmentStatus(event.data as string);\n        } else if (event.action?.key === 'delete') {\n          this.deleteDepartment(event.data as string);\n        }\n        break;\n    }\n  }\n\n  /**\n   * Handle department refresh\n   */\n  onDepartmentRefresh(): void {\n    this.loadDepartments();\n  }\n\n  /**\n   * Handle department row click\n   */\n  onDepartmentRowClick(department: ICoreSydept): void {\n    this.editDepartment(department._id || '');\n  }\n\n  /**\n   * Navigate to edit department form\n   */\n  editDepartment(itemId: string): void {\n    console.log('🔵 editDepartment called with:', itemId);\n    this.isEditMode.set(true);\n    this.getDepartmentById(itemId);\n  }\n\n  /**\n   * Get department by ID using the API\n   */\n  getDepartmentById(itemId: string): void {\n    console.log('🔵 getDepartmentById called with:', itemId);\n    this.loading.set(true);\n\n    this.departmentService.getDepartmentById(itemId)\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe({\n        next: (response) => {\n          if (response.success) {\n            console.log('✅ Department retrieved successfully:', response.data);\n            let department: ICoreSydept | null = null;\n            department = response.data || null;\n\n            this.retrievedDepartment.set(department);\n\n            if (this.isEditMode() && department) {\n              this.populateFormForEdit(department);\n            }\n          } else {\n            this.error.set('Failed to retrieve department');\n          }\n        },\n        error: (err) => {\n          this.error.set(err.message || 'An error occurred while retrieving the department');\n        },\n        complete: () => {\n          this.loading.set(false);\n        }\n      });\n  }\n\n  /**\n   * Populate form with department data for editing\n   */\n  populateFormForEdit(department: ICoreSydept): void {\n    console.log('🔵 populateFormForEdit called with:', department);\n\n    this.quickAddForm.patchValue({\n      sydept_code: department.sydept_code || '',\n      sydept_name: department.sydept_name || '',\n      sydept_description: department.sydept_description || '',\n      sydept_isactive: department.sydept_isactive ?? true,\n      sydept_department_id_sydept: department.sydept_department_id_sydept || '',\n      sydept_entity_id_syen: department.sydept_entity_id_syen || ''\n    });\n\n    if (department.sydept_department_id_sydept) {\n      const parentDepartment = this.departments().find(item => item._id === department.sydept_department_id_sydept);\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 department\n   */\n  async deleteDepartment(itemId: string): Promise<void> {\n    console.log('🔵 deleteDepartment called with:', itemId);\n    \n    // Find the department name for better confirmation message\n    const department = this.departments().find(d => d._id === itemId);\n    const departmentName = department?.sydept_name || 'this department';\n    \n    try {\n      const confirmed = await this.confirmationService.confirmDelete(departmentName);\n      \n      if (confirmed) {\n        this.loading.set(true);\n\n        this.departmentService.deleteDepartment(itemId)\n          .pipe(takeUntilDestroyed(this.destroyRef))\n          .subscribe({\n            next: (response) => {\n              if (response.success) {\n                this.notificationService.success(`Department \"${departmentName}\" deleted successfully`);\n                this.loadDepartments();\n              } else {\n                this.notificationService.error('Failed to delete department');\n              }\n            },\n            error: (err) => {\n              this.notificationService.error(err.message || 'An error occurred while deleting the department');\n            },\n            complete: () => {\n              this.loading.set(false);\n            }\n          });\n      }\n    } catch (error) {\n      console.log('User cancelled deletion');\n    }\n  }\n\n  /**\n   * Toggle department status\n   */\n  toggleDepartmentStatus(itemId: string): void {\n    console.log('🔵 toggleDepartmentStatus called with:', itemId);\n    \n    // Find the department for better notification message\n    const department = this.departments().find(d => d._id === itemId);\n    const departmentName = department?.sydept_name || 'department';\n    const newStatus = department?.sydept_isactive ? 'inactive' : 'active';\n    \n    this.loading.set(true);\n\n    this.departmentService.toggleDepartmentStatus({ sydept_id: itemId })\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe({\n        next: (response) => {\n          if (response.success) {\n            this.notificationService.success(`Department \"${departmentName}\" ${newStatus} successfully`);\n            this.loadDepartments();\n          } else {\n            this.notificationService.error('Failed to toggle department status');\n          }\n        },\n        error: (err) => {\n          this.notificationService.error(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 department using reactive form\n   */\n  quickAddDepartment() {\n    if (this.quickAddForm.invalid) return;\n\n    const formValue = this.quickAddForm.value;\n\n    const department: Partial<ICoreSydept> = {\n      _id: this.retrievedDepartment()?._id || '',\n      sydept_code: formValue.sydept_code,\n      sydept_name: formValue.sydept_name,\n      sydept_description: formValue.sydept_description || '',\n      sydept_isactive: formValue.sydept_isactive,\n      sydept_department_id_sydept: formValue.sydept_department_id_sydept || undefined,\n      sydept_entity_id_syen: formValue.sydept_entity_id_syen\n    };\n\n    if (this.isEditMode() && this.retrievedDepartment()) {\n      const itemId = this.retrievedDepartment()?._id;\n      if (itemId) {\n        console.log('🔵 Updating department:', itemId);\n        this.departmentService.updateDepartment(itemId, department).subscribe({\n          next: (response) => {\n            if (response.success) {\n              console.log('✅ Department updated successfully');\n              this.notificationService.success(`Department \"${department.sydept_name}\" updated successfully`);\n              this.resetQuickAddForm();\n              this.isEditMode.set(false);\n              this.retrievedDepartment.set(null);\n              this.loadDepartments();\n            } else {\n              this.notificationService.error('Failed to update department');\n            }\n          },\n          error: (err) => {\n            this.notificationService.error(err.message || 'Failed to update department');\n          }\n        });\n      }\n    } else {\n      console.log('🔵 Creating new department');\n      this.departmentService.createDepartment(department).subscribe({\n        next: (response) => {\n          if (response.success) {\n            console.log('✅ Department created successfully');\n            this.notificationService.success(`Department \"${department.sydept_name}\" created successfully`);\n            this.resetQuickAddForm();\n            this.loadDepartments();\n          } else {\n            this.notificationService.error('Failed to create department');\n          }\n        },\n        error: (err) => {\n          this.notificationService.error(err.message || 'Failed to create department');\n        }\n      });\n    }\n  }\n\n  /**\n   * Reset the quick add form to default values\n   */\n  resetQuickAddForm(): void {\n    this.selectedParentDepartment.set(null);\n    this.isEditMode.set(false);\n    this.retrievedDepartment.set(null);\n\n    this.quickAddForm.reset({\n      sydept_code: '',\n      sydept_name: '',\n      sydept_description: '',\n      sydept_isactive: true,\n      sydept_department_id_sydept: '',\n      sydept_entity_id_syen: this.appState.getActiveEntityId() || ''\n    });\n  }\n\n  /**\n   * Handle adding a child department\n   */\n  onAddChild(parentItem: ICoreSydept): void {\n    console.log('🔵 onAddChild called with:', parentItem);\n    console.log('🔵 Parent name:', parentItem.sydept_name);\n\n    // Clear edit mode and retrieved item when adding a child\n    this.isEditMode.set(false);\n    this.retrievedDepartment.set(null);\n\n    // Set the selected parent item first using signal\n    this.selectedParentDepartment.set(parentItem);\n    console.log('🔵 selectedParentDepartment set to:', this.selectedParentDepartment());\n\n    // Update form with parent context (don't call resetQuickAddForm as it clears the parent)\n    this.quickAddForm.patchValue({\n      sydept_code: '',\n      sydept_name: '',\n      sydept_description: '',\n      sydept_isactive: true,\n      sydept_department_id_sydept: parentItem._id,\n      sydept_entity_id_syen: this.appState.getActiveEntityId() || ''\n    });\n\n    console.log('🔵 Form updated, parent should be visible:', this.selectedParentDepartment()?.sydept_name);\n  }\n\n  /**\n   * Clear selected parent department\n   */\n  clearSelectedParent() {\n    this.selectedParentDepartment.set(null);\n    this.quickAddForm.patchValue({\n      sydept_department_id_sydept: ''\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.editDepartment(itemId);\n            break;\n          case 'toggle':\n            this.toggleDepartmentStatus(itemId);\n            break;\n          case 'delete':\n            this.deleteDepartment(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 department action clicks\n   */\n  handleDepartmentAction(action: string, itemId: string) {\n    const item = this.departments().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.editDepartment(itemId);\n        break;\n      case 'toggle':\n        this.toggleDepartmentStatus(itemId);\n        break;\n      case 'delete':\n        this.deleteDepartment(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 department actions\n   */\n  getDropdownItems(row: ICoreSydept): DropdownItem[] {\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.sydept_isactive ? '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   * Handle dropdown item click\n   */\n  onDropdownItemClick(item: DropdownItem, row: ICoreSydept): void {\n    console.log('🔵 onDropdownItemClick called with:', item, row);\n\n    switch (item.id) {\n      case 'edit':\n        this.editDepartment(row._id || '');\n        break;\n      case 'addChild':\n        this.onAddChild(row);\n        break;\n      case 'toggle':\n        this.toggleDepartmentStatus(row._id || '');\n        break;\n      case 'delete':\n        this.deleteDepartment(row._id || '');\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: ICoreSydept): string {\n    return item._id || '';\n  }\n} ","<!-- Department List Container -->\n<div class=\"tw-table tw-w-full tw-h-full\">\n\n<!-- Global Notifications -->\n<cide-ele-global-notifications></cide-ele-global-notifications>\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 Department' : 'Quick Add Department' }}</h6>\n      </div>\n      @if (selectedParentDepartment()) {\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\">{{ selectedParentDepartment()?.sydept_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    </div>\n    \n    <form [formGroup]=\"quickAddForm\" (ngSubmit)=\"quickAddDepartment()\">\n    <!-- First Row -->\n    <div class=\"tw-grid tw-grid-cols-1 md:tw-grid-cols-2 lg:tw-grid-cols-4 tw-gap-3 tw-mb-3\">\n      <!-- Department Code -->\n      <div>\n        <cide-ele-input \n          id=\"sydept_code\" \n          label=\"Code*\" \n          formControlName=\"sydept_code\"\n          placeholder=\"DEPT001\"\n          size=\"sm\">\n        </cide-ele-input>\n      </div>\n      \n      <!-- Department Name -->\n      <div>\n        <cide-ele-input \n          id=\"sydept_name\" \n          label=\"Name*\" \n          formControlName=\"sydept_name\"\n          placeholder=\"Department name\"\n          size=\"sm\">\n        </cide-ele-input>\n      </div>\n      \n\n      \n      <!-- Active Status -->\n      <div class=\"tw-flex tw-flex-col tw-justify-end\">\n        <cide-ele-input \n          id=\"sydept_isactive\"\n          type=\"checkbox\"\n          label=\"Active\"\n          formControlName=\"sydept_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=\"sydept_description\" \n          label=\"Description\" \n          formControlName=\"sydept_description\"\n          placeholder=\"Department description\"\n          rows=\"2\"\n          size=\"sm\">\n        </cide-ele-textarea>\n      </div>\n      \n\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  <!-- 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\">business</cide-ele-icon>\n        <h5 class=\"tw-text-base tw-font-medium tw-text-gray-900 tw-m-0\">Department 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<!-- Department Details Renderer Template -->\n<ng-template #departmentDetailsRendererTemplate let-row=\"row\" let-value=\"value\">\n  <div class=\"tw-flex tw-items-center tw-min-w-0\">\n    <!-- Department Icon -->\n    <div class=\"tw-flex-shrink-0\">\n      <cide-ele-icon \n        class=\"tw-text-gray-400\" \n        size=\"xs\">\n        business\n      </cide-ele-icon>\n    </div>\n    \n    <!-- Department Details -->\n    <div class=\"tw-ml-3 tw-min-w-0 tw-flex-1\">\n      <div class=\"tw-text-sm tw-font-medium tw-text-gray-900 tw-truncate\" \n           [title]=\"row.sydept_name\">\n        {{ row.sydept_name || 'Untitled' }}\n      </div>\n      @if (row.sydept_description) {\n        <div class=\"tw-text-xs tw-text-gray-500 tw-truncate\" \n             [title]=\"row.sydept_description\">\n          {{ row.sydept_description }}\n        </div>\n      }\n    </div>\n  </div>\n</ng-template>\n\n<!-- Department Status Renderer Template -->\n<ng-template #departmentStatusRendererTemplate 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.sydept_isactive)\">\n    {{ getStatusDisplay(row.sydept_isactive) }}\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> "]}