verben-ng-ui 0.1.9 → 0.2.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.
- package/esm2022/lib/components/data-export/data-export.component.mjs +2 -2
- package/esm2022/lib/components/data-export/data-export.service.mjs +7 -7
- package/esm2022/lib/components/data-table/data-table.component.mjs +32 -19
- package/esm2022/lib/components/data-view/data-view-click-outside.directive.mjs +1 -1
- package/esm2022/lib/components/data-view/data-view.component.mjs +4 -5
- package/esm2022/lib/components/data-view/data-view.module.mjs +5 -4
- package/esm2022/lib/components/notification/notification.component.mjs +1 -1
- package/esm2022/lib/components/visible-column/visible-column.component.mjs +7 -5
- package/esm2022/lib/verbena-button/verbena-button.component.mjs +12 -3
- package/fesm2022/verben-ng-ui.mjs +60 -37
- package/fesm2022/verben-ng-ui.mjs.map +1 -1
- package/lib/components/data-table/data-table.component.d.ts +5 -3
- package/lib/components/data-view/data-view.module.d.ts +2 -1
- package/lib/components/visible-column/visible-column.component.d.ts +2 -1
- package/lib/verbena-button/verbena-button.component.d.ts +4 -1
- package/package.json +1 -1
|
@@ -64,7 +64,7 @@ export class DataExportComponent {
|
|
|
64
64
|
}
|
|
65
65
|
initializeGroupItems() {
|
|
66
66
|
if (this.data && this.data.length > 0) {
|
|
67
|
-
const properties = Object.keys(this.data[0]);
|
|
67
|
+
const properties = Object.keys(this.data[0]).filter((k) => k !== 'id');
|
|
68
68
|
this.exportService.setBaseProperties(properties);
|
|
69
69
|
this.numericProperties = properties.filter((prop) => typeof this.data[0][prop] === 'number');
|
|
70
70
|
this.stringProperties = properties.filter((prop) => typeof this.data[0][prop] === 'string');
|
|
@@ -201,4 +201,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImpor
|
|
|
201
201
|
}], exportDataEvent: [{
|
|
202
202
|
type: Output
|
|
203
203
|
}] } });
|
|
204
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-export.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-ng-ui/src/lib/components/data-export/data-export.component.ts","../../../../../../projects/verben-ng-ui/src/lib/components/data-export/data-export.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAqC,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAE/E,OAAO,EAIL,SAAS,GACV,MAAM,qBAAqB,CAAC;;;;;;;;;AAQ7B,MAAM,OAAO,mBAAmB;IAiCpB;IACA;IAjCD,IAAI,CAAS;IACZ,eAAe,GAAG,IAAI,YAAY,EAAyB,CAAC;IAEtE,QAAQ,GAA8C,EAAE,CAAC;IACzD,UAAU,GAA2C,EAAE,CAAC;IACxD,YAAY,CAAY;IACxB,YAAY,GAAc;QACxB,EAAE,EAAE,EAAE;QACN,IAAI,EAAE,EAAE;QACR,MAAM,EAAE,EAAE;QACV,QAAQ,EAAE,SAAS,CAAC,GAAG;QACvB,MAAM,EAAE,EAAE;KACX,CAAC;IACF,iBAAiB,GAAa,EAAE,CAAC;IACjC,gBAAgB,GAAa,EAAE,CAAC;IAChC,kBAAkB,GAAY,KAAK,CAAC;IACpC,eAAe,GAAY,KAAK,CAAC;IACjC,aAAa,GAAY,KAAK,CAAC;IAE/B,gBAAgB,GAAgB;QAC9B,SAAS,CAAC,GAAG;QACb,SAAS,CAAC,QAAQ;QAClB,SAAS,CAAC,QAAQ;QAClB,SAAS,CAAC,MAAM;KACjB,CAAC;IACF,eAAe,GAAgB;QAC7B,SAAS,CAAC,gBAAgB;QAC1B,SAAS,CAAC,qBAAqB;QAC/B,SAAS,CAAC,gBAAgB;KAC3B,CAAC;IAEF,YACU,aAAgC,EAChC,EAAe;QADf,kBAAa,GAAb,aAAa,CAAmB;QAChC,OAAE,GAAF,EAAE,CAAa;QAEvB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;YAChC,IAAI,EAAE,CAAC,EAAE,EAAE,UAAU,CAAC,QAAQ,CAAC;SAChC,CAAC,CAAC;IACL,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;YACd,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC9B,CAAC;IACH,CAAC;IAED,IAAI,eAAe;QACjB,OAAO,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC1E,CAAC;IAED,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC5E,CAAC;IAED,oBAAoB;QAClB,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACtC,MAAM,UAAU,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;YAC7C,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC;YACjD,IAAI,CAAC,iBAAiB,GAAG,UAAU,CAAC,MAAM,CACxC,CAAC,IAAI,EAAE,EAAE,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,QAAQ,CACjD,CAAC;YACF,IAAI,CAAC,gBAAgB,GAAG,UAAU,CAAC,MAAM,CACvC,CAAC,IAAI,EAAE,EAAE,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,QAAQ,CACjD,CAAC;YACF,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC;IACH,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;YACjE,GAAG,OAAO;YACV,QAAQ,EAAE,KAAK;SAChB,CAAC,CAAC,CAAC;IACN,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;YAChE,GAAG,IAAI;YACP,QAAQ,EAAE,KAAK;SAChB,CAAC,CAAC,CAAC;IACN,CAAC;IAED,QAAQ;QACN,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAClB,IAAI,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;YAC5B,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACtE,IAAI,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC7B,MAAM,UAAU,GAAkB;oBAChC,EAAE,EAAE,IAAI,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE;oBACzB,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,KAAK;oBAC1C,KAAK,EAAE,aAAa;iBACrB,CAAC;gBACF,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;gBAC1C,IAAI,CAAC,cAAc,EAAE,CAAC;gBACtB,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,CAAC,CAAC;gBAC3D,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;gBAC1B,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;YAC1B,CAAC;YACD,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;QACvB,CAAC;IACH,CAAC;IAED,WAAW,CAAC,OAA8C;QACxD,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YAC/B,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAChC,CAAC,WAAW,EAAE,EAAE,CAAC,WAAW,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,CAC5C,CAAC;QACJ,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;IAC9B,CAAC;IAED,aAAa,CAAC,OAA8C;QAC1D,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC7C,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAED,oBAAoB;QAClB,IACE,IAAI,CAAC,YAAY,CAAC,IAAI;YACtB,IAAI,CAAC,YAAY,CAAC,MAAM;YACxB,IAAI,CAAC,YAAY,CAAC,MAAM,EACxB,CAAC;YACD,IAAI,IAAI,CAAC,kBAAkB,EAAE,CAAC;gBAC5B,IAAI,CAAC,aAAa,CAAC,eAAe,CAChC,IAAI,CAAC,YAAY,CAAC,EAAE,EACpB,IAAI,CAAC,YAAY,CAClB,CAAC;YACJ,CAAC;iBAAM,CAAC;gBACN,MAAM,SAAS,GAAc;oBAC3B,GAAG,IAAI,CAAC,YAAY;oBACpB,EAAE,EAAE,IAAI,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE;iBAC1B,CAAC;gBACF,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;YAC7C,CAAC;YACD,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACxB,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC5B,CAAC;IACH,CAAC;IAED,aAAa,CAAC,SAA6C;QACzD,IAAI,CAAC,YAAY,GAAG,EAAE,GAAI,SAAkC,EAAE,CAAC;QAC/D,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;IACjC,CAAC;IAED,eAAe,CAAC,SAA6C;QAC3D,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;QACjD,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,YAAY,GAAG;YAClB,EAAE,EAAE,EAAE;YACN,IAAI,EAAE,EAAE;YACR,MAAM,EAAE,EAAE;YACV,QAAQ,EAAE,SAAS,CAAC,GAAG;YACvB,MAAM,EAAE,EAAE;SACX,CAAC;QACF,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;IAClC,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;QAC9B,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;IAC5B,CAAC;IAED,UAAU;QACR,MAAM,gBAAgB,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAC3C,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,QAAQ,CAC9B,CAAC;QACF,IAAI,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAChC,MAAM,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,UAAU,CAChD,IAAI,CAAC,IAAI,EACT,gBAAgB,CACjB,CAAC;YACF,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAC1C,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,GAAG,CAAC,iCAAiC,CAAC,CAAC;QACjD,CAAC;IACH,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,YAAY,CAAC,MAAM,GAAG,EAAE,CAAC;QAC9B,IAAI,CAAC,YAAY,CAAC,QAAQ,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;YACxE,CAAC,CAAC,SAAS,CAAC,GAAG;YACf,CAAC,CAAC,SAAS,CAAC,gBAAgB,CAAC;IACjC,CAAC;IAED,cAAc,CAAC,KAAa;QAC1B,OAAO,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAChD,CAAC;IAED,IAAI,kBAAkB;QACpB,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;YAClD,CAAC,CAAC,IAAI,CAAC,gBAAgB;YACvB,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC;IAC3B,CAAC;IAED,IAAI,gBAAgB;QAClB,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;YAClD,CAAC,CAAC,IAAI,CAAC,iBAAiB;YACxB,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC;IAC5B,CAAC;IAED,qBAAqB;QACnB,IAAI,CAAC,eAAe,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC;IAC/C,CAAC;IAED,mBAAmB;QACjB,IAAI,CAAC,aAAa,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC;IAC3C,CAAC;uGA1NU,mBAAmB;2FAAnB,mBAAmB,uJCtBhC,2pMA4MA;;2FDtLa,mBAAmB;kBAN/B,SAAS;+BACE,iBAAiB,mBAGV,uBAAuB,CAAC,MAAM;gHAGtC,IAAI;sBAAZ,KAAK;gBACI,eAAe;sBAAxB,MAAM","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n} from '@angular/core';\nimport { FormArray, FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { DataExportService } from './data-export.service';\nimport {\n  ExportItem,\n  ExportProfile,\n  Operation,\n  Operators,\n} from './data-export.types';\n\n@Component({\n  selector: 'lib-data-export',\n  templateUrl: './data-export.component.html',\n  styleUrl: './data-export.component.css',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DataExportComponent {\n  @Input() data!: any[];\n  @Output() exportDataEvent = new EventEmitter<Record<string, any>[]>();\n\n  profiles: (ExportProfile & { selected: boolean })[] = [];\n  groupItems: (ExportItem & { selected: boolean })[] = [];\n  newGroupForm: FormGroup;\n  newOperation: Operation = {\n    id: '',\n    name: '',\n    field1: '',\n    operator: Operators.add,\n    field2: '',\n  };\n  numericProperties: string[] = [];\n  stringProperties: string[] = [];\n  isEditingOperation: boolean = false;\n  showAllProfiles: boolean = false;\n  showAllGroups: boolean = false;\n\n  operatorsNumeric: Operators[] = [\n    Operators.add,\n    Operators.subtract,\n    Operators.multiply,\n    Operators.divide,\n  ];\n  operatorsString: Operators[] = [\n    Operators.concatenateSpace,\n    Operators.concatenateCommaSpace,\n    Operators.concatenateComma,\n  ];\n\n  constructor(\n    private exportService: DataExportService,\n    private fb: FormBuilder\n  ) {\n    this.newGroupForm = this.fb.group({\n      name: ['', Validators.required],\n    });\n  }\n\n  ngOnInit() {\n    this.initializeGroupItems();\n    this.updateProfiles();\n  }\n\n  ngOnChanges() {\n    if (this.data) {\n      this.initializeGroupItems();\n    }\n  }\n\n  get visibleProfiles() {\n    return this.showAllProfiles ? this.profiles : this.profiles.slice(0, 3);\n  }\n\n  get visibleGroups() {\n    return this.showAllGroups ? this.groupItems : this.groupItems.slice(0, 3);\n  }\n\n  initializeGroupItems() {\n    if (this.data && this.data.length > 0) {\n      const properties = Object.keys(this.data[0]);\n      this.exportService.setBaseProperties(properties);\n      this.numericProperties = properties.filter(\n        (prop) => typeof this.data[0][prop] === 'number'\n      );\n      this.stringProperties = properties.filter(\n        (prop) => typeof this.data[0][prop] === 'string'\n      );\n      this.updateGroupItems();\n    }\n  }\n\n  updateProfiles() {\n    this.profiles = this.exportService.getProfiles().map((profile) => ({\n      ...profile,\n      selected: false,\n    }));\n  }\n\n  updateGroupItems() {\n    this.groupItems = this.exportService.getAllItems().map((item) => ({\n      ...item,\n      selected: false,\n    }));\n  }\n\n  addGroup() {\n    console.log('in');\n    if (this.newGroupForm.valid) {\n      const selectedItems = this.groupItems.filter((item) => item.selected);\n      if (selectedItems.length > 0) {\n        const newProfile: ExportProfile = {\n          id: Date.now().toString(),\n          name: this.newGroupForm.get('name')?.value,\n          items: selectedItems,\n        };\n        this.exportService.addProfile(newProfile);\n        this.updateProfiles();\n        this.groupItems.forEach((item) => (item.selected = false));\n        this.newGroupForm.reset();\n        console.log('SELECTED');\n      }\n      console.log('VALID');\n    }\n  }\n\n  editProfile(profile: ExportProfile & { selected: boolean }) {\n    this.groupItems.forEach((item) => {\n      item.selected = profile.items.some(\n        (profileItem) => profileItem.id === item.id\n      );\n    });\n    this.removeProfile(profile);\n  }\n\n  removeProfile(profile: ExportProfile & { selected: boolean }) {\n    this.exportService.removeProfile(profile.id);\n    this.updateProfiles();\n  }\n\n  addOrUpdateOperation() {\n    if (\n      this.newOperation.name &&\n      this.newOperation.field1 &&\n      this.newOperation.field2\n    ) {\n      if (this.isEditingOperation) {\n        this.exportService.updateOperation(\n          this.newOperation.id,\n          this.newOperation\n        );\n      } else {\n        const operation: Operation = {\n          ...this.newOperation,\n          id: Date.now().toString(),\n        };\n        this.exportService.addOperation(operation);\n      }\n      this.updateGroupItems();\n      this.resetOperationForm();\n    }\n  }\n\n  editOperation(operation: ExportItem & { selected: boolean }) {\n    this.newOperation = { ...(operation as unknown as Operation) };\n    this.isEditingOperation = true;\n  }\n\n  removeOperation(operation: ExportItem & { selected: boolean }) {\n    this.exportService.removeOperation(operation.id);\n    this.updateGroupItems();\n  }\n\n  resetOperationForm() {\n    this.newOperation = {\n      id: '',\n      name: '',\n      field1: '',\n      operator: Operators.add,\n      field2: '',\n    };\n    this.isEditingOperation = false;\n  }\n\n  resetAll() {\n    this.exportService.resetAll();\n    this.initializeGroupItems();\n    this.updateProfiles();\n    this.resetOperationForm();\n    this.newGroupForm.reset();\n  }\n\n  exportData() {\n    const selectedProfiles = this.profiles.filter(\n      (profile) => profile.selected\n    );\n    if (selectedProfiles.length > 0) {\n      const exportedData = this.exportService.exportData(\n        this.data,\n        selectedProfiles\n      );\n      this.exportDataEvent.emit(exportedData);\n    } else {\n      console.log('No profiles selected for export');\n    }\n  }\n\n  onField1Change() {\n    this.newOperation.field2 = '';\n    this.newOperation.operator = this.isNumericField(this.newOperation.field1)\n      ? Operators.add\n      : Operators.concatenateSpace;\n  }\n\n  isNumericField(field: string): boolean {\n    return this.numericProperties.includes(field);\n  }\n\n  get availableOperators(): Operators[] {\n    return this.isNumericField(this.newOperation.field1)\n      ? this.operatorsNumeric\n      : this.operatorsString;\n  }\n\n  get availableFields2(): string[] {\n    return this.isNumericField(this.newOperation.field1)\n      ? this.numericProperties\n      : this.stringProperties;\n  }\n\n  toggleShowAllProfiles() {\n    this.showAllProfiles = !this.showAllProfiles;\n  }\n\n  toggleShowAllGroups() {\n    this.showAllGroups = !this.showAllGroups;\n  }\n}\n","<verben-card\n  width=\"24rem\"\n  borderRadius=\"1rem\"\n  [border]=\"'1px solid #D4A007'\"\n  bgColor=\"#FFFFFF\"\n  class=\"export-card\"\n>\n  <div card-header class=\"card-header\">\n    <h4 class=\"header-title\">Export</h4>\n    <button\n      class=\"reset-button\"\n      [style.color]=\"'#3479E9'\"\n      [style.background-color]=\"'transparent'\"\n      [style.border]=\"'none'\"\n      [style.cursor]=\"'pointer'\"\n      [style.font-size]=\"'12px'\"\n      (click)=\"resetAll()\"\n    >\n      Reset\n    </button>\n  </div>\n  <div card-body class=\"card-body\">\n    <section class=\"section\">\n      <div class=\"section-header\">\n        <h3 class=\"section-title\">Profiles</h3>\n        <verben-svg\n          icon=\"info\"\n          [width]=\"15\"\n          [height]=\"15\"\n          fill=\"grey\"\n        ></verben-svg>\n      </div>\n      <div *ngFor=\"let profile of visibleProfiles; let i = index\" class=\"item\">\n        <div class=\"item-label\">\n          <input\n            type=\"checkbox\"\n            [id]=\"'profile-' + i\"\n            [(ngModel)]=\"profile.selected\"\n          />\n          <label [for]=\"'profile-' + i\" class=\"checkbox-label\">\n            {{ profile.name }}\n          </label>\n        </div>\n        <div class=\"item-actions\">\n          <verben-svg\n            icon=\"edit\"\n            [width]=\"15\"\n            [height]=\"15\"\n            stroke=\"#3479E9\"\n            fill=\"white\"\n            (click)=\"editProfile(profile)\"\n          ></verben-svg>\n          <verben-svg\n            icon=\"delete\"\n            [width]=\"15\"\n            [height]=\"15\"\n            stroke=\"#E20000\"\n            (click)=\"removeProfile(profile)\"\n          ></verben-svg>\n        </div>\n      </div>\n      <div\n        *ngIf=\"profiles.length > 3\"\n        (click)=\"toggleShowAllProfiles()\"\n        class=\"show-more\"\n      >\n        <span>{{ showAllProfiles ? \"Show less\" : \"Show more\" }}</span>\n        <verben-svg\n          icon=\"chevron\"\n          [width]=\"8\"\n          [height]=\"6\"\n          fill=\"black\"\n          stroke=\"black\"\n        ></verben-svg>\n      </div>\n    </section>\n    <hr class=\"divider\" />\n    <section class=\"section\">\n      <div class=\"section-header\">\n        <h3 class=\"section-title\">Group</h3>\n        <verben-svg\n          icon=\"info\"\n          [width]=\"15\"\n          [height]=\"15\"\n          fill=\"grey\"\n        ></verben-svg>\n      </div>\n      <form [formGroup]=\"newGroupForm\" (ngSubmit)=\"addGroup()\">\n        <verbena-input\n          placeholder=\"Group name\"\n          border=\"1px solid #ccc\"\n          borderRadius=\"5px\"\n          textColor=\"black\"\n          width=\"100%\"\n          height=\"20px\"\n          pd=\"4px 6px\"\n          [showBorder]=\"true\"\n          [showErrorMessage]=\"true\"\n          [errorPosition]=\"'bottom'\"\n          formControlName=\"name\"\n        ></verbena-input>\n      </form>\n      <div *ngFor=\"let item of visibleGroups; let i = index\" class=\"item\">\n        <div class=\"item-label\">\n          <input\n            type=\"checkbox\"\n            [id]=\"'group-' + i\"\n            [(ngModel)]=\"item.selected\"\n          />\n          <label [for]=\"'group-' + i\" class=\"checkbox-label\">\n            {{ item.name }}\n          </label>\n        </div>\n        <div class=\"item-actions\" *ngIf=\"item.type === 'operation'\">\n          <verben-svg\n            icon=\"edit\"\n            [width]=\"15\"\n            [height]=\"15\"\n            stroke=\"#3479E9\"\n            fill=\"white\"\n            (click)=\"editOperation(item)\"\n          ></verben-svg>\n          <verben-svg\n            icon=\"delete\"\n            [width]=\"15\"\n            [height]=\"15\"\n            stroke=\"#E20000\"\n            (click)=\"removeOperation(item)\"\n          ></verben-svg>\n        </div>\n      </div>\n      <div\n        *ngIf=\"groupItems.length > 3\"\n        (click)=\"toggleShowAllGroups()\"\n        class=\"show-more\"\n      >\n        <span>{{ showAllGroups ? \"Show less\" : \"Show more\" }}</span>\n        <verben-svg\n          icon=\"chevron\"\n          [width]=\"8\"\n          [height]=\"6\"\n          fill=\"black\"\n          stroke=\"black\"\n        ></verben-svg>\n      </div>\n      <button class=\"add-button\" (click)=\"addGroup()\">+ Add</button>\n    </section>\n    <hr class=\"divider\" />\n    <section class=\"section\">\n      <div class=\"section-header\">\n        <h3 class=\"section-title\">Operation</h3>\n        <verben-svg\n          icon=\"info\"\n          [width]=\"15\"\n          [height]=\"15\"\n          fill=\"grey\"\n        ></verben-svg>\n      </div>\n      <verbena-input\n        placeholder=\"Operation name\"\n        border=\"1px solid #ccc\"\n        borderRadius=\"5px\"\n        textColor=\"black\"\n        width=\"100%\"\n        height=\"20px\"\n        pd=\"2px 6px\"\n        [showBorder]=\"true\"\n        [showErrorMessage]=\"true\"\n        [errorPosition]=\"'bottom'\"\n        [(ngModel)]=\"newOperation.name\"\n      ></verbena-input>\n      <div class=\"operation-grid\">\n        <verben-drop-down\n          width=\"'8rem'\"\n          placeholder=\"Select field\"\n          [options]=\"numericProperties.concat(stringProperties)\"\n          [(ngModel)]=\"newOperation.field1\"\n          (ngModelChange)=\"onField1Change()\"\n        >\n        </verben-drop-down>\n        <verben-drop-down\n          width=\"'8rem'\"\n          placeholder=\"Select operator\"\n          [options]=\"availableOperators\"\n          [(ngModel)]=\"newOperation.operator\"\n        >\n        </verben-drop-down>\n        <verben-drop-down\n          width=\"'8rem'\"\n          placeholder=\"Select field\"\n          [options]=\"availableFields2\"\n          [(ngModel)]=\"newOperation.field2\"\n        >\n        </verben-drop-down>\n      </div>\n      <button class=\"add-button\" (click)=\"addOrUpdateOperation()\">\n        {{ isEditingOperation ? \"Update\" : \"+ Add\" }}\n      </button>\n    </section>\n  </div>\n  <div card-footer class=\"card-footer\">\n    <button class=\"export-button\" (click)=\"exportData()\">Export</button>\n  </div>\n</verben-card>\n"]}
|
|
204
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-export.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-ng-ui/src/lib/components/data-export/data-export.component.ts","../../../../../../projects/verben-ng-ui/src/lib/components/data-export/data-export.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n} from '@angular/core';\nimport { FormArray, FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { DataExportService } from './data-export.service';\nimport {\n  ExportItem,\n  ExportProfile,\n  Operation,\n  Operators,\n} from './data-export.types';\n\n@Component({\n  selector: 'lib-data-export',\n  templateUrl: './data-export.component.html',\n  styleUrl: './data-export.component.css',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DataExportComponent {\n  @Input() data!: any[];\n  @Output() exportDataEvent = new EventEmitter<Record<string, any>[]>();\n\n  profiles: (ExportProfile & { selected: boolean })[] = [];\n  groupItems: (ExportItem & { selected: boolean })[] = [];\n  newGroupForm: FormGroup;\n  newOperation: Operation = {\n    id: '',\n    name: '',\n    field1: '',\n    operator: Operators.add,\n    field2: '',\n  };\n  numericProperties: string[] = [];\n  stringProperties: string[] = [];\n  isEditingOperation: boolean = false;\n  showAllProfiles: boolean = false;\n  showAllGroups: boolean = false;\n\n  operatorsNumeric: Operators[] = [\n    Operators.add,\n    Operators.subtract,\n    Operators.multiply,\n    Operators.divide,\n  ];\n  operatorsString: Operators[] = [\n    Operators.concatenateSpace,\n    Operators.concatenateCommaSpace,\n    Operators.concatenateComma,\n  ];\n\n  constructor(\n    private exportService: DataExportService,\n    private fb: FormBuilder\n  ) {\n    this.newGroupForm = this.fb.group({\n      name: ['', Validators.required],\n    });\n  }\n\n  ngOnInit() {\n    this.initializeGroupItems();\n    this.updateProfiles();\n  }\n\n  ngOnChanges() {\n    if (this.data) {\n      this.initializeGroupItems();\n    }\n  }\n\n  get visibleProfiles() {\n    return this.showAllProfiles ? this.profiles : this.profiles.slice(0, 3);\n  }\n\n  get visibleGroups() {\n    return this.showAllGroups ? this.groupItems : this.groupItems.slice(0, 3);\n  }\n\n  initializeGroupItems() {\n    if (this.data && this.data.length > 0) {\n      const properties = Object.keys(this.data[0]).filter((k) => k !== 'id');\n      this.exportService.setBaseProperties(properties);\n      this.numericProperties = properties.filter(\n        (prop) => typeof this.data[0][prop] === 'number'\n      );\n      this.stringProperties = properties.filter(\n        (prop) => typeof this.data[0][prop] === 'string'\n      );\n      this.updateGroupItems();\n    }\n  }\n\n  updateProfiles() {\n    this.profiles = this.exportService.getProfiles().map((profile) => ({\n      ...profile,\n      selected: false,\n    }));\n  }\n\n  updateGroupItems() {\n    this.groupItems = this.exportService.getAllItems().map((item) => ({\n      ...item,\n      selected: false,\n    }));\n  }\n\n  addGroup() {\n    console.log('in');\n    if (this.newGroupForm.valid) {\n      const selectedItems = this.groupItems.filter((item) => item.selected);\n      if (selectedItems.length > 0) {\n        const newProfile: ExportProfile = {\n          id: Date.now().toString(),\n          name: this.newGroupForm.get('name')?.value,\n          items: selectedItems,\n        };\n        this.exportService.addProfile(newProfile);\n        this.updateProfiles();\n        this.groupItems.forEach((item) => (item.selected = false));\n        this.newGroupForm.reset();\n        console.log('SELECTED');\n      }\n      console.log('VALID');\n    }\n  }\n\n  editProfile(profile: ExportProfile & { selected: boolean }) {\n    this.groupItems.forEach((item) => {\n      item.selected = profile.items.some(\n        (profileItem) => profileItem.id === item.id\n      );\n    });\n    this.removeProfile(profile);\n  }\n\n  removeProfile(profile: ExportProfile & { selected: boolean }) {\n    this.exportService.removeProfile(profile.id);\n    this.updateProfiles();\n  }\n\n  addOrUpdateOperation() {\n    if (\n      this.newOperation.name &&\n      this.newOperation.field1 &&\n      this.newOperation.field2\n    ) {\n      if (this.isEditingOperation) {\n        this.exportService.updateOperation(\n          this.newOperation.id,\n          this.newOperation\n        );\n      } else {\n        const operation: Operation = {\n          ...this.newOperation,\n          id: Date.now().toString(),\n        };\n        this.exportService.addOperation(operation);\n      }\n      this.updateGroupItems();\n      this.resetOperationForm();\n    }\n  }\n\n  editOperation(operation: ExportItem & { selected: boolean }) {\n    this.newOperation = { ...(operation as unknown as Operation) };\n    this.isEditingOperation = true;\n  }\n\n  removeOperation(operation: ExportItem & { selected: boolean }) {\n    this.exportService.removeOperation(operation.id);\n    this.updateGroupItems();\n  }\n\n  resetOperationForm() {\n    this.newOperation = {\n      id: '',\n      name: '',\n      field1: '',\n      operator: Operators.add,\n      field2: '',\n    };\n    this.isEditingOperation = false;\n  }\n\n  resetAll() {\n    this.exportService.resetAll();\n    this.initializeGroupItems();\n    this.updateProfiles();\n    this.resetOperationForm();\n    this.newGroupForm.reset();\n  }\n\n  exportData() {\n    const selectedProfiles = this.profiles.filter(\n      (profile) => profile.selected\n    );\n    if (selectedProfiles.length > 0) {\n      const exportedData = this.exportService.exportData(\n        this.data,\n        selectedProfiles\n      );\n      this.exportDataEvent.emit(exportedData);\n    } else {\n      console.log('No profiles selected for export');\n    }\n  }\n\n  onField1Change() {\n    this.newOperation.field2 = '';\n    this.newOperation.operator = this.isNumericField(this.newOperation.field1)\n      ? Operators.add\n      : Operators.concatenateSpace;\n  }\n\n  isNumericField(field: string): boolean {\n    return this.numericProperties.includes(field);\n  }\n\n  get availableOperators(): Operators[] {\n    return this.isNumericField(this.newOperation.field1)\n      ? this.operatorsNumeric\n      : this.operatorsString;\n  }\n\n  get availableFields2(): string[] {\n    return this.isNumericField(this.newOperation.field1)\n      ? this.numericProperties\n      : this.stringProperties;\n  }\n\n  toggleShowAllProfiles() {\n    this.showAllProfiles = !this.showAllProfiles;\n  }\n\n  toggleShowAllGroups() {\n    this.showAllGroups = !this.showAllGroups;\n  }\n}\n","<verben-card\n  width=\"24rem\"\n  borderRadius=\"1rem\"\n  [border]=\"'1px solid #D4A007'\"\n  bgColor=\"#FFFFFF\"\n  class=\"export-card\"\n>\n  <div card-header class=\"card-header\">\n    <h4 class=\"header-title\">Export</h4>\n    <button\n      class=\"reset-button\"\n      [style.color]=\"'#3479E9'\"\n      [style.background-color]=\"'transparent'\"\n      [style.border]=\"'none'\"\n      [style.cursor]=\"'pointer'\"\n      [style.font-size]=\"'12px'\"\n      (click)=\"resetAll()\"\n    >\n      Reset\n    </button>\n  </div>\n  <div card-body class=\"card-body\">\n    <section class=\"section\">\n      <div class=\"section-header\">\n        <h3 class=\"section-title\">Profiles</h3>\n        <verben-svg\n          icon=\"info\"\n          [width]=\"15\"\n          [height]=\"15\"\n          fill=\"grey\"\n        ></verben-svg>\n      </div>\n      <div *ngFor=\"let profile of visibleProfiles; let i = index\" class=\"item\">\n        <div class=\"item-label\">\n          <input\n            type=\"checkbox\"\n            [id]=\"'profile-' + i\"\n            [(ngModel)]=\"profile.selected\"\n          />\n          <label [for]=\"'profile-' + i\" class=\"checkbox-label\">\n            {{ profile.name }}\n          </label>\n        </div>\n        <div class=\"item-actions\">\n          <verben-svg\n            icon=\"edit\"\n            [width]=\"15\"\n            [height]=\"15\"\n            stroke=\"#3479E9\"\n            fill=\"white\"\n            (click)=\"editProfile(profile)\"\n          ></verben-svg>\n          <verben-svg\n            icon=\"delete\"\n            [width]=\"15\"\n            [height]=\"15\"\n            stroke=\"#E20000\"\n            (click)=\"removeProfile(profile)\"\n          ></verben-svg>\n        </div>\n      </div>\n      <div\n        *ngIf=\"profiles.length > 3\"\n        (click)=\"toggleShowAllProfiles()\"\n        class=\"show-more\"\n      >\n        <span>{{ showAllProfiles ? \"Show less\" : \"Show more\" }}</span>\n        <verben-svg\n          icon=\"chevron\"\n          [width]=\"8\"\n          [height]=\"6\"\n          fill=\"black\"\n          stroke=\"black\"\n        ></verben-svg>\n      </div>\n    </section>\n    <hr class=\"divider\" />\n    <section class=\"section\">\n      <div class=\"section-header\">\n        <h3 class=\"section-title\">Group</h3>\n        <verben-svg\n          icon=\"info\"\n          [width]=\"15\"\n          [height]=\"15\"\n          fill=\"grey\"\n        ></verben-svg>\n      </div>\n      <form [formGroup]=\"newGroupForm\" (ngSubmit)=\"addGroup()\">\n        <verbena-input\n          placeholder=\"Group name\"\n          border=\"1px solid #ccc\"\n          borderRadius=\"5px\"\n          textColor=\"black\"\n          width=\"100%\"\n          height=\"20px\"\n          pd=\"4px 6px\"\n          [showBorder]=\"true\"\n          [showErrorMessage]=\"true\"\n          [errorPosition]=\"'bottom'\"\n          formControlName=\"name\"\n        ></verbena-input>\n      </form>\n      <div *ngFor=\"let item of visibleGroups; let i = index\" class=\"item\">\n        <div class=\"item-label\">\n          <input\n            type=\"checkbox\"\n            [id]=\"'group-' + i\"\n            [(ngModel)]=\"item.selected\"\n          />\n          <label [for]=\"'group-' + i\" class=\"checkbox-label\">\n            {{ item.name }}\n          </label>\n        </div>\n        <div class=\"item-actions\" *ngIf=\"item.type === 'operation'\">\n          <verben-svg\n            icon=\"edit\"\n            [width]=\"15\"\n            [height]=\"15\"\n            stroke=\"#3479E9\"\n            fill=\"white\"\n            (click)=\"editOperation(item)\"\n          ></verben-svg>\n          <verben-svg\n            icon=\"delete\"\n            [width]=\"15\"\n            [height]=\"15\"\n            stroke=\"#E20000\"\n            (click)=\"removeOperation(item)\"\n          ></verben-svg>\n        </div>\n      </div>\n      <div\n        *ngIf=\"groupItems.length > 3\"\n        (click)=\"toggleShowAllGroups()\"\n        class=\"show-more\"\n      >\n        <span>{{ showAllGroups ? \"Show less\" : \"Show more\" }}</span>\n        <verben-svg\n          icon=\"chevron\"\n          [width]=\"8\"\n          [height]=\"6\"\n          fill=\"black\"\n          stroke=\"black\"\n        ></verben-svg>\n      </div>\n      <button class=\"add-button\" (click)=\"addGroup()\">+ Add</button>\n    </section>\n    <hr class=\"divider\" />\n    <section class=\"section\">\n      <div class=\"section-header\">\n        <h3 class=\"section-title\">Operation</h3>\n        <verben-svg\n          icon=\"info\"\n          [width]=\"15\"\n          [height]=\"15\"\n          fill=\"grey\"\n        ></verben-svg>\n      </div>\n      <verbena-input\n        placeholder=\"Operation name\"\n        border=\"1px solid #ccc\"\n        borderRadius=\"5px\"\n        textColor=\"black\"\n        width=\"100%\"\n        height=\"20px\"\n        pd=\"2px 6px\"\n        [showBorder]=\"true\"\n        [showErrorMessage]=\"true\"\n        [errorPosition]=\"'bottom'\"\n        [(ngModel)]=\"newOperation.name\"\n      ></verbena-input>\n      <div class=\"operation-grid\">\n        <verben-drop-down\n          width=\"'8rem'\"\n          placeholder=\"Select field\"\n          [options]=\"numericProperties.concat(stringProperties)\"\n          [(ngModel)]=\"newOperation.field1\"\n          (ngModelChange)=\"onField1Change()\"\n        >\n        </verben-drop-down>\n        <verben-drop-down\n          width=\"'8rem'\"\n          placeholder=\"Select operator\"\n          [options]=\"availableOperators\"\n          [(ngModel)]=\"newOperation.operator\"\n        >\n        </verben-drop-down>\n        <verben-drop-down\n          width=\"'8rem'\"\n          placeholder=\"Select field\"\n          [options]=\"availableFields2\"\n          [(ngModel)]=\"newOperation.field2\"\n        >\n        </verben-drop-down>\n      </div>\n      <button class=\"add-button\" (click)=\"addOrUpdateOperation()\">\n        {{ isEditingOperation ? \"Update\" : \"+ Add\" }}\n      </button>\n    </section>\n  </div>\n  <div card-footer class=\"card-footer\">\n    <button class=\"export-button\" (click)=\"exportData()\">Export</button>\n  </div>\n</verben-card>\n"]}
|
|
@@ -33,7 +33,7 @@ export class DataExportService {
|
|
|
33
33
|
this.profiles = this.profiles.filter((p) => p.id !== id);
|
|
34
34
|
}
|
|
35
35
|
addOperation(operation) {
|
|
36
|
-
this.operations.
|
|
36
|
+
this.operations.unshift(operation);
|
|
37
37
|
this.updateDefaultProfile();
|
|
38
38
|
}
|
|
39
39
|
getOperations() {
|
|
@@ -61,16 +61,16 @@ export class DataExportService {
|
|
|
61
61
|
}
|
|
62
62
|
getAllItems() {
|
|
63
63
|
return [
|
|
64
|
-
...this.baseProperties.map((prop) => ({
|
|
65
|
-
id: prop,
|
|
66
|
-
name: prop,
|
|
67
|
-
type: 'property',
|
|
68
|
-
})),
|
|
69
64
|
...this.operations.map((op) => ({
|
|
70
65
|
id: op.id,
|
|
71
66
|
name: op.name,
|
|
72
67
|
type: 'operation',
|
|
73
68
|
})),
|
|
69
|
+
...this.baseProperties.map((prop) => ({
|
|
70
|
+
id: prop,
|
|
71
|
+
name: prop,
|
|
72
|
+
type: 'property',
|
|
73
|
+
})),
|
|
74
74
|
];
|
|
75
75
|
}
|
|
76
76
|
getBaseProperties() {
|
|
@@ -132,4 +132,4 @@ export class DataExportService {
|
|
|
132
132
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: DataExportService, decorators: [{
|
|
133
133
|
type: Injectable
|
|
134
134
|
}], ctorParameters: () => [] });
|
|
135
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-export.service.js","sourceRoot":"","sources":["../../../../../../projects/verben-ng-ui/src/lib/components/data-export/data-export.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport {\n  ExportProfile,\n  Operation,\n  ExportItem,\n  ExportItemType,\n  Operators,\n} from './data-export.types';\n\n@Injectable()\nexport class DataExportService {\n  private profiles: ExportProfile[] = [];\n  private operations: Operation[] = [];\n  private baseProperties: string[] = [];\n\n  constructor() {\n    this.initializeDefaultProfile();\n  }\n\n  private initializeDefaultProfile() {\n    this.profiles = [\n      {\n        id: 'default',\n        name: 'All',\n        items: [],\n      },\n    ];\n  }\n\n  addProfile(profile: ExportProfile): void {\n    this.profiles.push(profile);\n  }\n\n  getProfiles(): ExportProfile[] {\n    return this.profiles;\n  }\n\n  updateProfile(id: string, updatedProfile: ExportProfile): void {\n    const index = this.profiles.findIndex((p) => p.id === id);\n    if (index !== -1) {\n      this.profiles[index] = updatedProfile;\n    }\n  }\n\n  removeProfile(id: string): void {\n    this.profiles = this.profiles.filter((p) => p.id !== id);\n  }\n\n  addOperation(operation: Operation): void {\n    this.operations.push(operation);\n    this.updateDefaultProfile();\n  }\n\n  getOperations(): Operation[] {\n    return this.operations;\n  }\n\n  updateOperation(id: string, updatedOperation: Operation): void {\n    const index = this.operations.findIndex((o) => o.id === id);\n    if (index !== -1) {\n      this.operations[index] = updatedOperation;\n      this.updateDefaultProfile();\n    }\n  }\n\n  removeOperation(id: string): void {\n    this.operations = this.operations.filter((o) => o.id !== id);\n    this.updateDefaultProfile();\n    // Remove operation from all profiles\n    this.profiles.forEach((profile) => {\n      profile.items = profile.items.filter((item) => item.id !== id);\n    });\n  }\n\n  resetAll(): void {\n    this.operations = [];\n    this.baseProperties = [];\n    this.initializeDefaultProfile();\n  }\n\n  getAllItems(): ExportItem[] {\n    return [\n      ...this.baseProperties.map((prop) => ({\n        id: prop,\n        name: prop,\n        type: 'property' as ExportItemType,\n      })),\n      ...this.operations.map((op) => ({\n        id: op.id,\n        name: op.name,\n        type: 'operation' as ExportItemType,\n      })),\n    ];\n  }\n\n  getBaseProperties(): string[] {\n    return this.baseProperties;\n  }\n\n  setBaseProperties(properties: string[]): void {\n    this.baseProperties = properties;\n    this.updateDefaultProfile();\n  }\n\n  private updateDefaultProfile(): void {\n    this.profiles[0].items = this.getAllItems();\n  }\n\n  exportData<T>(\n    data: T[],\n    selectedProfiles: ExportProfile[]\n  ): Record<string, any>[] {\n    const uniqueItems = new Set<ExportItem>();\n    selectedProfiles.forEach((profile) => {\n      profile.items.forEach((item) => uniqueItems.add(item));\n    });\n\n    return data.map((item) => {\n      const exportedItem: Record<string, any> = {};\n      uniqueItems.forEach((exportItem) => {\n        if (exportItem.type === 'property') {\n          exportedItem[exportItem.id] = (item as any)[exportItem.id];\n        } else {\n          const operation = this.operations.find((o) => o.id === exportItem.id);\n          if (operation) {\n            exportedItem[exportItem.id] = this.calculateOperation(\n              item,\n              operation\n            );\n          }\n        }\n      });\n      return exportedItem;\n    });\n  }\n\n  private calculateOperation<T>(\n    item: T,\n    operation: Operation\n  ): number | string {\n    const value1 = Number((item as any)[operation.field1]);\n    const value2 = Number((item as any)[operation.field2]);\n    switch (operation.operator) {\n      case Operators.add:\n        return value1 + value2;\n      case Operators.subtract:\n        return value1 - value2;\n      case Operators.multiply:\n        return value1 * value2;\n      case Operators.divide:\n        return value2 !== 0 ? value1 / value2 : NaN;\n      case Operators.concatenateSpace:\n        return `${value1} ${value2}`;\n      case Operators.concatenateCommaSpace:\n        return `${value1}, ${value2}`;\n      case Operators.concatenateComma:\n        return `${value1},${value2}`;\n      default:\n        return NaN;\n    }\n  }\n}\n"]}
|
|
135
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-export.service.js","sourceRoot":"","sources":["../../../../../../projects/verben-ng-ui/src/lib/components/data-export/data-export.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport {\n  ExportProfile,\n  Operation,\n  ExportItem,\n  ExportItemType,\n  Operators,\n} from './data-export.types';\n\n@Injectable()\nexport class DataExportService {\n  private profiles: ExportProfile[] = [];\n  private operations: Operation[] = [];\n  private baseProperties: string[] = [];\n\n  constructor() {\n    this.initializeDefaultProfile();\n  }\n\n  private initializeDefaultProfile() {\n    this.profiles = [\n      {\n        id: 'default',\n        name: 'All',\n        items: [],\n      },\n    ];\n  }\n\n  addProfile(profile: ExportProfile): void {\n    this.profiles.push(profile);\n  }\n\n  getProfiles(): ExportProfile[] {\n    return this.profiles;\n  }\n\n  updateProfile(id: string, updatedProfile: ExportProfile): void {\n    const index = this.profiles.findIndex((p) => p.id === id);\n    if (index !== -1) {\n      this.profiles[index] = updatedProfile;\n    }\n  }\n\n  removeProfile(id: string): void {\n    this.profiles = this.profiles.filter((p) => p.id !== id);\n  }\n\n  addOperation(operation: Operation): void {\n    this.operations.unshift(operation);\n    this.updateDefaultProfile();\n  }\n\n  getOperations(): Operation[] {\n    return this.operations;\n  }\n\n  updateOperation(id: string, updatedOperation: Operation): void {\n    const index = this.operations.findIndex((o) => o.id === id);\n    if (index !== -1) {\n      this.operations[index] = updatedOperation;\n      this.updateDefaultProfile();\n    }\n  }\n\n  removeOperation(id: string): void {\n    this.operations = this.operations.filter((o) => o.id !== id);\n    this.updateDefaultProfile();\n    // Remove operation from all profiles\n    this.profiles.forEach((profile) => {\n      profile.items = profile.items.filter((item) => item.id !== id);\n    });\n  }\n\n  resetAll(): void {\n    this.operations = [];\n    this.baseProperties = [];\n    this.initializeDefaultProfile();\n  }\n\n  getAllItems(): ExportItem[] {\n    return [\n      ...this.operations.map((op) => ({\n        id: op.id,\n        name: op.name,\n        type: 'operation' as ExportItemType,\n      })),\n      ...this.baseProperties.map((prop) => ({\n        id: prop,\n        name: prop,\n        type: 'property' as ExportItemType,\n      })),\n    ];\n  }\n\n  getBaseProperties(): string[] {\n    return this.baseProperties;\n  }\n\n  setBaseProperties(properties: string[]): void {\n    this.baseProperties = properties;\n    this.updateDefaultProfile();\n  }\n\n  private updateDefaultProfile(): void {\n    this.profiles[0].items = this.getAllItems();\n  }\n\n  exportData<T>(\n    data: T[],\n    selectedProfiles: ExportProfile[]\n  ): Record<string, any>[] {\n    const uniqueItems = new Set<ExportItem>();\n    selectedProfiles.forEach((profile) => {\n      profile.items.forEach((item) => uniqueItems.add(item));\n    });\n\n    return data.map((item) => {\n      const exportedItem: Record<string, any> = {};\n      uniqueItems.forEach((exportItem) => {\n        if (exportItem.type === 'property') {\n          exportedItem[exportItem.id] = (item as any)[exportItem.id];\n        } else {\n          const operation = this.operations.find((o) => o.id === exportItem.id);\n          if (operation) {\n            exportedItem[exportItem.id] = this.calculateOperation(\n              item,\n              operation\n            );\n          }\n        }\n      });\n      return exportedItem;\n    });\n  }\n\n  private calculateOperation<T>(\n    item: T,\n    operation: Operation\n  ): number | string {\n    const value1 = Number((item as any)[operation.field1]);\n    const value2 = Number((item as any)[operation.field2]);\n    switch (operation.operator) {\n      case Operators.add:\n        return value1 + value2;\n      case Operators.subtract:\n        return value1 - value2;\n      case Operators.multiply:\n        return value1 * value2;\n      case Operators.divide:\n        return value2 !== 0 ? value1 / value2 : NaN;\n      case Operators.concatenateSpace:\n        return `${value1} ${value2}`;\n      case Operators.concatenateCommaSpace:\n        return `${value1}, ${value2}`;\n      case Operators.concatenateComma:\n        return `${value1},${value2}`;\n      default:\n        return NaN;\n    }\n  }\n}\n"]}
|
|
@@ -1,10 +1,13 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Input, Output, signal, } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, ContentChildren, EventEmitter, Input, Output, signal, } from '@angular/core';
|
|
2
2
|
import { ColumnDirective } from './column.directive';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "@angular/common";
|
|
5
5
|
export class DataTableComponent {
|
|
6
6
|
data;
|
|
7
|
-
columns
|
|
7
|
+
// Modify columns input to use a signal
|
|
8
|
+
set columns(value) {
|
|
9
|
+
this.columnsSignal.set(value);
|
|
10
|
+
}
|
|
8
11
|
styleConfig = defaultTableStyles;
|
|
9
12
|
columnTemplates;
|
|
10
13
|
rowEdit = new EventEmitter();
|
|
@@ -15,25 +18,35 @@ export class DataTableComponent {
|
|
|
15
18
|
selectedRowsSignal = signal(new Set());
|
|
16
19
|
editedDataSignal = signal(new Map());
|
|
17
20
|
columnsSignal = signal([]);
|
|
21
|
+
hasFooter = computed(() => this.columnsSignal().some((col) => col.footerTemplate !== undefined));
|
|
22
|
+
ngOnInit() {
|
|
23
|
+
// Set initial columns if not already set
|
|
24
|
+
if (this.columnsSignal().length === 0) {
|
|
25
|
+
this.columnsSignal.set(this.columns);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
18
28
|
ngAfterContentInit() {
|
|
19
29
|
this.columnTemplates.changes.subscribe(() => this.mergeColumnTemplates());
|
|
20
30
|
this.mergeColumnTemplates();
|
|
21
31
|
}
|
|
22
32
|
mergeColumnTemplates() {
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
33
|
+
// Only merge if we have both columns and templates
|
|
34
|
+
if (this.columnsSignal().length > 0) {
|
|
35
|
+
const updatedColumns = this.columnsSignal().map((column) => {
|
|
36
|
+
const matchingTemplate = this.columnTemplates.find((t) => t.columnId === column.id);
|
|
37
|
+
if (matchingTemplate) {
|
|
38
|
+
return {
|
|
39
|
+
...column,
|
|
40
|
+
cellTemplate: matchingTemplate.cellTemplate,
|
|
41
|
+
cellEditTemplate: matchingTemplate.cellEditTemplate,
|
|
42
|
+
headerTemplate: matchingTemplate.headerTemplate,
|
|
43
|
+
footerTemplate: matchingTemplate.footerTemplate,
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
return column;
|
|
47
|
+
});
|
|
48
|
+
this.columnsSignal.set(updatedColumns);
|
|
49
|
+
}
|
|
37
50
|
}
|
|
38
51
|
getCellValue = (row, column) => {
|
|
39
52
|
if (column.accessorKey) {
|
|
@@ -270,11 +283,11 @@ export class DataTableComponent {
|
|
|
270
283
|
return cellStyle;
|
|
271
284
|
}
|
|
272
285
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: DataTableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
273
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.5", type: DataTableComponent, selector: "lib-data-table", inputs: { data: "data", columns: "columns", styleConfig: "styleConfig" }, outputs: { rowEdit: "rowEdit", rowSave: "rowSave", rowDelete: "rowDelete", selectionChange: "selectionChange" }, queries: [{ propertyName: "columnTemplates", predicate: ColumnDirective }], ngImport: i0, template: "<table [ngStyle]=\"getTableStyle()\">\n <thead>\n <tr [ngStyle]=\"getHeaderStyle()\">\n @for (column of columnsSignal(); track column.id) {\n <th [ngStyle]=\"getCellStyle(-1, $index)\">\n @if (column.headerTemplate) {\n <ng-container\n [ngTemplateOutlet]=\"column.headerTemplate\"\n [ngTemplateOutletContext]=\"getHeaderContext(column)\"\n ></ng-container>\n } @else {\n {{ column.header }}\n }\n </th>\n }\n </tr>\n </thead>\n <tbody>\n @for (row of data; track row.id; let rowIndex = $index) {\n <tr [ngStyle]=\"getRowStyle(rowIndex)\">\n @for (column of columnsSignal(); track column.id; let colIndex = $index) {\n <td [ngStyle]=\"getCellStyle(rowIndex, colIndex)\">\n @if (isRowEditing(row.id) && column.cellEditTemplate) {\n <ng-container\n [ngTemplateOutlet]=\"column.cellEditTemplate\"\n [ngTemplateOutletContext]=\"getCellContext(row, column, rowIndex)\"\n ></ng-container>\n } @else if (column.cellTemplate) {\n <ng-container\n [ngTemplateOutlet]=\"column.cellTemplate\"\n [ngTemplateOutletContext]=\"getCellContext(row, column, rowIndex)\"\n ></ng-container>\n } @else {\n {{ getCellValue(row, column) }}\n }\n </td>\n }\n </tr>\n }\n </tbody>\n <tfoot>\n <tr [ngStyle]=\"getFooterStyle()\">\n @for (column of columnsSignal(); track column.id) {\n <td [ngStyle]=\"getCellStyle(-1, $index)\">\n @if (column.footerTemplate) {\n <ng-container\n [ngTemplateOutlet]=\"column.footerTemplate\"\n [ngTemplateOutletContext]=\"getFooterContext(column)\"\n ></ng-container>\n }\n </td>\n }\n </tr>\n </tfoot>\n</table>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
286
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.5", type: DataTableComponent, selector: "lib-data-table", inputs: { data: "data", columns: "columns", styleConfig: "styleConfig" }, outputs: { rowEdit: "rowEdit", rowSave: "rowSave", rowDelete: "rowDelete", selectionChange: "selectionChange" }, queries: [{ propertyName: "columnTemplates", predicate: ColumnDirective }], ngImport: i0, template: "<table [ngStyle]=\"getTableStyle()\">\n <thead>\n <tr [ngStyle]=\"getHeaderStyle()\">\n @for (column of columnsSignal(); track column.id) {\n <th [ngStyle]=\"getCellStyle(-1, $index)\">\n @if (column.headerTemplate) {\n <ng-container\n [ngTemplateOutlet]=\"column.headerTemplate\"\n [ngTemplateOutletContext]=\"getHeaderContext(column)\"\n ></ng-container>\n } @else {\n {{ column.header }}\n }\n </th>\n }\n </tr>\n </thead>\n <tbody>\n @for (row of data; track row.id; let rowIndex = $index) {\n <tr [ngStyle]=\"getRowStyle(rowIndex)\">\n @for (column of columnsSignal(); track column.id; let colIndex = $index) {\n <td [ngStyle]=\"getCellStyle(rowIndex, colIndex)\">\n @if (isRowEditing(row.id) && column.cellEditTemplate) {\n <ng-container\n [ngTemplateOutlet]=\"column.cellEditTemplate\"\n [ngTemplateOutletContext]=\"getCellContext(row, column, rowIndex)\"\n ></ng-container>\n } @else if (column.cellTemplate) {\n <ng-container\n [ngTemplateOutlet]=\"column.cellTemplate\"\n [ngTemplateOutletContext]=\"getCellContext(row, column, rowIndex)\"\n ></ng-container>\n } @else {\n {{ getCellValue(row, column) }}\n }\n </td>\n }\n </tr>\n }\n </tbody>\n @if (hasFooter()) {\n <tfoot>\n <tr [ngStyle]=\"getFooterStyle()\">\n @for (column of columnsSignal(); track column.id) {\n <td [ngStyle]=\"getCellStyle(-1, $index)\">\n @if (column.footerTemplate) {\n <ng-container\n [ngTemplateOutlet]=\"column.footerTemplate\"\n [ngTemplateOutletContext]=\"getFooterContext(column)\"\n ></ng-container>\n }\n </td>\n }\n </tr>\n </tfoot>\n }\n</table>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
274
287
|
}
|
|
275
288
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: DataTableComponent, decorators: [{
|
|
276
289
|
type: Component,
|
|
277
|
-
args: [{ selector: 'lib-data-table', changeDetection: ChangeDetectionStrategy.OnPush, template: "<table [ngStyle]=\"getTableStyle()\">\n <thead>\n <tr [ngStyle]=\"getHeaderStyle()\">\n @for (column of columnsSignal(); track column.id) {\n <th [ngStyle]=\"getCellStyle(-1, $index)\">\n @if (column.headerTemplate) {\n <ng-container\n [ngTemplateOutlet]=\"column.headerTemplate\"\n [ngTemplateOutletContext]=\"getHeaderContext(column)\"\n ></ng-container>\n } @else {\n {{ column.header }}\n }\n </th>\n }\n </tr>\n </thead>\n <tbody>\n @for (row of data; track row.id; let rowIndex = $index) {\n <tr [ngStyle]=\"getRowStyle(rowIndex)\">\n @for (column of columnsSignal(); track column.id; let colIndex = $index) {\n <td [ngStyle]=\"getCellStyle(rowIndex, colIndex)\">\n @if (isRowEditing(row.id) && column.cellEditTemplate) {\n <ng-container\n [ngTemplateOutlet]=\"column.cellEditTemplate\"\n [ngTemplateOutletContext]=\"getCellContext(row, column, rowIndex)\"\n ></ng-container>\n } @else if (column.cellTemplate) {\n <ng-container\n [ngTemplateOutlet]=\"column.cellTemplate\"\n [ngTemplateOutletContext]=\"getCellContext(row, column, rowIndex)\"\n ></ng-container>\n } @else {\n {{ getCellValue(row, column) }}\n }\n </td>\n }\n </tr>\n }\n </tbody>\n <tfoot>\n <tr [ngStyle]=\"getFooterStyle()\">\n @for (column of columnsSignal(); track column.id) {\n <td [ngStyle]=\"getCellStyle(-1, $index)\">\n @if (column.footerTemplate) {\n <ng-container\n [ngTemplateOutlet]=\"column.footerTemplate\"\n [ngTemplateOutletContext]=\"getFooterContext(column)\"\n ></ng-container>\n }\n </td>\n }\n </tr>\n </tfoot>\n</table>\n" }]
|
|
290
|
+
args: [{ selector: 'lib-data-table', changeDetection: ChangeDetectionStrategy.OnPush, template: "<table [ngStyle]=\"getTableStyle()\">\n <thead>\n <tr [ngStyle]=\"getHeaderStyle()\">\n @for (column of columnsSignal(); track column.id) {\n <th [ngStyle]=\"getCellStyle(-1, $index)\">\n @if (column.headerTemplate) {\n <ng-container\n [ngTemplateOutlet]=\"column.headerTemplate\"\n [ngTemplateOutletContext]=\"getHeaderContext(column)\"\n ></ng-container>\n } @else {\n {{ column.header }}\n }\n </th>\n }\n </tr>\n </thead>\n <tbody>\n @for (row of data; track row.id; let rowIndex = $index) {\n <tr [ngStyle]=\"getRowStyle(rowIndex)\">\n @for (column of columnsSignal(); track column.id; let colIndex = $index) {\n <td [ngStyle]=\"getCellStyle(rowIndex, colIndex)\">\n @if (isRowEditing(row.id) && column.cellEditTemplate) {\n <ng-container\n [ngTemplateOutlet]=\"column.cellEditTemplate\"\n [ngTemplateOutletContext]=\"getCellContext(row, column, rowIndex)\"\n ></ng-container>\n } @else if (column.cellTemplate) {\n <ng-container\n [ngTemplateOutlet]=\"column.cellTemplate\"\n [ngTemplateOutletContext]=\"getCellContext(row, column, rowIndex)\"\n ></ng-container>\n } @else {\n {{ getCellValue(row, column) }}\n }\n </td>\n }\n </tr>\n }\n </tbody>\n @if (hasFooter()) {\n <tfoot>\n <tr [ngStyle]=\"getFooterStyle()\">\n @for (column of columnsSignal(); track column.id) {\n <td [ngStyle]=\"getCellStyle(-1, $index)\">\n @if (column.footerTemplate) {\n <ng-container\n [ngTemplateOutlet]=\"column.footerTemplate\"\n [ngTemplateOutletContext]=\"getFooterContext(column)\"\n ></ng-container>\n }\n </td>\n }\n </tr>\n </tfoot>\n }\n</table>\n" }]
|
|
278
291
|
}], propDecorators: { data: [{
|
|
279
292
|
type: Input,
|
|
280
293
|
args: [{ required: true }]
|
|
@@ -337,4 +350,4 @@ const defaultTableStyles = {
|
|
|
337
350
|
borderTop: '2px solid #e0e0e0',
|
|
338
351
|
},
|
|
339
352
|
};
|
|
340
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-ng-ui/src/lib/components/data-table/data-table.component.ts","../../../../../../projects/verben-ng-ui/src/lib/components/data-table/data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  Input,\n  Output,\n  QueryList,\n  Signal,\n  signal,\n  WritableSignal,\n} from '@angular/core';\nimport { ColumnDefinition } from './data-table.types';\nimport { ColumnDirective } from './column.directive';\nimport { BaseStyles, TableStyles } from './style.types';\n\n@Component({\n  selector: 'lib-data-table',\n  templateUrl: './data-table.component.html',\n  styleUrl: './data-table.component.css',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DataTableComponent<T extends { id: string | number }>\n  implements AfterContentInit\n{\n  @Input({ required: true }) data!: T[];\n  @Input({ required: true }) columns!: ColumnDefinition<T>[];\n\n  @Input() styleConfig: TableStyles = defaultTableStyles;\n\n  @ContentChildren(ColumnDirective)\n  columnTemplates!: QueryList<ColumnDirective>;\n\n  @Output() rowEdit = new EventEmitter<T>();\n  @Output() rowSave = new EventEmitter<T>();\n  @Output() rowDelete = new EventEmitter<T>();\n  @Output() selectionChange = new EventEmitter<T[]>();\n\n  private editingRowsSignal = signal<Set<string | number>>(new Set());\n  private selectedRowsSignal = signal<Set<string | number>>(new Set());\n  private editedDataSignal = signal<Map<string | number, EditedData<T>>>(\n    new Map()\n  );\n\n  columnsSignal: WritableSignal<ColumnDefinition<T>[]> = signal([]);\n\n  ngAfterContentInit() {\n    this.columnTemplates.changes.subscribe(() => this.mergeColumnTemplates());\n    this.mergeColumnTemplates();\n  }\n\n  private mergeColumnTemplates() {\n    const updatedColumns = this.columns.map((column) => {\n      const matchingTemplate = this.columnTemplates.find(\n        (t) => t.columnId === column.id\n      );\n      if (matchingTemplate) {\n        return {\n          ...column,\n          cellTemplate: matchingTemplate.cellTemplate,\n          cellEditTemplate: matchingTemplate.cellEditTemplate,\n          headerTemplate: matchingTemplate.headerTemplate,\n          footerTemplate: matchingTemplate.footerTemplate,\n        };\n      }\n      return column;\n    });\n    this.columnsSignal.set(updatedColumns);\n  }\n\n  getCellValue = (row: T, column: ColumnDefinition<T>): any => {\n    if (column.accessorKey) {\n      return (row as any)[column.accessorKey];\n    }\n    return column.accessorFn ? column.accessorFn(row) : undefined;\n  };\n\n  isRowEditing = (rowId: string | number): boolean => {\n    return this.editingRowsSignal().has(rowId);\n  };\n\n  toggleRowEdit = (rowId: string | number) => {\n    this.editingRowsSignal.update((set) => {\n      const newSet = new Set(set);\n      if (newSet.has(rowId)) {\n        newSet.delete(rowId);\n        this.saveRow(rowId);\n      } else {\n        newSet.add(rowId);\n        this.initializeEditedData(rowId);\n      }\n      return newSet;\n    });\n  };\n\n  private initializeEditedData(rowId: string | number) {\n    const row = this.data.find((r) => r.id === rowId);\n    if (row) {\n      this.editedDataSignal.update((map) => {\n        const newMap = new Map(map);\n        newMap.set(rowId, { ...row });\n        return newMap;\n      });\n    }\n  }\n\n  private saveRow(rowId: string | number) {\n    const editedData = this.editedDataSignal().get(rowId);\n    if (editedData) {\n      const originalRowIndex = this.data.findIndex((r) => r.id === rowId);\n      if (originalRowIndex !== -1) {\n        const updatedRow = { ...this.data[originalRowIndex], ...editedData };\n        this.data[originalRowIndex] = updatedRow;\n        this.rowSave.emit(updatedRow);\n        this.editedDataSignal.update((map) => {\n          const newMap = new Map(map);\n          newMap.delete(rowId);\n          return newMap;\n        });\n      }\n    }\n  }\n\n  isRowSelected = (rowId: string | number): boolean => {\n    return this.selectedRowsSignal().has(rowId);\n  };\n\n  toggleRowSelection = (rowId: string | number) => {\n    this.selectedRowsSignal.update((set) => {\n      const newSet = new Set(set);\n      if (newSet.has(rowId)) {\n        newSet.delete(rowId);\n      } else {\n        newSet.add(rowId);\n      }\n      this.emitSelectionChange();\n      return newSet;\n    });\n  };\n\n  allRowsSelected = (): boolean => {\n    return this.selectedRowsSignal().size === this.data.length;\n  };\n\n  someRowsSelected = (): boolean => {\n    return (\n      this.selectedRowsSignal().size > 0 &&\n      this.selectedRowsSignal().size < this.data.length\n    );\n  };\n\n  toggleAllRows = () => {\n    if (this.allRowsSelected()) {\n      this.selectedRowsSignal.set(new Set());\n    } else {\n      this.selectedRowsSignal.set(new Set(this.data.map((row) => row.id)));\n    }\n    this.emitSelectionChange();\n  };\n\n  private emitSelectionChange() {\n    const selectedRows = this.data.filter((row) =>\n      this.selectedRowsSignal().has(row.id)\n    );\n    this.selectionChange.emit(selectedRows);\n  }\n\n  getHeaderContext(column: ColumnDefinition<T>) {\n    return {\n      $implicit: column,\n      column,\n      allRowsSelected: this.allRowsSelected,\n      someRowsSelected: this.someRowsSelected,\n      toggleAllRows: this.toggleAllRows,\n    };\n  }\n\n  updateEditedValue(rowId: string | number, columnId: keyof T, value: any) {\n    this.editedDataSignal.update((map) => {\n      const newMap = new Map(map);\n      const rowData = newMap.get(rowId) || ({} as EditedData<T>);\n      newMap.set(rowId, { ...rowData, [columnId]: value });\n      return newMap;\n    });\n  }\n\n  updateNestedEditedValue(\n    rowId: string | number,\n    columnId: keyof T,\n    nestedField: string,\n    value: any\n  ) {\n    this.editedDataSignal.update((map) => {\n      const newMap = new Map(map);\n      const rowData = newMap.get(rowId) || ({} as EditedData<T>);\n      const columnData = (rowData[columnId] as any) || {};\n      newMap.set(rowId, {\n        ...rowData,\n        [columnId]: {\n          ...columnData,\n          [nestedField]: value,\n        },\n      });\n      return newMap;\n    });\n  }\n\n  getCellContext(row: T, column: ColumnDefinition<T>, rowIndex: number) {\n    const rowId = row.id;\n    const isEditing = this.isRowEditing(rowId);\n    const editedData = this.editedDataSignal().get(rowId);\n\n    let value: any;\n    if (isEditing && editedData && column.id in editedData) {\n      value = editedData[column.id as keyof T];\n    } else {\n      value = this.getCellValue(row, column);\n    }\n\n    return {\n      $implicit: value,\n      value,\n      row,\n      column,\n      rowIndex,\n      isEditing,\n      isSelected: this.isRowSelected(rowId),\n      toggleRowSelection: () => this.toggleRowSelection(rowId),\n      toggleRowEdit: () => this.toggleRowEdit(rowId),\n      deleteRow: () => this.deleteRow(rowId),\n      updateValue: (newValue: any) =>\n        this.updateEditedValue(rowId, column.id as keyof T, newValue),\n      updateNestedValue: (nestedField: string, newValue: any) =>\n        this.updateNestedEditedValue(\n          rowId,\n          column.id as keyof T,\n          nestedField,\n          newValue\n        ),\n    };\n  }\n\n  deleteRow = (rowId: string | number) => {\n    const rowToDelete = this.data.find((row) => row.id === rowId);\n    if (rowToDelete) {\n      this.rowDelete.emit(rowToDelete);\n    }\n  };\n\n  getFooterContext(column: ColumnDefinition<T>) {\n    return {\n      $implicit: column,\n      column,\n      data: this.data,\n    };\n  }\n\n  getTableStyle(): any {\n    return {\n      ...this.styleConfig,\n      fontFamily: this.styleConfig.fontFamily,\n      fontSize: this.styleConfig.fontSize,\n      whiteSpace: this.styleConfig.whiteSpace,\n      margin: this.styleConfig.margin,\n      border: this.styleConfig.border,\n      borderCollapse: this.styleConfig.borderCollapse,\n      borderSpacing: this.styleConfig.borderSpacing,\n      tableLayout: this.styleConfig.tableLayout,\n      width: this.styleConfig.width,\n    };\n  }\n\n  getHeaderStyle(): any {\n    return {\n      ...this.styleConfig.header,\n      position: this.styleConfig.header?.stickyTop ? 'sticky' : 'static',\n      top: this.styleConfig.header?.stickyTop ? '0' : 'auto',\n      zIndex: this.styleConfig.header?.zIndex || 'auto',\n    };\n  }\n\n  getFooterStyle(): any {\n    return {\n      ...this.styleConfig.footer,\n      position: this.styleConfig.footer?.stickyBottom ? 'sticky' : 'static',\n      bottom: this.styleConfig.footer?.stickyBottom ? '0' : 'auto',\n      zIndex: this.styleConfig.footer?.zIndex || 'auto',\n    };\n  }\n\n  getRowStyle(rowIndex: number): any {\n    const rowStyles = this.styleConfig.rows;\n    if (rowStyles && 'even' in rowStyles && 'odd' in rowStyles) {\n      return rowIndex % 2 === 0 ? rowStyles.even : rowStyles.odd;\n    } else if (rowStyles && 'nth' in rowStyles && rowStyles.nth) {\n      const { interval, style } = rowStyles.nth;\n      return (rowIndex + 1) % (interval || 1) === 0 ? style : {};\n    } else {\n      return rowStyles || {};\n    }\n  }\n\n  getCellStyle(rowIndex: number, colIndex: number): any {\n    const isFirstColumn = colIndex === 0;\n    const isLastColumn = colIndex === this.columnsSignal().length - 1;\n\n    let cellStyle = { ...this.styleConfig.cells };\n\n    if (isFirstColumn) {\n      cellStyle = {\n        ...cellStyle,\n        ...this.styleConfig.firstColumn,\n        position: this.styleConfig.firstColumn?.stickyLeft\n          ? 'sticky'\n          : 'static',\n        left: this.styleConfig.firstColumn?.stickyLeft ? '0' : 'auto',\n        zIndex: this.styleConfig.firstColumn?.zIndex || 'auto',\n      };\n    } else if (isLastColumn) {\n      cellStyle = {\n        ...cellStyle,\n        ...this.styleConfig.lastColumn,\n        position: this.styleConfig.lastColumn?.stickyRight\n          ? 'sticky'\n          : 'static',\n        right: this.styleConfig.lastColumn?.stickyRight ? '0' : 'auto',\n        zIndex: this.styleConfig.lastColumn?.zIndex || 'auto',\n      };\n    }\n\n    if (rowIndex >= 0) {\n      // Apply body styles to all cells\n      cellStyle = { ...cellStyle, ...this.styleConfig.body };\n    } else {\n      cellStyle = { ...this.styleConfig.header };\n    }\n\n    return cellStyle;\n  }\n}\n\ntype EditedData<T> = {\n  [K in keyof T]?: T[K] extends object ? Partial<T[K]> : T[K];\n};\n\n// Default styles\nconst defaultTableStyles: TableStyles = {\n  border: '1px solid #e0e0e0',\n  borderRadius: '4px',\n  overflow: 'hidden',\n  boxShadow: '0 2px 4px rgba(0,0,0,0.1)',\n  width: '100%',\n  header: {\n    backgroundColor: '#f5f5f5',\n    fontWeight: 'bold',\n    color: '#333',\n    textAlign: 'left',\n    padding: '12px 16px',\n    borderBottom: '2px solid #e0e0e0',\n  },\n  rows: {\n    even: {\n      backgroundColor: '#ffffff',\n    },\n    odd: {\n      backgroundColor: '#f9f9f9',\n    },\n    nth: {\n      interval: 5,\n      style: {\n        backgroundColor: '#f0f0f0',\n      },\n    },\n  },\n  cells: {\n    padding: '12px 16px',\n    borderBottom: '1px solid #e0e0e0',\n  },\n  footer: {\n    backgroundColor: '#f5f5f5',\n    fontWeight: 'bold',\n    color: '#333',\n    textAlign: 'left',\n    padding: '12px 16px',\n    borderTop: '2px solid #e0e0e0',\n  },\n};\n","<table [ngStyle]=\"getTableStyle()\">\n  <thead>\n    <tr [ngStyle]=\"getHeaderStyle()\">\n      @for (column of columnsSignal(); track column.id) {\n      <th [ngStyle]=\"getCellStyle(-1, $index)\">\n        @if (column.headerTemplate) {\n        <ng-container\n          [ngTemplateOutlet]=\"column.headerTemplate\"\n          [ngTemplateOutletContext]=\"getHeaderContext(column)\"\n        ></ng-container>\n        } @else {\n        {{ column.header }}\n        }\n      </th>\n      }\n    </tr>\n  </thead>\n  <tbody>\n    @for (row of data; track row.id; let rowIndex = $index) {\n    <tr [ngStyle]=\"getRowStyle(rowIndex)\">\n      @for (column of columnsSignal(); track column.id; let colIndex = $index) {\n      <td [ngStyle]=\"getCellStyle(rowIndex, colIndex)\">\n        @if (isRowEditing(row.id) && column.cellEditTemplate) {\n        <ng-container\n          [ngTemplateOutlet]=\"column.cellEditTemplate\"\n          [ngTemplateOutletContext]=\"getCellContext(row, column, rowIndex)\"\n        ></ng-container>\n        } @else if (column.cellTemplate) {\n        <ng-container\n          [ngTemplateOutlet]=\"column.cellTemplate\"\n          [ngTemplateOutletContext]=\"getCellContext(row, column, rowIndex)\"\n        ></ng-container>\n        } @else {\n        {{ getCellValue(row, column) }}\n        }\n      </td>\n      }\n    </tr>\n    }\n  </tbody>\n  <tfoot>\n    <tr [ngStyle]=\"getFooterStyle()\">\n      @for (column of columnsSignal(); track column.id) {\n      <td [ngStyle]=\"getCellStyle(-1, $index)\">\n        @if (column.footerTemplate) {\n        <ng-container\n          [ngTemplateOutlet]=\"column.footerTemplate\"\n          [ngTemplateOutletContext]=\"getFooterContext(column)\"\n        ></ng-container>\n        }\n      </td>\n      }\n    </tr>\n  </tfoot>\n</table>\n"]}
|
|
353
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-ng-ui/src/lib/components/data-table/data-table.component.ts","../../../../../../projects/verben-ng-ui/src/lib/components/data-table/data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  computed,\n  ContentChildren,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  QueryList,\n  Signal,\n  signal,\n  WritableSignal,\n} from '@angular/core';\nimport { ColumnDefinition } from './data-table.types';\nimport { ColumnDirective } from './column.directive';\nimport { BaseStyles, TableStyles } from './style.types';\n\n@Component({\n  selector: 'lib-data-table',\n  templateUrl: './data-table.component.html',\n  styleUrl: './data-table.component.css',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DataTableComponent<T extends { id: string | number }>\n  implements OnInit, AfterContentInit\n{\n  @Input({ required: true }) data!: T[];\n  // Modify columns input to use a signal\n  @Input({ required: true })\n  set columns(value: ColumnDefinition<T>[]) {\n    this.columnsSignal.set(value);\n  }\n\n  @Input() styleConfig: TableStyles = defaultTableStyles;\n\n  @ContentChildren(ColumnDirective)\n  columnTemplates!: QueryList<ColumnDirective>;\n\n  @Output() rowEdit = new EventEmitter<T>();\n  @Output() rowSave = new EventEmitter<T>();\n  @Output() rowDelete = new EventEmitter<T>();\n  @Output() selectionChange = new EventEmitter<T[]>();\n\n  private editingRowsSignal = signal<Set<string | number>>(new Set());\n  private selectedRowsSignal = signal<Set<string | number>>(new Set());\n  private editedDataSignal = signal<Map<string | number, EditedData<T>>>(\n    new Map()\n  );\n\n  columnsSignal: WritableSignal<ColumnDefinition<T>[]> = signal([]);\n\n  hasFooter = computed(() =>\n    this.columnsSignal().some((col) => col.footerTemplate !== undefined)\n  );\n\n  ngOnInit() {\n    // Set initial columns if not already set\n    if (this.columnsSignal().length === 0) {\n      this.columnsSignal.set(this.columns);\n    }\n  }\n\n  ngAfterContentInit() {\n    this.columnTemplates.changes.subscribe(() => this.mergeColumnTemplates());\n    this.mergeColumnTemplates();\n  }\n\n  private mergeColumnTemplates() {\n    // Only merge if we have both columns and templates\n    if (this.columnsSignal().length > 0) {\n      const updatedColumns = this.columnsSignal().map((column) => {\n        const matchingTemplate = this.columnTemplates.find(\n          (t) => t.columnId === column.id\n        );\n        if (matchingTemplate) {\n          return {\n            ...column,\n            cellTemplate: matchingTemplate.cellTemplate,\n            cellEditTemplate: matchingTemplate.cellEditTemplate,\n            headerTemplate: matchingTemplate.headerTemplate,\n            footerTemplate: matchingTemplate.footerTemplate,\n          };\n        }\n        return column;\n      });\n      this.columnsSignal.set(updatedColumns);\n    }\n  }\n\n  getCellValue = (row: T, column: ColumnDefinition<T>): any => {\n    if (column.accessorKey) {\n      return (row as any)[column.accessorKey];\n    }\n    return column.accessorFn ? column.accessorFn(row) : undefined;\n  };\n\n  isRowEditing = (rowId: string | number): boolean => {\n    return this.editingRowsSignal().has(rowId);\n  };\n\n  toggleRowEdit = (rowId: string | number) => {\n    this.editingRowsSignal.update((set) => {\n      const newSet = new Set(set);\n      if (newSet.has(rowId)) {\n        newSet.delete(rowId);\n        this.saveRow(rowId);\n      } else {\n        newSet.add(rowId);\n        this.initializeEditedData(rowId);\n      }\n      return newSet;\n    });\n  };\n\n  private initializeEditedData(rowId: string | number) {\n    const row = this.data.find((r) => r.id === rowId);\n    if (row) {\n      this.editedDataSignal.update((map) => {\n        const newMap = new Map(map);\n        newMap.set(rowId, { ...row });\n        return newMap;\n      });\n    }\n  }\n\n  private saveRow(rowId: string | number) {\n    const editedData = this.editedDataSignal().get(rowId);\n    if (editedData) {\n      const originalRowIndex = this.data.findIndex((r) => r.id === rowId);\n      if (originalRowIndex !== -1) {\n        const updatedRow = { ...this.data[originalRowIndex], ...editedData };\n        this.data[originalRowIndex] = updatedRow;\n        this.rowSave.emit(updatedRow);\n        this.editedDataSignal.update((map) => {\n          const newMap = new Map(map);\n          newMap.delete(rowId);\n          return newMap;\n        });\n      }\n    }\n  }\n\n  isRowSelected = (rowId: string | number): boolean => {\n    return this.selectedRowsSignal().has(rowId);\n  };\n\n  toggleRowSelection = (rowId: string | number) => {\n    this.selectedRowsSignal.update((set) => {\n      const newSet = new Set(set);\n      if (newSet.has(rowId)) {\n        newSet.delete(rowId);\n      } else {\n        newSet.add(rowId);\n      }\n      this.emitSelectionChange();\n      return newSet;\n    });\n  };\n\n  allRowsSelected = (): boolean => {\n    return this.selectedRowsSignal().size === this.data.length;\n  };\n\n  someRowsSelected = (): boolean => {\n    return (\n      this.selectedRowsSignal().size > 0 &&\n      this.selectedRowsSignal().size < this.data.length\n    );\n  };\n\n  toggleAllRows = () => {\n    if (this.allRowsSelected()) {\n      this.selectedRowsSignal.set(new Set());\n    } else {\n      this.selectedRowsSignal.set(new Set(this.data.map((row) => row.id)));\n    }\n    this.emitSelectionChange();\n  };\n\n  private emitSelectionChange() {\n    const selectedRows = this.data.filter((row) =>\n      this.selectedRowsSignal().has(row.id)\n    );\n    this.selectionChange.emit(selectedRows);\n  }\n\n  getHeaderContext(column: ColumnDefinition<T>) {\n    return {\n      $implicit: column,\n      column,\n      allRowsSelected: this.allRowsSelected,\n      someRowsSelected: this.someRowsSelected,\n      toggleAllRows: this.toggleAllRows,\n    };\n  }\n\n  updateEditedValue(rowId: string | number, columnId: keyof T, value: any) {\n    this.editedDataSignal.update((map) => {\n      const newMap = new Map(map);\n      const rowData = newMap.get(rowId) || ({} as EditedData<T>);\n      newMap.set(rowId, { ...rowData, [columnId]: value });\n      return newMap;\n    });\n  }\n\n  updateNestedEditedValue(\n    rowId: string | number,\n    columnId: keyof T,\n    nestedField: string,\n    value: any\n  ) {\n    this.editedDataSignal.update((map) => {\n      const newMap = new Map(map);\n      const rowData = newMap.get(rowId) || ({} as EditedData<T>);\n      const columnData = (rowData[columnId] as any) || {};\n      newMap.set(rowId, {\n        ...rowData,\n        [columnId]: {\n          ...columnData,\n          [nestedField]: value,\n        },\n      });\n      return newMap;\n    });\n  }\n\n  getCellContext(row: T, column: ColumnDefinition<T>, rowIndex: number) {\n    const rowId = row.id;\n    const isEditing = this.isRowEditing(rowId);\n    const editedData = this.editedDataSignal().get(rowId);\n\n    let value: any;\n    if (isEditing && editedData && column.id in editedData) {\n      value = editedData[column.id as keyof T];\n    } else {\n      value = this.getCellValue(row, column);\n    }\n\n    return {\n      $implicit: value,\n      value,\n      row,\n      column,\n      rowIndex,\n      isEditing,\n      isSelected: this.isRowSelected(rowId),\n      toggleRowSelection: () => this.toggleRowSelection(rowId),\n      toggleRowEdit: () => this.toggleRowEdit(rowId),\n      deleteRow: () => this.deleteRow(rowId),\n      updateValue: (newValue: any) =>\n        this.updateEditedValue(rowId, column.id as keyof T, newValue),\n      updateNestedValue: (nestedField: string, newValue: any) =>\n        this.updateNestedEditedValue(\n          rowId,\n          column.id as keyof T,\n          nestedField,\n          newValue\n        ),\n    };\n  }\n\n  deleteRow = (rowId: string | number) => {\n    const rowToDelete = this.data.find((row) => row.id === rowId);\n    if (rowToDelete) {\n      this.rowDelete.emit(rowToDelete);\n    }\n  };\n\n  getFooterContext(column: ColumnDefinition<T>) {\n    return {\n      $implicit: column,\n      column,\n      data: this.data,\n    };\n  }\n\n  getTableStyle(): any {\n    return {\n      ...this.styleConfig,\n      fontFamily: this.styleConfig.fontFamily,\n      fontSize: this.styleConfig.fontSize,\n      whiteSpace: this.styleConfig.whiteSpace,\n      margin: this.styleConfig.margin,\n      border: this.styleConfig.border,\n      borderCollapse: this.styleConfig.borderCollapse,\n      borderSpacing: this.styleConfig.borderSpacing,\n      tableLayout: this.styleConfig.tableLayout,\n      width: this.styleConfig.width,\n    };\n  }\n\n  getHeaderStyle(): any {\n    return {\n      ...this.styleConfig.header,\n      position: this.styleConfig.header?.stickyTop ? 'sticky' : 'static',\n      top: this.styleConfig.header?.stickyTop ? '0' : 'auto',\n      zIndex: this.styleConfig.header?.zIndex || 'auto',\n    };\n  }\n\n  getFooterStyle(): any {\n    return {\n      ...this.styleConfig.footer,\n      position: this.styleConfig.footer?.stickyBottom ? 'sticky' : 'static',\n      bottom: this.styleConfig.footer?.stickyBottom ? '0' : 'auto',\n      zIndex: this.styleConfig.footer?.zIndex || 'auto',\n    };\n  }\n\n  getRowStyle(rowIndex: number): any {\n    const rowStyles = this.styleConfig.rows;\n    if (rowStyles && 'even' in rowStyles && 'odd' in rowStyles) {\n      return rowIndex % 2 === 0 ? rowStyles.even : rowStyles.odd;\n    } else if (rowStyles && 'nth' in rowStyles && rowStyles.nth) {\n      const { interval, style } = rowStyles.nth;\n      return (rowIndex + 1) % (interval || 1) === 0 ? style : {};\n    } else {\n      return rowStyles || {};\n    }\n  }\n\n  getCellStyle(rowIndex: number, colIndex: number): any {\n    const isFirstColumn = colIndex === 0;\n    const isLastColumn = colIndex === this.columnsSignal().length - 1;\n\n    let cellStyle = { ...this.styleConfig.cells };\n\n    if (isFirstColumn) {\n      cellStyle = {\n        ...cellStyle,\n        ...this.styleConfig.firstColumn,\n        position: this.styleConfig.firstColumn?.stickyLeft\n          ? 'sticky'\n          : 'static',\n        left: this.styleConfig.firstColumn?.stickyLeft ? '0' : 'auto',\n        zIndex: this.styleConfig.firstColumn?.zIndex || 'auto',\n      };\n    } else if (isLastColumn) {\n      cellStyle = {\n        ...cellStyle,\n        ...this.styleConfig.lastColumn,\n        position: this.styleConfig.lastColumn?.stickyRight\n          ? 'sticky'\n          : 'static',\n        right: this.styleConfig.lastColumn?.stickyRight ? '0' : 'auto',\n        zIndex: this.styleConfig.lastColumn?.zIndex || 'auto',\n      };\n    }\n\n    if (rowIndex >= 0) {\n      // Apply body styles to all cells\n      cellStyle = { ...cellStyle, ...this.styleConfig.body };\n    } else {\n      cellStyle = { ...this.styleConfig.header };\n    }\n\n    return cellStyle;\n  }\n}\n\ntype EditedData<T> = {\n  [K in keyof T]?: T[K] extends object ? Partial<T[K]> : T[K];\n};\n\n// Default styles\nconst defaultTableStyles: TableStyles = {\n  border: '1px solid #e0e0e0',\n  borderRadius: '4px',\n  overflow: 'hidden',\n  boxShadow: '0 2px 4px rgba(0,0,0,0.1)',\n  width: '100%',\n  header: {\n    backgroundColor: '#f5f5f5',\n    fontWeight: 'bold',\n    color: '#333',\n    textAlign: 'left',\n    padding: '12px 16px',\n    borderBottom: '2px solid #e0e0e0',\n  },\n  rows: {\n    even: {\n      backgroundColor: '#ffffff',\n    },\n    odd: {\n      backgroundColor: '#f9f9f9',\n    },\n    nth: {\n      interval: 5,\n      style: {\n        backgroundColor: '#f0f0f0',\n      },\n    },\n  },\n  cells: {\n    padding: '12px 16px',\n    borderBottom: '1px solid #e0e0e0',\n  },\n  footer: {\n    backgroundColor: '#f5f5f5',\n    fontWeight: 'bold',\n    color: '#333',\n    textAlign: 'left',\n    padding: '12px 16px',\n    borderTop: '2px solid #e0e0e0',\n  },\n};\n","<table [ngStyle]=\"getTableStyle()\">\n  <thead>\n    <tr [ngStyle]=\"getHeaderStyle()\">\n      @for (column of columnsSignal(); track column.id) {\n      <th [ngStyle]=\"getCellStyle(-1, $index)\">\n        @if (column.headerTemplate) {\n        <ng-container\n          [ngTemplateOutlet]=\"column.headerTemplate\"\n          [ngTemplateOutletContext]=\"getHeaderContext(column)\"\n        ></ng-container>\n        } @else {\n        {{ column.header }}\n        }\n      </th>\n      }\n    </tr>\n  </thead>\n  <tbody>\n    @for (row of data; track row.id; let rowIndex = $index) {\n    <tr [ngStyle]=\"getRowStyle(rowIndex)\">\n      @for (column of columnsSignal(); track column.id; let colIndex = $index) {\n      <td [ngStyle]=\"getCellStyle(rowIndex, colIndex)\">\n        @if (isRowEditing(row.id) && column.cellEditTemplate) {\n        <ng-container\n          [ngTemplateOutlet]=\"column.cellEditTemplate\"\n          [ngTemplateOutletContext]=\"getCellContext(row, column, rowIndex)\"\n        ></ng-container>\n        } @else if (column.cellTemplate) {\n        <ng-container\n          [ngTemplateOutlet]=\"column.cellTemplate\"\n          [ngTemplateOutletContext]=\"getCellContext(row, column, rowIndex)\"\n        ></ng-container>\n        } @else {\n        {{ getCellValue(row, column) }}\n        }\n      </td>\n      }\n    </tr>\n    }\n  </tbody>\n  @if (hasFooter()) {\n  <tfoot>\n    <tr [ngStyle]=\"getFooterStyle()\">\n      @for (column of columnsSignal(); track column.id) {\n      <td [ngStyle]=\"getCellStyle(-1, $index)\">\n        @if (column.footerTemplate) {\n        <ng-container\n          [ngTemplateOutlet]=\"column.footerTemplate\"\n          [ngTemplateOutletContext]=\"getFooterContext(column)\"\n        ></ng-container>\n        }\n      </td>\n      }\n    </tr>\n  </tfoot>\n  }\n</table>\n"]}
|
|
@@ -38,4 +38,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImpor
|
|
|
38
38
|
}], outSideClick: [{
|
|
39
39
|
type: Output
|
|
40
40
|
}] } });
|
|
41
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS12aWV3LWNsaWNrLW91dHNpZGUuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmVyYmVuLW5nLXVpL3NyYy9saWIvY29tcG9uZW50cy9kYXRhLXZpZXcvZGF0YS12aWV3LWNsaWNrLW91dHNpZGUuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLHdDQUF3QztBQUV4QyxPQUFPLEVBQ0gsU0FBUyxFQUVULFlBQVksRUFDWixLQUFLLEVBR0wsTUFBTSxHQUVQLE1BQU0sZUFBZSxDQUFDOztBQU12QixNQUFNLE9BQU8scUJBQXFCO0lBR1o7SUFBNkI7SUFGeEMsZUFBZSxDQUFVO0lBQ3hCLFlBQVksR0FBdUIsSUFBSSxZQUFZLEVBQUUsQ0FBQztJQUNoRSxZQUFvQixPQUFtQixFQUFVLFFBQW1CO1FBQWhELFlBQU8sR0FBUCxPQUFPLENBQVk7UUFBVSxhQUFRLEdBQVIsUUFBUSxDQUFXO0lBQUcsQ0FBQztJQUVoRSxRQUFRLENBQTJCO0lBRTNDLGVBQWUsR0FBRyxDQUFDLEtBQVksRUFBRSxFQUFFO1FBQ2pDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDO1lBQ3JFLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDM0IsQ0FBQztJQUNILENBQUMsQ0FBQztJQUVGLFFBQVE7UUFDTixJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUNsQyxVQUFVLEVBQ1YsT0FBTyxFQUNQLElBQUksQ0FBQyxlQUFlLENBQ3JCLENBQUM7SUFDSixDQUFDO0lBRUQsV0FBVztRQUNULElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQ2xCLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNsQixDQUFDO0lBQ0gsQ0FBQzt1R0F6QlUscUJBQXFCOzJGQUFyQixxQkFBcUI7OzJGQUFyQixxQkFBcUI7a0JBSmpDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLG1CQUFtQjtvQkFDN0IsVUFBVSxFQUFFLElBQUk7aUJBQ2pCO3VHQUVVLGVBQWU7c0JBQXZCLEtBQUs7Z0JBQ0ksWUFBWTtzQkFBckIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbIi8vIGRpcmVjdGl2ZXMvb3V0c2lkZS1jbGljay5kaXJlY3RpdmUudHNcblxuaW1wb3J0IHtcbiAgICBEaXJlY3RpdmUsXG4gICAgRWxlbWVudFJlZixcbiAgICBFdmVudEVtaXR0ZXIsXG4gICAgSW5wdXQsXG4gICAgT25EZXN0cm95LFxuICAgIE9uSW5pdCxcbiAgICBPdXRwdXQsXG4gICAgUmVuZGVyZXIyLFxuICB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuICBcbiAgQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbYXBwT3V0U2lkZUNsaWNrXScsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgfSlcbiAgZXhwb3J0IGNsYXNzIE91dFNpZGVDbGlja0RpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgICBASW5wdXQoKSBhcHBPdXRTaWRlQ2xpY2shOiBib29sZWFuXG4gICAgQE91dHB1dCgpIG91dFNpZGVDbGljazogRXZlbnRFbWl0dGVyPHZvaWQ+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgZWxlbWVudDogRWxlbWVudFJlZiwgcHJpdmF0ZSByZW5kZXJlcjogUmVuZGVyZXIyKSB7fVxuICBcbiAgICBwcml2YXRlIGxpc3RlbmVyOiAoKCkgPT4gdm9pZCkgfCB1bmRlZmluZWQ7XG4gIFxuICAgIG9uRG9jdW1lbnRDbGljayA9IChldmVudDogRXZlbnQpID0+IHtcbiAgICAgIGlmICghdGhpcy5lbGVtZW50Lm5hdGl2ZUVsZW1lbnQucGFyZW50RWxlbWVudC5jb250YWlucyhldmVudC50YXJnZXQpKSB7XG4gICAgICAgIHRoaXMub3V0U2lkZUNsaWNrLmVtaXQoKTtcbiAgICAgIH1cbiAgICB9O1xuICBcbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAgIHRoaXMubGlzdGVuZXIgPSB0aGlzLnJlbmRlcmVyLmxpc3RlbihcbiAgICAgICAgJ2RvY3VtZW50JyxcbiAgICAgICAgJ2NsaWNrJyxcbiAgICAgICAgdGhpcy5vbkRvY3VtZW50Q2xpY2tcbiAgICAgICk7XG4gICAgfVxuICBcbiAgICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICAgIGlmICh0aGlzLmxpc3RlbmVyKSB7XG4gICAgICAgIHRoaXMubGlzdGVuZXIoKTtcbiAgICAgIH1cbiAgICB9XG4gIH0iXX0=
|