tuain-ng-forms-lib 17.0.0 → 17.1.0
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/classes/forms/action.mjs +66 -40
- package/esm2022/lib/classes/forms/element.mjs +8 -3
- package/esm2022/lib/classes/forms/field.mjs +81 -71
- package/esm2022/lib/classes/forms/section.mjs +51 -39
- package/esm2022/lib/classes/forms/subsection.mjs +45 -27
- package/esm2022/lib/classes/forms/table/table.mjs +124 -82
- package/esm2022/lib/components/elements/action.component.mjs +29 -19
- package/esm2022/lib/components/elements/field.component.mjs +56 -69
- package/esm2022/lib/components/elements/layout/piece.component.mjs +43 -19
- package/esm2022/lib/components/elements/layout/section.component.mjs +21 -13
- package/esm2022/lib/components/elements/layout/sub-section.component.mjs +21 -13
- package/esm2022/lib/components/elements/tables/table-record-action.component.mjs +13 -8
- package/esm2022/lib/components/elements/tables/table.component.mjs +38 -35
- package/fesm2022/tuain-ng-forms-lib.mjs +581 -423
- package/fesm2022/tuain-ng-forms-lib.mjs.map +1 -1
- package/lib/classes/forms/action.d.ts +30 -14
- package/lib/classes/forms/field.d.ts +9 -4
- package/lib/classes/forms/section.d.ts +18 -6
- package/lib/classes/forms/subsection.d.ts +28 -10
- package/lib/classes/forms/table/table.d.ts +63 -21
- package/lib/components/elements/action.component.d.ts +8 -1
- package/lib/components/elements/field.component.d.ts +21 -15
- package/lib/components/elements/layout/piece.component.d.ts +8 -4
- package/lib/components/elements/layout/section.component.d.ts +1 -0
- package/lib/components/elements/layout/sub-section.component.d.ts +1 -0
- package/lib/components/elements/tables/table-record-action.component.d.ts +1 -0
- package/lib/components/elements/tables/table.component.d.ts +12 -5
- package/package.json +1 -1
|
@@ -1,10 +1,25 @@
|
|
|
1
|
-
import { Component, Input, ChangeDetectionStrategy } from '@angular/core';
|
|
1
|
+
import { Component, signal, Input, ChangeDetectionStrategy } from '@angular/core';
|
|
2
2
|
import { ElementComponent } from '../layout/element.component';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
+
const CUSTOM_ATTRIBUTES = 'customAttributes';
|
|
5
|
+
const signaledAttributes = [
|
|
6
|
+
'allSelected', 'code', 'globalSearch', 'globalFilterString', 'recordsPerPage', 'layout',
|
|
7
|
+
'columns', 'selectedRecords', 'currentPage', 'totalRecordsNumber', 'visibleRecords',
|
|
8
|
+
'visible', 'disabled',
|
|
9
|
+
];
|
|
4
10
|
export class LibTableComponent extends ElementComponent {
|
|
5
11
|
// Atributos sincronizados del objeto
|
|
6
|
-
|
|
7
|
-
|
|
12
|
+
allSelected = signal(null);
|
|
13
|
+
code = signal('');
|
|
14
|
+
globalSearch = signal(null);
|
|
15
|
+
globalFilterString = signal('');
|
|
16
|
+
recordsPerPage = signal(null);
|
|
17
|
+
layout = signal(null);
|
|
18
|
+
columns = signal(null);
|
|
19
|
+
selectedRecords = signal(null);
|
|
20
|
+
currentPage = signal(null);
|
|
21
|
+
totalRecordsNumber = signal(null);
|
|
22
|
+
visibleRecords = signal(null);
|
|
8
23
|
tableFieldStyles;
|
|
9
24
|
loaded = false;
|
|
10
25
|
selectable = false;
|
|
@@ -13,7 +28,6 @@ export class LibTableComponent extends ElementComponent {
|
|
|
13
28
|
globalActions;
|
|
14
29
|
selectionActions;
|
|
15
30
|
table = null;
|
|
16
|
-
visibleRecords = [];
|
|
17
31
|
waiting = false;
|
|
18
32
|
ngOnInit() {
|
|
19
33
|
if (!this.table) {
|
|
@@ -22,51 +36,42 @@ export class LibTableComponent extends ElementComponent {
|
|
|
22
36
|
this.table.setWidget(this);
|
|
23
37
|
this.formConfig = this.table?._formConfig;
|
|
24
38
|
this.tableFieldStyles = this.formConfig?.tableFieldStyles;
|
|
25
|
-
this.selectable = this.table?.
|
|
39
|
+
this.selectable = this.table?._selectable;
|
|
26
40
|
this.hasActions = this.table?.hasActions();
|
|
27
41
|
this.inlineActions = this.table?.getActions(this.formConfig?.tableActions.inline);
|
|
28
42
|
this.globalActions = this.table?.getActions(this.formConfig?.tableActions.global);
|
|
29
43
|
this.selectionActions = this.table?.getActions(this.formConfig?.tableActions.selection);
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
for (let index = 0; index < mapping.length; index++) {
|
|
33
|
-
const tableAttr = mapping[index]?.[0];
|
|
34
|
-
const componentAttr = mapping[index]?.[1]?.toString() ?? '';
|
|
35
|
-
const attributeValue = this.table?.[tableAttr];
|
|
36
|
-
this.defaultProcessAttributeChange(componentAttr, attributeValue);
|
|
37
|
-
this.customProcessAttributeChange(componentAttr, attributeValue);
|
|
38
|
-
}
|
|
39
|
-
// Subscripción a cambios en atributos
|
|
44
|
+
this.updatePropagatedAttributes();
|
|
45
|
+
this.replaceCustomAttributes(this.table?.customAttributes);
|
|
40
46
|
this.table?.attributeChange.subscribe(event => {
|
|
41
|
-
const { name:
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
this.
|
|
47
|
+
const { name: attribute, value = null } = event ?? {};
|
|
48
|
+
const attributeParts = attribute?.split('.') ?? [];
|
|
49
|
+
if (attribute === 'visibleRecords') {
|
|
50
|
+
this.updateTableData();
|
|
51
|
+
}
|
|
52
|
+
else if (signaledAttributes.includes(attribute)) {
|
|
53
|
+
this.updatePieceAttribute(signaledAttributes, attribute, value);
|
|
54
|
+
}
|
|
55
|
+
else if (attributeParts?.length > 1 && attributeParts?.[0] === CUSTOM_ATTRIBUTES) {
|
|
56
|
+
const subAttribute = attributeParts?.[1] ?? null;
|
|
57
|
+
this.updateCustomAttribute(subAttribute, value);
|
|
45
58
|
}
|
|
46
59
|
});
|
|
47
60
|
this.start();
|
|
48
61
|
}
|
|
62
|
+
updatePropagatedAttributes() {
|
|
63
|
+
this.updatePieceAttributes(this.table, signaledAttributes);
|
|
64
|
+
}
|
|
49
65
|
updateTableData() { }
|
|
50
66
|
tableGlobalAction(actionCode) { this.table?.notifyGlobalAction(actionCode); }
|
|
51
67
|
tableSelectionAction(actionCode) { this.table?.notifySelectionAction(actionCode); }
|
|
52
68
|
tableActionSelected(actionEvent) { this.table?.notifyInlineAction(actionEvent); }
|
|
53
69
|
tableSelectionToggle(recordId) { this.table?.notifyRecordSelection(recordId); }
|
|
54
|
-
toggleSelectAll() { return (this.table?.
|
|
70
|
+
toggleSelectAll() { return (this.table?._allSelected) ? this.table?.unSelectAll() : this.table?.selectAll(); }
|
|
55
71
|
globalFilterCompleted() { this.changePage(1); }
|
|
56
72
|
changePage(requestedPage) { this.table?.changePage(requestedPage); }
|
|
57
73
|
tableColumnSort(columnName, direction = null) { this.table?.sort(columnName, direction ?? 'ascend'); }
|
|
58
74
|
globalFilterChanged() { this.table?.setGlobalFilterString(this.globalFilterString?.trim() ?? '', false); }
|
|
59
|
-
defaultProcessAttributeChange(attribute, value) {
|
|
60
|
-
try {
|
|
61
|
-
if (attribute === 'visibleRecords') {
|
|
62
|
-
this.updateTableData();
|
|
63
|
-
}
|
|
64
|
-
return super.defaultProcessAttributeChange(attribute, value);
|
|
65
|
-
}
|
|
66
|
-
catch {
|
|
67
|
-
return false;
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
75
|
filterHasChanged(column, values) {
|
|
71
76
|
if (!values || values.length === 0) {
|
|
72
77
|
this.table?.removeColumnFilter(column.fieldCode);
|
|
@@ -76,7 +81,7 @@ export class LibTableComponent extends ElementComponent {
|
|
|
76
81
|
}
|
|
77
82
|
}
|
|
78
83
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: LibTableComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
79
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: LibTableComponent, selector: "lib-table", inputs: { table: "table",
|
|
84
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: LibTableComponent, selector: "lib-table", inputs: { table: "table", waiting: "waiting" }, usesInheritance: true, ngImport: i0, template: `<ng-content></ng-content>`, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
80
85
|
}
|
|
81
86
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: LibTableComponent, decorators: [{
|
|
82
87
|
type: Component,
|
|
@@ -87,9 +92,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
87
92
|
}]
|
|
88
93
|
}], propDecorators: { table: [{
|
|
89
94
|
type: Input
|
|
90
|
-
}], visibleRecords: [{
|
|
91
|
-
type: Input
|
|
92
95
|
}], waiting: [{
|
|
93
96
|
type: Input
|
|
94
97
|
}] } });
|
|
95
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../../projects/tuain-ng-forms-lib/src/lib/components/elements/tables/table.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, ChangeDetectionStrategy } from '@angular/core';\nimport { TableRecordData } from '../../../classes/forms/table/row-data';\nimport { TableActionEvent } from '../../../classes/forms/table/table';\nimport { RecordTable, TableEvent } from '../../../classes/forms/table/table';\nimport { ElementComponent } from '../layout/element.component';\n\n@Component({\n  selector: 'lib-table',\n  template: `<ng-content></ng-content>`,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\n\nexport class LibTableComponent extends ElementComponent implements OnInit {\n  // Atributos sincronizados del objeto\n  code: any;\n  globalFilterString: string = '';\n\n  tableFieldStyles: any;\n  loaded = false;\n  selectable = false;\n  hasActions = false;\n  inlineActions: any;\n  globalActions: any;\n  selectionActions: any;\n\n  @Input() table: RecordTable | null = null;\n  @Input() visibleRecords: TableRecordData[] = [];\n  @Input() waiting: boolean = false;\n\n  ngOnInit() {\n    if (!this.table) { return; }\n    this.table.setWidget(this);\n    this.formConfig = this.table?._formConfig;\n    this.tableFieldStyles = this.formConfig?.tableFieldStyles;\n    this.selectable = this.table?.selectable;\n    this.hasActions = this.table?.hasActions();\n    this.inlineActions = this.table?.getActions(this.formConfig?.tableActions.inline);\n    this.globalActions = this.table?.getActions(this.formConfig?.tableActions.global);\n    this.selectionActions = this.table?.getActions(this.formConfig?.tableActions.selection);\n    // Inicialización de campos mapeados del objeto\n    const mapping = Object.entries(this.formConfig?.tablePropagationAttributes);\n    for (let index = 0; index < mapping.length; index++) {\n      const tableAttr = mapping[index]?.[0];\n      const componentAttr = mapping[index]?.[1]?.toString() ?? '';\n      const attributeValue = this.table?.[tableAttr];\n      this.defaultProcessAttributeChange(componentAttr, attributeValue);\n      this.customProcessAttributeChange(componentAttr, attributeValue);\n    }\n    // Subscripción a cambios en atributos\n    this.table?.attributeChange.subscribe(event => {\n      const { name: attrName, value = null } = event ?? {};\n      if (attrName) {\n        this.defaultProcessAttributeChange(attrName, value);\n        this.customProcessAttributeChange(attrName, value);\n      }\n    });\n    this.start();\n  }\n\n  updateTableData() { }\n  tableGlobalAction(actionCode: string) { this.table?.notifyGlobalAction(actionCode); }\n  tableSelectionAction(actionCode: string) { this.table?.notifySelectionAction(actionCode); }\n  tableActionSelected(actionEvent: TableActionEvent) { this.table?.notifyInlineAction(actionEvent); }\n  tableSelectionToggle(recordId: any) { this.table?.notifyRecordSelection(recordId); }\n  toggleSelectAll() { return (this.table?.allSelected) ? this.table?.unSelectAll() : this.table?.selectAll(); }\n  globalFilterCompleted() { this.changePage(1); }\n  changePage(requestedPage: number) { this.table?.changePage(requestedPage); }\n  tableColumnSort(columnName: string, direction = null) { this.table?.sort(columnName, direction ?? 'ascend'); }\n  globalFilterChanged() { this.table?.setGlobalFilterString(this.globalFilterString?.trim() ?? '', false); }\n\n  override defaultProcessAttributeChange(attribute: string, value?: any): boolean {\n    try {\n      if (attribute === 'visibleRecords') {\n        this.updateTableData();\n      }\n      return super.defaultProcessAttributeChange(attribute, value);\n    } catch {\n      return false;\n    }\n  }\n\n  filterHasChanged(column, values) {\n    if (!values || values.length === 0) {\n      this.table?.removeColumnFilter(column.fieldCode);\n    } else {\n      this.table?.addColumnFilter(column.fieldCode, values);\n    }\n  }\n}\n"]}
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../../projects/tuain-ng-forms-lib/src/lib/components/elements/tables/table.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, signal, OnInit, Input, ChangeDetectionStrategy } from '@angular/core';\nimport { TableRecordData } from '../../../classes/forms/table/row-data';\nimport { TableActionEvent } from '../../../classes/forms/table/table';\nimport { RecordTable, TableEvent } from '../../../classes/forms/table/table';\nimport { ElementComponent } from '../layout/element.component';\n\nconst CUSTOM_ATTRIBUTES = 'customAttributes';\n\nconst signaledAttributes = [\n  'allSelected', 'code', 'globalSearch', 'globalFilterString', 'recordsPerPage', 'layout',\n  'columns', 'selectedRecords', 'currentPage', 'totalRecordsNumber', 'visibleRecords',\n  'visible', 'disabled',\n];\n\n@Component({\n  selector: 'lib-table',\n  template: `<ng-content></ng-content>`,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\n\nexport class LibTableComponent extends ElementComponent implements OnInit {\n  // Atributos sincronizados del objeto\n  allSelected: any = signal<any>(null);\n  code: any = signal<string>('');\n  globalSearch: any = signal<any>(null);\n  globalFilterString: any = signal<string>('');\n  recordsPerPage: any = signal<any>(null);\n  layout: any = signal<any>(null);\n  columns: any = signal<any>(null);\n  selectedRecords: any = signal<any>(null);\n  currentPage: any = signal<any>(null);\n  totalRecordsNumber: any = signal<any>(null);\n  visibleRecords: any = signal<any>(null);\n\n  tableFieldStyles: any;\n  loaded = false;\n  selectable = false;\n  hasActions = false;\n  inlineActions: any;\n  globalActions: any;\n  selectionActions: any;\n\n  @Input() table: RecordTable | null = null;\n  @Input() waiting: boolean = false;\n\n  ngOnInit() {\n    if (!this.table) { return; }\n    this.table.setWidget(this);\n    this.formConfig = this.table?._formConfig;\n\n    this.tableFieldStyles = this.formConfig?.tableFieldStyles;\n    this.selectable = this.table?._selectable;\n    this.hasActions = this.table?.hasActions();\n    this.inlineActions = this.table?.getActions(this.formConfig?.tableActions.inline);\n    this.globalActions = this.table?.getActions(this.formConfig?.tableActions.global);\n    this.selectionActions = this.table?.getActions(this.formConfig?.tableActions.selection);\n    this.updatePropagatedAttributes();\n    this.replaceCustomAttributes(this.table?.customAttributes);\n\n    this.table?.attributeChange.subscribe(event => {\n      const { name: attribute, value = null } = event ?? {};\n      const attributeParts = attribute?.split('.') ?? [];\n      if (attribute === 'visibleRecords') {\n        this.updateTableData();\n      } else if (signaledAttributes.includes(attribute)) {\n        this.updatePieceAttribute(signaledAttributes, attribute, value);\n      } else if (attributeParts?.length > 1 && attributeParts?.[0] === CUSTOM_ATTRIBUTES) {\n        const subAttribute = attributeParts?.[1] ?? null;\n        this.updateCustomAttribute(subAttribute, value);\n      }\n    });\n    this.start();\n  }\n\n  updatePropagatedAttributes() {\n    this.updatePieceAttributes(this.table, signaledAttributes)\n  }\n\n  updateTableData() { }\n  tableGlobalAction(actionCode: string) { this.table?.notifyGlobalAction(actionCode); }\n  tableSelectionAction(actionCode: string) { this.table?.notifySelectionAction(actionCode); }\n  tableActionSelected(actionEvent: TableActionEvent) { this.table?.notifyInlineAction(actionEvent); }\n  tableSelectionToggle(recordId: any) { this.table?.notifyRecordSelection(recordId); }\n  toggleSelectAll() { return (this.table?._allSelected) ? this.table?.unSelectAll() : this.table?.selectAll(); }\n  globalFilterCompleted() { this.changePage(1); }\n  changePage(requestedPage: number) { this.table?.changePage(requestedPage); }\n  tableColumnSort(columnName: string, direction = null) { this.table?.sort(columnName, direction ?? 'ascend'); }\n  globalFilterChanged() { this.table?.setGlobalFilterString(this.globalFilterString?.trim() ?? '', false); }\n\n  filterHasChanged(column, values) {\n    if (!values || values.length === 0) {\n      this.table?.removeColumnFilter(column.fieldCode);\n    } else {\n      this.table?.addColumnFilter(column.fieldCode, values);\n    }\n  }\n}\n"]}
|