tuain-ng-forms-lib 14.3.19 → 14.4.45
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/esm2020/lib/classes/forms/element.mjs +8 -69
- package/esm2020/lib/classes/forms/field.mjs +2 -9
- package/esm2020/lib/classes/forms/form.mjs +6 -2
- package/esm2020/lib/classes/forms/piece.mjs +115 -0
- package/esm2020/lib/classes/forms/section.mjs +25 -28
- package/esm2020/lib/classes/forms/subsection.mjs +12 -15
- package/esm2020/lib/classes/forms/table/action.mjs +5 -18
- package/esm2020/lib/classes/forms/table/column.mjs +4 -14
- package/esm2020/lib/classes/forms/table/table.mjs +50 -37
- package/esm2020/lib/components/elements/action.component.mjs +26 -13
- package/esm2020/lib/components/elements/field.component.mjs +18 -20
- package/esm2020/lib/components/elements/layout/element.component.mjs +5 -16
- package/esm2020/lib/components/elements/layout/form-header.component.mjs +5 -5
- package/esm2020/lib/components/elements/layout/piece.component.mjs +22 -0
- package/esm2020/lib/components/elements/layout/section.component.mjs +20 -5
- package/esm2020/lib/components/elements/layout/sub-section.component.mjs +20 -7
- package/esm2020/lib/components/elements/tables/table-record-action.component.mjs +21 -5
- package/esm2020/lib/components/elements/tables/table.component.mjs +67 -47
- package/esm2020/lib/components/forms/basic-form.mjs +25 -14
- package/fesm2015/tuain-ng-forms-lib.mjs +460 -339
- package/fesm2015/tuain-ng-forms-lib.mjs.map +1 -1
- package/fesm2020/tuain-ng-forms-lib.mjs +436 -320
- package/fesm2020/tuain-ng-forms-lib.mjs.map +1 -1
- package/lib/classes/forms/element.d.ts +3 -29
- package/lib/classes/forms/field.d.ts +0 -3
- package/lib/classes/forms/form.d.ts +3 -0
- package/lib/classes/forms/piece.d.ts +43 -0
- package/lib/classes/forms/section.d.ts +8 -18
- package/lib/classes/forms/subsection.d.ts +7 -12
- package/lib/classes/forms/table/action.d.ts +3 -11
- package/lib/classes/forms/table/column.d.ts +2 -7
- package/lib/classes/forms/table/table.d.ts +1 -3
- package/lib/components/elements/action.component.d.ts +4 -8
- package/lib/components/elements/field.component.d.ts +4 -9
- package/lib/components/elements/layout/element.component.d.ts +3 -8
- package/lib/components/elements/layout/form-header.component.d.ts +3 -3
- package/lib/components/elements/layout/piece.component.d.ts +10 -0
- package/lib/components/elements/layout/section.component.d.ts +4 -3
- package/lib/components/elements/layout/sub-section.component.d.ts +4 -4
- package/lib/components/elements/tables/table-record-action.component.d.ts +2 -2
- package/lib/components/elements/tables/table.component.d.ts +6 -10
- package/lib/components/forms/basic-form.d.ts +2 -0
- package/package.json +1 -1
|
@@ -1,12 +1,14 @@
|
|
|
1
1
|
import { Component, Input, ChangeDetectionStrategy } from '@angular/core';
|
|
2
|
+
import { ElementComponent } from '../layout/element.component';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
4
|
const changeViewAttributes = ['visibleRecords', 'currentPage', 'recordsPerPage'];
|
|
4
|
-
export class LibTableComponent {
|
|
5
|
+
export class LibTableComponent extends ElementComponent {
|
|
5
6
|
constructor() {
|
|
7
|
+
super(...arguments);
|
|
6
8
|
this.currentPage = 1;
|
|
7
9
|
this.globalSearch = false;
|
|
8
10
|
this.globalFilterString = '';
|
|
9
|
-
|
|
11
|
+
// visibleRecords: any[] = [];
|
|
10
12
|
this.selectedRecords = [];
|
|
11
13
|
this.totalRecordsNumber = 0;
|
|
12
14
|
this.allSelected = false;
|
|
@@ -14,51 +16,73 @@ export class LibTableComponent {
|
|
|
14
16
|
this.loaded = false;
|
|
15
17
|
this.selectable = false;
|
|
16
18
|
this.hasActions = false;
|
|
17
|
-
this.
|
|
19
|
+
this.table = null;
|
|
20
|
+
this.visibleRecords = [];
|
|
21
|
+
this.waiting = false;
|
|
18
22
|
}
|
|
19
23
|
ngOnInit() {
|
|
20
|
-
if (this.table) {
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
this.
|
|
38
|
-
const { name: tableAttr, value } = event;
|
|
39
|
-
const compAttr = this.formConfig.componentTableAttrMap[tableAttr];
|
|
40
|
-
this.syncAttribute(compAttr, value);
|
|
41
|
-
});
|
|
24
|
+
if (!this.table) {
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
this.formConfig = this.table?._formConfig;
|
|
28
|
+
this.tableFieldStyles = this.formConfig?.tableFieldStyles;
|
|
29
|
+
this.selectable = this.table?.selectable;
|
|
30
|
+
this.hasActions = this.table?.hasActions();
|
|
31
|
+
this.inlineActions = this.table?.getActions(this.formConfig?.tableActions.inline);
|
|
32
|
+
this.globalActions = this.table?.getActions(this.formConfig?.tableActions.global);
|
|
33
|
+
this.selectionActions = this.table?.getActions(this.formConfig?.tableActions.selection);
|
|
34
|
+
// Inicialización de campos mapeados del objeto
|
|
35
|
+
const mapping = Object.entries(this.formConfig?.actionPropagateAttributes);
|
|
36
|
+
for (let index = 0; index < mapping.length; index++) {
|
|
37
|
+
const tableAttr = mapping[index]?.[0];
|
|
38
|
+
const componentAttr = mapping[index]?.[1]?.toString() ?? '';
|
|
39
|
+
const attributeValue = this.table?.[tableAttr];
|
|
40
|
+
this.defaultProcessAttributeChange(componentAttr, attributeValue);
|
|
41
|
+
this.customProcessAttributeChange(componentAttr, attributeValue);
|
|
42
42
|
}
|
|
43
|
+
// Subscripción a cambios en atributos
|
|
44
|
+
this.table?.attributeChange.subscribe(event => {
|
|
45
|
+
const { name: attrName, value } = event;
|
|
46
|
+
this.defaultProcessAttributeChange(attrName, value);
|
|
47
|
+
this.customProcessAttributeChange(attrName, value);
|
|
48
|
+
});
|
|
49
|
+
// Suscripción a los cambios de atributos de las columnas
|
|
50
|
+
// this.table.columns.forEach(column => {
|
|
51
|
+
// mapping = this.formConfig?.tableColumnPropagateAttributes;
|
|
52
|
+
// for (let index = 0; index < mapping.length; index++) {
|
|
53
|
+
// const attrName = mapping[index].toString();
|
|
54
|
+
// const attributeValue = column?.[attrName];
|
|
55
|
+
// this.defaultColumnAttributeChange(column, attrName, attributeValue);
|
|
56
|
+
// }
|
|
57
|
+
// column?.attributeChange.subscribe(event => {
|
|
58
|
+
// const { name: attrName, value } = event;
|
|
59
|
+
// this.defaultColumnAttributeChange(column, attrName, value);
|
|
60
|
+
// });
|
|
61
|
+
// });
|
|
43
62
|
this.start();
|
|
44
63
|
}
|
|
45
|
-
|
|
64
|
+
// defaultColumnAttributeChange(column: any, attribute: string, value?: any) {
|
|
65
|
+
// attribute && (column[attribute] = value);
|
|
66
|
+
// }
|
|
46
67
|
updateTableData() { }
|
|
47
|
-
tableGlobalAction(actionCode) { this.table
|
|
48
|
-
tableSelectionAction(actionCode) { this.table
|
|
49
|
-
tableActionSelected(actionEvent) { this.table
|
|
50
|
-
tableSelectionToggle(recordId) { this.table
|
|
51
|
-
toggleSelectAll() { return (this.allSelected) ? this.table
|
|
68
|
+
tableGlobalAction(actionCode) { this.table?.notifyGlobalAction(actionCode); }
|
|
69
|
+
tableSelectionAction(actionCode) { this.table?.notifySelectionAction(actionCode); }
|
|
70
|
+
tableActionSelected(actionEvent) { this.table?.notifyInlineAction(actionEvent); }
|
|
71
|
+
tableSelectionToggle(recordId) { this.table?.notifyRecordSelection(recordId); }
|
|
72
|
+
toggleSelectAll() { return (this.allSelected) ? this.table?.unSelectAll() : this.table?.selectAll(); }
|
|
52
73
|
globalFilterCompleted() { this.changePage(1); }
|
|
53
|
-
changePage(requestedPage) { this.table
|
|
54
|
-
tableColumnSort(columnName, direction = null) { this.table
|
|
55
|
-
globalFilterChanged() { this.table
|
|
56
|
-
|
|
74
|
+
changePage(requestedPage) { this.table?.changePage(requestedPage); }
|
|
75
|
+
tableColumnSort(columnName, direction = null) { this.table?.sort(columnName, direction ?? 'ascend'); }
|
|
76
|
+
globalFilterChanged() { this.table?.setGlobalFilterString(this.globalFilterString?.trim() ?? '', false); }
|
|
77
|
+
defaultProcessAttributeChange(attribute, value) {
|
|
78
|
+
if (!attribute) {
|
|
79
|
+
return false;
|
|
80
|
+
}
|
|
57
81
|
try {
|
|
58
|
-
if (
|
|
82
|
+
if (attribute === 'visibleRecords') {
|
|
59
83
|
this.updateTableData();
|
|
60
84
|
}
|
|
61
|
-
this[
|
|
85
|
+
this[attribute] = value;
|
|
62
86
|
return true;
|
|
63
87
|
}
|
|
64
88
|
catch {
|
|
@@ -67,15 +91,15 @@ export class LibTableComponent {
|
|
|
67
91
|
}
|
|
68
92
|
filterHasChanged(column, values) {
|
|
69
93
|
if (!values || values.length === 0) {
|
|
70
|
-
this.table
|
|
94
|
+
this.table?.removeColumnFilter(column.fieldCode);
|
|
71
95
|
}
|
|
72
96
|
else {
|
|
73
|
-
this.table
|
|
97
|
+
this.table?.addColumnFilter(column.fieldCode, values);
|
|
74
98
|
}
|
|
75
99
|
}
|
|
76
100
|
}
|
|
77
|
-
LibTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: LibTableComponent, deps:
|
|
78
|
-
LibTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.6", type: LibTableComponent, selector: "lib-table", inputs: { table: "table",
|
|
101
|
+
LibTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: LibTableComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
102
|
+
LibTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.6", type: LibTableComponent, selector: "lib-table", inputs: { table: "table", visibleRecords: "visibleRecords", waiting: "waiting" }, usesInheritance: true, ngImport: i0, template: `<ng-content></ng-content>`, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
79
103
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: LibTableComponent, decorators: [{
|
|
80
104
|
type: Component,
|
|
81
105
|
args: [{
|
|
@@ -85,13 +109,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.6", ngImpor
|
|
|
85
109
|
}]
|
|
86
110
|
}], propDecorators: { table: [{
|
|
87
111
|
type: Input
|
|
88
|
-
}],
|
|
89
|
-
type: Input
|
|
90
|
-
}], disabled: [{
|
|
91
|
-
type: Input
|
|
92
|
-
}], state: [{
|
|
112
|
+
}], visibleRecords: [{
|
|
93
113
|
type: Input
|
|
94
114
|
}], waiting: [{
|
|
95
115
|
type: Input
|
|
96
116
|
}] } });
|
|
97
|
-
//# 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';\n\nconst changeViewAttributes = ['visibleRecords', 'currentPage', 'recordsPerPage'];\n\n@Component({\n  selector: 'lib-table',\n  template: `<ng-content></ng-content>`,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\n\nexport class LibTableComponent implements OnInit {\n  formConfig: any;\n\n  // Atributos sincronizados del objeto\n  code: any;\n  columns: any;\n  currentPage: number = 1;\n  globalSearch: boolean = false;\n  globalFilterString: string = '';\n  visibleRecords: any[] = [];\n  selectedRecords: any[] = [];\n  recordsPerPage: any;\n  totalRecordsNumber: number = 0;\n  allSelected: boolean = false;\n  layout: 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;\n  @Input() tableRecords: TableRecordData[];\n  @Input() disabled: boolean = false;\n  @Input() state: string;\n  @Input() waiting: boolean;\n\n  ngOnInit() {\n    if (this.table) {\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.componentTableAttrMap);\n      for (let index = 0; index < mapping.length; index++) {\n        const [tableAttrRaw, compAttrRaw] = mapping[index];\n        const tableAttr = tableAttrRaw.toString();\n        const compAttr = compAttrRaw.toString();\n        this.syncAttribute(compAttr, this.table[tableAttr]);\n      }\n      // Subscripción a cambios en atributos\n      this.table.attributeChange.subscribe(event => {\n        const { name: tableAttr, value } = event;\n        const compAttr = this.formConfig.componentTableAttrMap[tableAttr];\n        this.syncAttribute(compAttr, value);\n      });\n    }\n    this.start();\n  }\n\n  start() { }\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.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  syncAttribute(name: string, value: any) {\n    try {\n      if (name === 'visibleRecords') {\n        this.updateTableData();\n      }\n      this[name] = value;\n      return true;\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"]}
|
|
117
|
+
//# 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\nconst changeViewAttributes = ['visibleRecords', 'currentPage', 'recordsPerPage'];\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  columns: any;\n  currentPage: number = 1;\n  globalSearch: boolean = false;\n  globalFilterString: string = '';\n  // visibleRecords: any[] = [];\n  selectedRecords: any[] = [];\n  recordsPerPage: any;\n  totalRecordsNumber: number = 0;\n  allSelected: boolean = false;\n  layout: 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.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?.actionPropagateAttributes);\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 } = event;\n      this.defaultProcessAttributeChange(attrName, value);\n      this.customProcessAttributeChange(attrName, value);\n    });\n    // Suscripción a los cambios de atributos de las columnas\n    // this.table.columns.forEach(column => {\n    //   mapping = this.formConfig?.tableColumnPropagateAttributes;\n    //   for (let index = 0; index < mapping.length; index++) {\n    //     const attrName = mapping[index].toString();\n    //     const attributeValue = column?.[attrName];\n    //     this.defaultColumnAttributeChange(column, attrName, attributeValue);\n    //   }\n    //   column?.attributeChange.subscribe(event => {\n    //     const { name: attrName, value } = event;\n    //     this.defaultColumnAttributeChange(column, attrName, value);\n    //   });\n    // });\n    this.start();\n  }\n\n  // defaultColumnAttributeChange(column: any, attribute: string, value?: any) {\n  //   attribute && (column[attribute] = value);\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.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) {\n    if (!attribute) {\n      return false;\n    }\n    try {\n      if (attribute === 'visibleRecords') {\n        this.updateTableData();\n      }\n      this[attribute] = value;\n      return true;\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"]}
|