@futdevpro/fsm-dynamo 1.14.11 → 1.14.13

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.
Files changed (76) hide show
  1. package/.vscode/settings.json +11 -0
  2. package/build/_collections/utils/json-error-helper.util.d.ts.map +1 -1
  3. package/build/_collections/utils/json-error-helper.util.js.map +1 -1
  4. package/build/_collections/utils/stack.util.d.ts.map +1 -1
  5. package/build/_collections/utils/stack.util.js +3 -2
  6. package/build/_collections/utils/stack.util.js.map +1 -1
  7. package/build/_models/control-models/service-endpoint-settings-base.control-model.d.ts +22 -1
  8. package/build/_models/control-models/service-endpoint-settings-base.control-model.d.ts.map +1 -1
  9. package/build/_models/control-models/service-endpoint-settings-base.control-model.js +23 -1
  10. package/build/_models/control-models/service-endpoint-settings-base.control-model.js.map +1 -1
  11. package/build/_modules/ai/_modules/open-ai/index.d.ts.map +1 -1
  12. package/build/_modules/ai/_modules/open-ai/index.js +7 -7
  13. package/build/_modules/ai/_modules/open-ai/index.js.map +1 -1
  14. package/build/_modules/crypto/_collections/{crypto-2-non-stable.util.d.ts → crypto-v1.util.d.ts} +1 -1
  15. package/build/_modules/crypto/_collections/crypto-v1.util.d.ts.map +1 -0
  16. package/build/_modules/crypto/_collections/{crypto-2-non-stable.util.js → crypto-v1.util.js} +1 -1
  17. package/build/_modules/crypto/_collections/crypto-v1.util.js.map +1 -0
  18. package/build/_modules/crypto/_collections/{crypto-old.util.d.ts → crypto-v2.util.d.ts} +1 -1
  19. package/build/_modules/crypto/_collections/crypto-v2.util.d.ts.map +1 -0
  20. package/build/_modules/crypto/_collections/{crypto-old.util.js → crypto-v2.util.js} +10 -10
  21. package/build/_modules/crypto/_collections/crypto-v2.util.js.map +1 -0
  22. package/build/_modules/crypto/_collections/crypto-v4.util.d.ts +165 -0
  23. package/build/_modules/crypto/_collections/crypto-v4.util.d.ts.map +1 -0
  24. package/build/_modules/crypto/_collections/crypto-v4.util.js +611 -0
  25. package/build/_modules/crypto/_collections/crypto-v4.util.js.map +1 -0
  26. package/build/_modules/crypto/index.d.ts.map +1 -1
  27. package/build/_modules/crypto/index.js +7 -7
  28. package/build/_modules/crypto/index.js.map +1 -1
  29. package/build/_modules/data-handler/_models/data-handler-settings.control-model.d.ts +73 -0
  30. package/build/_modules/data-handler/_models/data-handler-settings.control-model.d.ts.map +1 -0
  31. package/build/_modules/data-handler/_models/data-handler-settings.control-model.js +83 -0
  32. package/build/_modules/data-handler/_models/data-handler-settings.control-model.js.map +1 -0
  33. package/build/_modules/data-handler/_models/data-handler.control-model.d.ts +136 -0
  34. package/build/_modules/data-handler/_models/data-handler.control-model.d.ts.map +1 -0
  35. package/build/_modules/data-handler/_models/data-handler.control-model.js +333 -0
  36. package/build/_modules/data-handler/_models/data-handler.control-model.js.map +1 -0
  37. package/build/_modules/data-handler/_models/data-list-handler.control-model.d.ts +111 -0
  38. package/build/_modules/data-handler/_models/data-list-handler.control-model.d.ts.map +1 -0
  39. package/build/_modules/data-handler/_models/data-list-handler.control-model.js +217 -0
  40. package/build/_modules/data-handler/_models/data-list-handler.control-model.js.map +1 -0
  41. package/build/_modules/data-handler/_models/data-search-handler.control-model.d.ts +172 -0
  42. package/build/_modules/data-handler/_models/data-search-handler.control-model.d.ts.map +1 -0
  43. package/build/_modules/data-handler/_models/data-search-handler.control-model.js +325 -0
  44. package/build/_modules/data-handler/_models/data-search-handler.control-model.js.map +1 -0
  45. package/build/_modules/data-handler/_models/list-collector-data-handler.control-model.d.ts +116 -0
  46. package/build/_modules/data-handler/_models/list-collector-data-handler.control-model.d.ts.map +1 -0
  47. package/build/_modules/data-handler/_models/list-collector-data-handler.control-model.js +245 -0
  48. package/build/_modules/data-handler/_models/list-collector-data-handler.control-model.js.map +1 -0
  49. package/build/_modules/data-handler/index.d.ts +6 -0
  50. package/build/_modules/data-handler/index.d.ts.map +1 -0
  51. package/build/_modules/data-handler/index.js +10 -0
  52. package/build/_modules/data-handler/index.js.map +1 -0
  53. package/eslint.config.js +4 -0
  54. package/futdevpro-fsm-dynamo-01.14.13.tgz +0 -0
  55. package/package.json +22 -3
  56. package/src/_collections/utils/json-error-helper.util.ts +5 -3
  57. package/src/_collections/utils/stack.util.ts +8 -4
  58. package/src/_models/control-models/service-endpoint-settings-base.control-model.ts +41 -4
  59. package/src/_modules/ai/_modules/open-ai/index.ts +4 -3
  60. package/src/_modules/crypto/_collections/{crypto-old.util.ts → crypto-v2.util.ts} +17 -9
  61. package/src/_modules/crypto/_collections/crypto-v4.util.ts +702 -0
  62. package/src/_modules/crypto/index.ts +4 -3
  63. package/src/_modules/data-handler/_models/data-handler-settings.control-model.ts +110 -0
  64. package/src/_modules/data-handler/_models/data-handler.control-model.ts +459 -0
  65. package/src/_modules/data-handler/_models/data-list-handler.control-model.ts +245 -0
  66. package/src/_modules/data-handler/_models/data-search-handler.control-model.ts +390 -0
  67. package/src/_modules/data-handler/_models/list-collector-data-handler.control-model.ts +274 -0
  68. package/src/_modules/data-handler/index.ts +6 -0
  69. package/src/_modules/usage/_collections/usg-module-settings.const.ts +1 -1
  70. package/.eslintrc.json +0 -155
  71. package/build/_modules/crypto/_collections/crypto-2-non-stable.util.d.ts.map +0 -1
  72. package/build/_modules/crypto/_collections/crypto-2-non-stable.util.js.map +0 -1
  73. package/build/_modules/crypto/_collections/crypto-old.util.d.ts.map +0 -1
  74. package/build/_modules/crypto/_collections/crypto-old.util.js.map +0 -1
  75. package/futdevpro-fsm-dynamo-01.14.11.tgz +0 -0
  76. /package/src/_modules/crypto/_collections/{crypto-2-non-stable.util.ts → crypto-v1.util.ts} +0 -0
