@libs-ui/services-http-request 0.1.1-1

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.
@@ -0,0 +1,3 @@
1
+ export * from './http-request-config.interface';
2
+ export * from './guild-auto-update-arguments-value.interface';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL3NlcnZpY2VzL2h0dHAtcmVxdWVzdC9zcmMvaW50ZXJmYWNlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsK0NBQStDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2h0dHAtcmVxdWVzdC1jb25maWcuaW50ZXJmYWNlJztcbmV4cG9ydCAqIGZyb20gJy4vZ3VpbGQtYXV0by11cGRhdGUtYXJndW1lbnRzLXZhbHVlLmludGVyZmFjZSc7XG4iXX0=
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlicy11aS1zZXJ2aWNlcy1odHRwLXJlcXVlc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzLXVpL3NlcnZpY2VzL2h0dHAtcmVxdWVzdC9zcmMvbGlicy11aS1zZXJ2aWNlcy1odHRwLXJlcXVlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=
@@ -0,0 +1,451 @@
1
+ import { HttpParams } from '@angular/common/http';
2
+ import * as i0 from '@angular/core';
3
+ import { inject, Injector, Injectable } from '@angular/core';
4
+ import { get, set, getKeyCacheByArrayObject, UtilsCache, isEmpty, isNil, isEqual, UtilsHttpParamsRequest } from '@libs-ui/utils';
5
+ import { lastValueFrom, timer, of, delay } from 'rxjs';
6
+
7
+ /* eslint-disable @typescript-eslint/no-explicit-any */
8
+ class LibsUiHttpRequestService {
9
+ injector = inject(Injector);
10
+ /** Chứa dữ liệu cache memory */
11
+ serviceStore = new Map();
12
+ async callApi(httpRequestConfig) {
13
+ if (!httpRequestConfig || !httpRequestConfig.functionName) {
14
+ throw 'http request config not exactly httpRequestConfig';
15
+ }
16
+ const serviceOther = get(httpRequestConfig, 'serviceOther'); // TODO: sẽ xóa khi migrate hết component
17
+ if (serviceOther) {
18
+ set(httpRequestConfig, 'objectInstance', serviceOther);
19
+ }
20
+ const { objectInstance, keyCache, functionName, argumentsValue, serviceClass } = httpRequestConfig;
21
+ if (!objectInstance && !serviceClass) {
22
+ throw `http request config not exactly objectInstance or serviceName`;
23
+ }
24
+ const instance = objectInstance || this.injector.get(serviceClass);
25
+ if (!instance) {
26
+ throw `http request notfound service instance`;
27
+ }
28
+ const methodInstance = instance[functionName];
29
+ if (!methodInstance) {
30
+ throw `http request config notfound methodInstance name: ${String(functionName)}`;
31
+ }
32
+ const keyCacheMD5 = getKeyCacheByArrayObject(keyCache || '', argumentsValue);
33
+ const cacheData = await this.getCacheData(httpRequestConfig, keyCacheMD5);
34
+ if (cacheData) {
35
+ return Promise.resolve(cacheData);
36
+ }
37
+ let callResponse = methodInstance.apply(instance, argumentsValue);
38
+ if (!callResponse.then) {
39
+ callResponse = lastValueFrom(callResponse);
40
+ }
41
+ const res = await callResponse;
42
+ return await this.setCacheData(res, httpRequestConfig, keyCacheMD5);
43
+ }
44
+ async getCacheData(httpRequestConfig, keyCache) {
45
+ const { cacheType, convertResponseData } = httpRequestConfig;
46
+ if (!cacheType || !keyCache) {
47
+ return undefined;
48
+ }
49
+ if (cacheType === 'service') {
50
+ const data = this.serviceStore.get(keyCache);
51
+ return data ? (convertResponseData ? convertResponseData(data) : data) : data;
52
+ }
53
+ const data = await UtilsCache.GetAsync(keyCache, undefined, true);
54
+ return data ? (convertResponseData ? convertResponseData(data) : data) : data;
55
+ }
56
+ async setCacheData(data, httpRequestConfig, keyCache) {
57
+ const { cacheType, clearCache, convertResponseData } = httpRequestConfig;
58
+ if (!cacheType || !keyCache) {
59
+ return convertResponseData ? convertResponseData(data) : data;
60
+ }
61
+ if (clearCache === true) {
62
+ this.clearCache(cacheType, keyCache);
63
+ }
64
+ if (cacheType === 'service') {
65
+ this.serviceStore.set(keyCache, data);
66
+ return convertResponseData ? convertResponseData(data) : data;
67
+ }
68
+ await UtilsCache.SetAsync(keyCache, data, (httpRequestConfig.timeCache || 5) * 60, true);
69
+ return convertResponseData ? convertResponseData(data) : data;
70
+ }
71
+ clearCache(cacheType, keyCache) {
72
+ if (cacheType === 'service') {
73
+ this.serviceStore.delete(keyCache);
74
+ return;
75
+ }
76
+ UtilsCache.ClearAsync(keyCache, true);
77
+ }
78
+ /**
79
+ * @return trả về trạng thái đã load hết item chưa (ví dụ: dựa vào tham số này để quyết định có tiếp tục gọi api khi scroll ko) .
80
+ */
81
+ updateArguments(argumentsValue, objectGetDataUpdate, pagingStore, keySearch, searchOnline, loadedLastItem, guideAutoUpdateArgumentsValue) {
82
+ if (!argumentsValue || !(argumentsValue instanceof Array) || loadedLastItem) {
83
+ return true;
84
+ }
85
+ if (!guideAutoUpdateArgumentsValue) {
86
+ return this.updateArgumentsDefault(argumentsValue, true, pagingStore, keySearch, searchOnline);
87
+ }
88
+ const { paging, search, other, detailById, sortOrderType, sortOrderBy } = guideAutoUpdateArgumentsValue;
89
+ if (search) {
90
+ search.fieldGetValue = 'keySearch';
91
+ this.processUpdateArgumentsValeConfig(argumentsValue, { keySearch }, search);
92
+ }
93
+ if (objectGetDataUpdate?.['storeParamsCallApi'] && typeof objectGetDataUpdate?.['storeParamsCallApi'] === 'object' && !(objectGetDataUpdate?.['storeParamsCallApi']).instanceSort) {
94
+ objectGetDataUpdate['storeParamsCallApi'] = { ...objectGetDataUpdate['storeParamsCallApi'], instanceSort: {} };
95
+ }
96
+ if (sortOrderBy) {
97
+ this.processUpdateArgumentsValeConfig(argumentsValue, objectGetDataUpdate, sortOrderBy);
98
+ }
99
+ if (sortOrderType) {
100
+ this.processUpdateArgumentsValeConfig(argumentsValue, objectGetDataUpdate, sortOrderType);
101
+ }
102
+ if (other && other.length) {
103
+ other.forEach((config) => this.processUpdateArgumentsValeConfig(argumentsValue, objectGetDataUpdate, config));
104
+ }
105
+ if (detailById) {
106
+ detailById.fieldGetValue = detailById.fieldGetValue || detailById.fieldGetValue.trim() || 'key';
107
+ this.processUpdateArgumentsValeConfig(argumentsValue, objectGetDataUpdate, detailById);
108
+ }
109
+ if (isEmpty(paging)) {
110
+ return this.updateArgumentsDefault(argumentsValue, false, pagingStore || this.fakeResponsePagingApi()['paging'], keySearch, searchOnline);
111
+ }
112
+ const { page, before, after } = paging;
113
+ if (page && objectGetDataUpdate) {
114
+ page.preprocessor = (value) => {
115
+ return ++value;
116
+ };
117
+ const valuePage = +this.processUpdateArgumentsValeConfig(argumentsValue, objectGetDataUpdate, page);
118
+ const valueLastPage = +get(objectGetDataUpdate, 'paging.total_pages');
119
+ if ((valuePage && Number(valuePage).valueOf() > Number(valueLastPage).valueOf()) || valueLastPage === 0) {
120
+ return true;
121
+ }
122
+ }
123
+ if (before && objectGetDataUpdate && !this.processUpdateArgumentsValeConfig(argumentsValue, objectGetDataUpdate, before) && !get(objectGetDataUpdate, 'paging.fake')) {
124
+ set(objectGetDataUpdate, 'paging.fake', false);
125
+ return true;
126
+ }
127
+ if (after && objectGetDataUpdate && !this.processUpdateArgumentsValeConfig(argumentsValue, objectGetDataUpdate, after) && !get(objectGetDataUpdate, 'paging.fake')) {
128
+ set(objectGetDataUpdate, 'paging.fake', false);
129
+ return true;
130
+ }
131
+ if (!argumentsValue || !argumentsValue.length) {
132
+ return true;
133
+ }
134
+ return false;
135
+ }
136
+ updateArgumentsDefault(argumentsValue, updateSearch, pagingStore, keySearch, searchOnline) {
137
+ if (!argumentsValue || !argumentsValue.length) {
138
+ return true;
139
+ }
140
+ for (const index in argumentsValue) {
141
+ let argumentValue = argumentsValue[index];
142
+ if (!(argumentValue instanceof HttpParams)) {
143
+ continue;
144
+ }
145
+ const pageValue = argumentValue.get('page');
146
+ if (searchOnline && updateSearch) {
147
+ argumentValue = argumentValue.set('search', keySearch);
148
+ argumentsValue[index] = argumentValue;
149
+ }
150
+ if (argumentValue.has('before')) {
151
+ argumentValue = argumentValue.set('before', pagingStore?.before);
152
+ argumentsValue[index] = argumentValue;
153
+ }
154
+ if (argumentValue.has('after')) {
155
+ argumentValue = argumentValue.set('after', pagingStore?.after);
156
+ argumentsValue[index] = argumentValue;
157
+ }
158
+ if (Number(pageValue).valueOf() === -1) {
159
+ return true;
160
+ }
161
+ if (!pagingStore || pageValue === undefined) {
162
+ break;
163
+ }
164
+ const { page, total_pages } = pagingStore;
165
+ const nextPage = (page || 0) + 1;
166
+ if (nextPage && Number(nextPage).valueOf() > Number(total_pages).valueOf()) {
167
+ return true;
168
+ }
169
+ argumentsValue[index] = argumentValue.set('page', nextPage);
170
+ break;
171
+ }
172
+ return false;
173
+ }
174
+ processUpdateArgumentsValeConfig(argumentsValue, objectGetDataUpdate, config) {
175
+ if (!config || !objectGetDataUpdate) {
176
+ return undefined;
177
+ }
178
+ if (config.log?.logInputs) {
179
+ console.log('config', config);
180
+ console.log('objectGetDataUpdate', objectGetDataUpdate);
181
+ console.log('argumentsValue', argumentsValue);
182
+ console.log('--------------------------------');
183
+ }
184
+ const { fieldUpdate, fieldGetValue, preprocessor } = config;
185
+ if (!fieldUpdate || !fieldGetValue) {
186
+ return undefined;
187
+ }
188
+ let value = get(objectGetDataUpdate, fieldGetValue);
189
+ if (config.log?.logGetValue) {
190
+ console.log(`value of objectGetDataUpdate[${fieldGetValue}]: `, value);
191
+ }
192
+ if (preprocessor) {
193
+ value = preprocessor(value);
194
+ }
195
+ if (fieldUpdate) {
196
+ let resultOfFieldUpdate = get(argumentsValue, fieldUpdate);
197
+ if (resultOfFieldUpdate instanceof HttpParams) {
198
+ resultOfFieldUpdate = resultOfFieldUpdate.set(config.subFieldUpdate || 'search', value);
199
+ set(argumentsValue, fieldUpdate, resultOfFieldUpdate);
200
+ return value;
201
+ }
202
+ if (resultOfFieldUpdate instanceof Array) {
203
+ resultOfFieldUpdate.push(value);
204
+ return value;
205
+ }
206
+ if (resultOfFieldUpdate instanceof Object) {
207
+ set(resultOfFieldUpdate, config.subFieldUpdate || 'search', value);
208
+ return value;
209
+ }
210
+ set(argumentsValue, fieldUpdate, value);
211
+ return value;
212
+ }
213
+ return value;
214
+ }
215
+ fakeResponsePagingApi() {
216
+ return {
217
+ paging: {
218
+ page: 0,
219
+ total_pages: 1,
220
+ before: '',
221
+ after: '',
222
+ fake: true,
223
+ },
224
+ };
225
+ }
226
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiHttpRequestService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
227
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiHttpRequestService, providedIn: 'root' });
228
+ }
229
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiHttpRequestService, decorators: [{
230
+ type: Injectable,
231
+ args: [{
232
+ providedIn: 'root',
233
+ }]
234
+ }] });
235
+
236
+ /**
237
+ * Trả về các phương thức để xử lý danh sách dữ liệu mock
238
+ * @param data - Mảng dữ liệu mặc định để mock
239
+ * @param functionGetData - Hàm tùy chọn để lấy dữ liệu động thay vì sử dụng data mặc định
240
+ * @returns Đối tượng chứa các phương thức:
241
+ * - list: Trả về Promise với toàn bộ dữ liệu (có delay 250ms)
242
+ * - listObservable: Trả về Observable với toàn bộ dữ liệu (có delay 250ms)
243
+ * - listPaging: Trả về Promise với dữ liệu đã phân trang dựa trên params (có delay 250ms)
244
+ *
245
+ * @example
246
+ * ```typescript
247
+ * const mockData = [{ id: 1, name: 'Item 1' }, { id: 2, name: 'Item 2' }];
248
+ * const listService = returnListObject(mockData);
249
+ *
250
+ * // Lấy toàn bộ dữ liệu
251
+ * const allData = await listService.list();
252
+ *
253
+ * // Lấy dữ liệu phân trang
254
+ * const params = new UtilsHttpParamsRequest();
255
+ * params.set('page', '1');
256
+ * params.set('per_page', '10');
257
+ * const pagedData = await listService.listPaging(params);
258
+ * ```
259
+ */
260
+ const returnListObject = (data, functionGetData) => {
261
+ return {
262
+ list: async () => {
263
+ if (functionGetData) {
264
+ data = functionGetData();
265
+ }
266
+ await lastValueFrom(timer(250));
267
+ return {
268
+ code: 200,
269
+ data: data || [],
270
+ paging: {},
271
+ };
272
+ },
273
+ listObservable: () => {
274
+ if (functionGetData) {
275
+ data = functionGetData();
276
+ }
277
+ return of({
278
+ code: 200,
279
+ data: data || [],
280
+ paging: {},
281
+ }).pipe(delay(250));
282
+ },
283
+ listPaging: async (params) => {
284
+ if (functionGetData) {
285
+ data = functionGetData();
286
+ }
287
+ const page = parseInt(params.get('page') || '1');
288
+ const per_page = parseInt(params.get('per_page') || '30');
289
+ const result = pagingToList(data, page, per_page);
290
+ await lastValueFrom(timer(250));
291
+ return result;
292
+ },
293
+ };
294
+ };
295
+ /**
296
+ * Tạo một đối tượng mock detail với các phương thức để lấy bản ghi riêng lẻ theo khóa.
297
+ * Hỗ trợ cả mảng dữ liệu tĩnh và các hàm dữ liệu động.
298
+ *
299
+ * @template TypeResponse - Kiểu dữ liệu phản hồi mong đợi
300
+ * @template TypeParams - Kiểu tham số HTTP (mặc định là any)
301
+ *
302
+ * @param httpParams - Tham số HTTP chứa:
303
+ * - keys: Khóa (hoặc các khóa) cần tìm kiếm
304
+ * - fieldKey: Tên trường để so khớp (mặc định là 'id')
305
+ * - dataResponseOject: Cờ boolean để định dạng đối tượng phản hồi
306
+ * @param data - Mảng dữ liệu tĩnh tùy chọn để tìm kiếm
307
+ * @param functionGetData - Hàm tùy chọn trả về dữ liệu (có thể là Promise hoặc Observable)
308
+ * @param ignoreSplit - Nếu true, coi keys như một giá trị đơn thay vì tách chuỗi
309
+ * @param splitOperator - Toán tử tùy chỉnh để tách keys (mặc định là dấu phẩy)
310
+ *
311
+ * @returns Đối tượng với các phương thức:
312
+ * - detailByData: Tìm kiếm thông qua mảng dữ liệu tĩnh được cung cấp
313
+ * - detailByFunction: Gọi functionGetData để lấy dữ liệu mới, sau đó tìm kiếm
314
+ *
315
+ * @example
316
+ * ```typescript
317
+ * const params = new UtilsHttpParamsRequest({fromObject:{keys:'1',fieldKey:'id'}});
318
+ * const mockDetail = returnDetailObject<User>(params, userData);
319
+ * const user = await mockDetail.detailByData();
320
+ * ```
321
+ */
322
+ const returnDetailObject = (httpParams, data, functionGetData, ignoreSplit, splitOperator) => {
323
+ const keysPrams = httpParams.get('keys');
324
+ const fieldKey = httpParams.get('fieldKey') || 'id';
325
+ const dataResponseOject = httpParams.get('dataResponseOject');
326
+ return {
327
+ detailByData: async (keys) => {
328
+ return filterData(fieldKey, data, keys ?? keysPrams, dataResponseOject, ignoreSplit, splitOperator);
329
+ },
330
+ detailByFunction: async (keys) => {
331
+ if (!functionGetData) {
332
+ return await filterData(fieldKey, undefined, undefined, dataResponseOject, ignoreSplit, splitOperator);
333
+ }
334
+ let dataResult = functionGetData();
335
+ try {
336
+ if (dataResult['subscribe']) {
337
+ dataResult = await lastValueFrom(dataResult);
338
+ }
339
+ if (dataResult['then']) {
340
+ dataResult = await dataResult;
341
+ }
342
+ }
343
+ catch (_) {
344
+ dataResult = { data: [] };
345
+ }
346
+ data = dataResult.data;
347
+ return await filterData(fieldKey, data, keys || keysPrams, dataResponseOject, ignoreSplit, splitOperator);
348
+ },
349
+ };
350
+ };
351
+ const filterData = (fieldKey, data, keys, dataResponseOject, ignoreSplit, splitOperator) => {
352
+ if (!data || typeof data !== 'object' || isNil(keys) || keys === '') {
353
+ return {
354
+ code: 200,
355
+ data: undefined,
356
+ paging: {},
357
+ };
358
+ }
359
+ data = data || [];
360
+ if (!(data instanceof Array)) {
361
+ data = [data];
362
+ }
363
+ const result = [];
364
+ if (!ignoreSplit && typeof keys === 'string') {
365
+ keys = keys.split(splitOperator || ',');
366
+ }
367
+ if (typeof keys === 'number' || typeof keys === 'boolean' || (typeof keys === 'string' && ignoreSplit)) {
368
+ keys = [keys];
369
+ }
370
+ keys.forEach((key) => {
371
+ const resultFilter = data?.filter((elData) => isEqual(get(elData, fieldKey), key, { ignoreExactlyDataType: true }));
372
+ if (resultFilter && resultFilter.length) {
373
+ result.push(...resultFilter);
374
+ }
375
+ });
376
+ return {
377
+ code: 200,
378
+ data: result.length ? (dataResponseOject ? result[0] : result) : undefined,
379
+ paging: {},
380
+ };
381
+ };
382
+ const per_page = 20;
383
+ const total_items = per_page * 150 + 15;
384
+ const getConfigListDataDemo = (httpParamsDetail = new UtilsHttpParamsRequest(), objectData, functionBuildObject) => {
385
+ if (!objectData) {
386
+ objectData = {
387
+ id: '',
388
+ name: 'item positon index ',
389
+ };
390
+ }
391
+ const data = [...Array(total_items).keys()].map((_, index) => {
392
+ if (functionBuildObject) {
393
+ return functionBuildObject(`${+index + 1}`);
394
+ }
395
+ const obj = {};
396
+ Object.keys(objectData).forEach((key) => {
397
+ set(obj, key, `${objectData[key]}${+index + 1}`);
398
+ });
399
+ return obj;
400
+ });
401
+ const listService = returnListObject(data);
402
+ const detailService = returnDetailObject(httpParamsDetail, data, undefined, false, ';');
403
+ return {
404
+ list: listService.listPaging,
405
+ detailByData: detailService.detailByData,
406
+ };
407
+ };
408
+ /**
409
+ * Hàm phân trang dữ liệu từ một mảng
410
+ * @param data - Mảng dữ liệu cần phân trang
411
+ * @param page - Số trang hiện tại (bắt đầu từ 1)
412
+ * @param per_page - Số lượng item trên mỗi trang
413
+ * @returns Đối tượng chứa dữ liệu đã phân trang và thông tin phân trang
414
+ */
415
+ const pagingToList = (data, page, per_page) => {
416
+ if (!data || !Array.isArray(data)) {
417
+ return {
418
+ code: 200,
419
+ data: [],
420
+ paging: {
421
+ page: page,
422
+ per_page: per_page,
423
+ total_items: 0,
424
+ total_pages: 0,
425
+ },
426
+ };
427
+ }
428
+ const start = (page - 1) * per_page;
429
+ const end = start + per_page;
430
+ const total_pages = Math.ceil(data.length / per_page);
431
+ const dataByPage = data.slice(start, end);
432
+ return {
433
+ code: 200,
434
+ data: dataByPage,
435
+ paging: {
436
+ page: page > total_pages ? total_pages : page,
437
+ per_page: per_page,
438
+ total_items: data.length,
439
+ total_pages: total_pages,
440
+ },
441
+ };
442
+ };
443
+
444
+ /* eslint-disable @typescript-eslint/no-explicit-any */
445
+
446
+ /**
447
+ * Generated bundle index. Do not edit.
448
+ */
449
+
450
+ export { LibsUiHttpRequestService, getConfigListDataDemo, pagingToList, returnDetailObject, returnListObject };
451
+ //# sourceMappingURL=libs-ui-services-http-request.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"libs-ui-services-http-request.mjs","sources":["../../../../../libs-ui/services/http-request/src/http-request.service.ts","../../../../../libs-ui/services/http-request/src/api-mockup.ts","../../../../../libs-ui/services/http-request/src/interfaces/http-request-config.interface.ts","../../../../../libs-ui/services/http-request/src/libs-ui-services-http-request.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { HttpParams } from '@angular/common/http';\nimport { inject, Injectable, Injector } from '@angular/core';\nimport { IPaging } from '@libs-ui/interfaces-types';\nimport { UtilsCache, get, getKeyCacheByArrayObject, isEmpty, set } from '@libs-ui/utils';\nimport { lastValueFrom } from 'rxjs';\nimport { IGuideAutoUpdateArgumentsValue, IGuideAutoUpdateArgumentsValueConfig, IHttpRequestConfig } from './interfaces/index';\n\n@Injectable({\n providedIn: 'root',\n})\nexport class LibsUiHttpRequestService {\n private injector = inject(Injector);\n /** Chứa dữ liệu cache memory */\n private serviceStore: Map<string, any> = new Map();\n\n public async callApi<T = any>(httpRequestConfig: IHttpRequestConfig): Promise<T> {\n if (!httpRequestConfig || !httpRequestConfig.functionName) {\n throw 'http request config not exactly httpRequestConfig';\n }\n const serviceOther = get<unknown>(httpRequestConfig, 'serviceOther'); // TODO: sẽ xóa khi migrate hết component\n\n if (serviceOther) {\n set(httpRequestConfig, 'objectInstance', serviceOther);\n }\n\n const { objectInstance, keyCache, functionName, argumentsValue, serviceClass } = httpRequestConfig;\n\n if (!objectInstance && !serviceClass) {\n throw `http request config not exactly objectInstance or serviceName`;\n }\n const instance: any = objectInstance || this.injector.get<T>(serviceClass as any);\n if (!instance) {\n throw `http request notfound service instance`;\n }\n const methodInstance = instance[functionName];\n\n if (!methodInstance) {\n throw `http request config notfound methodInstance name: ${String(functionName)}`;\n }\n const keyCacheMD5: string = getKeyCacheByArrayObject(keyCache || '', argumentsValue);\n const cacheData = await this.getCacheData(httpRequestConfig, keyCacheMD5);\n\n if (cacheData) {\n return Promise.resolve(cacheData);\n }\n\n let callResponse = methodInstance.apply(instance, argumentsValue);\n if (!callResponse.then) {\n callResponse = lastValueFrom(callResponse);\n }\n\n const res = await callResponse;\n\n return await this.setCacheData(res, httpRequestConfig, keyCacheMD5);\n }\n\n private async getCacheData(httpRequestConfig: IHttpRequestConfig, keyCache: string) {\n const { cacheType, convertResponseData } = httpRequestConfig;\n\n if (!cacheType || !keyCache) {\n return undefined;\n }\n if (cacheType === 'service') {\n const data = this.serviceStore.get(keyCache);\n\n return data ? (convertResponseData ? convertResponseData(data) : data) : data;\n }\n const data = await UtilsCache.GetAsync(keyCache, undefined, true);\n\n return data ? (convertResponseData ? convertResponseData(data) : data) : data;\n }\n\n private async setCacheData(data: any, httpRequestConfig: IHttpRequestConfig, keyCache: string) {\n const { cacheType, clearCache, convertResponseData } = httpRequestConfig;\n\n if (!cacheType || !keyCache) {\n return convertResponseData ? convertResponseData(data) : data;\n }\n if (clearCache === true) {\n this.clearCache(cacheType, keyCache);\n }\n if (cacheType === 'service') {\n this.serviceStore.set(keyCache, data);\n\n return convertResponseData ? convertResponseData(data) : data;\n }\n await UtilsCache.SetAsync(keyCache, data, (httpRequestConfig.timeCache || 5) * 60, true);\n\n return convertResponseData ? convertResponseData(data) : data;\n }\n\n private clearCache(cacheType: 'service' | 'local-store', keyCache: string) {\n if (cacheType === 'service') {\n this.serviceStore.delete(keyCache);\n\n return;\n }\n UtilsCache.ClearAsync(keyCache, true);\n }\n\n /**\n * @return trả về trạng thái đã load hết item chưa (ví dụ: dựa vào tham số này để quyết định có tiếp tục gọi api khi scroll ko) .\n */\n public updateArguments(\n argumentsValue: Array<any>,\n objectGetDataUpdate: Record<string, any>,\n pagingStore: IPaging,\n keySearch: string,\n searchOnline: boolean,\n loadedLastItem: boolean,\n guideAutoUpdateArgumentsValue?: IGuideAutoUpdateArgumentsValue\n ): boolean {\n if (!argumentsValue || !(argumentsValue instanceof Array) || loadedLastItem) {\n return true;\n }\n\n if (!guideAutoUpdateArgumentsValue) {\n return this.updateArgumentsDefault(argumentsValue, true, pagingStore, keySearch, searchOnline);\n }\n const { paging, search, other, detailById, sortOrderType, sortOrderBy } = guideAutoUpdateArgumentsValue;\n\n if (search) {\n search.fieldGetValue = 'keySearch';\n this.processUpdateArgumentsValeConfig(argumentsValue, { keySearch }, search);\n }\n if (objectGetDataUpdate?.['storeParamsCallApi'] && typeof objectGetDataUpdate?.['storeParamsCallApi'] === 'object' && !(objectGetDataUpdate?.['storeParamsCallApi'] as any).instanceSort) {\n objectGetDataUpdate['storeParamsCallApi'] = { ...objectGetDataUpdate['storeParamsCallApi'], instanceSort: {} };\n }\n if (sortOrderBy) {\n this.processUpdateArgumentsValeConfig(argumentsValue, objectGetDataUpdate, sortOrderBy);\n }\n if (sortOrderType) {\n this.processUpdateArgumentsValeConfig(argumentsValue, objectGetDataUpdate, sortOrderType);\n }\n if (other && other.length) {\n other.forEach((config) => this.processUpdateArgumentsValeConfig(argumentsValue, objectGetDataUpdate, config));\n }\n if (detailById) {\n detailById.fieldGetValue = detailById.fieldGetValue || detailById.fieldGetValue.trim() || 'key';\n this.processUpdateArgumentsValeConfig(argumentsValue, objectGetDataUpdate, detailById);\n }\n\n if (isEmpty(paging)) {\n return this.updateArgumentsDefault(argumentsValue, false, pagingStore || this.fakeResponsePagingApi()['paging'], keySearch, searchOnline);\n }\n const { page, before, after } = paging;\n\n if (page && objectGetDataUpdate) {\n page.preprocessor = (value: number): number => {\n return ++value;\n };\n const valuePage = +this.processUpdateArgumentsValeConfig(argumentsValue, objectGetDataUpdate, page);\n const valueLastPage = +get(objectGetDataUpdate as any, 'paging.total_pages');\n\n if ((valuePage && Number(valuePage).valueOf() > Number(valueLastPage).valueOf()) || valueLastPage === 0) {\n return true;\n }\n }\n if (before && objectGetDataUpdate && !this.processUpdateArgumentsValeConfig(argumentsValue, objectGetDataUpdate, before) && !get(objectGetDataUpdate, 'paging.fake')) {\n set(objectGetDataUpdate, 'paging.fake', false);\n\n return true;\n }\n if (after && objectGetDataUpdate && !this.processUpdateArgumentsValeConfig(argumentsValue, objectGetDataUpdate, after) && !get(objectGetDataUpdate, 'paging.fake')) {\n set(objectGetDataUpdate, 'paging.fake', false);\n\n return true;\n }\n\n if (!argumentsValue || !argumentsValue.length) {\n return true;\n }\n\n return false;\n }\n\n private updateArgumentsDefault(argumentsValue: Array<any>, updateSearch: boolean, pagingStore: IPaging, keySearch: string, searchOnline: boolean) {\n if (!argumentsValue || !argumentsValue.length) {\n return true;\n }\n\n for (const index in argumentsValue) {\n let argumentValue = argumentsValue[index];\n\n if (!(argumentValue instanceof HttpParams)) {\n continue;\n }\n const pageValue = argumentValue.get('page');\n\n if (searchOnline && updateSearch) {\n argumentValue = argumentValue.set('search', keySearch);\n argumentsValue[index] = argumentValue;\n }\n if (argumentValue.has('before')) {\n argumentValue = argumentValue.set('before', pagingStore?.before);\n argumentsValue[index] = argumentValue;\n }\n if (argumentValue.has('after')) {\n argumentValue = argumentValue.set('after', pagingStore?.after);\n argumentsValue[index] = argumentValue;\n }\n if (Number(pageValue).valueOf() === -1) {\n return true;\n }\n if (!pagingStore || pageValue === undefined) {\n break;\n }\n\n const { page, total_pages } = pagingStore;\n const nextPage = (page || 0) + 1;\n\n if (nextPage && Number(nextPage).valueOf() > Number(total_pages).valueOf()) {\n return true;\n }\n argumentsValue[index] = argumentValue.set('page', nextPage);\n break;\n }\n\n return false;\n }\n\n private processUpdateArgumentsValeConfig(argumentsValue: Array<any>, objectGetDataUpdate: any, config: IGuideAutoUpdateArgumentsValueConfig) {\n if (!config || !objectGetDataUpdate) {\n return undefined;\n }\n if (config.log?.logInputs) {\n console.log('config', config);\n console.log('objectGetDataUpdate', objectGetDataUpdate);\n console.log('argumentsValue', argumentsValue);\n console.log('--------------------------------');\n }\n const { fieldUpdate, fieldGetValue, preprocessor } = config;\n\n if (!fieldUpdate || !fieldGetValue) {\n return undefined;\n }\n\n let value = get(objectGetDataUpdate, fieldGetValue);\n if (config.log?.logGetValue) {\n console.log(`value of objectGetDataUpdate[${fieldGetValue}]: `, value);\n }\n\n if (preprocessor) {\n value = preprocessor(value);\n }\n if (fieldUpdate) {\n let resultOfFieldUpdate = get(argumentsValue, fieldUpdate as any);\n\n if (resultOfFieldUpdate instanceof HttpParams) {\n resultOfFieldUpdate = resultOfFieldUpdate.set(config.subFieldUpdate || 'search', value);\n set(argumentsValue, fieldUpdate as any, resultOfFieldUpdate);\n\n return value;\n }\n if (resultOfFieldUpdate instanceof Array) {\n resultOfFieldUpdate.push(value);\n\n return value;\n }\n if (resultOfFieldUpdate instanceof Object) {\n set(resultOfFieldUpdate, config.subFieldUpdate || 'search', value);\n\n return value;\n }\n set(argumentsValue, fieldUpdate as any, value);\n\n return value;\n }\n\n return value;\n }\n\n public fakeResponsePagingApi(): { paging: IPaging } {\n return {\n paging: {\n page: 0,\n total_pages: 1,\n before: '',\n after: '',\n fake: true,\n },\n };\n }\n}\n","/* eslint-disable @typescript-eslint/no-unused-vars */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { HttpParams } from '@angular/common/http';\nimport { IHttpResponse } from '@libs-ui/interfaces-types';\nimport { UtilsHttpParamsRequest, get, isNil, set, isEqual } from '@libs-ui/utils';\nimport { Observable, delay, lastValueFrom, of, timer } from 'rxjs';\n\n/**\n * Trả về các phương thức để xử lý danh sách dữ liệu mock\n * @param data - Mảng dữ liệu mặc định để mock\n * @param functionGetData - Hàm tùy chọn để lấy dữ liệu động thay vì sử dụng data mặc định\n * @returns Đối tượng chứa các phương thức:\n * - list: Trả về Promise với toàn bộ dữ liệu (có delay 250ms)\n * - listObservable: Trả về Observable với toàn bộ dữ liệu (có delay 250ms)\n * - listPaging: Trả về Promise với dữ liệu đã phân trang dựa trên params (có delay 250ms)\n *\n * @example\n * ```typescript\n * const mockData = [{ id: 1, name: 'Item 1' }, { id: 2, name: 'Item 2' }];\n * const listService = returnListObject(mockData);\n *\n * // Lấy toàn bộ dữ liệu\n * const allData = await listService.list();\n *\n * // Lấy dữ liệu phân trang\n * const params = new UtilsHttpParamsRequest();\n * params.set('page', '1');\n * params.set('per_page', '10');\n * const pagedData = await listService.listPaging(params);\n * ```\n */\n\nexport const returnListObject = (\n data?: Array<any>,\n functionGetData?: () => Array<any>\n): {\n list: <TypeResponse = any>() => Promise<IHttpResponse<TypeResponse>>;\n listObservable: <TypeResponse = any>() => Observable<IHttpResponse<TypeResponse>>;\n listPaging: <TypeResponse = any>(params: UtilsHttpParamsRequest) => Promise<IHttpResponse<TypeResponse>>;\n} => {\n return {\n list: async <TypeResponse = any>(): Promise<IHttpResponse<TypeResponse>> => {\n if (functionGetData) {\n data = functionGetData();\n }\n await lastValueFrom(timer(250));\n return {\n code: 200,\n data: (data as any) || [],\n paging: {},\n };\n },\n listObservable: <TypeResponse = any>(): Observable<IHttpResponse<TypeResponse>> => {\n if (functionGetData) {\n data = functionGetData();\n }\n\n return of({\n code: 200,\n data: (data as any) || [],\n paging: {},\n }).pipe(delay(250));\n },\n listPaging: async <TypeResponse = any>(params: UtilsHttpParamsRequest): Promise<IHttpResponse<TypeResponse>> => {\n if (functionGetData) {\n data = functionGetData();\n }\n const page = parseInt(params.get('page') || '1');\n const per_page = parseInt(params.get('per_page') || '30');\n const result = pagingToList(data as Array<any>, page, per_page);\n\n await lastValueFrom(timer(250));\n\n return result as IHttpResponse<TypeResponse>;\n },\n };\n};\n\n/**\n * Tạo một đối tượng mock detail với các phương thức để lấy bản ghi riêng lẻ theo khóa.\n * Hỗ trợ cả mảng dữ liệu tĩnh và các hàm dữ liệu động.\n *\n * @template TypeResponse - Kiểu dữ liệu phản hồi mong đợi\n * @template TypeParams - Kiểu tham số HTTP (mặc định là any)\n *\n * @param httpParams - Tham số HTTP chứa:\n * - keys: Khóa (hoặc các khóa) cần tìm kiếm\n * - fieldKey: Tên trường để so khớp (mặc định là 'id')\n * - dataResponseOject: Cờ boolean để định dạng đối tượng phản hồi\n * @param data - Mảng dữ liệu tĩnh tùy chọn để tìm kiếm\n * @param functionGetData - Hàm tùy chọn trả về dữ liệu (có thể là Promise hoặc Observable)\n * @param ignoreSplit - Nếu true, coi keys như một giá trị đơn thay vì tách chuỗi\n * @param splitOperator - Toán tử tùy chỉnh để tách keys (mặc định là dấu phẩy)\n *\n * @returns Đối tượng với các phương thức:\n * - detailByData: Tìm kiếm thông qua mảng dữ liệu tĩnh được cung cấp\n * - detailByFunction: Gọi functionGetData để lấy dữ liệu mới, sau đó tìm kiếm\n *\n * @example\n * ```typescript\n * const params = new UtilsHttpParamsRequest({fromObject:{keys:'1',fieldKey:'id'}});\n * const mockDetail = returnDetailObject<User>(params, userData);\n * const user = await mockDetail.detailByData();\n * ```\n */\n\nexport const returnDetailObject = <TypeResponse, TypeParams = any>(\n httpParams: UtilsHttpParamsRequest<TypeParams> | HttpParams,\n data?: Array<any>,\n functionGetData?: () => Promise<IHttpResponse<TypeResponse>> | Observable<IHttpResponse<TypeResponse>>,\n ignoreSplit?: boolean,\n splitOperator?: string\n): {\n detailByData: <TypeResponse = any>(keys?: any) => Promise<IHttpResponse<TypeResponse>>;\n detailByFunction: <TypeResponse = any>(keys?: any) => Promise<IHttpResponse<TypeResponse>>;\n} => {\n const keysPrams: any = httpParams.get('keys');\n const fieldKey: string = httpParams.get('fieldKey') || 'id';\n const dataResponseOject: any = httpParams.get('dataResponseOject');\n\n return {\n detailByData: async <TypeResponse>(keys?: any): Promise<IHttpResponse<TypeResponse>> => {\n return filterData<TypeResponse>(fieldKey, data, keys ?? keysPrams, dataResponseOject, ignoreSplit, splitOperator);\n },\n\n detailByFunction: async <TypeResponse>(keys?: any): Promise<IHttpResponse<TypeResponse>> => {\n if (!functionGetData) {\n return await filterData<TypeResponse>(fieldKey, undefined, undefined, dataResponseOject, ignoreSplit, splitOperator);\n }\n\n let dataResult: any = functionGetData();\n\n try {\n if (dataResult['subscribe']) {\n dataResult = await lastValueFrom(dataResult);\n }\n if (dataResult['then']) {\n dataResult = await dataResult;\n }\n } catch (_) {\n dataResult = { data: [] };\n }\n\n data = dataResult.data;\n\n return await filterData<TypeResponse>(fieldKey, data, keys || keysPrams, dataResponseOject, ignoreSplit, splitOperator);\n },\n };\n};\n\nconst filterData = <TypeResponse>(fieldKey: string, data?: Array<any>, keys?: any, dataResponseOject?: boolean, ignoreSplit?: boolean, splitOperator?: string): IHttpResponse<TypeResponse> => {\n if (!data || typeof data !== 'object' || isNil(keys) || keys === '') {\n return {\n code: 200,\n data: undefined,\n paging: {},\n };\n }\n\n data = data || [];\n\n if (!(data instanceof Array)) {\n data = [data];\n }\n const result: any = [];\n\n if (!ignoreSplit && typeof keys === 'string') {\n keys = keys.split(splitOperator || ',');\n }\n\n if (typeof keys === 'number' || typeof keys === 'boolean' || (typeof keys === 'string' && ignoreSplit)) {\n keys = [keys];\n }\n\n keys.forEach((key: string) => {\n const resultFilter = data?.filter((elData: { [key: string]: any }) => isEqual(get(elData, fieldKey), key, { ignoreExactlyDataType: true }));\n\n if (resultFilter && resultFilter.length) {\n result.push(...resultFilter);\n }\n });\n\n return {\n code: 200,\n data: result.length ? (dataResponseOject ? result[0] : result) : undefined,\n paging: {},\n };\n};\n\nconst per_page = 20;\nconst total_items = per_page * 150 + 15;\n\nexport const getConfigListDataDemo = (httpParamsDetail: UtilsHttpParamsRequest<any> = new UtilsHttpParamsRequest(), objectData?: Record<string, string>, functionBuildObject?: (numIncrement: string) => Record<string, string>) => {\n if (!objectData) {\n objectData = {\n id: '',\n name: 'item positon index ',\n };\n }\n\n const data = [...Array(total_items).keys()].map((_, index) => {\n if (functionBuildObject) {\n return functionBuildObject(`${+index + 1}`);\n }\n const obj: Record<string, string> = {};\n Object.keys(objectData).forEach((key) => {\n set(obj, key, `${objectData[key]}${+index + 1}`);\n });\n return obj;\n });\n\n const listService = returnListObject(data);\n const detailService = returnDetailObject(httpParamsDetail, data, undefined, false, ';');\n return {\n list: listService.listPaging,\n detailByData: detailService.detailByData,\n };\n};\n\n/**\n * Hàm phân trang dữ liệu từ một mảng\n * @param data - Mảng dữ liệu cần phân trang\n * @param page - Số trang hiện tại (bắt đầu từ 1)\n * @param per_page - Số lượng item trên mỗi trang\n * @returns Đối tượng chứa dữ liệu đã phân trang và thông tin phân trang\n */\nexport const pagingToList = (data: Array<any>, page: number, per_page: number) => {\n if (!data || !Array.isArray(data)) {\n return {\n code: 200,\n data: [],\n paging: {\n page: page,\n per_page: per_page,\n total_items: 0,\n total_pages: 0,\n },\n };\n }\n const start = (page - 1) * per_page;\n const end = start + per_page;\n const total_pages = Math.ceil(data.length / per_page);\n const dataByPage = data.slice(start, end);\n return {\n code: 200,\n data: dataByPage,\n paging: {\n page: page > total_pages ? total_pages : page,\n per_page: per_page,\n total_items: data.length,\n total_pages: total_pages,\n },\n };\n};\n","/* eslint-disable @typescript-eslint/no-explicit-any */\n\nimport { Type } from '@angular/core';\nimport { IGuideAutoUpdateArgumentsValue } from './guild-auto-update-arguments-value.interface';\n\nexport interface IHttpRequestConfig<T = any> {\n serviceClass?: Type<T>; // tên class của component gọi http request\n objectInstance?: T; // là 1 object không được inject trong httpRequest; được sử dụng để lấy data từ 1 đối tượng không phải là service inject\n functionName?: keyof T; // tên hàm muốn gọi trong service\n argumentsValue: Array<any>; // chứa dữ liệu của params truyền vào, mảng có kểu dữ liệu không cần giống nhau vd: hàm function(search:string,age:number,page:Object)={...} thì serviceSpecificParams = ['param',16,{page:1,page:per_page:25}]\n cacheType?: 'service' | 'local-store';\n keyCache?: string; // sử dụng nếu sử dụng cache. khi tạo bộ config sử dụng đối tượng uuid để lấy một id set vào biến này. và biến này sẽ ko thay đổi trong quá trình sử dụng\n timeCache?: number; // đơn vị phút\n clearCache?: boolean;\n guideAutoUpdateArgumentsValue?: IGuideAutoUpdateArgumentsValue; // khai báo không sử dụng cho HttpRequestService. Dùng cho cá component muốn lấy thông tin update arguments để load more khi scroll bottom. Ví dụ như MoLibShareComponentsListViewTemplatesComponentAbstract\n convertResponseData?: (response: any) => any;\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,23 @@
1
+ import { IPaging } from '@libs-ui/interfaces-types';
2
+ import { IGuideAutoUpdateArgumentsValue, IHttpRequestConfig } from './interfaces/index';
3
+ import * as i0 from "@angular/core";
4
+ export declare class LibsUiHttpRequestService {
5
+ private injector;
6
+ /** Chứa dữ liệu cache memory */
7
+ private serviceStore;
8
+ callApi<T = any>(httpRequestConfig: IHttpRequestConfig): Promise<T>;
9
+ private getCacheData;
10
+ private setCacheData;
11
+ private clearCache;
12
+ /**
13
+ * @return trả về trạng thái đã load hết item chưa (ví dụ: dựa vào tham số này để quyết định có tiếp tục gọi api khi scroll ko) .
14
+ */
15
+ updateArguments(argumentsValue: Array<any>, objectGetDataUpdate: Record<string, any>, pagingStore: IPaging, keySearch: string, searchOnline: boolean, loadedLastItem: boolean, guideAutoUpdateArgumentsValue?: IGuideAutoUpdateArgumentsValue): boolean;
16
+ private updateArgumentsDefault;
17
+ private processUpdateArgumentsValeConfig;
18
+ fakeResponsePagingApi(): {
19
+ paging: IPaging;
20
+ };
21
+ static ɵfac: i0.ɵɵFactoryDeclaration<LibsUiHttpRequestService, never>;
22
+ static ɵprov: i0.ɵɵInjectableDeclaration<LibsUiHttpRequestService>;
23
+ }
package/index.d.ts ADDED
@@ -0,0 +1,3 @@
1
+ export * from './http-request.service';
2
+ export * from './api-mockup';
3
+ export * from './interfaces';
@@ -0,0 +1,22 @@
1
+ export interface IGuideAutoUpdateArgumentsValue {
2
+ paging: {
3
+ page?: IGuideAutoUpdateArgumentsValueConfig;
4
+ before?: IGuideAutoUpdateArgumentsValueConfig;
5
+ after?: IGuideAutoUpdateArgumentsValueConfig;
6
+ };
7
+ search?: IGuideAutoUpdateArgumentsValueConfig;
8
+ sortOrderType?: IGuideAutoUpdateArgumentsValueConfig;
9
+ sortOrderBy?: IGuideAutoUpdateArgumentsValueConfig;
10
+ detailById?: IGuideAutoUpdateArgumentsValueConfig;
11
+ other?: Array<IGuideAutoUpdateArgumentsValueConfig>;
12
+ }
13
+ export interface IGuideAutoUpdateArgumentsValueConfig {
14
+ fieldUpdate: string;
15
+ subFieldUpdate?: string;
16
+ fieldGetValue: string;
17
+ preprocessor?: (value: any) => any;
18
+ log?: {
19
+ logInputs?: boolean;
20
+ logGetValue?: boolean;
21
+ };
22
+ }
@@ -0,0 +1,14 @@
1
+ import { Type } from '@angular/core';
2
+ import { IGuideAutoUpdateArgumentsValue } from './guild-auto-update-arguments-value.interface';
3
+ export interface IHttpRequestConfig<T = any> {
4
+ serviceClass?: Type<T>;
5
+ objectInstance?: T;
6
+ functionName?: keyof T;
7
+ argumentsValue: Array<any>;
8
+ cacheType?: 'service' | 'local-store';
9
+ keyCache?: string;
10
+ timeCache?: number;
11
+ clearCache?: boolean;
12
+ guideAutoUpdateArgumentsValue?: IGuideAutoUpdateArgumentsValue;
13
+ convertResponseData?: (response: any) => any;
14
+ }
@@ -0,0 +1,2 @@
1
+ export * from './http-request-config.interface';
2
+ export * from './guild-auto-update-arguments-value.interface';
package/package.json ADDED
@@ -0,0 +1,28 @@
1
+ {
2
+ "name": "@libs-ui/services-http-request",
3
+ "version": "0.1.1-1",
4
+ "peerDependencies": {
5
+ "@angular/common": ">=18.0.0",
6
+ "@angular/core": ">=18.0.0",
7
+ "@libs-ui/interfaces-types": "0.1.1-1",
8
+ "@libs-ui/utils": "0.1.1-1",
9
+ "rxjs": "~7.8.0"
10
+ },
11
+ "sideEffects": false,
12
+ "module": "fesm2022/libs-ui-services-http-request.mjs",
13
+ "typings": "index.d.ts",
14
+ "exports": {
15
+ "./package.json": {
16
+ "default": "./package.json"
17
+ },
18
+ ".": {
19
+ "types": "./index.d.ts",
20
+ "esm2022": "./esm2022/libs-ui-services-http-request.mjs",
21
+ "esm": "./esm2022/libs-ui-services-http-request.mjs",
22
+ "default": "./fesm2022/libs-ui-services-http-request.mjs"
23
+ }
24
+ },
25
+ "dependencies": {
26
+ "tslib": "^2.3.0"
27
+ }
28
+ }