@payloadcms/db-postgres 0.7.1 → 0.8.1
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/count.d.ts +3 -0
- package/dist/count.d.ts.map +1 -0
- package/dist/count.js +68 -0
- package/dist/create.d.ts.map +1 -1
- package/dist/create.js +7 -9
- package/dist/createGlobal.d.ts +1 -1
- package/dist/createGlobal.d.ts.map +1 -1
- package/dist/createGlobal.js +8 -10
- package/dist/createGlobalVersion.d.ts +1 -1
- package/dist/createGlobalVersion.d.ts.map +1 -1
- package/dist/createGlobalVersion.js +12 -14
- package/dist/createVersion.d.ts.map +1 -1
- package/dist/createVersion.js +22 -19
- package/dist/deleteMany.js +6 -8
- package/dist/deleteOne.d.ts.map +1 -1
- package/dist/deleteOne.js +6 -3
- package/dist/deleteVersions.d.ts.map +1 -1
- package/dist/deleteVersions.js +7 -8
- package/dist/find/buildFindManyArgs.js +3 -3
- package/dist/find/findMany.js +2 -2
- package/dist/find/traverseFields.d.ts.map +1 -1
- package/dist/find/traverseFields.js +23 -11
- package/dist/find.d.ts.map +1 -1
- package/dist/find.js +10 -11
- package/dist/findGlobal.d.ts.map +1 -1
- package/dist/findGlobal.js +7 -9
- package/dist/findGlobalVersions.d.ts.map +1 -1
- package/dist/findGlobalVersions.js +7 -8
- package/dist/findOne.d.ts +1 -1
- package/dist/findOne.d.ts.map +1 -1
- package/dist/findOne.js +9 -10
- package/dist/findVersions.d.ts.map +1 -1
- package/dist/findVersions.js +7 -8
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +7 -1
- package/dist/init.d.ts.map +1 -1
- package/dist/init.js +28 -15
- package/dist/queries/getTableColumnFromPath.d.ts.map +1 -1
- package/dist/queries/getTableColumnFromPath.js +148 -42
- package/dist/queries/sanitizeQueryValue.d.ts.map +1 -1
- package/dist/queries/sanitizeQueryValue.js +5 -2
- package/dist/queryDrafts.d.ts.map +1 -1
- package/dist/queryDrafts.js +7 -8
- package/dist/schema/build.d.ts +2 -1
- package/dist/schema/build.d.ts.map +1 -1
- package/dist/schema/build.js +19 -14
- package/dist/schema/getTableName.d.ts +32 -0
- package/dist/schema/getTableName.d.ts.map +1 -0
- package/dist/schema/getTableName.js +43 -0
- package/dist/schema/traverseFields.d.ts +2 -1
- package/dist/schema/traverseFields.d.ts.map +1 -1
- package/dist/schema/traverseFields.js +54 -18
- package/dist/schema/validateExistingBlockIsIdentical.d.ts +2 -1
- package/dist/schema/validateExistingBlockIsIdentical.d.ts.map +1 -1
- package/dist/schema/validateExistingBlockIsIdentical.js +14 -8
- package/dist/transform/write/blocks.d.ts +2 -2
- package/dist/transform/write/blocks.d.ts.map +1 -1
- package/dist/transform/write/blocks.js +4 -4
- package/dist/transform/write/traverseFields.d.ts +2 -2
- package/dist/transform/write/traverseFields.d.ts.map +1 -1
- package/dist/transform/write/traverseFields.js +34 -25
- package/dist/types.d.ts +13 -0
- package/dist/types.d.ts.map +1 -1
- package/dist/update.d.ts.map +1 -1
- package/dist/update.js +7 -4
- package/dist/updateGlobal.d.ts +1 -1
- package/dist/updateGlobal.d.ts.map +1 -1
- package/dist/updateGlobal.js +9 -11
- package/dist/updateGlobalVersion.d.ts.map +1 -1
- package/dist/updateGlobalVersion.js +9 -5
- package/dist/updateVersion.d.ts.map +1 -1
- package/dist/updateVersion.js +9 -5
- package/dist/upsertRow/index.d.ts.map +1 -1
- package/dist/upsertRow/index.js +7 -6
- package/dist/upsertRow/insertArrays.d.ts.map +1 -1
- package/dist/upsertRow/insertArrays.js +3 -3
- package/dist/upsertRow/types.d.ts +1 -1
- package/dist/upsertRow/types.d.ts.map +1 -1
- package/package.json +3 -3
package/dist/init.js
CHANGED
@@ -10,13 +10,8 @@ Object.defineProperty(exports, "init", {
|
|
10
10
|
});
|
11
11
|
const _pgcore = require("drizzle-orm/pg-core");
|
12
12
|
const _versions = require("payload/versions");
|
13
|
-
const _tosnakecase = /*#__PURE__*/ _interop_require_default(require("to-snake-case"));
|
14
13
|
const _build = require("./schema/build");
|
15
|
-
|
16
|
-
return obj && obj.__esModule ? obj : {
|
17
|
-
default: obj
|
18
|
-
};
|
19
|
-
}
|
14
|
+
const _getTableName = require("./schema/getTableName");
|
20
15
|
const init = async function init() {
|
21
16
|
if (this.schemaName) {
|
22
17
|
this.pgSchema = (0, _pgcore.pgSchema)(this.schemaName);
|
@@ -29,7 +24,10 @@ const init = async function init() {
|
|
29
24
|
this.enums.enum__locales = (0, _pgcore.pgEnum)('_locales', this.payload.config.localization.locales.map(({ code })=>code));
|
30
25
|
}
|
31
26
|
this.payload.config.collections.forEach((collection)=>{
|
32
|
-
const tableName = (0,
|
27
|
+
const tableName = (0, _getTableName.getTableName)({
|
28
|
+
adapter: this,
|
29
|
+
config: collection
|
30
|
+
});
|
33
31
|
(0, _build.buildTable)({
|
34
32
|
adapter: this,
|
35
33
|
buildNumbers: true,
|
@@ -39,10 +37,15 @@ const init = async function init() {
|
|
39
37
|
disableUnique: false,
|
40
38
|
fields: collection.fields,
|
41
39
|
tableName,
|
42
|
-
timestamps: collection.timestamps
|
40
|
+
timestamps: collection.timestamps,
|
41
|
+
versions: false
|
43
42
|
});
|
44
43
|
if (collection.versions) {
|
45
|
-
const versionsTableName =
|
44
|
+
const versionsTableName = (0, _getTableName.getTableName)({
|
45
|
+
adapter: this,
|
46
|
+
config: collection,
|
47
|
+
versions: true
|
48
|
+
});
|
46
49
|
const versionFields = (0, _versions.buildVersionCollectionFields)(collection);
|
47
50
|
(0, _build.buildTable)({
|
48
51
|
adapter: this,
|
@@ -53,12 +56,16 @@ const init = async function init() {
|
|
53
56
|
disableUnique: true,
|
54
57
|
fields: versionFields,
|
55
58
|
tableName: versionsTableName,
|
56
|
-
timestamps: true
|
59
|
+
timestamps: true,
|
60
|
+
versions: true
|
57
61
|
});
|
58
62
|
}
|
59
63
|
});
|
60
64
|
this.payload.config.globals.forEach((global)=>{
|
61
|
-
const tableName = (0,
|
65
|
+
const tableName = (0, _getTableName.getTableName)({
|
66
|
+
adapter: this,
|
67
|
+
config: global
|
68
|
+
});
|
62
69
|
(0, _build.buildTable)({
|
63
70
|
adapter: this,
|
64
71
|
buildNumbers: true,
|
@@ -68,10 +75,15 @@ const init = async function init() {
|
|
68
75
|
disableUnique: false,
|
69
76
|
fields: global.fields,
|
70
77
|
tableName,
|
71
|
-
timestamps: false
|
78
|
+
timestamps: false,
|
79
|
+
versions: false
|
72
80
|
});
|
73
81
|
if (global.versions) {
|
74
|
-
const versionsTableName =
|
82
|
+
const versionsTableName = (0, _getTableName.getTableName)({
|
83
|
+
adapter: this,
|
84
|
+
config: global,
|
85
|
+
versions: true
|
86
|
+
});
|
75
87
|
const versionFields = (0, _versions.buildVersionGlobalFields)(global);
|
76
88
|
(0, _build.buildTable)({
|
77
89
|
adapter: this,
|
@@ -82,10 +94,11 @@ const init = async function init() {
|
|
82
94
|
disableUnique: true,
|
83
95
|
fields: versionFields,
|
84
96
|
tableName: versionsTableName,
|
85
|
-
timestamps: true
|
97
|
+
timestamps: true,
|
98
|
+
versions: true
|
86
99
|
});
|
87
100
|
}
|
88
101
|
});
|
89
102
|
};
|
90
103
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,
|
104
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbml0LnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIG5vLXBhcmFtLXJlYXNzaWduICovXG5pbXBvcnQgdHlwZSB7IEluaXQgfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuaW1wb3J0IHR5cGUgeyBTYW5pdGl6ZWRDb2xsZWN0aW9uQ29uZmlnIH0gZnJvbSAncGF5bG9hZC90eXBlcydcblxuaW1wb3J0IHsgcGdFbnVtLCBwZ1NjaGVtYSwgcGdUYWJsZSB9IGZyb20gJ2RyaXp6bGUtb3JtL3BnLWNvcmUnXG5pbXBvcnQgeyBidWlsZFZlcnNpb25Db2xsZWN0aW9uRmllbGRzLCBidWlsZFZlcnNpb25HbG9iYWxGaWVsZHMgfSBmcm9tICdwYXlsb2FkL3ZlcnNpb25zJ1xuXG5pbXBvcnQgdHlwZSB7IFBvc3RncmVzQWRhcHRlciB9IGZyb20gJy4vdHlwZXMnXG5cbmltcG9ydCB7IGJ1aWxkVGFibGUgfSBmcm9tICcuL3NjaGVtYS9idWlsZCdcbmltcG9ydCB7IGdldFRhYmxlTmFtZSB9IGZyb20gJy4vc2NoZW1hL2dldFRhYmxlTmFtZSdcblxuZXhwb3J0IGNvbnN0IGluaXQ6IEluaXQgPSBhc3luYyBmdW5jdGlvbiBpbml0KHRoaXM6IFBvc3RncmVzQWRhcHRlcikge1xuICBpZiAodGhpcy5zY2hlbWFOYW1lKSB7XG4gICAgdGhpcy5wZ1NjaGVtYSA9IHBnU2NoZW1hKHRoaXMuc2NoZW1hTmFtZSlcbiAgfSBlbHNlIHtcbiAgICB0aGlzLnBnU2NoZW1hID0geyB0YWJsZTogcGdUYWJsZSB9XG4gIH1cblxuICBpZiAodGhpcy5wYXlsb2FkLmNvbmZpZy5sb2NhbGl6YXRpb24pIHtcbiAgICB0aGlzLmVudW1zLmVudW1fX2xvY2FsZXMgPSBwZ0VudW0oXG4gICAgICAnX2xvY2FsZXMnLFxuICAgICAgdGhpcy5wYXlsb2FkLmNvbmZpZy5sb2NhbGl6YXRpb24ubG9jYWxlcy5tYXAoKHsgY29kZSB9KSA9PiBjb2RlKSBhcyBbc3RyaW5nLCAuLi5zdHJpbmdbXV0sXG4gICAgKVxuICB9XG5cbiAgdGhpcy5wYXlsb2FkLmNvbmZpZy5jb2xsZWN0aW9ucy5mb3JFYWNoKChjb2xsZWN0aW9uOiBTYW5pdGl6ZWRDb2xsZWN0aW9uQ29uZmlnKSA9PiB7XG4gICAgY29uc3QgdGFibGVOYW1lID0gZ2V0VGFibGVOYW1lKHtcbiAgICAgIGFkYXB0ZXI6IHRoaXMsXG4gICAgICBjb25maWc6IGNvbGxlY3Rpb24sXG4gICAgfSlcblxuICAgIGJ1aWxkVGFibGUoe1xuICAgICAgYWRhcHRlcjogdGhpcyxcbiAgICAgIGJ1aWxkTnVtYmVyczogdHJ1ZSxcbiAgICAgIGJ1aWxkUmVsYXRpb25zaGlwczogdHJ1ZSxcbiAgICAgIGJ1aWxkVGV4dHM6IHRydWUsXG4gICAgICBkaXNhYmxlTm90TnVsbDogISFjb2xsZWN0aW9uPy52ZXJzaW9ucz8uZHJhZnRzLFxuICAgICAgZGlzYWJsZVVuaXF1ZTogZmFsc2UsXG4gICAgICBmaWVsZHM6IGNvbGxlY3Rpb24uZmllbGRzLFxuICAgICAgdGFibGVOYW1lLFxuICAgICAgdGltZXN0YW1wczogY29sbGVjdGlvbi50aW1lc3RhbXBzLFxuICAgICAgdmVyc2lvbnM6IGZhbHNlLFxuICAgIH0pXG5cbiAgICBpZiAoY29sbGVjdGlvbi52ZXJzaW9ucykge1xuICAgICAgY29uc3QgdmVyc2lvbnNUYWJsZU5hbWUgPSBnZXRUYWJsZU5hbWUoe1xuICAgICAgICBhZGFwdGVyOiB0aGlzLFxuICAgICAgICBjb25maWc6IGNvbGxlY3Rpb24sXG4gICAgICAgIHZlcnNpb25zOiB0cnVlLFxuICAgICAgfSlcbiAgICAgIGNvbnN0IHZlcnNpb25GaWVsZHMgPSBidWlsZFZlcnNpb25Db2xsZWN0aW9uRmllbGRzKGNvbGxlY3Rpb24pXG5cbiAgICAgIGJ1aWxkVGFibGUoe1xuICAgICAgICBhZGFwdGVyOiB0aGlzLFxuICAgICAgICBidWlsZE51bWJlcnM6IHRydWUsXG4gICAgICAgIGJ1aWxkUmVsYXRpb25zaGlwczogdHJ1ZSxcbiAgICAgICAgYnVpbGRUZXh0czogdHJ1ZSxcbiAgICAgICAgZGlzYWJsZU5vdE51bGw6ICEhY29sbGVjdGlvbi52ZXJzaW9ucz8uZHJhZnRzLFxuICAgICAgICBkaXNhYmxlVW5pcXVlOiB0cnVlLFxuICAgICAgICBmaWVsZHM6IHZlcnNpb25GaWVsZHMsXG4gICAgICAgIHRhYmxlTmFtZTogdmVyc2lvbnNUYWJsZU5hbWUsXG4gICAgICAgIHRpbWVzdGFtcHM6IHRydWUsXG4gICAgICAgIHZlcnNpb25zOiB0cnVlLFxuICAgICAgfSlcbiAgICB9XG4gIH0pXG5cbiAgdGhpcy5wYXlsb2FkLmNvbmZpZy5nbG9iYWxzLmZvckVhY2goKGdsb2JhbCkgPT4ge1xuICAgIGNvbnN0IHRhYmxlTmFtZSA9IGdldFRhYmxlTmFtZSh7IGFkYXB0ZXI6IHRoaXMsIGNvbmZpZzogZ2xvYmFsIH0pXG5cbiAgICBidWlsZFRhYmxlKHtcbiAgICAgIGFkYXB0ZXI6IHRoaXMsXG4gICAgICBidWlsZE51bWJlcnM6IHRydWUsXG4gICAgICBidWlsZFJlbGF0aW9uc2hpcHM6IHRydWUsXG4gICAgICBidWlsZFRleHRzOiB0cnVlLFxuICAgICAgZGlzYWJsZU5vdE51bGw6ICEhZ2xvYmFsPy52ZXJzaW9ucz8uZHJhZnRzLFxuICAgICAgZGlzYWJsZVVuaXF1ZTogZmFsc2UsXG4gICAgICBmaWVsZHM6IGdsb2JhbC5maWVsZHMsXG4gICAgICB0YWJsZU5hbWUsXG4gICAgICB0aW1lc3RhbXBzOiBmYWxzZSxcbiAgICAgIHZlcnNpb25zOiBmYWxzZSxcbiAgICB9KVxuXG4gICAgaWYgKGdsb2JhbC52ZXJzaW9ucykge1xuICAgICAgY29uc3QgdmVyc2lvbnNUYWJsZU5hbWUgPSBnZXRUYWJsZU5hbWUoeyBhZGFwdGVyOiB0aGlzLCBjb25maWc6IGdsb2JhbCwgdmVyc2lvbnM6IHRydWUgfSlcbiAgICAgIGNvbnN0IHZlcnNpb25GaWVsZHMgPSBidWlsZFZlcnNpb25HbG9iYWxGaWVsZHMoZ2xvYmFsKVxuXG4gICAgICBidWlsZFRhYmxlKHtcbiAgICAgICAgYWRhcHRlcjogdGhpcyxcbiAgICAgICAgYnVpbGROdW1iZXJzOiB0cnVlLFxuICAgICAgICBidWlsZFJlbGF0aW9uc2hpcHM6IHRydWUsXG4gICAgICAgIGJ1aWxkVGV4dHM6IHRydWUsXG4gICAgICAgIGRpc2FibGVOb3ROdWxsOiAhIWdsb2JhbC52ZXJzaW9ucz8uZHJhZnRzLFxuICAgICAgICBkaXNhYmxlVW5pcXVlOiB0cnVlLFxuICAgICAgICBmaWVsZHM6IHZlcnNpb25GaWVsZHMsXG4gICAgICAgIHRhYmxlTmFtZTogdmVyc2lvbnNUYWJsZU5hbWUsXG4gICAgICAgIHRpbWVzdGFtcHM6IHRydWUsXG4gICAgICAgIHZlcnNpb25zOiB0cnVlLFxuICAgICAgfSlcbiAgICB9XG4gIH0pXG59XG4iXSwibmFtZXMiOlsiaW5pdCIsInNjaGVtYU5hbWUiLCJwZ1NjaGVtYSIsInRhYmxlIiwicGdUYWJsZSIsInBheWxvYWQiLCJjb25maWciLCJsb2NhbGl6YXRpb24iLCJlbnVtcyIsImVudW1fX2xvY2FsZXMiLCJwZ0VudW0iLCJsb2NhbGVzIiwibWFwIiwiY29kZSIsImNvbGxlY3Rpb25zIiwiZm9yRWFjaCIsImNvbGxlY3Rpb24iLCJ0YWJsZU5hbWUiLCJnZXRUYWJsZU5hbWUiLCJhZGFwdGVyIiwiYnVpbGRUYWJsZSIsImJ1aWxkTnVtYmVycyIsImJ1aWxkUmVsYXRpb25zaGlwcyIsImJ1aWxkVGV4dHMiLCJkaXNhYmxlTm90TnVsbCIsInZlcnNpb25zIiwiZHJhZnRzIiwiZGlzYWJsZVVuaXF1ZSIsImZpZWxkcyIsInRpbWVzdGFtcHMiLCJ2ZXJzaW9uc1RhYmxlTmFtZSIsInZlcnNpb25GaWVsZHMiLCJidWlsZFZlcnNpb25Db2xsZWN0aW9uRmllbGRzIiwiZ2xvYmFscyIsImdsb2JhbCIsImJ1aWxkVmVyc2lvbkdsb2JhbEZpZWxkcyJdLCJtYXBwaW5ncyI6IkFBQUEsb0NBQW9DOzs7OytCQVl2QkE7OztlQUFBQTs7O3dCQVI2QjswQkFDNkI7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
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"getTableColumnFromPath.d.ts","sourceRoot":"","sources":["../../src/queries/getTableColumnFromPath.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,aAAa,CAAA;AACtC,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAA;AAC7D,OAAO,KAAK,EAAE,KAAK,EAAE,kBAAkB,EAAe,UAAU,EAAa,MAAM,eAAe,CAAA;AAUlG,OAAO,KAAK,EAAE,aAAa,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAC5E,OAAO,KAAK,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,cAAc,CAAA;
|
1
|
+
{"version":3,"file":"getTableColumnFromPath.d.ts","sourceRoot":"","sources":["../../src/queries/getTableColumnFromPath.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,aAAa,CAAA;AACtC,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAA;AAC7D,OAAO,KAAK,EAAE,KAAK,EAAE,kBAAkB,EAAe,UAAU,EAAa,MAAM,eAAe,CAAA;AAUlG,OAAO,KAAK,EAAE,aAAa,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAC5E,OAAO,KAAK,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,cAAc,CAAA;AAI1E,KAAK,UAAU,GAAG;IAChB,UAAU,EAAE,MAAM,CAAA;IAClB,KAAK,EAAE,YAAY,GAAG,kBAAkB,CAAC,GAAG,CAAC,CAAA;IAC7C,KAAK,EAAE,OAAO,CAAA;CACf,CAAA;AAED,KAAK,WAAW,GAAG;IACjB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,WAAW,EAAE,UAAU,EAAE,CAAA;IACzB,KAAK,EAAE,kBAAkB,CAAA;IACzB,uBAAuB,CAAC,EAAE,CAAC,GAAG,EAAE,OAAO,KAAK,MAAM,CAAA;IAClD,YAAY,CAAC,EAAE,MAAM,EAAE,CAAA;IACvB,SAAS,CAAC,EAAE,GAAG,CAAA;IACf,KAAK,EAAE,YAAY,GAAG,kBAAkB,CAAC,GAAG,CAAC,CAAA;CAC9C,CAAA;AAED,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,UAAU,CAAC,EAAE,YAAY,GAAG,kBAAkB,CAAC,GAAG,CAAC,CAAA;IACnD,cAAc,EAAE,MAAM,CAAA;IACtB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,WAAW,CAAC,EAAE,UAAU,EAAE,CAAA;IAC1B,MAAM,EAAE,CAAC,KAAK,GAAG,UAAU,CAAC,EAAE,CAAA;IAC9B,WAAW,EAAE,qBAAqB,CAAA;IAClC,KAAK,EAAE,eAAe,CAAA;IACtB,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,YAAY,EAAE,MAAM,EAAE,CAAA;IACtB,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,aAAa,CAAC,CAAA;IAC3C,SAAS,EAAE,MAAM,CAAA;IACjB;;OAEG;IACH,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB;;OAEG;IACH,KAAK,EAAE,OAAO,CAAA;CACf,CAAA;AACD;;;;GAIG;AACH,eAAO,MAAM,sBAAsB,2RAiBhC,IAAI,KAAG,WA4gBT,CAAA"}
|
@@ -15,6 +15,7 @@ const _types = require("payload/types");
|
|
15
15
|
const _utilities = require("payload/utilities");
|
16
16
|
const _tosnakecase = /*#__PURE__*/ _interop_require_default(require("to-snake-case"));
|
17
17
|
const _uuid = require("uuid");
|
18
|
+
const _getTableName = require("../schema/getTableName");
|
18
19
|
function _interop_require_default(obj) {
|
19
20
|
return obj && obj.__esModule ? obj : {
|
20
21
|
default: obj
|
@@ -121,7 +122,13 @@ const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPre
|
|
121
122
|
case 'group':
|
122
123
|
{
|
123
124
|
if (locale && field.localized && adapter.payload.config.localization) {
|
124
|
-
newTableName =
|
125
|
+
newTableName = (0, _getTableName.getTableName)({
|
126
|
+
adapter,
|
127
|
+
config: field,
|
128
|
+
locales: true,
|
129
|
+
parentTableName: tableName,
|
130
|
+
prefix: `${tableName}_`
|
131
|
+
});
|
125
132
|
joins[tableName] = (0, _drizzleorm.eq)(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID);
|
126
133
|
if (locale !== 'all') {
|
127
134
|
constraints.push({
|
@@ -150,9 +157,80 @@ const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPre
|
|
150
157
|
value
|
151
158
|
});
|
152
159
|
}
|
160
|
+
case 'select':
|
161
|
+
{
|
162
|
+
if (field.hasMany) {
|
163
|
+
newTableName = (0, _getTableName.getTableName)({
|
164
|
+
adapter,
|
165
|
+
config: field,
|
166
|
+
parentTableName: `${tableName}_${tableNameSuffix}`,
|
167
|
+
prefix: `${tableName}_${tableNameSuffix}`
|
168
|
+
});
|
169
|
+
if (locale && field.localized && adapter.payload.config.localization) {
|
170
|
+
joins[newTableName] = (0, _drizzleorm.and)((0, _drizzleorm.eq)(adapter.tables[tableName].id, adapter.tables[newTableName].parent), (0, _drizzleorm.eq)(adapter.tables[newTableName]._locale, locale));
|
171
|
+
if (locale !== 'all') {
|
172
|
+
constraints.push({
|
173
|
+
columnName: '_locale',
|
174
|
+
table: adapter.tables[newTableName],
|
175
|
+
value: locale
|
176
|
+
});
|
177
|
+
}
|
178
|
+
} else {
|
179
|
+
joins[newTableName] = (0, _drizzleorm.eq)(adapter.tables[tableName].id, adapter.tables[newTableName].parent);
|
180
|
+
}
|
181
|
+
return {
|
182
|
+
columnName: 'value',
|
183
|
+
constraints,
|
184
|
+
field,
|
185
|
+
table: adapter.tables[newTableName]
|
186
|
+
};
|
187
|
+
}
|
188
|
+
break;
|
189
|
+
}
|
190
|
+
case 'text':
|
191
|
+
case 'number':
|
192
|
+
{
|
193
|
+
if (field.hasMany) {
|
194
|
+
let tableType = 'texts';
|
195
|
+
let columnName = 'text';
|
196
|
+
if (field.type === 'number') {
|
197
|
+
tableType = 'numbers';
|
198
|
+
columnName = 'number';
|
199
|
+
}
|
200
|
+
newTableName = `${tableName}_${tableType}`;
|
201
|
+
const joinConstraints = [
|
202
|
+
(0, _drizzleorm.eq)(adapter.tables[tableName].id, adapter.tables[newTableName].parent),
|
203
|
+
(0, _drizzleorm.eq)(adapter.tables[newTableName].path, `${constraintPath}${field.name}`)
|
204
|
+
];
|
205
|
+
if (locale && field.localized && adapter.payload.config.localization) {
|
206
|
+
joins[newTableName] = (0, _drizzleorm.and)(...joinConstraints, (0, _drizzleorm.eq)(adapter.tables[newTableName]._locale, locale));
|
207
|
+
if (locale !== 'all') {
|
208
|
+
constraints.push({
|
209
|
+
columnName: 'locale',
|
210
|
+
table: adapter.tables[newTableName],
|
211
|
+
value: locale
|
212
|
+
});
|
213
|
+
}
|
214
|
+
} else {
|
215
|
+
joins[newTableName] = (0, _drizzleorm.and)(...joinConstraints);
|
216
|
+
}
|
217
|
+
return {
|
218
|
+
columnName,
|
219
|
+
constraints,
|
220
|
+
field,
|
221
|
+
table: adapter.tables[newTableName]
|
222
|
+
};
|
223
|
+
}
|
224
|
+
break;
|
225
|
+
}
|
153
226
|
case 'array':
|
154
227
|
{
|
155
|
-
newTableName =
|
228
|
+
newTableName = (0, _getTableName.getTableName)({
|
229
|
+
adapter,
|
230
|
+
config: field,
|
231
|
+
parentTableName: `${tableName}_${tableNameSuffix}`,
|
232
|
+
prefix: `${tableName}_${tableNameSuffix}`
|
233
|
+
});
|
156
234
|
constraintPath = `${constraintPath}${field.name}.%.`;
|
157
235
|
if (locale && field.localized && adapter.payload.config.localization) {
|
158
236
|
joins[newTableName] = (0, _drizzleorm.and)((0, _drizzleorm.eq)(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID), (0, _drizzleorm.eq)(adapter.tables[newTableName]._locale, locale));
|
@@ -194,7 +272,12 @@ const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPre
|
|
194
272
|
];
|
195
273
|
blockTypes.forEach((blockType)=>{
|
196
274
|
const block = field.blocks.find((block)=>block.slug === blockType);
|
197
|
-
newTableName =
|
275
|
+
newTableName = (0, _getTableName.getTableName)({
|
276
|
+
adapter,
|
277
|
+
config: block,
|
278
|
+
parentTableName: tableName,
|
279
|
+
prefix: `${tableName}_blocks_`
|
280
|
+
});
|
198
281
|
joins[newTableName] = (0, _drizzleorm.eq)(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID);
|
199
282
|
constraints.push({
|
200
283
|
columnName: '_path',
|
@@ -210,7 +293,12 @@ const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPre
|
|
210
293
|
};
|
211
294
|
}
|
212
295
|
const hasBlockField = field.blocks.some((block)=>{
|
213
|
-
newTableName =
|
296
|
+
newTableName = (0, _getTableName.getTableName)({
|
297
|
+
adapter,
|
298
|
+
config: block,
|
299
|
+
parentTableName: tableName,
|
300
|
+
prefix: `${tableName}_blocks_`
|
301
|
+
});
|
214
302
|
constraintPath = `${constraintPath}${field.name}.%.`;
|
215
303
|
let result;
|
216
304
|
const blockConstraints = [];
|
@@ -273,21 +361,39 @@ const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPre
|
|
273
361
|
case 'upload':
|
274
362
|
{
|
275
363
|
let relationshipFields;
|
276
|
-
const relationTableName = `${rootTableName}
|
364
|
+
const relationTableName = `${rootTableName}${adapter.relationshipsSuffix}`;
|
277
365
|
const newCollectionPath = pathSegments.slice(1).join('.');
|
278
366
|
const aliasRelationshipTableName = (0, _uuid.v4)();
|
279
367
|
const aliasRelationshipTable = (0, _pgcore.alias)(adapter.tables[relationTableName], aliasRelationshipTableName);
|
280
|
-
|
281
|
-
|
282
|
-
|
283
|
-
|
284
|
-
|
368
|
+
if (locale && field.localized && adapter.payload.config.localization) {
|
369
|
+
joinAliases.push({
|
370
|
+
condition: (0, _drizzleorm.and)((0, _drizzleorm.eq)((aliasTable || adapter.tables[rootTableName]).id, aliasRelationshipTable.parent), (0, _drizzleorm.eq)(aliasRelationshipTable.locale, locale), (0, _drizzleorm.like)(aliasRelationshipTable.path, `${constraintPath}${field.name}`)),
|
371
|
+
table: aliasRelationshipTable
|
372
|
+
});
|
373
|
+
if (locale !== 'all') {
|
374
|
+
constraints.push({
|
375
|
+
columnName: 'locale',
|
376
|
+
table: aliasRelationshipTable,
|
377
|
+
value: locale
|
378
|
+
});
|
379
|
+
}
|
380
|
+
} else {
|
381
|
+
// Join in the relationships table
|
382
|
+
joinAliases.push({
|
383
|
+
condition: (0, _drizzleorm.and)((0, _drizzleorm.eq)((aliasTable || adapter.tables[rootTableName]).id, aliasRelationshipTable.parent), (0, _drizzleorm.like)(aliasRelationshipTable.path, `${constraintPath}${field.name}`)),
|
384
|
+
table: aliasRelationshipTable
|
385
|
+
});
|
386
|
+
}
|
285
387
|
selectFields[`${relationTableName}.path`] = aliasRelationshipTable.path;
|
286
388
|
let newAliasTable;
|
287
389
|
if (typeof field.relationTo === 'string') {
|
288
|
-
|
390
|
+
const relationshipConfig = adapter.payload.collections[field.relationTo].config;
|
391
|
+
newTableName = (0, _getTableName.getTableName)({
|
392
|
+
adapter,
|
393
|
+
config: relationshipConfig
|
394
|
+
});
|
289
395
|
// parent to relationship join table
|
290
|
-
relationshipFields =
|
396
|
+
relationshipFields = relationshipConfig.fields;
|
291
397
|
newAliasTable = (0, _pgcore.alias)(adapter.tables[newTableName], (0, _tosnakecase.default)((0, _uuid.v4)()));
|
292
398
|
joinAliases.push({
|
293
399
|
condition: (0, _drizzleorm.eq)(newAliasTable.id, aliasRelationshipTable[`${field.relationTo}ID`]),
|
@@ -302,7 +408,10 @@ const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPre
|
|
302
408
|
};
|
303
409
|
}
|
304
410
|
} else if (newCollectionPath === 'value') {
|
305
|
-
const tableColumnsNames = field.relationTo.map((relationTo)=>`"${aliasRelationshipTableName}"."${(0,
|
411
|
+
const tableColumnsNames = field.relationTo.map((relationTo)=>`"${aliasRelationshipTableName}"."${(0, _getTableName.getTableName)({
|
412
|
+
adapter,
|
413
|
+
config: adapter.payload.collections[relationTo].config
|
414
|
+
})}_id"`);
|
306
415
|
return {
|
307
416
|
constraints,
|
308
417
|
field,
|
@@ -342,38 +451,35 @@ const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPre
|
|
342
451
|
value
|
343
452
|
});
|
344
453
|
}
|
345
|
-
|
346
|
-
|
347
|
-
|
348
|
-
|
349
|
-
|
350
|
-
|
351
|
-
|
352
|
-
|
353
|
-
|
354
|
-
|
355
|
-
|
356
|
-
|
357
|
-
|
358
|
-
|
359
|
-
|
360
|
-
});
|
361
|
-
}
|
362
|
-
}
|
363
|
-
const targetTable = aliasTable || adapter.tables[newTableName];
|
364
|
-
selectFields[`${newTableName}.${columnPrefix}${field.name}`] = targetTable[`${columnPrefix}${field.name}`];
|
365
|
-
return {
|
366
|
-
columnName: `${columnPrefix}${field.name}`,
|
367
|
-
constraints,
|
368
|
-
field,
|
369
|
-
pathSegments,
|
370
|
-
table: targetTable
|
371
|
-
};
|
372
|
-
}
|
454
|
+
}
|
455
|
+
if ((0, _types.fieldAffectsData)(field)) {
|
456
|
+
if (field.localized && adapter.payload.config.localization) {
|
457
|
+
// If localized, we go to localized table and set aliasTable to undefined
|
458
|
+
// so it is not picked up below to be used as targetTable
|
459
|
+
newTableName = `${tableName}${adapter.localesSuffix}`;
|
460
|
+
const parentTable = aliasTable || adapter.tables[tableName];
|
461
|
+
joins[newTableName] = (0, _drizzleorm.eq)(parentTable.id, adapter.tables[newTableName]._parentID);
|
462
|
+
aliasTable = undefined;
|
463
|
+
if (locale !== 'all') {
|
464
|
+
constraints.push({
|
465
|
+
columnName: '_locale',
|
466
|
+
table: adapter.tables[newTableName],
|
467
|
+
value: locale
|
468
|
+
});
|
373
469
|
}
|
470
|
+
}
|
471
|
+
const targetTable = aliasTable || adapter.tables[newTableName];
|
472
|
+
selectFields[`${newTableName}.${columnPrefix}${field.name}`] = targetTable[`${columnPrefix}${field.name}`];
|
473
|
+
return {
|
474
|
+
columnName: `${columnPrefix}${field.name}`,
|
475
|
+
constraints,
|
476
|
+
field,
|
477
|
+
pathSegments,
|
478
|
+
table: targetTable
|
479
|
+
};
|
374
480
|
}
|
375
481
|
}
|
376
482
|
throw new _errors.APIError(`Cannot find field for path at ${fieldPath}`);
|
377
483
|
};
|
378
484
|
|
379
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/queries/getTableColumnFromPath.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { SQL } from 'drizzle-orm'\nimport type { PgTableWithColumns } from 'drizzle-orm/pg-core'\nimport type { Field, FieldAffectingData, NumberField, TabAsField, TextField } from 'payload/types'\n\nimport { and, eq, like, sql } from 'drizzle-orm'\nimport { alias } from 'drizzle-orm/pg-core'\nimport { APIError } from 'payload/errors'\nimport { fieldAffectsData, tabHasName } from 'payload/types'\nimport { flattenTopLevelFields } from 'payload/utilities'\nimport toSnakeCase from 'to-snake-case'\nimport { v4 as uuid } from 'uuid'\n\nimport type { GenericColumn, GenericTable, PostgresAdapter } from '../types'\nimport type { BuildQueryJoinAliases, BuildQueryJoins } from './buildQuery'\n\ntype Constraint = {\n  columnName: string\n  table: GenericTable | PgTableWithColumns<any>\n  value: unknown\n}\n\ntype TableColumn = {\n  columnName?: string\n  constraints: Constraint[]\n  field: FieldAffectingData\n  getNotNullColumnByValue?: (val: unknown) => string\n  pathSegments?: string[]\n  rawColumn?: SQL\n  table: GenericTable | PgTableWithColumns<any>\n}\n\ntype Args = {\n  adapter: PostgresAdapter\n  aliasTable?: GenericTable | PgTableWithColumns<any>\n  collectionPath: string\n  columnPrefix?: string\n  constraintPath?: string\n  constraints?: Constraint[]\n  fields: (Field | TabAsField)[]\n  joinAliases: BuildQueryJoinAliases\n  joins: BuildQueryJoins\n  locale?: string\n  pathSegments: string[]\n  rootTableName?: string\n  selectFields: Record<string, GenericColumn>\n  tableName: string\n  /**\n   * If creating a new table name for arrays and blocks, this suffix should be appended to the table name\n   */\n  tableNameSuffix?: string\n  /**\n   * The raw value of the query before sanitization\n   */\n  value: unknown\n}\n/**\n * Transforms path to table and column name\n * Adds tables to `join`\n * @returns TableColumn\n */\nexport const getTableColumnFromPath = ({\n  adapter,\n  aliasTable,\n  collectionPath,\n  columnPrefix = '',\n  constraintPath: incomingConstraintPath,\n  constraints = [],\n  fields,\n  joinAliases,\n  joins,\n  locale: incomingLocale,\n  pathSegments: incomingSegments,\n  rootTableName: incomingRootTableName,\n  selectFields,\n  tableName,\n  tableNameSuffix = '',\n  value,\n}: Args): TableColumn => {\n  const fieldPath = incomingSegments[0]\n  let locale = incomingLocale\n  const rootTableName = incomingRootTableName || tableName\n  let constraintPath = incomingConstraintPath || ''\n\n  const field = flattenTopLevelFields(fields as Field[]).find(\n    (fieldToFind) => fieldAffectsData(fieldToFind) && fieldToFind.name === fieldPath,\n  ) as Field | TabAsField\n  let newTableName = tableName\n\n  if (!field && fieldPath === 'id') {\n    selectFields.id = adapter.tables[newTableName].id\n    return {\n      columnName: 'id',\n      constraints,\n      field: {\n        name: 'id',\n        type: adapter.idType === 'uuid' ? 'text' : 'number',\n      } as TextField | NumberField,\n      table: adapter.tables[newTableName],\n    }\n  }\n\n  if (field) {\n    const pathSegments = [...incomingSegments]\n\n    // If next segment is a locale,\n    // we need to take it out and use it as the locale from this point on\n    if ('localized' in field && field.localized && adapter.payload.config.localization) {\n      const matchedLocale = adapter.payload.config.localization.localeCodes.find(\n        (locale) => locale === pathSegments[1],\n      )\n\n      if (matchedLocale) {\n        locale = matchedLocale\n        pathSegments.splice(1, 1)\n      }\n    }\n\n    switch (field.type) {\n      case 'tabs': {\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable,\n          collectionPath,\n          columnPrefix,\n          constraintPath,\n          constraints,\n          fields: field.tabs.map((tab) => ({\n            ...tab,\n            type: 'tab',\n          })),\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName,\n          selectFields,\n          tableName: newTableName,\n          tableNameSuffix,\n          value,\n        })\n      }\n      case 'tab': {\n        if (tabHasName(field)) {\n          return getTableColumnFromPath({\n            adapter,\n            aliasTable,\n            collectionPath,\n            columnPrefix: `${columnPrefix}${field.name}_`,\n            constraintPath: `${constraintPath}${field.name}.`,\n            constraints,\n            fields: field.fields,\n            joinAliases,\n            joins,\n            locale,\n            pathSegments: pathSegments.slice(1),\n            rootTableName,\n            selectFields,\n            tableName: newTableName,\n            tableNameSuffix: `${tableNameSuffix}${toSnakeCase(field.name)}_`,\n            value,\n          })\n        }\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable,\n          collectionPath,\n          columnPrefix,\n          constraintPath,\n          constraints,\n          fields: field.fields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName,\n          selectFields,\n          tableName: newTableName,\n          tableNameSuffix,\n          value,\n        })\n      }\n\n      case 'group': {\n        if (locale && field.localized && adapter.payload.config.localization) {\n          newTableName = `${tableName}_locales`\n\n          joins[tableName] = eq(\n            adapter.tables[tableName].id,\n            adapter.tables[newTableName]._parentID,\n          )\n          if (locale !== 'all') {\n            constraints.push({\n              columnName: '_locale',\n              table: adapter.tables[newTableName],\n              value: locale,\n            })\n          }\n        }\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable,\n          collectionPath,\n          columnPrefix: `${columnPrefix}${field.name}_`,\n          constraintPath: `${constraintPath}${field.name}.`,\n          constraints,\n          fields: field.fields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName,\n          selectFields,\n          tableName: newTableName,\n          tableNameSuffix: `${tableNameSuffix}${toSnakeCase(field.name)}_`,\n          value,\n        })\n      }\n\n      case 'array': {\n        newTableName = `${tableName}_${tableNameSuffix}${toSnakeCase(field.name)}`\n        constraintPath = `${constraintPath}${field.name}.%.`\n        if (locale && field.localized && adapter.payload.config.localization) {\n          joins[newTableName] = and(\n            eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID),\n            eq(adapter.tables[newTableName]._locale, locale),\n          )\n          if (locale !== 'all') {\n            constraints.push({\n              columnName: '_locale',\n              table: adapter.tables[newTableName],\n              value: locale,\n            })\n          }\n        } else {\n          joins[newTableName] = eq(\n            adapter.tables[tableName].id,\n            adapter.tables[newTableName]._parentID,\n          )\n        }\n        return getTableColumnFromPath({\n          adapter,\n          collectionPath,\n          constraintPath,\n          constraints,\n          fields: field.fields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName,\n          selectFields,\n          tableName: newTableName,\n          value,\n        })\n      }\n\n      case 'blocks': {\n        let blockTableColumn: TableColumn\n        let newTableName: string\n\n        // handle blockType queries\n        if (pathSegments[1] === 'blockType') {\n          // find the block config using the value\n          const blockTypes = Array.isArray(value) ? value : [value]\n          blockTypes.forEach((blockType) => {\n            const block = field.blocks.find((block) => block.slug === blockType)\n            newTableName = `${tableName}_blocks_${toSnakeCase(block.slug)}`\n            joins[newTableName] = eq(\n              adapter.tables[tableName].id,\n              adapter.tables[newTableName]._parentID,\n            )\n            constraints.push({\n              columnName: '_path',\n              table: adapter.tables[newTableName],\n              value: pathSegments[0],\n            })\n          })\n          return {\n            constraints,\n            field,\n            getNotNullColumnByValue: () => 'id',\n            table: adapter.tables[tableName],\n          }\n        }\n\n        const hasBlockField = field.blocks.some((block) => {\n          newTableName = `${tableName}_blocks_${toSnakeCase(block.slug)}`\n          constraintPath = `${constraintPath}${field.name}.%.`\n          let result\n          const blockConstraints = []\n          const blockSelectFields = {}\n          try {\n            result = getTableColumnFromPath({\n              adapter,\n              collectionPath,\n              constraintPath,\n              constraints: blockConstraints,\n              fields: block.fields,\n              joinAliases,\n              joins,\n              locale,\n              pathSegments: pathSegments.slice(1),\n              rootTableName,\n              selectFields: blockSelectFields,\n              tableName: newTableName,\n              value,\n            })\n          } catch (error) {\n            // this is fine, not every block will have the field\n          }\n          if (!result) {\n            return\n          }\n          blockTableColumn = result\n          constraints = constraints.concat(blockConstraints)\n          selectFields = { ...selectFields, ...blockSelectFields }\n          if (field.localized && adapter.payload.config.localization) {\n            joins[newTableName] = and(\n              eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID),\n              eq(adapter.tables[newTableName]._locale, locale),\n            )\n            if (locale) {\n              constraints.push({\n                columnName: '_locale',\n                table: adapter.tables[newTableName],\n                value: locale,\n              })\n            }\n          } else {\n            joins[newTableName] = eq(\n              adapter.tables[tableName].id,\n              adapter.tables[newTableName]._parentID,\n            )\n          }\n          return true\n        })\n        if (hasBlockField) {\n          return {\n            columnName: blockTableColumn.columnName,\n            constraints,\n            field: blockTableColumn.field,\n            pathSegments: pathSegments.slice(1),\n            rawColumn: blockTableColumn.rawColumn,\n            table: blockTableColumn.table,\n          }\n        }\n        break\n      }\n\n      case 'relationship':\n      case 'upload': {\n        let relationshipFields\n        const relationTableName = `${rootTableName}_rels`\n        const newCollectionPath = pathSegments.slice(1).join('.')\n        const aliasRelationshipTableName = uuid()\n        const aliasRelationshipTable = alias(\n          adapter.tables[relationTableName],\n          aliasRelationshipTableName,\n        )\n\n        // Join in the relationships table\n        joinAliases.push({\n          condition: and(\n            eq((aliasTable || adapter.tables[rootTableName]).id, aliasRelationshipTable.parent),\n            like(aliasRelationshipTable.path, `${constraintPath}${field.name}`),\n          ),\n          table: aliasRelationshipTable,\n        })\n\n        selectFields[`${relationTableName}.path`] = aliasRelationshipTable.path\n\n        let newAliasTable\n\n        if (typeof field.relationTo === 'string') {\n          newTableName = `${toSnakeCase(field.relationTo)}`\n          // parent to relationship join table\n          relationshipFields = adapter.payload.collections[field.relationTo].config.fields\n\n          newAliasTable = alias(adapter.tables[newTableName], toSnakeCase(uuid()))\n\n          joinAliases.push({\n            condition: eq(newAliasTable.id, aliasRelationshipTable[`${field.relationTo}ID`]),\n            table: newAliasTable,\n          })\n\n          if (newCollectionPath === '' || newCollectionPath === 'id') {\n            return {\n              columnName: `${field.relationTo}ID`,\n              constraints,\n              field,\n              table: aliasRelationshipTable,\n            }\n          }\n        } else if (newCollectionPath === 'value') {\n          const tableColumnsNames = field.relationTo.map(\n            (relationTo) => `\"${aliasRelationshipTableName}\".\"${toSnakeCase(relationTo)}_id\"`,\n          )\n          return {\n            constraints,\n            field,\n            rawColumn: sql.raw(`COALESCE(${tableColumnsNames.join(', ')})`),\n            table: aliasRelationshipTable,\n          }\n        } else if (newCollectionPath === 'relationTo') {\n          const relationTo = Array.isArray(field.relationTo) ? field.relationTo : [field.relationTo]\n\n          return {\n            constraints,\n            field,\n            getNotNullColumnByValue: (val) => {\n              const matchedRelation = relationTo.find((relation) => relation === val)\n              if (matchedRelation) return `${matchedRelation}ID`\n              return undefined\n            },\n            table: aliasRelationshipTable,\n          }\n        } else {\n          throw new APIError('Not supported')\n        }\n\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable: newAliasTable,\n          collectionPath: newCollectionPath,\n          constraints,\n          fields: relationshipFields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName: newTableName,\n          selectFields,\n          tableName: newTableName,\n          value,\n        })\n      }\n\n      default: {\n        if (fieldAffectsData(field)) {\n          if (field.localized && adapter.payload.config.localization) {\n            // If localized, we go to localized table and set aliasTable to undefined\n            // so it is not picked up below to be used as targetTable\n            newTableName = `${tableName}_locales`\n\n            const parentTable = aliasTable || adapter.tables[tableName]\n\n            joins[newTableName] = eq(parentTable.id, adapter.tables[newTableName]._parentID)\n\n            aliasTable = undefined\n\n            if (locale !== 'all') {\n              constraints.push({\n                columnName: '_locale',\n                table: adapter.tables[newTableName],\n                value: locale,\n              })\n            }\n          }\n\n          const targetTable = aliasTable || adapter.tables[newTableName]\n\n          selectFields[`${newTableName}.${columnPrefix}${field.name}`] =\n            targetTable[`${columnPrefix}${field.name}`]\n\n          return {\n            columnName: `${columnPrefix}${field.name}`,\n            constraints,\n            field,\n            pathSegments,\n            table: targetTable,\n          }\n        }\n      }\n    }\n  }\n\n  throw new APIError(`Cannot find field for path at ${fieldPath}`)\n}\n"],"names":["getTableColumnFromPath","adapter","aliasTable","collectionPath","columnPrefix","constraintPath","incomingConstraintPath","constraints","fields","joinAliases","joins","locale","incomingLocale","pathSegments","incomingSegments","rootTableName","incomingRootTableName","selectFields","tableName","tableNameSuffix","value","fieldPath","field","flattenTopLevelFields","find","fieldToFind","fieldAffectsData","name","newTableName","id","tables","columnName","type","idType","table","localized","payload","config","localization","matchedLocale","localeCodes","splice","tabs","map","tab","slice","tabHasName","toSnakeCase","eq","_parentID","push","and","_locale","blockTableColumn","blockTypes","Array","isArray","forEach","blockType","block","blocks","slug","getNotNullColumnByValue","hasBlockField","some","result","blockConstraints","blockSelectFields","error","concat","rawColumn","relationshipFields","relationTableName","newCollectionPath","join","aliasRelationshipTableName","uuid","aliasRelationshipTable","alias","condition","parent","like","path","newAliasTable","relationTo","collections","tableColumnsNames","sql","raw","val","matchedRelation","relation","undefined","APIError","parentTable","targetTable"],"mappings":"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"}
|
485
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/queries/getTableColumnFromPath.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { SQL } from 'drizzle-orm'\nimport type { PgTableWithColumns } from 'drizzle-orm/pg-core'\nimport type { Field, FieldAffectingData, NumberField, TabAsField, TextField } from 'payload/types'\n\nimport { and, eq, like, sql } from 'drizzle-orm'\nimport { alias } from 'drizzle-orm/pg-core'\nimport { APIError } from 'payload/errors'\nimport { fieldAffectsData, tabHasName } from 'payload/types'\nimport { flattenTopLevelFields } from 'payload/utilities'\nimport toSnakeCase from 'to-snake-case'\nimport { v4 as uuid } from 'uuid'\n\nimport type { GenericColumn, GenericTable, PostgresAdapter } from '../types'\nimport type { BuildQueryJoinAliases, BuildQueryJoins } from './buildQuery'\n\nimport { getTableName } from '../schema/getTableName'\n\ntype Constraint = {\n  columnName: string\n  table: GenericTable | PgTableWithColumns<any>\n  value: unknown\n}\n\ntype TableColumn = {\n  columnName?: string\n  constraints: Constraint[]\n  field: FieldAffectingData\n  getNotNullColumnByValue?: (val: unknown) => string\n  pathSegments?: string[]\n  rawColumn?: SQL\n  table: GenericTable | PgTableWithColumns<any>\n}\n\ntype Args = {\n  adapter: PostgresAdapter\n  aliasTable?: GenericTable | PgTableWithColumns<any>\n  collectionPath: string\n  columnPrefix?: string\n  constraintPath?: string\n  constraints?: Constraint[]\n  fields: (Field | TabAsField)[]\n  joinAliases: BuildQueryJoinAliases\n  joins: BuildQueryJoins\n  locale?: string\n  pathSegments: string[]\n  rootTableName?: string\n  selectFields: Record<string, GenericColumn>\n  tableName: string\n  /**\n   * If creating a new table name for arrays and blocks, this suffix should be appended to the table name\n   */\n  tableNameSuffix?: string\n  /**\n   * The raw value of the query before sanitization\n   */\n  value: unknown\n}\n/**\n * Transforms path to table and column name\n * Adds tables to `join`\n * @returns TableColumn\n */\nexport const getTableColumnFromPath = ({\n  adapter,\n  aliasTable,\n  collectionPath,\n  columnPrefix = '',\n  constraintPath: incomingConstraintPath,\n  constraints = [],\n  fields,\n  joinAliases,\n  joins,\n  locale: incomingLocale,\n  pathSegments: incomingSegments,\n  rootTableName: incomingRootTableName,\n  selectFields,\n  tableName,\n  tableNameSuffix = '',\n  value,\n}: Args): TableColumn => {\n  const fieldPath = incomingSegments[0]\n  let locale = incomingLocale\n  const rootTableName = incomingRootTableName || tableName\n  let constraintPath = incomingConstraintPath || ''\n\n  const field = flattenTopLevelFields(fields as Field[]).find(\n    (fieldToFind) => fieldAffectsData(fieldToFind) && fieldToFind.name === fieldPath,\n  ) as Field | TabAsField\n  let newTableName = tableName\n\n  if (!field && fieldPath === 'id') {\n    selectFields.id = adapter.tables[newTableName].id\n    return {\n      columnName: 'id',\n      constraints,\n      field: {\n        name: 'id',\n        type: adapter.idType === 'uuid' ? 'text' : 'number',\n      } as NumberField | TextField,\n      table: adapter.tables[newTableName],\n    }\n  }\n\n  if (field) {\n    const pathSegments = [...incomingSegments]\n\n    // If next segment is a locale,\n    // we need to take it out and use it as the locale from this point on\n    if ('localized' in field && field.localized && adapter.payload.config.localization) {\n      const matchedLocale = adapter.payload.config.localization.localeCodes.find(\n        (locale) => locale === pathSegments[1],\n      )\n\n      if (matchedLocale) {\n        locale = matchedLocale\n        pathSegments.splice(1, 1)\n      }\n    }\n\n    switch (field.type) {\n      case 'tabs': {\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable,\n          collectionPath,\n          columnPrefix,\n          constraintPath,\n          constraints,\n          fields: field.tabs.map((tab) => ({\n            ...tab,\n            type: 'tab',\n          })),\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName,\n          selectFields,\n          tableName: newTableName,\n          tableNameSuffix,\n          value,\n        })\n      }\n      case 'tab': {\n        if (tabHasName(field)) {\n          return getTableColumnFromPath({\n            adapter,\n            aliasTable,\n            collectionPath,\n            columnPrefix: `${columnPrefix}${field.name}_`,\n            constraintPath: `${constraintPath}${field.name}.`,\n            constraints,\n            fields: field.fields,\n            joinAliases,\n            joins,\n            locale,\n            pathSegments: pathSegments.slice(1),\n            rootTableName,\n            selectFields,\n            tableName: newTableName,\n            tableNameSuffix: `${tableNameSuffix}${toSnakeCase(field.name)}_`,\n            value,\n          })\n        }\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable,\n          collectionPath,\n          columnPrefix,\n          constraintPath,\n          constraints,\n          fields: field.fields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName,\n          selectFields,\n          tableName: newTableName,\n          tableNameSuffix,\n          value,\n        })\n      }\n\n      case 'group': {\n        if (locale && field.localized && adapter.payload.config.localization) {\n          newTableName = getTableName({\n            adapter,\n            config: field,\n            locales: true,\n            parentTableName: tableName,\n            prefix: `${tableName}_`,\n          })\n\n          joins[tableName] = eq(\n            adapter.tables[tableName].id,\n            adapter.tables[newTableName]._parentID,\n          )\n          if (locale !== 'all') {\n            constraints.push({\n              columnName: '_locale',\n              table: adapter.tables[newTableName],\n              value: locale,\n            })\n          }\n        }\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable,\n          collectionPath,\n          columnPrefix: `${columnPrefix}${field.name}_`,\n          constraintPath: `${constraintPath}${field.name}.`,\n          constraints,\n          fields: field.fields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName,\n          selectFields,\n          tableName: newTableName,\n          tableNameSuffix: `${tableNameSuffix}${toSnakeCase(field.name)}_`,\n          value,\n        })\n      }\n\n      case 'select': {\n        if (field.hasMany) {\n          newTableName = getTableName({\n            adapter,\n            config: field,\n            parentTableName: `${tableName}_${tableNameSuffix}`,\n            prefix: `${tableName}_${tableNameSuffix}`,\n          })\n\n          if (locale && field.localized && adapter.payload.config.localization) {\n            joins[newTableName] = and(\n              eq(adapter.tables[tableName].id, adapter.tables[newTableName].parent),\n              eq(adapter.tables[newTableName]._locale, locale),\n            )\n            if (locale !== 'all') {\n              constraints.push({\n                columnName: '_locale',\n                table: adapter.tables[newTableName],\n                value: locale,\n              })\n            }\n          } else {\n            joins[newTableName] = eq(\n              adapter.tables[tableName].id,\n              adapter.tables[newTableName].parent,\n            )\n          }\n\n          return {\n            columnName: 'value',\n            constraints,\n            field,\n            table: adapter.tables[newTableName],\n          }\n        }\n        break\n      }\n\n      case 'text':\n      case 'number': {\n        if (field.hasMany) {\n          let tableType = 'texts'\n          let columnName = 'text'\n          if (field.type === 'number') {\n            tableType = 'numbers'\n            columnName = 'number'\n          }\n          newTableName = `${tableName}_${tableType}`\n          const joinConstraints = [\n            eq(adapter.tables[tableName].id, adapter.tables[newTableName].parent),\n            eq(adapter.tables[newTableName].path, `${constraintPath}${field.name}`),\n          ]\n\n          if (locale && field.localized && adapter.payload.config.localization) {\n            joins[newTableName] = and(\n              ...joinConstraints,\n              eq(adapter.tables[newTableName]._locale, locale),\n            )\n            if (locale !== 'all') {\n              constraints.push({\n                columnName: 'locale',\n                table: adapter.tables[newTableName],\n                value: locale,\n              })\n            }\n          } else {\n            joins[newTableName] = and(...joinConstraints)\n          }\n\n          return {\n            columnName,\n            constraints,\n            field,\n            table: adapter.tables[newTableName],\n          }\n        }\n        break\n      }\n\n      case 'array': {\n        newTableName = getTableName({\n          adapter,\n          config: field,\n          parentTableName: `${tableName}_${tableNameSuffix}`,\n          prefix: `${tableName}_${tableNameSuffix}`,\n        })\n        constraintPath = `${constraintPath}${field.name}.%.`\n        if (locale && field.localized && adapter.payload.config.localization) {\n          joins[newTableName] = and(\n            eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID),\n            eq(adapter.tables[newTableName]._locale, locale),\n          )\n          if (locale !== 'all') {\n            constraints.push({\n              columnName: '_locale',\n              table: adapter.tables[newTableName],\n              value: locale,\n            })\n          }\n        } else {\n          joins[newTableName] = eq(\n            adapter.tables[tableName].id,\n            adapter.tables[newTableName]._parentID,\n          )\n        }\n        return getTableColumnFromPath({\n          adapter,\n          collectionPath,\n          constraintPath,\n          constraints,\n          fields: field.fields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName,\n          selectFields,\n          tableName: newTableName,\n          value,\n        })\n      }\n\n      case 'blocks': {\n        let blockTableColumn: TableColumn\n        let newTableName: string\n\n        // handle blockType queries\n        if (pathSegments[1] === 'blockType') {\n          // find the block config using the value\n          const blockTypes = Array.isArray(value) ? value : [value]\n          blockTypes.forEach((blockType) => {\n            const block = field.blocks.find((block) => block.slug === blockType)\n            newTableName = getTableName({\n              adapter,\n              config: block,\n              parentTableName: tableName,\n              prefix: `${tableName}_blocks_`,\n            })\n            joins[newTableName] = eq(\n              adapter.tables[tableName].id,\n              adapter.tables[newTableName]._parentID,\n            )\n            constraints.push({\n              columnName: '_path',\n              table: adapter.tables[newTableName],\n              value: pathSegments[0],\n            })\n          })\n          return {\n            constraints,\n            field,\n            getNotNullColumnByValue: () => 'id',\n            table: adapter.tables[tableName],\n          }\n        }\n\n        const hasBlockField = field.blocks.some((block) => {\n          newTableName = getTableName({\n            adapter,\n            config: block,\n            parentTableName: tableName,\n            prefix: `${tableName}_blocks_`,\n          })\n          constraintPath = `${constraintPath}${field.name}.%.`\n          let result\n          const blockConstraints = []\n          const blockSelectFields = {}\n          try {\n            result = getTableColumnFromPath({\n              adapter,\n              collectionPath,\n              constraintPath,\n              constraints: blockConstraints,\n              fields: block.fields,\n              joinAliases,\n              joins,\n              locale,\n              pathSegments: pathSegments.slice(1),\n              rootTableName,\n              selectFields: blockSelectFields,\n              tableName: newTableName,\n              value,\n            })\n          } catch (error) {\n            // this is fine, not every block will have the field\n          }\n          if (!result) {\n            return\n          }\n          blockTableColumn = result\n          constraints = constraints.concat(blockConstraints)\n          selectFields = { ...selectFields, ...blockSelectFields }\n          if (field.localized && adapter.payload.config.localization) {\n            joins[newTableName] = and(\n              eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID),\n              eq(adapter.tables[newTableName]._locale, locale),\n            )\n            if (locale) {\n              constraints.push({\n                columnName: '_locale',\n                table: adapter.tables[newTableName],\n                value: locale,\n              })\n            }\n          } else {\n            joins[newTableName] = eq(\n              adapter.tables[tableName].id,\n              adapter.tables[newTableName]._parentID,\n            )\n          }\n          return true\n        })\n        if (hasBlockField) {\n          return {\n            columnName: blockTableColumn.columnName,\n            constraints,\n            field: blockTableColumn.field,\n            pathSegments: pathSegments.slice(1),\n            rawColumn: blockTableColumn.rawColumn,\n            table: blockTableColumn.table,\n          }\n        }\n        break\n      }\n\n      case 'relationship':\n      case 'upload': {\n        let relationshipFields\n        const relationTableName = `${rootTableName}${adapter.relationshipsSuffix}`\n        const newCollectionPath = pathSegments.slice(1).join('.')\n        const aliasRelationshipTableName = uuid()\n        const aliasRelationshipTable = alias(\n          adapter.tables[relationTableName],\n          aliasRelationshipTableName,\n        )\n\n        if (locale && field.localized && adapter.payload.config.localization) {\n          joinAliases.push({\n            condition: and(\n              eq((aliasTable || adapter.tables[rootTableName]).id, aliasRelationshipTable.parent),\n              eq(aliasRelationshipTable.locale, locale),\n              like(aliasRelationshipTable.path, `${constraintPath}${field.name}`),\n            ),\n            table: aliasRelationshipTable,\n          })\n          if (locale !== 'all') {\n            constraints.push({\n              columnName: 'locale',\n              table: aliasRelationshipTable,\n              value: locale,\n            })\n          }\n        } else {\n          // Join in the relationships table\n          joinAliases.push({\n            condition: and(\n              eq((aliasTable || adapter.tables[rootTableName]).id, aliasRelationshipTable.parent),\n              like(aliasRelationshipTable.path, `${constraintPath}${field.name}`),\n            ),\n            table: aliasRelationshipTable,\n          })\n        }\n\n        selectFields[`${relationTableName}.path`] = aliasRelationshipTable.path\n\n        let newAliasTable\n\n        if (typeof field.relationTo === 'string') {\n          const relationshipConfig = adapter.payload.collections[field.relationTo].config\n          newTableName = getTableName({\n            adapter,\n            config: relationshipConfig,\n          })\n          // parent to relationship join table\n          relationshipFields = relationshipConfig.fields\n\n          newAliasTable = alias(adapter.tables[newTableName], toSnakeCase(uuid()))\n\n          joinAliases.push({\n            condition: eq(newAliasTable.id, aliasRelationshipTable[`${field.relationTo}ID`]),\n            table: newAliasTable,\n          })\n\n          if (newCollectionPath === '' || newCollectionPath === 'id') {\n            return {\n              columnName: `${field.relationTo}ID`,\n              constraints,\n              field,\n              table: aliasRelationshipTable,\n            }\n          }\n        } else if (newCollectionPath === 'value') {\n          const tableColumnsNames = field.relationTo.map(\n            (relationTo) =>\n              `\"${aliasRelationshipTableName}\".\"${getTableName({\n                adapter,\n                config: adapter.payload.collections[relationTo].config,\n              })}_id\"`,\n          )\n          return {\n            constraints,\n            field,\n            rawColumn: sql.raw(`COALESCE(${tableColumnsNames.join(', ')})`),\n            table: aliasRelationshipTable,\n          }\n        } else if (newCollectionPath === 'relationTo') {\n          const relationTo = Array.isArray(field.relationTo) ? field.relationTo : [field.relationTo]\n\n          return {\n            constraints,\n            field,\n            getNotNullColumnByValue: (val) => {\n              const matchedRelation = relationTo.find((relation) => relation === val)\n              if (matchedRelation) return `${matchedRelation}ID`\n              return undefined\n            },\n            table: aliasRelationshipTable,\n          }\n        } else {\n          throw new APIError('Not supported')\n        }\n\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable: newAliasTable,\n          collectionPath: newCollectionPath,\n          constraints,\n          fields: relationshipFields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName: newTableName,\n          selectFields,\n          tableName: newTableName,\n          value,\n        })\n      }\n    }\n\n    if (fieldAffectsData(field)) {\n      if (field.localized && adapter.payload.config.localization) {\n        // If localized, we go to localized table and set aliasTable to undefined\n        // so it is not picked up below to be used as targetTable\n        newTableName = `${tableName}${adapter.localesSuffix}`\n\n        const parentTable = aliasTable || adapter.tables[tableName]\n\n        joins[newTableName] = eq(parentTable.id, adapter.tables[newTableName]._parentID)\n\n        aliasTable = undefined\n\n        if (locale !== 'all') {\n          constraints.push({\n            columnName: '_locale',\n            table: adapter.tables[newTableName],\n            value: locale,\n          })\n        }\n      }\n\n      const targetTable = aliasTable || adapter.tables[newTableName]\n\n      selectFields[`${newTableName}.${columnPrefix}${field.name}`] =\n        targetTable[`${columnPrefix}${field.name}`]\n\n      return {\n        columnName: `${columnPrefix}${field.name}`,\n        constraints,\n        field,\n        pathSegments,\n        table: targetTable,\n      }\n    }\n  }\n\n  throw new APIError(`Cannot find field for path at ${fieldPath}`)\n}\n"],"names":["getTableColumnFromPath","adapter","aliasTable","collectionPath","columnPrefix","constraintPath","incomingConstraintPath","constraints","fields","joinAliases","joins","locale","incomingLocale","pathSegments","incomingSegments","rootTableName","incomingRootTableName","selectFields","tableName","tableNameSuffix","value","fieldPath","field","flattenTopLevelFields","find","fieldToFind","fieldAffectsData","name","newTableName","id","tables","columnName","type","idType","table","localized","payload","config","localization","matchedLocale","localeCodes","splice","tabs","map","tab","slice","tabHasName","toSnakeCase","getTableName","locales","parentTableName","prefix","eq","_parentID","push","hasMany","and","parent","_locale","tableType","joinConstraints","path","blockTableColumn","blockTypes","Array","isArray","forEach","blockType","block","blocks","slug","getNotNullColumnByValue","hasBlockField","some","result","blockConstraints","blockSelectFields","error","concat","rawColumn","relationshipFields","relationTableName","relationshipsSuffix","newCollectionPath","join","aliasRelationshipTableName","uuid","aliasRelationshipTable","alias","condition","like","newAliasTable","relationTo","relationshipConfig","collections","tableColumnsNames","sql","raw","val","matchedRelation","relation","undefined","APIError","localesSuffix","parentTable","targetTable"],"mappings":"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"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"sanitizeQueryValue.d.ts","sourceRoot":"","sources":["../../src/queries/sanitizeQueryValue.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,KAAK,EAAE,KAAK,UAAU,EAAoB,MAAM,eAAe,CAAA;AAG7E,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAE/C,KAAK,sBAAsB,GAAG;IAC5B,OAAO,EAAE,eAAe,CAAA;IACxB,KAAK,EAAE,KAAK,GAAG,UAAU,CAAA;IACzB,QAAQ,EAAE,MAAM,CAAA;IAChB,cAAc,EAAE,MAAM,CAAA;IACtB,GAAG,EAAE,GAAG,CAAA;CACT,CAAA;AAED,eAAO,MAAM,kBAAkB,oEAM5B,sBAAsB;cAAe,MAAM;WAAS,OAAO;
|
1
|
+
{"version":3,"file":"sanitizeQueryValue.d.ts","sourceRoot":"","sources":["../../src/queries/sanitizeQueryValue.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,KAAK,EAAE,KAAK,UAAU,EAAoB,MAAM,eAAe,CAAA;AAG7E,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAE/C,KAAK,sBAAsB,GAAG;IAC5B,OAAO,EAAE,eAAe,CAAA;IACxB,KAAK,EAAE,KAAK,GAAG,UAAU,CAAA;IACzB,QAAQ,EAAE,MAAM,CAAA;IAChB,cAAc,EAAE,MAAM,CAAA;IACtB,GAAG,EAAE,GAAG,CAAA;CACT,CAAA;AAED,eAAO,MAAM,kBAAkB,oEAM5B,sBAAsB;cAAe,MAAM;WAAS,OAAO;CAyF7D,CAAA"}
|