File size: 1,515 Bytes
6491ad4
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
import { entityKind, is } from "../entity.js";
import { SQL, sql } from "../sql/sql.js";
import { gelSequenceWithSchema } from "./sequence.js";
import { gelTableWithSchema } from "./table.js";
class GelSchema {
  constructor(schemaName) {
    this.schemaName = schemaName;
  }
  static [entityKind] = "GelSchema";
  table = (name, columns, extraConfig) => {
    return gelTableWithSchema(name, columns, extraConfig, this.schemaName);
  };
  // view = ((name, columns) => {
  // 	return gelViewWithSchema(name, columns, this.schemaName);
  // }) as typeof gelView;
  // materializedView = ((name, columns) => {
  // 	return gelMaterializedViewWithSchema(name, columns, this.schemaName);
  // }) as typeof gelMaterializedView;
  // enum: typeof gelEnum = ((name, values) => {
  // 	return gelEnumWithSchema(name, values, this.schemaName);
  // });
  sequence = (name, options) => {
    return gelSequenceWithSchema(name, options, this.schemaName);
  };
  getSQL() {
    return new SQL([sql.identifier(this.schemaName)]);
  }
  shouldOmitSQLParens() {
    return true;
  }
}
function isGelSchema(obj) {
  return is(obj, GelSchema);
}
function gelSchema(name) {
  if (name === "public") {
    throw new Error(
      `You can't specify 'public' as schema name. Postgres is using public schema by default. If you want to use 'public' schema, just use GelTable() instead of creating a schema`
    );
  }
  return new GelSchema(name);
}
export {
  GelSchema,
  gelSchema,
  isGelSchema
};
//# sourceMappingURL=schema.js.map