@mediusinc/mng-commons 0.2.11 → 0.2.15

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.
Files changed (33) hide show
  1. package/esm2020/lib/api/models/filter-match-type.model.mjs +11 -12
  2. package/esm2020/lib/api/models/filter-param.model.mjs +11 -12
  3. package/esm2020/lib/api/models/query-mode.model.mjs +4 -4
  4. package/esm2020/lib/api/models/query-param.model.mjs +29 -30
  5. package/esm2020/lib/components/form/dropdown/dropdown.component.mjs +2 -4
  6. package/esm2020/lib/components/form/formly/fields/formly-field-dropdown/formly-field-dropdown.component.mjs +3 -3
  7. package/esm2020/lib/components/tableview/table/column-filter/column-filter.component.mjs +3 -3
  8. package/esm2020/lib/components/tableview/table/column-value/column-value.component.mjs +6 -3
  9. package/esm2020/lib/descriptors/editor.descriptor.mjs +2 -1
  10. package/esm2020/lib/descriptors/table.descriptor.mjs +82 -3
  11. package/esm2020/lib/descriptors/tableview.descriptor.mjs +4 -1
  12. package/esm2020/lib/mng-commons.module.mjs +5 -2
  13. package/esm2020/lib/pipes/enum.pipe.mjs +22 -0
  14. package/esm2020/lib/pipes/index.mjs +2 -1
  15. package/esm2020/lib/utils/enum.util.mjs +23 -2
  16. package/fesm2015/mediusinc-mng-commons.mjs +189 -66
  17. package/fesm2015/mediusinc-mng-commons.mjs.map +1 -1
  18. package/fesm2020/mediusinc-mng-commons.mjs +187 -66
  19. package/fesm2020/mediusinc-mng-commons.mjs.map +1 -1
  20. package/lib/api/models/filter-match-type.model.d.ts +10 -10
  21. package/lib/api/models/filter-param.model.d.ts +7 -7
  22. package/lib/api/models/query-mode.model.d.ts +3 -3
  23. package/lib/api/models/query-param.model.d.ts +14 -14
  24. package/lib/components/tableview/table/column-value/column-value.component.d.ts +1 -0
  25. package/lib/descriptors/table.descriptor.d.ts +22 -4
  26. package/lib/descriptors/tableview.descriptor.d.ts +1 -0
  27. package/lib/mng-commons.module.d.ts +70 -69
  28. package/lib/pipes/enum.pipe.d.ts +7 -0
  29. package/lib/pipes/index.d.ts +1 -0
  30. package/lib/utils/enum.util.d.ts +11 -0
  31. package/openapi/templates/model.mustache +82 -0
  32. package/openapi/templates/models.mustache +50 -0
  33. package/package.json +1 -1
@@ -472,7 +472,6 @@ class LookupDataProvider extends DataProvider {
472
472
  }
473
473
  }
474
474
 
475
- /* tslint:disable:no-angle-bracket-type-assertion no-trailing-whitespace member-ordering object-literal-key-quotes */
476
475
  /**
477
476
  * Generated API
478
477
  * No description provided (generated by Openapi Generator https://github.com/openapitools/openapi-generator)
@@ -486,16 +485,16 @@ class LookupDataProvider extends DataProvider {
486
485
  */
487
486
  var MediusFilterMatchType;
488
487
  (function (MediusFilterMatchType) {
489
- MediusFilterMatchType[MediusFilterMatchType["Equals"] = 'EQUALS'] = "Equals";
490
- MediusFilterMatchType[MediusFilterMatchType["NotEquals"] = 'NOT_EQUALS'] = "NotEquals";
491
- MediusFilterMatchType[MediusFilterMatchType["Contains"] = 'CONTAINS'] = "Contains";
492
- MediusFilterMatchType[MediusFilterMatchType["EndsWith"] = 'ENDS_WITH'] = "EndsWith";
493
- MediusFilterMatchType[MediusFilterMatchType["StartsWith"] = 'STARTS_WITH'] = "StartsWith";
494
- MediusFilterMatchType[MediusFilterMatchType["FromTo"] = 'FROM_TO'] = "FromTo";
495
- MediusFilterMatchType[MediusFilterMatchType["SmallerThan"] = 'SMALLER_THEN'] = "SmallerThan";
496
- MediusFilterMatchType[MediusFilterMatchType["GreaterThan"] = 'GREATER_THEN'] = "GreaterThan";
497
- MediusFilterMatchType[MediusFilterMatchType["In"] = 'IN'] = "In";
498
- MediusFilterMatchType[MediusFilterMatchType["NotIn"] = 'NOT_IN'] = "NotIn";
488
+ MediusFilterMatchType["Equals"] = "EQUALS";
489
+ MediusFilterMatchType["NotEquals"] = "NOT_EQUALS";
490
+ MediusFilterMatchType["FromTo"] = "FROM_TO";
491
+ MediusFilterMatchType["Contains"] = "CONTAINS";
492
+ MediusFilterMatchType["StartsWith"] = "STARTS_WITH";
493
+ MediusFilterMatchType["EndsWith"] = "ENDS_WITH";
494
+ MediusFilterMatchType["In"] = "IN";
495
+ MediusFilterMatchType["NotIn"] = "NOT_IN";
496
+ MediusFilterMatchType["SmallerThan"] = "SMALLER_THAN";
497
+ MediusFilterMatchType["GreaterThan"] = "GREATER_THAN";
499
498
  })(MediusFilterMatchType || (MediusFilterMatchType = {}));
500
499
 
501
500
  /* tslint:disable:no-angle-bracket-type-assertion no-trailing-whitespace member-ordering object-literal-key-quotes */
