@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,111 @@
1
+ import { BehaviorSubject, Observable } from 'rxjs';
2
+ import { DyFM_DataListHandler_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 arrays of data items.
7
+ * Extends DyFM_DataHandler to provide additional functionality for handling lists of data.
8
+ *
9
+ * @template T_DataList - The type of the data list (must be an array of T_DataItem)
10
+ * @template T_DependencyData - The type of dependency data (defaults to any)
11
+ * @template T_DataLoadBy - The type used to identify how data should be loaded (defaults to string)
12
+ * @template T_DataItem - The type of individual items in the list (must extend DyFM_Metadata)
13
+ *
14
+ * @example
15
+ * ```typescript
16
+ * // Create a data list handler for user messages
17
+ * const messagesHandler = new DyFM_DataListHandler<UserMessage[]>({
18
+ * get: async (userId: string): Promise<UserMessage[]> => {
19
+ * return await userApiService.getUserMessages(userId, 0, 100);
20
+ * }
21
+ * });
22
+ *
23
+ * // Access the data list
24
+ * const messages = messagesHandler.dataList;
25
+ *
26
+ * // Add a new message
27
+ * messagesHandler.addItem(newMessage);
28
+ *
29
+ * // Update an existing message
30
+ * messagesHandler.updateItem(updatedMessage);
31
+ *
32
+ * // Subscribe to changes
33
+ * messagesHandler.dataList$.subscribe(messages => {
34
+ * console.log('Messages updated:', messages);
35
+ * });
36
+ * ```
37
+ */
38
+ export declare class DyFM_DataListHandler<T_DataItem extends DyFM_Metadata, T_DependencyData extends DyFM_Metadata = any, T_DataLoadBy = string, T_UpdateItemBy = string> extends DyFM_DataHandler<T_DataItem[], T_DependencyData, T_DataLoadBy> {
39
+ protected readonly setItem: (item: T_DataItem, updateBy?: T_UpdateItemBy) => Promise<T_DataItem>;
40
+ protected readonly deleteItem: (id: string, updateBy?: T_UpdateItemBy) => Promise<void>;
41
+ /**
42
+ * BehaviorSubject that holds the current data list.
43
+ * Computed from the base data_BS BehaviorSubject, ensuring it always returns an array.
44
+ */
45
+ protected readonly dataList_BS: BehaviorSubject<T_DataItem[]>;
46
+ /**
47
+ * Observable that holds the current data list.
48
+ * Computed from the base data$ Observable, ensuring it always returns an array.
49
+ */
50
+ readonly dataList$: Observable<T_DataItem[]>;
51
+ /**
52
+ * BehaviorSubject that holds the currently active item.
53
+ */
54
+ readonly activeItem_BS: BehaviorSubject<T_DataItem>;
55
+ /**
56
+ * Observable that holds the currently active item.
57
+ */
58
+ readonly activeItem$: Observable<T_DataItem>;
59
+ /**
60
+ * Gets the current data list.
61
+ * @returns The current array of data items
62
+ */
63
+ get data(): T_DataItem[];
64
+ /**
65
+ * Gets the current data list.
66
+ * Alias for data getter.
67
+ * @returns The current array of data items
68
+ */
69
+ get dataList(): T_DataItem[];
70
+ /**
71
+ * Creates a new instance of DyFM_DataListHandler.
72
+ *
73
+ * @param set - Configuration settings for the data handler
74
+ * @param skipDependencyConnections - Optional flag to skip dependency connections during construction
75
+ */
76
+ constructor(set: DyFM_DataListHandler_Settings<T_DataItem, T_DependencyData, T_DataLoadBy, T_UpdateItemBy>,
77
+ /** is in construct?
78
+ * so the dependent data handlers are not added here, but in the extended class */
79
+ skipDependencyConnections?: boolean);
80
+ reloadData(loadBy?: T_DataLoadBy): Promise<T_DataItem[]>;
81
+ clear(dontClearDependents?: boolean): void;
82
+ /**
83
+ * Adds a new item to the data list.
84
+ *
85
+ * @param item - The item to add to the list
86
+ * @param updateBy - Optional parameter for update tracking
87
+ * @param dontSendUpdate - Optional flag to prevent sending update notification
88
+ */
89
+ addItem(item: T_DataItem, updateBy?: T_UpdateItemBy, dontSendUpdate?: boolean): Promise<void>;
90
+ /**
91
+ * Removes an item from the data list.
92
+ * The item is identified by its _id property.
93
+ *
94
+ * @param id - The id of the item to remove from the list
95
+ * @param updateBy - Optional parameter for update tracking
96
+ * @param dontSendUpdate - Optional flag to prevent sending update notification
97
+ */
98
+ removeItem(id: string, updateBy?: T_UpdateItemBy, dontSendUpdate?: boolean): Promise<void>;
99
+ /**
100
+ * Updates an existing item in the data list.
101
+ * The item is identified by its _id property.
102
+ *
103
+ * @param item - The updated item
104
+ * @param updateBy - Optional parameter for update tracking
105
+ * @param dontSendUpdate - Optional flag to prevent sending update notification
106
+ * @throws Error if the item is not found in the list
107
+ */
108
+ updateItem(item: T_DataItem, updateBy?: T_UpdateItemBy, dontSendUpdate?: boolean): Promise<void>;
109
+ setActiveItem(item: T_DataItem): void;
110
+ }
111
+ //# sourceMappingURL=data-list-handler.control-model.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"data-list-handler.control-model.d.ts","sourceRoot":"","sources":["../../../../src/_modules/data-handler/_models/data-list-handler.control-model.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAEnD,OAAO,EAAE,6BAA6B,EAAE,MAAM,uCAAuC,CAAC;AAEtF,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAChE,OAAO,EAAE,aAAa,EAAE,MAAM,kDAAkD,CAAC;AAGjF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgCG;AACH,qBAAa,oBAAoB,CAC/B,UAAU,SAAS,aAAa,EAChC,gBAAgB,SAAS,aAAa,GAAG,GAAG,EAC5C,YAAY,GAAG,MAAM,EACrB,cAAc,GAAG,MAAM,CACvB,SAAQ,gBAAgB,CAAC,UAAU,EAAE,EAAE,gBAAgB,EAAE,YAAY,CAAC;IAEtE,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC,IAAI,EAAE,UAAU,EAAE,QAAQ,CAAC,EAAE,cAAc,KAAK,OAAO,CAAC,UAAU,CAAC,CAAC;IACjG,SAAS,CAAC,QAAQ,CAAC,UAAU,EAAE,CAAC,EAAE,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,cAAc,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAExF;;;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,UAAU,EAAE,CAEhC;IAED;;;;OAIG;IACH,IAAI,QAAQ,IAAI,UAAU,EAAE,CAE3B;IAED;;;;;OAKG;gBAED,GAAG,EAAE,6BAA6B,CAAC,UAAU,EAAE,gBAAgB,EAAE,YAAY,EAAE,cAAc,CAAC;IAC9F;sFACkF;IAClF,yBAAyB,CAAC,EAAE,OAAO;IAmDtB,UAAU,CAAC,MAAM,CAAC,EAAE,YAAY,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;IAS9D,KAAK,CAAC,mBAAmB,CAAC,EAAE,OAAO,GAAG,IAAI;IAKnD;;;;;;OAMG;IACG,OAAO,CAAC,IAAI,EAAE,UAAU,EAAE,QAAQ,CAAC,EAAE,cAAc,EAAE,cAAc,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAanG;;;;;;;OAOG;IACG,UAAU,CAAC,EAAE,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,cAAc,EAAE,cAAc,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAiBhG;;;;;;;;OAQG;IACG,UAAU,CAAC,IAAI,EAAE,UAAU,EAAE,QAAQ,CAAC,EAAE,cAAc,EAAE,cAAc,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAsBtG,aAAa,CAAC,IAAI,EAAE,UAAU,GAAG,IAAI;CAGtC"}
@@ -0,0 +1,217 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DyFM_DataListHandler = void 0;
4
+ const rxjs_1 = require("rxjs");
5
+ const data_handler_control_model_1 = require("./data-handler.control-model");
6
+ const error_control_model_1 = require("../../../_models/control-models/error.control-model");
7
+ /**
8
+ * A specialized data handler for managing arrays of data items.
9
+ * Extends DyFM_DataHandler to provide additional functionality for handling lists of data.
10
+ *
11
+ * @template T_DataList - The type of the data list (must be an array of T_DataItem)
12
+ * @template T_DependencyData - The type of dependency data (defaults to any)
13
+ * @template T_DataLoadBy - The type used to identify how data should be loaded (defaults to string)
14
+ * @template T_DataItem - The type of individual items in the list (must extend DyFM_Metadata)
15
+ *
16
+ * @example
17
+ * ```typescript
18
+ * // Create a data list handler for user messages
19
+ * const messagesHandler = new DyFM_DataListHandler<UserMessage[]>({
20
+ * get: async (userId: string): Promise<UserMessage[]> => {
21
+ * return await userApiService.getUserMessages(userId, 0, 100);
22
+ * }
23
+ * });
24
+ *
25
+ * // Access the data list
26
+ * const messages = messagesHandler.dataList;
27
+ *
28
+ * // Add a new message
29
+ * messagesHandler.addItem(newMessage);
30
+ *
31
+ * // Update an existing message
32
+ * messagesHandler.updateItem(updatedMessage);
33
+ *
34
+ * // Subscribe to changes
35
+ * messagesHandler.dataList$.subscribe(messages => {
36
+ * console.log('Messages updated:', messages);
37
+ * });
38
+ * ```
39
+ */
40
+ class DyFM_DataListHandler extends data_handler_control_model_1.DyFM_DataHandler {
41
+ setItem;
42
+ deleteItem;
43
+ /**
44
+ * BehaviorSubject that holds the current data list.
45
+ * Computed from the base data_BS BehaviorSubject, ensuring it always returns an array.
46
+ */
47
+ dataList_BS;
48
+ /**
49
+ * Observable that holds the current data list.
50
+ * Computed from the base data$ Observable, ensuring it always returns an array.
51
+ */
52
+ dataList$;
53
+ /**
54
+ * BehaviorSubject that holds the currently active item.
55
+ */
56
+ activeItem_BS;
57
+ /**
58
+ * Observable that holds the currently active item.
59
+ */
60
+ activeItem$;
61
+ /**
62
+ * Gets the current data list.
63
+ * @returns The current array of data items
64
+ */
65
+ get data() {
66
+ return this.dataList_BS.value;
67
+ }
68
+ /**
69
+ * Gets the current data list.
70
+ * Alias for data getter.
71
+ * @returns The current array of data items
72
+ */
73
+ get dataList() {
74
+ return this.dataList_BS.value;
75
+ }
76
+ /**
77
+ * Creates a new instance of DyFM_DataListHandler.
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,
83
+ /** is in construct?
84
+ * so the dependent data handlers are not added here, but in the extended class */
85
+ skipDependencyConnections) {
86
+ super(set, skipDependencyConnections);
87
+ // Initialize dataList BehaviorSubject and Observable
88
+ this.dataList_BS = new rxjs_1.BehaviorSubject([]);
89
+ this.dataList$ = this.dataList_BS.asObservable();
90
+ // Initialize activeItem BehaviorSubject and Observable
91
+ this.activeItem_BS = new rxjs_1.BehaviorSubject(null);
92
+ this.activeItem$ = this.activeItem_BS.asObservable();
93
+ // Subscribe to data changes to update dataList
94
+ this.data$.subscribe(data => {
95
+ const dataList = Array.isArray(data) ? data : [];
96
+ this.dataList_BS.next(dataList);
97
+ });
98
+ if (set.setItem) {
99
+ this.setItem = set.setItem;
100
+ }
101
+ if (set.deleteItem) {
102
+ this.deleteItem = set.deleteItem;
103
+ }
104
+ this.getPostProcesses.push((data) => {
105
+ // check if data is an array
106
+ if (!Array.isArray(data)) {
107
+ console.error(`DYNAMO DataListHandler (${this.name}) ERROR: ` +
108
+ `\nData is not an array!:` +
109
+ '\n\n', data);
110
+ throw new Error(`Data is not an array! (${this.name})`);
111
+ }
112
+ return data;
113
+ });
114
+ if (!skipDependencyConnections) {
115
+ if (set.dependencyDataHandler) {
116
+ this.addDependencyDataHandler(set.dependencyDataHandler);
117
+ }
118
+ if (set.dependentDataHandlers) {
119
+ this.addDependentDataHandlers(set.dependentDataHandlers, true);
120
+ }
121
+ }
122
+ }
123
+ async reloadData(loadBy) {
124
+ const setActiveItem = !this.activeItem_BS.value || this.activeItem_BS.value?._id !== loadBy;
125
+ const dataList = await super.reloadData(loadBy);
126
+ if (setActiveItem && dataList.length > 0) {
127
+ this.setActiveItem(dataList[0]);
128
+ }
129
+ return dataList;
130
+ }
131
+ clear(dontClearDependents) {
132
+ super.clear(dontClearDependents);
133
+ this.activeItem_BS.next(null);
134
+ }
135
+ /**
136
+ * Adds a new item to the data list.
137
+ *
138
+ * @param item - The item to add to the list
139
+ * @param updateBy - Optional parameter for update tracking
140
+ * @param dontSendUpdate - Optional flag to prevent sending update notification
141
+ */
142
+ async addItem(item, updateBy, dontSendUpdate) {
143
+ const currentData = this.data;
144
+ currentData.push(item);
145
+ if (this.setItem && !dontSendUpdate) {
146
+ await this.setItem(item, updateBy);
147
+ // dont send update because we already sent it to the setItem function
148
+ await this.updateData(this.dataList_BS.value, true);
149
+ }
150
+ else {
151
+ await this.updateData(this.dataList_BS.value, dontSendUpdate);
152
+ }
153
+ this.activeItem_BS.next(item);
154
+ }
155
+ /**
156
+ * Removes an item from the data list.
157
+ * The item is identified by its _id property.
158
+ *
159
+ * @param id - The id of the item to remove from the list
160
+ * @param updateBy - Optional parameter for update tracking
161
+ * @param dontSendUpdate - Optional flag to prevent sending update notification
162
+ */
163
+ async removeItem(id, updateBy, dontSendUpdate) {
164
+ const currentData = this.data;
165
+ const index = currentData.findIndex(i => i._id === id);
166
+ if (index !== -1) {
167
+ currentData.splice(index, 1);
168
+ if (this.deleteItem) {
169
+ await this.deleteItem(id, updateBy);
170
+ await this.updateData(this.dataList_BS.value, true);
171
+ }
172
+ else {
173
+ await this.updateData(this.dataList_BS.value, dontSendUpdate);
174
+ }
175
+ }
176
+ if (this.activeItem_BS.value?._id === id) {
177
+ this.activeItem_BS.next(null);
178
+ }
179
+ }
180
+ /**
181
+ * Updates an existing item in the data list.
182
+ * The item is identified by its _id property.
183
+ *
184
+ * @param item - The updated item
185
+ * @param updateBy - Optional parameter for update tracking
186
+ * @param dontSendUpdate - Optional flag to prevent sending update notification
187
+ * @throws Error if the item is not found in the list
188
+ */
189
+ async updateItem(item, updateBy, dontSendUpdate) {
190
+ const currentData = this.data;
191
+ const index = currentData.findIndex(i => i._id === item._id);
192
+ if (index !== -1) {
193
+ currentData[index] = item;
194
+ if (this.setItem) {
195
+ await this.setItem(item, updateBy);
196
+ await this.updateData(this.dataList_BS.value, true);
197
+ }
198
+ else {
199
+ await this.updateData(this.dataList_BS.value, dontSendUpdate);
200
+ }
201
+ }
202
+ else {
203
+ throw new error_control_model_1.DyFM_Error({
204
+ error: new Error(`Item not found! (${this.name})`),
205
+ errorCode: 'DyFM-DLH-UI1',
206
+ additionalContent: {
207
+ item: item,
208
+ },
209
+ });
210
+ }
211
+ }
212
+ setActiveItem(item) {
213
+ this.activeItem_BS.next(item);
214
+ }
215
+ }
216
+ exports.DyFM_DataListHandler = DyFM_DataListHandler;
217
+ //# sourceMappingURL=data-list-handler.control-model.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"data-list-handler.control-model.js","sourceRoot":"","sources":["../../../../src/_modules/data-handler/_models/data-list-handler.control-model.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,172 @@
1
+ import { Subject } from 'rxjs';
2
+ import { DyFM_DataSearchHandler_Settings } from './data-handler-settings.control-model';
3
+ import { DyFM_DataListHandler } from './data-list-handler.control-model';
4
+ import { DyFM_Metadata } from '../../../_models/data-models/metadata.data-model';
5
+ import { DyFM_SearchQuery } from '../../../_models/interfaces/search-query.interface';
6
+ import { DyFM_SearchResult } from '../../../_models/interfaces/search-result.interface';
7
+ import { DyFM_DSFilter } from '../../../_models/types/ds-filter.type';
8
+ import { DyFM_DSSort } from '../../../_models/types/ds-sort.type';
9
+ interface SearchCache<T> {
10
+ page: number;
11
+ loadPageSize: number;
12
+ data: T[];
13
+ }
14
+ /**
15
+ * A specialized data handler for managing searchable data with pagination and caching.
16
+ * Extends DyFM_DataListHandler to provide additional functionality for handling search results.
17
+ *
18
+ * @template T_Data - The type of data items in the search results
19
+ * @template T_DataLoadBy - The type of search query (must extend DyFM_SearchQuery)
20
+ * @template T_Result - The type of search result (must extend DyFM_SearchResult)
21
+ * @template T_DependencyData - The type of dependency data (defaults to any)
22
+ *
23
+ * @example
24
+ * ```typescript
25
+ * // Create a search handler for flow runs
26
+ * const flowRunsHandler = new DyFM_DataSearchHandler<FlowRun_Preview>({
27
+ * name: 'myRuns',
28
+ * get: async (query?: DyFM_SearchQuery<FlowRun>): Promise<DyFM_SearchResult<FlowRun_Preview>> => {
29
+ * return await flowRunService.searchFlowRuns(query);
30
+ * },
31
+ * defaultQuery: {
32
+ * filterBy: { userId: currentUserId },
33
+ * pageSize: 20
34
+ * },
35
+ * queryUpdateDebounceTime: 500
36
+ * });
37
+ *
38
+ * // Update search query
39
+ * flowRunsHandler.updateQuery({
40
+ * page: 0,
41
+ * pageSize: 10,
42
+ * filterBy: { status: 'completed' }
43
+ * });
44
+ *
45
+ * // Access search results
46
+ * const runs = flowRunsHandler.dataList;
47
+ *
48
+ * // Get total items count
49
+ * const totalItems = flowRunsHandler.totalItems;
50
+ * ```
51
+ */
52
+ export declare class DyFM_DataSearchHandler<T_Data, T_DataLoadBy extends DyFM_SearchQuery<any> = DyFM_SearchQuery<T_Data>, T_Result extends DyFM_SearchResult<any> = DyFM_SearchResult<T_Data>, T_DependencyData extends DyFM_Metadata = any> extends DyFM_DataListHandler<T_Data, T_DependencyData, T_DataLoadBy> {
53
+ /**
54
+ * Subject for handling fresh search queries with debouncing.
55
+ * Used internally to manage query updates.
56
+ */
57
+ protected readonly _freshQuery_S: Subject<T_DataLoadBy>;
58
+ /**
59
+ * Cache of search results for different pages.
60
+ * Helps optimize performance by storing previously loaded results.
61
+ */
62
+ protected cache: SearchCache<T_Data>[];
63
+ /**
64
+ * Override of the get method to handle search queries.
65
+ * Must be implemented to fetch search results from the data source.
66
+ */
67
+ /**
68
+ * Maximum number of cached pages to keep in memory.
69
+ * Default is 5 pages.
70
+ */
71
+ protected cacheSize: number;
72
+ /**
73
+ * Default number of items per page.
74
+ * Used when no pageSize is specified in the query.
75
+ */
76
+ protected defaultPageSize: number;
77
+ /**
78
+ * Default search query to use when no query is provided.
79
+ * Can include default filters, sorting, and pagination settings.
80
+ */
81
+ protected get defaultQuery(): T_DataLoadBy;
82
+ protected _defaultQuery?: T_DataLoadBy;
83
+ /**
84
+ * Total number of items available in the search results.
85
+ * Updated after each successful search.
86
+ */
87
+ protected totalItems: number;
88
+ /**
89
+ * Debounce time in milliseconds for query updates.
90
+ * Helps prevent too frequent API calls when query changes rapidly.
91
+ */
92
+ protected queryUpdateDebounceTime: number;
93
+ /**
94
+ * Whether to perform initial search when handler is created.
95
+ * If true, will use defaultQuery for initial search.
96
+ */
97
+ protected searchOnInit: boolean;
98
+ /**
99
+ * Creates a new instance of DyFM_DataSearchHandler.
100
+ *
101
+ * @param set - Configuration settings for the search handler
102
+ */
103
+ constructor(set: DyFM_DataSearchHandler_Settings<T_Data, T_DataLoadBy, T_DependencyData>);
104
+ /**
105
+ * Updates the search query and triggers a new search.
106
+ * The search will be debounced according to queryUpdateDebounceTime.
107
+ *
108
+ * @param query - The new search query to use
109
+ */
110
+ updateQuery(query: T_DataLoadBy): void;
111
+ /**
112
+ * Override to prevent adding dependent data handlers.
113
+ * Search handlers cannot have dependencies.
114
+ *
115
+ * @throws Error - Always throws as search handlers cannot have dependencies
116
+ */
117
+ addDependentDataHandlers(dependentDataHandlers: any[]): void;
118
+ /**
119
+ * Filters the current search query
120
+ *
121
+ * @param filterBy - The filter to apply to the current search query
122
+ */
123
+ filter(filterBy: DyFM_DSFilter<T_Data>): void;
124
+ /**
125
+ * Adds a filter to the current search query
126
+ *
127
+ * @param filterBy - The filter to add to the current search query
128
+ */
129
+ addFiler(filterBy: DyFM_DSFilter<T_Data>): void;
130
+ /**
131
+ * Removes a filter from the current search query
132
+ *
133
+ * @param keys - The keys of the filter to remove from the current search query
134
+ */
135
+ removeFilter(keys: (keyof T_Data)[]): void;
136
+ clearFilters(): void;
137
+ /**
138
+ * Sorts the current search query
139
+ *
140
+ * @param sortBy - The sort to apply to the current search query
141
+ */
142
+ sort(sortBy: DyFM_DSSort[]): void;
143
+ /**
144
+ * Adds a sort to the current search query
145
+ *
146
+ * @param sortBy - The sort to add to the current search query
147
+ */
148
+ addSort(sortBy: DyFM_DSSort[]): void;
149
+ /**
150
+ * Removes a sort from the current search query
151
+ *
152
+ * @param keys - The keys of the sort to remove from the current search query
153
+ */
154
+ removeSort(keys: string[]): void;
155
+ clearSorts(): void;
156
+ /**
157
+ * Sets the page of the current search query
158
+ *
159
+ * @param page - The page to set to the current search query
160
+ */
161
+ page(page: number, pageSize?: number): void;
162
+ /**
163
+ * Sets the page size of the current search query
164
+ *
165
+ * @param pageSize - The page size to set to the current search query
166
+ */
167
+ pageSize(pageSize: number): void;
168
+ resetPage(): void;
169
+ resetQuery(): void;
170
+ }
171
+ export {};
172
+ //# sourceMappingURL=data-search-handler.control-model.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"data-search-handler.control-model.d.ts","sourceRoot":"","sources":["../../../../src/_modules/data-handler/_models/data-search-handler.control-model.ts"],"names":[],"mappings":"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"}