Some checks failed
CI / Lint (push) Successful in -27m59s
CI / Test (1.25) (push) Successful in -27m46s
CI / Test (1.24) (push) Failing after 59s
CI / Build (push) Successful in -28m14s
Integration Tests / Integration Tests (push) Failing after -28m16s
Release / Build and Release (push) Successful in 1m1s
feat(templ): ✨ added templ to command line that reads go template and outputs code Reviewed-on: #1 Co-authored-by: Hein <hein.puth@gmail.com> Co-committed-by: Hein <hein.puth@gmail.com>
76 lines
1.6 KiB
Go
76 lines
1.6 KiB
Go
package commontypes
|
|
|
|
// TypeScriptTypeMap maps PostgreSQL types to TypeScript types
|
|
var TypeScriptTypeMap = map[string]string{
|
|
// Integer types
|
|
"integer": "number",
|
|
"int": "number",
|
|
"int4": "number",
|
|
"smallint": "number",
|
|
"int2": "number",
|
|
"bigint": "number",
|
|
"int8": "number",
|
|
"serial": "number",
|
|
"bigserial": "number",
|
|
"smallserial": "number",
|
|
|
|
// String types
|
|
"text": "string",
|
|
"varchar": "string",
|
|
"char": "string",
|
|
"character": "string",
|
|
"citext": "string",
|
|
"bpchar": "string",
|
|
"uuid": "string",
|
|
|
|
// Boolean
|
|
"boolean": "boolean",
|
|
"bool": "boolean",
|
|
|
|
// Float types
|
|
"real": "number",
|
|
"float4": "number",
|
|
"double precision": "number",
|
|
"float8": "number",
|
|
"numeric": "number",
|
|
"decimal": "number",
|
|
|
|
// Date/Time types
|
|
"timestamp": "Date",
|
|
"timestamp without time zone": "Date",
|
|
"timestamp with time zone": "Date",
|
|
"timestamptz": "Date",
|
|
"date": "Date",
|
|
"time": "Date",
|
|
"time without time zone": "Date",
|
|
"time with time zone": "Date",
|
|
"timetz": "Date",
|
|
|
|
// Binary
|
|
"bytea": "Buffer",
|
|
|
|
// JSON
|
|
"json": "any",
|
|
"jsonb": "any",
|
|
|
|
// Array
|
|
"array": "any[]",
|
|
}
|
|
|
|
// SQLToTypeScript converts SQL types to TypeScript types
|
|
func SQLToTypeScript(sqlType string, nullable bool) string {
|
|
baseType := ExtractBaseType(sqlType)
|
|
|
|
tsType, ok := TypeScriptTypeMap[baseType]
|
|
if !ok {
|
|
tsType = "any"
|
|
}
|
|
|
|
// Handle nullable types
|
|
if nullable {
|
|
return tsType
|
|
}
|
|
|
|
return tsType + " | null"
|
|
}
|