@mediusinc/mng-commons 4.0.0-rc.1 → 4.0.0-rc.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/index.mjs +8 -2
- package/esm2022/lib/components/action/index.mjs +2 -1
- package/esm2022/lib/components/action/table/action-table.component.mjs +164 -0
- package/esm2022/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.mjs +4 -4
- package/esm2022/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.mjs +4 -5
- package/esm2022/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.mjs +3 -3
- package/esm2022/lib/components/layoutV2/topbar.component.mjs +2 -7
- package/esm2022/lib/components/table/column-filter-full/column-filter-full.component.mjs +466 -0
- package/esm2022/lib/components/table/column-value/column-value.component.mjs +87 -0
- package/esm2022/lib/components/table/models/table.event.mjs +16 -0
- package/esm2022/lib/components/table/models/table.interface.mjs +2 -0
- package/esm2022/lib/components/table/table-column-filter-class/table-column-filter-class.pipe.mjs +25 -0
- package/esm2022/lib/components/table/table.component.mjs +723 -0
- package/esm2022/lib/components/tableview/index.mjs +1 -4
- package/esm2022/lib/components/tableview/tableview.component.mjs +6 -7
- package/esm2022/lib/descriptors/editor/editor.descriptor.mjs +1 -1
- package/esm2022/lib/descriptors/table/table.descriptor.mjs +16 -17
- package/esm2022/lib/descriptors/tableview/tableview.descriptor.mjs +1 -1
- package/esm2022/lib/utils/tableview.util.mjs +2 -2
- package/fesm2022/mediusinc-mng-commons.mjs +2221 -2080
- package/fesm2022/mediusinc-mng-commons.mjs.map +1 -1
- package/index.d.ts +6 -1
- package/lib/components/action/index.d.ts +1 -0
- package/lib/components/action/table/action-table.component.d.ts +55 -0
- package/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.d.ts +1 -1
- package/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.d.ts +1 -1
- package/lib/components/layoutV2/topbar.component.d.ts +0 -1
- package/lib/components/{tableview/table → table}/column-filter-full/column-filter-full.component.d.ts +2 -2
- package/lib/components/{tableview/table → table}/column-value/column-value.component.d.ts +3 -3
- package/lib/components/{tableview/table → table}/models/table.interface.d.ts +3 -1
- package/lib/components/table/table-column-filter-class/table-column-filter-class.pipe.d.ts +8 -0
- package/lib/components/table/table.component.d.ts +125 -0
- package/lib/components/tableview/index.d.ts +0 -3
- package/lib/components/tableview/tableview.component.d.ts +3 -3
- package/lib/descriptors/editor/editor.descriptor.d.ts +1 -1
- package/lib/descriptors/table/table.descriptor.d.ts +15 -12
- package/lib/descriptors/tableview/tableview.descriptor.d.ts +1 -1
- package/package.json +1 -1
- package/scss/mng-overrides/_theme_datatable.scss +24 -10
- package/scss/v2/theme/theme-base/mng/_mng_theme_datatable.scss +24 -9
- package/scss/v2/theme/theme-dark/_variables.scss +24 -12
- package/scss/v2/theme/theme-dark/blue/theme.scss +4 -4
- package/scss/v2/theme/theme-light/_variables.scss +23 -11
- package/scss/v2/theme/theme-light/blue/theme.scss +2 -2
- package/esm2022/lib/components/tableview/models/index.mjs +0 -2
- package/esm2022/lib/components/tableview/models/table.event.mjs +0 -16
- package/esm2022/lib/components/tableview/table/column-filter-full/column-filter-full.component.mjs +0 -467
- package/esm2022/lib/components/tableview/table/column-value/column-value.component.mjs +0 -87
- package/esm2022/lib/components/tableview/table/models/index.mjs +0 -2
- package/esm2022/lib/components/tableview/table/models/table.interface.mjs +0 -2
- package/esm2022/lib/components/tableview/table/table.component.mjs +0 -752
- package/lib/components/tableview/models/index.d.ts +0 -1
- package/lib/components/tableview/table/models/index.d.ts +0 -1
- package/lib/components/tableview/table/table.component.d.ts +0 -147
- /package/lib/components/{tableview → table}/models/table.event.d.ts +0 -0
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
import { CurrencyPipe, DatePipe, DecimalPipe } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, ElementRef, HostBinding, Input } from '@angular/core';
|
|
3
|
+
import { TranslateModule, TranslateService } from '@ngx-translate/core';
|
|
4
|
+
import { MessageService } from 'primeng/api';
|
|
5
|
+
import { ButtonModule } from 'primeng/button';
|
|
6
|
+
import { RippleModule } from 'primeng/ripple';
|
|
7
|
+
import { TooltipModule } from 'primeng/tooltip';
|
|
8
|
+
import { ColumnDescriptor } from '../../../descriptors/table';
|
|
9
|
+
import { ColumnDisplayTypeEnum } from '../../../descriptors/types';
|
|
10
|
+
import { MngComponentDirective } from '../../../directives';
|
|
11
|
+
import { JsonPathPipe, MngBooleanPipe, MngEnumPipe, MngGetterPipe, MngTemplatePipe } from '../../../pipes';
|
|
12
|
+
import * as i0 from "@angular/core";
|
|
13
|
+
import * as i1 from "primeng/api";
|
|
14
|
+
import * as i2 from "@ngx-translate/core";
|
|
15
|
+
import * as i3 from "../../../pipes";
|
|
16
|
+
import * as i4 from "primeng/tooltip";
|
|
17
|
+
import * as i5 from "primeng/button";
|
|
18
|
+
import * as i6 from "primeng/ripple";
|
|
19
|
+
export class MngTableColumnValueComponent {
|
|
20
|
+
constructor(elementRef, messageService, translate, jsonPathPipe, getterPipe, templatePipe) {
|
|
21
|
+
this.elementRef = elementRef;
|
|
22
|
+
this.messageService = messageService;
|
|
23
|
+
this.translate = translate;
|
|
24
|
+
this.jsonPathPipe = jsonPathPipe;
|
|
25
|
+
this.getterPipe = getterPipe;
|
|
26
|
+
this.templatePipe = templatePipe;
|
|
27
|
+
this.columnDisplayTypeString = ColumnDisplayTypeEnum.String;
|
|
28
|
+
this.columnDisplayTypeNumber = ColumnDisplayTypeEnum.Number;
|
|
29
|
+
this.columnDisplayTypeCurrency = ColumnDisplayTypeEnum.Currency;
|
|
30
|
+
this.columnDisplayTypeBoolean = ColumnDisplayTypeEnum.Boolean;
|
|
31
|
+
this.columnDisplayTypeDate = ColumnDisplayTypeEnum.Date;
|
|
32
|
+
this.columnDisplayTypeEnum = ColumnDisplayTypeEnum.Enum;
|
|
33
|
+
this.columnDisplayTypeComponent = ColumnDisplayTypeEnum.Component;
|
|
34
|
+
this.columnDisplayTypeHtml = ColumnDisplayTypeEnum.Html;
|
|
35
|
+
this.styleMaxWidth = null;
|
|
36
|
+
this.className = 'nowrap';
|
|
37
|
+
this.jsonPath = '$';
|
|
38
|
+
}
|
|
39
|
+
ngOnInit() {
|
|
40
|
+
if (this.descriptor.columnDisplayType === ColumnDisplayTypeEnum.Currency) {
|
|
41
|
+
this.currency = this.descriptor.currencyProperty ? this.item[this.descriptor.currencyProperty] : this.descriptor.currencyCode ?? 'EUR';
|
|
42
|
+
}
|
|
43
|
+
else if (this.descriptor.columnDisplayType === ColumnDisplayTypeEnum.String) {
|
|
44
|
+
if (this.descriptor.isMultiline) {
|
|
45
|
+
this.className += ' multiline';
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
if (this.descriptor.maxWidth) {
|
|
49
|
+
this.styleMaxWidth = this.descriptor.maxWidth;
|
|
50
|
+
}
|
|
51
|
+
let value = this.item?.[this.descriptor.property];
|
|
52
|
+
if (typeof this.descriptor.getter === 'function') {
|
|
53
|
+
value = this.getterPipe.transform(this.item, this.descriptor.getter, value);
|
|
54
|
+
}
|
|
55
|
+
if (this.descriptor.template) {
|
|
56
|
+
value = this.templatePipe.transform(value, this.descriptor.template);
|
|
57
|
+
}
|
|
58
|
+
this.value = value;
|
|
59
|
+
}
|
|
60
|
+
copyToClipboard(event) {
|
|
61
|
+
event.stopPropagation();
|
|
62
|
+
const value = this.elementRef.nativeElement.innerText.trim();
|
|
63
|
+
navigator.clipboard.writeText(value);
|
|
64
|
+
const title = this.translate.instant('mngTable.copyNotificationTitle');
|
|
65
|
+
const message = this.translate.instant('mngTable.copyNotificationMessage', { value });
|
|
66
|
+
this.messageService.add({ severity: 'info', summary: title, detail: message });
|
|
67
|
+
}
|
|
68
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: MngTableColumnValueComponent, deps: [{ token: i0.ElementRef }, { token: i1.MessageService }, { token: i2.TranslateService }, { token: i3.JsonPathPipe }, { token: i3.MngGetterPipe }, { token: i3.MngTemplatePipe }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
69
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.0.8", type: MngTableColumnValueComponent, isStandalone: true, selector: "mng-table-column-value", inputs: { descriptor: "descriptor", item: "item" }, host: { properties: { "style.max-width.px": "this.styleMaxWidth", "class": "this.className" } }, ngImport: i0, template: "@if (descriptor.localizationExistsProperty && !item[descriptor.localizationExistsProperty]) {\n <i class=\"pi pi-exclamation-circle\" [pTooltip]=\"'mngTable.translationMissing' | translate\"></i>\n}\n@switch (descriptor.columnDisplayType) {\n @case (columnDisplayTypeString) {\n @if (descriptor.hasValueAsTooltip) {\n <span [pTooltip]=\"value\" tooltipPosition=\"left\">{{ value }}</span>\n } @else {\n {{ value }}\n }\n }\n @case (columnDisplayTypeHtml) {\n <span [innerHTML]=\"value\"></span>\n }\n @case (columnDisplayTypeNumber) {\n {{ value | number: descriptor.displayFormat : descriptor.locale }}\n }\n @case (columnDisplayTypeCurrency) {\n {{ value | currency: currency : descriptor.currencyDisplay : descriptor.displayFormat : descriptor.locale }}\n }\n @case (columnDisplayTypeDate) {\n {{ value | date: descriptor.displayFormat }}\n }\n @case (columnDisplayTypeBoolean) {\n @if (descriptor.booleanAsIcon) {\n <i [class]=\"value | boolean: descriptor.booleanYes : descriptor.booleanNo : true\"></i>\n } @else {\n {{ value | boolean: descriptor.booleanYes : descriptor.booleanNo | translate }}\n }\n }\n @case (columnDisplayTypeEnum) {\n {{ value | enum: descriptor.enumType : descriptor.enumTitlePath : descriptor.enumNameAsValue | translate }}\n }\n @case (columnDisplayTypeComponent) {\n <ng-container\n [mngComponent]=\"descriptor.customComponentType!\"\n [inputs]=\"{\n value: value,\n item: item,\n descriptor: descriptor\n }\"></ng-container>\n }\n}\n@if (descriptor.hasCopyToClipboard) {\n <div class=\"help-buttons\">\n <button pButton pRipple type=\"button\" icon=\"pi pi-copy\" class=\"p-button-rounded p-button-info p-button-sm\" (click)=\"copyToClipboard($event)\"></button>\n </div>\n}\n", styles: [":host{display:inline-block;overflow:hidden}:host.nowrap{white-space:nowrap;text-overflow:ellipsis}:host.multiline{white-space:pre-wrap;word-wrap:break-word}.help-buttons{display:none;position:absolute;right:0;top:50%;transform:translateY(-50%)}.help-buttons .p-button{height:1.9rem;width:1.9rem;padding:0}\n"], dependencies: [{ kind: "ngmodule", type: TooltipModule }, { kind: "directive", type: i4.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "pipe", type: MngBooleanPipe, name: "boolean" }, { kind: "pipe", type: MngEnumPipe, name: "enum" }, { kind: "directive", type: MngComponentDirective, selector: "[mngComponent]", inputs: ["mngComponent", "inputs", "attachToHost"], outputs: ["instanceCreated"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i5.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "ngmodule", type: RippleModule }, { kind: "directive", type: i6.Ripple, selector: "[pRipple]" }, { kind: "pipe", type: DecimalPipe, name: "number" }, { kind: "pipe", type: CurrencyPipe, name: "currency" }, { kind: "pipe", type: DatePipe, name: "date" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
70
|
+
}
|
|
71
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: MngTableColumnValueComponent, decorators: [{
|
|
72
|
+
type: Component,
|
|
73
|
+
args: [{ standalone: true, selector: 'mng-table-column-value', imports: [TooltipModule, TranslateModule, MngBooleanPipe, MngEnumPipe, MngComponentDirective, ButtonModule, RippleModule, DecimalPipe, CurrencyPipe, DatePipe], changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (descriptor.localizationExistsProperty && !item[descriptor.localizationExistsProperty]) {\n <i class=\"pi pi-exclamation-circle\" [pTooltip]=\"'mngTable.translationMissing' | translate\"></i>\n}\n@switch (descriptor.columnDisplayType) {\n @case (columnDisplayTypeString) {\n @if (descriptor.hasValueAsTooltip) {\n <span [pTooltip]=\"value\" tooltipPosition=\"left\">{{ value }}</span>\n } @else {\n {{ value }}\n }\n }\n @case (columnDisplayTypeHtml) {\n <span [innerHTML]=\"value\"></span>\n }\n @case (columnDisplayTypeNumber) {\n {{ value | number: descriptor.displayFormat : descriptor.locale }}\n }\n @case (columnDisplayTypeCurrency) {\n {{ value | currency: currency : descriptor.currencyDisplay : descriptor.displayFormat : descriptor.locale }}\n }\n @case (columnDisplayTypeDate) {\n {{ value | date: descriptor.displayFormat }}\n }\n @case (columnDisplayTypeBoolean) {\n @if (descriptor.booleanAsIcon) {\n <i [class]=\"value | boolean: descriptor.booleanYes : descriptor.booleanNo : true\"></i>\n } @else {\n {{ value | boolean: descriptor.booleanYes : descriptor.booleanNo | translate }}\n }\n }\n @case (columnDisplayTypeEnum) {\n {{ value | enum: descriptor.enumType : descriptor.enumTitlePath : descriptor.enumNameAsValue | translate }}\n }\n @case (columnDisplayTypeComponent) {\n <ng-container\n [mngComponent]=\"descriptor.customComponentType!\"\n [inputs]=\"{\n value: value,\n item: item,\n descriptor: descriptor\n }\"></ng-container>\n }\n}\n@if (descriptor.hasCopyToClipboard) {\n <div class=\"help-buttons\">\n <button pButton pRipple type=\"button\" icon=\"pi pi-copy\" class=\"p-button-rounded p-button-info p-button-sm\" (click)=\"copyToClipboard($event)\"></button>\n </div>\n}\n", styles: [":host{display:inline-block;overflow:hidden}:host.nowrap{white-space:nowrap;text-overflow:ellipsis}:host.multiline{white-space:pre-wrap;word-wrap:break-word}.help-buttons{display:none;position:absolute;right:0;top:50%;transform:translateY(-50%)}.help-buttons .p-button{height:1.9rem;width:1.9rem;padding:0}\n"] }]
|
|
74
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.MessageService }, { type: i2.TranslateService }, { type: i3.JsonPathPipe }, { type: i3.MngGetterPipe }, { type: i3.MngTemplatePipe }], propDecorators: { descriptor: [{
|
|
75
|
+
type: Input,
|
|
76
|
+
args: [{ required: true }]
|
|
77
|
+
}], item: [{
|
|
78
|
+
type: Input,
|
|
79
|
+
args: [{ required: true }]
|
|
80
|
+
}], styleMaxWidth: [{
|
|
81
|
+
type: HostBinding,
|
|
82
|
+
args: ['style.max-width.px']
|
|
83
|
+
}], className: [{
|
|
84
|
+
type: HostBinding,
|
|
85
|
+
args: ['class']
|
|
86
|
+
}] } });
|
|
87
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column-value.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/table/column-value/column-value.component.ts","../../../../../../src/lib/components/table/column-value/column-value.component.html"],"names":[],"mappings":"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","sourcesContent":["import {CurrencyPipe, DatePipe, DecimalPipe} from '@angular/common';\nimport {ChangeDetectionStrategy, Component, ElementRef, HostBinding, Input, OnInit} from '@angular/core';\n\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {MessageService} from 'primeng/api';\nimport {ButtonModule} from 'primeng/button';\nimport {RippleModule} from 'primeng/ripple';\nimport {TooltipModule} from 'primeng/tooltip';\n\nimport {ColumnDescriptor} from '../../../descriptors/table';\nimport {ColumnDisplayTypeEnum} from '../../../descriptors/types';\nimport {MngComponentDirective} from '../../../directives';\nimport {JsonPathPipe, MngBooleanPipe, MngEnumPipe, MngGetterPipe, MngTemplatePipe} from '../../../pipes';\n\n@Component({\n    standalone: true,\n    selector: 'mng-table-column-value',\n    templateUrl: './column-value.component.html',\n    styleUrls: ['./column-value.component.scss'],\n    imports: [TooltipModule, TranslateModule, MngBooleanPipe, MngEnumPipe, MngComponentDirective, ButtonModule, RippleModule, DecimalPipe, CurrencyPipe, DatePipe],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngTableColumnValueComponent<T, TT> implements OnInit {\n    public readonly columnDisplayTypeString: ColumnDisplayTypeEnum = ColumnDisplayTypeEnum.String;\n    public readonly columnDisplayTypeNumber: ColumnDisplayTypeEnum = ColumnDisplayTypeEnum.Number;\n    public readonly columnDisplayTypeCurrency: ColumnDisplayTypeEnum = ColumnDisplayTypeEnum.Currency;\n    public readonly columnDisplayTypeBoolean: ColumnDisplayTypeEnum = ColumnDisplayTypeEnum.Boolean;\n    public readonly columnDisplayTypeDate: ColumnDisplayTypeEnum = ColumnDisplayTypeEnum.Date;\n    public readonly columnDisplayTypeEnum: ColumnDisplayTypeEnum = ColumnDisplayTypeEnum.Enum;\n    public readonly columnDisplayTypeComponent: ColumnDisplayTypeEnum = ColumnDisplayTypeEnum.Component;\n    public readonly columnDisplayTypeHtml: ColumnDisplayTypeEnum = ColumnDisplayTypeEnum.Html;\n\n    @Input({required: true}) descriptor!: ColumnDescriptor<T, TT>;\n    @Input({required: true}) item!: any;\n\n    @HostBinding('style.max-width.px') public styleMaxWidth: number | null = null;\n    @HostBinding('class') public className = 'nowrap';\n\n    public currency?: string;\n\n    public jsonPath = '$';\n\n    public value: any;\n\n    constructor(\n        private elementRef: ElementRef,\n        private messageService: MessageService,\n        private translate: TranslateService,\n        private jsonPathPipe: JsonPathPipe,\n        private getterPipe: MngGetterPipe,\n        private templatePipe: MngTemplatePipe\n    ) {}\n\n    public ngOnInit() {\n        if (this.descriptor.columnDisplayType === ColumnDisplayTypeEnum.Currency) {\n            this.currency = this.descriptor.currencyProperty ? this.item[this.descriptor.currencyProperty] : this.descriptor.currencyCode ?? 'EUR';\n        } else if (this.descriptor.columnDisplayType === ColumnDisplayTypeEnum.String) {\n            if (this.descriptor.isMultiline) {\n                this.className += ' multiline';\n            }\n        }\n\n        if (this.descriptor.maxWidth) {\n            this.styleMaxWidth = this.descriptor.maxWidth;\n        }\n\n        let value = this.item?.[this.descriptor.property as keyof object];\n        if (typeof this.descriptor.getter === 'function') {\n            value = this.getterPipe.transform(this.item, this.descriptor.getter, value);\n        }\n        if (this.descriptor.template) {\n            value = this.templatePipe.transform(value, this.descriptor.template);\n        }\n\n        this.value = value;\n    }\n\n    public copyToClipboard(event: Event) {\n        event.stopPropagation();\n        const value = this.elementRef.nativeElement.innerText.trim();\n        navigator.clipboard.writeText(value);\n        const title = this.translate.instant('mngTable.copyNotificationTitle');\n        const message = this.translate.instant('mngTable.copyNotificationMessage', {value});\n        this.messageService.add({severity: 'info', summary: title, detail: message});\n    }\n}\n","@if (descriptor.localizationExistsProperty && !item[descriptor.localizationExistsProperty]) {\n    <i class=\"pi pi-exclamation-circle\" [pTooltip]=\"'mngTable.translationMissing' | translate\"></i>\n}\n@switch (descriptor.columnDisplayType) {\n    @case (columnDisplayTypeString) {\n        @if (descriptor.hasValueAsTooltip) {\n            <span [pTooltip]=\"value\" tooltipPosition=\"left\">{{ value }}</span>\n        } @else {\n            {{ value }}\n        }\n    }\n    @case (columnDisplayTypeHtml) {\n        <span [innerHTML]=\"value\"></span>\n    }\n    @case (columnDisplayTypeNumber) {\n        {{ value | number: descriptor.displayFormat : descriptor.locale }}\n    }\n    @case (columnDisplayTypeCurrency) {\n        {{ value | currency: currency : descriptor.currencyDisplay : descriptor.displayFormat : descriptor.locale }}\n    }\n    @case (columnDisplayTypeDate) {\n        {{ value | date: descriptor.displayFormat }}\n    }\n    @case (columnDisplayTypeBoolean) {\n        @if (descriptor.booleanAsIcon) {\n            <i [class]=\"value | boolean: descriptor.booleanYes : descriptor.booleanNo : true\"></i>\n        } @else {\n            {{ value | boolean: descriptor.booleanYes : descriptor.booleanNo | translate }}\n        }\n    }\n    @case (columnDisplayTypeEnum) {\n        {{ value | enum: descriptor.enumType : descriptor.enumTitlePath : descriptor.enumNameAsValue | translate }}\n    }\n    @case (columnDisplayTypeComponent) {\n        <ng-container\n            [mngComponent]=\"descriptor.customComponentType!\"\n            [inputs]=\"{\n                value: value,\n                item: item,\n                descriptor: descriptor\n            }\"></ng-container>\n    }\n}\n@if (descriptor.hasCopyToClipboard) {\n    <div class=\"help-buttons\">\n        <button pButton pRipple type=\"button\" icon=\"pi pi-copy\" class=\"p-button-rounded p-button-info p-button-sm\" (click)=\"copyToClipboard($event)\"></button>\n    </div>\n}\n"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export class MngTableLoadEvent {
|
|
2
|
+
}
|
|
3
|
+
export class MngTableCellClickEvent {
|
|
4
|
+
constructor(column, rowItem, rowIndex) {
|
|
5
|
+
this.column = column;
|
|
6
|
+
this.rowItem = rowItem;
|
|
7
|
+
this.rowIndex = rowIndex;
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
export class MngTableReloadEvent {
|
|
11
|
+
constructor() {
|
|
12
|
+
this.resetParams = false;
|
|
13
|
+
this.emitEvent = false;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuZXZlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvdGFibGUvbW9kZWxzL3RhYmxlLmV2ZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUtBLE1BQU0sT0FBTyxpQkFBaUI7Q0FHN0I7QUFFRCxNQUFNLE9BQU8sc0JBQXNCO0lBQy9CLFlBQ29CLE1BQWdDLEVBQ2hDLE9BQVUsRUFDVixRQUFnQjtRQUZoQixXQUFNLEdBQU4sTUFBTSxDQUEwQjtRQUNoQyxZQUFPLEdBQVAsT0FBTyxDQUFHO1FBQ1YsYUFBUSxHQUFSLFFBQVEsQ0FBUTtJQUNqQyxDQUFDO0NBQ1A7QUFFRCxNQUFNLE9BQU8sbUJBQW1CO0lBQWhDO1FBQ1csZ0JBQVcsR0FBRyxLQUFLLENBQUM7UUFDcEIsY0FBUyxHQUFHLEtBQUssQ0FBQztJQUM3QixDQUFDO0NBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1RhYmxlTGF6eUxvYWRFdmVudH0gZnJvbSAncHJpbWVuZy90YWJsZSc7XG5cbmltcG9ydCB7TWVkaXVzUXVlcnlQYXJhbX0gZnJvbSAnLi4vLi4vLi4vYXBpL21vZGVscyc7XG5pbXBvcnQge0NvbHVtbkRlc2NyaXB0b3J9IGZyb20gJy4uLy4uLy4uL2Rlc2NyaXB0b3JzL3RhYmxlJztcblxuZXhwb3J0IGNsYXNzIE1uZ1RhYmxlTG9hZEV2ZW50IHtcbiAgICBwdWJsaWMgcXVlcnlQYXJhbT86IE1lZGl1c1F1ZXJ5UGFyYW07XG4gICAgcHVibGljIG9yaWdpbmFsRXZlbnQ/OiBUYWJsZUxhenlMb2FkRXZlbnQ7XG59XG5cbmV4cG9ydCBjbGFzcyBNbmdUYWJsZUNlbGxDbGlja0V2ZW50PFQ+IHtcbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgcHVibGljIHJlYWRvbmx5IGNvbHVtbjogQ29sdW1uRGVzY3JpcHRvcjxhbnksIFQ+LFxuICAgICAgICBwdWJsaWMgcmVhZG9ubHkgcm93SXRlbTogVCxcbiAgICAgICAgcHVibGljIHJlYWRvbmx5IHJvd0luZGV4OiBudW1iZXJcbiAgICApIHt9XG59XG5cbmV4cG9ydCBjbGFzcyBNbmdUYWJsZVJlbG9hZEV2ZW50IHtcbiAgICBwdWJsaWMgcmVzZXRQYXJhbXMgPSBmYWxzZTtcbiAgICBwdWJsaWMgZW1pdEV2ZW50ID0gZmFsc2U7XG59XG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb21wb25lbnRzL3RhYmxlL21vZGVscy90YWJsZS5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29sdW1uRGVzY3JpcHRvcn0gZnJvbSAnLi4vLi4vLi4vZGVzY3JpcHRvcnMvdGFibGUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIENvbHVtbldpdGhQcmVmZXJlbmNlcyB7XG4gICAgaWQ6IHN0cmluZztcbiAgICBkZXNjcmlwdG9yOiBDb2x1bW5EZXNjcmlwdG9yPGFueSwgYW55PjtcbiAgICBkaXNhYmxlZDogYm9vbGVhbjtcbiAgICBpc1Zpc2libGU6IGJvb2xlYW47XG4gICAgd2lkdGg/OiBudW1iZXI7XG4gICAgb3JkZXJJZHg/OiBudW1iZXI7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGFibGVMYXlvdXRQcmVmZXJlbmNlcyB7XG4gICAgY29sdW1uV2lkdGhzPzogUmVjb3JkPHN0cmluZywgbnVtYmVyPjtcbiAgICBjb2x1bW5PcmRlcj86IHN0cmluZ1tdO1xuICAgIGNvbHVtblZpc2liaWxpdHk/OiBzdHJpbmdbXTtcbn1cbiJdfQ==
|
package/esm2022/lib/components/table/table-column-filter-class/table-column-filter-class.pipe.mjs
ADDED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import { FilterTypeEnum } from '../../../descriptors/types';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class MngTableColumnFilterClassPipe {
|
|
5
|
+
transform(value, column, isEnabled) {
|
|
6
|
+
const strValue = typeof value === 'string' ? value : '';
|
|
7
|
+
if (isEnabled && column.filterDescriptor?.filterType !== undefined) {
|
|
8
|
+
return `${strValue} mng-column-filter-${FilterTypeEnum[column.filterDescriptor.filterType].toLowerCase()}`;
|
|
9
|
+
}
|
|
10
|
+
else {
|
|
11
|
+
return strValue;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: MngTableColumnFilterClassPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
15
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "17.0.8", ngImport: i0, type: MngTableColumnFilterClassPipe, isStandalone: true, name: "mngTableColumnFilterClass" }); }
|
|
16
|
+
}
|
|
17
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: MngTableColumnFilterClassPipe, decorators: [{
|
|
18
|
+
type: Pipe,
|
|
19
|
+
args: [{
|
|
20
|
+
standalone: true,
|
|
21
|
+
pure: true,
|
|
22
|
+
name: 'mngTableColumnFilterClass'
|
|
23
|
+
}]
|
|
24
|
+
}] });
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY29sdW1uLWZpbHRlci1jbGFzcy5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb21wb25lbnRzL3RhYmxlL3RhYmxlLWNvbHVtbi1maWx0ZXItY2xhc3MvdGFibGUtY29sdW1uLWZpbHRlci1jbGFzcy5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxJQUFJLEVBQWdCLE1BQU0sZUFBZSxDQUFDO0FBR2xELE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQzs7QUFPMUQsTUFBTSxPQUFPLDZCQUE2QjtJQUN0QyxTQUFTLENBQUMsS0FBYyxFQUFFLE1BQWtDLEVBQUUsU0FBa0I7UUFDNUUsTUFBTSxRQUFRLEdBQUcsT0FBTyxLQUFLLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztRQUN4RCxJQUFJLFNBQVMsSUFBSSxNQUFNLENBQUMsZ0JBQWdCLEVBQUUsVUFBVSxLQUFLLFNBQVMsRUFBRTtZQUNoRSxPQUFPLEdBQUcsUUFBUSxzQkFBc0IsY0FBYyxDQUFDLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxVQUFVLENBQUMsQ0FBQyxXQUFXLEVBQUUsRUFBRSxDQUFDO1NBQzlHO2FBQU07WUFDSCxPQUFPLFFBQVEsQ0FBQztTQUNuQjtJQUNMLENBQUM7OEdBUlEsNkJBQTZCOzRHQUE3Qiw2QkFBNkI7OzJGQUE3Qiw2QkFBNkI7a0JBTHpDLElBQUk7bUJBQUM7b0JBQ0YsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLElBQUksRUFBRSxJQUFJO29CQUNWLElBQUksRUFBRSwyQkFBMkI7aUJBQ3BDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtQaXBlLCBQaXBlVHJhbnNmb3JtfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHtDb2x1bW5EZXNjcmlwdG9yfSBmcm9tICcuLi8uLi8uLi9kZXNjcmlwdG9ycy90YWJsZS9jb2x1bW4uZGVzY3JpcHRvcic7XG5pbXBvcnQge0ZpbHRlclR5cGVFbnVtfSBmcm9tICcuLi8uLi8uLi9kZXNjcmlwdG9ycy90eXBlcyc7XG5cbkBQaXBlKHtcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHB1cmU6IHRydWUsXG4gICAgbmFtZTogJ21uZ1RhYmxlQ29sdW1uRmlsdGVyQ2xhc3MnXG59KVxuZXhwb3J0IGNsYXNzIE1uZ1RhYmxlQ29sdW1uRmlsdGVyQ2xhc3NQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gICAgdHJhbnNmb3JtKHZhbHVlOiB1bmtub3duLCBjb2x1bW46IENvbHVtbkRlc2NyaXB0b3I8YW55LCBhbnk+LCBpc0VuYWJsZWQ6IGJvb2xlYW4pOiBzdHJpbmcge1xuICAgICAgICBjb25zdCBzdHJWYWx1ZSA9IHR5cGVvZiB2YWx1ZSA9PT0gJ3N0cmluZycgPyB2YWx1ZSA6ICcnO1xuICAgICAgICBpZiAoaXNFbmFibGVkICYmIGNvbHVtbi5maWx0ZXJEZXNjcmlwdG9yPy5maWx0ZXJUeXBlICE9PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICAgIHJldHVybiBgJHtzdHJWYWx1ZX0gbW5nLWNvbHVtbi1maWx0ZXItJHtGaWx0ZXJUeXBlRW51bVtjb2x1bW4uZmlsdGVyRGVzY3JpcHRvci5maWx0ZXJUeXBlXS50b0xvd2VyQ2FzZSgpfWA7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICByZXR1cm4gc3RyVmFsdWU7XG4gICAgICAgIH1cbiAgICB9XG59XG4iXX0=
|