@payloadcms/db-postgres 0.1.11 → 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":"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"}
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"}