c2-mongoose 2.1.104 → 2.1.106
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/flow/SearchFlow.d.ts +1 -5
- package/dist/flow/SearchFlow.js +22 -17
- package/package.json +1 -1
- package/src/flow/SearchFlow.ts +20 -7
|
@@ -23,11 +23,7 @@ declare abstract class SearchFlow {
|
|
|
23
23
|
buildPath(target: string, nested?: string): any;
|
|
24
24
|
buildOrdenation(): any;
|
|
25
25
|
buildRegex(searchText: string): RegExp;
|
|
26
|
-
searchPageable(model: mongoose.Model<any>, options: SearchOptions): Promise<
|
|
27
|
-
items: any;
|
|
28
|
-
paging: any;
|
|
29
|
-
metadata: any;
|
|
30
|
-
}>;
|
|
26
|
+
searchPageable(model: mongoose.Model<any>, options: SearchOptions): Promise<any>;
|
|
31
27
|
search(model: mongoose.Model<any>, options?: SearchOptions): Promise<SearchResponse<any>>;
|
|
32
28
|
/**
|
|
33
29
|
*
|
package/dist/flow/SearchFlow.js
CHANGED
|
@@ -185,9 +185,9 @@ var SearchFlow = /** @class */ (function () {
|
|
|
185
185
|
return new RegExp("".concat(regexExpression), 'i');
|
|
186
186
|
};
|
|
187
187
|
SearchFlow.prototype.searchPageable = function (model, options) {
|
|
188
|
-
var _a
|
|
188
|
+
var _a;
|
|
189
189
|
return __awaiter(this, void 0, void 0, function () {
|
|
190
|
-
var stagesItems, stagesPaging, stagesMetadata, result, items,
|
|
190
|
+
var stagesItems, stagesPaging, stagesMetadata, facet, _i, stagesMetadata_1, metadata, result, items, _b, _c, populate;
|
|
191
191
|
return __generator(this, function (_d) {
|
|
192
192
|
switch (_d.label) {
|
|
193
193
|
case 0:
|
|
@@ -214,36 +214,41 @@ var SearchFlow = /** @class */ (function () {
|
|
|
214
214
|
if ((0, Utils_1.isNotEmpty)(options.metadata)) {
|
|
215
215
|
stagesMetadata.push.apply(stagesMetadata, options.metadata);
|
|
216
216
|
}
|
|
217
|
+
facet = {
|
|
218
|
+
items: stagesItems,
|
|
219
|
+
paging: stagesPaging,
|
|
220
|
+
};
|
|
221
|
+
for (_i = 0, stagesMetadata_1 = stagesMetadata; _i < stagesMetadata_1.length; _i++) {
|
|
222
|
+
metadata = stagesMetadata_1[_i];
|
|
223
|
+
facet[metadata.id] = metadata.conditions;
|
|
224
|
+
}
|
|
217
225
|
return [4 /*yield*/, model.aggregate([
|
|
218
226
|
{
|
|
219
|
-
$facet:
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
227
|
+
$facet: facet
|
|
228
|
+
// {
|
|
229
|
+
// items: stagesItems,
|
|
230
|
+
// paging: stagesPaging,
|
|
231
|
+
// metadata: stagesMetadata
|
|
232
|
+
// }
|
|
233
|
+
},
|
|
225
234
|
]).session(options === null || options === void 0 ? void 0 : options.session)];
|
|
226
235
|
case 1:
|
|
227
236
|
result = _d.sent();
|
|
228
237
|
items = result[0].items;
|
|
229
238
|
if (!((0, Utils_1.isNotEmpty)(this.populate) && Array.isArray(this.populate))) return [3 /*break*/, 5];
|
|
230
|
-
|
|
239
|
+
_b = 0, _c = this.populate;
|
|
231
240
|
_d.label = 2;
|
|
232
241
|
case 2:
|
|
233
|
-
if (!(
|
|
234
|
-
populate = _c[
|
|
242
|
+
if (!(_b < _c.length)) return [3 /*break*/, 5];
|
|
243
|
+
populate = _c[_b];
|
|
235
244
|
return [4 /*yield*/, model.populate(result[0].items, populate)];
|
|
236
245
|
case 3:
|
|
237
246
|
items = _d.sent();
|
|
238
247
|
_d.label = 4;
|
|
239
248
|
case 4:
|
|
240
|
-
|
|
249
|
+
_b++;
|
|
241
250
|
return [3 /*break*/, 2];
|
|
242
|
-
case 5: return [2 /*return*/, {
|
|
243
|
-
items: items,
|
|
244
|
-
paging: ((_a = result[0]) === null || _a === void 0 ? void 0 : _a.paging[0]) || { total: 0, page: 1, limit: this.limit },
|
|
245
|
-
metadata: ((_b = result[0]) === null || _b === void 0 ? void 0 : _b.metadata[0]) || undefined
|
|
246
|
-
}];
|
|
251
|
+
case 5: return [2 /*return*/, __assign(__assign({}, result[0]), { items: items, paging: ((_a = result[0]) === null || _a === void 0 ? void 0 : _a.paging[0]) || { total: 0, page: 1, limit: this.limit } })];
|
|
247
252
|
}
|
|
248
253
|
});
|
|
249
254
|
});
|
package/package.json
CHANGED
package/src/flow/SearchFlow.ts
CHANGED
|
@@ -155,15 +155,28 @@ abstract class SearchFlow {
|
|
|
155
155
|
stagesMetadata.push(...options.metadata)
|
|
156
156
|
}
|
|
157
157
|
|
|
158
|
+
|
|
159
|
+
const facet: { [key: string]: any } = {
|
|
160
|
+
items: stagesItems,
|
|
161
|
+
paging: stagesPaging,
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
for (let metadata of stagesMetadata) {
|
|
165
|
+
facet[metadata.id] = metadata.conditions
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
|
|
169
|
+
|
|
158
170
|
const result = await model.aggregate(
|
|
159
171
|
[
|
|
160
172
|
{
|
|
161
|
-
$facet:
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
173
|
+
$facet: facet
|
|
174
|
+
// {
|
|
175
|
+
// items: stagesItems,
|
|
176
|
+
// paging: stagesPaging,
|
|
177
|
+
// metadata: stagesMetadata
|
|
178
|
+
// }
|
|
179
|
+
},
|
|
167
180
|
]
|
|
168
181
|
).session(options?.session as ClientSession)
|
|
169
182
|
|
|
@@ -176,9 +189,9 @@ abstract class SearchFlow {
|
|
|
176
189
|
}
|
|
177
190
|
|
|
178
191
|
return {
|
|
192
|
+
...result[0],
|
|
179
193
|
items,
|
|
180
194
|
paging: result[0]?.paging[0] || { total: 0, page: 1, limit: this.limit },
|
|
181
|
-
metadata: result[0]?.metadata[0] || undefined
|
|
182
195
|
}
|
|
183
196
|
}
|
|
184
197
|
|