@experteam-mx/ngx-services 18.9.13 → 18.9.15
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +24 -24
- package/esm2022/lib/apis/api-billing-do.service.mjs +1 -1
- package/esm2022/lib/apis/api-billing-gt.service.mjs +1 -1
- package/esm2022/lib/apis/api-billing-mx.service.mjs +1 -1
- package/esm2022/lib/apis/api-billing-pa.service.mjs +1 -1
- package/esm2022/lib/apis/api-billing-sv.service.mjs +1 -1
- package/esm2022/lib/apis/api-cash-operations.service.mjs +1 -1
- package/esm2022/lib/apis/api-catalogs.service.mjs +1 -1
- package/esm2022/lib/apis/api-companies.service.mjs +2 -2
- package/esm2022/lib/apis/api-composition.service.mjs +1 -1
- package/esm2022/lib/apis/api-customs.service.mjs +1 -1
- package/esm2022/lib/apis/api-discounts.service.mjs +1 -1
- package/esm2022/lib/apis/api-e-tools-auto-billing.service.mjs +1 -1
- package/esm2022/lib/apis/api-events.service.mjs +1 -1
- package/esm2022/lib/apis/api-external-ops.service.mjs +87 -0
- package/esm2022/lib/apis/api-inventories.service.mjs +15 -1
- package/esm2022/lib/apis/api-invoices.service.mjs +1 -1
- package/esm2022/lib/apis/api-notifications.service.mjs +1 -1
- package/esm2022/lib/apis/api-open-items.service.mjs +1 -1
- package/esm2022/lib/apis/api-quote.service.mjs +87 -0
- package/esm2022/lib/apis/api-reports.service.mjs +29 -1
- package/esm2022/lib/apis/api-security.service.mjs +1 -1
- package/esm2022/lib/apis/api-services.service.mjs +1 -1
- package/esm2022/lib/apis/api-shipments.service.mjs +1 -1
- package/esm2022/lib/apis/api-supplies.service.mjs +1 -1
- package/esm2022/lib/apis/models/api-billing-do.interfaces.mjs +1 -1
- package/esm2022/lib/apis/models/api-billing-do.types.mjs +1 -1
- package/esm2022/lib/apis/models/api-billing-mx.interfaces.mjs +1 -1
- package/esm2022/lib/apis/models/api-billing-mx.types.mjs +1 -1
- package/esm2022/lib/apis/models/api-billing-pa.interfaces.mjs +1 -1
- package/esm2022/lib/apis/models/api-billing-pa.types.mjs +1 -1
- package/esm2022/lib/apis/models/api-billing-sv.interfaces.mjs +1 -1
- package/esm2022/lib/apis/models/api-billing-sv.types.mjs +1 -1
- package/esm2022/lib/apis/models/api-billing.models.mjs +1 -1
- package/esm2022/lib/apis/models/api-cash-operations.interfaces.mjs +1 -1
- package/esm2022/lib/apis/models/api-cash-operations.types.mjs +1 -1
- package/esm2022/lib/apis/models/api-catalog.enum.mjs +1 -1
- package/esm2022/lib/apis/models/api-catalog.interfaces.mjs +1 -1
- package/esm2022/lib/apis/models/api-catalog.types.mjs +1 -1
- package/esm2022/lib/apis/models/api-companies.interfaces.mjs +1 -1
- package/esm2022/lib/apis/models/api-companies.types.mjs +1 -1
- package/esm2022/lib/apis/models/api-composition.interfaces.mjs +1 -1
- package/esm2022/lib/apis/models/api-composition.types.mjs +1 -1
- package/esm2022/lib/apis/models/api-customs.interfaces.mjs +1 -1
- package/esm2022/lib/apis/models/api-customs.types.mjs +1 -1
- package/esm2022/lib/apis/models/api-discounts.interfaces.mjs +1 -1
- package/esm2022/lib/apis/models/api-discounts.types.mjs +1 -1
- package/esm2022/lib/apis/models/api-e-tools-auto-billing.interfaces.mjs +1 -1
- package/esm2022/lib/apis/models/api-e-tools-auto-billing.types.mjs +1 -1
- package/esm2022/lib/apis/models/api-events.enum.mjs +1 -1
- package/esm2022/lib/apis/models/api-events.interfaces.mjs +1 -1
- package/esm2022/lib/apis/models/api-events.types.mjs +1 -1
- package/esm2022/lib/apis/models/api-external-ops.interfaces.mjs +2 -0
- package/esm2022/lib/apis/models/api-external-ops.types.mjs +2 -0
- package/esm2022/lib/apis/models/api-inventories.enum.mjs +1 -1
- package/esm2022/lib/apis/models/api-inventories.interfaces.mjs +1 -1
- package/esm2022/lib/apis/models/api-inventories.types.mjs +1 -1
- package/esm2022/lib/apis/models/api-invoices.interfaces.mjs +1 -1
- package/esm2022/lib/apis/models/api-invoices.types.mjs +1 -1
- package/esm2022/lib/apis/models/api-notifications.interfaces.mjs +1 -1
- package/esm2022/lib/apis/models/api-notifications.types.mjs +1 -1
- package/esm2022/lib/apis/models/api-open-items.interfaces.mjs +1 -1
- package/esm2022/lib/apis/models/api-open-items.types.mjs +1 -1
- package/esm2022/lib/apis/models/api-quote.interfaces.mjs +2 -0
- package/esm2022/lib/apis/models/api-quote.types.mjs +2 -0
- package/esm2022/lib/apis/models/api-reports.interfaces.mjs +1 -1
- package/esm2022/lib/apis/models/api-reports.types.mjs +1 -1
- package/esm2022/lib/apis/models/api-security.interfaces.mjs +1 -1
- package/esm2022/lib/apis/models/api-security.types.mjs +1 -1
- package/esm2022/lib/apis/models/api-services.interfaces.mjs +1 -1
- package/esm2022/lib/apis/models/api-services.types.mjs +1 -1
- package/esm2022/lib/apis/models/api-shipments.enums.mjs +1 -1
- package/esm2022/lib/apis/models/api-shipments.interfaces.mjs +1 -1
- package/esm2022/lib/apis/models/api-shipments.types.mjs +1 -1
- package/esm2022/lib/apis/models/api-supplies.interfaces.mjs +1 -1
- package/esm2022/lib/apis/models/api-supplies.types.mjs +1 -1
- package/esm2022/lib/apis/models/api.models.mjs +1 -1
- package/esm2022/lib/cypher/crypto.service.mjs +1 -1
- package/esm2022/lib/helpers/files.mjs +1 -1
- package/esm2022/lib/helpers/http.mjs +1 -1
- package/esm2022/lib/interceptors/api-headers.interceptor.mjs +1 -1
- package/esm2022/lib/interceptors/api-key.interceptor.mjs +48 -0
- package/esm2022/lib/interceptors/api-token.interceptor.mjs +1 -1
- package/esm2022/lib/interceptors/http-caching.interceptor.mjs +1 -1
- package/esm2022/lib/ngx-services.models.mjs +1 -1
- package/esm2022/lib/ngx-services.module.mjs +1 -1
- package/esm2022/lib/websockets/web-sockets.service.mjs +1 -1
- package/esm2022/public-api.mjs +13 -8
- package/fesm2022/experteam-mx-ngx-services.mjs +257 -73
- package/fesm2022/experteam-mx-ngx-services.mjs.map +1 -1
- package/lib/apis/{api-external-pickups.service.d.ts → api-external-ops.service.d.ts} +15 -7
- package/lib/apis/api-inventories.service.d.ts +12 -1
- package/lib/apis/api-quote.service.d.ts +65 -0
- package/lib/apis/api-reports.service.d.ts +26 -1
- package/lib/apis/models/api-external-ops.interfaces.d.ts +21 -0
- package/lib/apis/models/{api-external-pickups.types.d.ts → api-external-ops.types.d.ts} +4 -0
- package/lib/apis/models/api-inventories.types.d.ts +6 -0
- package/lib/apis/models/api-quote.interfaces.d.ts +13 -0
- package/lib/apis/models/api-quote.types.d.ts +17 -0
- package/lib/apis/models/api-reports.interfaces.d.ts +78 -0
- package/lib/apis/models/api-reports.types.d.ts +5 -1
- package/lib/interceptors/api-key.interceptor.d.ts +35 -0
- package/lib/ngx-services.models.d.ts +1 -0
- package/package.json +1 -1
- package/public-api.d.ts +12 -7
- package/esm2022/lib/apis/api-external-pickups.service.mjs +0 -74
- package/esm2022/lib/apis/models/api-external-pickups.types.mjs +0 -2
|
@@ -101,4 +101,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
101
101
|
type: Inject,
|
|
102
102
|
args: ['env']
|
|
103
103
|
}] }, { type: i1.HttpClient }] });
|
|
104
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
104
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-notifications.service.js","sourceRoot":"","sources":["../../../../../../projects/experteam-mx/ngx-services/src/lib/apis/api-notifications.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http'\nimport { Inject, Injectable } from '@angular/core'\nimport { Environment } from '../ngx-services.models'\nimport { ApiSuccess, QueryParams } from './models/api.models'\nimport {\n  NotificationConfigurationIn,\n  NotificationConfigurationOut,\n  NotificationIn,\n  NotificationOut,\n  NotificationsOut,\n  NotificationsTypeOut\n} from './models/api-notifications.types'\nimport { map, Observable } from 'rxjs'\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class ApiNotificationsService {\n  constructor (\n    @Inject('env') private environments: Environment,\n    private http: HttpClient\n  ) { }\n\n  /**\n   * Retrieves the URL for the notifications API from the environment settings.\n   * If the URL is not defined, an empty string is returned.\n   *\n   * @return {string} The API Notifications URL or an empty string if not defined.\n   */\n  get url (): string {\n    return this.environments.apiNotificationsUrl ?? ''\n  }\n\n  /**\n   * Retrieves notifications based on the provided query parameters.\n   *\n   * @param {QueryParams} params - The query parameters used to filter and retrieve notifications.\n   * @return {Observable<NotificationsOut>} An observable that emits the fetched notifications.\n   */\n  getNotifications (params: QueryParams): Observable<NotificationsOut> {\n    return this.http.get<ApiSuccess<NotificationsOut>>(`${this.url}/notifications`, { params })\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Sends a notification request to the server using the provided body.\n   *\n   * @param {NotificationIn} body - The notification data to be sent in the request body.\n   * @return {Observable<NotificationOut>} An observable emitting the response containing the notification output data.\n   */\n  postNotification (body: NotificationIn): Observable<NotificationOut> {\n    return this.http.post<ApiSuccess<NotificationOut>>(`${this.url}/notifications`, { body })\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Sends a PUT request to update a notification with the provided ID and body.\n   *\n   * @param {number} id - The unique identifier of the notification to be updated.\n   * @param {NotificationIn} body - The data to update the notification with.\n   * @return {Observable<NotificationOut>} An observable containing the updated notification data.\n   */\n  putNotification (id: number, body: NotificationIn): Observable<NotificationOut> {\n    return this.http.put<ApiSuccess<NotificationOut>>(`${this.url}/notifications/${id}`, { body })\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Deletes a notification by its unique identifier.\n   *\n   * @param {number} id - The unique identifier of the notification to delete.\n   * @return {Observable<{}>} An observable that emits the response after deleting the notification.\n   */\n  deleteNotification (id: number): Observable<{}> {\n    return this.http.delete<ApiSuccess<{}>>(`${this.url}/notifications/${id}`)\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Marks the notification as finished for the specified notification ID.\n   *\n   * @param {number} id - The unique identifier of the notification to be marked as finished.\n   * @return {Observable<NotificationOut>} An Observable emitting the updated notification object.\n   */\n  putNotificationFinish (id: number): Observable<NotificationOut> {\n    return this.http.put<ApiSuccess<NotificationOut>>(`${this.url}/notifications/finish/${id}`, {})\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Sends a POST request to create or update notification configurations.\n   *\n   * @param {NotificationConfigurationIn} body - The notification configuration payload to be sent in the request.\n   * @return {Observable<NotificationConfigurationOut>} An observable emitting the response containing the created or updated notification configuration.\n   */\n  postNotificationConfigurations (body: NotificationConfigurationIn): Observable<NotificationConfigurationOut> {\n    return this.http.post<ApiSuccess<NotificationConfigurationOut>>(`${this.url}/notification-configurations`, { body })\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Retrieves the notification types based on the provided query parameters.\n   *\n   * @param {QueryParams} params - The query parameters for fetching the notification types.\n   * @return {Observable<NotificationsTypeOut>} An observable that emits the fetched notification types.\n   */\n  getNotificationsType (params: QueryParams): Observable<NotificationsTypeOut> {\n    return this.http.get<ApiSuccess<NotificationsTypeOut>>(`${this.url}/notifications-type`, { params })\n      .pipe(map(({ data }) => data))\n  }\n}\n"]}
|
|
@@ -59,4 +59,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
59
59
|
type: Inject,
|
|
60
60
|
args: ['env']
|
|
61
61
|
}] }, { type: i1.HttpClient }] });
|
|
62
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
62
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLW9wZW4taXRlbXMuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2V4cGVydGVhbS1teC9uZ3gtc2VydmljZXMvc3JjL2xpYi9hcGlzL2FwaS1vcGVuLWl0ZW1zLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFLbEQsT0FBTyxFQUFFLEdBQUcsRUFBYyxNQUFNLE1BQU0sQ0FBQTs7O0FBTXRDLE1BQU0sT0FBTyxtQkFBbUI7SUFFTDtJQUNmO0lBRlYsWUFDeUIsWUFBeUIsRUFDeEMsSUFBZ0I7UUFERCxpQkFBWSxHQUFaLFlBQVksQ0FBYTtRQUN4QyxTQUFJLEdBQUosSUFBSSxDQUFZO0lBQ3ZCLENBQUM7SUFFSjs7OztPQUlHO0lBQ0gsSUFBSSxHQUFHO1FBQ0wsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLGVBQWUsSUFBSSxFQUFFLENBQUE7SUFDaEQsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0gsWUFBWSxDQUFFLE1BQW1CO1FBQy9CLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQTJCLEdBQUcsSUFBSSxDQUFDLEdBQUcsYUFBYSxFQUFFLEVBQUUsTUFBTSxFQUFFLENBQUM7YUFDakYsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUE7SUFDbEMsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0gsV0FBVyxDQUFFLElBQXVCO1FBQ2xDLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQXlCLEdBQUcsSUFBSSxDQUFDLEdBQUcsVUFBVSxFQUFFLElBQUksQ0FBQzthQUN2RSxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQTtJQUNsQyxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSCxnQkFBZ0IsQ0FBRSxJQUFvQjtRQUNwQyxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUE4QixHQUFHLElBQUksQ0FBQyxHQUFHLGlCQUFpQixFQUFFLElBQUksQ0FBQzthQUNuRixJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQTtJQUNsQyxDQUFDO3dHQTlDVSxtQkFBbUIsa0JBRXBCLEtBQUs7NEdBRkosbUJBQW1CLGNBRmxCLE1BQU07OzRGQUVQLG1CQUFtQjtrQkFIL0IsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkI7OzBCQUdJLE1BQU07MkJBQUMsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdCwgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQgeyBFbnZpcm9ubWVudCB9IGZyb20gJy4uL25neC1zZXJ2aWNlcy5tb2RlbHMnXG5pbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnXG5pbXBvcnQgeyBBcGlTdWNjZXNzLCBRdWVyeVBhcmFtcyB9IGZyb20gJy4vbW9kZWxzL2FwaS5tb2RlbHMnXG5pbXBvcnQgeyBPcGVuSXRlbXNPdXQsIE90aGVySW52b2ljZU91dCwgUGF5bWVudE91dCB9IGZyb20gJy4vbW9kZWxzL2FwaS1vcGVuLWl0ZW1zLnR5cGVzJ1xuaW1wb3J0IHsgbWFwLCBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcydcbmltcG9ydCB7IE90aGVySW52b2ljZUluLCBQYXltZW50T3Blbkl0ZW1JbiB9IGZyb20gJy4vbW9kZWxzL2FwaS1vcGVuLWl0ZW1zLmludGVyZmFjZXMnXG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGNsYXNzIEFwaU9wZW5JdGVtc1NlcnZpY2Uge1xuICBjb25zdHJ1Y3RvciAoXG4gICAgQEluamVjdCgnZW52JykgcHJpdmF0ZSBlbnZpcm9ubWVudHM6IEVudmlyb25tZW50LFxuICAgIHByaXZhdGUgaHR0cDogSHR0cENsaWVudFxuICApIHt9XG5cbiAgLyoqXG4gICAqIFJldHJpZXZlcyB0aGUgQVBJIFVSTCBmb3Igb3Blbi1pdGVtcyBmcm9tIHRoZSBlbnZpcm9ubWVudHMnIGNvbmZpZ3VyYXRpb24uXG4gICAqXG4gICAqIEByZXR1cm4ge3N0cmluZ30gVGhlIEFQSSBVUkwgZm9yIG9wZW4taXRlbXMuXG4gICAqL1xuICBnZXQgdXJsICgpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLmVudmlyb25tZW50cy5hcGlPcGVuSXRlbXNVcmwgPz8gJydcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXRyaWV2ZXMgYSBsaXN0IG9mIG9wZW4taXRlbXMgYmFzZWQgb24gdGhlIHByb3ZpZGVkIHF1ZXJ5IHBhcmFtZXRlcnMuXG4gICAqXG4gICAqIEBwYXJhbSB7UXVlcnlQYXJhbXN9IHBhcmFtcyAtIFRoZSBwYXJhbWV0ZXJzIHRvIHVzZSBmb3IgcXVlcnlpbmcgb3Blbi1pdGVtcy5cbiAgICogQHJldHVybiB7T2JzZXJ2YWJsZTxPcGVuSXRlbXNPdXQ+fSBBbiBvYnNlcnZhYmxlIHRoYXQgZW1pdHMgdGhlIG9wZW4taXRlbSdzIGRhdGEuXG4gICAqL1xuICBnZXRPcGVuSXRlbXMgKHBhcmFtczogUXVlcnlQYXJhbXMpOiBPYnNlcnZhYmxlPE9wZW5JdGVtc091dD4ge1xuICAgIHJldHVybiB0aGlzLmh0dHAuZ2V0PEFwaVN1Y2Nlc3M8T3Blbkl0ZW1zT3V0Pj4oYCR7dGhpcy51cmx9L29wZW4taXRlbXNgLCB7IHBhcmFtcyB9KVxuICAgICAgLnBpcGUobWFwKCh7IGRhdGEgfSkgPT4gZGF0YSkpXG4gIH1cblxuICAvKipcbiAgICogUHJvY2Vzc2VzIGEgcGF5bWVudCBmb3IgYW4gb3BlbiBpdGVtLlxuICAgKlxuICAgKiBAcGFyYW0ge1BheW1lbnRPcGVuSXRlbUlufSBib2R5IC0gVGhlIHBheW1lbnQgZGV0YWlscyBmb3IgdGhlIG9wZW4gaXRlbS5cbiAgICogQHJldHVybiB7T2JzZXJ2YWJsZTxQYXltZW50T3V0Pn0gQW4gb2JzZXJ2YWJsZSB0aGF0IGVtaXRzIHRoZSByZXN1bHQgb2YgdGhlIHBheW1lbnQgcHJvY2Vzc2luZy5cbiAgICovXG4gIHBvc3RQYXltZW50IChib2R5OiBQYXltZW50T3Blbkl0ZW1Jbik6IE9ic2VydmFibGU8UGF5bWVudE91dD4ge1xuICAgIHJldHVybiB0aGlzLmh0dHAucG9zdDxBcGlTdWNjZXNzPFBheW1lbnRPdXQ+PihgJHt0aGlzLnVybH0vcGF5bWVudGAsIGJvZHkpXG4gICAgICAucGlwZShtYXAoKHsgZGF0YSB9KSA9PiBkYXRhKSlcbiAgfVxuXG4gIC8qKlxuICAgKiBQcm9jZXNzZXMgYSBwYXltZW50IGZvciBvdGhlciBpbnZvaWNlLlxuICAgKlxuICAgKiBAcGFyYW0ge090aGVySW52b2ljZUlufSBib2R5IC0gVGhlIHBheW1lbnQgZGV0YWlscyBmb3IgdGhlIG90aGVyIGludm9pY2UuXG4gICAqIEByZXR1cm4ge09ic2VydmFibGU8T3RoZXJJbnZvaWNlT3V0Pn0gQW4gb2JzZXJ2YWJsZSB0aGF0IGVtaXRzIHRoZSByZXN1bHQgb2YgdGhlIHBheW1lbnQgcHJvY2Vzc2luZy5cbiAgICovXG4gIHBvc3RPdGhlckludm9pY2UgKGJvZHk6IE90aGVySW52b2ljZUluKTogT2JzZXJ2YWJsZTxPdGhlckludm9pY2VPdXQ+IHtcbiAgICByZXR1cm4gdGhpcy5odHRwLnBvc3Q8QXBpU3VjY2VzczxPdGhlckludm9pY2VPdXQ+PihgJHt0aGlzLnVybH0vb3RoZXItaW52b2ljZXNgLCBib2R5KVxuICAgICAgLnBpcGUobWFwKCh7IGRhdGEgfSkgPT4gZGF0YSkpXG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
import { Inject, Injectable } from '@angular/core';
|
|
2
|
+
import { map } from 'rxjs';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common/http";
|
|
5
|
+
/**
|
|
6
|
+
* Service to manage quote-related events.
|
|
7
|
+
*
|
|
8
|
+
* This service provides methods to retrieve, create, and get event types
|
|
9
|
+
* related to quote processes.
|
|
10
|
+
*/
|
|
11
|
+
export class ApiQuoteService {
|
|
12
|
+
environments;
|
|
13
|
+
http;
|
|
14
|
+
constructor(environments, http) {
|
|
15
|
+
this.environments = environments;
|
|
16
|
+
this.http = http;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Base URL for the Quotes API.
|
|
20
|
+
*/
|
|
21
|
+
get url() {
|
|
22
|
+
return this.environments.apiQuotesUrl ?? '';
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Retrieves all registered events for a specific quote.
|
|
26
|
+
*
|
|
27
|
+
* @param id - Quote identifier.
|
|
28
|
+
* @param params - Optional query parameters such as pagination or filtering.
|
|
29
|
+
* @returns Observable containing the list of quote events.
|
|
30
|
+
*
|
|
31
|
+
* @example
|
|
32
|
+
* ```ts
|
|
33
|
+
* this.apiQuoteService.getQuoteEvents(10, { page: 1 })
|
|
34
|
+
* .subscribe((events) => console.log(events))
|
|
35
|
+
* ```
|
|
36
|
+
*/
|
|
37
|
+
getQuoteEvents(id, params) {
|
|
38
|
+
return this.http.get(`${this.url}/quotes/${id}/quote-events`, { params })
|
|
39
|
+
.pipe(map(({ data }) => data));
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Registers a new event related to a specific quote.
|
|
43
|
+
*
|
|
44
|
+
* @param id - Quote identifier.
|
|
45
|
+
* @param body - Event payload to be created.
|
|
46
|
+
* @returns Observable containing the newly created event.
|
|
47
|
+
*
|
|
48
|
+
* @example
|
|
49
|
+
* ```ts
|
|
50
|
+
* const event: QuoteEventIn = { code: 'WON', note: 'Client approved' }
|
|
51
|
+
* this.apiQuoteService.postQuoteEvents(10, event)
|
|
52
|
+
* .subscribe((response) => console.log(response))
|
|
53
|
+
* ```
|
|
54
|
+
*/
|
|
55
|
+
postQuoteEvents(id, body) {
|
|
56
|
+
return this.http.post(`${this.url}/quotes/${id}/quote-events`, body)
|
|
57
|
+
.pipe(map(({ data }) => data));
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Retrieves the available quote event types.
|
|
61
|
+
*
|
|
62
|
+
* @param params - Optional query parameters such as pagination or filtering.
|
|
63
|
+
* @returns Observable containing the list of event types.
|
|
64
|
+
*
|
|
65
|
+
* @example
|
|
66
|
+
* ```ts
|
|
67
|
+
* this.apiQuoteService.getQuoteEventTypes({ page: 1 })
|
|
68
|
+
* .subscribe((types) => console.log(types))
|
|
69
|
+
* ```
|
|
70
|
+
*/
|
|
71
|
+
getQuoteEventTypes(params) {
|
|
72
|
+
return this.http.get(`${this.url}/quote-event-types`, { params })
|
|
73
|
+
.pipe(map(({ data }) => data));
|
|
74
|
+
}
|
|
75
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ApiQuoteService, deps: [{ token: 'env' }, { token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
76
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ApiQuoteService, providedIn: 'root' });
|
|
77
|
+
}
|
|
78
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ApiQuoteService, decorators: [{
|
|
79
|
+
type: Injectable,
|
|
80
|
+
args: [{
|
|
81
|
+
providedIn: 'root'
|
|
82
|
+
}]
|
|
83
|
+
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
84
|
+
type: Inject,
|
|
85
|
+
args: ['env']
|
|
86
|
+
}] }, { type: i1.HttpClient }] });
|
|
87
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLXF1b3RlLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9leHBlcnRlYW0tbXgvbmd4LXNlcnZpY2VzL3NyYy9saWIvYXBpcy9hcGktcXVvdGUuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUlsRCxPQUFPLEVBQUUsR0FBRyxFQUFjLE1BQU0sTUFBTSxDQUFBOzs7QUFHdEM7Ozs7O0dBS0c7QUFJSCxNQUFNLE9BQU8sZUFBZTtJQUVEO0lBQ2Y7SUFGVixZQUN5QixZQUF5QixFQUN4QyxJQUFnQjtRQURELGlCQUFZLEdBQVosWUFBWSxDQUFhO1FBQ3hDLFNBQUksR0FBSixJQUFJLENBQVk7SUFDdEIsQ0FBQztJQUVMOztPQUVHO0lBQ0gsSUFBSSxHQUFHO1FBQ0wsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLFlBQVksSUFBSSxFQUFFLENBQUE7SUFDN0MsQ0FBQztJQUVEOzs7Ozs7Ozs7Ozs7T0FZRztJQUNILGNBQWMsQ0FBRSxFQUFVLEVBQUUsTUFBbUI7UUFDN0MsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBNkIsR0FBRyxJQUFJLENBQUMsR0FBRyxXQUFXLEVBQUUsZUFBZSxFQUFFLEVBQUUsTUFBTSxFQUFFLENBQUM7YUFDbEcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUE7SUFDbEMsQ0FBQztJQUVEOzs7Ozs7Ozs7Ozs7O09BYUc7SUFDSCxlQUFlLENBQUUsRUFBVSxFQUFFLElBQWtCO1FBQzdDLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQTRCLEdBQUcsSUFBSSxDQUFDLEdBQUcsV0FBVyxFQUFFLGVBQWUsRUFBRSxJQUFJLENBQUM7YUFDNUYsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUE7SUFDbEMsQ0FBQztJQUVEOzs7Ozs7Ozs7OztPQVdHO0lBQ0gsa0JBQWtCLENBQUUsTUFBbUI7UUFDckMsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBaUMsR0FBRyxJQUFJLENBQUMsR0FBRyxvQkFBb0IsRUFBRSxFQUFFLE1BQU0sRUFBRSxDQUFDO2FBQzlGLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFLElBQUksRUFBRSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFBO0lBQ2xDLENBQUM7d0dBakVVLGVBQWUsa0JBRWhCLEtBQUs7NEdBRkosZUFBZSxjQUZkLE1BQU07OzRGQUVQLGVBQWU7a0JBSDNCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25COzswQkFHSSxNQUFNOzJCQUFDLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3QsIEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuaW1wb3J0IHsgRW52aXJvbm1lbnQgfSBmcm9tICcuLi9uZ3gtc2VydmljZXMubW9kZWxzJ1xuaW1wb3J0IHsgSHR0cENsaWVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJ1xuaW1wb3J0IHsgQXBpU3VjY2VzcywgUXVlcnlQYXJhbXMgfSBmcm9tICcuL21vZGVscy9hcGkubW9kZWxzJ1xuaW1wb3J0IHsgbWFwLCBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcydcbmltcG9ydCB7IFF1b3RlRXZlbnRJbiwgUXVvdGVFdmVudE91dCwgUXVvdGVFdmVudHNPdXQsIFF1b3RlRXZlbnRUeXBlc091dCB9IGZyb20gJy4vbW9kZWxzL2FwaS1xdW90ZS50eXBlcydcblxuLyoqXG4gKiBTZXJ2aWNlIHRvIG1hbmFnZSBxdW90ZS1yZWxhdGVkIGV2ZW50cy5cbiAqXG4gKiBUaGlzIHNlcnZpY2UgcHJvdmlkZXMgbWV0aG9kcyB0byByZXRyaWV2ZSwgY3JlYXRlLCBhbmQgZ2V0IGV2ZW50IHR5cGVzXG4gKiByZWxhdGVkIHRvIHF1b3RlIHByb2Nlc3Nlcy5cbiAqL1xuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgQXBpUXVvdGVTZXJ2aWNlIHtcbiAgY29uc3RydWN0b3IgKFxuICAgIEBJbmplY3QoJ2VudicpIHByaXZhdGUgZW52aXJvbm1lbnRzOiBFbnZpcm9ubWVudCxcbiAgICBwcml2YXRlIGh0dHA6IEh0dHBDbGllbnRcbiAgKSB7IH1cblxuICAvKipcbiAgICogQmFzZSBVUkwgZm9yIHRoZSBRdW90ZXMgQVBJLlxuICAgKi9cbiAgZ2V0IHVybCAoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5lbnZpcm9ubWVudHMuYXBpUXVvdGVzVXJsID8/ICcnXG4gIH1cblxuICAvKipcbiAgICogUmV0cmlldmVzIGFsbCByZWdpc3RlcmVkIGV2ZW50cyBmb3IgYSBzcGVjaWZpYyBxdW90ZS5cbiAgICpcbiAgICogQHBhcmFtIGlkIC0gUXVvdGUgaWRlbnRpZmllci5cbiAgICogQHBhcmFtIHBhcmFtcyAtIE9wdGlvbmFsIHF1ZXJ5IHBhcmFtZXRlcnMgc3VjaCBhcyBwYWdpbmF0aW9uIG9yIGZpbHRlcmluZy5cbiAgICogQHJldHVybnMgT2JzZXJ2YWJsZSBjb250YWluaW5nIHRoZSBsaXN0IG9mIHF1b3RlIGV2ZW50cy5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogYGBgdHNcbiAgICogdGhpcy5hcGlRdW90ZVNlcnZpY2UuZ2V0UXVvdGVFdmVudHMoMTAsIHsgcGFnZTogMSB9KVxuICAgKiAgIC5zdWJzY3JpYmUoKGV2ZW50cykgPT4gY29uc29sZS5sb2coZXZlbnRzKSlcbiAgICogYGBgXG4gICAqL1xuICBnZXRRdW90ZUV2ZW50cyAoaWQ6IG51bWJlciwgcGFyYW1zOiBRdWVyeVBhcmFtcyk6IE9ic2VydmFibGU8UXVvdGVFdmVudHNPdXQ+IHtcbiAgICByZXR1cm4gdGhpcy5odHRwLmdldDxBcGlTdWNjZXNzPFF1b3RlRXZlbnRzT3V0Pj4oYCR7dGhpcy51cmx9L3F1b3Rlcy8ke2lkfS9xdW90ZS1ldmVudHNgLCB7IHBhcmFtcyB9KVxuICAgICAgLnBpcGUobWFwKCh7IGRhdGEgfSkgPT4gZGF0YSkpXG4gIH1cblxuICAvKipcbiAgICogUmVnaXN0ZXJzIGEgbmV3IGV2ZW50IHJlbGF0ZWQgdG8gYSBzcGVjaWZpYyBxdW90ZS5cbiAgICpcbiAgICogQHBhcmFtIGlkIC0gUXVvdGUgaWRlbnRpZmllci5cbiAgICogQHBhcmFtIGJvZHkgLSBFdmVudCBwYXlsb2FkIHRvIGJlIGNyZWF0ZWQuXG4gICAqIEByZXR1cm5zIE9ic2VydmFibGUgY29udGFpbmluZyB0aGUgbmV3bHkgY3JlYXRlZCBldmVudC5cbiAgICpcbiAgICogQGV4YW1wbGVcbiAgICogYGBgdHNcbiAgICogY29uc3QgZXZlbnQ6IFF1b3RlRXZlbnRJbiA9IHsgY29kZTogJ1dPTicsIG5vdGU6ICdDbGllbnQgYXBwcm92ZWQnIH1cbiAgICogdGhpcy5hcGlRdW90ZVNlcnZpY2UucG9zdFF1b3RlRXZlbnRzKDEwLCBldmVudClcbiAgICogICAuc3Vic2NyaWJlKChyZXNwb25zZSkgPT4gY29uc29sZS5sb2cocmVzcG9uc2UpKVxuICAgKiBgYGBcbiAgICovXG4gIHBvc3RRdW90ZUV2ZW50cyAoaWQ6IG51bWJlciwgYm9keTogUXVvdGVFdmVudEluKTogT2JzZXJ2YWJsZTxRdW90ZUV2ZW50T3V0PiB7XG4gICAgcmV0dXJuIHRoaXMuaHR0cC5wb3N0PEFwaVN1Y2Nlc3M8UXVvdGVFdmVudE91dD4+KGAke3RoaXMudXJsfS9xdW90ZXMvJHtpZH0vcXVvdGUtZXZlbnRzYCwgYm9keSlcbiAgICAgIC5waXBlKG1hcCgoeyBkYXRhIH0pID0+IGRhdGEpKVxuICB9XG5cbiAgLyoqXG4gICAqIFJldHJpZXZlcyB0aGUgYXZhaWxhYmxlIHF1b3RlIGV2ZW50IHR5cGVzLlxuICAgKlxuICAgKiBAcGFyYW0gcGFyYW1zIC0gT3B0aW9uYWwgcXVlcnkgcGFyYW1ldGVycyBzdWNoIGFzIHBhZ2luYXRpb24gb3IgZmlsdGVyaW5nLlxuICAgKiBAcmV0dXJucyBPYnNlcnZhYmxlIGNvbnRhaW5pbmcgdGhlIGxpc3Qgb2YgZXZlbnQgdHlwZXMuXG4gICAqXG4gICAqIEBleGFtcGxlXG4gICAqIGBgYHRzXG4gICAqIHRoaXMuYXBpUXVvdGVTZXJ2aWNlLmdldFF1b3RlRXZlbnRUeXBlcyh7IHBhZ2U6IDEgfSlcbiAgICogICAuc3Vic2NyaWJlKCh0eXBlcykgPT4gY29uc29sZS5sb2codHlwZXMpKVxuICAgKiBgYGBcbiAgICovXG4gIGdldFF1b3RlRXZlbnRUeXBlcyAocGFyYW1zOiBRdWVyeVBhcmFtcyk6IE9ic2VydmFibGU8UXVvdGVFdmVudFR5cGVzT3V0PiB7XG4gICAgcmV0dXJuIHRoaXMuaHR0cC5nZXQ8QXBpU3VjY2VzczxRdW90ZUV2ZW50VHlwZXNPdXQ+PihgJHt0aGlzLnVybH0vcXVvdGUtZXZlbnQtdHlwZXNgLCB7IHBhcmFtcyB9KVxuICAgICAgLnBpcGUobWFwKCh7IGRhdGEgfSkgPT4gZGF0YSkpXG4gIH1cbn1cbiJdfQ==
|
|
@@ -38,6 +38,34 @@ export class ApiReportsService {
|
|
|
38
38
|
return this.http.get(`${this.url}/shipments-report`, { params })
|
|
39
39
|
.pipe(map(({ data }) => data));
|
|
40
40
|
}
|
|
41
|
+
/**
|
|
42
|
+
* Retrieves the shipments landing report from the reports API.
|
|
43
|
+
*
|
|
44
|
+
* Sends a GET request to the `/shipments-landing-report` endpoint with the provided query parameters.
|
|
45
|
+
* The HTTP response is expected to be wrapped in an `ApiSuccess` envelope, from which the `data`
|
|
46
|
+
* payload is extracted and returned as the stream value.
|
|
47
|
+
*
|
|
48
|
+
* @param params - Query parameters used to filter or paginate the shipments landing report.
|
|
49
|
+
* @returns An observable that emits the parsed `ShipmentsLandingReportOut` data from the API response.
|
|
50
|
+
*
|
|
51
|
+
* @remarks
|
|
52
|
+
* - The underlying HTTP call uses `HttpClient.get` with `params` serialized as query string values.
|
|
53
|
+
* - The response is piped through `map` to unwrap `data` from `ApiSuccess<T>`.
|
|
54
|
+
* - Errors from the HTTP request are propagated through the observable stream.
|
|
55
|
+
*
|
|
56
|
+
* @example
|
|
57
|
+
* ```ts
|
|
58
|
+
* // Basic usage:
|
|
59
|
+
* service.getShipmentsLandingReport({ page: 1, perPage: 25 })
|
|
60
|
+
* .subscribe(report => {
|
|
61
|
+
* // handle ShipmentsLandingReportOut
|
|
62
|
+
* });
|
|
63
|
+
* ```
|
|
64
|
+
*/
|
|
65
|
+
getShipmentsLandingReport(params) {
|
|
66
|
+
return this.http.get(`${this.url}/shipments-landing-report`, { params })
|
|
67
|
+
.pipe(map(({ data }) => data));
|
|
68
|
+
}
|
|
41
69
|
/**
|
|
42
70
|
* Retrieves a report of external shipments based on the provided query parameters.
|
|
43
71
|
*
|
|
@@ -125,4 +153,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
125
153
|
type: Inject,
|
|
126
154
|
args: ['env']
|
|
127
155
|
}] }, { type: i1.HttpClient }] });
|
|
128
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-reports.service.js","sourceRoot":"","sources":["../../../../../../projects/experteam-mx/ngx-services/src/lib/apis/api-reports.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient, HttpResponse } from '@angular/common/http'\r\nimport { Inject, Injectable } from '@angular/core'\r\nimport { map, Observable } from 'rxjs'\r\nimport { Environment } from '../ngx-services.models'\r\nimport {\r\n  CollectionPaymentsOut, ExternalShipmentsOut,\r\n  FileCheckOut, InvoicesOut, PartialWithdrawalsOut,\r\n  PromotionCodeDiscountsOut,\r\n  ShipmentsReportOut\r\n} from './models/api-reports.types'\r\nimport { ApiSuccess, QueryParams } from './models/api.models'\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class ApiReportsService {\r\n  constructor (\r\n    @Inject('env') private environments: Environment,\r\n    private http: HttpClient\r\n  ) { }\r\n\r\n  /**\r\n   * Retrieves the URL for the reports API from the environment configurations.\r\n   *\r\n   * @return {string} The URL of the reports API.\r\n   */\r\n  get url (): string {\r\n    return this.environments.apiReportsUrl ?? ''\r\n  }\r\n\r\n  /**\r\n   * Retrieves the list of collection payments\r\n   *\r\n   * @param {QueryParams} params - The query parameters used to fetch the collection payments.\r\n   * @return {Observable<CollectionPaymentsOut[]>} An observable that emits an array of collection payment.\r\n   */\r\n  getCollectionPayments (params: QueryParams): Observable<CollectionPaymentsOut> {\r\n    return this.http.get<ApiSuccess<CollectionPaymentsOut>>(`${this.url}/collection-payment`, {\r\n      params\r\n    }).pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Fetches shipment reports based on the provided query parameters.\r\n   *\r\n   * @param {QueryParams} params - The query parameters used to filter or define the shipment reports.\r\n   * @return {Observable<ShipmentsReportOut>} An observable emitting the shipment report data.\r\n   */\r\n  getShipmentsReport (params: QueryParams): Observable<ShipmentsReportOut> {\r\n    return this.http.get<ApiSuccess<ShipmentsReportOut>>(`${this.url}/shipments-report`, { params })\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Retrieves a report of external shipments based on the provided query parameters.\r\n   *\r\n   * @param {QueryParams} params - An object representing the query parameters for filtering the external shipments report.\r\n   * @return {Observable<ExternalShipmentsOut>} An observable that emits the external shipments report data.\r\n   */\r\n  getExternalShipmentsReport (params: QueryParams): Observable<ExternalShipmentsOut> {\r\n    return this.http.get<ApiSuccess<ExternalShipmentsOut>>(`${this.url}/external-shipments-report`, { params })\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Retrieves a report of promotion code discounts based on the provided query parameters.\r\n   *\r\n   * @param {QueryParams} params - An object representing the query parameters for filtering the promotion code discounts report.\r\n   * @return {Observable<PromotionCodeDiscountsOut>} An observable that emits the promotion code discounts report data.\r\n   */\r\n  getPromotionCodeDiscounts (params: QueryParams): Observable<PromotionCodeDiscountsOut> {\r\n    return this.http.get<ApiSuccess<PromotionCodeDiscountsOut>>(`${this.url}/promotion-code-discounts`, {\r\n      params\r\n    }).pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Retrieves the downloadable resource associated with the given transaction ID.\r\n   *\r\n   * @param {string} transactionId - The unique identifier of the transaction whose download is requested.\r\n   * @return {Observable<HttpResponse<ArrayBuffer>>} An observable that emits the HTTP response containing the resource in the form of an ArrayBuffer.\r\n   */\r\n  getDownload (transactionId: string): Observable<HttpResponse<ArrayBuffer>> {\r\n    return this.http.get(`${this.url}/download/${transactionId}`, {\r\n      observe: 'response',\r\n      responseType: 'arraybuffer'\r\n    })\r\n  }\r\n\r\n  /**\r\n   * Retrieves file check information for the specified transaction ID.\r\n   *\r\n   * @param {string} transactionId - The ID of the transaction for which the file check information is to be retrieved.\r\n   * @return {Observable<FileCheckOut>} An observable that emits the file check information associated with the given transaction ID.\r\n   */\r\n  getFileCheck (transactionId: string): Observable<FileCheckOut> {\r\n    return this.http.get<ApiSuccess<FileCheckOut>>(`${this.url}/file-check/${transactionId}`)\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Deletes the file check associated with the provided transaction ID.\r\n   *\r\n   * @param {string} transactionId - The unique identifier of the transaction whose file check is to be deleted.\r\n   * @return {Observable<{}>} An observable emitting the response data after the deletion is processed.\r\n   */\r\n  deleteFileCheck (transactionId: string): Observable<{}> {\r\n    return this.http.delete<ApiSuccess<{}>>(`${this.url}/file-check/${transactionId}`)\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Retrieves partial withdrawals based on the provided query parameters.\r\n   *\r\n   * @param {QueryParams} params - The parameters used to filter the list of partial withdrawals.\r\n   * @returns {Observable<PartialWithdrawalsOut>} An observable that emits the filtered list of partial withdrawals.\r\n   */\r\n  getPartialWithdrawals (params: QueryParams): Observable<PartialWithdrawalsOut> {\r\n    return this.http.get<ApiSuccess<PartialWithdrawalsOut>>(`${this.url}/partial-withdrawals`, {\r\n      params\r\n    })\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Retrieves a list of invoices based on the provided query parameters.\r\n   *\r\n   * @param params - The query parameters used to filter the invoices.\r\n   * @returns An observable that emits the list of invoices.\r\n   */\r\n  getInvoices (params: QueryParams): Observable<InvoicesOut> {\r\n    return this.http.get<ApiSuccess<InvoicesOut>>(`${this.url}/invoices`, { params })\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n}\r\n"]}
|
|
156
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-reports.service.js","sourceRoot":"","sources":["../../../../../../projects/experteam-mx/ngx-services/src/lib/apis/api-reports.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient, HttpResponse } from '@angular/common/http'\nimport { Inject, Injectable } from '@angular/core'\nimport { map, Observable } from 'rxjs'\nimport { Environment } from '../ngx-services.models'\nimport {\n  CollectionPaymentsOut, ExternalShipmentsOut,\n  FileCheckOut, InvoicesOut, PartialWithdrawalsOut,\n  PromotionCodeDiscountsOut,\n  ShipmentsLandingReportOut,\n  ShipmentsReportOut\n} from './models/api-reports.types'\nimport { ApiSuccess, QueryParams } from './models/api.models'\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class ApiReportsService {\n  constructor (\n    @Inject('env') private environments: Environment,\n    private http: HttpClient\n  ) { }\n\n  /**\n   * Retrieves the URL for the reports API from the environment configurations.\n   *\n   * @return {string} The URL of the reports API.\n   */\n  get url (): string {\n    return this.environments.apiReportsUrl ?? ''\n  }\n\n  /**\n   * Retrieves the list of collection payments\n   *\n   * @param {QueryParams} params - The query parameters used to fetch the collection payments.\n   * @return {Observable<CollectionPaymentsOut[]>} An observable that emits an array of collection payment.\n   */\n  getCollectionPayments (params: QueryParams): Observable<CollectionPaymentsOut> {\n    return this.http.get<ApiSuccess<CollectionPaymentsOut>>(`${this.url}/collection-payment`, {\n      params\n    }).pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Fetches shipment reports based on the provided query parameters.\n   *\n   * @param {QueryParams} params - The query parameters used to filter or define the shipment reports.\n   * @return {Observable<ShipmentsReportOut>} An observable emitting the shipment report data.\n   */\n  getShipmentsReport (params: QueryParams): Observable<ShipmentsReportOut> {\n    return this.http.get<ApiSuccess<ShipmentsReportOut>>(`${this.url}/shipments-report`, { params })\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Retrieves the shipments landing report from the reports API.\n   *\n   * Sends a GET request to the `/shipments-landing-report` endpoint with the provided query parameters.\n   * The HTTP response is expected to be wrapped in an `ApiSuccess` envelope, from which the `data`\n   * payload is extracted and returned as the stream value.\n   *\n   * @param params - Query parameters used to filter or paginate the shipments landing report.\n   * @returns An observable that emits the parsed `ShipmentsLandingReportOut` data from the API response.\n   *\n   * @remarks\n   * - The underlying HTTP call uses `HttpClient.get` with `params` serialized as query string values.\n   * - The response is piped through `map` to unwrap `data` from `ApiSuccess<T>`.\n   * - Errors from the HTTP request are propagated through the observable stream.\n   *\n   * @example\n   * ```ts\n   * // Basic usage:\n   * service.getShipmentsLandingReport({ page: 1, perPage: 25 })\n   *   .subscribe(report => {\n   *     // handle ShipmentsLandingReportOut\n   *   });\n   * ```\n   */\n  getShipmentsLandingReport (params: QueryParams): Observable<ShipmentsLandingReportOut> {\n    return this.http.get<ApiSuccess<ShipmentsLandingReportOut>>(`${this.url}/shipments-landing-report`, { params })\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Retrieves a report of external shipments based on the provided query parameters.\n   *\n   * @param {QueryParams} params - An object representing the query parameters for filtering the external shipments report.\n   * @return {Observable<ExternalShipmentsOut>} An observable that emits the external shipments report data.\n   */\n  getExternalShipmentsReport (params: QueryParams): Observable<ExternalShipmentsOut> {\n    return this.http.get<ApiSuccess<ExternalShipmentsOut>>(`${this.url}/external-shipments-report`, { params })\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Retrieves a report of promotion code discounts based on the provided query parameters.\n   *\n   * @param {QueryParams} params - An object representing the query parameters for filtering the promotion code discounts report.\n   * @return {Observable<PromotionCodeDiscountsOut>} An observable that emits the promotion code discounts report data.\n   */\n  getPromotionCodeDiscounts (params: QueryParams): Observable<PromotionCodeDiscountsOut> {\n    return this.http.get<ApiSuccess<PromotionCodeDiscountsOut>>(`${this.url}/promotion-code-discounts`, {\n      params\n    }).pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Retrieves the downloadable resource associated with the given transaction ID.\n   *\n   * @param {string} transactionId - The unique identifier of the transaction whose download is requested.\n   * @return {Observable<HttpResponse<ArrayBuffer>>} An observable that emits the HTTP response containing the resource in the form of an ArrayBuffer.\n   */\n  getDownload (transactionId: string): Observable<HttpResponse<ArrayBuffer>> {\n    return this.http.get(`${this.url}/download/${transactionId}`, {\n      observe: 'response',\n      responseType: 'arraybuffer'\n    })\n  }\n\n  /**\n   * Retrieves file check information for the specified transaction ID.\n   *\n   * @param {string} transactionId - The ID of the transaction for which the file check information is to be retrieved.\n   * @return {Observable<FileCheckOut>} An observable that emits the file check information associated with the given transaction ID.\n   */\n  getFileCheck (transactionId: string): Observable<FileCheckOut> {\n    return this.http.get<ApiSuccess<FileCheckOut>>(`${this.url}/file-check/${transactionId}`)\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Deletes the file check associated with the provided transaction ID.\n   *\n   * @param {string} transactionId - The unique identifier of the transaction whose file check is to be deleted.\n   * @return {Observable<{}>} An observable emitting the response data after the deletion is processed.\n   */\n  deleteFileCheck (transactionId: string): Observable<{}> {\n    return this.http.delete<ApiSuccess<{}>>(`${this.url}/file-check/${transactionId}`)\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Retrieves partial withdrawals based on the provided query parameters.\n   *\n   * @param {QueryParams} params - The parameters used to filter the list of partial withdrawals.\n   * @returns {Observable<PartialWithdrawalsOut>} An observable that emits the filtered list of partial withdrawals.\n   */\n  getPartialWithdrawals (params: QueryParams): Observable<PartialWithdrawalsOut> {\n    return this.http.get<ApiSuccess<PartialWithdrawalsOut>>(`${this.url}/partial-withdrawals`, {\n      params\n    })\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Retrieves a list of invoices based on the provided query parameters.\n   *\n   * @param params - The query parameters used to filter the invoices.\n   * @returns An observable that emits the list of invoices.\n   */\n  getInvoices (params: QueryParams): Observable<InvoicesOut> {\n    return this.http.get<ApiSuccess<InvoicesOut>>(`${this.url}/invoices`, { params })\n      .pipe(map(({ data }) => data))\n  }\n}\n"]}
|
|
@@ -242,4 +242,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
242
242
|
type: Inject,
|
|
243
243
|
args: ['env']
|
|
244
244
|
}] }, { type: i1.CookieService }, { type: i2.HttpClient }] });
|
|
245
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-security.service.js","sourceRoot":"","sources":["../../../../../../projects/experteam-mx/ngx-services/src/lib/apis/api-security.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAoBlD,OAAO,EAAc,WAAW,EAAE,MAAM,sBAAsB,CAAA;AAE9D,OAAO,EAAE,GAAG,EAAc,GAAG,EAAE,MAAM,MAAM,CAAA;;;;AAM3C,MAAM,OAAO,kBAAkB;IAEJ;IACf;IACA;IAHV,YACyB,YAAyB,EACxC,MAAqB,EACrB,IAAgB;QAFD,iBAAY,GAAZ,YAAY,CAAa;QACxC,WAAM,GAAN,MAAM,CAAe;QACrB,SAAI,GAAJ,IAAI,CAAY;IACvB,CAAC;IAEJ;;;;OAIG;IACH,IAAI,GAAG;QACL,OAAO,IAAI,CAAC,YAAY,CAAC,cAAc,IAAI,EAAE,CAAA;IAC/C,CAAC;IAED;;;;;OAKG;IACH,aAAa,CAAE,IAAiB;QAC9B,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAA2B,GAAG,IAAI,CAAC,GAAG,aAAa,EAAE,IAAI,CAAC;aAC5E,IAAI,CACH,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,EACvB,GAAG,CAAC,CAAC,EAAE,YAAY,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,YAAY,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC,CACtG,CAAA;IACL,CAAC;IAED;;;;;OAKG;IACH,iBAAiB,CAAE,IAAqB;QACtC,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAA2B,GAAG,IAAI,CAAC,GAAG,kBAAkB,EAAE,IAAI,CAAC;aACjF,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAClC,CAAC;IAED;;;;;;OAMG;IACH,cAAc;QACZ,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAiB,GAAG,IAAI,CAAC,GAAG,cAAc,EAAE,IAAI,CAAC;aACnE,IAAI,CACH,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,EACvB,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC,CACjE,CAAA;IACL,CAAC;IAED;;;;;;;;;OASG;IACH,WAAW,CAAE,EACX,SAAS,EACT,OAAO,EACP,KAAK,GACK;QACV,IAAI,OAAO,GAAG,IAAI,WAAW,CAAC,EAAE,CAAC,CAAA;QAEjC,IAAI,KAAK,EAAE,CAAC;YAAC,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,eAAe,EAAE,UAAU,KAAK,EAAE,CAAC,CAAA;QAAC,CAAC;QAExE,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CACnB,GAAG,IAAI,CAAC,GAAG,WAAW,EAAE;YACtB,UAAU,EAAE,SAAS;YACrB,QAAQ,EAAE,OAAO;SAClB,EAAE;YACD,OAAO;SACR,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IACpC,CAAC;IAED;;;;;;OAMG;IACH,SAAS;QACP,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAwB,GAAG,IAAI,CAAC,GAAG,UAAU,CAAC;aAC/D,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAClC,CAAC;IAED;;;;;OAKG;IACH,UAAU,CAAE,KAAa;QACvB,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAwB,GAAG,IAAI,CAAC,GAAG,UAAU,EAAE;YACjE,OAAO,EAAE;gBACP,aAAa,EAAE,UAAU,KAAK,EAAE;aACjC;SACF,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAClC,CAAC;IAED;;;;;OAKG;IACH,OAAO,CAAE,EAAU;QACjB,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAyB,GAAG,IAAI,CAAC,GAAG,UAAU,EAAE,EAAE,CAAC;aACpE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAClC,CAAC;IAED;;;;;OAKG;IACH,QAAQ,CAAE,MAAmB;QAC3B,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAA0B,GAAG,IAAI,CAAC,GAAG,QAAQ,EAAE,EAAE,MAAM,EAAE,CAAC;aAC3E,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAClC,CAAC;IAED;;;;;;;;OAQG;IACH,QAAQ,CAAE,EAAE,IAAI,EAAc;QAC5B,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAA0B,GAAG,IAAI,CAAC,GAAG,UAAU,IAAI,CAAC,EAAE,EAAE,EAAE,IAAI,CAAC;aAChF,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAClC,CAAC;IAED;;;;;;OAMG;IACH,iBAAiB,CAAE,EACjB,UAAU,EACO;QACjB,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAwB,GAAG,IAAI,CAAC,GAAG,UAAU,EAAE;YACjE,WAAW,EAAE,UAAU;SACxB,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAClC,CAAC;IAED;;;;;OAKG;IACH,QAAQ,CAAE,MAAmB;QAC3B,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAuB,GAAG,IAAI,CAAC,GAAG,QAAQ,EAAE,EAAE,MAAM,EAAE,CAAC;aACxE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAClC,CAAC;IAED;;;;;OAKG;IACH,OAAO,CAAE,EAAU;QACjB,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAsB,GAAG,IAAI,CAAC,GAAG,UAAU,EAAE,EAAE,CAAC;aACjE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAClC,CAAC;IAED;;;;;OAKG;IACH,QAAQ,CAAE,IAAY;QACpB,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAsB,GAAG,IAAI,CAAC,GAAG,QAAQ,EAAE,IAAI,CAAC;aAClE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAClC,CAAC;IAED;;;;;;OAMG;IACH,OAAO,CAAE,EAAU,EAAE,IAAY;QAC/B,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAsB,GAAG,IAAI,CAAC,GAAG,UAAU,EAAE,EAAE,EAAE,IAAI,CAAC;aACvE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAClC,CAAC;IAED;;;;;OAKG;IACH,UAAU,CAAE,EAAU;QACpB,OAAO,IAAI,CAAC,IAAI,CAAC,MAAM,CAAiB,GAAG,IAAI,CAAC,GAAG,UAAU,EAAE,EAAE,CAAC;aAC/D,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAClC,CAAC;IAED;;;;;OAKG;IACH,YAAY,CAAE,MAAmB;QAC/B,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAA2B,GAAG,IAAI,CAAC,GAAG,aAAa,EAAE,EAAE,MAAM,EAAE,CAAC;aACjF,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAClC,CAAC;IAED;;;;;OAKG;IACH,UAAU,CAAE,WAAwB;QAClC,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAyB,GAAG,IAAI,CAAC,GAAG,UAAU,EAAE;YAClE,MAAM,EAAE,WAAW;SACpB,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAClC,CAAC;IAED;;;;;;OAMG;IACH,iBAAiB,CAAE,MAGlB;QACC,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAyB,GAAG,IAAI,CAAC,GAAG,UAAU,EAAE;YAClE,MAAM,EAAE,MAAM,CAAC,WAAW;YAC1B,OAAO,EAAE;gBACP,aAAa,EAAE,UAAU,MAAM,CAAC,KAAK,EAAE;aACxC;SACF,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAClC,CAAC;wGAjQU,kBAAkB,kBAEnB,KAAK;4GAFJ,kBAAkB,cAFjB,MAAM;;4FAEP,kBAAkB;kBAH9B,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB;;0BAGI,MAAM;2BAAC,KAAK","sourcesContent":["import { Inject, Injectable } from '@angular/core'\r\nimport { ApiSuccess, QueryParams } from './models/api.models'\r\nimport {\r\n  AuthLoginIn,\r\n  AuthLoginOut,\r\n  AuthMeOut,\r\n  AuthUserLoginIn,\r\n  ChangeLanguageIn,\r\n  GetUserOut,\r\n  GetUsersOut,\r\n  ModulesOut,\r\n  PutUsersIn,\r\n  PutUsersOut,\r\n  RoleIn,\r\n  RoleOut,\r\n  RolesOut,\r\n  RoleTypesOut,\r\n  SessionIn,\r\n  SessionOut\r\n} from './models/api-security.types'\r\nimport { HttpClient, HttpHeaders } from '@angular/common/http'\r\nimport { Environment } from '../ngx-services.models'\r\nimport { map, Observable, tap } from 'rxjs'\r\nimport { CookieService } from 'ngx-cookie-service'\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class ApiSecurityService {\r\n  constructor (\r\n    @Inject('env') private environments: Environment,\r\n    private cookie: CookieService,\r\n    private http: HttpClient\r\n  ) {}\r\n\r\n  /**\r\n   * Retrieves the API security URL from the environments configuration.\r\n   *\r\n   * @return {string} The API security URL.\r\n   */\r\n  get url (): string {\r\n    return this.environments.apiSecurityUrl ?? ''\r\n  }\r\n\r\n  /**\r\n   * Handles the login authentication request by sending the login data to the authentication endpoint.\r\n   *\r\n   * @param {AuthLoginIn} body The payload containing login credentials.\r\n   * @return {Observable<AuthLoginOut>} An observable emitting the authentication response data.\r\n   */\r\n  postAuthLogin (body: AuthLoginIn): Observable<AuthLoginOut> {\r\n    return this.http.post<ApiSuccess<AuthLoginOut>>(`${this.url}/auth/login`, body)\r\n      .pipe(\r\n        map(({ data }) => data),\r\n        tap(({ access_token }) => this.cookie.set(this.environments.authCookie, access_token, { path: '/' }))\r\n      )\r\n  }\r\n\r\n  /**\r\n   * Handles the user login process by sending user credentials to the authentication endpoint.\r\n   *\r\n   * @param {AuthUserLoginIn} body - The request payload containing user login details such as username and password.\r\n   * @return {Observable<AuthLoginOut>} An observable that emits the authenticated user's login data upon successful login.\r\n   */\r\n  postAuthUserLogin (body: AuthUserLoginIn): Observable<AuthLoginOut> {\r\n    return this.http.post<ApiSuccess<AuthLoginOut>>(`${this.url}/auth/user-login`, body)\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Logs out the current user by making a POST request to the logout endpoint.\r\n   *\r\n   * This method deletes all cookies after a successful logout.\r\n   *\r\n   * @return {Observable<{}>} An observable that emits the server's response to the logout request.\r\n   */\r\n  postAuthLogout (): Observable<{}> {\r\n    return this.http.post<ApiSuccess<{}>>(`${this.url}/auth/logout`, null)\r\n      .pipe(\r\n        map(({ data }) => data),\r\n        tap(() => this.cookie.delete(this.environments.authCookie, '/'))\r\n      )\r\n  }\r\n\r\n  /**\r\n   * Creates a new session for a specified model.\r\n   *\r\n   * @param {Object} params - The parameters for creating the session.\r\n   * @param {string} params.modelType - The type of the model.\r\n   * @param {string} params.modelId - The ID of the model.\r\n   * @param {string} [params.token] - Optional authorization token.\r\n   *\r\n   * @return {Observable<SessionOut>} An observable containing the created session details.\r\n   */\r\n  postSession ({\r\n    modelType,\r\n    modelId,\r\n    token,\r\n  }: SessionIn): Observable<SessionOut> {\r\n    let headers = new HttpHeaders({})\r\n\r\n    if (token) { headers = headers.set('Authorization', `Bearer ${token}`) }\r\n\r\n    return this.http.post<ApiSuccess<SessionOut>>(\r\n      `${this.url}/sessions`, {\r\n        model_type: modelType,\r\n        model_id: modelId,\r\n      }, {\r\n        headers\r\n      }).pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Fetches the authenticated user's information.\r\n   * Sends a GET request to the endpoint '/auth/me' to retrieve information\r\n   * about the currently authenticated user.\r\n   *\r\n   * @return {Observable<AuthMeOut>} An observable that emits the authenticated user's data.\r\n   */\r\n  getAuthMe (): Observable<AuthMeOut> {\r\n    return this.http.get<ApiSuccess<AuthMeOut>>(`${this.url}/auth/me`)\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Fetches the authenticated user's details from the server.\r\n   *\r\n   * @param token The JWT token used for authorization.\r\n   * @return An Observable that emits the user's details encapsulated in a MeOut object.\r\n   */\r\n  getOtherMe (token: string): Observable<AuthMeOut> {\r\n    return this.http.get<ApiSuccess<AuthMeOut>>(`${this.url}/auth/me`, {\r\n      headers: {\r\n        Authorization: `Bearer ${token}`\r\n      }\r\n    }).pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Fetches a user by their unique ID.\r\n   *\r\n   * @param {number} id - The unique identifier of the user to be fetched.\r\n   * @return {Observable<GetUserOut>} An observable containing the user information.\r\n   */\r\n  getUser (id: number): Observable<GetUserOut> {\r\n    return this.http.get<ApiSuccess<GetUserOut>>(`${this.url}/users/${id}`)\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Fetches a list of users from the server based on the specified query parameters.\r\n   *\r\n   * @param {QueryParams} params - The query parameters to filter the list of users.\r\n   * @return {Observable<GetUsersOut>} An observable that emits the list of users retrieved from the server.\r\n   */\r\n  getUsers (params: QueryParams): Observable<GetUsersOut> {\r\n    return this.http.get<ApiSuccess<GetUsersOut>>(`${this.url}/users`, { params })\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Updates the information of a specified user on the server.\r\n   *\r\n   * @param {Object} params - The parameter object.\r\n   * @param {Object} params.user - The user object containing updated data.\r\n   * @param {string} params.user.id - The unique identifier of the user to be updated.\r\n   *\r\n   * @return {void} This method does not return a value.\r\n   */\r\n  putUsers ({ user }: PutUsersIn) {\r\n    return this.http.put<ApiSuccess<PutUsersOut>>(`${this.url}/users/${user.id}`, user)\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Changes the language for the authenticated user.\r\n   *\r\n   * @param {Object} params - The input parameters for changing the language.\r\n   * @param {string} params.languageId - The ID of the new language to be set.\r\n   * @return {Observable<ApiSuccess<AuthMeOut>>} An observable that emits the result of the language change request.\r\n   */\r\n  putChangeLanguage ({\r\n    languageId\r\n  }: ChangeLanguageIn): Observable<AuthMeOut> {\r\n    return this.http.put<ApiSuccess<AuthMeOut>>(`${this.url}/auth/me`, {\r\n      language_id: languageId\r\n    }).pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Retrieves a list of roles with their permissions.\r\n   *\r\n   * @param {QueryParams} params - The query parameters to filter the roles.\r\n   * @returns {Observable<RoleIn[]>} An observable that emits an array of role permissions.\r\n   */\r\n  getRoles (params: QueryParams): Observable<RolesOut> {\r\n    return this.http.get<ApiSuccess<RolesOut>>(`${this.url}/roles`, { params })\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Retrieves roles by the specified ID.\r\n   *\r\n   * @param id - The ID of the role to retrieve.\r\n   * @returns An Observable that emits the role data.\r\n   */\r\n  getRole (id: number): Observable<RoleOut> {\r\n    return this.http.get<ApiSuccess<RoleOut>>(`${this.url}/roles/${id}`)\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Creates a new role with the specified permissions.\r\n   *\r\n   * @param {RoleIn} body - The permissions and details for the new role.\r\n   * @returns {Observable<RoleOut>} An observable containing the created role's permissions.\r\n   */\r\n  postRole (body: RoleIn): Observable<RoleOut> {\r\n    return this.http.post<ApiSuccess<RoleOut>>(`${this.url}/roles`, body)\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Updates the permissions of a specific role.\r\n   *\r\n   * @param id - The unique identifier of the role to update.\r\n   * @param body - The new permissions to assign to the role.\r\n   * @returns An Observable that emits the updated module permissions.\r\n   */\r\n  putRole (id: number, body: RoleIn): Observable<RoleOut> {\r\n    return this.http.put<ApiSuccess<RoleOut>>(`${this.url}/roles/${id}`, body)\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Deletes the permissions associated with a specific role.\r\n   *\r\n   * @param {number} id - The unique identifier of the role whose permissions are to be deleted.\r\n   * @returns {Observable<{}>} An observable that emits the result of the delete operation.\r\n   */\r\n  deleteRole (id: number): Observable<{}> {\r\n    return this.http.delete<ApiSuccess<{}>>(`${this.url}/roles/${id}`)\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Retrieves the role types from the API.\r\n   *\r\n   * @param {QueryParams} params - The query parameters to be sent with the request.\r\n   * @returns {Observable<RoleTypesOut>} An observable containing the role types output.\r\n   */\r\n  getRoleTypes (params: QueryParams): Observable<RoleTypesOut> {\r\n    return this.http.get<ApiSuccess<RoleTypesOut>>(`${this.url}/role-types`, { params })\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Retrieves a list of modules and permissions\r\n   *\r\n   * @param queryParams - The query parameters to filter the modules.\r\n   * @returns Observable<ModulesOut[]> - An observable that emits an array of modules and permissions.\r\n   */\r\n  getModules (queryParams: QueryParams): Observable<ModulesOut> {\r\n    return this.http.get<ApiSuccess<ModulesOut>>(`${this.url}/modules`, {\r\n      params: queryParams\r\n    }).pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Retrieves a list of modules and permissions\r\n   *\r\n   * @param params.token - Custom token for authorization.\r\n   * @param params.queryParams - The query parameters to filter the modules.\r\n   * @returns Observable<ModulesOut[]> - An observable that emits an array of modules and permissions.\r\n   */\r\n  getModulesByToken (params: {\r\n    token: string,\r\n    queryParams: QueryParams\r\n  }): Observable<ModulesOut> {\r\n    return this.http.get<ApiSuccess<ModulesOut>>(`${this.url}/modules`, {\r\n      params: params.queryParams,\r\n      headers: {\r\n        Authorization: `Bearer ${params.token}`\r\n      }\r\n    }).pipe(map(({ data }) => data))\r\n  }\r\n}\r\n"]}
|
|
245
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-security.service.js","sourceRoot":"","sources":["../../../../../../projects/experteam-mx/ngx-services/src/lib/apis/api-security.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from '@angular/core'\nimport { ApiSuccess, QueryParams } from './models/api.models'\nimport {\n  AuthLoginIn,\n  AuthLoginOut,\n  AuthMeOut,\n  AuthUserLoginIn,\n  ChangeLanguageIn,\n  GetUserOut,\n  GetUsersOut,\n  ModulesOut,\n  PutUsersIn,\n  PutUsersOut,\n  RoleIn,\n  RoleOut,\n  RolesOut,\n  RoleTypesOut,\n  SessionIn,\n  SessionOut\n} from './models/api-security.types'\nimport { HttpClient, HttpHeaders } from '@angular/common/http'\nimport { Environment } from '../ngx-services.models'\nimport { map, Observable, tap } from 'rxjs'\nimport { CookieService } from 'ngx-cookie-service'\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class ApiSecurityService {\n  constructor (\n    @Inject('env') private environments: Environment,\n    private cookie: CookieService,\n    private http: HttpClient\n  ) {}\n\n  /**\n   * Retrieves the API security URL from the environments configuration.\n   *\n   * @return {string} The API security URL.\n   */\n  get url (): string {\n    return this.environments.apiSecurityUrl ?? ''\n  }\n\n  /**\n   * Handles the login authentication request by sending the login data to the authentication endpoint.\n   *\n   * @param {AuthLoginIn} body The payload containing login credentials.\n   * @return {Observable<AuthLoginOut>} An observable emitting the authentication response data.\n   */\n  postAuthLogin (body: AuthLoginIn): Observable<AuthLoginOut> {\n    return this.http.post<ApiSuccess<AuthLoginOut>>(`${this.url}/auth/login`, body)\n      .pipe(\n        map(({ data }) => data),\n        tap(({ access_token }) => this.cookie.set(this.environments.authCookie, access_token, { path: '/' }))\n      )\n  }\n\n  /**\n   * Handles the user login process by sending user credentials to the authentication endpoint.\n   *\n   * @param {AuthUserLoginIn} body - The request payload containing user login details such as username and password.\n   * @return {Observable<AuthLoginOut>} An observable that emits the authenticated user's login data upon successful login.\n   */\n  postAuthUserLogin (body: AuthUserLoginIn): Observable<AuthLoginOut> {\n    return this.http.post<ApiSuccess<AuthLoginOut>>(`${this.url}/auth/user-login`, body)\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Logs out the current user by making a POST request to the logout endpoint.\n   *\n   * This method deletes all cookies after a successful logout.\n   *\n   * @return {Observable<{}>} An observable that emits the server's response to the logout request.\n   */\n  postAuthLogout (): Observable<{}> {\n    return this.http.post<ApiSuccess<{}>>(`${this.url}/auth/logout`, null)\n      .pipe(\n        map(({ data }) => data),\n        tap(() => this.cookie.delete(this.environments.authCookie, '/'))\n      )\n  }\n\n  /**\n   * Creates a new session for a specified model.\n   *\n   * @param {Object} params - The parameters for creating the session.\n   * @param {string} params.modelType - The type of the model.\n   * @param {string} params.modelId - The ID of the model.\n   * @param {string} [params.token] - Optional authorization token.\n   *\n   * @return {Observable<SessionOut>} An observable containing the created session details.\n   */\n  postSession ({\n    modelType,\n    modelId,\n    token,\n  }: SessionIn): Observable<SessionOut> {\n    let headers = new HttpHeaders({})\n\n    if (token) { headers = headers.set('Authorization', `Bearer ${token}`) }\n\n    return this.http.post<ApiSuccess<SessionOut>>(\n      `${this.url}/sessions`, {\n        model_type: modelType,\n        model_id: modelId,\n      }, {\n        headers\n      }).pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Fetches the authenticated user's information.\n   * Sends a GET request to the endpoint '/auth/me' to retrieve information\n   * about the currently authenticated user.\n   *\n   * @return {Observable<AuthMeOut>} An observable that emits the authenticated user's data.\n   */\n  getAuthMe (): Observable<AuthMeOut> {\n    return this.http.get<ApiSuccess<AuthMeOut>>(`${this.url}/auth/me`)\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Fetches the authenticated user's details from the server.\n   *\n   * @param token The JWT token used for authorization.\n   * @return An Observable that emits the user's details encapsulated in a MeOut object.\n   */\n  getOtherMe (token: string): Observable<AuthMeOut> {\n    return this.http.get<ApiSuccess<AuthMeOut>>(`${this.url}/auth/me`, {\n      headers: {\n        Authorization: `Bearer ${token}`\n      }\n    }).pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Fetches a user by their unique ID.\n   *\n   * @param {number} id - The unique identifier of the user to be fetched.\n   * @return {Observable<GetUserOut>} An observable containing the user information.\n   */\n  getUser (id: number): Observable<GetUserOut> {\n    return this.http.get<ApiSuccess<GetUserOut>>(`${this.url}/users/${id}`)\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Fetches a list of users from the server based on the specified query parameters.\n   *\n   * @param {QueryParams} params - The query parameters to filter the list of users.\n   * @return {Observable<GetUsersOut>} An observable that emits the list of users retrieved from the server.\n   */\n  getUsers (params: QueryParams): Observable<GetUsersOut> {\n    return this.http.get<ApiSuccess<GetUsersOut>>(`${this.url}/users`, { params })\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Updates the information of a specified user on the server.\n   *\n   * @param {Object} params - The parameter object.\n   * @param {Object} params.user - The user object containing updated data.\n   * @param {string} params.user.id - The unique identifier of the user to be updated.\n   *\n   * @return {void} This method does not return a value.\n   */\n  putUsers ({ user }: PutUsersIn) {\n    return this.http.put<ApiSuccess<PutUsersOut>>(`${this.url}/users/${user.id}`, user)\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Changes the language for the authenticated user.\n   *\n   * @param {Object} params - The input parameters for changing the language.\n   * @param {string} params.languageId - The ID of the new language to be set.\n   * @return {Observable<ApiSuccess<AuthMeOut>>} An observable that emits the result of the language change request.\n   */\n  putChangeLanguage ({\n    languageId\n  }: ChangeLanguageIn): Observable<AuthMeOut> {\n    return this.http.put<ApiSuccess<AuthMeOut>>(`${this.url}/auth/me`, {\n      language_id: languageId\n    }).pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Retrieves a list of roles with their permissions.\n   *\n   * @param {QueryParams} params - The query parameters to filter the roles.\n   * @returns {Observable<RoleIn[]>} An observable that emits an array of role permissions.\n   */\n  getRoles (params: QueryParams): Observable<RolesOut> {\n    return this.http.get<ApiSuccess<RolesOut>>(`${this.url}/roles`, { params })\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Retrieves roles by the specified ID.\n   *\n   * @param id - The ID of the role to retrieve.\n   * @returns An Observable that emits the role data.\n   */\n  getRole (id: number): Observable<RoleOut> {\n    return this.http.get<ApiSuccess<RoleOut>>(`${this.url}/roles/${id}`)\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Creates a new role with the specified permissions.\n   *\n   * @param {RoleIn} body - The permissions and details for the new role.\n   * @returns {Observable<RoleOut>} An observable containing the created role's permissions.\n   */\n  postRole (body: RoleIn): Observable<RoleOut> {\n    return this.http.post<ApiSuccess<RoleOut>>(`${this.url}/roles`, body)\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Updates the permissions of a specific role.\n   *\n   * @param id - The unique identifier of the role to update.\n   * @param body - The new permissions to assign to the role.\n   * @returns An Observable that emits the updated module permissions.\n   */\n  putRole (id: number, body: RoleIn): Observable<RoleOut> {\n    return this.http.put<ApiSuccess<RoleOut>>(`${this.url}/roles/${id}`, body)\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Deletes the permissions associated with a specific role.\n   *\n   * @param {number} id - The unique identifier of the role whose permissions are to be deleted.\n   * @returns {Observable<{}>} An observable that emits the result of the delete operation.\n   */\n  deleteRole (id: number): Observable<{}> {\n    return this.http.delete<ApiSuccess<{}>>(`${this.url}/roles/${id}`)\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Retrieves the role types from the API.\n   *\n   * @param {QueryParams} params - The query parameters to be sent with the request.\n   * @returns {Observable<RoleTypesOut>} An observable containing the role types output.\n   */\n  getRoleTypes (params: QueryParams): Observable<RoleTypesOut> {\n    return this.http.get<ApiSuccess<RoleTypesOut>>(`${this.url}/role-types`, { params })\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Retrieves a list of modules and permissions\n   *\n   * @param queryParams - The query parameters to filter the modules.\n   * @returns Observable<ModulesOut[]> - An observable that emits an array of modules and permissions.\n   */\n  getModules (queryParams: QueryParams): Observable<ModulesOut> {\n    return this.http.get<ApiSuccess<ModulesOut>>(`${this.url}/modules`, {\n      params: queryParams\n    }).pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Retrieves a list of modules and permissions\n   *\n   * @param params.token - Custom token for authorization.\n   * @param params.queryParams - The query parameters to filter the modules.\n   * @returns Observable<ModulesOut[]> - An observable that emits an array of modules and permissions.\n   */\n  getModulesByToken (params: {\n    token: string,\n    queryParams: QueryParams\n  }): Observable<ModulesOut> {\n    return this.http.get<ApiSuccess<ModulesOut>>(`${this.url}/modules`, {\n      params: params.queryParams,\n      headers: {\n        Authorization: `Bearer ${params.token}`\n      }\n    }).pipe(map(({ data }) => data))\n  }\n}\n"]}
|
|
@@ -100,4 +100,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
100
100
|
type: Inject,
|
|
101
101
|
args: ['env']
|
|
102
102
|
}] }, { type: i1.HttpClient }] });
|
|
103
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
103
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-services.service.js","sourceRoot":"","sources":["../../../../../../projects/experteam-mx/ngx-services/src/lib/apis/api-services.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAIlD,OAAO,EAAE,GAAG,EAAc,MAAM,MAAM,CAAA;;;AAmBtC,MAAM,OAAO,kBAAkB;IAEJ;IACf;IAFV,YACyB,YAAyB,EACxC,IAAgB;QADD,iBAAY,GAAZ,YAAY,CAAa;QACxC,SAAI,GAAJ,IAAI,CAAY;IACvB,CAAC;IAEJ;;;;;OAKG;IACH,IAAI,GAAG;QACL,OAAO,IAAI,CAAC,YAAY,CAAC,cAAc,IAAI,EAAE,CAAA;IAC/C,CAAC;IAED;;;;;OAKG;IACH,gBAAgB,CAAE,IAAmB;QACnC,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAA8B,GAAG,IAAI,CAAC,GAAG,gBAAgB,EAAE,IAAI,CAAC;aAClF,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAClC,CAAC;IAED;;;;;OAKG;IACH,oBAAoB,CAAE,IAAwB;QAC5C,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAkC,GAAG,IAAI,CAAC,GAAG,aAAa,EAAE,IAAI,CAAC;aACnF,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAClC,CAAC;IAED;;;;;OAKG;IACH,cAAc,CAAE,IAAkB;QAChC,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAiB,GAAG,IAAI,CAAC,GAAG,eAAe,EAAE,IAAI,CAAC;aACpE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAClC,CAAC;IAED;;;;;OAKG;IACH,aAAa,CAAE,IAAiB;QAC9B,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAA2B,GAAG,IAAI,CAAC,GAAG,aAAa,EAAE,IAAI,CAAC;aAC5E,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAClC,CAAC;IAED;;;;;OAKG;IACH,eAAe,CAAE,IAAmB;QAClC,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAA6B,GAAG,IAAI,CAAC,GAAG,eAAe,EAAE,IAAI,CAAC;aAChF,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAClC,CAAC;IAED;;;;;OAKG;IACH,4BAA4B,CAAE,IAAgC;QAC5D,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAA0C,GAAG,IAAI,CAAC,GAAG,gCAAgC,EAAE,IAAI,CAAC;aAC9G,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAClC,CAAC;IAED;;;;OAIG;IACH,kBAAkB,CAAE,WAAiC;QACnD,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAiC,GAAG,IAAI,CAAC,GAAG,mBAAmB,EAAE;YACnF,MAAM,EAAE,WAAW;SACpB,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAClC,CAAC;wGA3FU,kBAAkB,kBAEnB,KAAK;4GAFJ,kBAAkB,cAHjB,MAAM;;4FAGP,kBAAkB;kBAJ9B,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB;;0BAII,MAAM;2BAAC,KAAK","sourcesContent":["import { Inject, Injectable } from '@angular/core'\nimport { Environment } from '../ngx-services.models'\nimport { HttpClient } from '@angular/common/http'\nimport { ApiSuccess } from './models/api.models'\nimport { map, Observable } from 'rxjs'\nimport {\n  ValidateFacilityIn,\n  ValidateFacilityOut,\n  ServiceAreasOut,\n  EmailErrorIn,\n  PromotionIn,\n  PromotionOut,\n  ValidateNIPOut,\n  ValidateNIPIn,\n  ValidateIdentificationBROut,\n  ValidateIdentificationBRIn, ServiceAreaIn, PostalLocationsOut, GetPostalLocationsIn\n} from './models/api-services.types'\nimport { ModulesOut } from './models/api-security.types'\n\n@Injectable({\n  providedIn: 'root'\n})\n\nexport class ApiServicesService {\n  constructor (\n    @Inject('env') private environments: Environment,\n    private http: HttpClient\n  ) {}\n\n  /**\n   * Retrieves the URL for the services API from the environment settings.\n   * If the URL is not defined, an empty string is returned.\n   *\n   * @return {string} The API Services URL or an empty string if not defined.\n   */\n  get url (): string {\n    return this.environments.apiServicesUrl ?? ''\n  }\n\n  /**\n   * Retrieves service areas based on the provided query parameters.\n   *\n   * @param {ServiceAreaIn} body - The query parameters used to filter and retrieve service areas.\n   * @return {Observable<NotificationsOut>} An observable that emits the fetched service areas.\n   */\n  postServiceAreas (body: ServiceAreaIn): Observable<ServiceAreasOut> {\n    return this.http.post<ApiSuccess<ServiceAreasOut>>(`${this.url}/service-areas`, body)\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Validate facility values based on the provided parameter.\n   *\n   * @param {ValidateFacilityIn} body - The facility data to be sent in the request body\n   * @return {Observable<ValidateFacilityOut>} An observable emitting the response containing the facility validated output data.\n   */\n  postValidateFacility (body: ValidateFacilityIn): Observable<ValidateFacilityOut> {\n    return this.http.post<ApiSuccess<ValidateFacilityOut>>(`${this.url}/facilities`, body)\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Create an email resource.\n   *\n   * @param {EmailErrorIn} body - The email data to be sent in the request body\n   * @return {Observable<{}>} An observable emitting the response data.\n   */\n  postEmailError (body: EmailErrorIn): Observable<{}> {\n    return this.http.post<ApiSuccess<{}>>(`${this.url}/emails/error`, body)\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Sends a promotion request to the server using the provided body.\n   *\n   * @param {PromotionIn} body - The promotion data to be sent in the request body.\n   * @return {Observable<PromotionOut>} An observable emitting the response containing the promotion output data.\n   */\n  postPromotion (body: PromotionIn): Observable<PromotionOut> {\n    return this.http.post<ApiSuccess<PromotionOut>>(`${this.url}/promotions`, body)\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Validate NIP account value based on the provided parameter.\n   *\n   * @param {ValidateNIPIn} body - The NIP account data to be sent in the request body\n   * @return {Observable<ValidateNIPOut>} An observable emitting the response containing the NIP account validated data.\n   */\n  postValidateNIP (body: ValidateNIPIn): Observable<ValidateNIPOut> {\n    return this.http.post<ApiSuccess<ValidateNIPOut>>(`${this.url}/accounts/nip`, body)\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Validate BR Identification value based on the provided parameter.\n   *\n   * @param {ValidateIdentificationBRIn} body - The BR Identification data to be sent in the request body\n   * @return {Observable<ValidateIdentificationBROut>} An observable emitting the response containing the BR Identification validated data.\n   */\n  postValidateIdentificationBR (body: ValidateIdentificationBRIn): Observable<ValidateIdentificationBROut> {\n    return this.http.post<ApiSuccess<ValidateIdentificationBROut>>(`${this.url}/identifications/br-validation`, body)\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Fetches postal location details based on the provided query parameters.\n   * @param {GetPostalLocationsIn} queryParams - The query parameters to filter and fetch postal location data.\n   * @return {Observable<PostalLocationsOut>} An observable that emits the postal location details.\n   */\n  getPostalLocations (queryParams: GetPostalLocationsIn): Observable<PostalLocationsOut> {\n    return this.http.get<ApiSuccess<PostalLocationsOut>>(`${this.url}/postal-locations`, {\n      params: queryParams\n    }).pipe(map(({ data }) => data))\n  }\n}\n"]}
|
|
@@ -84,4 +84,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
84
84
|
type: Inject,
|
|
85
85
|
args: ['env']
|
|
86
86
|
}] }, { type: i1.HttpClient }] });
|
|
87
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
87
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLXNoaXBtZW50cy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZXhwZXJ0ZWFtLW14L25neC1zZXJ2aWNlcy9zcmMvbGliL2FwaXMvYXBpLXNoaXBtZW50cy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBQ2xELE9BQU8sRUFBRSxHQUFHLEVBQWMsTUFBTSxNQUFNLENBQUE7OztBQWlCdEMsTUFBTSxPQUFPLG1CQUFtQjtJQUVMO0lBQ2Y7SUFGVixZQUN5QixZQUF5QixFQUN4QyxJQUFnQjtRQURELGlCQUFZLEdBQVosWUFBWSxDQUFhO1FBQ3hDLFNBQUksR0FBSixJQUFJLENBQVk7SUFDdEIsQ0FBQztJQUVMOzs7O09BSUc7SUFDSCxJQUFJLEdBQUc7UUFDTCxPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsY0FBYyxJQUFJLEVBQUUsQ0FBQTtJQUMvQyxDQUFDO0lBRUQ7Ozs7OztPQU1HO0lBQ0gsbUJBQW1CLENBQUUsSUFBdUI7UUFDMUMsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBaUMsR0FBRyxJQUFJLENBQUMsR0FBRyxXQUFXLEVBQUUsSUFBSSxDQUFDO2FBQ2hGLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFLElBQUksRUFBRSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFBO0lBQ2xDLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNILG9CQUFvQixDQUFFLElBQXdCO1FBQzVDLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQWtDLEdBQUcsSUFBSSxDQUFDLEdBQUcscUJBQXFCLEVBQUUsSUFBSSxDQUFDO2FBQzNGLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFLElBQUksRUFBRSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFBO0lBQ2xDLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNILG1CQUFtQixDQUFFLEVBQVU7UUFDN0IsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBdUMsR0FBRyxJQUFJLENBQUMsR0FBRyxnQ0FBZ0MsRUFBRSxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQTtJQUMzSSxDQUFDO0lBRUQ7Ozs7Ozs7O09BUUc7SUFDSCwwQkFBMEIsQ0FBRSxFQUFFLFVBQVUsRUFBRSxRQUFRLEVBQTBCO1FBQzFFLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQXNDLEdBQUcsSUFBSSxDQUFDLEdBQUcsY0FBYyxVQUFVLGVBQWUsRUFBRTtZQUM5RyxvQkFBb0IsRUFBRSxRQUFRO1NBQy9CLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQTtJQUNsQyxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSCxjQUFjLENBQUUsTUFBbUI7UUFDakMsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBNkIsR0FBRyxJQUFJLENBQUMsR0FBRyxlQUFlLEVBQUU7WUFDM0UsTUFBTTtTQUNQLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQTtJQUNsQyxDQUFDO3dHQXpFVSxtQkFBbUIsa0JBRXBCLEtBQUs7NEdBRkosbUJBQW1CLGNBRmxCLE1BQU07OzRGQUVQLG1CQUFtQjtrQkFIL0IsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkI7OzBCQUdJLE1BQU07MkJBQUMsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEh0dHBDbGllbnQgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCdcbmltcG9ydCB7IEluamVjdCwgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQgeyBtYXAsIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJ1xuaW1wb3J0IHsgRW52aXJvbm1lbnQgfSBmcm9tICcuLi9uZ3gtc2VydmljZXMubW9kZWxzJ1xuaW1wb3J0IHtcbiAgRXhwb3J0VHlwZXNPdXQsXG4gIE1hbmlmZXN0TXVsdGlwbGVJbixcbiAgTWFuaWZlc3RNdWx0aXBsZU91dCxcbiAgU2hpcG1lbnRDYW5jZWxsYXRpb25JbixcbiAgU2hpcG1lbnRDYW5jZWxsYXRpb25PdXQsXG4gIFNoaXBtZW50RW1wbG95ZWVDdXN0b21lcixcbiAgVmFsaWRhdGVBY2NvdW50SW4sXG4gIFZhbGlkYXRlQWNjb3VudE91dFxufSBmcm9tICcuL21vZGVscy9hcGktc2hpcG1lbnRzLnR5cGVzJ1xuaW1wb3J0IHsgQXBpU3VjY2VzcywgUXVlcnlQYXJhbXMgfSBmcm9tICcuL21vZGVscy9hcGkubW9kZWxzJ1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBBcGlTaGlwbWVudHNTZXJ2aWNlIHtcbiAgY29uc3RydWN0b3IgKFxuICAgIEBJbmplY3QoJ2VudicpIHByaXZhdGUgZW52aXJvbm1lbnRzOiBFbnZpcm9ubWVudCxcbiAgICBwcml2YXRlIGh0dHA6IEh0dHBDbGllbnRcbiAgKSB7IH1cblxuICAvKipcbiAgICogUmV0cmlldmVzIHRoZSBVUkwgZm9yIHRoZSBzaGlwbWVudHMgQVBJIGZyb20gdGhlIGVudmlyb25tZW50IGNvbmZpZ3VyYXRpb25zLlxuICAgKlxuICAgKiBAcmV0dXJuIHtzdHJpbmd9IFRoZSBVUkwgb2YgdGhlIHNoaXBtZW50cyBBUEkuXG4gICAqL1xuICBnZXQgdXJsICgpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLmVudmlyb25tZW50cy5hcGlTaGlwbWVudFVybCA/PyAnJ1xuICB9XG5cbiAgLyoqXG4gICAqIFJldHJpZXZlcyB0aGUgcGFyYW1ldGVyIHZhbHVlcyBiYXNlZCBvbiB0aGUgcHJvdmlkZWQgcGFyYW1ldGVyIG5hbWVzLlxuICAgKlxuICAgKiBAcGFyYW0ge1ZhbGlkYXRlQWNjb3VudElufSBib2R5IC0gQW4gb2JqZWN0IG9mIHBhcmFtZXRlciBuYW1lcyBmb3Igd2hpY2ggdGhlIHZhbHVlcyBuZWVkIHRvIGJlIGZldGNoZWQuXG4gICAqIEByZXR1cm4ge09ic2VydmFibGU8VmFsaWRhdGVBY2NvdW50SW4+fSBBbiBvYnNlcnZhYmxlIHRoYXQgZW1pdHMgdGhlIGZldGNoZWQgcGFyYW1ldGVyIHZhbHVlc1xuICAgKiBAcGFyYW0gYm9keVxuICAgKi9cbiAgcG9zdFZhbGlkYXRlQWNjb3VudCAoYm9keTogVmFsaWRhdGVBY2NvdW50SW4pOiBPYnNlcnZhYmxlPFZhbGlkYXRlQWNjb3VudE91dD4ge1xuICAgIHJldHVybiB0aGlzLmh0dHAucG9zdDxBcGlTdWNjZXNzPFZhbGlkYXRlQWNjb3VudE91dD4+KGAke3RoaXMudXJsfS9hY2NvdW50c2AsIGJvZHkpXG4gICAgICAucGlwZShtYXAoKHsgZGF0YSB9KSA9PiBkYXRhKSlcbiAgfVxuXG4gIC8qKlxuICAgKiBTZW5kcyBhIFBPU1QgcmVxdWVzdCB0byB0aGUgc2hpcG1lbnRzIG1hbmlmZXN0IGVuZHBvaW50IHdpdGggdGhlIHByb3ZpZGVkIGJvZHkuXG4gICAqXG4gICAqIEBwYXJhbSBib2R5IC0gVGhlIHJlcXVlc3QgcGF5bG9hZCBvZiB0eXBlIGBNYW5pZmVzdE11bHRpcGxlSW5gLlxuICAgKiBAcmV0dXJucyBBbiBvYnNlcnZhYmxlIHRoYXQgZW1pdHMgdGhlIHJlc3BvbnNlIGRhdGEgb2YgdHlwZSBgTWFuaWZlc3RNdWx0aXBsZU91dGAuXG4gICAqL1xuICBwb3N0TWFuaWZlc3RNdWx0aXBsZSAoYm9keTogTWFuaWZlc3RNdWx0aXBsZUluKSB7XG4gICAgcmV0dXJuIHRoaXMuaHR0cC5wb3N0PEFwaVN1Y2Nlc3M8TWFuaWZlc3RNdWx0aXBsZU91dD4+KGAke3RoaXMudXJsfS9zaGlwbWVudHMvbWFuaWZlc3RgLCBib2R5KVxuICAgICAgLnBpcGUobWFwKCh7IGRhdGEgfSkgPT4gZGF0YSkpXG4gIH1cblxuICAvKipcbiAgICogVmFsaWRhdGVzIGFuZCBvYnRhaW5zIHRoZSBudW1iZXIgb2Ygc2hpcG1lbnRzIGFsbG93ZWQgYnkgYW4gZW1wbG95ZWUgY3VzdG9tZXJcbiAgICpcbiAgICogQHJldHVybiB7T2JzZXJ2YWJsZTxTaGlwbWVudEVtcGxveWVlQ3VzdG9tZXI+fSBBbiBvYnNlcnZhYmxlIGNvbnRhaW5pbmcgdGhlIHNoaXBtZW50cyBhbGxvd2VkIGJ5IGFuIGVtcGxveWVlXG4gICAqIEBwYXJhbSBpZFxuICAgKi9cbiAgZ2V0RW1wbG95ZWVDdXN0b21lciAoaWQ6IG51bWJlcik6IE9ic2VydmFibGU8U2hpcG1lbnRFbXBsb3llZUN1c3RvbWVyPiB7XG4gICAgcmV0dXJuIHRoaXMuaHR0cC5nZXQ8QXBpU3VjY2VzczxTaGlwbWVudEVtcGxveWVlQ3VzdG9tZXI+PihgJHt0aGlzLnVybH0vc2hpcG1lbnRzL2VtcGxveWVlLWN1c3RvbWVyLyR7aWR9YCkucGlwZShtYXAoKHsgZGF0YSB9KSA9PiBkYXRhKSlcbiAgfVxuXG4gIC8qKlxuICAgKiBDYW5jZWxzIGEgc3BlY2lmaWMgc2hpcG1lbnQgYnkgcHJvdmlkaW5nIGl0cyBJRCBhbmQgYSByZWFzb24gZm9yIGNhbmNlbGxhdGlvbi5cbiAgICogU2VuZHMgYSBQQVRDSCByZXF1ZXN0IHRvIHVwZGF0ZSB0aGUgc2hpcG1lbnQncyBjYW5jZWxsYXRpb24gc3RhdHVzIHdpdGggdGhlIHNwZWNpZmllZCByZWFzb24uXG4gICAqXG4gICAqIEBwYXJhbSB7T2JqZWN0fSBwYXJhbTAgLSBUaGUgaW5wdXQgb2JqZWN0IGNvbnRhaW5pbmcgc2hpcG1lbnQgY2FuY2VsbGF0aW9uIGRldGFpbHMuXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBwYXJhbTAuc2hpcG1lbnRJZCAtIFRoZSB1bmlxdWUgaWRlbnRpZmllciBvZiB0aGUgc2hpcG1lbnQgdG8gYmUgY2FuY2VsZWQuXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBwYXJhbTAucmVhc29uSWQgLSBUaGUgdW5pcXVlIGlkZW50aWZpZXIgb2YgdGhlIHJlYXNvbiBmb3IgY2FuY2VsbGF0aW9uLlxuICAgKiBAcmV0dXJuIHtPYnNlcnZhYmxlPFNoaXBtZW50Q2FuY2VsbGF0aW9uT3V0Pn0gQW4gb2JzZXJ2YWJsZSBlbWl0dGluZyB0aGUgcmVzdWx0IG9mIHRoZSBjYW5jZWxsYXRpb24gb3BlcmF0aW9uLlxuICAgKi9cbiAgcGF0Y2hTaGlwbWVudHNDYW5jZWxsYXRpb24gKHsgc2hpcG1lbnRJZCwgcmVhc29uSWQgfTogU2hpcG1lbnRDYW5jZWxsYXRpb25Jbik6IE9ic2VydmFibGU8U2hpcG1lbnRDYW5jZWxsYXRpb25PdXQ+IHtcbiAgICByZXR1cm4gdGhpcy5odHRwLnBhdGNoPEFwaVN1Y2Nlc3M8U2hpcG1lbnRDYW5jZWxsYXRpb25PdXQ+PihgJHt0aGlzLnVybH0vc2hpcG1lbnRzLyR7c2hpcG1lbnRJZH0vY2FuY2VsbGF0aW9uYCwge1xuICAgICAgY2FuY2VsbGF0aW9uUmVhc29uSWQ6IHJlYXNvbklkXG4gICAgfSkucGlwZShtYXAoKHsgZGF0YSB9KSA9PiBkYXRhKSlcbiAgfVxuXG4gIC8qKlxuICAgKiBGZXRjaGVzIGEgbGlzdCBvZiBleHBvcnQgdHlwZXMgYmFzZWQgb24gdGhlIHByb3ZpZGVkIHF1ZXJ5IHBhcmFtZXRlcnMuXG4gICAqXG4gICAqIEBwYXJhbSB7UXVlcnlQYXJhbXN9IHBhcmFtcyAtIFRoZSBxdWVyeSBwYXJhbWV0ZXJzIHRvIGZpbHRlciB0aGUgZXhwb3J0IHR5cGVzLlxuICAgKiBAcmV0dXJuIHtPYnNlcnZhYmxlPEV4cG9ydFR5cGVzT3V0Pn0gQW4gb2JzZXJ2YWJsZSBjb250YWluaW5nIHRoZSBsaXN0IG9mIGV4cG9ydCB0eXBlcy5cbiAgICovXG4gIGdldEV4cG9ydFR5cGVzIChwYXJhbXM6IFF1ZXJ5UGFyYW1zKTogT2JzZXJ2YWJsZTxFeHBvcnRUeXBlc091dD4ge1xuICAgIHJldHVybiB0aGlzLmh0dHAuZ2V0PEFwaVN1Y2Nlc3M8RXhwb3J0VHlwZXNPdXQ+PihgJHt0aGlzLnVybH0vZXhwb3J0LXR5cGVzYCwge1xuICAgICAgcGFyYW1zXG4gICAgfSkucGlwZShtYXAoKHsgZGF0YSB9KSA9PiBkYXRhKSlcbiAgfVxufVxuIl19
|
|
@@ -130,4 +130,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
130
130
|
type: Inject,
|
|
131
131
|
args: ['env']
|
|
132
132
|
}] }, { type: i1.HttpClient }] });
|
|
133
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-supplies.service.js","sourceRoot":"","sources":["../../../../../../projects/experteam-mx/ngx-services/src/lib/apis/api-supplies.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http'\r\nimport { Inject, Injectable } from '@angular/core'\r\nimport { Environment } from '../ngx-services.models'\r\nimport { map, Observable } from 'rxjs'\r\nimport { ApiSuccess, QueryParams } from './models/api.models'\r\nimport {\r\n  SuppliesOut,\r\n  SupplyIn,\r\n  SupplyLocationIn,\r\n  SupplyLocationOut, SupplyLocationsOut, SupplyLocationTransactionIn, SupplyLocationTransactionOut,\r\n  SupplyOut, SupplyTransactionTypesOut,\r\n  SupplyTypesOut\r\n} from './models/api-supplies.types'\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class ApiSuppliesService {\r\n  constructor (\r\n    @Inject('env') private environments: Environment,\r\n    private http: HttpClient\r\n  ) { }\r\n\r\n  /**\r\n   * Retrieves the URL for the API supplies endpoint.\r\n   *\r\n   * @return {string} The API supplies URL or an empty string if not defined.\r\n   */\r\n  get url (): string {\r\n    return this.environments.apiSuppliesUrl ?? ''\r\n  }\r\n\r\n  /**\r\n   * Fetches a list of supplies based on the provided query parameters.\r\n   *\r\n   * @param {QueryParams} params - The query parameters to filter the supplies.\r\n   * @return {Observable<SuppliesOut>} An observable containing the list of supplies.\r\n   */\r\n  getSupplies (params: QueryParams): Observable<SuppliesOut> {\r\n    return this.http.get<ApiSuccess<SuppliesOut>>(`${this.url}/supplies`, { params })\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Retrieves the supply details for a given supply ID.\r\n   *\r\n   * @param {number} id - The unique identifier of the supply to retrieve.\r\n   * @return {Observable<SupplyOut>} An observable containing the supply details.\r\n   */\r\n  getSupply (id: number): Observable<SupplyOut> {\r\n    return this.http.get<ApiSuccess<SupplyOut>>(`${this.url}/supplies/${id}`)\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Sends a supply object to the server and returns the created or updated supply information.\r\n   *\r\n   * @param {SupplyIn} body - The supply information to be sent to the server.\r\n   * @return {Observable<SupplyOut>} An observable containing the response with the supply data.\r\n   */\r\n  postSupply (body: SupplyIn): Observable<SupplyOut> {\r\n    return this.http.post<ApiSuccess<SupplyOut>>(`${this.url}/supplies`, body)\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Updates an existing supply with the provided data.\r\n   *\r\n   * @param {number} id - The unique identifier of the supply to update.\r\n   * @param {SupplyIn} body - The data to update the supply with.\r\n   * @return {Observable<SupplyOut>} An observable containing the updated supply information.\r\n   */\r\n  putSupply (id: number, body: SupplyIn): Observable<SupplyOut> {\r\n    return this.http.put<ApiSuccess<SupplyOut>>(`${this.url}/supplies/${id}`, body)\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Fetches the supply types based on the provided query parameters.\r\n   *\r\n   * @param {QueryParams} params - The query parameters to filter the supply types.\r\n   * @return {Observable<SupplyTypesOut>} An Observable that emits the supply types data.\r\n   */\r\n  getSupplyTypes (params: QueryParams): Observable<SupplyTypesOut> {\r\n    return this.http.get<ApiSuccess<SupplyTypesOut>>(`${this.url}/supply-types`, { params })\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Creates a new supply location.\r\n   *\r\n   * @param {SupplyLocationIn} body - The supply location data to create.\r\n   * @return {Observable<SupplyLocationOut>} An Observable that emits the created supply location data.\r\n   */\r\n  postSupplyLocations (body: SupplyLocationIn): Observable<SupplyLocationOut> {\r\n    return this.http.post<ApiSuccess<SupplyLocationOut>>(`${this.url}/supply-locations`, body)\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Fetches the supply locations based on the provided query parameters.\r\n   *\r\n   * @param {QueryParams} params - The query parameters to filter the supply locations.\r\n   * @return {Observable<SupplyLocationsOut>} An Observable that emits the supply locations data.\r\n   */\r\n  getSupplyLocations (params: QueryParams): Observable<SupplyLocationsOut> {\r\n    return this.http.get<ApiSuccess<SupplyLocationsOut>>(`${this.url}/supply-locations`, { params })\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Creates a new supply location transaction.\r\n   *\r\n   * @param {SupplyLocationTransactionIn} body - The transaction data to create.\r\n   * @return {Observable<SupplyLocationTransactionOut>} An Observable that emits the created transaction data.\r\n   */\r\n  postSupplyLocationTransaction (body: SupplyLocationTransactionIn): Observable<SupplyLocationTransactionOut> {\r\n    return this.http.post<ApiSuccess<SupplyLocationTransactionOut>>(`${this.url}/supply-location-transactions`, body)\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Fetches the supply transaction types based on the provided query parameters.\r\n   *\r\n   * @param {QueryParams} params - The query parameters to filter the transaction types.\r\n   * @return {Observable<SupplyTransactionTypesOut>} An Observable that emits the supply transaction types data.\r\n   */\r\n  getSupplyTransactionTypes (params: QueryParams): Observable<SupplyTransactionTypesOut> {\r\n    return this.http.get<ApiSuccess<SupplyTransactionTypesOut>>(`${this.url}/supply-transaction-types`, { params })\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n\r\n  /**\r\n   * Exports the supply locations to an Excel file.\r\n   *\r\n   * @param {QueryParams} params - The query parameters to filter the data before export.\r\n   * @return {Observable<{ mime_type: string; base64: string }>} An Observable that emits the exported file's MIME type and Base64 content.\r\n   */\r\n  getSupplyLocationsExportToExcel (params: QueryParams): Observable<{ mime_type: string; base64: string }> {\r\n    return this.http.get<ApiSuccess<{ mime_type: string; base64: string }>>(`${this.url}/supply-locations/export/excel`, { params })\r\n      .pipe(map(({ data }) => data))\r\n  }\r\n}\r\n"]}
|
|
133
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-supplies.service.js","sourceRoot":"","sources":["../../../../../../projects/experteam-mx/ngx-services/src/lib/apis/api-supplies.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http'\nimport { Inject, Injectable } from '@angular/core'\nimport { Environment } from '../ngx-services.models'\nimport { map, Observable } from 'rxjs'\nimport { ApiSuccess, QueryParams } from './models/api.models'\nimport {\n  SuppliesOut,\n  SupplyIn,\n  SupplyLocationIn,\n  SupplyLocationOut, SupplyLocationsOut, SupplyLocationTransactionIn, SupplyLocationTransactionOut,\n  SupplyOut, SupplyTransactionTypesOut,\n  SupplyTypesOut\n} from './models/api-supplies.types'\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class ApiSuppliesService {\n  constructor (\n    @Inject('env') private environments: Environment,\n    private http: HttpClient\n  ) { }\n\n  /**\n   * Retrieves the URL for the API supplies endpoint.\n   *\n   * @return {string} The API supplies URL or an empty string if not defined.\n   */\n  get url (): string {\n    return this.environments.apiSuppliesUrl ?? ''\n  }\n\n  /**\n   * Fetches a list of supplies based on the provided query parameters.\n   *\n   * @param {QueryParams} params - The query parameters to filter the supplies.\n   * @return {Observable<SuppliesOut>} An observable containing the list of supplies.\n   */\n  getSupplies (params: QueryParams): Observable<SuppliesOut> {\n    return this.http.get<ApiSuccess<SuppliesOut>>(`${this.url}/supplies`, { params })\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Retrieves the supply details for a given supply ID.\n   *\n   * @param {number} id - The unique identifier of the supply to retrieve.\n   * @return {Observable<SupplyOut>} An observable containing the supply details.\n   */\n  getSupply (id: number): Observable<SupplyOut> {\n    return this.http.get<ApiSuccess<SupplyOut>>(`${this.url}/supplies/${id}`)\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Sends a supply object to the server and returns the created or updated supply information.\n   *\n   * @param {SupplyIn} body - The supply information to be sent to the server.\n   * @return {Observable<SupplyOut>} An observable containing the response with the supply data.\n   */\n  postSupply (body: SupplyIn): Observable<SupplyOut> {\n    return this.http.post<ApiSuccess<SupplyOut>>(`${this.url}/supplies`, body)\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Updates an existing supply with the provided data.\n   *\n   * @param {number} id - The unique identifier of the supply to update.\n   * @param {SupplyIn} body - The data to update the supply with.\n   * @return {Observable<SupplyOut>} An observable containing the updated supply information.\n   */\n  putSupply (id: number, body: SupplyIn): Observable<SupplyOut> {\n    return this.http.put<ApiSuccess<SupplyOut>>(`${this.url}/supplies/${id}`, body)\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Fetches the supply types based on the provided query parameters.\n   *\n   * @param {QueryParams} params - The query parameters to filter the supply types.\n   * @return {Observable<SupplyTypesOut>} An Observable that emits the supply types data.\n   */\n  getSupplyTypes (params: QueryParams): Observable<SupplyTypesOut> {\n    return this.http.get<ApiSuccess<SupplyTypesOut>>(`${this.url}/supply-types`, { params })\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Creates a new supply location.\n   *\n   * @param {SupplyLocationIn} body - The supply location data to create.\n   * @return {Observable<SupplyLocationOut>} An Observable that emits the created supply location data.\n   */\n  postSupplyLocations (body: SupplyLocationIn): Observable<SupplyLocationOut> {\n    return this.http.post<ApiSuccess<SupplyLocationOut>>(`${this.url}/supply-locations`, body)\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Fetches the supply locations based on the provided query parameters.\n   *\n   * @param {QueryParams} params - The query parameters to filter the supply locations.\n   * @return {Observable<SupplyLocationsOut>} An Observable that emits the supply locations data.\n   */\n  getSupplyLocations (params: QueryParams): Observable<SupplyLocationsOut> {\n    return this.http.get<ApiSuccess<SupplyLocationsOut>>(`${this.url}/supply-locations`, { params })\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Creates a new supply location transaction.\n   *\n   * @param {SupplyLocationTransactionIn} body - The transaction data to create.\n   * @return {Observable<SupplyLocationTransactionOut>} An Observable that emits the created transaction data.\n   */\n  postSupplyLocationTransaction (body: SupplyLocationTransactionIn): Observable<SupplyLocationTransactionOut> {\n    return this.http.post<ApiSuccess<SupplyLocationTransactionOut>>(`${this.url}/supply-location-transactions`, body)\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Fetches the supply transaction types based on the provided query parameters.\n   *\n   * @param {QueryParams} params - The query parameters to filter the transaction types.\n   * @return {Observable<SupplyTransactionTypesOut>} An Observable that emits the supply transaction types data.\n   */\n  getSupplyTransactionTypes (params: QueryParams): Observable<SupplyTransactionTypesOut> {\n    return this.http.get<ApiSuccess<SupplyTransactionTypesOut>>(`${this.url}/supply-transaction-types`, { params })\n      .pipe(map(({ data }) => data))\n  }\n\n  /**\n   * Exports the supply locations to an Excel file.\n   *\n   * @param {QueryParams} params - The query parameters to filter the data before export.\n   * @return {Observable<{ mime_type: string; base64: string }>} An Observable that emits the exported file's MIME type and Base64 content.\n   */\n  getSupplyLocationsExportToExcel (params: QueryParams): Observable<{ mime_type: string; base64: string }> {\n    return this.http.get<ApiSuccess<{ mime_type: string; base64: string }>>(`${this.url}/supply-locations/export/excel`, { params })\n      .pipe(map(({ data }) => data))\n  }\n}\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLWJpbGxpbmctZG8uaW50ZXJmYWNlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2V4cGVydGVhbS1teC9uZ3gtc2VydmljZXMvc3JjL2xpYi9hcGlzL21vZGVscy9hcGktYmlsbGluZy1kby5pbnRlcmZhY2VzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBMYXJhdmVsTW9kZWwgfSBmcm9tICcuL2FwaS5tb2RlbHMnXG5cbmV4cG9ydCBpbnRlcmZhY2UgSW5jb21lVHlwZSBleHRlbmRzIExhcmF2ZWxNb2RlbCB7XG4gIGNvZGU6IHN0cmluZ1xuICBuYW1lOiBzdHJpbmdcbiAgYmlsbGluZ19jb2RlOiBzdHJpbmdcbn1cbiJdfQ==
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLWJpbGxpbmctZG8udHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9leHBlcnRlYW0tbXgvbmd4LXNlcnZpY2VzL3NyYy9saWIvYXBpcy9tb2RlbHMvYXBpLWJpbGxpbmctZG8udHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluY29tZVR5cGUgfSBmcm9tICcuL2FwaS1iaWxsaW5nLWRvLmludGVyZmFjZXMnXG5cbmV4cG9ydCB0eXBlIEluY29tZVR5cGVzT3V0ID0ge1xuICBpbmNvbWVfdHlwZXM6IEluY29tZVR5cGVbXVxuICB0b3RhbDogbnVtYmVyXG59XG4iXX0=
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLWJpbGxpbmctbXguaW50ZXJmYWNlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2V4cGVydGVhbS1teC9uZ3gtc2VydmljZXMvc3JjL2xpYi9hcGlzL21vZGVscy9hcGktYmlsbGluZy1teC5pbnRlcmZhY2VzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBMYXJhdmVsTW9kZWwgfSBmcm9tICcuL2FwaS5tb2RlbHMnXG5cbmV4cG9ydCBpbnRlcmZhY2UgQ0ZESSBleHRlbmRzIExhcmF2ZWxNb2RlbCB7XG4gIGNvZGU6IHN0cmluZ1xuICBkZXNjcmlwdGlvbjogc3RyaW5nXG4gIGZpc2NhbF9yZWdpbWVuX3JlY2VwdG9yOiBzdHJpbmdcbiAgbW9yYWxfcGVyc29uOiBzdHJpbmdcbiAgcGh5c2ljYWxfcGVyc29uOiBzdHJpbmdcbn1cblxuZXhwb3J0IGludGVyZmFjZSBGaXNjYWxSZWdpbWVuIGV4dGVuZHMgTGFyYXZlbE1vZGVsIHtcbiAgY29kZTogc3RyaW5nXG4gIGRlc2NyaXB0aW9uOiBzdHJpbmdcbiAgbW9yYWxfcGVyc29uOiBzdHJpbmdcbiAgcGh5c2ljYWxfcGVyc29uOiBzdHJpbmdcbn1cblxuZXhwb3J0IGludGVyZmFjZSBQb3N0YWxDb2RlQmlsbGluZ3MgZXh0ZW5kcyBMYXJhdmVsTW9kZWwge1xuICBjaXR5OiBzdHJpbmcsXG4gIG11bmljaXBhbGl0eTogc3RyaW5nLFxuICBzdGF0ZTogc3RyaW5nLFxuICBzdWJ1cmI6IHN0cmluZyxcbiAgcG9zdGFsX2NvZGVfbnVtYmVyOiBzdHJpbmcsXG59XG4iXX0=
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLWJpbGxpbmctbXgudHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9leHBlcnRlYW0tbXgvbmd4LXNlcnZpY2VzL3NyYy9saWIvYXBpcy9tb2RlbHMvYXBpLWJpbGxpbmctbXgudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENGREksIEZpc2NhbFJlZ2ltZW4sIFBvc3RhbENvZGVCaWxsaW5ncyB9IGZyb20gJy4vYXBpLWJpbGxpbmctbXguaW50ZXJmYWNlcydcblxuZXhwb3J0IHR5cGUgRmlzY2FsUmVnaW1lbnNBY2NlcHRlZE91dCA9IHtcbiAgdG90YWw6IG51bWJlclxuICBjZmRpX3VzZTogQ0ZESVtdXG59XG5cbmV4cG9ydCB0eXBlIEZpc2NhbFJlZ2ltZW5zT3V0ID0ge1xuICB0b3RhbDogbnVtYmVyXG4gIGZpc2NhbF9yZWdpbWVuOiBGaXNjYWxSZWdpbWVuW11cbn1cblxuZXhwb3J0IHR5cGUgUG9zdGFsQ29kZXNPdXQgPSB7XG4gIHBvc3RhbF9jb2RlOiBQb3N0YWxDb2RlQmlsbGluZ3NbXVxuICB0b3RhbDogbnVtYmVyXG59XG4iXX0=
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLWJpbGxpbmctcGEuaW50ZXJmYWNlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2V4cGVydGVhbS1teC9uZ3gtc2VydmljZXMvc3JjL2xpYi9hcGlzL21vZGVscy9hcGktYmlsbGluZy1wYS5pbnRlcmZhY2VzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBMYXJhdmVsTW9kZWwgfSBmcm9tICcuL2FwaS5tb2RlbHMnXG5cbmV4cG9ydCBpbnRlcmZhY2UgQmlsbGluZ1BhQ3VzdG9tZXIge1xuICBkb2N1bWVudF9pZDogbnVtYmVyXG4gIG5hbWU6IHN0cmluZ1xuICBudW1iZXI6IHN0cmluZ1xuICB0eXBlX3J1YzogbnVtYmVyXG4gIHR5cGVfcnVjX2NvZGU6IHN0cmluZ1xuICB2ZXJpZmljYXRpb25fY29kZTogc3RyaW5nXG4gIHR5cGVfcmVjOiBzdHJpbmdcbiAgaWRlbnRpZmljYXRpb25fdHlwZV9pZDogbnVtYmVyXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGlzdHJpY3QgZXh0ZW5kcyBMYXJhdmVsTW9kZWwge1xuICBjb2RlOiBzdHJpbmdcbiAgbmFtZTogc3RyaW5nXG4gIHByb3ZpbmNlX2lkOiBudW1iZXJcbn1cblxuZXhwb3J0IGludGVyZmFjZSBQYXJpc2ggZXh0ZW5kcyBMYXJhdmVsTW9kZWwge1xuICBjb2RlOiBzdHJpbmdcbiAgbmFtZTogc3RyaW5nXG4gIGRpc3RyaWN0X2lkOiBudW1iZXJcbiAgcHJvdmluY2VfaWQ6IG51bWJlclxufVxuXG5leHBvcnQgaW50ZXJmYWNlIFByb3ZpbmNlIGV4dGVuZHMgTGFyYXZlbE1vZGVsIHtcbiAgY29kZTogc3RyaW5nXG4gIG5hbWU6IHN0cmluZ1xufVxuIl19
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLWJpbGxpbmctcGEudHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9leHBlcnRlYW0tbXgvbmd4LXNlcnZpY2VzL3NyYy9saWIvYXBpcy9tb2RlbHMvYXBpLWJpbGxpbmctcGEudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJpbGxpbmdQYUN1c3RvbWVyLCBEaXN0cmljdCwgUGFyaXNoLCBQcm92aW5jZSB9IGZyb20gJy4vYXBpLWJpbGxpbmctcGEuaW50ZXJmYWNlcydcblxuZXhwb3J0IHR5cGUgRGlzdHJpY3RzT3V0ID0ge1xuICB0b3RhbDogbnVtYmVyXG4gIGRpc3RyaWN0czogRGlzdHJpY3RbXVxufVxuXG5leHBvcnQgdHlwZSBCaWxsaW5nUGFDdXN0b21lck91dCA9IHtcbiAgY3VzdG9tZXI6IEJpbGxpbmdQYUN1c3RvbWVyXG59XG5cbmV4cG9ydCB0eXBlIFBhcmlzaGVzT3V0ID0ge1xuICB0b3RhbDogbnVtYmVyXG4gIHBhcmlzaGVzOiBQYXJpc2hbXVxufVxuXG5leHBvcnQgdHlwZSBQcm92aW5jZXNPdXQgPSB7XG4gIHRvdGFsOiBudW1iZXJcbiAgcHJvdmluY2VzOiBQcm92aW5jZVtdXG59XG4iXX0=
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLWJpbGxpbmctc3YuaW50ZXJmYWNlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2V4cGVydGVhbS1teC9uZ3gtc2VydmljZXMvc3JjL2xpYi9hcGlzL21vZGVscy9hcGktYmlsbGluZy1zdi5pbnRlcmZhY2VzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBMYXJhdmVsTW9kZWwgfSBmcm9tICcuL2FwaS5tb2RlbHMnXG5cbmV4cG9ydCBpbnRlcmZhY2UgUGVyc29uVHlwZSBleHRlbmRzIExhcmF2ZWxNb2RlbCB7XG4gIGNvZGU6IHN0cmluZ1xuICBuYW1lOiBzdHJpbmdcbn1cblxuZXhwb3J0IGludGVyZmFjZSBFY29ub21pY0FjdGl2aXR5IGV4dGVuZHMgTGFyYXZlbE1vZGVsIHtcbiAgY29kZTogc3RyaW5nXG4gIG5hbWU6IHN0cmluZ1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEVzdGFibGlzaG1lbnRUeXBlIGV4dGVuZHMgTGFyYXZlbE1vZGVsIHtcbiAgY29kZTogc3RyaW5nXG4gIG5hbWU6IHN0cmluZ1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIERlcGFydG1lbnQgZXh0ZW5kcyBMYXJhdmVsTW9kZWwge1xuICBjb2RlOiBzdHJpbmdcbiAgbmFtZTogc3RyaW5nXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTXVuaWNpcGFsaXR5IGV4dGVuZHMgTGFyYXZlbE1vZGVsIHtcbiAgY29kZTogc3RyaW5nXG4gIG5hbWU6IHN0cmluZ1xuICBkZXBhcnRtZW50X2NvZGU6IHN0cmluZ1xufVxuIl19
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLWJpbGxpbmctc3YudHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9leHBlcnRlYW0tbXgvbmd4LXNlcnZpY2VzL3NyYy9saWIvYXBpcy9tb2RlbHMvYXBpLWJpbGxpbmctc3YudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERlcGFydG1lbnQsIEVjb25vbWljQWN0aXZpdHksIEVzdGFibGlzaG1lbnRUeXBlLCBNdW5pY2lwYWxpdHksIFBlcnNvblR5cGUgfSBmcm9tICcuL2FwaS1iaWxsaW5nLXN2LmludGVyZmFjZXMnXG5cbmV4cG9ydCB0eXBlIEVjb25vbWljQWN0aXZpdGllc091dCA9IHtcbiAgZWNvbm9taWNfYWN0aXZpdGllczogRWNvbm9taWNBY3Rpdml0eVtdXG4gIHRvdGFsOiBudW1iZXJcbn1cblxuZXhwb3J0IHR5cGUgUGVyc29uVHlwZXNPdXQgPSB7XG4gIHBlcnNvbl90eXBlczogUGVyc29uVHlwZVtdXG4gIHRvdGFsOiBudW1iZXJcbn1cblxuZXhwb3J0IHR5cGUgRXN0YWJsaXNobWVudFR5cGVzT3V0ID0ge1xuICBlc3RhYmxpc2htZW50X3R5cGVzOiBFc3RhYmxpc2htZW50VHlwZVtdXG4gIHRvdGFsOiBudW1iZXJcbn1cblxuZXhwb3J0IHR5cGUgRGVwYXJ0bWVudHNPdXQgPSB7XG4gIGRlcGFydG1lbnRzOiBEZXBhcnRtZW50W11cbiAgdG90YWw6IG51bWJlclxufVxuXG5leHBvcnQgdHlwZSBNdW5pY2lwYWxpdGllc091dCA9IHtcbiAgbXVuaWNpcGFsaXRpZXM6IE11bmljaXBhbGl0eVtdXG4gIHRvdGFsOiBudW1iZXJcbn1cbiJdfQ==
|