@mediusinc/mng-commons-data-api 6.0.0-rc.5 → 6.0.0-rc.6

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.
@@ -1,6 +1,6 @@
1
1
  {{>licenseInfo}}
2
2
 
3
- /* eslint-disable @typescript-eslint/no-explicit-any, @typescript-eslint/ban-types */
3
+ /* eslint-disable @typescript-eslint/no-explicit-any, @typescript-eslint/no-empty-object-type */
4
4
 
5
5
  import {Injectable} from '@angular/core';
6
6
  import {HttpParams, HttpResponse} from '@angular/common/http';
@@ -1,6 +1,6 @@
1
1
  {{>licenseInfo}}
2
2
 
3
- /* eslint-disable @typescript-eslint/no-explicit-any, @typescript-eslint/ban-types */
3
+ /* eslint-disable @typescript-eslint/no-explicit-any, @typescript-eslint/no-empty-object-type */
4
4
 
5
5
  import { Observable } from 'rxjs';
6
6
 
@@ -105,8 +105,7 @@ export class {{configurationClassName}} {
105
105
  * @return True if the given MIME is JSON, false otherwise.
106
106
  */
107
107
  public isJsonMime(mime: string): boolean {
108
- // eslint-disable-next-line no-control-regex
109
- const jsonMime = new RegExp('^(application\/json|[^;/ \t]+\/[^;/ \t]+[+]json)[ \t]*(;.*)?$', 'i');
108
+ const jsonMime = new RegExp('^(application/json|[^;/\\s]+/[^;/\\s]+[+]json)\\s*(;.*)?$', 'i');
110
109
  return mime !== null && (jsonMime.test(mime) || mime.toLowerCase() === 'application/json-patch+json');
111
110
  }
112
111
 
@@ -1,4 +1,4 @@
1
- /* eslint-disable @typescript-eslint/no-explicit-any, @typescript-eslint/ban-types */
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
2
 
3
3
  export interface {{classname}}{{#allParents}}{{#-first}} extends {{/-first}}{{{.}}}{{^-last}}, {{/-last}}{{/allParents}} { {{>modelGenericAdditionalProperties}}
4
4
  {{#vars}}
package/package.json CHANGED
@@ -1,9 +1,9 @@
1
1
  {
2
2
  "name": "@mediusinc/mng-commons-data-api",
3
- "version": "6.0.0-rc.5",
3
+ "version": "6.0.0-rc.6",
4
4
  "peerDependencies": {
5
- "@angular/core": "^17.3.0 || ^18.0.0",
6
- "@mediusinc/mng-commons": "~6.0.0-rc.5"
5
+ "@angular/core": "^19.0.0",
6
+ "@mediusinc/mng-commons": "~6.0.0-rc.6"
7
7
  },
8
8
  "dependencies": {
9
9
  "tslib": "^2.8.1"
@@ -20,14 +20,10 @@
20
20
  },
21
21
  ".": {
22
22
  "types": "./index.d.ts",
23
- "esm2022": "./esm2022/mediusinc-mng-commons-data-api.mjs",
24
- "esm": "./esm2022/mediusinc-mng-commons-data-api.mjs",
25
23
  "default": "./fesm2022/mediusinc-mng-commons-data-api.mjs"
26
24
  },
27
25
  "./tableview": {
28
26
  "types": "./tableview/index.d.ts",
29
- "esm2022": "./esm2022/tableview/mediusinc-mng-commons-data-api-tableview.mjs",
30
- "esm": "./esm2022/tableview/mediusinc-mng-commons-data-api-tableview.mjs",
31
27
  "default": "./fesm2022/mediusinc-mng-commons-data-api-tableview.mjs"
32
28
  }
33
29
  }
package/version-info.json CHANGED
@@ -1,11 +1,11 @@
1
1
  {
2
2
  "name": "@mediusinc/mng-commons-data-api",
3
- "version": "6.0.0-rc.5",
3
+ "version": "6.0.0-rc.6",
4
4
  "tag": null,
5
5
  "distance": null,
6
- "hash": "7bc3839",
6
+ "hash": "65c2b24",
7
7
  "dirty": true,
8
8
  "semver": null,
9
9
  "buildTimestamp": null,
10
- "raw": "6.0.0-rc.5-7bc3839-dirty"
10
+ "raw": "6.0.0-rc.6-65c2b24-dirty"
11
11
  }
package/esm2022/index.mjs DELETED
@@ -1,9 +0,0 @@
1
- // helpers
2
- export * from './lib/helpers/get-all-params';
3
- // models
4
- export * from './lib/models/api-version.model';
5
- export * from './lib/models/request-params.model';
6
- export * from './lib/models/schema.model';
7
- // types
8
- export * from './lib/types/extract-get-all-types.type';
9
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsVUFBVTtBQUNWLGNBQWMsOEJBQThCLENBQUM7QUFFN0MsU0FBUztBQUNULGNBQWMsZ0NBQWdDLENBQUM7QUFDL0MsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLDJCQUEyQixDQUFDO0FBRTFDLFFBQVE7QUFDUixjQUFjLHdDQUF3QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gaGVscGVyc1xuZXhwb3J0ICogZnJvbSAnLi9saWIvaGVscGVycy9nZXQtYWxsLXBhcmFtcyc7XG5cbi8vIG1vZGVsc1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzL2FwaS12ZXJzaW9uLm1vZGVsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9yZXF1ZXN0LXBhcmFtcy5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RlbHMvc2NoZW1hLm1vZGVsJztcblxuLy8gdHlwZXNcbmV4cG9ydCAqIGZyb20gJy4vbGliL3R5cGVzL2V4dHJhY3QtZ2V0LWFsbC10eXBlcy50eXBlJztcbiJdfQ==
@@ -1,226 +0,0 @@
1
- import { CommonsInternalError, FilterMatchMode, dataListParamsFilterToUrlQuery, dataListParamsFiltersToUrlQuery, dataListParamsSortToUrlQuery, mapToDataList } from '@mediusinc/mng-commons/core';
2
- /**
3
- * Converts a filter match mode to its corresponding enum value.
4
- *
5
- * @param {string} matchMode - The filter match mode from data list filter to convert.
6
- * @returns {GetAllParamsFilterMatchType} - The converted enum value.
7
- * @throws {CommonsInternalError} - If the filter match mode is not supported.
8
- */
9
- export function toGetAllParamsFilterMatchMode(matchMode) {
10
- switch (matchMode) {
11
- case FilterMatchMode.Equals:
12
- return 'EQUALS';
13
- case FilterMatchMode.NotEquals:
14
- return 'NOT_EQUALS';
15
- case FilterMatchMode.Contains:
16
- return 'CONTAINS';
17
- case FilterMatchMode.NotContains:
18
- return 'NOT_CONTAINS';
19
- case FilterMatchMode.In:
20
- return 'IN';
21
- case FilterMatchMode.NotIn:
22
- return 'NOT_IN';
23
- case FilterMatchMode.StartsWith:
24
- return 'STARTS_WITH';
25
- case FilterMatchMode.EndsWith:
26
- return 'ENDS_WITH';
27
- case FilterMatchMode.LessThan:
28
- return 'LESS_THAN';
29
- case FilterMatchMode.LessThanOrEqualTo:
30
- return 'LESS_THAN_OR_EQUAL_TO';
31
- case FilterMatchMode.GreaterThan:
32
- return 'GREATER_THAN';
33
- case FilterMatchMode.GreaterThanOrEqualTo:
34
- return 'GREATER_THAN_OR_EQUAL_TO';
35
- case FilterMatchMode.Between:
36
- return 'BETWEEN';
37
- case FilterMatchMode.Exists:
38
- return 'EXISTS';
39
- case FilterMatchMode.DoesNotExist:
40
- return 'DOES_NOT_EXIST';
41
- default:
42
- throw new CommonsInternalError(`Filter match type '${matchMode}' not supported.`);
43
- }
44
- }
45
- function toGetAllParamsAsUrlQueryCommon(params) {
46
- const res = {};
47
- if (params.offset != null) {
48
- res.offset = params.offset;
49
- }
50
- if (params.limit != null) {
51
- res.limit = params.limit;
52
- }
53
- if (params.search != null && params.search !== '') {
54
- let caseSensitivityOption = 'ci';
55
- if (params.filters?.['global']?.caseSensitive === true) {
56
- caseSensitivityOption = 'cs';
57
- }
58
- res.globalFilter = `${caseSensitivityOption}:${params.search}`;
59
- }
60
- if (Array.isArray(params.sort) && params.sort.length > 0) {
61
- res.sort = dataListParamsSortToUrlQuery(params);
62
- }
63
- return res;
64
- }
65
- /**
66
- * Converts given parameters of a DataListParams object into a get all request param object with values as URL query string representation.
67
- *
68
- * @param {DataListParams} params - The parameters to convert.
69
- * @typeparam Sorts - The type of the sorting options for the data list.
70
- * @typeparam Filters - The type of the filters for the data list.
71
- * @returns {GetAllParamsUrlQueryType<Filters>} - Get all request param object with values as URL query string representation.
72
- */
73
- export function toGetAllParamsAsUrlQuery(params) {
74
- const res = toGetAllParamsAsUrlQueryCommon(params);
75
- if (params.filters) {
76
- Object.keys(params.filters).forEach(key => {
77
- res[key] = dataListParamsFiltersToUrlQuery(params, key);
78
- });
79
- }
80
- return res;
81
- }
82
- /**
83
- * Converts given parameters of a DataListParams object into a get all request param object with values as URL query string representation.
84
- *
85
- * @param {DataListParams} params - The parameters to convert.
86
- * @param {FilterKey} filterKey - Property key for filter object.
87
- * @typeparam Sorts - The type of the sorting options for the data list.
88
- * @typeparam Filters - The type of the filters for the data list.
89
- * @typeparam FilterKey - The type representing property key where filters will be put to.
90
- * @returns {GetAllParamsUrlQueryWithFiltersInKeyType<FilterKey, Filters>} - Get all request param object with values as URL query string representation.
91
- */
92
- export function toGetAllParamsAsUrlQueryWithFiltersInProperty(params, filterKey = 'filters') {
93
- const res = toGetAllParamsAsUrlQueryCommon(params);
94
- if (params.filters && Object.keys(params.filters).length > 0) {
95
- res[filterKey] = {};
96
- Object.keys(params.filters).forEach(key => {
97
- res[filterKey][key] = dataListParamsFiltersToUrlQuery(params, key);
98
- });
99
- }
100
- return res;
101
- }
102
- /**
103
- * Converts given parameters of a DataListParams object into a get all request param object with values as objects for POST requests.
104
- *
105
- * @param {DataListParams} params - The parameters to convert.
106
- * @typeparam Sorts - The type of the sorting options for the data list.
107
- * @typeparam Filters - The type of the filters for the data list.
108
- * @returns {GetAllParamsType<Sorts, Filters>} - Get all request param object with values as objects for POST requests.
109
- */
110
- export function toGetAllParams(params) {
111
- const res = {};
112
- if (params.offset != null) {
113
- res.offset = params.offset;
114
- }
115
- if (params.limit != null) {
116
- res.limit = params.limit;
117
- }
118
- if (params.search != null) {
119
- res.globalFilter = {
120
- value: params.search
121
- };
122
- }
123
- if (Array.isArray(params.sort) && params.sort.length > 0) {
124
- res.sort = params.sort.map(s => ({
125
- property: s.property,
126
- direction: s.ascending === true || s.ascending == null ? 'ASCENDING' : 'DESCENDING'
127
- }));
128
- }
129
- if (params.filters) {
130
- Object.keys(params.filters).forEach(key => {
131
- const paramsFilter = params.filters[key];
132
- if (!paramsFilter.matchMode) {
133
- return;
134
- }
135
- let value = Array.isArray(paramsFilter.value) ? undefined : paramsFilter.value;
136
- let values = Array.isArray(paramsFilter.value) ? paramsFilter.value : undefined;
137
- if (paramsFilter.matchMode === FilterMatchMode.Exists || paramsFilter.matchMode === FilterMatchMode.DoesNotExist) {
138
- value = undefined;
139
- values = undefined;
140
- }
141
- else if (paramsFilter.matchMode === FilterMatchMode.In || paramsFilter.matchMode === FilterMatchMode.NotIn) {
142
- if (values == null || values.length === 0) {
143
- throw new CommonsInternalError(`Filter with mode ${paramsFilter.matchMode} must have values in array, but has ${values}`);
144
- }
145
- }
146
- else if (paramsFilter.matchMode === FilterMatchMode.Between) {
147
- if (values == null || values.length !== 2) {
148
- throw new CommonsInternalError(`Filter with mode ${paramsFilter.matchMode} must have 2 values in array, but has ${values}`);
149
- }
150
- }
151
- else if (paramsFilter.value == null) {
152
- return;
153
- }
154
- const caseSensitivity = paramsFilter.caseSensitive ? 'CASE_SENSITIVE' : paramsFilter.caseSensitive === false ? 'CASE_INSENSITIVE' : undefined;
155
- const filter = {
156
- filterMatchType: toGetAllParamsFilterMatchMode(paramsFilter.matchMode)
157
- };
158
- if (value != null) {
159
- filter.value = value;
160
- }
161
- if (values != null && Array.isArray(values) && values.length > 0) {
162
- filter.values = values;
163
- }
164
- if (caseSensitivity != null) {
165
- filter.caseSensitivity = caseSensitivity;
166
- }
167
- res[key] = filter;
168
- });
169
- }
170
- return res;
171
- }
172
- /**
173
- * Converts DataListParams to sort query URL representation.
174
- *
175
- * @param {DataListParams} params - The params object with sort property to convert.
176
- * @returns {string | undefined} - The formatted sort query URL param or undefined.
177
- */
178
- export function toGetAllSortAsQueryUrl(params) {
179
- return dataListParamsSortToUrlQuery(params);
180
- }
181
- /**
182
- * Converts a DataListFilter object to a query URL string.
183
- *
184
- * @param {DataListFilter} filter - The filter object from params to convert.
185
- * @returns {string|undefined} - The formatted filter query URL param or undefined.
186
- */
187
- export function toGetAllFilterAsQueryUrl(filter) {
188
- return dataListParamsFilterToUrlQuery(filter);
189
- }
190
- /**
191
- * Executes the "getAll" on API service with request parameters.
192
- * Get all is expected to be executed via GET method using params as URL queries.
193
- *
194
- * @param {Service} service - The API service instance.
195
- * @param {Function} getAllFn - The "getAll" function on provided service instance.
196
- * @param {Object} params - The data list params.
197
- * @returns {Observable<<DataListResult<Item>>>} An observable with data list result.
198
- */
199
- export function executeGetAll(service, getAllFn, params) {
200
- return getAllFn.bind(service)(toGetAllParamsAsUrlQuery(params)).pipe(mapToDataList());
201
- }
202
- /**
203
- * Executes the "getAll" on API service with request parameters.
204
- * Get all is expected to be executed via GET method using params as URL queries.
205
- *
206
- * @param {Service} service - The API service instance.
207
- * @param {Function} getAllFn - The "getAll" function on provided service.
208
- * @param {Object} params - The data list params.
209
- * @returns {Observable<<DataListResult<Item>>>} An observable with data list result.
210
- */
211
- export function apiServiceGetAll(service, fn, params) {
212
- return service[fn](toGetAllParamsAsUrlQuery(params)).pipe(mapToDataList());
213
- }
214
- /**
215
- * Executes the "getAll" on API service with request parameters.
216
- * Get all is expected to be executed via POST method using params as object in body of request.
217
- *
218
- * @param {Service} service - The API service instance.
219
- * @param {Function} getAllFn - The "getAll" function on provided service instance.
220
- * @param {Object} params - The data list params.
221
- * @returns {Observable<<DataListResult<Item>>>} An observable with data list result.
222
- */
223
- export function executeGetAllAsPost(service, getAllFn, params) {
224
- return getAllFn.bind(service)(toGetAllParams(params)).pipe(mapToDataList());
225
- }
226
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"get-all-params.js","sourceRoot":"","sources":["../../../../src/lib/helpers/get-all-params.ts"],"names":[],"mappings":"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","sourcesContent":["import {Observable} from 'rxjs';\n\nimport {\n    ClassFunctionKeysWithParamAndReturnType,\n    CommonsInternalError,\n    DataListFilter,\n    DataListParams,\n    DataListResult,\n    FilterMatchMode,\n    dataListParamsFilterToUrlQuery,\n    dataListParamsFiltersToUrlQuery,\n    dataListParamsSortToUrlQuery,\n    mapToDataList\n} from '@mediusinc/mng-commons/core';\n\nimport {\n    GetAllParamsFilterMatchType,\n    GetAllParamsFilterType,\n    GetAllParamsType,\n    GetAllParamsUrlQueryType,\n    GetAllParamsUrlQueryWithFiltersInKeyType\n} from '../models/request-params.model';\n\n/**\n * Converts a filter match mode to its corresponding enum value.\n *\n * @param {string} matchMode - The filter match mode from data list filter to convert.\n * @returns {GetAllParamsFilterMatchType} - The converted enum value.\n * @throws {CommonsInternalError} - If the filter match mode is not supported.\n */\nexport function toGetAllParamsFilterMatchMode(matchMode: string): GetAllParamsFilterMatchType {\n    switch (matchMode) {\n        case FilterMatchMode.Equals:\n            return 'EQUALS';\n        case FilterMatchMode.NotEquals:\n            return 'NOT_EQUALS';\n        case FilterMatchMode.Contains:\n            return 'CONTAINS';\n        case FilterMatchMode.NotContains:\n            return 'NOT_CONTAINS';\n        case FilterMatchMode.In:\n            return 'IN';\n        case FilterMatchMode.NotIn:\n            return 'NOT_IN';\n        case FilterMatchMode.StartsWith:\n            return 'STARTS_WITH';\n        case FilterMatchMode.EndsWith:\n            return 'ENDS_WITH';\n        case FilterMatchMode.LessThan:\n            return 'LESS_THAN';\n        case FilterMatchMode.LessThanOrEqualTo:\n            return 'LESS_THAN_OR_EQUAL_TO';\n        case FilterMatchMode.GreaterThan:\n            return 'GREATER_THAN';\n        case FilterMatchMode.GreaterThanOrEqualTo:\n            return 'GREATER_THAN_OR_EQUAL_TO';\n        case FilterMatchMode.Between:\n            return 'BETWEEN';\n        case FilterMatchMode.Exists:\n            return 'EXISTS';\n        case FilterMatchMode.DoesNotExist:\n            return 'DOES_NOT_EXIST';\n        default:\n            throw new CommonsInternalError(`Filter match type '${matchMode}' not supported.`);\n    }\n}\n\nfunction toGetAllParamsAsUrlQueryCommon<Sorts, Filters extends keyof any>(params: DataListParams<Sorts, Filters>): GetAllParamsUrlQueryType<Filters> {\n    const res = {} as GetAllParamsUrlQueryType<Filters>;\n\n    if (params.offset != null) {\n        res.offset = params.offset;\n    }\n    if (params.limit != null) {\n        res.limit = params.limit;\n    }\n\n    if (params.search != null && params.search !== '') {\n        let caseSensitivityOption = 'ci';\n\n        if (params.filters?.['global' as Filters]?.caseSensitive === true) {\n            caseSensitivityOption = 'cs';\n        }\n\n        res.globalFilter = `${caseSensitivityOption}:${params.search}`;\n    }\n\n    if (Array.isArray(params.sort) && params.sort.length > 0) {\n        res.sort = dataListParamsSortToUrlQuery(params as DataListParams);\n    }\n\n    return res;\n}\n\n/**\n * Converts given parameters of a DataListParams object into a get all request param object with values as URL query string representation.\n *\n * @param {DataListParams} params - The parameters to convert.\n * @typeparam Sorts - The type of the sorting options for the data list.\n * @typeparam Filters - The type of the filters for the data list.\n * @returns {GetAllParamsUrlQueryType<Filters>} - Get all request param object with values as URL query string representation.\n */\nexport function toGetAllParamsAsUrlQuery<Sorts, Filters extends keyof any>(params: DataListParams<Sorts, Filters>): GetAllParamsUrlQueryType<Filters> {\n    const res = toGetAllParamsAsUrlQueryCommon(params);\n\n    if (params.filters) {\n        Object.keys(params.filters).forEach(key => {\n            res[key as Filters] = dataListParamsFiltersToUrlQuery(params, key as Filters) as any;\n        });\n    }\n\n    return res;\n}\n\n/**\n * Converts given parameters of a DataListParams object into a get all request param object with values as URL query string representation.\n *\n * @param {DataListParams} params - The parameters to convert.\n * @param {FilterKey} filterKey - Property key for filter object.\n * @typeparam Sorts - The type of the sorting options for the data list.\n * @typeparam Filters - The type of the filters for the data list.\n * @typeparam FilterKey - The type representing property key where filters will be put to.\n * @returns {GetAllParamsUrlQueryWithFiltersInKeyType<FilterKey, Filters>} - Get all request param object with values as URL query string representation.\n */\nexport function toGetAllParamsAsUrlQueryWithFiltersInProperty<Sorts, Filters extends keyof any, FilterKey extends string | number | symbol = 'filters'>(\n    params: DataListParams<Sorts, Filters>,\n    filterKey: FilterKey = 'filters' as FilterKey\n): GetAllParamsUrlQueryWithFiltersInKeyType<FilterKey, Filters> {\n    const res = toGetAllParamsAsUrlQueryCommon(params) as GetAllParamsUrlQueryWithFiltersInKeyType<FilterKey, Filters>;\n\n    if (params.filters && Object.keys(params.filters).length > 0) {\n        (res as any)[filterKey] = {};\n        Object.keys(params.filters).forEach(key => {\n            (res as any)[filterKey][key as Filters] = dataListParamsFiltersToUrlQuery(params, key as Filters) as any;\n        });\n    }\n\n    return res;\n}\n\n/**\n * Converts given parameters of a DataListParams object into a get all request param object with values as objects for POST requests.\n *\n * @param {DataListParams} params - The parameters to convert.\n * @typeparam Sorts - The type of the sorting options for the data list.\n * @typeparam Filters - The type of the filters for the data list.\n * @returns {GetAllParamsType<Sorts, Filters>} - Get all request param object with values as objects for POST requests.\n */\nexport function toGetAllParams<Sorts, Filters extends keyof any>(params: DataListParams<Sorts, Filters>): GetAllParamsType<Sorts, Filters> {\n    const res = {} as GetAllParamsType<Sorts, Filters>;\n\n    if (params.offset != null) {\n        res.offset = params.offset;\n    }\n    if (params.limit != null) {\n        res.limit = params.limit;\n    }\n\n    if (params.search != null) {\n        res.globalFilter = {\n            value: params.search\n        };\n    }\n\n    if (Array.isArray(params.sort) && params.sort.length > 0) {\n        res.sort = params.sort.map(s => ({\n            property: s.property,\n            direction: s.ascending === true || s.ascending == null ? 'ASCENDING' : 'DESCENDING'\n        }));\n    }\n\n    if (params.filters) {\n        Object.keys(params.filters).forEach(key => {\n            const paramsFilter = params.filters![key as Filters]!;\n            if (!paramsFilter.matchMode) {\n                return;\n            }\n\n            let value = Array.isArray(paramsFilter.value) ? undefined : paramsFilter.value;\n            let values = Array.isArray(paramsFilter.value) ? paramsFilter.value : undefined;\n\n            if (paramsFilter.matchMode === FilterMatchMode.Exists || paramsFilter.matchMode === FilterMatchMode.DoesNotExist) {\n                value = undefined;\n                values = undefined;\n            } else if (paramsFilter.matchMode === FilterMatchMode.In || paramsFilter.matchMode === FilterMatchMode.NotIn) {\n                if (values == null || values.length === 0) {\n                    throw new CommonsInternalError(`Filter with mode ${paramsFilter.matchMode} must have values in array, but has ${values}`);\n                }\n            } else if (paramsFilter.matchMode === FilterMatchMode.Between) {\n                if (values == null || values.length !== 2) {\n                    throw new CommonsInternalError(`Filter with mode ${paramsFilter.matchMode} must have 2 values in array, but has ${values}`);\n                }\n            } else if (paramsFilter.value == null) {\n                return;\n            }\n\n            const caseSensitivity = paramsFilter.caseSensitive ? 'CASE_SENSITIVE' : paramsFilter.caseSensitive === false ? 'CASE_INSENSITIVE' : undefined;\n            const filter = <GetAllParamsFilterType<any>>{\n                filterMatchType: toGetAllParamsFilterMatchMode(paramsFilter.matchMode)\n            };\n\n            if (value != null) {\n                filter.value = value;\n            }\n            if (values != null && Array.isArray(values) && values.length > 0) {\n                filter.values = values;\n            }\n            if (caseSensitivity != null) {\n                filter.caseSensitivity = caseSensitivity;\n            }\n\n            (res as any)[key as Filters] = filter;\n        });\n    }\n\n    return res;\n}\n\n/**\n * Converts DataListParams to sort query URL representation.\n *\n * @param {DataListParams} params - The params object with sort property to convert.\n * @returns {string | undefined} - The formatted sort query URL param or undefined.\n */\nexport function toGetAllSortAsQueryUrl(params?: DataListParams<any, any>): string | undefined {\n    return dataListParamsSortToUrlQuery(params);\n}\n\n/**\n * Converts a DataListFilter object to a query URL string.\n *\n * @param {DataListFilter} filter - The filter object from params to convert.\n * @returns {string|undefined} - The formatted filter query URL param or undefined.\n */\nexport function toGetAllFilterAsQueryUrl(filter?: DataListFilter): string | undefined {\n    return dataListParamsFilterToUrlQuery(filter);\n}\n\n/**\n * Executes the \"getAll\" on API service with request parameters.\n * Get all is expected to be executed via GET method using params as URL queries.\n *\n * @param {Service} service - The API service instance.\n * @param {Function} getAllFn - The \"getAll\" function on provided service instance.\n * @param {Object} params - The data list params.\n * @returns {Observable<<DataListResult<Item>>>} An observable with data list result.\n */\nexport function executeGetAll<Service, Item, Sorts, Filters extends keyof any>(\n    service: Service,\n    getAllFn: (requestParameters: GetAllParamsUrlQueryType<Filters>) => Observable<{data?: Item[]; totalCount?: number}>,\n    params: DataListParams<Sorts, Filters>\n): Observable<DataListResult<Item>> {\n    return getAllFn.bind(service)(toGetAllParamsAsUrlQuery(params)).pipe(mapToDataList<Item>());\n}\n\n/**\n * Executes the \"getAll\" on API service with request parameters.\n * Get all is expected to be executed via GET method using params as URL queries.\n *\n * @param {Service} service - The API service instance.\n * @param {Function} getAllFn - The \"getAll\" function on provided service.\n * @param {Object} params - The data list params.\n * @returns {Observable<<DataListResult<Item>>>} An observable with data list result.\n */\nexport function apiServiceGetAll<Service, Item, Sorts, Filters extends keyof any>(\n    service: Service,\n    fn: ClassFunctionKeysWithParamAndReturnType<Service, GetAllParamsUrlQueryType<Filters>, Observable<{data?: Item[]; totalCount?: number}>>,\n    params: DataListParams<Sorts, Filters>\n): Observable<DataListResult<Item>> {\n    return (service as any)[fn](toGetAllParamsAsUrlQuery(params)).pipe(mapToDataList<Item>());\n}\n\n/**\n * Executes the \"getAll\" on API service with request parameters.\n * Get all is expected to be executed via POST method using params as object in body of request.\n *\n * @param {Service} service - The API service instance.\n * @param {Function} getAllFn - The \"getAll\" function on provided service instance.\n * @param {Object} params - The data list params.\n * @returns {Observable<<DataListResult<Item>>>} An observable with data list result.\n */\nexport function executeGetAllAsPost<Service, Item, Sorts, Filters extends keyof any>(\n    service: Service,\n    getAllFn: (requestParameters: GetAllParamsType<Sorts, Filters>) => Observable<{data?: Item[]; totalCount?: number}>,\n    params: DataListParams<Sorts, Filters>\n): Observable<DataListResult<Item>> {\n    return getAllFn.bind(service)(toGetAllParams(params)).pipe(mapToDataList<Item>());\n}\n"]}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLXZlcnNpb24ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL21vZGVscy9hcGktdmVyc2lvbi5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBBcGlWZXJzaW9uIHtcbiAgICBhcHBOYW1lPzogc3RyaW5nO1xuICAgIGRlc2NyaXB0aW9uPzogc3RyaW5nO1xuICAgIHZlcnNpb24/OiBzdHJpbmc7XG4gICAgaW5mb0VtYWlsPzogc3RyaW5nO1xuICAgIGluZm9Vcmw/OiBzdHJpbmc7XG4gICAgbGljZW5zZUluZm8/OiBzdHJpbmc7XG4gICAgbGljZW5zZVVybD86IHN0cmluZztcbn1cbiJdfQ==
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVxdWVzdC1wYXJhbXMubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL21vZGVscy9yZXF1ZXN0LXBhcmFtcy5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBEZWZhdWx0IChleHBlY3RlZCkgdHlwZSB3aXRob3V0IGZpbHRlcnMsIHdoaWNoIGFyZSBcImR5bmFtaWNcIiBrZXlzLlxuICovXG5leHBvcnQgdHlwZSBHZXRBbGxQYXJhbXNEZWZhdWx0V29GaWx0ZXJzVHlwZTxTb3J0ID0gR2V0QWxsUGFyYW1zU29ydFR5cGVbXSB8IHN0cmluZywgR2xvYmFsRmlsdGVyID0gR2V0QWxsUGFyYW1zR2xvYmFsRmlsdGVyVHlwZSB8IHN0cmluZz4gPSB7XG4gICAgb2Zmc2V0PzogbnVtYmVyO1xuICAgIGxpbWl0PzogbnVtYmVyO1xuICAgIGdsb2JhbEZpbHRlcj86IEdsb2JhbEZpbHRlcjtcbiAgICBzb3J0PzogU29ydDtcbn07XG5cbi8qKlxuICogUmVwcmVzZW50cyB0aGUgc29ydCBkaXJlY3Rpb24gdHlwZSBmb3IgYSBnZXQgYWxsIHJlcXVlc3QgcGFyYW1zIChhc2NlbmRpbmcgb3IgZGVzY2VuZGluZykuXG4gKi9cbmV4cG9ydCB0eXBlIEdldEFsbFBhcmFtc1NvcnREaXJlY3Rpb25UeXBlID0gJ0FTQ0VORElORycgfCAnREVTQ0VORElORyc7XG5cbi8qKlxuICogUmVwcmVzZW50cyB0aGUgc29ydCB0eXBlIGZvciBhIGdldCBhbGwgcmVxdWVzdCBwYXJhbXMuXG4gKlxuICogQHR5cGVwYXJhbSBQcm9wZXJ0eSBUaGUgdHlwZSBvZiB0aGUgcHJvcGVydHkgdG8gc29ydCBieS5cbiAqIEB0eXBlcGFyYW0gRGlyZWN0aW9uIFRoZSB0eXBlIG9mIHRoZSBzb3J0IGRpcmVjdGlvbi5cbiAqL1xuZXhwb3J0IHR5cGUgR2V0QWxsUGFyYW1zU29ydFR5cGU8UHJvcGVydHkgPSBzdHJpbmcsIERpcmVjdGlvbiA9IEdldEFsbFBhcmFtc1NvcnREaXJlY3Rpb25UeXBlPiA9IHtcbiAgICBwcm9wZXJ0eTogUHJvcGVydHk7XG4gICAgZGlyZWN0aW9uOiBEaXJlY3Rpb247XG59O1xuXG4vKipcbiAqIFJlcHJlc2VudHMgdGhlIHBvc3NpYmxlIG1hdGNoIHR5cGVzIGZvciBmaWx0ZXJzIGluIGdldCBhbGwgcmVxdWVzdCBwYXJhbXMuXG4gKi9cbmV4cG9ydCB0eXBlIEdldEFsbFBhcmFtc0ZpbHRlck1hdGNoVHlwZSA9XG4gICAgfCAnRVFVQUxTJ1xuICAgIHwgJ05PVF9FUVVBTFMnXG4gICAgfCAnQkVUV0VFTidcbiAgICB8ICdDT05UQUlOUydcbiAgICB8ICdOT1RfQ09OVEFJTlMnXG4gICAgfCAnU1RBUlRTX1dJVEgnXG4gICAgfCAnRU5EU19XSVRIJ1xuICAgIHwgJ0lOJ1xuICAgIHwgJ05PVF9JTidcbiAgICB8ICdMRVNTX1RIQU4nXG4gICAgfCAnTEVTU19USEFOX09SX0VRVUFMX1RPJ1xuICAgIHwgJ0dSRUFURVJfVEhBTidcbiAgICB8ICdHUkVBVEVSX1RIQU5fT1JfRVFVQUxfVE8nXG4gICAgfCAnRVhJU1RTJ1xuICAgIHwgJ0RPRVNfTk9UX0VYSVNUJztcblxuLyoqXG4gKiBEZXNjcmliZXMgdGhlIHBvc3NpYmxlIGNhc2Ugc2Vuc2l0aXZpdHkgZm9yIGZpbHRlciBpbiBnZXQgYWxsIHJlcXVlc3QgcGFyYW1zLlxuICovXG5leHBvcnQgdHlwZSBHZXRBbGxQYXJhbXNGaWx0ZXJDYXNlU2Vuc2l0aXZpdHlUeXBlID0gJ0NBU0VfU0VOU0lUSVZFJyB8ICdDQVNFX0lOU0VOU0lUSVZFJztcblxuLyoqXG4gKiBEZXNjcmliZXMgdGhlIGdsb2JhbCBmaWx0ZXIgKHNlYXJjaCkgaW4gZ2V0IGFsbCByZXF1ZXN0IHBhcmFtcy5cbiAqL1xuZXhwb3J0IHR5cGUgR2V0QWxsUGFyYW1zR2xvYmFsRmlsdGVyVHlwZTxDYXNlU2Vuc2l0aXZpdHkgPSBHZXRBbGxQYXJhbXNGaWx0ZXJDYXNlU2Vuc2l0aXZpdHlUeXBlPiA9IHtcbiAgICB2YWx1ZTogc3RyaW5nO1xuICAgIGNhc2VTZW5zaXRpdml0eT86IENhc2VTZW5zaXRpdml0eTtcbn07XG5cbi8qKlxuICogRGVzY3JpYmVzIHRoZSBmaWx0ZXJzIGluIGdldCBhbGwgcmVxdWVzdCBwYXJhbXMuXG4gKi9cbmV4cG9ydCB0eXBlIEdldEFsbFBhcmFtc0ZpbHRlcnNUeXBlPEZpbHRlclR5cGUsIEZpbHRlclByb3BlcnRpZXMgZXh0ZW5kcyBrZXlvZiBhbnk+ID0ge1xuICAgIFtQIGluIEZpbHRlclByb3BlcnRpZXNdPzogRmlsdGVyVHlwZTtcbn07XG5cbi8qKlxuICogUmVwcmVzZW50cyBhIGZpbHRlciB0eXBlIGZvciBnZXQgYWxsIHJlcXVlc3QgcGFyYW1zLlxuICovXG5leHBvcnQgdHlwZSBHZXRBbGxQYXJhbXNGaWx0ZXJUeXBlPFZhbHVlLCBDYXNlU2Vuc2l0aXZpdHkgPSBHZXRBbGxQYXJhbXNGaWx0ZXJDYXNlU2Vuc2l0aXZpdHlUeXBlLCBNYXRjaFR5cGUgPSBHZXRBbGxQYXJhbXNGaWx0ZXJNYXRjaFR5cGU+ID0ge1xuICAgIHZhbHVlPzogVmFsdWU7XG4gICAgdmFsdWVzPzogQXJyYXk8VmFsdWU+O1xuICAgIGNhc2VTZW5zaXRpdml0eT86IENhc2VTZW5zaXRpdml0eTtcbiAgICBmaWx0ZXJNYXRjaFR5cGU6IE1hdGNoVHlwZTtcbn07XG5cbi8qKlxuICogRGVzY3JpYmVzIGdldCBhbGwgcGFyYW1zIHdpdGggdmFsdWVzIGFzIG9iamVjdHMgKGZvciBQT1NUIHJlcXVlc3RzKS5cbiAqL1xuZXhwb3J0IHR5cGUgR2V0QWxsUGFyYW1zVHlwZTxTb3J0cyA9IHN0cmluZywgRmlsdGVycyBleHRlbmRzIGtleW9mIGFueSA9IHN0cmluZz4gPSBHZXRBbGxQYXJhbXNEZWZhdWx0V29GaWx0ZXJzVHlwZTxHZXRBbGxQYXJhbXNTb3J0VHlwZTxTb3J0cz5bXSwgR2V0QWxsUGFyYW1zR2xvYmFsRmlsdGVyVHlwZT4gJlxuICAgIEdldEFsbFBhcmFtc0ZpbHRlcnNUeXBlPEdldEFsbFBhcmFtc0ZpbHRlclR5cGU8YW55PiwgRmlsdGVycz47XG5cbi8qKlxuICogRGVzY3JpYmVzIGdldCBhbGwgcGFyYW1zIHdpdGggdmFsdWVzIGFzIFVSTCBxdWVyaWVzIChmb3IgR0VUIHJlcXVlc3RzKS5cbiAqL1xuZXhwb3J0IHR5cGUgR2V0QWxsUGFyYW1zVXJsUXVlcnlUeXBlPEZpbHRlcnMgZXh0ZW5kcyBrZXlvZiBhbnk+ID0gR2V0QWxsUGFyYW1zRGVmYXVsdFdvRmlsdGVyc1R5cGU8c3RyaW5nLCBzdHJpbmc+ICYgR2V0QWxsUGFyYW1zRmlsdGVyc1R5cGU8c3RyaW5nLCBGaWx0ZXJzPjtcblxuLyoqXG4gKiBEZXNjcmliZXMgZ2V0IGFsbCBwYXJhbXMgd2l0aCB2YWx1ZXMgYXMgVVJMIHF1ZXJpZXMgKGZvciBHRVQgcmVxdWVzdHMpIHdoZXJlIGZpbHRlcnMgYXJlIHBsYWNlcyBhcyBvYmplY3QgdW5kZXIgcm9vdCB7RmlsdGVyS2V5fSBwcm9wZXJ0eS5cbiAqL1xuZXhwb3J0IHR5cGUgR2V0QWxsUGFyYW1zVXJsUXVlcnlXaXRoRmlsdGVyc0luS2V5VHlwZTxGaWx0ZXJLZXkgZXh0ZW5kcyBzdHJpbmcgfCBudW1iZXIgfCBzeW1ib2wsIEZpbHRlcnMgZXh0ZW5kcyBrZXlvZiBhbnk+ID0gR2V0QWxsUGFyYW1zRGVmYXVsdFdvRmlsdGVyc1R5cGU8c3RyaW5nLCBzdHJpbmc+ICYge1xuICAgIFtrZXkgaW4gRmlsdGVyS2V5XT86IEdldEFsbFBhcmFtc0ZpbHRlcnNUeXBlPHN0cmluZywgRmlsdGVycz47XG59O1xuIl19
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NoZW1hLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2xpYi9tb2RlbHMvc2NoZW1hLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFNjaGVtYU1vZGVsPE1vZGVsID0gYW55PiB7XG4gICAgbmFtZTogc3RyaW5nO1xuICAgIHByb3BlcnRpZXM6IFJlY29yZDxrZXlvZiBNb2RlbCwgU2NoZW1hUHJvcGVydHk+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNjaGVtYUVudW08RW51bVR5cGU+IHtcbiAgICBuYW1lOiBzdHJpbmc7XG4gICAgdmFsdWVzOiBFbnVtVHlwZVtdO1xuICAgIGNvbnN0YW50czogc3RyaW5nW107XG4gICAgdHlwZTogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNjaGVtYVByb3BlcnR5IHtcbiAgICB0eXBlOiBzdHJpbmc7XG4gICAgb2JqZWN0VHlwZT86IHN0cmluZztcbiAgICBpc1JlYWRPbmx5PzogYm9vbGVhbjtcbiAgICByZXF1aXJlZD86IGJvb2xlYW47XG4gICAgaXNOdWxsYWJsZT86IGJvb2xlYW47XG4gICAgbWluTGVuZ3RoPzogbnVtYmVyO1xuICAgIG1heExlbmd0aD86IG51bWJlcjtcbiAgICBtaW5pbXVtPzogbnVtYmVyO1xuICAgIG1heGltdW0/OiBudW1iZXI7XG4gICAgZXhjbHVzaXZlTWluaW11bT86IGJvb2xlYW47XG4gICAgZXhjbHVzaXZlTWF4aW11bT86IGJvb2xlYW47XG4gICAgaXNJbnRlZ2VyPzogYm9vbGVhbjtcbiAgICBwYXR0ZXJuPzogc3RyaW5nO1xuICAgIG1heEl0ZW1zPzogbnVtYmVyO1xuICAgIG1pbkl0ZW1zPzogbnVtYmVyO1xuICAgIGVudW1Nb2RlbD86IGFueTtcbiAgICBlbnVtTmFtZT86IHN0cmluZztcbiAgICBpc0VtYWlsPzogYm9vbGVhbjtcbiAgICBpc1Bhc3N3b3JkPzogYm9vbGVhbjtcbn1cbiJdfQ==
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXh0cmFjdC1nZXQtYWxsLXR5cGVzLnR5cGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL3R5cGVzL2V4dHJhY3QtZ2V0LWFsbC10eXBlcy50eXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0h0dHBSZXNwb25zZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuXG5pbXBvcnQge09ic2VydmFibGV9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQge0NsYXNzRnVuY3Rpb25LZXlzV2l0aEFueUFyZ3NBbmRSZXR1cm5UeXBlfSBmcm9tICdAbWVkaXVzaW5jL21uZy1jb21tb25zL2NvcmUnO1xuXG5pbXBvcnQge0dldEFsbFBhcmFtc0RlZmF1bHRXb0ZpbHRlcnNUeXBlLCBHZXRBbGxQYXJhbXNTb3J0VHlwZX0gZnJvbSAnLi4vbW9kZWxzL3JlcXVlc3QtcGFyYW1zLm1vZGVsJztcblxuLyoqXG4gKiBSZXByZXNlbnRzIHRoZSB0eXBlIGRlZmluaXRpb24gZm9yIHRoZSBgR2V0QWxsUGFyYW1zRGVmYXVsdFdvRmlsdGVyc1R5cGVgIGNsYXNzIC0gZXhjbHVkZXMgb2Zmc2V0LCBsaW1pdCwgc2VhcmNoIGFuZCBzb3J0IHByb3BlcnRpZXMuXG4gKiBBbGwgb3RoZXIgcHJvcGVydGllcyBhcmUgZXhwZWN0ZWQgdG8gYmUgZmlsdGVycy5cbiAqXG4gKiBAdHlwZXBhcmFtIFJlcXVlc3QgLSBUaGUgdHlwZSBwYXJhbWV0ZXIgcmVwcmVzZW50aW5nIHRoZSBleHRlbmRlZCBHZXRBbGxQYXJhbXNEZWZhdWx0V29GaWx0ZXJzVHlwZSBvYmplY3QuXG4gKi9cbmV4cG9ydCB0eXBlIEV4dHJhY3RHZXRBbGxQYXJhbXNGaWx0ZXJUeXBlPFJlcXVlc3QgZXh0ZW5kcyBHZXRBbGxQYXJhbXNEZWZhdWx0V29GaWx0ZXJzVHlwZT4gPSBSZXF1ZXN0IGV4dGVuZHMgR2V0QWxsUGFyYW1zRGVmYXVsdFdvRmlsdGVyc1R5cGVcbiAgICA/IGtleW9mIE9taXQ8UmVxdWVzdCwgJ29mZnNldCcgfCAnbGltaXQnIHwgJ2dsb2JhbEZpbHRlcicgfCAnc29ydCc+XG4gICAgOiBuZXZlcjtcblxuLyoqXG4gKiBSZXByZXNlbnRzIHRoZSB0eXBlIGRlZmluaXRpb24gZm9yIHRoZSBgR2V0QWxsUGFyYW1zRGVmYXVsdFdvRmlsdGVyc1R5cGVgIGNsYXNzIC0gZXh0cmFjdHMgYWxsb3dlZCBzb3J0IHByb3BlcnRpZXMgKHVzdWFsbHkgYW4gZW51bSkgb24gcHJvcGVydHkga2V5IHdpdGhpbiBhcnJheSB0eXBlLlxuICpcbiAqIEB0eXBlcGFyYW0gUmVxdWVzdCAtIFRoZSB0eXBlIHBhcmFtZXRlciByZXByZXNlbnRpbmcgdGhlIGV4dGVuZGVkIEdldEFsbFBhcmFtc0RlZmF1bHRXb0ZpbHRlcnNUeXBlIG9iamVjdC5cbiAqL1xuZXhwb3J0IHR5cGUgRXh0cmFjdEdldEFsbFBhcmFtc1NvcnRUeXBlPFJlcXVlc3QgZXh0ZW5kcyBHZXRBbGxQYXJhbXNEZWZhdWx0V29GaWx0ZXJzVHlwZTxHZXRBbGxQYXJhbXNTb3J0VHlwZTxhbnksIGFueT5bXSB8IHN0cmluZywgYW55Pj4gPVxuICAgIE5vbk51bGxhYmxlPFJlcXVlc3RbJ3NvcnQnXT4gZXh0ZW5kcyBBcnJheTxpbmZlciBVPiB8IHN0cmluZyA/ICgncHJvcGVydHknIGV4dGVuZHMga2V5b2YgVSA/IE5vbk51bGxhYmxlPFVbJ3Byb3BlcnR5J10+IDogbmV2ZXIpIDogbmV2ZXI7XG5cbmV4cG9ydCB0eXBlIEdldEFsbEh0dHBSZXNwb25zZVR5cGU8TW9kZWw+ID0ge2RhdGE/OiBBcnJheTxNb2RlbD47IHRvdGFsQ291bnQ/OiBudW1iZXJ9IHwgSHR0cFJlc3BvbnNlPHtkYXRhPzogQXJyYXk8TW9kZWw+OyB0b3RhbENvdW50PzogbnVtYmVyfT47XG5cbmV4cG9ydCB0eXBlIEFwaVNlcnZpY2VHZXRBbGxGaWx0ZXJUeXBlPFxuICAgIFNlcnZpY2UsXG4gICAgTW9kZWwsXG4gICAgRm4gZXh0ZW5kcyBDbGFzc0Z1bmN0aW9uS2V5c1dpdGhBbnlBcmdzQW5kUmV0dXJuVHlwZTxTZXJ2aWNlLCBPYnNlcnZhYmxlPEdldEFsbEh0dHBSZXNwb25zZVR5cGU8TW9kZWw+Pj5cbj4gPSBTZXJ2aWNlW0ZuXSBleHRlbmRzICguLi5hcmdzOiBhbnlbXSkgPT4gYW55ID8gTm9uTnVsbGFibGU8UGFyYW1ldGVyczxTZXJ2aWNlW0ZuXT5bMF0+IDogbmV2ZXI7XG5cbmV4cG9ydCB0eXBlIEV4dHJhY3RTZXJ2aWNlR2V0QWxsRGF0YVR5cGU8U2VydmljZSwgRm4gZXh0ZW5kcyBrZXlvZiBTZXJ2aWNlPiA9IFNlcnZpY2VbRm5dIGV4dGVuZHMgKFxuICAgIC4uLmFyZ3M6IGFueVtdXG4pID0+IE9ic2VydmFibGU8e2RhdGE/OiBBcnJheTxpbmZlciBNb2RlbD59IHwgSHR0cFJlc3BvbnNlPHtkYXRhPzogQXJyYXk8aW5mZXIgTW9kZWw+fT4+XG4gICAgPyBNb2RlbFxuICAgIDogbmV2ZXI7XG4iXX0=
@@ -1,5 +0,0 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './index';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVkaXVzaW5jLW1uZy1jb21tb25zLWRhdGEtYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL21lZGl1c2luYy1tbmctY29tbW9ucy1kYXRhLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
@@ -1,127 +0,0 @@
1
- import { Observable } from 'rxjs';
2
- import { toObservable, valueToDefined } from '@mediusinc/mng-commons/core';
3
- import { FilterTypeEnum } from '@mediusinc/mng-commons/filter';
4
- import { lookupDataProvider } from '@mediusinc/mng-commons/form/api';
5
- /**
6
- * Maps a property type to its corresponding filter type enum and applies default
7
- * filter options if no custom options are provided. If the property type is not recognized,
8
- * it returns a filter type value of null.
9
- *
10
- * @param propertyType - The property type to convert.
11
- * @param [opts] - The custom options to use for conversion.
12
- */
13
- export function convertPropertyTypeToFilterType(propertyType, opts) {
14
- let filterType;
15
- let returnOpts;
16
- switch (propertyType?.toLowerCase()) {
17
- case 'date':
18
- filterType = FilterTypeEnum.Date;
19
- returnOpts = opts?.dateOpts
20
- ? opts.dateOpts
21
- : {
22
- displayFormat: 'dd.MM.YYYY',
23
- applyFromDisplayFormat: true
24
- };
25
- break;
26
- case 'datetime':
27
- case 'date_time':
28
- case 'date-time':
29
- filterType = FilterTypeEnum.Date;
30
- returnOpts = opts?.dateOpts ? opts.dateOpts : { displayFormat: 'dd.MM.YYYY HH:mm', applyFromDisplayFormat: true };
31
- break;
32
- case 'string':
33
- case 'text':
34
- filterType = FilterTypeEnum.String;
35
- break;
36
- case 'enum':
37
- filterType = FilterTypeEnum.LookupEnum;
38
- break;
39
- case 'boolean':
40
- case 'bool':
41
- filterType = FilterTypeEnum.Boolean;
42
- break;
43
- case 'float':
44
- case 'double':
45
- case 'decimal':
46
- filterType = FilterTypeEnum.Number;
47
- returnOpts = opts?.numberOpts ? opts.numberOpts : { displayFormat: '1.1-30' };
48
- break;
49
- case 'integer':
50
- case 'int':
51
- case 'long':
52
- filterType = FilterTypeEnum.Number;
53
- returnOpts = opts?.numberOpts;
54
- break;
55
- default:
56
- filterType = null;
57
- }
58
- return { filterType, opts: returnOpts };
59
- }
60
- /**
61
- * Converts an object of properties and types into an array of filterable properties with the corresponding filter types and options.
62
- * @param properties - The object containing the properties.
63
- * @param [opts] - Custom filter options.
64
- */
65
- export function convertPropertyToFilterGenericProperties(properties, opts) {
66
- return Object.keys(properties).reduce((filterableProperties, key) => {
67
- const { filterType, opts: filterOpts } = convertPropertyTypeToFilterType(properties[key], opts);
68
- if (filterType !== null) {
69
- filterableProperties.push({
70
- property: key,
71
- type: filterType,
72
- opts: filterOpts
73
- });
74
- }
75
- return filterableProperties;
76
- }, []);
77
- }
78
- /**
79
- * Maps an Observable of properties to filter generic properties.
80
- */
81
- export function mapToFilterGenericProperties(opts) {
82
- return function (source) {
83
- return new Observable(subscriber => {
84
- return source.subscribe({
85
- next(value) {
86
- subscriber.next(convertPropertyToFilterGenericProperties(value, opts));
87
- },
88
- error: err => {
89
- subscriber.error(err);
90
- }
91
- });
92
- });
93
- };
94
- }
95
- /**
96
- * Creates a data provider for generic filter properties that can be used with the TableDescriptor's generic filter functionality.
97
- *
98
- * @param serviceType - The service to fetch the properties from.
99
- * @param lookupFn - The name of the service function to call for properties or function impl returning properties.
100
- * @param [opts] - Optional custom options for filter descriptors, such as date and number formatting.
101
- */
102
- export function filterPropertyLookupProvider(serviceType, lookupFn, opts) {
103
- if (typeof lookupFn === 'function') {
104
- return lookupDataProvider({ service: serviceType }).withLookup((_, service) => toObservable(lookupFn(service)).pipe(mapToFilterGenericProperties(opts)));
105
- }
106
- else {
107
- return lookupDataProvider({ service: serviceType }).withLookup((_, service) => service[lookupFn]().pipe(mapToFilterGenericProperties(opts)));
108
- }
109
- }
110
- /**
111
- * Creates a data provider for generic filter value suggestions that can be used with the TableDescriptor's generic filter functionality.
112
- *
113
- * @param service - The service to use for suggesting filter values.
114
- * @param lookupFn - The function name of the service to call for suggestion or function impl returning suggestions.
115
- */
116
- export function filterValueSuggestionLookupProvider(service, lookupFn) {
117
- if (typeof lookupFn === 'function') {
118
- return lookupDataProvider({ service }).withLookup((params, service, search) => lookupFn(service, valueToDefined(params?.filters?.['field']?.value), search));
119
- }
120
- else {
121
- return lookupDataProvider({ service }).withLookup((params, service, search) => service[lookupFn]({
122
- field: valueToDefined(params?.filters?.['field']?.value).toString(),
123
- text: search
124
- }));
125
- }
126
- }
127
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generic-filters.js","sourceRoot":"","sources":["../../../../tableview/src/filter/generic-filters.ts"],"names":[],"mappings":"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","sourcesContent":["import {Type} from '@angular/core';\n\nimport {Observable, OperatorFunction} from 'rxjs';\n\nimport {ClassFunctionKeysWithParamAndReturnType, ClassFunctionKeysWithReturnType, ItemOrObservable, toObservable, valueToDefined} from '@mediusinc/mng-commons/core';\nimport {FilterDateOptsType, FilterGenericProperty, FilterNumberOptsType, FilterTypeEnum} from '@mediusinc/mng-commons/filter';\nimport {LookupDataProviderInst, lookupDataProvider} from '@mediusinc/mng-commons/form/api';\n\nexport interface FilterGenericPropertyOptsType {\n    numberOpts?: FilterNumberOptsType;\n    dateOpts?: FilterDateOptsType;\n}\n\n/**\n * Maps a property type to its corresponding filter type enum and applies default\n * filter options if no custom options are provided. If the property type is not recognized,\n * it returns a filter type value of null.\n *\n * @param propertyType - The property type to convert.\n * @param [opts] - The custom options to use for conversion.\n */\nexport function convertPropertyTypeToFilterType(\n    propertyType?: string,\n    opts?: FilterGenericPropertyOptsType\n): {filterType: FilterTypeEnum | null; opts?: FilterDateOptsType | FilterNumberOptsType} {\n    let filterType: FilterTypeEnum | null;\n    let returnOpts: FilterDateOptsType | FilterNumberOptsType | undefined;\n\n    switch (propertyType?.toLowerCase()) {\n        case 'date':\n            filterType = FilterTypeEnum.Date;\n            returnOpts = opts?.dateOpts\n                ? opts.dateOpts\n                : {\n                      displayFormat: 'dd.MM.YYYY',\n                      applyFromDisplayFormat: true\n                  };\n            break;\n        case 'datetime':\n        case 'date_time':\n        case 'date-time':\n            filterType = FilterTypeEnum.Date;\n            returnOpts = opts?.dateOpts ? opts.dateOpts : {displayFormat: 'dd.MM.YYYY HH:mm', applyFromDisplayFormat: true};\n            break;\n        case 'string':\n        case 'text':\n            filterType = FilterTypeEnum.String;\n            break;\n        case 'enum':\n            filterType = FilterTypeEnum.LookupEnum;\n            break;\n        case 'boolean':\n        case 'bool':\n            filterType = FilterTypeEnum.Boolean;\n            break;\n        case 'float':\n        case 'double':\n        case 'decimal':\n            filterType = FilterTypeEnum.Number;\n            returnOpts = opts?.numberOpts ? opts.numberOpts : {displayFormat: '1.1-30'};\n            break;\n        case 'integer':\n        case 'int':\n        case 'long':\n            filterType = FilterTypeEnum.Number;\n            returnOpts = opts?.numberOpts;\n            break;\n        default:\n            filterType = null;\n    }\n\n    return {filterType, opts: returnOpts};\n}\n\ntype FilterGenericPropertiesMetadataType = {[key: string]: string | undefined};\n\n/**\n * Converts an object of properties and types into an array of filterable properties with the corresponding filter types and options.\n * @param properties - The object containing the properties.\n * @param [opts] - Custom filter options.\n */\nexport function convertPropertyToFilterGenericProperties(properties: FilterGenericPropertiesMetadataType, opts?: FilterGenericPropertyOptsType): FilterGenericProperty[] {\n    return Object.keys(properties).reduce<Array<FilterGenericProperty>>((filterableProperties, key) => {\n        const {filterType, opts: filterOpts} = convertPropertyTypeToFilterType(properties[key], opts);\n        if (filterType !== null) {\n            filterableProperties.push({\n                property: key,\n                type: filterType,\n                opts: filterOpts\n            });\n        }\n        return filterableProperties;\n    }, []);\n}\n\n/**\n * Maps an Observable of properties to filter generic properties.\n */\nexport function mapToFilterGenericProperties(opts?: FilterGenericPropertyOptsType): OperatorFunction<FilterGenericPropertiesMetadataType, FilterGenericProperty[]> {\n    return function (source: Observable<FilterGenericPropertiesMetadataType>): Observable<FilterGenericProperty[]> {\n        return new Observable(subscriber => {\n            return source.subscribe({\n                next(value) {\n                    subscriber.next(convertPropertyToFilterGenericProperties(value, opts));\n                },\n                error: err => {\n                    subscriber.error(err);\n                }\n            });\n        });\n    };\n}\n\ntype FilterPropertyLookupFnType<Service> = (service: Service) => ItemOrObservable<FilterGenericPropertiesMetadataType>;\n\n/**\n * Creates a data provider for generic filter properties that can be used with the TableDescriptor's generic filter functionality.\n *\n * @param serviceType - The service to fetch the properties from.\n * @param lookupFn - The name of the service function to call for properties or function impl returning properties.\n * @param [opts] - Optional custom options for filter descriptors, such as date and number formatting.\n */\nexport function filterPropertyLookupProvider<Service>(\n    serviceType: Type<Service>,\n    lookupFn: FilterPropertyLookupFnType<Service> | ClassFunctionKeysWithReturnType<Service, Observable<FilterGenericPropertiesMetadataType>>,\n    opts?: FilterGenericPropertyOptsType\n) {\n    if (typeof lookupFn === 'function') {\n        return lookupDataProvider<FilterGenericProperty, Service>({service: serviceType}).withLookup((_, service) =>\n            toObservable(lookupFn(service)).pipe(mapToFilterGenericProperties(opts))\n        );\n    } else {\n        return lookupDataProvider<FilterGenericProperty, Service>({service: serviceType}).withLookup((_, service) =>\n            (service as any)[lookupFn]().pipe(mapToFilterGenericProperties(opts))\n        );\n    }\n}\n\ntype FilterValueSuggestionLookupFnType<Service> = (service: Service, field: string, search?: string) => ItemOrObservable<string[]>;\n\n/**\n * Creates a data provider for generic filter value suggestions that can be used with the TableDescriptor's generic filter functionality.\n *\n * @param service - The service to use for suggesting filter values.\n * @param lookupFn - The function name of the service to call for suggestion or function impl returning suggestions.\n */\nexport function filterValueSuggestionLookupProvider<Service>(\n    service: Type<Service>,\n    lookupFn: FilterValueSuggestionLookupFnType<Service> | ClassFunctionKeysWithParamAndReturnType<Service, {field: string; text?: string}, Observable<string[]>>\n): LookupDataProviderInst<string, Service, string, 'field'> {\n    if (typeof lookupFn === 'function') {\n        return lookupDataProvider<string, Service, string, 'field'>({service}).withLookup((params, service, search?) =>\n            lookupFn(service, valueToDefined(params?.filters?.['field']?.value) as string, search)\n        );\n    } else {\n        return lookupDataProvider<string, Service, string, 'field'>({service}).withLookup((params, service, search?) =>\n            (service as any)[lookupFn]({\n                field: valueToDefined(params?.filters?.['field']?.value).toString(),\n                text: search\n            })\n        );\n    }\n}\n"]}