Clean up postgres export

This commit is contained in:
1ilit 2024-07-03 00:33:23 +03:00
parent 3c1e72fbdd
commit c1f651cb54

View File

@ -5,57 +5,33 @@ export function toPostgres(diagram) {
const enumStatements = diagram.enums const enumStatements = diagram.enums
.map( .map(
(e) => (e) =>
`CREATE TYPE "${e.name}" AS ENUM (\n${e.values.map((v) => `\t'${v}'`).join("\n")}\n);`, `CREATE TYPE "${e.name}" AS ENUM (\n${e.values.map((v) => `\t'${v}'`).join(",\n")}\n);`,
)
.join("\n\n");
const typeStatements = diagram.types
.map(
(type) =>
`CREATE TYPE ${type.name} AS (\n${type.fields
.map((f) => `\t${f.name} ${f.type}`)
.join("\n")}\n);\n${
type.comment.trim() !== ""
? `\nCOMMENT ON TYPE "${type.name}" IS '${type.comment}';\n`
: ""
}`,
) )
.join("\n"); .join("\n");
return `${enumStatements}\n${diagram.types.map((type) => { return `${enumStatements}\n\n${typeStatements}\n${diagram.tables
const typeStatements = type.fields
.filter((f) => f.type === "ENUM" || f.type === "SET")
.map(
(f) =>
`CREATE TYPE "${f.name}_t" AS ENUM (${f.values
.map((v) => `'${v}'`)
.join(", ")});\n`,
);
if (typeStatements.length > 0) {
return (
typeStatements.join("") +
`${
type.comment === "" ? "" : `/**\n${type.comment}\n*/\n`
}CREATE TYPE ${type.name} AS (\n${type.fields
.map((f) => `\t${f.name} ${f.type}`)
.join("\n")}\n);`
);
} else {
return `${
type.comment === "" ? "" : `/**\n${type.comment}\n*/\n`
}CREATE TYPE ${type.name} AS (\n${type.fields
.map((f) => `\t${f.name} ${f.type}`)
.join("\n")}\n);`;
}
})}\n${diagram.tables
.map( .map(
(table) => (table) =>
`${table.comment === "" ? "" : `/**\n${table.comment}\n*/\n`}${ `CREATE TABLE "${table.name}" (\n${table.fields
table.fields.filter((f) => f.type === "ENUM" || f.type === "SET")
.length > 0
? `${table.fields
.filter((f) => f.type === "ENUM" || f.type === "SET")
.map(
(f) =>
`CREATE TYPE "${f.name}_t" AS ENUM (${f.values
.map((v) => `'${v}'`)
.join(", ")});\n\n`,
)}`
: ""
}CREATE TABLE "${table.name}" (\n${table.fields
.map( .map(
(field) => (field) =>
`${field.comment === "" ? "" : `\t-- ${field.comment}\n`}\t"${ `${field.comment === "" ? "" : `\t-- ${field.comment}\n`}\t"${
field.name field.name
}" ${field.type}${field.notNull ? " NOT NULL" : ""}${ }" ${field.type}${field.notNull ? " NOT NULL" : ""}${field.unique ? " UNIQUE" : ""}${
field.default !== "" field.default.trim() !== ""
? ` DEFAULT ${parseDefault(field, diagram.database)}` ? ` DEFAULT ${parseDefault(field, diagram.database)}`
: "" : ""
}${ }${
@ -73,17 +49,19 @@ export function toPostgres(diagram) {
.join(", ")})` .join(", ")})`
: "" : ""
}\n);\n${ }\n);\n${
table.indices.length > 0 table.comment.trim() !== ""
? `${table.indices.map( ? `\nCOMMENT ON TABLE "${table.name}" IS '${table.comment}';\n`
(i) =>
`\nCREATE ${i.unique ? "UNIQUE " : ""}INDEX "${
i.name
}"\nON "${table.name}" (${i.fields
.map((f) => `"${f}"`)
.join(", ")});`,
)}`
: "" : ""
}`, }${table.indices
.map(
(i) =>
`\nCREATE ${i.unique ? "UNIQUE " : ""}INDEX "${
i.name
}"\nON "${table.name}" (${i.fields
.map((f) => `"${f}"`)
.join(", ")});`,
)
.join("\n")}\n`,
) )
.join("\n")}\n${diagram.references .join("\n")}\n${diagram.references
.map( .map(