@mediusinc/mng-commons 0.19.2 → 0.20.0
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/assets/i18n/en.json +5 -1
- package/assets/i18n/sl.json +5 -1
- package/esm2020/lib/components/action/action.component.mjs +12 -5
- package/esm2020/lib/components/action/editor/action-editor.component.mjs +17 -5
- package/esm2020/lib/components/action/models/action-execution.model.mjs +5 -1
- package/esm2020/lib/components/action/route/action-route.component.mjs +7 -2
- package/esm2020/lib/components/form/formly/fields/formly-field-input/formly-field-input.component.mjs +64 -17
- package/esm2020/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.mjs +1 -1
- package/esm2020/lib/components/form/formly/formly.config.mjs +27 -1
- package/esm2020/lib/components/tableview/route/tableview-route.abstract.component.mjs +38 -5
- package/esm2020/lib/components/tableview/table/column-filter/column-filter.component.mjs +1 -1
- package/esm2020/lib/components/tableview/table/column-value/column-value.component.mjs +32 -23
- package/esm2020/lib/components/tableview/table/table.component.mjs +3 -3
- package/esm2020/lib/components/tableview/tableview.component.mjs +3 -3
- package/esm2020/lib/descriptors/column.descriptor.mjs +17 -12
- package/esm2020/lib/descriptors/editor.descriptor.mjs +2 -2
- package/esm2020/lib/descriptors/field-validation.descriptor.mjs +5 -1
- package/esm2020/lib/descriptors/field.descriptor.mjs +39 -4
- package/esm2020/lib/descriptors/table.descriptor.mjs +6 -5
- package/esm2020/lib/descriptors/tableview.descriptor.mjs +4 -4
- package/esm2020/lib/descriptors/types/column.type.mjs +18 -9
- package/esm2020/lib/descriptors/types/field.type.mjs +4 -2
- package/esm2020/lib/mng-commons.module.mjs +6 -4
- package/esm2020/lib/models/tableview-attr.model.mjs +1 -1
- package/esm2020/lib/models/view-container.model.mjs +1 -1
- package/esm2020/lib/router/tableview-route-builder.mjs +4 -1
- package/esm2020/lib/services/action-executor.service.mjs +23 -19
- package/esm2020/lib/services/commons.service.mjs +2 -2
- package/esm2020/lib/services/view-container.component.service.mjs +8 -1
- package/esm2020/lib/utils/editor-formly.util.mjs +6 -1
- package/esm2020/lib/utils/tableview.util.mjs +31 -15
- package/fesm2015/mediusinc-mng-commons.mjs +393 -155
- package/fesm2015/mediusinc-mng-commons.mjs.map +1 -1
- package/fesm2020/mediusinc-mng-commons.mjs +385 -150
- package/fesm2020/mediusinc-mng-commons.mjs.map +1 -1
- package/lib/components/action/action.component.d.ts +6 -3
- package/lib/components/action/editor/action-editor.component.d.ts +6 -0
- package/lib/components/action/models/action-execution.model.d.ts +2 -0
- package/lib/components/form/formly/fields/formly-field-input/formly-field-input.component.d.ts +7 -2
- package/lib/components/form/formly/formly.config.d.ts +2 -0
- package/lib/components/tableview/route/tableview-route.abstract.component.d.ts +5 -3
- package/lib/components/tableview/table/column-value/column-value.component.d.ts +15 -10
- package/lib/descriptors/column.descriptor.d.ts +4 -2
- package/lib/descriptors/field-validation.descriptor.d.ts +1 -0
- package/lib/descriptors/field.descriptor.d.ts +10 -2
- package/lib/descriptors/table.descriptor.d.ts +3 -3
- package/lib/descriptors/tableview.descriptor.d.ts +2 -2
- package/lib/descriptors/types/column.type.d.ts +16 -8
- package/lib/descriptors/types/field.type.d.ts +3 -1
- package/lib/mng-commons.module.d.ts +2 -1
- package/lib/models/tableview-attr.model.d.ts +2 -1
- package/lib/models/view-container.model.d.ts +6 -0
- package/lib/services/view-container.component.service.d.ts +4 -1
- package/lib/utils/tableview.util.d.ts +5 -4
- package/package.json +1 -1
- package/scss/common/theme/designer/_components.scss +1 -0
- package/scss/common/theme/designer/components/multimedia/_image.scss +44 -0
- package/scss/common/variables/theme/_theme_dark.scss +15 -1
- package/scss/common/variables/theme/_theme_light.scss +15 -1
- package/scss/mng-overrides/_theme_forms.scss +5 -0
- package/scss/mng-overrides/_theme_image.scss +27 -0
- package/scss/mng-overrides/_theme_styles.scss +1 -0
- package/version-info.json +5 -5
|
@@ -97,6 +97,16 @@ export const formlyTypesConfig = [
|
|
|
97
97
|
}
|
|
98
98
|
}
|
|
99
99
|
},
|
|
100
|
+
{
|
|
101
|
+
name: 'imageUrl',
|
|
102
|
+
component: MngFormlyFieldInputComponent,
|
|
103
|
+
defaultOptions: {
|
|
104
|
+
props: {
|
|
105
|
+
type: 'imageUrl'
|
|
106
|
+
}
|
|
107
|
+
},
|
|
108
|
+
wrappers: ['field']
|
|
109
|
+
},
|
|
100
110
|
{
|
|
101
111
|
name: 'dropdown',
|
|
102
112
|
component: MngFormlyFieldDropdownComponent,
|
|
@@ -160,6 +170,20 @@ export function getMaxLengthValidationMessage(translate) {
|
|
|
160
170
|
return translate.instant('mngEditor.validation.maxLength', { field: fieldName, maxLength: field.props.maxLength });
|
|
161
171
|
};
|
|
162
172
|
}
|
|
173
|
+
export function getMinValidationMessage(translate) {
|
|
174
|
+
return (error, field) => {
|
|
175
|
+
const fieldLabel = field.props.label ?? 'field';
|
|
176
|
+
const fieldName = translate.instant(fieldLabel);
|
|
177
|
+
return translate.instant('mngEditor.validation.min', { field: fieldName, min: field.props.min });
|
|
178
|
+
};
|
|
179
|
+
}
|
|
180
|
+
export function getMaxValidationMessage(translate) {
|
|
181
|
+
return (error, field) => {
|
|
182
|
+
const fieldLabel = field.props.label || 'field';
|
|
183
|
+
const fieldName = translate.instant(fieldLabel);
|
|
184
|
+
return translate.instant('mngEditor.validation.max', { field: fieldName, max: field.props.max });
|
|
185
|
+
};
|
|
186
|
+
}
|
|
163
187
|
export function getTextPatternValidationMessage(translate) {
|
|
164
188
|
return (error, field) => {
|
|
165
189
|
const fieldLabel = field.props.label ?? 'field';
|
|
@@ -179,8 +203,10 @@ export const getFormlyValidationMessages = (translate) => {
|
|
|
179
203
|
{ name: 'required', message: getRequiredValidationMessage(translate) },
|
|
180
204
|
{ name: 'minLength', message: getMinLengthValidationMessage(translate) },
|
|
181
205
|
{ name: 'maxLength', message: getMaxLengthValidationMessage(translate) },
|
|
206
|
+
{ name: 'min', message: getMinValidationMessage(translate) },
|
|
207
|
+
{ name: 'max', message: getMaxValidationMessage(translate) },
|
|
182
208
|
{ name: 'pattern', message: getTextPatternValidationMessage(translate) },
|
|
183
209
|
{ name: 'email', message: getEmailValidationMessage(translate) }
|
|
184
210
|
];
|
|
185
211
|
};
|
|
186
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly.config.js","sourceRoot":"","sources":["../../../../../../src/lib/components/form/formly/formly.config.ts"],"names":[],"mappings":"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","sourcesContent":["import {WrapperOption} from '@ngx-formly/core/lib/models/config';\nimport {TranslateService} from '@ngx-translate/core';\nimport {Observable} from 'rxjs';\n\nimport {\n    MngFormlyFieldActionComponent,\n    MngFormlyFieldAutocompleteComponent,\n    MngFormlyFieldDropdownComponent,\n    MngFormlyFieldFieldsetComponent,\n    MngFormlyFieldInputComponent,\n    MngFormlyFieldLabelComponent,\n    MngFormlyFieldLookupDialogComponent,\n    MngFormlyFieldTableDialogFormComponent,\n    MngFormlyFieldTableDialogMultiselectComponent,\n    MngFormlyFieldTabsComponent\n} from './fields';\nimport {MngFormlyFieldConfig, MngFormlyTypeConfig} from './models';\nimport {MngFormlyFieldNoLabelWrapperComponent, MngFormlyFieldWrapperComponent} from './wrappers';\n\nexport const formlyWrappersConfig: WrapperOption[] = [\n    {name: 'field', component: MngFormlyFieldWrapperComponent},\n    {name: 'field-no-label', component: MngFormlyFieldNoLabelWrapperComponent}\n];\n\nexport const formlyTypesConfig: MngFormlyTypeConfig[] = [\n    {\n        name: 'label',\n        component: MngFormlyFieldLabelComponent,\n        wrappers: ['field']\n    },\n    {\n        name: 'input',\n        component: MngFormlyFieldInputComponent,\n        wrappers: ['field']\n    },\n    {name: 'string', extends: 'input'},\n    {\n        name: 'number',\n        extends: 'input',\n        defaultOptions: {\n            props: {\n                type: 'number'\n            }\n        }\n    },\n    {\n        name: 'currency',\n        extends: 'input',\n        defaultOptions: {\n            props: {\n                type: 'number'\n            }\n        }\n    },\n    {\n        name: 'integer',\n        extends: 'input',\n        defaultOptions: {\n            props: {\n                type: 'number'\n            }\n        }\n    },\n    {\n        name: 'textarea',\n        extends: 'input',\n        defaultOptions: {\n            props: {\n                type: 'textarea'\n            }\n        }\n    },\n    {\n        name: 'switch',\n        component: MngFormlyFieldInputComponent,\n        defaultOptions: {\n            props: {\n                type: 'switch'\n            }\n        }\n    },\n    {\n        name: 'radio',\n        extends: 'input',\n        defaultOptions: {\n            props: {\n                type: 'radio'\n            }\n        }\n    },\n    {\n        name: 'datepicker',\n        extends: 'input',\n        defaultOptions: {\n            props: {\n                type: 'datepicker'\n            }\n        }\n    },\n    {\n        name: 'mask',\n        extends: 'input',\n        defaultOptions: {\n            props: {\n                type: 'mask'\n            }\n        }\n    },\n    {\n        name: 'file',\n        extends: 'input',\n        defaultOptions: {\n            props: {\n                type: 'file'\n            }\n        }\n    },\n    {\n        name: 'dropdown',\n        component: MngFormlyFieldDropdownComponent,\n        wrappers: ['field']\n    },\n    {name: 'enum', extends: 'dropdown'},\n    {\n        name: 'autocomplete',\n        component: MngFormlyFieldAutocompleteComponent,\n        wrappers: ['field']\n    },\n    {\n        name: 'action',\n        component: MngFormlyFieldActionComponent,\n        wrappers: ['field-no-label']\n    },\n    {\n        name: 'dialog',\n        component: MngFormlyFieldLookupDialogComponent,\n        wrappers: ['field']\n    },\n    {\n        name: 'table-dialog-multiselect',\n        component: MngFormlyFieldTableDialogMultiselectComponent,\n        wrappers: ['field-no-label']\n    },\n    {\n        name: 'table-dialog-form',\n        component: MngFormlyFieldTableDialogFormComponent,\n        wrappers: ['field-no-label']\n    },\n    {\n        name: 'tabs',\n        component: MngFormlyFieldTabsComponent,\n        wrappers: []\n    },\n    {\n        name: 'fieldset',\n        component: MngFormlyFieldFieldsetComponent,\n        wrappers: []\n    }\n];\n\nexport function getRequiredValidationMessage(translate: TranslateService): (error: any, field: MngFormlyFieldConfig) => Observable<string> {\n    return (error: any, field: MngFormlyFieldConfig) => {\n        const fieldLabel = field.props.label || 'field';\n        const fieldName = translate.instant(fieldLabel);\n        return translate.instant('mngEditor.validation.required', {field: fieldName});\n    };\n}\n\nexport function getMinLengthValidationMessage(translate: TranslateService): (error: any, field: MngFormlyFieldConfig) => Observable<string> | undefined {\n    return (error: any, field: MngFormlyFieldConfig) => {\n        const fieldLabel = field.props.label ?? 'field';\n        const fieldName = translate.instant(fieldLabel);\n        return translate.instant('mngEditor.validation.minLength', {field: fieldName, minLength: field.props.minLength});\n    };\n}\n\nexport function getMaxLengthValidationMessage(translate: TranslateService): (error: any, field: MngFormlyFieldConfig) => Observable<string> | undefined {\n    return (error: any, field: MngFormlyFieldConfig) => {\n        const fieldLabel = field.props.label || 'field';\n        const fieldName = translate.instant(fieldLabel);\n        return translate.instant('mngEditor.validation.maxLength', {field: fieldName, maxLength: field.props.maxLength});\n    };\n}\n\nexport function getTextPatternValidationMessage(translate: TranslateService): (error: any, field: MngFormlyFieldConfig) => Observable<string> | undefined {\n    return (error: any, field: MngFormlyFieldConfig) => {\n        const fieldLabel = field.props.label ?? 'field';\n        const fieldName = translate.instant(fieldLabel);\n        return translate.instant('mngEditor.validation.pattern', {field: fieldName, pattern: field.props.pattern});\n    };\n}\n\nexport function getEmailValidationMessage(translate: TranslateService): (error: any, field: MngFormlyFieldConfig) => Observable<string> | undefined {\n    return (error: any, field: MngFormlyFieldConfig) => {\n        const fieldLabel = field.props.label || 'field';\n        const fieldName = translate.instant(fieldLabel);\n        return translate.instant('mngEditor.validation.email', {field: fieldName});\n    };\n}\n\nexport const getFormlyValidationMessages = (translate: TranslateService): any[] => {\n    return [\n        {name: 'required', message: getRequiredValidationMessage(translate)},\n        {name: 'minLength', message: getMinLengthValidationMessage(translate)},\n        {name: 'maxLength', message: getMaxLengthValidationMessage(translate)},\n        {name: 'pattern', message: getTextPatternValidationMessage(translate)},\n        {name: 'email', message: getEmailValidationMessage(translate)}\n    ];\n};\n"]}
|
|
212
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly.config.js","sourceRoot":"","sources":["../../../../../../src/lib/components/form/formly/formly.config.ts"],"names":[],"mappings":"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","sourcesContent":["import {WrapperOption} from '@ngx-formly/core/lib/models/config';\nimport {TranslateService} from '@ngx-translate/core';\nimport {Observable} from 'rxjs';\n\nimport {\n    MngFormlyFieldActionComponent,\n    MngFormlyFieldAutocompleteComponent,\n    MngFormlyFieldDropdownComponent,\n    MngFormlyFieldFieldsetComponent,\n    MngFormlyFieldInputComponent,\n    MngFormlyFieldLabelComponent,\n    MngFormlyFieldLookupDialogComponent,\n    MngFormlyFieldTableDialogFormComponent,\n    MngFormlyFieldTableDialogMultiselectComponent,\n    MngFormlyFieldTabsComponent\n} from './fields';\nimport {MngFormlyFieldConfig, MngFormlyTypeConfig} from './models';\nimport {MngFormlyFieldNoLabelWrapperComponent, MngFormlyFieldWrapperComponent} from './wrappers';\n\nexport const formlyWrappersConfig: WrapperOption[] = [\n    {name: 'field', component: MngFormlyFieldWrapperComponent},\n    {name: 'field-no-label', component: MngFormlyFieldNoLabelWrapperComponent}\n];\n\nexport const formlyTypesConfig: MngFormlyTypeConfig[] = [\n    {\n        name: 'label',\n        component: MngFormlyFieldLabelComponent,\n        wrappers: ['field']\n    },\n    {\n        name: 'input',\n        component: MngFormlyFieldInputComponent,\n        wrappers: ['field']\n    },\n    {name: 'string', extends: 'input'},\n    {\n        name: 'number',\n        extends: 'input',\n        defaultOptions: {\n            props: {\n                type: 'number'\n            }\n        }\n    },\n    {\n        name: 'currency',\n        extends: 'input',\n        defaultOptions: {\n            props: {\n                type: 'number'\n            }\n        }\n    },\n    {\n        name: 'integer',\n        extends: 'input',\n        defaultOptions: {\n            props: {\n                type: 'number'\n            }\n        }\n    },\n    {\n        name: 'textarea',\n        extends: 'input',\n        defaultOptions: {\n            props: {\n                type: 'textarea'\n            }\n        }\n    },\n    {\n        name: 'switch',\n        component: MngFormlyFieldInputComponent,\n        defaultOptions: {\n            props: {\n                type: 'switch'\n            }\n        }\n    },\n    {\n        name: 'radio',\n        extends: 'input',\n        defaultOptions: {\n            props: {\n                type: 'radio'\n            }\n        }\n    },\n    {\n        name: 'datepicker',\n        extends: 'input',\n        defaultOptions: {\n            props: {\n                type: 'datepicker'\n            }\n        }\n    },\n    {\n        name: 'mask',\n        extends: 'input',\n        defaultOptions: {\n            props: {\n                type: 'mask'\n            }\n        }\n    },\n    {\n        name: 'file',\n        extends: 'input',\n        defaultOptions: {\n            props: {\n                type: 'file'\n            }\n        }\n    },\n    {\n        name: 'imageUrl',\n        component: MngFormlyFieldInputComponent,\n        defaultOptions: {\n            props: {\n                type: 'imageUrl'\n            }\n        },\n        wrappers: ['field']\n    },\n    {\n        name: 'dropdown',\n        component: MngFormlyFieldDropdownComponent,\n        wrappers: ['field']\n    },\n    {name: 'enum', extends: 'dropdown'},\n    {\n        name: 'autocomplete',\n        component: MngFormlyFieldAutocompleteComponent,\n        wrappers: ['field']\n    },\n    {\n        name: 'action',\n        component: MngFormlyFieldActionComponent,\n        wrappers: ['field-no-label']\n    },\n    {\n        name: 'dialog',\n        component: MngFormlyFieldLookupDialogComponent,\n        wrappers: ['field']\n    },\n    {\n        name: 'table-dialog-multiselect',\n        component: MngFormlyFieldTableDialogMultiselectComponent,\n        wrappers: ['field-no-label']\n    },\n    {\n        name: 'table-dialog-form',\n        component: MngFormlyFieldTableDialogFormComponent,\n        wrappers: ['field-no-label']\n    },\n    {\n        name: 'tabs',\n        component: MngFormlyFieldTabsComponent,\n        wrappers: []\n    },\n    {\n        name: 'fieldset',\n        component: MngFormlyFieldFieldsetComponent,\n        wrappers: []\n    }\n];\n\nexport function getRequiredValidationMessage(translate: TranslateService): (error: any, field: MngFormlyFieldConfig) => Observable<string> {\n    return (error: any, field: MngFormlyFieldConfig) => {\n        const fieldLabel = field.props.label || 'field';\n        const fieldName = translate.instant(fieldLabel);\n        return translate.instant('mngEditor.validation.required', {field: fieldName});\n    };\n}\n\nexport function getMinLengthValidationMessage(translate: TranslateService): (error: any, field: MngFormlyFieldConfig) => Observable<string> | undefined {\n    return (error: any, field: MngFormlyFieldConfig) => {\n        const fieldLabel = field.props.label ?? 'field';\n        const fieldName = translate.instant(fieldLabel);\n        return translate.instant('mngEditor.validation.minLength', {field: fieldName, minLength: field.props.minLength});\n    };\n}\n\nexport function getMaxLengthValidationMessage(translate: TranslateService): (error: any, field: MngFormlyFieldConfig) => Observable<string> | undefined {\n    return (error: any, field: MngFormlyFieldConfig) => {\n        const fieldLabel = field.props.label || 'field';\n        const fieldName = translate.instant(fieldLabel);\n        return translate.instant('mngEditor.validation.maxLength', {field: fieldName, maxLength: field.props.maxLength});\n    };\n}\n\nexport function getMinValidationMessage(translate: TranslateService): (error: any, field: MngFormlyFieldConfig) => Observable<string> | undefined {\n    return (error: any, field: MngFormlyFieldConfig) => {\n        const fieldLabel = field.props.label ?? 'field';\n        const fieldName = translate.instant(fieldLabel);\n        return translate.instant('mngEditor.validation.min', {field: fieldName, min: field.props.min});\n    };\n}\n\nexport function getMaxValidationMessage(translate: TranslateService): (error: any, field: MngFormlyFieldConfig) => Observable<string> | undefined {\n    return (error: any, field: MngFormlyFieldConfig) => {\n        const fieldLabel = field.props.label || 'field';\n        const fieldName = translate.instant(fieldLabel);\n        return translate.instant('mngEditor.validation.max', {field: fieldName, max: field.props.max});\n    };\n}\n\nexport function getTextPatternValidationMessage(translate: TranslateService): (error: any, field: MngFormlyFieldConfig) => Observable<string> | undefined {\n    return (error: any, field: MngFormlyFieldConfig) => {\n        const fieldLabel = field.props.label ?? 'field';\n        const fieldName = translate.instant(fieldLabel);\n        return translate.instant('mngEditor.validation.pattern', {field: fieldName, pattern: field.props.pattern});\n    };\n}\n\nexport function getEmailValidationMessage(translate: TranslateService): (error: any, field: MngFormlyFieldConfig) => Observable<string> | undefined {\n    return (error: any, field: MngFormlyFieldConfig) => {\n        const fieldLabel = field.props.label || 'field';\n        const fieldName = translate.instant(fieldLabel);\n        return translate.instant('mngEditor.validation.email', {field: fieldName});\n    };\n}\n\nexport const getFormlyValidationMessages = (translate: TranslateService): any[] => {\n    return [\n        {name: 'required', message: getRequiredValidationMessage(translate)},\n        {name: 'minLength', message: getMinLengthValidationMessage(translate)},\n        {name: 'maxLength', message: getMaxLengthValidationMessage(translate)},\n        {name: 'min', message: getMinValidationMessage(translate)},\n        {name: 'max', message: getMaxValidationMessage(translate)},\n        {name: 'pattern', message: getTextPatternValidationMessage(translate)},\n        {name: 'email', message: getEmailValidationMessage(translate)}\n    ];\n};\n"]}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { Directive, inject } from '@angular/core';
|
|
2
2
|
import { ActivatedRoute } from '@angular/router';
|
|
3
3
|
import * as FileSaver from 'file-saver';
|
|
4
|
-
import { of } from 'rxjs';
|
|
4
|
+
import { of, tap } from 'rxjs';
|
|
5
5
|
import { map } from 'rxjs/operators';
|
|
6
6
|
import { MediusQueryParamBuilder } from '../../../api/models/builders/query-param.builder';
|
|
7
|
-
import { ActionDeleteDescriptor, ActionDescriptor, ActionEditorAddDescriptor, ActionEditorDetailsDescriptor, ActionEditorEditDescriptor } from '../../../descriptors';
|
|
7
|
+
import { ActionDeleteDescriptor, ActionDescriptor, ActionEditorAddDescriptor, ActionEditorDetailsDescriptor, ActionEditorEditDescriptor, ActionLinkDescriptor } from '../../../descriptors';
|
|
8
8
|
import { ActionPositionEnum } from '../../../descriptors/types';
|
|
9
|
-
import { StyleLevelEnum } from '../../../styles/models';
|
|
9
|
+
import { StyleLevelEnum, StyleSizeEnum } from '../../../styles/models';
|
|
10
10
|
import { ActionDataProviderUtil } from '../../../utils';
|
|
11
11
|
import { TableviewActionDefaultCategories } from '../../action/models';
|
|
12
12
|
import * as i0 from "@angular/core";
|
|
@@ -29,7 +29,10 @@ export class AMngTableviewRouteComponent {
|
|
|
29
29
|
this.createActionDescriptorForEdit(),
|
|
30
30
|
this.createActionDescriptorForDelete(),
|
|
31
31
|
this.createActionDescriptorForRefresh(),
|
|
32
|
-
this.createActionDescriptorForExport()
|
|
32
|
+
this.createActionDescriptorForExport(),
|
|
33
|
+
//details actions
|
|
34
|
+
this.createActionDescriptorForDetailsEditLink(),
|
|
35
|
+
this.createActionDescriptorForDetailsDelete()
|
|
33
36
|
].filter(e => e != null);
|
|
34
37
|
}
|
|
35
38
|
createActionDescriptorForDetails(descriptor = this.descriptor.detailsEditor) {
|
|
@@ -41,6 +44,36 @@ export class AMngTableviewRouteComponent {
|
|
|
41
44
|
createActionDescriptorForEdit(descriptor = this.descriptor.editEditor) {
|
|
42
45
|
return !this.routeData.tableviewActions || this.routeData.tableviewActions.hasEdit ? new ActionEditorEditDescriptor(descriptor) : null;
|
|
43
46
|
}
|
|
47
|
+
createActionDescriptorForDetailsEditLink(descriptor = this.descriptor.model) {
|
|
48
|
+
if (!this.routeData.tableviewActions || this.routeData.tableviewActions.hasEdit) {
|
|
49
|
+
const action = new ActionLinkDescriptor(descriptor, ActionEditorEditDescriptor.ACTION_NAME)
|
|
50
|
+
.withTableviewCategory(TableviewActionDefaultCategories.EDIT)
|
|
51
|
+
.withPositionTableviewCategories([TableviewActionDefaultCategories.DETAILS])
|
|
52
|
+
.withPosition(ActionPositionEnum.FooterLeft)
|
|
53
|
+
.withRouterLink('./edit');
|
|
54
|
+
action.button.styleClass.withActionLevel(StyleLevelEnum.Secondary);
|
|
55
|
+
action.button.withIcon('pi pi-pencil');
|
|
56
|
+
return action;
|
|
57
|
+
}
|
|
58
|
+
return null;
|
|
59
|
+
}
|
|
60
|
+
createActionDescriptorForDetailsDelete(descriptor = this.descriptor.model) {
|
|
61
|
+
const action = this.createActionDescriptorForDelete();
|
|
62
|
+
if (action) {
|
|
63
|
+
action
|
|
64
|
+
.withTableviewCategory(TableviewActionDefaultCategories.DELETE)
|
|
65
|
+
.withPositionTableviewCategories([TableviewActionDefaultCategories.DETAILS])
|
|
66
|
+
.withPosition(ActionPositionEnum.FooterLeft)
|
|
67
|
+
.withRunFunction(ctx => ActionDataProviderUtil.runDeleteOrFail(ctx).pipe(tap(() => {
|
|
68
|
+
ctx.parameters.viewContainer?.reloadTable?.({});
|
|
69
|
+
ctx.parameters.viewContainer?.closeEditor?.();
|
|
70
|
+
})));
|
|
71
|
+
action.button.withLabel(undefined);
|
|
72
|
+
action.button.styleClass.withSize(StyleSizeEnum.Normal);
|
|
73
|
+
return action;
|
|
74
|
+
}
|
|
75
|
+
return null;
|
|
76
|
+
}
|
|
44
77
|
createActionDescriptorForDelete(descriptor = this.descriptor.model) {
|
|
45
78
|
return !this.routeData.tableviewActions || this.routeData.tableviewActions.hasDelete ? new ActionDeleteDescriptor(descriptor) : null;
|
|
46
79
|
}
|
|
@@ -79,4 +112,4 @@ AMngTableviewRouteComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.
|
|
|
79
112
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: AMngTableviewRouteComponent, decorators: [{
|
|
80
113
|
type: Directive
|
|
81
114
|
}], ctorParameters: function () { return []; } });
|
|
82
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tableview-route.abstract.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/tableview/route/tableview-route.abstract.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, OnInit, inject} from '@angular/core';\nimport {ActivatedRoute} from '@angular/router';\n\nimport * as FileSaver from 'file-saver';\nimport {of} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\nimport {MediusQueryParamBuilder} from '../../../api/models/builders/query-param.builder';\nimport {ITableviewDataProvider} from '../../../data-providers';\nimport {\n    ActionDeleteDescriptor,\n    ActionDescriptor,\n    ActionEditorAddDescriptor,\n    ActionEditorDetailsDescriptor,\n    ActionEditorEditDescriptor,\n    EditorDescriptor,\n    ModelDescriptor,\n    TableviewDescriptor\n} from '../../../descriptors';\nimport {ActionPositionEnum} from '../../../descriptors/types';\nimport {IViewContainerTable} from '../../../models';\nimport {MngRouterData} from '../../../router/models';\nimport {StyleLevelEnum} from '../../../styles/models';\nimport {ActionDataProviderUtil} from '../../../utils';\nimport {ActionContext, TableviewActionDefaultCategories} from '../../action/models';\n\n@Directive()\nexport abstract class AMngTableviewRouteComponent<T, S> implements OnInit {\n    public descriptor!: TableviewDescriptor<T>;\n    public dataProvider!: ITableviewDataProvider<T, S>;\n    public actions!: Array<ActionDescriptor<T>>;\n\n    protected route: ActivatedRoute;\n\n    constructor() {\n        this.route = inject(ActivatedRoute);\n    }\n\n    protected get routeData() {\n        return this.route.snapshot.data as MngRouterData;\n    }\n\n    public ngOnInit() {\n        this.descriptor = this.createTableviewDescriptor();\n        this.dataProvider = this.createTableviewDataProvider();\n        this.actions = this.createActionDescriptors();\n    }\n\n    protected abstract createTableviewDescriptor(): TableviewDescriptor<T>;\n\n    protected abstract createTableviewDataProvider(): ITableviewDataProvider<T, S>;\n\n    protected createActionDescriptors(): Array<ActionDescriptor<T>> {\n        return [\n            this.createActionDescriptorForDetails(),\n            this.createActionDescriptorForAdd(),\n            this.createActionDescriptorForEdit(),\n            this.createActionDescriptorForDelete(),\n            this.createActionDescriptorForRefresh(),\n            this.createActionDescriptorForExport()\n        ].filter(e => e != null) as Array<ActionDescriptor<T>>;\n    }\n\n    protected createActionDescriptorForDetails(descriptor: EditorDescriptor<T> = this.descriptor.detailsEditor): ActionEditorDetailsDescriptor<T> | null {\n        return !this.routeData.tableviewActions || this.routeData.tableviewActions.hasDetails ? new ActionEditorDetailsDescriptor(descriptor) : null;\n    }\n\n    protected createActionDescriptorForAdd(descriptor: EditorDescriptor<T> = this.descriptor.addEditor): ActionEditorAddDescriptor<T> | null {\n        return !this.routeData.tableviewActions || this.routeData.tableviewActions.hasAdd ? new ActionEditorAddDescriptor(descriptor) : null;\n    }\n\n    protected createActionDescriptorForEdit(descriptor: EditorDescriptor<T> = this.descriptor.editEditor): ActionEditorEditDescriptor<T> | null {\n        return !this.routeData.tableviewActions || this.routeData.tableviewActions.hasEdit ? new ActionEditorEditDescriptor(descriptor) : null;\n    }\n\n    protected createActionDescriptorForDelete(descriptor: ModelDescriptor<T> = this.descriptor.model): ActionDeleteDescriptor<T> | null {\n        return !this.routeData.tableviewActions || this.routeData.tableviewActions.hasDelete ? new ActionDeleteDescriptor(descriptor) : null;\n    }\n\n    protected createActionDescriptorForExport(descriptor: ModelDescriptor<T> = this.descriptor.model): ActionDescriptor<T> {\n        const action = new ActionDescriptor(descriptor, 'export')\n            .withRunFunction(ctx => {\n                const queryParamBuilder = ctx.parameters.queryParam ? MediusQueryParamBuilder.createFromExisting(ctx.parameters.queryParam) : MediusQueryParamBuilder.create();\n                queryParamBuilder.withItemsOffset(0).withItemsPerPage(500);\n                ctx.parameters.withQueryParam(queryParamBuilder.build());\n                return ActionDataProviderUtil.runGetAllOrFail(ctx).pipe(\n                    map(res => {\n                        const blob = new Blob([JSON.stringify(res.pageData, undefined, 4)], {type: 'application/json;charset=utf-8'});\n                        const typeName = ctx.instance.action.model?.typeName ?? '';\n                        FileSaver.saveAs(blob, `${typeName ? typeName + '_' : ''}${ctx.instance.action.actionName}.json`);\n                        return undefined;\n                    })\n                );\n            })\n            .withPosition(ActionPositionEnum.ToolbarRight);\n        action.button.withIcon('pi pi-upload');\n        return action;\n    }\n\n    protected createActionDescriptorForRefresh(descriptor: ModelDescriptor<T> = this.descriptor.model): ActionDescriptor<T> {\n        const action = new ActionDescriptor<T>(descriptor, 'refresh')\n            .withPosition(ActionPositionEnum.ToolbarRight)\n            .withTableviewCategory(TableviewActionDefaultCategories.READ)\n            .withRunNotificationSuccess(undefined, undefined, false)\n            .withRunFunction((ctx: ActionContext<T, S>) => {\n                (ctx.parameters.viewContainer as IViewContainerTable<T, S>)?.reloadTable?.({});\n                return of(null);\n            });\n        action.button.withIcon('pi pi-refresh').styleClass.withActionLevel(StyleLevelEnum.Secondary);\n        return action;\n    }\n}\n"]}
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tableview-route.abstract.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/tableview/route/tableview-route.abstract.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, OnInit, inject} from '@angular/core';\nimport {ActivatedRoute} from '@angular/router';\n\nimport * as FileSaver from 'file-saver';\nimport {of, tap} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\nimport {MediusQueryParamBuilder} from '../../../api/models/builders/query-param.builder';\nimport {ITableviewDataProvider} from '../../../data-providers';\nimport {\n    ActionDeleteDescriptor,\n    ActionDescriptor,\n    ActionEditorAddDescriptor,\n    ActionEditorDetailsDescriptor,\n    ActionEditorEditDescriptor,\n    ActionLinkDescriptor,\n    EditorDescriptor,\n    ModelDescriptor,\n    TableviewDescriptor\n} from '../../../descriptors';\nimport {ActionPositionEnum} from '../../../descriptors/types';\nimport {IViewContainerEditor, IViewContainerTable} from '../../../models';\nimport {MngRouterData} from '../../../router/models';\nimport {StyleLevelEnum, StyleSizeEnum} from '../../../styles/models';\nimport {ActionDataProviderUtil} from '../../../utils';\nimport {ActionContext, TableviewActionDefaultCategories} from '../../action/models';\n\n@Directive()\nexport abstract class AMngTableviewRouteComponent<T, S> implements OnInit {\n    public descriptor!: TableviewDescriptor<T>;\n    public dataProvider!: ITableviewDataProvider<T, S>;\n    public actions!: Array<ActionDescriptor<T>>;\n\n    protected route: ActivatedRoute;\n\n    constructor() {\n        this.route = inject(ActivatedRoute);\n    }\n\n    protected get routeData() {\n        return this.route.snapshot.data as MngRouterData;\n    }\n\n    public ngOnInit() {\n        this.descriptor = this.createTableviewDescriptor();\n        this.dataProvider = this.createTableviewDataProvider();\n        this.actions = this.createActionDescriptors();\n    }\n\n    protected abstract createTableviewDescriptor(): TableviewDescriptor<T>;\n\n    protected abstract createTableviewDataProvider(): ITableviewDataProvider<T, S>;\n\n    protected createActionDescriptors(): Array<ActionDescriptor<T>> {\n        return [\n            this.createActionDescriptorForDetails(),\n            this.createActionDescriptorForAdd(),\n            this.createActionDescriptorForEdit(),\n            this.createActionDescriptorForDelete(),\n            this.createActionDescriptorForRefresh(),\n            this.createActionDescriptorForExport(),\n\n            //details actions\n            this.createActionDescriptorForDetailsEditLink(),\n            this.createActionDescriptorForDetailsDelete()\n        ].filter(e => e != null) as Array<ActionDescriptor<T>>;\n    }\n\n    protected createActionDescriptorForDetails(descriptor: EditorDescriptor<T> = this.descriptor.detailsEditor): ActionEditorDetailsDescriptor<T> | null {\n        return !this.routeData.tableviewActions || this.routeData.tableviewActions.hasDetails ? new ActionEditorDetailsDescriptor(descriptor) : null;\n    }\n\n    protected createActionDescriptorForAdd(descriptor: EditorDescriptor<T> = this.descriptor.addEditor): ActionEditorAddDescriptor<T> | null {\n        return !this.routeData.tableviewActions || this.routeData.tableviewActions.hasAdd ? new ActionEditorAddDescriptor(descriptor) : null;\n    }\n\n    protected createActionDescriptorForEdit(descriptor: EditorDescriptor<T> = this.descriptor.editEditor): ActionEditorEditDescriptor<T> | null {\n        return !this.routeData.tableviewActions || this.routeData.tableviewActions.hasEdit ? new ActionEditorEditDescriptor(descriptor) : null;\n    }\n\n    protected createActionDescriptorForDetailsEditLink(descriptor: ModelDescriptor<T> = this.descriptor.model): ActionLinkDescriptor<T> | null {\n        if (!this.routeData.tableviewActions || this.routeData.tableviewActions.hasEdit) {\n            const action = new ActionLinkDescriptor(descriptor, ActionEditorEditDescriptor.ACTION_NAME)\n                .withTableviewCategory(TableviewActionDefaultCategories.EDIT)\n                .withPositionTableviewCategories([TableviewActionDefaultCategories.DETAILS])\n                .withPosition(ActionPositionEnum.FooterLeft)\n                .withRouterLink('./edit');\n            action.button.styleClass.withActionLevel(StyleLevelEnum.Secondary);\n            action.button.withIcon('pi pi-pencil');\n\n            return action;\n        }\n\n        return null;\n    }\n\n    protected createActionDescriptorForDetailsDelete(descriptor: ModelDescriptor<T> = this.descriptor.model): ActionDescriptor<T> | null {\n        const action = this.createActionDescriptorForDelete();\n        if (action) {\n            action\n                .withTableviewCategory(TableviewActionDefaultCategories.DELETE)\n                .withPositionTableviewCategories([TableviewActionDefaultCategories.DETAILS])\n                .withPosition(ActionPositionEnum.FooterLeft)\n                .withRunFunction(ctx =>\n                    ActionDataProviderUtil.runDeleteOrFail(ctx).pipe(\n                        tap(() => {\n                            (ctx.parameters.viewContainer as IViewContainerTable<unknown, unknown>)?.reloadTable?.({});\n                            (ctx.parameters.viewContainer as IViewContainerEditor<unknown, unknown>)?.closeEditor?.();\n                        })\n                    )\n                );\n            action.button.withLabel(undefined);\n            action.button.styleClass.withSize(StyleSizeEnum.Normal);\n\n            return action;\n        }\n\n        return null;\n    }\n\n    protected createActionDescriptorForDelete(descriptor: ModelDescriptor<T> = this.descriptor.model): ActionDeleteDescriptor<T> | null {\n        return !this.routeData.tableviewActions || this.routeData.tableviewActions.hasDelete ? new ActionDeleteDescriptor(descriptor) : null;\n    }\n\n    protected createActionDescriptorForExport(descriptor: ModelDescriptor<T> = this.descriptor.model): ActionDescriptor<T> | null {\n        const action = new ActionDescriptor(descriptor, 'export')\n            .withRunFunction(ctx => {\n                const queryParamBuilder = ctx.parameters.queryParam ? MediusQueryParamBuilder.createFromExisting(ctx.parameters.queryParam) : MediusQueryParamBuilder.create();\n                queryParamBuilder.withItemsOffset(0).withItemsPerPage(500);\n                ctx.parameters.withQueryParam(queryParamBuilder.build());\n                return ActionDataProviderUtil.runGetAllOrFail(ctx).pipe(\n                    map(res => {\n                        const blob = new Blob([JSON.stringify(res.pageData, undefined, 4)], {type: 'application/json;charset=utf-8'});\n                        const typeName = ctx.instance.action.model?.typeName ?? '';\n                        FileSaver.saveAs(blob, `${typeName ? typeName + '_' : ''}${ctx.instance.action.actionName}.json`);\n                        return undefined;\n                    })\n                );\n            })\n            .withPosition(ActionPositionEnum.ToolbarRight);\n        action.button.withIcon('pi pi-upload');\n        return action;\n    }\n\n    protected createActionDescriptorForRefresh(descriptor: ModelDescriptor<T> = this.descriptor.model): ActionDescriptor<T> | null {\n        const action = new ActionDescriptor<T>(descriptor, 'refresh')\n            .withPosition(ActionPositionEnum.ToolbarRight)\n            .withTableviewCategory(TableviewActionDefaultCategories.READ)\n            .withRunNotificationSuccess(undefined, undefined, false)\n            .withRunFunction((ctx: ActionContext<T, S>) => {\n                (ctx.parameters.viewContainer as IViewContainerTable<T, S>)?.reloadTable?.({});\n                return of(null);\n            });\n        action.button.withIcon('pi pi-refresh').styleClass.withActionLevel(StyleLevelEnum.Secondary);\n        return action;\n    }\n}\n"]}
|
|
@@ -105,7 +105,7 @@ export class MngTableColumnFilterComponent {
|
|
|
105
105
|
}
|
|
106
106
|
}
|
|
107
107
|
MngTableColumnFilterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: MngTableColumnFilterComponent, deps: [{ token: i1.PrimeNGConfig }], target: i0.ɵɵFactoryTarget.Component });
|
|
108
|
-
MngTableColumnFilterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.0", type: MngTableColumnFilterComponent, selector: "mng-table-column-filter", inputs: { descriptor: "descriptor", display: "display" }, viewQueries: [{ propertyName: "primeColumnFilter", first: true, predicate: ColumnFilter, descendants: true }], ngImport: i0, template: "<p-columnFilter\n class=\"ml-auto\"\n [type]=\"primeType\"\n [field]=\"descriptor.property\"\n [display]=\"primeDisplay\"\n [matchMode]=\"$any(primeDefaultMatchMode)\"\n [matchModeOptions]=\"$any(primeMatchModes)\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.typeToFilter' | translate\"\n [showMatchModes]=\"true\"\n [showOperator]=\"false\"\n [showAddButton]=\"false\"\n [hideOnClear]=\"true\"\n [showMenu]=\"primeShowMatchMode\"\n [minFractionDigits]=\"$any(descriptor.numberMinFractionDigits)\"\n [maxFractionDigits]=\"$any(descriptor.numberMaxFractionDigits)\"\n [useGrouping]=\"descriptor.numberUseGrouping\">\n <ng-template *ngIf=\"primeType === 'date'\" pTemplate=\"filter\" let-value let-filterCallback=\"filterCallback\">\n <ng-container *ngIf=\"activeMatchMode === 'between'; else datePicker\">\n <mng-date-range\n [ngModel]=\"value\"\n (ngModelChange)=\"dateFilter($event, filterCallback)\"\n [showTime]=\"descriptor.datePickerShowTime\"\n [dateFormat]=\"descriptor.datePickerFormat\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.typeToFilter' | translate\"></mng-date-range>\n </ng-container>\n <ng-template #datePicker>\n <p-calendar\n appendTo=\"body\"\n [ngModel]=\"value\"\n (ngModelChange)=\"dateFilter($event, filterCallback)\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.typeToFilter' | translate\"\n [showIcon]=\"true\"\n [dateFormat]=\"descriptor.datePickerFormat ?? 'dd.mm.yy'\"\n [showTime]=\"descriptor.datePickerShowTime\">\n </p-calendar>\n </ng-template>\n </ng-template>\n <ng-template *ngIf=\"lookupDescriptor\" pTemplate=\"filter\" let-value let-filterCallback=\"filterCallback\">\n <ng-container [ngSwitch]=\"lookupDescriptor.lookupType\">\n <mng-autocomplete\n *ngSwitchCase=\"lookupTypeAutocomplete\"\n [ngModel]=\"value\"\n [dataProvider]=\"lookupDescriptor.dataProvider\"\n [dataKeyProperty]=\"lookupDescriptor.dataKeyProperty\"\n [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n [itemsLabelTranslate]=\"lookupDescriptor.itemsLabelTranslate\"\n [multiselect]=\"lookupDescriptor.multiselect\"\n [openOnFocus]=\"lookupDescriptor.autocompleteOpenOnFocus\"\n [inlineSearch]=\"lookupDescriptor.autocompleteInlineSearch\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.searchToFilter' | translate\"\n [className]=\"lookupDescriptor.className\"\n [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n (valueChange)=\"autocompleteFilter($event, filterCallback)\">\n </mng-autocomplete>\n <mng-dropdown\n *ngSwitchCase=\"lookupTypeDropdown\"\n [ngModel]=\"value\"\n [dataProvider]=\"lookupDescriptor.dataProvider\"\n [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n [itemsLabelTranslate]=\"lookupDescriptor.itemsLabelTranslate\"\n [multiselect]=\"lookupDescriptor.multiselect\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.selectToFilter' | translate\"\n [className]=\"lookupDescriptor.className\"\n [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n [showClear]=\"false\"\n [changeValueOnBlur]=\"lookupDescriptor.multiselect\"\n (valueChange)=\"dropdownFilter($event, filterCallback)\">\n </mng-dropdown>\n </ng-container>\n </ng-template>\n</p-columnFilter>\n", dependencies: [{ 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: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "component", type: i4.Calendar, selector: "p-calendar", inputs: ["style", "styleClass", "inputStyle", "inputId", "name", "inputStyleClass", "placeholder", "ariaLabelledBy", "iconAriaLabel", "disabled", "dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "selectOtherMonths", "showIcon", "icon", "appendTo", "readonlyInput", "shortYearCutoff", "monthNavigator", "yearNavigator", "hourFormat", "timeOnly", "stepHour", "stepMinute", "stepSecond", "showSeconds", "required", "showOnFocus", "showWeek", "showClear", "dataType", "selectionMode", "maxDateCount", "showButtonBar", "todayButtonStyleClass", "clearButtonStyleClass", "autoZIndex", "baseZIndex", "panelStyleClass", "panelStyle", "keepInvalid", "hideOnDateTimeSelect", "touchUI", "timeSeparator", "focusTrap", "showTransitionOptions", "hideTransitionOptions", "tabindex", "view", "defaultDate", "minDate", "maxDate", "disabledDates", "disabledDays", "yearRange", "showTime", "responsiveOptions", "numberOfMonths", "firstDayOfWeek", "locale"], outputs: ["onFocus", "onBlur", "onClose", "onSelect", "onClear", "onInput", "onTodayClick", "onClearClick", "onMonthChange", "onYearChange", "onClickOutside", "onShow"] }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.ColumnFilter, selector: "p-columnFilter", inputs: ["field", "type", "display", "showMenu", "matchMode", "operator", "showOperator", "showClearButton", "showApplyButton", "showMatchModes", "showAddButton", "hideOnClear", "placeholder", "matchModeOptions", "maxConstraints", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "locale", "localeMatcher", "currency", "currencyDisplay", "useGrouping"] }, { kind: "component", type: i6.MngAutocompleteComponent, selector: "mng-autocomplete", inputs: ["dataProvider", "dataKeyProperty", "itemsValueProperty", "itemsLabelProperty", "itemsLabelTranslate", "inlineSearch", "openOnFocus", "multiselect", "placeholder", "className", "dropdownClassName", "showClear", "autoClear", "selectFirst"], outputs: ["valueChange"] }, { kind: "component", type: i7.MngDropdownComponent, selector: "mng-dropdown", inputs: ["dataProvider", "dataKeyProperty", "itemsLabelProperty", "itemsLabelTranslate", "itemsValueProperty", "itemsDisabledProperty", "multiselect", "placeholder", "showClear", "selectFirstItem", "className", "dropdownClassName", "changeValueOnBlur"], outputs: ["valueChange"] }, { kind: "component", type: i8.MngDateRangeComponent, selector: "mng-date-range", inputs: ["placeholder", "showTime", "showSeconds", "dateFormat"] }, { kind: "pipe", type: i9.TranslatePipe, name: "translate" }] });
|
|
108
|
+
MngTableColumnFilterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.0", type: MngTableColumnFilterComponent, selector: "mng-table-column-filter", inputs: { descriptor: "descriptor", display: "display" }, viewQueries: [{ propertyName: "primeColumnFilter", first: true, predicate: ColumnFilter, descendants: true }], ngImport: i0, template: "<p-columnFilter\n class=\"ml-auto\"\n [type]=\"primeType\"\n [field]=\"descriptor.property\"\n [display]=\"primeDisplay\"\n [matchMode]=\"$any(primeDefaultMatchMode)\"\n [matchModeOptions]=\"$any(primeMatchModes)\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.typeToFilter' | translate\"\n [showMatchModes]=\"true\"\n [showOperator]=\"false\"\n [showAddButton]=\"false\"\n [hideOnClear]=\"true\"\n [showMenu]=\"primeShowMatchMode\"\n [minFractionDigits]=\"$any(descriptor.numberMinFractionDigits)\"\n [maxFractionDigits]=\"$any(descriptor.numberMaxFractionDigits)\"\n [useGrouping]=\"descriptor.numberUseGrouping\">\n <ng-template *ngIf=\"primeType === 'date'\" pTemplate=\"filter\" let-value let-filterCallback=\"filterCallback\">\n <ng-container *ngIf=\"activeMatchMode === 'between'; else datePicker\">\n <mng-date-range\n [ngModel]=\"value\"\n (ngModelChange)=\"dateFilter($event, filterCallback)\"\n [showTime]=\"descriptor.datePickerShowTime\"\n [dateFormat]=\"descriptor.datePickerFormat\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.typeToFilter' | translate\"></mng-date-range>\n </ng-container>\n <ng-template #datePicker>\n <p-calendar\n appendTo=\"body\"\n [ngModel]=\"value\"\n (ngModelChange)=\"dateFilter($event, filterCallback)\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.typeToFilter' | translate\"\n [showIcon]=\"true\"\n [dateFormat]=\"descriptor.datePickerFormat ?? 'dd.mm.yy'\"\n [showTime]=\"descriptor.datePickerShowTime\">\n </p-calendar>\n </ng-template>\n </ng-template>\n <ng-template *ngIf=\"lookupDescriptor\" pTemplate=\"filter\" let-value let-filterCallback=\"filterCallback\">\n <ng-container [ngSwitch]=\"lookupDescriptor.lookupType\">\n <mng-autocomplete\n *ngSwitchCase=\"lookupTypeAutocomplete\"\n [ngModel]=\"value\"\n [dataProvider]=\"lookupDescriptor.dataProvider\"\n [dataKeyProperty]=\"lookupDescriptor.dataKeyProperty\"\n [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n [itemsLabelTranslate]=\"lookupDescriptor.itemsLabelTranslate\"\n [multiselect]=\"lookupDescriptor.multiselect\"\n [openOnFocus]=\"lookupDescriptor.autocompleteOpenOnFocus\"\n [inlineSearch]=\"lookupDescriptor.autocompleteInlineSearch\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.searchToFilter' | translate\"\n [className]=\"lookupDescriptor.className\"\n [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n (valueChange)=\"autocompleteFilter($event, filterCallback)\">\n </mng-autocomplete>\n <mng-dropdown\n *ngSwitchCase=\"lookupTypeDropdown\"\n [ngModel]=\"value\"\n [dataProvider]=\"lookupDescriptor.dataProvider\"\n [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n [itemsLabelTranslate]=\"lookupDescriptor.itemsLabelTranslate\"\n [multiselect]=\"lookupDescriptor.multiselect\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.selectToFilter' | translate\"\n [className]=\"lookupDescriptor.className\"\n [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n [showClear]=\"false\"\n [changeValueOnBlur]=\"lookupDescriptor.multiselect\"\n (valueChange)=\"dropdownFilter($event, filterCallback)\">\n </mng-dropdown>\n </ng-container>\n </ng-template>\n</p-columnFilter>\n", dependencies: [{ 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: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "component", type: i4.Calendar, selector: "p-calendar", inputs: ["style", "styleClass", "inputStyle", "inputId", "name", "inputStyleClass", "placeholder", "ariaLabelledBy", "iconAriaLabel", "disabled", "dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "selectOtherMonths", "showIcon", "icon", "appendTo", "readonlyInput", "shortYearCutoff", "monthNavigator", "yearNavigator", "hourFormat", "timeOnly", "stepHour", "stepMinute", "stepSecond", "showSeconds", "required", "showOnFocus", "showWeek", "showClear", "dataType", "selectionMode", "maxDateCount", "showButtonBar", "todayButtonStyleClass", "clearButtonStyleClass", "autoZIndex", "baseZIndex", "panelStyleClass", "panelStyle", "keepInvalid", "hideOnDateTimeSelect", "touchUI", "timeSeparator", "focusTrap", "showTransitionOptions", "hideTransitionOptions", "tabindex", "view", "defaultDate", "minDate", "maxDate", "disabledDates", "disabledDays", "yearRange", "showTime", "responsiveOptions", "numberOfMonths", "firstDayOfWeek", "locale"], outputs: ["onFocus", "onBlur", "onClose", "onSelect", "onClear", "onInput", "onTodayClick", "onClearClick", "onMonthChange", "onYearChange", "onClickOutside", "onShow"] }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.ColumnFilter, selector: "p-columnFilter", inputs: ["field", "type", "display", "showMenu", "matchMode", "operator", "showOperator", "showClearButton", "showApplyButton", "showMatchModes", "showAddButton", "hideOnClear", "placeholder", "matchModeOptions", "maxConstraints", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "locale", "localeMatcher", "currency", "currencyDisplay", "useGrouping", "showButtons"] }, { kind: "component", type: i6.MngAutocompleteComponent, selector: "mng-autocomplete", inputs: ["dataProvider", "dataKeyProperty", "itemsValueProperty", "itemsLabelProperty", "itemsLabelTranslate", "inlineSearch", "openOnFocus", "multiselect", "placeholder", "className", "dropdownClassName", "showClear", "autoClear", "selectFirst"], outputs: ["valueChange"] }, { kind: "component", type: i7.MngDropdownComponent, selector: "mng-dropdown", inputs: ["dataProvider", "dataKeyProperty", "itemsLabelProperty", "itemsLabelTranslate", "itemsValueProperty", "itemsDisabledProperty", "multiselect", "placeholder", "showClear", "selectFirstItem", "className", "dropdownClassName", "changeValueOnBlur"], outputs: ["valueChange"] }, { kind: "component", type: i8.MngDateRangeComponent, selector: "mng-date-range", inputs: ["placeholder", "showTime", "showSeconds", "dateFormat"] }, { kind: "pipe", type: i9.TranslatePipe, name: "translate" }] });
|
|
109
109
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: MngTableColumnFilterComponent, decorators: [{
|
|
110
110
|
type: Component,
|
|
111
111
|
args: [{ selector: 'mng-table-column-filter', template: "<p-columnFilter\n class=\"ml-auto\"\n [type]=\"primeType\"\n [field]=\"descriptor.property\"\n [display]=\"primeDisplay\"\n [matchMode]=\"$any(primeDefaultMatchMode)\"\n [matchModeOptions]=\"$any(primeMatchModes)\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.typeToFilter' | translate\"\n [showMatchModes]=\"true\"\n [showOperator]=\"false\"\n [showAddButton]=\"false\"\n [hideOnClear]=\"true\"\n [showMenu]=\"primeShowMatchMode\"\n [minFractionDigits]=\"$any(descriptor.numberMinFractionDigits)\"\n [maxFractionDigits]=\"$any(descriptor.numberMaxFractionDigits)\"\n [useGrouping]=\"descriptor.numberUseGrouping\">\n <ng-template *ngIf=\"primeType === 'date'\" pTemplate=\"filter\" let-value let-filterCallback=\"filterCallback\">\n <ng-container *ngIf=\"activeMatchMode === 'between'; else datePicker\">\n <mng-date-range\n [ngModel]=\"value\"\n (ngModelChange)=\"dateFilter($event, filterCallback)\"\n [showTime]=\"descriptor.datePickerShowTime\"\n [dateFormat]=\"descriptor.datePickerFormat\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.typeToFilter' | translate\"></mng-date-range>\n </ng-container>\n <ng-template #datePicker>\n <p-calendar\n appendTo=\"body\"\n [ngModel]=\"value\"\n (ngModelChange)=\"dateFilter($event, filterCallback)\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.typeToFilter' | translate\"\n [showIcon]=\"true\"\n [dateFormat]=\"descriptor.datePickerFormat ?? 'dd.mm.yy'\"\n [showTime]=\"descriptor.datePickerShowTime\">\n </p-calendar>\n </ng-template>\n </ng-template>\n <ng-template *ngIf=\"lookupDescriptor\" pTemplate=\"filter\" let-value let-filterCallback=\"filterCallback\">\n <ng-container [ngSwitch]=\"lookupDescriptor.lookupType\">\n <mng-autocomplete\n *ngSwitchCase=\"lookupTypeAutocomplete\"\n [ngModel]=\"value\"\n [dataProvider]=\"lookupDescriptor.dataProvider\"\n [dataKeyProperty]=\"lookupDescriptor.dataKeyProperty\"\n [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n [itemsLabelTranslate]=\"lookupDescriptor.itemsLabelTranslate\"\n [multiselect]=\"lookupDescriptor.multiselect\"\n [openOnFocus]=\"lookupDescriptor.autocompleteOpenOnFocus\"\n [inlineSearch]=\"lookupDescriptor.autocompleteInlineSearch\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.searchToFilter' | translate\"\n [className]=\"lookupDescriptor.className\"\n [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n (valueChange)=\"autocompleteFilter($event, filterCallback)\">\n </mng-autocomplete>\n <mng-dropdown\n *ngSwitchCase=\"lookupTypeDropdown\"\n [ngModel]=\"value\"\n [dataProvider]=\"lookupDescriptor.dataProvider\"\n [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n [itemsLabelTranslate]=\"lookupDescriptor.itemsLabelTranslate\"\n [multiselect]=\"lookupDescriptor.multiselect\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.selectToFilter' | translate\"\n [className]=\"lookupDescriptor.className\"\n [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n [showClear]=\"false\"\n [changeValueOnBlur]=\"lookupDescriptor.multiselect\"\n (valueChange)=\"dropdownFilter($event, filterCallback)\">\n </mng-dropdown>\n </ng-container>\n </ng-template>\n</p-columnFilter>\n" }]
|
|
@@ -1,36 +1,37 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, HostBinding, Input } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { ColumnDisplayTypeEnum } from '../../../../descriptors/types';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "primeng/api";
|
|
5
5
|
import * as i2 from "@ngx-translate/core";
|
|
6
|
-
import * as i3 from "
|
|
7
|
-
import * as i4 from "
|
|
8
|
-
import * as i5 from "primeng/
|
|
9
|
-
import * as i6 from "
|
|
10
|
-
import * as i7 from "../../../../
|
|
6
|
+
import * as i3 from "../../../../pipes";
|
|
7
|
+
import * as i4 from "@angular/common";
|
|
8
|
+
import * as i5 from "primeng/button";
|
|
9
|
+
import * as i6 from "primeng/ripple";
|
|
10
|
+
import * as i7 from "../../../../directives/component.directive";
|
|
11
11
|
import * as i8 from "../../../../pipes/enum.pipe";
|
|
12
12
|
import * as i9 from "../../../../pipes/boolean.pipe";
|
|
13
|
-
import * as i10 from "../../../../pipes/getter.pipe";
|
|
14
|
-
import * as i11 from "../../../../pipes/template.pipe";
|
|
15
13
|
export class MngTableColumnValueComponent {
|
|
16
|
-
constructor(elementRef, messageService, translate) {
|
|
14
|
+
constructor(elementRef, messageService, translate, jsonPathPipe, getterPipe, templatePipe) {
|
|
17
15
|
this.elementRef = elementRef;
|
|
18
16
|
this.messageService = messageService;
|
|
19
17
|
this.translate = translate;
|
|
20
|
-
this.
|
|
21
|
-
this.
|
|
22
|
-
this.
|
|
23
|
-
this.
|
|
24
|
-
this.
|
|
25
|
-
this.
|
|
26
|
-
this.
|
|
27
|
-
this.
|
|
18
|
+
this.jsonPathPipe = jsonPathPipe;
|
|
19
|
+
this.getterPipe = getterPipe;
|
|
20
|
+
this.templatePipe = templatePipe;
|
|
21
|
+
this.columnDisplayTypeString = ColumnDisplayTypeEnum.String;
|
|
22
|
+
this.columnDisplayTypeNumber = ColumnDisplayTypeEnum.Number;
|
|
23
|
+
this.columnDisplayTypeCurrency = ColumnDisplayTypeEnum.Currency;
|
|
24
|
+
this.columnDisplayTypeBoolean = ColumnDisplayTypeEnum.Boolean;
|
|
25
|
+
this.columnDisplayTypeDate = ColumnDisplayTypeEnum.Date;
|
|
26
|
+
this.columnDisplayTypeEnum = ColumnDisplayTypeEnum.Enum;
|
|
27
|
+
this.columnDisplayTypeComponent = ColumnDisplayTypeEnum.Component;
|
|
28
|
+
this.columnDisplayTypeHtml = ColumnDisplayTypeEnum.Html;
|
|
28
29
|
this.styleMaxWidth = null;
|
|
29
30
|
this.className = 'nowrap';
|
|
30
31
|
this.jsonPath = '$';
|
|
31
32
|
}
|
|
32
33
|
ngOnInit() {
|
|
33
|
-
if (this.descriptor.
|
|
34
|
+
if (this.descriptor.columnDisplayType === ColumnDisplayTypeEnum.Currency) {
|
|
34
35
|
this.currency = this.descriptor.currencyFromProperty ? this.item[this.descriptor.currencyFromProperty] : this.descriptor.currencyCode ?? 'EUR';
|
|
35
36
|
}
|
|
36
37
|
if (this.descriptor.maxWidth) {
|
|
@@ -45,6 +46,14 @@ export class MngTableColumnValueComponent {
|
|
|
45
46
|
this.jsonPath = `$.${this.descriptor.property}.${this.descriptor.objectTitleProperty}`;
|
|
46
47
|
}
|
|
47
48
|
}
|
|
49
|
+
let value = this.jsonPathPipe.transform(this.item, this.jsonPath);
|
|
50
|
+
if (typeof this.descriptor.getter === 'function') {
|
|
51
|
+
value = this.getterPipe.transform(this.item, this.descriptor.getter, value);
|
|
52
|
+
}
|
|
53
|
+
if (this.descriptor.template) {
|
|
54
|
+
value = this.templatePipe.transform(value, this.descriptor.template);
|
|
55
|
+
}
|
|
56
|
+
this.value = value;
|
|
48
57
|
}
|
|
49
58
|
copyToClipboard(event) {
|
|
50
59
|
event.stopPropagation();
|
|
@@ -55,12 +64,12 @@ export class MngTableColumnValueComponent {
|
|
|
55
64
|
this.messageService.add({ severity: 'info', summary: title, detail: message });
|
|
56
65
|
}
|
|
57
66
|
}
|
|
58
|
-
MngTableColumnValueComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: MngTableColumnValueComponent, deps: [{ token: i0.ElementRef }, { token: i1.MessageService }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
|
|
59
|
-
MngTableColumnValueComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.0", type: MngTableColumnValueComponent, selector: "mng-table-column-value", inputs: { descriptor: "descriptor", item: "item" }, host: { properties: { "style.max-width.px": "this.styleMaxWidth", "class": "this.className" } }, ngImport: i0, template: "<ng-container [ngSwitch]=\"descriptor.
|
|
67
|
+
MngTableColumnValueComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.0", 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 });
|
|
68
|
+
MngTableColumnValueComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.0", type: MngTableColumnValueComponent, selector: "mng-table-column-value", inputs: { descriptor: "descriptor", item: "item" }, host: { properties: { "style.max-width.px": "this.styleMaxWidth", "class": "this.className" } }, ngImport: i0, template: "<ng-container [ngSwitch]=\"descriptor.columnDisplayType\">\n <ng-container *ngSwitchCase=\"columnDisplayTypeString\">\n {{ value }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeHtml\">\n <span [innerHTML]=\"value\"></span>\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeNumber\">\n {{ value | number: descriptor.displayFormat:descriptor.locale }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeCurrency\">\n {{ value | currency: currency:descriptor.currencyDisplay:descriptor.displayFormat:descriptor.locale }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeDate\">\n {{ value | date: descriptor.displayFormat }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeBoolean\">\n <ng-container *ngIf=\"descriptor.booleanAsIcon; else booleanText\">\n <i [class]=\"value | boolean: descriptor.booleanYes:descriptor.booleanNo:true\"></i>\n </ng-container>\n <ng-template #booleanText>\n {{ value | boolean: descriptor.booleanYes:descriptor.booleanNo | translate }}\n </ng-template>\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeEnum\">\n {{ value | enum: descriptor.enumType:descriptor.enumTitlePath:descriptor.enumNameAsValue | translate }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeComponent\">\n <ng-container\n [mngComponent]=\"descriptor.customComponentType!\"\n [inputs]=\"{\n value: value,\n item: item,\n descriptor: descriptor\n }\"></ng-container>\n </ng-container>\n</ng-container>\n<div class=\"help-buttons\" *ngIf=\"descriptor.hasCopyToClipboard\">\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", styles: [":host{display:inline-block;overflow:hidden}:host.nowrap{white-space:nowrap;text-overflow:ellipsis}.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: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i4.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i5.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "directive", type: i6.Ripple, selector: "[pRipple]" }, { kind: "directive", type: i7.MngComponentDirective, selector: "[mngComponent]", inputs: ["mngComponent", "inputs"], outputs: ["instanceCreated"] }, { kind: "pipe", type: i4.DecimalPipe, name: "number" }, { kind: "pipe", type: i4.CurrencyPipe, name: "currency" }, { kind: "pipe", type: i4.DatePipe, name: "date" }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "pipe", type: i8.MngEnumPipe, name: "enum" }, { kind: "pipe", type: i9.MngBooleanPipe, name: "boolean" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
60
69
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: MngTableColumnValueComponent, decorators: [{
|
|
61
70
|
type: Component,
|
|
62
|
-
args: [{ selector: 'mng-table-column-value', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container [ngSwitch]=\"descriptor.
|
|
63
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.MessageService }, { type: i2.TranslateService }]; }, propDecorators: { descriptor: [{
|
|
71
|
+
args: [{ selector: 'mng-table-column-value', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container [ngSwitch]=\"descriptor.columnDisplayType\">\n <ng-container *ngSwitchCase=\"columnDisplayTypeString\">\n {{ value }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeHtml\">\n <span [innerHTML]=\"value\"></span>\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeNumber\">\n {{ value | number: descriptor.displayFormat:descriptor.locale }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeCurrency\">\n {{ value | currency: currency:descriptor.currencyDisplay:descriptor.displayFormat:descriptor.locale }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeDate\">\n {{ value | date: descriptor.displayFormat }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeBoolean\">\n <ng-container *ngIf=\"descriptor.booleanAsIcon; else booleanText\">\n <i [class]=\"value | boolean: descriptor.booleanYes:descriptor.booleanNo:true\"></i>\n </ng-container>\n <ng-template #booleanText>\n {{ value | boolean: descriptor.booleanYes:descriptor.booleanNo | translate }}\n </ng-template>\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeEnum\">\n {{ value | enum: descriptor.enumType:descriptor.enumTitlePath:descriptor.enumNameAsValue | translate }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnDisplayTypeComponent\">\n <ng-container\n [mngComponent]=\"descriptor.customComponentType!\"\n [inputs]=\"{\n value: value,\n item: item,\n descriptor: descriptor\n }\"></ng-container>\n </ng-container>\n</ng-container>\n<div class=\"help-buttons\" *ngIf=\"descriptor.hasCopyToClipboard\">\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", styles: [":host{display:inline-block;overflow:hidden}:host.nowrap{white-space:nowrap;text-overflow:ellipsis}.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"] }]
|
|
72
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.MessageService }, { type: i2.TranslateService }, { type: i3.JsonPathPipe }, { type: i3.MngGetterPipe }, { type: i3.MngTemplatePipe }]; }, propDecorators: { descriptor: [{
|
|
64
73
|
type: Input
|
|
65
74
|
}], item: [{
|
|
66
75
|
type: Input
|
|
@@ -71,4 +80,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImpor
|
|
|
71
80
|
type: HostBinding,
|
|
72
81
|
args: ['class']
|
|
73
82
|
}] } });
|
|
74
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column-value.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/tableview/table/column-value/column-value.component.ts","../../../../../../../src/lib/components/tableview/table/column-value/column-value.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, ElementRef, HostBinding, Input, OnInit} from '@angular/core';\n\nimport {TranslateService} from '@ngx-translate/core';\nimport {MessageService} from 'primeng/api';\n\nimport {ColumnDescriptor} from '../../../../descriptors';\nimport {ColumnTypeEnum} from '../../../../descriptors/types';\n\n@Component({\n    selector: 'mng-table-column-value',\n    templateUrl: './column-value.component.html',\n    styleUrls: ['./column-value.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngTableColumnValueComponent<T, TT> implements OnInit {\n    public readonly columnTypeString: ColumnTypeEnum = ColumnTypeEnum.String;\n    public readonly columnTypeNumber: ColumnTypeEnum = ColumnTypeEnum.Number;\n    public readonly columnTypeCurrency: ColumnTypeEnum = ColumnTypeEnum.Currency;\n    public readonly columnTypeBoolean: ColumnTypeEnum = ColumnTypeEnum.Boolean;\n    public readonly columnTypeDate: ColumnTypeEnum = ColumnTypeEnum.Date;\n    public readonly columnTypeEnum: ColumnTypeEnum = ColumnTypeEnum.Enum;\n    public readonly columnTypeCustom: ColumnTypeEnum = ColumnTypeEnum.Custom;\n    public readonly columnTypeHtml: ColumnTypeEnum = ColumnTypeEnum.Html;\n\n    @Input() descriptor!: ColumnDescriptor<T, TT>;\n    @Input() 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    constructor(private elementRef: ElementRef, private messageService: MessageService, private translate: TranslateService) {}\n\n    public ngOnInit() {\n        if (this.descriptor.columnType === ColumnTypeEnum.Currency) {\n            this.currency = this.descriptor.currencyFromProperty ? this.item[this.descriptor.currencyFromProperty] : this.descriptor.currencyCode ?? 'EUR';\n        }\n\n        if (this.descriptor.maxWidth) {\n            this.styleMaxWidth = this.descriptor.maxWidth;\n        }\n\n        if (this.descriptor.jsonPath) {\n            this.jsonPath = this.descriptor.jsonPath;\n        } else {\n            this.jsonPath = `$.${this.descriptor.property}`;\n            if (this.descriptor.objectModelType) {\n                this.jsonPath = `$.${this.descriptor.property}.${this.descriptor.objectTitleProperty}`;\n            }\n        }\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","<ng-container [ngSwitch]=\"descriptor.columnType\">\n    <ng-container *ngSwitchCase=\"columnTypeString\">\n        {{ (descriptor.getter ? (item | getter: descriptor.getter:(item | jsonPath: jsonPath)) : (item | jsonPath: jsonPath)) | template: descriptor.template }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnTypeHtml\">\n        <span\n            [innerHTML]=\"(descriptor.getter ? (item | getter: descriptor.getter:(item | jsonPath: jsonPath)) : (item | jsonPath: jsonPath)) | template: descriptor.template\"></span>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnTypeNumber\">\n        {{ item | jsonPath: jsonPath | number: descriptor.displayFormat:descriptor.locale }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnTypeCurrency\">\n        {{ item | jsonPath: jsonPath | currency: currency:descriptor.currencyDisplay:descriptor.displayFormat:descriptor.locale }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnTypeDate\">\n        {{ item | jsonPath: jsonPath | date: descriptor.displayFormat }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnTypeBoolean\">\n        <ng-container *ngIf=\"descriptor.booleanAsIcon; else booleanText\"></ng-container>\n        <i [class]=\"item | jsonPath: jsonPath | boolean: descriptor.booleanYes:descriptor.booleanNo:true\"></i>\n        <ng-template #booleanText>\n            {{ item | jsonPath: jsonPath | boolean: descriptor.booleanYes:descriptor.booleanNo | translate }}\n        </ng-template>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnTypeEnum\">\n        {{ item | jsonPath: jsonPath | enum: descriptor.enumType:descriptor.enumTitlePath:descriptor.enumNameAsValue | translate }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnTypeCustom\">\n        <ng-container\n            [mngComponent]=\"descriptor.customComponentType!\"\n            [inputs]=\"{\n                value: item | jsonPath: jsonPath,\n                item: item,\n                descriptor: descriptor\n            }\"></ng-container>\n    </ng-container>\n</ng-container>\n<div class=\"help-buttons\" *ngIf=\"descriptor.hasCopyToClipboard\">\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"]}
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column-value.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/tableview/table/column-value/column-value.component.ts","../../../../../../../src/lib/components/tableview/table/column-value/column-value.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, ElementRef, HostBinding, Input, OnInit} from '@angular/core';\n\nimport {TranslateService} from '@ngx-translate/core';\nimport {MessageService} from 'primeng/api';\n\nimport {ColumnDescriptor} from '../../../../descriptors';\nimport {ColumnDisplayTypeEnum} from '../../../../descriptors/types';\nimport {JsonPathPipe, MngGetterPipe, MngTemplatePipe} from '../../../../pipes';\n\n@Component({\n    selector: 'mng-table-column-value',\n    templateUrl: './column-value.component.html',\n    styleUrls: ['./column-value.component.scss'],\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() descriptor!: ColumnDescriptor<T, TT>;\n    @Input() 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.currencyFromProperty ? this.item[this.descriptor.currencyFromProperty] : this.descriptor.currencyCode ?? 'EUR';\n        }\n\n        if (this.descriptor.maxWidth) {\n            this.styleMaxWidth = this.descriptor.maxWidth;\n        }\n\n        if (this.descriptor.jsonPath) {\n            this.jsonPath = this.descriptor.jsonPath;\n        } else {\n            this.jsonPath = `$.${this.descriptor.property}`;\n            if (this.descriptor.objectModelType) {\n                this.jsonPath = `$.${this.descriptor.property}.${this.descriptor.objectTitleProperty}`;\n            }\n        }\n\n        let value = this.jsonPathPipe.transform(this.item, this.jsonPath);\n\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","<ng-container [ngSwitch]=\"descriptor.columnDisplayType\">\n    <ng-container *ngSwitchCase=\"columnDisplayTypeString\">\n        {{ value }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnDisplayTypeHtml\">\n        <span [innerHTML]=\"value\"></span>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnDisplayTypeNumber\">\n        {{ value | number: descriptor.displayFormat:descriptor.locale }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnDisplayTypeCurrency\">\n        {{ value | currency: currency:descriptor.currencyDisplay:descriptor.displayFormat:descriptor.locale }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnDisplayTypeDate\">\n        {{ value | date: descriptor.displayFormat }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnDisplayTypeBoolean\">\n        <ng-container *ngIf=\"descriptor.booleanAsIcon; else booleanText\">\n            <i [class]=\"value | boolean: descriptor.booleanYes:descriptor.booleanNo:true\"></i>\n        </ng-container>\n        <ng-template #booleanText>\n            {{ value | boolean: descriptor.booleanYes:descriptor.booleanNo | translate }}\n        </ng-template>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnDisplayTypeEnum\">\n        {{ value | enum: descriptor.enumType:descriptor.enumTitlePath:descriptor.enumNameAsValue | translate }}\n    </ng-container>\n    <ng-container *ngSwitchCase=\"columnDisplayTypeComponent\">\n        <ng-container\n            [mngComponent]=\"descriptor.customComponentType!\"\n            [inputs]=\"{\n                value: value,\n                item: item,\n                descriptor: descriptor\n            }\"></ng-container>\n    </ng-container>\n</ng-container>\n<div class=\"help-buttons\" *ngIf=\"descriptor.hasCopyToClipboard\">\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"]}
|