datetime.cjs 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. "use strict";
  2. var __defProp = Object.defineProperty;
  3. var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
  4. var __getOwnPropNames = Object.getOwnPropertyNames;
  5. var __hasOwnProp = Object.prototype.hasOwnProperty;
  6. var __export = (target, all) => {
  7. for (var name in all)
  8. __defProp(target, name, { get: all[name], enumerable: true });
  9. };
  10. var __copyProps = (to, from, except, desc) => {
  11. if (from && typeof from === "object" || typeof from === "function") {
  12. for (let key of __getOwnPropNames(from))
  13. if (!__hasOwnProp.call(to, key) && key !== except)
  14. __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
  15. }
  16. return to;
  17. };
  18. var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
  19. var datetime_exports = {};
  20. __export(datetime_exports, {
  21. MySqlDateTime: () => MySqlDateTime,
  22. MySqlDateTimeBuilder: () => MySqlDateTimeBuilder,
  23. MySqlDateTimeString: () => MySqlDateTimeString,
  24. MySqlDateTimeStringBuilder: () => MySqlDateTimeStringBuilder,
  25. datetime: () => datetime
  26. });
  27. module.exports = __toCommonJS(datetime_exports);
  28. var import_entity = require("../../entity.cjs");
  29. var import_utils = require("../../utils.cjs");
  30. var import_common = require("./common.cjs");
  31. class MySqlDateTimeBuilder extends import_common.MySqlColumnBuilder {
  32. static [import_entity.entityKind] = "MySqlDateTimeBuilder";
  33. constructor(name, config) {
  34. super(name, "date", "MySqlDateTime");
  35. this.config.fsp = config?.fsp;
  36. }
  37. /** @internal */
  38. build(table) {
  39. return new MySqlDateTime(
  40. table,
  41. this.config
  42. );
  43. }
  44. }
  45. class MySqlDateTime extends import_common.MySqlColumn {
  46. static [import_entity.entityKind] = "MySqlDateTime";
  47. fsp;
  48. constructor(table, config) {
  49. super(table, config);
  50. this.fsp = config.fsp;
  51. }
  52. getSQLType() {
  53. const precision = this.fsp === void 0 ? "" : `(${this.fsp})`;
  54. return `datetime${precision}`;
  55. }
  56. mapToDriverValue(value) {
  57. return value.toISOString().replace("T", " ").replace("Z", "");
  58. }
  59. mapFromDriverValue(value) {
  60. return /* @__PURE__ */ new Date(value.replace(" ", "T") + "Z");
  61. }
  62. }
  63. class MySqlDateTimeStringBuilder extends import_common.MySqlColumnBuilder {
  64. static [import_entity.entityKind] = "MySqlDateTimeStringBuilder";
  65. constructor(name, config) {
  66. super(name, "string", "MySqlDateTimeString");
  67. this.config.fsp = config?.fsp;
  68. }
  69. /** @internal */
  70. build(table) {
  71. return new MySqlDateTimeString(
  72. table,
  73. this.config
  74. );
  75. }
  76. }
  77. class MySqlDateTimeString extends import_common.MySqlColumn {
  78. static [import_entity.entityKind] = "MySqlDateTimeString";
  79. fsp;
  80. constructor(table, config) {
  81. super(table, config);
  82. this.fsp = config.fsp;
  83. }
  84. getSQLType() {
  85. const precision = this.fsp === void 0 ? "" : `(${this.fsp})`;
  86. return `datetime${precision}`;
  87. }
  88. }
  89. function datetime(a, b) {
  90. const { name, config } = (0, import_utils.getColumnNameAndConfig)(a, b);
  91. if (config?.mode === "string") {
  92. return new MySqlDateTimeStringBuilder(name, config);
  93. }
  94. return new MySqlDateTimeBuilder(name, config);
  95. }
  96. // Annotate the CommonJS export names for ESM import in node:
  97. 0 && (module.exports = {
  98. MySqlDateTime,
  99. MySqlDateTimeBuilder,
  100. MySqlDateTimeString,
  101. MySqlDateTimeStringBuilder,
  102. datetime
  103. });
  104. //# sourceMappingURL=datetime.cjs.map