@@ -504,23 +503,12 @@ class MediusFilterParam {
504
503
  return MediusFilterParam.attributeTypeMap;
505
504
  }
506
505
  }
507
- MediusFilterParam.discriminator = undefined;
508
506
  MediusFilterParam.attributeTypeMap = [
509
507
  {
510
508
  name: 'property',
511
509
  baseName: 'property',
512
510
  type: 'string'
513
511
  },
514
- {
515
- name: 'filterMatchCaseSensitive',
516
- baseName: 'filter_match_case_sensitive',
517
- type: 'boolean'
518
- },
519
- {
520
- name: 'filterMatchType',
521
- baseName: 'filter_match_type',
522
- type: 'FilterMatchType'
523
- },
524
512
  {
525
513
  name: 'filterValue',
526
514
  baseName: 'filter_value',
@@ -530,6 +518,16 @@ MediusFilterParam.attributeTypeMap = [
530
518
  name: 'filterValueTo',
531
519
  baseName: 'filter_value_to',
532
520
  type: 'object'
521
+ },
522
+ {
523
+ name: 'filterMatchType',
524
+ baseName: 'filter_match_type',
525
+ type: 'FilterMatchType'
526
+ },
527
+ {
528
+ name: 'filterMatchCaseSensitive',
529
+ baseName: 'filter_match_case_sensitive',
530
+ type: 'boolean'
533
531
  }
534
532
  ];
535
533
 
@@ -547,9 +545,9 @@ MediusFilterParam.attributeTypeMap = [
547
545
  */
548
546
  var MediusQueryMode;
549
547
  (function (MediusQueryMode) {
550
- MediusQueryMode[MediusQueryMode["All"] = 'ALL'] = "All";
551
- MediusQueryMode[MediusQueryMode["Count"] = 'COUNT'] = "Count";
552
- MediusQueryMode[MediusQueryMode["Data"] = 'DATA'] = "Data";
548
+ MediusQueryMode["Count"] = "COUNT";
549
+ MediusQueryMode["Data"] = "DATA";
550
+ MediusQueryMode["All"] = "ALL";
553
551
  })(MediusQueryMode || (MediusQueryMode = {}));
554
552
 
555
553
  /* tslint:disable:no-angle-bracket-type-assertion no-trailing-whitespace member-ordering object-literal-key-quotes */
@@ -558,27 +556,16 @@ class MediusQueryParam {
558
556
  return MediusQueryParam.attributeTypeMap;
559
557
  }
560
558
  }
561
- MediusQueryParam.discriminator = undefined;
562
559
  MediusQueryParam.attributeTypeMap = [
563
560
  {
564
- name: 'filterAllParam',
565
- baseName: 'filter_all_param',
566
- type: 'string'
567
- },
568
- {
569
- name: 'filterAllProperties',
570
- baseName: 'filter_all_properties',
561
+ name: 'sortProperty',
562
+ baseName: 'sort_property',
571
563
  type: 'Array<string>'
572
564
  },
573
565
  {
574
- name: 'filterParams',
575
- baseName: 'filter_params',
576
- type: 'Array<FilterParam>'
577
- },
578
- {
579
- name: 'groupByProperties',
580
- baseName: 'group_by_properties',
581
- type: 'Array<string>'
566
+ name: 'sortAsc',
567
+ baseName: 'sort_asc',
568
+ type: 'Array<boolean>'
582
569
  },
583
570
  {
584
571
  name: 'itemsOffset',
@@ -591,34 +578,44 @@ MediusQueryParam.attributeTypeMap = [
591
578
  type: 'number'
592
579
  },
593
580
  {
594
- name: 'queryMode',
595
- baseName: 'query_mode',
596
- type: 'QueryMode'
581
+ name: 'filterParams',
582
+ baseName: 'filter_params',
583
+ type: 'Array<MediusFilterParam>'
584
+ },
585
+ {
586
+ name: 'filterAllParam',
587
+ baseName: 'filter_all_param',
588
+ type: 'string'
589
+ },
590
+ {
591
+ name: 'filterAllProperties',
592
+ baseName: 'filter_all_properties',
593
+ type: 'Array<string>'
594
+ },
595
+ {
596
+ name: 'validateProperties',
597
+ baseName: 'validate_properties',
598
+ type: 'Array<string>'
597
599
  },
598
600
  {
599
601
  name: 'selectInTwoSteps',
600
602
  baseName: 'select_in_two_steps',
601
603
  type: 'boolean'
602
604
  },
603
- {
604
- name: 'sortAsc',
605
- baseName: 'sort_asc',
606
- type: 'Array<boolean>'
607
- },
608
605
  {
609
606
  name: 'sortEnumByOrdinal',
610
607
  baseName: 'sort_enum_by_ordinal',
611
608
  type: 'boolean'
612
609
  },
613
610
  {
614
- name: 'sortProperty',
615
- baseName: 'sort_property',
611
+ name: 'groupByProperties',
612
+ baseName: 'group_by_properties',
616
613
  type: 'Array<string>'
617
614
  },
618
615
  {
619
- name: 'validateProperties',
620
- baseName: 'validate_properties',
621
- type: 'Array<string>'
616
+ name: 'queryMode',
617
+ baseName: 'query_mode',
618
+ type: 'MediusQueryMode'
622
619
  }
623
620
  ];
624
621
 
@@ -1236,6 +1233,7 @@ class FieldLookupEnumDescriptor extends FieldLookupDescriptor {
1236
1233
  this.withLookupDataProvider(dataProvider);
1237
1234
  this.withItemsLabelProperty('title');
1238
1235
  this.withItemsValueProperty('value');
1236
+ this.withDataKeyProperty('value');
1239
1237
  }
1240
1238
  get enumType() {
1241
1239
  return this._enumType;
@@ -1599,6 +1597,13 @@ class TableDescriptor {
1599
1597
  this.setDataKeyFromColumn();
1600
1598
  return column;
1601
1599
  }
1600
+ addColumnEnum(property, enumType, nameAsValue = false, titlePath) {
1601
+ const column = new ColumnDescriptor(this, property);
1602
+ column.asEnum(enumType, nameAsValue, titlePath);
1603
+ this._columns.push(column);
1604
+ this.setDataKeyFromColumn();
1605
+ return column;
1606
+ }
1602
1607
  addColumnObject(property, modelType, displayProperty) {
1603
1608
  const column = new ColumnDescriptor(this, property);
1604
1609
  column.withModelType(modelType);
@@ -1675,6 +1680,7 @@ class ColumnDescriptor {
1675
1680
  this._modelType = null;
1676
1681
  this._columnType = ColumnDescriptor.TypeEnum.String;
1677
1682
  this._isSortEnabled = false;
1683
+ this._enumNameAsValue = false;
1678
1684
  this._table = table;
1679
1685
  this._property = property;
1680
1686
  }
@@ -1705,6 +1711,15 @@ class ColumnDescriptor {
1705
1711
  get property() {
1706
1712
  return this._property;
1707
1713
  }
1714
+ get enumType() {
1715
+ return this._enumType;
1716
+ }
1717
+ get enumTitlePath() {
1718
+ return this._enumTitlePath;
1719
+ }
1720
+ get enumNameAsValue() {
1721
+ return this._enumNameAsValue;
1722
+ }
1708
1723
  asType(type = ColumnDescriptor.TypeEnum.String) {
1709
1724
  this._columnType = type;
1710
1725
  return this;
@@ -1723,6 +1738,16 @@ class ColumnDescriptor {
1723
1738
  this._columnType = ColumnDescriptor.TypeEnum.Boolean;
1724
1739
  return this;
1725
1740
  }
1741
+ asEnum(enumType, nameAsValue = false, titlePath) {
1742
+ this._columnType = ColumnDescriptor.TypeEnum.Enum;
1743
+ this._enumType = enumType;
1744
+ this._enumNameAsValue = nameAsValue;
1745
+ if (typeof titlePath === 'undefined') {
1746
+ titlePath = TypeUtil.findEnumName(enumType);
1747
+ }
1748
+ this._enumTitlePath = titlePath;
1749
+ return this;
1750
+ }
1726
1751
  withModelType(modelType) {
1727
1752
  this._modelType = modelType;
1728
1753
  return this;
@@ -1737,7 +1762,23 @@ class ColumnDescriptor {
1737
1762
  }
1738
1763
  withFilter() {
1739
1764
  this._filterDescriptor = new FilterDescriptor(this._property);
1740
- this._filterDescriptor.asFilterType(this._columnType);
1765
+ let filterType;
1766
+ switch (this._columnType) {
1767
+ case ColumnDescriptor.TypeEnum.Number:
1768
+ filterType = FilterDescriptor.TypeEnum.Number;
1769
+ break;
1770
+ case ColumnDescriptor.TypeEnum.Boolean:
1771
+ filterType = FilterDescriptor.TypeEnum.Boolean;
1772
+ break;
1773
+ case ColumnDescriptor.TypeEnum.Date:
1774
+ filterType = FilterDescriptor.TypeEnum.Date;
1775
+ break;
1776
+ case ColumnDescriptor.TypeEnum.String:
1777
+ default:
1778
+ filterType = FilterDescriptor.TypeEnum.String;
1779
+ break;
1780
+ }
1781
+ this._filterDescriptor.asFilterType(filterType);
1741
1782
  return this._filterDescriptor;
1742
1783
  }
1743
1784
  withFilterLookup() {
@@ -1745,6 +1786,14 @@ class ColumnDescriptor {
1745
1786
  this._filterDescriptor = filterDescriptor;
1746
1787
  return filterDescriptor;
1747
1788
  }
1789
+ withFilterLookupEnum(options) {
1790
+ if (this._columnType !== ColumnDescriptor.TypeEnum.Enum || !this._enumType) {
1791
+ throw new Error(`Column ${this._property} is not of type enum or enum type is undefined.`);
1792
+ }
1793
+ const filterDescriptor = new FilterLookupEnumDescriptor(this._property, this._enumType, options, this._enumNameAsValue, this._enumTitlePath);
1794
+ this._filterDescriptor = filterDescriptor;
1795
+ return filterDescriptor;
1796
+ }
1748
1797
  withSort(isEnabled = true) {
1749
1798
  this._isSortEnabled = isEnabled;
1750
1799
  return this;
@@ -1766,6 +1815,7 @@ class ColumnDescriptor {
1766
1815
  TypeEnum[TypeEnum["Number"] = 1] = "Number";
1767
1816
  TypeEnum[TypeEnum["Boolean"] = 2] = "Boolean";
1768
1817
  TypeEnum[TypeEnum["Date"] = 3] = "Date";
1818
+ TypeEnum[TypeEnum["Enum"] = 4] = "Enum";
1769
1819
  })(TypeEnum = ColumnDescriptor.TypeEnum || (ColumnDescriptor.TypeEnum = {}));
1770
1820
  })(ColumnDescriptor || (ColumnDescriptor = {}));
1771
1821
  class FilterDescriptor {
@@ -1837,6 +1887,7 @@ class FilterDescriptor {
1837
1887
  TypeEnum[TypeEnum["Boolean"] = 2] = "Boolean";
1838
1888
  TypeEnum[TypeEnum["Date"] = 3] = "Date";
1839
1889
  TypeEnum[TypeEnum["Lookup"] = 4] = "Lookup";
1890
+ TypeEnum[TypeEnum["LookupEnum"] = 5] = "LookupEnum";
1840
1891
  })(TypeEnum = FilterDescriptor.TypeEnum || (FilterDescriptor.TypeEnum = {}));
1841
1892
  let MatchModeEnum;
1842
1893
  (function (MatchModeEnum) {
@@ -1943,6 +1994,31 @@ class FilterLookupDescriptor extends FilterDescriptor {
1943
1994
  descriptor._dataKeyProperty = this._dataKeyProperty;
1944
1995
  }
1945
1996
  }
1997
+ class FilterLookupEnumDescriptor extends FilterLookupDescriptor {
1998
+ constructor(property, enumType, options, nameAsValue = false, optionsTitlePath) {
1999
+ super(property, null);
2000
+ this._enumType = enumType;
2001
+ if (typeof optionsTitlePath === 'undefined') {
2002
+ optionsTitlePath = TypeUtil.findEnumName(enumType);
2003
+ }
2004
+ const optionEnumValues = Array.isArray(options)
2005
+ ? EnumUtil.fromValuesAsEnumValueArray(enumType, options, nameAsValue, optionsTitlePath ?? undefined)
2006
+ : EnumUtil.fromConstantsAsEnumValueArray(enumType, nameAsValue, optionsTitlePath ?? undefined);
2007
+ const dataProvider = new LookupDataProvider(null).withLookup(() => of(optionEnumValues));
2008
+ this.withLookupDataProvider(dataProvider);
2009
+ this.withItemsLabelProperty('title');
2010
+ this.withItemsValueProperty('value');
2011
+ this.withDataKeyProperty('value');
2012
+ }
2013
+ get enumType() {
2014
+ return this._enumType;
2015
+ }
2016
+ copy() {
2017
+ const field = new FilterLookupEnumDescriptor(this._property, this._enumType, []);
2018
+ this.copyFieldsTo(field);
2019
+ return field;
2020
+ }
2021
+ }
1946
2022
  (function (FilterLookupDescriptor) {
1947
2023
  let LookupTypeEnum;
1948
2024
  (function (LookupTypeEnum) {
@@ -2020,6 +2096,9 @@ class TableviewDescriptor {
2020
2096
  addColumnBoolean(property) {
2021
2097
  return this._table.addColumnBoolean(property);
2022
2098
  }
2099
+ addColumnEnum(property, enumType, nameAsValue = false, titlePath) {
2100
+ return this._table.addColumnEnum(property, enumType, nameAsValue, titlePath);
2101
+ }
2023
2102
  addColumnObject(property, modelType, displayProperty) {
2024
2103
  return this._table.addColumnObject(property, modelType, displayProperty);
2025
2104
  }
@@ -2257,8 +2336,15 @@ class EnumUtil {
2257
2336
  * @param enumType Enum object.
2258
2337
  */
2259
2338
  static getConstantNames(enumType) {
2339
+ return EnumUtil.getConstantNamesFromEnumObject(enumType);
2340
+ }
2341
+ /**
2342
+ * Returns array of names for constants in enum.
2343
+ * @param enumObj Enum object.
2344
+ */
2345
+ static getConstantNamesFromEnumObject(enumObj) {
2260
2346
  // in number enum, the numbers are also represented in objects and should be filtered out
2261
- return Object.keys(enumType).filter(v => isNaN(+v));
2347
+ return Object.keys(enumObj).filter(v => isNaN(+v));
2262
2348
  }
2263
2349
  /**
2264
2350
  * Returns array of string values for constants in enum.
@@ -2310,6 +2396,20 @@ class EnumUtil {
2310
2396
  return typeof enumType[value] !== 'undefined' ? enumType[value] : null;
2311
2397
  }
2312
2398
  }
2399
+ /**
2400
+ * Gets constant name for value.
2401
+ * @param enumObj Enum object.
2402
+ * @param value Value of enum constant.
2403
+ */
2404
+ static getConstantNameFromEnumObject(enumObj, value) {
2405
+ const enumObjAny = enumObj;
2406
+ if (typeof value === 'string') {
2407
+ return this.getConstantNamesFromEnumObject(enumObj).find(c => enumObjAny[c] === value) ?? null;
2408
+ }
2409
+ else {
2410
+ return typeof enumObjAny[value] !== 'undefined' ? enumObjAny[value] : null;
2411
+ }
2412
+ }
2313
2413
  }
2314
2414
 
2315
2415
  class I18nUtil {
@@ -4323,9 +4423,7 @@ class MngDropdownComponent {
4323
4423
  }
4324
4424
  writeValue(obj) {
4325
4425
  this.dropdownFormControl.setValue(obj, { emitEvent: false });
4326
- if (this.primeDropdown) {
4327
- this.primeDropdown.writeValue(obj);
4328
- }
4426
+ this.primeDropdown?.writeValue(obj);
4329
4427
  }
4330
4428
  }
4331
4429
  MngDropdownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngDropdownComponent, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
@@ -4531,10 +4629,10 @@ class MngFormlyFieldDropdownComponent extends FieldType {
4531
4629
  }
4532
4630
  }
4533
4631
  MngFormlyFieldDropdownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngFormlyFieldDropdownComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
4534
- MngFormlyFieldDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngFormlyFieldDropdownComponent, selector: "mng-formly-field-dropdown", usesInheritance: true, ngImport: i0, template: "<mng-dropdown\n [id]=\"$any(key)\"\n [formControl]=\"dFormControl\"\n [formlyAttributes]=\"field\"\n [placeholder]=\"$any(descriptor.placeholder)\"\n [itemsLabelProperty]=\"$any(descriptor.itemsLabelProperty)\"\n [itemsValueProperty]=\"$any(descriptor.itemsValueProperty)\"\n [showClear]=\"!this.to.required\"\n [dataKeyProperty]=\"$any(descriptor.dataKeyProperty)\">\n</mng-dropdown>\n", components: [{ type: MngDropdownComponent, selector: "mng-dropdown", inputs: ["dataProvider", "dataKeyProperty", "itemsLabelProperty", "itemsValueProperty", "multiselect", "placeholder", "showClear", "className", "dropdownClassName"], outputs: ["valueChange"] }], directives: [{ type: i2$3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2$3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i3.ɵFormlyAttributes, selector: "[formlyAttributes]", inputs: ["formlyAttributes", "id"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
4632
+ MngFormlyFieldDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngFormlyFieldDropdownComponent, selector: "mng-formly-field-dropdown", usesInheritance: true, ngImport: i0, template: "<mng-dropdown\n [id]=\"$any(key)\"\n [formControl]=\"dFormControl\"\n [formlyAttributes]=\"field\"\n [placeholder]=\"$any(descriptor.placeholder)\"\n [dataProvider]=\"descriptor.dataProvider\"\n [itemsLabelProperty]=\"$any(descriptor.itemsLabelProperty)\"\n [itemsValueProperty]=\"$any(descriptor.itemsValueProperty)\"\n [showClear]=\"!this.to.required\"\n [dataKeyProperty]=\"$any(descriptor.dataKeyProperty)\">\n</mng-dropdown>\n", components: [{ type: MngDropdownComponent, selector: "mng-dropdown", inputs: ["dataProvider", "dataKeyProperty", "itemsLabelProperty", "itemsValueProperty", "multiselect", "placeholder", "showClear", "className", "dropdownClassName"], outputs: ["valueChange"] }], directives: [{ type: i2$3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2$3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i3.ɵFormlyAttributes, selector: "[formlyAttributes]", inputs: ["formlyAttributes", "id"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
4535
4633
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngFormlyFieldDropdownComponent, decorators: [{
4536
4634
  type: Component,
4537
- args: [{ selector: 'mng-formly-field-dropdown', changeDetection: ChangeDetectionStrategy.OnPush, template: "<mng-dropdown\n [id]=\"$any(key)\"\n [formControl]=\"dFormControl\"\n [formlyAttributes]=\"field\"\n [placeholder]=\"$any(descriptor.placeholder)\"\n [itemsLabelProperty]=\"$any(descriptor.itemsLabelProperty)\"\n [itemsValueProperty]=\"$any(descriptor.itemsValueProperty)\"\n [showClear]=\"!this.to.required\"\n [dataKeyProperty]=\"$any(descriptor.dataKeyProperty)\">\n</mng-dropdown>\n" }]
4635
+ args: [{ selector: 'mng-formly-field-dropdown', changeDetection: ChangeDetectionStrategy.OnPush, template: "<mng-dropdown\n [id]=\"$any(key)\"\n [formControl]=\"dFormControl\"\n [formlyAttributes]=\"field\"\n [placeholder]=\"$any(descriptor.placeholder)\"\n [dataProvider]=\"descriptor.dataProvider\"\n [itemsLabelProperty]=\"$any(descriptor.itemsLabelProperty)\"\n [itemsValueProperty]=\"$any(descriptor.itemsValueProperty)\"\n [showClear]=\"!this.to.required\"\n [dataKeyProperty]=\"$any(descriptor.dataKeyProperty)\">\n</mng-dropdown>\n" }]
4538
4636
  }] });
4539
4637
 
4540
4638
  class MngTableLoadEvent {
@@ -4618,10 +4716,10 @@ class MngTableColumnFilterComponent {
4618
4716
  }
4619
4717
  }
4620
4718
  MngTableColumnFilterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngTableColumnFilterComponent, deps: [{ token: i2$1.PrimeNGConfig }], target: i0.ɵɵFactoryTarget.Component });
4621
- MngTableColumnFilterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngTableColumnFilterComponent, selector: "mng-table-column-filter", inputs: { descriptor: "descriptor", display: "display" }, ngImport: i0, template: "<p-columnFilter\n class=\"ml-auto\"\n [type]=\"primeType\"\n matchMode=\"equals\"\n [field]=\"descriptor.property\"\n [display]=\"primeDisplay\"\n [matchMode]=\"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 <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 [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n [multiselect]=\"lookupDescriptor.multiselect\"\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 [dataKeyProperty]=\"lookupDescriptor.dataKeyProperty\"\n [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n [multiselect]=\"lookupDescriptor.multiselect\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.selectToFilter' | translate\"\n [className]=\"lookupDescriptor.className\"\n [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n [showClear]=\"true\"\n (change)=\"filterCallback($event)\">\n </mng-dropdown>\n </ng-container>\n </ng-template>\n</p-columnFilter>\n", components: [{ type: i4$4.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"] }, { type: MngAutocompleteComponent, selector: "mng-autocomplete", inputs: ["dataProvider", "dataKeyProperty", "itemsLabelProperty", "multiselect", "placeholder", "className", "dropdownClassName"], outputs: ["valueChange"] }, { type: MngDropdownComponent, selector: "mng-dropdown", inputs: ["dataProvider", "dataKeyProperty", "itemsLabelProperty", "itemsValueProperty", "multiselect", "placeholder", "showClear", "className", "dropdownClassName"], outputs: ["valueChange"] }], directives: [{ type: i4$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2$1.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { type: i4$1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i4$1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i2$3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2$3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], pipes: { "translate": i2$2.TranslatePipe } });
4719
+ MngTableColumnFilterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngTableColumnFilterComponent, selector: "mng-table-column-filter", inputs: { descriptor: "descriptor", display: "display" }, ngImport: i0, template: "<p-columnFilter\n class=\"ml-auto\"\n [type]=\"primeType\"\n matchMode=\"equals\"\n [field]=\"descriptor.property\"\n [display]=\"primeDisplay\"\n [matchMode]=\"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 <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 [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n [multiselect]=\"lookupDescriptor.multiselect\"\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 [dataKeyProperty]=\"lookupDescriptor.dataKeyProperty\"\n [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n [multiselect]=\"lookupDescriptor.multiselect\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.selectToFilter' | translate\"\n [className]=\"lookupDescriptor.className\"\n [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n [showClear]=\"true\"\n (valueChange)=\"filterCallback($event)\">\n </mng-dropdown>\n </ng-container>\n </ng-template>\n</p-columnFilter>\n", components: [{ type: i4$4.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"] }, { type: MngAutocompleteComponent, selector: "mng-autocomplete", inputs: ["dataProvider", "dataKeyProperty", "itemsLabelProperty", "multiselect", "placeholder", "className", "dropdownClassName"], outputs: ["valueChange"] }, { type: MngDropdownComponent, selector: "mng-dropdown", inputs: ["dataProvider", "dataKeyProperty", "itemsLabelProperty", "itemsValueProperty", "multiselect", "placeholder", "showClear", "className", "dropdownClassName"], outputs: ["valueChange"] }], directives: [{ type: i4$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2$1.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { type: i4$1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i4$1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i2$3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2$3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], pipes: { "translate": i2$2.TranslatePipe } });
4622
4720
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngTableColumnFilterComponent, decorators: [{
4623
4721
  type: Component,
4624
- args: [{ selector: 'mng-table-column-filter', template: "<p-columnFilter\n class=\"ml-auto\"\n [type]=\"primeType\"\n matchMode=\"equals\"\n [field]=\"descriptor.property\"\n [display]=\"primeDisplay\"\n [matchMode]=\"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 <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 [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n [multiselect]=\"lookupDescriptor.multiselect\"\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 [dataKeyProperty]=\"lookupDescriptor.dataKeyProperty\"\n [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n [multiselect]=\"lookupDescriptor.multiselect\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.selectToFilter' | translate\"\n [className]=\"lookupDescriptor.className\"\n [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n [showClear]=\"true\"\n (change)=\"filterCallback($event)\">\n </mng-dropdown>\n </ng-container>\n </ng-template>\n</p-columnFilter>\n" }]
4722
+ args: [{ selector: 'mng-table-column-filter', template: "<p-columnFilter\n class=\"ml-auto\"\n [type]=\"primeType\"\n matchMode=\"equals\"\n [field]=\"descriptor.property\"\n [display]=\"primeDisplay\"\n [matchMode]=\"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 <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 [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n [multiselect]=\"lookupDescriptor.multiselect\"\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 [dataKeyProperty]=\"lookupDescriptor.dataKeyProperty\"\n [itemsLabelProperty]=\"lookupDescriptor.itemsLabelProperty\"\n [itemsValueProperty]=\"lookupDescriptor.itemsValueProperty\"\n [multiselect]=\"lookupDescriptor.multiselect\"\n [placeholder]=\"descriptor.placeholder ?? 'mngTable.selectToFilter' | translate\"\n [className]=\"lookupDescriptor.className\"\n [dropdownClassName]=\"lookupDescriptor.dropdownClassName\"\n [showClear]=\"true\"\n (valueChange)=\"filterCallback($event)\">\n </mng-dropdown>\n </ng-container>\n </ng-template>\n</p-columnFilter>\n" }]
4625
4723
  }], ctorParameters: function () { return [{ type: i2$1.PrimeNGConfig }]; }, propDecorators: { descriptor: [{
4626
4724
  type: Input
4627
4725
  }], display: [{
@@ -4682,19 +4780,39 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImpor
4682
4780
  }]
4683
4781
  }] });
4684
4782
 
4783
+ class MngEnumPipe {
4784
+ transform(value, enumObj, i18nPath, nameAsValue = false) {
4785
+ const enumConstantName = nameAsValue ? value : EnumUtil.getConstantNameFromEnumObject(enumObj, value);
4786
+ if (typeof i18nPath === 'undefined') {
4787
+ i18nPath = TypeUtil.findEnumName(enumObj);
4788
+ }
4789
+ return i18nPath ? `${i18nPath}.${enumConstantName}` : enumConstantName;
4790
+ }
4791
+ }
4792
+ MngEnumPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngEnumPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
4793
+ MngEnumPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngEnumPipe, name: "enum" });
4794
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngEnumPipe, decorators: [{
4795
+ type: Pipe,
4796
+ args: [{
4797
+ name: 'enum',
4798
+ pure: true
4799
+ }]
4800
+ }] });
4801
+
4685
4802
  class MngTableColumnValueComponent {
4686
4803
  constructor() {
4687
4804
  this.columnTypeString = ColumnDescriptor.TypeEnum.String;
4688
4805
  this.columnTypeNumber = ColumnDescriptor.TypeEnum.Number;
4689
4806
  this.columnTypeBoolean = ColumnDescriptor.TypeEnum.Boolean;
4690
4807
  this.columnTypeDate = ColumnDescriptor.TypeEnum.Date;
4808
+ this.columnTypeEnum = ColumnDescriptor.TypeEnum.Enum;
4691
4809
  }
4692
4810
  }
4693
4811
  MngTableColumnValueComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngTableColumnValueComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
4694
- MngTableColumnValueComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngTableColumnValueComponent, selector: "mng-table-column-value", inputs: { descriptor: "descriptor", item: "item" }, ngImport: i0, template: "<ng-container [ngSwitch]=\"descriptor.columnType\">\n <ng-container *ngSwitchCase=\"columnTypeString\">\n {{ descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property] }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeNumber\">\n {{ (descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property]) | number: descriptor.displayFormat }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeDate\">\n {{ (descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property]) | date: descriptor.displayFormat }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeBoolean\">\n {{ (descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property]) | boolean }}\n </ng-container>\n</ng-container>\n", directives: [{ type: i4$1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i4$1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }], pipes: { "propertyPath": MngPropertyPathPipe, "number": i4$1.DecimalPipe, "date": i4$1.DatePipe, "boolean": MngBooleanPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
4812
+ MngTableColumnValueComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngTableColumnValueComponent, selector: "mng-table-column-value", inputs: { descriptor: "descriptor", item: "item" }, ngImport: i0, template: "<ng-container [ngSwitch]=\"descriptor.columnType\">\n <ng-container *ngSwitchCase=\"columnTypeString\">\n {{ descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property] }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeNumber\">\n {{ (descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property]) | number: descriptor.displayFormat }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeDate\">\n {{ (descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property]) | date: descriptor.displayFormat }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeBoolean\">\n {{ (descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property]) | boolean }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeEnum\">\n {{\n (descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property])\n | enum: descriptor.enumType:descriptor.enumTitlePath:descriptor.enumNameAsValue\n | translate\n }}\n </ng-container>\n</ng-container>\n", directives: [{ type: i4$1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i4$1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }], pipes: { "propertyPath": MngPropertyPathPipe, "number": i4$1.DecimalPipe, "date": i4$1.DatePipe, "boolean": MngBooleanPipe, "translate": i2$2.TranslatePipe, "enum": MngEnumPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
4695
4813
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngTableColumnValueComponent, decorators: [{
4696
4814
  type: Component,
4697
- args: [{ selector: 'mng-table-column-value', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container [ngSwitch]=\"descriptor.columnType\">\n <ng-container *ngSwitchCase=\"columnTypeString\">\n {{ descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property] }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeNumber\">\n {{ (descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property]) | number: descriptor.displayFormat }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeDate\">\n {{ (descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property]) | date: descriptor.displayFormat }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeBoolean\">\n {{ (descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property]) | boolean }}\n </ng-container>\n</ng-container>\n" }]
4815
+ args: [{ selector: 'mng-table-column-value', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container [ngSwitch]=\"descriptor.columnType\">\n <ng-container *ngSwitchCase=\"columnTypeString\">\n {{ descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property] }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeNumber\">\n {{ (descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property]) | number: descriptor.displayFormat }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeDate\">\n {{ (descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property]) | date: descriptor.displayFormat }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeBoolean\">\n {{ (descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property]) | boolean }}\n </ng-container>\n <ng-container *ngSwitchCase=\"columnTypeEnum\">\n {{\n (descriptor.displayPropertyPath ? (item | propertyPath: descriptor.displayPropertyPath) : item[descriptor.property])\n | enum: descriptor.enumType:descriptor.enumTitlePath:descriptor.enumNameAsValue\n | translate\n }}\n </ng-container>\n</ng-container>\n" }]
4698
4816
  }], propDecorators: { descriptor: [{
4699
4817
  type: Input
4700
4818
  }], item: [{
@@ -6131,6 +6249,7 @@ const declarations = [
6131
6249
  MngTemplateDirective,
6132
6250
  // pipes
6133
6251
  MngPropertyPathPipe,
6252
+ MngEnumPipe,
6134
6253
  MngBooleanPipe,
6135
6254
  MngI18nPropertyPipe,
6136
6255
  // layout components
@@ -6223,6 +6342,7 @@ MngCommonsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", versio
6223
6342
  MngTemplateDirective,
6224
6343
  // pipes
6225
6344
  MngPropertyPathPipe,
6345
+ MngEnumPipe,
6226
6346
  MngBooleanPipe,
6227
6347
  MngI18nPropertyPipe,
6228
6348
  // layout components
@@ -6333,6 +6453,7 @@ MngCommonsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", versio
6333
6453
  MngTemplateDirective,
6334
6454
  // pipes
6335
6455
  MngPropertyPathPipe,
6456
+ MngEnumPipe,
6336
6457
  MngBooleanPipe,
6337
6458
  MngI18nPropertyPipe,
6338
6459
  // layout components
@@ -6901,5 +7022,5 @@ class RouteBuilder {
6901
7022
  * Generated bundle index. Do not edit.
6902
7023
  */
6903
7024
 
6904
- export { AFieldDescriptor, AFieldGroupDescriptor, AGenericFieldDescriptor, AMngCrudApiService, AMngTableviewRouteComponent, ActionActivationResult, ActionActivationTriggerEnum, ActionDeleteDescriptor, ActionDescriptor, ActionEditorAddDescriptor, ActionEditorDescriptor, ActionEditorDetailsDescriptor, ActionEditorEditDescriptor, ActionError, ActionExecContext, ActionLevelEnum, ActionPositionEnum, ActionRunResult, ActionTriggerResult, ActionTypeEnum, ColumnDescriptor, DataProvider, EditorDataProvider, EditorDescriptor, EditorFormlyUtil, EnumName, EnumUtil, FieldGroupDescriptor, FieldInputDescriptor, FieldLookupDescriptor, FieldLookupEnumDescriptor, FieldManyEditorDescriptor, FieldManyToManyEditorDescriptor, FieldTabGroupDescriptor, FieldValidator, FilterDescriptor, FilterLookupDescriptor, I18nUtil, LookupDataProvider, MNG_AUTOCOMPLETE_VALUE_ACCESSOR, MNG_DROPDOWN_VALUE_ACCESSOR, MediusFilterMatchType, MediusFilterParam, MediusQueryMode, MediusQueryParam, MediusQueryParamBuilder, MediusQueryResult, MediusQueryResultBase, MediusQueryResultWithObject, MediusRestUtil, MngActionComponent, MngActionDialogComponent, MngActionRouteComponent, MngActionService, MngAutocompleteComponent, MngBooleanPipe, MngBreadcrumbComponent, MngCommonsModule, MngCommonsService, MngComponentDirective, MngConfigurationService, MngDropdownComponent, MngFooterComponent, MngFormEditorComponent, MngFormEditorSubmitEvent, MngFormlyFieldAutocompleteComponent, MngFormlyFieldDropdownComponent, MngFormlyFieldFieldsetComponent, MngFormlyFieldInputComponent, MngFormlyFieldTableDialogFormComponent, MngFormlyFieldTableDialogMultiselectComponent, MngFormlyFieldTabsComponent, MngFormlyFieldWrapperComponent, MngFormlyTableWrapperComponent, MngI18nPropertyPipe, MngMainLayoutComponent, MngMainLayoutComponentService, MngMenuComponent, MngMenuItemComponent, MngNavigationService, MngPropertyPathPipe, MngTableColumnFilterComponent, MngTableColumnValueComponent, MngTableComponent, MngTableviewComponent, MngTableviewRouteComponent, MngTemplateDirective, MngTopbarComponent, ModelDescriptor, ModelUtil, ObjectSerializer, RouteBuilder, RoutesBuilder, TableDescriptor, TableviewComponentService, TableviewDataProvider, TableviewDescriptor, ToastUtil, TypeName, TypeUtil, enumNameDecoratorPropertyName, enumsMapBase, formlyTypesConfig, formlyWrappersConfig, getEmailValidationMessage, getFormlyValidationMessages, getMaxLengthValidationMessage, getMinLengthValidationMessage, getRequiredValidationMessage, getTextPatternValidationMessage, mngCommonsInitializerProvider, mngConfigJsonAppInitializerProvider, mngConfigurationServiceProvider, mngFormlyConfigProvider, primeNgModules, typeMapBase, typeNameDecoratorPropertyName };
7025
+ export { AFieldDescriptor, AFieldGroupDescriptor, AGenericFieldDescriptor, AMngCrudApiService, AMngTableviewRouteComponent, ActionActivationResult, ActionActivationTriggerEnum, ActionDeleteDescriptor, ActionDescriptor, ActionEditorAddDescriptor, ActionEditorDescriptor, ActionEditorDetailsDescriptor, ActionEditorEditDescriptor, ActionError, ActionExecContext, ActionLevelEnum, ActionPositionEnum, ActionRunResult, ActionTriggerResult, ActionTypeEnum, ColumnDescriptor, DataProvider, EditorDataProvider, EditorDescriptor, EditorFormlyUtil, EnumName, EnumUtil, FieldGroupDescriptor, FieldInputDescriptor, FieldLookupDescriptor, FieldLookupEnumDescriptor, FieldManyEditorDescriptor, FieldManyToManyEditorDescriptor, FieldTabGroupDescriptor, FieldValidator, FilterDescriptor, FilterLookupDescriptor, FilterLookupEnumDescriptor, I18nUtil, LookupDataProvider, MNG_AUTOCOMPLETE_VALUE_ACCESSOR, MNG_DROPDOWN_VALUE_ACCESSOR, MediusFilterMatchType, MediusFilterParam, MediusQueryMode, MediusQueryParam, MediusQueryParamBuilder, MediusQueryResult, MediusQueryResultBase, MediusQueryResultWithObject, MediusRestUtil, MngActionComponent, MngActionDialogComponent, MngActionRouteComponent, MngActionService, MngAutocompleteComponent, MngBooleanPipe, MngBreadcrumbComponent, MngCommonsModule, MngCommonsService, MngComponentDirective, MngConfigurationService, MngDropdownComponent, MngEnumPipe, MngFooterComponent, MngFormEditorComponent, MngFormEditorSubmitEvent, MngFormlyFieldAutocompleteComponent, MngFormlyFieldDropdownComponent, MngFormlyFieldFieldsetComponent, MngFormlyFieldInputComponent, MngFormlyFieldTableDialogFormComponent, MngFormlyFieldTableDialogMultiselectComponent, MngFormlyFieldTabsComponent, MngFormlyFieldWrapperComponent, MngFormlyTableWrapperComponent, MngI18nPropertyPipe, MngMainLayoutComponent, MngMainLayoutComponentService, MngMenuComponent, MngMenuItemComponent, MngNavigationService, MngPropertyPathPipe, MngTableColumnFilterComponent, MngTableColumnValueComponent, MngTableComponent, MngTableviewComponent, MngTableviewRouteComponent, MngTemplateDirective, MngTopbarComponent, ModelDescriptor, ModelUtil, ObjectSerializer, RouteBuilder, RoutesBuilder, TableDescriptor, TableviewComponentService, TableviewDataProvider, TableviewDescriptor, ToastUtil, TypeName, TypeUtil, enumNameDecoratorPropertyName, enumsMapBase, formlyTypesConfig, formlyWrappersConfig, getEmailValidationMessage, getFormlyValidationMessages, getMaxLengthValidationMessage, getMinLengthValidationMessage, getRequiredValidationMessage, getTextPatternValidationMessage, mngCommonsInitializerProvider, mngConfigJsonAppInitializerProvider, mngConfigurationServiceProvider, mngFormlyConfigProvider, primeNgModules, typeMapBase, typeNameDecoratorPropertyName };
6905
7026
  //# sourceMappingURL=mediusinc-mng-commons.mjs.map