coer-elements 0.0.23 → 0.0.25
Sign up to get free protection for your applications and to get access to all the features.
- package/components/index.d.ts +5 -0
- package/components/lib/coer-button/coer-button.component.d.ts +44 -0
- package/components/lib/coer-checkbox/coer-checkbox.component.d.ts +28 -0
- package/components/lib/coer-filebox/coer-filebox.component.d.ts +33 -0
- package/components/lib/coer-form/coer-form.component.d.ts +33 -0
- package/components/lib/coer-grid/coer-grid.component.d.ts +53 -0
- package/components/lib/coer-grid/coer-grid.extension.d.ts +103 -0
- package/components/lib/coer-grid/coer-grid.templates.d.ts +9 -0
- package/components/lib/coer-modal/coer-modal.component.d.ts +38 -0
- package/components/lib/coer-numberbox/coer-numberbox.component.d.ts +55 -0
- package/components/lib/coer-page-title/coer-page-title.component.d.ts +12 -0
- package/components/lib/coer-selectbox/coer-selectbox.component.d.ts +75 -0
- package/components/lib/coer-switch/coer-switch.component.d.ts +31 -0
- package/components/lib/coer-tab/coer-tab.component.d.ts +35 -0
- package/components/lib/coer-textarea/coer-textarea.component.d.ts +51 -0
- package/components/lib/coer-textbox/coer-textbox.component.d.ts +57 -0
- package/components/lib/components.module.d.ts +30 -0
- package/components/public-api.d.ts +15 -0
- package/directives/index.d.ts +5 -0
- package/directives/lib/coer-ref.directive.d.ts +14 -0
- package/directives/lib/directives.module.d.ts +8 -0
- package/directives/lib/life-cycle.directive.d.ts +16 -0
- package/directives/public-api.d.ts +3 -0
- package/esm2022/components/coer-elements-components.mjs +5 -0
- package/esm2022/components/lib/coer-button/coer-button.component.mjs +133 -0
- package/esm2022/components/lib/coer-checkbox/coer-checkbox.component.mjs +83 -0
- package/esm2022/components/lib/coer-filebox/coer-filebox.component.mjs +102 -0
- package/esm2022/components/lib/coer-form/coer-form.component.mjs +101 -0
- package/esm2022/components/lib/coer-grid/coer-grid.component.mjs +512 -0
- package/esm2022/components/lib/coer-grid/coer-grid.extension.mjs +408 -0
- package/esm2022/components/lib/coer-grid/coer-grid.templates.mjs +30 -0
- package/esm2022/components/lib/coer-modal/coer-modal.component.mjs +107 -0
- package/esm2022/components/lib/coer-numberbox/coer-numberbox.component.mjs +258 -0
- package/esm2022/components/lib/coer-page-title/coer-page-title.component.mjs +44 -0
- package/esm2022/components/lib/coer-selectbox/coer-selectbox.component.mjs +338 -0
- package/esm2022/components/lib/coer-switch/coer-switch.component.mjs +93 -0
- package/esm2022/components/lib/coer-tab/coer-tab.component.mjs +116 -0
- package/esm2022/components/lib/coer-textarea/coer-textarea.component.mjs +156 -0
- package/esm2022/components/lib/coer-textbox/coer-textbox.component.mjs +195 -0
- package/esm2022/components/lib/components.module.mjs +129 -0
- package/esm2022/components/public-api.mjs +16 -0
- package/esm2022/directives/coer-elements-directives.mjs +5 -0
- package/esm2022/directives/lib/coer-ref.directive.mjs +23 -0
- package/esm2022/directives/lib/directives.module.mjs +25 -0
- package/esm2022/directives/lib/life-cycle.directive.mjs +33 -0
- package/esm2022/directives/public-api.mjs +4 -0
- package/esm2022/interfaces/coer-elements-interfaces.mjs +5 -0
- package/esm2022/interfaces/lib/app-source.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-filebox/file-image.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-filebox/file.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-grid/grid-button-by-row.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-grid/grid-checkbox.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-grid/grid-coer-numberbox.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-grid/grid-coer-selectbox.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-grid/grid-coer-switch.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-grid/grid-coer-textbox.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-grid/grid-column.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-grid/grid-data-source.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-grid/grid-header-button.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-grid/grid-header-export-button.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-grid/grid-header.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-grid/grid-import.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-grid/grid-input-checkbox.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-grid/grid-input-switch-change.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-grid/grid-input-textbox.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-grid/grid-item.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-grid/grid-keyup-enter.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-grid/grid-length.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-grid/grid-search.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-grid/grid-sort.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-menu/menu-option-selected.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-menu/menu-selected.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-menu/menu.interface.mjs +2 -0
- package/esm2022/interfaces/lib/coer-ref.interface.mjs +2 -0
- package/esm2022/interfaces/lib/page-title/breadcrumb.interface.mjs +2 -0
- package/esm2022/interfaces/lib/page-title/go-back.interface.mjs +2 -0
- package/esm2022/interfaces/lib/screen-size.interface.mjs +2 -0
- package/esm2022/interfaces/lib/service/http-request.interface.mjs +2 -0
- package/esm2022/interfaces/lib/service/http-response.interface.mjs +2 -0
- package/esm2022/interfaces/lib/service/patch.interface.mjs +2 -0
- package/esm2022/interfaces/public-api.mjs +39 -0
- package/esm2022/pipes/coer-elements-pipes.mjs +5 -0
- package/esm2022/pipes/lib/html.pipe.mjs +18 -0
- package/esm2022/pipes/lib/no-image.pipe.mjs +23 -0
- package/esm2022/pipes/lib/numeric-format.pipe.mjs +15 -0
- package/esm2022/pipes/lib/pipes.module.mjs +31 -0
- package/esm2022/pipes/public-api.mjs +5 -0
- package/esm2022/signals/coer-elements-signals.mjs +5 -0
- package/esm2022/signals/lib/breakpoint.signal.mjs +4 -0
- package/esm2022/signals/lib/is-loading.signal.mjs +3 -0
- package/esm2022/signals/lib/is-menu-open.signal.mjs +3 -0
- package/esm2022/signals/lib/is-modal-open.signal.mjs +3 -0
- package/esm2022/signals/lib/menu.signal.mjs +3 -0
- package/esm2022/signals/public-api.mjs +6 -0
- package/esm2022/tools/coer-elements-tools.mjs +5 -0
- package/esm2022/tools/lib/breadcrumbs.class.mjs +63 -0
- package/esm2022/tools/lib/coer-alert/coer-alert.component.mjs +228 -0
- package/esm2022/tools/lib/control-value.class.mjs +46 -0
- package/esm2022/tools/lib/date-time.class.mjs +29 -0
- package/esm2022/tools/lib/files.class.mjs +91 -0
- package/esm2022/tools/lib/menu.class.mjs +23 -0
- package/esm2022/tools/lib/page.class.mjs +156 -0
- package/esm2022/tools/lib/screen.class.mjs +51 -0
- package/esm2022/tools/lib/service.class.mjs +247 -0
- package/esm2022/tools/lib/source.class.mjs +80 -0
- package/esm2022/tools/lib/tools.mjs +220 -0
- package/esm2022/tools/public-api.mjs +12 -0
- package/fesm2022/coer-elements-components.mjs +2718 -0
- package/fesm2022/coer-elements-components.mjs.map +1 -0
- package/fesm2022/coer-elements-directives.mjs +82 -0
- package/fesm2022/coer-elements-directives.mjs.map +1 -0
- package/fesm2022/coer-elements-interfaces.mjs +6 -0
- package/fesm2022/coer-elements-interfaces.mjs.map +1 -0
- package/fesm2022/coer-elements-pipes.mjs +83 -0
- package/fesm2022/coer-elements-pipes.mjs.map +1 -0
- package/fesm2022/coer-elements-signals.mjs +19 -0
- package/fesm2022/coer-elements-signals.mjs.map +1 -0
- package/fesm2022/coer-elements-tools.mjs +1223 -0
- package/fesm2022/coer-elements-tools.mjs.map +1 -0
- package/interfaces/index.d.ts +5 -0
- package/interfaces/lib/app-source.interface.d.ts +4 -0
- package/interfaces/lib/coer-filebox/file-image.interface.d.ts +14 -0
- package/interfaces/lib/coer-filebox/file.interface.d.ts +5 -0
- package/interfaces/lib/coer-grid/grid-button-by-row.interface.d.ts +6 -0
- package/interfaces/lib/coer-grid/grid-checkbox.interface.d.ts +5 -0
- package/interfaces/lib/coer-grid/grid-coer-numberbox.interface.d.ts +12 -0
- package/interfaces/lib/coer-grid/grid-coer-selectbox.interface.d.ts +9 -0
- package/interfaces/lib/coer-grid/grid-coer-switch.interface.d.ts +6 -0
- package/interfaces/lib/coer-grid/grid-coer-textbox.interface.d.ts +11 -0
- package/interfaces/lib/coer-grid/grid-column.interface.d.ts +22 -0
- package/interfaces/lib/coer-grid/grid-data-source.interface.d.ts +6 -0
- package/interfaces/lib/coer-grid/grid-header-button.interface.d.ts +8 -0
- package/interfaces/lib/coer-grid/grid-header-export-button.interface.d.ts +10 -0
- package/interfaces/lib/coer-grid/grid-header.interface.d.ts +5 -0
- package/interfaces/lib/coer-grid/grid-import.interface.d.ts +4 -0
- package/interfaces/lib/coer-grid/grid-input-checkbox.interface.d.ts +5 -0
- package/interfaces/lib/coer-grid/grid-input-switch-change.interface.d.ts +5 -0
- package/interfaces/lib/coer-grid/grid-input-textbox.interface.d.ts +5 -0
- package/interfaces/lib/coer-grid/grid-item.interface.d.ts +5 -0
- package/interfaces/lib/coer-grid/grid-keyup-enter.interface.d.ts +6 -0
- package/interfaces/lib/coer-grid/grid-length.interface.d.ts +5 -0
- package/interfaces/lib/coer-grid/grid-search.interface.d.ts +4 -0
- package/interfaces/lib/coer-grid/grid-sort.interface.d.ts +5 -0
- package/interfaces/lib/coer-menu/menu-option-selected.interface.d.ts +9 -0
- package/interfaces/lib/coer-menu/menu-selected.interface.d.ts +10 -0
- package/interfaces/lib/coer-menu/menu.interface.d.ts +6 -0
- package/interfaces/lib/coer-ref.interface.d.ts +10 -0
- package/interfaces/lib/page-title/breadcrumb.interface.d.ts +6 -0
- package/interfaces/lib/page-title/go-back.interface.d.ts +6 -0
- package/interfaces/lib/screen-size.interface.d.ts +5 -0
- package/interfaces/lib/service/http-request.interface.d.ts +10 -0
- package/interfaces/lib/service/http-response.interface.d.ts +6 -0
- package/interfaces/lib/service/patch.interface.d.ts +5 -0
- package/interfaces/public-api.d.ts +33 -0
- package/package.json +37 -1
- package/pipes/index.d.ts +5 -0
- package/pipes/lib/html.pipe.d.ts +10 -0
- package/pipes/lib/no-image.pipe.d.ts +7 -0
- package/pipes/lib/numeric-format.pipe.d.ts +7 -0
- package/pipes/lib/pipes.module.d.ts +9 -0
- package/pipes/public-api.d.ts +4 -0
- package/signals/index.d.ts +5 -0
- package/signals/lib/breakpoint.signal.d.ts +1 -0
- package/signals/lib/is-loading.signal.d.ts +1 -0
- package/signals/lib/is-menu-open.signal.d.ts +1 -0
- package/signals/lib/is-modal-open.signal.d.ts +1 -0
- package/signals/lib/menu.signal.d.ts +2 -0
- package/signals/public-api.d.ts +5 -0
- package/tools/index.d.ts +5 -0
- package/tools/lib/breadcrumbs.class.d.ts +18 -0
- package/tools/lib/coer-alert/coer-alert.component.d.ts +23 -0
- package/tools/lib/control-value.class.d.ts +25 -0
- package/tools/lib/date-time.class.d.ts +13 -0
- package/tools/lib/files.class.d.ts +16 -0
- package/tools/lib/menu.class.d.ts +8 -0
- package/tools/lib/page.class.d.ts +60 -0
- package/tools/lib/screen.class.d.ts +13 -0
- package/tools/lib/service.class.d.ts +39 -0
- package/tools/lib/source.class.d.ts +20 -0
- package/tools/lib/tools.d.ts +34 -0
- package/tools/public-api.d.ts +11 -0
@@ -0,0 +1,408 @@
|
|
1
|
+
import { Component, Input, computed, inject, input, output, signal, viewChild, viewChildren } from "@angular/core";
|
2
|
+
import { CoerCheckbox } from "../../lib/coer-checkbox/coer-checkbox.component";
|
3
|
+
import { CoerNumberBox } from "../../lib/coer-numberbox/coer-numberbox.component";
|
4
|
+
import { CoerSelectbox } from "../../lib/coer-selectbox/coer-selectbox.component";
|
5
|
+
import { CoerTextBox } from "../../lib/coer-textbox/coer-textbox.component";
|
6
|
+
import { CoerAlert, ControlValue, DateTime, Screen, Tools } from 'coer-elements/tools';
|
7
|
+
import * as i0 from "@angular/core";
|
8
|
+
export class CoerGridExtension extends ControlValue {
|
9
|
+
constructor() {
|
10
|
+
super(...arguments);
|
11
|
+
//Injections
|
12
|
+
this.alert = inject(CoerAlert);
|
13
|
+
//Elements
|
14
|
+
this.inputFile = viewChild.required('inputFileRef');
|
15
|
+
this.inputSearch = viewChild.required('inputSearch');
|
16
|
+
this.coerTextboxList = viewChildren(CoerTextBox);
|
17
|
+
this.coerNumberboxList = viewChildren(CoerNumberBox);
|
18
|
+
this.coerSelectboxList = viewChildren(CoerSelectbox);
|
19
|
+
this.coerCheckboxList = viewChildren(CoerCheckbox);
|
20
|
+
//Variables
|
21
|
+
this._value = [];
|
22
|
+
this.value_signal = signal([]);
|
23
|
+
this._gridSearch = signal('');
|
24
|
+
this._isLoading = true;
|
25
|
+
this._isLoadingMessage = true;
|
26
|
+
this._id = Tools.GetGuid('coer-grid');
|
27
|
+
this._expandedGroups = [];
|
28
|
+
this._enableAnimations = false;
|
29
|
+
this._indexFocus = signal(0);
|
30
|
+
this._sort = signal({ columnName: '', direction: 'none', icon: '' });
|
31
|
+
//Generic Tools
|
32
|
+
this.GetNumericFormat = Tools.GetNumericFormat;
|
33
|
+
this.GetDateFormat = DateTime.GetDateFormat;
|
34
|
+
//Inputs
|
35
|
+
this.columns = input([]);
|
36
|
+
this.cleanColumnName = input(true);
|
37
|
+
this.addButton = { show: false };
|
38
|
+
this.exportButton = { show: false };
|
39
|
+
this.importButton = { show: false };
|
40
|
+
this.search = { show: false, ignore: false };
|
41
|
+
this.buttonByRow = {};
|
42
|
+
this.checkbox = { show: false };
|
43
|
+
this.tooltipByRow = input('');
|
44
|
+
this.isLoading = input(false);
|
45
|
+
this.isDisabled = input(false);
|
46
|
+
this.rowsByPage = input(50);
|
47
|
+
this.groupBy = input('');
|
48
|
+
this.showColumnGrouped = input(false);
|
49
|
+
this.rowsByGroup = input(50);
|
50
|
+
this.isInvisible = input(false);
|
51
|
+
this.showFooter = input(true);
|
52
|
+
this.width = input('100%');
|
53
|
+
this.MinWidth = input('250px');
|
54
|
+
this.MaxWidth = input('100%');
|
55
|
+
this.height = input('350px');
|
56
|
+
this.minHeight = input('140px');
|
57
|
+
this.maxHeight = input('100vh');
|
58
|
+
this.margin = input('auto');
|
59
|
+
this.enableSort = input(true);
|
60
|
+
this.enableRowFocus = input(true);
|
61
|
+
//Outputs
|
62
|
+
this.onClickAdd = output();
|
63
|
+
this.onClickImport = output();
|
64
|
+
this.onClickExport = output();
|
65
|
+
this.onClickRow = output();
|
66
|
+
this.onDoubleClickRow = output();
|
67
|
+
this.onClickDeleteRow = output();
|
68
|
+
this.onClickEditRow = output();
|
69
|
+
this.onClickGoRow = output();
|
70
|
+
this.onKeyupEnter = output();
|
71
|
+
this.onKeyupEnterLast = output();
|
72
|
+
this.onSwitchChange = output();
|
73
|
+
this.onTextboxChange = output();
|
74
|
+
this.onSelectboxChange = output();
|
75
|
+
this.onCheckboxChange = output();
|
76
|
+
//computed
|
77
|
+
this._isDisabled = computed(() => {
|
78
|
+
return this.isDisabled() || this.isLoading() || this.isInvisible();
|
79
|
+
});
|
80
|
+
//computed
|
81
|
+
this._isGrouped = computed(() => {
|
82
|
+
return this.groupBy().length > 0;
|
83
|
+
});
|
84
|
+
//computed
|
85
|
+
this.gridColumns = computed(() => {
|
86
|
+
const SET_COLUMNS = new Set();
|
87
|
+
//Has filter columns?
|
88
|
+
if (this.columns().length > 0) {
|
89
|
+
for (const { property } of this.columns()) {
|
90
|
+
SET_COLUMNS.add(property);
|
91
|
+
}
|
92
|
+
}
|
93
|
+
//Get all columns
|
94
|
+
else
|
95
|
+
for (const row of this.value_signal()) {
|
96
|
+
for (const property in row) {
|
97
|
+
SET_COLUMNS.add(property);
|
98
|
+
}
|
99
|
+
}
|
100
|
+
//Remove indexRow column
|
101
|
+
if (SET_COLUMNS.has('indexRow')) {
|
102
|
+
SET_COLUMNS.delete('indexRow');
|
103
|
+
}
|
104
|
+
//Remove groupBy column
|
105
|
+
if (this._isGrouped() && !this.showColumnGrouped() && SET_COLUMNS.has(this.groupBy())) {
|
106
|
+
SET_COLUMNS.delete(this.groupBy());
|
107
|
+
}
|
108
|
+
//Set index column
|
109
|
+
let indexColumn = 0;
|
110
|
+
return Array.from(SET_COLUMNS).map(property => Tools.BreakReference({
|
111
|
+
columnName: property,
|
112
|
+
indexColumn: indexColumn++,
|
113
|
+
width: this._GetColumnConfig(property)?.width || 'auto'
|
114
|
+
}));
|
115
|
+
});
|
116
|
+
//computed
|
117
|
+
this.gridDataSource = computed(() => {
|
118
|
+
let list = this.gridDataSourceFiltered();
|
119
|
+
//It's Grouped?
|
120
|
+
if (this._isGrouped()) {
|
121
|
+
//let indexRow = 0;
|
122
|
+
let indexGroup = 0;
|
123
|
+
const SET_COLUMN = new Set();
|
124
|
+
for (const row of list) {
|
125
|
+
SET_COLUMN.add(row[this.groupBy()]);
|
126
|
+
}
|
127
|
+
const DATA_SOURCE_GROPUED = [];
|
128
|
+
for (const column of SET_COLUMN) {
|
129
|
+
DATA_SOURCE_GROPUED.push({
|
130
|
+
groupBy: column,
|
131
|
+
indexGroup: indexGroup++,
|
132
|
+
length: list.filter((item) => item[this.groupBy()] == column).length,
|
133
|
+
rows: [...list]
|
134
|
+
.filter((item) => item[this.groupBy()] == column)
|
135
|
+
.splice(0, this.rowsByGroup())
|
136
|
+
//.map((item: any) => Object.assign({ indexRow: indexRow++ }, item))
|
137
|
+
});
|
138
|
+
}
|
139
|
+
//Response by group
|
140
|
+
return [...DATA_SOURCE_GROPUED].splice(0, this.rowsByPage());
|
141
|
+
}
|
142
|
+
//Response
|
143
|
+
return [{
|
144
|
+
groupBy: 'Not Grouped',
|
145
|
+
indexGroup: -1,
|
146
|
+
length: -1,
|
147
|
+
rows: [...list].splice(0, this.rowsByPage())
|
148
|
+
}];
|
149
|
+
});
|
150
|
+
//computed
|
151
|
+
this.gridDataSourceFiltered = computed(() => {
|
152
|
+
let list = [];
|
153
|
+
const dataSource = Tools.BreakReference(this.value_signal());
|
154
|
+
//Ignore Filter
|
155
|
+
if (this._gridSearch() == '' || this.search?.ignore) {
|
156
|
+
list = dataSource;
|
157
|
+
}
|
158
|
+
//Filter by search
|
159
|
+
else {
|
160
|
+
const SET_ROW = new Set();
|
161
|
+
let listFiltered = [];
|
162
|
+
for (const { columnName } of this.gridColumns()) {
|
163
|
+
listFiltered = dataSource.filter((item) => !SET_ROW.has(item['indexRow'])
|
164
|
+
&& String(item[Tools.FirstCharToLower(columnName)]).trim().toUpperCase().includes(String(this._gridSearch()).trim().toUpperCase()));
|
165
|
+
for (const { indexRow } of listFiltered) {
|
166
|
+
SET_ROW.add(indexRow);
|
167
|
+
}
|
168
|
+
list = Tools.BreakReference(list.concat(listFiltered));
|
169
|
+
}
|
170
|
+
}
|
171
|
+
return Tools.BreakReference(list);
|
172
|
+
});
|
173
|
+
/** Get Column Configuration */
|
174
|
+
this._GetColumnConfig = (columnName) => {
|
175
|
+
return this.columns().find(x => x.property.replaceAll(' ', '').toUpperCase() == columnName.replaceAll(' ', '').toUpperCase());
|
176
|
+
};
|
177
|
+
/** Clean Name or get alias */
|
178
|
+
this._GetColumnName = (columnName) => {
|
179
|
+
const columnConfig = this._GetColumnConfig(columnName);
|
180
|
+
//Get Alias
|
181
|
+
if (columnConfig && columnConfig.alias && columnConfig.alias.length > 0) {
|
182
|
+
return columnConfig.alias;
|
183
|
+
}
|
184
|
+
//Clean headerName
|
185
|
+
if (this.cleanColumnName() && columnName.length > 0) {
|
186
|
+
columnName = Tools.FirstCharToLower(columnName);
|
187
|
+
const charArray = [];
|
188
|
+
for (const char of columnName) {
|
189
|
+
if (char === char.toUpperCase())
|
190
|
+
charArray.push(' ');
|
191
|
+
charArray.push(char);
|
192
|
+
}
|
193
|
+
charArray[0] = charArray[0].toUpperCase();
|
194
|
+
columnName = charArray.join('');
|
195
|
+
}
|
196
|
+
return columnName.trim();
|
197
|
+
};
|
198
|
+
/** */
|
199
|
+
this._GetShortIcon = (columnName) => {
|
200
|
+
return this._sort().columnName == columnName ? this._sort().icon : '';
|
201
|
+
};
|
202
|
+
/** */
|
203
|
+
this._GetId = (indexRow, indexColumn, suffix = '') => {
|
204
|
+
if (suffix.length > 0)
|
205
|
+
suffix = `-${suffix}`;
|
206
|
+
return `${this._id}-row${indexRow}column${indexColumn}${suffix}`;
|
207
|
+
};
|
208
|
+
/** */
|
209
|
+
this._GetCellValue = (row, columnName) => {
|
210
|
+
return row[Tools.FirstCharToLower(columnName).replaceAll(' ', '')];
|
211
|
+
};
|
212
|
+
/** */
|
213
|
+
this._GetTooltip = (prefix, row, suffix = '') => {
|
214
|
+
let column = Tools.FirstCharToLower(this.tooltipByRow()).replaceAll(' ', '');
|
215
|
+
if (suffix.length > 0) {
|
216
|
+
suffix = ` ${suffix}`;
|
217
|
+
}
|
218
|
+
return this.tooltipByRow().length > 0
|
219
|
+
? `${prefix} ${row[column]}${suffix}`
|
220
|
+
: `${prefix}${suffix}`;
|
221
|
+
};
|
222
|
+
/** */
|
223
|
+
this._HideRow = (group) => {
|
224
|
+
return (this._isGrouped() ? !(this._expandedGroups.some(x => x == group.groupBy)) : false);
|
225
|
+
};
|
226
|
+
}
|
227
|
+
//getter
|
228
|
+
get _height() {
|
229
|
+
let height = this.height();
|
230
|
+
if (height == 'full') {
|
231
|
+
const TOOLBAR = 45;
|
232
|
+
const PAGE_HEADER = 70;
|
233
|
+
const GRID_HEADER = document.getElementById(`${this._id}-header`);
|
234
|
+
const HEADER = (GRID_HEADER && GRID_HEADER.children.length > 0) ? 50 : 0;
|
235
|
+
const MARGIN = 30;
|
236
|
+
const PADDING = 20;
|
237
|
+
const FOOTER = this.showFooter() ? 24.5 : 0;
|
238
|
+
height = (Screen.WINDOW_HEIGHT - TOOLBAR - PAGE_HEADER - MARGIN - HEADER - PADDING - FOOTER) + 'px';
|
239
|
+
}
|
240
|
+
return height;
|
241
|
+
}
|
242
|
+
//getter
|
243
|
+
get _onlyOneCheck() {
|
244
|
+
return Tools.IsNotNull(this.checkbox.onlyOneCheck) && this.checkbox.onlyOneCheck;
|
245
|
+
}
|
246
|
+
ngAfterViewInit() {
|
247
|
+
Tools.Sleep().then(() => {
|
248
|
+
this._enableAnimations = true;
|
249
|
+
this._isLoading = false;
|
250
|
+
this._isLoadingMessage = false;
|
251
|
+
});
|
252
|
+
}
|
253
|
+
//ControlValueAccessor
|
254
|
+
SetValue(value) {
|
255
|
+
let indexRow = 0;
|
256
|
+
if (!Tools.IsNotNull(value))
|
257
|
+
value = [];
|
258
|
+
const dataSource = Tools.BreakReference(value).map((item) => Object.assign({ checked: false }, { ...item }, { indexRow: indexRow++ }));
|
259
|
+
this._UpdateValue(dataSource);
|
260
|
+
this._value = dataSource;
|
261
|
+
this.value_signal.set(dataSource);
|
262
|
+
}
|
263
|
+
//ControlValueAccessor
|
264
|
+
writeValue(value) {
|
265
|
+
let indexRow = 0;
|
266
|
+
if (!Tools.IsNotNull(value))
|
267
|
+
value = [];
|
268
|
+
const dataSource = Tools.BreakReference(value).map((item) => Object.assign({ checked: false }, { ...item }, { indexRow: indexRow++ }));
|
269
|
+
this._value = dataSource;
|
270
|
+
this.value_signal.set(dataSource);
|
271
|
+
}
|
272
|
+
/** */
|
273
|
+
_IsCellType(property, data, type) {
|
274
|
+
let response = false;
|
275
|
+
const columnConfig = this._GetColumnConfig(property);
|
276
|
+
const value = data[property];
|
277
|
+
const row = Tools.BreakReference(data);
|
278
|
+
if (columnConfig) {
|
279
|
+
if (['coerTextbox', 'coerNumberbox', 'coerSelectbox', 'coerSwitch'].includes(type)) {
|
280
|
+
const inputConfig = columnConfig;
|
281
|
+
response = inputConfig.hasOwnProperty(type)
|
282
|
+
&& typeof inputConfig[type] === 'function'
|
283
|
+
&& inputConfig[type]({ property, row, value }).isInput;
|
284
|
+
}
|
285
|
+
else
|
286
|
+
switch (type) {
|
287
|
+
case 'number': {
|
288
|
+
if (typeof columnConfig.typeNumber === 'boolean') {
|
289
|
+
response = columnConfig.typeNumber;
|
290
|
+
}
|
291
|
+
else if (typeof columnConfig.typeNumber === 'function') {
|
292
|
+
response = (data === null) ? false : columnConfig.typeNumber({ property, row, value });
|
293
|
+
}
|
294
|
+
break;
|
295
|
+
}
|
296
|
+
case 'date': {
|
297
|
+
if (data === null)
|
298
|
+
return false;
|
299
|
+
if (typeof columnConfig.typeDate === 'boolean') {
|
300
|
+
response = columnConfig.typeDate;
|
301
|
+
}
|
302
|
+
else if (typeof columnConfig.typeDate === 'function') {
|
303
|
+
response = (data === null) ? false : columnConfig.typeDate({ property, row, value });
|
304
|
+
}
|
305
|
+
break;
|
306
|
+
}
|
307
|
+
case 'template': {
|
308
|
+
if (data === null)
|
309
|
+
return false;
|
310
|
+
response = (typeof columnConfig.template === 'string') || (typeof columnConfig.template === 'function');
|
311
|
+
break;
|
312
|
+
}
|
313
|
+
}
|
314
|
+
}
|
315
|
+
return response;
|
316
|
+
}
|
317
|
+
/** */
|
318
|
+
_IsCellColor(property, data, color) {
|
319
|
+
let response = false;
|
320
|
+
const columnConfig = this._GetColumnConfig(property);
|
321
|
+
if (columnConfig) {
|
322
|
+
if (typeof columnConfig[color] === 'boolean') {
|
323
|
+
response = columnConfig[color];
|
324
|
+
}
|
325
|
+
else if (typeof columnConfig[color] === 'function') {
|
326
|
+
response = columnConfig[color]({
|
327
|
+
property,
|
328
|
+
row: Tools.BreakReference(data),
|
329
|
+
value: data[property]
|
330
|
+
});
|
331
|
+
}
|
332
|
+
}
|
333
|
+
return response;
|
334
|
+
}
|
335
|
+
/** */
|
336
|
+
GetAttribute(property, data, attribute, type) {
|
337
|
+
const columnConfig = this._GetColumnConfig(property);
|
338
|
+
const value = Tools.IsNotNull(data) ? data[property] : null;
|
339
|
+
const row = Tools.BreakReference(data);
|
340
|
+
if (columnConfig) {
|
341
|
+
if (type === 'defaul-cell') {
|
342
|
+
switch (attribute) {
|
343
|
+
case 'textAlign': {
|
344
|
+
return columnConfig?.textAlign || 'left';
|
345
|
+
}
|
346
|
+
case 'template': {
|
347
|
+
const inputConfig = columnConfig;
|
348
|
+
if (inputConfig.hasOwnProperty(attribute)) {
|
349
|
+
if (typeof inputConfig[attribute] === 'string') {
|
350
|
+
return inputConfig[attribute];
|
351
|
+
}
|
352
|
+
else if (typeof inputConfig[attribute] === 'function') {
|
353
|
+
return inputConfig[attribute]({ property, row, value }) || '';
|
354
|
+
}
|
355
|
+
}
|
356
|
+
}
|
357
|
+
}
|
358
|
+
}
|
359
|
+
else if (['coerTextbox', 'coerNumberbox', 'coerSelectbox', 'coerSwitch'].includes(type)) {
|
360
|
+
const inputConfig = columnConfig;
|
361
|
+
if (inputConfig.hasOwnProperty(type) && typeof inputConfig[type] === 'function') {
|
362
|
+
return inputConfig[type]({ property, row, value })[attribute] || null;
|
363
|
+
}
|
364
|
+
}
|
365
|
+
}
|
366
|
+
return null;
|
367
|
+
}
|
368
|
+
/** */
|
369
|
+
ButtonByRow(property, data = null) {
|
370
|
+
let response = false;
|
371
|
+
const buttonByRow = this.buttonByRow;
|
372
|
+
const row = Tools.IsNotNull(data) ? Tools.BreakReference(data) : null;
|
373
|
+
if (buttonByRow.hasOwnProperty(property)) {
|
374
|
+
if (row === null) {
|
375
|
+
response = (typeof buttonByRow[property] === 'boolean') ? buttonByRow[property] : true;
|
376
|
+
}
|
377
|
+
else if (typeof buttonByRow[property] === 'boolean') {
|
378
|
+
response = buttonByRow[property];
|
379
|
+
}
|
380
|
+
else if (typeof buttonByRow[property] === 'function') {
|
381
|
+
response = buttonByRow[property]({ property, row, value: null });
|
382
|
+
}
|
383
|
+
}
|
384
|
+
return response ? (this._value && this._value.length > 0) : false;
|
385
|
+
}
|
386
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CoerGridExtension, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
387
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "17.3.12", type: CoerGridExtension, selector: "coer-grid-extension", inputs: { columns: { classPropertyName: "columns", publicName: "columns", isSignal: true, isRequired: false, transformFunction: null }, cleanColumnName: { classPropertyName: "cleanColumnName", publicName: "cleanColumnName", isSignal: true, isRequired: false, transformFunction: null }, addButton: { classPropertyName: "addButton", publicName: "addButton", isSignal: false, isRequired: false, transformFunction: null }, exportButton: { classPropertyName: "exportButton", publicName: "exportButton", isSignal: false, isRequired: false, transformFunction: null }, importButton: { classPropertyName: "importButton", publicName: "importButton", isSignal: false, isRequired: false, transformFunction: null }, search: { classPropertyName: "search", publicName: "search", isSignal: false, isRequired: false, transformFunction: null }, buttonByRow: { classPropertyName: "buttonByRow", publicName: "buttonByRow", isSignal: false, isRequired: false, transformFunction: null }, checkbox: { classPropertyName: "checkbox", publicName: "checkbox", isSignal: false, isRequired: false, transformFunction: null }, tooltipByRow: { classPropertyName: "tooltipByRow", publicName: "tooltipByRow", isSignal: true, isRequired: false, transformFunction: null }, isLoading: { classPropertyName: "isLoading", publicName: "isLoading", isSignal: true, isRequired: false, transformFunction: null }, isDisabled: { classPropertyName: "isDisabled", publicName: "isDisabled", isSignal: true, isRequired: false, transformFunction: null }, rowsByPage: { classPropertyName: "rowsByPage", publicName: "rowsByPage", isSignal: true, isRequired: false, transformFunction: null }, groupBy: { classPropertyName: "groupBy", publicName: "groupBy", isSignal: true, isRequired: false, transformFunction: null }, showColumnGrouped: { classPropertyName: "showColumnGrouped", publicName: "showColumnGrouped", isSignal: true, isRequired: false, transformFunction: null }, rowsByGroup: { classPropertyName: "rowsByGroup", publicName: "rowsByGroup", isSignal: true, isRequired: false, transformFunction: null }, isInvisible: { classPropertyName: "isInvisible", publicName: "isInvisible", isSignal: true, isRequired: false, transformFunction: null }, showFooter: { classPropertyName: "showFooter", publicName: "showFooter", isSignal: true, isRequired: false, transformFunction: null }, width: { classPropertyName: "width", publicName: "width", isSignal: true, isRequired: false, transformFunction: null }, MinWidth: { classPropertyName: "MinWidth", publicName: "MinWidth", isSignal: true, isRequired: false, transformFunction: null }, MaxWidth: { classPropertyName: "MaxWidth", publicName: "MaxWidth", isSignal: true, isRequired: false, transformFunction: null }, height: { classPropertyName: "height", publicName: "height", isSignal: true, isRequired: false, transformFunction: null }, minHeight: { classPropertyName: "minHeight", publicName: "minHeight", isSignal: true, isRequired: false, transformFunction: null }, maxHeight: { classPropertyName: "maxHeight", publicName: "maxHeight", isSignal: true, isRequired: false, transformFunction: null }, margin: { classPropertyName: "margin", publicName: "margin", isSignal: true, isRequired: false, transformFunction: null }, enableSort: { classPropertyName: "enableSort", publicName: "enableSort", isSignal: true, isRequired: false, transformFunction: null }, enableRowFocus: { classPropertyName: "enableRowFocus", publicName: "enableRowFocus", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onClickAdd: "onClickAdd", onClickImport: "onClickImport", onClickExport: "onClickExport", onClickRow: "onClickRow", onDoubleClickRow: "onDoubleClickRow", onClickDeleteRow: "onClickDeleteRow", onClickEditRow: "onClickEditRow", onClickGoRow: "onClickGoRow", onKeyupEnter: "onKeyupEnter", onKeyupEnterLast: "onKeyupEnterLast", onSwitchChange: "onSwitchChange", onTextboxChange: "onTextboxChange", onSelectboxChange: "onSelectboxChange", onCheckboxChange: "onCheckboxChange" }, viewQueries: [{ propertyName: "inputFile", first: true, predicate: ["inputFileRef"], descendants: true, isSignal: true }, { propertyName: "inputSearch", first: true, predicate: ["inputSearch"], descendants: true, isSignal: true }, { propertyName: "coerTextboxList", predicate: CoerTextBox, descendants: true, isSignal: true }, { propertyName: "coerNumberboxList", predicate: CoerNumberBox, descendants: true, isSignal: true }, { propertyName: "coerSelectboxList", predicate: CoerSelectbox, descendants: true, isSignal: true }, { propertyName: "coerCheckboxList", predicate: CoerCheckbox, descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: '', isInline: true }); }
|
388
|
+
}
|
389
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CoerGridExtension, decorators: [{
|
390
|
+
type: Component,
|
391
|
+
args: [{
|
392
|
+
selector: 'coer-grid-extension',
|
393
|
+
template: ''
|
394
|
+
}]
|
395
|
+
}], propDecorators: { addButton: [{
|
396
|
+
type: Input
|
397
|
+
}], exportButton: [{
|
398
|
+
type: Input
|
399
|
+
}], importButton: [{
|
400
|
+
type: Input
|
401
|
+
}], search: [{
|
402
|
+
type: Input
|
403
|
+
}], buttonByRow: [{
|
404
|
+
type: Input
|
405
|
+
}], checkbox: [{
|
406
|
+
type: Input
|
407
|
+
}] } });
|
408
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"coer-grid.extension.js","sourceRoot":"","sources":["../../../../../../projects/coer-elements/components/lib/coer-grid/coer-grid.extension.ts"],"names":[],"mappings":"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","sourcesContent":["import { IGridButtonByRow, IGridColumn, IGridDataSource, IGridImport, IGridHeaderButton, IGridHeaderExportButton, IGridKeyupEnter, IGridSearch, IGridInputSwitchChange, IGridInputTextbox, IGridSort, IGridCheckbox, IGridInputCheckbox, IGridHeader } from \"coer-elements/interfaces\";\r\nimport { AfterViewInit, Component, ElementRef, Input, computed, inject, input, output, signal, viewChild, viewChildren } from \"@angular/core\";\r\nimport { CoerCheckbox } from \"../../lib/coer-checkbox/coer-checkbox.component\";\r\nimport { CoerNumberBox } from \"../../lib/coer-numberbox/coer-numberbox.component\";\r\nimport { CoerSelectbox } from \"../../lib/coer-selectbox/coer-selectbox.component\";\r\nimport { CoerTextBox } from \"../../lib/coer-textbox/coer-textbox.component\";\r\nimport { CoerAlert, ControlValue, DateTime, Screen, Tools } from 'coer-elements/tools';\r\n\r\n@Component({\r\n    selector: 'coer-grid-extension',\r\n    template: ''\r\n})\r\nexport class CoerGridExtension<T> extends ControlValue implements AfterViewInit {\r\n\r\n    //Injections\r\n    protected readonly alert = inject(CoerAlert);\r\n\r\n    //Elements\r\n    protected inputFile = viewChild.required<ElementRef>('inputFileRef');\r\n    protected inputSearch = viewChild.required<CoerTextBox>('inputSearch');\r\n    protected coerTextboxList = viewChildren(CoerTextBox);\r\n    protected coerNumberboxList = viewChildren(CoerNumberBox);\r\n    protected coerSelectboxList = viewChildren(CoerSelectbox);\r\n    protected coerCheckboxList = viewChildren(CoerCheckbox);\r\n\r\n    //Variables\r\n    protected override _value: T[] = [];\r\n    protected value_signal = signal<T[]>([]);\r\n    protected _gridSearch = signal<string | number>('');\r\n    protected _isLoading: boolean = true;\r\n    protected _isLoadingMessage: boolean = true;\r\n    protected _id: string = Tools.GetGuid('coer-grid');\r\n    protected _expandedGroups: string[] = [];\r\n    protected _enableAnimations: boolean = false;\r\n    protected _indexFocus = signal<number>(0);\r\n    protected _sort = signal<IGridSort>({ columnName: '', direction: 'none', icon: '' });\r\n\r\n    //Generic Tools\r\n    protected GetNumericFormat = Tools.GetNumericFormat;\r\n    protected GetDateFormat = DateTime.GetDateFormat;\r\n\r\n    //Inputs\r\n    public columns = input<IGridColumn<T>[]>([]);\r\n    public cleanColumnName = input<boolean>(true);\r\n    @Input() addButton: IGridHeaderButton = { show: false };\r\n    @Input() exportButton: IGridHeaderExportButton = { show: false };\r\n    @Input() importButton: IGridHeaderButton = { show: false };\r\n    @Input() search: IGridSearch = { show: false, ignore: false };\r\n    @Input() buttonByRow: IGridButtonByRow<T> = {};\r\n    @Input() checkbox: IGridCheckbox = { show: false };\r\n    public tooltipByRow = input<string>('');\r\n    public isLoading = input<boolean>(false);\r\n    public isDisabled = input<boolean>(false);\r\n    public rowsByPage = input<number>(50);\r\n    public groupBy = input<string>('');\r\n    public showColumnGrouped = input<boolean>(false);\r\n    public rowsByGroup = input<number>(50);\r\n    public isInvisible = input<boolean>(false);\r\n    public showFooter = input<boolean>(true);\r\n    public width = input<string>('100%');\r\n    public MinWidth = input<string>('250px');\r\n    public MaxWidth = input<string>('100%');\r\n    public height = input<string>('350px');\r\n    public minHeight = input<string>('140px');\r\n    public maxHeight = input<string>('100vh');\r\n    public margin = input<string>('auto');\r\n    public enableSort = input<boolean>(true);\r\n    public enableRowFocus = input<boolean>(true);\r\n\r\n    //Outputs\r\n    public onClickAdd = output<void>();\r\n    public onClickImport = output<IGridImport<T>>();\r\n    public onClickExport = output<T[]>();\r\n    public onClickRow = output<T>();\r\n    public onDoubleClickRow = output<T>();\r\n    public onClickDeleteRow = output<T>();\r\n    public onClickEditRow = output<T>();\r\n    public onClickGoRow = output<T>();\r\n    public onKeyupEnter = output<IGridKeyupEnter>();\r\n    public onKeyupEnterLast = output<void>();\r\n    public onSwitchChange = output<IGridInputSwitchChange<T>>();\r\n    public onTextboxChange = output<IGridInputTextbox<T>>();\r\n    public onSelectboxChange = output<IGridInputTextbox<T>>();\r\n    public onCheckboxChange = output<IGridInputCheckbox<T>>();\r\n\r\n    //computed\r\n    protected _isDisabled = computed<boolean>(() => {\r\n        return this.isDisabled() || this.isLoading() || this.isInvisible();\r\n    });\r\n\r\n    //computed\r\n    protected _isGrouped = computed<boolean>(() => {\r\n        return this.groupBy().length > 0;\r\n    });\r\n\r\n    //getter\r\n    protected get _height(): string {\r\n        let height = this.height();\r\n\r\n        if (height == 'full') {\r\n            const TOOLBAR = 45;\r\n            const PAGE_HEADER = 70;\r\n            const GRID_HEADER = document.getElementById(`${this._id}-header`)!;\r\n            const HEADER = (GRID_HEADER && GRID_HEADER.children.length > 0) ? 50 : 0;\r\n            const MARGIN = 30;\r\n            const PADDING = 20;\r\n            const FOOTER = this.showFooter() ? 24.5 : 0;\r\n            height = (Screen.WINDOW_HEIGHT - TOOLBAR - PAGE_HEADER - MARGIN - HEADER - PADDING - FOOTER) + 'px';\r\n        }\r\n\r\n        return height;\r\n    }\r\n\r\n\r\n    //getter\r\n    protected get _onlyOneCheck() {\r\n        return Tools.IsNotNull(this.checkbox.onlyOneCheck) && this.checkbox.onlyOneCheck;\r\n    }\r\n\r\n\r\n    ngAfterViewInit(): void {\r\n        Tools.Sleep().then(() => {\r\n            this._enableAnimations = true;\r\n            this._isLoading = false;\r\n            this._isLoadingMessage = false;\r\n        });\r\n    }\r\n\r\n    //ControlValueAccessor\r\n    public override SetValue(value: T[]): void {\r\n        let indexRow = 0;\r\n        if(!Tools.IsNotNull(value)) value = [];\r\n\r\n        const dataSource = Tools.BreakReference(value).map((item: any) =>\r\n            Object.assign({ checked: false }, { ...item }, { indexRow: indexRow++ })\r\n        );\r\n\r\n        this._UpdateValue(dataSource);\r\n        this._value = dataSource;\r\n        this.value_signal.set(dataSource);\r\n    }\r\n\r\n\r\n    //ControlValueAccessor\r\n    public override writeValue(value: T[]): void {\r\n        let indexRow = 0;\r\n        if(!Tools.IsNotNull(value)) value = [];\r\n\r\n        const dataSource = Tools.BreakReference(value).map((item: any) =>\r\n            Object.assign({ checked: false }, { ...item }, { indexRow: indexRow++ })\r\n        );\r\n\r\n        this._value = dataSource;\r\n        this.value_signal.set(dataSource);\r\n    }\r\n\r\n\r\n     //computed\r\n     protected gridColumns = computed<IGridHeader[]>(() => {\r\n        const SET_COLUMNS = new Set<string>();\r\n\r\n        //Has filter columns?\r\n        if (this.columns().length > 0) {\r\n            for (const { property } of this.columns()) {\r\n                SET_COLUMNS.add(property);\r\n            }\r\n        }\r\n\r\n        //Get all columns\r\n        else for (const row of this.value_signal()) {\r\n            for (const property in row) {\r\n                SET_COLUMNS.add(property);\r\n            }\r\n        }\r\n\r\n        //Remove indexRow column\r\n        if (SET_COLUMNS.has('indexRow')) {\r\n            SET_COLUMNS.delete('indexRow');\r\n        }\r\n\r\n        //Remove groupBy column\r\n        if (this._isGrouped() && !this.showColumnGrouped() && SET_COLUMNS.has(this.groupBy())) {\r\n            SET_COLUMNS.delete(this.groupBy());\r\n        }\r\n\r\n        //Set index column\r\n        let indexColumn = 0;\r\n        return Array.from(SET_COLUMNS).map(property => Tools.BreakReference<IGridHeader>({\r\n            columnName: property,\r\n            indexColumn: indexColumn++,\r\n            width: this._GetColumnConfig(property)?.width || 'auto'\r\n        }));\r\n    });\r\n\r\n\r\n    //computed\r\n    protected gridDataSource = computed<IGridDataSource[]>(() => {\r\n        let list = this.gridDataSourceFiltered();\r\n\r\n        //It's Grouped?\r\n        if (this._isGrouped()) {\r\n            //let indexRow = 0;\r\n            let indexGroup = 0;\r\n\r\n            const SET_COLUMN = new Set<string>();\r\n            for (const row of list as any) {\r\n                SET_COLUMN.add(row[this.groupBy()]);\r\n            }\r\n\r\n            const DATA_SOURCE_GROPUED = [];\r\n            for (const column of SET_COLUMN) {\r\n                DATA_SOURCE_GROPUED.push({\r\n                    groupBy: column,\r\n                    indexGroup: indexGroup++,\r\n                    length: list.filter((item: any) => item[this.groupBy()] == column).length,\r\n                    rows: [...list]\r\n                        .filter((item: any) => item[this.groupBy()] == column)\r\n                        .splice(0, this.rowsByGroup())\r\n                        //.map((item: any) => Object.assign({ indexRow: indexRow++ }, item))\r\n                });\r\n            }\r\n\r\n            //Response by group\r\n            return [...DATA_SOURCE_GROPUED].splice(0, this.rowsByPage());\r\n        }\r\n\r\n        //Response\r\n        return [{\r\n            groupBy: 'Not Grouped',\r\n            indexGroup: -1,\r\n            length: -1,\r\n            rows: [...list].splice(0, this.rowsByPage())\r\n        }];\r\n    });\r\n\r\n\r\n    //computed\r\n    protected gridDataSourceFiltered = computed<T[]>(() => {\r\n        let list: T[] = [];\r\n\r\n        const dataSource = Tools.BreakReference(this.value_signal());\r\n\r\n        //Ignore Filter\r\n        if (this._gridSearch() == '' || this.search?.ignore) {\r\n            list = dataSource;\r\n        }\r\n\r\n        //Filter by search\r\n        else {\r\n            const SET_ROW = new Set<number>();\r\n\r\n            let listFiltered: any[] = [];\r\n            for(const { columnName } of this.gridColumns()) {\r\n                listFiltered = dataSource.filter((item: any) =>\r\n                    !SET_ROW.has(item['indexRow'])\r\n                    && String(item[Tools.FirstCharToLower(columnName)]).trim().toUpperCase().includes(String(this._gridSearch()).trim().toUpperCase())\r\n                );\r\n\r\n                for(const { indexRow } of listFiltered as any) {\r\n                    SET_ROW.add(indexRow);\r\n                }\r\n\r\n                list = Tools.BreakReference(list.concat(listFiltered));\r\n            }\r\n        }\r\n\r\n        return Tools.BreakReference(list);\r\n    });\r\n\r\n\r\n    /** Get Column Configuration */\r\n    protected _GetColumnConfig = (columnName: string): IGridColumn<T> | undefined => {\r\n        return this.columns().find(x => x.property.replaceAll(' ', '').toUpperCase() == columnName.replaceAll(' ', '').toUpperCase());\r\n    }\r\n\r\n\r\n    /** Clean Name or get alias */\r\n    protected _GetColumnName = (columnName: string): string => {\r\n        const columnConfig = this._GetColumnConfig(columnName);\r\n\r\n        //Get Alias\r\n        if (columnConfig && columnConfig.alias && columnConfig.alias.length > 0) {\r\n            return columnConfig.alias;\r\n        }\r\n\r\n        //Clean headerName\r\n        if (this.cleanColumnName() && columnName.length > 0) {\r\n            columnName = Tools.FirstCharToLower(columnName);\r\n\r\n            const charArray = [];\r\n            for(const char of columnName) {\r\n                if(char === char.toUpperCase()) charArray.push(' ');\r\n                charArray.push(char);\r\n            }\r\n\r\n            charArray[0] = charArray[0].toUpperCase();\r\n            columnName = charArray.join('');\r\n        }\r\n\r\n        return columnName.trim();\r\n    }\r\n\r\n\r\n    /** */\r\n    protected _GetShortIcon = (columnName: string) => {\r\n        return this._sort().columnName == columnName ? this._sort().icon : '';\r\n    }\r\n\r\n\r\n    /** */\r\n    protected _GetId = (indexRow: number, indexColumn: number, suffix: string = ''): string => {\r\n        if (suffix.length > 0) suffix = `-${suffix}`;\r\n        return `${this._id}-row${indexRow}column${indexColumn}${suffix}`;\r\n    }\r\n\r\n\r\n    /** */\r\n    protected _GetCellValue = (row: any, columnName: string): any => {\r\n        return row[Tools.FirstCharToLower(columnName).replaceAll(' ', '')];\r\n    }\r\n\r\n\r\n    /** */\r\n    protected _GetTooltip = (prefix: string, row: any, suffix: string = ''): string => {\r\n        let column = Tools.FirstCharToLower(this.tooltipByRow()).replaceAll(' ', '');\r\n\r\n        if (suffix.length > 0) {\r\n            suffix = ` ${suffix}`;\r\n        }\r\n\r\n        return this.tooltipByRow().length > 0\r\n            ? `${prefix} ${row[column]}${suffix}`\r\n            : `${prefix}${suffix}`;\r\n    }\r\n\r\n\r\n    /** */\r\n    protected _HideRow = (group: IGridDataSource): boolean => {\r\n        return (this._isGrouped() ? !(this._expandedGroups.some(x => x == group.groupBy)) : false)\r\n    }\r\n\r\n\r\n    /** */\r\n    protected _IsCellType(property: string, data: any, type: 'number' | 'date' | 'template' | 'coerTextbox' | 'coerNumberbox' | 'coerSelectbox'  | 'coerSwitch'): boolean {\r\n        let response = false;\r\n        const columnConfig = this._GetColumnConfig(property);\r\n        const value = data[property];\r\n        const row = Tools.BreakReference(data);\r\n\r\n        if (columnConfig) {\r\n            if (['coerTextbox', 'coerNumberbox', 'coerSelectbox', 'coerSwitch'].includes(type)) {\r\n                const inputConfig: any = columnConfig;\r\n                response = inputConfig.hasOwnProperty(type)\r\n                    && typeof inputConfig[type] === 'function'\r\n                    && inputConfig[type]({ property, row, value }).isInput;\r\n            }\r\n\r\n            else switch(type) {\r\n                case 'number': {\r\n                    if (typeof columnConfig.typeNumber === 'boolean') {\r\n                        response = columnConfig.typeNumber;\r\n                    }\r\n\r\n                    else if (typeof columnConfig.typeNumber === 'function') {\r\n                        response = (data === null) ? false : columnConfig.typeNumber({ property, row, value });\r\n                    }\r\n\r\n                    break;\r\n                }\r\n\r\n                case 'date': {\r\n                    if (data === null) return false;\r\n\r\n                    if (typeof columnConfig.typeDate === 'boolean') {\r\n                        response = columnConfig.typeDate;\r\n                    }\r\n\r\n                    else if (typeof columnConfig.typeDate === 'function') {\r\n                        response = (data === null) ? false : columnConfig.typeDate({ property, row, value });\r\n                    }\r\n\r\n                    break;\r\n                }\r\n\r\n                case 'template': {\r\n                    if (data === null) return false;\r\n                    response = (typeof columnConfig.template === 'string') || (typeof columnConfig.template === 'function');\r\n                    break;\r\n                }\r\n            }\r\n        }\r\n\r\n        return response;\r\n    }\r\n\r\n\r\n    /** */\r\n    protected _IsCellColor(property: string, data: any, color: 'colorBlue' | 'colorGreen' | 'colorYellow' | 'colorRed'): boolean {\r\n        let response = false;\r\n        const columnConfig: any = this._GetColumnConfig(property);\r\n\r\n        if (columnConfig) {\r\n            if (typeof columnConfig[color] === 'boolean') {\r\n                response = columnConfig[color];\r\n            }\r\n\r\n            else if (typeof columnConfig[color] === 'function') {\r\n                response = columnConfig[color]({\r\n                    property,\r\n                    row: Tools.BreakReference(data),\r\n                    value: data[property]\r\n                });\r\n            }\r\n        }\r\n\r\n        return response;\r\n    }\r\n\r\n\r\n    /** */\r\n    protected GetAttribute(property: string, data: any, attribute: string, type: 'coerSwitch' | 'coerTextbox' | 'coerNumberbox'| 'coerSelectbox' | 'defaul-cell' ): any {\r\n        const columnConfig = this._GetColumnConfig(property);\r\n        const value = Tools.IsNotNull(data) ? data[property] : null;\r\n        const row = Tools.BreakReference(data);\r\n\r\n        if (columnConfig) {\r\n            if (type === 'defaul-cell') {\r\n                switch(attribute) {\r\n                    case 'textAlign': {\r\n                        return columnConfig?.textAlign || 'left';\r\n                    }\r\n\r\n                    case 'template': {\r\n                        const inputConfig: any = columnConfig;\r\n\r\n                        if (inputConfig.hasOwnProperty(attribute)) {\r\n                            if(typeof inputConfig[attribute] === 'string') {\r\n                                return inputConfig[attribute];\r\n                            }\r\n\r\n                            else if(typeof inputConfig[attribute] === 'function') {\r\n                                return inputConfig[attribute]({ property, row, value }) || '';\r\n                            }\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n\r\n            else if(['coerTextbox', 'coerNumberbox', 'coerSelectbox', 'coerSwitch'].includes(type)) {\r\n                const inputConfig: any = columnConfig;\r\n                if (inputConfig.hasOwnProperty(type) && typeof inputConfig[type] === 'function') {\r\n                    return inputConfig[type]({ property, row, value })[attribute] || null;\r\n                }\r\n            }\r\n        }\r\n\r\n        return null;\r\n    }\r\n\r\n\r\n    /** */\r\n    protected ButtonByRow(property: 'showDeleteButton' | 'showEditButton' | 'showGoButton', data: any = null): boolean {\r\n        let response = false;\r\n        const buttonByRow: any = this.buttonByRow;\r\n        const row = Tools.IsNotNull(data) ? Tools.BreakReference(data) : null;\r\n\r\n        if (buttonByRow.hasOwnProperty(property)) {\r\n            if (row === null) {\r\n                response = (typeof buttonByRow[property] === 'boolean') ? buttonByRow[property] : true;\r\n            }\r\n\r\n            else if (typeof buttonByRow[property] === 'boolean') {\r\n                response = buttonByRow[property];\r\n            }\r\n\r\n            else if (typeof buttonByRow[property] === 'function') {\r\n                response = buttonByRow[property]({ property, row, value: null });\r\n            }\r\n        }\r\n\r\n        return response ? (this._value && this._value.length > 0) : false;\r\n    }\r\n}"]}
|
@@ -0,0 +1,30 @@
|
|
1
|
+
export const GridTemplates = {
|
2
|
+
/** Template for boolean property */
|
3
|
+
isActiveTemplate: (item) => {
|
4
|
+
if (item.value) {
|
5
|
+
return `
|
6
|
+
<span class='text-green-bold'>
|
7
|
+
<i class="fa-solid fa-circle-check"></i> Active
|
8
|
+
</span>
|
9
|
+
`;
|
10
|
+
}
|
11
|
+
else {
|
12
|
+
return `
|
13
|
+
<span class='text-gray-bold'>
|
14
|
+
<i class="fa-solid fa-circle-minus"></i> Disabled
|
15
|
+
</span>
|
16
|
+
`;
|
17
|
+
}
|
18
|
+
},
|
19
|
+
/** Template for boolean property */
|
20
|
+
coerSwitchTemplate: (item) => ({
|
21
|
+
isInput: true,
|
22
|
+
tooltip: `${item.value ? 'Active' : 'Disabled'}`
|
23
|
+
}),
|
24
|
+
/** Template for text property */
|
25
|
+
coerTextboxTemplate: (item) => ({
|
26
|
+
isInput: true,
|
27
|
+
isInvalid: item.value.length <= 0
|
28
|
+
})
|
29
|
+
};
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29lci1ncmlkLnRlbXBsYXRlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvZXItZWxlbWVudHMvY29tcG9uZW50cy9saWIvY29lci1ncmlkL2NvZXItZ3JpZC50ZW1wbGF0ZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHO0lBRXpCLG9DQUFvQztJQUNwQyxnQkFBZ0IsRUFBRSxDQUFDLElBQW9CLEVBQVUsRUFBRTtRQUMvQyxJQUFJLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUNiLE9BQU87Ozs7YUFJTixDQUFDO1FBQ04sQ0FBQzthQUVJLENBQUM7WUFDRixPQUFPOzs7O2FBSU4sQ0FBQztRQUNOLENBQUM7SUFDTCxDQUFDO0lBRUQsb0NBQW9DO0lBQ3BDLGtCQUFrQixFQUFFLENBQUMsSUFBb0IsRUFBbUIsRUFBRSxDQUFDLENBQUM7UUFDNUQsT0FBTyxFQUFFLElBQUk7UUFDYixPQUFPLEVBQUUsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLFVBQVcsRUFBRTtLQUNwRCxDQUFDO0lBR0YsaUNBQWlDO0lBQ2pDLG1CQUFtQixFQUFFLENBQUMsSUFBb0IsRUFBb0IsRUFBRSxDQUFDLENBQUM7UUFDOUQsT0FBTyxFQUFFLElBQUk7UUFDYixTQUFTLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLElBQUksQ0FBQztLQUNwQyxDQUFDO0NBQ0wsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElHcmlkQ29lclN3aXRjaCwgSUdyaWRDb2VyVGV4dEJveCwgSUdyaWRJdGVtIH0gZnJvbSBcImNvZXItZWxlbWVudHMvaW50ZXJmYWNlc1wiO1xyXG5cclxuZXhwb3J0IGNvbnN0IEdyaWRUZW1wbGF0ZXMgPSB7XHJcblxyXG4gICAgLyoqIFRlbXBsYXRlIGZvciBib29sZWFuIHByb3BlcnR5ICovXHJcbiAgICBpc0FjdGl2ZVRlbXBsYXRlOiAoaXRlbTogSUdyaWRJdGVtPGFueT4pOiBzdHJpbmcgPT4ge1xyXG4gICAgICAgIGlmIChpdGVtLnZhbHVlKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBgXHJcbiAgICAgICAgICAgICAgICA8c3BhbiBjbGFzcz0ndGV4dC1ncmVlbi1ib2xkJz5cclxuICAgICAgICAgICAgICAgICAgICA8aSBjbGFzcz1cImZhLXNvbGlkIGZhLWNpcmNsZS1jaGVja1wiPjwvaT4gQWN0aXZlXHJcbiAgICAgICAgICAgICAgICA8L3NwYW4+XHJcbiAgICAgICAgICAgIGA7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICBlbHNlIHtcclxuICAgICAgICAgICAgcmV0dXJuIGBcclxuICAgICAgICAgICAgICAgIDxzcGFuIGNsYXNzPSd0ZXh0LWdyYXktYm9sZCc+XHJcbiAgICAgICAgICAgICAgICAgICAgPGkgY2xhc3M9XCJmYS1zb2xpZCBmYS1jaXJjbGUtbWludXNcIj48L2k+IERpc2FibGVkXHJcbiAgICAgICAgICAgICAgICA8L3NwYW4+XHJcbiAgICAgICAgICAgIGA7XHJcbiAgICAgICAgfVxyXG4gICAgfSxcclxuXHJcbiAgICAvKiogVGVtcGxhdGUgZm9yIGJvb2xlYW4gcHJvcGVydHkgKi9cclxuICAgIGNvZXJTd2l0Y2hUZW1wbGF0ZTogKGl0ZW06IElHcmlkSXRlbTxhbnk+KTogSUdyaWRDb2VyU3dpdGNoID0+ICh7XHJcbiAgICAgICAgaXNJbnB1dDogdHJ1ZSxcclxuICAgICAgICB0b29sdGlwOiBgJHtpdGVtLnZhbHVlID8gJ0FjdGl2ZScgOiAnRGlzYWJsZWQnIH1gXHJcbiAgICB9KSxcclxuXHJcblxyXG4gICAgLyoqIFRlbXBsYXRlIGZvciB0ZXh0IHByb3BlcnR5ICovXHJcbiAgICBjb2VyVGV4dGJveFRlbXBsYXRlOiAoaXRlbTogSUdyaWRJdGVtPGFueT4pOiBJR3JpZENvZXJUZXh0Qm94ID0+ICh7XHJcbiAgICAgICAgaXNJbnB1dDogdHJ1ZSxcclxuICAgICAgICBpc0ludmFsaWQ6IGl0ZW0udmFsdWUubGVuZ3RoIDw9IDBcclxuICAgIH0pXHJcbn0iXX0=
|