@tots/table 15.0.48 → 15.0.50
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/components/tots-table-local/tots-table-local.component.mjs +138 -0
- package/esm2020/lib/entities/tots-table-local-config.mjs +8 -0
- package/esm2020/lib/table.module.mjs +10 -5
- package/esm2020/public-api.mjs +3 -1
- package/fesm2015/tots-table.mjs +149 -5
- package/fesm2015/tots-table.mjs.map +1 -1
- package/fesm2020/tots-table.mjs +149 -5
- package/fesm2020/tots-table.mjs.map +1 -1
- package/lib/components/tots-table-local/tots-table-local.component.d.ts +37 -0
- package/lib/entities/tots-table-local-config.d.ts +4 -0
- package/lib/table.module.d.ts +11 -10
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { TotsTableLocalConfig } from '../../entities/tots-table-local-config';
|
|
3
|
+
import { tap } from 'rxjs';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "../tots-table/tots-table.component";
|
|
6
|
+
export class TotsTableLocalComponent {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.configTable = new TotsTableLocalConfig();
|
|
9
|
+
this.hasPagination = true;
|
|
10
|
+
this.isPaginationStartIndexInZero = false;
|
|
11
|
+
this.onAction = new EventEmitter();
|
|
12
|
+
this.dataTotals = 0;
|
|
13
|
+
this.page = 1;
|
|
14
|
+
this.perPage = 50;
|
|
15
|
+
}
|
|
16
|
+
ngOnInit() {
|
|
17
|
+
this.loadConfig();
|
|
18
|
+
}
|
|
19
|
+
onFilterItems() {
|
|
20
|
+
if (this.dataItems == undefined) {
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
let items = [...this.dataItems];
|
|
24
|
+
if (this.orderKey != undefined) {
|
|
25
|
+
if (this.orderType == 'asc') {
|
|
26
|
+
items = items.sort((a, b) => (a[this.orderKey] > b[this.orderKey]) ? 1 : ((b[this.orderKey] > a[this.orderKey]) ? -1 : 0));
|
|
27
|
+
}
|
|
28
|
+
else {
|
|
29
|
+
items = items.sort((a, b) => (a[this.orderKey] < b[this.orderKey]) ? 1 : ((b[this.orderKey] < a[this.orderKey]) ? -1 : 0));
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
// Aplicar busqueda
|
|
33
|
+
if (this.searchQuery != undefined && this.searchQuery != '') {
|
|
34
|
+
items = items.filter(item => {
|
|
35
|
+
let isMatch = false;
|
|
36
|
+
this.configTable.searchKeys.forEach(key => {
|
|
37
|
+
if (item[key] != undefined && item[key].toString().toLowerCase().includes(this.searchQuery.toLowerCase())) {
|
|
38
|
+
isMatch = true;
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
return isMatch;
|
|
42
|
+
});
|
|
43
|
+
this.dataTotals = items.length;
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
this.dataTotals = this.dataItems.length;
|
|
47
|
+
}
|
|
48
|
+
let startIndex = (this.page - 1) * this.perPage;
|
|
49
|
+
let endIndex = startIndex + this.perPage;
|
|
50
|
+
this.setDataItems(this.generateListResponse(items.slice(startIndex, endIndex)));
|
|
51
|
+
}
|
|
52
|
+
onPagination(action) {
|
|
53
|
+
this.perPage = action.item.pageSize;
|
|
54
|
+
if (this.isPaginationStartIndexInZero) {
|
|
55
|
+
this.page = action.item.pageIndex;
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
this.page = action.item.pageIndex + 1;
|
|
59
|
+
}
|
|
60
|
+
this.onFilterItems();
|
|
61
|
+
}
|
|
62
|
+
onOrder(column) {
|
|
63
|
+
this.orderType = column.order;
|
|
64
|
+
this.orderKey = column.field_key;
|
|
65
|
+
this.onFilterItems();
|
|
66
|
+
}
|
|
67
|
+
onTableAction(action) {
|
|
68
|
+
if (action.key == 'page-change') {
|
|
69
|
+
this.onPagination(action);
|
|
70
|
+
}
|
|
71
|
+
else if (action.key == 'click-order') {
|
|
72
|
+
this.onOrder(action.item);
|
|
73
|
+
}
|
|
74
|
+
this.onAction.emit(action);
|
|
75
|
+
}
|
|
76
|
+
loadConfig() {
|
|
77
|
+
if (this.configTable.obs == undefined) {
|
|
78
|
+
return;
|
|
79
|
+
}
|
|
80
|
+
this.setObs(this.configTable.obs);
|
|
81
|
+
}
|
|
82
|
+
refreshQueryAndLoadItems() {
|
|
83
|
+
return this.loadItems();
|
|
84
|
+
}
|
|
85
|
+
loadItems() {
|
|
86
|
+
return this.tableComp.loadItems();
|
|
87
|
+
}
|
|
88
|
+
getDataItems() {
|
|
89
|
+
return this.tableComp.getDataItems();
|
|
90
|
+
}
|
|
91
|
+
setDataItems(items) {
|
|
92
|
+
this.tableComp.refreshDataItems(items);
|
|
93
|
+
}
|
|
94
|
+
setObs(obs) {
|
|
95
|
+
this.configTable.obs = obs.pipe(tap(res => this.dataItems = res.data));
|
|
96
|
+
}
|
|
97
|
+
onSearch(query) {
|
|
98
|
+
this.page = 1;
|
|
99
|
+
this.searchQuery = query;
|
|
100
|
+
this.onFilterItems();
|
|
101
|
+
}
|
|
102
|
+
generateListResponse(items) {
|
|
103
|
+
// calcular la iultima pagina
|
|
104
|
+
let lastPage = Math.ceil(this.dataTotals / this.perPage);
|
|
105
|
+
return {
|
|
106
|
+
current_page: this.page,
|
|
107
|
+
first_page_url: '',
|
|
108
|
+
from: '',
|
|
109
|
+
last_page: lastPage,
|
|
110
|
+
last_page_url: '',
|
|
111
|
+
next_page_url: '',
|
|
112
|
+
path: '',
|
|
113
|
+
per_page: this.perPage,
|
|
114
|
+
prev_page_url: '',
|
|
115
|
+
to: '',
|
|
116
|
+
total: this.dataTotals,
|
|
117
|
+
data: items
|
|
118
|
+
};
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
TotsTableLocalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsTableLocalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
122
|
+
TotsTableLocalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: TotsTableLocalComponent, selector: "tots-table-local", inputs: { configTable: "configTable", hasPagination: "hasPagination", isPaginationStartIndexInZero: "isPaginationStartIndexInZero" }, outputs: { onAction: "onAction" }, viewQueries: [{ propertyName: "tableComp", first: true, predicate: ["tableComp"], descendants: true }], ngImport: i0, template: "<tots-table #tableComp [config]=\"configTable\" [pageIndex]=\"page\" [pageSize]=\"perPage\" (onAction)=\"onTableAction($event)\" [hasPagination]=\"hasPagination\"></tots-table>\n", styles: [""], dependencies: [{ kind: "component", type: i1.TotsTableComponent, selector: "tots-table", inputs: ["config", "pageIndex", "pageSize", "hasPagination", "messageNotFound"], outputs: ["onAction"] }] });
|
|
123
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsTableLocalComponent, decorators: [{
|
|
124
|
+
type: Component,
|
|
125
|
+
args: [{ selector: 'tots-table-local', template: "<tots-table #tableComp [config]=\"configTable\" [pageIndex]=\"page\" [pageSize]=\"perPage\" (onAction)=\"onTableAction($event)\" [hasPagination]=\"hasPagination\"></tots-table>\n" }]
|
|
126
|
+
}], propDecorators: { tableComp: [{
|
|
127
|
+
type: ViewChild,
|
|
128
|
+
args: ['tableComp']
|
|
129
|
+
}], configTable: [{
|
|
130
|
+
type: Input
|
|
131
|
+
}], hasPagination: [{
|
|
132
|
+
type: Input
|
|
133
|
+
}], isPaginationStartIndexInZero: [{
|
|
134
|
+
type: Input
|
|
135
|
+
}], onAction: [{
|
|
136
|
+
type: Output
|
|
137
|
+
}] } });
|
|
138
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tots-table-local.component.js","sourceRoot":"","sources":["../../../../../../../projects/tots/table/src/lib/components/tots-table-local/tots-table-local.component.ts","../../../../../../../projects/tots/table/src/lib/components/tots-table-local/tots-table-local.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';\nimport { TotsTableLocalConfig } from '../../entities/tots-table-local-config';\nimport { TotsActionTable } from '../../entities/tots-action-table';\nimport { TotsListResponse } from '@tots/core';\nimport { Observable, tap } from 'rxjs';\nimport { TotsTableComponent } from '../tots-table/tots-table.component';\nimport { TotsColumn } from '../../entities/tots-column';\n\n@Component({\n  selector: 'tots-table-local',\n  templateUrl: './tots-table-local.component.html',\n  styleUrls: ['./tots-table-local.component.css']\n})\nexport class TotsTableLocalComponent {\n\n  @ViewChild('tableComp') tableComp!: TotsTableComponent;\n\n  @Input() configTable = new TotsTableLocalConfig();\n  @Input() hasPagination: boolean = true;\n  @Input() isPaginationStartIndexInZero: boolean = false;\n\n  @Output() onAction = new EventEmitter<TotsActionTable>();\n\n  dataItems?: Array<any>;\n  dataTotals = 0;\n  page: number = 1;\n  perPage: number = 50;\n  orderKey?: string;\n  orderType?: string;\n  searchQuery?: string;\n\n  ngOnInit(): void {\n    this.loadConfig();\n  }\n\n  onFilterItems() {\n    if(this.dataItems == undefined){\n      return;\n    }\n\n    let items = [...this.dataItems];\n\n    if(this.orderKey != undefined){\n      if(this.orderType == 'asc'){\n        items = items.sort((a,b) => (a[this.orderKey!] > b[this.orderKey!]) ? 1 : ((b[this.orderKey!] > a[this.orderKey!]) ? -1 : 0))\n      } else {\n        items = items.sort((a,b) => (a[this.orderKey!] < b[this.orderKey!]) ? 1 : ((b[this.orderKey!] < a[this.orderKey!]) ? -1 : 0))\n      }\n    }\n\n    // Aplicar busqueda\n    if(this.searchQuery != undefined && this.searchQuery != ''){\n      items = items.filter(item => {\n        let isMatch = false;\n        this.configTable.searchKeys.forEach(key => {\n          if(item[key] != undefined && item[key].toString().toLowerCase().includes(this.searchQuery!.toLowerCase())){\n            isMatch = true;\n          }\n        });\n        return isMatch;\n      });\n      this.dataTotals = items.length;\n    } else {\n      this.dataTotals = this.dataItems!.length;\n    }\n\n    let startIndex = (this.page - 1) * this.perPage;\n    let endIndex = startIndex + this.perPage;\n    this.setDataItems(this.generateListResponse(items.slice(startIndex, endIndex)));\n  }\n\n  onPagination(action: TotsActionTable) {\n    this.perPage = action.item.pageSize;\n    if(this.isPaginationStartIndexInZero){\n      this.page = action.item.pageIndex;\n    } else {\n      this.page = action.item.pageIndex + 1;\n    }\n    this.onFilterItems();\n  }\n\n  onOrder(column: TotsColumn) {\n    this.orderType = column.order;\n    this.orderKey = column.field_key as string;\n    this.onFilterItems();\n  }\n\n  onTableAction(action: TotsActionTable) {\n    if(action.key == 'page-change'){\n      this.onPagination(action);\n    } else if(action.key == 'click-order'){\n      this.onOrder(action.item);\n    }\n\n    this.onAction.emit(action);\n  }\n\n  loadConfig() {\n    if(this.configTable.obs == undefined){\n      return;\n    }\n    this.setObs(this.configTable.obs);\n  }\n\n  refreshQueryAndLoadItems() {\n    return this.loadItems();\n  }\n\n  loadItems() {\n    return this.tableComp.loadItems();\n  }\n\n  getDataItems(): TotsListResponse<any> | undefined {\n    return this.tableComp.getDataItems();\n  }\n\n  setDataItems(items: TotsListResponse<any>) {\n    this.tableComp.refreshDataItems(items);\n  }\n\n  setObs(obs: Observable<TotsListResponse<any>>) {\n    this.configTable.obs = obs.pipe(tap(res => this.dataItems = res.data));\n  }\n\n  onSearch(query: string) {\n    this.page = 1;\n    this.searchQuery = query;\n    this.onFilterItems();\n  }\n\n  generateListResponse(items: Array<any>): TotsListResponse<any> {\n    // calcular la iultima pagina\n    let lastPage = Math.ceil(this.dataTotals / this.perPage);\n\n    return {\n      current_page: this.page,\n      first_page_url: '',\n      from: '',\n      last_page: lastPage,\n      last_page_url: '',\n      next_page_url: '',\n      path: '',\n      per_page: this.perPage,\n      prev_page_url: '',\n      to: '',\n      total: this.dataTotals,\n      data: items\n    };\n  }\n}\n","<tots-table #tableComp [config]=\"configTable\" [pageIndex]=\"page\" [pageSize]=\"perPage\" (onAction)=\"onTableAction($event)\" [hasPagination]=\"hasPagination\"></tots-table>\n"]}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { TotsTableConfig } from "./tots-table-config";
|
|
2
|
+
export class TotsTableLocalConfig extends TotsTableConfig {
|
|
3
|
+
constructor() {
|
|
4
|
+
super(...arguments);
|
|
5
|
+
this.searchKeys = [];
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG90cy10YWJsZS1sb2NhbC1jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90b3RzL3RhYmxlL3NyYy9saWIvZW50aXRpZXMvdG90cy10YWJsZS1sb2NhbC1jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRXRELE1BQU0sT0FBTyxvQkFBcUIsU0FBUSxlQUFlO0lBQXpEOztRQUNFLGVBQVUsR0FBa0IsRUFBRSxDQUFDO0lBQ2pDLENBQUM7Q0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRvdHNCYXNlSHR0cFNlcnZpY2UsIFRvdHNMaXN0UmVzcG9uc2UsIFRvdHNRdWVyeSB9IGZyb20gXCJAdG90cy9jb3JlXCI7XG5pbXBvcnQgeyBUb3RzQ29sdW1uIH0gZnJvbSBcIi4vdG90cy1jb2x1bW5cIjtcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tIFwicnhqc1wiO1xuaW1wb3J0IHsgVG90c1RhYmxlQ29uZmlnIH0gZnJvbSBcIi4vdG90cy10YWJsZS1jb25maWdcIjtcblxuZXhwb3J0IGNsYXNzIFRvdHNUYWJsZUxvY2FsQ29uZmlnIGV4dGVuZHMgVG90c1RhYmxlQ29uZmlnIHtcbiAgc2VhcmNoS2V5czogQXJyYXk8c3RyaW5nPiA9IFtdO1xufVxuIl19
|
|
@@ -11,6 +11,7 @@ import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
|
|
|
11
11
|
/** Components */
|
|
12
12
|
import { TotsTableComponent } from './components/tots-table/tots-table.component';
|
|
13
13
|
import { TotsTableApiComponent } from './components/tots-table-api/tots-table-api.component';
|
|
14
|
+
import { TotsTableLocalComponent } from './components/tots-table-local/tots-table-local.component';
|
|
14
15
|
/** Columns */
|
|
15
16
|
import { BasePrintColumnComponent } from './columns/base-print-column/base-print-column.component';
|
|
16
17
|
import { StringColumnComponent } from './columns/string-column/string-column.component';
|
|
@@ -49,7 +50,8 @@ TotsTableModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version
|
|
|
49
50
|
BalanceCurrencyColumnComponent,
|
|
50
51
|
StatusIconColumnComponent,
|
|
51
52
|
BalanceCurrencyIconColumnComponent,
|
|
52
|
-
LoadingAnimationRendererComponent
|
|
53
|
+
LoadingAnimationRendererComponent,
|
|
54
|
+
TotsTableLocalComponent], imports: [CommonModule,
|
|
53
55
|
// Angular Material
|
|
54
56
|
MatIconModule,
|
|
55
57
|
MatTableModule,
|
|
@@ -59,7 +61,8 @@ TotsTableModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version
|
|
|
59
61
|
MatCheckboxModule,
|
|
60
62
|
MatProgressSpinnerModule,
|
|
61
63
|
MatProgressBarModule], exports: [TotsTableComponent,
|
|
62
|
-
TotsTableApiComponent
|
|
64
|
+
TotsTableApiComponent,
|
|
65
|
+
TotsTableLocalComponent] });
|
|
63
66
|
TotsTableModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsTableModule, providers: [
|
|
64
67
|
{
|
|
65
68
|
provide: TOTS_TABLE_DEFAULT_CONFIG,
|
|
@@ -95,7 +98,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
|
|
|
95
98
|
BalanceCurrencyColumnComponent,
|
|
96
99
|
StatusIconColumnComponent,
|
|
97
100
|
BalanceCurrencyIconColumnComponent,
|
|
98
|
-
LoadingAnimationRendererComponent
|
|
101
|
+
LoadingAnimationRendererComponent,
|
|
102
|
+
TotsTableLocalComponent
|
|
99
103
|
],
|
|
100
104
|
imports: [
|
|
101
105
|
CommonModule,
|
|
@@ -111,7 +115,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
|
|
|
111
115
|
],
|
|
112
116
|
exports: [
|
|
113
117
|
TotsTableComponent,
|
|
114
|
-
TotsTableApiComponent
|
|
118
|
+
TotsTableApiComponent,
|
|
119
|
+
TotsTableLocalComponent,
|
|
115
120
|
],
|
|
116
121
|
providers: [
|
|
117
122
|
{
|
|
@@ -121,4 +126,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
|
|
|
121
126
|
]
|
|
122
127
|
}]
|
|
123
128
|
}] });
|
|
124
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
129
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.module.js","sourceRoot":"","sources":["../../../../../projects/tots/table/src/lib/table.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\n\n/** Angular Material */\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatTableModule } from '@angular/material/table';\nimport { MatPaginatorModule } from '@angular/material/paginator';\nimport { MatMenuModule } from '@angular/material/menu';\nimport { MatCheckboxModule } from '@angular/material/checkbox';\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\n\n/** Components */\nimport { TotsTableComponent } from './components/tots-table/tots-table.component';\nimport { TotsTableApiComponent } from './components/tots-table-api/tots-table-api.component';\nimport { TotsTableLocalComponent } from './components/tots-table-local/tots-table-local.component';\n\n/** Columns */\nimport { BasePrintColumnComponent } from './columns/base-print-column/base-print-column.component';\nimport { StringColumnComponent } from './columns/string-column/string-column.component';\nimport { MoreMenuColumnComponent } from './columns/more-menu-column/more-menu-column.component';\nimport { BooleanColumnComponent } from './columns/boolean-column/boolean-column.component';\nimport { TwoStringColumnComponent } from './columns/two-string-column/two-string-column.component';\nimport { IconButtonColumnComponent } from './columns/icon-button-column/icon-button-column.component';\nimport { CheckboxColumnComponent } from './columns/checkbox-column/checkbox-column.component';\nimport { OptionColumnComponent } from './columns/option-column/option-column.component';\nimport { UserColumnComponent } from './columns/user-column/user-column.component';\nimport { CurrencyColumnComponent } from './columns/currency-column/currency-column.component';\nimport { StatusColumnComponent } from './columns/status-column/status-column.component';\nimport { BalanceCurrencyColumnComponent } from './columns/balance-currency-column/balance-currency-column.component';\nimport { StatusIconColumnComponent } from './columns/status-icon-column/status-icon-column.component';\nimport { BalanceCurrencyIconColumnComponent } from './columns/balance-currency-icon-column/balance-currency-icon-column.component';\nimport { TOTS_TABLE_DEFAULT_CONFIG, TotsTableDefaultConfig } from './entities/tots-table-default-config';\nimport { MatProgressBarModule } from '@angular/material/progress-bar';\nimport { LoadingAnimationRendererComponent } from './components/loading-animation-renderer/loading-animation-renderer.component';\n\n@NgModule({\n  declarations: [\n    TotsTableComponent,\n    BasePrintColumnComponent,\n    StringColumnComponent,\n    TotsTableApiComponent,\n    MoreMenuColumnComponent,\n    BooleanColumnComponent,\n    TwoStringColumnComponent,\n    IconButtonColumnComponent,\n    CheckboxColumnComponent,\n    OptionColumnComponent,\n    UserColumnComponent,\n    CurrencyColumnComponent,\n    StatusColumnComponent,\n    BalanceCurrencyColumnComponent,\n    StatusIconColumnComponent,\n    BalanceCurrencyIconColumnComponent,\n    LoadingAnimationRendererComponent,\n    TotsTableLocalComponent\n  ],\n  imports: [\n    CommonModule,\n    // Angular Material\n    MatIconModule,\n    MatTableModule,\n    MatPaginatorModule,\n    MatButtonModule,\n    MatMenuModule,\n    MatCheckboxModule,\n    MatProgressSpinnerModule,\n    MatProgressBarModule\n  ],\n  exports: [\n    TotsTableComponent,\n    TotsTableApiComponent,\n    TotsTableLocalComponent,\n  ],\n  providers: [\n    {\n      provide: TOTS_TABLE_DEFAULT_CONFIG,\n      useClass: TotsTableDefaultConfig\n    }\n  ]\n})\nexport class TotsTableModule { }\n"]}
|
package/esm2020/public-api.mjs
CHANGED
|
@@ -9,6 +9,7 @@ export * from './lib/entities/tots-table-config';
|
|
|
9
9
|
export * from './lib/entities/tots-table-default-config';
|
|
10
10
|
export * from './lib/entities/tots-action-table';
|
|
11
11
|
export * from './lib/entities/tots-table-api-config';
|
|
12
|
+
export * from './lib/entities/tots-table-local-config';
|
|
12
13
|
/**
|
|
13
14
|
* Helpers
|
|
14
15
|
*/
|
|
@@ -35,8 +36,9 @@ export * from './lib/columns/balance-currency-icon-column/balance-currency-icon-
|
|
|
35
36
|
*/
|
|
36
37
|
export * from './lib/components/tots-table/tots-table.component';
|
|
37
38
|
export * from './lib/components/tots-table-api/tots-table-api.component';
|
|
39
|
+
export * from './lib/components/tots-table-local/tots-table-local.component';
|
|
38
40
|
/**
|
|
39
41
|
* Modules
|
|
40
42
|
*/
|
|
41
43
|
export * from './lib/table.module';
|
|
42
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3RvdHMvdGFibGUvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSDs7R0FFRztBQUNILGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyxrQ0FBa0MsQ0FBQztBQUNqRCxjQUFjLDBDQUEwQyxDQUFDO0FBQ3pELGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLHdDQUF3QyxDQUFDO0FBRXZEOztHQUVHO0FBQ0gsY0FBYyxpQ0FBaUMsQ0FBQztBQUVoRDs7R0FFRztBQUNILGNBQWMsMENBQTBDLENBQUM7QUFDekQsY0FBYyxxREFBcUQsQ0FBQztBQUNwRSxjQUFjLDJEQUEyRCxDQUFDO0FBQzFFLGNBQWMsdURBQXVELENBQUM7QUFDdEUsY0FBYyw2REFBNkQsQ0FBQztBQUM1RSxjQUFjLCtEQUErRCxDQUFDO0FBQzlFLGNBQWMseURBQXlELENBQUM7QUFDeEUsY0FBYyxxREFBcUQsQ0FBQztBQUNwRSxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMseURBQXlELENBQUM7QUFDeEUsY0FBYyxxREFBcUQsQ0FBQztBQUNwRSxjQUFjLHlFQUF5RSxDQUFDO0FBQ3hGLGNBQWMsK0RBQStELENBQUM7QUFDOUUsY0FBYyxtRkFBbUYsQ0FBQztBQUVsRzs7R0FFRztBQUNILGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYywwREFBMEQsQ0FBQztBQUN6RSxjQUFjLDhEQUE4RCxDQUFDO0FBRTdFOztHQUVHO0FBQ0gsY0FBYyxvQkFBb0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgdGFibGVcbiAqL1xuXG4vKipcbiAqIEVudGl0aWVzXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vbGliL2VudGl0aWVzL3RvdHMtY29sdW1uJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VudGl0aWVzL3RvdHMtdGFibGUtY29uZmlnJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VudGl0aWVzL3RvdHMtdGFibGUtZGVmYXVsdC1jb25maWcnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZW50aXRpZXMvdG90cy1hY3Rpb24tdGFibGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZW50aXRpZXMvdG90cy10YWJsZS1hcGktY29uZmlnJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VudGl0aWVzL3RvdHMtdGFibGUtbG9jYWwtY29uZmlnJztcblxuLyoqXG4gKiBIZWxwZXJzXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vbGliL2hlbHBlcnMvdG90cy10YWJsZS1oZWxwZXInO1xuXG4vKipcbiAqIENvbHVtbnNcbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29sdW1ucy90b3RzLWJhc2UtY29sdW1uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb2x1bW5zL3N0cmluZy1jb2x1bW4vc3RyaW5nLWNvbHVtbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29sdW1ucy9tb3JlLW1lbnUtY29sdW1uL21vcmUtbWVudS1jb2x1bW4uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbHVtbnMvYm9vbGVhbi1jb2x1bW4vYm9vbGVhbi1jb2x1bW4uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbHVtbnMvdHdvLXN0cmluZy1jb2x1bW4vdHdvLXN0cmluZy1jb2x1bW4uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbHVtbnMvaWNvbi1idXR0b24tY29sdW1uL2ljb24tYnV0dG9uLWNvbHVtbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29sdW1ucy9jaGVja2JveC1jb2x1bW4vY2hlY2tib3gtY29sdW1uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb2x1bW5zL29wdGlvbi1jb2x1bW4vb3B0aW9uLWNvbHVtbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29sdW1ucy91c2VyLWNvbHVtbi91c2VyLWNvbHVtbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29sdW1ucy9jdXJyZW5jeS1jb2x1bW4vY3VycmVuY3ktY29sdW1uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb2x1bW5zL3N0YXR1cy1jb2x1bW4vc3RhdHVzLWNvbHVtbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29sdW1ucy9iYWxhbmNlLWN1cnJlbmN5LWNvbHVtbi9iYWxhbmNlLWN1cnJlbmN5LWNvbHVtbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29sdW1ucy9zdGF0dXMtaWNvbi1jb2x1bW4vc3RhdHVzLWljb24tY29sdW1uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb2x1bW5zL2JhbGFuY2UtY3VycmVuY3ktaWNvbi1jb2x1bW4vYmFsYW5jZS1jdXJyZW5jeS1pY29uLWNvbHVtbi5jb21wb25lbnQnO1xuXG4vKipcbiAqIENvbXBvbmVudHNcbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy90b3RzLXRhYmxlL3RvdHMtdGFibGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvdG90cy10YWJsZS1hcGkvdG90cy10YWJsZS1hcGkuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvdG90cy10YWJsZS1sb2NhbC90b3RzLXRhYmxlLWxvY2FsLmNvbXBvbmVudCc7XG5cbi8qKlxuICogTW9kdWxlc1xuICovXG5leHBvcnQgKiBmcm9tICcuL2xpYi90YWJsZS5tb2R1bGUnO1xuIl19
|
package/fesm2015/tots-table.mjs
CHANGED
|
@@ -61,6 +61,13 @@ class TotsTableApiConfig {
|
|
|
61
61
|
}
|
|
62
62
|
}
|
|
63
63
|
|
|
64
|
+
class TotsTableLocalConfig extends TotsTableConfig {
|
|
65
|
+
constructor() {
|
|
66
|
+
super(...arguments);
|
|
67
|
+
this.searchKeys = [];
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
|
|
64
71
|
class TotsTableHelper {
|
|
65
72
|
/**
|
|
66
73
|
* Obtiene el valor de un objeto a traves de la KEY
|
|
@@ -572,6 +579,139 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
|
|
|
572
579
|
type: Output
|
|
573
580
|
}] } });
|
|
574
581
|
|
|
582
|
+
class TotsTableLocalComponent {
|
|
583
|
+
constructor() {
|
|
584
|
+
this.configTable = new TotsTableLocalConfig();
|
|
585
|
+
this.hasPagination = true;
|
|
586
|
+
this.isPaginationStartIndexInZero = false;
|
|
587
|
+
this.onAction = new EventEmitter();
|
|
588
|
+
this.dataTotals = 0;
|
|
589
|
+
this.page = 1;
|
|
590
|
+
this.perPage = 50;
|
|
591
|
+
}
|
|
592
|
+
ngOnInit() {
|
|
593
|
+
this.loadConfig();
|
|
594
|
+
}
|
|
595
|
+
onFilterItems() {
|
|
596
|
+
if (this.dataItems == undefined) {
|
|
597
|
+
return;
|
|
598
|
+
}
|
|
599
|
+
let items = [...this.dataItems];
|
|
600
|
+
if (this.orderKey != undefined) {
|
|
601
|
+
if (this.orderType == 'asc') {
|
|
602
|
+
items = items.sort((a, b) => (a[this.orderKey] > b[this.orderKey]) ? 1 : ((b[this.orderKey] > a[this.orderKey]) ? -1 : 0));
|
|
603
|
+
}
|
|
604
|
+
else {
|
|
605
|
+
items = items.sort((a, b) => (a[this.orderKey] < b[this.orderKey]) ? 1 : ((b[this.orderKey] < a[this.orderKey]) ? -1 : 0));
|
|
606
|
+
}
|
|
607
|
+
}
|
|
608
|
+
// Aplicar busqueda
|
|
609
|
+
if (this.searchQuery != undefined && this.searchQuery != '') {
|
|
610
|
+
items = items.filter(item => {
|
|
611
|
+
let isMatch = false;
|
|
612
|
+
this.configTable.searchKeys.forEach(key => {
|
|
613
|
+
if (item[key] != undefined && item[key].toString().toLowerCase().includes(this.searchQuery.toLowerCase())) {
|
|
614
|
+
isMatch = true;
|
|
615
|
+
}
|
|
616
|
+
});
|
|
617
|
+
return isMatch;
|
|
618
|
+
});
|
|
619
|
+
this.dataTotals = items.length;
|
|
620
|
+
}
|
|
621
|
+
else {
|
|
622
|
+
this.dataTotals = this.dataItems.length;
|
|
623
|
+
}
|
|
624
|
+
let startIndex = (this.page - 1) * this.perPage;
|
|
625
|
+
let endIndex = startIndex + this.perPage;
|
|
626
|
+
this.setDataItems(this.generateListResponse(items.slice(startIndex, endIndex)));
|
|
627
|
+
}
|
|
628
|
+
onPagination(action) {
|
|
629
|
+
this.perPage = action.item.pageSize;
|
|
630
|
+
if (this.isPaginationStartIndexInZero) {
|
|
631
|
+
this.page = action.item.pageIndex;
|
|
632
|
+
}
|
|
633
|
+
else {
|
|
634
|
+
this.page = action.item.pageIndex + 1;
|
|
635
|
+
}
|
|
636
|
+
this.onFilterItems();
|
|
637
|
+
}
|
|
638
|
+
onOrder(column) {
|
|
639
|
+
this.orderType = column.order;
|
|
640
|
+
this.orderKey = column.field_key;
|
|
641
|
+
this.onFilterItems();
|
|
642
|
+
}
|
|
643
|
+
onTableAction(action) {
|
|
644
|
+
if (action.key == 'page-change') {
|
|
645
|
+
this.onPagination(action);
|
|
646
|
+
}
|
|
647
|
+
else if (action.key == 'click-order') {
|
|
648
|
+
this.onOrder(action.item);
|
|
649
|
+
}
|
|
650
|
+
this.onAction.emit(action);
|
|
651
|
+
}
|
|
652
|
+
loadConfig() {
|
|
653
|
+
if (this.configTable.obs == undefined) {
|
|
654
|
+
return;
|
|
655
|
+
}
|
|
656
|
+
this.setObs(this.configTable.obs);
|
|
657
|
+
}
|
|
658
|
+
refreshQueryAndLoadItems() {
|
|
659
|
+
return this.loadItems();
|
|
660
|
+
}
|
|
661
|
+
loadItems() {
|
|
662
|
+
return this.tableComp.loadItems();
|
|
663
|
+
}
|
|
664
|
+
getDataItems() {
|
|
665
|
+
return this.tableComp.getDataItems();
|
|
666
|
+
}
|
|
667
|
+
setDataItems(items) {
|
|
668
|
+
this.tableComp.refreshDataItems(items);
|
|
669
|
+
}
|
|
670
|
+
setObs(obs) {
|
|
671
|
+
this.configTable.obs = obs.pipe(tap(res => this.dataItems = res.data));
|
|
672
|
+
}
|
|
673
|
+
onSearch(query) {
|
|
674
|
+
this.page = 1;
|
|
675
|
+
this.searchQuery = query;
|
|
676
|
+
this.onFilterItems();
|
|
677
|
+
}
|
|
678
|
+
generateListResponse(items) {
|
|
679
|
+
// calcular la iultima pagina
|
|
680
|
+
let lastPage = Math.ceil(this.dataTotals / this.perPage);
|
|
681
|
+
return {
|
|
682
|
+
current_page: this.page,
|
|
683
|
+
first_page_url: '',
|
|
684
|
+
from: '',
|
|
685
|
+
last_page: lastPage,
|
|
686
|
+
last_page_url: '',
|
|
687
|
+
next_page_url: '',
|
|
688
|
+
path: '',
|
|
689
|
+
per_page: this.perPage,
|
|
690
|
+
prev_page_url: '',
|
|
691
|
+
to: '',
|
|
692
|
+
total: this.dataTotals,
|
|
693
|
+
data: items
|
|
694
|
+
};
|
|
695
|
+
}
|
|
696
|
+
}
|
|
697
|
+
TotsTableLocalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsTableLocalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
698
|
+
TotsTableLocalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: TotsTableLocalComponent, selector: "tots-table-local", inputs: { configTable: "configTable", hasPagination: "hasPagination", isPaginationStartIndexInZero: "isPaginationStartIndexInZero" }, outputs: { onAction: "onAction" }, viewQueries: [{ propertyName: "tableComp", first: true, predicate: ["tableComp"], descendants: true }], ngImport: i0, template: "<tots-table #tableComp [config]=\"configTable\" [pageIndex]=\"page\" [pageSize]=\"perPage\" (onAction)=\"onTableAction($event)\" [hasPagination]=\"hasPagination\"></tots-table>\n", styles: [""], dependencies: [{ kind: "component", type: TotsTableComponent, selector: "tots-table", inputs: ["config", "pageIndex", "pageSize", "hasPagination", "messageNotFound"], outputs: ["onAction"] }] });
|
|
699
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsTableLocalComponent, decorators: [{
|
|
700
|
+
type: Component,
|
|
701
|
+
args: [{ selector: 'tots-table-local', template: "<tots-table #tableComp [config]=\"configTable\" [pageIndex]=\"page\" [pageSize]=\"perPage\" (onAction)=\"onTableAction($event)\" [hasPagination]=\"hasPagination\"></tots-table>\n" }]
|
|
702
|
+
}], propDecorators: { tableComp: [{
|
|
703
|
+
type: ViewChild,
|
|
704
|
+
args: ['tableComp']
|
|
705
|
+
}], configTable: [{
|
|
706
|
+
type: Input
|
|
707
|
+
}], hasPagination: [{
|
|
708
|
+
type: Input
|
|
709
|
+
}], isPaginationStartIndexInZero: [{
|
|
710
|
+
type: Input
|
|
711
|
+
}], onAction: [{
|
|
712
|
+
type: Output
|
|
713
|
+
}] } });
|
|
714
|
+
|
|
575
715
|
class TotsTableModule {
|
|
576
716
|
}
|
|
577
717
|
TotsTableModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsTableModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
@@ -591,7 +731,8 @@ TotsTableModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version
|
|
|
591
731
|
BalanceCurrencyColumnComponent,
|
|
592
732
|
StatusIconColumnComponent,
|
|
593
733
|
BalanceCurrencyIconColumnComponent,
|
|
594
|
-
LoadingAnimationRendererComponent
|
|
734
|
+
LoadingAnimationRendererComponent,
|
|
735
|
+
TotsTableLocalComponent], imports: [CommonModule,
|
|
595
736
|
// Angular Material
|
|
596
737
|
MatIconModule,
|
|
597
738
|
MatTableModule,
|
|
@@ -601,7 +742,8 @@ TotsTableModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version
|
|
|
601
742
|
MatCheckboxModule,
|
|
602
743
|
MatProgressSpinnerModule,
|
|
603
744
|
MatProgressBarModule], exports: [TotsTableComponent,
|
|
604
|
-
TotsTableApiComponent
|
|
745
|
+
TotsTableApiComponent,
|
|
746
|
+
TotsTableLocalComponent] });
|
|
605
747
|
TotsTableModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsTableModule, providers: [
|
|
606
748
|
{
|
|
607
749
|
provide: TOTS_TABLE_DEFAULT_CONFIG,
|
|
@@ -637,7 +779,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
|
|
|
637
779
|
BalanceCurrencyColumnComponent,
|
|
638
780
|
StatusIconColumnComponent,
|
|
639
781
|
BalanceCurrencyIconColumnComponent,
|
|
640
|
-
LoadingAnimationRendererComponent
|
|
782
|
+
LoadingAnimationRendererComponent,
|
|
783
|
+
TotsTableLocalComponent
|
|
641
784
|
],
|
|
642
785
|
imports: [
|
|
643
786
|
CommonModule,
|
|
@@ -653,7 +796,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
|
|
|
653
796
|
],
|
|
654
797
|
exports: [
|
|
655
798
|
TotsTableComponent,
|
|
656
|
-
TotsTableApiComponent
|
|
799
|
+
TotsTableApiComponent,
|
|
800
|
+
TotsTableLocalComponent,
|
|
657
801
|
],
|
|
658
802
|
providers: [
|
|
659
803
|
{
|
|
@@ -672,5 +816,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
|
|
|
672
816
|
* Generated bundle index. Do not edit.
|
|
673
817
|
*/
|
|
674
818
|
|
|
675
|
-
export { BalanceCurrencyColumnComponent, BalanceCurrencyIconColumnComponent, BooleanColumnComponent, CheckboxColumnComponent, CurrencyColumnComponent, IconButtonColumnComponent, MoreMenuColumnComponent, OptionColumnComponent, StatusColumnComponent, StatusIconColumnComponent, StringColumnComponent, TOTS_TABLE_DEFAULT_CONFIG, TotsActionTable, TotsBaseColumnComponent, TotsColumn, TotsTableApiComponent, TotsTableApiConfig, TotsTableComponent, TotsTableConfig, TotsTableDefaultConfig, TotsTableHelper, TotsTableModule, TwoStringColumnComponent, UserColumnComponent };
|
|
819
|
+
export { BalanceCurrencyColumnComponent, BalanceCurrencyIconColumnComponent, BooleanColumnComponent, CheckboxColumnComponent, CurrencyColumnComponent, IconButtonColumnComponent, MoreMenuColumnComponent, OptionColumnComponent, StatusColumnComponent, StatusIconColumnComponent, StringColumnComponent, TOTS_TABLE_DEFAULT_CONFIG, TotsActionTable, TotsBaseColumnComponent, TotsColumn, TotsTableApiComponent, TotsTableApiConfig, TotsTableComponent, TotsTableConfig, TotsTableDefaultConfig, TotsTableHelper, TotsTableLocalComponent, TotsTableLocalConfig, TotsTableModule, TwoStringColumnComponent, UserColumnComponent };
|
|
676
820
|
//# sourceMappingURL=tots-table.mjs.map
|