nira-falcon 0.0.1 → 0.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/core-auto-complete/core-auto-complete.component.mjs +82 -0
- package/esm2022/lib/core-btn/core-btn.component.mjs +26 -11
- package/esm2022/lib/core-card/core-card.component.mjs +16 -0
- package/esm2022/lib/core-checkbox/core-checkbox.component.mjs +33 -0
- package/esm2022/lib/core-confirm-dialog/core-confirm-dialog.component.mjs +31 -0
- package/esm2022/lib/core-date-picker/core-date-picker.component.mjs +52 -0
- package/esm2022/lib/core-input/core-input.component.mjs +48 -0
- package/esm2022/lib/core-mulite-select/core-mulite-select-row/core-mulite-select-row.component.mjs +29 -0
- package/esm2022/lib/core-mulite-select/core-mulite-select.component.mjs +130 -0
- package/esm2022/lib/core-number/core-number.component.mjs +64 -0
- package/esm2022/lib/core-page-title/core-page-title.component.mjs +19 -0
- package/esm2022/lib/core-radio-buttons/core-radio-buttons.component.mjs +75 -0
- package/esm2022/lib/core-search-box/core-search-box.component.mjs +25 -0
- package/esm2022/lib/core-select/core-select.component.mjs +109 -0
- package/esm2022/lib/core-spinner/core-spinner.component.mjs +3 -3
- package/esm2022/lib/core-switch/core-switch.component.mjs +33 -0
- package/esm2022/lib/core-table/core-column-date-picker/core-column-date-picker.component.mjs +62 -0
- package/esm2022/lib/core-table/core-column-input/core-column-input.component.mjs +29 -0
- package/esm2022/lib/core-table/core-column-selector/core-column-selector.component.mjs +91 -0
- package/esm2022/lib/core-table/core-row-pelak/core-row-pelak.component.mjs +21 -0
- package/esm2022/lib/core-table/core-table/core-table.component.mjs +176 -0
- package/esm2022/lib/core-table/core-table-action-buttons-column/core-table-action-buttons-column.component.mjs +34 -0
- package/esm2022/lib/core-table/core-table-action-column/core-table-action-column.component.mjs +27 -0
- package/esm2022/lib/core-table/core-table-card-manager/core-table-card-manager.component.mjs +80 -0
- package/esm2022/lib/core-table/core-table-column-manager/core-table-column-manager.component.mjs +79 -0
- package/esm2022/lib/core-table/core-table-detail-viewer-for-report/core-table-detail-viewer-for-report.component.mjs +24 -0
- package/esm2022/lib/core-table/core-table-filter-dialog/core-table-filter-dialog/core-table-filter-dialog.component.mjs +82 -0
- package/esm2022/lib/core-table/core-table-no-content/core-table-no-content.component.mjs +23 -0
- package/esm2022/lib/core-table/core-table-no-content/core-table-no-content.label.mjs +9 -0
- package/esm2022/lib/core-table/core-table-row-selector-column/core-table-row-selector-column.component.mjs +42 -0
- package/esm2022/lib/core-table/core-table-shamsi-date/core-table-shamsi-date.component.mjs +26 -0
- package/esm2022/lib/core-table/core-table-status-active-column/core-table-status-active-column.component.mjs +20 -0
- package/esm2022/lib/core-table/core-table-status-column/core-table-status-column.component.mjs +18 -0
- package/esm2022/lib/core-textarea/core-textarea.component.mjs +47 -0
- package/esm2022/lib/core-time-picker/core-time-picker.component.mjs +104 -0
- package/esm2022/lib/core-time-picker/time-picker-modal/time-picker-modal.component.mjs +147 -0
- package/esm2022/lib/falcon-lib.module.mjs +228 -7
- package/esm2022/lib/falconTypes.mjs +9 -2
- package/esm2022/lib/pipes/digit-group.pipe.mjs +16 -0
- package/esm2022/lib/pipes/form-control.pipe.mjs +16 -0
- package/esm2022/lib/pipes/persian-digits.pipe.mjs +40 -0
- package/esm2022/lib/pipes/price-format.pipe.mjs +23 -0
- package/esm2022/lib/pipes/shamsi-date.pipe.mjs +18 -0
- package/esm2022/lib/pipes/time-format.pipe.mjs +28 -0
- package/esm2022/lib/pipes/weight.pipe.mjs +16 -0
- package/esm2022/lib/wordify.mjs +109 -0
- package/esm2022/public-api.mjs +25 -3
- package/esm2022/svg-icon/caret-up-icon/caret-up-icon.component.mjs +11 -0
- package/esm2022/svg-icon/close-icon/close-icon.component.mjs +11 -0
- package/esm2022/svg-icon/edit-square-icon/edit-square-icon.component.mjs +11 -0
- package/esm2022/svg-icon/pelak-icon/pelak-icon.component.mjs +11 -0
- package/esm2022/svg-icon/search-icon/search-icon.component.mjs +11 -0
- package/esm2022/svg-icon/sort-down-icon/sort-down-icon.component.mjs +11 -0
- package/esm2022/svg-icon/sort-solid-icon/sort-solid-icon.component.mjs +11 -0
- package/esm2022/svg-icon/sort-up-icon/sort-up-icon.component.mjs +11 -0
- package/esm2022/svg-icon/time-icon/time-icon.component.mjs +11 -0
- package/esm2022/svg-icon/warning-icon/warning-icon.component.mjs +11 -0
- package/esm2022/utils/constants.mjs +106 -0
- package/esm2022/utils/directives/detail-viewer-manager.directive.mjs +71 -0
- package/esm2022/utils/directives/table-detail-viewer-manager.directive.mjs +49 -0
- package/esm2022/utils/types.mjs +2 -0
- package/esm2022/utils/util.mjs +26 -0
- package/fesm2022/nira-falcon.mjs +2381 -43
- package/fesm2022/nira-falcon.mjs.map +1 -1
- package/lib/core-auto-complete/core-auto-complete.component.d.ts +30 -0
- package/lib/core-btn/core-btn.component.d.ts +3 -0
- package/lib/core-card/core-card.component.d.ts +6 -0
- package/lib/core-checkbox/core-checkbox.component.d.ts +13 -0
- package/lib/core-confirm-dialog/core-confirm-dialog.component.d.ts +14 -0
- package/lib/core-date-picker/core-date-picker.component.d.ts +20 -0
- package/lib/core-input/core-input.component.d.ts +17 -0
- package/lib/core-mulite-select/core-mulite-select-row/core-mulite-select-row.component.d.ts +11 -0
- package/lib/core-mulite-select/core-mulite-select.component.d.ts +42 -0
- package/lib/core-number/core-number.component.d.ts +12 -0
- package/lib/core-page-title/core-page-title.component.d.ts +7 -0
- package/lib/core-radio-buttons/core-radio-buttons.component.d.ts +29 -0
- package/lib/core-search-box/core-search-box.component.d.ts +10 -0
- package/lib/core-select/core-select.component.d.ts +40 -0
- package/lib/core-switch/core-switch.component.d.ts +17 -0
- package/lib/core-table/core-column-date-picker/core-column-date-picker.component.d.ts +21 -0
- package/lib/core-table/core-column-input/core-column-input.component.d.ts +11 -0
- package/lib/core-table/core-column-selector/core-column-selector.component.d.ts +33 -0
- package/lib/core-table/core-row-pelak/core-row-pelak.component.d.ts +8 -0
- package/lib/core-table/core-table/core-table.component.d.ts +33 -0
- package/lib/core-table/core-table-action-buttons-column/core-table-action-buttons-column.component.d.ts +11 -0
- package/lib/core-table/core-table-action-column/core-table-action-column.component.d.ts +11 -0
- package/lib/core-table/core-table-card-manager/core-table-card-manager.component.d.ts +23 -0
- package/lib/core-table/core-table-column-manager/core-table-column-manager.component.d.ts +23 -0
- package/lib/core-table/core-table-detail-viewer-for-report/core-table-detail-viewer-for-report.component.d.ts +10 -0
- package/lib/core-table/core-table-filter-dialog/core-table-filter-dialog/core-table-filter-dialog.component.d.ts +23 -0
- package/lib/core-table/core-table-no-content/core-table-no-content.component.d.ts +9 -0
- package/lib/core-table/core-table-no-content/core-table-no-content.label.d.ts +5 -0
- package/lib/core-table/core-table-row-selector-column/core-table-row-selector-column.component.d.ts +12 -0
- package/lib/core-table/core-table-shamsi-date/core-table-shamsi-date.component.d.ts +11 -0
- package/lib/core-table/core-table-status-active-column/core-table-status-active-column.component.d.ts +8 -0
- package/lib/core-table/core-table-status-column/core-table-status-column.component.d.ts +7 -0
- package/lib/core-textarea/core-textarea.component.d.ts +13 -0
- package/lib/core-time-picker/core-time-picker.component.d.ts +25 -0
- package/lib/core-time-picker/time-picker-modal/time-picker-modal.component.d.ts +35 -0
- package/lib/falcon-lib.module.d.ts +57 -4
- package/lib/falconTypes.d.ts +7 -0
- package/lib/pipes/digit-group.pipe.d.ts +7 -0
- package/lib/pipes/form-control.pipe.d.ts +8 -0
- package/lib/pipes/persian-digits.pipe.d.ts +7 -0
- package/lib/pipes/price-format.pipe.d.ts +7 -0
- package/lib/pipes/shamsi-date.pipe.d.ts +9 -0
- package/lib/pipes/time-format.pipe.d.ts +7 -0
- package/lib/pipes/weight.pipe.d.ts +7 -0
- package/lib/wordify.d.ts +2 -0
- package/package.json +2 -2
- package/public-api.d.ts +24 -2
- package/svg-icon/caret-up-icon/caret-up-icon.component.d.ts +5 -0
- package/svg-icon/close-icon/close-icon.component.d.ts +5 -0
- package/svg-icon/edit-square-icon/edit-square-icon.component.d.ts +5 -0
- package/svg-icon/pelak-icon/pelak-icon.component.d.ts +5 -0
- package/svg-icon/search-icon/search-icon.component.d.ts +5 -0
- package/svg-icon/sort-down-icon/sort-down-icon.component.d.ts +5 -0
- package/svg-icon/sort-solid-icon/sort-solid-icon.component.d.ts +5 -0
- package/svg-icon/sort-up-icon/sort-up-icon.component.d.ts +5 -0
- package/svg-icon/time-icon/time-icon.component.d.ts +5 -0
- package/svg-icon/warning-icon/warning-icon.component.d.ts +5 -0
- package/utils/constants.d.ts +77 -0
- package/utils/directives/detail-viewer-manager.directive.d.ts +18 -0
- package/utils/directives/table-detail-viewer-manager.directive.d.ts +16 -0
- package/utils/types.d.ts +10 -0
- package/utils/util.d.ts +11 -0
- package/esm2022/lib/falcon-lib.component.mjs +0 -19
- package/esm2022/lib/falcon-lib.service.mjs +0 -14
- package/esm2022/nira-falcon-lib.mjs +0 -5
- package/fesm2022/nira-falcon-lib.mjs +0 -120
- package/fesm2022/nira-falcon-lib.mjs.map +0 -1
- package/lib/falcon-lib.component.d.ts +0 -5
- package/lib/falcon-lib.service.d.ts +0 -6
|
@@ -0,0 +1,176 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output, } from '@angular/core';
|
|
2
|
+
import { COLUMNS_TYPES, } from 'projects/falcon-lib/src/utils/constants';
|
|
3
|
+
import { BehaviorSubject } from 'rxjs';
|
|
4
|
+
import { Util } from 'projects/falcon-lib/src/utils/util';
|
|
5
|
+
import { orderBy } from 'lodash';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "ngx-indexed-db";
|
|
8
|
+
import * as i2 from "@angular/common";
|
|
9
|
+
import * as i3 from "../../core-card/core-card.component";
|
|
10
|
+
import * as i4 from "../core-column-date-picker/core-column-date-picker.component";
|
|
11
|
+
import * as i5 from "../core-column-input/core-column-input.component";
|
|
12
|
+
import * as i6 from "../core-column-selector/core-column-selector.component";
|
|
13
|
+
import * as i7 from "../core-table-card-manager/core-table-card-manager.component";
|
|
14
|
+
import * as i8 from "../core-table-column-manager/core-table-column-manager.component";
|
|
15
|
+
import * as i9 from "../core-table-no-content/core-table-no-content.component";
|
|
16
|
+
import * as i10 from "../../../svg-icon/sort-down-icon/sort-down-icon.component";
|
|
17
|
+
import * as i11 from "../../../svg-icon/sort-solid-icon/sort-solid-icon.component";
|
|
18
|
+
import * as i12 from "../../../svg-icon/sort-up-icon/sort-up-icon.component";
|
|
19
|
+
export class CoreTableComponent {
|
|
20
|
+
get columnsTypes() {
|
|
21
|
+
return COLUMNS_TYPES;
|
|
22
|
+
}
|
|
23
|
+
get isRunningOnSmallScreen() {
|
|
24
|
+
return Util.isRunningOnSmallScreen();
|
|
25
|
+
}
|
|
26
|
+
constructor(dbService) {
|
|
27
|
+
this.dbService = dbService;
|
|
28
|
+
this.tableData = new BehaviorSubject([]);
|
|
29
|
+
this.responsive = true;
|
|
30
|
+
this.rowSelector = undefined;
|
|
31
|
+
this.onColumnClicked = new EventEmitter();
|
|
32
|
+
this.sortedTableData = [];
|
|
33
|
+
}
|
|
34
|
+
ngOnInit() {
|
|
35
|
+
this.tableData.subscribe((val) => {
|
|
36
|
+
this.sortedTableData = val;
|
|
37
|
+
});
|
|
38
|
+
if (this.key) {
|
|
39
|
+
this.dbService
|
|
40
|
+
.getByIndex('tableFilter', 'key', this.key)
|
|
41
|
+
.subscribe((data) => {
|
|
42
|
+
this.dbTableFilter = data;
|
|
43
|
+
if (this.dbTableFilter) {
|
|
44
|
+
this.setTableFilter();
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
setTableFilter() {
|
|
50
|
+
this.columnsSchema.map((column) => {
|
|
51
|
+
JSON.parse(this.dbTableFilter.columnsSchema).forEach((dbColumnsSchema) => {
|
|
52
|
+
if (dbColumnsSchema.key === column.key) {
|
|
53
|
+
column.active = dbColumnsSchema.active;
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
return column;
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
columnClicked(val) {
|
|
60
|
+
this.onColumnClicked.emit(val);
|
|
61
|
+
}
|
|
62
|
+
sortByHeader(column) {
|
|
63
|
+
if (this.sortDetail && this.sortDetail.key == column.key) {
|
|
64
|
+
if (this.sortDetail.sort == 'desc') {
|
|
65
|
+
this.sortDetail = { key: column.key, sort: 'asc' };
|
|
66
|
+
}
|
|
67
|
+
else {
|
|
68
|
+
this.sortDetail = { key: column.key, sort: 'desc' };
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
else {
|
|
72
|
+
this.sortDetail = { key: column.key, sort: 'asc' };
|
|
73
|
+
}
|
|
74
|
+
if (column.type == COLUMNS_TYPES.TEXT ||
|
|
75
|
+
column.type == COLUMNS_TYPES.NUMBER) {
|
|
76
|
+
this.sortedTableData = orderBy(this.sortedTableData, [column.key], [this.sortDetail.sort]);
|
|
77
|
+
}
|
|
78
|
+
else if (column.type == COLUMNS_TYPES.SELECTOR) {
|
|
79
|
+
this.sortedTableData = orderBy(this.sortedTableData, [(c) => c[column.key][column.data.key]], [this.sortDetail.sort]);
|
|
80
|
+
}
|
|
81
|
+
else if (column.type == COLUMNS_TYPES.SHAMSI_DATE) {
|
|
82
|
+
this.sortedTableData = orderBy(this.sortedTableData, [(c) => new Date(c[column.key]).getTime()], [this.sortDetail.sort]);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
activeColumnsSchema() {
|
|
86
|
+
return this.columnsSchema.filter((column) => column.active === undefined || column.active);
|
|
87
|
+
}
|
|
88
|
+
tableDataFiltered(text, column) {
|
|
89
|
+
this.columnsSchema.map((columnSchema) => {
|
|
90
|
+
if (columnSchema.key === column.key) {
|
|
91
|
+
columnSchema.columnFilter = text;
|
|
92
|
+
}
|
|
93
|
+
return columnSchema;
|
|
94
|
+
});
|
|
95
|
+
const tableData = this.tableData.getValue();
|
|
96
|
+
this.sortedTableData = tableData.filter((data) => {
|
|
97
|
+
let result = true;
|
|
98
|
+
this.columnsSchema.forEach((columnSchema) => {
|
|
99
|
+
if (columnSchema.type === this.columnsTypes.ROW_SELECTOR ||
|
|
100
|
+
columnSchema.type === this.columnsTypes.ACTION ||
|
|
101
|
+
columnSchema.type === this.columnsTypes.ACTION_BUTTONS ||
|
|
102
|
+
columnSchema.columnFilter === undefined ||
|
|
103
|
+
!result) {
|
|
104
|
+
return;
|
|
105
|
+
}
|
|
106
|
+
if (columnSchema.type === this.columnsTypes.SELECTOR) {
|
|
107
|
+
result = data[columnSchema.key][columnSchema.data.key]
|
|
108
|
+
.toLowerCase()
|
|
109
|
+
.includes(columnSchema.columnFilter.toString().toLowerCase());
|
|
110
|
+
}
|
|
111
|
+
else if (columnSchema.type === this.columnsTypes.SHAMSI_DATE) {
|
|
112
|
+
if (columnSchema.columnFilter === '') {
|
|
113
|
+
result = true;
|
|
114
|
+
}
|
|
115
|
+
else {
|
|
116
|
+
result = data[columnSchema.key]
|
|
117
|
+
.toLowerCase()
|
|
118
|
+
.includes(Util.shamsiToMiladi(columnSchema.columnFilter.toString(), 'YYYY-MM-DD'));
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
else if (columnSchema.type === this.columnsTypes.MULTI_COLUMN) {
|
|
122
|
+
result = columnSchema.columns.some((item) => {
|
|
123
|
+
return data[item.key][item.data.key]
|
|
124
|
+
.toLowerCase()
|
|
125
|
+
.includes(columnSchema.columnFilter?.toString()?.toLowerCase());
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
else if (columnSchema.type === this.columnsTypes.STATUS) {
|
|
129
|
+
if (columnSchema.columnFilter === '') {
|
|
130
|
+
result = true;
|
|
131
|
+
}
|
|
132
|
+
else {
|
|
133
|
+
result = data[columnSchema.key] === columnSchema.columnFilter;
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
else {
|
|
137
|
+
result = data[columnSchema.key]
|
|
138
|
+
.toString()
|
|
139
|
+
.toLowerCase()
|
|
140
|
+
.includes(columnSchema.columnFilter?.toString()?.toLowerCase());
|
|
141
|
+
}
|
|
142
|
+
});
|
|
143
|
+
return result;
|
|
144
|
+
});
|
|
145
|
+
}
|
|
146
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CoreTableComponent, deps: [{ token: i1.NgxIndexedDBService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
147
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CoreTableComponent, selector: "core-table", inputs: { key: "key", columnsSchema: "columnsSchema", tableData: "tableData", responsive: "responsive", loading: "loading", styleFilter: "styleFilter", rowSelector: "rowSelector" }, outputs: { onColumnClicked: "onColumnClicked" }, ngImport: i0, template: "<div class=\"p-2 overflow-x-auto\">\r\n <table *ngIf=\"!isRunningOnSmallScreen || !responsive; else smallDeviceCard\">\r\n <tr>\r\n <th\r\n class=\"cursor-pointer text-center\"\r\n *ngFor=\"let column of activeColumnsSchema()\"\r\n >\r\n <div class=\"grid grid-rows-2\">\r\n <span\r\n class=\"p-2 relative\"\r\n (click)=\"sortByHeader(column)\"\r\n [ngStyle]=\"{\r\n minWidth:\r\n column.type === columnsTypes.ACTION_BUTTONS\r\n ? column.data.length * 30 + 'px'\r\n : '',\r\n display:\r\n column.type === columnsTypes.ACTION_BUTTONS\r\n ? 'inline-block'\r\n : ''\r\n }\"\r\n >{{ column.label }}\r\n <app-sort-down-icon\r\n class=\"sort-icon w-2 h-2 inline-block absolute top-3 right-[-3px]\"\r\n *ngIf=\"\r\n sortDetail?.key == column.key && sortDetail?.sort === 'asc'\r\n \"\r\n ></app-sort-down-icon>\r\n <app-sort-up-icon\r\n class=\"sort-icon w-2 h-2 inline-block absolute top-3 right-[-3px]\"\r\n *ngIf=\"\r\n sortDetail?.key == column.key && sortDetail?.sort === 'desc'\r\n \"\r\n ></app-sort-up-icon>\r\n <app-sort-solid-icon\r\n class=\"sort-icon w-2 h-2 inline-block absolute top-3 right-[-3px]\"\r\n *ngIf=\"sortDetail?.key !== column.key\"\r\n ></app-sort-solid-icon>\r\n </span>\r\n <core-column-date-picker\r\n *ngIf=\"column.type == columnsTypes.SHAMSI_DATE\"\r\n [canSelectToday]=\"true\"\r\n (onChange)=\"tableDataFiltered($event, column)\"\r\n >\r\n </core-column-date-picker>\r\n <core-column-input\r\n *ngIf=\"\r\n column.type !== columnsTypes.ACTION &&\r\n column.type !== columnsTypes.STATUS &&\r\n column.type !== columnsTypes.SHAMSI_DATE\r\n \"\r\n (onChange)=\"tableDataFiltered($event, column)\"\r\n ></core-column-input>\r\n <core-column-selector\r\n *ngIf=\"column.type == columnsTypes.STATUS\"\r\n [titleKey]=\"'title'\"\r\n [valueKey]=\"'value'\"\r\n (onItemSelected)=\"tableDataFiltered($event, column)\"\r\n ></core-column-selector>\r\n </div>\r\n </th>\r\n </tr>\r\n <tr *ngFor=\"let data of sortedTableData\">\r\n <td\r\n *ngFor=\"let column of activeColumnsSchema()\"\r\n [class]=\"styleFilter ? styleFilter(data) : ''\"\r\n >\r\n <app-core-table-column-manager\r\n *ngIf=\"column.type != columnsTypes.MULTI_COLUMN; else elseBlock\"\r\n [rowSelector]=\"rowSelector\"\r\n (onColumnClicked)=\"columnClicked($event)\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-table-column-manager>\r\n <ng-template #elseBlock>\r\n <app-core-table-column-manager\r\n *ngFor=\"let childColumn of column.columns; let i = index\"\r\n [rowSelector]=\"rowSelector\"\r\n (onColumnClicked)=\"columnClicked($event)\"\r\n [data]=\"data\"\r\n [column]=\"childColumn\"\r\n >\r\n <span *ngIf=\"i > 0\">-</span>\r\n </app-core-table-column-manager>\r\n </ng-template>\r\n </td>\r\n </tr>\r\n </table>\r\n <ng-template #smallDeviceCard>\r\n <div>\r\n <core-card\r\n *ngFor=\"let data of sortedTableData\"\r\n [cardClass]=\"'background-card m-4 p-4 relative'\"\r\n >\r\n <div\r\n class=\"leading-8\"\r\n *ngFor=\"let column of activeColumnsSchema()\"\r\n [class]=\"\r\n column.type === columnsTypes.ACTION_BUTTONS\r\n ? 'actionButtons'\r\n : column.type === columnsTypes.ROW_SELECTOR\r\n ? 'selectRow'\r\n : ''\r\n \"\r\n >\r\n <span\r\n *ngIf=\"\r\n column.type !== columnsTypes.ACTION_BUTTONS &&\r\n column.type !== columnsTypes.ROW_SELECTOR\r\n \"\r\n class=\"secondary-text-color\"\r\n >\r\n {{ column.label }} :\r\n </span>\r\n <span class=\"primary-text-color font-semibold\">\r\n <app-core-table-card-manager\r\n *ngIf=\"\r\n column.type != columnsTypes.MULTI_COLUMN;\r\n else cardManagerElseBlock\r\n \"\r\n [rowSelector]=\"rowSelector\"\r\n (onColumnClicked)=\"columnClicked($event)\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n >\r\n </app-core-table-card-manager>\r\n\r\n <ng-template #cardManagerElseBlock>\r\n <app-core-table-card-manager\r\n *ngFor=\"let childColumn of column.columns; let i = index\"\r\n [rowSelector]=\"rowSelector\"\r\n (onColumnClicked)=\"columnClicked($event)\"\r\n [data]=\"data\"\r\n [column]=\"childColumn\"\r\n >\r\n <span *ngIf=\"i > 0\">-</span>\r\n </app-core-table-card-manager>\r\n </ng-template>\r\n </span>\r\n </div>\r\n </core-card>\r\n </div>\r\n </ng-template>\r\n <core-table-no-content\r\n *ngIf=\"!loading\"\r\n [tableData]=\"sortedTableData\"\r\n [loading]=\"loading\"\r\n ></core-table-no-content>\r\n</div>\r\n", styles: ["table{border-collapse:collapse;width:100%;text-align:start}table td,table th{padding-top:12px;padding-bottom:12px;padding-inline-start:8px}table td{font-size:small;color:var(--default-table-td-text-color)}table tr:nth-child(2n){background-color:var(--default-table-tr-child-background-color)}table tr:hover{background-color:var(--default-table-tr-hover-background-color)}table th{background-color:var(--default-table-th-background-color);text-align:start;color:#1d1d1d}.actionButtons{position:absolute;bottom:0;background:var(--default-table-action-buttons-background-color);left:0;right:0;text-align:left;border-radius:.5rem;border-top-right-radius:0;border-top-left-radius:0;padding-top:4px;padding-left:16px}.selectRow{position:absolute;left:0;top:18px}.desc-sort-icon{transform:rotate(180deg)}.sort-icon{fill:var(--default-table-sort-icon-color)}.background-card{background-color:var(--default-table-background-card-color)}.secondary-text-color{color:var(--default-table-secondary-text-color)}.primary-text-color{color:var(--default-table-primary-text-color)}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3.CoreCardComponent, selector: "core-card", inputs: ["cardClass"] }, { kind: "component", type: i4.CoreColumnDatePickerComponent, selector: "core-column-date-picker", inputs: ["canSelectToday", "defaultDate", "inputFormControl"], outputs: ["onChange"] }, { kind: "component", type: i5.CoreColumnInputComponent, selector: "core-column-input", inputs: ["showRemoveIcon", "placeholder", "value"], outputs: ["onChange"] }, { kind: "component", type: i6.CoreColumnSelectorComponent, selector: "core-column-selector", inputs: ["titleKey", "valueKey", "label", "inputFormControl"], outputs: ["onItemSelected"] }, { kind: "component", type: i7.CoreTableCardManagerComponent, selector: "app-core-table-card-manager", inputs: ["data", "column", "rowSelector"], outputs: ["onColumnClicked"] }, { kind: "component", type: i8.CoreTableColumnManagerComponent, selector: "app-core-table-column-manager", inputs: ["data", "column", "rowSelector"], outputs: ["onColumnClicked"] }, { kind: "component", type: i9.CoreTableNoContentComponent, selector: "core-table-no-content", inputs: ["tableData", "loading"] }, { kind: "component", type: i10.SortDownIconComponent, selector: "app-sort-down-icon" }, { kind: "component", type: i11.SortSolidIconComponent, selector: "app-sort-solid-icon" }, { kind: "component", type: i12.SortUpIconComponent, selector: "app-sort-up-icon" }] }); }
|
|
148
|
+
}
|
|
149
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CoreTableComponent, decorators: [{
|
|
150
|
+
type: Component,
|
|
151
|
+
args: [{ selector: 'core-table', template: "<div class=\"p-2 overflow-x-auto\">\r\n <table *ngIf=\"!isRunningOnSmallScreen || !responsive; else smallDeviceCard\">\r\n <tr>\r\n <th\r\n class=\"cursor-pointer text-center\"\r\n *ngFor=\"let column of activeColumnsSchema()\"\r\n >\r\n <div class=\"grid grid-rows-2\">\r\n <span\r\n class=\"p-2 relative\"\r\n (click)=\"sortByHeader(column)\"\r\n [ngStyle]=\"{\r\n minWidth:\r\n column.type === columnsTypes.ACTION_BUTTONS\r\n ? column.data.length * 30 + 'px'\r\n : '',\r\n display:\r\n column.type === columnsTypes.ACTION_BUTTONS\r\n ? 'inline-block'\r\n : ''\r\n }\"\r\n >{{ column.label }}\r\n <app-sort-down-icon\r\n class=\"sort-icon w-2 h-2 inline-block absolute top-3 right-[-3px]\"\r\n *ngIf=\"\r\n sortDetail?.key == column.key && sortDetail?.sort === 'asc'\r\n \"\r\n ></app-sort-down-icon>\r\n <app-sort-up-icon\r\n class=\"sort-icon w-2 h-2 inline-block absolute top-3 right-[-3px]\"\r\n *ngIf=\"\r\n sortDetail?.key == column.key && sortDetail?.sort === 'desc'\r\n \"\r\n ></app-sort-up-icon>\r\n <app-sort-solid-icon\r\n class=\"sort-icon w-2 h-2 inline-block absolute top-3 right-[-3px]\"\r\n *ngIf=\"sortDetail?.key !== column.key\"\r\n ></app-sort-solid-icon>\r\n </span>\r\n <core-column-date-picker\r\n *ngIf=\"column.type == columnsTypes.SHAMSI_DATE\"\r\n [canSelectToday]=\"true\"\r\n (onChange)=\"tableDataFiltered($event, column)\"\r\n >\r\n </core-column-date-picker>\r\n <core-column-input\r\n *ngIf=\"\r\n column.type !== columnsTypes.ACTION &&\r\n column.type !== columnsTypes.STATUS &&\r\n column.type !== columnsTypes.SHAMSI_DATE\r\n \"\r\n (onChange)=\"tableDataFiltered($event, column)\"\r\n ></core-column-input>\r\n <core-column-selector\r\n *ngIf=\"column.type == columnsTypes.STATUS\"\r\n [titleKey]=\"'title'\"\r\n [valueKey]=\"'value'\"\r\n (onItemSelected)=\"tableDataFiltered($event, column)\"\r\n ></core-column-selector>\r\n </div>\r\n </th>\r\n </tr>\r\n <tr *ngFor=\"let data of sortedTableData\">\r\n <td\r\n *ngFor=\"let column of activeColumnsSchema()\"\r\n [class]=\"styleFilter ? styleFilter(data) : ''\"\r\n >\r\n <app-core-table-column-manager\r\n *ngIf=\"column.type != columnsTypes.MULTI_COLUMN; else elseBlock\"\r\n [rowSelector]=\"rowSelector\"\r\n (onColumnClicked)=\"columnClicked($event)\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-table-column-manager>\r\n <ng-template #elseBlock>\r\n <app-core-table-column-manager\r\n *ngFor=\"let childColumn of column.columns; let i = index\"\r\n [rowSelector]=\"rowSelector\"\r\n (onColumnClicked)=\"columnClicked($event)\"\r\n [data]=\"data\"\r\n [column]=\"childColumn\"\r\n >\r\n <span *ngIf=\"i > 0\">-</span>\r\n </app-core-table-column-manager>\r\n </ng-template>\r\n </td>\r\n </tr>\r\n </table>\r\n <ng-template #smallDeviceCard>\r\n <div>\r\n <core-card\r\n *ngFor=\"let data of sortedTableData\"\r\n [cardClass]=\"'background-card m-4 p-4 relative'\"\r\n >\r\n <div\r\n class=\"leading-8\"\r\n *ngFor=\"let column of activeColumnsSchema()\"\r\n [class]=\"\r\n column.type === columnsTypes.ACTION_BUTTONS\r\n ? 'actionButtons'\r\n : column.type === columnsTypes.ROW_SELECTOR\r\n ? 'selectRow'\r\n : ''\r\n \"\r\n >\r\n <span\r\n *ngIf=\"\r\n column.type !== columnsTypes.ACTION_BUTTONS &&\r\n column.type !== columnsTypes.ROW_SELECTOR\r\n \"\r\n class=\"secondary-text-color\"\r\n >\r\n {{ column.label }} :\r\n </span>\r\n <span class=\"primary-text-color font-semibold\">\r\n <app-core-table-card-manager\r\n *ngIf=\"\r\n column.type != columnsTypes.MULTI_COLUMN;\r\n else cardManagerElseBlock\r\n \"\r\n [rowSelector]=\"rowSelector\"\r\n (onColumnClicked)=\"columnClicked($event)\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n >\r\n </app-core-table-card-manager>\r\n\r\n <ng-template #cardManagerElseBlock>\r\n <app-core-table-card-manager\r\n *ngFor=\"let childColumn of column.columns; let i = index\"\r\n [rowSelector]=\"rowSelector\"\r\n (onColumnClicked)=\"columnClicked($event)\"\r\n [data]=\"data\"\r\n [column]=\"childColumn\"\r\n >\r\n <span *ngIf=\"i > 0\">-</span>\r\n </app-core-table-card-manager>\r\n </ng-template>\r\n </span>\r\n </div>\r\n </core-card>\r\n </div>\r\n </ng-template>\r\n <core-table-no-content\r\n *ngIf=\"!loading\"\r\n [tableData]=\"sortedTableData\"\r\n [loading]=\"loading\"\r\n ></core-table-no-content>\r\n</div>\r\n", styles: ["table{border-collapse:collapse;width:100%;text-align:start}table td,table th{padding-top:12px;padding-bottom:12px;padding-inline-start:8px}table td{font-size:small;color:var(--default-table-td-text-color)}table tr:nth-child(2n){background-color:var(--default-table-tr-child-background-color)}table tr:hover{background-color:var(--default-table-tr-hover-background-color)}table th{background-color:var(--default-table-th-background-color);text-align:start;color:#1d1d1d}.actionButtons{position:absolute;bottom:0;background:var(--default-table-action-buttons-background-color);left:0;right:0;text-align:left;border-radius:.5rem;border-top-right-radius:0;border-top-left-radius:0;padding-top:4px;padding-left:16px}.selectRow{position:absolute;left:0;top:18px}.desc-sort-icon{transform:rotate(180deg)}.sort-icon{fill:var(--default-table-sort-icon-color)}.background-card{background-color:var(--default-table-background-card-color)}.secondary-text-color{color:var(--default-table-secondary-text-color)}.primary-text-color{color:var(--default-table-primary-text-color)}\n"] }]
|
|
152
|
+
}], ctorParameters: function () { return [{ type: i1.NgxIndexedDBService }]; }, propDecorators: { key: [{
|
|
153
|
+
type: Input,
|
|
154
|
+
args: [{ required: false }]
|
|
155
|
+
}], columnsSchema: [{
|
|
156
|
+
type: Input,
|
|
157
|
+
args: [{ required: true }]
|
|
158
|
+
}], tableData: [{
|
|
159
|
+
type: Input,
|
|
160
|
+
args: [{ required: true }]
|
|
161
|
+
}], responsive: [{
|
|
162
|
+
type: Input,
|
|
163
|
+
args: [{ required: false }]
|
|
164
|
+
}], loading: [{
|
|
165
|
+
type: Input,
|
|
166
|
+
args: [{ required: true }]
|
|
167
|
+
}], styleFilter: [{
|
|
168
|
+
type: Input,
|
|
169
|
+
args: [{ required: false }]
|
|
170
|
+
}], rowSelector: [{
|
|
171
|
+
type: Input,
|
|
172
|
+
args: [{ required: false }]
|
|
173
|
+
}], onColumnClicked: [{
|
|
174
|
+
type: Output
|
|
175
|
+
}] } });
|
|
176
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-table.component.js","sourceRoot":"","sources":["../../../../../../projects/falcon-lib/src/lib/core-table/core-table/core-table.component.ts","../../../../../../projects/falcon-lib/src/lib/core-table/core-table/core-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterContentChecked,\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  Output,\r\n} from '@angular/core';\r\nimport {\r\n  COLUMNS_TYPES,\r\n  TableKeys,\r\n} from 'projects/falcon-lib/src/utils/constants';\r\nimport { BehaviorSubject } from 'rxjs';\r\n\r\nimport { Util } from 'projects/falcon-lib/src/utils/util';\r\nimport { NgxIndexedDBService } from 'ngx-indexed-db';\r\nimport { orderBy } from 'lodash';\r\n@Component({\r\n  selector: 'core-table',\r\n  templateUrl: './core-table.component.html',\r\n  styleUrls: ['./core-table.component.scss'],\r\n})\r\nexport class CoreTableComponent {\r\n  @Input({ required: false }) key: TableKeys | undefined;\r\n  @Input({ required: true }) columnsSchema: any;\r\n  @Input({ required: true }) tableData: BehaviorSubject<any[]> =\r\n    new BehaviorSubject<any[]>([]);\r\n  @Input({ required: false }) responsive: boolean = true;\r\n  @Input({ required: true }) loading: any;\r\n  @Input({ required: false }) styleFilter: ((data: any) => string) | undefined;\r\n  @Input({ required: false }) rowSelector: BehaviorSubject<any> | undefined =\r\n    undefined;\r\n  @Output() onColumnClicked: EventEmitter<any> = new EventEmitter();\r\n\r\n  sortDetail: { key: string; sort: 'asc' | 'desc' } | undefined;\r\n  sortedTableData: any[] = [];\r\n  dbTableFilter: any;\r\n  get columnsTypes() {\r\n    return COLUMNS_TYPES;\r\n  }\r\n  get isRunningOnSmallScreen() {\r\n    return Util.isRunningOnSmallScreen();\r\n  }\r\n  constructor(private dbService: NgxIndexedDBService) {}\r\n\r\n  ngOnInit(): void {\r\n    this.tableData.subscribe((val: any) => {\r\n      this.sortedTableData = val;\r\n    });\r\n    if (this.key) {\r\n      this.dbService\r\n        .getByIndex('tableFilter', 'key', this.key)\r\n        .subscribe((data: any) => {\r\n          this.dbTableFilter = data;\r\n          if (this.dbTableFilter) {\r\n            this.setTableFilter();\r\n          }\r\n        });\r\n    }\r\n  }\r\n  setTableFilter() {\r\n    this.columnsSchema.map((column: any) => {\r\n      JSON.parse(this.dbTableFilter.columnsSchema).forEach(\r\n        (dbColumnsSchema: any) => {\r\n          if (dbColumnsSchema.key === column.key) {\r\n            column.active = dbColumnsSchema.active;\r\n          }\r\n        }\r\n      );\r\n      return column;\r\n    });\r\n  }\r\n\r\n  columnClicked(val: any) {\r\n    this.onColumnClicked.emit(val);\r\n  }\r\n  sortByHeader(column: any) {\r\n    if (this.sortDetail && this.sortDetail.key == column.key) {\r\n      if (this.sortDetail.sort == 'desc') {\r\n        this.sortDetail = { key: column.key, sort: 'asc' };\r\n      } else {\r\n        this.sortDetail = { key: column.key, sort: 'desc' };\r\n      }\r\n    } else {\r\n      this.sortDetail = { key: column.key, sort: 'asc' };\r\n    }\r\n    if (\r\n      column.type == COLUMNS_TYPES.TEXT ||\r\n      column.type == COLUMNS_TYPES.NUMBER\r\n    ) {\r\n      this.sortedTableData = orderBy(\r\n        this.sortedTableData,\r\n        [column.key],\r\n        [this.sortDetail.sort]\r\n      );\r\n    } else if (column.type == COLUMNS_TYPES.SELECTOR) {\r\n      this.sortedTableData = orderBy(\r\n        this.sortedTableData,\r\n        [(c) => c[column.key][column.data.key]],\r\n        [this.sortDetail.sort]\r\n      );\r\n    } else if (column.type == COLUMNS_TYPES.SHAMSI_DATE) {\r\n      this.sortedTableData = orderBy(\r\n        this.sortedTableData,\r\n        [(c) => new Date(c[column.key]).getTime()],\r\n        [this.sortDetail.sort]\r\n      );\r\n    }\r\n  }\r\n\r\n  activeColumnsSchema(): any[] {\r\n    return this.columnsSchema.filter(\r\n      (column: any) => column.active === undefined || column.active\r\n    );\r\n  }\r\n\r\n  tableDataFiltered(text: String | boolean, column: any) {\r\n    this.columnsSchema.map((columnSchema: any) => {\r\n      if (columnSchema.key === column.key) {\r\n        columnSchema.columnFilter = text;\r\n      }\r\n      return columnSchema;\r\n    });\r\n    const tableData = this.tableData.getValue();\r\n    this.sortedTableData = tableData.filter((data: any) => {\r\n      let result = true;\r\n      this.columnsSchema.forEach((columnSchema: any) => {\r\n        if (\r\n          columnSchema.type === this.columnsTypes.ROW_SELECTOR ||\r\n          columnSchema.type === this.columnsTypes.ACTION ||\r\n          columnSchema.type === this.columnsTypes.ACTION_BUTTONS ||\r\n          columnSchema.columnFilter === undefined ||\r\n          !result\r\n        ) {\r\n          return;\r\n        }\r\n        if (columnSchema.type === this.columnsTypes.SELECTOR) {\r\n          result = data[columnSchema.key][columnSchema.data.key]\r\n            .toLowerCase()\r\n            .includes(columnSchema.columnFilter.toString().toLowerCase());\r\n        } else if (columnSchema.type === this.columnsTypes.SHAMSI_DATE) {\r\n          if (columnSchema.columnFilter === '') {\r\n            result = true;\r\n          } else {\r\n            result = data[columnSchema.key]\r\n              .toLowerCase()\r\n              .includes(\r\n                Util.shamsiToMiladi(\r\n                  columnSchema.columnFilter.toString(),\r\n                  'YYYY-MM-DD'\r\n                )\r\n              );\r\n          }\r\n        } else if (columnSchema.type === this.columnsTypes.MULTI_COLUMN) {\r\n          result = columnSchema.columns.some((item: any) => {\r\n            return data[item.key][item.data.key]\r\n              .toLowerCase()\r\n              .includes(columnSchema.columnFilter?.toString()?.toLowerCase());\r\n          });\r\n        } else if (columnSchema.type === this.columnsTypes.STATUS) {\r\n          if (columnSchema.columnFilter === '') {\r\n            result = true;\r\n          } else {\r\n            result = data[columnSchema.key] === columnSchema.columnFilter;\r\n          }\r\n        } else {\r\n          result = data[columnSchema.key]\r\n            .toString()\r\n            .toLowerCase()\r\n            .includes(columnSchema.columnFilter?.toString()?.toLowerCase());\r\n        }\r\n      });\r\n      return result;\r\n    });\r\n  }\r\n}\r\n","<div class=\"p-2 overflow-x-auto\">\r\n  <table *ngIf=\"!isRunningOnSmallScreen || !responsive; else smallDeviceCard\">\r\n    <tr>\r\n      <th\r\n        class=\"cursor-pointer text-center\"\r\n        *ngFor=\"let column of activeColumnsSchema()\"\r\n      >\r\n        <div class=\"grid grid-rows-2\">\r\n          <span\r\n            class=\"p-2 relative\"\r\n            (click)=\"sortByHeader(column)\"\r\n            [ngStyle]=\"{\r\n              minWidth:\r\n                column.type === columnsTypes.ACTION_BUTTONS\r\n                  ? column.data.length * 30 + 'px'\r\n                  : '',\r\n              display:\r\n                column.type === columnsTypes.ACTION_BUTTONS\r\n                  ? 'inline-block'\r\n                  : ''\r\n            }\"\r\n            >{{ column.label }}\r\n            <app-sort-down-icon\r\n              class=\"sort-icon w-2 h-2 inline-block absolute top-3 right-[-3px]\"\r\n              *ngIf=\"\r\n                sortDetail?.key == column.key && sortDetail?.sort === 'asc'\r\n              \"\r\n            ></app-sort-down-icon>\r\n            <app-sort-up-icon\r\n              class=\"sort-icon w-2 h-2 inline-block absolute top-3 right-[-3px]\"\r\n              *ngIf=\"\r\n                sortDetail?.key == column.key && sortDetail?.sort === 'desc'\r\n              \"\r\n            ></app-sort-up-icon>\r\n            <app-sort-solid-icon\r\n              class=\"sort-icon w-2 h-2 inline-block absolute top-3 right-[-3px]\"\r\n              *ngIf=\"sortDetail?.key !== column.key\"\r\n            ></app-sort-solid-icon>\r\n          </span>\r\n          <core-column-date-picker\r\n            *ngIf=\"column.type == columnsTypes.SHAMSI_DATE\"\r\n            [canSelectToday]=\"true\"\r\n            (onChange)=\"tableDataFiltered($event, column)\"\r\n          >\r\n          </core-column-date-picker>\r\n          <core-column-input\r\n            *ngIf=\"\r\n              column.type !== columnsTypes.ACTION &&\r\n              column.type !== columnsTypes.STATUS &&\r\n              column.type !== columnsTypes.SHAMSI_DATE\r\n            \"\r\n            (onChange)=\"tableDataFiltered($event, column)\"\r\n          ></core-column-input>\r\n          <core-column-selector\r\n            *ngIf=\"column.type == columnsTypes.STATUS\"\r\n            [titleKey]=\"'title'\"\r\n            [valueKey]=\"'value'\"\r\n            (onItemSelected)=\"tableDataFiltered($event, column)\"\r\n          ></core-column-selector>\r\n        </div>\r\n      </th>\r\n    </tr>\r\n    <tr *ngFor=\"let data of sortedTableData\">\r\n      <td\r\n        *ngFor=\"let column of activeColumnsSchema()\"\r\n        [class]=\"styleFilter ? styleFilter(data) : ''\"\r\n      >\r\n        <app-core-table-column-manager\r\n          *ngIf=\"column.type != columnsTypes.MULTI_COLUMN; else elseBlock\"\r\n          [rowSelector]=\"rowSelector\"\r\n          (onColumnClicked)=\"columnClicked($event)\"\r\n          [data]=\"data\"\r\n          [column]=\"column\"\r\n        ></app-core-table-column-manager>\r\n        <ng-template #elseBlock>\r\n          <app-core-table-column-manager\r\n            *ngFor=\"let childColumn of column.columns; let i = index\"\r\n            [rowSelector]=\"rowSelector\"\r\n            (onColumnClicked)=\"columnClicked($event)\"\r\n            [data]=\"data\"\r\n            [column]=\"childColumn\"\r\n          >\r\n            <span *ngIf=\"i > 0\">-</span>\r\n          </app-core-table-column-manager>\r\n        </ng-template>\r\n      </td>\r\n    </tr>\r\n  </table>\r\n  <ng-template #smallDeviceCard>\r\n    <div>\r\n      <core-card\r\n        *ngFor=\"let data of sortedTableData\"\r\n        [cardClass]=\"'background-card m-4 p-4 relative'\"\r\n      >\r\n        <div\r\n          class=\"leading-8\"\r\n          *ngFor=\"let column of activeColumnsSchema()\"\r\n          [class]=\"\r\n            column.type === columnsTypes.ACTION_BUTTONS\r\n              ? 'actionButtons'\r\n              : column.type === columnsTypes.ROW_SELECTOR\r\n              ? 'selectRow'\r\n              : ''\r\n          \"\r\n        >\r\n          <span\r\n            *ngIf=\"\r\n              column.type !== columnsTypes.ACTION_BUTTONS &&\r\n              column.type !== columnsTypes.ROW_SELECTOR\r\n            \"\r\n            class=\"secondary-text-color\"\r\n          >\r\n            {{ column.label }} :\r\n          </span>\r\n          <span class=\"primary-text-color font-semibold\">\r\n            <app-core-table-card-manager\r\n              *ngIf=\"\r\n                column.type != columnsTypes.MULTI_COLUMN;\r\n                else cardManagerElseBlock\r\n              \"\r\n              [rowSelector]=\"rowSelector\"\r\n              (onColumnClicked)=\"columnClicked($event)\"\r\n              [data]=\"data\"\r\n              [column]=\"column\"\r\n            >\r\n            </app-core-table-card-manager>\r\n\r\n            <ng-template #cardManagerElseBlock>\r\n              <app-core-table-card-manager\r\n                *ngFor=\"let childColumn of column.columns; let i = index\"\r\n                [rowSelector]=\"rowSelector\"\r\n                (onColumnClicked)=\"columnClicked($event)\"\r\n                [data]=\"data\"\r\n                [column]=\"childColumn\"\r\n              >\r\n                <span *ngIf=\"i > 0\">-</span>\r\n              </app-core-table-card-manager>\r\n            </ng-template>\r\n          </span>\r\n        </div>\r\n      </core-card>\r\n    </div>\r\n  </ng-template>\r\n  <core-table-no-content\r\n    *ngIf=\"!loading\"\r\n    [tableData]=\"sortedTableData\"\r\n    [loading]=\"loading\"\r\n  ></core-table-no-content>\r\n</div>\r\n"]}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
export class CoreTableActionButtonsColumnComponent {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.onClick = new EventEmitter();
|
|
7
|
+
}
|
|
8
|
+
clicked(key) {
|
|
9
|
+
this.onClick.emit({ data: this.data, key: key });
|
|
10
|
+
}
|
|
11
|
+
checkFilter(column) {
|
|
12
|
+
if (column.filter) {
|
|
13
|
+
return column.filter(this.data);
|
|
14
|
+
}
|
|
15
|
+
else {
|
|
16
|
+
return true;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CoreTableActionButtonsColumnComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
20
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CoreTableActionButtonsColumnComponent, selector: "app-core-table-action-buttons-column", inputs: { data: "data", column: "column" }, outputs: { onClick: "onClick" }, ngImport: i0, template: "<span *ngFor=\"let data of column.data\">\r\n <span\r\n *ngIf=\"checkFilter(data)\"\r\n class=\"icon-color cursor-pointer h-5 inline-block icon-color m-1\"\r\n (click)=\"clicked(data.key)\"\r\n >\r\n <ng-container *ngComponentOutlet=\"data.component\" />\r\n </span>\r\n</span>\r\n", styles: [".icon-color{fill:var(--default-table-column-action-buttons-fill-icon-color)}\n"], dependencies: [{ kind: "directive", type: i1.NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInputs", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
|
|
21
|
+
}
|
|
22
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CoreTableActionButtonsColumnComponent, decorators: [{
|
|
23
|
+
type: Component,
|
|
24
|
+
args: [{ selector: 'app-core-table-action-buttons-column', template: "<span *ngFor=\"let data of column.data\">\r\n <span\r\n *ngIf=\"checkFilter(data)\"\r\n class=\"icon-color cursor-pointer h-5 inline-block icon-color m-1\"\r\n (click)=\"clicked(data.key)\"\r\n >\r\n <ng-container *ngComponentOutlet=\"data.component\" />\r\n </span>\r\n</span>\r\n", styles: [".icon-color{fill:var(--default-table-column-action-buttons-fill-icon-color)}\n"] }]
|
|
25
|
+
}], propDecorators: { data: [{
|
|
26
|
+
type: Input,
|
|
27
|
+
args: [{ required: true }]
|
|
28
|
+
}], column: [{
|
|
29
|
+
type: Input,
|
|
30
|
+
args: [{ required: true }]
|
|
31
|
+
}], onClick: [{
|
|
32
|
+
type: Output
|
|
33
|
+
}] } });
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29yZS10YWJsZS1hY3Rpb24tYnV0dG9ucy1jb2x1bW4uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZmFsY29uLWxpYi9zcmMvbGliL2NvcmUtdGFibGUvY29yZS10YWJsZS1hY3Rpb24tYnV0dG9ucy1jb2x1bW4vY29yZS10YWJsZS1hY3Rpb24tYnV0dG9ucy1jb2x1bW4uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZmFsY29uLWxpYi9zcmMvbGliL2NvcmUtdGFibGUvY29yZS10YWJsZS1hY3Rpb24tYnV0dG9ucy1jb2x1bW4vY29yZS10YWJsZS1hY3Rpb24tYnV0dG9ucy1jb2x1bW4uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBT3ZFLE1BQU0sT0FBTyxxQ0FBcUM7SUFMbEQ7UUFRWSxZQUFPLEdBQXNCLElBQUksWUFBWSxFQUFFLENBQUM7S0FhM0Q7SUFYQyxPQUFPLENBQUMsR0FBVztRQUNqQixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSSxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDO0lBQ25ELENBQUM7SUFFRCxXQUFXLENBQUMsTUFBVztRQUNyQixJQUFJLE1BQU0sQ0FBQyxNQUFNLEVBQUU7WUFDakIsT0FBTyxNQUFNLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztTQUNqQzthQUFNO1lBQ0wsT0FBTyxJQUFJLENBQUM7U0FDYjtJQUNILENBQUM7K0dBZlUscUNBQXFDO21HQUFyQyxxQ0FBcUMseUpDUGxELDBTQVNBOzs0RkRGYSxxQ0FBcUM7a0JBTGpELFNBQVM7K0JBQ0Usc0NBQXNDOzhCQUtyQixJQUFJO3NCQUE5QixLQUFLO3VCQUFDLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRTtnQkFDRSxNQUFNO3NCQUFoQyxLQUFLO3VCQUFDLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRTtnQkFDZixPQUFPO3NCQUFoQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYXBwLWNvcmUtdGFibGUtYWN0aW9uLWJ1dHRvbnMtY29sdW1uJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vY29yZS10YWJsZS1hY3Rpb24tYnV0dG9ucy1jb2x1bW4uY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2NvcmUtdGFibGUtYWN0aW9uLWJ1dHRvbnMtY29sdW1uLmNvbXBvbmVudC5zY3NzJ10sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDb3JlVGFibGVBY3Rpb25CdXR0b25zQ29sdW1uQ29tcG9uZW50IHtcclxuICBASW5wdXQoeyByZXF1aXJlZDogdHJ1ZSB9KSBkYXRhITogYW55O1xyXG4gIEBJbnB1dCh7IHJlcXVpcmVkOiB0cnVlIH0pIGNvbHVtbiE6IGFueTtcclxuICBAT3V0cHV0KCkgb25DbGljazogRXZlbnRFbWl0dGVyPGFueT4gPSBuZXcgRXZlbnRFbWl0dGVyKCk7XHJcblxyXG4gIGNsaWNrZWQoa2V5OiBzdHJpbmcpIHtcclxuICAgIHRoaXMub25DbGljay5lbWl0KHsgZGF0YTogdGhpcy5kYXRhLCBrZXk6IGtleSB9KTtcclxuICB9XHJcblxyXG4gIGNoZWNrRmlsdGVyKGNvbHVtbjogYW55KSB7XHJcbiAgICBpZiAoY29sdW1uLmZpbHRlcikge1xyXG4gICAgICByZXR1cm4gY29sdW1uLmZpbHRlcih0aGlzLmRhdGEpO1xyXG4gICAgfSBlbHNlIHtcclxuICAgICAgcmV0dXJuIHRydWU7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiIsIjxzcGFuICpuZ0Zvcj1cImxldCBkYXRhIG9mIGNvbHVtbi5kYXRhXCI+XHJcbiAgPHNwYW5cclxuICAgICpuZ0lmPVwiY2hlY2tGaWx0ZXIoZGF0YSlcIlxyXG4gICAgY2xhc3M9XCJpY29uLWNvbG9yIGN1cnNvci1wb2ludGVyIGgtNSBpbmxpbmUtYmxvY2sgaWNvbi1jb2xvciBtLTFcIlxyXG4gICAgKGNsaWNrKT1cImNsaWNrZWQoZGF0YS5rZXkpXCJcclxuICA+XHJcbiAgICA8bmctY29udGFpbmVyICpuZ0NvbXBvbmVudE91dGxldD1cImRhdGEuY29tcG9uZW50XCIgLz5cclxuICA8L3NwYW4+XHJcbjwvc3Bhbj5cclxuIl19
|
package/esm2022/lib/core-table/core-table-action-column/core-table-action-column.component.mjs
ADDED
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "nira-modal";
|
|
4
|
+
import * as i2 from "../../../svg-icon/edit-square-icon/edit-square-icon.component";
|
|
5
|
+
export class CoreTableActionColumnComponent {
|
|
6
|
+
constructor(niraModalService) {
|
|
7
|
+
this.niraModalService = niraModalService;
|
|
8
|
+
}
|
|
9
|
+
openDialog() {
|
|
10
|
+
this.niraModalService.open(this.column.data.component, {
|
|
11
|
+
data: this.data[this.column.data.key],
|
|
12
|
+
});
|
|
13
|
+
}
|
|
14
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CoreTableActionColumnComponent, deps: [{ token: i1.NiraModalService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
15
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CoreTableActionColumnComponent, selector: "app-core-table-action-column", inputs: { data: "data", column: "column" }, ngImport: i0, template: "<span class=\"icon-color h-5 inline-block\">\r\n <edit-square-icon\r\n class=\"cursor-pointer\"\r\n (click)=\"openDialog()\"\r\n ></edit-square-icon>\r\n</span>\r\n", styles: [".icon-color{fill:var(--default-table-action-column-fill-icon-color)}\n"], dependencies: [{ kind: "component", type: i2.EditSquareIconComponent, selector: "edit-square-icon" }] }); }
|
|
16
|
+
}
|
|
17
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CoreTableActionColumnComponent, decorators: [{
|
|
18
|
+
type: Component,
|
|
19
|
+
args: [{ selector: 'app-core-table-action-column', template: "<span class=\"icon-color h-5 inline-block\">\r\n <edit-square-icon\r\n class=\"cursor-pointer\"\r\n (click)=\"openDialog()\"\r\n ></edit-square-icon>\r\n</span>\r\n", styles: [".icon-color{fill:var(--default-table-action-column-fill-icon-color)}\n"] }]
|
|
20
|
+
}], ctorParameters: function () { return [{ type: i1.NiraModalService }]; }, propDecorators: { data: [{
|
|
21
|
+
type: Input,
|
|
22
|
+
args: [{ required: true }]
|
|
23
|
+
}], column: [{
|
|
24
|
+
type: Input,
|
|
25
|
+
args: [{ required: true }]
|
|
26
|
+
}] } });
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29yZS10YWJsZS1hY3Rpb24tY29sdW1uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2ZhbGNvbi1saWIvc3JjL2xpYi9jb3JlLXRhYmxlL2NvcmUtdGFibGUtYWN0aW9uLWNvbHVtbi9jb3JlLXRhYmxlLWFjdGlvbi1jb2x1bW4uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZmFsY29uLWxpYi9zcmMvbGliL2NvcmUtdGFibGUvY29yZS10YWJsZS1hY3Rpb24tY29sdW1uL2NvcmUtdGFibGUtYWN0aW9uLWNvbHVtbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7OztBQVFqRCxNQUFNLE9BQU8sOEJBQThCO0lBR3pDLFlBQW9CLGdCQUFrQztRQUFsQyxxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO0lBQUcsQ0FBQztJQUUxRCxVQUFVO1FBQ1IsSUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUU7WUFDckQsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDO1NBQ3RDLENBQUMsQ0FBQztJQUNMLENBQUM7K0dBVFUsOEJBQThCO21HQUE5Qiw4QkFBOEIsZ0hDUjNDLDhLQU1BOzs0RkRFYSw4QkFBOEI7a0JBTDFDLFNBQVM7K0JBQ0UsOEJBQThCO3VHQUtiLElBQUk7c0JBQTlCLEtBQUs7dUJBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFO2dCQUNFLE1BQU07c0JBQWhDLEtBQUs7dUJBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmlyYU1vZGFsU2VydmljZSB9IGZyb20gJ25pcmEtbW9kYWwnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdhcHAtY29yZS10YWJsZS1hY3Rpb24tY29sdW1uJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2NvcmUtdGFibGUtYWN0aW9uLWNvbHVtbi5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2NvcmUtdGFibGUtYWN0aW9uLWNvbHVtbi5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBDb3JlVGFibGVBY3Rpb25Db2x1bW5Db21wb25lbnQge1xuICBASW5wdXQoeyByZXF1aXJlZDogdHJ1ZSB9KSBkYXRhITogYW55O1xuICBASW5wdXQoeyByZXF1aXJlZDogdHJ1ZSB9KSBjb2x1bW4hOiBhbnk7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgbmlyYU1vZGFsU2VydmljZTogTmlyYU1vZGFsU2VydmljZSkge31cblxuICBvcGVuRGlhbG9nKCkge1xuICAgIHRoaXMubmlyYU1vZGFsU2VydmljZS5vcGVuKHRoaXMuY29sdW1uLmRhdGEuY29tcG9uZW50LCB7XG4gICAgICBkYXRhOiB0aGlzLmRhdGFbdGhpcy5jb2x1bW4uZGF0YS5rZXldLFxuICAgIH0pO1xuICB9XG59XG4iLCI8c3BhbiBjbGFzcz1cImljb24tY29sb3IgaC01IGlubGluZS1ibG9ja1wiPlxyXG4gIDxlZGl0LXNxdWFyZS1pY29uXHJcbiAgICBjbGFzcz1cImN1cnNvci1wb2ludGVyXCJcclxuICAgIChjbGljayk9XCJvcGVuRGlhbG9nKClcIlxyXG4gID48L2VkaXQtc3F1YXJlLWljb24+XHJcbjwvc3Bhbj5cclxuIl19
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { COLUMNS_TYPES } from 'projects/falcon-lib/src/utils/constants';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "nira-snack-bar";
|
|
5
|
+
import * as i2 from "@angular/common";
|
|
6
|
+
import * as i3 from "../core-table-action-buttons-column/core-table-action-buttons-column.component";
|
|
7
|
+
import * as i4 from "../core-table-action-column/core-table-action-column.component";
|
|
8
|
+
import * as i5 from "../core-table-row-selector-column/core-table-row-selector-column.component";
|
|
9
|
+
import * as i6 from "../core-table-shamsi-date/core-table-shamsi-date.component";
|
|
10
|
+
import * as i7 from "../core-table-status-column/core-table-status-column.component";
|
|
11
|
+
import * as i8 from "../../core-number/core-number.component";
|
|
12
|
+
import * as i9 from "../../../utils/directives/table-detail-viewer-manager.directive";
|
|
13
|
+
import * as i10 from "../core-table-status-active-column/core-table-status-active-column.component";
|
|
14
|
+
import * as i11 from "../core-row-pelak/core-row-pelak.component";
|
|
15
|
+
import * as i12 from "../../pipes/persian-digits.pipe";
|
|
16
|
+
export class CoreTableCardManagerComponent {
|
|
17
|
+
get columnsTypes() {
|
|
18
|
+
return COLUMNS_TYPES;
|
|
19
|
+
}
|
|
20
|
+
constructor(niraSnackBar) {
|
|
21
|
+
this.niraSnackBar = niraSnackBar;
|
|
22
|
+
this.rowSelector = undefined;
|
|
23
|
+
this.onColumnClicked = new EventEmitter();
|
|
24
|
+
}
|
|
25
|
+
getSelectorData(data, key) {
|
|
26
|
+
if (key) {
|
|
27
|
+
const split = key.split('.');
|
|
28
|
+
if (split.length === 1) {
|
|
29
|
+
return data[key];
|
|
30
|
+
}
|
|
31
|
+
else {
|
|
32
|
+
let newData = data;
|
|
33
|
+
split.forEach((newKay) => {
|
|
34
|
+
newData = newData[newKay];
|
|
35
|
+
});
|
|
36
|
+
return newData;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
onTextColumnClicked(column, data) {
|
|
41
|
+
if (!column.coptToClipboard)
|
|
42
|
+
return;
|
|
43
|
+
navigator.clipboard
|
|
44
|
+
.writeText(data)
|
|
45
|
+
.then((e) => {
|
|
46
|
+
this.niraSnackBar.show('با موفقیت کپی شد', {
|
|
47
|
+
statusClass: 'success',
|
|
48
|
+
duration: 3000,
|
|
49
|
+
});
|
|
50
|
+
})
|
|
51
|
+
.catch((e) => console.error(e));
|
|
52
|
+
}
|
|
53
|
+
clicked(val) {
|
|
54
|
+
this.onColumnClicked.emit(val);
|
|
55
|
+
}
|
|
56
|
+
combinedData(detailViewer, data) {
|
|
57
|
+
return {
|
|
58
|
+
detailViewer: detailViewer,
|
|
59
|
+
data: data,
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CoreTableCardManagerComponent, deps: [{ token: i1.NiraSnackBarService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
63
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CoreTableCardManagerComponent, selector: "app-core-table-card-manager", inputs: { data: "data", column: "column", rowSelector: "rowSelector" }, outputs: { onColumnClicked: "onColumnClicked" }, ngImport: i0, template: "<container-element [ngSwitch]=\"column.type\">\r\n <ng-content></ng-content>\r\n\r\n <app-core-table-row-selector-column\r\n *ngSwitchCase=\"columnsTypes.ROW_SELECTOR\"\r\n [rowSelector]=\"rowSelector\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-table-row-selector-column>\r\n <app-core-table-status-active-column\r\n *ngSwitchCase=\"columnsTypes.STATUS_ACTIVE\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-table-status-active-column>\r\n <app-core-table-status-column\r\n *ngSwitchCase=\"columnsTypes.STATUS\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-table-status-column>\r\n <app-core-table-action-column\r\n *ngSwitchCase=\"columnsTypes.ACTION\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-table-action-column>\r\n <app-core-table-action-buttons-column\r\n *ngSwitchCase=\"columnsTypes.ACTION_BUTTONS\"\r\n (onClick)=\"clicked($event)\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-table-action-buttons-column>\r\n <app-core-table-shamsi-date\r\n *ngSwitchCase=\"columnsTypes.SHAMSI_DATE\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n >\r\n </app-core-table-shamsi-date>\r\n <app-core-row-pelak\r\n class=\"inline-block\"\r\n *ngSwitchCase=\"columnsTypes.PELAK\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-row-pelak>\r\n <span\r\n *ngSwitchCase=\"columnsTypes.TEXT\"\r\n [ngClass]=\"{ 'cursor-pointer': column.coptToClipboard }\"\r\n (click)=\"onTextColumnClicked(column, data[column.key])\"\r\n tableDetailViewerManager\r\n [detailViewerData]=\"\r\n combinedData(column.detailViewer, data[column.detailViewer?.key])\r\n \"\r\n >{{ data[column.key] | persianDigits }}</span\r\n >\r\n <span\r\n *ngSwitchCase=\"columnsTypes.NUMBER\"\r\n [ngClass]=\"{\r\n 'cursor-pointer': column.copyToClipboard,\r\n green: data[column.key] > 0 && column.canColorfulNumber,\r\n red: data[column.key] < 0 && column.canColorfulNumber\r\n }\"\r\n (click)=\"onTextColumnClicked(column, data[column.key])\"\r\n tableDetailViewerManager\r\n dir=\"ltr\"\r\n [detailViewerData]=\"\r\n combinedData(column.detailViewer, data[column.detailViewer?.key])\r\n \"\r\n ><app-core-number\r\n [number]=\"data[column.key]\"\r\n [type]=\"'number'\"\r\n [canSplitNumbers]=\"true\"\r\n [canShowWordInToolTip]=\"true\"\r\n >\r\n </app-core-number>\r\n </span>\r\n <span *ngSwitchCase=\"columnsTypes.SELECTOR\">\r\n <span\r\n *ngIf=\"data[column.key.split('.')[0]]\"\r\n tableDetailViewerManager\r\n [detailViewerData]=\"\r\n combinedData(\r\n column.detailViewer,\r\n getSelectorData(\r\n data[column.key.split('.')[0]],\r\n column.detailViewer?.key\r\n )\r\n )\r\n \"\r\n >{{\r\n getSelectorData(data[column.key.split(\".\")[0]], column.data.key)\r\n | persianDigits\r\n }}</span\r\n >\r\n </span>\r\n</container-element>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: i3.CoreTableActionButtonsColumnComponent, selector: "app-core-table-action-buttons-column", inputs: ["data", "column"], outputs: ["onClick"] }, { kind: "component", type: i4.CoreTableActionColumnComponent, selector: "app-core-table-action-column", inputs: ["data", "column"] }, { kind: "component", type: i5.CoreTableRowSelectorColumnComponent, selector: "app-core-table-row-selector-column", inputs: ["data", "column", "rowSelector"] }, { kind: "component", type: i6.CoreTableShamsiDateComponent, selector: "app-core-table-shamsi-date", inputs: ["data", "column"], outputs: ["onClick"] }, { kind: "component", type: i7.CoreTableStatusColumnComponent, selector: "app-core-table-status-column", inputs: ["data", "column"] }, { kind: "component", type: i8.CoreNumberComponent, selector: "app-core-number", inputs: ["number", "type", "canSplitNumbers", "canShowWordInToolTip", "canShowIRR"] }, { kind: "directive", type: i9.TableDetailViewerManagerDirective, selector: "[tableDetailViewerManager]", inputs: ["detailViewerData"] }, { kind: "component", type: i10.CoreTableStatusActiveColumnComponent, selector: "app-core-table-status-active-column", inputs: ["data", "column"] }, { kind: "component", type: i11.CoreRowPelakComponent, selector: "app-core-row-pelak", inputs: ["data", "column"] }, { kind: "pipe", type: i12.PersianDigitsPipe, name: "persianDigits" }] }); }
|
|
64
|
+
}
|
|
65
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CoreTableCardManagerComponent, decorators: [{
|
|
66
|
+
type: Component,
|
|
67
|
+
args: [{ selector: 'app-core-table-card-manager', template: "<container-element [ngSwitch]=\"column.type\">\r\n <ng-content></ng-content>\r\n\r\n <app-core-table-row-selector-column\r\n *ngSwitchCase=\"columnsTypes.ROW_SELECTOR\"\r\n [rowSelector]=\"rowSelector\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-table-row-selector-column>\r\n <app-core-table-status-active-column\r\n *ngSwitchCase=\"columnsTypes.STATUS_ACTIVE\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-table-status-active-column>\r\n <app-core-table-status-column\r\n *ngSwitchCase=\"columnsTypes.STATUS\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-table-status-column>\r\n <app-core-table-action-column\r\n *ngSwitchCase=\"columnsTypes.ACTION\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-table-action-column>\r\n <app-core-table-action-buttons-column\r\n *ngSwitchCase=\"columnsTypes.ACTION_BUTTONS\"\r\n (onClick)=\"clicked($event)\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-table-action-buttons-column>\r\n <app-core-table-shamsi-date\r\n *ngSwitchCase=\"columnsTypes.SHAMSI_DATE\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n >\r\n </app-core-table-shamsi-date>\r\n <app-core-row-pelak\r\n class=\"inline-block\"\r\n *ngSwitchCase=\"columnsTypes.PELAK\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-row-pelak>\r\n <span\r\n *ngSwitchCase=\"columnsTypes.TEXT\"\r\n [ngClass]=\"{ 'cursor-pointer': column.coptToClipboard }\"\r\n (click)=\"onTextColumnClicked(column, data[column.key])\"\r\n tableDetailViewerManager\r\n [detailViewerData]=\"\r\n combinedData(column.detailViewer, data[column.detailViewer?.key])\r\n \"\r\n >{{ data[column.key] | persianDigits }}</span\r\n >\r\n <span\r\n *ngSwitchCase=\"columnsTypes.NUMBER\"\r\n [ngClass]=\"{\r\n 'cursor-pointer': column.copyToClipboard,\r\n green: data[column.key] > 0 && column.canColorfulNumber,\r\n red: data[column.key] < 0 && column.canColorfulNumber\r\n }\"\r\n (click)=\"onTextColumnClicked(column, data[column.key])\"\r\n tableDetailViewerManager\r\n dir=\"ltr\"\r\n [detailViewerData]=\"\r\n combinedData(column.detailViewer, data[column.detailViewer?.key])\r\n \"\r\n ><app-core-number\r\n [number]=\"data[column.key]\"\r\n [type]=\"'number'\"\r\n [canSplitNumbers]=\"true\"\r\n [canShowWordInToolTip]=\"true\"\r\n >\r\n </app-core-number>\r\n </span>\r\n <span *ngSwitchCase=\"columnsTypes.SELECTOR\">\r\n <span\r\n *ngIf=\"data[column.key.split('.')[0]]\"\r\n tableDetailViewerManager\r\n [detailViewerData]=\"\r\n combinedData(\r\n column.detailViewer,\r\n getSelectorData(\r\n data[column.key.split('.')[0]],\r\n column.detailViewer?.key\r\n )\r\n )\r\n \"\r\n >{{\r\n getSelectorData(data[column.key.split(\".\")[0]], column.data.key)\r\n | persianDigits\r\n }}</span\r\n >\r\n </span>\r\n</container-element>\r\n" }]
|
|
68
|
+
}], ctorParameters: function () { return [{ type: i1.NiraSnackBarService }]; }, propDecorators: { data: [{
|
|
69
|
+
type: Input,
|
|
70
|
+
args: [{ required: true }]
|
|
71
|
+
}], column: [{
|
|
72
|
+
type: Input,
|
|
73
|
+
args: [{ required: true }]
|
|
74
|
+
}], rowSelector: [{
|
|
75
|
+
type: Input,
|
|
76
|
+
args: [{ required: false }]
|
|
77
|
+
}], onColumnClicked: [{
|
|
78
|
+
type: Output
|
|
79
|
+
}] } });
|
|
80
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-table-card-manager.component.js","sourceRoot":"","sources":["../../../../../../projects/falcon-lib/src/lib/core-table/core-table-card-manager/core-table-card-manager.component.ts","../../../../../../projects/falcon-lib/src/lib/core-table/core-table-card-manager/core-table-card-manager.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvE,OAAO,EAAE,aAAa,EAAE,MAAM,yCAAyC,CAAC;;;;;;;;;;;;;;AAQxE,MAAM,OAAO,6BAA6B;IAMxC,IAAI,YAAY;QACd,OAAO,aAAa,CAAC;IACvB,CAAC;IACD,YAAoB,YAAiC;QAAjC,iBAAY,GAAZ,YAAY,CAAqB;QANzB,gBAAW,GACrC,SAAS,CAAC;QACF,oBAAe,GAAsB,IAAI,YAAY,EAAE,CAAC;IAIV,CAAC;IACzD,eAAe,CAAC,IAAS,EAAE,GAAW;QACpC,IAAI,GAAG,EAAE;YACP,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAC7B,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;gBACtB,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC;aAClB;iBAAM;gBACL,IAAI,OAAO,GAAG,IAAI,CAAC;gBACnB,KAAK,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;oBACvB,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;gBAC5B,CAAC,CAAC,CAAC;gBAEH,OAAO,OAAO,CAAC;aAChB;SACF;IACH,CAAC;IACD,mBAAmB,CAAC,MAAW,EAAE,IAAY;QAC3C,IAAI,CAAC,MAAM,CAAC,eAAe;YAAE,OAAO;QACpC,SAAS,CAAC,SAAS;aAChB,SAAS,CAAC,IAAI,CAAC;aACf,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE;YACV,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,kBAAkB,EAAE;gBACzC,WAAW,EAAE,SAAS;gBACtB,QAAQ,EAAE,IAAI;aACf,CAAC,CAAC;QACL,CAAC,CAAC;aACD,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IACpC,CAAC;IACD,OAAO,CAAC,GAAQ;QACd,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACjC,CAAC;IACD,YAAY,CAAC,YAAiB,EAAE,IAAS;QACvC,OAAO;YACL,YAAY,EAAE,YAAY;YAC1B,IAAI,EAAE,IAAI;SACX,CAAC;IACJ,CAAC;+GA7CU,6BAA6B;mGAA7B,6BAA6B,4LCV1C,+hGA6FA;;4FDnFa,6BAA6B;kBALzC,SAAS;+BACE,6BAA6B;0GAKZ,IAAI;sBAA9B,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBACE,MAAM;sBAAhC,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBACG,WAAW;sBAAtC,KAAK;uBAAC,EAAE,QAAQ,EAAE,KAAK,EAAE;gBAEhB,eAAe;sBAAxB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport { NiraSnackBarService } from 'nira-snack-bar';\r\nimport { COLUMNS_TYPES } from 'projects/falcon-lib/src/utils/constants';\r\nimport { BehaviorSubject } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'app-core-table-card-manager',\r\n  templateUrl: './core-table-card-manager.component.html',\r\n  styleUrls: ['./core-table-card-manager.component.scss'],\r\n})\r\nexport class CoreTableCardManagerComponent {\r\n  @Input({ required: true }) data!: any;\r\n  @Input({ required: true }) column!: any;\r\n  @Input({ required: false }) rowSelector: BehaviorSubject<any> | undefined =\r\n    undefined;\r\n  @Output() onColumnClicked: EventEmitter<any> = new EventEmitter();\r\n  get columnsTypes() {\r\n    return COLUMNS_TYPES;\r\n  }\r\n  constructor(private niraSnackBar: NiraSnackBarService) {}\r\n  getSelectorData(data: any, key: string) {\r\n    if (key) {\r\n      const split = key.split('.');\r\n      if (split.length === 1) {\r\n        return data[key];\r\n      } else {\r\n        let newData = data;\r\n        split.forEach((newKay) => {\r\n          newData = newData[newKay];\r\n        });\r\n\r\n        return newData;\r\n      }\r\n    }\r\n  }\r\n  onTextColumnClicked(column: any, data: string) {\r\n    if (!column.coptToClipboard) return;\r\n    navigator.clipboard\r\n      .writeText(data)\r\n      .then((e) => {\r\n        this.niraSnackBar.show('با موفقیت کپی شد', {\r\n          statusClass: 'success',\r\n          duration: 3000,\r\n        });\r\n      })\r\n      .catch((e) => console.error(e));\r\n  }\r\n  clicked(val: any) {\r\n    this.onColumnClicked.emit(val);\r\n  }\r\n  combinedData(detailViewer: any, data: any) {\r\n    return {\r\n      detailViewer: detailViewer,\r\n      data: data,\r\n    };\r\n  }\r\n}\r\n","<container-element [ngSwitch]=\"column.type\">\r\n  <ng-content></ng-content>\r\n\r\n  <app-core-table-row-selector-column\r\n    *ngSwitchCase=\"columnsTypes.ROW_SELECTOR\"\r\n    [rowSelector]=\"rowSelector\"\r\n    [data]=\"data\"\r\n    [column]=\"column\"\r\n  ></app-core-table-row-selector-column>\r\n  <app-core-table-status-active-column\r\n    *ngSwitchCase=\"columnsTypes.STATUS_ACTIVE\"\r\n    [data]=\"data\"\r\n    [column]=\"column\"\r\n  ></app-core-table-status-active-column>\r\n  <app-core-table-status-column\r\n    *ngSwitchCase=\"columnsTypes.STATUS\"\r\n    [data]=\"data\"\r\n    [column]=\"column\"\r\n  ></app-core-table-status-column>\r\n  <app-core-table-action-column\r\n    *ngSwitchCase=\"columnsTypes.ACTION\"\r\n    [data]=\"data\"\r\n    [column]=\"column\"\r\n  ></app-core-table-action-column>\r\n  <app-core-table-action-buttons-column\r\n    *ngSwitchCase=\"columnsTypes.ACTION_BUTTONS\"\r\n    (onClick)=\"clicked($event)\"\r\n    [data]=\"data\"\r\n    [column]=\"column\"\r\n  ></app-core-table-action-buttons-column>\r\n  <app-core-table-shamsi-date\r\n    *ngSwitchCase=\"columnsTypes.SHAMSI_DATE\"\r\n    [data]=\"data\"\r\n    [column]=\"column\"\r\n  >\r\n  </app-core-table-shamsi-date>\r\n  <app-core-row-pelak\r\n    class=\"inline-block\"\r\n    *ngSwitchCase=\"columnsTypes.PELAK\"\r\n    [data]=\"data\"\r\n    [column]=\"column\"\r\n  ></app-core-row-pelak>\r\n  <span\r\n    *ngSwitchCase=\"columnsTypes.TEXT\"\r\n    [ngClass]=\"{ 'cursor-pointer': column.coptToClipboard }\"\r\n    (click)=\"onTextColumnClicked(column, data[column.key])\"\r\n    tableDetailViewerManager\r\n    [detailViewerData]=\"\r\n      combinedData(column.detailViewer, data[column.detailViewer?.key])\r\n    \"\r\n    >{{ data[column.key] | persianDigits }}</span\r\n  >\r\n  <span\r\n    *ngSwitchCase=\"columnsTypes.NUMBER\"\r\n    [ngClass]=\"{\r\n      'cursor-pointer': column.copyToClipboard,\r\n      green: data[column.key] > 0 && column.canColorfulNumber,\r\n      red: data[column.key] < 0 && column.canColorfulNumber\r\n    }\"\r\n    (click)=\"onTextColumnClicked(column, data[column.key])\"\r\n    tableDetailViewerManager\r\n    dir=\"ltr\"\r\n    [detailViewerData]=\"\r\n      combinedData(column.detailViewer, data[column.detailViewer?.key])\r\n    \"\r\n    ><app-core-number\r\n      [number]=\"data[column.key]\"\r\n      [type]=\"'number'\"\r\n      [canSplitNumbers]=\"true\"\r\n      [canShowWordInToolTip]=\"true\"\r\n    >\r\n    </app-core-number>\r\n  </span>\r\n  <span *ngSwitchCase=\"columnsTypes.SELECTOR\">\r\n    <span\r\n      *ngIf=\"data[column.key.split('.')[0]]\"\r\n      tableDetailViewerManager\r\n      [detailViewerData]=\"\r\n        combinedData(\r\n          column.detailViewer,\r\n          getSelectorData(\r\n            data[column.key.split('.')[0]],\r\n            column.detailViewer?.key\r\n          )\r\n        )\r\n      \"\r\n      >{{\r\n        getSelectorData(data[column.key.split(\".\")[0]], column.data.key)\r\n          | persianDigits\r\n      }}</span\r\n    >\r\n  </span>\r\n</container-element>\r\n"]}
|
package/esm2022/lib/core-table/core-table-column-manager/core-table-column-manager.component.mjs
ADDED
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { COLUMNS_TYPES } from 'projects/falcon-lib/src/utils/constants';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "nira-snack-bar";
|
|
5
|
+
import * as i2 from "@angular/common";
|
|
6
|
+
import * as i3 from "../core-table-action-buttons-column/core-table-action-buttons-column.component";
|
|
7
|
+
import * as i4 from "../core-table-action-column/core-table-action-column.component";
|
|
8
|
+
import * as i5 from "../core-table-row-selector-column/core-table-row-selector-column.component";
|
|
9
|
+
import * as i6 from "../core-table-shamsi-date/core-table-shamsi-date.component";
|
|
10
|
+
import * as i7 from "../core-table-status-column/core-table-status-column.component";
|
|
11
|
+
import * as i8 from "../../core-number/core-number.component";
|
|
12
|
+
import * as i9 from "../../../utils/directives/table-detail-viewer-manager.directive";
|
|
13
|
+
import * as i10 from "../core-table-status-active-column/core-table-status-active-column.component";
|
|
14
|
+
import * as i11 from "../core-row-pelak/core-row-pelak.component";
|
|
15
|
+
import * as i12 from "../core-table-detail-viewer-for-report/core-table-detail-viewer-for-report.component";
|
|
16
|
+
import * as i13 from "../../pipes/persian-digits.pipe";
|
|
17
|
+
export class CoreTableColumnManagerComponent {
|
|
18
|
+
get columnsTypes() {
|
|
19
|
+
return COLUMNS_TYPES;
|
|
20
|
+
}
|
|
21
|
+
constructor(niraSnackBar) {
|
|
22
|
+
this.niraSnackBar = niraSnackBar;
|
|
23
|
+
this.rowSelector = undefined;
|
|
24
|
+
this.onColumnClicked = new EventEmitter();
|
|
25
|
+
}
|
|
26
|
+
getSelectorData(data, key) {
|
|
27
|
+
const split = key.split('.');
|
|
28
|
+
if (split.length === 1) {
|
|
29
|
+
return data[key];
|
|
30
|
+
}
|
|
31
|
+
else {
|
|
32
|
+
let newData = data;
|
|
33
|
+
split.forEach((newKay) => {
|
|
34
|
+
newData = newData[newKay];
|
|
35
|
+
});
|
|
36
|
+
return newData;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
onTextColumnClicked(column, data) {
|
|
40
|
+
if (!column.coptToClipboard)
|
|
41
|
+
return;
|
|
42
|
+
navigator.clipboard
|
|
43
|
+
.writeText(data)
|
|
44
|
+
.then((e) => {
|
|
45
|
+
this.niraSnackBar.show('با موفقیت کپی شد', {
|
|
46
|
+
statusClass: 'success',
|
|
47
|
+
duration: 3000,
|
|
48
|
+
});
|
|
49
|
+
})
|
|
50
|
+
.catch((e) => console.error(e));
|
|
51
|
+
}
|
|
52
|
+
clicked(val) {
|
|
53
|
+
this.onColumnClicked.emit(val);
|
|
54
|
+
}
|
|
55
|
+
combinedData(detailViewer, data) {
|
|
56
|
+
return {
|
|
57
|
+
detailViewer: detailViewer,
|
|
58
|
+
data: data,
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CoreTableColumnManagerComponent, deps: [{ token: i1.NiraSnackBarService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
62
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CoreTableColumnManagerComponent, selector: "app-core-table-column-manager", inputs: { data: "data", column: "column", rowSelector: "rowSelector" }, outputs: { onColumnClicked: "onColumnClicked" }, ngImport: i0, template: "<container-element [ngSwitch]=\"column.type\">\r\n <ng-content></ng-content>\r\n\r\n <app-core-table-row-selector-column\r\n *ngSwitchCase=\"columnsTypes.ROW_SELECTOR\"\r\n [rowSelector]=\"rowSelector\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-table-row-selector-column>\r\n <app-core-table-status-active-column\r\n *ngSwitchCase=\"columnsTypes.STATUS_ACTIVE\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-table-status-active-column>\r\n <app-core-table-status-column\r\n *ngSwitchCase=\"columnsTypes.STATUS\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-table-status-column>\r\n <app-core-table-action-column\r\n *ngSwitchCase=\"columnsTypes.ACTION\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-table-action-column>\r\n <app-core-table-action-buttons-column\r\n *ngSwitchCase=\"columnsTypes.ACTION_BUTTONS\"\r\n (onClick)=\"clicked($event)\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-table-action-buttons-column>\r\n <app-core-table-shamsi-date\r\n *ngSwitchCase=\"columnsTypes.SHAMSI_DATE\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n >\r\n </app-core-table-shamsi-date>\r\n <app-core-row-pelak\r\n *ngSwitchCase=\"columnsTypes.PELAK\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-row-pelak>\r\n <core-table-detail-viewer-for-report\r\n *ngSwitchCase=\"columnsTypes.DETAIL_VIEWER_FOR_REPORT\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></core-table-detail-viewer-for-report>\r\n <span\r\n *ngSwitchCase=\"columnsTypes.TEXT\"\r\n [ngClass]=\"{ 'cursor-pointer': column.coptToClipboard }\"\r\n (click)=\"onTextColumnClicked(column, data[column.key])\"\r\n tableDetailViewerManager\r\n [detailViewerData]=\"\r\n combinedData(column.detailViewer, data[column.detailViewer?.key])\r\n \"\r\n >{{ data[column.key] | persianDigits }}</span\r\n >\r\n <span\r\n *ngSwitchCase=\"columnsTypes.NUMBER\"\r\n [ngClass]=\"{\r\n 'cursor-pointer': column.copyToClipboard,\r\n green: data[column.key] > 0 && column.canColorfulNumber,\r\n red: data[column.key] < 0 && column.canColorfulNumber\r\n }\"\r\n (click)=\"onTextColumnClicked(column, data[column.key])\"\r\n tableDetailViewerManager\r\n dir=\"ltr\"\r\n [detailViewerData]=\"\r\n combinedData(column.detailViewer, data[column.detailViewer?.key])\r\n \"\r\n ><app-core-number\r\n [number]=\"data[column.key]\"\r\n [type]=\"'number'\"\r\n [canSplitNumbers]=\"true\"\r\n [canShowWordInToolTip]=\"true\"\r\n >\r\n </app-core-number>\r\n </span>\r\n\r\n <span *ngSwitchCase=\"columnsTypes.SELECTOR\">\r\n <span\r\n *ngIf=\"data[column.key.split('.')[0]]\"\r\n tableDetailViewerManager\r\n [detailViewerData]=\"\r\n combinedData(\r\n column.detailViewer,\r\n getSelectorData(\r\n data[column.key.split('.')[0]],\r\n column.detailViewer?.key\r\n )\r\n )\r\n \"\r\n >{{\r\n getSelectorData(data[column.key.split(\".\")[0]], column.data.key)\r\n | persianDigits\r\n }}</span\r\n >\r\n </span>\r\n</container-element>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: i3.CoreTableActionButtonsColumnComponent, selector: "app-core-table-action-buttons-column", inputs: ["data", "column"], outputs: ["onClick"] }, { kind: "component", type: i4.CoreTableActionColumnComponent, selector: "app-core-table-action-column", inputs: ["data", "column"] }, { kind: "component", type: i5.CoreTableRowSelectorColumnComponent, selector: "app-core-table-row-selector-column", inputs: ["data", "column", "rowSelector"] }, { kind: "component", type: i6.CoreTableShamsiDateComponent, selector: "app-core-table-shamsi-date", inputs: ["data", "column"], outputs: ["onClick"] }, { kind: "component", type: i7.CoreTableStatusColumnComponent, selector: "app-core-table-status-column", inputs: ["data", "column"] }, { kind: "component", type: i8.CoreNumberComponent, selector: "app-core-number", inputs: ["number", "type", "canSplitNumbers", "canShowWordInToolTip", "canShowIRR"] }, { kind: "directive", type: i9.TableDetailViewerManagerDirective, selector: "[tableDetailViewerManager]", inputs: ["detailViewerData"] }, { kind: "component", type: i10.CoreTableStatusActiveColumnComponent, selector: "app-core-table-status-active-column", inputs: ["data", "column"] }, { kind: "component", type: i11.CoreRowPelakComponent, selector: "app-core-row-pelak", inputs: ["data", "column"] }, { kind: "component", type: i12.CoreTableDetailViewerForReportComponent, selector: "core-table-detail-viewer-for-report", inputs: ["data", "column"] }, { kind: "pipe", type: i13.PersianDigitsPipe, name: "persianDigits" }] }); }
|
|
63
|
+
}
|
|
64
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CoreTableColumnManagerComponent, decorators: [{
|
|
65
|
+
type: Component,
|
|
66
|
+
args: [{ selector: 'app-core-table-column-manager', template: "<container-element [ngSwitch]=\"column.type\">\r\n <ng-content></ng-content>\r\n\r\n <app-core-table-row-selector-column\r\n *ngSwitchCase=\"columnsTypes.ROW_SELECTOR\"\r\n [rowSelector]=\"rowSelector\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-table-row-selector-column>\r\n <app-core-table-status-active-column\r\n *ngSwitchCase=\"columnsTypes.STATUS_ACTIVE\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-table-status-active-column>\r\n <app-core-table-status-column\r\n *ngSwitchCase=\"columnsTypes.STATUS\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-table-status-column>\r\n <app-core-table-action-column\r\n *ngSwitchCase=\"columnsTypes.ACTION\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-table-action-column>\r\n <app-core-table-action-buttons-column\r\n *ngSwitchCase=\"columnsTypes.ACTION_BUTTONS\"\r\n (onClick)=\"clicked($event)\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-table-action-buttons-column>\r\n <app-core-table-shamsi-date\r\n *ngSwitchCase=\"columnsTypes.SHAMSI_DATE\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n >\r\n </app-core-table-shamsi-date>\r\n <app-core-row-pelak\r\n *ngSwitchCase=\"columnsTypes.PELAK\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></app-core-row-pelak>\r\n <core-table-detail-viewer-for-report\r\n *ngSwitchCase=\"columnsTypes.DETAIL_VIEWER_FOR_REPORT\"\r\n [data]=\"data\"\r\n [column]=\"column\"\r\n ></core-table-detail-viewer-for-report>\r\n <span\r\n *ngSwitchCase=\"columnsTypes.TEXT\"\r\n [ngClass]=\"{ 'cursor-pointer': column.coptToClipboard }\"\r\n (click)=\"onTextColumnClicked(column, data[column.key])\"\r\n tableDetailViewerManager\r\n [detailViewerData]=\"\r\n combinedData(column.detailViewer, data[column.detailViewer?.key])\r\n \"\r\n >{{ data[column.key] | persianDigits }}</span\r\n >\r\n <span\r\n *ngSwitchCase=\"columnsTypes.NUMBER\"\r\n [ngClass]=\"{\r\n 'cursor-pointer': column.copyToClipboard,\r\n green: data[column.key] > 0 && column.canColorfulNumber,\r\n red: data[column.key] < 0 && column.canColorfulNumber\r\n }\"\r\n (click)=\"onTextColumnClicked(column, data[column.key])\"\r\n tableDetailViewerManager\r\n dir=\"ltr\"\r\n [detailViewerData]=\"\r\n combinedData(column.detailViewer, data[column.detailViewer?.key])\r\n \"\r\n ><app-core-number\r\n [number]=\"data[column.key]\"\r\n [type]=\"'number'\"\r\n [canSplitNumbers]=\"true\"\r\n [canShowWordInToolTip]=\"true\"\r\n >\r\n </app-core-number>\r\n </span>\r\n\r\n <span *ngSwitchCase=\"columnsTypes.SELECTOR\">\r\n <span\r\n *ngIf=\"data[column.key.split('.')[0]]\"\r\n tableDetailViewerManager\r\n [detailViewerData]=\"\r\n combinedData(\r\n column.detailViewer,\r\n getSelectorData(\r\n data[column.key.split('.')[0]],\r\n column.detailViewer?.key\r\n )\r\n )\r\n \"\r\n >{{\r\n getSelectorData(data[column.key.split(\".\")[0]], column.data.key)\r\n | persianDigits\r\n }}</span\r\n >\r\n </span>\r\n</container-element>\r\n" }]
|
|
67
|
+
}], ctorParameters: function () { return [{ type: i1.NiraSnackBarService }]; }, propDecorators: { data: [{
|
|
68
|
+
type: Input,
|
|
69
|
+
args: [{ required: true }]
|
|
70
|
+
}], column: [{
|
|
71
|
+
type: Input,
|
|
72
|
+
args: [{ required: true }]
|
|
73
|
+
}], rowSelector: [{
|
|
74
|
+
type: Input,
|
|
75
|
+
args: [{ required: false }]
|
|
76
|
+
}], onColumnClicked: [{
|
|
77
|
+
type: Output
|
|
78
|
+
}] } });
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-table-column-manager.component.js","sourceRoot":"","sources":["../../../../../../projects/falcon-lib/src/lib/core-table/core-table-column-manager/core-table-column-manager.component.ts","../../../../../../projects/falcon-lib/src/lib/core-table/core-table-column-manager/core-table-column-manager.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvE,OAAO,EAAE,aAAa,EAAE,MAAM,yCAAyC,CAAC;;;;;;;;;;;;;;;AAQxE,MAAM,OAAO,+BAA+B;IAM1C,IAAI,YAAY;QACd,OAAO,aAAa,CAAC;IACvB,CAAC;IACD,YAAoB,YAAiC;QAAjC,iBAAY,GAAZ,YAAY,CAAqB;QANzB,gBAAW,GACrC,SAAS,CAAC;QACF,oBAAe,GAAsB,IAAI,YAAY,EAAE,CAAC;IAIV,CAAC;IACzD,eAAe,CAAC,IAAS,EAAE,GAAW;QACpC,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC7B,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;YACtB,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC;SAClB;aAAM;YACL,IAAI,OAAO,GAAG,IAAI,CAAC;YACnB,KAAK,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;gBACvB,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;YAC5B,CAAC,CAAC,CAAC;YACH,OAAO,OAAO,CAAC;SAChB;IACH,CAAC;IACD,mBAAmB,CAAC,MAAW,EAAE,IAAY;QAC3C,IAAI,CAAC,MAAM,CAAC,eAAe;YAAE,OAAO;QACpC,SAAS,CAAC,SAAS;aAChB,SAAS,CAAC,IAAI,CAAC;aACf,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE;YACV,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,kBAAkB,EAAE;gBACzC,WAAW,EAAE,SAAS;gBACtB,QAAQ,EAAE,IAAI;aACf,CAAC,CAAC;QACL,CAAC,CAAC;aACD,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IACpC,CAAC;IACD,OAAO,CAAC,GAAQ;QACd,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACjC,CAAC;IACD,YAAY,CAAC,YAAiB,EAAE,IAAS;QACvC,OAAO;YACL,YAAY,EAAE,YAAY;YAC1B,IAAI,EAAE,IAAI;SACX,CAAC;IACJ,CAAC;+GA1CU,+BAA+B;mGAA/B,+BAA+B,8LCV5C,6sGAkGA;;4FDxFa,+BAA+B;kBAL3C,SAAS;+BACE,+BAA+B;0GAKd,IAAI;sBAA9B,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBACE,MAAM;sBAAhC,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBACG,WAAW;sBAAtC,KAAK;uBAAC,EAAE,QAAQ,EAAE,KAAK,EAAE;gBAEhB,eAAe;sBAAxB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport { NiraSnackBarService } from 'nira-snack-bar';\r\nimport { COLUMNS_TYPES } from 'projects/falcon-lib/src/utils/constants';\r\nimport { BehaviorSubject } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'app-core-table-column-manager',\r\n  templateUrl: './core-table-column-manager.component.html',\r\n  styleUrls: ['./core-table-column-manager.component.scss'],\r\n})\r\nexport class CoreTableColumnManagerComponent {\r\n  @Input({ required: true }) data!: any;\r\n  @Input({ required: true }) column!: any;\r\n  @Input({ required: false }) rowSelector: BehaviorSubject<any> | undefined =\r\n    undefined;\r\n  @Output() onColumnClicked: EventEmitter<any> = new EventEmitter();\r\n  get columnsTypes() {\r\n    return COLUMNS_TYPES;\r\n  }\r\n  constructor(private niraSnackBar: NiraSnackBarService) {}\r\n  getSelectorData(data: any, key: string) {\r\n    const split = key.split('.');\r\n    if (split.length === 1) {\r\n      return data[key];\r\n    } else {\r\n      let newData = data;\r\n      split.forEach((newKay) => {\r\n        newData = newData[newKay];\r\n      });\r\n      return newData;\r\n    }\r\n  }\r\n  onTextColumnClicked(column: any, data: string) {\r\n    if (!column.coptToClipboard) return;\r\n    navigator.clipboard\r\n      .writeText(data)\r\n      .then((e) => {\r\n        this.niraSnackBar.show('با موفقیت کپی شد', {\r\n          statusClass: 'success',\r\n          duration: 3000,\r\n        });\r\n      })\r\n      .catch((e) => console.error(e));\r\n  }\r\n  clicked(val: any) {\r\n    this.onColumnClicked.emit(val);\r\n  }\r\n  combinedData(detailViewer: any, data: any) {\r\n    return {\r\n      detailViewer: detailViewer,\r\n      data: data,\r\n    };\r\n  }\r\n}\r\n","<container-element [ngSwitch]=\"column.type\">\r\n  <ng-content></ng-content>\r\n\r\n  <app-core-table-row-selector-column\r\n    *ngSwitchCase=\"columnsTypes.ROW_SELECTOR\"\r\n    [rowSelector]=\"rowSelector\"\r\n    [data]=\"data\"\r\n    [column]=\"column\"\r\n  ></app-core-table-row-selector-column>\r\n  <app-core-table-status-active-column\r\n    *ngSwitchCase=\"columnsTypes.STATUS_ACTIVE\"\r\n    [data]=\"data\"\r\n    [column]=\"column\"\r\n  ></app-core-table-status-active-column>\r\n  <app-core-table-status-column\r\n    *ngSwitchCase=\"columnsTypes.STATUS\"\r\n    [data]=\"data\"\r\n    [column]=\"column\"\r\n  ></app-core-table-status-column>\r\n  <app-core-table-action-column\r\n    *ngSwitchCase=\"columnsTypes.ACTION\"\r\n    [data]=\"data\"\r\n    [column]=\"column\"\r\n  ></app-core-table-action-column>\r\n  <app-core-table-action-buttons-column\r\n    *ngSwitchCase=\"columnsTypes.ACTION_BUTTONS\"\r\n    (onClick)=\"clicked($event)\"\r\n    [data]=\"data\"\r\n    [column]=\"column\"\r\n  ></app-core-table-action-buttons-column>\r\n  <app-core-table-shamsi-date\r\n    *ngSwitchCase=\"columnsTypes.SHAMSI_DATE\"\r\n    [data]=\"data\"\r\n    [column]=\"column\"\r\n  >\r\n  </app-core-table-shamsi-date>\r\n  <app-core-row-pelak\r\n    *ngSwitchCase=\"columnsTypes.PELAK\"\r\n    [data]=\"data\"\r\n    [column]=\"column\"\r\n  ></app-core-row-pelak>\r\n  <core-table-detail-viewer-for-report\r\n    *ngSwitchCase=\"columnsTypes.DETAIL_VIEWER_FOR_REPORT\"\r\n    [data]=\"data\"\r\n    [column]=\"column\"\r\n  ></core-table-detail-viewer-for-report>\r\n  <span\r\n    *ngSwitchCase=\"columnsTypes.TEXT\"\r\n    [ngClass]=\"{ 'cursor-pointer': column.coptToClipboard }\"\r\n    (click)=\"onTextColumnClicked(column, data[column.key])\"\r\n    tableDetailViewerManager\r\n    [detailViewerData]=\"\r\n      combinedData(column.detailViewer, data[column.detailViewer?.key])\r\n    \"\r\n    >{{ data[column.key] | persianDigits }}</span\r\n  >\r\n  <span\r\n    *ngSwitchCase=\"columnsTypes.NUMBER\"\r\n    [ngClass]=\"{\r\n      'cursor-pointer': column.copyToClipboard,\r\n      green: data[column.key] > 0 && column.canColorfulNumber,\r\n      red: data[column.key] < 0 && column.canColorfulNumber\r\n    }\"\r\n    (click)=\"onTextColumnClicked(column, data[column.key])\"\r\n    tableDetailViewerManager\r\n    dir=\"ltr\"\r\n    [detailViewerData]=\"\r\n      combinedData(column.detailViewer, data[column.detailViewer?.key])\r\n    \"\r\n    ><app-core-number\r\n      [number]=\"data[column.key]\"\r\n      [type]=\"'number'\"\r\n      [canSplitNumbers]=\"true\"\r\n      [canShowWordInToolTip]=\"true\"\r\n    >\r\n    </app-core-number>\r\n  </span>\r\n\r\n  <span *ngSwitchCase=\"columnsTypes.SELECTOR\">\r\n    <span\r\n      *ngIf=\"data[column.key.split('.')[0]]\"\r\n      tableDetailViewerManager\r\n      [detailViewerData]=\"\r\n        combinedData(\r\n          column.detailViewer,\r\n          getSelectorData(\r\n            data[column.key.split('.')[0]],\r\n            column.detailViewer?.key\r\n          )\r\n        )\r\n      \"\r\n      >{{\r\n        getSelectorData(data[column.key.split(\".\")[0]], column.data.key)\r\n          | persianDigits\r\n      }}</span\r\n    >\r\n  </span>\r\n</container-element>\r\n"]}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { DetailViewers } from '../../falconTypes';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
import * as i2 from "../../../utils/directives/detail-viewer-manager.directive";
|
|
6
|
+
export class CoreTableDetailViewerForReportComponent {
|
|
7
|
+
get detailViewers() {
|
|
8
|
+
return DetailViewers;
|
|
9
|
+
}
|
|
10
|
+
ngOnInit() { }
|
|
11
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CoreTableDetailViewerForReportComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
12
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CoreTableDetailViewerForReportComponent, selector: "core-table-detail-viewer-for-report", inputs: { data: "data", column: "column" }, ngImport: i0, template: "<ng-container [ngSwitch]=\"data.refType\">\r\n <span\r\n *ngSwitchCase=\"'MANIFEST'\"\r\n detailViewerManager\r\n [detailViewerName]=\"detailViewers.MANIFEST\"\r\n [detailViewerData]=\"data.refCode\"\r\n >{{ data.refCode }}</span\r\n >\r\n <span\r\n *ngSwitchCase=\"'BILL'\"\r\n detailViewerManager\r\n [detailViewerName]=\"detailViewers.BILL\"\r\n [detailViewerData]=\"data.refCode\"\r\n >{{ data.refCode }}</span\r\n >\r\n <span *ngSwitchDefault>{{ data.refCode }}</span>\r\n</ng-container>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i1.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "directive", type: i2.DetailViewerManagerDirective, selector: "[detailViewerManager]", inputs: ["detailViewerData", "detailViewerName"] }] }); }
|
|
13
|
+
}
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CoreTableDetailViewerForReportComponent, decorators: [{
|
|
15
|
+
type: Component,
|
|
16
|
+
args: [{ selector: 'core-table-detail-viewer-for-report', template: "<ng-container [ngSwitch]=\"data.refType\">\r\n <span\r\n *ngSwitchCase=\"'MANIFEST'\"\r\n detailViewerManager\r\n [detailViewerName]=\"detailViewers.MANIFEST\"\r\n [detailViewerData]=\"data.refCode\"\r\n >{{ data.refCode }}</span\r\n >\r\n <span\r\n *ngSwitchCase=\"'BILL'\"\r\n detailViewerManager\r\n [detailViewerName]=\"detailViewers.BILL\"\r\n [detailViewerData]=\"data.refCode\"\r\n >{{ data.refCode }}</span\r\n >\r\n <span *ngSwitchDefault>{{ data.refCode }}</span>\r\n</ng-container>\r\n" }]
|
|
17
|
+
}], propDecorators: { data: [{
|
|
18
|
+
type: Input,
|
|
19
|
+
args: [{ required: true }]
|
|
20
|
+
}], column: [{
|
|
21
|
+
type: Input,
|
|
22
|
+
args: [{ required: true }]
|
|
23
|
+
}] } });
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29yZS10YWJsZS1kZXRhaWwtdmlld2VyLWZvci1yZXBvcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZmFsY29uLWxpYi9zcmMvbGliL2NvcmUtdGFibGUvY29yZS10YWJsZS1kZXRhaWwtdmlld2VyLWZvci1yZXBvcnQvY29yZS10YWJsZS1kZXRhaWwtdmlld2VyLWZvci1yZXBvcnQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZmFsY29uLWxpYi9zcmMvbGliL2NvcmUtdGFibGUvY29yZS10YWJsZS1kZXRhaWwtdmlld2VyLWZvci1yZXBvcnQvY29yZS10YWJsZS1kZXRhaWwtdmlld2VyLWZvci1yZXBvcnQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG1CQUFtQixDQUFDOzs7O0FBT2xELE1BQU0sT0FBTyx1Q0FBdUM7SUFJbEQsSUFBSSxhQUFhO1FBQ2YsT0FBTyxhQUFhLENBQUM7SUFDdkIsQ0FBQztJQUVELFFBQVEsS0FBVSxDQUFDOytHQVJSLHVDQUF1QzttR0FBdkMsdUNBQXVDLHVIQ1JwRCxxaEJBaUJBOzs0RkRUYSx1Q0FBdUM7a0JBTG5ELFNBQVM7K0JBQ0UscUNBQXFDOzhCQUtwQixJQUFJO3NCQUE5QixLQUFLO3VCQUFDLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRTtnQkFDRSxNQUFNO3NCQUFoQyxLQUFLO3VCQUFDLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRGV0YWlsVmlld2VycyB9IGZyb20gJy4uLy4uL2ZhbGNvblR5cGVzJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnY29yZS10YWJsZS1kZXRhaWwtdmlld2VyLWZvci1yZXBvcnQnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9jb3JlLXRhYmxlLWRldGFpbC12aWV3ZXItZm9yLXJlcG9ydC5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vY29yZS10YWJsZS1kZXRhaWwtdmlld2VyLWZvci1yZXBvcnQuY29tcG9uZW50LnNjc3MnXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIENvcmVUYWJsZURldGFpbFZpZXdlckZvclJlcG9ydENvbXBvbmVudCB7XHJcbiAgQElucHV0KHsgcmVxdWlyZWQ6IHRydWUgfSkgZGF0YSE6IGFueTtcclxuICBASW5wdXQoeyByZXF1aXJlZDogdHJ1ZSB9KSBjb2x1bW4hOiBhbnk7XHJcblxyXG4gIGdldCBkZXRhaWxWaWV3ZXJzKCkge1xyXG4gICAgcmV0dXJuIERldGFpbFZpZXdlcnM7XHJcbiAgfVxyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHt9XHJcbn1cclxuIiwiPG5nLWNvbnRhaW5lciBbbmdTd2l0Y2hdPVwiZGF0YS5yZWZUeXBlXCI+XHJcbiAgPHNwYW5cclxuICAgICpuZ1N3aXRjaENhc2U9XCInTUFOSUZFU1QnXCJcclxuICAgIGRldGFpbFZpZXdlck1hbmFnZXJcclxuICAgIFtkZXRhaWxWaWV3ZXJOYW1lXT1cImRldGFpbFZpZXdlcnMuTUFOSUZFU1RcIlxyXG4gICAgW2RldGFpbFZpZXdlckRhdGFdPVwiZGF0YS5yZWZDb2RlXCJcclxuICAgID57eyBkYXRhLnJlZkNvZGUgfX08L3NwYW5cclxuICA+XHJcbiAgPHNwYW5cclxuICAgICpuZ1N3aXRjaENhc2U9XCInQklMTCdcIlxyXG4gICAgZGV0YWlsVmlld2VyTWFuYWdlclxyXG4gICAgW2RldGFpbFZpZXdlck5hbWVdPVwiZGV0YWlsVmlld2Vycy5CSUxMXCJcclxuICAgIFtkZXRhaWxWaWV3ZXJEYXRhXT1cImRhdGEucmVmQ29kZVwiXHJcbiAgICA+e3sgZGF0YS5yZWZDb2RlIH19PC9zcGFuXHJcbiAgPlxyXG4gIDxzcGFuICpuZ1N3aXRjaERlZmF1bHQ+e3sgZGF0YS5yZWZDb2RlIH19PC9zcGFuPlxyXG48L25nLWNvbnRhaW5lcj5cclxuIl19
|