@mediusinc/mng-commons 0.2.14 → 0.2.17
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/esm2020/lib/api/models/filter-match-type.model.mjs +11 -12
- package/esm2020/lib/api/models/filter-param.model.mjs +11 -12
- package/esm2020/lib/api/models/query-mode.model.mjs +4 -4
- package/esm2020/lib/api/models/query-param.model.mjs +29 -30
- package/esm2020/lib/components/form/autocomplete/autocomplete.component.mjs +9 -13
- package/esm2020/lib/components/form/dropdown/dropdown.component.mjs +13 -15
- package/esm2020/lib/components/form/formly/fields/formly-field-dropdown/formly-field-dropdown.component.mjs +3 -3
- package/esm2020/lib/components/form/formly/fields/formly-field-input/formly-field-input.component.mjs +3 -3
- package/esm2020/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.mjs +7 -6
- package/esm2020/lib/components/layout/main-layout.component.mjs +1 -3
- package/esm2020/lib/components/layout/topbar.component.mjs +1 -3
- package/esm2020/lib/components/tableview/table/column-filter/column-filter.component.mjs +1 -1
- package/esm2020/lib/components/tableview/table/table.component.mjs +7 -9
- package/esm2020/lib/descriptors/editor.descriptor.mjs +8 -3
- package/esm2020/lib/descriptors/table.descriptor.mjs +1 -2
- package/esm2020/lib/router/models/router.model.mjs +1 -1
- package/esm2020/lib/router/route-builder.mjs +75 -11
- package/esm2020/lib/services/configuration.service.mjs +3 -3
- package/fesm2015/mediusinc-mng-commons.mjs +176 -111
- package/fesm2015/mediusinc-mng-commons.mjs.map +1 -1
- package/fesm2020/mediusinc-mng-commons.mjs +169 -114
- package/fesm2020/mediusinc-mng-commons.mjs.map +1 -1
- package/lib/api/models/filter-match-type.model.d.ts +10 -10
- package/lib/api/models/filter-param.model.d.ts +6 -6
- package/lib/api/models/query-mode.model.d.ts +3 -3
- package/lib/api/models/query-param.model.d.ts +13 -13
- package/lib/components/form/autocomplete/autocomplete.component.d.ts +3 -2
- package/lib/components/form/dropdown/dropdown.component.d.ts +6 -3
- package/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.d.ts +1 -0
- package/lib/components/layout/main-layout.component.d.ts +2 -3
- package/lib/components/layout/topbar.component.d.ts +2 -3
- package/lib/descriptors/editor.descriptor.d.ts +3 -1
- package/lib/router/models/router.model.d.ts +2 -2
- package/lib/router/route-builder.d.ts +18 -4
- package/openapi/templates/model.mustache +82 -0
- package/openapi/templates/models.mustache +50 -0
- package/package.json +1 -1
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
/* tslint:disable:no-angle-bracket-type-assertion no-trailing-whitespace member-ordering object-literal-key-quotes */
|
|
2
1
|
/**
|
|
3
2
|
* Generated API
|
|
4
3
|
* No description provided (generated by Openapi Generator https://github.com/openapitools/openapi-generator)
|
|
@@ -12,15 +11,15 @@
|
|
|
12
11
|
*/
|
|
13
12
|
export var MediusFilterMatchType;
|
|
14
13
|
(function (MediusFilterMatchType) {
|
|
15
|
-
MediusFilterMatchType[
|
|
16
|
-
MediusFilterMatchType[
|
|
17
|
-
MediusFilterMatchType[
|
|
18
|
-
MediusFilterMatchType[
|
|
19
|
-
MediusFilterMatchType[
|
|
20
|
-
MediusFilterMatchType[
|
|
21
|
-
MediusFilterMatchType[
|
|
22
|
-
MediusFilterMatchType[
|
|
23
|
-
MediusFilterMatchType[
|
|
24
|
-
MediusFilterMatchType[
|
|
14
|
+
MediusFilterMatchType["Equals"] = "EQUALS";
|
|
15
|
+
MediusFilterMatchType["NotEquals"] = "NOT_EQUALS";
|
|
16
|
+
MediusFilterMatchType["FromTo"] = "FROM_TO";
|
|
17
|
+
MediusFilterMatchType["Contains"] = "CONTAINS";
|
|
18
|
+
MediusFilterMatchType["StartsWith"] = "STARTS_WITH";
|
|
19
|
+
MediusFilterMatchType["EndsWith"] = "ENDS_WITH";
|
|
20
|
+
MediusFilterMatchType["In"] = "IN";
|
|
21
|
+
MediusFilterMatchType["NotIn"] = "NOT_IN";
|
|
22
|
+
MediusFilterMatchType["SmallerThan"] = "SMALLER_THAN";
|
|
23
|
+
MediusFilterMatchType["GreaterThan"] = "GREATER_THAN";
|
|
25
24
|
})(MediusFilterMatchType || (MediusFilterMatchType = {}));
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLW1hdGNoLXR5cGUubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL2FwaS9tb2RlbHMvZmlsdGVyLW1hdGNoLXR5cGUubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7R0FVRztBQUVILE1BQU0sQ0FBTixJQUFZLHFCQVdYO0FBWEQsV0FBWSxxQkFBcUI7SUFDN0IsMENBQWlCLENBQUE7SUFDakIsaURBQXdCLENBQUE7SUFDeEIsMkNBQWtCLENBQUE7SUFDbEIsOENBQXFCLENBQUE7SUFDckIsbURBQTBCLENBQUE7SUFDMUIsK0NBQXNCLENBQUE7SUFDdEIsa0NBQVMsQ0FBQTtJQUNULHlDQUFnQixDQUFBO0lBQ2hCLHFEQUE0QixDQUFBO0lBQzVCLHFEQUE0QixDQUFBO0FBQ2hDLENBQUMsRUFYVyxxQkFBcUIsS0FBckIscUJBQXFCLFFBV2hDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgQVBJXG4gKiBObyBkZXNjcmlwdGlvbiBwcm92aWRlZCAoZ2VuZXJhdGVkIGJ5IE9wZW5hcGkgR2VuZXJhdG9yIGh0dHBzOi8vZ2l0aHViLmNvbS9vcGVuYXBpdG9vbHMvb3BlbmFwaS1nZW5lcmF0b3IpXG4gKlxuICogVGhlIHZlcnNpb24gb2YgdGhlIE9wZW5BUEkgZG9jdW1lbnQ6IDEuMFxuICpcbiAqXG4gKiBOT1RFOiBUaGlzIGNsYXNzIGlzIGF1dG8gZ2VuZXJhdGVkIGJ5IE9wZW5BUEkgR2VuZXJhdG9yIChodHRwczovL29wZW5hcGktZ2VuZXJhdG9yLnRlY2gpLlxuICogaHR0cHM6Ly9vcGVuYXBpLWdlbmVyYXRvci50ZWNoXG4gKiBEbyBub3QgZWRpdCB0aGUgY2xhc3MgbWFudWFsbHkuXG4gKi9cblxuZXhwb3J0IGVudW0gTWVkaXVzRmlsdGVyTWF0Y2hUeXBlIHtcbiAgICBFcXVhbHMgPSAnRVFVQUxTJyxcbiAgICBOb3RFcXVhbHMgPSAnTk9UX0VRVUFMUycsXG4gICAgRnJvbVRvID0gJ0ZST01fVE8nLFxuICAgIENvbnRhaW5zID0gJ0NPTlRBSU5TJyxcbiAgICBTdGFydHNXaXRoID0gJ1NUQVJUU19XSVRIJyxcbiAgICBFbmRzV2l0aCA9ICdFTkRTX1dJVEgnLFxuICAgIEluID0gJ0lOJyxcbiAgICBOb3RJbiA9ICdOT1RfSU4nLFxuICAgIFNtYWxsZXJUaGFuID0gJ1NNQUxMRVJfVEhBTicsXG4gICAgR3JlYXRlclRoYW4gPSAnR1JFQVRFUl9USEFOJ1xufVxuIl19
|
|
@@ -4,23 +4,12 @@ export class MediusFilterParam {
|
|
|
4
4
|
return MediusFilterParam.attributeTypeMap;
|
|
5
5
|
}
|
|
6
6
|
}
|
|
7
|
-
MediusFilterParam.discriminator = undefined;
|
|
8
7
|
MediusFilterParam.attributeTypeMap = [
|
|
9
8
|
{
|
|
10
9
|
name: 'property',
|
|
11
10
|
baseName: 'property',
|
|
12
11
|
type: 'string'
|
|
13
12
|
},
|
|
14
|
-
{
|
|
15
|
-
name: 'filterMatchCaseSensitive',
|
|
16
|
-
baseName: 'filter_match_case_sensitive',
|
|
17
|
-
type: 'boolean'
|
|
18
|
-
},
|
|
19
|
-
{
|
|
20
|
-
name: 'filterMatchType',
|
|
21
|
-
baseName: 'filter_match_type',
|
|
22
|
-
type: 'FilterMatchType'
|
|
23
|
-
},
|
|
24
13
|
{
|
|
25
14
|
name: 'filterValue',
|
|
26
15
|
baseName: 'filter_value',
|
|
@@ -30,6 +19,16 @@ MediusFilterParam.attributeTypeMap = [
|
|
|
30
19
|
name: 'filterValueTo',
|
|
31
20
|
baseName: 'filter_value_to',
|
|
32
21
|
type: 'object'
|
|
22
|
+
},
|
|
23
|
+
{
|
|
24
|
+
name: 'filterMatchType',
|
|
25
|
+
baseName: 'filter_match_type',
|
|
26
|
+
type: 'FilterMatchType'
|
|
27
|
+
},
|
|
28
|
+
{
|
|
29
|
+
name: 'filterMatchCaseSensitive',
|
|
30
|
+
baseName: 'filter_match_case_sensitive',
|
|
31
|
+
type: 'boolean'
|
|
33
32
|
}
|
|
34
33
|
];
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLXBhcmFtLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9hcGkvbW9kZWxzL2ZpbHRlci1wYXJhbS5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxxSEFBcUg7QUFnQnJILE1BQU0sT0FBTyxpQkFBaUI7SUFxQ25CLE1BQU0sQ0FBQyxtQkFBbUI7UUFDN0IsT0FBTyxpQkFBaUIsQ0FBQyxnQkFBZ0IsQ0FBQztJQUM5QyxDQUFDOztBQTlCYSxrQ0FBZ0IsR0FBd0I7SUFDbEQ7UUFDSSxJQUFJLEVBQUUsVUFBVTtRQUNoQixRQUFRLEVBQUUsVUFBVTtRQUNwQixJQUFJLEVBQUUsUUFBUTtLQUNqQjtJQUNEO1FBQ0ksSUFBSSxFQUFFLGFBQWE7UUFDbkIsUUFBUSxFQUFFLGNBQWM7UUFDeEIsSUFBSSxFQUFFLFFBQVE7S0FDakI7SUFDRDtRQUNJLElBQUksRUFBRSxlQUFlO1FBQ3JCLFFBQVEsRUFBRSxpQkFBaUI7UUFDM0IsSUFBSSxFQUFFLFFBQVE7S0FDakI7SUFDRDtRQUNJLElBQUksRUFBRSxpQkFBaUI7UUFDdkIsUUFBUSxFQUFFLG1CQUFtQjtRQUM3QixJQUFJLEVBQUUsaUJBQWlCO0tBQzFCO0lBQ0Q7UUFDSSxJQUFJLEVBQUUsMEJBQTBCO1FBQ2hDLFFBQVEsRUFBRSw2QkFBNkI7UUFDdkMsSUFBSSxFQUFFLFNBQVM7S0FDbEI7Q0FDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyogdHNsaW50OmRpc2FibGU6bm8tYW5nbGUtYnJhY2tldC10eXBlLWFzc2VydGlvbiBuby10cmFpbGluZy13aGl0ZXNwYWNlIG1lbWJlci1vcmRlcmluZyBvYmplY3QtbGl0ZXJhbC1rZXktcXVvdGVzICovXG5cbi8qKlxuICogR2VuZXJhdGVkIEFQSVxuICogTm8gZGVzY3JpcHRpb24gcHJvdmlkZWQgKGdlbmVyYXRlZCBieSBPcGVuYXBpIEdlbmVyYXRvciBodHRwczovL2dpdGh1Yi5jb20vb3BlbmFwaXRvb2xzL29wZW5hcGktZ2VuZXJhdG9yKVxuICpcbiAqIFRoZSB2ZXJzaW9uIG9mIHRoZSBPcGVuQVBJIGRvY3VtZW50OiAxLjBcbiAqXG4gKlxuICogTk9URTogVGhpcyBjbGFzcyBpcyBhdXRvIGdlbmVyYXRlZCBieSBPcGVuQVBJIEdlbmVyYXRvciAoaHR0cHM6Ly9vcGVuYXBpLWdlbmVyYXRvci50ZWNoKS5cbiAqIGh0dHBzOi8vb3BlbmFwaS1nZW5lcmF0b3IudGVjaFxuICogRG8gbm90IGVkaXQgdGhlIGNsYXNzIG1hbnVhbGx5LlxuICovXG5pbXBvcnQge01lZGl1c0ZpbHRlck1hdGNoVHlwZX0gZnJvbSAnLi9maWx0ZXItbWF0Y2gtdHlwZS5tb2RlbCc7XG5pbXBvcnQge0F0dHJpYnV0ZURlZn0gZnJvbSAnLi9zZXJpYWxpemF0aW9uLm1vZGVsJztcblxuZXhwb3J0IGNsYXNzIE1lZGl1c0ZpbHRlclBhcmFtIHtcbiAgICBwcm9wZXJ0eT86IHN0cmluZztcbiAgICBmaWx0ZXJWYWx1ZT86IG9iamVjdDtcbiAgICBmaWx0ZXJWYWx1ZVRvPzogb2JqZWN0O1xuICAgIGZpbHRlck1hdGNoVHlwZT86IE1lZGl1c0ZpbHRlck1hdGNoVHlwZTtcbiAgICBmaWx0ZXJNYXRjaENhc2VTZW5zaXRpdmU/OiBib29sZWFuO1xuXG4gICAgcHVibGljIHN0YXRpYyBkaXNjcmltaW5hdG9yPzogc3RyaW5nO1xuXG4gICAgcHVibGljIHN0YXRpYyBhdHRyaWJ1dGVUeXBlTWFwOiBBcnJheTxBdHRyaWJ1dGVEZWY+ID0gW1xuICAgICAgICB7XG4gICAgICAgICAgICBuYW1lOiAncHJvcGVydHknLFxuICAgICAgICAgICAgYmFzZU5hbWU6ICdwcm9wZXJ0eScsXG4gICAgICAgICAgICB0eXBlOiAnc3RyaW5nJ1xuICAgICAgICB9LFxuICAgICAgICB7XG4gICAgICAgICAgICBuYW1lOiAnZmlsdGVyVmFsdWUnLFxuICAgICAgICAgICAgYmFzZU5hbWU6ICdmaWx0ZXJfdmFsdWUnLFxuICAgICAgICAgICAgdHlwZTogJ29iamVjdCdcbiAgICAgICAgfSxcbiAgICAgICAge1xuICAgICAgICAgICAgbmFtZTogJ2ZpbHRlclZhbHVlVG8nLFxuICAgICAgICAgICAgYmFzZU5hbWU6ICdmaWx0ZXJfdmFsdWVfdG8nLFxuICAgICAgICAgICAgdHlwZTogJ29iamVjdCdcbiAgICAgICAgfSxcbiAgICAgICAge1xuICAgICAgICAgICAgbmFtZTogJ2ZpbHRlck1hdGNoVHlwZScsXG4gICAgICAgICAgICBiYXNlTmFtZTogJ2ZpbHRlcl9tYXRjaF90eXBlJyxcbiAgICAgICAgICAgIHR5cGU6ICdGaWx0ZXJNYXRjaFR5cGUnXG4gICAgICAgIH0sXG4gICAgICAgIHtcbiAgICAgICAgICAgIG5hbWU6ICdmaWx0ZXJNYXRjaENhc2VTZW5zaXRpdmUnLFxuICAgICAgICAgICAgYmFzZU5hbWU6ICdmaWx0ZXJfbWF0Y2hfY2FzZV9zZW5zaXRpdmUnLFxuICAgICAgICAgICAgdHlwZTogJ2Jvb2xlYW4nXG4gICAgICAgIH1cbiAgICBdO1xuXG4gICAgcHVibGljIHN0YXRpYyBnZXRBdHRyaWJ1dGVUeXBlTWFwKCkge1xuICAgICAgICByZXR1cm4gTWVkaXVzRmlsdGVyUGFyYW0uYXR0cmlidXRlVHlwZU1hcDtcbiAgICB9XG59XG4iXX0=
|
|
@@ -12,8 +12,8 @@
|
|
|
12
12
|
*/
|
|
13
13
|
export var MediusQueryMode;
|
|
14
14
|
(function (MediusQueryMode) {
|
|
15
|
-
MediusQueryMode[
|
|
16
|
-
MediusQueryMode[
|
|
17
|
-
MediusQueryMode[
|
|
15
|
+
MediusQueryMode["Count"] = "COUNT";
|
|
16
|
+
MediusQueryMode["Data"] = "DATA";
|
|
17
|
+
MediusQueryMode["All"] = "ALL";
|
|
18
18
|
})(MediusQueryMode || (MediusQueryMode = {}));
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVlcnktbW9kZS5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvYXBpL21vZGVscy9xdWVyeS1tb2RlLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLHFIQUFxSDtBQUNySDs7Ozs7Ozs7OztHQVVHO0FBRUgsTUFBTSxDQUFOLElBQVksZUFJWDtBQUpELFdBQVksZUFBZTtJQUN2QixrQ0FBZSxDQUFBO0lBQ2YsZ0NBQWEsQ0FBQTtJQUNiLDhCQUFXLENBQUE7QUFDZixDQUFDLEVBSlcsZUFBZSxLQUFmLGVBQWUsUUFJMUIiLCJzb3VyY2VzQ29udGVudCI6WyIvKiB0c2xpbnQ6ZGlzYWJsZTpuby1hbmdsZS1icmFja2V0LXR5cGUtYXNzZXJ0aW9uIG5vLXRyYWlsaW5nLXdoaXRlc3BhY2UgbWVtYmVyLW9yZGVyaW5nIG9iamVjdC1saXRlcmFsLWtleS1xdW90ZXMgKi9cbi8qKlxuICogR2VuZXJhdGVkIEFQSVxuICogTm8gZGVzY3JpcHRpb24gcHJvdmlkZWQgKGdlbmVyYXRlZCBieSBPcGVuYXBpIEdlbmVyYXRvciBodHRwczovL2dpdGh1Yi5jb20vb3BlbmFwaXRvb2xzL29wZW5hcGktZ2VuZXJhdG9yKVxuICpcbiAqIFRoZSB2ZXJzaW9uIG9mIHRoZSBPcGVuQVBJIGRvY3VtZW50OiAxLjBcbiAqXG4gKlxuICogTk9URTogVGhpcyBjbGFzcyBpcyBhdXRvIGdlbmVyYXRlZCBieSBPcGVuQVBJIEdlbmVyYXRvciAoaHR0cHM6Ly9vcGVuYXBpLWdlbmVyYXRvci50ZWNoKS5cbiAqIGh0dHBzOi8vb3BlbmFwaS1nZW5lcmF0b3IudGVjaFxuICogRG8gbm90IGVkaXQgdGhlIGNsYXNzIG1hbnVhbGx5LlxuICovXG5cbmV4cG9ydCBlbnVtIE1lZGl1c1F1ZXJ5TW9kZSB7XG4gICAgQ291bnQgPSAnQ09VTlQnLFxuICAgIERhdGEgPSAnREFUQScsXG4gICAgQWxsID0gJ0FMTCdcbn1cbiJdfQ==
|
|
@@ -4,27 +4,16 @@ export class MediusQueryParam {
|
|
|
4
4
|
return MediusQueryParam.attributeTypeMap;
|
|
5
5
|
}
|
|
6
6
|
}
|
|
7
|
-
MediusQueryParam.discriminator = undefined;
|
|
8
7
|
MediusQueryParam.attributeTypeMap = [
|
|
9
8
|
{
|
|
10
|
-
name: '
|
|
11
|
-
baseName: '
|
|
12
|
-
type: 'string'
|
|
13
|
-
},
|
|
14
|
-
{
|
|
15
|
-
name: 'filterAllProperties',
|
|
16
|
-
baseName: 'filter_all_properties',
|
|
9
|
+
name: 'sortProperty',
|
|
10
|
+
baseName: 'sort_property',
|
|
17
11
|
type: 'Array<string>'
|
|
18
12
|
},
|
|
19
13
|
{
|
|
20
|
-
name: '
|
|
21
|
-
baseName: '
|
|
22
|
-
type: 'Array<
|
|
23
|
-
},
|
|
24
|
-
{
|
|
25
|
-
name: 'groupByProperties',
|
|
26
|
-
baseName: 'group_by_properties',
|
|
27
|
-
type: 'Array<string>'
|
|
14
|
+
name: 'sortAsc',
|
|
15
|
+
baseName: 'sort_asc',
|
|
16
|
+
type: 'Array<boolean>'
|
|
28
17
|
},
|
|
29
18
|
{
|
|
30
19
|
name: 'itemsOffset',
|
|
@@ -37,34 +26,44 @@ MediusQueryParam.attributeTypeMap = [
|
|
|
37
26
|
type: 'number'
|
|
38
27
|
},
|
|
39
28
|
{
|
|
40
|
-
name: '
|
|
41
|
-
baseName: '
|
|
42
|
-
type: '
|
|
29
|
+
name: 'filterParams',
|
|
30
|
+
baseName: 'filter_params',
|
|
31
|
+
type: 'Array<MediusFilterParam>'
|
|
32
|
+
},
|
|
33
|
+
{
|
|
34
|
+
name: 'filterAllParam',
|
|
35
|
+
baseName: 'filter_all_param',
|
|
36
|
+
type: 'string'
|
|
37
|
+
},
|
|
38
|
+
{
|
|
39
|
+
name: 'filterAllProperties',
|
|
40
|
+
baseName: 'filter_all_properties',
|
|
41
|
+
type: 'Array<string>'
|
|
42
|
+
},
|
|
43
|
+
{
|
|
44
|
+
name: 'validateProperties',
|
|
45
|
+
baseName: 'validate_properties',
|
|
46
|
+
type: 'Array<string>'
|
|
43
47
|
},
|
|
44
48
|
{
|
|
45
49
|
name: 'selectInTwoSteps',
|
|
46
50
|
baseName: 'select_in_two_steps',
|
|
47
51
|
type: 'boolean'
|
|
48
52
|
},
|
|
49
|
-
{
|
|
50
|
-
name: 'sortAsc',
|
|
51
|
-
baseName: 'sort_asc',
|
|
52
|
-
type: 'Array<boolean>'
|
|
53
|
-
},
|
|
54
53
|
{
|
|
55
54
|
name: 'sortEnumByOrdinal',
|
|
56
55
|
baseName: 'sort_enum_by_ordinal',
|
|
57
56
|
type: 'boolean'
|
|
58
57
|
},
|
|
59
58
|
{
|
|
60
|
-
name: '
|
|
61
|
-
baseName: '
|
|
59
|
+
name: 'groupByProperties',
|
|
60
|
+
baseName: 'group_by_properties',
|
|
62
61
|
type: 'Array<string>'
|
|
63
62
|
},
|
|
64
63
|
{
|
|
65
|
-
name: '
|
|
66
|
-
baseName: '
|
|
67
|
-
type: '
|
|
64
|
+
name: 'queryMode',
|
|
65
|
+
baseName: 'query_mode',
|
|
66
|
+
type: 'MediusQueryMode'
|
|
68
67
|
}
|
|
69
68
|
];
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVlcnktcGFyYW0ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL2FwaS9tb2RlbHMvcXVlcnktcGFyYW0ubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEscUhBQXFIO0FBaUJySCxNQUFNLE9BQU8sZ0JBQWdCO0lBK0VsQixNQUFNLENBQUMsbUJBQW1CO1FBQzdCLE9BQU8sZ0JBQWdCLENBQUMsZ0JBQWdCLENBQUM7SUFDN0MsQ0FBQzs7QUFqRWEsaUNBQWdCLEdBQXdCO0lBQ2xEO1FBQ0ksSUFBSSxFQUFFLGNBQWM7UUFDcEIsUUFBUSxFQUFFLGVBQWU7UUFDekIsSUFBSSxFQUFFLGVBQWU7S0FDeEI7SUFDRDtRQUNJLElBQUksRUFBRSxTQUFTO1FBQ2YsUUFBUSxFQUFFLFVBQVU7UUFDcEIsSUFBSSxFQUFFLGdCQUFnQjtLQUN6QjtJQUNEO1FBQ0ksSUFBSSxFQUFFLGFBQWE7UUFDbkIsUUFBUSxFQUFFLGNBQWM7UUFDeEIsSUFBSSxFQUFFLFFBQVE7S0FDakI7SUFDRDtRQUNJLElBQUksRUFBRSxjQUFjO1FBQ3BCLFFBQVEsRUFBRSxnQkFBZ0I7UUFDMUIsSUFBSSxFQUFFLFFBQVE7S0FDakI7SUFDRDtRQUNJLElBQUksRUFBRSxjQUFjO1FBQ3BCLFFBQVEsRUFBRSxlQUFlO1FBQ3pCLElBQUksRUFBRSwwQkFBMEI7S0FDbkM7SUFDRDtRQUNJLElBQUksRUFBRSxnQkFBZ0I7UUFDdEIsUUFBUSxFQUFFLGtCQUFrQjtRQUM1QixJQUFJLEVBQUUsUUFBUTtLQUNqQjtJQUNEO1FBQ0ksSUFBSSxFQUFFLHFCQUFxQjtRQUMzQixRQUFRLEVBQUUsdUJBQXVCO1FBQ2pDLElBQUksRUFBRSxlQUFlO0tBQ3hCO0lBQ0Q7UUFDSSxJQUFJLEVBQUUsb0JBQW9CO1FBQzFCLFFBQVEsRUFBRSxxQkFBcUI7UUFDL0IsSUFBSSxFQUFFLGVBQWU7S0FDeEI7SUFDRDtRQUNJLElBQUksRUFBRSxrQkFBa0I7UUFDeEIsUUFBUSxFQUFFLHFCQUFxQjtRQUMvQixJQUFJLEVBQUUsU0FBUztLQUNsQjtJQUNEO1FBQ0ksSUFBSSxFQUFFLG1CQUFtQjtRQUN6QixRQUFRLEVBQUUsc0JBQXNCO1FBQ2hDLElBQUksRUFBRSxTQUFTO0tBQ2xCO0lBQ0Q7UUFDSSxJQUFJLEVBQUUsbUJBQW1CO1FBQ3pCLFFBQVEsRUFBRSxxQkFBcUI7UUFDL0IsSUFBSSxFQUFFLGVBQWU7S0FDeEI7SUFDRDtRQUNJLElBQUksRUFBRSxXQUFXO1FBQ2pCLFFBQVEsRUFBRSxZQUFZO1FBQ3RCLElBQUksRUFBRSxpQkFBaUI7S0FDMUI7Q0FDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyogdHNsaW50OmRpc2FibGU6bm8tYW5nbGUtYnJhY2tldC10eXBlLWFzc2VydGlvbiBuby10cmFpbGluZy13aGl0ZXNwYWNlIG1lbWJlci1vcmRlcmluZyBvYmplY3QtbGl0ZXJhbC1rZXktcXVvdGVzICovXG5cbi8qKlxuICogR2VuZXJhdGVkIEFQSVxuICogTm8gZGVzY3JpcHRpb24gcHJvdmlkZWQgKGdlbmVyYXRlZCBieSBPcGVuYXBpIEdlbmVyYXRvciBodHRwczovL2dpdGh1Yi5jb20vb3BlbmFwaXRvb2xzL29wZW5hcGktZ2VuZXJhdG9yKVxuICpcbiAqIFRoZSB2ZXJzaW9uIG9mIHRoZSBPcGVuQVBJIGRvY3VtZW50OiAxLjBcbiAqXG4gKlxuICogTk9URTogVGhpcyBjbGFzcyBpcyBhdXRvIGdlbmVyYXRlZCBieSBPcGVuQVBJIEdlbmVyYXRvciAoaHR0cHM6Ly9vcGVuYXBpLWdlbmVyYXRvci50ZWNoKS5cbiAqIGh0dHBzOi8vb3BlbmFwaS1nZW5lcmF0b3IudGVjaFxuICogRG8gbm90IGVkaXQgdGhlIGNsYXNzIG1hbnVhbGx5LlxuICovXG5pbXBvcnQge01lZGl1c0ZpbHRlclBhcmFtfSBmcm9tICcuL2ZpbHRlci1wYXJhbS5tb2RlbCc7XG5pbXBvcnQge01lZGl1c1F1ZXJ5TW9kZX0gZnJvbSAnLi9xdWVyeS1tb2RlLm1vZGVsJztcbmltcG9ydCB7QXR0cmlidXRlRGVmfSBmcm9tICcuL3NlcmlhbGl6YXRpb24ubW9kZWwnO1xuXG5leHBvcnQgY2xhc3MgTWVkaXVzUXVlcnlQYXJhbSB7XG4gICAgc29ydFByb3BlcnR5PzogQXJyYXk8c3RyaW5nPjtcbiAgICBzb3J0QXNjPzogQXJyYXk8Ym9vbGVhbj47XG4gICAgaXRlbXNPZmZzZXQ/OiBudW1iZXI7XG4gICAgaXRlbXNQZXJQYWdlPzogbnVtYmVyO1xuICAgIGZpbHRlclBhcmFtcz86IEFycmF5PE1lZGl1c0ZpbHRlclBhcmFtPjtcbiAgICBmaWx0ZXJBbGxQYXJhbT86IHN0cmluZztcbiAgICBmaWx0ZXJBbGxQcm9wZXJ0aWVzPzogQXJyYXk8c3RyaW5nPjtcbiAgICB2YWxpZGF0ZVByb3BlcnRpZXM/OiBBcnJheTxzdHJpbmc+O1xuICAgIHNlbGVjdEluVHdvU3RlcHM/OiBib29sZWFuO1xuICAgIHNvcnRFbnVtQnlPcmRpbmFsPzogYm9vbGVhbjtcbiAgICBncm91cEJ5UHJvcGVydGllcz86IEFycmF5PHN0cmluZz47XG4gICAgcXVlcnlNb2RlPzogTWVkaXVzUXVlcnlNb2RlO1xuXG4gICAgcHVibGljIHN0YXRpYyBkaXNjcmltaW5hdG9yPzogc3RyaW5nO1xuXG4gICAgcHVibGljIHN0YXRpYyBhdHRyaWJ1dGVUeXBlTWFwOiBBcnJheTxBdHRyaWJ1dGVEZWY+ID0gW1xuICAgICAgICB7XG4gICAgICAgICAgICBuYW1lOiAnc29ydFByb3BlcnR5JyxcbiAgICAgICAgICAgIGJhc2VOYW1lOiAnc29ydF9wcm9wZXJ0eScsXG4gICAgICAgICAgICB0eXBlOiAnQXJyYXk8c3RyaW5nPidcbiAgICAgICAgfSxcbiAgICAgICAge1xuICAgICAgICAgICAgbmFtZTogJ3NvcnRBc2MnLFxuICAgICAgICAgICAgYmFzZU5hbWU6ICdzb3J0X2FzYycsXG4gICAgICAgICAgICB0eXBlOiAnQXJyYXk8Ym9vbGVhbj4nXG4gICAgICAgIH0sXG4gICAgICAgIHtcbiAgICAgICAgICAgIG5hbWU6ICdpdGVtc09mZnNldCcsXG4gICAgICAgICAgICBiYXNlTmFtZTogJ2l0ZW1zX29mZnNldCcsXG4gICAgICAgICAgICB0eXBlOiAnbnVtYmVyJ1xuICAgICAgICB9LFxuICAgICAgICB7XG4gICAgICAgICAgICBuYW1lOiAnaXRlbXNQZXJQYWdlJyxcbiAgICAgICAgICAgIGJhc2VOYW1lOiAnaXRlbXNfcGVyX3BhZ2UnLFxuICAgICAgICAgICAgdHlwZTogJ251bWJlcidcbiAgICAgICAgfSxcbiAgICAgICAge1xuICAgICAgICAgICAgbmFtZTogJ2ZpbHRlclBhcmFtcycsXG4gICAgICAgICAgICBiYXNlTmFtZTogJ2ZpbHRlcl9wYXJhbXMnLFxuICAgICAgICAgICAgdHlwZTogJ0FycmF5PE1lZGl1c0ZpbHRlclBhcmFtPidcbiAgICAgICAgfSxcbiAgICAgICAge1xuICAgICAgICAgICAgbmFtZTogJ2ZpbHRlckFsbFBhcmFtJyxcbiAgICAgICAgICAgIGJhc2VOYW1lOiAnZmlsdGVyX2FsbF9wYXJhbScsXG4gICAgICAgICAgICB0eXBlOiAnc3RyaW5nJ1xuICAgICAgICB9LFxuICAgICAgICB7XG4gICAgICAgICAgICBuYW1lOiAnZmlsdGVyQWxsUHJvcGVydGllcycsXG4gICAgICAgICAgICBiYXNlTmFtZTogJ2ZpbHRlcl9hbGxfcHJvcGVydGllcycsXG4gICAgICAgICAgICB0eXBlOiAnQXJyYXk8c3RyaW5nPidcbiAgICAgICAgfSxcbiAgICAgICAge1xuICAgICAgICAgICAgbmFtZTogJ3ZhbGlkYXRlUHJvcGVydGllcycsXG4gICAgICAgICAgICBiYXNlTmFtZTogJ3ZhbGlkYXRlX3Byb3BlcnRpZXMnLFxuICAgICAgICAgICAgdHlwZTogJ0FycmF5PHN0cmluZz4nXG4gICAgICAgIH0sXG4gICAgICAgIHtcbiAgICAgICAgICAgIG5hbWU6ICdzZWxlY3RJblR3b1N0ZXBzJyxcbiAgICAgICAgICAgIGJhc2VOYW1lOiAnc2VsZWN0X2luX3R3b19zdGVwcycsXG4gICAgICAgICAgICB0eXBlOiAnYm9vbGVhbidcbiAgICAgICAgfSxcbiAgICAgICAge1xuICAgICAgICAgICAgbmFtZTogJ3NvcnRFbnVtQnlPcmRpbmFsJyxcbiAgICAgICAgICAgIGJhc2VOYW1lOiAnc29ydF9lbnVtX2J5X29yZGluYWwnLFxuICAgICAgICAgICAgdHlwZTogJ2Jvb2xlYW4nXG4gICAgICAgIH0sXG4gICAgICAgIHtcbiAgICAgICAgICAgIG5hbWU6ICdncm91cEJ5UHJvcGVydGllcycsXG4gICAgICAgICAgICBiYXNlTmFtZTogJ2dyb3VwX2J5X3Byb3BlcnRpZXMnLFxuICAgICAgICAgICAgdHlwZTogJ0FycmF5PHN0cmluZz4nXG4gICAgICAgIH0sXG4gICAgICAgIHtcbiAgICAgICAgICAgIG5hbWU6ICdxdWVyeU1vZGUnLFxuICAgICAgICAgICAgYmFzZU5hbWU6ICdxdWVyeV9tb2RlJyxcbiAgICAgICAgICAgIHR5cGU6ICdNZWRpdXNRdWVyeU1vZGUnXG4gICAgICAgIH1cbiAgICBdO1xuXG4gICAgcHVibGljIHN0YXRpYyBnZXRBdHRyaWJ1dGVUeXBlTWFwKCkge1xuICAgICAgICByZXR1cm4gTWVkaXVzUXVlcnlQYXJhbS5hdHRyaWJ1dGVUeXBlTWFwO1xuICAgIH1cbn1cbiJdfQ==
|
|
@@ -2,7 +2,6 @@ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewCh
|
|
|
2
2
|
import { FormControl, NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
3
|
import { AutoComplete } from 'primeng/autocomplete';
|
|
4
4
|
import { Subject } from 'rxjs';
|
|
5
|
-
import { finalize, first } from 'rxjs/operators';
|
|
6
5
|
import { MediusFilterMatchType, MediusQueryParamBuilder } from '../../../api/models';
|
|
7
6
|
import * as i0 from "@angular/core";
|
|
8
7
|
import * as i1 from "primeng/autocomplete";
|
|
@@ -40,11 +39,11 @@ export class MngAutocompleteComponent {
|
|
|
40
39
|
console.warn(`Data provider should be provided for MngAutocompleteComponent.`);
|
|
41
40
|
}
|
|
42
41
|
}
|
|
42
|
+
ngOnDestroy() {
|
|
43
|
+
this.searchSubscription?.unsubscribe();
|
|
44
|
+
}
|
|
43
45
|
onSearch(event) {
|
|
44
|
-
|
|
45
|
-
// try to cancel existing HTTP request subscription
|
|
46
|
-
this.searchSubscription.unsubscribe();
|
|
47
|
-
}
|
|
46
|
+
this.searchSubscription?.unsubscribe();
|
|
48
47
|
if (this.dataProvider) {
|
|
49
48
|
this.isLoading = true;
|
|
50
49
|
const queryParamBuilder = MediusQueryParamBuilder.create();
|
|
@@ -54,11 +53,11 @@ export class MngAutocompleteComponent {
|
|
|
54
53
|
if (event.query && event.query.length > 0 && this.itemsLabelProperty) {
|
|
55
54
|
queryParamBuilder.withFilter(this.itemsLabelProperty, event.query, undefined, MediusFilterMatchType.StartsWith);
|
|
56
55
|
}
|
|
57
|
-
this.searchSubscription = this.dataProvider
|
|
58
|
-
.lookup(queryParamBuilder.build(), this.dataProviderService, event.query)
|
|
59
|
-
.pipe(first(), finalize(() => (this.isLoading = false)))
|
|
60
|
-
.subscribe((res) => {
|
|
56
|
+
this.searchSubscription = this.dataProvider.lookup(queryParamBuilder.build(), this.dataProviderService, event.query).subscribe((res) => {
|
|
61
57
|
this.suggestionsSubject.next(res);
|
|
58
|
+
this.isLoading = false;
|
|
59
|
+
}, () => {
|
|
60
|
+
this.isLoading = false;
|
|
62
61
|
});
|
|
63
62
|
}
|
|
64
63
|
}
|
|
@@ -82,9 +81,6 @@ export class MngAutocompleteComponent {
|
|
|
82
81
|
}
|
|
83
82
|
writeValue(obj) {
|
|
84
83
|
this.autocompleteFormControl.setValue(obj, { emitEvent: false });
|
|
85
|
-
if (this.primeAutocomplete) {
|
|
86
|
-
this.primeAutocomplete.writeValue(obj);
|
|
87
|
-
}
|
|
88
84
|
}
|
|
89
85
|
}
|
|
90
86
|
MngAutocompleteComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngAutocompleteComponent, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
|
|
@@ -113,4 +109,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImpor
|
|
|
113
109
|
type: ViewChild,
|
|
114
110
|
args: [AutoComplete]
|
|
115
111
|
}] } });
|
|
116
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/form/autocomplete/autocomplete.component.ts","../../../../../../src/lib/components/form/autocomplete/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, EventEmitter, ExistingProvider, Injector, Input, OnInit, Output, ViewChild, forwardRef} from '@angular/core';\nimport {ControlValueAccessor, FormControl, NG_VALUE_ACCESSOR} from '@angular/forms';\n\nimport {AutoComplete} from 'primeng/autocomplete';\nimport {Observable, Subject, Subscription} from 'rxjs';\nimport {finalize, first} from 'rxjs/operators';\n\nimport {MediusFilterMatchType, MediusQueryParamBuilder} from '../../../api/models';\nimport {ILookupDataProvider} from '../../../data-providers';\n\nexport const MNG_AUTOCOMPLETE_VALUE_ACCESSOR: ExistingProvider = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => MngAutocompleteComponent),\n    multi: true\n};\n\n@Component({\n    selector: 'mng-autocomplete',\n    templateUrl: './autocomplete.component.html',\n    providers: [MNG_AUTOCOMPLETE_VALUE_ACCESSOR],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngAutocompleteComponent implements OnInit, ControlValueAccessor {\n    @Input() public dataProvider?: ILookupDataProvider<any, any>;\n    @Input() public dataKeyProperty?: string;\n    @Input() public itemsLabelProperty?: string;\n    @Input() public multiselect = false;\n    @Input() public placeholder?: string;\n    @Input() public className: string | null = null;\n    @Input() public dropdownClassName: string | null = null;\n\n    @Output('valueChange') public valueChangeEventEmitter = new EventEmitter();\n\n    @ViewChild(AutoComplete) public primeAutocomplete?: AutoComplete;\n\n    private suggestionsSubject: Subject<Array<any>> = new Subject<Array<any>>();\n    private searchSubscription: Subscription | null = null;\n    private dataProviderService: any = null;\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onChangeFn: any = () => {};\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onTouchedFn: any = () => {};\n\n    public autocompleteFormControl: FormControl = new FormControl();\n    public suggestions$: Observable<Array<any>> = this.suggestionsSubject.asObservable();\n    public isLoading = false;\n\n    constructor(private injector: Injector) {}\n\n    ngOnInit() {\n        if (this.dataProvider) {\n            this.dataProviderService = this.dataProvider.serviceType ? this.injector.get<any>(this.dataProvider.serviceType) : null;\n        } else {\n            console.warn(`Data provider should be provided for MngAutocompleteComponent.`);\n        }\n    }\n\n    onSearch(event: any) {\n        if (this.searchSubscription) {\n            // try to cancel existing HTTP request subscription\n            this.searchSubscription.unsubscribe();\n        }\n\n        if (this.dataProvider) {\n            this.isLoading = true;\n            const queryParamBuilder = MediusQueryParamBuilder.create();\n            if (this.itemsLabelProperty) {\n                queryParamBuilder.withSort(this.itemsLabelProperty);\n            }\n            if (event.query && event.query.length > 0 && this.itemsLabelProperty) {\n                queryParamBuilder.withFilter(this.itemsLabelProperty, event.query, undefined, MediusFilterMatchType.StartsWith);\n            }\n            this.searchSubscription = this.dataProvider\n                .lookup(queryParamBuilder.build(), this.dataProviderService, event.query)\n                .pipe(\n                    first(),\n                    finalize(() => (this.isLoading = false))\n                )\n                .subscribe((res: any) => {\n                    this.suggestionsSubject.next(res);\n                });\n        }\n    }\n\n    onSelect(value: any) {\n        this.onChangeFn(value);\n        this.valueChangeEventEmitter.next(value);\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChangeFn = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouchedFn = fn;\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        if (isDisabled) {\n            this.autocompleteFormControl.disable();\n        } else {\n            this.autocompleteFormControl.enable();\n        }\n    }\n\n    writeValue(obj: any): void {\n        this.autocompleteFormControl.setValue(obj, {emitEvent: false});\n        if (this.primeAutocomplete) {\n            this.primeAutocomplete.writeValue(obj);\n        }\n    }\n}\n","<p-autoComplete\n    [formControl]=\"autocompleteFormControl\"\n    [placeholder]=\"$any(placeholder)\"\n    [dropdown]=\"true\"\n    [dataKey]=\"$any(dataKeyProperty)\"\n    [field]=\"$any(itemsLabelProperty)\"\n    [suggestions]=\"(suggestions$ | async) ?? []\"\n    [multiple]=\"multiselect\"\n    [showEmptyMessage]=\"true\"\n    [emptyMessage]=\"'mngAutocomplete.noMatches' | translate\"\n    [styleClass]=\"$any(className)\"\n    [panelStyleClass]=\"$any(dropdownClassName)\"\n    (completeMethod)=\"onSearch($event)\"\n    (onSelect)=\"onSelect($event)\"\n    appendTo=\"body\"\n    dropdownMode=\"current\">\n</p-autoComplete>\n"]}
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/form/autocomplete/autocomplete.component.ts","../../../../../../src/lib/components/form/autocomplete/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, EventEmitter, ExistingProvider, Injector, Input, OnDestroy, OnInit, Output, ViewChild, forwardRef} from '@angular/core';\nimport {ControlValueAccessor, FormControl, NG_VALUE_ACCESSOR} from '@angular/forms';\n\nimport {AutoComplete} from 'primeng/autocomplete';\nimport {Observable, Subject, Subscription} from 'rxjs';\n\nimport {MediusFilterMatchType, MediusQueryParamBuilder} from '../../../api/models';\nimport {ILookupDataProvider} from '../../../data-providers';\n\nexport const MNG_AUTOCOMPLETE_VALUE_ACCESSOR: ExistingProvider = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => MngAutocompleteComponent),\n    multi: true\n};\n\n@Component({\n    selector: 'mng-autocomplete',\n    templateUrl: './autocomplete.component.html',\n    providers: [MNG_AUTOCOMPLETE_VALUE_ACCESSOR],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngAutocompleteComponent implements OnInit, OnDestroy, ControlValueAccessor {\n    @Input() public dataProvider?: ILookupDataProvider<any, any>;\n    @Input() public dataKeyProperty?: string;\n    @Input() public itemsLabelProperty?: string;\n    @Input() public multiselect = false;\n    @Input() public placeholder?: string;\n    @Input() public className: string | null = null;\n    @Input() public dropdownClassName: string | null = null;\n\n    @Output('valueChange') public valueChangeEventEmitter = new EventEmitter();\n\n    @ViewChild(AutoComplete) public primeAutocomplete?: AutoComplete;\n\n    private suggestionsSubject: Subject<Array<any>> = new Subject<Array<any>>();\n    private searchSubscription: Subscription | null = null;\n    private dataProviderService: any = null;\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onChangeFn: any = () => {};\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onTouchedFn: any = () => {};\n\n    public autocompleteFormControl: FormControl = new FormControl();\n    public suggestions$: Observable<Array<any>> = this.suggestionsSubject.asObservable();\n    public isLoading = false;\n\n    constructor(private injector: Injector) {}\n\n    ngOnInit() {\n        if (this.dataProvider) {\n            this.dataProviderService = this.dataProvider.serviceType ? this.injector.get<any>(this.dataProvider.serviceType) : null;\n        } else {\n            console.warn(`Data provider should be provided for MngAutocompleteComponent.`);\n        }\n    }\n\n    ngOnDestroy() {\n        this.searchSubscription?.unsubscribe();\n    }\n\n    onSearch(event: any) {\n        this.searchSubscription?.unsubscribe();\n\n        if (this.dataProvider) {\n            this.isLoading = true;\n            const queryParamBuilder = MediusQueryParamBuilder.create();\n            if (this.itemsLabelProperty) {\n                queryParamBuilder.withSort(this.itemsLabelProperty);\n            }\n            if (event.query && event.query.length > 0 && this.itemsLabelProperty) {\n                queryParamBuilder.withFilter(this.itemsLabelProperty, event.query, undefined, MediusFilterMatchType.StartsWith);\n            }\n            this.searchSubscription = this.dataProvider.lookup(queryParamBuilder.build(), this.dataProviderService, event.query).subscribe(\n                (res: any) => {\n                    this.suggestionsSubject.next(res);\n                    this.isLoading = false;\n                },\n                () => {\n                    this.isLoading = false;\n                }\n            );\n        }\n    }\n\n    onSelect(value: any) {\n        this.onChangeFn(value);\n        this.valueChangeEventEmitter.next(value);\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChangeFn = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouchedFn = fn;\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        if (isDisabled) {\n            this.autocompleteFormControl.disable();\n        } else {\n            this.autocompleteFormControl.enable();\n        }\n    }\n\n    writeValue(obj: any): void {\n        this.autocompleteFormControl.setValue(obj, {emitEvent: false});\n    }\n}\n","<p-autoComplete\n    [formControl]=\"autocompleteFormControl\"\n    [placeholder]=\"$any(placeholder)\"\n    [dropdown]=\"true\"\n    [dataKey]=\"$any(dataKeyProperty)\"\n    [field]=\"$any(itemsLabelProperty)\"\n    [suggestions]=\"(suggestions$ | async) ?? []\"\n    [multiple]=\"multiselect\"\n    [showEmptyMessage]=\"true\"\n    [emptyMessage]=\"'mngAutocomplete.noMatches' | translate\"\n    [styleClass]=\"$any(className)\"\n    [panelStyleClass]=\"$any(dropdownClassName)\"\n    (completeMethod)=\"onSearch($event)\"\n    (onSelect)=\"onSelect($event)\"\n    appendTo=\"body\"\n    dropdownMode=\"current\">\n</p-autoComplete>\n"]}
|
|
@@ -19,6 +19,7 @@ export class MngDropdownComponent {
|
|
|
19
19
|
this.injector = injector;
|
|
20
20
|
this.multiselect = false;
|
|
21
21
|
this.showClear = true;
|
|
22
|
+
this.selectFirstItem = false;
|
|
22
23
|
this.className = null;
|
|
23
24
|
this.dropdownClassName = null;
|
|
24
25
|
this.valueChangeEventEmitter = new EventEmitter();
|
|
@@ -39,20 +40,13 @@ export class MngDropdownComponent {
|
|
|
39
40
|
if (this.dataProvider) {
|
|
40
41
|
this.dataProviderService = this.dataProvider.serviceType ? this.injector.get(this.dataProvider.serviceType) : null;
|
|
41
42
|
const queryParamBuilder = MediusQueryParamBuilder.create();
|
|
42
|
-
this.dataProvider
|
|
43
|
-
.lookup(queryParamBuilder.build(), this.dataProviderService)
|
|
44
|
-
.pipe(first())
|
|
45
|
-
.subscribe(res => {
|
|
43
|
+
this.itemsSubscription = this.dataProvider.lookup(queryParamBuilder.build(), this.dataProviderService).subscribe(res => {
|
|
46
44
|
this.itemsSubject.next(res);
|
|
47
45
|
});
|
|
48
|
-
if (!this.dropdownFormControl?.value) {
|
|
46
|
+
if (this.selectFirstItem && !this.dropdownFormControl?.value) {
|
|
49
47
|
this.items$.pipe(first()).subscribe(res => {
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
const value = this.itemsValueProperty ? res[0][this.itemsValueProperty] : res[0];
|
|
53
|
-
this.dropdownFormControl?.patchValue(value);
|
|
54
|
-
console.log('patched dropdown form value with', value);
|
|
55
|
-
}
|
|
48
|
+
const value = this.itemsValueProperty ? res[0][this.itemsValueProperty] : res[0];
|
|
49
|
+
this.dropdownFormControl?.setValue(value);
|
|
56
50
|
});
|
|
57
51
|
}
|
|
58
52
|
}
|
|
@@ -60,6 +54,9 @@ export class MngDropdownComponent {
|
|
|
60
54
|
console.warn(`Data provider should be provided for MngDropdownComponent.`);
|
|
61
55
|
}
|
|
62
56
|
}
|
|
57
|
+
ngOnDestroy() {
|
|
58
|
+
this.itemsSubscription?.unsubscribe();
|
|
59
|
+
}
|
|
63
60
|
registerOnChange(fn) {
|
|
64
61
|
this.onChangeFn = fn;
|
|
65
62
|
}
|
|
@@ -76,14 +73,13 @@ export class MngDropdownComponent {
|
|
|
76
73
|
}
|
|
77
74
|
writeValue(obj) {
|
|
78
75
|
this.dropdownFormControl.setValue(obj, { emitEvent: false });
|
|
79
|
-
this.primeDropdown?.writeValue(obj);
|
|
80
76
|
}
|
|
81
77
|
}
|
|
82
78
|
MngDropdownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngDropdownComponent, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
|
|
83
|
-
MngDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngDropdownComponent, selector: "mng-dropdown", inputs: { dataProvider: "dataProvider", dataKeyProperty: "dataKeyProperty", itemsLabelProperty: "itemsLabelProperty", itemsValueProperty: "itemsValueProperty", multiselect: "multiselect", placeholder: "placeholder", showClear: "showClear", className: "className", dropdownClassName: "dropdownClassName" }, outputs: { valueChangeEventEmitter: "valueChange" }, providers: [MNG_DROPDOWN_VALUE_ACCESSOR], viewQueries: [{ propertyName: "primeDropdown", first: true, predicate: Dropdown, descendants: true }], ngImport: i0, template: "<p-dropdown\n *ngIf=\"!multiselect; else pMultiselect\"\n [formControl]=\"dropdownFormControl\"\n [placeholder]=\"$any(placeholder)\"\n [dataKey]=\"$any(dataKeyProperty)\"\n [optionLabel]=\"$any(itemsLabelProperty)\"\n [optionValue]=\"$any(itemsValueProperty)\"\n [options]=\"(items$ | async)
|
|
79
|
+
MngDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngDropdownComponent, selector: "mng-dropdown", inputs: { dataProvider: "dataProvider", dataKeyProperty: "dataKeyProperty", itemsLabelProperty: "itemsLabelProperty", itemsValueProperty: "itemsValueProperty", multiselect: "multiselect", placeholder: "placeholder", showClear: "showClear", selectFirstItem: "selectFirstItem", className: "className", dropdownClassName: "dropdownClassName" }, outputs: { valueChangeEventEmitter: "valueChange" }, providers: [MNG_DROPDOWN_VALUE_ACCESSOR], viewQueries: [{ propertyName: "primeDropdown", first: true, predicate: Dropdown, descendants: true }], ngImport: i0, template: "<p-dropdown\n *ngIf=\"!multiselect; else pMultiselect\"\n [formControl]=\"dropdownFormControl\"\n [placeholder]=\"$any(placeholder)\"\n [dataKey]=\"$any(dataKeyProperty)\"\n [optionLabel]=\"$any(itemsLabelProperty)\"\n [optionValue]=\"$any(itemsValueProperty)\"\n [options]=\"$any(items$ | async)\"\n [showClear]=\"showClear\"\n [autoDisplayFirst]=\"false\"\n [styleClass]=\"$any(className)\"\n [panelStyleClass]=\"$any(dropdownClassName)\"\n appendTo=\"body\">\n</p-dropdown>\n<ng-template #pMultiselect>\n <p-multiSelect\n display=\"chip\"\n [formControl]=\"dropdownFormControl\"\n [defaultLabel]=\"$any(placeholder)\"\n [dataKey]=\"$any(dataKeyProperty)\"\n [optionLabel]=\"$any(itemsLabelProperty)\"\n [optionValue]=\"$any(itemsValueProperty)\"\n [options]=\"(items$ | async) ?? []\"\n [styleClass]=\"$any(className)\"\n [panelStyleClass]=\"$any(dropdownClassName)\"\n [filter]=\"false\"\n appendTo=\"body\">\n </p-multiSelect>\n</ng-template>\n", components: [{ type: i1.Dropdown, selector: "p-dropdown", inputs: ["scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "filterPlaceholder", "filterLocale", "inputId", "selectId", "dataKey", "filterBy", "autofocus", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "virtualScroll", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "ariaFilterLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "disabled", "options", "filterValue"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear"] }, { type: i2.MultiSelect, selector: "p-multiSelect", inputs: ["style", "styleClass", "panelStyle", "panelStyleClass", "inputId", "disabled", "readonly", "group", "filter", "filterPlaceHolder", "filterLocale", "overlayVisible", "tabindex", "appendTo", "dataKey", "name", "ariaLabelledBy", "displaySelectedLabel", "maxSelectedLabels", "selectionLimit", "selectedItemsLabel", "showToggleAll", "emptyFilterMessage", "emptyMessage", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "showHeader", "autoZIndex", "baseZIndex", "filterBy", "virtualScroll", "itemSize", "showTransitionOptions", "hideTransitionOptions", "ariaFilterLabel", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "display", "scrollHeight", "defaultLabel", "placeholder", "options", "filterValue"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onPanelShow", "onPanelHide"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }], pipes: { "async": i3.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
84
80
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngDropdownComponent, decorators: [{
|
|
85
81
|
type: Component,
|
|
86
|
-
args: [{ selector: 'mng-dropdown', providers: [MNG_DROPDOWN_VALUE_ACCESSOR], changeDetection: ChangeDetectionStrategy.OnPush, template: "<p-dropdown\n *ngIf=\"!multiselect; else pMultiselect\"\n [formControl]=\"dropdownFormControl\"\n [placeholder]=\"$any(placeholder)\"\n [dataKey]=\"$any(dataKeyProperty)\"\n [optionLabel]=\"$any(itemsLabelProperty)\"\n [optionValue]=\"$any(itemsValueProperty)\"\n [options]=\"(items$ | async)
|
|
82
|
+
args: [{ selector: 'mng-dropdown', providers: [MNG_DROPDOWN_VALUE_ACCESSOR], changeDetection: ChangeDetectionStrategy.OnPush, template: "<p-dropdown\n *ngIf=\"!multiselect; else pMultiselect\"\n [formControl]=\"dropdownFormControl\"\n [placeholder]=\"$any(placeholder)\"\n [dataKey]=\"$any(dataKeyProperty)\"\n [optionLabel]=\"$any(itemsLabelProperty)\"\n [optionValue]=\"$any(itemsValueProperty)\"\n [options]=\"$any(items$ | async)\"\n [showClear]=\"showClear\"\n [autoDisplayFirst]=\"false\"\n [styleClass]=\"$any(className)\"\n [panelStyleClass]=\"$any(dropdownClassName)\"\n appendTo=\"body\">\n</p-dropdown>\n<ng-template #pMultiselect>\n <p-multiSelect\n display=\"chip\"\n [formControl]=\"dropdownFormControl\"\n [defaultLabel]=\"$any(placeholder)\"\n [dataKey]=\"$any(dataKeyProperty)\"\n [optionLabel]=\"$any(itemsLabelProperty)\"\n [optionValue]=\"$any(itemsValueProperty)\"\n [options]=\"(items$ | async) ?? []\"\n [styleClass]=\"$any(className)\"\n [panelStyleClass]=\"$any(dropdownClassName)\"\n [filter]=\"false\"\n appendTo=\"body\">\n </p-multiSelect>\n</ng-template>\n" }]
|
|
87
83
|
}], ctorParameters: function () { return [{ type: i0.Injector }]; }, propDecorators: { dataProvider: [{
|
|
88
84
|
type: Input
|
|
89
85
|
}], dataKeyProperty: [{
|
|
@@ -98,6 +94,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImpor
|
|
|
98
94
|
type: Input
|
|
99
95
|
}], showClear: [{
|
|
100
96
|
type: Input
|
|
97
|
+
}], selectFirstItem: [{
|
|
98
|
+
type: Input
|
|
101
99
|
}], className: [{
|
|
102
100
|
type: Input
|
|
103
101
|
}], dropdownClassName: [{
|
|
@@ -109,4 +107,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImpor
|
|
|
109
107
|
type: ViewChild,
|
|
110
108
|
args: [Dropdown]
|
|
111
109
|
}] } });
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/form/dropdown/dropdown.component.ts","../../../../../../src/lib/components/form/dropdown/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, EventEmitter, ExistingProvider, Injector, Input, OnInit, Output, ViewChild, forwardRef} from '@angular/core';\nimport {ControlValueAccessor, FormControl, NG_VALUE_ACCESSOR} from '@angular/forms';\n\nimport {Dropdown} from 'primeng/dropdown';\nimport {Observable, ReplaySubject, Subject} from 'rxjs';\nimport {first} from 'rxjs/operators';\n\nimport {MediusQueryParamBuilder} from '../../../api/models';\nimport {ILookupDataProvider} from '../../../data-providers';\n\nexport const MNG_DROPDOWN_VALUE_ACCESSOR: ExistingProvider = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => MngDropdownComponent),\n    multi: true\n};\n\n@Component({\n    selector: 'mng-dropdown',\n    templateUrl: './dropdown.component.html',\n    providers: [MNG_DROPDOWN_VALUE_ACCESSOR],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngDropdownComponent implements OnInit, ControlValueAccessor {\n    @Input() public dataProvider?: ILookupDataProvider<any, any>;\n    @Input() public dataKeyProperty?: string;\n    @Input() public itemsLabelProperty?: string;\n    @Input() public itemsValueProperty?: string;\n    @Input() public multiselect = false;\n    @Input() public placeholder?: string;\n    @Input() public showClear = true;\n    @Input() public className: string | null = null;\n    @Input() public dropdownClassName: string | null = null;\n\n    @Output('valueChange') public valueChangeEventEmitter = new EventEmitter();\n\n    @ViewChild(Dropdown) public primeDropdown?: Dropdown;\n\n    private itemsSubject: Subject<Array<any>> = new ReplaySubject<Array<any>>(1);\n    private dataProviderService: any = null;\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onChangeFn: any = () => {};\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onTouchedFn: any = () => {};\n\n    public dropdownFormControl: FormControl = new FormControl();\n    public items$: Observable<Array<any>> = this.itemsSubject.asObservable();\n\n    constructor(private injector: Injector) {}\n\n    ngOnInit(): void {\n        this.dropdownFormControl.valueChanges.subscribe(v => {\n            this.onChangeFn(v);\n            this.valueChangeEventEmitter.next(v);\n        });\n\n        if (this.dataProvider) {\n            this.dataProviderService = this.dataProvider.serviceType ? this.injector.get<any>(this.dataProvider.serviceType) : null;\n\n            const queryParamBuilder = MediusQueryParamBuilder.create();\n            this.dataProvider\n                .lookup(queryParamBuilder.build(), this.dataProviderService)\n                .pipe(first())\n                .subscribe(res => {\n                    this.itemsSubject.next(res);\n                });\n\n            if (!this.dropdownFormControl?.value) {\n                this.items$.pipe(first()).subscribe(res => {\n                    // TODO: check if really only way\n                    if (res.length === 1) {\n                        const value = this.itemsValueProperty ? res[0][this.itemsValueProperty] : res[0];\n                        this.dropdownFormControl?.patchValue(value);\n                        console.log('patched dropdown form value with', value);\n                    }\n                });\n            }\n        } else {\n            console.warn(`Data provider should be provided for MngDropdownComponent.`);\n        }\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChangeFn = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouchedFn = fn;\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        if (isDisabled) {\n            this.dropdownFormControl.disable();\n        } else {\n            this.dropdownFormControl.enable();\n        }\n    }\n\n    writeValue(obj: any): void {\n        this.dropdownFormControl.setValue(obj, {emitEvent: false});\n        this.primeDropdown?.writeValue(obj);\n    }\n}\n","<p-dropdown\n    *ngIf=\"!multiselect; else pMultiselect\"\n    [formControl]=\"dropdownFormControl\"\n    [placeholder]=\"$any(placeholder)\"\n    [dataKey]=\"$any(dataKeyProperty)\"\n    [optionLabel]=\"$any(itemsLabelProperty)\"\n    [optionValue]=\"$any(itemsValueProperty)\"\n    [options]=\"(items$ | async) ?? []\"\n    [showClear]=\"showClear\"\n    [autoDisplayFirst]=\"false\"\n    [styleClass]=\"$any(className)\"\n    [panelStyleClass]=\"$any(dropdownClassName)\"\n    appendTo=\"body\">\n</p-dropdown>\n<ng-template #pMultiselect>\n    <p-multiSelect\n        display=\"chip\"\n        [formControl]=\"dropdownFormControl\"\n        [defaultLabel]=\"$any(placeholder)\"\n        [dataKey]=\"$any(dataKeyProperty)\"\n        [optionLabel]=\"$any(itemsLabelProperty)\"\n        [optionValue]=\"$any(itemsValueProperty)\"\n        [options]=\"(items$ | async) ?? []\"\n        [styleClass]=\"$any(className)\"\n        [panelStyleClass]=\"$any(dropdownClassName)\"\n        [filter]=\"false\"\n        appendTo=\"body\">\n    </p-multiSelect>\n</ng-template>\n"]}
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/form/dropdown/dropdown.component.ts","../../../../../../src/lib/components/form/dropdown/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, EventEmitter, ExistingProvider, Injector, Input, OnDestroy, OnInit, Output, ViewChild, forwardRef} from '@angular/core';\nimport {ControlValueAccessor, FormControl, NG_VALUE_ACCESSOR} from '@angular/forms';\n\nimport {Dropdown} from 'primeng/dropdown';\nimport {Observable, ReplaySubject, Subject, Subscription} from 'rxjs';\nimport {first} from 'rxjs/operators';\n\nimport {MediusQueryParamBuilder} from '../../../api/models';\nimport {ILookupDataProvider} from '../../../data-providers';\n\nexport const MNG_DROPDOWN_VALUE_ACCESSOR: ExistingProvider = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => MngDropdownComponent),\n    multi: true\n};\n\n@Component({\n    selector: 'mng-dropdown',\n    templateUrl: './dropdown.component.html',\n    providers: [MNG_DROPDOWN_VALUE_ACCESSOR],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngDropdownComponent implements OnInit, OnDestroy, ControlValueAccessor {\n    @Input() public dataProvider?: ILookupDataProvider<any, any>;\n    @Input() public dataKeyProperty?: string;\n    @Input() public itemsLabelProperty?: string;\n    @Input() public itemsValueProperty?: string;\n    @Input() public multiselect = false;\n    @Input() public placeholder?: string;\n    @Input() public showClear = true;\n    @Input() public selectFirstItem = false;\n    @Input() public className: string | null = null;\n    @Input() public dropdownClassName: string | null = null;\n\n    @Output('valueChange') public valueChangeEventEmitter = new EventEmitter();\n\n    @ViewChild(Dropdown) public primeDropdown?: Dropdown;\n\n    private itemsSubject: Subject<Array<any>> = new ReplaySubject<Array<any>>(1);\n    private dataProviderService: any = null;\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onChangeFn: any = () => {};\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onTouchedFn: any = () => {};\n\n    public dropdownFormControl: FormControl = new FormControl();\n    public items$: Observable<Array<any>> = this.itemsSubject.asObservable();\n    private itemsSubscription?: Subscription;\n\n    constructor(private injector: Injector) {}\n\n    ngOnInit(): void {\n        this.dropdownFormControl.valueChanges.subscribe(v => {\n            this.onChangeFn(v);\n            this.valueChangeEventEmitter.next(v);\n        });\n\n        if (this.dataProvider) {\n            this.dataProviderService = this.dataProvider.serviceType ? this.injector.get<any>(this.dataProvider.serviceType) : null;\n\n            const queryParamBuilder = MediusQueryParamBuilder.create();\n            this.itemsSubscription = this.dataProvider.lookup(queryParamBuilder.build(), this.dataProviderService).subscribe(res => {\n                this.itemsSubject.next(res);\n            });\n\n            if (this.selectFirstItem && !this.dropdownFormControl?.value) {\n                this.items$.pipe(first()).subscribe(res => {\n                    const value = this.itemsValueProperty ? res[0][this.itemsValueProperty] : res[0];\n                    this.dropdownFormControl?.setValue(value);\n                });\n            }\n        } else {\n            console.warn(`Data provider should be provided for MngDropdownComponent.`);\n        }\n    }\n\n    ngOnDestroy() {\n        this.itemsSubscription?.unsubscribe();\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChangeFn = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouchedFn = fn;\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        if (isDisabled) {\n            this.dropdownFormControl.disable();\n        } else {\n            this.dropdownFormControl.enable();\n        }\n    }\n\n    writeValue(obj: any): void {\n        this.dropdownFormControl.setValue(obj, {emitEvent: false});\n    }\n}\n","<p-dropdown\n    *ngIf=\"!multiselect; else pMultiselect\"\n    [formControl]=\"dropdownFormControl\"\n    [placeholder]=\"$any(placeholder)\"\n    [dataKey]=\"$any(dataKeyProperty)\"\n    [optionLabel]=\"$any(itemsLabelProperty)\"\n    [optionValue]=\"$any(itemsValueProperty)\"\n    [options]=\"$any(items$ | async)\"\n    [showClear]=\"showClear\"\n    [autoDisplayFirst]=\"false\"\n    [styleClass]=\"$any(className)\"\n    [panelStyleClass]=\"$any(dropdownClassName)\"\n    appendTo=\"body\">\n</p-dropdown>\n<ng-template #pMultiselect>\n    <p-multiSelect\n        display=\"chip\"\n        [formControl]=\"dropdownFormControl\"\n        [defaultLabel]=\"$any(placeholder)\"\n        [dataKey]=\"$any(dataKeyProperty)\"\n        [optionLabel]=\"$any(itemsLabelProperty)\"\n        [optionValue]=\"$any(itemsValueProperty)\"\n        [options]=\"(items$ | async) ?? []\"\n        [styleClass]=\"$any(className)\"\n        [panelStyleClass]=\"$any(dropdownClassName)\"\n        [filter]=\"false\"\n        appendTo=\"body\">\n    </p-multiSelect>\n</ng-template>\n"]}
|
|
@@ -11,9 +11,9 @@ export class MngFormlyFieldDropdownComponent extends FieldType {
|
|
|
11
11
|
}
|
|
12
12
|
}
|
|
13
13
|
MngFormlyFieldDropdownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngFormlyFieldDropdownComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
14
|
-
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 [
|
|
14
|
+
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 [dataKeyProperty]=\"$any(descriptor.dataKeyProperty)\"\n [showClear]=\"!this.to.required\">\n</mng-dropdown>\n", components: [{ type: i1.MngDropdownComponent, selector: "mng-dropdown", inputs: ["dataProvider", "dataKeyProperty", "itemsLabelProperty", "itemsValueProperty", "multiselect", "placeholder", "showClear", "selectFirstItem", "className", "dropdownClassName"], outputs: ["valueChange"] }], directives: [{ type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i3.ɵFormlyAttributes, selector: "[formlyAttributes]", inputs: ["formlyAttributes", "id"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
15
15
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngFormlyFieldDropdownComponent, decorators: [{
|
|
16
16
|
type: Component,
|
|
17
|
-
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 [
|
|
17
|
+
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 [dataKeyProperty]=\"$any(descriptor.dataKeyProperty)\"\n [showClear]=\"!this.to.required\">\n</mng-dropdown>\n" }]
|
|
18
18
|
}] });
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybWx5LWZpZWxkLWRyb3Bkb3duLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9mb3JtL2Zvcm1seS9maWVsZHMvZm9ybWx5LWZpZWxkLWRyb3Bkb3duL2Zvcm1seS1maWVsZC1kcm9wZG93bi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9mb3JtbHkvZmllbGRzL2Zvcm1seS1maWVsZC1kcm9wZG93bi9mb3JtbHktZmllbGQtZHJvcGRvd24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLHVCQUF1QixFQUFFLFNBQVMsRUFBUyxNQUFNLGVBQWUsQ0FBQztBQUd6RSxPQUFPLEVBQUMsU0FBUyxFQUFDLE1BQU0sa0JBQWtCLENBQUM7Ozs7O0FBUzNDLE1BQU0sT0FBTywrQkFBbUMsU0FBUSxTQUFTO0lBSXRELFFBQVE7UUFDWCxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxXQUEwQixDQUFDO1FBQ3BELElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLEVBQUUsQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUM1QyxDQUFDOzs0SEFQUSwrQkFBK0I7Z0hBQS9CLCtCQUErQix3RkNaNUMsNGNBV0E7MkZEQ2EsK0JBQStCO2tCQUwzQyxTQUFTOytCQUNJLDJCQUEyQixtQkFFcEIsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgT25Jbml0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7Rm9ybUNvbnRyb2x9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuaW1wb3J0IHtGaWVsZFR5cGV9IGZyb20gJ0BuZ3gtZm9ybWx5L2NvcmUnO1xuXG5pbXBvcnQge0ZpZWxkTG9va3VwRGVzY3JpcHRvcn0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vZGVzY3JpcHRvcnMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ21uZy1mb3JtbHktZmllbGQtZHJvcGRvd24nLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9mb3JtbHktZmllbGQtZHJvcGRvd24uY29tcG9uZW50Lmh0bWwnLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIE1uZ0Zvcm1seUZpZWxkRHJvcGRvd25Db21wb25lbnQ8VD4gZXh0ZW5kcyBGaWVsZFR5cGUgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIHB1YmxpYyBkRm9ybUNvbnRyb2whOiBGb3JtQ29udHJvbDtcbiAgICBwdWJsaWMgZGVzY3JpcHRvciE6IEZpZWxkTG9va3VwRGVzY3JpcHRvcjxULCBhbnk+
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybWx5LWZpZWxkLWRyb3Bkb3duLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9mb3JtL2Zvcm1seS9maWVsZHMvZm9ybWx5LWZpZWxkLWRyb3Bkb3duL2Zvcm1seS1maWVsZC1kcm9wZG93bi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9mb3JtbHkvZmllbGRzL2Zvcm1seS1maWVsZC1kcm9wZG93bi9mb3JtbHktZmllbGQtZHJvcGRvd24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLHVCQUF1QixFQUFFLFNBQVMsRUFBUyxNQUFNLGVBQWUsQ0FBQztBQUd6RSxPQUFPLEVBQUMsU0FBUyxFQUFDLE1BQU0sa0JBQWtCLENBQUM7Ozs7O0FBUzNDLE1BQU0sT0FBTywrQkFBbUMsU0FBUSxTQUFTO0lBSXRELFFBQVE7UUFDWCxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxXQUEwQixDQUFDO1FBQ3BELElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLEVBQUUsQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUM1QyxDQUFDOzs0SEFQUSwrQkFBK0I7Z0hBQS9CLCtCQUErQix3RkNaNUMsNGNBV0E7MkZEQ2EsK0JBQStCO2tCQUwzQyxTQUFTOytCQUNJLDJCQUEyQixtQkFFcEIsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgT25Jbml0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7Rm9ybUNvbnRyb2x9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuaW1wb3J0IHtGaWVsZFR5cGV9IGZyb20gJ0BuZ3gtZm9ybWx5L2NvcmUnO1xuXG5pbXBvcnQge0ZpZWxkTG9va3VwRGVzY3JpcHRvcn0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vZGVzY3JpcHRvcnMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ21uZy1mb3JtbHktZmllbGQtZHJvcGRvd24nLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9mb3JtbHktZmllbGQtZHJvcGRvd24uY29tcG9uZW50Lmh0bWwnLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIE1uZ0Zvcm1seUZpZWxkRHJvcGRvd25Db21wb25lbnQ8VD4gZXh0ZW5kcyBGaWVsZFR5cGUgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIHB1YmxpYyBkRm9ybUNvbnRyb2whOiBGb3JtQ29udHJvbDtcbiAgICBwdWJsaWMgZGVzY3JpcHRvciE6IEZpZWxkTG9va3VwRGVzY3JpcHRvcjxULCBhbnk+O1xuXG4gICAgcHVibGljIG5nT25Jbml0KCkge1xuICAgICAgICB0aGlzLmRGb3JtQ29udHJvbCA9IHRoaXMuZm9ybUNvbnRyb2wgYXMgRm9ybUNvbnRyb2w7XG4gICAgICAgIHRoaXMuZGVzY3JpcHRvciA9IHRoaXMudG9bJ2Rlc2NyaXB0b3InXTtcbiAgICB9XG59XG4iLCI8bW5nLWRyb3Bkb3duXG4gICAgW2lkXT1cIiRhbnkoa2V5KVwiXG4gICAgW2Zvcm1Db250cm9sXT1cImRGb3JtQ29udHJvbFwiXG4gICAgW2Zvcm1seUF0dHJpYnV0ZXNdPVwiZmllbGRcIlxuICAgIFtwbGFjZWhvbGRlcl09XCIkYW55KGRlc2NyaXB0b3IucGxhY2Vob2xkZXIpXCJcbiAgICBbZGF0YVByb3ZpZGVyXT1cImRlc2NyaXB0b3IuZGF0YVByb3ZpZGVyXCJcbiAgICBbaXRlbXNMYWJlbFByb3BlcnR5XT1cIiRhbnkoZGVzY3JpcHRvci5pdGVtc0xhYmVsUHJvcGVydHkpXCJcbiAgICBbaXRlbXNWYWx1ZVByb3BlcnR5XT1cIiRhbnkoZGVzY3JpcHRvci5pdGVtc1ZhbHVlUHJvcGVydHkpXCJcbiAgICBbZGF0YUtleVByb3BlcnR5XT1cIiRhbnkoZGVzY3JpcHRvci5kYXRhS2V5UHJvcGVydHkpXCJcbiAgICBbc2hvd0NsZWFyXT1cIiF0aGlzLnRvLnJlcXVpcmVkXCI+XG48L21uZy1kcm9wZG93bj5cbiJdfQ==
|