cloud-ide-core 1.0.1 → 1.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
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-BNYoP_bS.mjs} +132 -134
  3. package/fesm2022/{cloud-ide-core-general-master-type.component-B26auJZw.mjs.map → cloud-ide-core-general-master-type.component-BNYoP_bS.mjs.map} +1 -1
  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-CFGGHinl.mjs} +152 -154
  7. package/fesm2022/{cloud-ide-core-general-master.component-B6llTVoV.mjs.map → cloud-ide-core-general-master.component-CFGGHinl.mjs.map} +1 -1
  8. package/fesm2022/{cloud-ide-core-page-form.component-CaEca3mB.mjs → cloud-ide-core-page-form.component-vfE-LkTS.mjs} +25 -25
  9. package/fesm2022/{cloud-ide-core-page-form.component-CaEca3mB.mjs.map → cloud-ide-core-page-form.component-vfE-LkTS.mjs.map} +1 -1
  10. package/fesm2022/cloud-ide-core.mjs +1113 -1110
  11. package/fesm2022/cloud-ide-core.mjs.map +1 -1
  12. package/index.d.ts +1736 -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,794 +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 { GradeLevelManagementService } from '../../services/grade-level-management.service';
7
- import { AppStateHelperService } from 'cloud-ide-layout';
8
- import { CideEleButtonComponent, CideEleDataGridComponent, CideIconComponent, CideInputComponent, CideSelectComponent, CideTextareaComponent, CideEleDropdownComponent } 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 GradeLevelListComponent {
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.gradeLevelService = inject(GradeLevelManagementService);
30
- this.appState = inject(AppStateHelperService);
31
- this.fb = inject(NonNullableFormBuilder);
32
- this.router = inject(Router);
33
- // Modern ViewChild signals for template renderers (Angular 20 approach)
34
- this.dragHandleRendererTemplate = viewChild.required('dragHandleRendererTemplate');
35
- this.gradeLevelDetailsRendererTemplate = viewChild.required('gradeLevelDetailsRendererTemplate');
36
- this.gradeLevelStatusRendererTemplate = viewChild.required('gradeLevelStatusRendererTemplate');
37
- this.actionsDropdownRendererTemplate = viewChild.required('actionsDropdownRendererTemplate');
38
- // Make Math available in template
39
- this.Math = Math;
40
- // Signals for reactive state management
41
- this.gradeLevels = signal([]);
42
- this.loading = signal(false);
43
- this.error = signal(null);
44
- this.selectedItems = signal([]);
45
- this.searchTerm = signal('');
46
- // Retrieved grade level data
47
- this.retrievedGradeLevel = signal(null);
48
- // Edit mode flag
49
- this.isEditMode = signal(false);
50
- // Drag order management
51
- this.originalOrder = signal([]);
52
- this.hasOrderChanged = 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
- sydsgl_name: this.fb.control('', [Validators.required, Validators.minLength(1), Validators.maxLength(20)]),
60
- sydsgl_description: this.fb.control('', [Validators.maxLength(400)]),
61
- sydsgl_order: this.fb.control(1, [Validators.required, Validators.min(1), Validators.max(100)]),
62
- sydsgl_isactive: this.fb.control(true, [Validators.required]),
63
- sydsgl_entity_id_syen: this.fb.control(this.appState.getActiveEntityId() || '', [Validators.required])
64
- });
65
- // Grid configuration signal
66
- this.gridConfig = signal({
67
- id: 'grade-level-list-grid',
68
- title: '',
69
- subtitle: '',
70
- columns: [
71
- {
72
- key: 'dragHandle',
73
- header: '',
74
- type: 'custom',
75
- width: '40px',
76
- truncate: false,
77
- align: 'center',
78
- renderer: 'dragHandleRenderer'
79
- },
80
- {
81
- key: 'details',
82
- header: 'Grade Level',
83
- type: 'custom',
84
- width: 'auto',
85
- truncate: true,
86
- align: 'left',
87
- renderer: 'gradeLevelDetailsRenderer'
88
- },
89
- {
90
- key: 'sydsgl_isactive',
91
- header: 'Status',
92
- type: 'custom',
93
- width: '100px',
94
- truncate: false,
95
- align: 'center',
96
- renderer: 'gradeLevelStatusRenderer'
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
- trackBy: '_id',
110
- dragDrop: {
111
- enabled: true,
112
- orderField: 'sydsgl_order',
113
- dragClass: 'tw-opacity-50 tw-bg-blue-50',
114
- dropClass: 'tw-bg-green-50'
115
- },
116
- pagination: {
117
- enabled: true,
118
- pageSize: 10,
119
- pageSizeOptions: [10, 25, 50, 100],
120
- showQuickJump: true,
121
- showPageInfo: true,
122
- showRefresh: true
123
- },
124
- search: {
125
- enabled: true,
126
- placeholder: 'Search grade levels...',
127
- searchableColumns: ['sydsgl_name', 'sydsgl_description'],
128
- debounceMs: 300
129
- },
130
- loading: {
131
- useDefer: true,
132
- skeletonRows: 5,
133
- showOverlay: false
134
- },
135
- scroll: {
136
- enabled: true,
137
- maxHeight: '',
138
- minHeight: '',
139
- stickyHeader: true,
140
- virtualScroll: false,
141
- rowHeight: 50
142
- },
143
- responsive: true,
144
- striped: false,
145
- bordered: true,
146
- compact: false,
147
- tableClass: 'tw-table-fixed tw-w-full tw-rounded-none',
148
- onRefresh: 'onGradeLevelRefresh'
149
- });
150
- // Template renderers using Angular best practices
151
- this.templateRenderers = computed(() => ({
152
- dragHandleRenderer: this.dragHandleRendererTemplate(),
153
- gradeLevelDetailsRenderer: this.gradeLevelDetailsRendererTemplate(),
154
- gradeLevelStatusRenderer: this.gradeLevelStatusRendererTemplate(),
155
- actionsDropdownRenderer: this.actionsDropdownRendererTemplate()
156
- }));
157
- // Mixed renderers (templates + string functions)
158
- this.customRenderers = computed(() => ({
159
- ...this.templateRenderers()
160
- }));
161
- // Action handlers for grid actions
162
- this.actionHandlers = {
163
- onEditGradeLevel: (row) => this.editGradeLevel(row._id || ''),
164
- onToggleGradeLevel: (row) => this.toggleGradeLevelStatus(row._id || ''),
165
- onDeleteGradeLevel: (row) => this.deleteGradeLevel(row._id || ''),
166
- onGradeLevelRowClick: (row) => this.onGradeLevelRowClick(row),
167
- onGradeLevelRefresh: () => this.onGradeLevelRefresh(),
168
- resetOrder: () => this.resetDragOrder(),
169
- saveOrder: () => this.saveGradeLevelOrder()
170
- };
171
- // Computed properties
172
- this.filteredItems = computed(() => {
173
- const items = this.gradeLevels();
174
- const search = this.searchTerm()?.toLowerCase();
175
- if (!search)
176
- return items;
177
- return items.filter(item => {
178
- return item.sydsgl_name?.toLowerCase().includes(search) ||
179
- item.sydsgl_description?.toLowerCase().includes(search);
180
- });
181
- });
182
- this.hasSelection = computed(() => this.selectedItems().length > 0);
183
- // Pagination computed properties
184
- this.totalPages = computed(() => Math.ceil(this.totalItems() / this.pageSize()));
185
- this.hasNextPage = computed(() => this.currentPage() < this.totalPages());
186
- this.hasPreviousPage = computed(() => this.currentPage() > 1);
187
- // Computed property for next order
188
- this.nextOrder = computed(() => this.calculateNextOrder());
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('GradeLevelListComponent initialized with modern Angular patterns');
199
- this.loadGradeLevels();
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.handleGradeLevelAction = this.handleGradeLevelAction.bind(this);
224
- }
225
- }
226
- /**
227
- * Load grade levels from service
228
- */
229
- loadGradeLevels() {
230
- console.log('🚀 GradeLevelListComponent.loadGradeLevels() 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.gradeLevelService) {
241
- console.error('❌ GradeLevelService is not available');
242
- this.error.set('Grade level service is not available');
243
- this.loading.set(false);
244
- return;
245
- }
246
- this.gradeLevelService.getGradeLevelList(requestBody)
247
- .pipe(takeUntilDestroyed(this.destroyRef))
248
- .subscribe({
249
- next: (response) => {
250
- console.log('📥 GradeLevelListComponent received response:', response);
251
- if (response?.success) {
252
- console.log('✅ Response successful, setting grade levels:', response.data);
253
- const gradeLevelData = response?.data || [];
254
- this.gradeLevels.set(gradeLevelData);
255
- this.totalItems.set(response.total || 0);
256
- this.updateGridData(gradeLevelData);
257
- // Update the order field in the form if not in edit mode
258
- if (!this.isEditMode()) {
259
- const nextOrder = this.calculateNextOrder();
260
- this.quickAddForm.patchValue({ sydsgl_order: nextOrder });
261
- }
262
- }
263
- else {
264
- console.error('❌ Response was not successful:', response);
265
- this.error.set('Failed to load grade levels');
266
- }
267
- },
268
- error: (err) => {
269
- console.error('❌ GradeLevelListComponent error:', err);
270
- this.error.set(err.message || 'An error occurred while loading grade levels');
271
- },
272
- complete: () => {
273
- console.log('GradeLevelListComponent loadGradeLevels completed');
274
- this.loading.set(false);
275
- }
276
- });
277
- }
278
- /**
279
- * Update grid data
280
- */
281
- updateGridData(gradeLevels) {
282
- console.log('🔄 updateGridData called with:', gradeLevels);
283
- this.gridConfig.update(config => {
284
- const newConfig = {
285
- ...config,
286
- data: gradeLevels
287
- };
288
- console.log('⚙️ Updated grid config with grade levels');
289
- return newConfig;
290
- });
291
- }
292
- /**
293
- * Handle grid events
294
- */
295
- onGridEvent(event) {
296
- console.log('onGridEvent', event);
297
- switch (event.type) {
298
- case 'search':
299
- this.searchTerm.set(event.data);
300
- this.currentPage.set(1);
301
- this.loadGradeLevels();
302
- break;
303
- case 'pageChange': {
304
- const pageData = event.data;
305
- if (pageData) {
306
- this.currentPage.set(pageData.page);
307
- this.pageSize.set(pageData.pageSize);
308
- this.loadGradeLevels();
309
- }
310
- else {
311
- const page = event.data;
312
- if (page) {
313
- this.currentPage.set(page);
314
- this.loadGradeLevels();
315
- }
316
- }
317
- break;
318
- }
319
- case 'refresh':
320
- this.onGradeLevelRefresh();
321
- break;
322
- case 'rowClick':
323
- this.onGradeLevelRowClick(event.data);
324
- break;
325
- case 'rowReorder':
326
- this.onGradeLevelReorder(event.data);
327
- break;
328
- case 'action':
329
- if (event.action?.key === 'edit') {
330
- this.editGradeLevel(event.data);
331
- }
332
- else if (event.action?.key === 'toggle') {
333
- this.toggleGradeLevelStatus(event.data);
334
- }
335
- else if (event.action?.key === 'delete') {
336
- this.deleteGradeLevel(event.data);
337
- }
338
- break;
339
- }
340
- }
341
- /**
342
- * Handle grade level refresh
343
- */
344
- onGradeLevelRefresh() {
345
- this.loadGradeLevels();
346
- }
347
- /**
348
- * Handle grade level reorder via drag and drop
349
- */
350
- onGradeLevelReorder(data) {
351
- console.log('🔄 Grade level reorder event:', data);
352
- // Save original order if not already saved
353
- if (this.originalOrder().length === 0) {
354
- this.originalOrder.set([...this.gradeLevels()]);
355
- }
356
- // Update the displayed data with new order
357
- const updatedItems = data.newOrder.map((item, index) => ({
358
- ...item,
359
- sydsgl_order: index + 1
360
- }));
361
- this.gradeLevels.set(updatedItems);
362
- // Mark that order has changed
363
- this.hasOrderChanged.set(true);
364
- // Update grid data
365
- this.updateGridDataAfterReorder();
366
- console.log('Updated gradeLevels:', this.gradeLevels());
367
- }
368
- /**
369
- * Update grid data after reordering
370
- */
371
- updateGridDataAfterReorder() {
372
- const currentConfig = this.gridConfig();
373
- this.gridConfig.set({
374
- ...currentConfig,
375
- data: this.gradeLevels()
376
- });
377
- }
378
- /**
379
- * Save grade level order
380
- */
381
- saveGradeLevelOrder() {
382
- console.log('💾 Saving grade level order...');
383
- // Send updates to the server for each item that changed order
384
- const promises = this.gradeLevels().map(item => {
385
- return this.gradeLevelService.updateGradeLevel(item._id || '', {
386
- sydsgl_order: item.sydsgl_order
387
- }).toPromise();
388
- });
389
- // Wait for all updates to complete
390
- Promise.all(promises)
391
- .then(() => {
392
- console.log('✅ All grade level orders updated successfully');
393
- // Update original order and reset change flag
394
- this.originalOrder.set([...this.gradeLevels()]);
395
- this.hasOrderChanged.set(false);
396
- })
397
- .catch((error) => {
398
- console.error('❌ Error updating grade level orders:', error);
399
- this.error.set('Failed to update grade level order');
400
- });
401
- }
402
- /**
403
- * Reset drag order to original state
404
- */
405
- resetDragOrder() {
406
- console.log('🔄 Resetting drag order to original state');
407
- // Restore the original order
408
- const originalItems = this.originalOrder();
409
- if (originalItems.length > 0) {
410
- this.gradeLevels.set([...originalItems]);
411
- this.updateGridDataAfterReorder();
412
- }
413
- // Reset the change flag
414
- this.hasOrderChanged.set(false);
415
- console.log('✅ Drag order reset successfully');
416
- }
417
- /**
418
- * Check if order has changed
419
- */
420
- hasOrderChanges() {
421
- return this.hasOrderChanged();
422
- }
423
- /**
424
- * Handle grade level row click
425
- */
426
- onGradeLevelRowClick(gradeLevel) {
427
- this.editGradeLevel(gradeLevel._id || '');
428
- }
429
- /**
430
- * Navigate to edit grade level form
431
- */
432
- editGradeLevel(itemId) {
433
- console.log('🔵 editGradeLevel called with:', itemId);
434
- this.isEditMode.set(true);
435
- this.getGradeLevelById(itemId);
436
- }
437
- /**
438
- * Get grade level by ID using the API
439
- */
440
- getGradeLevelById(itemId) {
441
- console.log('🔵 getGradeLevelById called with:', itemId);
442
- this.loading.set(true);
443
- this.gradeLevelService.getGradeLevelById(itemId)
444
- .pipe(takeUntilDestroyed(this.destroyRef))
445
- .subscribe({
446
- next: (response) => {
447
- if (response.success) {
448
- console.log('✅ Grade level retrieved successfully:', response.data);
449
- let gradeLevel = null;
450
- gradeLevel = response.data || null;
451
- this.retrievedGradeLevel.set(gradeLevel);
452
- if (this.isEditMode() && gradeLevel) {
453
- this.populateFormForEdit(gradeLevel);
454
- }
455
- }
456
- else {
457
- this.error.set('Failed to retrieve grade level');
458
- }
459
- },
460
- error: (err) => {
461
- this.error.set(err.message || 'An error occurred while retrieving the grade level');
462
- },
463
- complete: () => {
464
- this.loading.set(false);
465
- }
466
- });
467
- }
468
- /**
469
- * Populate form with grade level data for editing
470
- */
471
- populateFormForEdit(gradeLevel) {
472
- console.log('🔵 populateFormForEdit called with:', gradeLevel);
473
- this.quickAddForm.patchValue({
474
- sydsgl_name: gradeLevel.sydsgl_name || '',
475
- sydsgl_description: gradeLevel.sydsgl_description || '',
476
- sydsgl_order: gradeLevel.sydsgl_order || 1,
477
- sydsgl_isactive: gradeLevel.sydsgl_isactive ?? true,
478
- sydsgl_entity_id_syen: gradeLevel.sydsgl_entity_id_syen || ''
479
- });
480
- console.log('✅ Form populated for editing:', this.quickAddForm.value);
481
- }
482
- /**
483
- * Delete grade level
484
- */
485
- deleteGradeLevel(itemId) {
486
- console.log('🔵 deleteGradeLevel called with:', itemId);
487
- if (confirm('Are you sure you want to delete this grade level?')) {
488
- this.loading.set(true);
489
- this.gradeLevelService.deleteGradeLevel(itemId)
490
- .pipe(takeUntilDestroyed(this.destroyRef))
491
- .subscribe({
492
- next: (response) => {
493
- if (response.success) {
494
- this.loadGradeLevels();
495
- }
496
- else {
497
- this.error.set('Failed to delete grade level');
498
- }
499
- },
500
- error: (err) => {
501
- this.error.set(err.message || 'An error occurred while deleting the grade level');
502
- },
503
- complete: () => {
504
- this.loading.set(false);
505
- }
506
- });
507
- }
508
- }
509
- /**
510
- * Toggle grade level status
511
- */
512
- toggleGradeLevelStatus(itemId) {
513
- console.log('🔵 toggleGradeLevelStatus called with:', itemId);
514
- this.loading.set(true);
515
- this.gradeLevelService.toggleGradeLevelStatus(itemId)
516
- .pipe(takeUntilDestroyed(this.destroyRef))
517
- .subscribe({
518
- next: (response) => {
519
- if (response.success) {
520
- this.loadGradeLevels();
521
- }
522
- else {
523
- this.error.set('Failed to toggle grade level status');
524
- }
525
- },
526
- error: (err) => {
527
- this.error.set(err.message || 'An error occurred while toggling status');
528
- },
529
- complete: () => {
530
- this.loading.set(false);
531
- }
532
- });
533
- }
534
- /**
535
- * Quick add or update grade level using reactive form
536
- */
537
- quickAddGradeLevel() {
538
- if (this.quickAddForm.invalid)
539
- return;
540
- const formValue = this.quickAddForm.value;
541
- // For new grade levels, ensure the order is set to the calculated next order
542
- let order = formValue.sydsgl_order;
543
- if (!this.isEditMode()) {
544
- order = this.calculateNextOrder();
545
- }
546
- const gradeLevel = {
547
- _id: this.retrievedGradeLevel()?._id || '',
548
- sydsgl_name: formValue.sydsgl_name,
549
- sydsgl_description: formValue.sydsgl_description || '',
550
- sydsgl_order: order,
551
- sydsgl_isactive: formValue.sydsgl_isactive,
552
- sydsgl_entity_id_syen: formValue.sydsgl_entity_id_syen
553
- };
554
- if (this.isEditMode() && this.retrievedGradeLevel()) {
555
- const itemId = this.retrievedGradeLevel()?._id;
556
- if (itemId) {
557
- console.log('🔵 Updating grade level:', itemId);
558
- this.gradeLevelService.updateGradeLevel(itemId, gradeLevel).subscribe({
559
- next: (response) => {
560
- if (response.success) {
561
- console.log('✅ Grade level updated successfully');
562
- this.resetQuickAddForm();
563
- this.isEditMode.set(false);
564
- this.retrievedGradeLevel.set(null);
565
- this.loadGradeLevels();
566
- }
567
- },
568
- error: () => {
569
- this.error.set('Failed to update grade level');
570
- }
571
- });
572
- }
573
- }
574
- else {
575
- console.log('🔵 Creating new grade level');
576
- this.gradeLevelService.createGradeLevel(gradeLevel).subscribe({
577
- next: (response) => {
578
- if (response.success) {
579
- console.log('✅ Grade level created successfully');
580
- this.resetQuickAddForm();
581
- this.loadGradeLevels();
582
- }
583
- },
584
- error: () => {
585
- this.error.set('Failed to create grade level');
586
- }
587
- });
588
- }
589
- }
590
- /**
591
- * Calculate the highest order from existing grade levels
592
- */
593
- calculateNextOrder() {
594
- const currentGradeLevels = this.gradeLevels();
595
- if (currentGradeLevels.length === 0) {
596
- return 1;
597
- }
598
- const maxOrder = Math.max(...currentGradeLevels.map(level => level.sydsgl_order || 0));
599
- return maxOrder + 1;
600
- }
601
- /**
602
- * Reset the quick add form to default values
603
- */
604
- resetQuickAddForm() {
605
- this.isEditMode.set(false);
606
- this.retrievedGradeLevel.set(null);
607
- // Calculate the next order automatically
608
- const nextOrder = this.calculateNextOrder();
609
- this.quickAddForm.reset({
610
- sydsgl_name: '',
611
- sydsgl_description: '',
612
- sydsgl_order: nextOrder,
613
- sydsgl_isactive: true,
614
- sydsgl_entity_id_syen: this.appState.getActiveEntityId() || ''
615
- });
616
- }
617
- /**
618
- * Handle click outside dropdown
619
- */
620
- handleClickOutside(event) {
621
- const target = event.target;
622
- if (!target?.closest('[data-dropdown]') && !target?.closest('[data-action="more-actions"]')) {
623
- document.querySelectorAll('[data-dropdown]').forEach((el) => {
624
- const dropdown = el;
625
- dropdown.classList.add('tw-hidden');
626
- });
627
- document.querySelectorAll('[data-action="more-actions"]').forEach((el) => {
628
- const button = el;
629
- button.setAttribute('aria-expanded', 'false');
630
- });
631
- }
632
- }
633
- /**
634
- * Handle dropdown action clicks
635
- */
636
- handleDropdownAction(event) {
637
- const target = event.target;
638
- const actionButton = target.closest('[data-action]');
639
- if (actionButton) {
640
- const action = actionButton.getAttribute('data-action');
641
- const itemId = actionButton.getAttribute('data-item-id');
642
- if (action && itemId) {
643
- event.preventDefault();
644
- event.stopPropagation();
645
- const dropdown = actionButton.closest('[data-dropdown]');
646
- if (dropdown) {
647
- dropdown.classList.add('tw-hidden');
648
- }
649
- switch (action) {
650
- case 'edit':
651
- this.editGradeLevel(itemId);
652
- break;
653
- case 'toggle':
654
- this.toggleGradeLevelStatus(itemId);
655
- break;
656
- case 'delete':
657
- this.deleteGradeLevel(itemId);
658
- break;
659
- }
660
- }
661
- }
662
- }
663
- /**
664
- * Toggle dropdown visibility
665
- */
666
- toggleDropdown(itemId) {
667
- document.querySelectorAll('.dropdown-menu').forEach(menu => {
668
- if (menu.getAttribute('data-dropdown') !== itemId) {
669
- menu.classList.add('tw-hidden');
670
- }
671
- });
672
- const dropdown = document.querySelector(`[data-dropdown="${itemId}"]`);
673
- if (dropdown) {
674
- dropdown.classList.toggle('tw-hidden');
675
- }
676
- }
677
- /**
678
- * Handle grade level action clicks
679
- */
680
- handleGradeLevelAction(action, itemId) {
681
- const item = this.gradeLevels().find(item => item._id === itemId);
682
- if (!item)
683
- return;
684
- const dropdown = document.querySelector(`[data-dropdown="${itemId}"]`);
685
- if (dropdown) {
686
- dropdown.classList.add('tw-hidden');
687
- }
688
- switch (action) {
689
- case 'edit':
690
- this.editGradeLevel(itemId);
691
- break;
692
- case 'toggle':
693
- this.toggleGradeLevelStatus(itemId);
694
- break;
695
- case 'delete':
696
- this.deleteGradeLevel(itemId);
697
- break;
698
- }
699
- }
700
- /**
701
- * Get status display
702
- */
703
- getStatusDisplay(isActive) {
704
- return isActive ? 'Active' : 'Inactive';
705
- }
706
- /**
707
- * Get status class for styling
708
- */
709
- getStatusClass(isActive) {
710
- return isActive ? 'tw-bg-green-100 tw-text-green-800' : 'tw-bg-red-100 tw-text-red-800';
711
- }
712
- /**
713
- * Generate dropdown items for grade level actions
714
- */
715
- getDropdownItems(row) {
716
- return [
717
- {
718
- id: 'edit',
719
- label: 'Edit',
720
- icon: 'edit',
721
- iconColor: 'tw-text-gray-400',
722
- textColor: 'tw-text-gray-700',
723
- hoverBgColor: 'hover:tw-bg-gray-100'
724
- },
725
- {
726
- id: 'toggle',
727
- label: row.sydsgl_isactive ? 'Deactivate' : 'Activate',
728
- icon: 'power_settings_new',
729
- iconColor: 'tw-text-gray-400',
730
- textColor: 'tw-text-gray-700',
731
- hoverBgColor: 'hover:tw-bg-gray-100'
732
- },
733
- {
734
- id: 'delete',
735
- label: 'Delete',
736
- icon: 'delete',
737
- iconColor: 'tw-text-red-400',
738
- textColor: 'tw-text-red-600',
739
- hoverBgColor: 'hover:tw-bg-red-50'
740
- }
741
- ];
742
- }
743
- /**
744
- * Handle dropdown item click
745
- */
746
- onDropdownItemClick(item, row) {
747
- console.log('🔵 onDropdownItemClick called with:', item, row);
748
- switch (item.id) {
749
- case 'edit':
750
- this.editGradeLevel(row._id || '');
751
- break;
752
- case 'toggle':
753
- this.toggleGradeLevelStatus(row._id || '');
754
- break;
755
- case 'delete':
756
- this.deleteGradeLevel(row._id || '');
757
- break;
758
- default:
759
- console.log('🔵 Unknown action:', item.id);
760
- }
761
- this.closeAllDropdowns();
762
- }
763
- /**
764
- * Close all dropdowns
765
- */
766
- closeAllDropdowns() {
767
- const event = new MouseEvent('click', { bubbles: true });
768
- document.dispatchEvent(event);
769
- }
770
- /**
771
- * Track by function for ngFor
772
- */
773
- trackByItemId(index, item) {
774
- return item._id || '';
775
- }
776
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: GradeLevelListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
777
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: GradeLevelListComponent, isStandalone: true, selector: "cide-core-app-grade-level-list", viewQueries: [{ propertyName: "dragHandleRendererTemplate", first: true, predicate: ["dragHandleRendererTemplate"], descendants: true, isSignal: true }, { propertyName: "gradeLevelDetailsRendererTemplate", first: true, predicate: ["gradeLevelDetailsRendererTemplate"], descendants: true, isSignal: true }, { propertyName: "gradeLevelStatusRendererTemplate", first: true, predicate: ["gradeLevelStatusRendererTemplate"], descendants: true, isSignal: true }, { propertyName: "actionsDropdownRendererTemplate", first: true, predicate: ["actionsDropdownRendererTemplate"], descendants: true, isSignal: true }], ngImport: i0, template: "<!-- Grade Level 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-3\">\n <div class=\"tw-flex tw-items-center tw-space-x-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 Grade Level' : 'Quick Add Grade Level' }}</h6>\n </div>\n </div>\n \n <form [formGroup]=\"quickAddForm\" (ngSubmit)=\"quickAddGradeLevel()\">\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 <!-- Grade Level Name -->\n <div>\n <cide-ele-input \n id=\"sydsgl_name\" \n label=\"Name*\" \n formControlName=\"sydsgl_name\"\n placeholder=\"Grade level name\"\n size=\"sm\">\n </cide-ele-input>\n </div>\n \n <!-- Active Status -->\n <div class=\"tw-flex tw-flex-col tw-justify-end\">\n <cide-ele-input \n id=\"sydsgl_isactive\"\n type=\"checkbox\"\n label=\"Active\"\n formControlName=\"sydsgl_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=\"sydsgl_description\" \n label=\"Description\" \n formControlName=\"sydsgl_description\"\n placeholder=\"Grade level 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=\"sydsgl_entity_id_syen\" \n label=\"Entity ID*\" \n formControlName=\"sydsgl_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 <!-- 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\">school</cide-ele-icon>\n <h5 class=\"tw-text-base tw-font-medium tw-text-gray-900 tw-m-0\">Grade Level 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 [dragDropEnabled]=\"true\"\n (gridEvent)=\"onGridEvent($event)\">\n </cide-ele-data-grid>\n </div>\n\n </div>\n </div>\n\n</div>\n\n<!-- Drag Handle Renderer Template -->\n<ng-template #dragHandleRendererTemplate let-row=\"row\" let-value=\"value\">\n <div class=\"tw-flex tw-items-center tw-justify-center tw-w-full tw-h-full tw-cursor-move drag-handle\">\n <cide-ele-icon \n class=\"tw-text-gray-400 hover:tw-text-gray-600 tw-transition-colors\" \n size=\"xs\">\n drag_indicator\n </cide-ele-icon>\n </div>\n</ng-template>\n\n<!-- Grade Level Details Renderer Template -->\n<ng-template #gradeLevelDetailsRendererTemplate let-row=\"row\" let-value=\"value\">\n <div class=\"tw-flex tw-items-center tw-min-w-0\">\n <!-- Grade Level Icon -->\n <div class=\"tw-flex-shrink-0\">\n <cide-ele-icon \n class=\"tw-text-gray-400\" \n size=\"xs\">\n school\n </cide-ele-icon>\n </div>\n \n <!-- Grade Level 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.sydsgl_name\">\n {{ row.sydsgl_name || 'Untitled' }}\n </div>\n @if (row.sydsgl_description) {\n <div class=\"tw-text-xs tw-text-gray-500 tw-truncate\" \n [title]=\"row.sydsgl_description\">\n {{ row.sydsgl_description }}\n </div>\n }\n </div>\n </div>\n</ng-template>\n\n<!-- Grade Level Status Renderer Template -->\n<ng-template #gradeLevelStatusRendererTemplate 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.sydsgl_isactive)\">\n {{ getStatusDisplay(row.sydsgl_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"] }] }); }
778
- }
779
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: GradeLevelListComponent, decorators: [{
780
- type: Component,
781
- args: [{ selector: 'cide-core-app-grade-level-list', standalone: true, imports: [
782
- CommonModule,
783
- ReactiveFormsModule,
784
- FormsModule,
785
- CideEleDataGridComponent,
786
- CideEleButtonComponent,
787
- CideInputComponent,
788
- CideSelectComponent,
789
- CideTextareaComponent,
790
- CideIconComponent,
791
- CideEleDropdownComponent
792
- ], template: "<!-- Grade Level 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-3\">\n <div class=\"tw-flex tw-items-center tw-space-x-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 Grade Level' : 'Quick Add Grade Level' }}</h6>\n </div>\n </div>\n \n <form [formGroup]=\"quickAddForm\" (ngSubmit)=\"quickAddGradeLevel()\">\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 <!-- Grade Level Name -->\n <div>\n <cide-ele-input \n id=\"sydsgl_name\" \n label=\"Name*\" \n formControlName=\"sydsgl_name\"\n placeholder=\"Grade level name\"\n size=\"sm\">\n </cide-ele-input>\n </div>\n \n <!-- Active Status -->\n <div class=\"tw-flex tw-flex-col tw-justify-end\">\n <cide-ele-input \n id=\"sydsgl_isactive\"\n type=\"checkbox\"\n label=\"Active\"\n formControlName=\"sydsgl_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=\"sydsgl_description\" \n label=\"Description\" \n formControlName=\"sydsgl_description\"\n placeholder=\"Grade level 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=\"sydsgl_entity_id_syen\" \n label=\"Entity ID*\" \n formControlName=\"sydsgl_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 <!-- 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\">school</cide-ele-icon>\n <h5 class=\"tw-text-base tw-font-medium tw-text-gray-900 tw-m-0\">Grade Level 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 [dragDropEnabled]=\"true\"\n (gridEvent)=\"onGridEvent($event)\">\n </cide-ele-data-grid>\n </div>\n\n </div>\n </div>\n\n</div>\n\n<!-- Drag Handle Renderer Template -->\n<ng-template #dragHandleRendererTemplate let-row=\"row\" let-value=\"value\">\n <div class=\"tw-flex tw-items-center tw-justify-center tw-w-full tw-h-full tw-cursor-move drag-handle\">\n <cide-ele-icon \n class=\"tw-text-gray-400 hover:tw-text-gray-600 tw-transition-colors\" \n size=\"xs\">\n drag_indicator\n </cide-ele-icon>\n </div>\n</ng-template>\n\n<!-- Grade Level Details Renderer Template -->\n<ng-template #gradeLevelDetailsRendererTemplate let-row=\"row\" let-value=\"value\">\n <div class=\"tw-flex tw-items-center tw-min-w-0\">\n <!-- Grade Level Icon -->\n <div class=\"tw-flex-shrink-0\">\n <cide-ele-icon \n class=\"tw-text-gray-400\" \n size=\"xs\">\n school\n </cide-ele-icon>\n </div>\n \n <!-- Grade Level 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.sydsgl_name\">\n {{ row.sydsgl_name || 'Untitled' }}\n </div>\n @if (row.sydsgl_description) {\n <div class=\"tw-text-xs tw-text-gray-500 tw-truncate\" \n [title]=\"row.sydsgl_description\">\n {{ row.sydsgl_description }}\n </div>\n }\n </div>\n </div>\n</ng-template>\n\n<!-- Grade Level Status Renderer Template -->\n<ng-template #gradeLevelStatusRendererTemplate 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.sydsgl_isactive)\">\n {{ getStatusDisplay(row.sydsgl_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> " }]
793
- }], ctorParameters: () => [] });
794
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grade-level-list.component.js","sourceRoot":"","sources":["../../../../../../../../projects/cloud-ide-core/src/lib/core/grade-level-management/components/grade-level-list/grade-level-list.component.ts","../../../../../../../../projects/cloud-ide-core/src/lib/core/grade-level-management/components/grade-level-list/grade-level-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 { ICoreSydsgl } from 'cloud-ide-lms-model';\nimport { GradeLevelManagementService } from '../../services/grade-level-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\n@Component({\n  selector: 'cide-core-app-grade-level-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: './grade-level-list.component.html',\n  styleUrls: []\n})\nexport class GradeLevelListComponent {\n  // Dependency injection\n  private destroyRef = inject(DestroyRef);\n  private gradeLevelService = inject(GradeLevelManagementService);\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  dragHandleRendererTemplate = viewChild.required<TemplateRef<TemplateContext<Record<string, unknown>>>>('dragHandleRendererTemplate');\n  gradeLevelDetailsRendererTemplate = viewChild.required<TemplateRef<TemplateContext<Record<string, unknown>>>>('gradeLevelDetailsRendererTemplate');\n  gradeLevelStatusRendererTemplate = viewChild.required<TemplateRef<TemplateContext<Record<string, unknown>>>>('gradeLevelStatusRendererTemplate');\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  gradeLevels = signal<ICoreSydsgl[]>([]);\n  loading = signal(false);\n  error = signal<string | null>(null);\n  selectedItems = signal<string[]>([]);\n  searchTerm = signal('');\n\n  // Retrieved grade level data\n  retrievedGradeLevel = signal<ICoreSydsgl | null>(null);\n\n  // Edit mode flag\n  isEditMode = signal(false);\n\n  // Drag order management\n  originalOrder = signal<ICoreSydsgl[]>([]);\n  hasOrderChanged = 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    sydsgl_name: this.fb.control('', [Validators.required, Validators.minLength(1), Validators.maxLength(20)]),\n    sydsgl_description: this.fb.control('', [Validators.maxLength(400)]),\n    sydsgl_order: this.fb.control(1, [Validators.required, Validators.min(1), Validators.max(100)]),\n    sydsgl_isactive: this.fb.control(true, [Validators.required]),\n    sydsgl_entity_id_syen: this.fb.control(this.appState.getActiveEntityId() || '', [Validators.required])\n  });\n\n  // Grid configuration signal\n  gridConfig = signal<GridConfiguration<ICoreSydsgl>>({\n    id: 'grade-level-list-grid',\n    title: '',\n    subtitle: '',\n    columns: [\n      {\n        key: 'dragHandle',\n        header: '',\n        type: 'custom',\n        width: '40px',\n        truncate: false,\n        align: 'center',\n        renderer: 'dragHandleRenderer'\n      },\n      {\n        key: 'details',\n        header: 'Grade Level',\n        type: 'custom',\n        width: 'auto',\n        truncate: true,\n        align: 'left',\n        renderer: 'gradeLevelDetailsRenderer'\n      },\n      {\n        key: 'sydsgl_isactive',\n        header: 'Status',\n        type: 'custom',\n        width: '100px',\n        truncate: false,\n        align: 'center',\n        renderer: 'gradeLevelStatusRenderer'\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    dragDrop: {\n      enabled: true,\n      orderField: 'sydsgl_order',\n      dragClass: 'tw-opacity-50 tw-bg-blue-50',\n      dropClass: 'tw-bg-green-50'\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 grade levels...',\n      searchableColumns: ['sydsgl_name', 'sydsgl_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: 'onGradeLevelRefresh'\n  });\n\n  // Template renderers using Angular best practices\n  templateRenderers = computed((): Record<string, TemplateRef<TemplateContext>> => ({\n    dragHandleRenderer: this.dragHandleRendererTemplate(),\n    gradeLevelDetailsRenderer: this.gradeLevelDetailsRendererTemplate(),\n    gradeLevelStatusRenderer: this.gradeLevelStatusRendererTemplate(),\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: ICoreSydsgl) => string> {\n    return {};\n  }\n\n  // Action handlers for grid actions\n  actionHandlers = {\n    onEditGradeLevel: (row: ICoreSydsgl) => this.editGradeLevel(row._id || ''),\n    onToggleGradeLevel: (row: ICoreSydsgl) => this.toggleGradeLevelStatus(row._id || ''),\n    onDeleteGradeLevel: (row: ICoreSydsgl) => this.deleteGradeLevel(row._id || ''),\n    onGradeLevelRowClick: (row: ICoreSydsgl) => this.onGradeLevelRowClick(row),\n    onGradeLevelRefresh: () => this.onGradeLevelRefresh(),\n    resetOrder: () => this.resetDragOrder(),\n    saveOrder: () => this.saveGradeLevelOrder()\n  };\n\n  // Computed properties\n  filteredItems = computed(() => {\n    const items = this.gradeLevels();\n    const search = this.searchTerm()?.toLowerCase();\n\n    if (!search) return items;\n\n    return items.filter(item => {\n      return item.sydsgl_name?.toLowerCase().includes(search) ||\n        item.sydsgl_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  // Computed property for next order\n  nextOrder = computed(() => this.calculateNextOrder());\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('GradeLevelListComponent initialized with modern Angular patterns');\n    this.loadGradeLevels();\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 { handleGradeLevelAction: (action: string, id: string) => void }).handleGradeLevelAction = this.handleGradeLevelAction.bind(this);\n    }\n  }\n\n  /**\n   * Load grade levels from service\n   */\n  loadGradeLevels(): void {\n    console.log('🚀 GradeLevelListComponent.loadGradeLevels() 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.gradeLevelService) {\n      console.error('❌ GradeLevelService is not available');\n      this.error.set('Grade level service is not available');\n      this.loading.set(false);\n      return;\n    }\n\n    this.gradeLevelService.getGradeLevelList(requestBody)\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe({\n        next: (response) => {\n          console.log('📥 GradeLevelListComponent received response:', response);\n          if (response?.success) {\n            console.log('✅ Response successful, setting grade levels:', response.data);\n            const gradeLevelData = response?.data || [];\n            this.gradeLevels.set(gradeLevelData);\n            this.totalItems.set(response.total || 0);\n            this.updateGridData(gradeLevelData);\n            \n            // Update the order field in the form if not in edit mode\n            if (!this.isEditMode()) {\n              const nextOrder = this.calculateNextOrder();\n              this.quickAddForm.patchValue({ sydsgl_order: nextOrder });\n            }\n          } else {\n            console.error('❌ Response was not successful:', response);\n            this.error.set('Failed to load grade levels');\n          }\n        },\n        error: (err) => {\n          console.error('❌ GradeLevelListComponent error:', err);\n          this.error.set(err.message || 'An error occurred while loading grade levels');\n        },\n        complete: () => {\n          console.log('GradeLevelListComponent loadGradeLevels completed');\n          this.loading.set(false);\n        }\n      });\n  }\n\n  /**\n   * Update grid data\n   */\n  private updateGridData(gradeLevels: ICoreSydsgl[]): void {\n    console.log('🔄 updateGridData called with:', gradeLevels);\n    \n    this.gridConfig.update(config => {\n      const newConfig = {\n        ...config,\n        data: gradeLevels\n      };\n      console.log('⚙️ Updated grid config with grade levels');\n      return newConfig;\n    });\n  }\n\n  /**\n   * Handle grid events\n   */\n  onGridEvent(event: GridEvent<ICoreSydsgl>): 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.loadGradeLevels();\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.loadGradeLevels();\n        } else {\n          const page = event.data as number;\n          if (page) {\n            this.currentPage.set(page);\n            this.loadGradeLevels();\n          }\n        }\n        break;\n      }\n      case 'refresh':\n        this.onGradeLevelRefresh();\n        break;\n      case 'rowClick':\n        this.onGradeLevelRowClick(event.data as ICoreSydsgl);\n        break;\n      case 'rowReorder':\n        this.onGradeLevelReorder(event.data as { sourceIndex: number; targetIndex: number; newOrder: ICoreSydsgl[] });\n        break;\n      case 'action':\n        if (event.action?.key === 'edit') {\n          this.editGradeLevel(event.data as string);\n        } else if (event.action?.key === 'toggle') {\n          this.toggleGradeLevelStatus(event.data as string);\n        } else if (event.action?.key === 'delete') {\n          this.deleteGradeLevel(event.data as string);\n        }\n        break;\n    }\n  }\n\n  /**\n   * Handle grade level refresh\n   */\n  onGradeLevelRefresh(): void {\n    this.loadGradeLevels();\n  }\n\n  /**\n   * Handle grade level reorder via drag and drop\n   */\n  onGradeLevelReorder(data: { sourceIndex: number; targetIndex: number; newOrder: ICoreSydsgl[] }): void {\n    console.log('🔄 Grade level reorder event:', data);\n\n    // Save original order if not already saved\n    if (this.originalOrder().length === 0) {\n      this.originalOrder.set([...this.gradeLevels()]);\n    }\n\n    // Update the displayed data with new order\n    const updatedItems = data.newOrder.map((item, index) => ({\n      ...item,\n      sydsgl_order: index + 1\n    }));\n    \n    this.gradeLevels.set(updatedItems);\n\n    // Mark that order has changed\n    this.hasOrderChanged.set(true);\n\n    // Update grid data\n    this.updateGridDataAfterReorder();\n    console.log('Updated gradeLevels:', this.gradeLevels());\n  }\n\n  /**\n   * Update grid data after reordering\n   */\n  private updateGridDataAfterReorder() {\n    const currentConfig = this.gridConfig();\n    this.gridConfig.set({\n      ...currentConfig,\n      data: this.gradeLevels()\n    });\n  }\n\n  /**\n   * Save grade level order\n   */\n  saveGradeLevelOrder() {\n    console.log('💾 Saving grade level order...');\n    \n    // Send updates to the server for each item that changed order\n    const promises = this.gradeLevels().map(item => {\n      return this.gradeLevelService.updateGradeLevel(item._id || '', {\n        sydsgl_order: item.sydsgl_order\n      }).toPromise();\n    });\n\n    // Wait for all updates to complete\n    Promise.all(promises)\n      .then(() => {\n        console.log('✅ All grade level orders updated successfully');\n        // Update original order and reset change flag\n        this.originalOrder.set([...this.gradeLevels()]);\n        this.hasOrderChanged.set(false);\n      })\n      .catch((error) => {\n        console.error('❌ Error updating grade level orders:', error);\n        this.error.set('Failed to update grade level order');\n      });\n  }\n\n  /**\n   * Reset drag order to original state\n   */\n  resetDragOrder() {\n    console.log('🔄 Resetting drag order to original state');\n\n    // Restore the original order\n    const originalItems = this.originalOrder();\n    if (originalItems.length > 0) {\n      this.gradeLevels.set([...originalItems]);\n      this.updateGridDataAfterReorder();\n    }\n\n    // Reset the change flag\n    this.hasOrderChanged.set(false);\n\n    console.log('✅ Drag order reset successfully');\n  }\n\n  /**\n   * Check if order has changed\n   */\n  hasOrderChanges(): boolean {\n    return this.hasOrderChanged();\n  }\n\n  /**\n   * Handle grade level row click\n   */\n  onGradeLevelRowClick(gradeLevel: ICoreSydsgl): void {\n    this.editGradeLevel(gradeLevel._id || '');\n  }\n\n  /**\n   * Navigate to edit grade level form\n   */\n  editGradeLevel(itemId: string): void {\n    console.log('🔵 editGradeLevel called with:', itemId);\n    this.isEditMode.set(true);\n    this.getGradeLevelById(itemId);\n  }\n\n  /**\n   * Get grade level by ID using the API\n   */\n  getGradeLevelById(itemId: string): void {\n    console.log('🔵 getGradeLevelById called with:', itemId);\n    this.loading.set(true);\n\n    this.gradeLevelService.getGradeLevelById(itemId)\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe({\n        next: (response) => {\n          if (response.success) {\n            console.log('✅ Grade level retrieved successfully:', response.data);\n            let gradeLevel: ICoreSydsgl | null = null;\n            gradeLevel = response.data || null;\n\n            this.retrievedGradeLevel.set(gradeLevel);\n\n            if (this.isEditMode() && gradeLevel) {\n              this.populateFormForEdit(gradeLevel);\n            }\n          } else {\n            this.error.set('Failed to retrieve grade level');\n          }\n        },\n        error: (err) => {\n          this.error.set(err.message || 'An error occurred while retrieving the grade level');\n        },\n        complete: () => {\n          this.loading.set(false);\n        }\n      });\n  }\n\n  /**\n   * Populate form with grade level data for editing\n   */\n  populateFormForEdit(gradeLevel: ICoreSydsgl): void {\n    console.log('🔵 populateFormForEdit called with:', gradeLevel);\n\n    this.quickAddForm.patchValue({\n      sydsgl_name: gradeLevel.sydsgl_name || '',\n      sydsgl_description: gradeLevel.sydsgl_description || '',\n      sydsgl_order: gradeLevel.sydsgl_order || 1,\n      sydsgl_isactive: gradeLevel.sydsgl_isactive ?? true,\n      sydsgl_entity_id_syen: gradeLevel.sydsgl_entity_id_syen || ''\n    });\n\n    console.log('✅ Form populated for editing:', this.quickAddForm.value);\n  }\n\n  /**\n   * Delete grade level\n   */\n  deleteGradeLevel(itemId: string): void {\n    console.log('🔵 deleteGradeLevel called with:', itemId);\n    if (confirm('Are you sure you want to delete this grade level?')) {\n      this.loading.set(true);\n\n      this.gradeLevelService.deleteGradeLevel(itemId)\n        .pipe(takeUntilDestroyed(this.destroyRef))\n        .subscribe({\n          next: (response) => {\n            if (response.success) {\n              this.loadGradeLevels();\n            } else {\n              this.error.set('Failed to delete grade level');\n            }\n          },\n          error: (err) => {\n            this.error.set(err.message || 'An error occurred while deleting the grade level');\n          },\n          complete: () => {\n            this.loading.set(false);\n          }\n        });\n    }\n  }\n\n  /**\n   * Toggle grade level status\n   */\n  toggleGradeLevelStatus(itemId: string): void {\n    console.log('🔵 toggleGradeLevelStatus called with:', itemId);\n    this.loading.set(true);\n\n    this.gradeLevelService.toggleGradeLevelStatus(itemId)\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe({\n        next: (response) => {\n          if (response.success) {\n            this.loadGradeLevels();\n          } else {\n            this.error.set('Failed to toggle grade level 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 grade level using reactive form\n   */\n  quickAddGradeLevel() {\n    if (this.quickAddForm.invalid) return;\n\n    const formValue = this.quickAddForm.value;\n\n    // For new grade levels, ensure the order is set to the calculated next order\n    let order = formValue.sydsgl_order;\n    if (!this.isEditMode()) {\n      order = this.calculateNextOrder();\n    }\n\n    const gradeLevel: Partial<ICoreSydsgl> = {\n      _id: this.retrievedGradeLevel()?._id || '',\n      sydsgl_name: formValue.sydsgl_name,\n      sydsgl_description: formValue.sydsgl_description || '',\n      sydsgl_order: order,\n      sydsgl_isactive: formValue.sydsgl_isactive,\n      sydsgl_entity_id_syen: formValue.sydsgl_entity_id_syen\n    };\n\n    if (this.isEditMode() && this.retrievedGradeLevel()) {\n      const itemId = this.retrievedGradeLevel()?._id;\n      if (itemId) {\n        console.log('🔵 Updating grade level:', itemId);\n        this.gradeLevelService.updateGradeLevel(itemId, gradeLevel).subscribe({\n          next: (response) => {\n            if (response.success) {\n              console.log('✅ Grade level updated successfully');\n              this.resetQuickAddForm();\n              this.isEditMode.set(false);\n              this.retrievedGradeLevel.set(null);\n              this.loadGradeLevels();\n            }\n          },\n          error: () => {\n            this.error.set('Failed to update grade level');\n          }\n        });\n      }\n    } else {\n      console.log('🔵 Creating new grade level');\n      this.gradeLevelService.createGradeLevel(gradeLevel).subscribe({\n        next: (response) => {\n          if (response.success) {\n            console.log('✅ Grade level created successfully');\n            this.resetQuickAddForm();\n            this.loadGradeLevels();\n          }\n        },\n        error: () => {\n          this.error.set('Failed to create grade level');\n        }\n      });\n    }\n  }\n\n  /**\n   * Calculate the highest order from existing grade levels\n   */\n  private calculateNextOrder(): number {\n    const currentGradeLevels = this.gradeLevels();\n    if (currentGradeLevels.length === 0) {\n      return 1;\n    }\n    \n    const maxOrder = Math.max(...currentGradeLevels.map(level => level.sydsgl_order || 0));\n    return maxOrder + 1;\n  }\n\n  /**\n   * Reset the quick add form to default values\n   */\n  resetQuickAddForm(): void {\n    this.isEditMode.set(false);\n    this.retrievedGradeLevel.set(null);\n\n    // Calculate the next order automatically\n    const nextOrder = this.calculateNextOrder();\n\n    this.quickAddForm.reset({\n      sydsgl_name: '',\n      sydsgl_description: '',\n      sydsgl_order: nextOrder,\n      sydsgl_isactive: true,\n      sydsgl_entity_id_syen: this.appState.getActiveEntityId() || ''\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.editGradeLevel(itemId);\n            break;\n          case 'toggle':\n            this.toggleGradeLevelStatus(itemId);\n            break;\n          case 'delete':\n            this.deleteGradeLevel(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 grade level action clicks\n   */\n  handleGradeLevelAction(action: string, itemId: string) {\n    const item = this.gradeLevels().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.editGradeLevel(itemId);\n        break;\n      case 'toggle':\n        this.toggleGradeLevelStatus(itemId);\n        break;\n      case 'delete':\n        this.deleteGradeLevel(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 grade level actions\n   */\n  getDropdownItems(row: ICoreSydsgl): 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: 'toggle',\n        label: row.sydsgl_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: ICoreSydsgl): void {\n    console.log('🔵 onDropdownItemClick called with:', item, row);\n\n    switch (item.id) {\n      case 'edit':\n        this.editGradeLevel(row._id || '');\n        break;\n      case 'toggle':\n        this.toggleGradeLevelStatus(row._id || '');\n        break;\n      case 'delete':\n        this.deleteGradeLevel(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: ICoreSydsgl): string {\n    return item._id || '';\n  }\n} ","<!-- Grade Level 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-3\">\n      <div class=\"tw-flex tw-items-center tw-space-x-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 Grade Level' : 'Quick Add Grade Level' }}</h6>\n      </div>\n    </div>\n    \n    <form [formGroup]=\"quickAddForm\" (ngSubmit)=\"quickAddGradeLevel()\">\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      <!-- Grade Level Name -->\n      <div>\n        <cide-ele-input \n          id=\"sydsgl_name\" \n          label=\"Name*\" \n          formControlName=\"sydsgl_name\"\n          placeholder=\"Grade level name\"\n          size=\"sm\">\n        </cide-ele-input>\n      </div>\n      \n      <!-- Active Status -->\n      <div class=\"tw-flex tw-flex-col tw-justify-end\">\n        <cide-ele-input \n          id=\"sydsgl_isactive\"\n          type=\"checkbox\"\n          label=\"Active\"\n          formControlName=\"sydsgl_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=\"sydsgl_description\" \n          label=\"Description\" \n          formControlName=\"sydsgl_description\"\n          placeholder=\"Grade level 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=\"sydsgl_entity_id_syen\" \n          label=\"Entity ID*\" \n          formControlName=\"sydsgl_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  <!-- 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\">school</cide-ele-icon>\n        <h5 class=\"tw-text-base tw-font-medium tw-text-gray-900 tw-m-0\">Grade Level 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      [dragDropEnabled]=\"true\"\n      (gridEvent)=\"onGridEvent($event)\">\n    </cide-ele-data-grid>\n  </div>\n\n    </div>\n  </div>\n\n</div>\n\n<!-- Drag Handle Renderer Template -->\n<ng-template #dragHandleRendererTemplate let-row=\"row\" let-value=\"value\">\n  <div class=\"tw-flex tw-items-center tw-justify-center tw-w-full tw-h-full tw-cursor-move drag-handle\">\n    <cide-ele-icon \n      class=\"tw-text-gray-400 hover:tw-text-gray-600 tw-transition-colors\" \n      size=\"xs\">\n      drag_indicator\n    </cide-ele-icon>\n  </div>\n</ng-template>\n\n<!-- Grade Level Details Renderer Template -->\n<ng-template #gradeLevelDetailsRendererTemplate let-row=\"row\" let-value=\"value\">\n  <div class=\"tw-flex tw-items-center tw-min-w-0\">\n    <!-- Grade Level Icon -->\n    <div class=\"tw-flex-shrink-0\">\n      <cide-ele-icon \n        class=\"tw-text-gray-400\" \n        size=\"xs\">\n        school\n      </cide-ele-icon>\n    </div>\n    \n    <!-- Grade Level 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.sydsgl_name\">\n        {{ row.sydsgl_name || 'Untitled' }}\n      </div>\n      @if (row.sydsgl_description) {\n        <div class=\"tw-text-xs tw-text-gray-500 tw-truncate\" \n             [title]=\"row.sydsgl_description\">\n          {{ row.sydsgl_description }}\n        </div>\n      }\n    </div>\n  </div>\n</ng-template>\n\n<!-- Grade Level Status Renderer Template -->\n<ng-template #gradeLevelStatusRendererTemplate 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.sydsgl_isactive)\">\n    {{ getStatusDisplay(row.sydsgl_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> "]}