UNPKG

@netgrif/components-core

Version:

Netgrif Application engine frontend core Angular library

114 lines 13.1 kB
import { PaginationParams } from '../../utility/pagination/pagination-params'; /** * The class that contains behavior common to all resource services. * * Mostly endpoint URL resolution and utility functions for response parsing. */ export class AbstractResourceService { _resourceProvider; configurationService; _SERVER_URL; resourceName; /** * @param resourceName the identifier of the desired endpoint from configuration, found in * {@link SetAuthAndResourcesAddress}.[resources]{@link Resources}. * @param _resourceProvider `ResourceProvider` instance * @param configurationService `ConfigurationService` instance */ constructor(resourceName, _resourceProvider, configurationService) { this._resourceProvider = _resourceProvider; this.configurationService = configurationService; this.resourceName = resourceName; } get SERVER_URL() { if (!this._SERVER_URL) { this._SERVER_URL = this.getResourceAddress(this.resourceName); } return this._SERVER_URL; } /** * Get URL form nae.json - resources * @param name - ID property */ getResourceAddress(name) { let URL = ''; const resourcesArray = this.configurationService.getConfigurationSubtree(['providers', 'resources']); if (resourcesArray instanceof Array) { resourcesArray.forEach(resource => { if (resource.name === name) { URL = resource.address; } }); } else if (resourcesArray && resourcesArray.name === name) { URL = resourcesArray.address; } return URL; } /** * Parses a response `response` into a {@link Page} instance * @param response - response object * @param propertiesParams - plural form of the resource name, that is used to extract the data. Eg. "cases". */ getResourcePage(response, propertiesParams) { if (!response) { return response; } const defaultPage = { number: -1, size: 0, totalPages: 0, totalElements: 0 }; return { content: this.changeType(response, propertiesParams), pagination: response.hasOwnProperty(PaginationParams.PAGE_NUMBER) ? response.page : defaultPage }; } /** * Extracts data from the response `response` into an object with better usability. * @param response - response object * @param propertiesParams - plural form of the resource name, that is used to extract the data. Eg. "cases". */ changeType(response, propertiesParams) { if (!response) { return response; } if (response.hasOwnProperty('_embedded')) { return propertiesParams && response._embedded.hasOwnProperty(propertiesParams) ? response._embedded[propertiesParams] : response._embedded; } else { return response; } } /** * Converts a Spring-style paginated response into the application's Page<T> format. * @param response The raw response from backend (Spring `PageImpl` structure). * @returns Converted Page<T> object. */ mapToPage(response) { if (!response || !response.content) { return { content: [], pagination: { size: 0, totalElements: 0, totalPages: 0, number: 0 } }; } return { content: response.content, pagination: { size: response.size, totalElements: response.totalElements, totalPages: response.totalPages, number: response.number } }; } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-resource.service.js","sourceRoot":"","sources":["../../../../../../projects/netgrif-components-core/src/lib/resources/abstract-endpoint/abstract-resource.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {ResourceProvider} from '../resource-provider.service';\nimport {ConfigurationService} from '../../configuration/configuration.service';\nimport {Page} from '../interface/page';\nimport {Pagination} from '../interface/pagination';\nimport {PaginationParams} from '../../utility/pagination/pagination-params';\n\n/**\n * The class that contains behavior common to all resource services.\n *\n * Mostly endpoint URL resolution and utility functions for response parsing.\n */\nexport abstract class AbstractResourceService {\n\n    private _SERVER_URL: string;\n    private readonly resourceName: string;\n\n    /**\n     * @param resourceName the identifier of the desired endpoint from configuration, found in\n     * {@link SetAuthAndResourcesAddress}.[resources]{@link Resources}.\n     * @param _resourceProvider `ResourceProvider` instance\n     * @param configurationService `ConfigurationService` instance\n     */\n    protected constructor(resourceName: string,\n                          protected _resourceProvider: ResourceProvider,\n                          protected configurationService: ConfigurationService) {\n        this.resourceName = resourceName;\n    }\n\n    protected get SERVER_URL(): string {\n        if (!this._SERVER_URL) {\n            this._SERVER_URL = this.getResourceAddress(this.resourceName);\n        }\n        return this._SERVER_URL;\n    }\n\n    /**\n     * Get URL form nae.json - resources\n     * @param name - ID property\n     */\n    protected getResourceAddress(name: string): string {\n        let URL = '';\n\n        const resourcesArray = this.configurationService.getConfigurationSubtree(['providers', 'resources']);\n\n        if (resourcesArray instanceof Array) {\n            resourcesArray.forEach(resource => {\n                if (resource.name === name) {\n                    URL = resource.address;\n                }\n            });\n        } else if (resourcesArray && resourcesArray.name === name) {\n            URL = resourcesArray.address;\n        }\n        return URL;\n    }\n\n    /**\n     * Parses a response `response` into a {@link Page} instance\n     * @param response - response object\n     * @param propertiesParams - plural form of the resource name, that is used to extract the data. Eg. \"cases\".\n     */\n    protected getResourcePage<T>(response: any, propertiesParams: string): Page<T> {\n        if (!response) {\n            return response;\n        }\n        const defaultPage: Pagination = {\n            number: -1,\n            size: 0,\n            totalPages: 0,\n            totalElements: 0\n        };\n\n        return {\n            content: this.changeType<Array<T>>(response, propertiesParams),\n            pagination: response.hasOwnProperty(PaginationParams.PAGE_NUMBER) ? response.page : defaultPage\n        };\n    }\n\n    /**\n     * Extracts data from the response `response` into an object with better usability.\n     * @param response - response object\n     * @param propertiesParams - plural form of the resource name, that is used to extract the data. Eg. \"cases\".\n     */\n    protected changeType<T>(response: any, propertiesParams: string): T {\n        if (!response) {\n            return response;\n        }\n        if (response.hasOwnProperty('_embedded')) {\n            return propertiesParams && response._embedded.hasOwnProperty(propertiesParams)\n                ? response._embedded[propertiesParams]\n                : response._embedded;\n        } else {\n            return response;\n        }\n    }\n\n    /**\n     * Converts a Spring-style paginated response into the application's Page<T> format.\n     * @param response The raw response from backend (Spring `PageImpl` structure).\n     * @returns Converted Page<T> object.\n     */\n    protected mapToPage<T>(response: any): Page<T> {\n        if (!response || !response.content) {\n            return {\n                content: [],\n                pagination: {\n                    size: 0,\n                    totalElements: 0,\n                    totalPages: 0,\n                    number: 0\n                }\n            };\n        }\n\n        return {\n            content: response.content,\n            pagination: {\n                size: response.size,\n                totalElements: response.totalElements,\n                totalPages: response.totalPages,\n                number: response.number\n            }\n        };\n    }\n}\n"]}