drizzle-orm
Version:
Drizzle ORM package for SQL databases
163 lines • 5.14 kB
JavaScript
;
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __export = (target, all) => {
for (var name in all)
__defProp(target, name, { get: all[name], enumerable: true });
};
var __copyProps = (to, from, except, desc) => {
if (from && typeof from === "object" || typeof from === "function") {
for (let key of __getOwnPropNames(from))
if (!__hasOwnProp.call(to, key) && key !== except)
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
}
return to;
};
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
var numeric_exports = {};
__export(numeric_exports, {
PgNumeric: () => PgNumeric,
PgNumericBigInt: () => PgNumericBigInt,
PgNumericBigIntBuilder: () => PgNumericBigIntBuilder,
PgNumericBuilder: () => PgNumericBuilder,
PgNumericNumber: () => PgNumericNumber,
PgNumericNumberBuilder: () => PgNumericNumberBuilder,
decimal: () => decimal,
numeric: () => numeric
});
module.exports = __toCommonJS(numeric_exports);
var import_entity = require("../../entity.cjs");
var import_utils = require("../../utils.cjs");
var import_common = require("./common.cjs");
class PgNumericBuilder extends import_common.PgColumnBuilder {
static [import_entity.entityKind] = "PgNumericBuilder";
constructor(name, precision, scale) {
super(name, "string", "PgNumeric");
this.config.precision = precision;
this.config.scale = scale;
}
/** @internal */
build(table) {
return new PgNumeric(table, this.config);
}
}
class PgNumeric extends import_common.PgColumn {
static [import_entity.entityKind] = "PgNumeric";
precision;
scale;
constructor(table, config) {
super(table, config);
this.precision = config.precision;
this.scale = config.scale;
}
mapFromDriverValue(value) {
if (typeof value === "string")
return value;
return String(value);
}
getSQLType() {
if (this.precision !== void 0 && this.scale !== void 0) {
return `numeric(${this.precision}, ${this.scale})`;
} else if (this.precision === void 0) {
return "numeric";
} else {
return `numeric(${this.precision})`;
}
}
}
class PgNumericNumberBuilder extends import_common.PgColumnBuilder {
static [import_entity.entityKind] = "PgNumericNumberBuilder";
constructor(name, precision, scale) {
super(name, "number", "PgNumericNumber");
this.config.precision = precision;
this.config.scale = scale;
}
/** @internal */
build(table) {
return new PgNumericNumber(
table,
this.config
);
}
}
class PgNumericNumber extends import_common.PgColumn {
static [import_entity.entityKind] = "PgNumericNumber";
precision;
scale;
constructor(table, config) {
super(table, config);
this.precision = config.precision;
this.scale = config.scale;
}
mapFromDriverValue(value) {
if (typeof value === "number")
return value;
return Number(value);
}
mapToDriverValue = String;
getSQLType() {
if (this.precision !== void 0 && this.scale !== void 0) {
return `numeric(${this.precision}, ${this.scale})`;
} else if (this.precision === void 0) {
return "numeric";
} else {
return `numeric(${this.precision})`;
}
}
}
class PgNumericBigIntBuilder extends import_common.PgColumnBuilder {
static [import_entity.entityKind] = "PgNumericBigIntBuilder";
constructor(name, precision, scale) {
super(name, "bigint", "PgNumericBigInt");
this.config.precision = precision;
this.config.scale = scale;
}
/** @internal */
build(table) {
return new PgNumericBigInt(
table,
this.config
);
}
}
class PgNumericBigInt extends import_common.PgColumn {
static [import_entity.entityKind] = "PgNumericBigInt";
precision;
scale;
constructor(table, config) {
super(table, config);
this.precision = config.precision;
this.scale = config.scale;
}
mapFromDriverValue = BigInt;
mapToDriverValue = String;
getSQLType() {
if (this.precision !== void 0 && this.scale !== void 0) {
return `numeric(${this.precision}, ${this.scale})`;
} else if (this.precision === void 0) {
return "numeric";
} else {
return `numeric(${this.precision})`;
}
}
}
function numeric(a, b) {
const { name, config } = (0, import_utils.getColumnNameAndConfig)(a, b);
const mode = config?.mode;
return mode === "number" ? new PgNumericNumberBuilder(name, config?.precision, config?.scale) : mode === "bigint" ? new PgNumericBigIntBuilder(name, config?.precision, config?.scale) : new PgNumericBuilder(name, config?.precision, config?.scale);
}
const decimal = numeric;
// Annotate the CommonJS export names for ESM import in node:
0 && (module.exports = {
PgNumeric,
PgNumericBigInt,
PgNumericBigIntBuilder,
PgNumericBuilder,
PgNumericNumber,
PgNumericNumberBuilder,
decimal,
numeric
});
//# sourceMappingURL=numeric.cjs.map