@payloadcms/plugin-search 1.0.0 → 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +4 -126
- package/dist/Search/hooks/deleteFromSearch.d.ts +2 -1
- package/dist/Search/hooks/deleteFromSearch.d.ts.map +1 -0
- package/dist/Search/hooks/deleteFromSearch.js +31 -68
- package/dist/Search/hooks/syncWithSearch.d.ts +2 -1
- package/dist/Search/hooks/syncWithSearch.d.ts.map +1 -0
- package/dist/Search/hooks/syncWithSearch.js +115 -168
- package/dist/Search/index.d.ts +3 -2
- package/dist/Search/index.d.ts.map +1 -0
- package/dist/Search/index.js +70 -62
- package/dist/Search/ui/index.d.ts +2 -1
- package/dist/Search/ui/index.d.ts.map +1 -0
- package/dist/Search/ui/index.js +40 -30
- package/dist/index.d.ts +3 -2
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +65 -93
- package/dist/types.d.ts +18 -14
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +5 -2
- package/package.json +27 -16
- package/types.d.ts +1 -0
- package/types.js +1 -0
- package/dist/Search/hooks/deleteFromSearch.js.map +0 -1
- package/dist/Search/hooks/syncWithSearch.js.map +0 -1
- package/dist/Search/index.js.map +0 -1
- package/dist/Search/ui/index.js.map +0 -1
- package/dist/collections/FormSubmissions/hooks/createCharge.d.ts +0 -3
- package/dist/collections/FormSubmissions/hooks/createCharge.js +0 -53
- package/dist/collections/FormSubmissions/hooks/createCharge.js.map +0 -1
- package/dist/collections/FormSubmissions/hooks/sendEmail.d.ts +0 -3
- package/dist/collections/FormSubmissions/hooks/sendEmail.js +0 -151
- package/dist/collections/FormSubmissions/hooks/sendEmail.js.map +0 -1
- package/dist/collections/FormSubmissions/index.d.ts +0 -3
- package/dist/collections/FormSubmissions/index.js +0 -137
- package/dist/collections/FormSubmissions/index.js.map +0 -1
- package/dist/collections/Forms/DynamicFieldSelector.d.ts +0 -3
- package/dist/collections/Forms/DynamicFieldSelector.js +0 -62
- package/dist/collections/Forms/DynamicFieldSelector.js.map +0 -1
- package/dist/collections/Forms/DynamicPriceSelector.d.ts +0 -3
- package/dist/collections/Forms/DynamicPriceSelector.js +0 -77
- package/dist/collections/Forms/DynamicPriceSelector.js.map +0 -1
- package/dist/collections/Forms/fields.d.ts +0 -6
- package/dist/collections/Forms/fields.js +0 -456
- package/dist/collections/Forms/fields.js.map +0 -1
- package/dist/collections/Forms/index.d.ts +0 -3
- package/dist/collections/Forms/index.js +0 -194
- package/dist/collections/Forms/index.js.map +0 -1
- package/dist/collections/Search/index.d.ts +0 -3
- package/dist/collections/Search/index.js +0 -63
- package/dist/collections/Search/index.js.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/mocks/serverModule.d.ts +0 -2
- package/dist/mocks/serverModule.js +0 -4
- package/dist/mocks/serverModule.js.map +0 -1
- package/dist/types.js.map +0 -1
- package/dist/utilities/calculatePaymentTotal.d.ts +0 -4
- package/dist/utilities/calculatePaymentTotal.js +0 -47
- package/dist/utilities/calculatePaymentTotal.js.map +0 -1
- package/dist/utilities/deepMerge.d.ts +0 -2
- package/dist/utilities/deepMerge.js +0 -44
- package/dist/utilities/deepMerge.js.map +0 -1
- package/dist/utilities/getPaymentTotal.d.ts +0 -4
- package/dist/utilities/getPaymentTotal.js +0 -44
- package/dist/utilities/getPaymentTotal.js.map +0 -1
- package/dist/utilities/replaceDoubleCurlys.d.ts +0 -7
- package/dist/utilities/replaceDoubleCurlys.js +0 -20
- package/dist/utilities/replaceDoubleCurlys.js.map +0 -1
- package/dist/utilities/serializeRichText.d.ts +0 -10
- package/dist/utilities/serializeRichText.js +0 -49
- package/dist/utilities/serializeRichText.js.map +0 -1
package/README.md
CHANGED
|
@@ -1,129 +1,7 @@
|
|
|
1
1
|
# Payload Search Plugin
|
|
2
2
|
|
|
3
|
-
[
|
|
3
|
+
A plugin for [Payload](https://github.com/payloadcms/payload) to generate records of your documents that are extremely fast to search on.
|
|
4
4
|
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
- Creates a `search` collection that:
|
|
9
|
-
- Automatically creates, syncs, and deletes search results related to your documents
|
|
10
|
-
- Serves search results extremely quickly by saving only search-critical data that you define
|
|
11
|
-
- Allows you to sort search results by priority
|
|
12
|
-
|
|
13
|
-
## Installation
|
|
14
|
-
|
|
15
|
-
```bash
|
|
16
|
-
yarn add @payloadcms/plugin-search
|
|
17
|
-
# OR
|
|
18
|
-
npm i @payloadcms/plugin-search
|
|
19
|
-
```
|
|
20
|
-
|
|
21
|
-
## Basic Usage
|
|
22
|
-
|
|
23
|
-
In the `plugins` array of your [Payload config](https://payloadcms.com/docs/configuration/overview), call the plugin with [options](#options):
|
|
24
|
-
|
|
25
|
-
```js
|
|
26
|
-
import { buildConfig } from 'payload/config';
|
|
27
|
-
import search from 'payload-search';
|
|
28
|
-
|
|
29
|
-
const config = buildConfig({
|
|
30
|
-
collections: [
|
|
31
|
-
{
|
|
32
|
-
slug: 'pages',
|
|
33
|
-
fields: []
|
|
34
|
-
},
|
|
35
|
-
{
|
|
36
|
-
slug: 'posts',
|
|
37
|
-
fields: []
|
|
38
|
-
}
|
|
39
|
-
],
|
|
40
|
-
plugins: [
|
|
41
|
-
search({
|
|
42
|
-
collections: [
|
|
43
|
-
'pages',
|
|
44
|
-
'posts'
|
|
45
|
-
],
|
|
46
|
-
defaultPriorities: {
|
|
47
|
-
pages: 10,
|
|
48
|
-
posts: 20
|
|
49
|
-
}
|
|
50
|
-
})
|
|
51
|
-
]
|
|
52
|
-
});
|
|
53
|
-
|
|
54
|
-
export default config;
|
|
55
|
-
```
|
|
56
|
-
|
|
57
|
-
### Options
|
|
58
|
-
|
|
59
|
-
#### `collections`
|
|
60
|
-
|
|
61
|
-
An array of collections slugs to enable sync-to-search. Enabled collections receive a `beforeChange` and `afterDelete` hook that creates, syncs, and deleted the document to its related search document as it changes over time, and also an `afterDelete` hook that deletes.
|
|
62
|
-
|
|
63
|
-
#### `defaultPriorities`
|
|
64
|
-
|
|
65
|
-
The default priorities first set on `create` operations. Send an object of collection slugs, and set them to either a number or a function.
|
|
66
|
-
|
|
67
|
-
```js
|
|
68
|
-
plugins: [
|
|
69
|
-
searchPlugin({
|
|
70
|
-
defaultPriorities: {
|
|
71
|
-
pages: ({ doc }) => doc.title.startsWith('Hello, world!') ? 1 : 10,
|
|
72
|
-
posts: 20
|
|
73
|
-
}
|
|
74
|
-
})
|
|
75
|
-
]
|
|
76
|
-
```
|
|
77
|
-
|
|
78
|
-
#### `searchOverrides`
|
|
79
|
-
|
|
80
|
-
Override anything on the search collection by sending a [Payload Collection Config](https://payloadcms.com/docs/configuration/collections).
|
|
81
|
-
|
|
82
|
-
```js
|
|
83
|
-
plugins: [
|
|
84
|
-
searchPlugin({
|
|
85
|
-
searchOverrides: {
|
|
86
|
-
slug: 'search-results'
|
|
87
|
-
}
|
|
88
|
-
})
|
|
89
|
-
]
|
|
90
|
-
```
|
|
91
|
-
|
|
92
|
-
#### `beforeSync`
|
|
93
|
-
|
|
94
|
-
An [afterChange]([afterChange](https://payloadcms.com/docs/hooks/globals#afterchange)) hook that is called before creating or syncing the document to search. This allows you to modify the data in any way before doing so.
|
|
95
|
-
|
|
96
|
-
```js
|
|
97
|
-
plugins: [
|
|
98
|
-
searchPlugin({
|
|
99
|
-
beforeSync: ({ originalDoc, searchDoc }) => ({
|
|
100
|
-
...searchDoc,
|
|
101
|
-
// Modify your docs in any way here, this can be async
|
|
102
|
-
excerpt: originalDoc?.excerpt || 'This is a fallback excerpt'
|
|
103
|
-
}),
|
|
104
|
-
})
|
|
105
|
-
]
|
|
106
|
-
```
|
|
107
|
-
|
|
108
|
-
#### `syncDrafts`
|
|
109
|
-
|
|
110
|
-
If true, will sync draft documents to search. By default, this plugin will only sync published documents. False by default. You must have [Payload Drafts](https://payloadcms.com/docs/versions/drafts) enabled for this to apply.
|
|
111
|
-
|
|
112
|
-
#### `deleteDrafts`
|
|
113
|
-
|
|
114
|
-
If true, will delete documents from search that change to draft status. True by default. You must have [Payload Drafts](https://payloadcms.com/docs/versions/drafts) enabled for this to apply.
|
|
115
|
-
|
|
116
|
-
## TypeScript
|
|
117
|
-
|
|
118
|
-
All types can be directly imported:
|
|
119
|
-
|
|
120
|
-
```js
|
|
121
|
-
import {
|
|
122
|
-
SearchConfig,
|
|
123
|
-
BeforeSync
|
|
124
|
-
} from '@payloadcms/plugin-search/dist/types';
|
|
125
|
-
```
|
|
126
|
-
|
|
127
|
-
## Screenshots
|
|
128
|
-
|
|
129
|
-
<!--  -->
|
|
5
|
+
- [Source code](https://github.com/payloadcms/payload/tree/main/packages/plugin-search)
|
|
6
|
+
- [Documentation](https://payloadcms.com/docs/plugins/search)
|
|
7
|
+
- [Documentation source](https://github.com/payloadcms/payload/tree/main/docs/plugins/search.mdx)
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deleteFromSearch.d.ts","sourceRoot":"","sources":["../../../src/Search/hooks/deleteFromSearch.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,eAAe,CAAA;AAE9D,QAAA,MAAM,gBAAgB,EAAE,yBA2BvB,CAAA;AAED,eAAe,gBAAgB,CAAA"}
|
|
@@ -1,76 +1,39 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
12
|
-
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
13
|
-
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
14
|
-
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
15
|
-
function step(op) {
|
|
16
|
-
if (f) throw new TypeError("Generator is already executing.");
|
|
17
|
-
while (_) try {
|
|
18
|
-
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
19
|
-
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
20
|
-
switch (op[0]) {
|
|
21
|
-
case 0: case 1: t = op; break;
|
|
22
|
-
case 4: _.label++; return { value: op[1], done: false };
|
|
23
|
-
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
24
|
-
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
25
|
-
default:
|
|
26
|
-
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
27
|
-
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
28
|
-
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
29
|
-
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
30
|
-
if (t[2]) _.ops.pop();
|
|
31
|
-
_.trys.pop(); continue;
|
|
32
|
-
}
|
|
33
|
-
op = body.call(thisArg, _);
|
|
34
|
-
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
35
|
-
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "default", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return _default;
|
|
36
9
|
}
|
|
37
|
-
};
|
|
38
|
-
|
|
39
|
-
var deleteFromSearch = function (_a) {
|
|
40
|
-
var payload = _a.req.payload, doc = _a.doc;
|
|
10
|
+
});
|
|
11
|
+
const deleteFromSearch = async ({ doc, req: { payload }, req })=>{
|
|
41
12
|
try {
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
where: {
|
|
50
|
-
'doc.value': {
|
|
51
|
-
equals: doc.id,
|
|
52
|
-
},
|
|
53
|
-
},
|
|
54
|
-
depth: 0,
|
|
55
|
-
})];
|
|
56
|
-
case 1:
|
|
57
|
-
searchDocQuery = _d.sent();
|
|
58
|
-
if ((_a = searchDocQuery === null || searchDocQuery === void 0 ? void 0 : searchDocQuery.docs) === null || _a === void 0 ? void 0 : _a[0]) {
|
|
59
|
-
payload.delete({
|
|
60
|
-
collection: 'search',
|
|
61
|
-
id: (_c = (_b = searchDocQuery === null || searchDocQuery === void 0 ? void 0 : searchDocQuery.docs) === null || _b === void 0 ? void 0 : _b[0]) === null || _c === void 0 ? void 0 : _c.id,
|
|
62
|
-
});
|
|
63
|
-
}
|
|
64
|
-
return [2 /*return*/];
|
|
13
|
+
const searchDocQuery = await payload.find({
|
|
14
|
+
collection: 'search',
|
|
15
|
+
depth: 0,
|
|
16
|
+
req,
|
|
17
|
+
where: {
|
|
18
|
+
'doc.value': {
|
|
19
|
+
equals: doc.id
|
|
65
20
|
}
|
|
21
|
+
}
|
|
22
|
+
});
|
|
23
|
+
if (searchDocQuery?.docs?.[0]) {
|
|
24
|
+
await payload.delete({
|
|
25
|
+
id: searchDocQuery?.docs?.[0]?.id,
|
|
26
|
+
collection: 'search',
|
|
27
|
+
req
|
|
66
28
|
});
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
29
|
+
}
|
|
30
|
+
} catch (err) {
|
|
31
|
+
payload.logger.error({
|
|
32
|
+
err: `Error deleting search doc: ${err}`
|
|
33
|
+
});
|
|
72
34
|
}
|
|
73
35
|
return doc;
|
|
74
36
|
};
|
|
75
|
-
|
|
76
|
-
|
|
37
|
+
const _default = deleteFromSearch;
|
|
38
|
+
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9TZWFyY2gvaG9va3MvZGVsZXRlRnJvbVNlYXJjaC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IENvbGxlY3Rpb25BZnRlckRlbGV0ZUhvb2sgfSBmcm9tICdwYXlsb2FkL3R5cGVzJ1xuXG5jb25zdCBkZWxldGVGcm9tU2VhcmNoOiBDb2xsZWN0aW9uQWZ0ZXJEZWxldGVIb29rID0gYXN5bmMgKHsgZG9jLCByZXE6IHsgcGF5bG9hZCB9LCByZXEgfSkgPT4ge1xuICB0cnkge1xuICAgIGNvbnN0IHNlYXJjaERvY1F1ZXJ5ID0gYXdhaXQgcGF5bG9hZC5maW5kKHtcbiAgICAgIGNvbGxlY3Rpb246ICdzZWFyY2gnLFxuICAgICAgZGVwdGg6IDAsXG4gICAgICByZXEsXG4gICAgICB3aGVyZToge1xuICAgICAgICAnZG9jLnZhbHVlJzoge1xuICAgICAgICAgIGVxdWFsczogZG9jLmlkLFxuICAgICAgICB9LFxuICAgICAgfSxcbiAgICB9KVxuXG4gICAgaWYgKHNlYXJjaERvY1F1ZXJ5Py5kb2NzPy5bMF0pIHtcbiAgICAgIGF3YWl0IHBheWxvYWQuZGVsZXRlKHtcbiAgICAgICAgaWQ6IHNlYXJjaERvY1F1ZXJ5Py5kb2NzPy5bMF0/LmlkLFxuICAgICAgICBjb2xsZWN0aW9uOiAnc2VhcmNoJyxcbiAgICAgICAgcmVxLFxuICAgICAgfSlcbiAgICB9XG4gIH0gY2F0Y2ggKGVycjogdW5rbm93bikge1xuICAgIHBheWxvYWQubG9nZ2VyLmVycm9yKHtcbiAgICAgIGVycjogYEVycm9yIGRlbGV0aW5nIHNlYXJjaCBkb2M6ICR7ZXJyfWAsXG4gICAgfSlcbiAgfVxuXG4gIHJldHVybiBkb2Ncbn1cblxuZXhwb3J0IGRlZmF1bHQgZGVsZXRlRnJvbVNlYXJjaFxuIl0sIm5hbWVzIjpbImRlbGV0ZUZyb21TZWFyY2giLCJkb2MiLCJyZXEiLCJwYXlsb2FkIiwic2VhcmNoRG9jUXVlcnkiLCJmaW5kIiwiY29sbGVjdGlvbiIsImRlcHRoIiwid2hlcmUiLCJlcXVhbHMiLCJpZCIsImRvY3MiLCJkZWxldGUiLCJlcnIiLCJsb2dnZXIiLCJlcnJvciJdLCJtYXBwaW5ncyI6Ijs7OzsrQkErQkE7OztlQUFBOzs7QUE3QkEsTUFBTUEsbUJBQThDLE9BQU8sRUFBRUMsR0FBRyxFQUFFQyxLQUFLLEVBQUVDLE9BQU8sRUFBRSxFQUFFRCxHQUFHLEVBQUU7SUFDdkYsSUFBSTtRQUNGLE1BQU1FLGlCQUFpQixNQUFNRCxRQUFRRSxJQUFJLENBQUM7WUFDeENDLFlBQVk7WUFDWkMsT0FBTztZQUNQTDtZQUNBTSxPQUFPO2dCQUNMLGFBQWE7b0JBQ1hDLFFBQVFSLElBQUlTLEVBQUU7Z0JBQ2hCO1lBQ0Y7UUFDRjtRQUVBLElBQUlOLGdCQUFnQk8sTUFBTSxDQUFDLEVBQUUsRUFBRTtZQUM3QixNQUFNUixRQUFRUyxNQUFNLENBQUM7Z0JBQ25CRixJQUFJTixnQkFBZ0JPLE1BQU0sQ0FBQyxFQUFFLEVBQUVEO2dCQUMvQkosWUFBWTtnQkFDWko7WUFDRjtRQUNGO0lBQ0YsRUFBRSxPQUFPVyxLQUFjO1FBQ3JCVixRQUFRVyxNQUFNLENBQUNDLEtBQUssQ0FBQztZQUNuQkYsS0FBSyxDQUFDLDJCQUEyQixFQUFFQSxJQUFJLENBQUM7UUFDMUM7SUFDRjtJQUVBLE9BQU9aO0FBQ1Q7TUFFQSxXQUFlRCJ9
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"syncWithSearch.d.ts","sourceRoot":"","sources":["../../../src/Search/hooks/syncWithSearch.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAA2B,cAAc,EAAE,MAAM,aAAa,CAAA;AAE1E,QAAA,MAAM,cAAc,EAAE,cA8JrB,CAAA;AAED,eAAe,cAAc,CAAA"}
|
|
@@ -1,201 +1,148 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "default", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return _default;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
const syncWithSearch = async (args)=>{
|
|
12
|
+
const { collection, doc, operation, req: { payload }, req, // @ts-expect-error
|
|
13
|
+
searchConfig } = args;
|
|
14
|
+
const { id, _status: status, title } = doc || {};
|
|
15
|
+
const { beforeSync, defaultPriorities, deleteDrafts, syncDrafts } = searchConfig// todo fix SyncWithSearch type, see note in ./types.ts
|
|
16
|
+
;
|
|
17
|
+
let dataToSave = {
|
|
18
|
+
doc: {
|
|
19
|
+
relationTo: collection,
|
|
20
|
+
value: id
|
|
21
|
+
},
|
|
22
|
+
title
|
|
10
23
|
};
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
};
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
while (_) try {
|
|
29
|
-
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
30
|
-
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
31
|
-
switch (op[0]) {
|
|
32
|
-
case 0: case 1: t = op; break;
|
|
33
|
-
case 4: _.label++; return { value: op[1], done: false };
|
|
34
|
-
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
35
|
-
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
36
|
-
default:
|
|
37
|
-
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
38
|
-
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
39
|
-
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
40
|
-
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
41
|
-
if (t[2]) _.ops.pop();
|
|
42
|
-
_.trys.pop(); continue;
|
|
24
|
+
if (typeof beforeSync === 'function') {
|
|
25
|
+
dataToSave = await beforeSync({
|
|
26
|
+
originalDoc: doc,
|
|
27
|
+
payload,
|
|
28
|
+
req,
|
|
29
|
+
searchDoc: dataToSave
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
let defaultPriority = 0;
|
|
33
|
+
if (defaultPriorities) {
|
|
34
|
+
const { [collection]: priority } = defaultPriorities;
|
|
35
|
+
if (typeof priority === 'function') {
|
|
36
|
+
try {
|
|
37
|
+
defaultPriority = await priority(doc);
|
|
38
|
+
} catch (err) {
|
|
39
|
+
payload.logger.error(err);
|
|
40
|
+
payload.logger.error(`Error gathering default priority for search documents related to ${collection}`);
|
|
43
41
|
}
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
42
|
+
} else {
|
|
43
|
+
defaultPriority = priority;
|
|
44
|
+
}
|
|
47
45
|
}
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
switch (_e.label) {
|
|
58
|
-
case 0:
|
|
59
|
-
payload = args.req.payload, doc = args.doc, operation = args.operation, collection = args.collection, searchConfig = args.searchConfig;
|
|
60
|
-
_a = doc || {}, title = _a.title, id = _a.id, status = _a._status;
|
|
61
|
-
_b = searchConfig, beforeSync = _b.beforeSync, syncDrafts = _b.syncDrafts, deleteDrafts = _b.deleteDrafts, defaultPriorities = _b.defaultPriorities;
|
|
62
|
-
dataToSave = {
|
|
63
|
-
title: title,
|
|
64
|
-
doc: {
|
|
65
|
-
relationTo: collection,
|
|
66
|
-
value: id,
|
|
46
|
+
const doSync = syncDrafts || !syncDrafts && status !== 'draft';
|
|
47
|
+
try {
|
|
48
|
+
if (operation === 'create') {
|
|
49
|
+
if (doSync) {
|
|
50
|
+
await payload.create({
|
|
51
|
+
collection: 'search',
|
|
52
|
+
data: {
|
|
53
|
+
...dataToSave,
|
|
54
|
+
priority: defaultPriority
|
|
67
55
|
},
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
_e.label = 3;
|
|
84
|
-
case 3:
|
|
85
|
-
_e.trys.push([3, 5, , 6]);
|
|
86
|
-
return [4 /*yield*/, priority(doc)];
|
|
87
|
-
case 4:
|
|
88
|
-
defaultPriority = _e.sent();
|
|
89
|
-
return [3 /*break*/, 6];
|
|
90
|
-
case 5:
|
|
91
|
-
err_1 = _e.sent();
|
|
92
|
-
payload.logger.error(err_1);
|
|
93
|
-
payload.logger.error("Error gathering default priority for search documents related to ".concat(collection));
|
|
94
|
-
return [3 /*break*/, 6];
|
|
95
|
-
case 6: return [3 /*break*/, 8];
|
|
96
|
-
case 7:
|
|
97
|
-
defaultPriority = priority;
|
|
98
|
-
_e.label = 8;
|
|
99
|
-
case 8:
|
|
100
|
-
doSync = syncDrafts || (!syncDrafts && status !== 'draft');
|
|
101
|
-
_e.label = 9;
|
|
102
|
-
case 9:
|
|
103
|
-
_e.trys.push([9, 14, , 15]);
|
|
104
|
-
if (operation === 'create') {
|
|
105
|
-
if (doSync) {
|
|
106
|
-
payload.create({
|
|
107
|
-
collection: 'search',
|
|
108
|
-
data: __assign(__assign({}, dataToSave), { priority: defaultPriority }),
|
|
109
|
-
});
|
|
56
|
+
req
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
if (operation === 'update') {
|
|
61
|
+
try {
|
|
62
|
+
// find the correct doc to sync with
|
|
63
|
+
const searchDocQuery = await payload.find({
|
|
64
|
+
collection: 'search',
|
|
65
|
+
depth: 0,
|
|
66
|
+
req,
|
|
67
|
+
where: {
|
|
68
|
+
'doc.value': {
|
|
69
|
+
equals: id
|
|
70
|
+
}
|
|
110
71
|
}
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
case 10:
|
|
115
|
-
_e.trys.push([10, 12, , 13]);
|
|
116
|
-
return [4 /*yield*/, payload.find({
|
|
117
|
-
collection: 'search',
|
|
118
|
-
where: {
|
|
119
|
-
'doc.value': {
|
|
120
|
-
equals: id,
|
|
121
|
-
},
|
|
122
|
-
},
|
|
123
|
-
depth: 0,
|
|
124
|
-
})];
|
|
125
|
-
case 11:
|
|
126
|
-
searchDocQuery = _e.sent();
|
|
127
|
-
docs = (searchDocQuery === null || searchDocQuery === void 0 ? void 0 : searchDocQuery.docs) || [];
|
|
128
|
-
foundDoc = docs[0], duplicativeDocs = docs.slice(1);
|
|
72
|
+
});
|
|
73
|
+
const docs = searchDocQuery?.docs || [];
|
|
74
|
+
const [foundDoc, ...duplicativeDocs] = docs;
|
|
129
75
|
// delete all duplicative search docs (docs that reference the same page)
|
|
130
76
|
// to ensure the same, out-of-date result does not appear twice (where only syncing the first found doc)
|
|
131
77
|
if (duplicativeDocs.length > 0) {
|
|
132
78
|
try {
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
79
|
+
const duplicativeDocIDs = duplicativeDocs.map(({ id })=>id);
|
|
80
|
+
await payload.delete({
|
|
81
|
+
collection: 'search',
|
|
82
|
+
req,
|
|
83
|
+
where: {
|
|
84
|
+
id: {
|
|
85
|
+
in: duplicativeDocIDs
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
});
|
|
89
|
+
} catch (err) {
|
|
90
|
+
payload.logger.error(`Error deleting duplicative search documents.`);
|
|
143
91
|
}
|
|
144
92
|
}
|
|
145
93
|
if (foundDoc) {
|
|
146
|
-
searchDocID = foundDoc
|
|
94
|
+
const { id: searchDocID } = foundDoc;
|
|
147
95
|
if (doSync) {
|
|
148
96
|
// update the doc normally
|
|
149
97
|
try {
|
|
150
|
-
payload.update({
|
|
151
|
-
collection: 'search',
|
|
98
|
+
await payload.update({
|
|
152
99
|
id: searchDocID,
|
|
153
|
-
|
|
100
|
+
collection: 'search',
|
|
101
|
+
data: {
|
|
102
|
+
...dataToSave,
|
|
103
|
+
priority: foundDoc.priority || defaultPriority
|
|
104
|
+
},
|
|
105
|
+
req
|
|
154
106
|
});
|
|
155
|
-
}
|
|
156
|
-
|
|
157
|
-
payload.logger.error("Error updating search document.");
|
|
107
|
+
} catch (err) {
|
|
108
|
+
payload.logger.error(`Error updating search document.`);
|
|
158
109
|
}
|
|
159
110
|
}
|
|
160
111
|
if (deleteDrafts && status === 'draft') {
|
|
161
112
|
// do not include draft docs in search results, so delete the record
|
|
162
113
|
try {
|
|
163
|
-
payload.delete({
|
|
164
|
-
collection: 'search',
|
|
114
|
+
await payload.delete({
|
|
165
115
|
id: searchDocID,
|
|
116
|
+
collection: 'search',
|
|
117
|
+
req
|
|
166
118
|
});
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
payload.logger.error("Error deleting search document.");
|
|
119
|
+
} catch (err) {
|
|
120
|
+
payload.logger.error(`Error deleting search document: ${err}`);
|
|
170
121
|
}
|
|
171
122
|
}
|
|
172
|
-
}
|
|
173
|
-
else if (doSync) {
|
|
123
|
+
} else if (doSync) {
|
|
174
124
|
try {
|
|
175
|
-
payload.create({
|
|
125
|
+
await payload.create({
|
|
176
126
|
collection: 'search',
|
|
177
|
-
data:
|
|
127
|
+
data: {
|
|
128
|
+
...dataToSave,
|
|
129
|
+
priority: defaultPriority
|
|
130
|
+
},
|
|
131
|
+
req
|
|
178
132
|
});
|
|
179
|
-
}
|
|
180
|
-
|
|
181
|
-
payload.logger.error(err);
|
|
182
|
-
payload.logger.error("Error creating search document.");
|
|
133
|
+
} catch (err) {
|
|
134
|
+
payload.logger.error(`Error creating search document: ${err}`);
|
|
183
135
|
}
|
|
184
136
|
}
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
payload.logger.error("Error finding search document.");
|
|
189
|
-
return [3 /*break*/, 13];
|
|
190
|
-
case 13: return [3 /*break*/, 15];
|
|
191
|
-
case 14:
|
|
192
|
-
err_3 = _e.sent();
|
|
193
|
-
payload.logger.error(err_3);
|
|
194
|
-
payload.logger.error("Error syncing search document related to ".concat(collection, " with id: '").concat(id, "'"));
|
|
195
|
-
return [3 /*break*/, 15];
|
|
196
|
-
case 15: return [2 /*return*/, doc];
|
|
137
|
+
} catch (err) {
|
|
138
|
+
payload.logger.error(`Error finding search document: ${err}`);
|
|
139
|
+
}
|
|
197
140
|
}
|
|
198
|
-
})
|
|
199
|
-
}
|
|
200
|
-
|
|
201
|
-
|
|
141
|
+
} catch (err) {
|
|
142
|
+
payload.logger.error(`Error syncing search document related to ${collection} with id: '${id}': ${err}`);
|
|
143
|
+
}
|
|
144
|
+
return doc;
|
|
145
|
+
};
|
|
146
|
+
const _default = syncWithSearch;
|
|
147
|
+
|
|
148
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/Search/hooks/syncWithSearch.ts"],"sourcesContent":["import type { DocToSync, SearchConfig, SyncWithSearch } from '../../types'\n\nconst syncWithSearch: SyncWithSearch = async (args) => {\n  const {\n    collection,\n    doc,\n    operation,\n    req: { payload },\n    req,\n    // @ts-expect-error\n    searchConfig,\n  } = args\n\n  const { id, _status: status, title } = doc || {}\n\n  const { beforeSync, defaultPriorities, deleteDrafts, syncDrafts } = searchConfig as SearchConfig // todo fix SyncWithSearch type, see note in ./types.ts\n\n  let dataToSave: DocToSync = {\n    doc: {\n      relationTo: collection,\n      value: id,\n    },\n    title,\n  }\n\n  if (typeof beforeSync === 'function') {\n    dataToSave = await beforeSync({\n      originalDoc: doc,\n      payload,\n      req,\n      searchDoc: dataToSave,\n    })\n  }\n\n  let defaultPriority = 0\n  if (defaultPriorities) {\n    const { [collection]: priority } = defaultPriorities\n\n    if (typeof priority === 'function') {\n      try {\n        defaultPriority = await priority(doc)\n      } catch (err: unknown) {\n        payload.logger.error(err)\n        payload.logger.error(\n          `Error gathering default priority for search documents related to ${collection}`,\n        )\n      }\n    } else {\n      defaultPriority = priority\n    }\n  }\n\n  const doSync = syncDrafts || (!syncDrafts && status !== 'draft')\n\n  try {\n    if (operation === 'create') {\n      if (doSync) {\n        await payload.create({\n          collection: 'search',\n          data: {\n            ...dataToSave,\n            priority: defaultPriority,\n          },\n          req,\n        })\n      }\n    }\n\n    if (operation === 'update') {\n      try {\n        // find the correct doc to sync with\n        const searchDocQuery = await payload.find({\n          collection: 'search',\n          depth: 0,\n          req,\n          where: {\n            'doc.value': {\n              equals: id,\n            },\n          },\n        })\n\n        const docs: Array<{\n          id: number | string\n          priority?: number\n        }> = searchDocQuery?.docs || []\n\n        const [foundDoc, ...duplicativeDocs] = docs\n\n        // delete all duplicative search docs (docs that reference the same page)\n        // to ensure the same, out-of-date result does not appear twice (where only syncing the first found doc)\n        if (duplicativeDocs.length > 0) {\n          try {\n            const duplicativeDocIDs = duplicativeDocs.map(({ id }) => id)\n            await payload.delete({\n              collection: 'search',\n              req,\n              where: { id: { in: duplicativeDocIDs } },\n            })\n          } catch (err: unknown) {\n            payload.logger.error(`Error deleting duplicative search documents.`)\n          }\n        }\n\n        if (foundDoc) {\n          const { id: searchDocID } = foundDoc\n\n          if (doSync) {\n            // update the doc normally\n            try {\n              await payload.update({\n                id: searchDocID,\n                collection: 'search',\n                data: {\n                  ...dataToSave,\n                  priority: foundDoc.priority || defaultPriority,\n                },\n                req,\n              })\n            } catch (err: unknown) {\n              payload.logger.error(`Error updating search document.`)\n            }\n          }\n          if (deleteDrafts && status === 'draft') {\n            // do not include draft docs in search results, so delete the record\n            try {\n              await payload.delete({\n                id: searchDocID,\n                collection: 'search',\n                req,\n              })\n            } catch (err: unknown) {\n              payload.logger.error(`Error deleting search document: ${err}`)\n            }\n          }\n        } else if (doSync) {\n          try {\n            await payload.create({\n              collection: 'search',\n              data: {\n                ...dataToSave,\n                priority: defaultPriority,\n              },\n              req,\n            })\n          } catch (err: unknown) {\n            payload.logger.error(`Error creating search document: ${err}`)\n          }\n        }\n      } catch (err: unknown) {\n        payload.logger.error(`Error finding search document: ${err}`)\n      }\n    }\n  } catch (err: unknown) {\n    payload.logger.error(\n      `Error syncing search document related to ${collection} with id: '${id}': ${err}`,\n    )\n  }\n\n  return doc\n}\n\nexport default syncWithSearch\n"],"names":["syncWithSearch","args","collection","doc","operation","req","payload","searchConfig","id","_status","status","title","beforeSync","defaultPriorities","deleteDrafts","syncDrafts","dataToSave","relationTo","value","originalDoc","searchDoc","defaultPriority","priority","err","logger","error","doSync","create","data","searchDocQuery","find","depth","where","equals","docs","foundDoc","duplicativeDocs","length","duplicativeDocIDs","map","delete","in","searchDocID","update"],"mappings":"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"}
|
package/dist/Search/index.d.ts
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
-
import { CollectionConfig } from 'payload/types';
|
|
2
|
-
import { SearchConfig } from '../types';
|
|
1
|
+
import type { CollectionConfig } from 'payload/types';
|
|
2
|
+
import type { SearchConfig } from '../types';
|
|
3
3
|
export declare const generateSearchCollection: (searchConfig: SearchConfig) => CollectionConfig;
|
|
4
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/Search/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAA;AAIrD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AAK5C,eAAO,MAAM,wBAAwB,iBAAkB,YAAY,KAAG,gBA2DnE,CAAA"}
|