drizzle-orm
Version:
Drizzle ORM package for SQL databases
108 lines • 3.84 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 timestamp_exports = {};
__export(timestamp_exports, {
PgTimestamp: () => PgTimestamp,
PgTimestampBuilder: () => PgTimestampBuilder,
PgTimestampString: () => PgTimestampString,
PgTimestampStringBuilder: () => PgTimestampStringBuilder,
timestamp: () => timestamp
});
module.exports = __toCommonJS(timestamp_exports);
var import_entity = require("../../entity.cjs");
var import_utils = require("../../utils.cjs");
var import_common = require("./common.cjs");
var import_date_common = require("./date.common.cjs");
class PgTimestampBuilder extends import_date_common.PgDateColumnBaseBuilder {
static [import_entity.entityKind] = "PgTimestampBuilder";
constructor(name, withTimezone, precision) {
super(name, "date", "PgTimestamp");
this.config.withTimezone = withTimezone;
this.config.precision = precision;
}
/** @internal */
build(table) {
return new PgTimestamp(table, this.config);
}
}
class PgTimestamp extends import_common.PgColumn {
static [import_entity.entityKind] = "PgTimestamp";
withTimezone;
precision;
constructor(table, config) {
super(table, config);
this.withTimezone = config.withTimezone;
this.precision = config.precision;
}
getSQLType() {
const precision = this.precision === void 0 ? "" : ` (${this.precision})`;
return `timestamp${precision}${this.withTimezone ? " with time zone" : ""}`;
}
mapFromDriverValue = (value) => {
return new Date(this.withTimezone ? value : value + "+0000");
};
mapToDriverValue = (value) => {
return value.toISOString();
};
}
class PgTimestampStringBuilder extends import_date_common.PgDateColumnBaseBuilder {
static [import_entity.entityKind] = "PgTimestampStringBuilder";
constructor(name, withTimezone, precision) {
super(name, "string", "PgTimestampString");
this.config.withTimezone = withTimezone;
this.config.precision = precision;
}
/** @internal */
build(table) {
return new PgTimestampString(
table,
this.config
);
}
}
class PgTimestampString extends import_common.PgColumn {
static [import_entity.entityKind] = "PgTimestampString";
withTimezone;
precision;
constructor(table, config) {
super(table, config);
this.withTimezone = config.withTimezone;
this.precision = config.precision;
}
getSQLType() {
const precision = this.precision === void 0 ? "" : `(${this.precision})`;
return `timestamp${precision}${this.withTimezone ? " with time zone" : ""}`;
}
}
function timestamp(a, b = {}) {
const { name, config } = (0, import_utils.getColumnNameAndConfig)(a, b);
if (config?.mode === "string") {
return new PgTimestampStringBuilder(name, config.withTimezone ?? false, config.precision);
}
return new PgTimestampBuilder(name, config?.withTimezone ?? false, config?.precision);
}
// Annotate the CommonJS export names for ESM import in node:
0 && (module.exports = {
PgTimestamp,
PgTimestampBuilder,
PgTimestampString,
PgTimestampStringBuilder,
timestamp
});
//# sourceMappingURL=timestamp.cjs.map
;