@mediusinc/mng-commons-data-api 5.3.0-rc.3 → 5.3.0-rc.5

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.
@@ -183,4 +183,4 @@ export function executeGetAll(service, getAllFn, params) {
183
183
  export function executeGetAllAsPost(service, getAllFn, params) {
184
184
  return getAllFn.bind(service)(toGetAllParams(params)).pipe(mapToDataList());
185
185
  }
186
- //# 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    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 {GetAllParamsFilterMatchType, GetAllParamsFilterType, GetAllParamsType, GetAllParamsUrlQueryType} 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\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 = {} 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) {\n        res.globalFilter = params.search;\n    }\n\n    if (Array.isArray(params.sort) && params.sort.length > 0) {\n        res.sort = dataListParamsSortToUrlQuery(params as DataListParams);\n    }\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 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 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"]}
186
+ //# 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    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 {GetAllParamsFilterMatchType, GetAllParamsFilterType, GetAllParamsType, GetAllParamsUrlQueryType} 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\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 = {} 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) {\n        res.globalFilter = params.search;\n    }\n\n    if (Array.isArray(params.sort) && params.sort.length > 0) {\n        res.sort = dataListParamsSortToUrlQuery(params as DataListParams);\n    }\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 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 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 +1 @@
1
- {"version":3,"file":"mediusinc-mng-commons-data-api.mjs","sources":["../../src/lib/helpers/get-all-params.ts","../../src/index.ts","../../src/mediusinc-mng-commons-data-api.ts"],"sourcesContent":["import {Observable} from 'rxjs';\n\nimport {\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 {GetAllParamsFilterMatchType, GetAllParamsFilterType, GetAllParamsType, GetAllParamsUrlQueryType} 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\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 = {} 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) {\n res.globalFilter = params.search;\n }\n\n if (Array.isArray(params.sort) && params.sort.length > 0) {\n res.sort = dataListParamsSortToUrlQuery(params as DataListParams);\n }\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 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 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","// helpers\nexport * from './lib/helpers/get-all-params';\n\n// models\nexport * from './lib/models/api-version.model';\nexport * from './lib/models/request-params.model';\nexport * from './lib/models/schema.model';\n\n// types\nexport * from './lib/types/extract-get-all-params.type';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"mediusinc-mng-commons-data-api.mjs","sources":["../../src/lib/helpers/get-all-params.ts","../../src/index.ts","../../src/mediusinc-mng-commons-data-api.ts"],"sourcesContent":["import {Observable} from 'rxjs';\n\nimport {\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 {GetAllParamsFilterMatchType, GetAllParamsFilterType, GetAllParamsType, GetAllParamsUrlQueryType} 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\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 = {} 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) {\n res.globalFilter = params.search;\n }\n\n if (Array.isArray(params.sort) && params.sort.length > 0) {\n res.sort = dataListParamsSortToUrlQuery(params as DataListParams);\n }\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 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 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","// helpers\nexport * from './lib/helpers/get-all-params';\n\n// models\nexport * from './lib/models/api-version.model';\nexport * from './lib/models/request-params.model';\nexport * from './lib/models/schema.model';\n\n// types\nexport * from './lib/types/extract-get-all-params.type';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,9 +1,9 @@
1
1
  {
2
2
  "name": "@mediusinc/mng-commons-data-api",
3
- "version": "5.3.0-rc.3",
3
+ "version": "5.3.0-rc.5",
4
4
  "peerDependencies": {
5
5
  "@angular/core": "^17.3.0 || ^18.0.0",
6
- "@mediusinc/mng-commons": "~5.3.0-rc.3"
6
+ "@mediusinc/mng-commons": "~5.3.0-rc.5"
7
7
  },
8
8
  "dependencies": {
9
9
  "tslib": "^2.3.0"
@@ -130,7 +130,7 @@ export declare class SchemaFieldsBuilder<Model, Parent = unknown, SchModel = Mod
130
130
  *
131
131
  * @return The created lookup field.
132
132
  */
133
- addLookup<Property extends Extract<keyof Model, keyof SchModel>, LookupModel = NonNullable<Model[Property]>>(property: Property): FieldLookupDescriptor<LookupModel, Model, undefined, Model[Property], Parent>;
133
+ addLookup<Property extends Extract<keyof Model, keyof SchModel>, LookupModel = NonNullable<Model[Property]>>(property: Property): FieldLookupDescriptor<LookupModel, Model, undefined, Model[Property], Parent, keyof LookupModel, keyof LookupModel>;
134
134
  /**
135
135
  * <em>Experimental:</em> Adds a lookup field where property schema is manually provided.
136
136
  * {EditorDescriptorInt.addFieldLookup} is used to create field and ${setFieldBasicOptionsFromSchema} to add basic field's options from schema.
@@ -142,7 +142,7 @@ export declare class SchemaFieldsBuilder<Model, Parent = unknown, SchModel = Mod
142
142
  *
143
143
  * @return The created lookup field.
144
144
  */
145
- addLookupFromSchema<Property extends keyof Model>(property: Property, schemaProperty: SchemaProperty): FieldLookupDescriptor<NonNullable<Model[Property]>, Model, undefined, Model[Property], Parent>;
145
+ addLookupFromSchema<Property extends keyof Model>(property: Property, schemaProperty: SchemaProperty): FieldLookupDescriptor<NonNullable<Model[Property]>, Model, undefined, Model[Property], Parent, keyof NonNullable<Model[Property]>, keyof NonNullable<Model[Property]>>;
146
146
  /**
147
147
  * <em>Experimental:</em> Adds a lookup field.
148
148
  * {EditorDescriptorInt.addFieldLookupWithOptionsValueProperty} is used to create field and ${setFieldBasicOptionsFromSchema} to add basic field's options from schema.
@@ -155,7 +155,7 @@ export declare class SchemaFieldsBuilder<Model, Parent = unknown, SchModel = Mod
155
155
  *
156
156
  * @return The created lookup field.
157
157
  */
158
- addLookupWithOptionsValueProperty<Property extends Extract<keyof Model, keyof SchModel>, LookupModel, LookupValueProperty extends KeyofAndOfType<LookupModel, Model[Property]>>(property: Property, type: TypeDescriptor<LookupModel>, lookupOptionsValueProperty: LookupValueProperty): FieldLookupDescriptor<LookupModel, Model, undefined, Model[Property], Parent>;
158
+ addLookupWithOptionsValueProperty<Property extends Extract<keyof Model, keyof SchModel>, LookupModel, LookupValueProperty extends KeyofAndOfType<LookupModel, Model[Property]>>(property: Property, type: TypeDescriptor<LookupModel>, lookupOptionsValueProperty: LookupValueProperty): FieldLookupDescriptor<LookupModel, Model, undefined, Model[Property], Parent, keyof LookupModel, keyof LookupModel>;
159
159
  /**
160
160
  * <em>Experimental:</em> Adds a lookup field where property schema is manually provided.
161
161
  * {EditorDescriptorInt.addFieldLookupWithOptionsValueProperty} is used to create field and ${setFieldBasicOptionsFromSchema} to add basic field's options from schema.
@@ -169,7 +169,7 @@ export declare class SchemaFieldsBuilder<Model, Parent = unknown, SchModel = Mod
169
169
  *
170
170
  * @return The created lookup field.
171
171
  */
172
- addLookupWithOptionsValuePropertyFromSchema<Property extends keyof Model, LookupModel, LookupValueProperty extends KeyofAndOfType<LookupModel, Model[Property]>>(property: Property, type: TypeDescriptor<LookupModel>, lookupOptionsValueProperty: LookupValueProperty, schemaProperty: SchemaProperty): FieldLookupDescriptor<LookupModel, Model, undefined, Model[Property], Parent>;
172
+ addLookupWithOptionsValuePropertyFromSchema<Property extends keyof Model, LookupModel, LookupValueProperty extends KeyofAndOfType<LookupModel, Model[Property]>>(property: Property, type: TypeDescriptor<LookupModel>, lookupOptionsValueProperty: LookupValueProperty, schemaProperty: SchemaProperty): FieldLookupDescriptor<LookupModel, Model, undefined, Model[Property], Parent, keyof LookupModel, keyof LookupModel>;
173
173
  /**
174
174
  * <em>Experimental:</em> Adds a lookup field.
175
175
  * {EditorDescriptorInt.addFieldLookupWithProvider} is used to create field and ${setFieldBasicOptionsFromSchema} to add basic field's options from schema.
@@ -181,7 +181,7 @@ export declare class SchemaFieldsBuilder<Model, Parent = unknown, SchModel = Mod
181
181
  *
182
182
  * @return The created lookup field.
183
183
  */
184
- addLookupWithProvider<Property extends Extract<keyof Model, keyof SchModel>, Service, LookupModel = NonNullable<Model[Property]>>(property: Property, provider: FieldLookupProviderType<LookupModel, Service>): FieldLookupDescriptor<LookupModel, Model, Service, Model[Property], Parent>;
184
+ addLookupWithProvider<Property extends Extract<keyof Model, keyof SchModel>, Service, LookupModel = NonNullable<Model[Property]>>(property: Property, provider: FieldLookupProviderType<LookupModel, Service>): FieldLookupDescriptor<LookupModel, Model, Service, Model[Property], Parent, keyof LookupModel, keyof LookupModel>;
185
185
  /**
186
186
  * <em>Experimental:</em> Adds a lookup field where property schema is manually provided.
187
187
  * {EditorDescriptorInt.addFieldLookupWithProvider} is used to create field and ${setFieldBasicOptionsFromSchema} to add basic field's options from schema.
@@ -194,7 +194,7 @@ export declare class SchemaFieldsBuilder<Model, Parent = unknown, SchModel = Mod
194
194
  *
195
195
  * @return The created lookup field.
196
196
  */
197
- addLookupWithProviderFromSchema<Property extends keyof Model, Service, LookupModel = NonNullable<Model[Property]>>(property: Property, provider: FieldLookupProviderType<LookupModel, Service>, schemaProperty: SchemaProperty): FieldLookupDescriptor<LookupModel, Model, Service, Model[Property], Parent>;
197
+ addLookupWithProviderFromSchema<Property extends keyof Model, Service, LookupModel = NonNullable<Model[Property]>>(property: Property, provider: FieldLookupProviderType<LookupModel, Service>, schemaProperty: SchemaProperty): FieldLookupDescriptor<LookupModel, Model, Service, Model[Property], Parent, keyof LookupModel, keyof LookupModel>;
198
198
  /**
199
199
  * <em>Experimental:</em> Adds a lookup field.
200
200
  * {EditorDescriptorInt.addFieldLookupWithProviderAndOptionsValueProperty} is used to create field and ${setFieldBasicOptionsFromSchema} to add basic field's options from schema.
package/version-info.json CHANGED
@@ -1,11 +1,11 @@
1
1
  {
2
2
  "name": "@mediusinc/mng-commons-data-api",
3
- "version": "5.3.0-rc.3",
4
- "tag": "v5.2.0-rc.2",
5
- "distance": 39,
6
- "hash": "6e974648",
3
+ "version": "5.3.0-rc.5",
4
+ "tag": "v5.3.0-rc.5",
5
+ "distance": 0,
6
+ "hash": "de1259e1",
7
7
  "dirty": true,
8
- "semver": "5.2.0-rc.2+39.g6e974648.dirty",
8
+ "semver": "5.3.0-rc.5+0.gde1259e1.dirty",
9
9
  "buildTimestamp": null,
10
- "raw": "v5.2.0-rc.2-39-6e974648-dirty"
10
+ "raw": "v5.3.0-rc.5-de1259e1-dirty"
11
11
  }