@payloadcms/db-postgres 0.1.12 → 0.1.13

Sign up to get free protection for your applications and to get access to all the features.
@@ -1 +1 @@
1
- {"version":3,"file":"init.d.ts","sourceRoot":"","sources":["../src/init.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAA;AAW5C,eAAO,MAAM,IAAI,EAAE,IAiElB,CAAA"}
1
+ {"version":3,"file":"init.d.ts","sourceRoot":"","sources":["../src/init.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAA;AAW5C,eAAO,MAAM,IAAI,EAAE,IAqElB,CAAA"}
package/dist/init.js CHANGED
@@ -25,6 +25,7 @@ const init = async function init() {
25
25
  const tableName = (0, _tosnakecase.default)(collection.slug);
26
26
  (0, _build.buildTable)({
27
27
  adapter: this,
28
+ buildNumbers: true,
28
29
  buildRelationships: true,
29
30
  disableNotNull: !!collection?.versions?.drafts,
30
31
  disableUnique: false,
@@ -37,6 +38,7 @@ const init = async function init() {
37
38
  const versionFields = (0, _versions.buildVersionCollectionFields)(collection);
38
39
  (0, _build.buildTable)({
39
40
  adapter: this,
41
+ buildNumbers: true,
40
42
  buildRelationships: true,
41
43
  disableNotNull: !!collection.versions?.drafts,
42
44
  disableUnique: true,
@@ -50,6 +52,7 @@ const init = async function init() {
50
52
  const tableName = (0, _tosnakecase.default)(global.slug);
51
53
  (0, _build.buildTable)({
52
54
  adapter: this,
55
+ buildNumbers: true,
53
56
  buildRelationships: true,
54
57
  disableNotNull: !!global?.versions?.drafts,
55
58
  disableUnique: false,
@@ -62,6 +65,7 @@ const init = async function init() {
62
65
  const versionFields = (0, _versions.buildVersionGlobalFields)(global);
63
66
  (0, _build.buildTable)({
64
67
  adapter: this,
68
+ buildNumbers: true,
65
69
  buildRelationships: true,
66
70
  disableNotNull: !!global.versions?.drafts,
67
71
  disableUnique: true,
@@ -73,4 +77,4 @@ const init = async function init() {
73
77
  });
74
78
  };
75
79
 
76
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbml0LnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIG5vLXBhcmFtLXJlYXNzaWduICovXG5pbXBvcnQgdHlwZSB7IEluaXQgfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuaW1wb3J0IHR5cGUgeyBTYW5pdGl6ZWRDb2xsZWN0aW9uQ29uZmlnIH0gZnJvbSAncGF5bG9hZC90eXBlcydcblxuaW1wb3J0IHsgcGdFbnVtIH0gZnJvbSAnZHJpenpsZS1vcm0vcGctY29yZSdcbmltcG9ydCB7IGJ1aWxkVmVyc2lvbkNvbGxlY3Rpb25GaWVsZHMsIGJ1aWxkVmVyc2lvbkdsb2JhbEZpZWxkcyB9IGZyb20gJ3BheWxvYWQvdmVyc2lvbnMnXG5pbXBvcnQgdG9TbmFrZUNhc2UgZnJvbSAndG8tc25ha2UtY2FzZSdcblxuaW1wb3J0IHR5cGUgeyBQb3N0Z3Jlc0FkYXB0ZXIgfSBmcm9tICcuL3R5cGVzJ1xuXG5pbXBvcnQgeyBidWlsZFRhYmxlIH0gZnJvbSAnLi9zY2hlbWEvYnVpbGQnXG5cbmV4cG9ydCBjb25zdCBpbml0OiBJbml0ID0gYXN5bmMgZnVuY3Rpb24gaW5pdCh0aGlzOiBQb3N0Z3Jlc0FkYXB0ZXIpIHtcbiAgaWYgKHRoaXMucGF5bG9hZC5jb25maWcubG9jYWxpemF0aW9uKSB7XG4gICAgdGhpcy5lbnVtcy5lbnVtX19sb2NhbGVzID0gcGdFbnVtKFxuICAgICAgJ19sb2NhbGVzJyxcbiAgICAgIHRoaXMucGF5bG9hZC5jb25maWcubG9jYWxpemF0aW9uLmxvY2FsZXMubWFwKCh7IGNvZGUgfSkgPT4gY29kZSkgYXMgW3N0cmluZywgLi4uc3RyaW5nW11dLFxuICAgIClcbiAgfVxuXG4gIHRoaXMucGF5bG9hZC5jb25maWcuY29sbGVjdGlvbnMuZm9yRWFjaCgoY29sbGVjdGlvbjogU2FuaXRpemVkQ29sbGVjdGlvbkNvbmZpZykgPT4ge1xuICAgIGNvbnN0IHRhYmxlTmFtZSA9IHRvU25ha2VDYXNlKGNvbGxlY3Rpb24uc2x1ZylcblxuICAgIGJ1aWxkVGFibGUoe1xuICAgICAgYWRhcHRlcjogdGhpcyxcbiAgICAgIGJ1aWxkUmVsYXRpb25zaGlwczogdHJ1ZSxcbiAgICAgIGRpc2FibGVOb3ROdWxsOiAhIWNvbGxlY3Rpb24/LnZlcnNpb25zPy5kcmFmdHMsXG4gICAgICBkaXNhYmxlVW5pcXVlOiBmYWxzZSxcbiAgICAgIGZpZWxkczogY29sbGVjdGlvbi5maWVsZHMsXG4gICAgICB0YWJsZU5hbWUsXG4gICAgICB0aW1lc3RhbXBzOiBjb2xsZWN0aW9uLnRpbWVzdGFtcHMsXG4gICAgfSlcblxuICAgIGlmIChjb2xsZWN0aW9uLnZlcnNpb25zKSB7XG4gICAgICBjb25zdCB2ZXJzaW9uc1RhYmxlTmFtZSA9IGBfJHt0YWJsZU5hbWV9X3ZgXG4gICAgICBjb25zdCB2ZXJzaW9uRmllbGRzID0gYnVpbGRWZXJzaW9uQ29sbGVjdGlvbkZpZWxkcyhjb2xsZWN0aW9uKVxuXG4gICAgICBidWlsZFRhYmxlKHtcbiAgICAgICAgYWRhcHRlcjogdGhpcyxcbiAgICAgICAgYnVpbGRSZWxhdGlvbnNoaXBzOiB0cnVlLFxuICAgICAgICBkaXNhYmxlTm90TnVsbDogISFjb2xsZWN0aW9uLnZlcnNpb25zPy5kcmFmdHMsXG4gICAgICAgIGRpc2FibGVVbmlxdWU6IHRydWUsXG4gICAgICAgIGZpZWxkczogdmVyc2lvbkZpZWxkcyxcbiAgICAgICAgdGFibGVOYW1lOiB2ZXJzaW9uc1RhYmxlTmFtZSxcbiAgICAgICAgdGltZXN0YW1wczogdHJ1ZSxcbiAgICAgIH0pXG4gICAgfVxuICB9KVxuXG4gIHRoaXMucGF5bG9hZC5jb25maWcuZ2xvYmFscy5mb3JFYWNoKChnbG9iYWwpID0+IHtcbiAgICBjb25zdCB0YWJsZU5hbWUgPSB0b1NuYWtlQ2FzZShnbG9iYWwuc2x1ZylcblxuICAgIGJ1aWxkVGFibGUoe1xuICAgICAgYWRhcHRlcjogdGhpcyxcbiAgICAgIGJ1aWxkUmVsYXRpb25zaGlwczogdHJ1ZSxcbiAgICAgIGRpc2FibGVOb3ROdWxsOiAhIWdsb2JhbD8udmVyc2lvbnM/LmRyYWZ0cyxcbiAgICAgIGRpc2FibGVVbmlxdWU6IGZhbHNlLFxuICAgICAgZmllbGRzOiBnbG9iYWwuZmllbGRzLFxuICAgICAgdGFibGVOYW1lLFxuICAgICAgdGltZXN0YW1wczogZmFsc2UsXG4gICAgfSlcblxuICAgIGlmIChnbG9iYWwudmVyc2lvbnMpIHtcbiAgICAgIGNvbnN0IHZlcnNpb25zVGFibGVOYW1lID0gYF8ke3RhYmxlTmFtZX1fdmBcbiAgICAgIGNvbnN0IHZlcnNpb25GaWVsZHMgPSBidWlsZFZlcnNpb25HbG9iYWxGaWVsZHMoZ2xvYmFsKVxuXG4gICAgICBidWlsZFRhYmxlKHtcbiAgICAgICAgYWRhcHRlcjogdGhpcyxcbiAgICAgICAgYnVpbGRSZWxhdGlvbnNoaXBzOiB0cnVlLFxuICAgICAgICBkaXNhYmxlTm90TnVsbDogISFnbG9iYWwudmVyc2lvbnM/LmRyYWZ0cyxcbiAgICAgICAgZGlzYWJsZVVuaXF1ZTogdHJ1ZSxcbiAgICAgICAgZmllbGRzOiB2ZXJzaW9uRmllbGRzLFxuICAgICAgICB0YWJsZU5hbWU6IHZlcnNpb25zVGFibGVOYW1lLFxuICAgICAgICB0aW1lc3RhbXBzOiB0cnVlLFxuICAgICAgfSlcbiAgICB9XG4gIH0pXG59XG4iXSwibmFtZXMiOlsiaW5pdCIsInBheWxvYWQiLCJjb25maWciLCJsb2NhbGl6YXRpb24iLCJlbnVtcyIsImVudW1fX2xvY2FsZXMiLCJwZ0VudW0iLCJsb2NhbGVzIiwibWFwIiwiY29kZSIsImNvbGxlY3Rpb25zIiwiZm9yRWFjaCIsImNvbGxlY3Rpb24iLCJ0YWJsZU5hbWUiLCJ0b1NuYWtlQ2FzZSIsInNsdWciLCJidWlsZFRhYmxlIiwiYWRhcHRlciIsImJ1aWxkUmVsYXRpb25zaGlwcyIsImRpc2FibGVOb3ROdWxsIiwidmVyc2lvbnMiLCJkcmFmdHMiLCJkaXNhYmxlVW5pcXVlIiwiZmllbGRzIiwidGltZXN0YW1wcyIsInZlcnNpb25zVGFibGVOYW1lIiwidmVyc2lvbkZpZWxkcyIsImJ1aWxkVmVyc2lvbkNvbGxlY3Rpb25GaWVsZHMiLCJnbG9iYWxzIiwiZ2xvYmFsIiwiYnVpbGRWZXJzaW9uR2xvYmFsRmllbGRzIl0sIm1hcHBpbmdzIjoiQUFBQSxvQ0FBb0M7Ozs7K0JBWXZCQTs7O2VBQUFBOzs7d0JBUlU7MEJBQ2dEO29FQUMvQzt1QkFJRzs7Ozs7O0FBRXBCLE1BQU1BLE9BQWEsZUFBZUE7SUFDdkMsSUFBSSxJQUFJLENBQUNDLE9BQU8sQ0FBQ0MsTUFBTSxDQUFDQyxZQUFZLEVBQUU7UUFDcEMsSUFBSSxDQUFDQyxLQUFLLENBQUNDLGFBQWEsR0FBR0MsSUFBQUEsY0FBTSxFQUMvQixZQUNBLElBQUksQ0FBQ0wsT0FBTyxDQUFDQyxNQUFNLENBQUNDLFlBQVksQ0FBQ0ksT0FBTyxDQUFDQyxHQUFHLENBQUMsQ0FBQyxFQUFFQyxJQUFJLEVBQUUsR0FBS0E7SUFFL0Q7SUFFQSxJQUFJLENBQUNSLE9BQU8sQ0FBQ0MsTUFBTSxDQUFDUSxXQUFXLENBQUNDLE9BQU8sQ0FBQyxDQUFDQztRQUN2QyxNQUFNQyxZQUFZQyxJQUFBQSxvQkFBVyxFQUFDRixXQUFXRyxJQUFJO1FBRTdDQyxJQUFBQSxpQkFBVSxFQUFDO1lBQ1RDLFNBQVMsSUFBSTtZQUNiQyxvQkFBb0I7WUFDcEJDLGdCQUFnQixDQUFDLENBQUNQLFlBQVlRLFVBQVVDO1lBQ3hDQyxlQUFlO1lBQ2ZDLFFBQVFYLFdBQVdXLE1BQU07WUFDekJWO1lBQ0FXLFlBQVlaLFdBQVdZLFVBQVU7UUFDbkM7UUFFQSxJQUFJWixXQUFXUSxRQUFRLEVBQUU7WUFDdkIsTUFBTUssb0JBQW9CLENBQUMsQ0FBQyxFQUFFWixVQUFVLEVBQUUsQ0FBQztZQUMzQyxNQUFNYSxnQkFBZ0JDLElBQUFBLHNDQUE0QixFQUFDZjtZQUVuREksSUFBQUEsaUJBQVUsRUFBQztnQkFDVEMsU0FBUyxJQUFJO2dCQUNiQyxvQkFBb0I7Z0JBQ3BCQyxnQkFBZ0IsQ0FBQyxDQUFDUCxXQUFXUSxRQUFRLEVBQUVDO2dCQUN2Q0MsZUFBZTtnQkFDZkMsUUFBUUc7Z0JBQ1JiLFdBQVdZO2dCQUNYRCxZQUFZO1lBQ2Q7UUFDRjtJQUNGO0lBRUEsSUFBSSxDQUFDdkIsT0FBTyxDQUFDQyxNQUFNLENBQUMwQixPQUFPLENBQUNqQixPQUFPLENBQUMsQ0FBQ2tCO1FBQ25DLE1BQU1oQixZQUFZQyxJQUFBQSxvQkFBVyxFQUFDZSxPQUFPZCxJQUFJO1FBRXpDQyxJQUFBQSxpQkFBVSxFQUFDO1lBQ1RDLFNBQVMsSUFBSTtZQUNiQyxvQkFBb0I7WUFDcEJDLGdCQUFnQixDQUFDLENBQUNVLFFBQVFULFVBQVVDO1lBQ3BDQyxlQUFlO1lBQ2ZDLFFBQVFNLE9BQU9OLE1BQU07WUFDckJWO1lBQ0FXLFlBQVk7UUFDZDtRQUVBLElBQUlLLE9BQU9ULFFBQVEsRUFBRTtZQUNuQixNQUFNSyxvQkFBb0IsQ0FBQyxDQUFDLEVBQUVaLFVBQVUsRUFBRSxDQUFDO1lBQzNDLE1BQU1hLGdCQUFnQkksSUFBQUEsa0NBQXdCLEVBQUNEO1lBRS9DYixJQUFBQSxpQkFBVSxFQUFDO2dCQUNUQyxTQUFTLElBQUk7Z0JBQ2JDLG9CQUFvQjtnQkFDcEJDLGdCQUFnQixDQUFDLENBQUNVLE9BQU9ULFFBQVEsRUFBRUM7Z0JBQ25DQyxlQUFlO2dCQUNmQyxRQUFRRztnQkFDUmIsV0FBV1k7Z0JBQ1hELFlBQVk7WUFDZDtRQUNGO0lBQ0Y7QUFDRiJ9
80
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbml0LnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIG5vLXBhcmFtLXJlYXNzaWduICovXG5pbXBvcnQgdHlwZSB7IEluaXQgfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuaW1wb3J0IHR5cGUgeyBTYW5pdGl6ZWRDb2xsZWN0aW9uQ29uZmlnIH0gZnJvbSAncGF5bG9hZC90eXBlcydcblxuaW1wb3J0IHsgcGdFbnVtIH0gZnJvbSAnZHJpenpsZS1vcm0vcGctY29yZSdcbmltcG9ydCB7IGJ1aWxkVmVyc2lvbkNvbGxlY3Rpb25GaWVsZHMsIGJ1aWxkVmVyc2lvbkdsb2JhbEZpZWxkcyB9IGZyb20gJ3BheWxvYWQvdmVyc2lvbnMnXG5pbXBvcnQgdG9TbmFrZUNhc2UgZnJvbSAndG8tc25ha2UtY2FzZSdcblxuaW1wb3J0IHR5cGUgeyBQb3N0Z3Jlc0FkYXB0ZXIgfSBmcm9tICcuL3R5cGVzJ1xuXG5pbXBvcnQgeyBidWlsZFRhYmxlIH0gZnJvbSAnLi9zY2hlbWEvYnVpbGQnXG5cbmV4cG9ydCBjb25zdCBpbml0OiBJbml0ID0gYXN5bmMgZnVuY3Rpb24gaW5pdCh0aGlzOiBQb3N0Z3Jlc0FkYXB0ZXIpIHtcbiAgaWYgKHRoaXMucGF5bG9hZC5jb25maWcubG9jYWxpemF0aW9uKSB7XG4gICAgdGhpcy5lbnVtcy5lbnVtX19sb2NhbGVzID0gcGdFbnVtKFxuICAgICAgJ19sb2NhbGVzJyxcbiAgICAgIHRoaXMucGF5bG9hZC5jb25maWcubG9jYWxpemF0aW9uLmxvY2FsZXMubWFwKCh7IGNvZGUgfSkgPT4gY29kZSkgYXMgW3N0cmluZywgLi4uc3RyaW5nW11dLFxuICAgIClcbiAgfVxuXG4gIHRoaXMucGF5bG9hZC5jb25maWcuY29sbGVjdGlvbnMuZm9yRWFjaCgoY29sbGVjdGlvbjogU2FuaXRpemVkQ29sbGVjdGlvbkNvbmZpZykgPT4ge1xuICAgIGNvbnN0IHRhYmxlTmFtZSA9IHRvU25ha2VDYXNlKGNvbGxlY3Rpb24uc2x1ZylcblxuICAgIGJ1aWxkVGFibGUoe1xuICAgICAgYWRhcHRlcjogdGhpcyxcbiAgICAgIGJ1aWxkTnVtYmVyczogdHJ1ZSxcbiAgICAgIGJ1aWxkUmVsYXRpb25zaGlwczogdHJ1ZSxcbiAgICAgIGRpc2FibGVOb3ROdWxsOiAhIWNvbGxlY3Rpb24/LnZlcnNpb25zPy5kcmFmdHMsXG4gICAgICBkaXNhYmxlVW5pcXVlOiBmYWxzZSxcbiAgICAgIGZpZWxkczogY29sbGVjdGlvbi5maWVsZHMsXG4gICAgICB0YWJsZU5hbWUsXG4gICAgICB0aW1lc3RhbXBzOiBjb2xsZWN0aW9uLnRpbWVzdGFtcHMsXG4gICAgfSlcblxuICAgIGlmIChjb2xsZWN0aW9uLnZlcnNpb25zKSB7XG4gICAgICBjb25zdCB2ZXJzaW9uc1RhYmxlTmFtZSA9IGBfJHt0YWJsZU5hbWV9X3ZgXG4gICAgICBjb25zdCB2ZXJzaW9uRmllbGRzID0gYnVpbGRWZXJzaW9uQ29sbGVjdGlvbkZpZWxkcyhjb2xsZWN0aW9uKVxuXG4gICAgICBidWlsZFRhYmxlKHtcbiAgICAgICAgYWRhcHRlcjogdGhpcyxcbiAgICAgICAgYnVpbGROdW1iZXJzOiB0cnVlLFxuICAgICAgICBidWlsZFJlbGF0aW9uc2hpcHM6IHRydWUsXG4gICAgICAgIGRpc2FibGVOb3ROdWxsOiAhIWNvbGxlY3Rpb24udmVyc2lvbnM/LmRyYWZ0cyxcbiAgICAgICAgZGlzYWJsZVVuaXF1ZTogdHJ1ZSxcbiAgICAgICAgZmllbGRzOiB2ZXJzaW9uRmllbGRzLFxuICAgICAgICB0YWJsZU5hbWU6IHZlcnNpb25zVGFibGVOYW1lLFxuICAgICAgICB0aW1lc3RhbXBzOiB0cnVlLFxuICAgICAgfSlcbiAgICB9XG4gIH0pXG5cbiAgdGhpcy5wYXlsb2FkLmNvbmZpZy5nbG9iYWxzLmZvckVhY2goKGdsb2JhbCkgPT4ge1xuICAgIGNvbnN0IHRhYmxlTmFtZSA9IHRvU25ha2VDYXNlKGdsb2JhbC5zbHVnKVxuXG4gICAgYnVpbGRUYWJsZSh7XG4gICAgICBhZGFwdGVyOiB0aGlzLFxuICAgICAgYnVpbGROdW1iZXJzOiB0cnVlLFxuICAgICAgYnVpbGRSZWxhdGlvbnNoaXBzOiB0cnVlLFxuICAgICAgZGlzYWJsZU5vdE51bGw6ICEhZ2xvYmFsPy52ZXJzaW9ucz8uZHJhZnRzLFxuICAgICAgZGlzYWJsZVVuaXF1ZTogZmFsc2UsXG4gICAgICBmaWVsZHM6IGdsb2JhbC5maWVsZHMsXG4gICAgICB0YWJsZU5hbWUsXG4gICAgICB0aW1lc3RhbXBzOiBmYWxzZSxcbiAgICB9KVxuXG4gICAgaWYgKGdsb2JhbC52ZXJzaW9ucykge1xuICAgICAgY29uc3QgdmVyc2lvbnNUYWJsZU5hbWUgPSBgXyR7dGFibGVOYW1lfV92YFxuICAgICAgY29uc3QgdmVyc2lvbkZpZWxkcyA9IGJ1aWxkVmVyc2lvbkdsb2JhbEZpZWxkcyhnbG9iYWwpXG5cbiAgICAgIGJ1aWxkVGFibGUoe1xuICAgICAgICBhZGFwdGVyOiB0aGlzLFxuICAgICAgICBidWlsZE51bWJlcnM6IHRydWUsXG4gICAgICAgIGJ1aWxkUmVsYXRpb25zaGlwczogdHJ1ZSxcbiAgICAgICAgZGlzYWJsZU5vdE51bGw6ICEhZ2xvYmFsLnZlcnNpb25zPy5kcmFmdHMsXG4gICAgICAgIGRpc2FibGVVbmlxdWU6IHRydWUsXG4gICAgICAgIGZpZWxkczogdmVyc2lvbkZpZWxkcyxcbiAgICAgICAgdGFibGVOYW1lOiB2ZXJzaW9uc1RhYmxlTmFtZSxcbiAgICAgICAgdGltZXN0YW1wczogdHJ1ZSxcbiAgICAgIH0pXG4gICAgfVxuICB9KVxufVxuIl0sIm5hbWVzIjpbImluaXQiLCJwYXlsb2FkIiwiY29uZmlnIiwibG9jYWxpemF0aW9uIiwiZW51bXMiLCJlbnVtX19sb2NhbGVzIiwicGdFbnVtIiwibG9jYWxlcyIsIm1hcCIsImNvZGUiLCJjb2xsZWN0aW9ucyIsImZvckVhY2giLCJjb2xsZWN0aW9uIiwidGFibGVOYW1lIiwidG9TbmFrZUNhc2UiLCJzbHVnIiwiYnVpbGRUYWJsZSIsImFkYXB0ZXIiLCJidWlsZE51bWJlcnMiLCJidWlsZFJlbGF0aW9uc2hpcHMiLCJkaXNhYmxlTm90TnVsbCIsInZlcnNpb25zIiwiZHJhZnRzIiwiZGlzYWJsZVVuaXF1ZSIsImZpZWxkcyIsInRpbWVzdGFtcHMiLCJ2ZXJzaW9uc1RhYmxlTmFtZSIsInZlcnNpb25GaWVsZHMiLCJidWlsZFZlcnNpb25Db2xsZWN0aW9uRmllbGRzIiwiZ2xvYmFscyIsImdsb2JhbCIsImJ1aWxkVmVyc2lvbkdsb2JhbEZpZWxkcyJdLCJtYXBwaW5ncyI6IkFBQUEsb0NBQW9DOzs7OytCQVl2QkE7OztlQUFBQTs7O3dCQVJVOzBCQUNnRDtvRUFDL0M7dUJBSUc7Ozs7OztBQUVwQixNQUFNQSxPQUFhLGVBQWVBO0lBQ3ZDLElBQUksSUFBSSxDQUFDQyxPQUFPLENBQUNDLE1BQU0sQ0FBQ0MsWUFBWSxFQUFFO1FBQ3BDLElBQUksQ0FBQ0MsS0FBSyxDQUFDQyxhQUFhLEdBQUdDLElBQUFBLGNBQU0sRUFDL0IsWUFDQSxJQUFJLENBQUNMLE9BQU8sQ0FBQ0MsTUFBTSxDQUFDQyxZQUFZLENBQUNJLE9BQU8sQ0FBQ0MsR0FBRyxDQUFDLENBQUMsRUFBRUMsSUFBSSxFQUFFLEdBQUtBO0lBRS9EO0lBRUEsSUFBSSxDQUFDUixPQUFPLENBQUNDLE1BQU0sQ0FBQ1EsV0FBVyxDQUFDQyxPQUFPLENBQUMsQ0FBQ0M7UUFDdkMsTUFBTUMsWUFBWUMsSUFBQUEsb0JBQVcsRUFBQ0YsV0FBV0csSUFBSTtRQUU3Q0MsSUFBQUEsaUJBQVUsRUFBQztZQUNUQyxTQUFTLElBQUk7WUFDYkMsY0FBYztZQUNkQyxvQkFBb0I7WUFDcEJDLGdCQUFnQixDQUFDLENBQUNSLFlBQVlTLFVBQVVDO1lBQ3hDQyxlQUFlO1lBQ2ZDLFFBQVFaLFdBQVdZLE1BQU07WUFDekJYO1lBQ0FZLFlBQVliLFdBQVdhLFVBQVU7UUFDbkM7UUFFQSxJQUFJYixXQUFXUyxRQUFRLEVBQUU7WUFDdkIsTUFBTUssb0JBQW9CLENBQUMsQ0FBQyxFQUFFYixVQUFVLEVBQUUsQ0FBQztZQUMzQyxNQUFNYyxnQkFBZ0JDLElBQUFBLHNDQUE0QixFQUFDaEI7WUFFbkRJLElBQUFBLGlCQUFVLEVBQUM7Z0JBQ1RDLFNBQVMsSUFBSTtnQkFDYkMsY0FBYztnQkFDZEMsb0JBQW9CO2dCQUNwQkMsZ0JBQWdCLENBQUMsQ0FBQ1IsV0FBV1MsUUFBUSxFQUFFQztnQkFDdkNDLGVBQWU7Z0JBQ2ZDLFFBQVFHO2dCQUNSZCxXQUFXYTtnQkFDWEQsWUFBWTtZQUNkO1FBQ0Y7SUFDRjtJQUVBLElBQUksQ0FBQ3hCLE9BQU8sQ0FBQ0MsTUFBTSxDQUFDMkIsT0FBTyxDQUFDbEIsT0FBTyxDQUFDLENBQUNtQjtRQUNuQyxNQUFNakIsWUFBWUMsSUFBQUEsb0JBQVcsRUFBQ2dCLE9BQU9mLElBQUk7UUFFekNDLElBQUFBLGlCQUFVLEVBQUM7WUFDVEMsU0FBUyxJQUFJO1lBQ2JDLGNBQWM7WUFDZEMsb0JBQW9CO1lBQ3BCQyxnQkFBZ0IsQ0FBQyxDQUFDVSxRQUFRVCxVQUFVQztZQUNwQ0MsZUFBZTtZQUNmQyxRQUFRTSxPQUFPTixNQUFNO1lBQ3JCWDtZQUNBWSxZQUFZO1FBQ2Q7UUFFQSxJQUFJSyxPQUFPVCxRQUFRLEVBQUU7WUFDbkIsTUFBTUssb0JBQW9CLENBQUMsQ0FBQyxFQUFFYixVQUFVLEVBQUUsQ0FBQztZQUMzQyxNQUFNYyxnQkFBZ0JJLElBQUFBLGtDQUF3QixFQUFDRDtZQUUvQ2QsSUFBQUEsaUJBQVUsRUFBQztnQkFDVEMsU0FBUyxJQUFJO2dCQUNiQyxjQUFjO2dCQUNkQyxvQkFBb0I7Z0JBQ3BCQyxnQkFBZ0IsQ0FBQyxDQUFDVSxPQUFPVCxRQUFRLEVBQUVDO2dCQUNuQ0MsZUFBZTtnQkFDZkMsUUFBUUc7Z0JBQ1JkLFdBQVdhO2dCQUNYRCxZQUFZO1lBQ2Q7UUFDRjtJQUNGO0FBQ0YifQ==
@@ -5,6 +5,7 @@ type Args = {
5
5
  adapter: PostgresAdapter;
6
6
  baseColumns?: Record<string, PgColumnBuilder>;
7
7
  baseExtraConfig?: Record<string, (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder>;
8
+ buildNumbers?: boolean;
8
9
  buildRelationships?: boolean;
9
10
  disableNotNull: boolean;
10
11
  disableUnique: boolean;
@@ -17,8 +18,9 @@ type Args = {
17
18
  timestamps?: boolean;
18
19
  };
19
20
  type Result = {
21
+ hasManyNumberField: 'index' | boolean;
20
22
  relationsToBuild: Map<string, string>;
21
23
  };
22
- export declare const buildTable: ({ adapter, baseColumns, baseExtraConfig, buildRelationships, disableNotNull, disableUnique, fields, rootRelationsToBuild, rootRelationships, rootTableIDColType, rootTableName, tableName, timestamps, }: Args) => Result;
24
+ export declare const buildTable: ({ adapter, baseColumns, baseExtraConfig, buildNumbers, buildRelationships, disableNotNull, disableUnique, fields, rootRelationsToBuild, rootRelationships, rootTableIDColType, rootTableName: incomingRootTableName, tableName, timestamps, }: Args) => Result;
23
25
  export {};
24
26
  //# sourceMappingURL=build.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"build.d.ts","sourceRoot":"","sources":["../../src/schema/build.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,eAAe,EAAE,uBAAuB,EAAE,MAAM,qBAAqB,CAAA;AACjG,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAgB1C,OAAO,KAAK,EAAE,cAAc,EAAgB,eAAe,EAAE,MAAM,UAAU,CAAA;AAK7E,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,WAAW,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IAC7C,eAAe,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,YAAY,GAAG,uBAAuB,CAAC,CAAA;IAClG,kBAAkB,CAAC,EAAE,OAAO,CAAA;IAC5B,cAAc,EAAE,OAAO,CAAA;IACvB,aAAa,EAAE,OAAO,CAAA;IACtB,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,oBAAoB,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IAC1C,iBAAiB,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IAC/B,kBAAkB,CAAC,EAAE,MAAM,CAAA;IAC3B,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,SAAS,EAAE,MAAM,CAAA;IACjB,UAAU,CAAC,EAAE,OAAO,CAAA;CACrB,CAAA;AAED,KAAK,MAAM,GAAG;IACZ,gBAAgB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;CACtC,CAAA;AAED,eAAO,MAAM,UAAU,6MAcpB,IAAI,KAAG,MAgRT,CAAA"}
1
+ {"version":3,"file":"build.d.ts","sourceRoot":"","sources":["../../src/schema/build.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,eAAe,EAAE,uBAAuB,EAAE,MAAM,qBAAqB,CAAA;AACjG,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAgB1C,OAAO,KAAK,EAAE,cAAc,EAAgB,eAAe,EAAE,MAAM,UAAU,CAAA;AAK7E,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,WAAW,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IAC7C,eAAe,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,YAAY,GAAG,uBAAuB,CAAC,CAAA;IAClG,YAAY,CAAC,EAAE,OAAO,CAAA;IACtB,kBAAkB,CAAC,EAAE,OAAO,CAAA;IAC5B,cAAc,EAAE,OAAO,CAAA;IACvB,aAAa,EAAE,OAAO,CAAA;IACtB,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,oBAAoB,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IAC1C,iBAAiB,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IAC/B,kBAAkB,CAAC,EAAE,MAAM,CAAA;IAC3B,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,SAAS,EAAE,MAAM,CAAA;IACjB,UAAU,CAAC,EAAE,OAAO,CAAA;CACrB,CAAA;AAED,KAAK,MAAM,GAAG;IACZ,kBAAkB,EAAE,OAAO,GAAG,OAAO,CAAA;IACrC,gBAAgB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;CACtC,CAAA;AAED,eAAO,MAAM,UAAU,kPAepB,IAAI,KAAG,MAkRT,CAAA"}
@@ -19,7 +19,8 @@ function _interop_require_default(obj) {
19
19
  default: obj
20
20
  };
21
21
  }
22
- const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildRelationships, disableNotNull, disableUnique = false, fields, rootRelationsToBuild, rootRelationships, rootTableIDColType, rootTableName, tableName, timestamps })=>{
22
+ const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildNumbers, buildRelationships, disableNotNull, disableUnique = false, fields, rootRelationsToBuild, rootRelationships, rootTableIDColType, rootTableName: incomingRootTableName, tableName, timestamps })=>{
23
+ const rootTableName = incomingRootTableName || tableName;
23
24
  const columns = baseColumns;
24
25
  const indexes = {};
25
26
  let hasLocalizedField = false;
@@ -51,6 +52,7 @@ const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildRela
51
52
  }
52
53
  ({ hasLocalizedField, hasLocalizedManyNumberField, hasLocalizedRelationshipField, hasManyNumberField } = (0, _traverseFields.traverseFields)({
53
54
  adapter,
55
+ buildNumbers,
54
56
  buildRelationships,
55
57
  columns,
56
58
  disableNotNull,
@@ -65,7 +67,7 @@ const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildRela
65
67
  relationships,
66
68
  rootRelationsToBuild: rootRelationsToBuild || relationsToBuild,
67
69
  rootTableIDColType: rootTableIDColType || idColType,
68
- rootTableName: rootTableName || tableName
70
+ rootTableName
69
71
  }));
70
72
  if (timestamps) {
71
73
  columns.createdAt = (0, _pgcore.timestamp)('created_at', {
@@ -118,8 +120,8 @@ const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildRela
118
120
  }));
119
121
  adapter.relations[`relations_${localeTableName}`] = localesTableRelations;
120
122
  }
121
- if (hasManyNumberField) {
122
- const numbersTableName = `${tableName}_numbers`;
123
+ if (hasManyNumberField && buildNumbers) {
124
+ const numbersTableName = `${rootTableName}_numbers`;
123
125
  const columns = {
124
126
  id: (0, _pgcore.serial)('id').primaryKey(),
125
127
  number: (0, _pgcore.numeric)('number'),
@@ -242,8 +244,9 @@ const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildRela
242
244
  });
243
245
  adapter.relations[`relations_${tableName}`] = tableRelations;
244
246
  return {
247
+ hasManyNumberField,
245
248
  relationsToBuild
246
249
  };
247
250
  };
248
251
 
249
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/schema/build.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { Relation } from 'drizzle-orm'\nimport type { IndexBuilder, PgColumnBuilder, UniqueConstraintBuilder } from 'drizzle-orm/pg-core'\nimport type { Field } from 'payload/types'\n\nimport { relations } from 'drizzle-orm'\nimport {\n  index,\n  integer,\n  numeric,\n  pgTable,\n  serial,\n  timestamp,\n  unique,\n  varchar,\n} from 'drizzle-orm/pg-core'\nimport { fieldAffectsData } from 'payload/types'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { GenericColumns, GenericTable, PostgresAdapter } from '../types'\n\nimport { parentIDColumnMap } from './parentIDColumnMap'\nimport { traverseFields } from './traverseFields'\n\ntype Args = {\n  adapter: PostgresAdapter\n  baseColumns?: Record<string, PgColumnBuilder>\n  baseExtraConfig?: Record<string, (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder>\n  buildRelationships?: boolean\n  disableNotNull: boolean\n  disableUnique: boolean\n  fields: Field[]\n  rootRelationsToBuild?: Map<string, string>\n  rootRelationships?: Set<string>\n  rootTableIDColType?: string\n  rootTableName?: string\n  tableName: string\n  timestamps?: boolean\n}\n\ntype Result = {\n  relationsToBuild: Map<string, string>\n}\n\nexport const buildTable = ({\n  adapter,\n  baseColumns = {},\n  baseExtraConfig = {},\n  buildRelationships,\n  disableNotNull,\n  disableUnique = false,\n  fields,\n  rootRelationsToBuild,\n  rootRelationships,\n  rootTableIDColType,\n  rootTableName,\n  tableName,\n  timestamps,\n}: Args): Result => {\n  const columns: Record<string, PgColumnBuilder> = baseColumns\n  const indexes: Record<string, (cols: GenericColumns) => IndexBuilder> = {}\n\n  let hasLocalizedField = false\n  let hasLocalizedRelationshipField = false\n  let hasManyNumberField: 'index' | boolean = false\n  let hasLocalizedManyNumberField = false\n\n  const localesColumns: Record<string, PgColumnBuilder> = {}\n  const localesIndexes: Record<string, (cols: GenericColumns) => IndexBuilder> = {}\n  let localesTable: GenericTable\n  let numbersTable: GenericTable\n\n  // Relationships to the base collection\n  const relationships: Set<string> = rootRelationships || new Set()\n\n  let relationshipsTable: GenericTable\n\n  // Drizzle relations\n  const relationsToBuild: Map<string, string> = new Map()\n\n  const idField = fields.find((field) => fieldAffectsData(field) && field.name === 'id')\n  let idColType = 'integer'\n\n  if (idField) {\n    if (idField.type === 'number') {\n      idColType = 'numeric'\n      columns.id = numeric('id').primaryKey()\n    }\n\n    if (idField.type === 'text') {\n      idColType = 'varchar'\n      columns.id = varchar('id').primaryKey()\n    }\n  } else {\n    columns.id = serial('id').primaryKey()\n  }\n\n  ;({\n    hasLocalizedField,\n    hasLocalizedManyNumberField,\n    hasLocalizedRelationshipField,\n    hasManyNumberField,\n  } = traverseFields({\n    adapter,\n    buildRelationships,\n    columns,\n    disableNotNull,\n    disableUnique,\n    fields,\n    indexes,\n    localesColumns,\n    localesIndexes,\n    newTableName: tableName,\n    parentTableName: tableName,\n    relationsToBuild,\n    relationships,\n    rootRelationsToBuild: rootRelationsToBuild || relationsToBuild,\n    rootTableIDColType: rootTableIDColType || idColType,\n    rootTableName: rootTableName || tableName,\n  }))\n\n  if (timestamps) {\n    columns.createdAt = timestamp('created_at', {\n      mode: 'string',\n      precision: 3,\n      withTimezone: true,\n    })\n      .defaultNow()\n      .notNull()\n    columns.updatedAt = timestamp('updated_at', {\n      mode: 'string',\n      precision: 3,\n      withTimezone: true,\n    })\n      .defaultNow()\n      .notNull()\n  }\n\n  const table = pgTable(tableName, columns, (cols) => {\n    const extraConfig = Object.entries(baseExtraConfig).reduce((config, [key, func]) => {\n      config[key] = func(cols)\n      return config\n    }, {})\n\n    return Object.entries(indexes).reduce((acc, [colName, func]) => {\n      acc[colName] = func(cols)\n      return acc\n    }, extraConfig)\n  })\n\n  adapter.tables[tableName] = table\n\n  if (hasLocalizedField) {\n    const localeTableName = `${tableName}_locales`\n    localesColumns.id = serial('id').primaryKey()\n    localesColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n    localesColumns._parentID = parentIDColumnMap[idColType]('_parent_id')\n      .references(() => table.id, { onDelete: 'cascade' })\n      .notNull()\n\n    localesTable = pgTable(localeTableName, localesColumns, (cols) => {\n      return Object.entries(localesIndexes).reduce(\n        (acc, [colName, func]) => {\n          acc[colName] = func(cols)\n          return acc\n        },\n        {\n          _localeParent: unique(`${localeTableName}_locale_parent_id_unique`).on(\n            cols._locale,\n            cols._parentID,\n          ),\n        },\n      )\n    })\n\n    adapter.tables[localeTableName] = localesTable\n\n    const localesTableRelations = relations(localesTable, ({ one }) => ({\n      _parentID: one(table, {\n        fields: [localesTable._parentID],\n        references: [table.id],\n      }),\n    }))\n\n    adapter.relations[`relations_${localeTableName}`] = localesTableRelations\n  }\n\n  if (hasManyNumberField) {\n    const numbersTableName = `${tableName}_numbers`\n    const columns: Record<string, PgColumnBuilder> = {\n      id: serial('id').primaryKey(),\n      number: numeric('number'),\n      order: integer('order').notNull(),\n      parent: parentIDColumnMap[idColType]('parent_id')\n        .references(() => table.id, { onDelete: 'cascade' })\n        .notNull(),\n      path: varchar('path').notNull(),\n    }\n\n    if (hasLocalizedManyNumberField) {\n      columns.locale = adapter.enums.enum__locales('locale')\n    }\n\n    numbersTable = pgTable(numbersTableName, columns, (cols) => {\n      const indexes: Record<string, IndexBuilder> = {\n        orderParentIdx: index('order_parent_idx').on(cols.order, cols.parent),\n      }\n\n      if (hasManyNumberField === 'index') {\n        indexes.numberIdx = index('number_idx').on(cols.number)\n      }\n\n      if (hasLocalizedManyNumberField) {\n        indexes.localeParent = index('locale_parent').on(cols.locale, cols.parent)\n      }\n\n      return indexes\n    })\n\n    adapter.tables[numbersTableName] = numbersTable\n\n    const numbersTableRelations = relations(numbersTable, ({ one }) => ({\n      parent: one(table, {\n        fields: [numbersTable.parent],\n        references: [table.id],\n      }),\n    }))\n\n    adapter.relations[`relations_${numbersTableName}`] = numbersTableRelations\n  }\n\n  if (buildRelationships) {\n    if (relationships.size) {\n      const relationshipColumns: Record<string, PgColumnBuilder> = {\n        id: serial('id').primaryKey(),\n        order: integer('order'),\n        parent: parentIDColumnMap[idColType]('parent_id')\n          .references(() => table.id, { onDelete: 'cascade' })\n          .notNull(),\n        path: varchar('path').notNull(),\n      }\n\n      if (hasLocalizedRelationshipField) {\n        relationshipColumns.locale = adapter.enums.enum__locales('locale')\n      }\n\n      relationships.forEach((relationTo) => {\n        const formattedRelationTo = toSnakeCase(relationTo)\n        let colType = 'integer'\n        const relatedCollectionCustomID = adapter.payload.collections[\n          relationTo\n        ].config.fields.find((field) => fieldAffectsData(field) && field.name === 'id')\n        if (relatedCollectionCustomID?.type === 'number') colType = 'numeric'\n        if (relatedCollectionCustomID?.type === 'text') colType = 'varchar'\n\n        relationshipColumns[`${relationTo}ID`] = parentIDColumnMap[colType](\n          `${formattedRelationTo}_id`,\n        ).references(() => adapter.tables[formattedRelationTo].id, { onDelete: 'cascade' })\n      })\n\n      const relationshipsTableName = `${tableName}_rels`\n\n      relationshipsTable = pgTable(relationshipsTableName, relationshipColumns, (cols) => {\n        const result: Record<string, unknown> = {\n          order: index('order_idx').on(cols.order),\n          parentIdx: index('parent_idx').on(cols.parent),\n          pathIdx: index('path_idx').on(cols.path),\n        }\n\n        if (hasLocalizedRelationshipField) {\n          result.localeIdx = index('locale_idx').on(cols.locale)\n        }\n\n        return result\n      })\n\n      adapter.tables[relationshipsTableName] = relationshipsTable\n\n      const relationshipsTableRelations = relations(relationshipsTable, ({ one }) => {\n        const result: Record<string, Relation<string>> = {\n          parent: one(table, {\n            fields: [relationshipsTable.parent],\n            references: [table.id],\n            relationName: '_rels',\n          }),\n        }\n\n        relationships.forEach((relationTo) => {\n          const relatedTableName = toSnakeCase(relationTo)\n          const idColumnName = `${relationTo}ID`\n          result[idColumnName] = one(adapter.tables[relatedTableName], {\n            fields: [relationshipsTable[idColumnName]],\n            references: [adapter.tables[relatedTableName].id],\n          })\n        })\n\n        return result\n      })\n\n      adapter.relations[`relations_${relationshipsTableName}`] = relationshipsTableRelations\n    }\n  }\n\n  const tableRelations = relations(table, ({ many }) => {\n    const result: Record<string, Relation<string>> = {}\n\n    relationsToBuild.forEach((val, key) => {\n      result[key] = many(adapter.tables[val])\n    })\n\n    if (hasLocalizedField) {\n      result._locales = many(localesTable)\n    }\n\n    if (hasManyNumberField) {\n      result._numbers = many(numbersTable)\n    }\n\n    if (relationships.size && relationshipsTable) {\n      result._rels = many(relationshipsTable, {\n        relationName: '_rels',\n      })\n    }\n\n    return result\n  })\n\n  adapter.relations[`relations_${tableName}`] = tableRelations\n\n  return { relationsToBuild }\n}\n"],"names":["buildTable","adapter","baseColumns","baseExtraConfig","buildRelationships","disableNotNull","disableUnique","fields","rootRelationsToBuild","rootRelationships","rootTableIDColType","rootTableName","tableName","timestamps","columns","indexes","hasLocalizedField","hasLocalizedRelationshipField","hasManyNumberField","hasLocalizedManyNumberField","localesColumns","localesIndexes","localesTable","numbersTable","relationships","Set","relationshipsTable","relationsToBuild","Map","idField","find","field","fieldAffectsData","name","idColType","type","id","numeric","primaryKey","varchar","serial","traverseFields","newTableName","parentTableName","createdAt","timestamp","mode","precision","withTimezone","defaultNow","notNull","updatedAt","table","pgTable","cols","extraConfig","Object","entries","reduce","config","key","func","acc","colName","tables","localeTableName","_locale","enums","enum__locales","_parentID","parentIDColumnMap","references","onDelete","_localeParent","unique","on","localesTableRelations","relations","one","numbersTableName","number","order","integer","parent","path","locale","orderParentIdx","index","numberIdx","localeParent","numbersTableRelations","size","relationshipColumns","forEach","relationTo","formattedRelationTo","toSnakeCase","colType","relatedCollectionCustomID","payload","collections","relationshipsTableName","result","parentIdx","pathIdx","localeIdx","relationshipsTableRelations","relationName","relatedTableName","idColumnName","tableRelations","many","val","_locales","_numbers","_rels"],"mappings":"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"}
252
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/schema/build.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { Relation } from 'drizzle-orm'\nimport type { IndexBuilder, PgColumnBuilder, UniqueConstraintBuilder } from 'drizzle-orm/pg-core'\nimport type { Field } from 'payload/types'\n\nimport { relations } from 'drizzle-orm'\nimport {\n  index,\n  integer,\n  numeric,\n  pgTable,\n  serial,\n  timestamp,\n  unique,\n  varchar,\n} from 'drizzle-orm/pg-core'\nimport { fieldAffectsData } from 'payload/types'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { GenericColumns, GenericTable, PostgresAdapter } from '../types'\n\nimport { parentIDColumnMap } from './parentIDColumnMap'\nimport { traverseFields } from './traverseFields'\n\ntype Args = {\n  adapter: PostgresAdapter\n  baseColumns?: Record<string, PgColumnBuilder>\n  baseExtraConfig?: Record<string, (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder>\n  buildNumbers?: boolean\n  buildRelationships?: boolean\n  disableNotNull: boolean\n  disableUnique: boolean\n  fields: Field[]\n  rootRelationsToBuild?: Map<string, string>\n  rootRelationships?: Set<string>\n  rootTableIDColType?: string\n  rootTableName?: string\n  tableName: string\n  timestamps?: boolean\n}\n\ntype Result = {\n  hasManyNumberField: 'index' | boolean\n  relationsToBuild: Map<string, string>\n}\n\nexport const buildTable = ({\n  adapter,\n  baseColumns = {},\n  baseExtraConfig = {},\n  buildNumbers,\n  buildRelationships,\n  disableNotNull,\n  disableUnique = false,\n  fields,\n  rootRelationsToBuild,\n  rootRelationships,\n  rootTableIDColType,\n  rootTableName: incomingRootTableName,\n  tableName,\n  timestamps,\n}: Args): Result => {\n  const rootTableName = incomingRootTableName || tableName\n  const columns: Record<string, PgColumnBuilder> = baseColumns\n  const indexes: Record<string, (cols: GenericColumns) => IndexBuilder> = {}\n\n  let hasLocalizedField = false\n  let hasLocalizedRelationshipField = false\n  let hasManyNumberField: 'index' | boolean = false\n  let hasLocalizedManyNumberField = false\n\n  const localesColumns: Record<string, PgColumnBuilder> = {}\n  const localesIndexes: Record<string, (cols: GenericColumns) => IndexBuilder> = {}\n  let localesTable: GenericTable\n  let numbersTable: GenericTable\n\n  // Relationships to the base collection\n  const relationships: Set<string> = rootRelationships || new Set()\n\n  let relationshipsTable: GenericTable\n\n  // Drizzle relations\n  const relationsToBuild: Map<string, string> = new Map()\n\n  const idField = fields.find((field) => fieldAffectsData(field) && field.name === 'id')\n  let idColType = 'integer'\n\n  if (idField) {\n    if (idField.type === 'number') {\n      idColType = 'numeric'\n      columns.id = numeric('id').primaryKey()\n    }\n\n    if (idField.type === 'text') {\n      idColType = 'varchar'\n      columns.id = varchar('id').primaryKey()\n    }\n  } else {\n    columns.id = serial('id').primaryKey()\n  }\n\n  ;({\n    hasLocalizedField,\n    hasLocalizedManyNumberField,\n    hasLocalizedRelationshipField,\n    hasManyNumberField,\n  } = traverseFields({\n    adapter,\n    buildNumbers,\n    buildRelationships,\n    columns,\n    disableNotNull,\n    disableUnique,\n    fields,\n    indexes,\n    localesColumns,\n    localesIndexes,\n    newTableName: tableName,\n    parentTableName: tableName,\n    relationsToBuild,\n    relationships,\n    rootRelationsToBuild: rootRelationsToBuild || relationsToBuild,\n    rootTableIDColType: rootTableIDColType || idColType,\n    rootTableName,\n  }))\n\n  if (timestamps) {\n    columns.createdAt = timestamp('created_at', {\n      mode: 'string',\n      precision: 3,\n      withTimezone: true,\n    })\n      .defaultNow()\n      .notNull()\n    columns.updatedAt = timestamp('updated_at', {\n      mode: 'string',\n      precision: 3,\n      withTimezone: true,\n    })\n      .defaultNow()\n      .notNull()\n  }\n\n  const table = pgTable(tableName, columns, (cols) => {\n    const extraConfig = Object.entries(baseExtraConfig).reduce((config, [key, func]) => {\n      config[key] = func(cols)\n      return config\n    }, {})\n\n    return Object.entries(indexes).reduce((acc, [colName, func]) => {\n      acc[colName] = func(cols)\n      return acc\n    }, extraConfig)\n  })\n\n  adapter.tables[tableName] = table\n\n  if (hasLocalizedField) {\n    const localeTableName = `${tableName}_locales`\n    localesColumns.id = serial('id').primaryKey()\n    localesColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n    localesColumns._parentID = parentIDColumnMap[idColType]('_parent_id')\n      .references(() => table.id, { onDelete: 'cascade' })\n      .notNull()\n\n    localesTable = pgTable(localeTableName, localesColumns, (cols) => {\n      return Object.entries(localesIndexes).reduce(\n        (acc, [colName, func]) => {\n          acc[colName] = func(cols)\n          return acc\n        },\n        {\n          _localeParent: unique(`${localeTableName}_locale_parent_id_unique`).on(\n            cols._locale,\n            cols._parentID,\n          ),\n        },\n      )\n    })\n\n    adapter.tables[localeTableName] = localesTable\n\n    const localesTableRelations = relations(localesTable, ({ one }) => ({\n      _parentID: one(table, {\n        fields: [localesTable._parentID],\n        references: [table.id],\n      }),\n    }))\n\n    adapter.relations[`relations_${localeTableName}`] = localesTableRelations\n  }\n\n  if (hasManyNumberField && buildNumbers) {\n    const numbersTableName = `${rootTableName}_numbers`\n    const columns: Record<string, PgColumnBuilder> = {\n      id: serial('id').primaryKey(),\n      number: numeric('number'),\n      order: integer('order').notNull(),\n      parent: parentIDColumnMap[idColType]('parent_id')\n        .references(() => table.id, { onDelete: 'cascade' })\n        .notNull(),\n      path: varchar('path').notNull(),\n    }\n\n    if (hasLocalizedManyNumberField) {\n      columns.locale = adapter.enums.enum__locales('locale')\n    }\n\n    numbersTable = pgTable(numbersTableName, columns, (cols) => {\n      const indexes: Record<string, IndexBuilder> = {\n        orderParentIdx: index('order_parent_idx').on(cols.order, cols.parent),\n      }\n\n      if (hasManyNumberField === 'index') {\n        indexes.numberIdx = index('number_idx').on(cols.number)\n      }\n\n      if (hasLocalizedManyNumberField) {\n        indexes.localeParent = index('locale_parent').on(cols.locale, cols.parent)\n      }\n\n      return indexes\n    })\n\n    adapter.tables[numbersTableName] = numbersTable\n\n    const numbersTableRelations = relations(numbersTable, ({ one }) => ({\n      parent: one(table, {\n        fields: [numbersTable.parent],\n        references: [table.id],\n      }),\n    }))\n\n    adapter.relations[`relations_${numbersTableName}`] = numbersTableRelations\n  }\n\n  if (buildRelationships) {\n    if (relationships.size) {\n      const relationshipColumns: Record<string, PgColumnBuilder> = {\n        id: serial('id').primaryKey(),\n        order: integer('order'),\n        parent: parentIDColumnMap[idColType]('parent_id')\n          .references(() => table.id, { onDelete: 'cascade' })\n          .notNull(),\n        path: varchar('path').notNull(),\n      }\n\n      if (hasLocalizedRelationshipField) {\n        relationshipColumns.locale = adapter.enums.enum__locales('locale')\n      }\n\n      relationships.forEach((relationTo) => {\n        const formattedRelationTo = toSnakeCase(relationTo)\n        let colType = 'integer'\n        const relatedCollectionCustomID = adapter.payload.collections[\n          relationTo\n        ].config.fields.find((field) => fieldAffectsData(field) && field.name === 'id')\n        if (relatedCollectionCustomID?.type === 'number') colType = 'numeric'\n        if (relatedCollectionCustomID?.type === 'text') colType = 'varchar'\n\n        relationshipColumns[`${relationTo}ID`] = parentIDColumnMap[colType](\n          `${formattedRelationTo}_id`,\n        ).references(() => adapter.tables[formattedRelationTo].id, { onDelete: 'cascade' })\n      })\n\n      const relationshipsTableName = `${tableName}_rels`\n\n      relationshipsTable = pgTable(relationshipsTableName, relationshipColumns, (cols) => {\n        const result: Record<string, unknown> = {\n          order: index('order_idx').on(cols.order),\n          parentIdx: index('parent_idx').on(cols.parent),\n          pathIdx: index('path_idx').on(cols.path),\n        }\n\n        if (hasLocalizedRelationshipField) {\n          result.localeIdx = index('locale_idx').on(cols.locale)\n        }\n\n        return result\n      })\n\n      adapter.tables[relationshipsTableName] = relationshipsTable\n\n      const relationshipsTableRelations = relations(relationshipsTable, ({ one }) => {\n        const result: Record<string, Relation<string>> = {\n          parent: one(table, {\n            fields: [relationshipsTable.parent],\n            references: [table.id],\n            relationName: '_rels',\n          }),\n        }\n\n        relationships.forEach((relationTo) => {\n          const relatedTableName = toSnakeCase(relationTo)\n          const idColumnName = `${relationTo}ID`\n          result[idColumnName] = one(adapter.tables[relatedTableName], {\n            fields: [relationshipsTable[idColumnName]],\n            references: [adapter.tables[relatedTableName].id],\n          })\n        })\n\n        return result\n      })\n\n      adapter.relations[`relations_${relationshipsTableName}`] = relationshipsTableRelations\n    }\n  }\n\n  const tableRelations = relations(table, ({ many }) => {\n    const result: Record<string, Relation<string>> = {}\n\n    relationsToBuild.forEach((val, key) => {\n      result[key] = many(adapter.tables[val])\n    })\n\n    if (hasLocalizedField) {\n      result._locales = many(localesTable)\n    }\n\n    if (hasManyNumberField) {\n      result._numbers = many(numbersTable)\n    }\n\n    if (relationships.size && relationshipsTable) {\n      result._rels = many(relationshipsTable, {\n        relationName: '_rels',\n      })\n    }\n\n    return result\n  })\n\n  adapter.relations[`relations_${tableName}`] = tableRelations\n\n  return { hasManyNumberField, relationsToBuild }\n}\n"],"names":["buildTable","adapter","baseColumns","baseExtraConfig","buildNumbers","buildRelationships","disableNotNull","disableUnique","fields","rootRelationsToBuild","rootRelationships","rootTableIDColType","rootTableName","incomingRootTableName","tableName","timestamps","columns","indexes","hasLocalizedField","hasLocalizedRelationshipField","hasManyNumberField","hasLocalizedManyNumberField","localesColumns","localesIndexes","localesTable","numbersTable","relationships","Set","relationshipsTable","relationsToBuild","Map","idField","find","field","fieldAffectsData","name","idColType","type","id","numeric","primaryKey","varchar","serial","traverseFields","newTableName","parentTableName","createdAt","timestamp","mode","precision","withTimezone","defaultNow","notNull","updatedAt","table","pgTable","cols","extraConfig","Object","entries","reduce","config","key","func","acc","colName","tables","localeTableName","_locale","enums","enum__locales","_parentID","parentIDColumnMap","references","onDelete","_localeParent","unique","on","localesTableRelations","relations","one","numbersTableName","number","order","integer","parent","path","locale","orderParentIdx","index","numberIdx","localeParent","numbersTableRelations","size","relationshipColumns","forEach","relationTo","formattedRelationTo","toSnakeCase","colType","relatedCollectionCustomID","payload","collections","relationshipsTableName","result","parentIdx","pathIdx","localeIdx","relationshipsTableRelations","relationName","relatedTableName","idColumnName","tableRelations","many","val","_locales","_numbers","_rels"],"mappings":"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"}
@@ -3,6 +3,7 @@ import type { Field, TabAsField } from 'payload/types';
3
3
  import type { GenericColumns, PostgresAdapter } from '../types';
4
4
  type Args = {
5
5
  adapter: PostgresAdapter;
6
+ buildNumbers: boolean;
6
7
  buildRelationships: boolean;
7
8
  columnPrefix?: string;
8
9
  columns: Record<string, PgColumnBuilder>;
@@ -28,6 +29,6 @@ type Result = {
28
29
  hasLocalizedRelationshipField: boolean;
29
30
  hasManyNumberField: 'index' | boolean;
30
31
  };
31
- export declare const traverseFields: ({ adapter, buildRelationships, columnPrefix, columns, disableNotNull, disableUnique, fieldPrefix, fields, forceLocalized, indexes, localesColumns, localesIndexes, newTableName, parentTableName, relationsToBuild, relationships, rootRelationsToBuild, rootTableIDColType, rootTableName, }: Args) => Result;
32
+ export declare const traverseFields: ({ adapter, buildNumbers, buildRelationships, columnPrefix, columns, disableNotNull, disableUnique, fieldPrefix, fields, forceLocalized, indexes, localesColumns, localesIndexes, newTableName, parentTableName, relationsToBuild, relationships, rootRelationsToBuild, rootTableIDColType, rootTableName, }: Args) => Result;
32
33
  export {};
33
34
  //# sourceMappingURL=traverseFields.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"traverseFields.d.ts","sourceRoot":"","sources":["../../src/schema/traverseFields.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,YAAY,EAAE,eAAe,EAA2B,MAAM,qBAAqB,CAAA;AAcjG,OAAO,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAKtD,OAAO,KAAK,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAS/D,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,kBAAkB,EAAE,OAAO,CAAA;IAC3B,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IACxC,cAAc,EAAE,OAAO,CAAA;IACvB,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,MAAM,EAAE,CAAC,KAAK,GAAG,UAAU,CAAC,EAAE,CAAA;IAC9B,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,YAAY,CAAC,CAAA;IAC/D,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IAC/C,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,YAAY,CAAC,CAAA;IACtE,YAAY,EAAE,MAAM,CAAA;IACpB,eAAe,EAAE,MAAM,CAAA;IACvB,gBAAgB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IACrC,aAAa,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IAC1B,oBAAoB,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IAC1C,kBAAkB,EAAE,MAAM,CAAA;IAC1B,aAAa,EAAE,MAAM,CAAA;CACtB,CAAA;AAED,KAAK,MAAM,GAAG;IACZ,iBAAiB,EAAE,OAAO,CAAA;IAC1B,2BAA2B,EAAE,OAAO,CAAA;IACpC,6BAA6B,EAAE,OAAO,CAAA;IACtC,kBAAkB,EAAE,OAAO,GAAG,OAAO,CAAA;CACtC,CAAA;AAED,eAAO,MAAM,cAAc,kSAoBxB,IAAI,KAAG,MA6fT,CAAA"}
1
+ {"version":3,"file":"traverseFields.d.ts","sourceRoot":"","sources":["../../src/schema/traverseFields.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,eAAe,EAA2B,MAAM,qBAAqB,CAAA;AACjG,OAAO,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAoBtD,OAAO,KAAK,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAS/D,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,YAAY,EAAE,OAAO,CAAA;IACrB,kBAAkB,EAAE,OAAO,CAAA;IAC3B,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IACxC,cAAc,EAAE,OAAO,CAAA;IACvB,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,MAAM,EAAE,CAAC,KAAK,GAAG,UAAU,CAAC,EAAE,CAAA;IAC9B,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,YAAY,CAAC,CAAA;IAC/D,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IAC/C,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,YAAY,CAAC,CAAA;IACtE,YAAY,EAAE,MAAM,CAAA;IACpB,eAAe,EAAE,MAAM,CAAA;IACvB,gBAAgB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IACrC,aAAa,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IAC1B,oBAAoB,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IAC1C,kBAAkB,EAAE,MAAM,CAAA;IAC1B,aAAa,EAAE,MAAM,CAAA;CACtB,CAAA;AAED,KAAK,MAAM,GAAG;IACZ,iBAAiB,EAAE,OAAO,CAAA;IAC1B,2BAA2B,EAAE,OAAO,CAAA;IACpC,6BAA6B,EAAE,OAAO,CAAA;IACtC,kBAAkB,EAAE,OAAO,GAAG,OAAO,CAAA;CACtC,CAAA;AAED,eAAO,MAAM,cAAc,gTAqBxB,IAAI,KAAG,MA+gBT,CAAA"}
@@ -10,8 +10,8 @@ Object.defineProperty(exports, "traverseFields", {
10
10
  });
11
11
  const _drizzleorm = require("drizzle-orm");
12
12
  const _pgcore = require("drizzle-orm/pg-core");
13
- const _types = require("payload/types");
14
13
  const _errors = require("payload/errors");
14
+ const _types = require("payload/types");
15
15
  const _tosnakecase = /*#__PURE__*/ _interop_require_default(require("to-snake-case"));
16
16
  const _hasLocalesTable = require("../utilities/hasLocalesTable");
17
17
  const _build = require("./build");
@@ -24,7 +24,7 @@ function _interop_require_default(obj) {
24
24
  default: obj
25
25
  };
26
26
  }
27
- const traverseFields = ({ adapter, buildRelationships, columnPrefix, columns, disableNotNull, disableUnique = false, fieldPrefix, fields, forceLocalized, indexes, localesColumns, localesIndexes, newTableName, parentTableName, relationsToBuild, relationships, rootRelationsToBuild, rootTableIDColType, rootTableName })=>{
27
+ const traverseFields = ({ adapter, buildNumbers, buildRelationships, columnPrefix, columns, disableNotNull, disableUnique = false, fieldPrefix, fields, forceLocalized, indexes, localesColumns, localesIndexes, newTableName, parentTableName, relationsToBuild, relationships, rootRelationsToBuild, rootTableIDColType, rootTableName })=>{
28
28
  let hasLocalizedField = false;
29
29
  let hasLocalizedRelationshipField = false;
30
30
  let hasManyNumberField = false;
@@ -200,7 +200,7 @@ const traverseFields = ({ adapter, buildRelationships, columnPrefix, columns, di
200
200
  baseColumns._locale = adapter.enums.enum__locales('_locale').notNull();
201
201
  baseExtraConfig._localeIdx = (cols)=>(0, _pgcore.index)('_locale_idx').on(cols._locale);
202
202
  }
203
- const { relationsToBuild: subRelationsToBuild } = (0, _build.buildTable)({
203
+ const { hasManyNumberField: subHasManyNumberField, relationsToBuild: subRelationsToBuild } = (0, _build.buildTable)({
204
204
  adapter,
205
205
  baseColumns,
206
206
  baseExtraConfig,
@@ -213,6 +213,9 @@ const traverseFields = ({ adapter, buildRelationships, columnPrefix, columns, di
213
213
  rootTableName,
214
214
  tableName: arrayTableName
215
215
  });
216
+ if (subHasManyNumberField) {
217
+ if (!hasManyNumberField || subHasManyNumberField === 'index') hasManyNumberField = subHasManyNumberField;
218
+ }
216
219
  relationsToBuild.set(fieldName, arrayTableName);
217
220
  const arrayTableRelations = (0, _drizzleorm.relations)(adapter.tables[arrayTableName], ({ many, one })=>{
218
221
  const result = {
@@ -258,7 +261,7 @@ const traverseFields = ({ adapter, buildRelationships, columnPrefix, columns, di
258
261
  baseColumns._locale = adapter.enums.enum__locales('_locale').notNull();
259
262
  baseExtraConfig._localeIdx = (cols)=>(0, _pgcore.index)('locale_idx').on(cols._locale);
260
263
  }
261
- const { relationsToBuild: subRelationsToBuild } = (0, _build.buildTable)({
264
+ const { hasManyNumberField: subHasManyNumberField, relationsToBuild: subRelationsToBuild } = (0, _build.buildTable)({
262
265
  adapter,
263
266
  baseColumns,
264
267
  baseExtraConfig,
@@ -271,6 +274,9 @@ const traverseFields = ({ adapter, buildRelationships, columnPrefix, columns, di
271
274
  rootTableName,
272
275
  tableName: blockTableName
273
276
  });
277
+ if (subHasManyNumberField) {
278
+ if (!hasManyNumberField || subHasManyNumberField === 'index') hasManyNumberField = subHasManyNumberField;
279
+ }
274
280
  const blockTableRelations = (0, _drizzleorm.relations)(adapter.tables[blockTableName], ({ many, one })=>{
275
281
  const result = {
276
282
  _parentID: one(adapter.tables[rootTableName], {
@@ -309,6 +315,7 @@ const traverseFields = ({ adapter, buildRelationships, columnPrefix, columns, di
309
315
  if (!('name' in field)) {
310
316
  const { hasLocalizedField: groupHasLocalizedField, hasLocalizedManyNumberField: groupHasLocalizedManyNumberField, hasLocalizedRelationshipField: groupHasLocalizedRelationshipField, hasManyNumberField: groupHasManyNumberField } = traverseFields({
311
317
  adapter,
318
+ buildNumbers,
312
319
  buildRelationships,
313
320
  columnPrefix,
314
321
  columns,
@@ -337,6 +344,7 @@ const traverseFields = ({ adapter, buildRelationships, columnPrefix, columns, di
337
344
  const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull;
338
345
  const { hasLocalizedField: groupHasLocalizedField, hasLocalizedManyNumberField: groupHasLocalizedManyNumberField, hasLocalizedRelationshipField: groupHasLocalizedRelationshipField, hasManyNumberField: groupHasManyNumberField } = traverseFields({
339
346
  adapter,
347
+ buildNumbers,
340
348
  buildRelationships,
341
349
  columnPrefix: `${columnName}_`,
342
350
  columns,
@@ -367,6 +375,7 @@ const traverseFields = ({ adapter, buildRelationships, columnPrefix, columns, di
367
375
  const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull;
368
376
  const { hasLocalizedField: tabHasLocalizedField, hasLocalizedManyNumberField: tabHasLocalizedManyNumberField, hasLocalizedRelationshipField: tabHasLocalizedRelationshipField, hasManyNumberField: tabHasManyNumberField } = traverseFields({
369
377
  adapter,
378
+ buildNumbers,
370
379
  buildRelationships,
371
380
  columnPrefix,
372
381
  columns,
@@ -401,6 +410,7 @@ const traverseFields = ({ adapter, buildRelationships, columnPrefix, columns, di
401
410
  const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull;
402
411
  const { hasLocalizedField: rowHasLocalizedField, hasLocalizedManyNumberField: rowHasLocalizedManyNumberField, hasLocalizedRelationshipField: rowHasLocalizedRelationshipField, hasManyNumberField: rowHasManyNumberField } = traverseFields({
403
412
  adapter,
413
+ buildNumbers,
404
414
  buildRelationships,
405
415
  columnPrefix,
406
416
  columns,
@@ -453,4 +463,4 @@ const traverseFields = ({ adapter, buildRelationships, columnPrefix, columns, di
453
463
  };
454
464
  };
455
465
 
456
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/schema/traverseFields.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { Relation } from 'drizzle-orm'\nimport { relations } from 'drizzle-orm'\nimport type { IndexBuilder, PgColumnBuilder, UniqueConstraintBuilder } from 'drizzle-orm/pg-core'\nimport {\n  boolean,\n  index,\n  integer,\n  jsonb,\n  numeric,\n  pgEnum,\n  PgNumericBuilder,\n  PgVarcharBuilder,\n  text,\n  timestamp,\n  varchar,\n} from 'drizzle-orm/pg-core'\nimport type { Field, TabAsField } from 'payload/types'\nimport { fieldAffectsData, optionIsObject } from 'payload/types'\nimport { InvalidConfiguration } from 'payload/errors'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { GenericColumns, PostgresAdapter } from '../types'\n\nimport { hasLocalesTable } from '../utilities/hasLocalesTable'\nimport { buildTable } from './build'\nimport { createIndex } from './createIndex'\nimport { idToUUID } from './idToUUID'\nimport { parentIDColumnMap } from './parentIDColumnMap'\nimport { validateExistingBlockIsIdentical } from './validateExistingBlockIsIdentical'\n\ntype Args = {\n  adapter: PostgresAdapter\n  buildRelationships: boolean\n  columnPrefix?: string\n  columns: Record<string, PgColumnBuilder>\n  disableNotNull: boolean\n  disableUnique?: boolean\n  fieldPrefix?: string\n  fields: (Field | TabAsField)[]\n  forceLocalized?: boolean\n  indexes: Record<string, (cols: GenericColumns) => IndexBuilder>\n  localesColumns: Record<string, PgColumnBuilder>\n  localesIndexes: Record<string, (cols: GenericColumns) => IndexBuilder>\n  newTableName: string\n  parentTableName: string\n  relationsToBuild: Map<string, string>\n  relationships: Set<string>\n  rootRelationsToBuild?: Map<string, string>\n  rootTableIDColType: string\n  rootTableName: string\n}\n\ntype Result = {\n  hasLocalizedField: boolean\n  hasLocalizedManyNumberField: boolean\n  hasLocalizedRelationshipField: boolean\n  hasManyNumberField: 'index' | boolean\n}\n\nexport const traverseFields = ({\n  adapter,\n  buildRelationships,\n  columnPrefix,\n  columns,\n  disableNotNull,\n  disableUnique = false,\n  fieldPrefix,\n  fields,\n  forceLocalized,\n  indexes,\n  localesColumns,\n  localesIndexes,\n  newTableName,\n  parentTableName,\n  relationsToBuild,\n  relationships,\n  rootRelationsToBuild,\n  rootTableIDColType,\n  rootTableName,\n}: Args): Result => {\n  let hasLocalizedField = false\n  let hasLocalizedRelationshipField = false\n  let hasManyNumberField: 'index' | boolean = false\n  let hasLocalizedManyNumberField = false\n\n  let parentIDColType = 'integer'\n  if (columns.id instanceof PgNumericBuilder) parentIDColType = 'numeric'\n  if (columns.id instanceof PgVarcharBuilder) parentIDColType = 'varchar'\n\n  fields.forEach((field) => {\n    if ('name' in field && field.name === 'id') return\n    let columnName: string\n    let fieldName: string\n\n    let targetTable = columns\n    let targetIndexes = indexes\n\n    if (fieldAffectsData(field)) {\n      columnName = `${columnPrefix || ''}${field.name[0] === '_' ? '_' : ''}${toSnakeCase(\n        field.name,\n      )}`\n      fieldName = `${fieldPrefix?.replace('.', '_') || ''}${field.name}`\n\n      // If field is localized,\n      // add the column to the locale table instead of main table\n      if (adapter.payload.config.localization && (field.localized || forceLocalized)) {\n        hasLocalizedField = true\n        targetTable = localesColumns\n        targetIndexes = localesIndexes\n      }\n\n      if (\n        (field.unique || field.index) &&\n        !['array', 'blocks', 'group', 'point', 'relationship', 'upload'].includes(field.type) &&\n        !(field.type === 'number' && field.hasMany === true)\n      ) {\n        const unique = disableUnique !== true && field.unique\n        if (unique) {\n          const constraintValue = `${fieldPrefix || ''}${field.name}`\n          if (!adapter.fieldConstraints?.[rootTableName]) {\n            adapter.fieldConstraints[rootTableName] = {}\n          }\n          adapter.fieldConstraints[rootTableName][`${columnName}_idx`] = constraintValue\n        }\n        targetIndexes[`${field.name}Idx`] = createIndex({\n          name: fieldName,\n          columnName,\n          unique,\n        })\n      }\n    }\n\n    switch (field.type) {\n      case 'text':\n      case 'email':\n      case 'code':\n      case 'textarea': {\n        targetTable[fieldName] = varchar(columnName)\n        break\n      }\n\n      case 'number': {\n        if (field.hasMany) {\n          if (field.localized) {\n            hasLocalizedManyNumberField = true\n          }\n\n          if (field.index) {\n            hasManyNumberField = 'index'\n          } else if (!hasManyNumberField) {\n            hasManyNumberField = true\n          }\n\n          if (field.unique) {\n            throw new InvalidConfiguration(\n              'Unique is not supported in Postgres for hasMany number fields.',\n            )\n          }\n        } else {\n          targetTable[fieldName] = numeric(columnName)\n        }\n        break\n      }\n\n      case 'richText':\n      case 'json': {\n        targetTable[fieldName] = jsonb(columnName)\n        break\n      }\n\n      case 'date': {\n        targetTable[fieldName] = timestamp(columnName, {\n          mode: 'string',\n          precision: 3,\n          withTimezone: true,\n        })\n        break\n      }\n\n      case 'point': {\n        break\n      }\n\n      case 'radio':\n      case 'select': {\n        const enumName = `enum_${newTableName}_${toSnakeCase(field.name)}`\n\n        adapter.enums[enumName] = pgEnum(\n          enumName,\n          field.options.map((option) => {\n            if (optionIsObject(option)) {\n              return option.value\n            }\n\n            return option\n          }) as [string, ...string[]],\n        )\n\n        if (field.type === 'select' && field.hasMany) {\n          const selectTableName = `${newTableName}_${toSnakeCase(field.name)}`\n          const baseColumns: Record<string, PgColumnBuilder> = {\n            order: integer('order').notNull(),\n            parent: parentIDColumnMap[parentIDColType]('parent_id')\n              .references(() => adapter.tables[parentTableName].id, { onDelete: 'cascade' })\n              .notNull(),\n            value: adapter.enums[enumName]('value'),\n          }\n\n          const baseExtraConfig: Record<\n            string,\n            (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n          > = {\n            orderIdx: (cols) => index('order_idx').on(cols.order),\n            parentIdx: (cols) => index('parent_idx').on(cols.parent),\n          }\n\n          if (field.localized) {\n            baseColumns.locale = adapter.enums.enum__locales('locale').notNull()\n            baseExtraConfig.localeIdx = (cols) => index('locale_idx').on(cols.locale)\n          }\n\n          if (field.index) {\n            baseExtraConfig.value = (cols) => index('value_idx').on(cols.value)\n          }\n\n          buildTable({\n            adapter,\n            baseColumns,\n            baseExtraConfig,\n            disableNotNull,\n            disableUnique,\n            fields: [],\n            tableName: selectTableName,\n          })\n\n          relationsToBuild.set(fieldName, selectTableName)\n\n          const selectTableRelations = relations(adapter.tables[selectTableName], ({ one }) => {\n            const result: Record<string, Relation<string>> = {\n              parent: one(adapter.tables[parentTableName], {\n                fields: [adapter.tables[selectTableName].parent],\n                references: [adapter.tables[parentTableName].id],\n              }),\n            }\n\n            return result\n          })\n\n          adapter.relations[`relation_${selectTableName}`] = selectTableRelations\n        } else {\n          targetTable[fieldName] = adapter.enums[enumName](fieldName)\n        }\n        break\n      }\n\n      case 'checkbox': {\n        targetTable[fieldName] = boolean(columnName)\n        break\n      }\n\n      case 'array': {\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n        const arrayTableName = `${newTableName}_${toSnakeCase(field.name)}`\n        const baseColumns: Record<string, PgColumnBuilder> = {\n          _order: integer('_order').notNull(),\n          _parentID: parentIDColumnMap[parentIDColType]('_parent_id')\n            .references(() => adapter.tables[parentTableName].id, { onDelete: 'cascade' })\n            .notNull(),\n        }\n\n        const baseExtraConfig: Record<\n          string,\n          (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n        > = {\n          _orderIdx: (cols) => index('_order_idx').on(cols._order),\n          _parentIDIdx: (cols) => index('_parent_id_idx').on(cols._parentID),\n        }\n\n        if (field.localized && adapter.payload.config.localization) {\n          baseColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n          baseExtraConfig._localeIdx = (cols) => index('_locale_idx').on(cols._locale)\n        }\n\n        const { relationsToBuild: subRelationsToBuild } = buildTable({\n          adapter,\n          baseColumns,\n          baseExtraConfig,\n          disableNotNull: disableNotNullFromHere,\n          disableUnique,\n          fields: disableUnique ? idToUUID(field.fields) : field.fields,\n          rootRelationsToBuild,\n          rootRelationships: relationships,\n          rootTableIDColType,\n          rootTableName,\n          tableName: arrayTableName,\n        })\n\n        relationsToBuild.set(fieldName, arrayTableName)\n\n        const arrayTableRelations = relations(adapter.tables[arrayTableName], ({ many, one }) => {\n          const result: Record<string, Relation<string>> = {\n            _parentID: one(adapter.tables[parentTableName], {\n              fields: [adapter.tables[arrayTableName]._parentID],\n              references: [adapter.tables[parentTableName].id],\n            }),\n          }\n\n          if (hasLocalesTable(field.fields)) {\n            result._locales = many(adapter.tables[`${arrayTableName}_locales`])\n          }\n\n          subRelationsToBuild.forEach((val, key) => {\n            result[key] = many(adapter.tables[val])\n          })\n\n          return result\n        })\n\n        adapter.relations[`relations_${arrayTableName}`] = arrayTableRelations\n\n        break\n      }\n\n      case 'blocks': {\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n        field.blocks.forEach((block) => {\n          const blockTableName = `${rootTableName}_blocks_${toSnakeCase(block.slug)}`\n          if (!adapter.tables[blockTableName]) {\n            const baseColumns: Record<string, PgColumnBuilder> = {\n              _order: integer('_order').notNull(),\n              _parentID: parentIDColumnMap[rootTableIDColType]('_parent_id')\n                .references(() => adapter.tables[rootTableName].id, { onDelete: 'cascade' })\n                .notNull(),\n              _path: text('_path').notNull(),\n            }\n\n            const baseExtraConfig: Record<\n              string,\n              (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n            > = {\n              _orderIdx: (cols) => index('order_idx').on(cols._order),\n              _parentIDIdx: (cols) => index('parent_id_idx').on(cols._parentID),\n              _pathIdx: (cols) => index('path_idx').on(cols._path),\n            }\n\n            if (field.localized && adapter.payload.config.localization) {\n              baseColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n              baseExtraConfig._localeIdx = (cols) => index('locale_idx').on(cols._locale)\n            }\n\n            const { relationsToBuild: subRelationsToBuild } = buildTable({\n              adapter,\n              baseColumns,\n              baseExtraConfig,\n              disableNotNull: disableNotNullFromHere,\n              disableUnique,\n              fields: disableUnique ? idToUUID(block.fields) : block.fields,\n              rootRelationsToBuild,\n              rootRelationships: relationships,\n              rootTableIDColType,\n              rootTableName,\n              tableName: blockTableName,\n            })\n\n            const blockTableRelations = relations(\n              adapter.tables[blockTableName],\n              ({ many, one }) => {\n                const result: Record<string, Relation<string>> = {\n                  _parentID: one(adapter.tables[rootTableName], {\n                    fields: [adapter.tables[blockTableName]._parentID],\n                    references: [adapter.tables[rootTableName].id],\n                  }),\n                }\n\n                if (hasLocalesTable(block.fields)) {\n                  result._locales = many(adapter.tables[`${blockTableName}_locales`])\n                }\n\n                subRelationsToBuild.forEach((val, key) => {\n                  result[key] = many(adapter.tables[val])\n                })\n\n                return result\n              },\n            )\n\n            adapter.relations[`relations_${blockTableName}`] = blockTableRelations\n          } else if (process.env.NODE_ENV !== 'production') {\n            validateExistingBlockIsIdentical({\n              block,\n              localized: field.localized,\n              rootTableName,\n              table: adapter.tables[blockTableName],\n            })\n          }\n\n          rootRelationsToBuild.set(`_blocks_${block.slug}`, blockTableName)\n        })\n\n        break\n      }\n\n      case 'tab':\n      case 'group': {\n        if (!('name' in field)) {\n          const {\n            hasLocalizedField: groupHasLocalizedField,\n            hasLocalizedManyNumberField: groupHasLocalizedManyNumberField,\n            hasLocalizedRelationshipField: groupHasLocalizedRelationshipField,\n            hasManyNumberField: groupHasManyNumberField,\n          } = traverseFields({\n            adapter,\n            buildRelationships,\n            columnPrefix,\n            columns,\n            disableNotNull,\n            disableUnique,\n            fieldPrefix,\n            fields: field.fields,\n            forceLocalized,\n            indexes,\n            localesColumns,\n            localesIndexes,\n            newTableName,\n            parentTableName,\n            relationsToBuild,\n            relationships,\n            rootRelationsToBuild,\n            rootTableIDColType,\n            rootTableName,\n          })\n\n          if (groupHasLocalizedField) hasLocalizedField = true\n          if (groupHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n          if (groupHasManyNumberField) hasManyNumberField = true\n          if (groupHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n          break\n        }\n\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n        const {\n          hasLocalizedField: groupHasLocalizedField,\n          hasLocalizedManyNumberField: groupHasLocalizedManyNumberField,\n          hasLocalizedRelationshipField: groupHasLocalizedRelationshipField,\n          hasManyNumberField: groupHasManyNumberField,\n        } = traverseFields({\n          adapter,\n          buildRelationships,\n          columnPrefix: `${columnName}_`,\n          columns,\n          disableNotNull: disableNotNullFromHere,\n          disableUnique,\n          fieldPrefix: `${fieldName}.`,\n          fields: field.fields,\n          forceLocalized: field.localized,\n          indexes,\n          localesColumns,\n          localesIndexes,\n          newTableName: `${parentTableName}_${columnName}`,\n          parentTableName,\n          relationsToBuild,\n          relationships,\n          rootRelationsToBuild,\n          rootTableIDColType,\n          rootTableName,\n        })\n\n        if (groupHasLocalizedField) hasLocalizedField = true\n        if (groupHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n        if (groupHasManyNumberField) hasManyNumberField = true\n        if (groupHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n        break\n      }\n\n      case 'tabs': {\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n        const {\n          hasLocalizedField: tabHasLocalizedField,\n          hasLocalizedManyNumberField: tabHasLocalizedManyNumberField,\n          hasLocalizedRelationshipField: tabHasLocalizedRelationshipField,\n          hasManyNumberField: tabHasManyNumberField,\n        } = traverseFields({\n          adapter,\n          buildRelationships,\n          columnPrefix,\n          columns,\n          disableNotNull: disableNotNullFromHere,\n          disableUnique,\n          fieldPrefix,\n          fields: field.tabs.map((tab) => ({ ...tab, type: 'tab' })),\n          forceLocalized,\n          indexes,\n          localesColumns,\n          localesIndexes,\n          newTableName,\n          parentTableName,\n          relationsToBuild,\n          relationships,\n          rootRelationsToBuild,\n          rootTableIDColType,\n          rootTableName,\n        })\n\n        if (tabHasLocalizedField) hasLocalizedField = true\n        if (tabHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n        if (tabHasManyNumberField) hasManyNumberField = true\n        if (tabHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n\n        break\n      }\n\n      case 'row':\n      case 'collapsible': {\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n        const {\n          hasLocalizedField: rowHasLocalizedField,\n          hasLocalizedManyNumberField: rowHasLocalizedManyNumberField,\n          hasLocalizedRelationshipField: rowHasLocalizedRelationshipField,\n          hasManyNumberField: rowHasManyNumberField,\n        } = traverseFields({\n          adapter,\n          buildRelationships,\n          columnPrefix,\n          columns,\n          disableNotNull: disableNotNullFromHere,\n          disableUnique,\n          fieldPrefix,\n          fields: field.fields,\n          forceLocalized,\n          indexes,\n          localesColumns,\n          localesIndexes,\n          newTableName: parentTableName,\n          parentTableName,\n          relationsToBuild,\n          relationships,\n          rootRelationsToBuild,\n          rootTableIDColType,\n          rootTableName,\n        })\n\n        if (rowHasLocalizedField) hasLocalizedField = true\n        if (rowHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n        if (rowHasManyNumberField) hasManyNumberField = true\n        if (rowHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n        break\n      }\n\n      case 'relationship':\n      case 'upload':\n        if (Array.isArray(field.relationTo)) {\n          field.relationTo.forEach((relation) => relationships.add(relation))\n        } else {\n          relationships.add(field.relationTo)\n        }\n\n        if (field.localized && adapter.payload.config.localization) {\n          hasLocalizedRelationshipField = true\n        }\n        break\n\n      default:\n        break\n    }\n\n    const condition = field.admin && field.admin.condition\n\n    if (\n      !disableNotNull &&\n      targetTable[fieldName] &&\n      'required' in field &&\n      field.required &&\n      !condition\n    ) {\n      targetTable[fieldName].notNull()\n    }\n  })\n\n  return {\n    hasLocalizedField,\n    hasLocalizedManyNumberField,\n    hasLocalizedRelationshipField,\n    hasManyNumberField,\n  }\n}\n"],"names":["traverseFields","adapter","buildRelationships","columnPrefix","columns","disableNotNull","disableUnique","fieldPrefix","fields","forceLocalized","indexes","localesColumns","localesIndexes","newTableName","parentTableName","relationsToBuild","relationships","rootRelationsToBuild","rootTableIDColType","rootTableName","hasLocalizedField","hasLocalizedRelationshipField","hasManyNumberField","hasLocalizedManyNumberField","parentIDColType","id","PgNumericBuilder","PgVarcharBuilder","forEach","field","name","columnName","fieldName","targetTable","targetIndexes","fieldAffectsData","toSnakeCase","replace","payload","config","localization","localized","unique","index","includes","type","hasMany","constraintValue","fieldConstraints","createIndex","varchar","InvalidConfiguration","numeric","jsonb","timestamp","mode","precision","withTimezone","enumName","enums","pgEnum","options","map","option","optionIsObject","value","selectTableName","baseColumns","order","integer","notNull","parent","parentIDColumnMap","references","tables","onDelete","baseExtraConfig","orderIdx","cols","on","parentIdx","locale","enum__locales","localeIdx","buildTable","tableName","set","selectTableRelations","relations","one","result","boolean","disableNotNullFromHere","Boolean","admin","condition","arrayTableName","_order","_parentID","_orderIdx","_parentIDIdx","_locale","_localeIdx","subRelationsToBuild","idToUUID","rootRelationships","arrayTableRelations","many","hasLocalesTable","_locales","val","key","blocks","block","blockTableName","slug","_path","text","_pathIdx","blockTableRelations","process","env","NODE_ENV","validateExistingBlockIsIdentical","table","groupHasLocalizedField","groupHasLocalizedManyNumberField","groupHasLocalizedRelationshipField","groupHasManyNumberField","tabHasLocalizedField","tabHasLocalizedManyNumberField","tabHasLocalizedRelationshipField","tabHasManyNumberField","tabs","tab","rowHasLocalizedField","rowHasLocalizedManyNumberField","rowHasLocalizedRelationshipField","rowHasManyNumberField","Array","isArray","relationTo","relation","add","required"],"mappings":"AAAA,oCAAoC;;;;+BA4DvBA;;;eAAAA;;;4BA1Da;wBAcnB;uBAE0C;wBACZ;oEACb;iCAIQ;uBACL;6BACC;0BACH;mCACS;kDACe;;;;;;AA+B1C,MAAMA,iBAAiB,CAAC,EAC7BC,OAAO,EACPC,kBAAkB,EAClBC,YAAY,EACZC,OAAO,EACPC,cAAc,EACdC,gBAAgB,KAAK,EACrBC,WAAW,EACXC,MAAM,EACNC,cAAc,EACdC,OAAO,EACPC,cAAc,EACdC,cAAc,EACdC,YAAY,EACZC,eAAe,EACfC,gBAAgB,EAChBC,aAAa,EACbC,oBAAoB,EACpBC,kBAAkB,EAClBC,aAAa,EACR;IACL,IAAIC,oBAAoB;IACxB,IAAIC,gCAAgC;IACpC,IAAIC,qBAAwC;IAC5C,IAAIC,8BAA8B;IAElC,IAAIC,kBAAkB;IACtB,IAAIpB,QAAQqB,EAAE,YAAYC,wBAAgB,EAAEF,kBAAkB;IAC9D,IAAIpB,QAAQqB,EAAE,YAAYE,wBAAgB,EAAEH,kBAAkB;IAE9DhB,OAAOoB,OAAO,CAAC,CAACC;QACd,IAAI,UAAUA,SAASA,MAAMC,IAAI,KAAK,MAAM;QAC5C,IAAIC;QACJ,IAAIC;QAEJ,IAAIC,cAAc7B;QAClB,IAAI8B,gBAAgBxB;QAEpB,IAAIyB,IAAAA,uBAAgB,EAACN,QAAQ;YAC3BE,aAAa,CAAC,EAAE5B,gBAAgB,GAAG,EAAE0B,MAAMC,IAAI,CAAC,EAAE,KAAK,MAAM,MAAM,GAAG,EAAEM,IAAAA,oBAAW,EACjFP,MAAMC,IAAI,EACV,CAAC;YACHE,YAAY,CAAC,EAAEzB,aAAa8B,QAAQ,KAAK,QAAQ,GAAG,EAAER,MAAMC,IAAI,CAAC,CAAC;YAElE,yBAAyB;YACzB,2DAA2D;YAC3D,IAAI7B,QAAQqC,OAAO,CAACC,MAAM,CAACC,YAAY,IAAKX,CAAAA,MAAMY,SAAS,IAAIhC,cAAa,GAAI;gBAC9EW,oBAAoB;gBACpBa,cAActB;gBACduB,gBAAgBtB;YAClB;YAEA,IACE,AAACiB,CAAAA,MAAMa,MAAM,IAAIb,MAAMc,KAAK,AAAD,KAC3B,CAAC;gBAAC;gBAAS;gBAAU;gBAAS;gBAAS;gBAAgB;aAAS,CAACC,QAAQ,CAACf,MAAMgB,IAAI,KACpF,CAAEhB,CAAAA,MAAMgB,IAAI,KAAK,YAAYhB,MAAMiB,OAAO,KAAK,IAAG,GAClD;gBACA,MAAMJ,SAASpC,kBAAkB,QAAQuB,MAAMa,MAAM;gBACrD,IAAIA,QAAQ;oBACV,MAAMK,kBAAkB,CAAC,EAAExC,eAAe,GAAG,EAAEsB,MAAMC,IAAI,CAAC,CAAC;oBAC3D,IAAI,CAAC7B,QAAQ+C,gBAAgB,EAAE,CAAC7B,cAAc,EAAE;wBAC9ClB,QAAQ+C,gBAAgB,CAAC7B,cAAc,GAAG,CAAC;oBAC7C;oBACAlB,QAAQ+C,gBAAgB,CAAC7B,cAAc,CAAC,CAAC,EAAEY,WAAW,IAAI,CAAC,CAAC,GAAGgB;gBACjE;gBACAb,aAAa,CAAC,CAAC,EAAEL,MAAMC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAGmB,IAAAA,wBAAW,EAAC;oBAC9CnB,MAAME;oBACND;oBACAW;gBACF;YACF;QACF;QAEA,OAAQb,MAAMgB,IAAI;YAChB,KAAK;YACL,KAAK;YACL,KAAK;YACL,KAAK;gBAAY;oBACfZ,WAAW,CAACD,UAAU,GAAGkB,IAAAA,eAAO,EAACnB;oBACjC;gBACF;YAEA,KAAK;gBAAU;oBACb,IAAIF,MAAMiB,OAAO,EAAE;wBACjB,IAAIjB,MAAMY,SAAS,EAAE;4BACnBlB,8BAA8B;wBAChC;wBAEA,IAAIM,MAAMc,KAAK,EAAE;4BACfrB,qBAAqB;wBACvB,OAAO,IAAI,CAACA,oBAAoB;4BAC9BA,qBAAqB;wBACvB;wBAEA,IAAIO,MAAMa,MAAM,EAAE;4BAChB,MAAM,IAAIS,4BAAoB,CAC5B;wBAEJ;oBACF,OAAO;wBACLlB,WAAW,CAACD,UAAU,GAAGoB,IAAAA,eAAO,EAACrB;oBACnC;oBACA;gBACF;YAEA,KAAK;YACL,KAAK;gBAAQ;oBACXE,WAAW,CAACD,UAAU,GAAGqB,IAAAA,aAAK,EAACtB;oBAC/B;gBACF;YAEA,KAAK;gBAAQ;oBACXE,WAAW,CAACD,UAAU,GAAGsB,IAAAA,iBAAS,EAACvB,YAAY;wBAC7CwB,MAAM;wBACNC,WAAW;wBACXC,cAAc;oBAChB;oBACA;gBACF;YAEA,KAAK;gBAAS;oBACZ;gBACF;YAEA,KAAK;YACL,KAAK;gBAAU;oBACb,MAAMC,WAAW,CAAC,KAAK,EAAE7C,aAAa,CAAC,EAAEuB,IAAAA,oBAAW,EAACP,MAAMC,IAAI,EAAE,CAAC;oBAElE7B,QAAQ0D,KAAK,CAACD,SAAS,GAAGE,IAAAA,cAAM,EAC9BF,UACA7B,MAAMgC,OAAO,CAACC,GAAG,CAAC,CAACC;wBACjB,IAAIC,IAAAA,qBAAc,EAACD,SAAS;4BAC1B,OAAOA,OAAOE,KAAK;wBACrB;wBAEA,OAAOF;oBACT;oBAGF,IAAIlC,MAAMgB,IAAI,KAAK,YAAYhB,MAAMiB,OAAO,EAAE;wBAC5C,MAAMoB,kBAAkB,CAAC,EAAErD,aAAa,CAAC,EAAEuB,IAAAA,oBAAW,EAACP,MAAMC,IAAI,EAAE,CAAC;wBACpE,MAAMqC,cAA+C;4BACnDC,OAAOC,IAAAA,eAAO,EAAC,SAASC,OAAO;4BAC/BC,QAAQC,oCAAiB,CAAChD,gBAAgB,CAAC,aACxCiD,UAAU,CAAC,IAAMxE,QAAQyE,MAAM,CAAC5D,gBAAgB,CAACW,EAAE,EAAE;gCAAEkD,UAAU;4BAAU,GAC3EL,OAAO;4BACVL,OAAOhE,QAAQ0D,KAAK,CAACD,SAAS,CAAC;wBACjC;wBAEA,MAAMkB,kBAGF;4BACFC,UAAU,CAACC,OAASnC,IAAAA,aAAK,EAAC,aAAaoC,EAAE,CAACD,KAAKV,KAAK;4BACpDY,WAAW,CAACF,OAASnC,IAAAA,aAAK,EAAC,cAAcoC,EAAE,CAACD,KAAKP,MAAM;wBACzD;wBAEA,IAAI1C,MAAMY,SAAS,EAAE;4BACnB0B,YAAYc,MAAM,GAAGhF,QAAQ0D,KAAK,CAACuB,aAAa,CAAC,UAAUZ,OAAO;4BAClEM,gBAAgBO,SAAS,GAAG,CAACL,OAASnC,IAAAA,aAAK,EAAC,cAAcoC,EAAE,CAACD,KAAKG,MAAM;wBAC1E;wBAEA,IAAIpD,MAAMc,KAAK,EAAE;4BACfiC,gBAAgBX,KAAK,GAAG,CAACa,OAASnC,IAAAA,aAAK,EAAC,aAAaoC,EAAE,CAACD,KAAKb,KAAK;wBACpE;wBAEAmB,IAAAA,iBAAU,EAAC;4BACTnF;4BACAkE;4BACAS;4BACAvE;4BACAC;4BACAE,QAAQ,EAAE;4BACV6E,WAAWnB;wBACb;wBAEAnD,iBAAiBuE,GAAG,CAACtD,WAAWkC;wBAEhC,MAAMqB,uBAAuBC,IAAAA,qBAAS,EAACvF,QAAQyE,MAAM,CAACR,gBAAgB,EAAE,CAAC,EAAEuB,GAAG,EAAE;4BAC9E,MAAMC,SAA2C;gCAC/CnB,QAAQkB,IAAIxF,QAAQyE,MAAM,CAAC5D,gBAAgB,EAAE;oCAC3CN,QAAQ;wCAACP,QAAQyE,MAAM,CAACR,gBAAgB,CAACK,MAAM;qCAAC;oCAChDE,YAAY;wCAACxE,QAAQyE,MAAM,CAAC5D,gBAAgB,CAACW,EAAE;qCAAC;gCAClD;4BACF;4BAEA,OAAOiE;wBACT;wBAEAzF,QAAQuF,SAAS,CAAC,CAAC,SAAS,EAAEtB,gBAAgB,CAAC,CAAC,GAAGqB;oBACrD,OAAO;wBACLtD,WAAW,CAACD,UAAU,GAAG/B,QAAQ0D,KAAK,CAACD,SAAS,CAAC1B;oBACnD;oBACA;gBACF;YAEA,KAAK;gBAAY;oBACfC,WAAW,CAACD,UAAU,GAAG2D,IAAAA,eAAO,EAAC5D;oBACjC;gBACF;YAEA,KAAK;gBAAS;oBACZ,MAAM6D,yBAAyBC,QAAQhE,MAAMiE,KAAK,EAAEC,cAAc1F;oBAElE,MAAM2F,iBAAiB,CAAC,EAAEnF,aAAa,CAAC,EAAEuB,IAAAA,oBAAW,EAACP,MAAMC,IAAI,EAAE,CAAC;oBACnE,MAAMqC,cAA+C;wBACnD8B,QAAQ5B,IAAAA,eAAO,EAAC,UAAUC,OAAO;wBACjC4B,WAAW1B,oCAAiB,CAAChD,gBAAgB,CAAC,cAC3CiD,UAAU,CAAC,IAAMxE,QAAQyE,MAAM,CAAC5D,gBAAgB,CAACW,EAAE,EAAE;4BAAEkD,UAAU;wBAAU,GAC3EL,OAAO;oBACZ;oBAEA,MAAMM,kBAGF;wBACFuB,WAAW,CAACrB,OAASnC,IAAAA,aAAK,EAAC,cAAcoC,EAAE,CAACD,KAAKmB,MAAM;wBACvDG,cAAc,CAACtB,OAASnC,IAAAA,aAAK,EAAC,kBAAkBoC,EAAE,CAACD,KAAKoB,SAAS;oBACnE;oBAEA,IAAIrE,MAAMY,SAAS,IAAIxC,QAAQqC,OAAO,CAACC,MAAM,CAACC,YAAY,EAAE;wBAC1D2B,YAAYkC,OAAO,GAAGpG,QAAQ0D,KAAK,CAACuB,aAAa,CAAC,WAAWZ,OAAO;wBACpEM,gBAAgB0B,UAAU,GAAG,CAACxB,OAASnC,IAAAA,aAAK,EAAC,eAAeoC,EAAE,CAACD,KAAKuB,OAAO;oBAC7E;oBAEA,MAAM,EAAEtF,kBAAkBwF,mBAAmB,EAAE,GAAGnB,IAAAA,iBAAU,EAAC;wBAC3DnF;wBACAkE;wBACAS;wBACAvE,gBAAgBuF;wBAChBtF;wBACAE,QAAQF,gBAAgBkG,IAAAA,kBAAQ,EAAC3E,MAAMrB,MAAM,IAAIqB,MAAMrB,MAAM;wBAC7DS;wBACAwF,mBAAmBzF;wBACnBE;wBACAC;wBACAkE,WAAWW;oBACb;oBAEAjF,iBAAiBuE,GAAG,CAACtD,WAAWgE;oBAEhC,MAAMU,sBAAsBlB,IAAAA,qBAAS,EAACvF,QAAQyE,MAAM,CAACsB,eAAe,EAAE,CAAC,EAAEW,IAAI,EAAElB,GAAG,EAAE;wBAClF,MAAMC,SAA2C;4BAC/CQ,WAAWT,IAAIxF,QAAQyE,MAAM,CAAC5D,gBAAgB,EAAE;gCAC9CN,QAAQ;oCAACP,QAAQyE,MAAM,CAACsB,eAAe,CAACE,SAAS;iCAAC;gCAClDzB,YAAY;oCAACxE,QAAQyE,MAAM,CAAC5D,gBAAgB,CAACW,EAAE;iCAAC;4BAClD;wBACF;wBAEA,IAAImF,IAAAA,gCAAe,EAAC/E,MAAMrB,MAAM,GAAG;4BACjCkF,OAAOmB,QAAQ,GAAGF,KAAK1G,QAAQyE,MAAM,CAAC,CAAC,EAAEsB,eAAe,QAAQ,CAAC,CAAC;wBACpE;wBAEAO,oBAAoB3E,OAAO,CAAC,CAACkF,KAAKC;4BAChCrB,MAAM,CAACqB,IAAI,GAAGJ,KAAK1G,QAAQyE,MAAM,CAACoC,IAAI;wBACxC;wBAEA,OAAOpB;oBACT;oBAEAzF,QAAQuF,SAAS,CAAC,CAAC,UAAU,EAAEQ,eAAe,CAAC,CAAC,GAAGU;oBAEnD;gBACF;YAEA,KAAK;gBAAU;oBACb,MAAMd,yBAAyBC,QAAQhE,MAAMiE,KAAK,EAAEC,cAAc1F;oBAElEwB,MAAMmF,MAAM,CAACpF,OAAO,CAAC,CAACqF;wBACpB,MAAMC,iBAAiB,CAAC,EAAE/F,cAAc,QAAQ,EAAEiB,IAAAA,oBAAW,EAAC6E,MAAME,IAAI,EAAE,CAAC;wBAC3E,IAAI,CAAClH,QAAQyE,MAAM,CAACwC,eAAe,EAAE;4BACnC,MAAM/C,cAA+C;gCACnD8B,QAAQ5B,IAAAA,eAAO,EAAC,UAAUC,OAAO;gCACjC4B,WAAW1B,oCAAiB,CAACtD,mBAAmB,CAAC,cAC9CuD,UAAU,CAAC,IAAMxE,QAAQyE,MAAM,CAACvD,cAAc,CAACM,EAAE,EAAE;oCAAEkD,UAAU;gCAAU,GACzEL,OAAO;gCACV8C,OAAOC,IAAAA,YAAI,EAAC,SAAS/C,OAAO;4BAC9B;4BAEA,MAAMM,kBAGF;gCACFuB,WAAW,CAACrB,OAASnC,IAAAA,aAAK,EAAC,aAAaoC,EAAE,CAACD,KAAKmB,MAAM;gCACtDG,cAAc,CAACtB,OAASnC,IAAAA,aAAK,EAAC,iBAAiBoC,EAAE,CAACD,KAAKoB,SAAS;gCAChEoB,UAAU,CAACxC,OAASnC,IAAAA,aAAK,EAAC,YAAYoC,EAAE,CAACD,KAAKsC,KAAK;4BACrD;4BAEA,IAAIvF,MAAMY,SAAS,IAAIxC,QAAQqC,OAAO,CAACC,MAAM,CAACC,YAAY,EAAE;gCAC1D2B,YAAYkC,OAAO,GAAGpG,QAAQ0D,KAAK,CAACuB,aAAa,CAAC,WAAWZ,OAAO;gCACpEM,gBAAgB0B,UAAU,GAAG,CAACxB,OAASnC,IAAAA,aAAK,EAAC,cAAcoC,EAAE,CAACD,KAAKuB,OAAO;4BAC5E;4BAEA,MAAM,EAAEtF,kBAAkBwF,mBAAmB,EAAE,GAAGnB,IAAAA,iBAAU,EAAC;gCAC3DnF;gCACAkE;gCACAS;gCACAvE,gBAAgBuF;gCAChBtF;gCACAE,QAAQF,gBAAgBkG,IAAAA,kBAAQ,EAACS,MAAMzG,MAAM,IAAIyG,MAAMzG,MAAM;gCAC7DS;gCACAwF,mBAAmBzF;gCACnBE;gCACAC;gCACAkE,WAAW6B;4BACb;4BAEA,MAAMK,sBAAsB/B,IAAAA,qBAAS,EACnCvF,QAAQyE,MAAM,CAACwC,eAAe,EAC9B,CAAC,EAAEP,IAAI,EAAElB,GAAG,EAAE;gCACZ,MAAMC,SAA2C;oCAC/CQ,WAAWT,IAAIxF,QAAQyE,MAAM,CAACvD,cAAc,EAAE;wCAC5CX,QAAQ;4CAACP,QAAQyE,MAAM,CAACwC,eAAe,CAAChB,SAAS;yCAAC;wCAClDzB,YAAY;4CAACxE,QAAQyE,MAAM,CAACvD,cAAc,CAACM,EAAE;yCAAC;oCAChD;gCACF;gCAEA,IAAImF,IAAAA,gCAAe,EAACK,MAAMzG,MAAM,GAAG;oCACjCkF,OAAOmB,QAAQ,GAAGF,KAAK1G,QAAQyE,MAAM,CAAC,CAAC,EAAEwC,eAAe,QAAQ,CAAC,CAAC;gCACpE;gCAEAX,oBAAoB3E,OAAO,CAAC,CAACkF,KAAKC;oCAChCrB,MAAM,CAACqB,IAAI,GAAGJ,KAAK1G,QAAQyE,MAAM,CAACoC,IAAI;gCACxC;gCAEA,OAAOpB;4BACT;4BAGFzF,QAAQuF,SAAS,CAAC,CAAC,UAAU,EAAE0B,eAAe,CAAC,CAAC,GAAGK;wBACrD,OAAO,IAAIC,QAAQC,GAAG,CAACC,QAAQ,KAAK,cAAc;4BAChDC,IAAAA,kEAAgC,EAAC;gCAC/BV;gCACAxE,WAAWZ,MAAMY,SAAS;gCAC1BtB;gCACAyG,OAAO3H,QAAQyE,MAAM,CAACwC,eAAe;4BACvC;wBACF;wBAEAjG,qBAAqBqE,GAAG,CAAC,CAAC,QAAQ,EAAE2B,MAAME,IAAI,CAAC,CAAC,EAAED;oBACpD;oBAEA;gBACF;YAEA,KAAK;YACL,KAAK;gBAAS;oBACZ,IAAI,CAAE,CAAA,UAAUrF,KAAI,GAAI;wBACtB,MAAM,EACJT,mBAAmByG,sBAAsB,EACzCtG,6BAA6BuG,gCAAgC,EAC7DzG,+BAA+B0G,kCAAkC,EACjEzG,oBAAoB0G,uBAAuB,EAC5C,GAAGhI,eAAe;4BACjBC;4BACAC;4BACAC;4BACAC;4BACAC;4BACAC;4BACAC;4BACAC,QAAQqB,MAAMrB,MAAM;4BACpBC;4BACAC;4BACAC;4BACAC;4BACAC;4BACAC;4BACAC;4BACAC;4BACAC;4BACAC;4BACAC;wBACF;wBAEA,IAAI0G,wBAAwBzG,oBAAoB;wBAChD,IAAI2G,oCAAoC1G,gCAAgC;wBACxE,IAAI2G,yBAAyB1G,qBAAqB;wBAClD,IAAIwG,kCAAkCvG,8BAA8B;wBACpE;oBACF;oBAEA,MAAMqE,yBAAyBC,QAAQhE,MAAMiE,KAAK,EAAEC,cAAc1F;oBAElE,MAAM,EACJe,mBAAmByG,sBAAsB,EACzCtG,6BAA6BuG,gCAAgC,EAC7DzG,+BAA+B0G,kCAAkC,EACjEzG,oBAAoB0G,uBAAuB,EAC5C,GAAGhI,eAAe;wBACjBC;wBACAC;wBACAC,cAAc,CAAC,EAAE4B,WAAW,CAAC,CAAC;wBAC9B3B;wBACAC,gBAAgBuF;wBAChBtF;wBACAC,aAAa,CAAC,EAAEyB,UAAU,CAAC,CAAC;wBAC5BxB,QAAQqB,MAAMrB,MAAM;wBACpBC,gBAAgBoB,MAAMY,SAAS;wBAC/B/B;wBACAC;wBACAC;wBACAC,cAAc,CAAC,EAAEC,gBAAgB,CAAC,EAAEiB,WAAW,CAAC;wBAChDjB;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC;oBACF;oBAEA,IAAI0G,wBAAwBzG,oBAAoB;oBAChD,IAAI2G,oCAAoC1G,gCAAgC;oBACxE,IAAI2G,yBAAyB1G,qBAAqB;oBAClD,IAAIwG,kCAAkCvG,8BAA8B;oBACpE;gBACF;YAEA,KAAK;gBAAQ;oBACX,MAAMqE,yBAAyBC,QAAQhE,MAAMiE,KAAK,EAAEC,cAAc1F;oBAElE,MAAM,EACJe,mBAAmB6G,oBAAoB,EACvC1G,6BAA6B2G,8BAA8B,EAC3D7G,+BAA+B8G,gCAAgC,EAC/D7G,oBAAoB8G,qBAAqB,EAC1C,GAAGpI,eAAe;wBACjBC;wBACAC;wBACAC;wBACAC;wBACAC,gBAAgBuF;wBAChBtF;wBACAC;wBACAC,QAAQqB,MAAMwG,IAAI,CAACvE,GAAG,CAAC,CAACwE,MAAS,CAAA;gCAAE,GAAGA,GAAG;gCAAEzF,MAAM;4BAAM,CAAA;wBACvDpC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC;oBACF;oBAEA,IAAI8G,sBAAsB7G,oBAAoB;oBAC9C,IAAI+G,kCAAkC9G,gCAAgC;oBACtE,IAAI+G,uBAAuB9G,qBAAqB;oBAChD,IAAI4G,gCAAgC3G,8BAA8B;oBAElE;gBACF;YAEA,KAAK;YACL,KAAK;gBAAe;oBAClB,MAAMqE,yBAAyBC,QAAQhE,MAAMiE,KAAK,EAAEC,cAAc1F;oBAClE,MAAM,EACJe,mBAAmBmH,oBAAoB,EACvChH,6BAA6BiH,8BAA8B,EAC3DnH,+BAA+BoH,gCAAgC,EAC/DnH,oBAAoBoH,qBAAqB,EAC1C,GAAG1I,eAAe;wBACjBC;wBACAC;wBACAC;wBACAC;wBACAC,gBAAgBuF;wBAChBtF;wBACAC;wBACAC,QAAQqB,MAAMrB,MAAM;wBACpBC;wBACAC;wBACAC;wBACAC;wBACAC,cAAcC;wBACdA;wBACAC;wBACAC;wBACAC;wBACAC;wBACAC;oBACF;oBAEA,IAAIoH,sBAAsBnH,oBAAoB;oBAC9C,IAAIqH,kCAAkCpH,gCAAgC;oBACtE,IAAIqH,uBAAuBpH,qBAAqB;oBAChD,IAAIkH,gCAAgCjH,8BAA8B;oBAClE;gBACF;YAEA,KAAK;YACL,KAAK;gBACH,IAAIoH,MAAMC,OAAO,CAAC/G,MAAMgH,UAAU,GAAG;oBACnChH,MAAMgH,UAAU,CAACjH,OAAO,CAAC,CAACkH,WAAa9H,cAAc+H,GAAG,CAACD;gBAC3D,OAAO;oBACL9H,cAAc+H,GAAG,CAAClH,MAAMgH,UAAU;gBACpC;gBAEA,IAAIhH,MAAMY,SAAS,IAAIxC,QAAQqC,OAAO,CAACC,MAAM,CAACC,YAAY,EAAE;oBAC1DnB,gCAAgC;gBAClC;gBACA;YAEF;gBACE;QACJ;QAEA,MAAM0E,YAAYlE,MAAMiE,KAAK,IAAIjE,MAAMiE,KAAK,CAACC,SAAS;QAEtD,IACE,CAAC1F,kBACD4B,WAAW,CAACD,UAAU,IACtB,cAAcH,SACdA,MAAMmH,QAAQ,IACd,CAACjD,WACD;YACA9D,WAAW,CAACD,UAAU,CAACsC,OAAO;QAChC;IACF;IAEA,OAAO;QACLlD;QACAG;QACAF;QACAC;IACF;AACF"}
466
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/schema/traverseFields.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { Relation } from 'drizzle-orm'\nimport type { IndexBuilder, PgColumnBuilder, UniqueConstraintBuilder } from 'drizzle-orm/pg-core'\nimport type { Field, TabAsField } from 'payload/types'\n\nimport { relations } from 'drizzle-orm'\nimport {\n  PgNumericBuilder,\n  PgVarcharBuilder,\n  boolean,\n  index,\n  integer,\n  jsonb,\n  numeric,\n  pgEnum,\n  text,\n  timestamp,\n  varchar,\n} from 'drizzle-orm/pg-core'\nimport { InvalidConfiguration } from 'payload/errors'\nimport { fieldAffectsData, optionIsObject } from 'payload/types'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { GenericColumns, PostgresAdapter } from '../types'\n\nimport { hasLocalesTable } from '../utilities/hasLocalesTable'\nimport { buildTable } from './build'\nimport { createIndex } from './createIndex'\nimport { idToUUID } from './idToUUID'\nimport { parentIDColumnMap } from './parentIDColumnMap'\nimport { validateExistingBlockIsIdentical } from './validateExistingBlockIsIdentical'\n\ntype Args = {\n  adapter: PostgresAdapter\n  buildNumbers: boolean\n  buildRelationships: boolean\n  columnPrefix?: string\n  columns: Record<string, PgColumnBuilder>\n  disableNotNull: boolean\n  disableUnique?: boolean\n  fieldPrefix?: string\n  fields: (Field | TabAsField)[]\n  forceLocalized?: boolean\n  indexes: Record<string, (cols: GenericColumns) => IndexBuilder>\n  localesColumns: Record<string, PgColumnBuilder>\n  localesIndexes: Record<string, (cols: GenericColumns) => IndexBuilder>\n  newTableName: string\n  parentTableName: string\n  relationsToBuild: Map<string, string>\n  relationships: Set<string>\n  rootRelationsToBuild?: Map<string, string>\n  rootTableIDColType: string\n  rootTableName: string\n}\n\ntype Result = {\n  hasLocalizedField: boolean\n  hasLocalizedManyNumberField: boolean\n  hasLocalizedRelationshipField: boolean\n  hasManyNumberField: 'index' | boolean\n}\n\nexport const traverseFields = ({\n  adapter,\n  buildNumbers,\n  buildRelationships,\n  columnPrefix,\n  columns,\n  disableNotNull,\n  disableUnique = false,\n  fieldPrefix,\n  fields,\n  forceLocalized,\n  indexes,\n  localesColumns,\n  localesIndexes,\n  newTableName,\n  parentTableName,\n  relationsToBuild,\n  relationships,\n  rootRelationsToBuild,\n  rootTableIDColType,\n  rootTableName,\n}: Args): Result => {\n  let hasLocalizedField = false\n  let hasLocalizedRelationshipField = false\n  let hasManyNumberField: 'index' | boolean = false\n  let hasLocalizedManyNumberField = false\n\n  let parentIDColType = 'integer'\n  if (columns.id instanceof PgNumericBuilder) parentIDColType = 'numeric'\n  if (columns.id instanceof PgVarcharBuilder) parentIDColType = 'varchar'\n\n  fields.forEach((field) => {\n    if ('name' in field && field.name === 'id') return\n    let columnName: string\n    let fieldName: string\n\n    let targetTable = columns\n    let targetIndexes = indexes\n\n    if (fieldAffectsData(field)) {\n      columnName = `${columnPrefix || ''}${field.name[0] === '_' ? '_' : ''}${toSnakeCase(\n        field.name,\n      )}`\n      fieldName = `${fieldPrefix?.replace('.', '_') || ''}${field.name}`\n\n      // If field is localized,\n      // add the column to the locale table instead of main table\n      if (adapter.payload.config.localization && (field.localized || forceLocalized)) {\n        hasLocalizedField = true\n        targetTable = localesColumns\n        targetIndexes = localesIndexes\n      }\n\n      if (\n        (field.unique || field.index) &&\n        !['array', 'blocks', 'group', 'point', 'relationship', 'upload'].includes(field.type) &&\n        !(field.type === 'number' && field.hasMany === true)\n      ) {\n        const unique = disableUnique !== true && field.unique\n        if (unique) {\n          const constraintValue = `${fieldPrefix || ''}${field.name}`\n          if (!adapter.fieldConstraints?.[rootTableName]) {\n            adapter.fieldConstraints[rootTableName] = {}\n          }\n          adapter.fieldConstraints[rootTableName][`${columnName}_idx`] = constraintValue\n        }\n        targetIndexes[`${field.name}Idx`] = createIndex({\n          name: fieldName,\n          columnName,\n          unique,\n        })\n      }\n    }\n\n    switch (field.type) {\n      case 'text':\n      case 'email':\n      case 'code':\n      case 'textarea': {\n        targetTable[fieldName] = varchar(columnName)\n        break\n      }\n\n      case 'number': {\n        if (field.hasMany) {\n          if (field.localized) {\n            hasLocalizedManyNumberField = true\n          }\n\n          if (field.index) {\n            hasManyNumberField = 'index'\n          } else if (!hasManyNumberField) {\n            hasManyNumberField = true\n          }\n\n          if (field.unique) {\n            throw new InvalidConfiguration(\n              'Unique is not supported in Postgres for hasMany number fields.',\n            )\n          }\n        } else {\n          targetTable[fieldName] = numeric(columnName)\n        }\n        break\n      }\n\n      case 'richText':\n      case 'json': {\n        targetTable[fieldName] = jsonb(columnName)\n        break\n      }\n\n      case 'date': {\n        targetTable[fieldName] = timestamp(columnName, {\n          mode: 'string',\n          precision: 3,\n          withTimezone: true,\n        })\n        break\n      }\n\n      case 'point': {\n        break\n      }\n\n      case 'radio':\n      case 'select': {\n        const enumName = `enum_${newTableName}_${toSnakeCase(field.name)}`\n\n        adapter.enums[enumName] = pgEnum(\n          enumName,\n          field.options.map((option) => {\n            if (optionIsObject(option)) {\n              return option.value\n            }\n\n            return option\n          }) as [string, ...string[]],\n        )\n\n        if (field.type === 'select' && field.hasMany) {\n          const selectTableName = `${newTableName}_${toSnakeCase(field.name)}`\n          const baseColumns: Record<string, PgColumnBuilder> = {\n            order: integer('order').notNull(),\n            parent: parentIDColumnMap[parentIDColType]('parent_id')\n              .references(() => adapter.tables[parentTableName].id, { onDelete: 'cascade' })\n              .notNull(),\n            value: adapter.enums[enumName]('value'),\n          }\n\n          const baseExtraConfig: Record<\n            string,\n            (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n          > = {\n            orderIdx: (cols) => index('order_idx').on(cols.order),\n            parentIdx: (cols) => index('parent_idx').on(cols.parent),\n          }\n\n          if (field.localized) {\n            baseColumns.locale = adapter.enums.enum__locales('locale').notNull()\n            baseExtraConfig.localeIdx = (cols) => index('locale_idx').on(cols.locale)\n          }\n\n          if (field.index) {\n            baseExtraConfig.value = (cols) => index('value_idx').on(cols.value)\n          }\n\n          buildTable({\n            adapter,\n            baseColumns,\n            baseExtraConfig,\n            disableNotNull,\n            disableUnique,\n            fields: [],\n            tableName: selectTableName,\n          })\n\n          relationsToBuild.set(fieldName, selectTableName)\n\n          const selectTableRelations = relations(adapter.tables[selectTableName], ({ one }) => {\n            const result: Record<string, Relation<string>> = {\n              parent: one(adapter.tables[parentTableName], {\n                fields: [adapter.tables[selectTableName].parent],\n                references: [adapter.tables[parentTableName].id],\n              }),\n            }\n\n            return result\n          })\n\n          adapter.relations[`relation_${selectTableName}`] = selectTableRelations\n        } else {\n          targetTable[fieldName] = adapter.enums[enumName](fieldName)\n        }\n        break\n      }\n\n      case 'checkbox': {\n        targetTable[fieldName] = boolean(columnName)\n        break\n      }\n\n      case 'array': {\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n        const arrayTableName = `${newTableName}_${toSnakeCase(field.name)}`\n        const baseColumns: Record<string, PgColumnBuilder> = {\n          _order: integer('_order').notNull(),\n          _parentID: parentIDColumnMap[parentIDColType]('_parent_id')\n            .references(() => adapter.tables[parentTableName].id, { onDelete: 'cascade' })\n            .notNull(),\n        }\n\n        const baseExtraConfig: Record<\n          string,\n          (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n        > = {\n          _orderIdx: (cols) => index('_order_idx').on(cols._order),\n          _parentIDIdx: (cols) => index('_parent_id_idx').on(cols._parentID),\n        }\n\n        if (field.localized && adapter.payload.config.localization) {\n          baseColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n          baseExtraConfig._localeIdx = (cols) => index('_locale_idx').on(cols._locale)\n        }\n\n        const { hasManyNumberField: subHasManyNumberField, relationsToBuild: subRelationsToBuild } =\n          buildTable({\n            adapter,\n            baseColumns,\n            baseExtraConfig,\n            disableNotNull: disableNotNullFromHere,\n            disableUnique,\n            fields: disableUnique ? idToUUID(field.fields) : field.fields,\n            rootRelationsToBuild,\n            rootRelationships: relationships,\n            rootTableIDColType,\n            rootTableName,\n            tableName: arrayTableName,\n          })\n\n        if (subHasManyNumberField) {\n          if (!hasManyNumberField || subHasManyNumberField === 'index')\n            hasManyNumberField = subHasManyNumberField\n        }\n\n        relationsToBuild.set(fieldName, arrayTableName)\n\n        const arrayTableRelations = relations(adapter.tables[arrayTableName], ({ many, one }) => {\n          const result: Record<string, Relation<string>> = {\n            _parentID: one(adapter.tables[parentTableName], {\n              fields: [adapter.tables[arrayTableName]._parentID],\n              references: [adapter.tables[parentTableName].id],\n            }),\n          }\n\n          if (hasLocalesTable(field.fields)) {\n            result._locales = many(adapter.tables[`${arrayTableName}_locales`])\n          }\n\n          subRelationsToBuild.forEach((val, key) => {\n            result[key] = many(adapter.tables[val])\n          })\n\n          return result\n        })\n\n        adapter.relations[`relations_${arrayTableName}`] = arrayTableRelations\n\n        break\n      }\n\n      case 'blocks': {\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n        field.blocks.forEach((block) => {\n          const blockTableName = `${rootTableName}_blocks_${toSnakeCase(block.slug)}`\n          if (!adapter.tables[blockTableName]) {\n            const baseColumns: Record<string, PgColumnBuilder> = {\n              _order: integer('_order').notNull(),\n              _parentID: parentIDColumnMap[rootTableIDColType]('_parent_id')\n                .references(() => adapter.tables[rootTableName].id, { onDelete: 'cascade' })\n                .notNull(),\n              _path: text('_path').notNull(),\n            }\n\n            const baseExtraConfig: Record<\n              string,\n              (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n            > = {\n              _orderIdx: (cols) => index('order_idx').on(cols._order),\n              _parentIDIdx: (cols) => index('parent_id_idx').on(cols._parentID),\n              _pathIdx: (cols) => index('path_idx').on(cols._path),\n            }\n\n            if (field.localized && adapter.payload.config.localization) {\n              baseColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n              baseExtraConfig._localeIdx = (cols) => index('locale_idx').on(cols._locale)\n            }\n\n            const {\n              hasManyNumberField: subHasManyNumberField,\n              relationsToBuild: subRelationsToBuild,\n            } = buildTable({\n              adapter,\n              baseColumns,\n              baseExtraConfig,\n              disableNotNull: disableNotNullFromHere,\n              disableUnique,\n              fields: disableUnique ? idToUUID(block.fields) : block.fields,\n              rootRelationsToBuild,\n              rootRelationships: relationships,\n              rootTableIDColType,\n              rootTableName,\n              tableName: blockTableName,\n            })\n\n            if (subHasManyNumberField) {\n              if (!hasManyNumberField || subHasManyNumberField === 'index')\n                hasManyNumberField = subHasManyNumberField\n            }\n\n            const blockTableRelations = relations(\n              adapter.tables[blockTableName],\n              ({ many, one }) => {\n                const result: Record<string, Relation<string>> = {\n                  _parentID: one(adapter.tables[rootTableName], {\n                    fields: [adapter.tables[blockTableName]._parentID],\n                    references: [adapter.tables[rootTableName].id],\n                  }),\n                }\n\n                if (hasLocalesTable(block.fields)) {\n                  result._locales = many(adapter.tables[`${blockTableName}_locales`])\n                }\n\n                subRelationsToBuild.forEach((val, key) => {\n                  result[key] = many(adapter.tables[val])\n                })\n\n                return result\n              },\n            )\n\n            adapter.relations[`relations_${blockTableName}`] = blockTableRelations\n          } else if (process.env.NODE_ENV !== 'production') {\n            validateExistingBlockIsIdentical({\n              block,\n              localized: field.localized,\n              rootTableName,\n              table: adapter.tables[blockTableName],\n            })\n          }\n\n          rootRelationsToBuild.set(`_blocks_${block.slug}`, blockTableName)\n        })\n\n        break\n      }\n\n      case 'tab':\n      case 'group': {\n        if (!('name' in field)) {\n          const {\n            hasLocalizedField: groupHasLocalizedField,\n            hasLocalizedManyNumberField: groupHasLocalizedManyNumberField,\n            hasLocalizedRelationshipField: groupHasLocalizedRelationshipField,\n            hasManyNumberField: groupHasManyNumberField,\n          } = traverseFields({\n            adapter,\n            buildNumbers,\n            buildRelationships,\n            columnPrefix,\n            columns,\n            disableNotNull,\n            disableUnique,\n            fieldPrefix,\n            fields: field.fields,\n            forceLocalized,\n            indexes,\n            localesColumns,\n            localesIndexes,\n            newTableName,\n            parentTableName,\n            relationsToBuild,\n            relationships,\n            rootRelationsToBuild,\n            rootTableIDColType,\n            rootTableName,\n          })\n\n          if (groupHasLocalizedField) hasLocalizedField = true\n          if (groupHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n          if (groupHasManyNumberField) hasManyNumberField = true\n          if (groupHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n          break\n        }\n\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n        const {\n          hasLocalizedField: groupHasLocalizedField,\n          hasLocalizedManyNumberField: groupHasLocalizedManyNumberField,\n          hasLocalizedRelationshipField: groupHasLocalizedRelationshipField,\n          hasManyNumberField: groupHasManyNumberField,\n        } = traverseFields({\n          adapter,\n          buildNumbers,\n          buildRelationships,\n          columnPrefix: `${columnName}_`,\n          columns,\n          disableNotNull: disableNotNullFromHere,\n          disableUnique,\n          fieldPrefix: `${fieldName}.`,\n          fields: field.fields,\n          forceLocalized: field.localized,\n          indexes,\n          localesColumns,\n          localesIndexes,\n          newTableName: `${parentTableName}_${columnName}`,\n          parentTableName,\n          relationsToBuild,\n          relationships,\n          rootRelationsToBuild,\n          rootTableIDColType,\n          rootTableName,\n        })\n\n        if (groupHasLocalizedField) hasLocalizedField = true\n        if (groupHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n        if (groupHasManyNumberField) hasManyNumberField = true\n        if (groupHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n        break\n      }\n\n      case 'tabs': {\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n        const {\n          hasLocalizedField: tabHasLocalizedField,\n          hasLocalizedManyNumberField: tabHasLocalizedManyNumberField,\n          hasLocalizedRelationshipField: tabHasLocalizedRelationshipField,\n          hasManyNumberField: tabHasManyNumberField,\n        } = traverseFields({\n          adapter,\n          buildNumbers,\n          buildRelationships,\n          columnPrefix,\n          columns,\n          disableNotNull: disableNotNullFromHere,\n          disableUnique,\n          fieldPrefix,\n          fields: field.tabs.map((tab) => ({ ...tab, type: 'tab' })),\n          forceLocalized,\n          indexes,\n          localesColumns,\n          localesIndexes,\n          newTableName,\n          parentTableName,\n          relationsToBuild,\n          relationships,\n          rootRelationsToBuild,\n          rootTableIDColType,\n          rootTableName,\n        })\n\n        if (tabHasLocalizedField) hasLocalizedField = true\n        if (tabHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n        if (tabHasManyNumberField) hasManyNumberField = true\n        if (tabHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n\n        break\n      }\n\n      case 'row':\n      case 'collapsible': {\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n        const {\n          hasLocalizedField: rowHasLocalizedField,\n          hasLocalizedManyNumberField: rowHasLocalizedManyNumberField,\n          hasLocalizedRelationshipField: rowHasLocalizedRelationshipField,\n          hasManyNumberField: rowHasManyNumberField,\n        } = traverseFields({\n          adapter,\n          buildNumbers,\n          buildRelationships,\n          columnPrefix,\n          columns,\n          disableNotNull: disableNotNullFromHere,\n          disableUnique,\n          fieldPrefix,\n          fields: field.fields,\n          forceLocalized,\n          indexes,\n          localesColumns,\n          localesIndexes,\n          newTableName: parentTableName,\n          parentTableName,\n          relationsToBuild,\n          relationships,\n          rootRelationsToBuild,\n          rootTableIDColType,\n          rootTableName,\n        })\n\n        if (rowHasLocalizedField) hasLocalizedField = true\n        if (rowHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n        if (rowHasManyNumberField) hasManyNumberField = true\n        if (rowHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n        break\n      }\n\n      case 'relationship':\n      case 'upload':\n        if (Array.isArray(field.relationTo)) {\n          field.relationTo.forEach((relation) => relationships.add(relation))\n        } else {\n          relationships.add(field.relationTo)\n        }\n\n        if (field.localized && adapter.payload.config.localization) {\n          hasLocalizedRelationshipField = true\n        }\n        break\n\n      default:\n        break\n    }\n\n    const condition = field.admin && field.admin.condition\n\n    if (\n      !disableNotNull &&\n      targetTable[fieldName] &&\n      'required' in field &&\n      field.required &&\n      !condition\n    ) {\n      targetTable[fieldName].notNull()\n    }\n  })\n\n  return {\n    hasLocalizedField,\n    hasLocalizedManyNumberField,\n    hasLocalizedRelationshipField,\n    hasManyNumberField,\n  }\n}\n"],"names":["traverseFields","adapter","buildNumbers","buildRelationships","columnPrefix","columns","disableNotNull","disableUnique","fieldPrefix","fields","forceLocalized","indexes","localesColumns","localesIndexes","newTableName","parentTableName","relationsToBuild","relationships","rootRelationsToBuild","rootTableIDColType","rootTableName","hasLocalizedField","hasLocalizedRelationshipField","hasManyNumberField","hasLocalizedManyNumberField","parentIDColType","id","PgNumericBuilder","PgVarcharBuilder","forEach","field","name","columnName","fieldName","targetTable","targetIndexes","fieldAffectsData","toSnakeCase","replace","payload","config","localization","localized","unique","index","includes","type","hasMany","constraintValue","fieldConstraints","createIndex","varchar","InvalidConfiguration","numeric","jsonb","timestamp","mode","precision","withTimezone","enumName","enums","pgEnum","options","map","option","optionIsObject","value","selectTableName","baseColumns","order","integer","notNull","parent","parentIDColumnMap","references","tables","onDelete","baseExtraConfig","orderIdx","cols","on","parentIdx","locale","enum__locales","localeIdx","buildTable","tableName","set","selectTableRelations","relations","one","result","boolean","disableNotNullFromHere","Boolean","admin","condition","arrayTableName","_order","_parentID","_orderIdx","_parentIDIdx","_locale","_localeIdx","subHasManyNumberField","subRelationsToBuild","idToUUID","rootRelationships","arrayTableRelations","many","hasLocalesTable","_locales","val","key","blocks","block","blockTableName","slug","_path","text","_pathIdx","blockTableRelations","process","env","NODE_ENV","validateExistingBlockIsIdentical","table","groupHasLocalizedField","groupHasLocalizedManyNumberField","groupHasLocalizedRelationshipField","groupHasManyNumberField","tabHasLocalizedField","tabHasLocalizedManyNumberField","tabHasLocalizedRelationshipField","tabHasManyNumberField","tabs","tab","rowHasLocalizedField","rowHasLocalizedManyNumberField","rowHasLocalizedRelationshipField","rowHasManyNumberField","Array","isArray","relationTo","relation","add","required"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"commitTransaction.d.ts","sourceRoot":"","sources":["../../src/transactions/commitTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAA;AAEzD,eAAO,MAAM,iBAAiB,EAAE,iBAY/B,CAAA"}
1
+ {"version":3,"file":"commitTransaction.d.ts","sourceRoot":"","sources":["../../src/transactions/commitTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAA;AAEzD,eAAO,MAAM,iBAAiB,EAAE,iBAa/B,CAAA"}
@@ -9,6 +9,7 @@ Object.defineProperty(exports, "commitTransaction", {
9
9
  }
10
10
  });
11
11
  const commitTransaction = async function commitTransaction(id) {
12
+ // if the session was deleted it has already been aborted
12
13
  if (!this.sessions[id]) {
13
14
  return;
14
15
  }
@@ -20,4 +21,4 @@ const commitTransaction = async function commitTransaction(id) {
20
21
  delete this.sessions[id];
21
22
  };
22
23
 
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90cmFuc2FjdGlvbnMvY29tbWl0VHJhbnNhY3Rpb24udHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBDb21taXRUcmFuc2FjdGlvbiB9IGZyb20gJ3BheWxvYWQvZGF0YWJhc2UnXG5cbmV4cG9ydCBjb25zdCBjb21taXRUcmFuc2FjdGlvbjogQ29tbWl0VHJhbnNhY3Rpb24gPSBhc3luYyBmdW5jdGlvbiBjb21taXRUcmFuc2FjdGlvbihpZCkge1xuICBpZiAoIXRoaXMuc2Vzc2lvbnNbaWRdKSB7XG4gICAgcmV0dXJuXG4gIH1cblxuICB0cnkge1xuICAgIHRoaXMuc2Vzc2lvbnNbaWRdLnJlc29sdmUoKVxuICB9IGNhdGNoIChlcnI6IHVua25vd24pIHtcbiAgICB0aGlzLnNlc3Npb25zW2lkXS5yZWplY3QoKVxuICB9XG5cbiAgZGVsZXRlIHRoaXMuc2Vzc2lvbnNbaWRdXG59XG4iXSwibmFtZXMiOlsiY29tbWl0VHJhbnNhY3Rpb24iLCJpZCIsInNlc3Npb25zIiwicmVzb2x2ZSIsImVyciIsInJlamVjdCJdLCJtYXBwaW5ncyI6Ijs7OzsrQkFFYUE7OztlQUFBQTs7O0FBQU4sTUFBTUEsb0JBQXVDLGVBQWVBLGtCQUFrQkMsRUFBRTtJQUNyRixJQUFJLENBQUMsSUFBSSxDQUFDQyxRQUFRLENBQUNELEdBQUcsRUFBRTtRQUN0QjtJQUNGO0lBRUEsSUFBSTtRQUNGLElBQUksQ0FBQ0MsUUFBUSxDQUFDRCxHQUFHLENBQUNFLE9BQU87SUFDM0IsRUFBRSxPQUFPQyxLQUFjO1FBQ3JCLElBQUksQ0FBQ0YsUUFBUSxDQUFDRCxHQUFHLENBQUNJLE1BQU07SUFDMUI7SUFFQSxPQUFPLElBQUksQ0FBQ0gsUUFBUSxDQUFDRCxHQUFHO0FBQzFCIn0=
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90cmFuc2FjdGlvbnMvY29tbWl0VHJhbnNhY3Rpb24udHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBDb21taXRUcmFuc2FjdGlvbiB9IGZyb20gJ3BheWxvYWQvZGF0YWJhc2UnXG5cbmV4cG9ydCBjb25zdCBjb21taXRUcmFuc2FjdGlvbjogQ29tbWl0VHJhbnNhY3Rpb24gPSBhc3luYyBmdW5jdGlvbiBjb21taXRUcmFuc2FjdGlvbihpZCkge1xuICAvLyBpZiB0aGUgc2Vzc2lvbiB3YXMgZGVsZXRlZCBpdCBoYXMgYWxyZWFkeSBiZWVuIGFib3J0ZWRcbiAgaWYgKCF0aGlzLnNlc3Npb25zW2lkXSkge1xuICAgIHJldHVyblxuICB9XG5cbiAgdHJ5IHtcbiAgICB0aGlzLnNlc3Npb25zW2lkXS5yZXNvbHZlKClcbiAgfSBjYXRjaCAoZXJyOiB1bmtub3duKSB7XG4gICAgdGhpcy5zZXNzaW9uc1tpZF0ucmVqZWN0KClcbiAgfVxuXG4gIGRlbGV0ZSB0aGlzLnNlc3Npb25zW2lkXVxufVxuIl0sIm5hbWVzIjpbImNvbW1pdFRyYW5zYWN0aW9uIiwiaWQiLCJzZXNzaW9ucyIsInJlc29sdmUiLCJlcnIiLCJyZWplY3QiXSwibWFwcGluZ3MiOiI7Ozs7K0JBRWFBOzs7ZUFBQUE7OztBQUFOLE1BQU1BLG9CQUF1QyxlQUFlQSxrQkFBa0JDLEVBQUU7SUFDckYseURBQXlEO0lBQ3pELElBQUksQ0FBQyxJQUFJLENBQUNDLFFBQVEsQ0FBQ0QsR0FBRyxFQUFFO1FBQ3RCO0lBQ0Y7SUFFQSxJQUFJO1FBQ0YsSUFBSSxDQUFDQyxRQUFRLENBQUNELEdBQUcsQ0FBQ0UsT0FBTztJQUMzQixFQUFFLE9BQU9DLEtBQWM7UUFDckIsSUFBSSxDQUFDRixRQUFRLENBQUNELEdBQUcsQ0FBQ0ksTUFBTTtJQUMxQjtJQUVBLE9BQU8sSUFBSSxDQUFDSCxRQUFRLENBQUNELEdBQUc7QUFDMUIifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"rollbackTransaction.d.ts","sourceRoot":"","sources":["../../src/transactions/rollbackTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAA;AAE3D,eAAO,MAAM,mBAAmB,EAAE,mBAWjC,CAAA"}
1
+ {"version":3,"file":"rollbackTransaction.d.ts","sourceRoot":"","sources":["../../src/transactions/rollbackTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAA;AAE3D,eAAO,MAAM,mBAAmB,EAAE,mBAcjC,CAAA"}
@@ -9,12 +9,15 @@ Object.defineProperty(exports, "rollbackTransaction", {
9
9
  }
10
10
  });
11
11
  const rollbackTransaction = async function rollbackTransaction(id = '') {
12
+ // if multiple operations are using the same transaction, the first will flow through and delete the session.
13
+ // subsequent calls should be ignored.
12
14
  if (!this.sessions[id]) {
13
- this.payload.logger.warn('rollbackTransaction called when no transaction exists');
14
15
  return;
15
16
  }
17
+ // end the session promise in failure by calling reject
16
18
  await this.sessions[id].reject();
19
+ // delete the session causing any other operations with the same transaction to fail
17
20
  delete this.sessions[id];
18
21
  };
19
22
 
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90cmFuc2FjdGlvbnMvcm9sbGJhY2tUcmFuc2FjdGlvbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFJvbGxiYWNrVHJhbnNhY3Rpb24gfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuXG5leHBvcnQgY29uc3Qgcm9sbGJhY2tUcmFuc2FjdGlvbjogUm9sbGJhY2tUcmFuc2FjdGlvbiA9IGFzeW5jIGZ1bmN0aW9uIHJvbGxiYWNrVHJhbnNhY3Rpb24oXG4gIGlkID0gJycsXG4pIHtcbiAgaWYgKCF0aGlzLnNlc3Npb25zW2lkXSkge1xuICAgIHRoaXMucGF5bG9hZC5sb2dnZXIud2Fybigncm9sbGJhY2tUcmFuc2FjdGlvbiBjYWxsZWQgd2hlbiBubyB0cmFuc2FjdGlvbiBleGlzdHMnKVxuICAgIHJldHVyblxuICB9XG5cbiAgYXdhaXQgdGhpcy5zZXNzaW9uc1tpZF0ucmVqZWN0KClcblxuICBkZWxldGUgdGhpcy5zZXNzaW9uc1tpZF1cbn1cbiJdLCJuYW1lcyI6WyJyb2xsYmFja1RyYW5zYWN0aW9uIiwiaWQiLCJzZXNzaW9ucyIsInBheWxvYWQiLCJsb2dnZXIiLCJ3YXJuIiwicmVqZWN0Il0sIm1hcHBpbmdzIjoiOzs7OytCQUVhQTs7O2VBQUFBOzs7QUFBTixNQUFNQSxzQkFBMkMsZUFBZUEsb0JBQ3JFQyxLQUFLLEVBQUU7SUFFUCxJQUFJLENBQUMsSUFBSSxDQUFDQyxRQUFRLENBQUNELEdBQUcsRUFBRTtRQUN0QixJQUFJLENBQUNFLE9BQU8sQ0FBQ0MsTUFBTSxDQUFDQyxJQUFJLENBQUM7UUFDekI7SUFDRjtJQUVBLE1BQU0sSUFBSSxDQUFDSCxRQUFRLENBQUNELEdBQUcsQ0FBQ0ssTUFBTTtJQUU5QixPQUFPLElBQUksQ0FBQ0osUUFBUSxDQUFDRCxHQUFHO0FBQzFCIn0=
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90cmFuc2FjdGlvbnMvcm9sbGJhY2tUcmFuc2FjdGlvbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFJvbGxiYWNrVHJhbnNhY3Rpb24gfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuXG5leHBvcnQgY29uc3Qgcm9sbGJhY2tUcmFuc2FjdGlvbjogUm9sbGJhY2tUcmFuc2FjdGlvbiA9IGFzeW5jIGZ1bmN0aW9uIHJvbGxiYWNrVHJhbnNhY3Rpb24oXG4gIGlkID0gJycsXG4pIHtcbiAgLy8gaWYgbXVsdGlwbGUgb3BlcmF0aW9ucyBhcmUgdXNpbmcgdGhlIHNhbWUgdHJhbnNhY3Rpb24sIHRoZSBmaXJzdCB3aWxsIGZsb3cgdGhyb3VnaCBhbmQgZGVsZXRlIHRoZSBzZXNzaW9uLlxuICAvLyBzdWJzZXF1ZW50IGNhbGxzIHNob3VsZCBiZSBpZ25vcmVkLlxuICBpZiAoIXRoaXMuc2Vzc2lvbnNbaWRdKSB7XG4gICAgcmV0dXJuXG4gIH1cblxuICAvLyBlbmQgdGhlIHNlc3Npb24gcHJvbWlzZSBpbiBmYWlsdXJlIGJ5IGNhbGxpbmcgcmVqZWN0XG4gIGF3YWl0IHRoaXMuc2Vzc2lvbnNbaWRdLnJlamVjdCgpXG5cbiAgLy8gZGVsZXRlIHRoZSBzZXNzaW9uIGNhdXNpbmcgYW55IG90aGVyIG9wZXJhdGlvbnMgd2l0aCB0aGUgc2FtZSB0cmFuc2FjdGlvbiB0byBmYWlsXG4gIGRlbGV0ZSB0aGlzLnNlc3Npb25zW2lkXVxufVxuIl0sIm5hbWVzIjpbInJvbGxiYWNrVHJhbnNhY3Rpb24iLCJpZCIsInNlc3Npb25zIiwicmVqZWN0Il0sIm1hcHBpbmdzIjoiOzs7OytCQUVhQTs7O2VBQUFBOzs7QUFBTixNQUFNQSxzQkFBMkMsZUFBZUEsb0JBQ3JFQyxLQUFLLEVBQUU7SUFFUCw2R0FBNkc7SUFDN0csc0NBQXNDO0lBQ3RDLElBQUksQ0FBQyxJQUFJLENBQUNDLFFBQVEsQ0FBQ0QsR0FBRyxFQUFFO1FBQ3RCO0lBQ0Y7SUFFQSx1REFBdUQ7SUFDdkQsTUFBTSxJQUFJLENBQUNDLFFBQVEsQ0FBQ0QsR0FBRyxDQUFDRSxNQUFNO0lBRTlCLG9GQUFvRjtJQUNwRixPQUFPLElBQUksQ0FBQ0QsUUFBUSxDQUFDRCxHQUFHO0FBQzFCIn0=
@@ -1,7 +1,8 @@
1
1
  type Args = {
2
2
  data: unknown;
3
+ id?: unknown;
3
4
  locale?: string;
4
5
  };
5
- export declare const transformSelects: ({ data, locale }: Args) => Record<string, unknown>[];
6
+ export declare const transformSelects: ({ id, data, locale }: Args) => Record<string, unknown>[];
6
7
  export {};
7
8
  //# sourceMappingURL=selects.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"selects.d.ts","sourceRoot":"","sources":["../../../src/transform/write/selects.ts"],"names":[],"mappings":"AAGA,KAAK,IAAI,GAAG;IACV,IAAI,EAAE,OAAO,CAAA;IACb,MAAM,CAAC,EAAE,MAAM,CAAA;CAChB,CAAA;AAED,eAAO,MAAM,gBAAgB,qBAAsB,IAAI,8BAmBtD,CAAA"}
1
+ {"version":3,"file":"selects.d.ts","sourceRoot":"","sources":["../../../src/transform/write/selects.ts"],"names":[],"mappings":"AAGA,KAAK,IAAI,GAAG;IACV,IAAI,EAAE,OAAO,CAAA;IACb,EAAE,CAAC,EAAE,OAAO,CAAA;IACZ,MAAM,CAAC,EAAE,MAAM,CAAA;CAChB,CAAA;AAED,eAAO,MAAM,gBAAgB,yBAA0B,IAAI,8BAoB1D,CAAA"}
@@ -9,12 +9,13 @@ Object.defineProperty(exports, "transformSelects", {
9
9
  }
10
10
  });
11
11
  const _isArrayOfRows = require("../../utilities/isArrayOfRows");
12
- const transformSelects = ({ data, locale })=>{
12
+ const transformSelects = ({ id, data, locale })=>{
13
13
  const newRows = [];
14
14
  if ((0, _isArrayOfRows.isArrayOfRows)(data)) {
15
15
  data.forEach((value, i)=>{
16
16
  const newRow = {
17
17
  order: i + 1,
18
+ parent: id,
18
19
  value
19
20
  };
20
21
  if (locale) {
@@ -26,4 +27,4 @@ const transformSelects = ({ data, locale })=>{
26
27
  return newRows;
27
28
  };
28
29
 
29
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy90cmFuc2Zvcm0vd3JpdGUvc2VsZWN0cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBuby1wYXJhbS1yZWFzc2lnbiAqL1xuaW1wb3J0IHsgaXNBcnJheU9mUm93cyB9IGZyb20gJy4uLy4uL3V0aWxpdGllcy9pc0FycmF5T2ZSb3dzJ1xuXG50eXBlIEFyZ3MgPSB7XG4gIGRhdGE6IHVua25vd25cbiAgbG9jYWxlPzogc3RyaW5nXG59XG5cbmV4cG9ydCBjb25zdCB0cmFuc2Zvcm1TZWxlY3RzID0gKHsgZGF0YSwgbG9jYWxlIH06IEFyZ3MpID0+IHtcbiAgY29uc3QgbmV3Um93czogUmVjb3JkPHN0cmluZywgdW5rbm93bj5bXSA9IFtdXG5cbiAgaWYgKGlzQXJyYXlPZlJvd3MoZGF0YSkpIHtcbiAgICBkYXRhLmZvckVhY2goKHZhbHVlLCBpKSA9PiB7XG4gICAgICBjb25zdCBuZXdSb3c6IFJlY29yZDxzdHJpbmcsIHVua25vd24+ID0ge1xuICAgICAgICBvcmRlcjogaSArIDEsXG4gICAgICAgIHZhbHVlLFxuICAgICAgfVxuXG4gICAgICBpZiAobG9jYWxlKSB7XG4gICAgICAgIG5ld1Jvdy5sb2NhbGUgPSBsb2NhbGVcbiAgICAgIH1cblxuICAgICAgbmV3Um93cy5wdXNoKG5ld1JvdylcbiAgICB9KVxuICB9XG5cbiAgcmV0dXJuIG5ld1Jvd3Ncbn1cbiJdLCJuYW1lcyI6WyJ0cmFuc2Zvcm1TZWxlY3RzIiwiZGF0YSIsImxvY2FsZSIsIm5ld1Jvd3MiLCJpc0FycmF5T2ZSb3dzIiwiZm9yRWFjaCIsInZhbHVlIiwiaSIsIm5ld1JvdyIsIm9yZGVyIiwicHVzaCJdLCJtYXBwaW5ncyI6IkFBQUEsb0NBQW9DOzs7OytCQVF2QkE7OztlQUFBQTs7OytCQVBpQjtBQU92QixNQUFNQSxtQkFBbUIsQ0FBQyxFQUFFQyxJQUFJLEVBQUVDLE1BQU0sRUFBUTtJQUNyRCxNQUFNQyxVQUFxQyxFQUFFO0lBRTdDLElBQUlDLElBQUFBLDRCQUFhLEVBQUNILE9BQU87UUFDdkJBLEtBQUtJLE9BQU8sQ0FBQyxDQUFDQyxPQUFPQztZQUNuQixNQUFNQyxTQUFrQztnQkFDdENDLE9BQU9GLElBQUk7Z0JBQ1hEO1lBQ0Y7WUFFQSxJQUFJSixRQUFRO2dCQUNWTSxPQUFPTixNQUFNLEdBQUdBO1lBQ2xCO1lBRUFDLFFBQVFPLElBQUksQ0FBQ0Y7UUFDZjtJQUNGO0lBRUEsT0FBT0w7QUFDVCJ9
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy90cmFuc2Zvcm0vd3JpdGUvc2VsZWN0cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBuby1wYXJhbS1yZWFzc2lnbiAqL1xuaW1wb3J0IHsgaXNBcnJheU9mUm93cyB9IGZyb20gJy4uLy4uL3V0aWxpdGllcy9pc0FycmF5T2ZSb3dzJ1xuXG50eXBlIEFyZ3MgPSB7XG4gIGRhdGE6IHVua25vd25cbiAgaWQ/OiB1bmtub3duXG4gIGxvY2FsZT86IHN0cmluZ1xufVxuXG5leHBvcnQgY29uc3QgdHJhbnNmb3JtU2VsZWN0cyA9ICh7IGlkLCBkYXRhLCBsb2NhbGUgfTogQXJncykgPT4ge1xuICBjb25zdCBuZXdSb3dzOiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPltdID0gW11cblxuICBpZiAoaXNBcnJheU9mUm93cyhkYXRhKSkge1xuICAgIGRhdGEuZm9yRWFjaCgodmFsdWUsIGkpID0+IHtcbiAgICAgIGNvbnN0IG5ld1JvdzogUmVjb3JkPHN0cmluZywgdW5rbm93bj4gPSB7XG4gICAgICAgIG9yZGVyOiBpICsgMSxcbiAgICAgICAgcGFyZW50OiBpZCxcbiAgICAgICAgdmFsdWUsXG4gICAgICB9XG5cbiAgICAgIGlmIChsb2NhbGUpIHtcbiAgICAgICAgbmV3Um93LmxvY2FsZSA9IGxvY2FsZVxuICAgICAgfVxuXG4gICAgICBuZXdSb3dzLnB1c2gobmV3Um93KVxuICAgIH0pXG4gIH1cblxuICByZXR1cm4gbmV3Um93c1xufVxuIl0sIm5hbWVzIjpbInRyYW5zZm9ybVNlbGVjdHMiLCJpZCIsImRhdGEiLCJsb2NhbGUiLCJuZXdSb3dzIiwiaXNBcnJheU9mUm93cyIsImZvckVhY2giLCJ2YWx1ZSIsImkiLCJuZXdSb3ciLCJvcmRlciIsInBhcmVudCIsInB1c2giXSwibWFwcGluZ3MiOiJBQUFBLG9DQUFvQzs7OzsrQkFTdkJBOzs7ZUFBQUE7OzsrQkFSaUI7QUFRdkIsTUFBTUEsbUJBQW1CLENBQUMsRUFBRUMsRUFBRSxFQUFFQyxJQUFJLEVBQUVDLE1BQU0sRUFBUTtJQUN6RCxNQUFNQyxVQUFxQyxFQUFFO0lBRTdDLElBQUlDLElBQUFBLDRCQUFhLEVBQUNILE9BQU87UUFDdkJBLEtBQUtJLE9BQU8sQ0FBQyxDQUFDQyxPQUFPQztZQUNuQixNQUFNQyxTQUFrQztnQkFDdENDLE9BQU9GLElBQUk7Z0JBQ1hHLFFBQVFWO2dCQUNSTTtZQUNGO1lBRUEsSUFBSUosUUFBUTtnQkFDVk0sT0FBT04sTUFBTSxHQUFHQTtZQUNsQjtZQUVBQyxRQUFRUSxJQUFJLENBQUNIO1FBQ2Y7SUFDRjtJQUVBLE9BQU9MO0FBQ1QifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"traverseFields.d.ts","sourceRoot":"","sources":["../../../src/transform/write/traverseFields.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAK1C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,aAAa,CAAA;AAClD,OAAO,KAAK,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,oBAAoB,EAAE,MAAM,SAAS,CAAA;AASvF,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,MAAM,EAAE;QACN,CAAC,SAAS,EAAE,MAAM,GAAG,gBAAgB,EAAE,CAAA;KACxC,CAAA;IACD;;OAEG;IACH,aAAa,EAAE,MAAM,CAAA;IACrB,MAAM,EAAE;QACN,CAAC,SAAS,EAAE,MAAM,GAAG,gBAAgB,EAAE,CAAA;KACxC,CAAA;IACD,cAAc,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IAC3B;;;OAGG;IACH,YAAY,EAAE,MAAM,CAAA;IACpB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;IAC7B,eAAe,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAA;IAC3C;;;OAGG;IACH,WAAW,EAAE,MAAM,CAAA;IACnB,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,OAAO,EAAE;QACP,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;KAC1C,CAAA;IACD,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAA;IAClC;;OAEG;IACH,eAAe,EAAE,MAAM,CAAA;IACvB,IAAI,EAAE,MAAM,CAAA;IACZ,aAAa,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAA;IACxC,qBAAqB,EAAE,oBAAoB,EAAE,CAAA;IAC7C,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;IAC5B,OAAO,EAAE;QACP,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAA;KAC/C,CAAA;CACF,CAAA;AAED,eAAO,MAAM,cAAc,qOAoBxB,IAAI,SAsZN,CAAA"}
1
+ {"version":3,"file":"traverseFields.d.ts","sourceRoot":"","sources":["../../../src/transform/write/traverseFields.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAK1C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,aAAa,CAAA;AAClD,OAAO,KAAK,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,oBAAoB,EAAE,MAAM,SAAS,CAAA;AASvF,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,MAAM,EAAE;QACN,CAAC,SAAS,EAAE,MAAM,GAAG,gBAAgB,EAAE,CAAA;KACxC,CAAA;IACD;;OAEG;IACH,aAAa,EAAE,MAAM,CAAA;IACrB,MAAM,EAAE;QACN,CAAC,SAAS,EAAE,MAAM,GAAG,gBAAgB,EAAE,CAAA;KACxC,CAAA;IACD,cAAc,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IAC3B;;;OAGG;IACH,YAAY,EAAE,MAAM,CAAA;IACpB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;IAC7B,eAAe,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAA;IAC3C;;;OAGG;IACH,WAAW,EAAE,MAAM,CAAA;IACnB,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,OAAO,EAAE;QACP,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;KAC1C,CAAA;IACD,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAA;IAClC;;OAEG;IACH,eAAe,EAAE,MAAM,CAAA;IACvB,IAAI,EAAE,MAAM,CAAA;IACZ,aAAa,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAA;IACxC,qBAAqB,EAAE,oBAAoB,EAAE,CAAA;IAC7C,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;IAC5B,OAAO,EAAE;QACP,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAA;KAC/C,CAAA;CACF,CAAA;AAED,eAAO,MAAM,cAAc,qOAoBxB,IAAI,SAwZN,CAAA"}
@@ -343,6 +343,7 @@ const traverseFields = ({ adapter, arrays, baseTableName, blocks, blocksToDelete
343
343
  Object.entries(data[field.name]).forEach(([localeKey, localeData])=>{
344
344
  if (Array.isArray(localeData)) {
345
345
  const newRows = (0, _selects.transformSelects)({
346
+ id: data._uuid || data.id,
346
347
  data: localeData,
347
348
  locale: localeKey
348
349
  });
@@ -352,6 +353,7 @@ const traverseFields = ({ adapter, arrays, baseTableName, blocks, blocksToDelete
352
353
  }
353
354
  } else if (Array.isArray(data[field.name])) {
354
355
  const newRows = (0, _selects.transformSelects)({
356
+ id: data._uuid || data.id,
355
357
  data: data[field.name]
356
358
  });
357
359
  selects[selectTableName] = selects[selectTableName].concat(newRows);
@@ -399,4 +401,4 @@ const traverseFields = ({ adapter, arrays, baseTableName, blocks, blocksToDelete
399
401
  });
400
402
  };
401
403
 
402
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/transform/write/traverseFields.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { Field } from 'payload/types'\n\nimport { fieldAffectsData } from 'payload/types'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { PostgresAdapter } from '../../types'\nimport type { ArrayRowToInsert, BlockRowToInsert, RelationshipToDelete } from './types'\n\nimport { isArrayOfRows } from '../../utilities/isArrayOfRows'\nimport { transformArray } from './array'\nimport { transformBlocks } from './blocks'\nimport { transformNumbers } from './numbers'\nimport { transformRelationship } from './relationships'\nimport { transformSelects } from './selects'\n\ntype Args = {\n  adapter: PostgresAdapter\n  arrays: {\n    [tableName: string]: ArrayRowToInsert[]\n  }\n  /**\n   * This is the name of the base table\n   */\n  baseTableName: string\n  blocks: {\n    [blockType: string]: BlockRowToInsert[]\n  }\n  blocksToDelete: Set<string>\n  /**\n   * A snake-case field prefix, representing prior fields\n   * Ex: my_group_my_named_tab_\n   */\n  columnPrefix: string\n  data: Record<string, unknown>\n  existingLocales?: Record<string, unknown>[]\n  /**\n   * A prefix that will retain camel-case formatting, representing prior fields\n   * Ex: myGroup_myNamedTab_\n   */\n  fieldPrefix: string\n  fields: Field[]\n  forcedLocale?: string\n  locales: {\n    [locale: string]: Record<string, unknown>\n  }\n  numbers: Record<string, unknown>[]\n  /**\n   * This is the name of the parent table\n   */\n  parentTableName: string\n  path: string\n  relationships: Record<string, unknown>[]\n  relationshipsToDelete: RelationshipToDelete[]\n  row: Record<string, unknown>\n  selects: {\n    [tableName: string]: Record<string, unknown>[]\n  }\n}\n\nexport const traverseFields = ({\n  adapter,\n  arrays,\n  baseTableName,\n  blocks,\n  blocksToDelete,\n  columnPrefix,\n  data,\n  existingLocales,\n  fieldPrefix,\n  fields,\n  forcedLocale,\n  locales,\n  numbers,\n  parentTableName,\n  path,\n  relationships,\n  relationshipsToDelete,\n  row,\n  selects,\n}: Args) => {\n  fields.forEach((field) => {\n    let columnName = ''\n    let fieldName = ''\n    let fieldData: unknown\n\n    if (fieldAffectsData(field)) {\n      columnName = `${columnPrefix || ''}${toSnakeCase(field.name)}`\n      fieldName = `${fieldPrefix || ''}${field.name}`\n      fieldData = data[field.name]\n    }\n\n    if (field.type === 'array') {\n      const arrayTableName = `${parentTableName}_${columnName}`\n\n      if (!arrays[arrayTableName]) arrays[arrayTableName] = []\n\n      if (field.localized) {\n        if (typeof data[field.name] === 'object' && data[field.name] !== null) {\n          Object.entries(data[field.name]).forEach(([localeKey, localeData]) => {\n            if (Array.isArray(localeData)) {\n              const newRows = transformArray({\n                adapter,\n                arrayTableName,\n                baseTableName,\n                blocks,\n                blocksToDelete,\n                data: localeData,\n                field,\n                locale: localeKey,\n                numbers,\n                path,\n                relationships,\n                relationshipsToDelete,\n                selects,\n              })\n\n              arrays[arrayTableName] = arrays[arrayTableName].concat(newRows)\n            }\n          })\n        }\n      } else {\n        const newRows = transformArray({\n          adapter,\n          arrayTableName,\n          baseTableName,\n          blocks,\n          blocksToDelete,\n          data: data[field.name],\n          field,\n          numbers,\n          path,\n          relationships,\n          relationshipsToDelete,\n          selects,\n        })\n\n        arrays[arrayTableName] = arrays[arrayTableName].concat(newRows)\n      }\n\n      return\n    }\n\n    if (field.type === 'blocks') {\n      field.blocks.forEach(({ slug }) => {\n        blocksToDelete.add(toSnakeCase(slug))\n      })\n\n      if (field.localized) {\n        if (typeof data[field.name] === 'object' && data[field.name] !== null) {\n          Object.entries(data[field.name]).forEach(([localeKey, localeData]) => {\n            if (Array.isArray(localeData)) {\n              transformBlocks({\n                adapter,\n                baseTableName,\n                blocks,\n                blocksToDelete,\n                data: localeData,\n                field,\n                locale: localeKey,\n                numbers,\n                path,\n                relationships,\n                relationshipsToDelete,\n                selects,\n              })\n            }\n          })\n        }\n      } else if (isArrayOfRows(fieldData)) {\n        transformBlocks({\n          adapter,\n          baseTableName,\n          blocks,\n          blocksToDelete,\n          data: fieldData,\n          field,\n          numbers,\n          path,\n          relationships,\n          relationshipsToDelete,\n          selects,\n        })\n      }\n\n      return\n    }\n\n    if (field.type === 'group') {\n      if (typeof data[field.name] === 'object' && data[field.name] !== null) {\n        if (field.localized) {\n          Object.entries(data[field.name]).forEach(([localeKey, localeData]) => {\n            traverseFields({\n              adapter,\n              arrays,\n              baseTableName,\n              blocks,\n              blocksToDelete,\n              columnPrefix: `${columnName}_`,\n              data: localeData as Record<string, unknown>,\n              existingLocales,\n              fieldPrefix: `${fieldName}_`,\n              fields: field.fields,\n              forcedLocale: localeKey,\n              locales,\n              numbers,\n              parentTableName,\n              path: `${path || ''}${field.name}.`,\n              relationships,\n              relationshipsToDelete,\n              row,\n              selects,\n            })\n          })\n        } else {\n          traverseFields({\n            adapter,\n            arrays,\n            baseTableName,\n            blocks,\n            blocksToDelete,\n            columnPrefix: `${columnName}_`,\n            data: data[field.name] as Record<string, unknown>,\n            existingLocales,\n            fieldPrefix: `${fieldName}_`,\n            fields: field.fields,\n            locales,\n            numbers,\n            parentTableName,\n            path: `${path || ''}${field.name}.`,\n            relationships,\n            relationshipsToDelete,\n            row,\n            selects,\n          })\n        }\n      }\n\n      return\n    }\n\n    if (field.type === 'tabs') {\n      field.tabs.forEach((tab) => {\n        if ('name' in tab) {\n          if (typeof data[tab.name] === 'object' && data[tab.name] !== null) {\n            if (tab.localized) {\n              Object.entries(data[tab.name]).forEach(([localeKey, localeData]) => {\n                traverseFields({\n                  adapter,\n                  arrays,\n                  baseTableName,\n                  blocks,\n                  blocksToDelete,\n                  columnPrefix: `${columnPrefix || ''}${toSnakeCase(tab.name)}_`,\n                  data: localeData as Record<string, unknown>,\n                  existingLocales,\n                  fieldPrefix: `${fieldPrefix || ''}${tab.name}_`,\n                  fields: tab.fields,\n                  forcedLocale: localeKey,\n                  locales,\n                  numbers,\n                  parentTableName,\n                  path: `${path || ''}${tab.name}.`,\n                  relationships,\n                  relationshipsToDelete,\n                  row,\n                  selects,\n                })\n              })\n            } else {\n              traverseFields({\n                adapter,\n                arrays,\n                baseTableName,\n                blocks,\n                blocksToDelete,\n                columnPrefix: `${columnPrefix || ''}${toSnakeCase(tab.name)}_`,\n                data: data[tab.name] as Record<string, unknown>,\n                existingLocales,\n                fieldPrefix: `${fieldPrefix || ''}${tab.name}_`,\n                fields: tab.fields,\n                locales,\n                numbers,\n                parentTableName,\n                path: `${path || ''}${tab.name}.`,\n                relationships,\n                relationshipsToDelete,\n                row,\n                selects,\n              })\n            }\n          }\n        } else {\n          traverseFields({\n            adapter,\n            arrays,\n            baseTableName,\n            blocks,\n            blocksToDelete,\n            columnPrefix,\n            data,\n            existingLocales,\n            fieldPrefix,\n            fields: tab.fields,\n            locales,\n            numbers,\n            parentTableName,\n            path,\n            relationships,\n            relationshipsToDelete,\n            row,\n            selects,\n          })\n        }\n      })\n    }\n\n    if (field.type === 'row' || field.type === 'collapsible') {\n      traverseFields({\n        adapter,\n        arrays,\n        baseTableName,\n        blocks,\n        blocksToDelete,\n        columnPrefix,\n        data,\n        existingLocales,\n        fieldPrefix,\n        fields: field.fields,\n        locales,\n        numbers,\n        parentTableName,\n        path,\n        relationships,\n        relationshipsToDelete,\n        row,\n        selects,\n      })\n    }\n\n    if (field.type === 'relationship' || field.type === 'upload') {\n      const relationshipPath = `${path || ''}${field.name}`\n\n      if (field.localized) {\n        if (typeof fieldData === 'object') {\n          Object.entries(fieldData).forEach(([localeKey, localeData]) => {\n            if (localeData === null) {\n              relationshipsToDelete.push({\n                locale: localeKey,\n                path: relationshipPath,\n              })\n              return\n            }\n\n            transformRelationship({\n              baseRow: {\n                locale: localeKey,\n                path: relationshipPath,\n              },\n              data: localeData,\n              field,\n              relationships,\n            })\n          })\n        }\n      } else {\n        if (fieldData === null || (Array.isArray(fieldData) && fieldData.length === 0)) {\n          relationshipsToDelete.push({ path: relationshipPath })\n          return\n        }\n\n        transformRelationship({\n          baseRow: {\n            path: relationshipPath,\n          },\n          data: fieldData,\n          field,\n          relationships,\n        })\n      }\n\n      return\n    }\n\n    if (field.type === 'number' && field.hasMany) {\n      const numberPath = `${path || ''}${field.name}`\n\n      if (field.localized) {\n        if (typeof fieldData === 'object') {\n          Object.entries(fieldData).forEach(([localeKey, localeData]) => {\n            if (Array.isArray(localeData)) {\n              transformNumbers({\n                baseRow: {\n                  locale: localeKey,\n                  path: numberPath,\n                },\n                data: localeData,\n                numbers,\n              })\n            }\n          })\n        }\n      } else if (Array.isArray(fieldData)) {\n        transformNumbers({\n          baseRow: {\n            path: numberPath,\n          },\n          data: fieldData,\n          numbers,\n        })\n      }\n\n      return\n    }\n\n    if (field.type === 'select' && field.hasMany) {\n      const selectTableName = `${parentTableName}_${columnName}`\n      if (!selects[selectTableName]) selects[selectTableName] = []\n\n      if (field.localized) {\n        if (typeof data[field.name] === 'object' && data[field.name] !== null) {\n          Object.entries(data[field.name]).forEach(([localeKey, localeData]) => {\n            if (Array.isArray(localeData)) {\n              const newRows = transformSelects({\n                data: localeData,\n                locale: localeKey,\n              })\n\n              selects[selectTableName] = selects[selectTableName].concat(newRows)\n            }\n          })\n        }\n      } else if (Array.isArray(data[field.name])) {\n        const newRows = transformSelects({\n          data: data[field.name],\n        })\n\n        selects[selectTableName] = selects[selectTableName].concat(newRows)\n      }\n\n      return\n    }\n\n    if (fieldAffectsData(field)) {\n      const valuesToTransform: { localeKey?: string; ref: unknown; value: unknown }[] = []\n\n      if (field.localized) {\n        if (typeof fieldData === 'object' && fieldData !== null) {\n          Object.entries(fieldData).forEach(([localeKey, localeData]) => {\n            if (!locales[localeKey]) locales[localeKey] = {}\n\n            valuesToTransform.push({\n              localeKey,\n              ref: locales,\n              value: localeData,\n            })\n          })\n        }\n      } else {\n        let ref = row\n\n        if (forcedLocale) {\n          if (!locales[forcedLocale]) locales[forcedLocale] = {}\n          ref = locales[forcedLocale]\n        }\n\n        valuesToTransform.push({ ref, value: fieldData })\n      }\n\n      valuesToTransform.forEach(({ localeKey, ref, value }) => {\n        if (typeof value !== 'undefined') {\n          let formattedValue = value\n\n          if (field.type === 'date' && field.name === 'updatedAt') {\n            formattedValue = new Date().toISOString()\n          }\n\n          if (localeKey) {\n            ref[localeKey][fieldName] = formattedValue\n          } else {\n            ref[fieldName] = formattedValue\n          }\n        }\n      })\n    }\n  })\n}\n"],"names":["traverseFields","adapter","arrays","baseTableName","blocks","blocksToDelete","columnPrefix","data","existingLocales","fieldPrefix","fields","forcedLocale","locales","numbers","parentTableName","path","relationships","relationshipsToDelete","row","selects","forEach","field","columnName","fieldName","fieldData","fieldAffectsData","toSnakeCase","name","type","arrayTableName","localized","Object","entries","localeKey","localeData","Array","isArray","newRows","transformArray","locale","concat","slug","add","transformBlocks","isArrayOfRows","tabs","tab","relationshipPath","push","transformRelationship","baseRow","length","hasMany","numberPath","transformNumbers","selectTableName","transformSelects","valuesToTransform","ref","value","formattedValue","Date","toISOString"],"mappings":"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"}
404
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/transform/write/traverseFields.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { Field } from 'payload/types'\n\nimport { fieldAffectsData } from 'payload/types'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { PostgresAdapter } from '../../types'\nimport type { ArrayRowToInsert, BlockRowToInsert, RelationshipToDelete } from './types'\n\nimport { isArrayOfRows } from '../../utilities/isArrayOfRows'\nimport { transformArray } from './array'\nimport { transformBlocks } from './blocks'\nimport { transformNumbers } from './numbers'\nimport { transformRelationship } from './relationships'\nimport { transformSelects } from './selects'\n\ntype Args = {\n  adapter: PostgresAdapter\n  arrays: {\n    [tableName: string]: ArrayRowToInsert[]\n  }\n  /**\n   * This is the name of the base table\n   */\n  baseTableName: string\n  blocks: {\n    [blockType: string]: BlockRowToInsert[]\n  }\n  blocksToDelete: Set<string>\n  /**\n   * A snake-case field prefix, representing prior fields\n   * Ex: my_group_my_named_tab_\n   */\n  columnPrefix: string\n  data: Record<string, unknown>\n  existingLocales?: Record<string, unknown>[]\n  /**\n   * A prefix that will retain camel-case formatting, representing prior fields\n   * Ex: myGroup_myNamedTab_\n   */\n  fieldPrefix: string\n  fields: Field[]\n  forcedLocale?: string\n  locales: {\n    [locale: string]: Record<string, unknown>\n  }\n  numbers: Record<string, unknown>[]\n  /**\n   * This is the name of the parent table\n   */\n  parentTableName: string\n  path: string\n  relationships: Record<string, unknown>[]\n  relationshipsToDelete: RelationshipToDelete[]\n  row: Record<string, unknown>\n  selects: {\n    [tableName: string]: Record<string, unknown>[]\n  }\n}\n\nexport const traverseFields = ({\n  adapter,\n  arrays,\n  baseTableName,\n  blocks,\n  blocksToDelete,\n  columnPrefix,\n  data,\n  existingLocales,\n  fieldPrefix,\n  fields,\n  forcedLocale,\n  locales,\n  numbers,\n  parentTableName,\n  path,\n  relationships,\n  relationshipsToDelete,\n  row,\n  selects,\n}: Args) => {\n  fields.forEach((field) => {\n    let columnName = ''\n    let fieldName = ''\n    let fieldData: unknown\n\n    if (fieldAffectsData(field)) {\n      columnName = `${columnPrefix || ''}${toSnakeCase(field.name)}`\n      fieldName = `${fieldPrefix || ''}${field.name}`\n      fieldData = data[field.name]\n    }\n\n    if (field.type === 'array') {\n      const arrayTableName = `${parentTableName}_${columnName}`\n\n      if (!arrays[arrayTableName]) arrays[arrayTableName] = []\n\n      if (field.localized) {\n        if (typeof data[field.name] === 'object' && data[field.name] !== null) {\n          Object.entries(data[field.name]).forEach(([localeKey, localeData]) => {\n            if (Array.isArray(localeData)) {\n              const newRows = transformArray({\n                adapter,\n                arrayTableName,\n                baseTableName,\n                blocks,\n                blocksToDelete,\n                data: localeData,\n                field,\n                locale: localeKey,\n                numbers,\n                path,\n                relationships,\n                relationshipsToDelete,\n                selects,\n              })\n\n              arrays[arrayTableName] = arrays[arrayTableName].concat(newRows)\n            }\n          })\n        }\n      } else {\n        const newRows = transformArray({\n          adapter,\n          arrayTableName,\n          baseTableName,\n          blocks,\n          blocksToDelete,\n          data: data[field.name],\n          field,\n          numbers,\n          path,\n          relationships,\n          relationshipsToDelete,\n          selects,\n        })\n\n        arrays[arrayTableName] = arrays[arrayTableName].concat(newRows)\n      }\n\n      return\n    }\n\n    if (field.type === 'blocks') {\n      field.blocks.forEach(({ slug }) => {\n        blocksToDelete.add(toSnakeCase(slug))\n      })\n\n      if (field.localized) {\n        if (typeof data[field.name] === 'object' && data[field.name] !== null) {\n          Object.entries(data[field.name]).forEach(([localeKey, localeData]) => {\n            if (Array.isArray(localeData)) {\n              transformBlocks({\n                adapter,\n                baseTableName,\n                blocks,\n                blocksToDelete,\n                data: localeData,\n                field,\n                locale: localeKey,\n                numbers,\n                path,\n                relationships,\n                relationshipsToDelete,\n                selects,\n              })\n            }\n          })\n        }\n      } else if (isArrayOfRows(fieldData)) {\n        transformBlocks({\n          adapter,\n          baseTableName,\n          blocks,\n          blocksToDelete,\n          data: fieldData,\n          field,\n          numbers,\n          path,\n          relationships,\n          relationshipsToDelete,\n          selects,\n        })\n      }\n\n      return\n    }\n\n    if (field.type === 'group') {\n      if (typeof data[field.name] === 'object' && data[field.name] !== null) {\n        if (field.localized) {\n          Object.entries(data[field.name]).forEach(([localeKey, localeData]) => {\n            traverseFields({\n              adapter,\n              arrays,\n              baseTableName,\n              blocks,\n              blocksToDelete,\n              columnPrefix: `${columnName}_`,\n              data: localeData as Record<string, unknown>,\n              existingLocales,\n              fieldPrefix: `${fieldName}_`,\n              fields: field.fields,\n              forcedLocale: localeKey,\n              locales,\n              numbers,\n              parentTableName,\n              path: `${path || ''}${field.name}.`,\n              relationships,\n              relationshipsToDelete,\n              row,\n              selects,\n            })\n          })\n        } else {\n          traverseFields({\n            adapter,\n            arrays,\n            baseTableName,\n            blocks,\n            blocksToDelete,\n            columnPrefix: `${columnName}_`,\n            data: data[field.name] as Record<string, unknown>,\n            existingLocales,\n            fieldPrefix: `${fieldName}_`,\n            fields: field.fields,\n            locales,\n            numbers,\n            parentTableName,\n            path: `${path || ''}${field.name}.`,\n            relationships,\n            relationshipsToDelete,\n            row,\n            selects,\n          })\n        }\n      }\n\n      return\n    }\n\n    if (field.type === 'tabs') {\n      field.tabs.forEach((tab) => {\n        if ('name' in tab) {\n          if (typeof data[tab.name] === 'object' && data[tab.name] !== null) {\n            if (tab.localized) {\n              Object.entries(data[tab.name]).forEach(([localeKey, localeData]) => {\n                traverseFields({\n                  adapter,\n                  arrays,\n                  baseTableName,\n                  blocks,\n                  blocksToDelete,\n                  columnPrefix: `${columnPrefix || ''}${toSnakeCase(tab.name)}_`,\n                  data: localeData as Record<string, unknown>,\n                  existingLocales,\n                  fieldPrefix: `${fieldPrefix || ''}${tab.name}_`,\n                  fields: tab.fields,\n                  forcedLocale: localeKey,\n                  locales,\n                  numbers,\n                  parentTableName,\n                  path: `${path || ''}${tab.name}.`,\n                  relationships,\n                  relationshipsToDelete,\n                  row,\n                  selects,\n                })\n              })\n            } else {\n              traverseFields({\n                adapter,\n                arrays,\n                baseTableName,\n                blocks,\n                blocksToDelete,\n                columnPrefix: `${columnPrefix || ''}${toSnakeCase(tab.name)}_`,\n                data: data[tab.name] as Record<string, unknown>,\n                existingLocales,\n                fieldPrefix: `${fieldPrefix || ''}${tab.name}_`,\n                fields: tab.fields,\n                locales,\n                numbers,\n                parentTableName,\n                path: `${path || ''}${tab.name}.`,\n                relationships,\n                relationshipsToDelete,\n                row,\n                selects,\n              })\n            }\n          }\n        } else {\n          traverseFields({\n            adapter,\n            arrays,\n            baseTableName,\n            blocks,\n            blocksToDelete,\n            columnPrefix,\n            data,\n            existingLocales,\n            fieldPrefix,\n            fields: tab.fields,\n            locales,\n            numbers,\n            parentTableName,\n            path,\n            relationships,\n            relationshipsToDelete,\n            row,\n            selects,\n          })\n        }\n      })\n    }\n\n    if (field.type === 'row' || field.type === 'collapsible') {\n      traverseFields({\n        adapter,\n        arrays,\n        baseTableName,\n        blocks,\n        blocksToDelete,\n        columnPrefix,\n        data,\n        existingLocales,\n        fieldPrefix,\n        fields: field.fields,\n        locales,\n        numbers,\n        parentTableName,\n        path,\n        relationships,\n        relationshipsToDelete,\n        row,\n        selects,\n      })\n    }\n\n    if (field.type === 'relationship' || field.type === 'upload') {\n      const relationshipPath = `${path || ''}${field.name}`\n\n      if (field.localized) {\n        if (typeof fieldData === 'object') {\n          Object.entries(fieldData).forEach(([localeKey, localeData]) => {\n            if (localeData === null) {\n              relationshipsToDelete.push({\n                locale: localeKey,\n                path: relationshipPath,\n              })\n              return\n            }\n\n            transformRelationship({\n              baseRow: {\n                locale: localeKey,\n                path: relationshipPath,\n              },\n              data: localeData,\n              field,\n              relationships,\n            })\n          })\n        }\n      } else {\n        if (fieldData === null || (Array.isArray(fieldData) && fieldData.length === 0)) {\n          relationshipsToDelete.push({ path: relationshipPath })\n          return\n        }\n\n        transformRelationship({\n          baseRow: {\n            path: relationshipPath,\n          },\n          data: fieldData,\n          field,\n          relationships,\n        })\n      }\n\n      return\n    }\n\n    if (field.type === 'number' && field.hasMany) {\n      const numberPath = `${path || ''}${field.name}`\n\n      if (field.localized) {\n        if (typeof fieldData === 'object') {\n          Object.entries(fieldData).forEach(([localeKey, localeData]) => {\n            if (Array.isArray(localeData)) {\n              transformNumbers({\n                baseRow: {\n                  locale: localeKey,\n                  path: numberPath,\n                },\n                data: localeData,\n                numbers,\n              })\n            }\n          })\n        }\n      } else if (Array.isArray(fieldData)) {\n        transformNumbers({\n          baseRow: {\n            path: numberPath,\n          },\n          data: fieldData,\n          numbers,\n        })\n      }\n\n      return\n    }\n\n    if (field.type === 'select' && field.hasMany) {\n      const selectTableName = `${parentTableName}_${columnName}`\n      if (!selects[selectTableName]) selects[selectTableName] = []\n\n      if (field.localized) {\n        if (typeof data[field.name] === 'object' && data[field.name] !== null) {\n          Object.entries(data[field.name]).forEach(([localeKey, localeData]) => {\n            if (Array.isArray(localeData)) {\n              const newRows = transformSelects({\n                id: data._uuid || data.id,\n                data: localeData,\n                locale: localeKey,\n              })\n\n              selects[selectTableName] = selects[selectTableName].concat(newRows)\n            }\n          })\n        }\n      } else if (Array.isArray(data[field.name])) {\n        const newRows = transformSelects({\n          id: data._uuid || data.id,\n          data: data[field.name],\n        })\n\n        selects[selectTableName] = selects[selectTableName].concat(newRows)\n      }\n\n      return\n    }\n\n    if (fieldAffectsData(field)) {\n      const valuesToTransform: { localeKey?: string; ref: unknown; value: unknown }[] = []\n\n      if (field.localized) {\n        if (typeof fieldData === 'object' && fieldData !== null) {\n          Object.entries(fieldData).forEach(([localeKey, localeData]) => {\n            if (!locales[localeKey]) locales[localeKey] = {}\n\n            valuesToTransform.push({\n              localeKey,\n              ref: locales,\n              value: localeData,\n            })\n          })\n        }\n      } else {\n        let ref = row\n\n        if (forcedLocale) {\n          if (!locales[forcedLocale]) locales[forcedLocale] = {}\n          ref = locales[forcedLocale]\n        }\n\n        valuesToTransform.push({ ref, value: fieldData })\n      }\n\n      valuesToTransform.forEach(({ localeKey, ref, value }) => {\n        if (typeof value !== 'undefined') {\n          let formattedValue = value\n\n          if (field.type === 'date' && field.name === 'updatedAt') {\n            formattedValue = new Date().toISOString()\n          }\n\n          if (localeKey) {\n            ref[localeKey][fieldName] = formattedValue\n          } else {\n            ref[fieldName] = formattedValue\n          }\n        }\n      })\n    }\n  })\n}\n"],"names":["traverseFields","adapter","arrays","baseTableName","blocks","blocksToDelete","columnPrefix","data","existingLocales","fieldPrefix","fields","forcedLocale","locales","numbers","parentTableName","path","relationships","relationshipsToDelete","row","selects","forEach","field","columnName","fieldName","fieldData","fieldAffectsData","toSnakeCase","name","type","arrayTableName","localized","Object","entries","localeKey","localeData","Array","isArray","newRows","transformArray","locale","concat","slug","add","transformBlocks","isArrayOfRows","tabs","tab","relationshipPath","push","transformRelationship","baseRow","length","hasMany","numberPath","transformNumbers","selectTableName","transformSelects","id","_uuid","valuesToTransform","ref","value","formattedValue","Date","toISOString"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/upsertRow/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAO/C,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,SAAS,CAAA;AASnC,eAAO,MAAM,SAAS,mHAYnB,IAAI,eAgSN,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/upsertRow/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAO/C,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,SAAS,CAAA;AASnC,eAAO,MAAM,SAAS,mHAYnB,IAAI,eAkSN,CAAA"}
@@ -80,7 +80,9 @@ const upsertRow = async ({ id, adapter, data, db, fields, operation, path = '',
80
80
  if (Object.keys(rowToInsert.selects).length > 0) {
81
81
  Object.entries(rowToInsert.selects).forEach(([selectTableName, selectRows])=>{
82
82
  selectRows.forEach((row)=>{
83
- row.parent = insertedRow.id;
83
+ if (typeof row.parent === 'undefined') {
84
+ row.parent = insertedRow.id;
85
+ }
84
86
  if (!selectsToInsert[selectTableName]) selectsToInsert[selectTableName] = [];
85
87
  selectsToInsert[selectTableName].push(row);
86
88
  });
@@ -255,4 +257,4 @@ const upsertRow = async ({ id, adapter, data, db, fields, operation, path = '',
255
257
  return result;
256
258
  };
257
259
 
258
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/upsertRow/index.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { TypeWithID } from 'payload/types'\n\nimport { eq } from 'drizzle-orm'\nimport { ValidationError } from 'payload/errors'\nimport { i18nInit } from 'payload/utilities'\n\nimport type { BlockRowToInsert } from '../transform/write/types'\nimport type { Args } from './types'\n\nimport { buildFindManyArgs } from '../find/buildFindManyArgs'\nimport { transform } from '../transform/read'\nimport { transformForWrite } from '../transform/write'\nimport { deleteExistingArrayRows } from './deleteExistingArrayRows'\nimport { deleteExistingRowsByPath } from './deleteExistingRowsByPath'\nimport { insertArrays } from './insertArrays'\n\nexport const upsertRow = async <T extends TypeWithID>({\n  id,\n  adapter,\n  data,\n  db,\n  fields,\n  operation,\n  path = '',\n  req,\n  tableName,\n  upsertTarget,\n  where,\n}: Args): Promise<T> => {\n  // Split out the incoming data into the corresponding:\n  // base row, locales, relationships, blocks, and arrays\n  const rowToInsert = transformForWrite({\n    adapter,\n    data,\n    fields,\n    path,\n    tableName,\n  })\n\n  // First, we insert the main row\n  let insertedRow: Record<string, unknown>\n\n  try {\n    if (operation === 'update') {\n      const target = upsertTarget || adapter.tables[tableName].id\n\n      if (id) {\n        rowToInsert.row.id = id\n        ;[insertedRow] = await db\n          .insert(adapter.tables[tableName])\n          .values(rowToInsert.row)\n          .onConflictDoUpdate({ set: rowToInsert.row, target })\n          .returning()\n      } else {\n        ;[insertedRow] = await db\n          .insert(adapter.tables[tableName])\n          .values(rowToInsert.row)\n          .onConflictDoUpdate({ set: rowToInsert.row, target, where })\n          .returning()\n      }\n    } else {\n      ;[insertedRow] = await db\n        .insert(adapter.tables[tableName])\n        .values(rowToInsert.row)\n        .returning()\n    }\n\n    const localesToInsert: Record<string, unknown>[] = []\n    const relationsToInsert: Record<string, unknown>[] = []\n    const numbersToInsert: Record<string, unknown>[] = []\n    const blocksToInsert: { [blockType: string]: BlockRowToInsert[] } = {}\n    const selectsToInsert: { [selectTableName: string]: Record<string, unknown>[] } = {}\n\n    // If there are locale rows with data, add the parent and locale to each\n    if (Object.keys(rowToInsert.locales).length > 0) {\n      Object.entries(rowToInsert.locales).forEach(([locale, localeRow]) => {\n        localeRow._parentID = insertedRow.id\n        localeRow._locale = locale\n        localesToInsert.push(localeRow)\n      })\n    }\n\n    // If there are relationships, add parent to each\n    if (rowToInsert.relationships.length > 0) {\n      rowToInsert.relationships.forEach((relation) => {\n        relation.parent = insertedRow.id\n        relationsToInsert.push(relation)\n      })\n    }\n\n    // If there are numbers, add parent to each\n    if (rowToInsert.numbers.length > 0) {\n      rowToInsert.numbers.forEach((numberRow) => {\n        numberRow.parent = insertedRow.id\n        numbersToInsert.push(numberRow)\n      })\n    }\n\n    // If there are selects, add parent to each, and then\n    // store by table name and rows\n    if (Object.keys(rowToInsert.selects).length > 0) {\n      Object.entries(rowToInsert.selects).forEach(([selectTableName, selectRows]) => {\n        selectRows.forEach((row) => {\n          row.parent = insertedRow.id\n          if (!selectsToInsert[selectTableName]) selectsToInsert[selectTableName] = []\n          selectsToInsert[selectTableName].push(row)\n        })\n      })\n    }\n\n    // If there are blocks, add parent to each, and then\n    // store by table name and rows\n    Object.keys(rowToInsert.blocks).forEach((blockName) => {\n      rowToInsert.blocks[blockName].forEach((blockRow) => {\n        blockRow.row._parentID = insertedRow.id\n        if (!blocksToInsert[blockName]) blocksToInsert[blockName] = []\n        if (blockRow.row.uuid) {\n          delete blockRow.row.uuid\n        }\n        blocksToInsert[blockName].push(blockRow)\n      })\n    })\n\n    // //////////////////////////////////\n    // INSERT LOCALES\n    // //////////////////////////////////\n\n    if (localesToInsert.length > 0) {\n      const localeTable = adapter.tables[`${tableName}_locales`]\n\n      if (operation === 'update') {\n        await db.delete(localeTable).where(eq(localeTable._parentID, insertedRow.id))\n      }\n\n      await db.insert(localeTable).values(localesToInsert)\n    }\n\n    // //////////////////////////////////\n    // INSERT RELATIONSHIPS\n    // //////////////////////////////////\n\n    const relationshipsTableName = `${tableName}_rels`\n\n    if (operation === 'update') {\n      await deleteExistingRowsByPath({\n        adapter,\n        db,\n        localeColumnName: 'locale',\n        parentColumnName: 'parent',\n        parentID: insertedRow.id,\n        pathColumnName: 'path',\n        rows: [...relationsToInsert, ...rowToInsert.relationshipsToDelete],\n        tableName: relationshipsTableName,\n      })\n    }\n\n    if (relationsToInsert.length > 0) {\n      await db.insert(adapter.tables[relationshipsTableName]).values(relationsToInsert)\n    }\n\n    // //////////////////////////////////\n    // INSERT hasMany NUMBERS\n    // //////////////////////////////////\n\n    const numbersTableName = `${tableName}_numbers`\n\n    if (operation === 'update') {\n      await deleteExistingRowsByPath({\n        adapter,\n        db,\n        localeColumnName: 'locale',\n        parentColumnName: 'parent',\n        parentID: insertedRow.id,\n        pathColumnName: 'path',\n        rows: numbersToInsert,\n        tableName: numbersTableName,\n      })\n    }\n\n    if (numbersToInsert.length > 0) {\n      await db.insert(adapter.tables[numbersTableName]).values(numbersToInsert).returning()\n    }\n\n    // //////////////////////////////////\n    // INSERT BLOCKS\n    // //////////////////////////////////\n\n    const insertedBlockRows: Record<string, Record<string, unknown>[]> = {}\n\n    if (operation === 'update') {\n      for (const blockName of rowToInsert.blocksToDelete) {\n        const blockTableName = `${tableName}_blocks_${blockName}`\n        const blockTable = adapter.tables[blockTableName]\n        await db.delete(blockTable).where(eq(blockTable._parentID, insertedRow.id))\n      }\n    }\n\n    for (const [blockName, blockRows] of Object.entries(blocksToInsert)) {\n      insertedBlockRows[blockName] = await db\n        .insert(adapter.tables[`${tableName}_blocks_${blockName}`])\n        .values(blockRows.map(({ row }) => row))\n        .returning()\n\n      insertedBlockRows[blockName].forEach((row, i) => {\n        blockRows[i].row = row\n      })\n\n      const blockLocaleIndexMap: number[] = []\n\n      const blockLocaleRowsToInsert = blockRows.reduce((acc, blockRow, i) => {\n        if (Object.entries(blockRow.locales).length > 0) {\n          Object.entries(blockRow.locales).forEach(([blockLocale, blockLocaleData]) => {\n            if (Object.keys(blockLocaleData).length > 0) {\n              blockLocaleData._parentID = blockRow.row.id\n              blockLocaleData._locale = blockLocale\n              acc.push(blockLocaleData)\n              blockLocaleIndexMap.push(i)\n            }\n          })\n        }\n\n        return acc\n      }, [])\n\n      if (blockLocaleRowsToInsert.length > 0) {\n        await db\n          .insert(adapter.tables[`${tableName}_blocks_${blockName}_locales`])\n          .values(blockLocaleRowsToInsert)\n          .returning()\n      }\n\n      await insertArrays({\n        adapter,\n        arrays: blockRows.map(({ arrays }) => arrays),\n        db,\n        parentRows: insertedBlockRows[blockName],\n      })\n    }\n\n    // //////////////////////////////////\n    // INSERT ARRAYS RECURSIVELY\n    // //////////////////////////////////\n\n    if (operation === 'update') {\n      for (const arrayTableName of Object.keys(rowToInsert.arrays)) {\n        await deleteExistingArrayRows({\n          adapter,\n          db,\n          parentID: insertedRow.id,\n          tableName: arrayTableName,\n        })\n      }\n    }\n\n    await insertArrays({\n      adapter,\n      arrays: [rowToInsert.arrays],\n      db,\n      parentRows: [insertedRow],\n    })\n\n    // //////////////////////////////////\n    // INSERT hasMany SELECTS\n    // //////////////////////////////////\n\n    for (const [selectTableName, tableRows] of Object.entries(selectsToInsert)) {\n      const selectTable = adapter.tables[selectTableName]\n      if (operation === 'update') {\n        await db.delete(selectTable).where(eq(selectTable.parent, insertedRow.id))\n      }\n      await db.insert(selectTable).values(tableRows).returning()\n    }\n\n    // //////////////////////////////////\n    // Error Handling\n    // //////////////////////////////////\n  } catch (error) {\n    throw error.code === '23505'\n      ? new ValidationError(\n          [\n            {\n              field: adapter.fieldConstraints[tableName][error.constraint],\n              message: req.t('error:valueMustBeUnique'),\n            },\n          ],\n          req?.t ?? i18nInit(req.payload.config.i18n).t,\n        )\n      : error\n  }\n\n  // //////////////////////////////////\n  // RETRIEVE NEWLY UPDATED ROW\n  // //////////////////////////////////\n\n  const findManyArgs = buildFindManyArgs({\n    adapter,\n    depth: 0,\n    fields,\n    tableName,\n  })\n\n  findManyArgs.where = eq(adapter.tables[tableName].id, insertedRow.id)\n\n  const doc = await db.query[tableName].findFirst(findManyArgs)\n\n  // //////////////////////////////////\n  // TRANSFORM DATA\n  // //////////////////////////////////\n\n  const result = transform<T>({\n    config: adapter.payload.config,\n    data: doc,\n    fields,\n  })\n\n  return result\n}\n"],"names":["upsertRow","id","adapter","data","db","fields","operation","path","req","tableName","upsertTarget","where","rowToInsert","transformForWrite","insertedRow","target","tables","row","insert","values","onConflictDoUpdate","set","returning","localesToInsert","relationsToInsert","numbersToInsert","blocksToInsert","selectsToInsert","Object","keys","locales","length","entries","forEach","locale","localeRow","_parentID","_locale","push","relationships","relation","parent","numbers","numberRow","selects","selectTableName","selectRows","blocks","blockName","blockRow","uuid","localeTable","delete","eq","relationshipsTableName","deleteExistingRowsByPath","localeColumnName","parentColumnName","parentID","pathColumnName","rows","relationshipsToDelete","numbersTableName","insertedBlockRows","blocksToDelete","blockTableName","blockTable","blockRows","map","i","blockLocaleIndexMap","blockLocaleRowsToInsert","reduce","acc","blockLocale","blockLocaleData","insertArrays","arrays","parentRows","arrayTableName","deleteExistingArrayRows","tableRows","selectTable","error","code","ValidationError","field","fieldConstraints","constraint","message","t","i18nInit","payload","config","i18n","findManyArgs","buildFindManyArgs","depth","doc","query","findFirst","result","transform"],"mappings":"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"}
260
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/upsertRow/index.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { TypeWithID } from 'payload/types'\n\nimport { eq } from 'drizzle-orm'\nimport { ValidationError } from 'payload/errors'\nimport { i18nInit } from 'payload/utilities'\n\nimport type { BlockRowToInsert } from '../transform/write/types'\nimport type { Args } from './types'\n\nimport { buildFindManyArgs } from '../find/buildFindManyArgs'\nimport { transform } from '../transform/read'\nimport { transformForWrite } from '../transform/write'\nimport { deleteExistingArrayRows } from './deleteExistingArrayRows'\nimport { deleteExistingRowsByPath } from './deleteExistingRowsByPath'\nimport { insertArrays } from './insertArrays'\n\nexport const upsertRow = async <T extends TypeWithID>({\n  id,\n  adapter,\n  data,\n  db,\n  fields,\n  operation,\n  path = '',\n  req,\n  tableName,\n  upsertTarget,\n  where,\n}: Args): Promise<T> => {\n  // Split out the incoming data into the corresponding:\n  // base row, locales, relationships, blocks, and arrays\n  const rowToInsert = transformForWrite({\n    adapter,\n    data,\n    fields,\n    path,\n    tableName,\n  })\n\n  // First, we insert the main row\n  let insertedRow: Record<string, unknown>\n\n  try {\n    if (operation === 'update') {\n      const target = upsertTarget || adapter.tables[tableName].id\n\n      if (id) {\n        rowToInsert.row.id = id\n        ;[insertedRow] = await db\n          .insert(adapter.tables[tableName])\n          .values(rowToInsert.row)\n          .onConflictDoUpdate({ set: rowToInsert.row, target })\n          .returning()\n      } else {\n        ;[insertedRow] = await db\n          .insert(adapter.tables[tableName])\n          .values(rowToInsert.row)\n          .onConflictDoUpdate({ set: rowToInsert.row, target, where })\n          .returning()\n      }\n    } else {\n      ;[insertedRow] = await db\n        .insert(adapter.tables[tableName])\n        .values(rowToInsert.row)\n        .returning()\n    }\n\n    const localesToInsert: Record<string, unknown>[] = []\n    const relationsToInsert: Record<string, unknown>[] = []\n    const numbersToInsert: Record<string, unknown>[] = []\n    const blocksToInsert: { [blockType: string]: BlockRowToInsert[] } = {}\n    const selectsToInsert: { [selectTableName: string]: Record<string, unknown>[] } = {}\n\n    // If there are locale rows with data, add the parent and locale to each\n    if (Object.keys(rowToInsert.locales).length > 0) {\n      Object.entries(rowToInsert.locales).forEach(([locale, localeRow]) => {\n        localeRow._parentID = insertedRow.id\n        localeRow._locale = locale\n        localesToInsert.push(localeRow)\n      })\n    }\n\n    // If there are relationships, add parent to each\n    if (rowToInsert.relationships.length > 0) {\n      rowToInsert.relationships.forEach((relation) => {\n        relation.parent = insertedRow.id\n        relationsToInsert.push(relation)\n      })\n    }\n\n    // If there are numbers, add parent to each\n    if (rowToInsert.numbers.length > 0) {\n      rowToInsert.numbers.forEach((numberRow) => {\n        numberRow.parent = insertedRow.id\n        numbersToInsert.push(numberRow)\n      })\n    }\n\n    // If there are selects, add parent to each, and then\n    // store by table name and rows\n    if (Object.keys(rowToInsert.selects).length > 0) {\n      Object.entries(rowToInsert.selects).forEach(([selectTableName, selectRows]) => {\n        selectRows.forEach((row) => {\n          if (typeof row.parent === 'undefined') {\n            row.parent = insertedRow.id\n          }\n          if (!selectsToInsert[selectTableName]) selectsToInsert[selectTableName] = []\n          selectsToInsert[selectTableName].push(row)\n        })\n      })\n    }\n\n    // If there are blocks, add parent to each, and then\n    // store by table name and rows\n    Object.keys(rowToInsert.blocks).forEach((blockName) => {\n      rowToInsert.blocks[blockName].forEach((blockRow) => {\n        blockRow.row._parentID = insertedRow.id\n        if (!blocksToInsert[blockName]) blocksToInsert[blockName] = []\n        if (blockRow.row.uuid) {\n          delete blockRow.row.uuid\n        }\n        blocksToInsert[blockName].push(blockRow)\n      })\n    })\n\n    // //////////////////////////////////\n    // INSERT LOCALES\n    // //////////////////////////////////\n\n    if (localesToInsert.length > 0) {\n      const localeTable = adapter.tables[`${tableName}_locales`]\n\n      if (operation === 'update') {\n        await db.delete(localeTable).where(eq(localeTable._parentID, insertedRow.id))\n      }\n\n      await db.insert(localeTable).values(localesToInsert)\n    }\n\n    // //////////////////////////////////\n    // INSERT RELATIONSHIPS\n    // //////////////////////////////////\n\n    const relationshipsTableName = `${tableName}_rels`\n\n    if (operation === 'update') {\n      await deleteExistingRowsByPath({\n        adapter,\n        db,\n        localeColumnName: 'locale',\n        parentColumnName: 'parent',\n        parentID: insertedRow.id,\n        pathColumnName: 'path',\n        rows: [...relationsToInsert, ...rowToInsert.relationshipsToDelete],\n        tableName: relationshipsTableName,\n      })\n    }\n\n    if (relationsToInsert.length > 0) {\n      await db.insert(adapter.tables[relationshipsTableName]).values(relationsToInsert)\n    }\n\n    // //////////////////////////////////\n    // INSERT hasMany NUMBERS\n    // //////////////////////////////////\n\n    const numbersTableName = `${tableName}_numbers`\n\n    if (operation === 'update') {\n      await deleteExistingRowsByPath({\n        adapter,\n        db,\n        localeColumnName: 'locale',\n        parentColumnName: 'parent',\n        parentID: insertedRow.id,\n        pathColumnName: 'path',\n        rows: numbersToInsert,\n        tableName: numbersTableName,\n      })\n    }\n\n    if (numbersToInsert.length > 0) {\n      await db.insert(adapter.tables[numbersTableName]).values(numbersToInsert).returning()\n    }\n\n    // //////////////////////////////////\n    // INSERT BLOCKS\n    // //////////////////////////////////\n\n    const insertedBlockRows: Record<string, Record<string, unknown>[]> = {}\n\n    if (operation === 'update') {\n      for (const blockName of rowToInsert.blocksToDelete) {\n        const blockTableName = `${tableName}_blocks_${blockName}`\n        const blockTable = adapter.tables[blockTableName]\n        await db.delete(blockTable).where(eq(blockTable._parentID, insertedRow.id))\n      }\n    }\n\n    for (const [blockName, blockRows] of Object.entries(blocksToInsert)) {\n      insertedBlockRows[blockName] = await db\n        .insert(adapter.tables[`${tableName}_blocks_${blockName}`])\n        .values(blockRows.map(({ row }) => row))\n        .returning()\n\n      insertedBlockRows[blockName].forEach((row, i) => {\n        blockRows[i].row = row\n      })\n\n      const blockLocaleIndexMap: number[] = []\n\n      const blockLocaleRowsToInsert = blockRows.reduce((acc, blockRow, i) => {\n        if (Object.entries(blockRow.locales).length > 0) {\n          Object.entries(blockRow.locales).forEach(([blockLocale, blockLocaleData]) => {\n            if (Object.keys(blockLocaleData).length > 0) {\n              blockLocaleData._parentID = blockRow.row.id\n              blockLocaleData._locale = blockLocale\n              acc.push(blockLocaleData)\n              blockLocaleIndexMap.push(i)\n            }\n          })\n        }\n\n        return acc\n      }, [])\n\n      if (blockLocaleRowsToInsert.length > 0) {\n        await db\n          .insert(adapter.tables[`${tableName}_blocks_${blockName}_locales`])\n          .values(blockLocaleRowsToInsert)\n          .returning()\n      }\n\n      await insertArrays({\n        adapter,\n        arrays: blockRows.map(({ arrays }) => arrays),\n        db,\n        parentRows: insertedBlockRows[blockName],\n      })\n    }\n\n    // //////////////////////////////////\n    // INSERT ARRAYS RECURSIVELY\n    // //////////////////////////////////\n\n    if (operation === 'update') {\n      for (const arrayTableName of Object.keys(rowToInsert.arrays)) {\n        await deleteExistingArrayRows({\n          adapter,\n          db,\n          parentID: insertedRow.id,\n          tableName: arrayTableName,\n        })\n      }\n    }\n\n    await insertArrays({\n      adapter,\n      arrays: [rowToInsert.arrays],\n      db,\n      parentRows: [insertedRow],\n    })\n\n    // //////////////////////////////////\n    // INSERT hasMany SELECTS\n    // //////////////////////////////////\n\n    for (const [selectTableName, tableRows] of Object.entries(selectsToInsert)) {\n      const selectTable = adapter.tables[selectTableName]\n      if (operation === 'update') {\n        await db.delete(selectTable).where(eq(selectTable.parent, insertedRow.id))\n      }\n      await db.insert(selectTable).values(tableRows).returning()\n    }\n\n    // //////////////////////////////////\n    // Error Handling\n    // //////////////////////////////////\n  } catch (error) {\n    throw error.code === '23505'\n      ? new ValidationError(\n          [\n            {\n              field: adapter.fieldConstraints[tableName][error.constraint],\n              message: req.t('error:valueMustBeUnique'),\n            },\n          ],\n          req?.t ?? i18nInit(req.payload.config.i18n).t,\n        )\n      : error\n  }\n\n  // //////////////////////////////////\n  // RETRIEVE NEWLY UPDATED ROW\n  // //////////////////////////////////\n\n  const findManyArgs = buildFindManyArgs({\n    adapter,\n    depth: 0,\n    fields,\n    tableName,\n  })\n\n  findManyArgs.where = eq(adapter.tables[tableName].id, insertedRow.id)\n\n  const doc = await db.query[tableName].findFirst(findManyArgs)\n\n  // //////////////////////////////////\n  // TRANSFORM DATA\n  // //////////////////////////////////\n\n  const result = transform<T>({\n    config: adapter.payload.config,\n    data: doc,\n    fields,\n  })\n\n  return result\n}\n"],"names":["upsertRow","id","adapter","data","db","fields","operation","path","req","tableName","upsertTarget","where","rowToInsert","transformForWrite","insertedRow","target","tables","row","insert","values","onConflictDoUpdate","set","returning","localesToInsert","relationsToInsert","numbersToInsert","blocksToInsert","selectsToInsert","Object","keys","locales","length","entries","forEach","locale","localeRow","_parentID","_locale","push","relationships","relation","parent","numbers","numberRow","selects","selectTableName","selectRows","blocks","blockName","blockRow","uuid","localeTable","delete","eq","relationshipsTableName","deleteExistingRowsByPath","localeColumnName","parentColumnName","parentID","pathColumnName","rows","relationshipsToDelete","numbersTableName","insertedBlockRows","blocksToDelete","blockTableName","blockTable","blockRows","map","i","blockLocaleIndexMap","blockLocaleRowsToInsert","reduce","acc","blockLocale","blockLocaleData","insertArrays","arrays","parentRows","arrayTableName","deleteExistingArrayRows","tableRows","selectTable","error","code","ValidationError","field","fieldConstraints","constraint","message","t","i18nInit","payload","config","i18n","findManyArgs","buildFindManyArgs","depth","doc","query","findFirst","result","transform"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@payloadcms/db-postgres",
3
- "version": "0.1.12",
3
+ "version": "0.1.13",
4
4
  "description": "The officially supported Postgres database adapter for Payload",
5
5
  "repository": "https://github.com/payloadcms/payload",
6
6
  "license": "MIT",
@@ -25,7 +25,7 @@
25
25
  "@types/pg": "8.10.2",
26
26
  "@types/to-snake-case": "1.0.0",
27
27
  "@payloadcms/eslint-config": "1.0.0",
28
- "payload": "2.0.15"
28
+ "payload": "2.1.0"
29
29
  },
30
30
  "peerDependencies": {
31
31
  "payload": "^2.0.0"