@libs-ui/components-table 0.2.184 → 0.2.185
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/interfaces/table-config.interface.mjs +1 -1
- package/esm2022/pipes/calculator-column.pipe.mjs +53 -25
- package/esm2022/table.component.mjs +4 -3
- package/fesm2022/libs-ui-components-table.mjs +56 -27
- package/fesm2022/libs-ui-components-table.mjs.map +1 -1
- package/interfaces/table-config.interface.d.ts +1 -1
- package/package.json +23 -23
- package/pipes/calculator-column.pipe.d.ts +3 -0
- package/table.component.d.ts +2 -1
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY29uZmlnLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMtdWkvY29tcG9uZW50cy90YWJsZS9zcmMvaW50ZXJmYWNlcy90YWJsZS1jb25maWcuaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55ICovXG5pbXBvcnQgeyBUWVBFX1NPUlRfVFlQRSB9IGZyb20gXCJAbGlicy11aS9jb21wb25lbnRzLWJ1dHRvbnMtc29ydFwiO1xuaW1wb3J0IHsgSVBvcG92ZXIsIFRZUEVfUE9QT1ZFUl9UWVBFIH0gZnJvbSBcIkBsaWJzLXVpL2NvbXBvbmVudHMtcG9wb3ZlclwiO1xuaW1wb3J0IHsgVFlQRV9GVU5DVElPTiwgVFlQRV9PQkpFQ1QgfSBmcm9tIFwiQGxpYnMtdWkvaW50ZXJmYWNlcy10eXBlc1wiO1xuaW1wb3J0IHsgSVRhYmxlVGVtcGxhdGVDb25maWcgfSBmcm9tIFwiLi90ZW1wbGF0ZS1jb25maWcuaW50ZXJmYWNlXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSVRhYmxlSGVhZGVyQ29uZmlnIHtcbiAgbmdTdHlsZT86IFRZUEVfT0JKRUNUO1xuICBrZWVwV2lkdGhJc1B4Q29sdW1uSWZUYWJsZVdpZHRoR3JhbmRUb3RhbENvbHVtbnNIZWFkZXI/OiBib29sZWFuO1xuICBuZ0NsYXNzPzogVFlQRV9PQkpFQ1Q7XG4gIHR5cGU/OiBUWVBFX1BPUE9WRVJfVFlQRTtcbiAgbGFiZWw/OiBzdHJpbmcgfCBUWVBFX09CSkVDVDtcbiAgbGFiZWxDb25maWc/OiBJUG9wb3ZlcjsgLy8gY29uZmlnIGRhdGFWaWV3IGtow7RuZyBjw7MgdMOhYyBk4bulbmcsIHPhu60gZOG7pW5nIGxhYmVsIMSR4buDIGNvbmZpZy5cbiAgcGFyc2VWYWx1ZT86IFRZUEVfRlVOQ1RJT047IC8vIGTDuW5nIGtoaSBtdeG7kW4gY3VzdG9tIGxhYmVsIGhlYWRlclxuICB0b29sdGlwT3RoZXI/OiBJUG9wb3ZlcjsgLy8gRMO5bmcga2hpIGhlYWRlciB0YWJsZSBjw7MgdG9vbHRpcFxuICBoYXNDaGVja2JveD86IGJvb2xlYW47IC8vIETDuW5nIGtoaSBjw7MgY2hlY2tib3hcbiAgaGFzQ2hlY2tib3hBbGw/OiBib29sZWFuOyAvLyBEw7luZyBraGkgY8OzIGNoZWNrYm94XG4gIGNoZWNrYm94QWxpZ25DZW50ZXI/OiBib29sZWFuO1xuICBjb250ZW50SGVhZGVyQWxpZ25DZW50ZXI/OiBib29sZWFuOyAvLyBkw7luZyDEkeG7gyBjxINuIGdp4buvYSBu4buZaSBkdW5nIGtoaSBjw7MgdGjDqm0gdG9vbHRpcE90aGVyXG4gIGNvbnRlbnRIZWFkZXJKdXN0aWZ5Q29udGVudEVuZD86IGJvb2xlYW47IC8vIGTDuW5nIMSR4buDIGPEg24gbuG7mWkgZHVuZyB2ZSBiZW4gcGhhaVxuICBpZ25vcmVCb3JkZXJSaWdodD86IGJvb2xlYW47XG4gIGhhc1NvcnQ/OiBib29sZWFuO1xuICBvcmRlcmJ5Pzogc3RyaW5nOyAvLyBvcmRlciBjb3QgdGhlbyB0cnVvbmcgbmFvLlxuICBwYWRkaW5nTGVmdFJpZ2h0SGVhZGVyQ29udGFpbmVyPzogc3RyaW5nOyAvLyBwYWRkaW5nIGNobyBoZWFkZXJcbiAgaWdub3JlUHlEZWZhdWx0PzogYm9vbGVhbjsgLy8gdOG6r3QgcGFkZGluZyBkZWZhdWx0IGhlYWRlclxuICB0ZW1wbGF0ZUNzc1dyYXBwZXI/OiBzdHJpbmc7XG4gIHRlbXBsYXRlQ3NzV3JhcHBlckhvc3Q/OiBzdHJpbmc7XG4gIGNvbFRlbXBsYXRlQ29uZmlnPzogQXJyYXk8SVRhYmxlVGVtcGxhdGVDb25maWc+O1xuICBzb3J0SWdub3JlVG9vbHRpcENvbnRlbnQ/OiBib29sZWFuO1xuICBzb3J0VG9vbHRpcENvbnRlbnRBc2M/OiBzdHJpbmc7XG4gIHNvcnRUb29sdGlwQ29udGVudERlc2M/OiBzdHJpbmc7XG4gIHpJbmRleFRvb2x0aXBTb3J0PzogbnVtYmVyO1xuICBkZWZhdWx0TW9kZT86IFRZUEVfU09SVF9UWVBFO1xuICBsYWJlbERlc2NyaXB0aW9uPzoge1xuICAgIGNvbnRlbnQ6IHN0cmluZztcbiAgICBjbGFzc0luY2x1ZGU/OiBzdHJpbmc7XG4gIH07XG4gIHJvd3NDb25maWc/OiB7XG4gICAgY2xhc3NDb250YWluZXJSb3dzPzogc3RyaW5nO1xuICAgIHJvd3M6IEFycmF5PHsgY2xhc3NSb3c/OiBzdHJpbmc7IGNvbHM6IEFycmF5PElUYWJsZUhlYWRlckNvbmZpZ0NvbD4gfT47XG4gIH07XG4gIGNoZWNrYm94Q2xhc3NJbmNsdWRlPzogc3RyaW5nO1xuICBjaGVja0NvbmRpdGlvbkNoZWNrQm94SGlkZGVuPzogVFlQRV9GVU5DVElPTjxib29sZWFuPjsgLy8gRMO5bmcga2hpIGPDsyBjaGVja2JveCBuaMawbmcgY8OzIMSRaeG7gXUga2nhu4duIGLhu5Ugc3VuZyDEkeG7gyDhuqluIMSRaSBjaGVja2JveCBj4bunYSAxIHbDoGkgaXRlbVxuICBjaGVja2JveEFsbENsYXNzSW5jbHVkZT86IHN0cmluZztcbiAgaXNTaG93SW5kZXhPblJvdz86IGJvb2xlYW47XG4gIGNsYXNzSW5jbHVkZUluZGV4T25Sb3c/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSVRhYmxlSGVhZGVyQ29uZmlnQ29sIHtcbiAgbmdTdHlsZT86IFRZUEVfT0JKRUNUO1xuICBuZ0NsYXNzPzogVFlQRV9PQkpFQ1Q7XG4gIHR5cGU/OiBUWVBFX1BPUE9WRVJfVFlQRTtcbiAgbGFiZWw/OiBzdHJpbmcgfCBUWVBFX09CSkVDVDtcbiAgbGFiZWxDb25maWc/OiBJUG9wb3ZlcjsgLy8gY29uZmlnIGRhdGFWaWV3IGtow7RuZyBjw7MgdMOhYyBk4bulbmcsIHPhu60gZOG7pW5nIGxhYmVsIMSR4buDIGNvbmZpZy5cbiAgcGFyc2VWYWx1ZT86IFRZUEVfRlVOQ1RJT047IC8vIGTDuW5nIGtoaSBtdeG7kW4gY3VzdG9tIGxhYmVsIGhlYWRlclxuICB0b29sdGlwT3RoZXI/OiBJUG9wb3ZlcjsgLy8gRMO5bmcga2hpIGhlYWRlciB0YWJsZSBjw7MgdG9vbHRpcFxuICBjb250ZW50SGVhZGVyQWxpZ25DZW50ZXI/OiBib29sZWFuOyAvLyBkw7luZyDEkeG7gyBjxINuIGdp4buvYSBu4buZaSBkdW5nIGtoaSBjw7MgdGjDqm0gdG9vbHRpcE90aGVyXG4gIGNvbnRlbnRIZWFkZXJKdXN0aWZ5Q29udGVudEVuZD86IGJvb2xlYW47IC8vIGTDuW5nIMSR4buDIGPEg24gbuG7mWkgZHVuZyB2ZSBiZW4gcGhhaVxuICBoYXNTb3J0PzogYm9vbGVhbjtcbiAgb3JkZXJieT86IHN0cmluZzsgLy8gb3JkZXIgY290IHRoZW8gdHJ1b25nIG5hby5cbiAgc29ydElnbm9yZVRvb2x0aXBDb250ZW50PzogYm9vbGVhbjtcbiAgc29ydFRvb2x0aXBDb250ZW50QXNjPzogc3RyaW5nO1xuICBzb3J0VG9vbHRpcENvbnRlbnREZXNjPzogc3RyaW5nO1xuICBkZWZhdWx0TW9kZT86IFRZUEVfU09SVF9UWVBFO1xuICBsYWJlbERlc2NyaXB0aW9uPzoge1xuICAgIGNvbnRlbnQ6IHN0cmluZztcbiAgICBjbGFzc0luY2x1ZGU/OiBzdHJpbmc7XG4gIH07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUNvbmZpZ1RlbXBsYXRlSXRlbUNvbGxhcHNlRXhwYW5kIHtcbiAgZmllbGRHZXREYXRhRXhwYW5kPzogc3RyaW5nO1xuICBjc3NXcmFwcGVyPzogc3RyaW5nO1xuICB0ZW1wbGF0ZUNzc1dyYXBwZXI/OiBzdHJpbmc7XG4gIGNvbFRlbXBsYXRlQ29uZmlnPzogQXJyYXk8SVRhYmxlVGVtcGxhdGVDb25maWc+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElUYWJsZUZvb3RlckNvbmZpZyB7XG4gIGlnbm9yZUJvcmRlclJpZ2h0PzogYm9vbGVhbjtcbiAgbmdTdHlsZT86IFRZUEVfT0JKRUNUO1xuICBuZ0NsYXNzPzogVFlQRV9PQkpFQ1Q7XG4gIHRlbXBsYXRlQ3NzV3JhcHBlcj86IHN0cmluZztcbiAgY29sVGVtcGxhdGVDb25maWc/OiBBcnJheTxJVGFibGVUZW1wbGF0ZUNvbmZpZz47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUNvbmZpZ1NlbGVjdE1vcmVJdGVtIHtcbiAga2V5UGVyUGFnZT86IHN0cmluZztcbiAgcGFnaW5nTnVtYmVyPzogYm9vbGVhbjtcbiAgZ2V0VmFsdWU6IChpdGVtOiBhbnkpID0+IHN0cmluZzsgLy8gbMOgIGjDoG0gZ2V0IHZhbHVlIGPhu6dhIGxpc3RWaWV3IHR5cGUgdGV4dFxuICBsaXN0T3B0aW9uOiBBcnJheTx7IGtleTogc3RyaW5nOyBsYWJlbDogc3RyaW5nOyB9Pjtcbn0iXX0=
|
|
@@ -5,35 +5,63 @@ export class LibsUiTableCalculatorColumnPipe {
|
|
|
5
5
|
if (!header?.ngStyle) {
|
|
6
6
|
return undefined;
|
|
7
7
|
}
|
|
8
|
-
const
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
offsetWidth -= widthMax;
|
|
19
|
-
return 0;
|
|
20
|
-
}
|
|
21
|
-
return widthMax;
|
|
22
|
-
};
|
|
23
|
-
let totalWidthHeader = headerLeftConfig?.reduce((acc, curr) => acc + getWidthOfStyle(curr), 0) ?? 0;
|
|
24
|
-
if (headerRightConfig?.length) {
|
|
25
|
-
totalWidthHeader = headerRightConfig?.reduce((acc, curr) => acc + getWidthOfStyle(curr), totalWidthHeader) ?? 0;
|
|
8
|
+
const mixHeaderConfig = [...(headerLeftConfig || []), ...(headerRightConfig || [])];
|
|
9
|
+
let totalPxWidthHeader = mixHeaderConfig.reduce((acc, curr) => acc + this.getWidthPxOfStyle(curr), 0);
|
|
10
|
+
const totalPercentWidthHeader = mixHeaderConfig.reduce((acc, curr) => acc + this.getWidthPercentOfStyle(curr), 0);
|
|
11
|
+
const totalWidthIsPxColumnIfTableWidthGrandTotalColumnsHeader = mixHeaderConfig.reduce((acc, curr) => acc + (curr.keepWidthIsPxColumnIfTableWidthGrandTotalColumnsHeader ? this.getWidthPxOfStyle(curr) : 0), 0);
|
|
12
|
+
if (mixHeaderConfig.some(header => header.isShowIndexOnRow)) {
|
|
13
|
+
offsetWidth -= 50;
|
|
14
|
+
}
|
|
15
|
+
if (totalWidthIsPxColumnIfTableWidthGrandTotalColumnsHeader) {
|
|
16
|
+
offsetWidth -= totalWidthIsPxColumnIfTableWidthGrandTotalColumnsHeader;
|
|
17
|
+
totalPxWidthHeader -= totalWidthIsPxColumnIfTableWidthGrandTotalColumnsHeader;
|
|
26
18
|
}
|
|
27
|
-
|
|
28
|
-
|
|
19
|
+
let percent = this.getWidthPercentOfStyle(header);
|
|
20
|
+
if (percent) {
|
|
21
|
+
offsetWidth -= totalPxWidthHeader;
|
|
22
|
+
const percentDivide = (totalPercentWidthHeader - 100) / mixHeaderConfig.length;
|
|
23
|
+
percent -= percentDivide;
|
|
24
|
+
const widthCalculator = (percent / 100) * offsetWidth;
|
|
25
|
+
return this.getStyleUpdate(widthCalculator, header.ngStyle);
|
|
29
26
|
}
|
|
30
|
-
if (
|
|
27
|
+
if (totalPxWidthHeader > offsetWidth || header.keepWidthIsPxColumnIfTableWidthGrandTotalColumnsHeader || totalPercentWidthHeader) {
|
|
31
28
|
return header.ngStyle;
|
|
32
29
|
}
|
|
33
|
-
const width =
|
|
34
|
-
const widthCalculator = (width /
|
|
30
|
+
const width = this.getWidthPxOfStyle(header);
|
|
31
|
+
const widthCalculator = (width / totalPxWidthHeader) * offsetWidth;
|
|
32
|
+
return this.getStyleUpdate(widthCalculator, header.ngStyle);
|
|
33
|
+
}
|
|
34
|
+
getWidthPxOfStyle(headerGetWidth) {
|
|
35
|
+
let { flex, width, maxWidth } = headerGetWidth.ngStyle || {};
|
|
36
|
+
if (flex?.includes('%') || width?.includes('%') || maxWidth?.includes('%')) {
|
|
37
|
+
return 0;
|
|
38
|
+
}
|
|
39
|
+
width = parseInt(width || '0');
|
|
40
|
+
maxWidth = parseInt(maxWidth || '0');
|
|
41
|
+
flex = parseInt((flex || '0').split(' ').pop() || '0');
|
|
42
|
+
if (!flex && !width && !maxWidth) {
|
|
43
|
+
return 0;
|
|
44
|
+
}
|
|
45
|
+
const widthMax = Math.max(width, maxWidth, flex);
|
|
46
|
+
return widthMax;
|
|
47
|
+
}
|
|
48
|
+
getWidthPercentOfStyle(headerGetWidth) {
|
|
49
|
+
let { flex, width, maxWidth } = headerGetWidth.ngStyle || {};
|
|
50
|
+
if (flex?.includes('px') || width?.includes('px') || maxWidth?.includes('px')) {
|
|
51
|
+
return 0;
|
|
52
|
+
}
|
|
53
|
+
width = parseInt(width || '0');
|
|
54
|
+
maxWidth = parseInt(maxWidth || '0');
|
|
55
|
+
flex = parseInt((flex || '0').split(' ').pop() || '0');
|
|
56
|
+
if (!flex && !width && !maxWidth) {
|
|
57
|
+
return 0;
|
|
58
|
+
}
|
|
59
|
+
const widthMax = Math.max(width, maxWidth, flex);
|
|
60
|
+
return widthMax;
|
|
61
|
+
}
|
|
62
|
+
getStyleUpdate(widthCalculator, ngStyle) {
|
|
35
63
|
return {
|
|
36
|
-
...
|
|
64
|
+
...ngStyle,
|
|
37
65
|
flex: `0 0 ${widthCalculator}px`,
|
|
38
66
|
width: `${widthCalculator}px`,
|
|
39
67
|
maxWidth: `${widthCalculator}px`
|
|
@@ -49,4 +77,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
49
77
|
standalone: true
|
|
50
78
|
}]
|
|
51
79
|
}] });
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
80
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calculator-column.pipe.js","sourceRoot":"","sources":["../../../../../../libs-ui/components/table/src/pipes/calculator-column.pipe.ts"],"names":[],"mappings":"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","sourcesContent":["import { Pipe, PipeTransform } from '@angular/core';\nimport { ITableHeaderConfig } from '../interfaces/table-config.interface';\nimport { TYPE_OBJECT } from '@libs-ui/interfaces-types';\n@Pipe({\n  name: 'LibsUiTableCalculatorColumnPipe',\n  standalone: true\n})\n\nexport class LibsUiTableCalculatorColumnPipe implements PipeTransform {\n  transform(header: ITableHeaderConfig | undefined, offsetWidth: number, headerLeftConfig?: Array<ITableHeaderConfig>, headerRightConfig?: Array<ITableHeaderConfig>): TYPE_OBJECT | undefined {\n    if (!header?.ngStyle) {\n      return undefined;\n    }\n\n    const mixHeaderConfig = [...(headerLeftConfig || []), ...(headerRightConfig || [])];\n\n    let totalPxWidthHeader = mixHeaderConfig.reduce((acc, curr) => acc + this.getWidthPxOfStyle(curr), 0);\n    const totalPercentWidthHeader = mixHeaderConfig.reduce((acc, curr) => acc + this.getWidthPercentOfStyle(curr), 0);\n    const totalWidthIsPxColumnIfTableWidthGrandTotalColumnsHeader = mixHeaderConfig.reduce((acc, curr) => acc + (curr.keepWidthIsPxColumnIfTableWidthGrandTotalColumnsHeader ? this.getWidthPxOfStyle(curr) : 0), 0);\n\n    if (mixHeaderConfig.some(header => header.isShowIndexOnRow)) {\n      offsetWidth -= 50;\n    }\n\n    if (totalWidthIsPxColumnIfTableWidthGrandTotalColumnsHeader) {\n      offsetWidth -= totalWidthIsPxColumnIfTableWidthGrandTotalColumnsHeader;\n      totalPxWidthHeader -= totalWidthIsPxColumnIfTableWidthGrandTotalColumnsHeader;\n    }\n\n    let percent = this.getWidthPercentOfStyle(header);\n    if (percent) {\n      offsetWidth -= totalPxWidthHeader;\n      const percentDivide = (totalPercentWidthHeader - 100) / mixHeaderConfig.length;\n      percent -= percentDivide;\n      const widthCalculator = (percent / 100) * offsetWidth;\n      return this.getStyleUpdate(widthCalculator, header.ngStyle);\n    }\n\n    if (totalPxWidthHeader > offsetWidth || header.keepWidthIsPxColumnIfTableWidthGrandTotalColumnsHeader || totalPercentWidthHeader) {\n      return header.ngStyle;\n    }\n    const width = this.getWidthPxOfStyle(header);\n    const widthCalculator = (width / totalPxWidthHeader) * offsetWidth;\n    return this.getStyleUpdate(widthCalculator, header.ngStyle);\n\n  }\n\n  private getWidthPxOfStyle(headerGetWidth: ITableHeaderConfig): number {\n    let { flex, width, maxWidth } = headerGetWidth.ngStyle || {};\n    if (flex?.includes('%') || width?.includes('%') || maxWidth?.includes('%')) {\n      return 0;\n    }\n    width = parseInt(width || '0');\n    maxWidth = parseInt(maxWidth || '0');\n    flex = parseInt((flex || '0').split(' ').pop() || '0');\n\n    if (!flex && !width && !maxWidth) {\n      return 0;\n    }\n    const widthMax = Math.max(width, maxWidth, flex);\n    return widthMax;\n  }\n\n  private getWidthPercentOfStyle(headerGetWidth: ITableHeaderConfig): number {\n    let { flex, width, maxWidth } = headerGetWidth.ngStyle || {};\n    if (flex?.includes('px') || width?.includes('px') || maxWidth?.includes('px')) {\n      return 0;\n    }\n    width = parseInt(width || '0');\n    maxWidth = parseInt(maxWidth || '0');\n    flex = parseInt((flex || '0').split(' ').pop() || '0');\n    if (!flex && !width && !maxWidth) {\n      return 0;\n    }\n    const widthMax = Math.max(width, maxWidth, flex);\n    return widthMax;\n  }\n\n  private getStyleUpdate(widthCalculator: number, ngStyle: TYPE_OBJECT) {\n    return {\n      ...ngStyle,\n      flex: `0 0 ${widthCalculator}px`,\n      width: `${widthCalculator}px`,\n      maxWidth: `${widthCalculator}px`\n    };\n  }\n}\n"]}
|