@@ -0,0 +1,325 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DyFM_DataSearchHandler = void 0;
4
+ const rxjs_1 = require("rxjs");
5
+ const data_list_handler_control_model_1 = require("./data-list-handler.control-model");
6
+ const object_util_1 = require("../../../_collections/utils/object.util");
7
+ /**
8
+ * A specialized data handler for managing searchable data with pagination and caching.
9
+ * Extends DyFM_DataListHandler to provide additional functionality for handling search results.
10
+ *
11
+ * @template T_Data - The type of data items in the search results
12
+ * @template T_DataLoadBy - The type of search query (must extend DyFM_SearchQuery)
13
+ * @template T_Result - The type of search result (must extend DyFM_SearchResult)
14
+ * @template T_DependencyData - The type of dependency data (defaults to any)
15
+ *
16
+ * @example
17
+ * ```typescript
18
+ * // Create a search handler for flow runs
19
+ * const flowRunsHandler = new DyFM_DataSearchHandler<FlowRun_Preview>({
20
+ * name: 'myRuns',
21
+ * get: async (query?: DyFM_SearchQuery<FlowRun>): Promise<DyFM_SearchResult<FlowRun_Preview>> => {
22
+ * return await flowRunService.searchFlowRuns(query);
23
+ * },
24
+ * defaultQuery: {
25
+ * filterBy: { userId: currentUserId },
26
+ * pageSize: 20
27
+ * },
28
+ * queryUpdateDebounceTime: 500
29
+ * });
30
+ *
31
+ * // Update search query
32
+ * flowRunsHandler.updateQuery({
33
+ * page: 0,
34
+ * pageSize: 10,
35
+ * filterBy: { status: 'completed' }
36
+ * });
37
+ *
38
+ * // Access search results
39
+ * const runs = flowRunsHandler.dataList;
40
+ *
41
+ * // Get total items count
42
+ * const totalItems = flowRunsHandler.totalItems;
43
+ * ```
44
+ */
45
+ class DyFM_DataSearchHandler extends data_list_handler_control_model_1.DyFM_DataListHandler {
46
+ /**
47
+ * Subject for handling fresh search queries with debouncing.
48
+ * Used internally to manage query updates.
49
+ */
50
+ _freshQuery_S = new rxjs_1.Subject();
51
+ /**
52
+ * Cache of search results for different pages.
53
+ * Helps optimize performance by storing previously loaded results.
54
+ */
55
+ cache = [];
56
+ /**
57
+ * Override of the get method to handle search queries.
58
+ * Must be implemented to fetch search results from the data source.
59
+ */
60
+ // this is redundant, because the base class has the get method and it uses Generic type
61
+ /* override get: (query?: T_DataLoadBy) => Promise<T_Result>; */
62
+ /**
63
+ * Maximum number of cached pages to keep in memory.
64
+ * Default is 5 pages.
65
+ */
66
+ cacheSize = 5;
67
+ /**
68
+ * Default number of items per page.
69
+ * Used when no pageSize is specified in the query.
70
+ */
71
+ defaultPageSize = 10;
72
+ /**
73
+ * Default search query to use when no query is provided.
74
+ * Can include default filters, sorting, and pagination settings.
75
+ */
76
+ get defaultQuery() {
77
+ return object_util_1.DyFM_Object.clone(this._defaultQuery);
78
+ }
79
+ _defaultQuery;
80
+ /**
81
+ * Total number of items available in the search results.
82
+ * Updated after each successful search.
83
+ */
84
+ totalItems;
85
+ /**
86
+ * Debounce time in milliseconds for query updates.
87
+ * Helps prevent too frequent API calls when query changes rapidly.
88
+ */
89
+ queryUpdateDebounceTime = 500;
90
+ /**
91
+ * Whether to perform initial search when handler is created.
92
+ * If true, will use defaultQuery for initial search.
93
+ */
94
+ searchOnInit = true;
95
+ /**
96
+ * Creates a new instance of DyFM_DataSearchHandler.
97
+ *
98
+ * @param set - Configuration settings for the search handler
99
+ */
100
+ constructor(set) {
101
+ super({
102
+ ...set,
103
+ noId: true,
104
+ });
105
+ if (set.queryUpdateDebounceTime) {
106
+ this.queryUpdateDebounceTime = set.queryUpdateDebounceTime;
107
+ }
108
+ if (set.defaultQuery) {
109
+ this._defaultQuery = set.defaultQuery;
110
+ }
111
+ // 3
112
+ // Add post-processing for search results
113
+ this.getPostProcesses.unshift((searchResult, loadedBy) => {
114
+ console.warn('WTF DyFM_Search_DataHandler getPostProcess', searchResult, this.lastLoadedBy);
115
+ this.cache = this.cache.filter((c) => c.loadPageSize !== this.lastLoadedBy?.pageSize);
116
+ if (this.cache.length >= this.cacheSize) {
117
+ this.cache.shift();
118
+ }
119
+ this.cache.push({
120
+ page: this.lastLoadedBy?.page,
121
+ loadPageSize: this.lastLoadedBy?.pageSize,
122
+ data: searchResult.results,
123
+ });
124
+ this.totalItems = searchResult.totalItems;
125
+ return searchResult.results;
126
+ });
127
+ // 2
128
+ // Set up query update handling with debouncing
129
+ this._freshQuery_S.pipe((0, rxjs_1.debounceTime)(this.queryUpdateDebounceTime)).subscribe((query) => {
130
+ console.warn('asd', query, this.lastLoadedBy);
131
+ if (!query) {
132
+ if (!this._defaultQuery) {
133
+ this.reloadData();
134
+ return;
135
+ }
136
+ query = this.defaultQuery;
137
+ }
138
+ if (!query.page) {
139
+ query.page = 0;
140
+ }
141
+ if (!query.pageSize) {
142
+ query.pageSize = this.defaultPageSize;
143
+ }
144
+ if (this._defaultQuery?.filterBy) {
145
+ if (!query.filterBy) {
146
+ query.filterBy = {};
147
+ }
148
+ for (const key in this._defaultQuery.filterBy) {
149
+ if (!query.filterBy[key] && query.filterBy[key] !== null) {
150
+ query.filterBy[key] = this._defaultQuery.filterBy[key];
151
+ }
152
+ }
153
+ }
154
+ if (this._defaultQuery?.sortBy) {
155
+ if (!query.sortBy) {
156
+ query.sortBy = [];
157
+ }
158
+ if (!query.sortBy.length) {
159
+ query.sortBy = object_util_1.DyFM_Object.clone(this._defaultQuery.sortBy);
160
+ }
161
+ }
162
+ this.reloadData(query);
163
+ });
164
+ if (this.searchOnInit) {
165
+ this._freshQuery_S.next(this.defaultQuery);
166
+ }
167
+ }
168
+ // 1
169
+ /**
170
+ * Updates the search query and triggers a new search.
171
+ * The search will be debounced according to queryUpdateDebounceTime.
172
+ *
173
+ * @param query - The new search query to use
174
+ */
175
+ updateQuery(query) {
176
+ this._freshQuery_S.next(query);
177
+ }
178
+ /**
179
+ * Override to prevent adding dependent data handlers.
180
+ * Search handlers cannot have dependencies.
181
+ *
182
+ * @throws Error - Always throws as search handlers cannot have dependencies
183
+ */
184
+ addDependentDataHandlers(dependentDataHandlers) {
185
+ throw new Error('Cannot add dependent data handlers to a search data handler');
186
+ }
187
+ /**
188
+ * Filters the current search query
189
+ *
190
+ * @param filterBy - The filter to apply to the current search query
191
+ */
192
+ filter(filterBy) {
193
+ const query = this.lastLoadedBy ?? this.defaultQuery;
194
+ if (query) {
195
+ query.filterBy = filterBy;
196
+ this.reloadData(query);
197
+ }
198
+ }
199
+ /**
200
+ * Adds a filter to the current search query
201
+ *
202
+ * @param filterBy - The filter to add to the current search query
203
+ */
204
+ addFiler(filterBy) {
205
+ const query = this.lastLoadedBy ?? this.defaultQuery;
206
+ if (query) {
207
+ Object.assign(query.filterBy, filterBy);
208
+ this.reloadData(query);
209
+ }
210
+ }
211
+ /**
212
+ * Removes a filter from the current search query
213
+ *
214
+ * @param keys - The keys of the filter to remove from the current search query
215
+ */
216
+ removeFilter(keys) {
217
+ const query = this.lastLoadedBy ?? this.defaultQuery;
218
+ if (query) {
219
+ keys.forEach((key) => {
220
+ delete query.filterBy[key];
221
+ });
222
+ this.reloadData(query);
223
+ }
224
+ }
225
+ clearFilters() {
226
+ const query = this.lastLoadedBy ?? this.defaultQuery;
227
+ if (query) {
228
+ query.filterBy = {};
229
+ this.reloadData(query);
230
+ }
231
+ }
232
+ /**
233
+ * Sorts the current search query
234
+ *
235
+ * @param sortBy - The sort to apply to the current search query
236
+ */
237
+ sort(sortBy) {
238
+ const query = this.lastLoadedBy ?? this.defaultQuery;
239
+ if (query) {
240
+ query.sortBy = sortBy;
241
+ this.reloadData(query);
242
+ }
243
+ }
244
+ /**
245
+ * Adds a sort to the current search query
246
+ *
247
+ * @param sortBy - The sort to add to the current search query
248
+ */
249
+ addSort(sortBy) {
250
+ const query = this.lastLoadedBy ?? this.defaultQuery;
251
+ if (query) {
252
+ query.sortBy.push(...sortBy);
253
+ this.reloadData(query);
254
+ }
255
+ }
256
+ /**
257
+ * Removes a sort from the current search query
258
+ *
259
+ * @param keys - The keys of the sort to remove from the current search query
260
+ */
261
+ removeSort(keys) {
262
+ const query = this.lastLoadedBy ?? this.defaultQuery;
263
+ if (query) {
264
+ query.sortBy = query.sortBy.filter((sort) => !keys.includes(sort.key));
265
+ this.reloadData(query);
266
+ }
267
+ }
268
+ clearSorts() {
269
+ const query = this.lastLoadedBy ?? this.defaultQuery;
270
+ if (query) {
271
+ query.sortBy = [];
272
+ this.reloadData(query);
273
+ }
274
+ }
275
+ /**
276
+ * Sets the page of the current search query
277
+ *
278
+ * @param page - The page to set to the current search query
279
+ */
280
+ page(page, pageSize) {
281
+ const query = this.lastLoadedBy ?? this.defaultQuery;
282
+ if (query) {
283
+ query.page = page;
284
+ if (pageSize) {
285
+ query.pageSize = pageSize;
286
+ }
287
+ this.reloadData(query);
288
+ }
289
+ }
290
+ /**
291
+ * Sets the page size of the current search query
292
+ *
293
+ * @param pageSize - The page size to set to the current search query
294
+ */
295
+ pageSize(pageSize) {
296
+ const query = this.lastLoadedBy ?? this.defaultQuery;
297
+ if (query) {
298
+ query.pageSize = pageSize;
299
+ this.reloadData(query);
300
+ }
301
+ }
302
+ resetPage() {
303
+ const query = this.lastLoadedBy ?? this.defaultQuery;
304
+ if (query) {
305
+ query.page = 0;
306
+ query.pageSize = this.defaultPageSize;
307
+ this.reloadData(query);
308
+ }
309
+ }
310
+ resetQuery() {
311
+ const query = this.defaultQuery;
312
+ if (query) {
313
+ this.reloadData(query);
314
+ }
315
+ else {
316
+ query.filterBy = {};
317
+ query.sortBy = [];
318
+ query.page = 0;
319
+ query.pageSize = this.defaultPageSize;
320
+ this.reloadData(query);
321
+ }
322
+ }
323
+ }
324
+ exports.DyFM_DataSearchHandler = DyFM_DataSearchHandler;
325
+ //# sourceMappingURL=data-search-handler.control-model.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"data-search-handler.control-model.js","sourceRoot":"","sources":["../../../../src/_modules/data-handler/_models/data-search-handler.control-model.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,116 @@
1
+ import { BehaviorSubject, Observable } from 'rxjs';
2
+ import { DyFM_ListCollectorDataHandler_Settings } from './data-handler-settings.control-model';
3
+ import { DyFM_DataHandler } from './data-handler.control-model';
4
+ import { DyFM_Metadata } from '../../../_models/data-models/metadata.data-model';
5
+ /**
6
+ * A specialized data handler for managing list collections within a parent data object.
7
+ * Extends DyFM_DataHandler to provide functionality for handling lists within a collector object.
8
+ *
9
+ * @template T_ListCollectorData - The type of the parent collector data object
10
+ * @template T_DataItem - The type of individual items in the list (must extend DyFM_Metadata)
11
+ * @template T_DependencyData - The type of dependency data (defaults to any)
12
+ * @template T_DataLoadBy - The type used to identify how data should be loaded (defaults to string)
13
+ *
14
+ * @example
15
+ * ```typescript
16
+ * // Create a list collector handler for user's projects
17
+ * const userProjectsHandler = new DyFM_ListCollectorDataHandler<User, Project>({
18
+ * listKey: 'projects',
19
+ * get: async (userId: string): Promise<User> => {
20
+ * return await userService.getUserWithProjects(userId);
21
+ * }
22
+ * });
23
+ *
24
+ * // Access the data list
25
+ * const projects = userProjectsHandler.dataList;
26
+ *
27
+ * // Add a new project
28
+ * userProjectsHandler.addItem(newProject);
29
+ *
30
+ * // Update an existing project
31
+ * userProjectsHandler.updateItem(updatedProject);
32
+ *
33
+ * // Subscribe to changes
34
+ * userProjectsHandler.dataList$.subscribe(projects => {
35
+ * console.log('Projects updated:', projects);
36
+ * });
37
+ * ```
38
+ */
39
+ export declare class DyFM_ListCollectorDataHandler<T_ListCollectorData extends DyFM_Metadata, T_DataItem extends DyFM_Metadata, T_DependencyData extends DyFM_Metadata = any, T_DataLoadBy = string> extends DyFM_DataHandler<T_ListCollectorData, T_DependencyData, T_DataLoadBy> {
40
+ /** this is only for data list handlers,
41
+ * while creating arrow function for this, dont forget to use async n await! */
42
+ protected readonly setItem?: (item: T_DataItem, collectorId?: string) => Promise<T_DataItem>;
43
+ /** this is only for data list handlers,
44
+ * while creating arrow function for this, dont forget to use async n await! */
45
+ protected readonly deleteItem?: (id: string, collectorId?: string) => Promise<void>;
46
+ protected readonly listKey: string;
47
+ /**
48
+ * BehaviorSubject that holds the current data list.
49
+ * Computed from the base data_BS BehaviorSubject, ensuring it always returns an array.
50
+ */
51
+ protected readonly dataList_BS: BehaviorSubject<T_DataItem[]>;
52
+ /**
53
+ * Observable that holds the current data list.
54
+ * Computed from the base data$ Observable, ensuring it always returns an array.
55
+ */
56
+ readonly dataList$: Observable<T_DataItem[]>;
57
+ /**
58
+ * BehaviorSubject that holds the currently active item.
59
+ */
60
+ readonly activeItem_BS: BehaviorSubject<T_DataItem>;
61
+ /**
62
+ * Observable that holds the currently active item.
63
+ */
64
+ readonly activeItem$: Observable<T_DataItem>;
65
+ /**
66
+ * Gets the current data value.
67
+ * @returns The current data value
68
+ */
69
+ get data(): T_ListCollectorData;
70
+ /**
71
+ * Gets the current data list.
72
+ * Alias for data getter.
73
+ * @returns The current array of data items
74
+ */
75
+ get dataList(): T_DataItem[];
76
+ /**
77
+ * Creates a new instance of DyFM_ListCollectorDataHandler.
78
+ *
79
+ * @param set - Configuration settings for the data handler
80
+ * @param skipDependencyConnections - Optional flag to skip dependency connections during construction
81
+ */
82
+ constructor(set: DyFM_ListCollectorDataHandler_Settings<T_ListCollectorData, T_DataItem, T_DependencyData, T_DataLoadBy>,
83
+ /** is in construct?
84
+ * so the dependent data handlers are not added here, but in the extended class */
85
+ skipDependencyConnections?: boolean);
86
+ clear(dontClearDependents?: boolean): void;
87
+ /**
88
+ * Adds a new item to the data list.
89
+ *
90
+ * @param item - The item to add to the list
91
+ * @param collectorId - Optional collector ID for tracking
92
+ * @param dontSendUpdate - Optional flag to prevent sending update notification
93
+ */
94
+ addItem(item: T_DataItem, collectorId?: string, dontSendUpdate?: boolean): Promise<void>;
95
+ /**
96
+ * Removes an item from the data list.
97
+ * The item is identified by its _id property.
98
+ *
99
+ * @param id - The id of the item to remove from the list
100
+ * @param collectorId - Optional collector ID for tracking
101
+ * @param dontSendUpdate - Optional flag to prevent sending update notification
102
+ */
103
+ removeItem(id: string, collectorId?: string, dontSendUpdate?: boolean): Promise<void>;
104
+ /**
105
+ * Updates an existing item in the data list.
106
+ * The item is identified by its _id property.
107
+ *
108
+ * @param item - The updated item
109
+ * @param collectorId - Optional collector ID for tracking
110
+ * @param dontSendUpdate - Optional flag to prevent sending update notification
111
+ * @throws Error if the item is not found in the list
112
+ */
113
+ updateItem(item: T_DataItem, collectorId?: string, dontSendUpdate?: boolean): Promise<void>;
114
+ setActiveItem(item: T_DataItem): void;
115
+ }
116
+ //# sourceMappingURL=list-collector-data-handler.control-model.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"list-collector-data-handler.control-model.d.ts","sourceRoot":"","sources":["../../../../src/_modules/data-handler/_models/list-collector-data-handler.control-model.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAEnD,OAAO,EAAE,sCAAsC,EAAE,MAAM,uCAAuC,CAAC;AAE/F,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAEhE,OAAO,EAAE,aAAa,EAAE,MAAM,kDAAkD,CAAC;AAEjF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAiCG;AACH,qBAAa,6BAA6B,CACxC,mBAAmB,SAAS,aAAa,EACzC,UAAU,SAAS,aAAa,EAChC,gBAAgB,SAAS,aAAa,GAAG,GAAG,EAC5C,YAAY,GAAG,MAAM,CACrB,SAAQ,gBAAgB,CAAC,mBAAmB,EAAE,gBAAgB,EAAE,YAAY,CAAC;IAE7E;mFAC+E;IAC/E,SAAS,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,CAAC,IAAI,EAAE,UAAU,EAAE,WAAW,CAAC,EAAE,MAAM,KAAK,OAAO,CAAC,UAAU,CAAC,CAAC;IAC7F;mFAC+E;IAC/E,SAAS,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,CAAC,EAAE,EAAE,MAAM,EAAE,WAAW,CAAC,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAEpF,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;IAEnC;;;OAGG;IACH,SAAS,CAAC,QAAQ,CAAC,WAAW,EAAE,eAAe,CAAC,UAAU,EAAE,CAAC,CAAC;IAE9D;;;OAGG;IACH,QAAQ,CAAC,SAAS,EAAE,UAAU,CAAC,UAAU,EAAE,CAAC,CAAC;IAE7C;;OAEG;IACH,QAAQ,CAAC,aAAa,EAAE,eAAe,CAAC,UAAU,CAAC,CAAC;IAEpD;;OAEG;IACH,QAAQ,CAAC,WAAW,EAAE,UAAU,CAAC,UAAU,CAAC,CAAC;IAE7C;;;OAGG;IACH,IAAa,IAAI,IAAI,mBAAmB,CAEvC;IAED;;;;OAIG;IACH,IAAI,QAAQ,IAAI,UAAU,EAAE,CAE3B;IAED;;;;;OAKG;gBAED,GAAG,EAAE,sCAAsC,CAAC,mBAAmB,EAAE,UAAU,EAAE,gBAAgB,EAAE,YAAY,CAAC;IAC5G;sFACkF;IAClF,yBAAyB,CAAC,EAAE,OAAO;IAqD5B,KAAK,CAAC,mBAAmB,CAAC,EAAE,OAAO,GAAG,IAAI;IAKnD;;;;;;OAMG;IACG,OAAO,CAAC,IAAI,EAAE,UAAU,EAAE,WAAW,CAAC,EAAE,MAAM,EAAE,cAAc,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAsB9F;;;;;;;OAOG;IACG,UAAU,CAAC,EAAE,EAAE,MAAM,EAAE,WAAW,CAAC,EAAE,MAAM,EAAE,cAAc,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAyB3F;;;;;;;;OAQG;IACG,UAAU,CAAC,IAAI,EAAE,UAAU,EAAE,WAAW,CAAC,EAAE,MAAM,EAAE,cAAc,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAkCjG,aAAa,CAAC,IAAI,EAAE,UAAU,GAAG,IAAI;CAGtC"}