cloud-ide-core 0.0.1 → 1.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (25) hide show
  1. package/esm2022/lib/cloud-ide-core.routes.mjs +137 -0
  2. package/esm2022/lib/core/general-master-management/components/general-master/general-master.component.mjs +738 -0
  3. package/esm2022/lib/core/general-master-management/components/general-master-type/general-master-type.component.mjs +608 -0
  4. package/esm2022/lib/core/general-master-management/services/general-master-type.service.mjs +203 -0
  5. package/esm2022/lib/core/general-master-management/services/general-master.service.mjs +166 -0
  6. package/esm2022/lib/core/page-management/components/page-form/page-form.component.mjs +212 -0
  7. package/esm2022/public-api.mjs +2 -1
  8. package/fesm2022/cloud-ide-core-general-master-type.component-B26auJZw.mjs +611 -0
  9. package/fesm2022/cloud-ide-core-general-master-type.component-B26auJZw.mjs.map +1 -0
  10. package/fesm2022/cloud-ide-core-general-master-type.service-Ab64Jjps.mjs +206 -0
  11. package/fesm2022/cloud-ide-core-general-master-type.service-Ab64Jjps.mjs.map +1 -0
  12. package/fesm2022/cloud-ide-core-general-master.component-B6llTVoV.mjs +903 -0
  13. package/fesm2022/cloud-ide-core-general-master.component-B6llTVoV.mjs.map +1 -0
  14. package/fesm2022/cloud-ide-core-page-form.component-CaEca3mB.mjs +215 -0
  15. package/fesm2022/cloud-ide-core-page-form.component-CaEca3mB.mjs.map +1 -0
  16. package/fesm2022/cloud-ide-core.mjs +173 -1
  17. package/fesm2022/cloud-ide-core.mjs.map +1 -1
  18. package/lib/cloud-ide-core.routes.d.ts +2 -0
  19. package/lib/core/general-master-management/components/general-master/general-master.component.d.ts +167 -0
  20. package/lib/core/general-master-management/components/general-master-type/general-master-type.component.d.ts +129 -0
  21. package/lib/core/general-master-management/services/general-master-type.service.d.ts +75 -0
  22. package/lib/core/general-master-management/services/general-master.service.d.ts +62 -0
  23. package/lib/core/page-management/components/page-form/page-form.component.d.ts +35 -0
  24. package/package.json +1 -1
  25. package/public-api.d.ts +1 -0
