ng-prime-tools 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +25 -0
- package/esm2022/lib/advanced-table/advanced-table.component.mjs +288 -0
- package/esm2022/lib/enums/table-type-enum.mjs +12 -0
- package/esm2022/lib/models/index.mjs +2 -0
- package/esm2022/lib/models/table-column.model.mjs +2 -0
- package/esm2022/lib/ng-prime-tools.component.mjs +11 -0
- package/esm2022/lib/ng-prime-tools.service.mjs +14 -0
- package/esm2022/lib/pipes/custom-currency.mjs +38 -0
- package/esm2022/ng-prime-tools.mjs +5 -0
- package/esm2022/public-api.mjs +9 -0
- package/fesm2022/ng-prime-tools.mjs +365 -0
- package/fesm2022/ng-prime-tools.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/advanced-table/advanced-table.component.d.ts +54 -0
- package/lib/enums/table-type-enum.d.ts +10 -0
- package/lib/models/index.d.ts +1 -0
- package/lib/models/table-column.model.d.ts +14 -0
- package/lib/ng-prime-tools.component.d.ts +5 -0
- package/lib/ng-prime-tools.service.d.ts +6 -0
- package/lib/pipes/custom-currency.d.ts +7 -0
- package/package.json +31 -0
- package/public-api.d.ts +5 -0
package/README.md
ADDED
@@ -0,0 +1,25 @@
|
|
1
|
+
# AdvancedPrimeTools
|
2
|
+
|
3
|
+
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 18.0.0.
|
4
|
+
|
5
|
+
## Code scaffolding
|
6
|
+
|
7
|
+
Run `ng generate component component-name --project ng-prime-tools` to generate a new component. You can also use `ng generate directive|pipe|service|class|guard|interface|enum|module --project ng-prime-tools`.
|
8
|
+
|
9
|
+
> Note: Don't forget to add `--project ng-prime-tools` or else it will be added to the default project in your `angular.json` file.
|
10
|
+
|
11
|
+
## Build
|
12
|
+
|
13
|
+
Run `ng build ng-prime-tools` to build the project. The build artifacts will be stored in the `dist/` directory.
|
14
|
+
|
15
|
+
## Publishing
|
16
|
+
|
17
|
+
After building your library with `ng build ng-prime-tools`, go to the dist folder `cd dist/ng-prime-tools` and run `npm publish`.
|
18
|
+
|
19
|
+
## Running unit tests
|
20
|
+
|
21
|
+
Run `ng test ng-prime-tools` to execute the unit tests via [Karma](https://karma-runner.github.io).
|
22
|
+
|
23
|
+
## Further help
|
24
|
+
|
25
|
+
To get more help on the Angular CLI use `ng help` or go check out the [Angular CLI Overview and Command Reference](https://angular.dev/tools/cli) page.
|
@@ -0,0 +1,288 @@
|
|
1
|
+
import { Component, Input, Output, ViewChild } from '@angular/core';
|
2
|
+
import { EventEmitter } from '@angular/core';
|
3
|
+
import { TableModule } from 'primeng/table';
|
4
|
+
import { TableTypeEnum } from '../enums/table-type-enum';
|
5
|
+
import { CommonModule } from '@angular/common';
|
6
|
+
import { FormsModule } from '@angular/forms';
|
7
|
+
import { ButtonModule } from 'primeng/button';
|
8
|
+
import { CalendarModule } from 'primeng/calendar';
|
9
|
+
import { InputTextModule } from 'primeng/inputtext';
|
10
|
+
import { MultiSelectModule } from 'primeng/multiselect';
|
11
|
+
import { CustomCurrencyPipe } from '../pipes/custom-currency';
|
12
|
+
import { IconFieldModule } from 'primeng/iconfield';
|
13
|
+
import { InputIconModule } from 'primeng/inputicon';
|
14
|
+
import { TagModule } from 'primeng/tag';
|
15
|
+
import * as i0 from "@angular/core";
|
16
|
+
import * as i1 from "@angular/common";
|
17
|
+
import * as i2 from "primeng/table";
|
18
|
+
import * as i3 from "primeng/api";
|
19
|
+
import * as i4 from "primeng/inputtext";
|
20
|
+
import * as i5 from "primeng/button";
|
21
|
+
import * as i6 from "primeng/calendar";
|
22
|
+
import * as i7 from "@angular/forms";
|
23
|
+
import * as i8 from "primeng/multiselect";
|
24
|
+
import * as i9 from "primeng/iconfield";
|
25
|
+
import * as i10 from "primeng/inputicon";
|
26
|
+
import * as i11 from "primeng/tag";
|
27
|
+
export class AdvancedTableComponent {
|
28
|
+
constructor() {
|
29
|
+
// Inputs
|
30
|
+
this.data = [];
|
31
|
+
this.columns = [];
|
32
|
+
this.totalRecords = 0;
|
33
|
+
this.rowsPerPage = [];
|
34
|
+
this.hasSearchFilter = false;
|
35
|
+
this.hasColumnFilter = false;
|
36
|
+
this.isPaginated = false;
|
37
|
+
this.actions = [];
|
38
|
+
this.isSortable = false;
|
39
|
+
// Outputs: Events emitted to the parent component
|
40
|
+
this.filter = new EventEmitter();
|
41
|
+
this.search = new EventEmitter();
|
42
|
+
this.searchValue = '';
|
43
|
+
this.validCurrencyCodes = ['USD', 'EUR', 'MAD'];
|
44
|
+
// Component state properties
|
45
|
+
this.isDelete = false;
|
46
|
+
this.isEdit = false;
|
47
|
+
this.rows = 0;
|
48
|
+
// Data management properties
|
49
|
+
this.dataMap = new Map();
|
50
|
+
this.map = new Map();
|
51
|
+
this.optionEntries = new Map();
|
52
|
+
this.optionValues = [];
|
53
|
+
this.globalFilterFields = [];
|
54
|
+
// CRUD operation handlers
|
55
|
+
this.Delete = () => { };
|
56
|
+
this.initEditableRow = () => { };
|
57
|
+
this.saveEditableRow = () => { };
|
58
|
+
this.cancelEditableRow = () => { };
|
59
|
+
}
|
60
|
+
ngOnInit() {
|
61
|
+
// Transform the date fields based on column metadata
|
62
|
+
this.data = this.formatingDateFields();
|
63
|
+
this.globalFilterFields = this.columns
|
64
|
+
.map((col) => col.code)
|
65
|
+
.filter((code) => code !== undefined);
|
66
|
+
this.initializePagination();
|
67
|
+
this.initializeActions();
|
68
|
+
// Set default value for isSortable
|
69
|
+
this.columns.forEach((col) => {
|
70
|
+
if (col.type === TableTypeEnum.ACTION) {
|
71
|
+
col.isEditable = false;
|
72
|
+
col.isFilter = false;
|
73
|
+
col.isSortable = false;
|
74
|
+
}
|
75
|
+
if (col.isSortable === undefined) {
|
76
|
+
col.isSortable = true;
|
77
|
+
}
|
78
|
+
if (col.isEditable === undefined) {
|
79
|
+
col.isEditable = true;
|
80
|
+
}
|
81
|
+
if (col.isFilter !== false && col.code !== undefined) {
|
82
|
+
this.globalFilterFields.push(col.code);
|
83
|
+
}
|
84
|
+
});
|
85
|
+
}
|
86
|
+
// Initialization Methods
|
87
|
+
formatingDateFields() {
|
88
|
+
return this.data.map((item) => {
|
89
|
+
const transformedItem = { ...item };
|
90
|
+
this.columns.forEach((column) => {
|
91
|
+
if (column.type === TableTypeEnum.DATE &&
|
92
|
+
column.code !== undefined &&
|
93
|
+
transformedItem[column.code] !== undefined) {
|
94
|
+
const dateValue = this.parseDate(transformedItem[column.code]);
|
95
|
+
transformedItem[column.code] = dateValue ? dateValue : null;
|
96
|
+
}
|
97
|
+
});
|
98
|
+
return transformedItem;
|
99
|
+
});
|
100
|
+
}
|
101
|
+
clear(table) {
|
102
|
+
table.clear();
|
103
|
+
this.searchValue = '';
|
104
|
+
}
|
105
|
+
parseDate(dateString) {
|
106
|
+
const parts = dateString.split('/');
|
107
|
+
if (parts.length === 3) {
|
108
|
+
// Assuming date format is DD/MM/YYYY
|
109
|
+
const day = parseInt(parts[0], 10);
|
110
|
+
const month = parseInt(parts[1], 10) - 1;
|
111
|
+
const year = parseInt(parts[2], 10);
|
112
|
+
const date = new Date(year, month, day);
|
113
|
+
return isNaN(date.getTime()) ? null : date;
|
114
|
+
}
|
115
|
+
return null;
|
116
|
+
}
|
117
|
+
initializePagination() {
|
118
|
+
if (this.isPaginated) {
|
119
|
+
this.rowsPerPage = this.rowsPerPage || [20, 30, 40];
|
120
|
+
this.rows = this.rowsPerPage[0];
|
121
|
+
}
|
122
|
+
}
|
123
|
+
initializeActions() {
|
124
|
+
if (this.actions) {
|
125
|
+
this.actions.forEach((action) => {
|
126
|
+
switch (action.code) {
|
127
|
+
case 'delete':
|
128
|
+
this.isDelete = true;
|
129
|
+
this.Delete = (value) => action.action(value);
|
130
|
+
break;
|
131
|
+
case 'edit':
|
132
|
+
this.initializeEditActions(action);
|
133
|
+
break;
|
134
|
+
default:
|
135
|
+
this.isDelete = false;
|
136
|
+
this.isEdit = false;
|
137
|
+
}
|
138
|
+
});
|
139
|
+
}
|
140
|
+
}
|
141
|
+
initializeEditActions(action) {
|
142
|
+
this.isEdit = true;
|
143
|
+
this.initEditableRow = (data) => action.action.init(data);
|
144
|
+
this.saveEditableRow = (data) => {
|
145
|
+
const record = this.map.get(data.id);
|
146
|
+
action.action.save(data, record);
|
147
|
+
this.dataMap.clear();
|
148
|
+
};
|
149
|
+
this.cancelEditableRow = (item) => console.log(item);
|
150
|
+
}
|
151
|
+
onChange(event, id, key) {
|
152
|
+
const target = event.target;
|
153
|
+
this.changeHandler(id, key, target.value);
|
154
|
+
}
|
155
|
+
changeHandler(id, key, value) {
|
156
|
+
let column = this.columns.find((item) => item.code === key);
|
157
|
+
if (!this.map.get(id)) {
|
158
|
+
if (column?.type === TableTypeEnum.DATE) {
|
159
|
+
let date = this.parseDate(value);
|
160
|
+
this.dataMap.set(key, date);
|
161
|
+
}
|
162
|
+
else {
|
163
|
+
this.dataMap.set(key, value);
|
164
|
+
}
|
165
|
+
this.map.set(id, new Map(this.dataMap));
|
166
|
+
}
|
167
|
+
else {
|
168
|
+
let mapItem = this.map.get(id);
|
169
|
+
if (column?.type === TableTypeEnum.DATE) {
|
170
|
+
let date = this.parseDate(value);
|
171
|
+
mapItem.set(key, date);
|
172
|
+
}
|
173
|
+
else {
|
174
|
+
mapItem.set(key, value);
|
175
|
+
}
|
176
|
+
}
|
177
|
+
}
|
178
|
+
getColumnFilterType(column) {
|
179
|
+
switch (column.type) {
|
180
|
+
case TableTypeEnum.STRING:
|
181
|
+
return 'text';
|
182
|
+
case TableTypeEnum.AMOUNT:
|
183
|
+
return 'numeric';
|
184
|
+
case TableTypeEnum.NUMBER:
|
185
|
+
return 'numeric';
|
186
|
+
case TableTypeEnum.DATE:
|
187
|
+
return 'date';
|
188
|
+
case TableTypeEnum.MULTISELECT:
|
189
|
+
return 'multiSelect';
|
190
|
+
case TableTypeEnum.BOOLEAN:
|
191
|
+
return 'boolean';
|
192
|
+
default:
|
193
|
+
return 'text';
|
194
|
+
}
|
195
|
+
}
|
196
|
+
// State Check Methods
|
197
|
+
isEditable(key) {
|
198
|
+
let column = this.columns.find((item) => item.code === key);
|
199
|
+
return column?.isEditable !== false;
|
200
|
+
}
|
201
|
+
isMultiSelect(key) {
|
202
|
+
let column = this.columns.find((item) => item.code === key);
|
203
|
+
if (column?.type === TableTypeEnum.MULTISELECT &&
|
204
|
+
column.options &&
|
205
|
+
column.code !== undefined) {
|
206
|
+
this.optionEntries = new Map([
|
207
|
+
[column.code, Object.values(column.options)],
|
208
|
+
]);
|
209
|
+
this.optionValues = this.optionEntries.get(key) || [];
|
210
|
+
return true;
|
211
|
+
}
|
212
|
+
return false;
|
213
|
+
}
|
214
|
+
isDatePicker(key) {
|
215
|
+
return (this.columns.find((item) => item.code === key)?.type ===
|
216
|
+
TableTypeEnum.DATE);
|
217
|
+
}
|
218
|
+
// Utility Methods
|
219
|
+
dateConverter(value) {
|
220
|
+
return new Date(value).toLocaleDateString('en-US');
|
221
|
+
}
|
222
|
+
getCurrencySymbol(column) {
|
223
|
+
return column.type === TableTypeEnum.AMOUNT &&
|
224
|
+
column.currency &&
|
225
|
+
this.isValidCurrencyCode(column.currency)
|
226
|
+
? column.currency
|
227
|
+
: undefined;
|
228
|
+
}
|
229
|
+
isValidCurrencyCode(currencyCode) {
|
230
|
+
return this.validCurrencyCodes.includes(currencyCode);
|
231
|
+
}
|
232
|
+
customDateFilter(value, filter) {
|
233
|
+
if (!filter || !value) {
|
234
|
+
return true;
|
235
|
+
}
|
236
|
+
const filterDate = new Date(filter);
|
237
|
+
const valueDate = new Date(value);
|
238
|
+
return valueDate.toDateString() === filterDate.toDateString();
|
239
|
+
}
|
240
|
+
filterGlobal(event) {
|
241
|
+
const target = event.target;
|
242
|
+
this.dt.filterGlobal(target.value, 'contains');
|
243
|
+
}
|
244
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AdvancedTableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
245
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.3", type: AdvancedTableComponent, isStandalone: true, selector: "advanced-table", inputs: { data: "data", columns: "columns", totalRecords: "totalRecords", rowsPerPage: "rowsPerPage", hasSearchFilter: "hasSearchFilter", hasColumnFilter: "hasColumnFilter", isPaginated: "isPaginated", actions: "actions", isSortable: "isSortable" }, outputs: { filter: "filter", search: "search" }, viewQueries: [{ propertyName: "dt", first: true, predicate: ["dt"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"table-container\">\n <div>\n <p-table\n #dt\n [value]=\"data\"\n dataKey=\"id\"\n [rows]=\"rows\"\n [paginator]=\"isPaginated\"\n [globalFilterFields]=\"globalFilterFields\"\n styleClass=\"p-datatable-gridlines\"\n [rowsPerPageOptions]=\"rowsPerPage\"\n styleClass=\"p-datatable-striped\"\n editMode=\"row\"\n [globalFilterFields]=\"globalFilterFields\"\n >\n <ng-template pTemplate=\"caption\">\n <div class=\"flex\">\n <div>\n <h3>Total: {{ totalRecords }}</h3>\n </div>\n\n <div>\n <p-button\n label=\"Clear\"\n [outlined]=\"true\"\n icon=\"pi pi-filter-slash\"\n (click)=\"clear(dt)\"\n class=\"bt-filter-btn\"\n />\n </div>\n <div class=\"ml-auto\" *ngIf=\"hasSearchFilter\">\n <!-- Add this wrapper div with ml-auto class -->\n <p-iconField iconPosition=\"left\" class=\"ml-auto\">\n <p-inputIcon>\n <i class=\"pi pi-search\"></i>\n </p-inputIcon>\n <input\n pInputText\n type=\"text\"\n [(ngModel)]=\"searchValue\"\n (input)=\"filterGlobal($event)\"\n placeholder=\"Search keyword\"\n />\n </p-iconField>\n </div>\n </div>\n </ng-template>\n\n <ng-template pTemplate=\"header\">\n <tr>\n <th *ngFor=\"let col of columns\">\n <ng-container\n *ngIf=\"isSortable && col.isSortable !== false; else noSortHeader\"\n >\n <th pSortableColumn=\"{{ col.code }}\" style=\"width: 20%\">\n <div class=\"header-container\">\n <span>{{ col.title }}</span>\n <p-sortIcon field=\"{{ col.code }}\" />\n <ng-container *ngIf=\"col.isFilter !== false\">\n <p-columnFilter\n *ngIf=\"col.type === 'AMOUNT'\"\n display=\"menu\"\n [field]=\"col.code\"\n [type]=\"getColumnFilterType(col)\"\n [currency]=\"getCurrencySymbol(col)\"\n ></p-columnFilter>\n\n <p-columnFilter\n *ngIf=\"col.type !== 'AMOUNT'\"\n display=\"menu\"\n [field]=\"col.code\"\n display=\"menu\"\n [type]=\"getColumnFilterType(col)\"\n [type]=\"getColumnFilterType(col)\"\n >\n <ng-template\n pTemplate=\"filter\"\n let-value\n let-filterCallback=\"filterCallback\"\n *ngIf=\"getColumnFilterType(col) === 'date'\"\n >\n <p-calendar\n [ngModel]=\"value\"\n (ngModelChange)=\"filterCallback($event)\"\n [dateFormat]=\"'dd/mm/yy'\"\n ></p-calendar>\n </ng-template>\n\n <ng-template\n pTemplate=\"filter\"\n let-value\n let-filterCallback=\"filterCallback\"\n *ngIf=\"getColumnFilterType(col) === 'multiSelect'\"\n >\n <p-multiSelect\n [options]=\"col.filterOptions\"\n [ngModel]=\"value\"\n (ngModelChange)=\"filterCallback($event)\"\n [display]=\"'chip'\"\n placeholder=\"Select\"\n class=\"custom-multiselect\"\n ></p-multiSelect>\n </ng-template>\n </p-columnFilter>\n </ng-container>\n </div>\n </th>\n </ng-container>\n <ng-template #noSortHeader>\n <th>\n <div class=\"header-container\">\n <span>{{ col.title }}</span>\n <ng-container *ngIf=\"col.isFilter !== false\">\n <p-columnFilter\n *ngIf=\"col.type === 'AMOUNT'\"\n display=\"menu\"\n [field]=\"col.code\"\n [type]=\"getColumnFilterType(col)\"\n [currency]=\"getCurrencySymbol(col)\"\n ></p-columnFilter>\n\n <p-columnFilter\n *ngIf=\"col.type !== 'AMOUNT'\"\n display=\"menu\"\n [field]=\"col.code\"\n [type]=\"getColumnFilterType(col)\"\n >\n <ng-template\n pTemplate=\"filter\"\n let-value\n let-filterCallback=\"filterCallback\"\n *ngIf=\"getColumnFilterType(col) === 'date'\"\n >\n <p-calendar\n [ngModel]=\"value\"\n (ngModelChange)=\"filterCallback($event)\"\n [dateFormat]=\"'dd/mm/yy'\"\n ></p-calendar>\n </ng-template>\n\n <ng-template\n pTemplate=\"filter\"\n let-value\n let-filterCallback=\"filterCallback\"\n *ngIf=\"getColumnFilterType(col) === 'multiSelect'\"\n >\n <p-multiSelect\n [options]=\"col.filterOptions\"\n [ngModel]=\"value\"\n (ngModelChange)=\"filterCallback($event)\"\n [display]=\"'chip'\"\n placeholder=\"Select\"\n class=\"custom-multiselect\"\n ></p-multiSelect>\n </ng-template>\n </p-columnFilter>\n </ng-container>\n </div>\n </th>\n </ng-template>\n </th>\n </tr>\n </ng-template>\n\n <ng-template\n pTemplate=\"body\"\n let-data\n let-editing=\"editing\"\n let-ri=\"rowIndex\"\n >\n <!-- Render a table row and make it editable if `isEdit` is true -->\n <tr [pEditableRow]=\"isEdit ? data : null\">\n <!-- Loop through each column and render corresponding table cells -->\n <ng-container *ngFor=\"let col of columns\">\n <ng-container *ngIf=\"col.code !== undefined\">\n <!-- Check if the data for the column exists -->\n <ng-container *ngIf=\"data[col.code] !== undefined\">\n <!-- Render an editable cell if the column is editable -->\n <td *ngIf=\"isEditable(col.code); else normalTD\">\n <!-- Multi-select input for columns that are multi-selectable -->\n <ng-container\n *ngIf=\"isMultiSelect(col.code); else datePicker\"\n >\n <p-cellEditor>\n <ng-template pTemplate=\"input\">\n <p-multiSelect\n appendTo=\"body\"\n [ngModel]=\"data[col.code]\"\n [style]=\"{ width: '100%' }\"\n (ngModelChange)=\"\n changeHandler(data.id, col.code, $event)\n \"\n [options]=\"optionValues\"\n ></p-multiSelect>\n </ng-template>\n <ng-template pTemplate=\"output\">\n <div class=\"multi-select-container\">\n <ng-container *ngFor=\"let rec of data[col.code]\">\n <p-tag [value]=\"rec\"></p-tag>\n </ng-container>\n </div>\n </ng-template>\n </p-cellEditor>\n </ng-container>\n\n <!-- Date picker input for columns that require date selection -->\n <ng-template #datePicker>\n <ng-container\n *ngIf=\"isDatePicker(col.code); else normalInput\"\n >\n <p-cellEditor>\n <ng-template pTemplate=\"input\">\n <p-calendar\n [inputId]=\"data[col.code]\"\n [ngModel]=\"data[col.code]\"\n (ngModelChange)=\"\n changeHandler(data.id, col.code, $event)\n \"\n [dateFormat]=\"'dd/mm/yy'\"\n ></p-calendar>\n </ng-template>\n <ng-template pTemplate=\"output\">\n {{ data[col.code] | date : \"dd/MM/yyyy\" }}\n </ng-template>\n </p-cellEditor>\n </ng-container>\n </ng-template>\n\n <!-- Normal text input for other columns -->\n <ng-template #normalInput>\n <p-cellEditor>\n <ng-template pTemplate=\"input\">\n <input\n pInputText\n type=\"text\"\n [ngModel]=\"data[col.code]\"\n (change)=\"onChange($event, data.id, col.code)\"\n />\n </ng-template>\n <ng-template pTemplate=\"output\">\n <!-- Use currency pipe to format the output for AMOUNT type -->\n <ng-container\n *ngIf=\"col.type === 'AMOUNT'; else normalOutput\"\n >\n {{\n data[col.code]\n | customCurrency\n : getCurrencySymbol(col)\n : col.decimalPlaces\n }}\n </ng-container>\n <ng-template #normalOutput>\n {{ data[col.code] }}\n </ng-template>\n </ng-template>\n </p-cellEditor>\n </ng-template>\n </td>\n\n <!-- Render a normal table cell if the column is not editable -->\n <ng-template #normalTD>\n <td>\n <!-- Use customCurrency pipe to format the output for AMOUNT type with optional decimal places -->\n <ng-container\n *ngIf=\"col.type === 'AMOUNT'; else normalText\"\n >\n >\n {{\n data[col.code]\n | customCurrency\n : getCurrencySymbol(col)\n : col.decimalPlaces\n }}\n </ng-container>\n <ng-template #normalText>\n {{ data[col.code] }}\n </ng-template>\n </td>\n </ng-template>\n </ng-container>\n </ng-container>\n </ng-container>\n\n <!-- Render action buttons if there are any actions defined -->\n <td *ngIf=\"actions?.length\">\n <div class=\"action-buttons-container\">\n <!-- Delete button if deletion is allowed -->\n <div *ngIf=\"isDelete\">\n <button\n pButton\n pRipple\n type=\"button\"\n icon=\"pi pi-trash\"\n (click)=\"Delete(data.id)\"\n class=\"p-button-rounded p-button-text\"\n ></button>\n </div>\n <!-- Edit, save, and cancel buttons for row editing -->\n <div>\n <button\n pInitEditableRow\n *ngIf=\"!editing\"\n pButton\n pRipple\n type=\"button\"\n icon=\"pi pi-pencil\"\n (click)=\"initEditableRow(data)\"\n class=\"p-button-rounded p-button-text\"\n ></button>\n <button\n *ngIf=\"editing\"\n pSaveEditableRow\n pButton\n pRipple\n type=\"button\"\n icon=\"pi pi-check\"\n (click)=\"saveEditableRow(data)\"\n class=\"p-button-rounded p-button-text\"\n ></button>\n <button\n *ngIf=\"editing\"\n pCancelEditableRow\n pButton\n pRipple\n type=\"button\"\n icon=\"pi pi-times\"\n (click)=\"cancelEditableRow(data)\"\n class=\"p-button-rounded p-button-text\"\n ></button>\n </div>\n </div>\n </td>\n </tr>\n </ng-template>\n </p-table>\n </div>\n</div>\n", styles: [".date{width:100%;height:5rem;display:grid;justify-items:start;align-items:center}.filter-container{width:100%;display:flex;justify-content:space-between;align-items:center}.settings{display:flex;gap:1rem}.multi-select-container{display:flex;justify-content:center;align-items:center;gap:.3rem}::ng-deep p-table{min-width:50rem}.table-container{display:flex;flex-direction:column;gap:.5rem}::ng-deep .custom-multiselect .p-hidden-accessible input{display:none}::ng-deep .p-datatable .p-sortable-column.p-highlight:hover{background:none}::ng-deep .p-datatable .p-sortable-column:focus{box-shadow:none;outline:0 none}::ng-deep .header-container{display:flex;align-items:center}::ng-deep .header-container span{margin-right:.5em}::ng-deep p-columnfilter.p-element.ng-star-inserted{margin-top:4px}.flex{display:flex;justify-content:space-between;align-items:center}.ml-auto{margin-left:auto}::ng-deep p-inputicon{margin-right:-1.5rem;z-index:2;position:relative}::ng-deep .p-inputtext{padding-left:1.7rem}::ng-deep .bt-filter-btn button{cursor:pointer;margin-left:1rem}::ng-deep .p-icon-field-left .p-input-icon:first-of-type{left:-1rem}.table-row{text-align:center;display:flex;gap:1rem;justify-content:center}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.DatePipe, name: "date" }, { kind: "ngmodule", type: TableModule }, { kind: "component", type: i2.Table, selector: "p-table", inputs: ["frozenColumns", "frozenValue", "style", "styleClass", "tableStyle", "tableStyleClass", "paginator", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "paginatorStyleClass", "paginatorDropdownAppendTo", "paginatorDropdownScrollHeight", "currentPageReportTemplate", "showCurrentPageReport", "showJumpToPageDropdown", "showJumpToPageInput", "showFirstLastIcon", "showPageLinks", "defaultSortOrder", "sortMode", "resetPageOnSort", "selectionMode", "selectionPageOnly", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "rowSelectable", "rowTrackBy", "lazy", "lazyLoadOnInit", "compareSelectionBy", "csvSeparator", "exportFilename", "filters", "globalFilterFields", "filterDelay", "filterLocale", "expandedRowKeys", "editingRowKeys", "rowExpandMode", "scrollable", "scrollDirection", "rowGroupMode", "scrollHeight", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "virtualScrollDelay", "frozenWidth", "responsive", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "autoLayout", "exportFunction", "exportHeader", "stateKey", "stateStorage", "editMode", "groupRowsBy", "groupRowsByOrder", "responsiveLayout", "breakpoint", "paginatorLocale", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "selectAll", "virtualRowHeight"], outputs: ["contextMenuSelectionChange", "selectAllChange", "selectionChange", "onRowSelect", "onRowUnselect", "onPage", "onSort", "onFilter", "onLazyLoad", "onRowExpand", "onRowCollapse", "onContextMenuSelect", "onColResize", "onColReorder", "onRowReorder", "onEditInit", "onEditComplete", "onEditCancel", "onHeaderCheckboxToggle", "sortFunction", "firstChange", "rowsChange", "onStateSave", "onStateRestore"] }, { kind: "directive", type: i3.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "directive", type: i2.SortableColumn, selector: "[pSortableColumn]", inputs: ["pSortableColumn", "pSortableColumnDisabled"] }, { kind: "component", type: i2.CellEditor, selector: "p-cellEditor" }, { kind: "component", type: i2.SortIcon, selector: "p-sortIcon", inputs: ["field"] }, { kind: "directive", type: i2.EditableRow, selector: "[pEditableRow]", inputs: ["pEditableRow", "pEditableRowDisabled"] }, { kind: "directive", type: i2.InitEditableRow, selector: "[pInitEditableRow]" }, { kind: "directive", type: i2.SaveEditableRow, selector: "[pSaveEditableRow]" }, { kind: "directive", type: i2.CancelEditableRow, selector: "[pCancelEditableRow]" }, { kind: "component", type: i2.ColumnFilter, selector: "p-columnFilter", inputs: ["field", "type", "display", "showMenu", "matchMode", "operator", "showOperator", "showClearButton", "showApplyButton", "showMatchModes", "showAddButton", "hideOnClear", "placeholder", "matchModeOptions", "maxConstraints", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "locale", "localeMatcher", "currency", "currencyDisplay", "useGrouping", "showButtons", "ariaLabel"], outputs: ["onShow", "onHide"] }, { kind: "ngmodule", type: InputTextModule }, { kind: "directive", type: i4.InputText, selector: "[pInputText]", inputs: ["variant"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i5.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading", "severity", "raised", "rounded", "text", "outlined", "size", "plain"] }, { kind: "component", type: i5.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "style", "styleClass", "badgeClass", "ariaLabel", "autofocus"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "ngmodule", type: CalendarModule }, { kind: "component", type: i6.Calendar, selector: "p-calendar", inputs: ["iconDisplay", "style", "styleClass", "inputStyle", "inputId", "name", "inputStyleClass", "placeholder", "ariaLabelledBy", "ariaLabel", "iconAriaLabel", "disabled", "dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "selectOtherMonths", "showIcon", "icon", "appendTo", "readonlyInput", "shortYearCutoff", "monthNavigator", "yearNavigator", "hourFormat", "timeOnly", "stepYearPicker", "stepHour", "stepMinute", "stepSecond", "showSeconds", "required", "showOnFocus", "showWeek", "startWeekFromFirstDayOfYear", "showClear", "dataType", "selectionMode", "maxDateCount", "showButtonBar", "todayButtonStyleClass", "clearButtonStyleClass", "autofocus", "autoZIndex", "baseZIndex", "panelStyleClass", "panelStyle", "keepInvalid", "hideOnDateTimeSelect", "touchUI", "timeSeparator", "focusTrap", "showTransitionOptions", "hideTransitionOptions", "tabindex", "variant", "minDate", "maxDate", "disabledDates", "disabledDays", "yearRange", "showTime", "responsiveOptions", "numberOfMonths", "firstDayOfWeek", "locale", "view", "defaultDate"], outputs: ["onFocus", "onBlur", "onClose", "onSelect", "onClear", "onInput", "onTodayClick", "onClearClick", "onMonthChange", "onYearChange", "onClickOutside", "onShow"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i7.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: MultiSelectModule }, { kind: "component", type: i8.MultiSelect, selector: "p-multiSelect", inputs: ["id", "ariaLabel", "style", "styleClass", "panelStyle", "panelStyleClass", "inputId", "disabled", "readonly", "group", "filter", "filterPlaceHolder", "filterLocale", "overlayVisible", "tabindex", "variant", "appendTo", "dataKey", "name", "ariaLabelledBy", "displaySelectedLabel", "maxSelectedLabels", "selectionLimit", "selectedItemsLabel", "showToggleAll", "emptyFilterMessage", "emptyMessage", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "showHeader", "filterBy", "scrollHeight", "lazy", "virtualScroll", "loading", "virtualScrollItemSize", "loadingIcon", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "display", "autocomplete", "showClear", "autofocus", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "defaultLabel", "placeholder", "options", "filterValue", "itemSize", "selectAll", "focusOnHover", "filterFields", "selectOnFocus", "autoOptionFocus"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onClear", "onPanelShow", "onPanelHide", "onLazyLoad", "onRemove", "onSelectAllChange"] }, { kind: "pipe", type: CustomCurrencyPipe, name: "customCurrency" }, { kind: "ngmodule", type: IconFieldModule }, { kind: "component", type: i9.IconField, selector: "p-iconField", inputs: ["iconPosition"] }, { kind: "ngmodule", type: InputIconModule }, { kind: "component", type: i10.InputIcon, selector: "p-inputIcon", inputs: ["styleClass"] }, { kind: "ngmodule", type: TagModule }, { kind: "component", type: i11.Tag, selector: "p-tag", inputs: ["style", "styleClass", "severity", "value", "icon", "rounded"] }] }); }
|
246
|
+
}
|
247
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AdvancedTableComponent, decorators: [{
|
248
|
+
type: Component,
|
249
|
+
args: [{ selector: 'advanced-table', standalone: true, imports: [
|
250
|
+
CommonModule,
|
251
|
+
TableModule,
|
252
|
+
InputTextModule,
|
253
|
+
ButtonModule,
|
254
|
+
CalendarModule,
|
255
|
+
FormsModule,
|
256
|
+
MultiSelectModule,
|
257
|
+
CustomCurrencyPipe,
|
258
|
+
IconFieldModule,
|
259
|
+
InputIconModule,
|
260
|
+
TagModule,
|
261
|
+
], template: "<div class=\"table-container\">\n <div>\n <p-table\n #dt\n [value]=\"data\"\n dataKey=\"id\"\n [rows]=\"rows\"\n [paginator]=\"isPaginated\"\n [globalFilterFields]=\"globalFilterFields\"\n styleClass=\"p-datatable-gridlines\"\n [rowsPerPageOptions]=\"rowsPerPage\"\n styleClass=\"p-datatable-striped\"\n editMode=\"row\"\n [globalFilterFields]=\"globalFilterFields\"\n >\n <ng-template pTemplate=\"caption\">\n <div class=\"flex\">\n <div>\n <h3>Total: {{ totalRecords }}</h3>\n </div>\n\n <div>\n <p-button\n label=\"Clear\"\n [outlined]=\"true\"\n icon=\"pi pi-filter-slash\"\n (click)=\"clear(dt)\"\n class=\"bt-filter-btn\"\n />\n </div>\n <div class=\"ml-auto\" *ngIf=\"hasSearchFilter\">\n <!-- Add this wrapper div with ml-auto class -->\n <p-iconField iconPosition=\"left\" class=\"ml-auto\">\n <p-inputIcon>\n <i class=\"pi pi-search\"></i>\n </p-inputIcon>\n <input\n pInputText\n type=\"text\"\n [(ngModel)]=\"searchValue\"\n (input)=\"filterGlobal($event)\"\n placeholder=\"Search keyword\"\n />\n </p-iconField>\n </div>\n </div>\n </ng-template>\n\n <ng-template pTemplate=\"header\">\n <tr>\n <th *ngFor=\"let col of columns\">\n <ng-container\n *ngIf=\"isSortable && col.isSortable !== false; else noSortHeader\"\n >\n <th pSortableColumn=\"{{ col.code }}\" style=\"width: 20%\">\n <div class=\"header-container\">\n <span>{{ col.title }}</span>\n <p-sortIcon field=\"{{ col.code }}\" />\n <ng-container *ngIf=\"col.isFilter !== false\">\n <p-columnFilter\n *ngIf=\"col.type === 'AMOUNT'\"\n display=\"menu\"\n [field]=\"col.code\"\n [type]=\"getColumnFilterType(col)\"\n [currency]=\"getCurrencySymbol(col)\"\n ></p-columnFilter>\n\n <p-columnFilter\n *ngIf=\"col.type !== 'AMOUNT'\"\n display=\"menu\"\n [field]=\"col.code\"\n display=\"menu\"\n [type]=\"getColumnFilterType(col)\"\n [type]=\"getColumnFilterType(col)\"\n >\n <ng-template\n pTemplate=\"filter\"\n let-value\n let-filterCallback=\"filterCallback\"\n *ngIf=\"getColumnFilterType(col) === 'date'\"\n >\n <p-calendar\n [ngModel]=\"value\"\n (ngModelChange)=\"filterCallback($event)\"\n [dateFormat]=\"'dd/mm/yy'\"\n ></p-calendar>\n </ng-template>\n\n <ng-template\n pTemplate=\"filter\"\n let-value\n let-filterCallback=\"filterCallback\"\n *ngIf=\"getColumnFilterType(col) === 'multiSelect'\"\n >\n <p-multiSelect\n [options]=\"col.filterOptions\"\n [ngModel]=\"value\"\n (ngModelChange)=\"filterCallback($event)\"\n [display]=\"'chip'\"\n placeholder=\"Select\"\n class=\"custom-multiselect\"\n ></p-multiSelect>\n </ng-template>\n </p-columnFilter>\n </ng-container>\n </div>\n </th>\n </ng-container>\n <ng-template #noSortHeader>\n <th>\n <div class=\"header-container\">\n <span>{{ col.title }}</span>\n <ng-container *ngIf=\"col.isFilter !== false\">\n <p-columnFilter\n *ngIf=\"col.type === 'AMOUNT'\"\n display=\"menu\"\n [field]=\"col.code\"\n [type]=\"getColumnFilterType(col)\"\n [currency]=\"getCurrencySymbol(col)\"\n ></p-columnFilter>\n\n <p-columnFilter\n *ngIf=\"col.type !== 'AMOUNT'\"\n display=\"menu\"\n [field]=\"col.code\"\n [type]=\"getColumnFilterType(col)\"\n >\n <ng-template\n pTemplate=\"filter\"\n let-value\n let-filterCallback=\"filterCallback\"\n *ngIf=\"getColumnFilterType(col) === 'date'\"\n >\n <p-calendar\n [ngModel]=\"value\"\n (ngModelChange)=\"filterCallback($event)\"\n [dateFormat]=\"'dd/mm/yy'\"\n ></p-calendar>\n </ng-template>\n\n <ng-template\n pTemplate=\"filter\"\n let-value\n let-filterCallback=\"filterCallback\"\n *ngIf=\"getColumnFilterType(col) === 'multiSelect'\"\n >\n <p-multiSelect\n [options]=\"col.filterOptions\"\n [ngModel]=\"value\"\n (ngModelChange)=\"filterCallback($event)\"\n [display]=\"'chip'\"\n placeholder=\"Select\"\n class=\"custom-multiselect\"\n ></p-multiSelect>\n </ng-template>\n </p-columnFilter>\n </ng-container>\n </div>\n </th>\n </ng-template>\n </th>\n </tr>\n </ng-template>\n\n <ng-template\n pTemplate=\"body\"\n let-data\n let-editing=\"editing\"\n let-ri=\"rowIndex\"\n >\n <!-- Render a table row and make it editable if `isEdit` is true -->\n <tr [pEditableRow]=\"isEdit ? data : null\">\n <!-- Loop through each column and render corresponding table cells -->\n <ng-container *ngFor=\"let col of columns\">\n <ng-container *ngIf=\"col.code !== undefined\">\n <!-- Check if the data for the column exists -->\n <ng-container *ngIf=\"data[col.code] !== undefined\">\n <!-- Render an editable cell if the column is editable -->\n <td *ngIf=\"isEditable(col.code); else normalTD\">\n <!-- Multi-select input for columns that are multi-selectable -->\n <ng-container\n *ngIf=\"isMultiSelect(col.code); else datePicker\"\n >\n <p-cellEditor>\n <ng-template pTemplate=\"input\">\n <p-multiSelect\n appendTo=\"body\"\n [ngModel]=\"data[col.code]\"\n [style]=\"{ width: '100%' }\"\n (ngModelChange)=\"\n changeHandler(data.id, col.code, $event)\n \"\n [options]=\"optionValues\"\n ></p-multiSelect>\n </ng-template>\n <ng-template pTemplate=\"output\">\n <div class=\"multi-select-container\">\n <ng-container *ngFor=\"let rec of data[col.code]\">\n <p-tag [value]=\"rec\"></p-tag>\n </ng-container>\n </div>\n </ng-template>\n </p-cellEditor>\n </ng-container>\n\n <!-- Date picker input for columns that require date selection -->\n <ng-template #datePicker>\n <ng-container\n *ngIf=\"isDatePicker(col.code); else normalInput\"\n >\n <p-cellEditor>\n <ng-template pTemplate=\"input\">\n <p-calendar\n [inputId]=\"data[col.code]\"\n [ngModel]=\"data[col.code]\"\n (ngModelChange)=\"\n changeHandler(data.id, col.code, $event)\n \"\n [dateFormat]=\"'dd/mm/yy'\"\n ></p-calendar>\n </ng-template>\n <ng-template pTemplate=\"output\">\n {{ data[col.code] | date : \"dd/MM/yyyy\" }}\n </ng-template>\n </p-cellEditor>\n </ng-container>\n </ng-template>\n\n <!-- Normal text input for other columns -->\n <ng-template #normalInput>\n <p-cellEditor>\n <ng-template pTemplate=\"input\">\n <input\n pInputText\n type=\"text\"\n [ngModel]=\"data[col.code]\"\n (change)=\"onChange($event, data.id, col.code)\"\n />\n </ng-template>\n <ng-template pTemplate=\"output\">\n <!-- Use currency pipe to format the output for AMOUNT type -->\n <ng-container\n *ngIf=\"col.type === 'AMOUNT'; else normalOutput\"\n >\n {{\n data[col.code]\n | customCurrency\n : getCurrencySymbol(col)\n : col.decimalPlaces\n }}\n </ng-container>\n <ng-template #normalOutput>\n {{ data[col.code] }}\n </ng-template>\n </ng-template>\n </p-cellEditor>\n </ng-template>\n </td>\n\n <!-- Render a normal table cell if the column is not editable -->\n <ng-template #normalTD>\n <td>\n <!-- Use customCurrency pipe to format the output for AMOUNT type with optional decimal places -->\n <ng-container\n *ngIf=\"col.type === 'AMOUNT'; else normalText\"\n >\n >\n {{\n data[col.code]\n | customCurrency\n : getCurrencySymbol(col)\n : col.decimalPlaces\n }}\n </ng-container>\n <ng-template #normalText>\n {{ data[col.code] }}\n </ng-template>\n </td>\n </ng-template>\n </ng-container>\n </ng-container>\n </ng-container>\n\n <!-- Render action buttons if there are any actions defined -->\n <td *ngIf=\"actions?.length\">\n <div class=\"action-buttons-container\">\n <!-- Delete button if deletion is allowed -->\n <div *ngIf=\"isDelete\">\n <button\n pButton\n pRipple\n type=\"button\"\n icon=\"pi pi-trash\"\n (click)=\"Delete(data.id)\"\n class=\"p-button-rounded p-button-text\"\n ></button>\n </div>\n <!-- Edit, save, and cancel buttons for row editing -->\n <div>\n <button\n pInitEditableRow\n *ngIf=\"!editing\"\n pButton\n pRipple\n type=\"button\"\n icon=\"pi pi-pencil\"\n (click)=\"initEditableRow(data)\"\n class=\"p-button-rounded p-button-text\"\n ></button>\n <button\n *ngIf=\"editing\"\n pSaveEditableRow\n pButton\n pRipple\n type=\"button\"\n icon=\"pi pi-check\"\n (click)=\"saveEditableRow(data)\"\n class=\"p-button-rounded p-button-text\"\n ></button>\n <button\n *ngIf=\"editing\"\n pCancelEditableRow\n pButton\n pRipple\n type=\"button\"\n icon=\"pi pi-times\"\n (click)=\"cancelEditableRow(data)\"\n class=\"p-button-rounded p-button-text\"\n ></button>\n </div>\n </div>\n </td>\n </tr>\n </ng-template>\n </p-table>\n </div>\n</div>\n", styles: [".date{width:100%;height:5rem;display:grid;justify-items:start;align-items:center}.filter-container{width:100%;display:flex;justify-content:space-between;align-items:center}.settings{display:flex;gap:1rem}.multi-select-container{display:flex;justify-content:center;align-items:center;gap:.3rem}::ng-deep p-table{min-width:50rem}.table-container{display:flex;flex-direction:column;gap:.5rem}::ng-deep .custom-multiselect .p-hidden-accessible input{display:none}::ng-deep .p-datatable .p-sortable-column.p-highlight:hover{background:none}::ng-deep .p-datatable .p-sortable-column:focus{box-shadow:none;outline:0 none}::ng-deep .header-container{display:flex;align-items:center}::ng-deep .header-container span{margin-right:.5em}::ng-deep p-columnfilter.p-element.ng-star-inserted{margin-top:4px}.flex{display:flex;justify-content:space-between;align-items:center}.ml-auto{margin-left:auto}::ng-deep p-inputicon{margin-right:-1.5rem;z-index:2;position:relative}::ng-deep .p-inputtext{padding-left:1.7rem}::ng-deep .bt-filter-btn button{cursor:pointer;margin-left:1rem}::ng-deep .p-icon-field-left .p-input-icon:first-of-type{left:-1rem}.table-row{text-align:center;display:flex;gap:1rem;justify-content:center}\n"] }]
|
262
|
+
}], ctorParameters: () => [], propDecorators: { data: [{
|
263
|
+
type: Input
|
264
|
+
}], columns: [{
|
265
|
+
type: Input
|
266
|
+
}], totalRecords: [{
|
267
|
+
type: Input
|
268
|
+
}], rowsPerPage: [{
|
269
|
+
type: Input
|
270
|
+
}], hasSearchFilter: [{
|
271
|
+
type: Input
|
272
|
+
}], hasColumnFilter: [{
|
273
|
+
type: Input
|
274
|
+
}], isPaginated: [{
|
275
|
+
type: Input
|
276
|
+
}], actions: [{
|
277
|
+
type: Input
|
278
|
+
}], isSortable: [{
|
279
|
+
type: Input
|
280
|
+
}], filter: [{
|
281
|
+
type: Output
|
282
|
+
}], search: [{
|
283
|
+
type: Output
|
284
|
+
}], dt: [{
|
285
|
+
type: ViewChild,
|
286
|
+
args: ['dt', { static: true }]
|
287
|
+
}] } });
|
288
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"advanced-table.component.js","sourceRoot":"","sources":["../../../../../projects/ng-prime-tools/src/lib/advanced-table/advanced-table.component.ts","../../../../../projects/ng-prime-tools/src/lib/advanced-table/advanced-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, Output, ViewChild } from '@angular/core';\nimport { EventEmitter } from '@angular/core';\nimport { Table, TableModule } from 'primeng/table';\nimport { TableColumn } from '../models/table-column.model';\nimport { TableTypeEnum } from '../enums/table-type-enum';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport { ButtonModule } from 'primeng/button';\nimport { CalendarModule } from 'primeng/calendar';\nimport { InputTextModule } from 'primeng/inputtext';\nimport { MultiSelectModule } from 'primeng/multiselect';\nimport { CustomCurrencyPipe } from '../pipes/custom-currency';\nimport { IconFieldModule } from 'primeng/iconfield';\nimport { InputIconModule } from 'primeng/inputicon';\nimport { TagModule } from 'primeng/tag';\n\n@Component({\n  selector: 'advanced-table',\n  standalone: true,\n  imports: [\n    CommonModule,\n    TableModule,\n    InputTextModule,\n    ButtonModule,\n    CalendarModule,\n    FormsModule,\n    MultiSelectModule,\n    CustomCurrencyPipe,\n    IconFieldModule,\n    InputIconModule,\n    TagModule,\n  ],\n  templateUrl: './advanced-table.component.html',\n  styleUrl: './advanced-table.component.css',\n})\nexport class AdvancedTableComponent implements OnInit {\n  // Inputs\n  @Input() data: any[] = [];\n  @Input() columns: TableColumn[] = [];\n  @Input() totalRecords: number = 0;\n  @Input() rowsPerPage: number[] = [];\n  @Input() hasSearchFilter: boolean = false;\n  @Input() hasColumnFilter: boolean = false;\n  @Input() isPaginated: boolean = false;\n  @Input() actions: any[] = [];\n  @Input() isSortable: boolean = false;\n\n  // Outputs: Events emitted to the parent component\n  @Output() filter = new EventEmitter();\n  @Output() search = new EventEmitter<any>();\n\n  @ViewChild('dt', { static: true }) dt!: Table;\n\n  searchValue: string = '';\n\n  private validCurrencyCodes = ['USD', 'EUR', 'MAD'];\n\n  // Component state properties\n  isDelete: boolean = false;\n  isEdit: boolean = false;\n  rows: number = 0;\n\n  // Data management properties\n  dataMap = new Map();\n  map = new Map();\n  optionEntries = new Map<string, any[]>();\n  optionValues: any[] = [];\n  globalFilterFields: string[] = [];\n\n  // CRUD operation handlers\n  Delete: (value: any) => void = () => {};\n  initEditableRow: (data: any) => void = () => {};\n  saveEditableRow: (data: any) => void = () => {};\n  cancelEditableRow: (item: any) => void = () => {};\n\n  constructor() {}\n\n  ngOnInit(): void {\n    // Transform the date fields based on column metadata\n    this.data = this.formatingDateFields();\n    this.globalFilterFields = this.columns\n      .map((col) => col.code)\n      .filter((code): code is string => code !== undefined);\n    this.initializePagination();\n    this.initializeActions();\n\n    // Set default value for isSortable\n    this.columns.forEach((col) => {\n      if (col.type === TableTypeEnum.ACTION) {\n        col.isEditable = false;\n        col.isFilter = false;\n        col.isSortable = false;\n      }\n\n      if (col.isSortable === undefined) {\n        col.isSortable = true;\n      }\n\n      if (col.isEditable === undefined) {\n        col.isEditable = true;\n      }\n\n      if (col.isFilter !== false && col.code !== undefined) {\n        this.globalFilterFields.push(col.code);\n      }\n    });\n  }\n\n  // Initialization Methods\n  private formatingDateFields(): any {\n    return this.data.map((item) => {\n      const transformedItem = { ...item };\n      this.columns.forEach((column) => {\n        if (\n          column.type === TableTypeEnum.DATE &&\n          column.code !== undefined &&\n          transformedItem[column.code] !== undefined\n        ) {\n          const dateValue = this.parseDate(transformedItem[column.code]);\n          transformedItem[column.code] = dateValue ? dateValue : null;\n        }\n      });\n      return transformedItem;\n    });\n  }\n\n  clear(table: Table) {\n    table.clear();\n    this.searchValue = '';\n  }\n\n  private parseDate(dateString: string): Date | null {\n    const parts = dateString.split('/');\n    if (parts.length === 3) {\n      // Assuming date format is DD/MM/YYYY\n      const day = parseInt(parts[0], 10);\n      const month = parseInt(parts[1], 10) - 1;\n      const year = parseInt(parts[2], 10);\n      const date = new Date(year, month, day);\n      return isNaN(date.getTime()) ? null : date;\n    }\n    return null;\n  }\n\n  private initializePagination(): void {\n    if (this.isPaginated) {\n      this.rowsPerPage = this.rowsPerPage || [20, 30, 40];\n      this.rows = this.rowsPerPage[0];\n    }\n  }\n\n  private initializeActions(): void {\n    if (this.actions) {\n      this.actions.forEach((action) => {\n        switch (action.code) {\n          case 'delete':\n            this.isDelete = true;\n            this.Delete = (value: any) => action.action(value);\n            break;\n          case 'edit':\n            this.initializeEditActions(action);\n            break;\n          default:\n            this.isDelete = false;\n            this.isEdit = false;\n        }\n      });\n    }\n  }\n\n  private initializeEditActions(action: any): void {\n    this.isEdit = true;\n    this.initEditableRow = (data: any) => action.action.init(data);\n    this.saveEditableRow = (data: any) => {\n      const record = this.map.get(data.id);\n      action.action.save(data, record);\n      this.dataMap.clear();\n    };\n    this.cancelEditableRow = (item: any) => console.log(item);\n  }\n\n  onChange(event: Event, id: number, key: any) {\n    const target = event.target as HTMLInputElement;\n    this.changeHandler(id, key, target.value);\n  }\n\n  changeHandler(id: number, key: any, value: any) {\n    let column = this.columns.find((item) => item.code === key);\n    if (!this.map.get(id)) {\n      if (column?.type === TableTypeEnum.DATE) {\n        let date = this.parseDate(value);\n        this.dataMap.set(key, date);\n      } else {\n        this.dataMap.set(key, value);\n      }\n      this.map.set(id, new Map(this.dataMap));\n    } else {\n      let mapItem = this.map.get(id);\n      if (column?.type === TableTypeEnum.DATE) {\n        let date = this.parseDate(value);\n        mapItem.set(key, date);\n      } else {\n        mapItem.set(key, value);\n      }\n    }\n  }\n\n  getColumnFilterType(column: TableColumn): string {\n    switch (column.type) {\n      case TableTypeEnum.STRING:\n        return 'text';\n      case TableTypeEnum.AMOUNT:\n        return 'numeric';\n      case TableTypeEnum.NUMBER:\n        return 'numeric';\n      case TableTypeEnum.DATE:\n        return 'date';\n      case TableTypeEnum.MULTISELECT:\n        return 'multiSelect';\n      case TableTypeEnum.BOOLEAN:\n        return 'boolean';\n      default:\n        return 'text';\n    }\n  }\n\n  // State Check Methods\n  isEditable(key: string): boolean {\n    let column = this.columns.find((item) => item.code === key);\n    return column?.isEditable !== false;\n  }\n\n  isMultiSelect(key: any): boolean {\n    let column = this.columns.find((item) => item.code === key);\n    if (\n      column?.type === TableTypeEnum.MULTISELECT &&\n      column.options &&\n      column.code !== undefined\n    ) {\n      this.optionEntries = new Map([\n        [column.code, Object.values(column.options)],\n      ]);\n      this.optionValues = this.optionEntries.get(key) || [];\n      return true;\n    }\n    return false;\n  }\n\n  isDatePicker(key: any): boolean {\n    return (\n      this.columns.find((item) => item.code === key)?.type ===\n      TableTypeEnum.DATE\n    );\n  }\n\n  // Utility Methods\n  dateConverter(value: any): string {\n    return new Date(value).toLocaleDateString('en-US');\n  }\n\n  getCurrencySymbol(column: TableColumn): string | undefined {\n    return column.type === TableTypeEnum.AMOUNT &&\n      column.currency &&\n      this.isValidCurrencyCode(column.currency)\n      ? column.currency\n      : undefined;\n  }\n\n  private isValidCurrencyCode(currencyCode: string): boolean {\n    return this.validCurrencyCodes.includes(currencyCode);\n  }\n\n  customDateFilter(value: any, filter: any): boolean {\n    if (!filter || !value) {\n      return true;\n    }\n\n    const filterDate = new Date(filter);\n    const valueDate = new Date(value);\n\n    return valueDate.toDateString() === filterDate.toDateString();\n  }\n\n  filterGlobal(event: Event): void {\n    const target = event.target as HTMLInputElement;\n    this.dt.filterGlobal(target.value, 'contains');\n  }\n}\n","<div class=\"table-container\">\n  <div>\n    <p-table\n      #dt\n      [value]=\"data\"\n      dataKey=\"id\"\n      [rows]=\"rows\"\n      [paginator]=\"isPaginated\"\n      [globalFilterFields]=\"globalFilterFields\"\n      styleClass=\"p-datatable-gridlines\"\n      [rowsPerPageOptions]=\"rowsPerPage\"\n      styleClass=\"p-datatable-striped\"\n      editMode=\"row\"\n      [globalFilterFields]=\"globalFilterFields\"\n    >\n      <ng-template pTemplate=\"caption\">\n        <div class=\"flex\">\n          <div>\n            <h3>Total: {{ totalRecords }}</h3>\n          </div>\n\n          <div>\n            <p-button\n              label=\"Clear\"\n              [outlined]=\"true\"\n              icon=\"pi pi-filter-slash\"\n              (click)=\"clear(dt)\"\n              class=\"bt-filter-btn\"\n            />\n          </div>\n          <div class=\"ml-auto\" *ngIf=\"hasSearchFilter\">\n            <!-- Add this wrapper div with ml-auto class -->\n            <p-iconField iconPosition=\"left\" class=\"ml-auto\">\n              <p-inputIcon>\n                <i class=\"pi pi-search\"></i>\n              </p-inputIcon>\n              <input\n                pInputText\n                type=\"text\"\n                [(ngModel)]=\"searchValue\"\n                (input)=\"filterGlobal($event)\"\n                placeholder=\"Search keyword\"\n              />\n            </p-iconField>\n          </div>\n        </div>\n      </ng-template>\n\n      <ng-template pTemplate=\"header\">\n        <tr>\n          <th *ngFor=\"let col of columns\">\n            <ng-container\n              *ngIf=\"isSortable && col.isSortable !== false; else noSortHeader\"\n            >\n              <th pSortableColumn=\"{{ col.code }}\" style=\"width: 20%\">\n                <div class=\"header-container\">\n                  <span>{{ col.title }}</span>\n                  <p-sortIcon field=\"{{ col.code }}\" />\n                  <ng-container *ngIf=\"col.isFilter !== false\">\n                    <p-columnFilter\n                      *ngIf=\"col.type === 'AMOUNT'\"\n                      display=\"menu\"\n                      [field]=\"col.code\"\n                      [type]=\"getColumnFilterType(col)\"\n                      [currency]=\"getCurrencySymbol(col)\"\n                    ></p-columnFilter>\n\n                    <p-columnFilter\n                      *ngIf=\"col.type !== 'AMOUNT'\"\n                      display=\"menu\"\n                      [field]=\"col.code\"\n                      display=\"menu\"\n                      [type]=\"getColumnFilterType(col)\"\n                      [type]=\"getColumnFilterType(col)\"\n                    >\n                      <ng-template\n                        pTemplate=\"filter\"\n                        let-value\n                        let-filterCallback=\"filterCallback\"\n                        *ngIf=\"getColumnFilterType(col) === 'date'\"\n                      >\n                        <p-calendar\n                          [ngModel]=\"value\"\n                          (ngModelChange)=\"filterCallback($event)\"\n                          [dateFormat]=\"'dd/mm/yy'\"\n                        ></p-calendar>\n                      </ng-template>\n\n                      <ng-template\n                        pTemplate=\"filter\"\n                        let-value\n                        let-filterCallback=\"filterCallback\"\n                        *ngIf=\"getColumnFilterType(col) === 'multiSelect'\"\n                      >\n                        <p-multiSelect\n                          [options]=\"col.filterOptions\"\n                          [ngModel]=\"value\"\n                          (ngModelChange)=\"filterCallback($event)\"\n                          [display]=\"'chip'\"\n                          placeholder=\"Select\"\n                          class=\"custom-multiselect\"\n                        ></p-multiSelect>\n                      </ng-template>\n                    </p-columnFilter>\n                  </ng-container>\n                </div>\n              </th>\n            </ng-container>\n            <ng-template #noSortHeader>\n              <th>\n                <div class=\"header-container\">\n                  <span>{{ col.title }}</span>\n                  <ng-container *ngIf=\"col.isFilter !== false\">\n                    <p-columnFilter\n                      *ngIf=\"col.type === 'AMOUNT'\"\n                      display=\"menu\"\n                      [field]=\"col.code\"\n                      [type]=\"getColumnFilterType(col)\"\n                      [currency]=\"getCurrencySymbol(col)\"\n                    ></p-columnFilter>\n\n                    <p-columnFilter\n                      *ngIf=\"col.type !== 'AMOUNT'\"\n                      display=\"menu\"\n                      [field]=\"col.code\"\n                      [type]=\"getColumnFilterType(col)\"\n                    >\n                      <ng-template\n                        pTemplate=\"filter\"\n                        let-value\n                        let-filterCallback=\"filterCallback\"\n                        *ngIf=\"getColumnFilterType(col) === 'date'\"\n                      >\n                        <p-calendar\n                          [ngModel]=\"value\"\n                          (ngModelChange)=\"filterCallback($event)\"\n                          [dateFormat]=\"'dd/mm/yy'\"\n                        ></p-calendar>\n                      </ng-template>\n\n                      <ng-template\n                        pTemplate=\"filter\"\n                        let-value\n                        let-filterCallback=\"filterCallback\"\n                        *ngIf=\"getColumnFilterType(col) === 'multiSelect'\"\n                      >\n                        <p-multiSelect\n                          [options]=\"col.filterOptions\"\n                          [ngModel]=\"value\"\n                          (ngModelChange)=\"filterCallback($event)\"\n                          [display]=\"'chip'\"\n                          placeholder=\"Select\"\n                          class=\"custom-multiselect\"\n                        ></p-multiSelect>\n                      </ng-template>\n                    </p-columnFilter>\n                  </ng-container>\n                </div>\n              </th>\n            </ng-template>\n          </th>\n        </tr>\n      </ng-template>\n\n      <ng-template\n        pTemplate=\"body\"\n        let-data\n        let-editing=\"editing\"\n        let-ri=\"rowIndex\"\n      >\n        <!-- Render a table row and make it editable if `isEdit` is true -->\n        <tr [pEditableRow]=\"isEdit ? data : null\">\n          <!-- Loop through each column and render corresponding table cells -->\n          <ng-container *ngFor=\"let col of columns\">\n            <ng-container *ngIf=\"col.code !== undefined\">\n              <!-- Check if the data for the column exists -->\n              <ng-container *ngIf=\"data[col.code] !== undefined\">\n                <!-- Render an editable cell if the column is editable -->\n                <td *ngIf=\"isEditable(col.code); else normalTD\">\n                  <!-- Multi-select input for columns that are multi-selectable -->\n                  <ng-container\n                    *ngIf=\"isMultiSelect(col.code); else datePicker\"\n                  >\n                    <p-cellEditor>\n                      <ng-template pTemplate=\"input\">\n                        <p-multiSelect\n                          appendTo=\"body\"\n                          [ngModel]=\"data[col.code]\"\n                          [style]=\"{ width: '100%' }\"\n                          (ngModelChange)=\"\n                            changeHandler(data.id, col.code, $event)\n                          \"\n                          [options]=\"optionValues\"\n                        ></p-multiSelect>\n                      </ng-template>\n                      <ng-template pTemplate=\"output\">\n                        <div class=\"multi-select-container\">\n                          <ng-container *ngFor=\"let rec of data[col.code]\">\n                            <p-tag [value]=\"rec\"></p-tag>\n                          </ng-container>\n                        </div>\n                      </ng-template>\n                    </p-cellEditor>\n                  </ng-container>\n\n                  <!-- Date picker input for columns that require date selection -->\n                  <ng-template #datePicker>\n                    <ng-container\n                      *ngIf=\"isDatePicker(col.code); else normalInput\"\n                    >\n                      <p-cellEditor>\n                        <ng-template pTemplate=\"input\">\n                          <p-calendar\n                            [inputId]=\"data[col.code]\"\n                            [ngModel]=\"data[col.code]\"\n                            (ngModelChange)=\"\n                              changeHandler(data.id, col.code, $event)\n                            \"\n                            [dateFormat]=\"'dd/mm/yy'\"\n                          ></p-calendar>\n                        </ng-template>\n                        <ng-template pTemplate=\"output\">\n                          {{ data[col.code] | date : \"dd/MM/yyyy\" }}\n                        </ng-template>\n                      </p-cellEditor>\n                    </ng-container>\n                  </ng-template>\n\n                  <!-- Normal text input for other columns -->\n                  <ng-template #normalInput>\n                    <p-cellEditor>\n                      <ng-template pTemplate=\"input\">\n                        <input\n                          pInputText\n                          type=\"text\"\n                          [ngModel]=\"data[col.code]\"\n                          (change)=\"onChange($event, data.id, col.code)\"\n                        />\n                      </ng-template>\n                      <ng-template pTemplate=\"output\">\n                        <!-- Use currency pipe to format the output for AMOUNT type -->\n                        <ng-container\n                          *ngIf=\"col.type === 'AMOUNT'; else normalOutput\"\n                        >\n                          {{\n                            data[col.code]\n                              | customCurrency\n                                : getCurrencySymbol(col)\n                                : col.decimalPlaces\n                          }}\n                        </ng-container>\n                        <ng-template #normalOutput>\n                          {{ data[col.code] }}\n                        </ng-template>\n                      </ng-template>\n                    </p-cellEditor>\n                  </ng-template>\n                </td>\n\n                <!-- Render a normal table cell if the column is not editable -->\n                <ng-template #normalTD>\n                  <td>\n                    <!-- Use customCurrency pipe to format the output for AMOUNT type with optional decimal places -->\n                    <ng-container\n                      *ngIf=\"col.type === 'AMOUNT'; else normalText\"\n                    >\n                      >\n                      {{\n                        data[col.code]\n                          | customCurrency\n                            : getCurrencySymbol(col)\n                            : col.decimalPlaces\n                      }}\n                    </ng-container>\n                    <ng-template #normalText>\n                      {{ data[col.code] }}\n                    </ng-template>\n                  </td>\n                </ng-template>\n              </ng-container>\n            </ng-container>\n          </ng-container>\n\n          <!-- Render action buttons if there are any actions defined -->\n          <td *ngIf=\"actions?.length\">\n            <div class=\"action-buttons-container\">\n              <!-- Delete button if deletion is allowed -->\n              <div *ngIf=\"isDelete\">\n                <button\n                  pButton\n                  pRipple\n                  type=\"button\"\n                  icon=\"pi pi-trash\"\n                  (click)=\"Delete(data.id)\"\n                  class=\"p-button-rounded p-button-text\"\n                ></button>\n              </div>\n              <!-- Edit, save, and cancel buttons for row editing -->\n              <div>\n                <button\n                  pInitEditableRow\n                  *ngIf=\"!editing\"\n                  pButton\n                  pRipple\n                  type=\"button\"\n                  icon=\"pi pi-pencil\"\n                  (click)=\"initEditableRow(data)\"\n                  class=\"p-button-rounded p-button-text\"\n                ></button>\n                <button\n                  *ngIf=\"editing\"\n                  pSaveEditableRow\n                  pButton\n                  pRipple\n                  type=\"button\"\n                  icon=\"pi pi-check\"\n                  (click)=\"saveEditableRow(data)\"\n                  class=\"p-button-rounded p-button-text\"\n                ></button>\n                <button\n                  *ngIf=\"editing\"\n                  pCancelEditableRow\n                  pButton\n                  pRipple\n                  type=\"button\"\n                  icon=\"pi pi-times\"\n                  (click)=\"cancelEditableRow(data)\"\n                  class=\"p-button-rounded p-button-text\"\n                ></button>\n              </div>\n            </div>\n          </td>\n        </tr>\n      </ng-template>\n    </p-table>\n  </div>\n</div>\n"]}
|
@@ -0,0 +1,12 @@
|
|
1
|
+
export var TableTypeEnum;
|
2
|
+
(function (TableTypeEnum) {
|
3
|
+
TableTypeEnum["DATE"] = "DATE";
|
4
|
+
TableTypeEnum["STRING"] = "STRING";
|
5
|
+
TableTypeEnum["AMOUNT"] = "AMOUNT";
|
6
|
+
TableTypeEnum["NUMBER"] = "NUMBER";
|
7
|
+
TableTypeEnum["MULTISELECT"] = "MULTISELECT";
|
8
|
+
TableTypeEnum["CURRENCY"] = "CURRENCY";
|
9
|
+
TableTypeEnum["BOOLEAN"] = "BOOLEAN";
|
10
|
+
TableTypeEnum["ACTION"] = "ACTION";
|
11
|
+
})(TableTypeEnum || (TableTypeEnum = {}));
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtdHlwZS1lbnVtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctcHJpbWUtdG9vbHMvc3JjL2xpYi9lbnVtcy90YWJsZS10eXBlLWVudW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksYUFTWDtBQVRELFdBQVksYUFBYTtJQUN2Qiw4QkFBYSxDQUFBO0lBQ2Isa0NBQWlCLENBQUE7SUFDakIsa0NBQWlCLENBQUE7SUFDakIsa0NBQWlCLENBQUE7SUFDakIsNENBQTJCLENBQUE7SUFDM0Isc0NBQXFCLENBQUE7SUFDckIsb0NBQW1CLENBQUE7SUFDbkIsa0NBQWlCLENBQUE7QUFDbkIsQ0FBQyxFQVRXLGFBQWEsS0FBYixhQUFhLFFBU3hCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gVGFibGVUeXBlRW51bSB7XG4gIERBVEUgPSAnREFURScsXG4gIFNUUklORyA9ICdTVFJJTkcnLFxuICBBTU9VTlQgPSAnQU1PVU5UJyxcbiAgTlVNQkVSID0gJ05VTUJFUicsXG4gIE1VTFRJU0VMRUNUID0gJ01VTFRJU0VMRUNUJyxcbiAgQ1VSUkVOQ1kgPSAnQ1VSUkVOQ1knLFxuICBCT09MRUFOID0gJ0JPT0xFQU4nLFxuICBBQ1RJT04gPSAnQUNUSU9OJyxcbn1cbiJdfQ==
|
@@ -0,0 +1,2 @@
|
|
1
|
+
export * from './table-column.model';
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1wcmltZS10b29scy9zcmMvbGliL21vZGVscy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHNCQUFzQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi90YWJsZS1jb2x1bW4ubW9kZWwnO1xuIl19
|
@@ -0,0 +1,2 @@
|
|
1
|
+
export {};
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY29sdW1uLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctcHJpbWUtdG9vbHMvc3JjL2xpYi9tb2RlbHMvdGFibGUtY29sdW1uLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUYWJsZVR5cGVFbnVtIH0gZnJvbSAnLi4vZW51bXMvdGFibGUtdHlwZS1lbnVtJztcblxuZXhwb3J0IGludGVyZmFjZSBUYWJsZUNvbHVtbiB7XG4gIHRpdGxlOiBzdHJpbmc7XG4gIGNvZGU/OiBzdHJpbmc7XG4gIHR5cGU/OiBUYWJsZVR5cGVFbnVtO1xuICBvcHRpb25zPzogYW55W107XG4gIGlzRWRpdGFibGU/OiBib29sZWFuO1xuICBpc0ZpbHRlcj86IGJvb2xlYW47XG4gIGRhdGVGb3JtYXQ/OiBzdHJpbmc7XG4gIGN1cnJlbmN5Pzogc3RyaW5nO1xuICBmaWx0ZXJPcHRpb25zPzogYW55W107XG4gIGRlY2ltYWxQbGFjZXM/OiBudW1iZXI7XG4gIGlzU29ydGFibGU/OiBib29sZWFuO1xufVxuIl19
|
@@ -0,0 +1,11 @@
|
|
1
|
+
import { Component } from '@angular/core';
|
2
|
+
import * as i0 from "@angular/core";
|
3
|
+
export class AdvancedPrimeToolsComponent {
|
4
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AdvancedPrimeToolsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
5
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.3", type: AdvancedPrimeToolsComponent, isStandalone: true, selector: "lib-ng-prime-tools", ngImport: i0, template: ` <p>ng-prime-tools works!</p> `, isInline: true, styles: [""] }); }
|
6
|
+
}
|
7
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AdvancedPrimeToolsComponent, decorators: [{
|
8
|
+
type: Component,
|
9
|
+
args: [{ selector: 'lib-ng-prime-tools', standalone: true, imports: [], template: ` <p>ng-prime-tools works!</p> ` }]
|
10
|
+
}] });
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmctcHJpbWUtdG9vbHMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctcHJpbWUtdG9vbHMvc3JjL2xpYi9uZy1wcmltZS10b29scy5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFTMUMsTUFBTSxPQUFPLDJCQUEyQjs4R0FBM0IsMkJBQTJCO2tHQUEzQiwyQkFBMkIsOEVBSDVCLGdDQUFnQzs7MkZBRy9CLDJCQUEyQjtrQkFQdkMsU0FBUzsrQkFDRSxvQkFBb0IsY0FDbEIsSUFBSSxXQUNQLEVBQUUsWUFDRCxnQ0FBZ0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbGliLW5nLXByaW1lLXRvb2xzJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW10sXG4gIHRlbXBsYXRlOiBgIDxwPm5nLXByaW1lLXRvb2xzIHdvcmtzITwvcD4gYCxcbiAgc3R5bGVzOiBgYCxcbn0pXG5leHBvcnQgY2xhc3MgQWR2YW5jZWRQcmltZVRvb2xzQ29tcG9uZW50IHt9XG4iXX0=
|
@@ -0,0 +1,14 @@
|
|
1
|
+
import { Injectable } from '@angular/core';
|
2
|
+
import * as i0 from "@angular/core";
|
3
|
+
export class AdvancedPrimeToolsService {
|
4
|
+
constructor() { }
|
5
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AdvancedPrimeToolsService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
6
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AdvancedPrimeToolsService, providedIn: 'root' }); }
|
7
|
+
}
|
8
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: AdvancedPrimeToolsService, decorators: [{
|
9
|
+
type: Injectable,
|
10
|
+
args: [{
|
11
|
+
providedIn: 'root'
|
12
|
+
}]
|
13
|
+
}], ctorParameters: () => [] });
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmctcHJpbWUtdG9vbHMuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvbmctcHJpbWUtdG9vbHMuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUszQyxNQUFNLE9BQU8seUJBQXlCO0lBRXBDLGdCQUFnQixDQUFDOzhHQUZOLHlCQUF5QjtrSEFBekIseUJBQXlCLGNBRnhCLE1BQU07OzJGQUVQLHlCQUF5QjtrQkFIckMsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGNsYXNzIEFkdmFuY2VkUHJpbWVUb29sc1NlcnZpY2Uge1xuXG4gIGNvbnN0cnVjdG9yKCkgeyB9XG59XG4iXX0=
|
@@ -0,0 +1,38 @@
|
|
1
|
+
import { Pipe } from '@angular/core';
|
2
|
+
import * as i0 from "@angular/core";
|
3
|
+
export class CustomCurrencyPipe {
|
4
|
+
transform(value, currency = 'MAD', decimalPlaces) {
|
5
|
+
let formattedValue;
|
6
|
+
if (decimalPlaces !== undefined) {
|
7
|
+
formattedValue = new Intl.NumberFormat('en-US', {
|
8
|
+
minimumFractionDigits: decimalPlaces,
|
9
|
+
maximumFractionDigits: decimalPlaces,
|
10
|
+
}).format(value);
|
11
|
+
}
|
12
|
+
else {
|
13
|
+
formattedValue = new Intl.NumberFormat('en-US').format(value);
|
14
|
+
}
|
15
|
+
let formattedCurrency;
|
16
|
+
switch (currency) {
|
17
|
+
case 'MAD':
|
18
|
+
formattedCurrency = `${formattedValue} DH`;
|
19
|
+
break;
|
20
|
+
case 'USD':
|
21
|
+
formattedCurrency = `$${formattedValue}`;
|
22
|
+
break;
|
23
|
+
default:
|
24
|
+
formattedCurrency = `${formattedValue} ${currency}`;
|
25
|
+
}
|
26
|
+
return formattedCurrency;
|
27
|
+
}
|
28
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: CustomCurrencyPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
29
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.0.3", ngImport: i0, type: CustomCurrencyPipe, isStandalone: true, name: "customCurrency" }); }
|
30
|
+
}
|
31
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: CustomCurrencyPipe, decorators: [{
|
32
|
+
type: Pipe,
|
33
|
+
args: [{
|
34
|
+
name: 'customCurrency',
|
35
|
+
standalone: true,
|
36
|
+
}]
|
37
|
+
}] });
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLWN1cnJlbmN5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctcHJpbWUtdG9vbHMvc3JjL2xpYi9waXBlcy9jdXN0b20tY3VycmVuY3kudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7O0FBTXBELE1BQU0sT0FBTyxrQkFBa0I7SUFDN0IsU0FBUyxDQUNQLEtBQWEsRUFDYixXQUFtQixLQUFLLEVBQ3hCLGFBQXNCO1FBRXRCLElBQUksY0FBc0IsQ0FBQztRQUUzQixJQUFJLGFBQWEsS0FBSyxTQUFTLEVBQUUsQ0FBQztZQUNoQyxjQUFjLEdBQUcsSUFBSSxJQUFJLENBQUMsWUFBWSxDQUFDLE9BQU8sRUFBRTtnQkFDOUMscUJBQXFCLEVBQUUsYUFBYTtnQkFDcEMscUJBQXFCLEVBQUUsYUFBYTthQUNyQyxDQUFDLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ25CLENBQUM7YUFBTSxDQUFDO1lBQ04sY0FBYyxHQUFHLElBQUksSUFBSSxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDaEUsQ0FBQztRQUVELElBQUksaUJBQXlCLENBQUM7UUFFOUIsUUFBUSxRQUFRLEVBQUUsQ0FBQztZQUNqQixLQUFLLEtBQUs7Z0JBQ1IsaUJBQWlCLEdBQUcsR0FBRyxjQUFjLEtBQUssQ0FBQztnQkFDM0MsTUFBTTtZQUNSLEtBQUssS0FBSztnQkFDUixpQkFBaUIsR0FBRyxJQUFJLGNBQWMsRUFBRSxDQUFDO2dCQUN6QyxNQUFNO1lBQ1I7Z0JBQ0UsaUJBQWlCLEdBQUcsR0FBRyxjQUFjLElBQUksUUFBUSxFQUFFLENBQUM7UUFDeEQsQ0FBQztRQUVELE9BQU8saUJBQWlCLENBQUM7SUFDM0IsQ0FBQzs4R0EvQlUsa0JBQWtCOzRHQUFsQixrQkFBa0I7OzJGQUFsQixrQkFBa0I7a0JBSjlCLElBQUk7bUJBQUM7b0JBQ0osSUFBSSxFQUFFLGdCQUFnQjtvQkFDdEIsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AUGlwZSh7XG4gIG5hbWU6ICdjdXN0b21DdXJyZW5jeScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIEN1c3RvbUN1cnJlbmN5UGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICB0cmFuc2Zvcm0oXG4gICAgdmFsdWU6IG51bWJlcixcbiAgICBjdXJyZW5jeTogc3RyaW5nID0gJ01BRCcsXG4gICAgZGVjaW1hbFBsYWNlcz86IG51bWJlclxuICApOiBzdHJpbmcge1xuICAgIGxldCBmb3JtYXR0ZWRWYWx1ZTogc3RyaW5nO1xuXG4gICAgaWYgKGRlY2ltYWxQbGFjZXMgIT09IHVuZGVmaW5lZCkge1xuICAgICAgZm9ybWF0dGVkVmFsdWUgPSBuZXcgSW50bC5OdW1iZXJGb3JtYXQoJ2VuLVVTJywge1xuICAgICAgICBtaW5pbXVtRnJhY3Rpb25EaWdpdHM6IGRlY2ltYWxQbGFjZXMsXG4gICAgICAgIG1heGltdW1GcmFjdGlvbkRpZ2l0czogZGVjaW1hbFBsYWNlcyxcbiAgICAgIH0pLmZvcm1hdCh2YWx1ZSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIGZvcm1hdHRlZFZhbHVlID0gbmV3IEludGwuTnVtYmVyRm9ybWF0KCdlbi1VUycpLmZvcm1hdCh2YWx1ZSk7XG4gICAgfVxuXG4gICAgbGV0IGZvcm1hdHRlZEN1cnJlbmN5OiBzdHJpbmc7XG5cbiAgICBzd2l0Y2ggKGN1cnJlbmN5KSB7XG4gICAgICBjYXNlICdNQUQnOlxuICAgICAgICBmb3JtYXR0ZWRDdXJyZW5jeSA9IGAke2Zvcm1hdHRlZFZhbHVlfSBESGA7XG4gICAgICAgIGJyZWFrO1xuICAgICAgY2FzZSAnVVNEJzpcbiAgICAgICAgZm9ybWF0dGVkQ3VycmVuY3kgPSBgJCR7Zm9ybWF0dGVkVmFsdWV9YDtcbiAgICAgICAgYnJlYWs7XG4gICAgICBkZWZhdWx0OlxuICAgICAgICBmb3JtYXR0ZWRDdXJyZW5jeSA9IGAke2Zvcm1hdHRlZFZhbHVlfSAke2N1cnJlbmN5fWA7XG4gICAgfVxuXG4gICAgcmV0dXJuIGZvcm1hdHRlZEN1cnJlbmN5O1xuICB9XG59XG4iXX0=
|
@@ -0,0 +1,5 @@
|
|
1
|
+
/**
|
2
|
+
* Generated bundle index. Do not edit.
|
3
|
+
*/
|
4
|
+
export * from './public-api';
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmctcHJpbWUtdG9vbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy9uZy1wcmltZS10b29scy9zcmMvbmctcHJpbWUtdG9vbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
|
@@ -0,0 +1,9 @@
|
|
1
|
+
/*
|
2
|
+
* Public API Surface of ng-prime-tools
|
3
|
+
*/
|
4
|
+
export * from './lib/ng-prime-tools.service';
|
5
|
+
export * from './lib/ng-prime-tools.component';
|
6
|
+
export * from './lib/advanced-table/advanced-table.component';
|
7
|
+
export * from './lib/enums/table-type-enum';
|
8
|
+
export * from './lib/models/index';
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLG9CQUFvQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBuZy1wcmltZS10b29sc1xuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL25nLXByaW1lLXRvb2xzLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbmctcHJpbWUtdG9vbHMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FkdmFuY2VkLXRhYmxlL2FkdmFuY2VkLXRhYmxlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbnVtcy90YWJsZS10eXBlLWVudW0nO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzL2luZGV4JztcbiJdfQ==
|