@colijnit/corecomponents_v12 258.1.8 → 258.1.10

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.
@@ -16,7 +16,7 @@ export class ExcelExportService {
16
16
  exportData = data.map(item => {
17
17
  const newItem = {};
18
18
  columns.forEach(col => {
19
- newItem[col.header] = this.getNestedValue(item, col.key);
19
+ newItem[col.header] = this.getFlatValue(item, col.key);
20
20
  });
21
21
  return newItem;
22
22
  });
@@ -88,6 +88,9 @@ export class ExcelExportService {
88
88
  return current && current[key] !== undefined ? current[key] : '';
89
89
  }, obj);
90
90
  }
91
+ getFlatValue(obj, key) {
92
+ return obj && obj[key] !== undefined ? obj[key] : '';
93
+ }
91
94
  /**
92
95
  * Format date for Excel export
93
96
  * @param date - Date to format
@@ -122,4 +125,4 @@ ExcelExportService.decorators = [
122
125
  providedIn: 'root'
123
126
  },] }
124
127
  ];
125
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"excel-export.service.js","sourceRoot":"","sources":["../../../../../projects/corecomponents/src/lib/service/excel-export.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable} from '@angular/core';\r\nimport * as XLSX from 'xlsx';\r\n\r\nexport interface ExportColumn {\r\n  key: string;\r\n  header: string;\r\n  width?: number;\r\n}\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class ExcelExportService {\r\n\r\n  /**\r\n   * Export data to Excel file\r\n   * @param data - Array of objects to export\r\n   * @param columns - Column configuration (optional)\r\n   * @param fileName - Name of the exported file\r\n   * @param sheetName - Name of the Excel sheet\r\n   */\r\n  exportToExcel(\r\n    data: any[],\r\n    columns?: ExportColumn[],\r\n    fileName: string = 'export',\r\n    sheetName: string = 'Sheet1'\r\n  ): void {\r\n\r\n    // If columns are specified, transform data to match column structure\r\n    let exportData = data;\r\n    if (columns && columns.length > 0) {\r\n      exportData = data.map(item => {\r\n        const newItem: any = {};\r\n        columns.forEach(col => {\r\n          newItem[col.header] = this.getNestedValue(item, col.key);\r\n        });\r\n        return newItem;\r\n      });\r\n    }\r\n\r\n    // Create workbook and worksheet\r\n    const wb: XLSX.WorkBook = XLSX.utils.book_new();\r\n    const ws: XLSX.WorkSheet = XLSX.utils.json_to_sheet(exportData);\r\n\r\n    // Set column widths if specified\r\n    if (columns && columns.some(col => col.width)) {\r\n      const colWidths = columns.map(col => ({wch: col.width || 20}));\r\n      ws['!cols'] = colWidths;\r\n    }\r\n\r\n    // Add worksheet to workbook\r\n    XLSX.utils.book_append_sheet(wb, ws, sheetName);\r\n\r\n    // Save file\r\n    XLSX.writeFile(wb, `${fileName}.xlsx`);\r\n  }\r\n\r\n  /**\r\n   * Export multiple sheets to one Excel file\r\n   * @param sheets - Array of sheet data\r\n   * @param fileName - Name of the exported file\r\n   */\r\n  exportMultipleSheets(\r\n    sheets: Array<{\r\n      data: any[];\r\n      columns?: ExportColumn[];\r\n      sheetName: string;\r\n    }>,\r\n    fileName: string = 'multi-sheet-export'\r\n  ): void {\r\n    const wb: XLSX.WorkBook = XLSX.utils.book_new();\r\n\r\n    sheets.forEach(sheet => {\r\n      let exportData = sheet.data;\r\n\r\n      if (sheet.columns && sheet.columns.length > 0) {\r\n        exportData = sheet.data.map(item => {\r\n          const newItem: any = {};\r\n          sheet.columns!.forEach(col => {\r\n            newItem[col.header] = this.getNestedValue(item, col.key);\r\n          });\r\n          return newItem;\r\n        });\r\n      }\r\n\r\n      const ws: XLSX.WorkSheet = XLSX.utils.json_to_sheet(exportData);\r\n\r\n      if (sheet.columns && sheet.columns.some(col => col.width)) {\r\n        const colWidths = sheet.columns.map(col => ({wch: col.width || 20}));\r\n        ws['!cols'] = colWidths;\r\n      }\r\n\r\n      XLSX.utils.book_append_sheet(wb, ws, sheet.sheetName);\r\n    });\r\n\r\n    XLSX.writeFile(wb, `${fileName}.xlsx`);\r\n  }\r\n\r\n  /**\r\n   * Export HTML table to Excel\r\n   * @param tableId - ID of the HTML table element\r\n   * @param fileName - Name of the exported file\r\n   * @param sheetName - Name of the Excel sheet\r\n   */\r\n  exportTableToExcel(\r\n    tableId: string,\r\n    fileName: string = 'table-export',\r\n    sheetName: string = 'Sheet1'\r\n  ): void {\r\n    const table = document.getElementById(tableId);\r\n    if (!table) {\r\n      console.error(`Table with ID '${tableId}' not found`);\r\n      return;\r\n    }\r\n\r\n    const wb: XLSX.WorkBook = XLSX.utils.book_new();\r\n    const ws: XLSX.WorkSheet = XLSX.utils.table_to_sheet(table);\r\n\r\n    XLSX.utils.book_append_sheet(wb, ws, sheetName);\r\n    XLSX.writeFile(wb, `${fileName}.xlsx`);\r\n  }\r\n\r\n  /**\r\n   * Get nested object value using dot notation\r\n   * @param obj - Object to search in\r\n   * @param path - Dot notation path (e.g., 'user.address.city')\r\n   */\r\n  private getNestedValue(obj: any, path: string): any {\r\n    return path.split('.').reduce((current, key) => {\r\n      return current && current[key] !== undefined ? current[key] : '';\r\n    }, obj);\r\n  }\r\n\r\n  /**\r\n   * Format date for Excel export\r\n   * @param date - Date to format\r\n   * @param format - Format string (default: 'MM/DD/YYYY')\r\n   */\r\n  formatDateForExport(date: Date | string, format: string = 'MM/DD/YYYY'): string {\r\n    if (!date) {\r\n      return '';\r\n    }\r\n\r\n    const d = new Date(date);\r\n    if (isNaN(d.getTime())) {\r\n      return '';\r\n    }\r\n\r\n    const month = (d.getMonth() + 1).toString().padStart(2, '0');\r\n    const day = d.getDate().toString().padStart(2, '0');\r\n    const year = d.getFullYear();\r\n\r\n    switch (format) {\r\n      case 'MM/DD/YYYY':\r\n        return `${month}/${day}/${year}`;\r\n      case 'DD/MM/YYYY':\r\n        return `${day}/${month}/${year}`;\r\n      case 'YYYY-MM-DD':\r\n        return `${year}-${month}-${day}`;\r\n      default:\r\n        return d.toLocaleDateString();\r\n    }\r\n  }\r\n}\r\n"]}
128
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"excel-export.service.js","sourceRoot":"","sources":["../../../../../projects/corecomponents/src/lib/service/excel-export.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable} from '@angular/core';\r\nimport * as XLSX from 'xlsx';\r\n\r\nexport interface ExportColumn {\r\n  key: string;\r\n  header: string;\r\n  width?: number;\r\n}\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class ExcelExportService {\r\n\r\n  /**\r\n   * Export data to Excel file\r\n   * @param data - Array of objects to export\r\n   * @param columns - Column configuration (optional)\r\n   * @param fileName - Name of the exported file\r\n   * @param sheetName - Name of the Excel sheet\r\n   */\r\n  exportToExcel(\r\n    data: any[],\r\n    columns?: ExportColumn[],\r\n    fileName: string = 'export',\r\n    sheetName: string = 'Sheet1'\r\n  ): void {\r\n    // If columns are specified, transform data to match column structure\r\n    let exportData = data;\r\n    if (columns && columns.length > 0) {\r\n      exportData = data.map(item => {\r\n        const newItem: any = {};\r\n        columns.forEach(col => {\r\n          newItem[col.header] = this.getFlatValue(item, col.key);\r\n        });\r\n        return newItem;\r\n      });\r\n    }\r\n\r\n    // Create workbook and worksheet\r\n    const wb: XLSX.WorkBook = XLSX.utils.book_new();\r\n    const ws: XLSX.WorkSheet = XLSX.utils.json_to_sheet(exportData);\r\n\r\n    // Set column widths if specified\r\n    if (columns && columns.some(col => col.width)) {\r\n      const colWidths = columns.map(col => ({wch: col.width || 20}));\r\n      ws['!cols'] = colWidths;\r\n    }\r\n\r\n    // Add worksheet to workbook\r\n    XLSX.utils.book_append_sheet(wb, ws, sheetName);\r\n\r\n    // Save file\r\n    XLSX.writeFile(wb, `${fileName}.xlsx`);\r\n  }\r\n\r\n  /**\r\n   * Export multiple sheets to one Excel file\r\n   * @param sheets - Array of sheet data\r\n   * @param fileName - Name of the exported file\r\n   */\r\n  exportMultipleSheets(\r\n    sheets: Array<{\r\n      data: any[];\r\n      columns?: ExportColumn[];\r\n      sheetName: string;\r\n    }>,\r\n    fileName: string = 'multi-sheet-export'\r\n  ): void {\r\n    const wb: XLSX.WorkBook = XLSX.utils.book_new();\r\n\r\n    sheets.forEach(sheet => {\r\n      let exportData = sheet.data;\r\n\r\n      if (sheet.columns && sheet.columns.length > 0) {\r\n        exportData = sheet.data.map(item => {\r\n          const newItem: any = {};\r\n          sheet.columns!.forEach(col => {\r\n            newItem[col.header] = this.getNestedValue(item, col.key);\r\n          });\r\n          return newItem;\r\n        });\r\n      }\r\n\r\n      const ws: XLSX.WorkSheet = XLSX.utils.json_to_sheet(exportData);\r\n\r\n      if (sheet.columns && sheet.columns.some(col => col.width)) {\r\n        const colWidths = sheet.columns.map(col => ({wch: col.width || 20}));\r\n        ws['!cols'] = colWidths;\r\n      }\r\n\r\n      XLSX.utils.book_append_sheet(wb, ws, sheet.sheetName);\r\n    });\r\n\r\n    XLSX.writeFile(wb, `${fileName}.xlsx`);\r\n  }\r\n\r\n  /**\r\n   * Export HTML table to Excel\r\n   * @param tableId - ID of the HTML table element\r\n   * @param fileName - Name of the exported file\r\n   * @param sheetName - Name of the Excel sheet\r\n   */\r\n  exportTableToExcel(\r\n    tableId: string,\r\n    fileName: string = 'table-export',\r\n    sheetName: string = 'Sheet1'\r\n  ): void {\r\n    const table = document.getElementById(tableId);\r\n    if (!table) {\r\n      console.error(`Table with ID '${tableId}' not found`);\r\n      return;\r\n    }\r\n\r\n    const wb: XLSX.WorkBook = XLSX.utils.book_new();\r\n    const ws: XLSX.WorkSheet = XLSX.utils.table_to_sheet(table);\r\n\r\n    XLSX.utils.book_append_sheet(wb, ws, sheetName);\r\n    XLSX.writeFile(wb, `${fileName}.xlsx`);\r\n  }\r\n\r\n  /**\r\n   * Get nested object value using dot notation\r\n   * @param obj - Object to search in\r\n   * @param path - Dot notation path (e.g., 'user.address.city')\r\n   */\r\n  private getNestedValue(obj: any, path: string): any {\r\n    return path.split('.').reduce((current, key) => {\r\n      return current && current[key] !== undefined ? current[key] : '';\r\n    }, obj);\r\n  }\r\n\r\n  private getFlatValue(obj: any, key: string): any {\r\n    return obj && obj[key] !== undefined ? obj[key] : '';\r\n  }\r\n\r\n  /**\r\n   * Format date for Excel export\r\n   * @param date - Date to format\r\n   * @param format - Format string (default: 'MM/DD/YYYY')\r\n   */\r\n  formatDateForExport(date: Date | string, format: string = 'MM/DD/YYYY'): string {\r\n    if (!date) {\r\n      return '';\r\n    }\r\n\r\n    const d = new Date(date);\r\n    if (isNaN(d.getTime())) {\r\n      return '';\r\n    }\r\n\r\n    const month = (d.getMonth() + 1).toString().padStart(2, '0');\r\n    const day = d.getDate().toString().padStart(2, '0');\r\n    const year = d.getFullYear();\r\n\r\n    switch (format) {\r\n      case 'MM/DD/YYYY':\r\n        return `${month}/${day}/${year}`;\r\n      case 'DD/MM/YYYY':\r\n        return `${day}/${month}/${year}`;\r\n      case 'YYYY-MM-DD':\r\n        return `${year}-${month}-${day}`;\r\n      default:\r\n        return d.toLocaleDateString();\r\n    }\r\n  }\r\n}\r\n"]}
@@ -7450,6 +7450,7 @@ class InputNumberPickerComponent extends BaseInputComponent {
7450
7450
  this.ngZoneWrapper = ngZoneWrapper;
7451
7451
  this.elementRef = elementRef;
7452
7452
  this.modelChangeOnEnter = true;
7453
+ this.showPermanentLabel = false;
7453
7454
  this.minusIcon = CoreComponentsIcon.MinusSimple;
7454
7455
  this.plusIcon = CoreComponentsIcon.PlusSimple;
7455
7456
  // Whether to show buttons 'always', 'onFocusOnly', or 'never'
@@ -7675,16 +7676,19 @@ InputNumberPickerComponent.decorators = [
7675
7676
  (mousedown)="onMinusMouseDown($event)"
7676
7677
  (mouseup)="stopAutoCounting()" (mouseleave)="stopAutoCounting()"></co-button>
7677
7678
  </div>
7678
- <input type="text"
7679
- [tabIndex]="readonly ? -1 : 0"
7680
- [ngModel]="model"
7681
- [readonly]="readonly"
7682
- [disabled]="disabled"
7683
- [required]="required"
7684
- [placeholder]="label"
7685
- (ngModelChange)="handleChangeModel($event)"
7686
- (keydown)="handleInputKeyDown($event)"
7687
- (blur)="handleBlur()"/>
7679
+ <div class="input-wrapper">
7680
+ <span class='permanent-label' [textContent]="label" *ngIf="showPermanentLabel"></span>
7681
+ <input type="text"
7682
+ [tabIndex]="readonly ? -1 : 0"
7683
+ [ngModel]="model"
7684
+ [readonly]="readonly"
7685
+ [disabled]="disabled"
7686
+ [required]="required"
7687
+ [placeholder]="label"
7688
+ (ngModelChange)="handleChangeModel($event)"
7689
+ (keydown)="handleInputKeyDown($event)"
7690
+ (blur)="handleBlur()"/>
7691
+ </div>
7688
7692
  <div class="button-wrapper">
7689
7693
  <co-button *ngIf="showButtons" class="plus-operator" [class.select]="plusSelected" tabindex="-1"
7690
7694
  [disabled]="readonly"
@@ -7719,6 +7723,7 @@ InputNumberPickerComponent.ctorParameters = () => [
7719
7723
  InputNumberPickerComponent.propDecorators = {
7720
7724
  model: [{ type: Input }],
7721
7725
  modelChangeOnEnter: [{ type: Input }],
7726
+ showPermanentLabel: [{ type: Input }],
7722
7727
  leftIconData: [{ type: HostBinding, args: ['class.has-icon',] }, { type: Input }],
7723
7728
  min: [{ type: Input }],
7724
7729
  step: [{ type: Input }],
@@ -9490,7 +9495,7 @@ class ExcelExportService {
9490
9495
  exportData = data.map(item => {
9491
9496
  const newItem = {};
9492
9497
  columns.forEach(col => {
9493
- newItem[col.header] = this.getNestedValue(item, col.key);
9498
+ newItem[col.header] = this.getFlatValue(item, col.key);
9494
9499
  });
9495
9500
  return newItem;
9496
9501
  });
@@ -9562,6 +9567,9 @@ class ExcelExportService {
9562
9567
  return current && current[key] !== undefined ? current[key] : '';
9563
9568
  }, obj);
9564
9569
  }
9570
+ getFlatValue(obj, key) {
9571
+ return obj && obj[key] !== undefined ? obj[key] : '';
9572
+ }
9565
9573
  /**
9566
9574
  * Format date for Excel export
9567
9575
  * @param date - Date to format
@@ -9619,8 +9627,8 @@ class SimpleGridComponent extends BaseSimpleGridComponent {
9619
9627
  this.selectedRowIndex = -1;
9620
9628
  this.currentPage = 1;
9621
9629
  this.sortDirection = 'asc';
9622
- this.Icons = CoreComponentsIcon;
9623
9630
  this.hoveredRowIndex = -1;
9631
+ this.Icons = CoreComponentsIcon;
9624
9632
  this._doubleClicked = false;
9625
9633
  this._newRow = false;
9626
9634
  this.IconCacheService = IconCacheService;
@@ -9783,16 +9791,19 @@ class SimpleGridComponent extends BaseSimpleGridComponent {
9783
9791
  this._resetDblClick();
9784
9792
  });
9785
9793
  }
9786
- editRow(event, selectCell = true) {
9787
- this.editRowIndex = this.selectedRowIndex;
9788
- this.rowToEdit = this.data[this.editRowIndex];
9789
- this.editing = true;
9790
- if (selectCell) {
9791
- this._nextAvailableCellToEdit(true).then((index) => {
9792
- this.editCellIndex = index;
9793
- });
9794
- }
9795
- this._detectChanges();
9794
+ editRow(event, selectCell = true, rowIndex) {
9795
+ return __awaiter(this, void 0, void 0, function* () {
9796
+ if (rowIndex !== undefined) {
9797
+ this.selectTheRow(rowIndex, false);
9798
+ }
9799
+ this.editRowIndex = this.selectedRowIndex;
9800
+ this.rowToEdit = this.data[this.editRowIndex];
9801
+ this.editing = true;
9802
+ if (selectCell) {
9803
+ this.editCellIndex = yield this._nextAvailableCellToEdit(true);
9804
+ }
9805
+ this._detectChanges();
9806
+ });
9796
9807
  }
9797
9808
  handleCellClick(event, row, rowIndex, cellIndex) {
9798
9809
  return __awaiter(this, void 0, void 0, function* () {
@@ -9882,7 +9893,45 @@ class SimpleGridComponent extends BaseSimpleGridComponent {
9882
9893
  this.headerColumnsCopy = this.headerColumns;
9883
9894
  }
9884
9895
  exportToExcel() {
9885
- this.excelExportService.exportTableToExcel('simple-grid-table', 'ExcelSheet', 'Sheet1');
9896
+ this.isSettingsMenuOpen = false;
9897
+ const columns = this.headerColumnsCopy.map(column => {
9898
+ return ({
9899
+ key: column.field,
9900
+ header: column.headerText
9901
+ });
9902
+ });
9903
+ const headers = columns.map(col => col.header);
9904
+ const rows = this.data.map(row => columns.map(col => {
9905
+ const value = row[col.key];
9906
+ if (value instanceof Date) {
9907
+ const pad = (n) => String(n).padStart(2, '0');
9908
+ return `${value.getFullYear()}-${pad(value.getMonth() + 1)}-${pad(value.getDate())}T${pad(value.getHours())}:${pad(value.getMinutes())}:${pad(value.getSeconds())}`;
9909
+ }
9910
+ else if (Array.isArray(value)) {
9911
+ return value.join(', ');
9912
+ }
9913
+ else if (typeof value === 'object' && value !== null) {
9914
+ return JSON.stringify(value);
9915
+ }
9916
+ else {
9917
+ return String(value !== null && value !== void 0 ? value : '');
9918
+ }
9919
+ }));
9920
+ const csvContent = [headers, ...rows].map(row => row.map(cell => `"${cell.replace(/"/g, '""')}"`).join(',')).join('\r\n');
9921
+ const blob = new Blob([csvContent], { type: 'text/csv;charset=utf-8;' });
9922
+ const link = document.createElement('a');
9923
+ const url = URL.createObjectURL(blob);
9924
+ link.href = url;
9925
+ link.setAttribute('download', 'ExcelSheet');
9926
+ document.body.appendChild(link);
9927
+ link.click();
9928
+ document.body.removeChild(link);
9929
+ // this.excelExportService.exportToExcel(
9930
+ // this.data,
9931
+ // columns,
9932
+ // 'ExcelSheet',
9933
+ // 'Sheet1'
9934
+ // );
9886
9935
  }
9887
9936
  prepareDataRow(row, index) {
9888
9937
  this.isRowDisabled(row, index);
@@ -10170,8 +10219,7 @@ SimpleGridComponent.decorators = [
10170
10219
  <div class="icons-container" *ngIf="!editing">
10171
10220
  <co-icon class="icon-item icon-edit"
10172
10221
  [iconData]="icons.getIcon(Icons.PenToSquareSolid)" *ngIf="hoveredRowIndex === rowIndex"
10173
- (click)="editRow($event)"></co-icon>
10174
-
10222
+ (click)="editRow($event, true, rowIndex); $event.stopPropagation()"></co-icon>
10175
10223
  <co-icon class="icon-item icon-delete"
10176
10224
  [iconData]="icons.getIcon(Icons.TrashBin)" *ngIf="hoveredRowIndex === rowIndex"
10177
10225
  (click)="removeRow()"></co-icon>
@@ -10181,7 +10229,6 @@ SimpleGridComponent.decorators = [
10181
10229
  *ngIf="editing && (selectedRowIndex === rowIndex || (isNewRow && rowIndex === editRowIndex))"
10182
10230
  [iconData]="icons.getIcon(Icons.CheckDuotone)"
10183
10231
  (click)="validateAndSave(); $event.stopPropagation()"></co-button>
10184
-
10185
10232
  <co-button class="close-button"
10186
10233
  *ngIf="editing && (selectedRowIndex === rowIndex || (isNewRow && rowIndex === editRowIndex))"
10187
10234
  [iconData]="icons.getIcon(Icons.CrossSkinny)"
@@ -10193,7 +10240,6 @@ SimpleGridComponent.decorators = [
10193
10240
  </co-form>
10194
10241
  </tbody>
10195
10242
  </table>
10196
-
10197
10243
  <co-pagination-bar
10198
10244
  *ngIf="data?.length > rowsPerPage" class="pagination-bar"
10199
10245
  [itemsPerPage]="rowsPerPage"