@@ -0,0 +1,608 @@
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 { GeneralMasterTypeService } from '../../services/general-master-type.service';
7
+ import { CideEleDataGridComponent, CideIconComponent, CideInputComponent, CideSelectComponent, CideTextareaComponent, CideEleDropdownComponent, CideEleJsonEditorComponent, CideEleButtonComponent } from 'cloud-ide-element';
8
+ import { generateStringFromObject } from 'cloud-ide-lms-model';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "@angular/forms";
11
+ export class GeneralMasterTypeComponent {
12
+ constructor() {
13
+ // Dependency injection
14
+ this.destroyRef = inject(DestroyRef);
15
+ this.typeService = inject(GeneralMasterTypeService);
16
+ this.fb = inject(NonNullableFormBuilder);
17
+ this.router = inject(Router);
18
+ // Modern ViewChild signals for template renderers (Angular 20 approach)
19
+ this.typeDetailsRendererTemplate = viewChild.required('typeDetailsRendererTemplate');
20
+ this.typeStatusRendererTemplate = viewChild.required('typeStatusRendererTemplate');
21
+ this.actionsDropdownRendererTemplate = viewChild.required('actionsDropdownRendererTemplate');
22
+ // Make Math available in template
23
+ this.Math = Math;
24
+ // Signals for reactive state management
25
+ this.types = signal([]);
26
+ this.loading = signal(false);
27
+ this.error = signal(null);
28
+ this.selectedItems = signal([]);
29
+ this.searchTerm = signal('');
30
+ // Form state
31
+ this.isEditMode = signal(false);
32
+ this.editingTypeId = signal(null);
33
+ this.retrievedType = signal(null);
34
+ // Pagination signals
35
+ this.currentPage = signal(1);
36
+ this.pageSize = signal(10);
37
+ this.totalItems = signal(0);
38
+ // Modern reactive forms with signals
39
+ this.typeForm = this.fb.group({
40
+ sygmt_code: [''],
41
+ sygmt_title: [''],
42
+ sygmt_desc: [''],
43
+ sygmt_configuration: ['{}'],
44
+ sygmt_isactive: [true],
45
+ sygmt_id_sygmt: [''] // Parent type ID for child types
46
+ });
47
+ // Computed values
48
+ this.isFormDirty = computed(() => this.typeForm.dirty);
49
+ // Grid configuration signal
50
+ this.gridConfig = signal({
51
+ id: 'type-list-grid',
52
+ title: '',
53
+ subtitle: '',
54
+ columns: [
55
+ {
56
+ key: 'details',
57
+ header: 'Type Details',
58
+ type: 'custom',
59
+ width: 'auto',
60
+ truncate: true,
61
+ align: 'left',
62
+ renderer: 'typeDetailsRenderer'
63
+ },
64
+ {
65
+ key: 'sygmt_code',
66
+ header: 'Type Code',
67
+ type: 'text',
68
+ width: '150px',
69
+ truncate: true,
70
+ align: 'left'
71
+ },
72
+ {
73
+ key: 'sygmt_isactive',
74
+ header: 'Status',
75
+ type: 'custom',
76
+ width: '100px',
77
+ truncate: false,
78
+ align: 'center',
79
+ renderer: 'typeStatusRenderer'
80
+ },
81
+ {
82
+ key: 'actions',
83
+ header: '',
84
+ type: 'custom',
85
+ width: '150px',
86
+ truncate: false,
87
+ align: 'center',
88
+ renderer: 'actionsDropdownRenderer'
89
+ }
90
+ ],
91
+ data: [],
92
+ trackBy: '_id',
93
+ tree: {
94
+ enabled: true,
95
+ foreignKey: 'sygmt_id_sygmt',
96
+ primaryKey: '_id'
97
+ },
98
+ pagination: {
99
+ enabled: true,
100
+ pageSize: 10,
101
+ pageSizeOptions: [10, 25, 50, 100],
102
+ showQuickJump: true,
103
+ showPageInfo: true,
104
+ showRefresh: true
105
+ },
106
+ search: {
107
+ enabled: true,
108
+ placeholder: 'Search types...',
109
+ searchableColumns: ['sygmt_title', 'sygmt_desc', 'sygmt_code'],
110
+ debounceMs: 300
111
+ },
112
+ loading: {
113
+ useDefer: true,
114
+ skeletonRows: 5,
115
+ showOverlay: false
116
+ },
117
+ scroll: {
118
+ enabled: true,
119
+ maxHeight: '',
120
+ minHeight: '',
121
+ stickyHeader: true,
122
+ virtualScroll: false,
123
+ rowHeight: 40
124
+ },
125
+ responsive: true,
126
+ striped: false,
127
+ bordered: true,
128
+ compact: true,
129
+ tableClass: 'tw-table-fixed tw-w-full tw-rounded-none'
130
+ });
131
+ // Action handlers for grid
132
+ this.actionHandlers = {
133
+ onEdit: (item) => this.editType(item),
134
+ onDelete: (item) => this.deleteType(item),
135
+ onToggleStatus: (item) => this.toggleTypeStatus(item)
136
+ };
137
+ // Computed template renderers for grid
138
+ this.templateRenderers = computed(() => ({
139
+ typeDetailsRenderer: this.typeDetailsRendererTemplate(),
140
+ typeStatusRenderer: this.typeStatusRendererTemplate(),
141
+ actionsDropdownRenderer: this.actionsDropdownRendererTemplate()
142
+ }));
143
+ }
144
+ ngOnInit() {
145
+ this.initializeComponent();
146
+ // Add form submission debugging
147
+ this.typeForm.valueChanges.subscribe(value => {
148
+ console.log('🔵 Form value changed:', value);
149
+ });
150
+ this.typeForm.statusChanges.subscribe(status => {
151
+ console.log('🔵 Form status changed:', status);
152
+ });
153
+ }
154
+ /**
155
+ * Initialize component
156
+ */
157
+ initializeComponent() {
158
+ this.loadTypes();
159
+ this.setupFormSubscriptions();
160
+ }
161
+ /**
162
+ * Load types from API
163
+ */
164
+ loadTypes() {
165
+ this.loading.set(true);
166
+ this.error.set(null);
167
+ const request = {};
168
+ this.typeService.getTypeList(request)
169
+ .pipe(takeUntilDestroyed(this.destroyRef))
170
+ .subscribe({
171
+ next: (response) => {
172
+ if (response.success) {
173
+ this.types.set(response.data || []);
174
+ this.totalItems.set(response.total || 0);
175
+ this.updateGridData();
176
+ }
177
+ else {
178
+ this.error.set(response.message || 'Failed to load types');
179
+ }
180
+ this.loading.set(false);
181
+ },
182
+ error: (error) => {
183
+ console.error('Error loading types:', error);
184
+ this.error.set('Failed to load types. Please try again.');
185
+ this.loading.set(false);
186
+ }
187
+ });
188
+ }
189
+ /**
190
+ * Setup form subscriptions
191
+ */
192
+ setupFormSubscriptions() {
193
+ // Watch for form changes to enable/disable save button
194
+ this.typeForm.valueChanges
195
+ .pipe(takeUntilDestroyed(this.destroyRef))
196
+ .subscribe(() => {
197
+ // Form validation is handled by computed signals
198
+ });
199
+ }
200
+ /**
201
+ * Update grid data
202
+ */
203
+ updateGridData() {
204
+ this.gridConfig.update(config => ({
205
+ ...config,
206
+ data: this.types()
207
+ }));
208
+ }
209
+ /**
210
+ * Handle grid events
211
+ */
212
+ onGridEvent(event) {
213
+ switch (event.type) {
214
+ case 'pageChange':
215
+ if (event.data && typeof event.data === 'object' && 'pageIndex' in event.data && 'pageSize' in event.data) {
216
+ this.currentPage.set(event.data['pageIndex']);
217
+ this.pageSize.set(event.data['pageSize']);
218
+ this.loadTypes();
219
+ }
220
+ break;
221
+ case 'search':
222
+ if (event.data && typeof event.data === 'string') {
223
+ this.searchTerm.set(event.data);
224
+ this.currentPage.set(1);
225
+ this.loadTypes();
226
+ }
227
+ break;
228
+ case 'refresh':
229
+ this.loadTypes();
230
+ break;
231
+ case 'action':
232
+ // Handle action events if needed
233
+ console.log('Action event:', event);
234
+ break;
235
+ case 'rowClick':
236
+ // Handle row click events if needed
237
+ console.log('Row click event:', event);
238
+ break;
239
+ case 'sort':
240
+ // Handle sort events if needed
241
+ console.log('Sort event:', event);
242
+ break;
243
+ case 'export':
244
+ // Handle export events if needed
245
+ console.log('Export event:', event);
246
+ break;
247
+ case 'rowReorder':
248
+ // Handle row reorder events if needed
249
+ console.log('Row reorder event:', event);
250
+ break;
251
+ }
252
+ }
253
+ /**
254
+ * Create new type
255
+ */
256
+ createType() {
257
+ if (!this.typeForm.valid) {
258
+ this.markFormAsTouched();
259
+ return;
260
+ }
261
+ const formValue = this.typeForm.getRawValue();
262
+ const newType = {
263
+ _id: '', // Empty _id for create operation
264
+ sygmt_code: formValue.sygmt_code,
265
+ sygmt_title: formValue.sygmt_title,
266
+ sygmt_desc: formValue.sygmt_desc,
267
+ sygmt_configuration: JSON.parse(formValue.sygmt_configuration),
268
+ sygmt_isactive: formValue.sygmt_isactive
269
+ };
270
+ this.loading.set(true);
271
+ this.typeService.saveType(newType)
272
+ .pipe(takeUntilDestroyed(this.destroyRef))
273
+ .subscribe({
274
+ next: (response) => {
275
+ if (response.success) {
276
+ this.cancelForm();
277
+ this.loadTypes();
278
+ console.log('✅ Type created successfully');
279
+ }
280
+ else {
281
+ console.error('❌ Failed to create type:', response.message);
282
+ }
283
+ this.loading.set(false);
284
+ },
285
+ error: (error) => {
286
+ console.error('Error creating type:', error);
287
+ console.error('❌ Failed to create type. Please try again.');
288
+ this.loading.set(false);
289
+ }
290
+ });
291
+ }
292
+ /**
293
+ * Update existing type
294
+ */
295
+ updateType() {
296
+ console.log('🔵 updateType called');
297
+ console.log('🔵 form valid:', this.typeForm.valid);
298
+ console.log('🔵 editingTypeId:', this.editingTypeId());
299
+ if (!this.typeForm.valid || !this.editingTypeId()) {
300
+ console.log('🔵 Form validation failed or no editing ID');
301
+ this.markFormAsTouched();
302
+ return;
303
+ }
304
+ const formValue = this.typeForm.getRawValue();
305
+ const updatedType = {
306
+ _id: this.editingTypeId(), // Include _id for update operation
307
+ sygmt_code: formValue.sygmt_code,
308
+ sygmt_title: formValue.sygmt_title,
309
+ sygmt_desc: formValue.sygmt_desc,
310
+ sygmt_configuration: JSON.parse(formValue.sygmt_configuration || '{}'),
311
+ sygmt_isactive: formValue.sygmt_isactive
312
+ };
313
+ console.log('🔵 Making API call to update type:', updatedType);
314
+ this.loading.set(true);
315
+ this.typeService.saveType(updatedType)
316
+ .pipe(takeUntilDestroyed(this.destroyRef))
317
+ .subscribe({
318
+ next: (response) => {
319
+ console.log('🔵 API response received:', response);
320
+ if (response.success) {
321
+ this.cancelForm();
322
+ this.loadTypes();
323
+ console.log('✅ Type updated successfully');
324
+ }
325
+ else {
326
+ console.error('❌ Failed to update type:', response.message);
327
+ }
328
+ this.loading.set(false);
329
+ },
330
+ error: (error) => {
331
+ console.error('🔵 API error:', error);
332
+ console.error('❌ Failed to update type. Please try again.');
333
+ this.loading.set(false);
334
+ }
335
+ });
336
+ }
337
+ /**
338
+ * Edit type
339
+ */
340
+ editType(type) {
341
+ this.isEditMode.set(true);
342
+ this.editingTypeId.set(type._id || "");
343
+ this.retrievedType.set(type);
344
+ this.typeForm.patchValue({
345
+ sygmt_code: type.sygmt_code,
346
+ sygmt_title: type.sygmt_title,
347
+ sygmt_desc: type.sygmt_desc,
348
+ sygmt_configuration: JSON.stringify(type.sygmt_configuration, null, 2),
349
+ sygmt_isactive: type.sygmt_isactive
350
+ });
351
+ this.typeForm.markAsPristine();
352
+ }
353
+ /**
354
+ * Delete type
355
+ */
356
+ deleteType(type) {
357
+ if (confirm(`Are you sure you want to delete the type "${type.sygmt_title}"?`)) {
358
+ this.loading.set(true);
359
+ this.typeService.deleteType(type._id || "")
360
+ .pipe(takeUntilDestroyed(this.destroyRef))
361
+ .subscribe({
362
+ next: (response) => {
363
+ if (response.success) {
364
+ this.loadTypes();
365
+ console.log('✅ Type deleted successfully');
366
+ }
367
+ else {
368
+ console.error('❌ Failed to delete type:', response.message);
369
+ }
370
+ this.loading.set(false);
371
+ },
372
+ error: (error) => {
373
+ console.error('Error deleting type:', error);
374
+ console.error('❌ Failed to delete type. Please try again.');
375
+ this.loading.set(false);
376
+ }
377
+ });
378
+ }
379
+ }
380
+ /**
381
+ * Toggle type status
382
+ */
383
+ toggleTypeStatus(type) {
384
+ this.loading.set(true);
385
+ this.typeService.toggleTypeStatus({ sygmt_id: type._id || "" })
386
+ .pipe(takeUntilDestroyed(this.destroyRef))
387
+ .subscribe({
388
+ next: (response) => {
389
+ if (response.success) {
390
+ this.loadTypes();
391
+ console.log(`✅ Type ${type.sygmt_isactive ? 'deactivated' : 'activated'} successfully`);
392
+ }
393
+ else {
394
+ console.error('❌ Failed to toggle type status:', response.message);
395
+ }
396
+ this.loading.set(false);
397
+ },
398
+ error: (error) => {
399
+ console.error('Error toggling type status:', error);
400
+ console.error('❌ Failed to toggle type status. Please try again.');
401
+ this.loading.set(false);
402
+ }
403
+ });
404
+ }
405
+ /**
406
+ * Navigate to general master management for this type
407
+ */
408
+ navigateToGeneralMaster(type) {
409
+ const payload = generateStringFromObject({
410
+ sygmt_id: type._id,
411
+ sygmt_title: type.sygmt_title
412
+ });
413
+ this.router.navigate(['control-panel', 'general_master_entry', payload]);
414
+ }
415
+ /**
416
+ * Handle form submission event
417
+ */
418
+ onSubmit(event) {
419
+ event.preventDefault();
420
+ console.log('🔵 Form onSubmit event triggered');
421
+ this.saveType();
422
+ }
423
+ /**
424
+ * Save type (create or update)
425
+ */
426
+ saveType() {
427
+ console.log('🔵 saveType called');
428
+ console.log('🔵 isEditMode:', this.isEditMode());
429
+ console.log('🔵 editingTypeId:', this.editingTypeId());
430
+ console.log('🔵 form valid:', this.typeForm.valid);
431
+ console.log('🔵 form values:', this.typeForm.getRawValue());
432
+ console.log('🔵 form dirty:', this.typeForm.dirty);
433
+ console.log('🔵 form pristine:', this.typeForm.pristine);
434
+ console.log('🔵 form touched:', this.typeForm.touched);
435
+ if (this.isEditMode()) {
436
+ console.log('🔵 Calling updateType');
437
+ this.updateType();
438
+ }
439
+ else {
440
+ console.log('🔵 Calling createType');
441
+ this.createType();
442
+ }
443
+ }
444
+ /**
445
+ * Cancel form (reset to defaults and exit edit mode)
446
+ */
447
+ cancelForm() {
448
+ this.typeForm.reset({
449
+ sygmt_code: '',
450
+ sygmt_title: '',
451
+ sygmt_desc: '',
452
+ sygmt_configuration: '{}',
453
+ sygmt_isactive: true,
454
+ sygmt_id_sygmt: '' // Clear parent type ID
455
+ });
456
+ this.isEditMode.set(false);
457
+ this.editingTypeId.set(null);
458
+ this.retrievedType.set(null);
459
+ this.typeForm.markAsPristine();
460
+ this.typeForm.markAsUntouched();
461
+ }
462
+ /**
463
+ * Mark form as touched to trigger validation display
464
+ */
465
+ markFormAsTouched() {
466
+ Object.keys(this.typeForm.controls).forEach(key => {
467
+ const control = this.typeForm.get(key);
468
+ control?.markAsTouched();
469
+ });
470
+ }
471
+ /**
472
+ * Clear parent type relationship
473
+ */
474
+ clearParentType() {
475
+ this.typeForm.patchValue({
476
+ sygmt_id_sygmt: ''
477
+ });
478
+ console.log('🔵 Parent type relationship cleared');
479
+ }
480
+ /**
481
+ * Get dropdown items for actions
482
+ */
483
+ getActionDropdownItems(type) {
484
+ return [
485
+ {
486
+ id: 'edit',
487
+ label: 'Edit',
488
+ icon: 'edit',
489
+ disabled: false
490
+ },
491
+ {
492
+ id: 'addChild',
493
+ label: 'Add Child',
494
+ icon: 'add',
495
+ disabled: false
496
+ },
497
+ {
498
+ id: 'general-master',
499
+ label: 'General Master',
500
+ icon: 'list',
501
+ disabled: false
502
+ },
503
+ {
504
+ id: 'toggle',
505
+ label: type.sygmt_isactive ? 'Deactivate' : 'Activate',
506
+ icon: type.sygmt_isactive ? 'block' : 'check_circle',
507
+ disabled: false
508
+ },
509
+ {
510
+ id: 'delete',
511
+ label: 'Delete',
512
+ icon: 'delete',
513
+ disabled: false
514
+ }
515
+ ];
516
+ }
517
+ /**
518
+ * Get parent type display name
519
+ */
520
+ getParentTypeDisplay() {
521
+ const parentId = this.typeForm.get('sygmt_id_sygmt')?.value;
522
+ if (!parentId)
523
+ return '';
524
+ const parentType = this.types().find(t => t._id === parentId);
525
+ return parentType ? (parentType.sygmt_title || 'Unknown Parent') : 'Unknown Parent';
526
+ }
527
+ /**
528
+ * Handle adding a child type
529
+ */
530
+ onAddChild(parentType) {
531
+ console.log('🔵 onAddChild called with:', parentType);
532
+ console.log('🔵 Parent title:', parentType.sygmt_title);
533
+ // Clear edit mode and retrieved item when adding a child
534
+ this.isEditMode.set(false);
535
+ this.editingTypeId.set(null);
536
+ this.retrievedType.set(null);
537
+ // Reset form and pre-fill with parent context
538
+ this.typeForm.patchValue({
539
+ sygmt_code: '',
540
+ sygmt_title: '',
541
+ sygmt_desc: '',
542
+ sygmt_configuration: '{}',
543
+ sygmt_isactive: true,
544
+ sygmt_id_sygmt: parentType._id // Set parent type ID
545
+ });
546
+ // Store the parent type for reference (you can display this in the UI)
547
+ console.log('🔵 Ready to add child type for parent:', parentType.sygmt_title);
548
+ }
549
+ /**
550
+ * Handle dropdown item click
551
+ */
552
+ onDropdownItemClick(item, row) {
553
+ console.log('🔵 onDropdownItemClick called with:', item, row);
554
+ switch (item.id) {
555
+ case 'edit':
556
+ console.log('🔵 Calling editType with:', row);
557
+ this.editType(row);
558
+ break;
559
+ case 'addChild':
560
+ console.log('🔵 Calling onAddChild with:', row);
561
+ this.onAddChild(row);
562
+ break;
563
+ case 'general-master':
564
+ console.log('🔵 Calling navigateToGeneralMaster with:', row);
565
+ this.navigateToGeneralMaster(row);
566
+ break;
567
+ case 'toggle':
568
+ console.log('🔵 Calling toggleTypeStatus with:', row);
569
+ this.toggleTypeStatus(row);
570
+ break;
571
+ case 'delete':
572
+ console.log('🔵 Calling deleteType with:', row);
573
+ this.deleteType(row);
574
+ break;
575
+ default:
576
+ console.log('🔵 Unknown action:', item.id);
577
+ }
578
+ // Close all dropdowns after action
579
+ this.closeAllDropdowns();
580
+ }
581
+ /**
582
+ * Close all dropdowns
583
+ */
584
+ closeAllDropdowns() {
585
+ // Close all dropdowns by clicking outside
586
+ const event = new MouseEvent('click', { bubbles: true });
587
+ document.dispatchEvent(event);
588
+ }
589
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: GeneralMasterTypeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
590
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: GeneralMasterTypeComponent, isStandalone: true, selector: "cide-core-app-general-master-type", viewQueries: [{ propertyName: "typeDetailsRendererTemplate", first: true, predicate: ["typeDetailsRendererTemplate"], descendants: true, isSignal: true }, { propertyName: "typeStatusRendererTemplate", first: true, predicate: ["typeStatusRendererTemplate"], descendants: true, isSignal: true }, { propertyName: "actionsDropdownRendererTemplate", first: true, predicate: ["actionsDropdownRendererTemplate"], descendants: true, isSignal: true }], ngImport: i0, template: "<!-- General Master Type 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-4 tw-py-3 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-4 tw-h-4\">{{ isEditMode() ? 'edit' : 'add' }}</cide-ele-icon>\n <h6 class=\"tw-text-sm tw-font-medium tw-text-gray-900 tw-m-0\">{{ isEditMode() ? 'Edit Type' : 'Quick Add Type' }}</h6>\n </div>\n \n <!-- Parent Type Info (shown when adding child) -->\n @if (typeForm.get('sygmt_id_sygmt')?.value) {\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\">{{ getParentTypeDisplay() }}</span>\n </div>\n <button \n cideEleButton \n variant=\"ghost\" \n size=\"xs\" \n type=\"button\" \n (click)=\"clearParentType()\" \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]=\"typeForm\" (ngSubmit)=\"onSubmit($event)\" class=\"tw-space-y-2 tw-relative\">\n <!-- Hidden field for parent type ID -->\n <input type=\"hidden\" formControlName=\"sygmt_id_sygmt\">\n \n <!-- First Row - Basic fields -->\n <div class=\"tw-grid tw-grid-cols-1 md:tw-grid-cols-2 lg:tw-grid-cols-6 tw-gap-2\">\n <!-- Type Code -->\n <div class=\"lg:tw-col-span-1\">\n <cide-ele-input \n formControlName=\"sygmt_code\" \n label=\"Type Code*\" \n placeholder=\"Enter type code\"\n size=\"sm\"\n [maxlength]=\"40\">\n </cide-ele-input>\n </div>\n \n <!-- Type Title -->\n <div class=\"lg:tw-col-span-2\">\n <cide-ele-input \n formControlName=\"sygmt_title\" \n label=\"Type Title*\" \n placeholder=\"Enter type title\"\n size=\"sm\"\n [maxlength]=\"100\">\n </cide-ele-input>\n </div>\n \n <!-- Active Status -->\n <div class=\"lg:tw-col-span-1 tw-flex tw-items-center tw-pt-0\">\n <cide-ele-input \n formControlName=\"sygmt_isactive\"\n type=\"checkbox\"\n label=\"Active\"\n size=\"sm\">\n </cide-ele-input>\n </div>\n </div>\n <!-- Second Row - JSON Configuration and Description/Save side by side -->\n <div class=\"tw-flex tw-gap-4\">\n <!-- JSON Configuration (60% width) -->\n <div class=\"tw-w-3/5\">\n <cide-ele-json-editor \n formControlName=\"sygmt_configuration\" \n label=\"Configuration*\" \n size=\"sm\">\n </cide-ele-json-editor>\n </div>\n \n <!-- Description and Save Button (40% width) -->\n <div class=\"tw-w-2/5 tw-flex tw-flex-col tw-space-y-4\">\n <!-- Description -->\n <div class=\"tw-flex-1\">\n <cide-ele-textarea \n formControlName=\"sygmt_desc\" \n label=\"Description\" \n placeholder=\"Enter description\"\n size=\"sm\"\n [maxlength]=\"255\" \n [rows]=\"4\">\n </cide-ele-textarea>\n </div>\n \n <!-- Action Buttons -->\n <div class=\"tw-flex tw-justify-end tw-space-x-2\">\n <button \n cideEleButton \n variant=\"outline\" \n size=\"sm\" \n type=\"button\" \n (click)=\"cancelForm()\"\n [disabled]=\"loading()\"\n class=\"tw-px-4 tw-py-2\">\n Cancel\n </button>\n <button \n cideEleButton \n variant=\"primary\" \n size=\"sm\" \n type=\"submit\"\n [disabled]=\"loading()\"\n class=\"tw-px-4 tw-py-2\" [leftIcon]=\"isEditMode() ? 'edit' : 'add'\">\n {{ isEditMode() ? 'Update' : 'Save' }}\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-4 tw-py-2 tw-border-b tw-border-gray-200 tw-bg-gray-50\">\n <div class=\"tw-flex tw-flex-col sm:tw-flex-row tw-justify-between tw-items-start sm:tw-items-center tw-space-y-2 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-4 tw-h-4\">category</cide-ele-icon>\n <h5 class=\"tw-text-sm tw-font-medium tw-text-gray-900 tw-m-0\">General Master Type Management</h5>\n </div>\n\n <!-- Actions -->\n <div class=\"tw-flex tw-flex-col sm:tw-flex-row tw-items-start sm:tw-items-center tw-space-y-2 sm:tw-space-y-0 sm:tw-space-x-3\">\n\n </div>\n </div>\n\n <!-- Error Message -->\n @if (error()) {\n <div class=\"tw-mt-3 tw-p-3 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-4 tw-h-4 tw-mt-0.5 tw-flex-shrink-0\"></cide-ele-icon>\n <div class=\"tw-ml-2\">\n <h3 class=\"tw-text-xs tw-font-medium tw-text-red-800 tw-m-0\">Error</h3>\n <p class=\"tw-text-xs 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 <cide-ele-data-grid \n [config]=\"gridConfig()\" \n [templateRenderers]=\"templateRenderers()\"\n (gridEvent)=\"onGridEvent($event)\">\n </cide-ele-data-grid>\n </div>\n\n </div>\n </div>\n\n</div>\n\n<!-- Template Renderers -->\n<ng-template #typeDetailsRendererTemplate let-row=\"row\">\n <div class=\"tw-flex tw-flex-col\">\n <div class=\"tw-font-medium tw-text-gray-900\">{{ row.sygmt_title || 'N/A' }}</div>\n <div class=\"tw-text-sm tw-text-gray-500 tw-truncate tw-max-w-xs\" title=\"{{ row.sygmt_desc || 'No description' }}\">{{ row.sygmt_desc || 'No description' }}</div>\n </div>\n</ng-template>\n\n<ng-template #typeStatusRendererTemplate let-row=\"row\">\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\"\n [class.tw-bg-green-100]=\"row.sygmt_isactive\"\n [class.tw-text-green-800]=\"row.sygmt_isactive\"\n [class.tw-bg-red-100]=\"!row.sygmt_isactive\"\n [class.tw-text-red-800]=\"!row.sygmt_isactive\">\n {{ row.sygmt_isactive ? 'Active' : 'Inactive' }}\n </span>\n</ng-template>\n\n\n\n<ng-template #actionsDropdownRendererTemplate let-row=\"row\">\n <cide-ele-dropdown\n [items]=\"getActionDropdownItems(row)\"\n (itemClick)=\"onDropdownItemClick($event, row)\">\n </cide-ele-dropdown>\n</ng-template>", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: FormsModule }, { kind: "component", type: 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: CideEleJsonEditorComponent, selector: "cide-ele-json-editor", inputs: ["label", "helperText", "required", "disabled", "showCharacterCount", "config"], outputs: ["valueChange", "objectChange", "errorsChange", "validChange"] }] }); }
591
+ }
592
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: GeneralMasterTypeComponent, decorators: [{
593
+ type: Component,
594
+ args: [{ selector: 'cide-core-app-general-master-type', standalone: true, imports: [
595
+ CommonModule,
596
+ ReactiveFormsModule,
597
+ FormsModule,
598
+ CideEleDataGridComponent,
599
+ CideEleButtonComponent,
600
+ CideInputComponent,
601
+ CideSelectComponent,
602
+ CideTextareaComponent,
603
+ CideIconComponent,
604
+ CideEleDropdownComponent,
605
+ CideEleJsonEditorComponent
606
+ ], template: "<!-- General Master Type 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-4 tw-py-3 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-4 tw-h-4\">{{ isEditMode() ? 'edit' : 'add' }}</cide-ele-icon>\n <h6 class=\"tw-text-sm tw-font-medium tw-text-gray-900 tw-m-0\">{{ isEditMode() ? 'Edit Type' : 'Quick Add Type' }}</h6>\n </div>\n \n <!-- Parent Type Info (shown when adding child) -->\n @if (typeForm.get('sygmt_id_sygmt')?.value) {\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\">{{ getParentTypeDisplay() }}</span>\n </div>\n <button \n cideEleButton \n variant=\"ghost\" \n size=\"xs\" \n type=\"button\" \n (click)=\"clearParentType()\" \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]=\"typeForm\" (ngSubmit)=\"onSubmit($event)\" class=\"tw-space-y-2 tw-relative\">\n <!-- Hidden field for parent type ID -->\n <input type=\"hidden\" formControlName=\"sygmt_id_sygmt\">\n \n <!-- First Row - Basic fields -->\n <div class=\"tw-grid tw-grid-cols-1 md:tw-grid-cols-2 lg:tw-grid-cols-6 tw-gap-2\">\n <!-- Type Code -->\n <div class=\"lg:tw-col-span-1\">\n <cide-ele-input \n formControlName=\"sygmt_code\" \n label=\"Type Code*\" \n placeholder=\"Enter type code\"\n size=\"sm\"\n [maxlength]=\"40\">\n </cide-ele-input>\n </div>\n \n <!-- Type Title -->\n <div class=\"lg:tw-col-span-2\">\n <cide-ele-input \n formControlName=\"sygmt_title\" \n label=\"Type Title*\" \n placeholder=\"Enter type title\"\n size=\"sm\"\n [maxlength]=\"100\">\n </cide-ele-input>\n </div>\n \n <!-- Active Status -->\n <div class=\"lg:tw-col-span-1 tw-flex tw-items-center tw-pt-0\">\n <cide-ele-input \n formControlName=\"sygmt_isactive\"\n type=\"checkbox\"\n label=\"Active\"\n size=\"sm\">\n </cide-ele-input>\n </div>\n </div>\n <!-- Second Row - JSON Configuration and Description/Save side by side -->\n <div class=\"tw-flex tw-gap-4\">\n <!-- JSON Configuration (60% width) -->\n <div class=\"tw-w-3/5\">\n <cide-ele-json-editor \n formControlName=\"sygmt_configuration\" \n label=\"Configuration*\" \n size=\"sm\">\n </cide-ele-json-editor>\n </div>\n \n <!-- Description and Save Button (40% width) -->\n <div class=\"tw-w-2/5 tw-flex tw-flex-col tw-space-y-4\">\n <!-- Description -->\n <div class=\"tw-flex-1\">\n <cide-ele-textarea \n formControlName=\"sygmt_desc\" \n label=\"Description\" \n placeholder=\"Enter description\"\n size=\"sm\"\n [maxlength]=\"255\" \n [rows]=\"4\">\n </cide-ele-textarea>\n </div>\n \n <!-- Action Buttons -->\n <div class=\"tw-flex tw-justify-end tw-space-x-2\">\n <button \n cideEleButton \n variant=\"outline\" \n size=\"sm\" \n type=\"button\" \n (click)=\"cancelForm()\"\n [disabled]=\"loading()\"\n class=\"tw-px-4 tw-py-2\">\n Cancel\n </button>\n <button \n cideEleButton \n variant=\"primary\" \n size=\"sm\" \n type=\"submit\"\n [disabled]=\"loading()\"\n class=\"tw-px-4 tw-py-2\" [leftIcon]=\"isEditMode() ? 'edit' : 'add'\">\n {{ isEditMode() ? 'Update' : 'Save' }}\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-4 tw-py-2 tw-border-b tw-border-gray-200 tw-bg-gray-50\">\n <div class=\"tw-flex tw-flex-col sm:tw-flex-row tw-justify-between tw-items-start sm:tw-items-center tw-space-y-2 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-4 tw-h-4\">category</cide-ele-icon>\n <h5 class=\"tw-text-sm tw-font-medium tw-text-gray-900 tw-m-0\">General Master Type Management</h5>\n </div>\n\n <!-- Actions -->\n <div class=\"tw-flex tw-flex-col sm:tw-flex-row tw-items-start sm:tw-items-center tw-space-y-2 sm:tw-space-y-0 sm:tw-space-x-3\">\n\n </div>\n </div>\n\n <!-- Error Message -->\n @if (error()) {\n <div class=\"tw-mt-3 tw-p-3 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-4 tw-h-4 tw-mt-0.5 tw-flex-shrink-0\"></cide-ele-icon>\n <div class=\"tw-ml-2\">\n <h3 class=\"tw-text-xs tw-font-medium tw-text-red-800 tw-m-0\">Error</h3>\n <p class=\"tw-text-xs 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 <cide-ele-data-grid \n [config]=\"gridConfig()\" \n [templateRenderers]=\"templateRenderers()\"\n (gridEvent)=\"onGridEvent($event)\">\n </cide-ele-data-grid>\n </div>\n\n </div>\n </div>\n\n</div>\n\n<!-- Template Renderers -->\n<ng-template #typeDetailsRendererTemplate let-row=\"row\">\n <div class=\"tw-flex tw-flex-col\">\n <div class=\"tw-font-medium tw-text-gray-900\">{{ row.sygmt_title || 'N/A' }}</div>\n <div class=\"tw-text-sm tw-text-gray-500 tw-truncate tw-max-w-xs\" title=\"{{ row.sygmt_desc || 'No description' }}\">{{ row.sygmt_desc || 'No description' }}</div>\n </div>\n</ng-template>\n\n<ng-template #typeStatusRendererTemplate let-row=\"row\">\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\"\n [class.tw-bg-green-100]=\"row.sygmt_isactive\"\n [class.tw-text-green-800]=\"row.sygmt_isactive\"\n [class.tw-bg-red-100]=\"!row.sygmt_isactive\"\n [class.tw-text-red-800]=\"!row.sygmt_isactive\">\n {{ row.sygmt_isactive ? 'Active' : 'Inactive' }}\n </span>\n</ng-template>\n\n\n\n<ng-template #actionsDropdownRendererTemplate let-row=\"row\">\n <cide-ele-dropdown\n [items]=\"getActionDropdownItems(row)\"\n (itemClick)=\"onDropdownItemClick($event, row)\">\n </cide-ele-dropdown>\n</ng-template>" }]
607
+ }] });
608
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"general-master-type.component.js","sourceRoot":"","sources":["../../../../../../../../projects/cloud-ide-core/src/lib/core/general-master-management/components/general-master-type/general-master-type.component.ts","../../../../../../../../projects/cloud-ide-core/src/lib/core/general-master-management/components/general-master-type/general-master-type.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, signal, computed, viewChild, TemplateRef, DestroyRef, inject, OnInit } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { ReactiveFormsModule, NonNullableFormBuilder, FormsModule } from '@angular/forms';\nimport { Router } from '@angular/router';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { GeneralMasterTypeService } from '../../services/general-master-type.service';\nimport { CideEleDataGridComponent, CideIconComponent, CideInputComponent, CideSelectComponent, CideTextareaComponent, GridConfiguration, GridEvent, CideEleDropdownComponent, DropdownItem, CideEleJsonEditorComponent, CideEleButtonComponent } from 'cloud-ide-element';\nimport { TemplateContext } from 'cloud-ide-element';\nimport { generateStringFromObject, ICoreSygmt } from 'cloud-ide-lms-model';\n\n@Component({\n  selector: 'cide-core-app-general-master-type',\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    FormsModule,\n    CideEleDataGridComponent,\n    CideEleButtonComponent,\n    CideInputComponent,\n    CideSelectComponent,\n    CideTextareaComponent,\n    CideIconComponent,\n    CideEleDropdownComponent,\n    CideEleJsonEditorComponent\n  ],\n  templateUrl: './general-master-type.component.html',\n  styleUrls: []\n})\nexport class GeneralMasterTypeComponent implements OnInit {\n  // Dependency injection\n  private destroyRef = inject(DestroyRef);\n  private typeService = inject(GeneralMasterTypeService);\n  private fb = inject(NonNullableFormBuilder);\n  private router = inject(Router);\n\n  // Modern ViewChild signals for template renderers (Angular 20 approach)\n  typeDetailsRendererTemplate = viewChild.required<TemplateRef<TemplateContext>>('typeDetailsRendererTemplate');\n  typeStatusRendererTemplate = viewChild.required<TemplateRef<TemplateContext>>('typeStatusRendererTemplate');\n  actionsDropdownRendererTemplate = viewChild.required<TemplateRef<TemplateContext>>('actionsDropdownRendererTemplate');\n\n  // Make Math available in template\n  Math = Math;\n\n  // Signals for reactive state management\n  types = signal<ICoreSygmt[]>([]);\n  loading = signal(false);\n  error = signal<string | null>(null);\n  selectedItems = signal<string[]>([]);\n  searchTerm = signal('');\n\n\n  // Form state\n  isEditMode = signal(false);\n  editingTypeId = signal<string | null>(null);\n  retrievedType = signal<ICoreSygmt | null>(null);\n\n  // Pagination signals\n  currentPage = signal(1);\n  pageSize = signal(10);\n  totalItems = signal(0);\n\n  // Modern reactive forms with signals\n  typeForm = this.fb.group({\n    sygmt_code: [''],\n    sygmt_title: [''],\n    sygmt_desc: [''],\n    sygmt_configuration: ['{}'],\n    sygmt_isactive: [true],\n    sygmt_id_sygmt: [''] // Parent type ID for child types\n  });\n\n  // Computed values\n\n  isFormDirty = computed(() => this.typeForm.dirty);\n\n\n\n  // Grid configuration signal\n  gridConfig = signal<GridConfiguration<ICoreSygmt>>({\n    id: 'type-list-grid',\n    title: '',\n    subtitle: '',\n    columns: [\n      {\n        key: 'details',\n        header: 'Type Details',\n        type: 'custom',\n        width: 'auto',\n        truncate: true,\n        align: 'left',\n        renderer: 'typeDetailsRenderer'\n      },\n      {\n        key: 'sygmt_code',\n        header: 'Type Code',\n        type: 'text',\n        width: '150px',\n        truncate: true,\n        align: 'left'\n      },\n      {\n        key: 'sygmt_isactive',\n        header: 'Status',\n        type: 'custom',\n        width: '100px',\n        truncate: false,\n        align: 'center',\n        renderer: 'typeStatusRenderer'\n      },\n      {\n        key: 'actions',\n        header: '',\n        type: 'custom',\n        width: '150px',\n        truncate: false,\n        align: 'center',\n        renderer: 'actionsDropdownRenderer'\n      }\n    ],\n    data: [],\n    trackBy: '_id',\n    tree: {\n      enabled: true,\n      foreignKey: 'sygmt_id_sygmt',\n      primaryKey: '_id'\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 types...',\n      searchableColumns: ['sygmt_title', 'sygmt_desc', 'sygmt_code'],\n      debounceMs: 300\n    },\n    loading: {\n      useDefer: true,\n      skeletonRows: 5,\n      showOverlay: false\n    },\n    scroll: {\n      enabled: true,\n      maxHeight: '',\n      minHeight: '',\n      stickyHeader: true,\n      virtualScroll: false,\n      rowHeight: 40\n    },\n    responsive: true,\n    striped: false,\n    bordered: true,\n    compact: true,\n    tableClass: 'tw-table-fixed tw-w-full tw-rounded-none'\n  });\n\n  // Action handlers for grid\n  actionHandlers = {\n    onEdit: (item: ICoreSygmt) => this.editType(item),\n    onDelete: (item: ICoreSygmt) => this.deleteType(item),\n    onToggleStatus: (item: ICoreSygmt) => this.toggleTypeStatus(item)\n  };\n\n  ngOnInit(): void {\n    this.initializeComponent();\n    \n    // Add form submission debugging\n    this.typeForm.valueChanges.subscribe(value => {\n      console.log('🔵 Form value changed:', value);\n    });\n    \n    this.typeForm.statusChanges.subscribe(status => {\n      console.log('🔵 Form status changed:', status);\n    });\n  }\n\n  /**\n   * Initialize component\n   */\n  private initializeComponent(): void {\n    this.loadTypes();\n    this.setupFormSubscriptions();\n  }\n\n  /**\n   * Load types from API\n   */\n  loadTypes(): void {\n    this.loading.set(true);\n    this.error.set(null);\n\n    const request = {};\n\n    this.typeService.getTypeList(request)\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe({\n        next: (response) => {\n          if (response.success) {\n            this.types.set(response.data || []);\n            this.totalItems.set(response.total || 0);\n            this.updateGridData();\n          } else {\n            this.error.set(response.message || 'Failed to load types');\n          }\n          this.loading.set(false);\n        },\n        error: (error) => {\n          console.error('Error loading types:', error);\n          this.error.set('Failed to load types. Please try again.');\n          this.loading.set(false);\n        }\n      });\n  }\n\n\n\n  /**\n   * Setup form subscriptions\n   */\n  private setupFormSubscriptions(): void {\n    // Watch for form changes to enable/disable save button\n    this.typeForm.valueChanges\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe(() => {\n        // Form validation is handled by computed signals\n      });\n  }\n\n  /**\n   * Update grid data\n   */\n  private updateGridData(): void {\n    this.gridConfig.update(config => ({\n      ...config,\n      data: this.types()\n    }));\n  }\n\n  // Computed template renderers for grid\n  templateRenderers = computed((): Record<string, TemplateRef<TemplateContext>> => ({\n    typeDetailsRenderer: this.typeDetailsRendererTemplate(),\n    typeStatusRenderer: this.typeStatusRendererTemplate(),\n    actionsDropdownRenderer: this.actionsDropdownRendererTemplate()\n  }));\n\n  /**\n   * Handle grid events\n   */\n  onGridEvent(event: GridEvent<ICoreSygmt>): void {\n    switch (event.type) {\n      case 'pageChange':\n        if (event.data && typeof event.data === 'object' && 'pageIndex' in event.data && 'pageSize' in event.data) {\n          this.currentPage.set(event.data['pageIndex'] as number);\n          this.pageSize.set(event.data['pageSize'] as number);\n          this.loadTypes();\n        }\n        break;\n      case 'search':\n        if (event.data && typeof event.data === 'string') {\n          this.searchTerm.set(event.data);\n          this.currentPage.set(1);\n          this.loadTypes();\n        }\n        break;\n      case 'refresh':\n        this.loadTypes();\n        break;\n      case 'action':\n        // Handle action events if needed\n        console.log('Action event:', event);\n        break;\n      case 'rowClick':\n        // Handle row click events if needed\n        console.log('Row click event:', event);\n        break;\n      case 'sort':\n        // Handle sort events if needed\n        console.log('Sort event:', event);\n        break;\n      case 'export':\n        // Handle export events if needed\n        console.log('Export event:', event);\n        break;\n      case 'rowReorder':\n        // Handle row reorder events if needed\n        console.log('Row reorder event:', event);\n        break;\n    }\n  }\n\n  /**\n   * Create new type\n   */\n  createType(): void {\n    if (!this.typeForm.valid) {\n      this.markFormAsTouched();\n      return;\n    }\n\n    const formValue = this.typeForm.getRawValue();\n    const newType: ICoreSygmt = {\n      _id: '', // Empty _id for create operation\n      sygmt_code: formValue.sygmt_code,\n      sygmt_title: formValue.sygmt_title,\n      sygmt_desc: formValue.sygmt_desc,\n      sygmt_configuration: JSON.parse(formValue.sygmt_configuration),\n      sygmt_isactive: formValue.sygmt_isactive\n    };\n\n    this.loading.set(true);\n    this.typeService.saveType(newType)\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe({\n        next: (response) => {\n          if (response.success) {\n            this.cancelForm();\n            this.loadTypes();\n            console.log('✅ Type created successfully');\n          } else {\n            console.error('❌ Failed to create type:', response.message);\n          }\n          this.loading.set(false);\n        },\n        error: (error) => {\n          console.error('Error creating type:', error);\n          console.error('❌ Failed to create type. Please try again.');\n          this.loading.set(false);\n        }\n      });\n  }\n\n  /**\n   * Update existing type\n   */\n  updateType(): void {\n    console.log('🔵 updateType called');\n    console.log('🔵 form valid:', this.typeForm.valid);\n    console.log('🔵 editingTypeId:', this.editingTypeId());\n    \n    if (!this.typeForm.valid || !this.editingTypeId()) {\n      console.log('🔵 Form validation failed or no editing ID');\n      this.markFormAsTouched();\n      return;\n    }\n\n    const formValue = this.typeForm.getRawValue();\n    const updatedType: ICoreSygmt = {\n      _id: this.editingTypeId()!, // Include _id for update operation\n      sygmt_code: formValue.sygmt_code,\n      sygmt_title: formValue.sygmt_title,\n      sygmt_desc: formValue.sygmt_desc,\n      sygmt_configuration: JSON.parse(formValue.sygmt_configuration || '{}'),\n      sygmt_isactive: formValue.sygmt_isactive\n    };\n\n    console.log('🔵 Making API call to update type:', updatedType);\n    this.loading.set(true);\n    this.typeService.saveType(updatedType)\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe({\n        next: (response) => {\n          console.log('🔵 API response received:', response);\n          if (response.success) {\n            this.cancelForm();\n            this.loadTypes();\n            console.log('✅ Type updated successfully');\n          } else {\n            console.error('❌ Failed to update type:', response.message);\n          }\n          this.loading.set(false);\n        },\n        error: (error) => {\n          console.error('🔵 API error:', error);\n          console.error('❌ Failed to update type. Please try again.');\n          this.loading.set(false);\n        }\n      });\n  }\n\n  /**\n   * Edit type\n   */\n  editType(type: ICoreSygmt): void {\n    this.isEditMode.set(true);\n    this.editingTypeId.set(type._id || \"\");\n    this.retrievedType.set(type);\n\n    this.typeForm.patchValue({  \n      sygmt_code: type.sygmt_code,\n      sygmt_title: type.sygmt_title,\n      sygmt_desc: type.sygmt_desc,\n      sygmt_configuration: JSON.stringify(type.sygmt_configuration, null, 2),\n      sygmt_isactive: type.sygmt_isactive\n    });\n\n    this.typeForm.markAsPristine();\n  }\n\n  /**\n   * Delete type\n   */\n  deleteType(type: ICoreSygmt): void {\n    if (confirm(`Are you sure you want to delete the type \"${type.sygmt_title}\"?`)) {\n      this.loading.set(true);\n      this.typeService.deleteType(type._id || \"\")\n        .pipe(takeUntilDestroyed(this.destroyRef))\n        .subscribe({\n          next: (response) => {\n            if (response.success) {\n                          this.loadTypes();\n            console.log('✅ Type deleted successfully');\n            } else {\n              console.error('❌ Failed to delete type:', response.message);\n            }\n            this.loading.set(false);\n          },\n          error: (error) => {\n            console.error('Error deleting type:', error);\n            console.error('❌ Failed to delete type. Please try again.');\n            this.loading.set(false);\n          }\n        });\n    }\n  }\n\n  /**\n   * Toggle type status\n   */\n  toggleTypeStatus(type: ICoreSygmt): void {\n    this.loading.set(true);\n    this.typeService.toggleTypeStatus({ sygmt_id: type._id || \"\" })\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe({\n        next: (response) => {\n          if (response.success) {\n            this.loadTypes();\n            console.log(`✅ Type ${type.sygmt_isactive ? 'deactivated' : 'activated'} successfully`);\n          } else {\n            console.error('❌ Failed to toggle type status:', response.message);\n          }\n          this.loading.set(false);\n        },\n        error: (error) => {\n          console.error('Error toggling type status:', error);\n          console.error('❌ Failed to toggle type status. Please try again.');\n          this.loading.set(false);\n        }\n      });\n  }\n\n  /**\n   * Navigate to general master management for this type\n   */\n  navigateToGeneralMaster(type: ICoreSygmt): void {\n    const payload = generateStringFromObject({\n      sygmt_id: type._id,\n      sygmt_title: type.sygmt_title\n    });\n    this.router.navigate(['control-panel' ,'general_master_entry', payload]);\n  }\n\n  /**\n   * Handle form submission event\n   */\n  onSubmit(event: Event): void {\n    event.preventDefault();\n    console.log('🔵 Form onSubmit event triggered');\n    this.saveType();\n  }\n\n  /**\n   * Save type (create or update)\n   */\n  saveType(): void {\n    console.log('🔵 saveType called');\n    console.log('🔵 isEditMode:', this.isEditMode());\n    console.log('🔵 editingTypeId:', this.editingTypeId());\n    console.log('🔵 form valid:', this.typeForm.valid);\n    console.log('🔵 form values:', this.typeForm.getRawValue());\n    console.log('🔵 form dirty:', this.typeForm.dirty);\n    console.log('🔵 form pristine:', this.typeForm.pristine);\n    console.log('🔵 form touched:', this.typeForm.touched);\n    \n    if (this.isEditMode()) {\n      console.log('🔵 Calling updateType');\n      this.updateType();\n    } else {\n      console.log('🔵 Calling createType');\n      this.createType();\n    }\n  }\n\n  /**\n   * Cancel form (reset to defaults and exit edit mode)\n   */\n  cancelForm(): void {\n    this.typeForm.reset({\n      sygmt_code: '',\n      sygmt_title: '',\n      sygmt_desc: '',\n      sygmt_configuration: '{}',\n      sygmt_isactive: true,\n      sygmt_id_sygmt: '' // Clear parent type ID\n    });\n    this.isEditMode.set(false);\n    this.editingTypeId.set(null);\n    this.retrievedType.set(null);\n    this.typeForm.markAsPristine();\n    this.typeForm.markAsUntouched();\n  }\n\n  /**\n   * Mark form as touched to trigger validation display\n   */\n  private markFormAsTouched(): void {\n    Object.keys(this.typeForm.controls).forEach(key => {\n      const control = this.typeForm.get(key);\n      control?.markAsTouched();\n    });\n  }\n\n  /**\n   * Clear parent type relationship\n   */\n  clearParentType(): void {\n    this.typeForm.patchValue({\n      sygmt_id_sygmt: ''\n    });\n    console.log('🔵 Parent type relationship cleared');\n  }\n\n  /**\n   * Get dropdown items for actions\n   */\n  getActionDropdownItems(type: ICoreSygmt): DropdownItem[] {\n    return [\n      {\n        id: 'edit',\n        label: 'Edit',\n        icon: 'edit',\n        disabled: false\n      },\n      {\n        id: 'addChild',\n        label: 'Add Child',\n        icon: 'add',\n        disabled: false\n      },\n      {\n        id: 'general-master',\n        label: 'General Master',\n        icon: 'list',\n        disabled: false\n      },\n      {\n        id: 'toggle',\n        label: type.sygmt_isactive ? 'Deactivate' : 'Activate',\n        icon: type.sygmt_isactive ? 'block' : 'check_circle',\n        disabled: false\n      },\n      {\n        id: 'delete',\n        label: 'Delete',\n        icon: 'delete',\n        disabled: false\n      }\n    ];\n  }\n\n  /**\n   * Get parent type display name\n   */\n  getParentTypeDisplay(): string {\n    const parentId = this.typeForm.get('sygmt_id_sygmt')?.value;\n    if (!parentId) return '';\n    \n    const parentType = this.types().find(t => t._id === parentId);\n    return parentType ? (parentType.sygmt_title || 'Unknown Parent') : 'Unknown Parent';\n  }\n\n  /**\n   * Handle adding a child type\n   */\n  onAddChild(parentType: ICoreSygmt): void {\n    console.log('🔵 onAddChild called with:', parentType);\n    console.log('🔵 Parent title:', parentType.sygmt_title);\n\n    // Clear edit mode and retrieved item when adding a child\n    this.isEditMode.set(false);\n    this.editingTypeId.set(null);\n    this.retrievedType.set(null);\n\n    // Reset form and pre-fill with parent context\n    this.typeForm.patchValue({\n      sygmt_code: '',\n      sygmt_title: '',\n      sygmt_desc: '',\n      sygmt_configuration: '{}',\n      sygmt_isactive: true,\n      sygmt_id_sygmt: parentType._id // Set parent type ID\n    });\n\n    // Store the parent type for reference (you can display this in the UI)\n    console.log('🔵 Ready to add child type for parent:', parentType.sygmt_title);\n  }\n\n  /**\n   * Handle dropdown item click\n   */\n  onDropdownItemClick(item: DropdownItem, row: ICoreSygmt): void {\n    console.log('🔵 onDropdownItemClick called with:', item, row);\n\n    switch (item.id) {\n      case 'edit':\n        console.log('🔵 Calling editType with:', row);\n        this.editType(row);\n        break;\n      case 'addChild':\n        console.log('🔵 Calling onAddChild with:', row);\n        this.onAddChild(row);\n        break;\n      case 'general-master':\n        console.log('🔵 Calling navigateToGeneralMaster with:', row);\n        this.navigateToGeneralMaster(row);\n        break;\n      case 'toggle':\n        console.log('🔵 Calling toggleTypeStatus with:', row);\n        this.toggleTypeStatus(row);\n        break;\n      case 'delete':\n        console.log('🔵 Calling deleteType with:', row);\n        this.deleteType(row);\n        break;\n      default:\n        console.log('🔵 Unknown action:', item.id);\n    }\n\n    // Close all dropdowns after action\n    this.closeAllDropdowns();\n  }\n\n\n\n\n\n  /**\n   * Close all dropdowns\n   */\n  private closeAllDropdowns(): void {\n    // Close all dropdowns by clicking outside\n    const event = new MouseEvent('click', { bubbles: true });\n    document.dispatchEvent(event);\n  }\n} ","<!-- General Master Type 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-4 tw-py-3 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-4 tw-h-4\">{{ isEditMode() ? 'edit' : 'add' }}</cide-ele-icon>\n          <h6 class=\"tw-text-sm tw-font-medium tw-text-gray-900 tw-m-0\">{{ isEditMode() ? 'Edit Type' : 'Quick Add Type' }}</h6>\n        </div>\n        \n        <!-- Parent Type Info (shown when adding child) -->\n        @if (typeForm.get('sygmt_id_sygmt')?.value) {\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\">{{ getParentTypeDisplay() }}</span>\n            </div>\n            <button \n              cideEleButton \n              variant=\"ghost\" \n              size=\"xs\" \n              type=\"button\" \n              (click)=\"clearParentType()\" \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]=\"typeForm\" (ngSubmit)=\"onSubmit($event)\" class=\"tw-space-y-2 tw-relative\">\n        <!-- Hidden field for parent type ID -->\n        <input type=\"hidden\" formControlName=\"sygmt_id_sygmt\">\n        \n        <!-- First Row - Basic fields -->\n        <div class=\"tw-grid tw-grid-cols-1 md:tw-grid-cols-2 lg:tw-grid-cols-6 tw-gap-2\">\n          <!-- Type Code -->\n          <div class=\"lg:tw-col-span-1\">\n            <cide-ele-input \n              formControlName=\"sygmt_code\" \n              label=\"Type Code*\" \n              placeholder=\"Enter type code\"\n              size=\"sm\"\n              [maxlength]=\"40\">\n            </cide-ele-input>\n          </div>\n          \n          <!-- Type Title -->\n          <div class=\"lg:tw-col-span-2\">\n            <cide-ele-input \n              formControlName=\"sygmt_title\" \n              label=\"Type Title*\" \n              placeholder=\"Enter type title\"\n              size=\"sm\"\n              [maxlength]=\"100\">\n            </cide-ele-input>\n          </div>\n          \n          <!-- Active Status -->\n          <div class=\"lg:tw-col-span-1 tw-flex tw-items-center tw-pt-0\">\n            <cide-ele-input \n              formControlName=\"sygmt_isactive\"\n              type=\"checkbox\"\n              label=\"Active\"\n              size=\"sm\">\n            </cide-ele-input>\n          </div>\n        </div>\n        <!-- Second Row - JSON Configuration and Description/Save side by side -->\n        <div class=\"tw-flex tw-gap-4\">\n          <!-- JSON Configuration (60% width) -->\n          <div class=\"tw-w-3/5\">\n            <cide-ele-json-editor \n              formControlName=\"sygmt_configuration\" \n              label=\"Configuration*\" \n              size=\"sm\">\n            </cide-ele-json-editor>\n          </div>\n          \n          <!-- Description and Save Button (40% width) -->\n          <div class=\"tw-w-2/5 tw-flex tw-flex-col tw-space-y-4\">\n            <!-- Description -->\n            <div class=\"tw-flex-1\">\n              <cide-ele-textarea \n                formControlName=\"sygmt_desc\" \n                label=\"Description\" \n                placeholder=\"Enter description\"\n                size=\"sm\"\n                [maxlength]=\"255\" \n                [rows]=\"4\">\n              </cide-ele-textarea>\n            </div>\n            \n            <!-- Action Buttons -->\n            <div class=\"tw-flex tw-justify-end tw-space-x-2\">\n              <button \n                cideEleButton \n                variant=\"outline\" \n                size=\"sm\" \n                type=\"button\" \n                (click)=\"cancelForm()\"\n                [disabled]=\"loading()\"\n                class=\"tw-px-4 tw-py-2\">\n                Cancel\n              </button>\n              <button \n                cideEleButton \n                variant=\"primary\" \n                size=\"sm\" \n                type=\"submit\"\n                [disabled]=\"loading()\"\n                class=\"tw-px-4 tw-py-2\" [leftIcon]=\"isEditMode() ? 'edit' : 'add'\">\n                {{ isEditMode() ? 'Update' : 'Save' }}\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-4 tw-py-2 tw-border-b tw-border-gray-200 tw-bg-gray-50\">\n      <div class=\"tw-flex tw-flex-col sm:tw-flex-row tw-justify-between tw-items-start sm:tw-items-center tw-space-y-2 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-4 tw-h-4\">category</cide-ele-icon>\n          <h5 class=\"tw-text-sm tw-font-medium tw-text-gray-900 tw-m-0\">General Master Type Management</h5>\n        </div>\n\n        <!-- Actions -->\n        <div class=\"tw-flex tw-flex-col sm:tw-flex-row tw-items-start sm:tw-items-center tw-space-y-2 sm:tw-space-y-0 sm:tw-space-x-3\">\n\n        </div>\n      </div>\n\n      <!-- Error Message -->\n      @if (error()) {\n        <div class=\"tw-mt-3 tw-p-3 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-4 tw-h-4 tw-mt-0.5 tw-flex-shrink-0\"></cide-ele-icon>\n            <div class=\"tw-ml-2\">\n              <h3 class=\"tw-text-xs tw-font-medium tw-text-red-800 tw-m-0\">Error</h3>\n              <p class=\"tw-text-xs 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        <cide-ele-data-grid \n          [config]=\"gridConfig()\" \n          [templateRenderers]=\"templateRenderers()\"\n          (gridEvent)=\"onGridEvent($event)\">\n        </cide-ele-data-grid>\n      </div>\n\n    </div>\n  </div>\n\n</div>\n\n<!-- Template Renderers -->\n<ng-template #typeDetailsRendererTemplate let-row=\"row\">\n  <div class=\"tw-flex tw-flex-col\">\n    <div class=\"tw-font-medium tw-text-gray-900\">{{ row.sygmt_title || 'N/A' }}</div>\n    <div class=\"tw-text-sm tw-text-gray-500 tw-truncate tw-max-w-xs\" title=\"{{ row.sygmt_desc || 'No description' }}\">{{ row.sygmt_desc || 'No description' }}</div>\n  </div>\n</ng-template>\n\n<ng-template #typeStatusRendererTemplate let-row=\"row\">\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\"\n        [class.tw-bg-green-100]=\"row.sygmt_isactive\"\n        [class.tw-text-green-800]=\"row.sygmt_isactive\"\n        [class.tw-bg-red-100]=\"!row.sygmt_isactive\"\n        [class.tw-text-red-800]=\"!row.sygmt_isactive\">\n    {{ row.sygmt_isactive ? 'Active' : 'Inactive' }}\n  </span>\n</ng-template>\n\n\n\n<ng-template #actionsDropdownRendererTemplate let-row=\"row\">\n  <cide-ele-dropdown\n    [items]=\"getActionDropdownItems(row)\"\n    (itemClick)=\"onDropdownItemClick($event, row)\">\n  </cide-ele-dropdown>\n</ng-template>"]}