UNPKG

ms-data-grid

Version:

A powerful, customizable Angular data grid component with advanced features like sorting, filtering, pagination, column pinning, and taskbar actions. Perfect for enterprise applications.

209 lines 32.6 kB
import { Injectable } from '@angular/core'; import * as i0 from "@angular/core"; export class CopyServiceService { constructor() { this.updateRows = []; } getSelectedDataForCopy(dataSet, columns, rowSelectedIndexes, selectedCells, getNestedValue) { const copiedRows = []; const findRowByVirtualIndex = (vIndex) => dataSet.find((r) => r.__virtualIndex === vIndex); if (rowSelectedIndexes && rowSelectedIndexes.size > 0) { const sortedIndexes = [...rowSelectedIndexes].sort((a, b) => a - b); for (const vIndex of sortedIndexes) { const row = findRowByVirtualIndex(vIndex); if (!row) continue; const extractValue = (field) => { const nested = getNestedValue(row, field); const value = nested?.value ?? nested?.name ?? nested ?? '-'; if (Array.isArray(value)) { return value .map(v => typeof v === 'object' ? (v.departmentName ?? v.roleName ?? '') : (v?.toString() ?? '')) .join(', '); } return value ?? ''; }; const mapped = columns.map(col => { if (col.children && Array.isArray(col.children)) { return col.children.map((c) => extractValue(c.field)); } return [extractValue(col.field)]; }); const rowValues = mapped.reduce((acc, curr) => acc.concat(curr), []); copiedRows.push(rowValues); } } if (selectedCells && selectedCells.length > 0) { const rowsMap = new Map(); for (const cell of selectedCells) { const row = findRowByVirtualIndex(cell.rowIndex); if (!row) continue; const col = columns[cell.colIndex]; let fieldName = col?.field; if (col?.children && col.children[cell.subColIndex]) { fieldName = col.children[cell.subColIndex].field; } let value = getNestedValue(row, fieldName) || getNestedValue(row, fieldName)?.name || getNestedValue(row, fieldName) || '-'; if (Array.isArray(value)) { value = value .map(v => typeof v === 'object' ? v.departmentName ?? v.roleName ?? '' : v?.toString() ?? '') .join(', '); } else { value = value ?? ''; } if (!rowsMap.has(cell.rowIndex)) rowsMap.set(cell.rowIndex, []); rowsMap.get(cell.rowIndex).push(value); } const sortedCells = [...rowsMap.entries()] .sort(([a], [b]) => a - b) .map(([_, v]) => v); copiedRows.push(...sortedCells); } if (copiedRows.length === 0) { const activeCell = document.querySelector('.active-cell'); if (activeCell) return [[activeCell.textContent?.trim() || '']]; } const maxCols = copiedRows.reduce((max, row) => Math.max(max, row.length), 0); return copiedRows.map(row => { const newRow = [...row]; while (newRow.length < maxCols) newRow.push(''); return newRow; }); } copyToClipboard(selectedData, selector = '.selected-cell, .active-cell, .row-selected') { if (!selectedData || selectedData.length === 0) return; const textToCopy = selectedData .map(row => row.map(cell => (cell ?? '').toString()).join('\t')) .join('\n'); navigator.clipboard.writeText(textToCopy).catch(err => console.error(err)); const selectedEls = document.querySelectorAll(selector); selectedEls.forEach(el => el.classList.add('flash-bg')); setTimeout(() => { selectedEls.forEach(el => el.classList.remove('flash-bg')); }, 1000); } async pasteFromClipboardText(text, dataSet, columns, startRowIndex, startColIndex, startSubColIndex = 0) { if (!text) return []; this.updateRows = []; const rows = text.split(/\r?\n/).map(r => r.split('\t')); const flattenedColumns = []; columns.forEach(col => { if (col.children?.length) { col.children.forEach((child) => flattenedColumns.push({ parent: col, ...child })); } else { flattenedColumns.push(col); } }); let startFlattenedIndex = 0; for (let i = 0; i < startColIndex; i++) { const col = columns[i]; startFlattenedIndex += col.children?.length || 1; } const startCol = columns[startColIndex]; if (startCol?.children?.length) { startFlattenedIndex += Math.min(startSubColIndex, startCol.children.length - 1); } rows.forEach((rowValues, rOffset) => { const targetRowIndex = startRowIndex + rOffset; const row = dataSet.find(r => r?.__virtualIndex === targetRowIndex); if (!row) return; rowValues.forEach((value, cOffset) => { const targetIndex = startFlattenedIndex + cOffset; if (targetIndex < 0 || targetIndex >= flattenedColumns.length) return; const targetColumn = flattenedColumns[targetIndex]; this.setNestedValue(row, targetColumn, value); }); }); return this.updateRows; } setNestedValue(obj, column, option, calledFromInput = false) { debugger; if (column.type === 'date' || column.type === 'image') return; const path = column.field; if (!path) return; const keys = path.split('.'); const lastKey = keys.pop(); const parent = keys.reduce((acc, key) => (acc[key] ??= {}), obj); if (parent && lastKey) { if (typeof option === 'object' && option !== null) { parent[lastKey] = { id: option.id ?? 1, value: option.value ?? option, }; } else { parent[lastKey] = option; } } const sendObj = { data: { ...obj }, eventType: 'onCellEdit', }; this.updateRows.push(obj); } cutSelectedSelectedData(dataSet, rowSelectedIndexes, selectedCells, columns, setNestedValue) { let updatedData = [...dataSet]; if (rowSelectedIndexes?.size) { const indexes = [...rowSelectedIndexes]; updatedData = updatedData.filter((row) => !indexes.includes(row.__virtualIndex)); // rowSelectedIndexes.clear(); } else if (selectedCells?.length) { this.updateRows = []; for (const cell of selectedCells) { const row = updatedData.find(r => r.__virtualIndex === cell.rowIndex); if (!row) continue; let col = columns[cell.colIndex]; if (col?.children && col.children[cell.subColIndex]) { col = col.children[cell.subColIndex]; } this.setNestedValue(row, col, ''); } // selectedCells.length = 0; } return { updatedData: updatedData, updatedRows: this.updateRows }; } cutWithAnimation(selectedData, selector = '.selected-cell, .active-cell, .row-selected') { if (!selectedData || selectedData.length === 0) return; const textToCopy = selectedData .map(row => row.map(cell => (cell ?? '').toString()).join('\t')) .join('\n'); navigator.clipboard.writeText(textToCopy).catch(err => console.error(err)); // Apply red cut animation const selectedEls = document.querySelectorAll(selector); selectedEls.forEach(el => el.classList.add('cut-flash-bg')); setTimeout(() => { selectedEls.forEach(el => el.classList.remove('cut-flash-bg')); }, 1000); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CopyServiceService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); } static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CopyServiceService, providedIn: 'root' }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CopyServiceService, decorators: [{ type: Injectable, args: [{ providedIn: 'root' }] }], ctorParameters: function () { return []; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"copy-service.service.js","sourceRoot":"","sources":["../../../../../projects/data-grid/src/lib/services/copy-service.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class CopyServiceService {\r\n\r\n  constructor() { }\r\n  getSelectedDataForCopy(\r\n    dataSet: any[],\r\n    columns: any[],\r\n    rowSelectedIndexes: Set<number>,\r\n    selectedCells: any[],\r\n    getNestedValue: (obj: any, path: string) => any\r\n  ): any[][] {\r\n    const copiedRows: any[][] = [];\r\n    const findRowByVirtualIndex = (vIndex: number) =>\r\n      dataSet.find((r: any) => r.__virtualIndex === vIndex);\r\n    if (rowSelectedIndexes && rowSelectedIndexes.size > 0) {\r\n      const sortedIndexes = [...rowSelectedIndexes].sort((a, b) => a - b);\r\n      for (const vIndex of sortedIndexes) {\r\n        const row = findRowByVirtualIndex(vIndex);\r\n        if (!row) continue;\r\n        const extractValue = (field: string): string => {\r\n          const nested = getNestedValue(row, field);\r\n          const value =\r\n            nested?.value ??\r\n            nested?.name ??\r\n            nested ??\r\n            '-';\r\n\r\n          if (Array.isArray(value)) {\r\n            return value\r\n              .map(v =>\r\n                typeof v === 'object'\r\n                  ? (v.departmentName ?? v.roleName ?? '')\r\n                  : (v?.toString() ?? '')\r\n              )\r\n              .join(', ');\r\n          }\r\n          return value ?? '';\r\n        };\r\n        const mapped = columns.map(col => {\r\n          if (col.children && Array.isArray(col.children)) {\r\n            return col.children.map((c: { field: string }) => extractValue(c.field));\r\n          }\r\n          return [extractValue(col.field)];\r\n        });\r\n        const rowValues = mapped.reduce<string[]>((acc, curr) => acc.concat(curr), []);\r\n        copiedRows.push(rowValues);\r\n      }\r\n    }\r\n    if (selectedCells && selectedCells.length > 0) {\r\n      const rowsMap = new Map<number, any[]>();\r\n      for (const cell of selectedCells) {\r\n        const row = findRowByVirtualIndex(cell.rowIndex);\r\n        if (!row) continue;\r\n        const col = columns[cell.colIndex];\r\n        let fieldName = col?.field;\r\n        if (col?.children && col.children[cell.subColIndex]) {\r\n          fieldName = col.children[cell.subColIndex].field;\r\n        }\r\n        let value = getNestedValue(row, fieldName) || getNestedValue(row, fieldName)?.name || getNestedValue(row, fieldName) || '-';\r\n        if (Array.isArray(value)) {\r\n          value = value\r\n            .map(v =>\r\n              typeof v === 'object'\r\n                ? v.departmentName ?? v.roleName ?? ''\r\n                : v?.toString() ?? ''\r\n            )\r\n            .join(', ');\r\n        } else {\r\n          value = value ?? '';\r\n        }\r\n        if (!rowsMap.has(cell.rowIndex)) rowsMap.set(cell.rowIndex, []);\r\n        rowsMap.get(cell.rowIndex)!.push(value);\r\n      }\r\n      const sortedCells = [...rowsMap.entries()]\r\n        .sort(([a], [b]) => a - b)\r\n        .map(([_, v]) => v);\r\n      copiedRows.push(...sortedCells);\r\n    }\r\n    if (copiedRows.length === 0) {\r\n      const activeCell = document.querySelector('.active-cell');\r\n      if (activeCell) return [[activeCell.textContent?.trim() || '']];\r\n    }\r\n\r\n    const maxCols = copiedRows.reduce((max, row) => Math.max(max, row.length), 0);\r\n    return copiedRows.map(row => {\r\n      const newRow = [...row];\r\n      while (newRow.length < maxCols) newRow.push('');\r\n      return newRow;\r\n    });\r\n  }\r\n\r\n\r\n  copyToClipboard(\r\n    selectedData: any[][],\r\n    selector = '.selected-cell, .active-cell, .row-selected'\r\n  ): void {\r\n    if (!selectedData || selectedData.length === 0) return;\r\n    const textToCopy = selectedData\r\n      .map(row => row.map(cell => (cell ?? '').toString()).join('\\t'))\r\n      .join('\\n');\r\n    navigator.clipboard.writeText(textToCopy).catch(err => console.error(err));\r\n    const selectedEls = document.querySelectorAll(selector);\r\n    selectedEls.forEach(el => el.classList.add('flash-bg'));\r\n    setTimeout(() => {\r\n      selectedEls.forEach(el => el.classList.remove('flash-bg'));\r\n    }, 1000);\r\n  }\r\n\r\n\r\n  updateRows: any[] = [];\r\n  async pasteFromClipboardText(\r\n    text: string,\r\n    dataSet: any[],\r\n    columns: any[],\r\n    startRowIndex: number,\r\n    startColIndex: number,\r\n    startSubColIndex: number = 0\r\n  ): Promise<any[]> {\r\n    if (!text) return [];\r\n    this.updateRows = [];\r\n    const rows = text.split(/\\r?\\n/).map(r => r.split('\\t'));\r\n    const flattenedColumns: any[] = [];\r\n    columns.forEach(col => {\r\n      if (col.children?.length) {\r\n        col.children.forEach((child: any) => flattenedColumns.push({ parent: col, ...child }));\r\n      } else {\r\n        flattenedColumns.push(col);\r\n      }\r\n    });\r\n    let startFlattenedIndex = 0;\r\n    for (let i = 0; i < startColIndex; i++) {\r\n      const col = columns[i];\r\n      startFlattenedIndex += col.children?.length || 1;\r\n    }\r\n    const startCol = columns[startColIndex];\r\n    if (startCol?.children?.length) {\r\n      startFlattenedIndex += Math.min(startSubColIndex, startCol.children.length - 1);\r\n    }\r\n\r\n    rows.forEach((rowValues, rOffset) => {\r\n      const targetRowIndex = startRowIndex + rOffset;\r\n      const row = dataSet.find(r => r?.__virtualIndex === targetRowIndex);\r\n      if (!row) return;\r\n\r\n      rowValues.forEach((value, cOffset) => {\r\n        const targetIndex = startFlattenedIndex + cOffset;\r\n        if (targetIndex < 0 || targetIndex >= flattenedColumns.length) return;\r\n\r\n        const targetColumn = flattenedColumns[targetIndex];\r\n        this.setNestedValue(row, targetColumn, value);\r\n      });\r\n    });\r\n\r\n    return this.updateRows;\r\n  }\r\n\r\n\r\n  setNestedValue(obj: any, column: any, option: any, calledFromInput = false): void {\r\n    debugger\r\n    if (column.type === 'date' || column.type === 'image') return;\r\n    const path = column.field;\r\n    if (!path) return;\r\n    const keys = path.split('.');\r\n    const lastKey = keys.pop();\r\n    const parent = keys.reduce((acc: any, key: string) => (acc[key] ??= {}), obj);\r\n    if (parent && lastKey) {\r\n      if (typeof option === 'object' && option !== null) {\r\n        parent[lastKey] = {\r\n          id: option.id ?? 1,\r\n          value: option.value ?? option,\r\n        };\r\n      } else {\r\n        parent[lastKey] = option;\r\n      }\r\n    }\r\n    const sendObj = {\r\n      data: { ...obj },\r\n      eventType: 'onCellEdit',\r\n    };\r\n    this.updateRows.push(obj);\r\n  }\r\n\r\n\r\n  cutSelectedSelectedData(\r\n    dataSet: any[],\r\n    rowSelectedIndexes: Set<number>,\r\n    selectedCells: any[],\r\n    columns: any[],\r\n    setNestedValue: (obj: any, column: any, value: any) => void\r\n  ): any {\r\n    let updatedData = [...dataSet];\r\n    if (rowSelectedIndexes?.size) {\r\n      const indexes = [...rowSelectedIndexes];\r\n      updatedData = updatedData.filter(\r\n        (row: any) => !indexes.includes(row.__virtualIndex)\r\n      );\r\n      // rowSelectedIndexes.clear();\r\n    }\r\n    else if (selectedCells?.length) {\r\n      this.updateRows = [];\r\n      for (const cell of selectedCells) {\r\n        const row = updatedData.find(r => r.__virtualIndex === cell.rowIndex);\r\n        if (!row) continue;\r\n        let col = columns[cell.colIndex];\r\n        if (col?.children && col.children[cell.subColIndex]) {\r\n          col = col.children[cell.subColIndex];\r\n        }\r\n        this.setNestedValue(row, col, '');\r\n      }\r\n      // selectedCells.length = 0;\r\n    }\r\n    return {updatedData: updatedData, updatedRows: this.updateRows};\r\n  }\r\n\r\n\r\n  cutWithAnimation(\r\n    selectedData: any[][],\r\n    selector = '.selected-cell, .active-cell, .row-selected'\r\n  ): void {\r\n    if (!selectedData || selectedData.length === 0) return;\r\n\r\n    const textToCopy = selectedData\r\n      .map(row => row.map(cell => (cell ?? '').toString()).join('\\t'))\r\n      .join('\\n');\r\n\r\n    navigator.clipboard.writeText(textToCopy).catch(err => console.error(err));\r\n\r\n    // Apply red cut animation\r\n    const selectedEls = document.querySelectorAll(selector);\r\n    selectedEls.forEach(el => el.classList.add('cut-flash-bg'));\r\n    setTimeout(() => {\r\n      selectedEls.forEach(el => el.classList.remove('cut-flash-bg'));\r\n    }, 1000);\r\n  }\r\n\r\n\r\n}\r\n"]}