drizzle-orm 1.0.0-beta.1-08e4e66 → 1.0.0-beta.1-fd8bfcc

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1309) hide show
  1. package/_relations.cjs +0 -48
  2. package/_relations.cjs.map +1 -1
  3. package/_relations.d.cts +0 -1
  4. package/_relations.d.ts +0 -1
  5. package/_relations.js +0 -47
  6. package/_relations.js.map +1 -1
  7. package/column-builder.cjs.map +1 -1
  8. package/column-builder.d.cts +8 -10
  9. package/column-builder.d.ts +8 -10
  10. package/column-builder.js.map +1 -1
  11. package/column.cjs +0 -2
  12. package/column.cjs.map +1 -1
  13. package/column.d.cts +0 -1
  14. package/column.d.ts +0 -1
  15. package/column.js +0 -2
  16. package/column.js.map +1 -1
  17. package/gel-core/columns/bigint.cjs.map +1 -1
  18. package/gel-core/columns/bigint.d.cts +1 -0
  19. package/gel-core/columns/bigint.d.ts +1 -0
  20. package/gel-core/columns/bigint.js.map +1 -1
  21. package/gel-core/columns/bigintT.cjs.map +1 -1
  22. package/gel-core/columns/bigintT.d.cts +1 -0
  23. package/gel-core/columns/bigintT.d.ts +1 -0
  24. package/gel-core/columns/bigintT.js.map +1 -1
  25. package/gel-core/columns/boolean.cjs.map +1 -1
  26. package/gel-core/columns/boolean.d.cts +1 -0
  27. package/gel-core/columns/boolean.d.ts +1 -0
  28. package/gel-core/columns/boolean.js.map +1 -1
  29. package/gel-core/columns/bytes.cjs.map +1 -1
  30. package/gel-core/columns/bytes.d.cts +1 -0
  31. package/gel-core/columns/bytes.d.ts +1 -0
  32. package/gel-core/columns/bytes.js.map +1 -1
  33. package/gel-core/columns/custom.cjs.map +1 -1
  34. package/gel-core/columns/custom.d.cts +1 -0
  35. package/gel-core/columns/custom.d.ts +1 -0
  36. package/gel-core/columns/custom.js.map +1 -1
  37. package/gel-core/columns/date-duration.cjs.map +1 -1
  38. package/gel-core/columns/date-duration.d.cts +1 -0
  39. package/gel-core/columns/date-duration.d.ts +1 -0
  40. package/gel-core/columns/date-duration.js.map +1 -1
  41. package/gel-core/columns/decimal.cjs.map +1 -1
  42. package/gel-core/columns/decimal.d.cts +1 -0
  43. package/gel-core/columns/decimal.d.ts +1 -0
  44. package/gel-core/columns/decimal.js.map +1 -1
  45. package/gel-core/columns/double-precision.cjs.map +1 -1
  46. package/gel-core/columns/double-precision.d.cts +1 -0
  47. package/gel-core/columns/double-precision.d.ts +1 -0
  48. package/gel-core/columns/double-precision.js.map +1 -1
  49. package/gel-core/columns/duration.cjs.map +1 -1
  50. package/gel-core/columns/duration.d.cts +1 -0
  51. package/gel-core/columns/duration.d.ts +1 -0
  52. package/gel-core/columns/duration.js.map +1 -1
  53. package/gel-core/columns/integer.cjs.map +1 -1
  54. package/gel-core/columns/integer.d.cts +1 -0
  55. package/gel-core/columns/integer.d.ts +1 -0
  56. package/gel-core/columns/integer.js.map +1 -1
  57. package/gel-core/columns/json.cjs.map +1 -1
  58. package/gel-core/columns/json.d.cts +1 -0
  59. package/gel-core/columns/json.d.ts +1 -0
  60. package/gel-core/columns/json.js.map +1 -1
  61. package/gel-core/columns/localdate.cjs.map +1 -1
  62. package/gel-core/columns/localdate.d.cts +1 -0
  63. package/gel-core/columns/localdate.d.ts +1 -0
  64. package/gel-core/columns/localdate.js.map +1 -1
  65. package/gel-core/columns/localtime.cjs.map +1 -1
  66. package/gel-core/columns/localtime.d.cts +1 -0
  67. package/gel-core/columns/localtime.d.ts +1 -0
  68. package/gel-core/columns/localtime.js.map +1 -1
  69. package/gel-core/columns/real.cjs.map +1 -1
  70. package/gel-core/columns/real.d.cts +1 -0
  71. package/gel-core/columns/real.d.ts +1 -0
  72. package/gel-core/columns/real.js.map +1 -1
  73. package/gel-core/columns/relative-duration.cjs.map +1 -1
  74. package/gel-core/columns/relative-duration.d.cts +1 -0
  75. package/gel-core/columns/relative-duration.d.ts +1 -0
  76. package/gel-core/columns/relative-duration.js.map +1 -1
  77. package/gel-core/columns/smallint.cjs.map +1 -1
  78. package/gel-core/columns/smallint.d.cts +1 -0
  79. package/gel-core/columns/smallint.d.ts +1 -0
  80. package/gel-core/columns/smallint.js.map +1 -1
  81. package/gel-core/columns/text.cjs.map +1 -1
  82. package/gel-core/columns/text.d.cts +1 -0
  83. package/gel-core/columns/text.d.ts +1 -0
  84. package/gel-core/columns/text.js.map +1 -1
  85. package/gel-core/columns/timestamp.cjs.map +1 -1
  86. package/gel-core/columns/timestamp.d.cts +1 -0
  87. package/gel-core/columns/timestamp.d.ts +1 -0
  88. package/gel-core/columns/timestamp.js.map +1 -1
  89. package/gel-core/columns/timestamptz.cjs.map +1 -1
  90. package/gel-core/columns/timestamptz.d.cts +1 -0
  91. package/gel-core/columns/timestamptz.d.ts +1 -0
  92. package/gel-core/columns/timestamptz.js.map +1 -1
  93. package/gel-core/columns/uuid.cjs.map +1 -1
  94. package/gel-core/columns/uuid.d.cts +1 -0
  95. package/gel-core/columns/uuid.d.ts +1 -0
  96. package/gel-core/columns/uuid.js.map +1 -1
  97. package/gel-core/query-builders/insert.cjs.map +1 -1
  98. package/gel-core/query-builders/insert.d.cts +9 -6
  99. package/gel-core/query-builders/insert.d.ts +9 -6
  100. package/gel-core/query-builders/insert.js.map +1 -1
  101. package/gel-core/query-builders/update.cjs.map +1 -1
  102. package/gel-core/query-builders/update.d.cts +1 -1
  103. package/gel-core/query-builders/update.d.ts +1 -1
  104. package/gel-core/query-builders/update.js.map +1 -1
  105. package/mysql-core/columns/bigint.cjs.map +1 -1
  106. package/mysql-core/columns/bigint.d.cts +2 -0
  107. package/mysql-core/columns/bigint.d.ts +2 -0
  108. package/mysql-core/columns/bigint.js.map +1 -1
  109. package/mysql-core/columns/binary.cjs +1 -0
  110. package/mysql-core/columns/binary.cjs.map +1 -1
  111. package/mysql-core/columns/binary.d.cts +2 -0
  112. package/mysql-core/columns/binary.d.ts +2 -0
  113. package/mysql-core/columns/binary.js +1 -0
  114. package/mysql-core/columns/binary.js.map +1 -1
  115. package/mysql-core/columns/boolean.cjs.map +1 -1
  116. package/mysql-core/columns/boolean.d.cts +1 -0
  117. package/mysql-core/columns/boolean.d.ts +1 -0
  118. package/mysql-core/columns/boolean.js.map +1 -1
  119. package/mysql-core/columns/char.cjs +1 -0
  120. package/mysql-core/columns/char.cjs.map +1 -1
  121. package/mysql-core/columns/char.d.cts +2 -0
  122. package/mysql-core/columns/char.d.ts +2 -0
  123. package/mysql-core/columns/char.js +1 -0
  124. package/mysql-core/columns/char.js.map +1 -1
  125. package/mysql-core/columns/common.cjs.map +1 -1
  126. package/mysql-core/columns/common.d.cts +1 -1
  127. package/mysql-core/columns/common.d.ts +1 -1
  128. package/mysql-core/columns/common.js.map +1 -1
  129. package/mysql-core/columns/custom.cjs +3 -1
  130. package/mysql-core/columns/custom.cjs.map +1 -1
  131. package/mysql-core/columns/custom.d.cts +1 -0
  132. package/mysql-core/columns/custom.d.ts +1 -0
  133. package/mysql-core/columns/custom.js +3 -1
  134. package/mysql-core/columns/custom.js.map +1 -1
  135. package/mysql-core/columns/date.cjs.map +1 -1
  136. package/mysql-core/columns/date.d.cts +2 -0
  137. package/mysql-core/columns/date.d.ts +2 -0
  138. package/mysql-core/columns/date.js.map +1 -1
  139. package/mysql-core/columns/datetime.cjs.map +1 -1
  140. package/mysql-core/columns/datetime.d.cts +2 -0
  141. package/mysql-core/columns/datetime.d.ts +2 -0
  142. package/mysql-core/columns/datetime.js.map +1 -1
  143. package/mysql-core/columns/decimal.cjs.map +1 -1
  144. package/mysql-core/columns/decimal.d.cts +3 -0
  145. package/mysql-core/columns/decimal.d.ts +3 -0
  146. package/mysql-core/columns/decimal.js.map +1 -1
  147. package/mysql-core/columns/double.cjs.map +1 -1
  148. package/mysql-core/columns/double.d.cts +1 -0
  149. package/mysql-core/columns/double.d.ts +1 -0
  150. package/mysql-core/columns/double.js.map +1 -1
  151. package/mysql-core/columns/enum.cjs.map +1 -1
  152. package/mysql-core/columns/enum.d.cts +2 -0
  153. package/mysql-core/columns/enum.d.ts +2 -0
  154. package/mysql-core/columns/enum.js.map +1 -1
  155. package/mysql-core/columns/float.cjs.map +1 -1
  156. package/mysql-core/columns/float.d.cts +1 -0
  157. package/mysql-core/columns/float.d.ts +1 -0
  158. package/mysql-core/columns/float.js.map +1 -1
  159. package/mysql-core/columns/int.cjs.map +1 -1
  160. package/mysql-core/columns/int.d.cts +1 -0
  161. package/mysql-core/columns/int.d.ts +1 -0
  162. package/mysql-core/columns/int.js.map +1 -1
  163. package/mysql-core/columns/json.cjs.map +1 -1
  164. package/mysql-core/columns/json.d.cts +1 -0
  165. package/mysql-core/columns/json.d.ts +1 -0
  166. package/mysql-core/columns/json.js.map +1 -1
  167. package/mysql-core/columns/mediumint.cjs.map +1 -1
  168. package/mysql-core/columns/mediumint.d.cts +1 -0
  169. package/mysql-core/columns/mediumint.d.ts +1 -0
  170. package/mysql-core/columns/mediumint.js.map +1 -1
  171. package/mysql-core/columns/real.cjs.map +1 -1
  172. package/mysql-core/columns/real.d.cts +1 -0
  173. package/mysql-core/columns/real.d.ts +1 -0
  174. package/mysql-core/columns/real.js.map +1 -1
  175. package/mysql-core/columns/serial.cjs.map +1 -1
  176. package/mysql-core/columns/serial.d.cts +1 -0
  177. package/mysql-core/columns/serial.d.ts +1 -0
  178. package/mysql-core/columns/serial.js.map +1 -1
  179. package/mysql-core/columns/smallint.cjs.map +1 -1
  180. package/mysql-core/columns/smallint.d.cts +1 -0
  181. package/mysql-core/columns/smallint.d.ts +1 -0
  182. package/mysql-core/columns/smallint.js.map +1 -1
  183. package/mysql-core/columns/text.cjs.map +1 -1
  184. package/mysql-core/columns/text.d.cts +1 -0
  185. package/mysql-core/columns/text.d.ts +1 -0
  186. package/mysql-core/columns/text.js.map +1 -1
  187. package/mysql-core/columns/time.cjs.map +1 -1
  188. package/mysql-core/columns/time.d.cts +1 -0
  189. package/mysql-core/columns/time.d.ts +1 -0
  190. package/mysql-core/columns/time.js.map +1 -1
  191. package/mysql-core/columns/timestamp.cjs.map +1 -1
  192. package/mysql-core/columns/timestamp.d.cts +2 -0
  193. package/mysql-core/columns/timestamp.d.ts +2 -0
  194. package/mysql-core/columns/timestamp.js.map +1 -1
  195. package/mysql-core/columns/tinyint.cjs.map +1 -1
  196. package/mysql-core/columns/tinyint.d.cts +1 -0
  197. package/mysql-core/columns/tinyint.d.ts +1 -0
  198. package/mysql-core/columns/tinyint.js.map +1 -1
  199. package/mysql-core/columns/varbinary.cjs.map +1 -1
  200. package/mysql-core/columns/varbinary.d.cts +1 -0
  201. package/mysql-core/columns/varbinary.d.ts +1 -0
  202. package/mysql-core/columns/varbinary.js.map +1 -1
  203. package/mysql-core/columns/varchar.cjs +1 -1
  204. package/mysql-core/columns/varchar.cjs.map +1 -1
  205. package/mysql-core/columns/varchar.d.cts +2 -1
  206. package/mysql-core/columns/varchar.d.ts +2 -1
  207. package/mysql-core/columns/varchar.js +1 -1
  208. package/mysql-core/columns/varchar.js.map +1 -1
  209. package/mysql-core/columns/year.cjs.map +1 -1
  210. package/mysql-core/columns/year.d.cts +1 -0
  211. package/mysql-core/columns/year.d.ts +1 -0
  212. package/mysql-core/columns/year.js.map +1 -1
  213. package/mysql-core/dialect.cjs +0 -3
  214. package/mysql-core/dialect.cjs.map +1 -1
  215. package/mysql-core/dialect.d.cts +0 -1
  216. package/mysql-core/dialect.d.ts +0 -1
  217. package/mysql-core/dialect.js +0 -3
  218. package/mysql-core/dialect.js.map +1 -1
  219. package/mysql-core/query-builders/insert.cjs.map +1 -1
  220. package/mysql-core/query-builders/insert.d.cts +2 -2
  221. package/mysql-core/query-builders/insert.d.ts +2 -2
  222. package/mysql-core/query-builders/insert.js.map +1 -1
  223. package/mysql-core/query-builders/update.cjs.map +1 -1
  224. package/mysql-core/query-builders/update.d.cts +1 -1
  225. package/mysql-core/query-builders/update.d.ts +1 -1
  226. package/mysql-core/query-builders/update.js.map +1 -1
  227. package/mysql-proxy/driver.cjs +2 -2
  228. package/mysql-proxy/driver.cjs.map +1 -1
  229. package/mysql-proxy/driver.d.cts +1 -2
  230. package/mysql-proxy/driver.d.ts +1 -2
  231. package/mysql-proxy/driver.js +2 -2
  232. package/mysql-proxy/driver.js.map +1 -1
  233. package/node-postgres/session.cjs.map +1 -1
  234. package/node-postgres/session.js.map +1 -1
  235. package/package.json +190 -1632
  236. package/pg-core/columns/bigint.cjs.map +1 -1
  237. package/pg-core/columns/bigint.d.cts +2 -0
  238. package/pg-core/columns/bigint.d.ts +2 -0
  239. package/pg-core/columns/bigint.js.map +1 -1
  240. package/pg-core/columns/bigserial.cjs +0 -1
  241. package/pg-core/columns/bigserial.cjs.map +1 -1
  242. package/pg-core/columns/bigserial.d.cts +2 -0
  243. package/pg-core/columns/bigserial.d.ts +2 -0
  244. package/pg-core/columns/bigserial.js +0 -1
  245. package/pg-core/columns/bigserial.js.map +1 -1
  246. package/pg-core/columns/boolean.cjs.map +1 -1
  247. package/pg-core/columns/boolean.d.cts +1 -0
  248. package/pg-core/columns/boolean.d.ts +1 -0
  249. package/pg-core/columns/boolean.js.map +1 -1
  250. package/pg-core/columns/bytea.cjs.map +1 -1
  251. package/pg-core/columns/bytea.d.cts +1 -0
  252. package/pg-core/columns/bytea.d.ts +1 -0
  253. package/pg-core/columns/bytea.js.map +1 -1
  254. package/pg-core/columns/char.cjs +1 -0
  255. package/pg-core/columns/char.cjs.map +1 -1
  256. package/pg-core/columns/char.d.cts +2 -0
  257. package/pg-core/columns/char.d.ts +2 -0
  258. package/pg-core/columns/char.js +1 -0
  259. package/pg-core/columns/char.js.map +1 -1
  260. package/pg-core/columns/cidr.cjs.map +1 -1
  261. package/pg-core/columns/cidr.d.cts +1 -0
  262. package/pg-core/columns/cidr.d.ts +1 -0
  263. package/pg-core/columns/cidr.js.map +1 -1
  264. package/pg-core/columns/common.cjs +10 -11
  265. package/pg-core/columns/common.cjs.map +1 -1
  266. package/pg-core/columns/common.d.cts +2 -3
  267. package/pg-core/columns/common.d.ts +2 -3
  268. package/pg-core/columns/common.js +10 -11
  269. package/pg-core/columns/common.js.map +1 -1
  270. package/pg-core/columns/custom.cjs.map +1 -1
  271. package/pg-core/columns/custom.d.cts +1 -0
  272. package/pg-core/columns/custom.d.ts +1 -0
  273. package/pg-core/columns/custom.js.map +1 -1
  274. package/pg-core/columns/date.cjs.map +1 -1
  275. package/pg-core/columns/date.d.cts +2 -0
  276. package/pg-core/columns/date.d.ts +2 -0
  277. package/pg-core/columns/date.js.map +1 -1
  278. package/pg-core/columns/double-precision.cjs.map +1 -1
  279. package/pg-core/columns/double-precision.d.cts +1 -0
  280. package/pg-core/columns/double-precision.d.ts +1 -0
  281. package/pg-core/columns/double-precision.js.map +1 -1
  282. package/pg-core/columns/enum.cjs.map +1 -1
  283. package/pg-core/columns/enum.d.cts +2 -0
  284. package/pg-core/columns/enum.d.ts +2 -0
  285. package/pg-core/columns/enum.js.map +1 -1
  286. package/pg-core/columns/inet.cjs.map +1 -1
  287. package/pg-core/columns/inet.d.cts +1 -0
  288. package/pg-core/columns/inet.d.ts +1 -0
  289. package/pg-core/columns/inet.js.map +1 -1
  290. package/pg-core/columns/integer.cjs.map +1 -1
  291. package/pg-core/columns/integer.d.cts +1 -0
  292. package/pg-core/columns/integer.d.ts +1 -0
  293. package/pg-core/columns/integer.js.map +1 -1
  294. package/pg-core/columns/interval.cjs.map +1 -1
  295. package/pg-core/columns/interval.d.cts +1 -0
  296. package/pg-core/columns/interval.d.ts +1 -0
  297. package/pg-core/columns/interval.js.map +1 -1
  298. package/pg-core/columns/json.cjs.map +1 -1
  299. package/pg-core/columns/json.d.cts +1 -0
  300. package/pg-core/columns/json.d.ts +1 -0
  301. package/pg-core/columns/json.js.map +1 -1
  302. package/pg-core/columns/jsonb.cjs.map +1 -1
  303. package/pg-core/columns/jsonb.d.cts +1 -0
  304. package/pg-core/columns/jsonb.d.ts +1 -0
  305. package/pg-core/columns/jsonb.js.map +1 -1
  306. package/pg-core/columns/line.cjs +0 -2
  307. package/pg-core/columns/line.cjs.map +1 -1
  308. package/pg-core/columns/line.d.cts +2 -2
  309. package/pg-core/columns/line.d.ts +2 -2
  310. package/pg-core/columns/line.js +0 -2
  311. package/pg-core/columns/line.js.map +1 -1
  312. package/pg-core/columns/macaddr.cjs.map +1 -1
  313. package/pg-core/columns/macaddr.d.cts +1 -0
  314. package/pg-core/columns/macaddr.d.ts +1 -0
  315. package/pg-core/columns/macaddr.js.map +1 -1
  316. package/pg-core/columns/macaddr8.cjs.map +1 -1
  317. package/pg-core/columns/macaddr8.d.cts +1 -0
  318. package/pg-core/columns/macaddr8.d.ts +1 -0
  319. package/pg-core/columns/macaddr8.js.map +1 -1
  320. package/pg-core/columns/numeric.cjs.map +1 -1
  321. package/pg-core/columns/numeric.d.cts +3 -0
  322. package/pg-core/columns/numeric.d.ts +3 -0
  323. package/pg-core/columns/numeric.js.map +1 -1
  324. package/pg-core/columns/point.cjs +0 -2
  325. package/pg-core/columns/point.cjs.map +1 -1
  326. package/pg-core/columns/point.d.cts +2 -2
  327. package/pg-core/columns/point.d.ts +2 -2
  328. package/pg-core/columns/point.js +0 -2
  329. package/pg-core/columns/point.js.map +1 -1
  330. package/pg-core/columns/postgis_extension/geometry.cjs +8 -14
  331. package/pg-core/columns/postgis_extension/geometry.cjs.map +1 -1
  332. package/pg-core/columns/postgis_extension/geometry.d.cts +6 -16
  333. package/pg-core/columns/postgis_extension/geometry.d.ts +6 -16
  334. package/pg-core/columns/postgis_extension/geometry.js +8 -14
  335. package/pg-core/columns/postgis_extension/geometry.js.map +1 -1
  336. package/pg-core/columns/postgis_extension/utils.cjs +3 -3
  337. package/pg-core/columns/postgis_extension/utils.cjs.map +1 -1
  338. package/pg-core/columns/postgis_extension/utils.d.cts +1 -4
  339. package/pg-core/columns/postgis_extension/utils.d.ts +1 -4
  340. package/pg-core/columns/postgis_extension/utils.js +3 -3
  341. package/pg-core/columns/postgis_extension/utils.js.map +1 -1
  342. package/pg-core/columns/real.cjs.map +1 -1
  343. package/pg-core/columns/real.d.cts +1 -0
  344. package/pg-core/columns/real.d.ts +1 -0
  345. package/pg-core/columns/real.js.map +1 -1
  346. package/pg-core/columns/serial.cjs.map +1 -1
  347. package/pg-core/columns/serial.d.cts +1 -0
  348. package/pg-core/columns/serial.d.ts +1 -0
  349. package/pg-core/columns/serial.js.map +1 -1
  350. package/pg-core/columns/smallint.cjs.map +1 -1
  351. package/pg-core/columns/smallint.d.cts +1 -0
  352. package/pg-core/columns/smallint.d.ts +1 -0
  353. package/pg-core/columns/smallint.js.map +1 -1
  354. package/pg-core/columns/smallserial.cjs.map +1 -1
  355. package/pg-core/columns/smallserial.d.cts +1 -0
  356. package/pg-core/columns/smallserial.d.ts +1 -0
  357. package/pg-core/columns/smallserial.js.map +1 -1
  358. package/pg-core/columns/text.cjs.map +1 -1
  359. package/pg-core/columns/text.d.cts +1 -0
  360. package/pg-core/columns/text.d.ts +1 -0
  361. package/pg-core/columns/text.js.map +1 -1
  362. package/pg-core/columns/time.cjs.map +1 -1
  363. package/pg-core/columns/time.d.cts +1 -0
  364. package/pg-core/columns/time.d.ts +1 -0
  365. package/pg-core/columns/time.js.map +1 -1
  366. package/pg-core/columns/timestamp.cjs.map +1 -1
  367. package/pg-core/columns/timestamp.d.cts +2 -0
  368. package/pg-core/columns/timestamp.d.ts +2 -0
  369. package/pg-core/columns/timestamp.js.map +1 -1
  370. package/pg-core/columns/uuid.cjs.map +1 -1
  371. package/pg-core/columns/uuid.d.cts +1 -0
  372. package/pg-core/columns/uuid.d.ts +1 -0
  373. package/pg-core/columns/uuid.js.map +1 -1
  374. package/pg-core/columns/varchar.cjs.map +1 -1
  375. package/pg-core/columns/varchar.d.cts +1 -0
  376. package/pg-core/columns/varchar.d.ts +1 -0
  377. package/pg-core/columns/varchar.js.map +1 -1
  378. package/pg-core/columns/vector_extension/bit.cjs.map +1 -1
  379. package/pg-core/columns/vector_extension/bit.d.cts +1 -0
  380. package/pg-core/columns/vector_extension/bit.d.ts +1 -0
  381. package/pg-core/columns/vector_extension/bit.js.map +1 -1
  382. package/pg-core/columns/vector_extension/halfvec.cjs.map +1 -1
  383. package/pg-core/columns/vector_extension/halfvec.d.cts +1 -0
  384. package/pg-core/columns/vector_extension/halfvec.d.ts +1 -0
  385. package/pg-core/columns/vector_extension/halfvec.js.map +1 -1
  386. package/pg-core/columns/vector_extension/sparsevec.cjs.map +1 -1
  387. package/pg-core/columns/vector_extension/sparsevec.d.cts +1 -0
  388. package/pg-core/columns/vector_extension/sparsevec.d.ts +1 -0
  389. package/pg-core/columns/vector_extension/sparsevec.js.map +1 -1
  390. package/pg-core/columns/vector_extension/vector.cjs.map +1 -1
  391. package/pg-core/columns/vector_extension/vector.d.cts +1 -0
  392. package/pg-core/columns/vector_extension/vector.d.ts +1 -0
  393. package/pg-core/columns/vector_extension/vector.js.map +1 -1
  394. package/pg-core/foreign-keys.cjs +0 -4
  395. package/pg-core/foreign-keys.cjs.map +1 -1
  396. package/pg-core/foreign-keys.d.cts +0 -2
  397. package/pg-core/foreign-keys.d.ts +0 -2
  398. package/pg-core/foreign-keys.js +0 -4
  399. package/pg-core/foreign-keys.js.map +1 -1
  400. package/pg-core/primary-keys.cjs +0 -3
  401. package/pg-core/primary-keys.cjs.map +1 -1
  402. package/pg-core/primary-keys.d.cts +0 -1
  403. package/pg-core/primary-keys.d.ts +0 -1
  404. package/pg-core/primary-keys.js +0 -3
  405. package/pg-core/primary-keys.js.map +1 -1
  406. package/pg-core/query-builders/insert.cjs.map +1 -1
  407. package/pg-core/query-builders/insert.d.cts +9 -6
  408. package/pg-core/query-builders/insert.d.ts +9 -6
  409. package/pg-core/query-builders/insert.js.map +1 -1
  410. package/pg-core/query-builders/update.cjs.map +1 -1
  411. package/pg-core/query-builders/update.d.cts +1 -1
  412. package/pg-core/query-builders/update.d.ts +1 -1
  413. package/pg-core/query-builders/update.js.map +1 -1
  414. package/pg-core/unique-constraint.cjs +0 -5
  415. package/pg-core/unique-constraint.cjs.map +1 -1
  416. package/pg-core/unique-constraint.d.cts +0 -2
  417. package/pg-core/unique-constraint.d.ts +0 -2
  418. package/pg-core/unique-constraint.js +0 -5
  419. package/pg-core/unique-constraint.js.map +1 -1
  420. package/relations.cjs +5 -0
  421. package/relations.cjs.map +1 -1
  422. package/relations.js +5 -0
  423. package/relations.js.map +1 -1
  424. package/singlestore-core/columns/bigint.cjs.map +1 -1
  425. package/singlestore-core/columns/bigint.d.cts +2 -0
  426. package/singlestore-core/columns/bigint.d.ts +2 -0
  427. package/singlestore-core/columns/bigint.js.map +1 -1
  428. package/singlestore-core/columns/binary.cjs +1 -0
  429. package/singlestore-core/columns/binary.cjs.map +1 -1
  430. package/singlestore-core/columns/binary.d.cts +2 -0
  431. package/singlestore-core/columns/binary.d.ts +2 -0
  432. package/singlestore-core/columns/binary.js +1 -0
  433. package/singlestore-core/columns/binary.js.map +1 -1
  434. package/singlestore-core/columns/boolean.cjs.map +1 -1
  435. package/singlestore-core/columns/boolean.d.cts +1 -0
  436. package/singlestore-core/columns/boolean.d.ts +1 -0
  437. package/singlestore-core/columns/boolean.js.map +1 -1
  438. package/singlestore-core/columns/char.cjs +1 -0
  439. package/singlestore-core/columns/char.cjs.map +1 -1
  440. package/singlestore-core/columns/char.d.cts +2 -0
  441. package/singlestore-core/columns/char.d.ts +2 -0
  442. package/singlestore-core/columns/char.js +1 -0
  443. package/singlestore-core/columns/char.js.map +1 -1
  444. package/singlestore-core/columns/common.cjs.map +1 -1
  445. package/singlestore-core/columns/common.d.cts +1 -1
  446. package/singlestore-core/columns/common.d.ts +1 -1
  447. package/singlestore-core/columns/common.js.map +1 -1
  448. package/singlestore-core/columns/custom.cjs.map +1 -1
  449. package/singlestore-core/columns/custom.d.cts +1 -0
  450. package/singlestore-core/columns/custom.d.ts +1 -0
  451. package/singlestore-core/columns/custom.js.map +1 -1
  452. package/singlestore-core/columns/date.cjs.map +1 -1
  453. package/singlestore-core/columns/date.d.cts +2 -0
  454. package/singlestore-core/columns/date.d.ts +2 -0
  455. package/singlestore-core/columns/date.js.map +1 -1
  456. package/singlestore-core/columns/datetime.cjs.map +1 -1
  457. package/singlestore-core/columns/datetime.d.cts +2 -0
  458. package/singlestore-core/columns/datetime.d.ts +2 -0
  459. package/singlestore-core/columns/datetime.js.map +1 -1
  460. package/singlestore-core/columns/decimal.cjs.map +1 -1
  461. package/singlestore-core/columns/decimal.d.cts +3 -0
  462. package/singlestore-core/columns/decimal.d.ts +3 -0
  463. package/singlestore-core/columns/decimal.js.map +1 -1
  464. package/singlestore-core/columns/double.cjs.map +1 -1
  465. package/singlestore-core/columns/double.d.cts +1 -0
  466. package/singlestore-core/columns/double.d.ts +1 -0
  467. package/singlestore-core/columns/double.js.map +1 -1
  468. package/singlestore-core/columns/enum.cjs.map +1 -1
  469. package/singlestore-core/columns/enum.d.cts +1 -0
  470. package/singlestore-core/columns/enum.d.ts +1 -0
  471. package/singlestore-core/columns/enum.js.map +1 -1
  472. package/singlestore-core/columns/float.cjs.map +1 -1
  473. package/singlestore-core/columns/float.d.cts +1 -0
  474. package/singlestore-core/columns/float.d.ts +1 -0
  475. package/singlestore-core/columns/float.js.map +1 -1
  476. package/singlestore-core/columns/int.cjs.map +1 -1
  477. package/singlestore-core/columns/int.d.cts +1 -0
  478. package/singlestore-core/columns/int.d.ts +1 -0
  479. package/singlestore-core/columns/int.js.map +1 -1
  480. package/singlestore-core/columns/json.cjs.map +1 -1
  481. package/singlestore-core/columns/json.d.cts +1 -0
  482. package/singlestore-core/columns/json.d.ts +1 -0
  483. package/singlestore-core/columns/json.js.map +1 -1
  484. package/singlestore-core/columns/mediumint.cjs.map +1 -1
  485. package/singlestore-core/columns/mediumint.d.cts +1 -0
  486. package/singlestore-core/columns/mediumint.d.ts +1 -0
  487. package/singlestore-core/columns/mediumint.js.map +1 -1
  488. package/singlestore-core/columns/real.cjs.map +1 -1
  489. package/singlestore-core/columns/real.d.cts +1 -0
  490. package/singlestore-core/columns/real.d.ts +1 -0
  491. package/singlestore-core/columns/real.js.map +1 -1
  492. package/singlestore-core/columns/serial.cjs.map +1 -1
  493. package/singlestore-core/columns/serial.d.cts +1 -0
  494. package/singlestore-core/columns/serial.d.ts +1 -0
  495. package/singlestore-core/columns/serial.js.map +1 -1
  496. package/singlestore-core/columns/smallint.cjs.map +1 -1
  497. package/singlestore-core/columns/smallint.d.cts +1 -0
  498. package/singlestore-core/columns/smallint.d.ts +1 -0
  499. package/singlestore-core/columns/smallint.js.map +1 -1
  500. package/singlestore-core/columns/text.cjs.map +1 -1
  501. package/singlestore-core/columns/text.d.cts +1 -0
  502. package/singlestore-core/columns/text.d.ts +1 -0
  503. package/singlestore-core/columns/text.js.map +1 -1
  504. package/singlestore-core/columns/time.cjs.map +1 -1
  505. package/singlestore-core/columns/time.d.cts +1 -0
  506. package/singlestore-core/columns/time.d.ts +1 -0
  507. package/singlestore-core/columns/time.js.map +1 -1
  508. package/singlestore-core/columns/timestamp.cjs.map +1 -1
  509. package/singlestore-core/columns/timestamp.d.cts +2 -0
  510. package/singlestore-core/columns/timestamp.d.ts +2 -0
  511. package/singlestore-core/columns/timestamp.js.map +1 -1
  512. package/singlestore-core/columns/tinyint.cjs.map +1 -1
  513. package/singlestore-core/columns/tinyint.d.cts +1 -0
  514. package/singlestore-core/columns/tinyint.d.ts +1 -0
  515. package/singlestore-core/columns/tinyint.js.map +1 -1
  516. package/singlestore-core/columns/varbinary.cjs.map +1 -1
  517. package/singlestore-core/columns/varbinary.d.cts +1 -0
  518. package/singlestore-core/columns/varbinary.d.ts +1 -0
  519. package/singlestore-core/columns/varbinary.js.map +1 -1
  520. package/singlestore-core/columns/varchar.cjs.map +1 -1
  521. package/singlestore-core/columns/varchar.d.cts +1 -0
  522. package/singlestore-core/columns/varchar.d.ts +1 -0
  523. package/singlestore-core/columns/varchar.js.map +1 -1
  524. package/singlestore-core/columns/vector.cjs.map +1 -1
  525. package/singlestore-core/columns/vector.d.cts +2 -0
  526. package/singlestore-core/columns/vector.d.ts +2 -0
  527. package/singlestore-core/columns/vector.js.map +1 -1
  528. package/singlestore-core/columns/year.cjs.map +1 -1
  529. package/singlestore-core/columns/year.d.cts +1 -0
  530. package/singlestore-core/columns/year.d.ts +1 -0
  531. package/singlestore-core/columns/year.js.map +1 -1
  532. package/singlestore-core/query-builders/insert.cjs.map +1 -1
  533. package/singlestore-core/query-builders/insert.d.cts +1 -1
  534. package/singlestore-core/query-builders/insert.d.ts +1 -1
  535. package/singlestore-core/query-builders/insert.js.map +1 -1
  536. package/singlestore-core/query-builders/update.cjs.map +1 -1
  537. package/singlestore-core/query-builders/update.d.cts +1 -1
  538. package/singlestore-core/query-builders/update.d.ts +1 -1
  539. package/singlestore-core/query-builders/update.js.map +1 -1
  540. package/sql/sql.cjs +3 -10
  541. package/sql/sql.cjs.map +1 -1
  542. package/sql/sql.d.cts +1 -1
  543. package/sql/sql.d.ts +1 -1
  544. package/sql/sql.js +3 -10
  545. package/sql/sql.js.map +1 -1
  546. package/sqlite-core/columns/blob.cjs +3 -3
  547. package/sqlite-core/columns/blob.cjs.map +1 -1
  548. package/sqlite-core/columns/blob.d.cts +3 -0
  549. package/sqlite-core/columns/blob.d.ts +3 -0
  550. package/sqlite-core/columns/blob.js +3 -3
  551. package/sqlite-core/columns/blob.js.map +1 -1
  552. package/sqlite-core/columns/custom.cjs.map +1 -1
  553. package/sqlite-core/columns/custom.d.cts +1 -0
  554. package/sqlite-core/columns/custom.d.ts +1 -0
  555. package/sqlite-core/columns/custom.js.map +1 -1
  556. package/sqlite-core/columns/integer.cjs.map +1 -1
  557. package/sqlite-core/columns/integer.d.cts +3 -0
  558. package/sqlite-core/columns/integer.d.ts +3 -0
  559. package/sqlite-core/columns/integer.js.map +1 -1
  560. package/sqlite-core/columns/numeric.cjs.map +1 -1
  561. package/sqlite-core/columns/numeric.d.cts +3 -0
  562. package/sqlite-core/columns/numeric.d.ts +3 -0
  563. package/sqlite-core/columns/numeric.js.map +1 -1
  564. package/sqlite-core/columns/real.cjs.map +1 -1
  565. package/sqlite-core/columns/real.d.cts +1 -0
  566. package/sqlite-core/columns/real.d.ts +1 -0
  567. package/sqlite-core/columns/real.js.map +1 -1
  568. package/sqlite-core/columns/text.cjs.map +1 -1
  569. package/sqlite-core/columns/text.d.cts +2 -0
  570. package/sqlite-core/columns/text.d.ts +2 -0
  571. package/sqlite-core/columns/text.js.map +1 -1
  572. package/sqlite-core/query-builders/insert.cjs.map +1 -1
  573. package/sqlite-core/query-builders/insert.d.cts +2 -2
  574. package/sqlite-core/query-builders/insert.d.ts +2 -2
  575. package/sqlite-core/query-builders/insert.js.map +1 -1
  576. package/sqlite-core/query-builders/update.cjs.map +1 -1
  577. package/sqlite-core/query-builders/update.d.cts +1 -1
  578. package/sqlite-core/query-builders/update.d.ts +1 -1
  579. package/sqlite-core/query-builders/update.js.map +1 -1
  580. package/version.cjs +1 -1
  581. package/version.d.cts +1 -1
  582. package/version.d.ts +1 -1
  583. package/version.js +1 -1
  584. package/cockroach/driver.cjs +0 -113
  585. package/cockroach/driver.cjs.map +0 -1
  586. package/cockroach/driver.d.cts +0 -42
  587. package/cockroach/driver.d.ts +0 -42
  588. package/cockroach/driver.js +0 -77
  589. package/cockroach/driver.js.map +0 -1
  590. package/cockroach/index.cjs +0 -25
  591. package/cockroach/index.cjs.map +0 -1
  592. package/cockroach/index.d.cts +0 -2
  593. package/cockroach/index.d.ts +0 -2
  594. package/cockroach/index.js +0 -3
  595. package/cockroach/index.js.map +0 -1
  596. package/cockroach/migrator.cjs +0 -33
  597. package/cockroach/migrator.cjs.map +0 -1
  598. package/cockroach/migrator.d.cts +0 -3
  599. package/cockroach/migrator.d.ts +0 -3
  600. package/cockroach/migrator.js +0 -9
  601. package/cockroach/migrator.js.map +0 -1
  602. package/cockroach/session.cjs +0 -253
  603. package/cockroach/session.cjs.map +0 -1
  604. package/cockroach/session.d.cts +0 -48
  605. package/cockroach/session.d.ts +0 -48
  606. package/cockroach/session.js +0 -217
  607. package/cockroach/session.js.map +0 -1
  608. package/cockroach-core/alias.cjs +0 -32
  609. package/cockroach-core/alias.cjs.map +0 -1
  610. package/cockroach-core/alias.d.cts +0 -4
  611. package/cockroach-core/alias.d.ts +0 -4
  612. package/cockroach-core/alias.js +0 -8
  613. package/cockroach-core/alias.js.map +0 -1
  614. package/cockroach-core/checks.cjs +0 -58
  615. package/cockroach-core/checks.cjs.map +0 -1
  616. package/cockroach-core/checks.d.cts +0 -18
  617. package/cockroach-core/checks.d.ts +0 -18
  618. package/cockroach-core/checks.js +0 -32
  619. package/cockroach-core/checks.js.map +0 -1
  620. package/cockroach-core/columns/all.cjs +0 -81
  621. package/cockroach-core/columns/all.cjs.map +0 -1
  622. package/cockroach-core/columns/all.d.cts +0 -52
  623. package/cockroach-core/columns/all.d.ts +0 -52
  624. package/cockroach-core/columns/all.js +0 -57
  625. package/cockroach-core/columns/all.js.map +0 -1
  626. package/cockroach-core/columns/bigint.cjs +0 -104
  627. package/cockroach-core/columns/bigint.cjs.map +0 -1
  628. package/cockroach-core/columns/bigint.d.cts +0 -37
  629. package/cockroach-core/columns/bigint.d.ts +0 -37
  630. package/cockroach-core/columns/bigint.js +0 -75
  631. package/cockroach-core/columns/bigint.js.map +0 -1
  632. package/cockroach-core/columns/bit.cjs +0 -61
  633. package/cockroach-core/columns/bit.cjs.map +0 -1
  634. package/cockroach-core/columns/bit.d.cts +0 -29
  635. package/cockroach-core/columns/bit.d.ts +0 -29
  636. package/cockroach-core/columns/bit.js +0 -35
  637. package/cockroach-core/columns/bit.js.map +0 -1
  638. package/cockroach-core/columns/bool.cjs +0 -59
  639. package/cockroach-core/columns/bool.cjs.map +0 -1
  640. package/cockroach-core/columns/bool.d.cts +0 -17
  641. package/cockroach-core/columns/bool.d.ts +0 -17
  642. package/cockroach-core/columns/bool.js +0 -32
  643. package/cockroach-core/columns/bool.js.map +0 -1
  644. package/cockroach-core/columns/char.cjs +0 -62
  645. package/cockroach-core/columns/char.cjs.map +0 -1
  646. package/cockroach-core/columns/char.d.cts +0 -31
  647. package/cockroach-core/columns/char.d.ts +0 -31
  648. package/cockroach-core/columns/char.js +0 -36
  649. package/cockroach-core/columns/char.js.map +0 -1
  650. package/cockroach-core/columns/common.cjs +0 -199
  651. package/cockroach-core/columns/common.cjs.map +0 -1
  652. package/cockroach-core/columns/common.d.cts +0 -98
  653. package/cockroach-core/columns/common.d.ts +0 -98
  654. package/cockroach-core/columns/common.js +0 -169
  655. package/cockroach-core/columns/common.js.map +0 -1
  656. package/cockroach-core/columns/custom.cjs +0 -102
  657. package/cockroach-core/columns/custom.cjs.map +0 -1
  658. package/cockroach-core/columns/custom.d.cts +0 -261
  659. package/cockroach-core/columns/custom.d.ts +0 -261
  660. package/cockroach-core/columns/custom.js +0 -76
  661. package/cockroach-core/columns/custom.js.map +0 -1
  662. package/cockroach-core/columns/date.cjs +0 -91
  663. package/cockroach-core/columns/date.cjs.map +0 -1
  664. package/cockroach-core/columns/date.common.cjs +0 -37
  665. package/cockroach-core/columns/date.common.cjs.map +0 -1
  666. package/cockroach-core/columns/date.common.d.cts +0 -7
  667. package/cockroach-core/columns/date.common.d.ts +0 -7
  668. package/cockroach-core/columns/date.common.js +0 -13
  669. package/cockroach-core/columns/date.common.js.map +0 -1
  670. package/cockroach-core/columns/date.d.cts +0 -36
  671. package/cockroach-core/columns/date.d.ts +0 -36
  672. package/cockroach-core/columns/date.js +0 -63
  673. package/cockroach-core/columns/date.js.map +0 -1
  674. package/cockroach-core/columns/decimal.cjs +0 -164
  675. package/cockroach-core/columns/decimal.cjs.map +0 -1
  676. package/cockroach-core/columns/decimal.d.cts +0 -80
  677. package/cockroach-core/columns/decimal.d.ts +0 -80
  678. package/cockroach-core/columns/decimal.js +0 -133
  679. package/cockroach-core/columns/decimal.js.map +0 -1
  680. package/cockroach-core/columns/enum.cjs +0 -127
  681. package/cockroach-core/columns/enum.cjs.map +0 -1
  682. package/cockroach-core/columns/enum.d.cts +0 -64
  683. package/cockroach-core/columns/enum.d.ts +0 -64
  684. package/cockroach-core/columns/enum.js +0 -96
  685. package/cockroach-core/columns/enum.js.map +0 -1
  686. package/cockroach-core/columns/float.cjs +0 -65
  687. package/cockroach-core/columns/float.cjs.map +0 -1
  688. package/cockroach-core/columns/float.d.cts +0 -18
  689. package/cockroach-core/columns/float.d.ts +0 -18
  690. package/cockroach-core/columns/float.js +0 -38
  691. package/cockroach-core/columns/float.js.map +0 -1
  692. package/cockroach-core/columns/geometry.cjs +0 -105
  693. package/cockroach-core/columns/geometry.cjs.map +0 -1
  694. package/cockroach-core/columns/geometry.d.cts +0 -60
  695. package/cockroach-core/columns/geometry.d.ts +0 -60
  696. package/cockroach-core/columns/geometry.js +0 -77
  697. package/cockroach-core/columns/geometry.js.map +0 -1
  698. package/cockroach-core/columns/index.cjs +0 -71
  699. package/cockroach-core/columns/index.cjs.map +0 -1
  700. package/cockroach-core/columns/index.d.cts +0 -25
  701. package/cockroach-core/columns/index.d.ts +0 -25
  702. package/cockroach-core/columns/index.js +0 -26
  703. package/cockroach-core/columns/index.js.map +0 -1
  704. package/cockroach-core/columns/inet.cjs +0 -56
  705. package/cockroach-core/columns/inet.cjs.map +0 -1
  706. package/cockroach-core/columns/inet.d.cts +0 -16
  707. package/cockroach-core/columns/inet.d.ts +0 -16
  708. package/cockroach-core/columns/inet.js +0 -30
  709. package/cockroach-core/columns/inet.js.map +0 -1
  710. package/cockroach-core/columns/int.common.cjs +0 -55
  711. package/cockroach-core/columns/int.common.cjs.map +0 -1
  712. package/cockroach-core/columns/int.common.d.cts +0 -11
  713. package/cockroach-core/columns/int.common.d.ts +0 -11
  714. package/cockroach-core/columns/int.common.js +0 -31
  715. package/cockroach-core/columns/int.common.js.map +0 -1
  716. package/cockroach-core/columns/integer.cjs +0 -63
  717. package/cockroach-core/columns/integer.cjs.map +0 -1
  718. package/cockroach-core/columns/integer.d.cts +0 -18
  719. package/cockroach-core/columns/integer.d.ts +0 -18
  720. package/cockroach-core/columns/integer.js +0 -37
  721. package/cockroach-core/columns/integer.js.map +0 -1
  722. package/cockroach-core/columns/interval.cjs +0 -63
  723. package/cockroach-core/columns/interval.cjs.map +0 -1
  724. package/cockroach-core/columns/interval.d.cts +0 -28
  725. package/cockroach-core/columns/interval.d.ts +0 -28
  726. package/cockroach-core/columns/interval.js +0 -37
  727. package/cockroach-core/columns/interval.js.map +0 -1
  728. package/cockroach-core/columns/jsonb.cjs +0 -72
  729. package/cockroach-core/columns/jsonb.cjs.map +0 -1
  730. package/cockroach-core/columns/jsonb.d.cts +0 -20
  731. package/cockroach-core/columns/jsonb.d.ts +0 -20
  732. package/cockroach-core/columns/jsonb.js +0 -46
  733. package/cockroach-core/columns/jsonb.js.map +0 -1
  734. package/cockroach-core/columns/real.cjs +0 -66
  735. package/cockroach-core/columns/real.cjs.map +0 -1
  736. package/cockroach-core/columns/real.d.cts +0 -21
  737. package/cockroach-core/columns/real.d.ts +0 -21
  738. package/cockroach-core/columns/real.js +0 -40
  739. package/cockroach-core/columns/real.js.map +0 -1
  740. package/cockroach-core/columns/smallint.cjs +0 -68
  741. package/cockroach-core/columns/smallint.cjs.map +0 -1
  742. package/cockroach-core/columns/smallint.d.cts +0 -19
  743. package/cockroach-core/columns/smallint.d.ts +0 -19
  744. package/cockroach-core/columns/smallint.js +0 -41
  745. package/cockroach-core/columns/smallint.js.map +0 -1
  746. package/cockroach-core/columns/string.cjs +0 -67
  747. package/cockroach-core/columns/string.cjs.map +0 -1
  748. package/cockroach-core/columns/string.d.cts +0 -36
  749. package/cockroach-core/columns/string.d.ts +0 -36
  750. package/cockroach-core/columns/string.js +0 -40
  751. package/cockroach-core/columns/string.js.map +0 -1
  752. package/cockroach-core/columns/time.cjs +0 -70
  753. package/cockroach-core/columns/time.cjs.map +0 -1
  754. package/cockroach-core/columns/time.d.cts +0 -31
  755. package/cockroach-core/columns/time.d.ts +0 -31
  756. package/cockroach-core/columns/time.js +0 -44
  757. package/cockroach-core/columns/time.js.map +0 -1
  758. package/cockroach-core/columns/timestamp.cjs +0 -111
  759. package/cockroach-core/columns/timestamp.cjs.map +0 -1
  760. package/cockroach-core/columns/timestamp.d.cts +0 -52
  761. package/cockroach-core/columns/timestamp.d.ts +0 -52
  762. package/cockroach-core/columns/timestamp.js +0 -83
  763. package/cockroach-core/columns/timestamp.js.map +0 -1
  764. package/cockroach-core/columns/utils.cjs +0 -65
  765. package/cockroach-core/columns/utils.cjs.map +0 -1
  766. package/cockroach-core/columns/utils.d.cts +0 -4
  767. package/cockroach-core/columns/utils.d.ts +0 -4
  768. package/cockroach-core/columns/utils.js +0 -41
  769. package/cockroach-core/columns/utils.js.map +0 -1
  770. package/cockroach-core/columns/uuid.cjs +0 -63
  771. package/cockroach-core/columns/uuid.cjs.map +0 -1
  772. package/cockroach-core/columns/uuid.d.cts +0 -20
  773. package/cockroach-core/columns/uuid.d.ts +0 -20
  774. package/cockroach-core/columns/uuid.js +0 -37
  775. package/cockroach-core/columns/uuid.js.map +0 -1
  776. package/cockroach-core/columns/varbit.cjs +0 -59
  777. package/cockroach-core/columns/varbit.cjs.map +0 -1
  778. package/cockroach-core/columns/varbit.d.cts +0 -24
  779. package/cockroach-core/columns/varbit.d.ts +0 -24
  780. package/cockroach-core/columns/varbit.js +0 -33
  781. package/cockroach-core/columns/varbit.js.map +0 -1
  782. package/cockroach-core/columns/varchar.cjs +0 -61
  783. package/cockroach-core/columns/varchar.cjs.map +0 -1
  784. package/cockroach-core/columns/varchar.d.cts +0 -30
  785. package/cockroach-core/columns/varchar.d.ts +0 -30
  786. package/cockroach-core/columns/varchar.js +0 -35
  787. package/cockroach-core/columns/varchar.js.map +0 -1
  788. package/cockroach-core/columns/vector.cjs +0 -65
  789. package/cockroach-core/columns/vector.cjs.map +0 -1
  790. package/cockroach-core/columns/vector.d.cts +0 -26
  791. package/cockroach-core/columns/vector.d.ts +0 -26
  792. package/cockroach-core/columns/vector.js +0 -39
  793. package/cockroach-core/columns/vector.js.map +0 -1
  794. package/cockroach-core/db.cjs +0 -346
  795. package/cockroach-core/db.cjs.map +0 -1
  796. package/cockroach-core/db.d.cts +0 -282
  797. package/cockroach-core/db.d.ts +0 -282
  798. package/cockroach-core/db.js +0 -327
  799. package/cockroach-core/db.js.map +0 -1
  800. package/cockroach-core/dialect.cjs +0 -1146
  801. package/cockroach-core/dialect.cjs.map +0 -1
  802. package/cockroach-core/dialect.d.cts +0 -65
  803. package/cockroach-core/dialect.d.ts +0 -65
  804. package/cockroach-core/dialect.js +0 -1126
  805. package/cockroach-core/dialect.js.map +0 -1
  806. package/cockroach-core/expressions.cjs +0 -49
  807. package/cockroach-core/expressions.cjs.map +0 -1
  808. package/cockroach-core/expressions.d.cts +0 -8
  809. package/cockroach-core/expressions.d.ts +0 -8
  810. package/cockroach-core/expressions.js +0 -22
  811. package/cockroach-core/expressions.js.map +0 -1
  812. package/cockroach-core/foreign-keys.cjs +0 -92
  813. package/cockroach-core/foreign-keys.cjs.map +0 -1
  814. package/cockroach-core/foreign-keys.d.cts +0 -52
  815. package/cockroach-core/foreign-keys.d.ts +0 -52
  816. package/cockroach-core/foreign-keys.js +0 -66
  817. package/cockroach-core/foreign-keys.js.map +0 -1
  818. package/cockroach-core/index.cjs +0 -61
  819. package/cockroach-core/index.cjs.map +0 -1
  820. package/cockroach-core/index.d.cts +0 -20
  821. package/cockroach-core/index.d.ts +0 -20
  822. package/cockroach-core/index.js +0 -21
  823. package/cockroach-core/index.js.map +0 -1
  824. package/cockroach-core/indexes.cjs +0 -137
  825. package/cockroach-core/indexes.cjs.map +0 -1
  826. package/cockroach-core/indexes.d.cts +0 -64
  827. package/cockroach-core/indexes.d.ts +0 -64
  828. package/cockroach-core/indexes.js +0 -109
  829. package/cockroach-core/indexes.js.map +0 -1
  830. package/cockroach-core/policies.cjs +0 -58
  831. package/cockroach-core/policies.cjs.map +0 -1
  832. package/cockroach-core/policies.d.cts +0 -24
  833. package/cockroach-core/policies.d.ts +0 -24
  834. package/cockroach-core/policies.js +0 -33
  835. package/cockroach-core/policies.js.map +0 -1
  836. package/cockroach-core/primary-keys.cjs +0 -64
  837. package/cockroach-core/primary-keys.cjs.map +0 -1
  838. package/cockroach-core/primary-keys.d.cts +0 -23
  839. package/cockroach-core/primary-keys.d.ts +0 -23
  840. package/cockroach-core/primary-keys.js +0 -38
  841. package/cockroach-core/primary-keys.js.map +0 -1
  842. package/cockroach-core/query-builders/count.cjs +0 -79
  843. package/cockroach-core/query-builders/count.cjs.map +0 -1
  844. package/cockroach-core/query-builders/count.d.cts +0 -29
  845. package/cockroach-core/query-builders/count.d.ts +0 -29
  846. package/cockroach-core/query-builders/count.js +0 -55
  847. package/cockroach-core/query-builders/count.js.map +0 -1
  848. package/cockroach-core/query-builders/delete.cjs +0 -124
  849. package/cockroach-core/query-builders/delete.cjs.map +0 -1
  850. package/cockroach-core/query-builders/delete.d.cts +0 -103
  851. package/cockroach-core/query-builders/delete.d.ts +0 -103
  852. package/cockroach-core/query-builders/delete.js +0 -100
  853. package/cockroach-core/query-builders/delete.js.map +0 -1
  854. package/cockroach-core/query-builders/index.cjs +0 -35
  855. package/cockroach-core/query-builders/index.cjs.map +0 -1
  856. package/cockroach-core/query-builders/index.d.cts +0 -7
  857. package/cockroach-core/query-builders/index.d.ts +0 -7
  858. package/cockroach-core/query-builders/index.js +0 -8
  859. package/cockroach-core/query-builders/index.js.map +0 -1
  860. package/cockroach-core/query-builders/insert.cjs +0 -213
  861. package/cockroach-core/query-builders/insert.cjs.map +0 -1
  862. package/cockroach-core/query-builders/insert.d.cts +0 -168
  863. package/cockroach-core/query-builders/insert.d.ts +0 -168
  864. package/cockroach-core/query-builders/insert.js +0 -188
  865. package/cockroach-core/query-builders/insert.js.map +0 -1
  866. package/cockroach-core/query-builders/query-builder.cjs +0 -118
  867. package/cockroach-core/query-builders/query-builder.cjs.map +0 -1
  868. package/cockroach-core/query-builders/query-builder.d.cts +0 -37
  869. package/cockroach-core/query-builders/query-builder.d.ts +0 -37
  870. package/cockroach-core/query-builders/query-builder.js +0 -94
  871. package/cockroach-core/query-builders/query-builder.js.map +0 -1
  872. package/cockroach-core/query-builders/query.cjs +0 -145
  873. package/cockroach-core/query-builders/query.cjs.map +0 -1
  874. package/cockroach-core/query-builders/query.d.cts +0 -47
  875. package/cockroach-core/query-builders/query.d.ts +0 -47
  876. package/cockroach-core/query-builders/query.js +0 -122
  877. package/cockroach-core/query-builders/query.js.map +0 -1
  878. package/cockroach-core/query-builders/raw.cjs +0 -57
  879. package/cockroach-core/query-builders/raw.cjs.map +0 -1
  880. package/cockroach-core/query-builders/raw.d.cts +0 -22
  881. package/cockroach-core/query-builders/raw.d.ts +0 -22
  882. package/cockroach-core/query-builders/raw.js +0 -33
  883. package/cockroach-core/query-builders/raw.js.map +0 -1
  884. package/cockroach-core/query-builders/refresh-materialized-view.cjs +0 -83
  885. package/cockroach-core/query-builders/refresh-materialized-view.cjs.map +0 -1
  886. package/cockroach-core/query-builders/refresh-materialized-view.d.cts +0 -28
  887. package/cockroach-core/query-builders/refresh-materialized-view.d.ts +0 -28
  888. package/cockroach-core/query-builders/refresh-materialized-view.js +0 -59
  889. package/cockroach-core/query-builders/refresh-materialized-view.js.map +0 -1
  890. package/cockroach-core/query-builders/select.cjs +0 -848
  891. package/cockroach-core/query-builders/select.cjs.map +0 -1
  892. package/cockroach-core/query-builders/select.d.cts +0 -787
  893. package/cockroach-core/query-builders/select.d.ts +0 -787
  894. package/cockroach-core/query-builders/select.js +0 -821
  895. package/cockroach-core/query-builders/select.js.map +0 -1
  896. package/cockroach-core/query-builders/select.types.cjs +0 -17
  897. package/cockroach-core/query-builders/select.types.cjs.map +0 -1
  898. package/cockroach-core/query-builders/select.types.d.cts +0 -140
  899. package/cockroach-core/query-builders/select.types.d.ts +0 -140
  900. package/cockroach-core/query-builders/select.types.js +0 -1
  901. package/cockroach-core/query-builders/select.types.js.map +0 -1
  902. package/cockroach-core/query-builders/update.cjs +0 -240
  903. package/cockroach-core/query-builders/update.cjs.map +0 -1
  904. package/cockroach-core/query-builders/update.d.cts +0 -170
  905. package/cockroach-core/query-builders/update.d.ts +0 -170
  906. package/cockroach-core/query-builders/update.js +0 -219
  907. package/cockroach-core/query-builders/update.js.map +0 -1
  908. package/cockroach-core/roles.cjs +0 -54
  909. package/cockroach-core/roles.cjs.map +0 -1
  910. package/cockroach-core/roles.d.cts +0 -12
  911. package/cockroach-core/roles.d.ts +0 -12
  912. package/cockroach-core/roles.js +0 -29
  913. package/cockroach-core/roles.js.map +0 -1
  914. package/cockroach-core/schema.cjs +0 -80
  915. package/cockroach-core/schema.cjs.map +0 -1
  916. package/cockroach-core/schema.d.cts +0 -22
  917. package/cockroach-core/schema.d.ts +0 -22
  918. package/cockroach-core/schema.js +0 -60
  919. package/cockroach-core/schema.js.map +0 -1
  920. package/cockroach-core/sequence.cjs +0 -52
  921. package/cockroach-core/sequence.cjs.map +0 -1
  922. package/cockroach-core/sequence.d.cts +0 -17
  923. package/cockroach-core/sequence.d.ts +0 -17
  924. package/cockroach-core/sequence.js +0 -25
  925. package/cockroach-core/sequence.js.map +0 -1
  926. package/cockroach-core/session.cjs +0 -120
  927. package/cockroach-core/session.cjs.map +0 -1
  928. package/cockroach-core/session.d.cts +0 -62
  929. package/cockroach-core/session.d.ts +0 -62
  930. package/cockroach-core/session.js +0 -94
  931. package/cockroach-core/session.js.map +0 -1
  932. package/cockroach-core/subquery.cjs +0 -17
  933. package/cockroach-core/subquery.cjs.map +0 -1
  934. package/cockroach-core/subquery.d.cts +0 -18
  935. package/cockroach-core/subquery.d.ts +0 -18
  936. package/cockroach-core/subquery.js +0 -1
  937. package/cockroach-core/subquery.js.map +0 -1
  938. package/cockroach-core/table.cjs +0 -100
  939. package/cockroach-core/table.cjs.map +0 -1
  940. package/cockroach-core/table.d.cts +0 -37
  941. package/cockroach-core/table.d.ts +0 -37
  942. package/cockroach-core/table.js +0 -73
  943. package/cockroach-core/table.js.map +0 -1
  944. package/cockroach-core/unique-constraint.cjs +0 -77
  945. package/cockroach-core/unique-constraint.cjs.map +0 -1
  946. package/cockroach-core/unique-constraint.d.cts +0 -23
  947. package/cockroach-core/unique-constraint.d.ts +0 -23
  948. package/cockroach-core/unique-constraint.js +0 -50
  949. package/cockroach-core/unique-constraint.js.map +0 -1
  950. package/cockroach-core/utils/array.cjs +0 -106
  951. package/cockroach-core/utils/array.cjs.map +0 -1
  952. package/cockroach-core/utils/array.d.cts +0 -3
  953. package/cockroach-core/utils/array.d.ts +0 -3
  954. package/cockroach-core/utils/array.js +0 -80
  955. package/cockroach-core/utils/array.js.map +0 -1
  956. package/cockroach-core/utils/index.cjs +0 -23
  957. package/cockroach-core/utils/index.cjs.map +0 -1
  958. package/cockroach-core/utils/index.d.cts +0 -1
  959. package/cockroach-core/utils/index.d.ts +0 -1
  960. package/cockroach-core/utils/index.js +0 -2
  961. package/cockroach-core/utils/index.js.map +0 -1
  962. package/cockroach-core/utils.cjs +0 -98
  963. package/cockroach-core/utils.cjs.map +0 -1
  964. package/cockroach-core/utils.d.cts +0 -47
  965. package/cockroach-core/utils.d.ts +0 -47
  966. package/cockroach-core/utils.js +0 -72
  967. package/cockroach-core/utils.js.map +0 -1
  968. package/cockroach-core/view-base.cjs +0 -33
  969. package/cockroach-core/view-base.cjs.map +0 -1
  970. package/cockroach-core/view-base.d.cts +0 -8
  971. package/cockroach-core/view-base.d.ts +0 -8
  972. package/cockroach-core/view-base.js +0 -9
  973. package/cockroach-core/view-base.js.map +0 -1
  974. package/cockroach-core/view.cjs +0 -271
  975. package/cockroach-core/view.cjs.map +0 -1
  976. package/cockroach-core/view.d.cts +0 -106
  977. package/cockroach-core/view.d.ts +0 -106
  978. package/cockroach-core/view.js +0 -233
  979. package/cockroach-core/view.js.map +0 -1
  980. package/mssql-core/alias.cjs +0 -32
  981. package/mssql-core/alias.cjs.map +0 -1
  982. package/mssql-core/alias.d.cts +0 -4
  983. package/mssql-core/alias.d.ts +0 -4
  984. package/mssql-core/alias.js +0 -8
  985. package/mssql-core/alias.js.map +0 -1
  986. package/mssql-core/checks.cjs +0 -58
  987. package/mssql-core/checks.cjs.map +0 -1
  988. package/mssql-core/checks.d.cts +0 -18
  989. package/mssql-core/checks.d.ts +0 -18
  990. package/mssql-core/checks.js +0 -32
  991. package/mssql-core/checks.js.map +0 -1
  992. package/mssql-core/columns/all.cjs +0 -74
  993. package/mssql-core/columns/all.cjs.map +0 -1
  994. package/mssql-core/columns/all.d.cts +0 -45
  995. package/mssql-core/columns/all.d.ts +0 -45
  996. package/mssql-core/columns/all.js +0 -50
  997. package/mssql-core/columns/all.js.map +0 -1
  998. package/mssql-core/columns/bigint.cjs +0 -72
  999. package/mssql-core/columns/bigint.cjs.map +0 -1
  1000. package/mssql-core/columns/bigint.d.cts +0 -25
  1001. package/mssql-core/columns/bigint.d.ts +0 -25
  1002. package/mssql-core/columns/bigint.js +0 -46
  1003. package/mssql-core/columns/bigint.js.map +0 -1
  1004. package/mssql-core/columns/binary.cjs +0 -57
  1005. package/mssql-core/columns/binary.cjs.map +0 -1
  1006. package/mssql-core/columns/binary.d.cts +0 -24
  1007. package/mssql-core/columns/binary.d.ts +0 -24
  1008. package/mssql-core/columns/binary.js +0 -31
  1009. package/mssql-core/columns/binary.js.map +0 -1
  1010. package/mssql-core/columns/bit.cjs +0 -54
  1011. package/mssql-core/columns/bit.cjs.map +0 -1
  1012. package/mssql-core/columns/bit.d.cts +0 -17
  1013. package/mssql-core/columns/bit.d.ts +0 -17
  1014. package/mssql-core/columns/bit.js +0 -28
  1015. package/mssql-core/columns/bit.js.map +0 -1
  1016. package/mssql-core/columns/char.cjs +0 -73
  1017. package/mssql-core/columns/char.cjs.map +0 -1
  1018. package/mssql-core/columns/char.d.cts +0 -29
  1019. package/mssql-core/columns/char.d.ts +0 -29
  1020. package/mssql-core/columns/char.js +0 -46
  1021. package/mssql-core/columns/char.js.map +0 -1
  1022. package/mssql-core/columns/common.cjs +0 -112
  1023. package/mssql-core/columns/common.cjs.map +0 -1
  1024. package/mssql-core/columns/common.d.cts +0 -57
  1025. package/mssql-core/columns/common.d.ts +0 -57
  1026. package/mssql-core/columns/common.js +0 -85
  1027. package/mssql-core/columns/common.js.map +0 -1
  1028. package/mssql-core/columns/custom.cjs +0 -105
  1029. package/mssql-core/columns/custom.cjs.map +0 -1
  1030. package/mssql-core/columns/custom.d.cts +0 -261
  1031. package/mssql-core/columns/custom.d.ts +0 -261
  1032. package/mssql-core/columns/custom.js +0 -79
  1033. package/mssql-core/columns/custom.js.map +0 -1
  1034. package/mssql-core/columns/date.cjs +0 -94
  1035. package/mssql-core/columns/date.cjs.map +0 -1
  1036. package/mssql-core/columns/date.common.cjs +0 -37
  1037. package/mssql-core/columns/date.common.cjs.map +0 -1
  1038. package/mssql-core/columns/date.common.d.cts +0 -12
  1039. package/mssql-core/columns/date.common.d.ts +0 -12
  1040. package/mssql-core/columns/date.common.js +0 -13
  1041. package/mssql-core/columns/date.common.js.map +0 -1
  1042. package/mssql-core/columns/date.d.cts +0 -39
  1043. package/mssql-core/columns/date.d.ts +0 -39
  1044. package/mssql-core/columns/date.js +0 -66
  1045. package/mssql-core/columns/date.js.map +0 -1
  1046. package/mssql-core/columns/datetime.cjs +0 -94
  1047. package/mssql-core/columns/datetime.cjs.map +0 -1
  1048. package/mssql-core/columns/datetime.d.cts +0 -38
  1049. package/mssql-core/columns/datetime.d.ts +0 -38
  1050. package/mssql-core/columns/datetime.js +0 -66
  1051. package/mssql-core/columns/datetime.js.map +0 -1
  1052. package/mssql-core/columns/datetime2.cjs +0 -102
  1053. package/mssql-core/columns/datetime2.cjs.map +0 -1
  1054. package/mssql-core/columns/datetime2.d.cts +0 -38
  1055. package/mssql-core/columns/datetime2.d.ts +0 -38
  1056. package/mssql-core/columns/datetime2.js +0 -74
  1057. package/mssql-core/columns/datetime2.js.map +0 -1
  1058. package/mssql-core/columns/datetimeoffset.cjs +0 -102
  1059. package/mssql-core/columns/datetimeoffset.cjs.map +0 -1
  1060. package/mssql-core/columns/datetimeoffset.d.cts +0 -39
  1061. package/mssql-core/columns/datetimeoffset.d.ts +0 -39
  1062. package/mssql-core/columns/datetimeoffset.js +0 -74
  1063. package/mssql-core/columns/datetimeoffset.js.map +0 -1
  1064. package/mssql-core/columns/decimal.cjs +0 -146
  1065. package/mssql-core/columns/decimal.cjs.map +0 -1
  1066. package/mssql-core/columns/decimal.d.cts +0 -58
  1067. package/mssql-core/columns/decimal.d.ts +0 -58
  1068. package/mssql-core/columns/decimal.js +0 -116
  1069. package/mssql-core/columns/decimal.js.map +0 -1
  1070. package/mssql-core/columns/float.cjs +0 -58
  1071. package/mssql-core/columns/float.cjs.map +0 -1
  1072. package/mssql-core/columns/float.d.cts +0 -21
  1073. package/mssql-core/columns/float.d.ts +0 -21
  1074. package/mssql-core/columns/float.js +0 -32
  1075. package/mssql-core/columns/float.js.map +0 -1
  1076. package/mssql-core/columns/index.cjs +0 -63
  1077. package/mssql-core/columns/index.cjs.map +0 -1
  1078. package/mssql-core/columns/index.d.cts +0 -21
  1079. package/mssql-core/columns/index.d.ts +0 -21
  1080. package/mssql-core/columns/index.js +0 -22
  1081. package/mssql-core/columns/index.js.map +0 -1
  1082. package/mssql-core/columns/int.cjs +0 -53
  1083. package/mssql-core/columns/int.cjs.map +0 -1
  1084. package/mssql-core/columns/int.d.cts +0 -16
  1085. package/mssql-core/columns/int.d.ts +0 -16
  1086. package/mssql-core/columns/int.js +0 -27
  1087. package/mssql-core/columns/int.js.map +0 -1
  1088. package/mssql-core/columns/numeric.cjs +0 -146
  1089. package/mssql-core/columns/numeric.cjs.map +0 -1
  1090. package/mssql-core/columns/numeric.d.cts +0 -58
  1091. package/mssql-core/columns/numeric.d.ts +0 -58
  1092. package/mssql-core/columns/numeric.js +0 -116
  1093. package/mssql-core/columns/numeric.js.map +0 -1
  1094. package/mssql-core/columns/real.cjs +0 -53
  1095. package/mssql-core/columns/real.cjs.map +0 -1
  1096. package/mssql-core/columns/real.d.cts +0 -16
  1097. package/mssql-core/columns/real.d.ts +0 -16
  1098. package/mssql-core/columns/real.js +0 -27
  1099. package/mssql-core/columns/real.js.map +0 -1
  1100. package/mssql-core/columns/smallint.cjs +0 -62
  1101. package/mssql-core/columns/smallint.cjs.map +0 -1
  1102. package/mssql-core/columns/smallint.d.cts +0 -17
  1103. package/mssql-core/columns/smallint.d.ts +0 -17
  1104. package/mssql-core/columns/smallint.js +0 -36
  1105. package/mssql-core/columns/smallint.js.map +0 -1
  1106. package/mssql-core/columns/text.cjs +0 -68
  1107. package/mssql-core/columns/text.cjs.map +0 -1
  1108. package/mssql-core/columns/text.d.cts +0 -36
  1109. package/mssql-core/columns/text.d.ts +0 -36
  1110. package/mssql-core/columns/text.js +0 -41
  1111. package/mssql-core/columns/text.js.map +0 -1
  1112. package/mssql-core/columns/time.cjs +0 -90
  1113. package/mssql-core/columns/time.cjs.map +0 -1
  1114. package/mssql-core/columns/time.d.cts +0 -37
  1115. package/mssql-core/columns/time.d.ts +0 -37
  1116. package/mssql-core/columns/time.js +0 -62
  1117. package/mssql-core/columns/time.js.map +0 -1
  1118. package/mssql-core/columns/tinyint.cjs +0 -62
  1119. package/mssql-core/columns/tinyint.cjs.map +0 -1
  1120. package/mssql-core/columns/tinyint.d.cts +0 -17
  1121. package/mssql-core/columns/tinyint.d.ts +0 -17
  1122. package/mssql-core/columns/tinyint.js +0 -36
  1123. package/mssql-core/columns/tinyint.js.map +0 -1
  1124. package/mssql-core/columns/varbinary.cjs +0 -61
  1125. package/mssql-core/columns/varbinary.cjs.map +0 -1
  1126. package/mssql-core/columns/varbinary.d.cts +0 -23
  1127. package/mssql-core/columns/varbinary.d.ts +0 -23
  1128. package/mssql-core/columns/varbinary.js +0 -35
  1129. package/mssql-core/columns/varbinary.js.map +0 -1
  1130. package/mssql-core/columns/varchar.cjs +0 -117
  1131. package/mssql-core/columns/varchar.cjs.map +0 -1
  1132. package/mssql-core/columns/varchar.d.cts +0 -59
  1133. package/mssql-core/columns/varchar.d.ts +0 -59
  1134. package/mssql-core/columns/varchar.js +0 -88
  1135. package/mssql-core/columns/varchar.js.map +0 -1
  1136. package/mssql-core/db.cjs +0 -254
  1137. package/mssql-core/db.cjs.map +0 -1
  1138. package/mssql-core/db.d.cts +0 -228
  1139. package/mssql-core/db.d.ts +0 -228
  1140. package/mssql-core/db.js +0 -235
  1141. package/mssql-core/db.js.map +0 -1
  1142. package/mssql-core/dialect.cjs +0 -633
  1143. package/mssql-core/dialect.cjs.map +0 -1
  1144. package/mssql-core/dialect.d.cts +0 -58
  1145. package/mssql-core/dialect.d.ts +0 -58
  1146. package/mssql-core/dialect.js +0 -599
  1147. package/mssql-core/dialect.js.map +0 -1
  1148. package/mssql-core/expressions.cjs +0 -49
  1149. package/mssql-core/expressions.cjs.map +0 -1
  1150. package/mssql-core/expressions.d.cts +0 -8
  1151. package/mssql-core/expressions.d.ts +0 -8
  1152. package/mssql-core/expressions.js +0 -22
  1153. package/mssql-core/expressions.js.map +0 -1
  1154. package/mssql-core/foreign-keys.cjs +0 -91
  1155. package/mssql-core/foreign-keys.cjs.map +0 -1
  1156. package/mssql-core/foreign-keys.d.cts +0 -51
  1157. package/mssql-core/foreign-keys.d.ts +0 -51
  1158. package/mssql-core/foreign-keys.js +0 -65
  1159. package/mssql-core/foreign-keys.js.map +0 -1
  1160. package/mssql-core/index.cjs +0 -55
  1161. package/mssql-core/index.cjs.map +0 -1
  1162. package/mssql-core/index.d.cts +0 -17
  1163. package/mssql-core/index.d.ts +0 -17
  1164. package/mssql-core/index.js +0 -18
  1165. package/mssql-core/index.js.map +0 -1
  1166. package/mssql-core/indexes.cjs +0 -80
  1167. package/mssql-core/indexes.cjs.map +0 -1
  1168. package/mssql-core/indexes.d.cts +0 -49
  1169. package/mssql-core/indexes.d.ts +0 -49
  1170. package/mssql-core/indexes.js +0 -52
  1171. package/mssql-core/indexes.js.map +0 -1
  1172. package/mssql-core/primary-keys.cjs +0 -64
  1173. package/mssql-core/primary-keys.cjs.map +0 -1
  1174. package/mssql-core/primary-keys.d.cts +0 -23
  1175. package/mssql-core/primary-keys.d.ts +0 -23
  1176. package/mssql-core/primary-keys.js +0 -38
  1177. package/mssql-core/primary-keys.js.map +0 -1
  1178. package/mssql-core/query-builders/delete.cjs +0 -107
  1179. package/mssql-core/query-builders/delete.cjs.map +0 -1
  1180. package/mssql-core/query-builders/delete.d.cts +0 -98
  1181. package/mssql-core/query-builders/delete.d.ts +0 -98
  1182. package/mssql-core/query-builders/delete.js +0 -83
  1183. package/mssql-core/query-builders/delete.js.map +0 -1
  1184. package/mssql-core/query-builders/index.cjs +0 -33
  1185. package/mssql-core/query-builders/index.cjs.map +0 -1
  1186. package/mssql-core/query-builders/index.d.cts +0 -6
  1187. package/mssql-core/query-builders/index.d.ts +0 -6
  1188. package/mssql-core/query-builders/index.js +0 -7
  1189. package/mssql-core/query-builders/index.js.map +0 -1
  1190. package/mssql-core/query-builders/insert.cjs +0 -105
  1191. package/mssql-core/query-builders/insert.cjs.map +0 -1
  1192. package/mssql-core/query-builders/insert.d.cts +0 -79
  1193. package/mssql-core/query-builders/insert.d.ts +0 -79
  1194. package/mssql-core/query-builders/insert.js +0 -80
  1195. package/mssql-core/query-builders/insert.js.map +0 -1
  1196. package/mssql-core/query-builders/query-builder.cjs +0 -95
  1197. package/mssql-core/query-builders/query-builder.cjs.map +0 -1
  1198. package/mssql-core/query-builders/query-builder.d.cts +0 -32
  1199. package/mssql-core/query-builders/query-builder.d.ts +0 -32
  1200. package/mssql-core/query-builders/query-builder.js +0 -71
  1201. package/mssql-core/query-builders/query-builder.js.map +0 -1
  1202. package/mssql-core/query-builders/query.cjs +0 -126
  1203. package/mssql-core/query-builders/query.cjs.map +0 -1
  1204. package/mssql-core/query-builders/query.d.cts +0 -42
  1205. package/mssql-core/query-builders/query.d.ts +0 -42
  1206. package/mssql-core/query-builders/query.js +0 -103
  1207. package/mssql-core/query-builders/query.js.map +0 -1
  1208. package/mssql-core/query-builders/select.cjs +0 -679
  1209. package/mssql-core/query-builders/select.cjs.map +0 -1
  1210. package/mssql-core/query-builders/select.d.cts +0 -549
  1211. package/mssql-core/query-builders/select.d.ts +0 -549
  1212. package/mssql-core/query-builders/select.js +0 -649
  1213. package/mssql-core/query-builders/select.js.map +0 -1
  1214. package/mssql-core/query-builders/select.types.cjs +0 -17
  1215. package/mssql-core/query-builders/select.types.cjs.map +0 -1
  1216. package/mssql-core/query-builders/select.types.d.cts +0 -142
  1217. package/mssql-core/query-builders/select.types.d.ts +0 -142
  1218. package/mssql-core/query-builders/select.types.js +0 -1
  1219. package/mssql-core/query-builders/select.types.js.map +0 -1
  1220. package/mssql-core/query-builders/update.cjs +0 -138
  1221. package/mssql-core/query-builders/update.cjs.map +0 -1
  1222. package/mssql-core/query-builders/update.d.cts +0 -142
  1223. package/mssql-core/query-builders/update.d.ts +0 -142
  1224. package/mssql-core/query-builders/update.js +0 -113
  1225. package/mssql-core/query-builders/update.js.map +0 -1
  1226. package/mssql-core/schema.cjs +0 -51
  1227. package/mssql-core/schema.cjs.map +0 -1
  1228. package/mssql-core/schema.d.cts +0 -22
  1229. package/mssql-core/schema.d.ts +0 -22
  1230. package/mssql-core/schema.js +0 -25
  1231. package/mssql-core/schema.js.map +0 -1
  1232. package/mssql-core/session.cjs +0 -74
  1233. package/mssql-core/session.cjs.map +0 -1
  1234. package/mssql-core/session.d.cts +0 -63
  1235. package/mssql-core/session.d.ts +0 -63
  1236. package/mssql-core/session.js +0 -48
  1237. package/mssql-core/session.js.map +0 -1
  1238. package/mssql-core/subquery.cjs +0 -17
  1239. package/mssql-core/subquery.cjs.map +0 -1
  1240. package/mssql-core/subquery.d.cts +0 -18
  1241. package/mssql-core/subquery.d.ts +0 -18
  1242. package/mssql-core/subquery.js +0 -1
  1243. package/mssql-core/subquery.js.map +0 -1
  1244. package/mssql-core/table.cjs +0 -81
  1245. package/mssql-core/table.cjs.map +0 -1
  1246. package/mssql-core/table.d.cts +0 -40
  1247. package/mssql-core/table.d.ts +0 -40
  1248. package/mssql-core/table.js +0 -55
  1249. package/mssql-core/table.js.map +0 -1
  1250. package/mssql-core/unique-constraint.cjs +0 -76
  1251. package/mssql-core/unique-constraint.cjs.map +0 -1
  1252. package/mssql-core/unique-constraint.d.cts +0 -23
  1253. package/mssql-core/unique-constraint.d.ts +0 -23
  1254. package/mssql-core/unique-constraint.js +0 -49
  1255. package/mssql-core/unique-constraint.js.map +0 -1
  1256. package/mssql-core/utils.cjs +0 -85
  1257. package/mssql-core/utils.cjs.map +0 -1
  1258. package/mssql-core/utils.d.cts +0 -31
  1259. package/mssql-core/utils.d.ts +0 -31
  1260. package/mssql-core/utils.js +0 -60
  1261. package/mssql-core/utils.js.map +0 -1
  1262. package/mssql-core/view-base.cjs +0 -33
  1263. package/mssql-core/view-base.cjs.map +0 -1
  1264. package/mssql-core/view-base.d.cts +0 -9
  1265. package/mssql-core/view-base.d.ts +0 -9
  1266. package/mssql-core/view-base.js +0 -9
  1267. package/mssql-core/view-base.js.map +0 -1
  1268. package/mssql-core/view-common.cjs +0 -29
  1269. package/mssql-core/view-common.cjs.map +0 -1
  1270. package/mssql-core/view-common.d.cts +0 -1
  1271. package/mssql-core/view-common.d.ts +0 -1
  1272. package/mssql-core/view-common.js +0 -5
  1273. package/mssql-core/view-common.js.map +0 -1
  1274. package/mssql-core/view.cjs +0 -154
  1275. package/mssql-core/view.cjs.map +0 -1
  1276. package/mssql-core/view.d.cts +0 -63
  1277. package/mssql-core/view.d.ts +0 -63
  1278. package/mssql-core/view.js +0 -125
  1279. package/mssql-core/view.js.map +0 -1
  1280. package/node-mssql/driver.cjs +0 -117
  1281. package/node-mssql/driver.cjs.map +0 -1
  1282. package/node-mssql/driver.d.cts +0 -46
  1283. package/node-mssql/driver.d.ts +0 -46
  1284. package/node-mssql/driver.js +0 -81
  1285. package/node-mssql/driver.js.map +0 -1
  1286. package/node-mssql/index.cjs +0 -25
  1287. package/node-mssql/index.cjs.map +0 -1
  1288. package/node-mssql/index.d.cts +0 -2
  1289. package/node-mssql/index.d.ts +0 -2
  1290. package/node-mssql/index.js +0 -3
  1291. package/node-mssql/index.js.map +0 -1
  1292. package/node-mssql/migrator.cjs +0 -33
  1293. package/node-mssql/migrator.cjs.map +0 -1
  1294. package/node-mssql/migrator.d.cts +0 -3
  1295. package/node-mssql/migrator.d.ts +0 -3
  1296. package/node-mssql/migrator.js +0 -9
  1297. package/node-mssql/migrator.js.map +0 -1
  1298. package/node-mssql/pool.cjs +0 -54
  1299. package/node-mssql/pool.cjs.map +0 -1
  1300. package/node-mssql/pool.d.cts +0 -8
  1301. package/node-mssql/pool.d.ts +0 -8
  1302. package/node-mssql/pool.js +0 -20
  1303. package/node-mssql/pool.js.map +0 -1
  1304. package/node-mssql/session.cjs +0 -256
  1305. package/node-mssql/session.cjs.map +0 -1
  1306. package/node-mssql/session.d.cts +0 -48
  1307. package/node-mssql/session.d.ts +0 -48
  1308. package/node-mssql/session.js +0 -224
  1309. package/node-mssql/session.js.map +0 -1
@@ -11,15 +11,14 @@ class PgColumnBuilder extends ColumnBuilder {
11
11
  array(length) {
12
12
  return new PgArrayBuilder(this.config.name, this, length);
13
13
  }
14
- references(ref, config = {}) {
15
- this.foreignKeyConfigs.push({ ref, config });
14
+ references(ref, actions = {}) {
15
+ this.foreignKeyConfigs.push({ ref, actions });
16
16
  return this;
17
17
  }
18
18
  unique(name, config) {
19
19
  this.config.isUnique = true;
20
20
  this.config.uniqueName = name;
21
21
  this.config.uniqueType = config?.nulls;
22
- this.config.uniqueNameExplicit = name ? true : false;
23
22
  return this;
24
23
  }
25
24
  generatedAlwaysAs(as) {
@@ -32,23 +31,23 @@ class PgColumnBuilder extends ColumnBuilder {
32
31
  }
33
32
  /** @internal */
34
33
  buildForeignKeys(column, table) {
35
- return this.foreignKeyConfigs.map(({ ref, config }) => {
34
+ return this.foreignKeyConfigs.map(({ ref, actions }) => {
36
35
  return iife(
37
- (ref2, config2) => {
36
+ (ref2, actions2) => {
38
37
  const builder = new ForeignKeyBuilder(() => {
39
38
  const foreignColumn = ref2();
40
- return { name: config2.name, columns: [column], foreignColumns: [foreignColumn] };
39
+ return { columns: [column], foreignColumns: [foreignColumn] };
41
40
  });
42
- if (config2.onUpdate) {
43
- builder.onUpdate(config2.onUpdate);
41
+ if (actions2.onUpdate) {
42
+ builder.onUpdate(actions2.onUpdate);
44
43
  }
45
- if (config2.onDelete) {
46
- builder.onDelete(config2.onDelete);
44
+ if (actions2.onDelete) {
45
+ builder.onDelete(actions2.onDelete);
47
46
  }
48
47
  return builder.build(table);
49
48
  },
50
49
  ref,
51
- config
50
+ actions
52
51
  );
53
52
  });
54
53
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/pg-core/columns/common.ts"],"sourcesContent":["import type {\n\tColumnBuilderBaseConfig,\n\tColumnBuilderExtraConfig,\n\tColumnBuilderRuntimeConfig,\n\tColumnType,\n\tHasGenerated,\n} from '~/column-builder.ts';\nimport { ColumnBuilder } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { Column } from '~/column.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport type { ForeignKey, UpdateDeleteAction } from '~/pg-core/foreign-keys.ts';\nimport { ForeignKeyBuilder } from '~/pg-core/foreign-keys.ts';\nimport type { AnyPgTable, PgTable } from '~/pg-core/table.ts';\nimport type { SQL } from '~/sql/sql.ts';\nimport { iife } from '~/tracing-utils.ts';\nimport type { Update } from '~/utils.ts';\nimport type { PgIndexOpClass } from '../indexes.ts';\nimport { uniqueKeyName } from '../unique-constraint.ts';\nimport { makePgArray, parsePgArray } from '../utils/array.ts';\n\nexport type PgColumns = Record<string, PgColumn<any>>;\n\nexport interface ReferenceConfig {\n\tref: () => PgColumn;\n\tconfig: {\n\t\tname?: string;\n\t\tonUpdate?: UpdateDeleteAction;\n\t\tonDelete?: UpdateDeleteAction;\n\t};\n}\n\nexport abstract class PgColumnBuilder<\n\tT extends ColumnBuilderBaseConfig<ColumnType> = ColumnBuilderBaseConfig<ColumnType>,\n\tTRuntimeConfig extends object = object,\n> extends ColumnBuilder<T, TRuntimeConfig, ColumnBuilderExtraConfig> {\n\tprivate foreignKeyConfigs: ReferenceConfig[] = [];\n\n\tstatic override readonly [entityKind]: string = 'PgColumnBuilder';\n\n\tarray(length?: number): PgArrayBuilder<\n\t\t& {\n\t\t\tname: string;\n\t\t\tdataType: 'array basecolumn';\n\t\t\tdata: T['data'][];\n\t\t\tdriverParam: T['driverParam'][] | string;\n\t\t\tbaseBuilder: T;\n\t\t}\n\t\t& (T extends { notNull: true } ? { notNull: true } : {})\n\t\t& (T extends { hasDefault: true } ? { hasDefault: true } : {}),\n\t\tT\n\t> {\n\t\treturn new PgArrayBuilder(this.config.name, this as PgColumnBuilder<any, any>, length as any);\n\t}\n\n\treferences(\n\t\tref: ReferenceConfig['ref'],\n\t\tconfig: ReferenceConfig['config'] = {},\n\t): this {\n\t\tthis.foreignKeyConfigs.push({ ref, config });\n\t\treturn this;\n\t}\n\n\tunique(\n\t\tname?: string,\n\t\tconfig?: { nulls: 'distinct' | 'not distinct' },\n\t): this {\n\t\tthis.config.isUnique = true;\n\t\tthis.config.uniqueName = name;\n\t\tthis.config.uniqueType = config?.nulls;\n\t\tthis.config.uniqueNameExplicit = name ? true : false;\n\t\treturn this;\n\t}\n\n\tgeneratedAlwaysAs(as: SQL | T['data'] | (() => SQL)): HasGenerated<this, {\n\t\ttype: 'always';\n\t}> {\n\t\tthis.config.generated = {\n\t\t\tas,\n\t\t\ttype: 'always',\n\t\t\tmode: 'stored',\n\t\t};\n\t\treturn this as HasGenerated<this, {\n\t\t\ttype: 'always';\n\t\t}>;\n\t}\n\n\t/** @internal */\n\tbuildForeignKeys(column: PgColumn, table: PgTable): ForeignKey[] {\n\t\treturn this.foreignKeyConfigs.map(({ ref, config }) => {\n\t\t\treturn iife(\n\t\t\t\t(ref, config) => {\n\t\t\t\t\tconst builder = new ForeignKeyBuilder(() => {\n\t\t\t\t\t\tconst foreignColumn = ref();\n\t\t\t\t\t\treturn { name: config.name, columns: [column], foreignColumns: [foreignColumn] };\n\t\t\t\t\t});\n\t\t\t\t\tif (config.onUpdate) {\n\t\t\t\t\t\tbuilder.onUpdate(config.onUpdate);\n\t\t\t\t\t}\n\t\t\t\t\tif (config.onDelete) {\n\t\t\t\t\t\tbuilder.onDelete(config.onDelete);\n\t\t\t\t\t}\n\t\t\t\t\treturn builder.build(table);\n\t\t\t\t},\n\t\t\t\tref,\n\t\t\t\tconfig,\n\t\t\t);\n\t\t});\n\t}\n\n\t/** @internal */\n\tabstract build(table: PgTable): PgColumn<any>;\n\n\t/** @internal */\n\tbuildExtraConfigColumn<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): ExtraConfigColumn {\n\t\treturn new ExtraConfigColumn(table, this.config);\n\t}\n}\n\n// To understand how to use `PgColumn` and `PgColumn`, see `Column` and `AnyColumn` documentation.\nexport abstract class PgColumn<\n\tT extends ColumnBaseConfig<ColumnType> = ColumnBaseConfig<ColumnType>,\n\tTRuntimeConfig extends object = {},\n> extends Column<T, TRuntimeConfig> {\n\tstatic override readonly [entityKind]: string = 'PgColumn';\n\n\t/** @internal */\n\toverride readonly table: PgTable;\n\n\tconstructor(\n\t\ttable: PgTable,\n\t\tconfig: ColumnBuilderRuntimeConfig<T['data']> & TRuntimeConfig,\n\t) {\n\t\tif (!config.uniqueName) {\n\t\t\tconfig.uniqueName = uniqueKeyName(table, [config.name]);\n\t\t}\n\t\tsuper(table, config);\n\t\tthis.table = table;\n\t}\n}\n\nexport type IndexedExtraConfigType = { order?: 'asc' | 'desc'; nulls?: 'first' | 'last'; opClass?: string };\n\nexport class ExtraConfigColumn<\n\tT extends ColumnBaseConfig<ColumnType> = ColumnBaseConfig<ColumnType>,\n> extends PgColumn<T, IndexedExtraConfigType> {\n\tstatic override readonly [entityKind]: string = 'ExtraConfigColumn';\n\n\toverride getSQLType(): string {\n\t\treturn this.getSQLType();\n\t}\n\n\tindexConfig: IndexedExtraConfigType = {\n\t\torder: this.config.order ?? 'asc',\n\t\tnulls: this.config.nulls ?? 'last',\n\t\topClass: this.config.opClass,\n\t};\n\tdefaultConfig: IndexedExtraConfigType = {\n\t\torder: 'asc',\n\t\tnulls: 'last',\n\t\topClass: undefined,\n\t};\n\n\tasc(): Omit<this, 'asc' | 'desc'> {\n\t\tthis.indexConfig.order = 'asc';\n\t\treturn this;\n\t}\n\n\tdesc(): Omit<this, 'asc' | 'desc'> {\n\t\tthis.indexConfig.order = 'desc';\n\t\treturn this;\n\t}\n\n\tnullsFirst(): Omit<this, 'nullsFirst' | 'nullsLast'> {\n\t\tthis.indexConfig.nulls = 'first';\n\t\treturn this;\n\t}\n\n\tnullsLast(): Omit<this, 'nullsFirst' | 'nullsLast'> {\n\t\tthis.indexConfig.nulls = 'last';\n\t\treturn this;\n\t}\n\n\t/**\n\t * ### PostgreSQL documentation quote\n\t *\n\t * > An operator class with optional parameters can be specified for each column of an index.\n\t * The operator class identifies the operators to be used by the index for that column.\n\t * For example, a B-tree index on four-byte integers would use the int4_ops class;\n\t * this operator class includes comparison functions for four-byte integers.\n\t * In practice the default operator class for the column's data type is usually sufficient.\n\t * The main point of having operator classes is that for some data types, there could be more than one meaningful ordering.\n\t * For example, we might want to sort a complex-number data type either by absolute value or by real part.\n\t * We could do this by defining two operator classes for the data type and then selecting the proper class when creating an index.\n\t * More information about operator classes check:\n\t *\n\t * ### Useful links\n\t * https://www.postgresql.org/docs/current/sql-createindex.html\n\t *\n\t * https://www.postgresql.org/docs/current/indexes-opclass.html\n\t *\n\t * https://www.postgresql.org/docs/current/xindex.html\n\t *\n\t * ### Additional types\n\t * If you have the `pg_vector` extension installed in your database, you can use the\n\t * `vector_l2_ops`, `vector_ip_ops`, `vector_cosine_ops`, `vector_l1_ops`, `bit_hamming_ops`, `bit_jaccard_ops`, `halfvec_l2_ops`, `sparsevec_l2_ops` options, which are predefined types.\n\t *\n\t * **You can always specify any string you want in the operator class, in case Drizzle doesn't have it natively in its types**\n\t *\n\t * @param opClass\n\t * @returns\n\t */\n\top(opClass: PgIndexOpClass): Omit<this, 'op'> {\n\t\tthis.indexConfig.opClass = opClass;\n\t\treturn this;\n\t}\n}\n\nexport class IndexedColumn {\n\tstatic readonly [entityKind]: string = 'IndexedColumn';\n\tconstructor(\n\t\tname: string | undefined,\n\t\tkeyAsName: boolean,\n\t\ttype: string,\n\t\tindexConfig: IndexedExtraConfigType,\n\t) {\n\t\tthis.name = name;\n\t\tthis.keyAsName = keyAsName;\n\t\tthis.type = type;\n\t\tthis.indexConfig = indexConfig;\n\t}\n\n\tname: string | undefined;\n\tkeyAsName: boolean;\n\ttype: string;\n\tindexConfig: IndexedExtraConfigType;\n}\n\nexport type AnyPgColumn<TPartial extends Partial<ColumnBaseConfig<ColumnType>> = {}> = PgColumn<\n\tRequired<Update<ColumnBaseConfig<ColumnType>, TPartial>>\n>;\n\nexport type PgArrayColumnBuilderBaseConfig = ColumnBuilderBaseConfig<'array basecolumn'> & {\n\tbaseBuilder: ColumnBuilderBaseConfig<ColumnType>;\n};\n\nexport class PgArrayBuilder<\n\tT extends PgArrayColumnBuilderBaseConfig,\n\tTBase extends ColumnBuilderBaseConfig<ColumnType> | PgArrayColumnBuilderBaseConfig,\n> extends PgColumnBuilder<\n\tT & {\n\t\tbaseBuilder: TBase extends PgArrayColumnBuilderBaseConfig ? PgArrayBuilder<\n\t\t\t\tTBase,\n\t\t\t\tTBase extends { baseBuilder: infer TBaseBuilder extends ColumnBuilderBaseConfig<any> } ? TBaseBuilder\n\t\t\t\t\t: never\n\t\t\t>\n\t\t\t: PgColumnBuilder<TBase, {}>;\n\t},\n\t{\n\t\tbaseBuilder: TBase extends PgArrayColumnBuilderBaseConfig ? PgArrayBuilder<\n\t\t\t\tTBase,\n\t\t\t\tTBase extends { baseBuilder: infer TBaseBuilder extends ColumnBuilderBaseConfig<any> } ? TBaseBuilder\n\t\t\t\t\t: never\n\t\t\t>\n\t\t\t: PgColumnBuilder<TBase, {}>;\n\t\tlength: number | undefined;\n\t}\n> {\n\tstatic override readonly [entityKind] = 'PgArrayBuilder';\n\n\tconstructor(\n\t\tname: string,\n\t\tbaseBuilder: PgArrayBuilder<T, TBase>['config']['baseBuilder'],\n\t\tlength: number | undefined,\n\t) {\n\t\tsuper(name, 'array basecolumn', 'PgArray');\n\t\tthis.config.baseBuilder = baseBuilder;\n\t\tthis.config.length = length;\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable) {\n\t\tconst baseColumn: any = this.config.baseBuilder.build(table);\n\t\treturn new PgArray(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t\tbaseColumn,\n\t\t);\n\t}\n}\n\nexport class PgArray<\n\tT extends ColumnBaseConfig<'array basecolumn'> & {\n\t\tlength: number | undefined;\n\t\tbaseBuilder: ColumnBuilderBaseConfig<ColumnType>;\n\t},\n\tTBase extends ColumnBuilderBaseConfig<ColumnType>,\n> extends PgColumn<T, {}> {\n\tstatic override readonly [entityKind]: string = 'PgArray';\n\n\tconstructor(\n\t\ttable: AnyPgTable<{ name: T['tableName'] }>,\n\t\tconfig: PgArrayBuilder<T, TBase>['config'],\n\t\treadonly baseColumn: PgColumn,\n\t\treadonly range?: [number | undefined, number | undefined],\n\t) {\n\t\tsuper(table, config);\n\t}\n\n\tgetSQLType(): string {\n\t\treturn `${this.baseColumn.getSQLType()}[${typeof this.length === 'number' ? this.length : ''}]`;\n\t}\n\n\toverride mapFromDriverValue(value: unknown[] | string): T['data'] {\n\t\tif (typeof value === 'string') {\n\t\t\t// Thank you node-postgres for not parsing enum arrays\n\t\t\tvalue = parsePgArray(value);\n\t\t}\n\t\treturn value.map((v) => this.baseColumn.mapFromDriverValue(v));\n\t}\n\n\t// Needed for arrays of custom types\n\tmapFromJsonValue(value: unknown[] | string): T['data'] {\n\t\tif (typeof value === 'string') {\n\t\t\t// Thank you node-postgres for not parsing enum arrays\n\t\t\tvalue = parsePgArray(value);\n\t\t}\n\n\t\tconst base = this.baseColumn;\n\n\t\treturn 'mapFromJsonValue' in base\n\t\t\t? value.map((v) => (<(value: unknown) => unknown> base.mapFromJsonValue)(v))\n\t\t\t: value.map((v) => base.mapFromDriverValue(v));\n\t}\n\n\toverride mapToDriverValue(value: unknown[], isNestedArray = false): unknown[] | string {\n\t\tconst a = value.map((v) =>\n\t\t\tv === null\n\t\t\t\t? null\n\t\t\t\t: is(this.baseColumn, PgArray)\n\t\t\t\t? this.baseColumn.mapToDriverValue(v as unknown[], true)\n\t\t\t\t: this.baseColumn.mapToDriverValue(v)\n\t\t);\n\t\tif (isNestedArray) return a;\n\t\treturn makePgArray(a);\n\t}\n}\n"],"mappings":"AAOA,SAAS,qBAAqB;AAE9B,SAAS,cAAc;AACvB,SAAS,YAAY,UAAU;AAE/B,SAAS,yBAAyB;AAGlC,SAAS,YAAY;AAGrB,SAAS,qBAAqB;AAC9B,SAAS,aAAa,oBAAoB;AAanC,MAAe,wBAGZ,cAA2D;AAAA,EAC5D,oBAAuC,CAAC;AAAA,EAEhD,QAA0B,UAAU,IAAY;AAAA,EAEhD,MAAM,QAWJ;AACD,WAAO,IAAI,eAAe,KAAK,OAAO,MAAM,MAAmC,MAAa;AAAA,EAC7F;AAAA,EAEA,WACC,KACA,SAAoC,CAAC,GAC9B;AACP,SAAK,kBAAkB,KAAK,EAAE,KAAK,OAAO,CAAC;AAC3C,WAAO;AAAA,EACR;AAAA,EAEA,OACC,MACA,QACO;AACP,SAAK,OAAO,WAAW;AACvB,SAAK,OAAO,aAAa;AACzB,SAAK,OAAO,aAAa,QAAQ;AACjC,SAAK,OAAO,qBAAqB,OAAO,OAAO;AAC/C,WAAO;AAAA,EACR;AAAA,EAEA,kBAAkB,IAEf;AACF,SAAK,OAAO,YAAY;AAAA,MACvB;AAAA,MACA,MAAM;AAAA,MACN,MAAM;AAAA,IACP;AACA,WAAO;AAAA,EAGR;AAAA;AAAA,EAGA,iBAAiB,QAAkB,OAA8B;AAChE,WAAO,KAAK,kBAAkB,IAAI,CAAC,EAAE,KAAK,OAAO,MAAM;AACtD,aAAO;AAAA,QACN,CAACA,MAAKC,YAAW;AAChB,gBAAM,UAAU,IAAI,kBAAkB,MAAM;AAC3C,kBAAM,gBAAgBD,KAAI;AAC1B,mBAAO,EAAE,MAAMC,QAAO,MAAM,SAAS,CAAC,MAAM,GAAG,gBAAgB,CAAC,aAAa,EAAE;AAAA,UAChF,CAAC;AACD,cAAIA,QAAO,UAAU;AACpB,oBAAQ,SAASA,QAAO,QAAQ;AAAA,UACjC;AACA,cAAIA,QAAO,UAAU;AACpB,oBAAQ,SAASA,QAAO,QAAQ;AAAA,UACjC;AACA,iBAAO,QAAQ,MAAM,KAAK;AAAA,QAC3B;AAAA,QACA;AAAA,QACA;AAAA,MACD;AAAA,IACD,CAAC;AAAA,EACF;AAAA;AAAA,EAMA,uBACC,OACoB;AACpB,WAAO,IAAI,kBAAkB,OAAO,KAAK,MAAM;AAAA,EAChD;AACD;AAGO,MAAe,iBAGZ,OAA0B;AAAA,EACnC,QAA0B,UAAU,IAAY;AAAA;AAAA,EAG9B;AAAA,EAElB,YACC,OACA,QACC;AACD,QAAI,CAAC,OAAO,YAAY;AACvB,aAAO,aAAa,cAAc,OAAO,CAAC,OAAO,IAAI,CAAC;AAAA,IACvD;AACA,UAAM,OAAO,MAAM;AACnB,SAAK,QAAQ;AAAA,EACd;AACD;AAIO,MAAM,0BAEH,SAAoC;AAAA,EAC7C,QAA0B,UAAU,IAAY;AAAA,EAEvC,aAAqB;AAC7B,WAAO,KAAK,WAAW;AAAA,EACxB;AAAA,EAEA,cAAsC;AAAA,IACrC,OAAO,KAAK,OAAO,SAAS;AAAA,IAC5B,OAAO,KAAK,OAAO,SAAS;AAAA,IAC5B,SAAS,KAAK,OAAO;AAAA,EACtB;AAAA,EACA,gBAAwC;AAAA,IACvC,OAAO;AAAA,IACP,OAAO;AAAA,IACP,SAAS;AAAA,EACV;AAAA,EAEA,MAAkC;AACjC,SAAK,YAAY,QAAQ;AACzB,WAAO;AAAA,EACR;AAAA,EAEA,OAAmC;AAClC,SAAK,YAAY,QAAQ;AACzB,WAAO;AAAA,EACR;AAAA,EAEA,aAAqD;AACpD,SAAK,YAAY,QAAQ;AACzB,WAAO;AAAA,EACR;AAAA,EAEA,YAAoD;AACnD,SAAK,YAAY,QAAQ;AACzB,WAAO;AAAA,EACR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EA+BA,GAAG,SAA2C;AAC7C,SAAK,YAAY,UAAU;AAC3B,WAAO;AAAA,EACR;AACD;AAEO,MAAM,cAAc;AAAA,EAC1B,QAAiB,UAAU,IAAY;AAAA,EACvC,YACC,MACA,WACA,MACA,aACC;AACD,SAAK,OAAO;AACZ,SAAK,YAAY;AACjB,SAAK,OAAO;AACZ,SAAK,cAAc;AAAA,EACpB;AAAA,EAEA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACD;AAUO,MAAM,uBAGH,gBAkBR;AAAA,EACD,QAA0B,UAAU,IAAI;AAAA,EAExC,YACC,MACA,aACA,QACC;AACD,UAAM,MAAM,oBAAoB,SAAS;AACzC,SAAK,OAAO,cAAc;AAC1B,SAAK,OAAO,SAAS;AAAA,EACtB;AAAA;AAAA,EAGS,MAAM,OAAgB;AAC9B,UAAM,aAAkB,KAAK,OAAO,YAAY,MAAM,KAAK;AAC3D,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,MACL;AAAA,IACD;AAAA,EACD;AACD;AAEO,MAAM,gBAMH,SAAgB;AAAA,EAGzB,YACC,OACA,QACS,YACA,OACR;AACD,UAAM,OAAO,MAAM;AAHV;AACA;AAAA,EAGV;AAAA,EATA,QAA0B,UAAU,IAAY;AAAA,EAWhD,aAAqB;AACpB,WAAO,GAAG,KAAK,WAAW,WAAW,CAAC,IAAI,OAAO,KAAK,WAAW,WAAW,KAAK,SAAS,EAAE;AAAA,EAC7F;AAAA,EAES,mBAAmB,OAAsC;AACjE,QAAI,OAAO,UAAU,UAAU;AAE9B,cAAQ,aAAa,KAAK;AAAA,IAC3B;AACA,WAAO,MAAM,IAAI,CAAC,MAAM,KAAK,WAAW,mBAAmB,CAAC,CAAC;AAAA,EAC9D;AAAA;AAAA,EAGA,iBAAiB,OAAsC;AACtD,QAAI,OAAO,UAAU,UAAU;AAE9B,cAAQ,aAAa,KAAK;AAAA,IAC3B;AAEA,UAAM,OAAO,KAAK;AAElB,WAAO,sBAAsB,OAC1B,MAAM,IAAI,CAAC,MAAqC,KAAK,iBAAkB,CAAC,CAAC,IACzE,MAAM,IAAI,CAAC,MAAM,KAAK,mBAAmB,CAAC,CAAC;AAAA,EAC/C;AAAA,EAES,iBAAiB,OAAkB,gBAAgB,OAA2B;AACtF,UAAM,IAAI,MAAM;AAAA,MAAI,CAAC,MACpB,MAAM,OACH,OACA,GAAG,KAAK,YAAY,OAAO,IAC3B,KAAK,WAAW,iBAAiB,GAAgB,IAAI,IACrD,KAAK,WAAW,iBAAiB,CAAC;AAAA,IACtC;AACA,QAAI,cAAe,QAAO;AAC1B,WAAO,YAAY,CAAC;AAAA,EACrB;AACD;","names":["ref","config"]}
1
+ {"version":3,"sources":["../../../src/pg-core/columns/common.ts"],"sourcesContent":["import type {\n\tColumnBuilderBaseConfig,\n\tColumnBuilderExtraConfig,\n\tColumnBuilderRuntimeConfig,\n\tColumnType,\n\tHasGenerated,\n} from '~/column-builder.ts';\nimport { ColumnBuilder } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { Column } from '~/column.ts';\nimport { entityKind, is } from '~/entity.ts';\nimport type { ForeignKey, UpdateDeleteAction } from '~/pg-core/foreign-keys.ts';\nimport { ForeignKeyBuilder } from '~/pg-core/foreign-keys.ts';\nimport type { AnyPgTable, PgTable } from '~/pg-core/table.ts';\nimport type { SQL } from '~/sql/sql.ts';\nimport { iife } from '~/tracing-utils.ts';\nimport type { Update } from '~/utils.ts';\nimport type { PgIndexOpClass } from '../indexes.ts';\nimport { uniqueKeyName } from '../unique-constraint.ts';\nimport { makePgArray, parsePgArray } from '../utils/array.ts';\n\nexport type PgColumns = Record<string, PgColumn<any>>;\n\nexport interface ReferenceConfig {\n\tref: () => PgColumn;\n\tactions: {\n\t\tonUpdate?: UpdateDeleteAction;\n\t\tonDelete?: UpdateDeleteAction;\n\t};\n}\n\nexport abstract class PgColumnBuilder<\n\tT extends ColumnBuilderBaseConfig<ColumnType> = ColumnBuilderBaseConfig<ColumnType>,\n\tTRuntimeConfig extends object = object,\n> extends ColumnBuilder<T, TRuntimeConfig, ColumnBuilderExtraConfig> {\n\tprivate foreignKeyConfigs: ReferenceConfig[] = [];\n\n\tstatic override readonly [entityKind]: string = 'PgColumnBuilder';\n\n\tarray(length?: number): PgArrayBuilder<\n\t\t& {\n\t\t\tname: string;\n\t\t\tdataType: 'array basecolumn';\n\t\t\tdata: T['data'][];\n\t\t\tdriverParam: T['driverParam'][] | string;\n\t\t\tbaseBuilder: T;\n\t\t}\n\t\t& (T extends { notNull: true } ? { notNull: true } : {})\n\t\t& (T extends { hasDefault: true } ? { hasDefault: true } : {}),\n\t\tT\n\t> {\n\t\treturn new PgArrayBuilder(this.config.name, this as PgColumnBuilder<any, any>, length as any);\n\t}\n\n\treferences(\n\t\tref: ReferenceConfig['ref'],\n\t\tactions: ReferenceConfig['actions'] = {},\n\t): this {\n\t\tthis.foreignKeyConfigs.push({ ref, actions });\n\t\treturn this;\n\t}\n\n\tunique(\n\t\tname?: string,\n\t\tconfig?: { nulls: 'distinct' | 'not distinct' },\n\t): this {\n\t\tthis.config.isUnique = true;\n\t\tthis.config.uniqueName = name;\n\t\tthis.config.uniqueType = config?.nulls;\n\t\treturn this;\n\t}\n\n\tgeneratedAlwaysAs(as: SQL | T['data'] | (() => SQL)): HasGenerated<this, {\n\t\ttype: 'always';\n\t}> {\n\t\tthis.config.generated = {\n\t\t\tas,\n\t\t\ttype: 'always',\n\t\t\tmode: 'stored',\n\t\t};\n\t\treturn this as HasGenerated<this, {\n\t\t\ttype: 'always';\n\t\t}>;\n\t}\n\n\t/** @internal */\n\tbuildForeignKeys(column: PgColumn, table: PgTable): ForeignKey[] {\n\t\treturn this.foreignKeyConfigs.map(({ ref, actions }) => {\n\t\t\treturn iife(\n\t\t\t\t(ref, actions) => {\n\t\t\t\t\tconst builder = new ForeignKeyBuilder(() => {\n\t\t\t\t\t\tconst foreignColumn = ref();\n\t\t\t\t\t\treturn { columns: [column], foreignColumns: [foreignColumn] };\n\t\t\t\t\t});\n\t\t\t\t\tif (actions.onUpdate) {\n\t\t\t\t\t\tbuilder.onUpdate(actions.onUpdate);\n\t\t\t\t\t}\n\t\t\t\t\tif (actions.onDelete) {\n\t\t\t\t\t\tbuilder.onDelete(actions.onDelete);\n\t\t\t\t\t}\n\t\t\t\t\treturn builder.build(table);\n\t\t\t\t},\n\t\t\t\tref,\n\t\t\t\tactions,\n\t\t\t);\n\t\t});\n\t}\n\n\t/** @internal */\n\tabstract build(table: PgTable): PgColumn<any>;\n\n\t/** @internal */\n\tbuildExtraConfigColumn<TTableName extends string>(\n\t\ttable: AnyPgTable<{ name: TTableName }>,\n\t): ExtraConfigColumn {\n\t\treturn new ExtraConfigColumn(table, this.config);\n\t}\n}\n\n// To understand how to use `PgColumn` and `PgColumn`, see `Column` and `AnyColumn` documentation.\nexport abstract class PgColumn<\n\tT extends ColumnBaseConfig<ColumnType> = ColumnBaseConfig<ColumnType>,\n\tTRuntimeConfig extends object = {},\n> extends Column<T, TRuntimeConfig> {\n\tstatic override readonly [entityKind]: string = 'PgColumn';\n\n\t/** @internal */\n\toverride readonly table: PgTable;\n\n\tconstructor(\n\t\ttable: PgTable,\n\t\tconfig: ColumnBuilderRuntimeConfig<T['data']> & TRuntimeConfig,\n\t) {\n\t\tif (!config.uniqueName) {\n\t\t\tconfig.uniqueName = uniqueKeyName(table, [config.name]);\n\t\t}\n\t\tsuper(table, config);\n\t\tthis.table = table;\n\t}\n}\n\nexport type IndexedExtraConfigType = { order?: 'asc' | 'desc'; nulls?: 'first' | 'last'; opClass?: string };\n\nexport class ExtraConfigColumn<\n\tT extends ColumnBaseConfig<ColumnType> = ColumnBaseConfig<ColumnType>,\n> extends PgColumn<T, IndexedExtraConfigType> {\n\tstatic override readonly [entityKind]: string = 'ExtraConfigColumn';\n\n\toverride getSQLType(): string {\n\t\treturn this.getSQLType();\n\t}\n\n\tindexConfig: IndexedExtraConfigType = {\n\t\torder: this.config.order ?? 'asc',\n\t\tnulls: this.config.nulls ?? 'last',\n\t\topClass: this.config.opClass,\n\t};\n\tdefaultConfig: IndexedExtraConfigType = {\n\t\torder: 'asc',\n\t\tnulls: 'last',\n\t\topClass: undefined,\n\t};\n\n\tasc(): Omit<this, 'asc' | 'desc'> {\n\t\tthis.indexConfig.order = 'asc';\n\t\treturn this;\n\t}\n\n\tdesc(): Omit<this, 'asc' | 'desc'> {\n\t\tthis.indexConfig.order = 'desc';\n\t\treturn this;\n\t}\n\n\tnullsFirst(): Omit<this, 'nullsFirst' | 'nullsLast'> {\n\t\tthis.indexConfig.nulls = 'first';\n\t\treturn this;\n\t}\n\n\tnullsLast(): Omit<this, 'nullsFirst' | 'nullsLast'> {\n\t\tthis.indexConfig.nulls = 'last';\n\t\treturn this;\n\t}\n\n\t/**\n\t * ### PostgreSQL documentation quote\n\t *\n\t * > An operator class with optional parameters can be specified for each column of an index.\n\t * The operator class identifies the operators to be used by the index for that column.\n\t * For example, a B-tree index on four-byte integers would use the int4_ops class;\n\t * this operator class includes comparison functions for four-byte integers.\n\t * In practice the default operator class for the column's data type is usually sufficient.\n\t * The main point of having operator classes is that for some data types, there could be more than one meaningful ordering.\n\t * For example, we might want to sort a complex-number data type either by absolute value or by real part.\n\t * We could do this by defining two operator classes for the data type and then selecting the proper class when creating an index.\n\t * More information about operator classes check:\n\t *\n\t * ### Useful links\n\t * https://www.postgresql.org/docs/current/sql-createindex.html\n\t *\n\t * https://www.postgresql.org/docs/current/indexes-opclass.html\n\t *\n\t * https://www.postgresql.org/docs/current/xindex.html\n\t *\n\t * ### Additional types\n\t * If you have the `pg_vector` extension installed in your database, you can use the\n\t * `vector_l2_ops`, `vector_ip_ops`, `vector_cosine_ops`, `vector_l1_ops`, `bit_hamming_ops`, `bit_jaccard_ops`, `halfvec_l2_ops`, `sparsevec_l2_ops` options, which are predefined types.\n\t *\n\t * **You can always specify any string you want in the operator class, in case Drizzle doesn't have it natively in its types**\n\t *\n\t * @param opClass\n\t * @returns\n\t */\n\top(opClass: PgIndexOpClass): Omit<this, 'op'> {\n\t\tthis.indexConfig.opClass = opClass;\n\t\treturn this;\n\t}\n}\n\nexport class IndexedColumn {\n\tstatic readonly [entityKind]: string = 'IndexedColumn';\n\tconstructor(\n\t\tname: string | undefined,\n\t\tkeyAsName: boolean,\n\t\ttype: string,\n\t\tindexConfig: IndexedExtraConfigType,\n\t) {\n\t\tthis.name = name;\n\t\tthis.keyAsName = keyAsName;\n\t\tthis.type = type;\n\t\tthis.indexConfig = indexConfig;\n\t}\n\n\tname: string | undefined;\n\tkeyAsName: boolean;\n\ttype: string;\n\tindexConfig: IndexedExtraConfigType;\n}\n\nexport type AnyPgColumn<TPartial extends Partial<ColumnBaseConfig<ColumnType>> = {}> = PgColumn<\n\tRequired<Update<ColumnBaseConfig<ColumnType>, TPartial>>\n>;\n\nexport type PgArrayColumnBuilderBaseConfig = ColumnBuilderBaseConfig<'array basecolumn'> & {\n\tbaseBuilder: ColumnBuilderBaseConfig<ColumnType>;\n};\n\nexport class PgArrayBuilder<\n\tT extends PgArrayColumnBuilderBaseConfig,\n\tTBase extends ColumnBuilderBaseConfig<ColumnType> | PgArrayColumnBuilderBaseConfig,\n> extends PgColumnBuilder<\n\tT & {\n\t\tbaseBuilder: TBase extends PgArrayColumnBuilderBaseConfig ? PgArrayBuilder<\n\t\t\t\tTBase,\n\t\t\t\tTBase extends { baseBuilder: infer TBaseBuilder extends ColumnBuilderBaseConfig<any> } ? TBaseBuilder\n\t\t\t\t\t: never\n\t\t\t>\n\t\t\t: PgColumnBuilder<TBase, {}>;\n\t},\n\t{\n\t\tbaseBuilder: TBase extends PgArrayColumnBuilderBaseConfig ? PgArrayBuilder<\n\t\t\t\tTBase,\n\t\t\t\tTBase extends { baseBuilder: infer TBaseBuilder extends ColumnBuilderBaseConfig<any> } ? TBaseBuilder\n\t\t\t\t\t: never\n\t\t\t>\n\t\t\t: PgColumnBuilder<TBase, {}>;\n\t\tlength: number | undefined;\n\t}\n> {\n\tstatic override readonly [entityKind] = 'PgArrayBuilder';\n\n\tconstructor(\n\t\tname: string,\n\t\tbaseBuilder: PgArrayBuilder<T, TBase>['config']['baseBuilder'],\n\t\tlength: number | undefined,\n\t) {\n\t\tsuper(name, 'array basecolumn', 'PgArray');\n\t\tthis.config.baseBuilder = baseBuilder;\n\t\tthis.config.length = length;\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable) {\n\t\tconst baseColumn: any = this.config.baseBuilder.build(table);\n\t\treturn new PgArray(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t\tbaseColumn,\n\t\t);\n\t}\n}\n\nexport class PgArray<\n\tT extends ColumnBaseConfig<'array basecolumn'> & {\n\t\tlength: number | undefined;\n\t\tbaseBuilder: ColumnBuilderBaseConfig<ColumnType>;\n\t},\n\tTBase extends ColumnBuilderBaseConfig<ColumnType>,\n> extends PgColumn<T, {}> {\n\tstatic override readonly [entityKind]: string = 'PgArray';\n\n\tconstructor(\n\t\ttable: AnyPgTable<{ name: T['tableName'] }>,\n\t\tconfig: PgArrayBuilder<T, TBase>['config'],\n\t\treadonly baseColumn: PgColumn,\n\t\treadonly range?: [number | undefined, number | undefined],\n\t) {\n\t\tsuper(table, config);\n\t}\n\n\tgetSQLType(): string {\n\t\treturn `${this.baseColumn.getSQLType()}[${typeof this.length === 'number' ? this.length : ''}]`;\n\t}\n\n\toverride mapFromDriverValue(value: unknown[] | string): T['data'] {\n\t\tif (typeof value === 'string') {\n\t\t\t// Thank you node-postgres for not parsing enum arrays\n\t\t\tvalue = parsePgArray(value);\n\t\t}\n\t\treturn value.map((v) => this.baseColumn.mapFromDriverValue(v));\n\t}\n\n\t// Needed for arrays of custom types\n\tmapFromJsonValue(value: unknown[] | string): T['data'] {\n\t\tif (typeof value === 'string') {\n\t\t\t// Thank you node-postgres for not parsing enum arrays\n\t\t\tvalue = parsePgArray(value);\n\t\t}\n\n\t\tconst base = this.baseColumn;\n\n\t\treturn 'mapFromJsonValue' in base\n\t\t\t? value.map((v) => (<(value: unknown) => unknown> base.mapFromJsonValue)(v))\n\t\t\t: value.map((v) => base.mapFromDriverValue(v));\n\t}\n\n\toverride mapToDriverValue(value: unknown[], isNestedArray = false): unknown[] | string {\n\t\tconst a = value.map((v) =>\n\t\t\tv === null\n\t\t\t\t? null\n\t\t\t\t: is(this.baseColumn, PgArray)\n\t\t\t\t? this.baseColumn.mapToDriverValue(v as unknown[], true)\n\t\t\t\t: this.baseColumn.mapToDriverValue(v)\n\t\t);\n\t\tif (isNestedArray) return a;\n\t\treturn makePgArray(a);\n\t}\n}\n"],"mappings":"AAOA,SAAS,qBAAqB;AAE9B,SAAS,cAAc;AACvB,SAAS,YAAY,UAAU;AAE/B,SAAS,yBAAyB;AAGlC,SAAS,YAAY;AAGrB,SAAS,qBAAqB;AAC9B,SAAS,aAAa,oBAAoB;AAYnC,MAAe,wBAGZ,cAA2D;AAAA,EAC5D,oBAAuC,CAAC;AAAA,EAEhD,QAA0B,UAAU,IAAY;AAAA,EAEhD,MAAM,QAWJ;AACD,WAAO,IAAI,eAAe,KAAK,OAAO,MAAM,MAAmC,MAAa;AAAA,EAC7F;AAAA,EAEA,WACC,KACA,UAAsC,CAAC,GAChC;AACP,SAAK,kBAAkB,KAAK,EAAE,KAAK,QAAQ,CAAC;AAC5C,WAAO;AAAA,EACR;AAAA,EAEA,OACC,MACA,QACO;AACP,SAAK,OAAO,WAAW;AACvB,SAAK,OAAO,aAAa;AACzB,SAAK,OAAO,aAAa,QAAQ;AACjC,WAAO;AAAA,EACR;AAAA,EAEA,kBAAkB,IAEf;AACF,SAAK,OAAO,YAAY;AAAA,MACvB;AAAA,MACA,MAAM;AAAA,MACN,MAAM;AAAA,IACP;AACA,WAAO;AAAA,EAGR;AAAA;AAAA,EAGA,iBAAiB,QAAkB,OAA8B;AAChE,WAAO,KAAK,kBAAkB,IAAI,CAAC,EAAE,KAAK,QAAQ,MAAM;AACvD,aAAO;AAAA,QACN,CAACA,MAAKC,aAAY;AACjB,gBAAM,UAAU,IAAI,kBAAkB,MAAM;AAC3C,kBAAM,gBAAgBD,KAAI;AAC1B,mBAAO,EAAE,SAAS,CAAC,MAAM,GAAG,gBAAgB,CAAC,aAAa,EAAE;AAAA,UAC7D,CAAC;AACD,cAAIC,SAAQ,UAAU;AACrB,oBAAQ,SAASA,SAAQ,QAAQ;AAAA,UAClC;AACA,cAAIA,SAAQ,UAAU;AACrB,oBAAQ,SAASA,SAAQ,QAAQ;AAAA,UAClC;AACA,iBAAO,QAAQ,MAAM,KAAK;AAAA,QAC3B;AAAA,QACA;AAAA,QACA;AAAA,MACD;AAAA,IACD,CAAC;AAAA,EACF;AAAA;AAAA,EAMA,uBACC,OACoB;AACpB,WAAO,IAAI,kBAAkB,OAAO,KAAK,MAAM;AAAA,EAChD;AACD;AAGO,MAAe,iBAGZ,OAA0B;AAAA,EACnC,QAA0B,UAAU,IAAY;AAAA;AAAA,EAG9B;AAAA,EAElB,YACC,OACA,QACC;AACD,QAAI,CAAC,OAAO,YAAY;AACvB,aAAO,aAAa,cAAc,OAAO,CAAC,OAAO,IAAI,CAAC;AAAA,IACvD;AACA,UAAM,OAAO,MAAM;AACnB,SAAK,QAAQ;AAAA,EACd;AACD;AAIO,MAAM,0BAEH,SAAoC;AAAA,EAC7C,QAA0B,UAAU,IAAY;AAAA,EAEvC,aAAqB;AAC7B,WAAO,KAAK,WAAW;AAAA,EACxB;AAAA,EAEA,cAAsC;AAAA,IACrC,OAAO,KAAK,OAAO,SAAS;AAAA,IAC5B,OAAO,KAAK,OAAO,SAAS;AAAA,IAC5B,SAAS,KAAK,OAAO;AAAA,EACtB;AAAA,EACA,gBAAwC;AAAA,IACvC,OAAO;AAAA,IACP,OAAO;AAAA,IACP,SAAS;AAAA,EACV;AAAA,EAEA,MAAkC;AACjC,SAAK,YAAY,QAAQ;AACzB,WAAO;AAAA,EACR;AAAA,EAEA,OAAmC;AAClC,SAAK,YAAY,QAAQ;AACzB,WAAO;AAAA,EACR;AAAA,EAEA,aAAqD;AACpD,SAAK,YAAY,QAAQ;AACzB,WAAO;AAAA,EACR;AAAA,EAEA,YAAoD;AACnD,SAAK,YAAY,QAAQ;AACzB,WAAO;AAAA,EACR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EA+BA,GAAG,SAA2C;AAC7C,SAAK,YAAY,UAAU;AAC3B,WAAO;AAAA,EACR;AACD;AAEO,MAAM,cAAc;AAAA,EAC1B,QAAiB,UAAU,IAAY;AAAA,EACvC,YACC,MACA,WACA,MACA,aACC;AACD,SAAK,OAAO;AACZ,SAAK,YAAY;AACjB,SAAK,OAAO;AACZ,SAAK,cAAc;AAAA,EACpB;AAAA,EAEA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACD;AAUO,MAAM,uBAGH,gBAkBR;AAAA,EACD,QAA0B,UAAU,IAAI;AAAA,EAExC,YACC,MACA,aACA,QACC;AACD,UAAM,MAAM,oBAAoB,SAAS;AACzC,SAAK,OAAO,cAAc;AAC1B,SAAK,OAAO,SAAS;AAAA,EACtB;AAAA;AAAA,EAGS,MAAM,OAAgB;AAC9B,UAAM,aAAkB,KAAK,OAAO,YAAY,MAAM,KAAK;AAC3D,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,MACL;AAAA,IACD;AAAA,EACD;AACD;AAEO,MAAM,gBAMH,SAAgB;AAAA,EAGzB,YACC,OACA,QACS,YACA,OACR;AACD,UAAM,OAAO,MAAM;AAHV;AACA;AAAA,EAGV;AAAA,EATA,QAA0B,UAAU,IAAY;AAAA,EAWhD,aAAqB;AACpB,WAAO,GAAG,KAAK,WAAW,WAAW,CAAC,IAAI,OAAO,KAAK,WAAW,WAAW,KAAK,SAAS,EAAE;AAAA,EAC7F;AAAA,EAES,mBAAmB,OAAsC;AACjE,QAAI,OAAO,UAAU,UAAU;AAE9B,cAAQ,aAAa,KAAK;AAAA,IAC3B;AACA,WAAO,MAAM,IAAI,CAAC,MAAM,KAAK,WAAW,mBAAmB,CAAC,CAAC;AAAA,EAC9D;AAAA;AAAA,EAGA,iBAAiB,OAAsC;AACtD,QAAI,OAAO,UAAU,UAAU;AAE9B,cAAQ,aAAa,KAAK;AAAA,IAC3B;AAEA,UAAM,OAAO,KAAK;AAElB,WAAO,sBAAsB,OAC1B,MAAM,IAAI,CAAC,MAAqC,KAAK,iBAAkB,CAAC,CAAC,IACzE,MAAM,IAAI,CAAC,MAAM,KAAK,mBAAmB,CAAC,CAAC;AAAA,EAC/C;AAAA,EAES,iBAAiB,OAAkB,gBAAgB,OAA2B;AACtF,UAAM,IAAI,MAAM;AAAA,MAAI,CAAC,MACpB,MAAM,OACH,OACA,GAAG,KAAK,YAAY,OAAO,IAC3B,KAAK,WAAW,iBAAiB,GAAgB,IAAI,IACrD,KAAK,WAAW,iBAAiB,CAAC;AAAA,IACtC;AACA,QAAI,cAAe,QAAO;AAC1B,WAAO,YAAY,CAAC;AAAA,EACrB;AACD;","names":["ref","actions"]}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/pg-core/columns/custom.ts"],"sourcesContent":["import type { ColumnBuilderBaseConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { PgTable } from '~/pg-core/table.ts';\nimport type { SQL, SQLGenerator } from '~/sql/sql.ts';\nimport { type Equal, getColumnNameAndConfig } from '~/utils.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport type ConvertCustomConfig<T extends Partial<CustomTypeValues>> =\n\t& {\n\t\tdataType: 'custom';\n\t\tdata: T['data'];\n\t\tdriverParam: T['driverData'];\n\t}\n\t& (T['notNull'] extends true ? { notNull: true } : {})\n\t& (T['default'] extends true ? { hasDefault: true } : {});\n\nexport interface PgCustomColumnInnerConfig {\n\tcustomTypeValues: CustomTypeValues;\n}\n\nexport class PgCustomColumnBuilder<T extends ColumnBuilderBaseConfig<'custom'>> extends PgColumnBuilder<\n\tT,\n\t{\n\t\tfieldConfig: CustomTypeValues['config'];\n\t\tcustomTypeParams: CustomTypeParams<any>;\n\t}\n> {\n\tstatic override readonly [entityKind]: string = 'PgCustomColumnBuilder';\n\n\tconstructor(\n\t\tname: string,\n\t\tfieldConfig: CustomTypeValues['config'],\n\t\tcustomTypeParams: CustomTypeParams<any>,\n\t) {\n\t\tsuper(name, 'custom', 'PgCustomColumn');\n\t\tthis.config.fieldConfig = fieldConfig;\n\t\tthis.config.customTypeParams = customTypeParams;\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgCustomColumn(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class PgCustomColumn<T extends ColumnBaseConfig<'custom'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgCustomColumn';\n\n\tprivate sqlName: string;\n\tprivate mapTo?: (value: T['data']) => T['driverParam'];\n\tprivate mapFrom?: (value: T['driverParam']) => T['data'];\n\tprivate mapJson?: (value: unknown) => T['data'];\n\tprivate forJsonSelect?: (identifier: SQL, sql: SQLGenerator, arrayDimensions?: number) => SQL;\n\n\tconstructor(\n\t\ttable: PgTable<any>,\n\t\tconfig: PgCustomColumnBuilder<T>['config'],\n\t) {\n\t\tsuper(table, config);\n\t\tthis.sqlName = config.customTypeParams.dataType(config.fieldConfig);\n\t\tthis.mapTo = config.customTypeParams.toDriver;\n\t\tthis.mapFrom = config.customTypeParams.fromDriver;\n\t\tthis.mapJson = config.customTypeParams.fromJson;\n\t\tthis.forJsonSelect = config.customTypeParams.forJsonSelect;\n\t}\n\n\tgetSQLType(): string {\n\t\treturn this.sqlName;\n\t}\n\n\toverride mapFromDriverValue(value: T['driverParam']): T['data'] {\n\t\treturn typeof this.mapFrom === 'function' ? this.mapFrom(value) : value as T['data'];\n\t}\n\n\tmapFromJsonValue(value: unknown): T['data'] {\n\t\treturn typeof this.mapJson === 'function' ? this.mapJson(value) : this.mapFromDriverValue(value) as T['data'];\n\t}\n\n\tjsonSelectIdentifier(identifier: SQL, sql: SQLGenerator, arrayDimensions?: number): SQL {\n\t\tif (typeof this.forJsonSelect === 'function') return this.forJsonSelect(identifier, sql, arrayDimensions);\n\n\t\tconst rawType = this.getSQLType().toLowerCase();\n\t\tconst parenPos = rawType.indexOf('(');\n\t\tconst type = (parenPos + 1) ? rawType.slice(0, parenPos) : rawType;\n\n\t\tswitch (type) {\n\t\t\tcase 'bytea':\n\t\t\tcase 'geometry':\n\t\t\tcase 'timestamp':\n\t\t\tcase 'numeric':\n\t\t\tcase 'bigint': {\n\t\t\t\tconst arrVal = '[]'.repeat(arrayDimensions ?? 0);\n\n\t\t\t\treturn sql`${identifier}::text${sql.raw(arrVal).if(arrayDimensions)}`;\n\t\t\t}\n\t\t\tdefault: {\n\t\t\t\treturn identifier;\n\t\t\t}\n\t\t}\n\t}\n\n\toverride mapToDriverValue(value: T['data']): T['driverParam'] {\n\t\treturn typeof this.mapTo === 'function' ? this.mapTo(value) : value as T['data'];\n\t}\n}\n\nexport interface CustomTypeValues {\n\t/**\n\t * Required type for custom column, that will infer proper type model\n\t *\n\t * Examples:\n\t *\n\t * If you want your column to be `string` type after selecting/or on inserting - use `data: string`. Like `text`, `varchar`\n\t *\n\t * If you want your column to be `number` type after selecting/or on inserting - use `data: number`. Like `integer`\n\t */\n\tdata: unknown;\n\n\t/**\n\t * Type helper, that represents what type database driver is accepting for specific database data type\n\t */\n\tdriverData?: unknown;\n\n\t/**\n\t * Type helper, that represents what type database driver is returning for specific database data type\n\t *\n\t * Needed only in case driver's output and input for type differ\n\t *\n\t * Defaults to {@link driverData}\n\t */\n\tdriverOutput?: unknown;\n\n\t/**\n\t * Type helper, that represents what type field returns after being aggregated to JSON\n\t */\n\tjsonData?: unknown;\n\n\t/**\n\t * What config type should be used for {@link CustomTypeParams} `dataType` generation\n\t */\n\tconfig?: Record<string, any>;\n\n\t/**\n\t * Whether the config argument should be required or not\n\t * @default false\n\t */\n\tconfigRequired?: boolean;\n\n\t/**\n\t * If your custom data type should be notNull by default you can use `notNull: true`\n\t *\n\t * @example\n\t * const customSerial = customType<{ data: number, notNull: true, default: true }>({\n\t * \t dataType() {\n\t * \t return 'serial';\n\t * },\n\t * });\n\t */\n\tnotNull?: boolean;\n\n\t/**\n\t * If your custom data type has default you can use `default: true`\n\t *\n\t * @example\n\t * const customSerial = customType<{ data: number, notNull: true, default: true }>({\n\t * \t dataType() {\n\t * \t return 'serial';\n\t * },\n\t * });\n\t */\n\tdefault?: boolean;\n}\n\nexport interface CustomTypeParams<T extends CustomTypeValues> {\n\t/**\n\t * Database data type string representation, that is used for migrations\n\t * @example\n\t * ```\n\t * `jsonb`, `text`\n\t * ```\n\t *\n\t * If database data type needs additional params you can use them from `config` param\n\t * @example\n\t * ```\n\t * `varchar(256)`, `numeric(2,3)`\n\t * ```\n\t *\n\t * To make `config` be of specific type please use config generic in {@link CustomTypeValues}\n\t *\n\t * @example\n\t * Usage example\n\t * ```\n\t * dataType() {\n\t * return 'boolean';\n\t * },\n\t * ```\n\t * Or\n\t * ```\n\t * dataType(config) {\n\t * \t return typeof config.length !== 'undefined' ? `varchar(${config.length})` : `varchar`;\n\t * \t }\n\t * ```\n\t */\n\tdataType: (config: T['config'] | (Equal<T['configRequired'], true> extends true ? never : undefined)) => string;\n\n\t/**\n\t * Optional mapping function, that is used to transform inputs from desired to be used in code format to one suitable for driver\n\t * @example\n\t * For example, when using jsonb we need to map JS/TS object to string before writing to database\n\t * ```\n\t * toDriver(value: TData): string {\n\t * \t return JSON.stringify(value);\n\t * }\n\t * ```\n\t */\n\ttoDriver?: (value: T['data']) => T['driverData'] | SQL;\n\n\t/**\n\t * Optional mapping function, that is used for transforming data returned by driver to desired column's output format\n\t * @example\n\t * For example, when using timestamp we need to map string Date representation to JS Date\n\t * ```\n\t * fromDriver(value: string): Date {\n\t * \treturn new Date(value);\n\t * }\n\t * ```\n\t *\n\t * It'll cause the returned data to change from:\n\t * ```\n\t * {\n\t * \tcustomField: \"2025-04-07T03:25:16.635Z\";\n\t * }\n\t * ```\n\t * to:\n\t * ```\n\t * {\n\t * \tcustomField: new Date(\"2025-04-07T03:25:16.635Z\");\n\t * }\n\t * ```\n\t */\n\tfromDriver?: (value: 'driverOutput' extends keyof T ? T['driverOutput'] : T['driverData']) => T['data'];\n\n\t/**\n\t * Optional mapping function, that is used for transforming data returned by transofmed to JSON in database data to desired format\n\t *\n\t * Used by [relational queries](https://orm.drizzle.team/docs/rqb-v2)\n\t *\n\t * Defaults to {@link fromDriver} function\n\t * @example\n\t * For example, when querying bigint column via [RQB](https://orm.drizzle.team/docs/rqb-v2) or [JSON functions](https://orm.drizzle.team/docs/json-functions), the result field will be returned as it's string representation, as opposed to bigint from regular query\n\t * To handle that, we need a separate function to handle such field's mapping:\n\t * ```\n\t * fromJson(value: string): bigint {\n\t * \treturn BigInt(value);\n\t * },\n\t * ```\n\t *\n\t * It'll cause the returned data to change from:\n\t * ```\n\t * {\n\t * \tcustomField: \"5044565289845416380\";\n\t * }\n\t * ```\n\t * to:\n\t * ```\n\t * {\n\t * \tcustomField: 5044565289845416380n;\n\t * }\n\t * ```\n\t */\n\tfromJson?: (value: T['jsonData']) => T['data'];\n\n\t/**\n\t * Optional selection modifier function, that is used for modifying selection of column inside [JSON functions](https://orm.drizzle.team/docs/json-functions)\n\t *\n\t * Additional mapping that could be required for such scenarios can be handled using {@link fromJson} function\n\t *\n\t * Used by [relational queries](https://orm.drizzle.team/docs/rqb-v2)\n\t *\n\t * Following types are being casted to text by default: `bytea`, `geometry`, `timestamp`, `numeric`, `bigint`\n\t * @example\n\t * For example, when using bigint we need to cast field to text to preserve data integrity\n\t * ```\n\t * forJsonSelect(identifier: SQL, sql: SQLGenerator, arrayDimensions?: number): SQL {\n\t * \treturn sql`${identifier}::text`\n\t * },\n\t * ```\n\t *\n\t * This will change query from:\n\t * ```\n\t * SELECT\n\t * \trow_to_json(\"t\".*)\n\t * \tFROM\n\t * \t(\n\t * \t\tSELECT\n\t * \t\t\"table\".\"custom_bigint\" AS \"bigint\"\n\t * \t\tFROM\n\t * \t\t\"table\"\n\t * \t) AS \"t\"\n\t * ```\n\t * to:\n\t * ```\n\t * SELECT\n\t * \trow_to_json(\"t\".*)\n\t * \tFROM\n\t * \t(\n\t * \t\tSELECT\n\t * \t\t\"table\".\"custom_bigint\"::text AS \"bigint\"\n\t * \t\tFROM\n\t * \t\t\"table\"\n\t * \t) AS \"t\"\n\t * ```\n\t *\n\t * Returned by query object will change from:\n\t * ```\n\t * {\n\t * \tbigint: 5044565289845416000; // Partial data loss due to direct conversion to JSON format\n\t * }\n\t * ```\n\t * to:\n\t * ```\n\t * {\n\t * \tbigint: \"5044565289845416380\"; // Data is preserved due to conversion of field to text before JSON-ification\n\t * }\n\t * ```\n\t */\n\tforJsonSelect?: (identifier: SQL, sql: SQLGenerator, arrayDimensions?: number) => SQL;\n}\n\n/**\n * Custom pg database data type generator\n */\nexport function customType<T extends CustomTypeValues = CustomTypeValues>(\n\tcustomTypeParams: CustomTypeParams<T>,\n): Equal<T['configRequired'], true> extends true ? {\n\t\t<TConfig extends Record<string, any> & T['config']>(\n\t\t\tfieldConfig: TConfig,\n\t\t): PgCustomColumnBuilder<ConvertCustomConfig<T>>;\n\t\t(\n\t\t\tdbName: string,\n\t\t\tfieldConfig: T['config'],\n\t\t): PgCustomColumnBuilder<ConvertCustomConfig<T>>;\n\t}\n\t: {\n\t\t<TConfig extends Record<string, any> & T['config']>(\n\t\t\tfieldConfig?: TConfig,\n\t\t): PgCustomColumnBuilder<ConvertCustomConfig<T>>;\n\t\t(\n\t\t\tdbName: string,\n\t\t\tfieldConfig?: T['config'],\n\t\t): PgCustomColumnBuilder<ConvertCustomConfig<T>>;\n\t}\n{\n\treturn (\n\t\ta?: string | T['config'],\n\t\tb?: T['config'],\n\t): PgCustomColumnBuilder<ConvertCustomConfig<T>> => {\n\t\tconst { name, config } = getColumnNameAndConfig<T['config']>(a, b);\n\t\treturn new PgCustomColumnBuilder(name, config, customTypeParams);\n\t};\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAEA,oBAA2B;AAG3B,mBAAmD;AACnD,oBAA0C;AAenC,MAAM,8BAA2E,8BAMtF;AAAA,EACD,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YACC,MACA,aACA,kBACC;AACD,UAAM,MAAM,UAAU,gBAAgB;AACtC,SAAK,OAAO,cAAc;AAC1B,SAAK,OAAO,mBAAmB;AAAA,EAChC;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,uBAA6D,uBAAY;AAAA,EACrF,QAA0B,wBAAU,IAAY;AAAA,EAExC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EAER,YACC,OACA,QACC;AACD,UAAM,OAAO,MAAM;AACnB,SAAK,UAAU,OAAO,iBAAiB,SAAS,OAAO,WAAW;AAClE,SAAK,QAAQ,OAAO,iBAAiB;AACrC,SAAK,UAAU,OAAO,iBAAiB;AACvC,SAAK,UAAU,OAAO,iBAAiB;AACvC,SAAK,gBAAgB,OAAO,iBAAiB;AAAA,EAC9C;AAAA,EAEA,aAAqB;AACpB,WAAO,KAAK;AAAA,EACb;AAAA,EAES,mBAAmB,OAAoC;AAC/D,WAAO,OAAO,KAAK,YAAY,aAAa,KAAK,QAAQ,KAAK,IAAI;AAAA,EACnE;AAAA,EAEA,iBAAiB,OAA2B;AAC3C,WAAO,OAAO,KAAK,YAAY,aAAa,KAAK,QAAQ,KAAK,IAAI,KAAK,mBAAmB,KAAK;AAAA,EAChG;AAAA,EAEA,qBAAqB,YAAiB,KAAmB,iBAA+B;AACvF,QAAI,OAAO,KAAK,kBAAkB,WAAY,QAAO,KAAK,cAAc,YAAY,KAAK,eAAe;AAExG,UAAM,UAAU,KAAK,WAAW,EAAE,YAAY;AAC9C,UAAM,WAAW,QAAQ,QAAQ,GAAG;AACpC,UAAM,OAAQ,WAAW,IAAK,QAAQ,MAAM,GAAG,QAAQ,IAAI;AAE3D,YAAQ,MAAM;AAAA,MACb,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK,UAAU;AACd,cAAM,SAAS,KAAK,OAAO,mBAAmB,CAAC;AAE/C,eAAO,MAAM,UAAU,SAAS,IAAI,IAAI,MAAM,EAAE,GAAG,eAAe,CAAC;AAAA,MACpE;AAAA,MACA,SAAS;AACR,eAAO;AAAA,MACR;AAAA,IACD;AAAA,EACD;AAAA,EAES,iBAAiB,OAAoC;AAC7D,WAAO,OAAO,KAAK,UAAU,aAAa,KAAK,MAAM,KAAK,IAAI;AAAA,EAC/D;AACD;AAoOO,SAAS,WACf,kBAmBD;AACC,SAAO,CACN,GACA,MACmD;AACnD,UAAM,EAAE,MAAM,OAAO,QAAI,qCAAoC,GAAG,CAAC;AACjE,WAAO,IAAI,sBAAsB,MAAM,QAAQ,gBAAgB;AAAA,EAChE;AACD;","names":[]}
1
+ {"version":3,"sources":["../../../src/pg-core/columns/custom.ts"],"sourcesContent":["import type { ColumnBuilderBaseConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { PgTable } from '~/pg-core/table.ts';\nimport type { SQL, SQLGenerator } from '~/sql/sql.ts';\nimport { type Equal, getColumnNameAndConfig } from '~/utils.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport type ConvertCustomConfig<T extends Partial<CustomTypeValues>> =\n\t& {\n\t\tname: string;\n\t\tdataType: 'custom';\n\t\tdata: T['data'];\n\t\tdriverParam: T['driverData'];\n\t}\n\t& (T['notNull'] extends true ? { notNull: true } : {})\n\t& (T['default'] extends true ? { hasDefault: true } : {});\n\nexport interface PgCustomColumnInnerConfig {\n\tcustomTypeValues: CustomTypeValues;\n}\n\nexport class PgCustomColumnBuilder<T extends ColumnBuilderBaseConfig<'custom'>> extends PgColumnBuilder<\n\tT,\n\t{\n\t\tfieldConfig: CustomTypeValues['config'];\n\t\tcustomTypeParams: CustomTypeParams<any>;\n\t}\n> {\n\tstatic override readonly [entityKind]: string = 'PgCustomColumnBuilder';\n\n\tconstructor(\n\t\tname: string,\n\t\tfieldConfig: CustomTypeValues['config'],\n\t\tcustomTypeParams: CustomTypeParams<any>,\n\t) {\n\t\tsuper(name, 'custom', 'PgCustomColumn');\n\t\tthis.config.fieldConfig = fieldConfig;\n\t\tthis.config.customTypeParams = customTypeParams;\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgCustomColumn(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class PgCustomColumn<T extends ColumnBaseConfig<'custom'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgCustomColumn';\n\n\tprivate sqlName: string;\n\tprivate mapTo?: (value: T['data']) => T['driverParam'];\n\tprivate mapFrom?: (value: T['driverParam']) => T['data'];\n\tprivate mapJson?: (value: unknown) => T['data'];\n\tprivate forJsonSelect?: (identifier: SQL, sql: SQLGenerator, arrayDimensions?: number) => SQL;\n\n\tconstructor(\n\t\ttable: PgTable<any>,\n\t\tconfig: PgCustomColumnBuilder<T>['config'],\n\t) {\n\t\tsuper(table, config);\n\t\tthis.sqlName = config.customTypeParams.dataType(config.fieldConfig);\n\t\tthis.mapTo = config.customTypeParams.toDriver;\n\t\tthis.mapFrom = config.customTypeParams.fromDriver;\n\t\tthis.mapJson = config.customTypeParams.fromJson;\n\t\tthis.forJsonSelect = config.customTypeParams.forJsonSelect;\n\t}\n\n\tgetSQLType(): string {\n\t\treturn this.sqlName;\n\t}\n\n\toverride mapFromDriverValue(value: T['driverParam']): T['data'] {\n\t\treturn typeof this.mapFrom === 'function' ? this.mapFrom(value) : value as T['data'];\n\t}\n\n\tmapFromJsonValue(value: unknown): T['data'] {\n\t\treturn typeof this.mapJson === 'function' ? this.mapJson(value) : this.mapFromDriverValue(value) as T['data'];\n\t}\n\n\tjsonSelectIdentifier(identifier: SQL, sql: SQLGenerator, arrayDimensions?: number): SQL {\n\t\tif (typeof this.forJsonSelect === 'function') return this.forJsonSelect(identifier, sql, arrayDimensions);\n\n\t\tconst rawType = this.getSQLType().toLowerCase();\n\t\tconst parenPos = rawType.indexOf('(');\n\t\tconst type = (parenPos + 1) ? rawType.slice(0, parenPos) : rawType;\n\n\t\tswitch (type) {\n\t\t\tcase 'bytea':\n\t\t\tcase 'geometry':\n\t\t\tcase 'timestamp':\n\t\t\tcase 'numeric':\n\t\t\tcase 'bigint': {\n\t\t\t\tconst arrVal = '[]'.repeat(arrayDimensions ?? 0);\n\n\t\t\t\treturn sql`${identifier}::text${sql.raw(arrVal).if(arrayDimensions)}`;\n\t\t\t}\n\t\t\tdefault: {\n\t\t\t\treturn identifier;\n\t\t\t}\n\t\t}\n\t}\n\n\toverride mapToDriverValue(value: T['data']): T['driverParam'] {\n\t\treturn typeof this.mapTo === 'function' ? this.mapTo(value) : value as T['data'];\n\t}\n}\n\nexport interface CustomTypeValues {\n\t/**\n\t * Required type for custom column, that will infer proper type model\n\t *\n\t * Examples:\n\t *\n\t * If you want your column to be `string` type after selecting/or on inserting - use `data: string`. Like `text`, `varchar`\n\t *\n\t * If you want your column to be `number` type after selecting/or on inserting - use `data: number`. Like `integer`\n\t */\n\tdata: unknown;\n\n\t/**\n\t * Type helper, that represents what type database driver is accepting for specific database data type\n\t */\n\tdriverData?: unknown;\n\n\t/**\n\t * Type helper, that represents what type database driver is returning for specific database data type\n\t *\n\t * Needed only in case driver's output and input for type differ\n\t *\n\t * Defaults to {@link driverData}\n\t */\n\tdriverOutput?: unknown;\n\n\t/**\n\t * Type helper, that represents what type field returns after being aggregated to JSON\n\t */\n\tjsonData?: unknown;\n\n\t/**\n\t * What config type should be used for {@link CustomTypeParams} `dataType` generation\n\t */\n\tconfig?: Record<string, any>;\n\n\t/**\n\t * Whether the config argument should be required or not\n\t * @default false\n\t */\n\tconfigRequired?: boolean;\n\n\t/**\n\t * If your custom data type should be notNull by default you can use `notNull: true`\n\t *\n\t * @example\n\t * const customSerial = customType<{ data: number, notNull: true, default: true }>({\n\t * \t dataType() {\n\t * \t return 'serial';\n\t * },\n\t * });\n\t */\n\tnotNull?: boolean;\n\n\t/**\n\t * If your custom data type has default you can use `default: true`\n\t *\n\t * @example\n\t * const customSerial = customType<{ data: number, notNull: true, default: true }>({\n\t * \t dataType() {\n\t * \t return 'serial';\n\t * },\n\t * });\n\t */\n\tdefault?: boolean;\n}\n\nexport interface CustomTypeParams<T extends CustomTypeValues> {\n\t/**\n\t * Database data type string representation, that is used for migrations\n\t * @example\n\t * ```\n\t * `jsonb`, `text`\n\t * ```\n\t *\n\t * If database data type needs additional params you can use them from `config` param\n\t * @example\n\t * ```\n\t * `varchar(256)`, `numeric(2,3)`\n\t * ```\n\t *\n\t * To make `config` be of specific type please use config generic in {@link CustomTypeValues}\n\t *\n\t * @example\n\t * Usage example\n\t * ```\n\t * dataType() {\n\t * return 'boolean';\n\t * },\n\t * ```\n\t * Or\n\t * ```\n\t * dataType(config) {\n\t * \t return typeof config.length !== 'undefined' ? `varchar(${config.length})` : `varchar`;\n\t * \t }\n\t * ```\n\t */\n\tdataType: (config: T['config'] | (Equal<T['configRequired'], true> extends true ? never : undefined)) => string;\n\n\t/**\n\t * Optional mapping function, that is used to transform inputs from desired to be used in code format to one suitable for driver\n\t * @example\n\t * For example, when using jsonb we need to map JS/TS object to string before writing to database\n\t * ```\n\t * toDriver(value: TData): string {\n\t * \t return JSON.stringify(value);\n\t * }\n\t * ```\n\t */\n\ttoDriver?: (value: T['data']) => T['driverData'] | SQL;\n\n\t/**\n\t * Optional mapping function, that is used for transforming data returned by driver to desired column's output format\n\t * @example\n\t * For example, when using timestamp we need to map string Date representation to JS Date\n\t * ```\n\t * fromDriver(value: string): Date {\n\t * \treturn new Date(value);\n\t * }\n\t * ```\n\t *\n\t * It'll cause the returned data to change from:\n\t * ```\n\t * {\n\t * \tcustomField: \"2025-04-07T03:25:16.635Z\";\n\t * }\n\t * ```\n\t * to:\n\t * ```\n\t * {\n\t * \tcustomField: new Date(\"2025-04-07T03:25:16.635Z\");\n\t * }\n\t * ```\n\t */\n\tfromDriver?: (value: 'driverOutput' extends keyof T ? T['driverOutput'] : T['driverData']) => T['data'];\n\n\t/**\n\t * Optional mapping function, that is used for transforming data returned by transofmed to JSON in database data to desired format\n\t *\n\t * Used by [relational queries](https://orm.drizzle.team/docs/rqb-v2)\n\t *\n\t * Defaults to {@link fromDriver} function\n\t * @example\n\t * For example, when querying bigint column via [RQB](https://orm.drizzle.team/docs/rqb-v2) or [JSON functions](https://orm.drizzle.team/docs/json-functions), the result field will be returned as it's string representation, as opposed to bigint from regular query\n\t * To handle that, we need a separate function to handle such field's mapping:\n\t * ```\n\t * fromJson(value: string): bigint {\n\t * \treturn BigInt(value);\n\t * },\n\t * ```\n\t *\n\t * It'll cause the returned data to change from:\n\t * ```\n\t * {\n\t * \tcustomField: \"5044565289845416380\";\n\t * }\n\t * ```\n\t * to:\n\t * ```\n\t * {\n\t * \tcustomField: 5044565289845416380n;\n\t * }\n\t * ```\n\t */\n\tfromJson?: (value: T['jsonData']) => T['data'];\n\n\t/**\n\t * Optional selection modifier function, that is used for modifying selection of column inside [JSON functions](https://orm.drizzle.team/docs/json-functions)\n\t *\n\t * Additional mapping that could be required for such scenarios can be handled using {@link fromJson} function\n\t *\n\t * Used by [relational queries](https://orm.drizzle.team/docs/rqb-v2)\n\t *\n\t * Following types are being casted to text by default: `bytea`, `geometry`, `timestamp`, `numeric`, `bigint`\n\t * @example\n\t * For example, when using bigint we need to cast field to text to preserve data integrity\n\t * ```\n\t * forJsonSelect(identifier: SQL, sql: SQLGenerator, arrayDimensions?: number): SQL {\n\t * \treturn sql`${identifier}::text`\n\t * },\n\t * ```\n\t *\n\t * This will change query from:\n\t * ```\n\t * SELECT\n\t * \trow_to_json(\"t\".*)\n\t * \tFROM\n\t * \t(\n\t * \t\tSELECT\n\t * \t\t\"table\".\"custom_bigint\" AS \"bigint\"\n\t * \t\tFROM\n\t * \t\t\"table\"\n\t * \t) AS \"t\"\n\t * ```\n\t * to:\n\t * ```\n\t * SELECT\n\t * \trow_to_json(\"t\".*)\n\t * \tFROM\n\t * \t(\n\t * \t\tSELECT\n\t * \t\t\"table\".\"custom_bigint\"::text AS \"bigint\"\n\t * \t\tFROM\n\t * \t\t\"table\"\n\t * \t) AS \"t\"\n\t * ```\n\t *\n\t * Returned by query object will change from:\n\t * ```\n\t * {\n\t * \tbigint: 5044565289845416000; // Partial data loss due to direct conversion to JSON format\n\t * }\n\t * ```\n\t * to:\n\t * ```\n\t * {\n\t * \tbigint: \"5044565289845416380\"; // Data is preserved due to conversion of field to text before JSON-ification\n\t * }\n\t * ```\n\t */\n\tforJsonSelect?: (identifier: SQL, sql: SQLGenerator, arrayDimensions?: number) => SQL;\n}\n\n/**\n * Custom pg database data type generator\n */\nexport function customType<T extends CustomTypeValues = CustomTypeValues>(\n\tcustomTypeParams: CustomTypeParams<T>,\n): Equal<T['configRequired'], true> extends true ? {\n\t\t<TConfig extends Record<string, any> & T['config']>(\n\t\t\tfieldConfig: TConfig,\n\t\t): PgCustomColumnBuilder<ConvertCustomConfig<T>>;\n\t\t(\n\t\t\tdbName: string,\n\t\t\tfieldConfig: T['config'],\n\t\t): PgCustomColumnBuilder<ConvertCustomConfig<T>>;\n\t}\n\t: {\n\t\t<TConfig extends Record<string, any> & T['config']>(\n\t\t\tfieldConfig?: TConfig,\n\t\t): PgCustomColumnBuilder<ConvertCustomConfig<T>>;\n\t\t(\n\t\t\tdbName: string,\n\t\t\tfieldConfig?: T['config'],\n\t\t): PgCustomColumnBuilder<ConvertCustomConfig<T>>;\n\t}\n{\n\treturn (\n\t\ta?: string | T['config'],\n\t\tb?: T['config'],\n\t): PgCustomColumnBuilder<ConvertCustomConfig<T>> => {\n\t\tconst { name, config } = getColumnNameAndConfig<T['config']>(a, b);\n\t\treturn new PgCustomColumnBuilder(name as ConvertCustomConfig<T>['name'], config, customTypeParams);\n\t};\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAEA,oBAA2B;AAG3B,mBAAmD;AACnD,oBAA0C;AAgBnC,MAAM,8BAA2E,8BAMtF;AAAA,EACD,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YACC,MACA,aACA,kBACC;AACD,UAAM,MAAM,UAAU,gBAAgB;AACtC,SAAK,OAAO,cAAc;AAC1B,SAAK,OAAO,mBAAmB;AAAA,EAChC;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,uBAA6D,uBAAY;AAAA,EACrF,QAA0B,wBAAU,IAAY;AAAA,EAExC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EAER,YACC,OACA,QACC;AACD,UAAM,OAAO,MAAM;AACnB,SAAK,UAAU,OAAO,iBAAiB,SAAS,OAAO,WAAW;AAClE,SAAK,QAAQ,OAAO,iBAAiB;AACrC,SAAK,UAAU,OAAO,iBAAiB;AACvC,SAAK,UAAU,OAAO,iBAAiB;AACvC,SAAK,gBAAgB,OAAO,iBAAiB;AAAA,EAC9C;AAAA,EAEA,aAAqB;AACpB,WAAO,KAAK;AAAA,EACb;AAAA,EAES,mBAAmB,OAAoC;AAC/D,WAAO,OAAO,KAAK,YAAY,aAAa,KAAK,QAAQ,KAAK,IAAI;AAAA,EACnE;AAAA,EAEA,iBAAiB,OAA2B;AAC3C,WAAO,OAAO,KAAK,YAAY,aAAa,KAAK,QAAQ,KAAK,IAAI,KAAK,mBAAmB,KAAK;AAAA,EAChG;AAAA,EAEA,qBAAqB,YAAiB,KAAmB,iBAA+B;AACvF,QAAI,OAAO,KAAK,kBAAkB,WAAY,QAAO,KAAK,cAAc,YAAY,KAAK,eAAe;AAExG,UAAM,UAAU,KAAK,WAAW,EAAE,YAAY;AAC9C,UAAM,WAAW,QAAQ,QAAQ,GAAG;AACpC,UAAM,OAAQ,WAAW,IAAK,QAAQ,MAAM,GAAG,QAAQ,IAAI;AAE3D,YAAQ,MAAM;AAAA,MACb,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK,UAAU;AACd,cAAM,SAAS,KAAK,OAAO,mBAAmB,CAAC;AAE/C,eAAO,MAAM,UAAU,SAAS,IAAI,IAAI,MAAM,EAAE,GAAG,eAAe,CAAC;AAAA,MACpE;AAAA,MACA,SAAS;AACR,eAAO;AAAA,MACR;AAAA,IACD;AAAA,EACD;AAAA,EAES,iBAAiB,OAAoC;AAC7D,WAAO,OAAO,KAAK,UAAU,aAAa,KAAK,MAAM,KAAK,IAAI;AAAA,EAC/D;AACD;AAoOO,SAAS,WACf,kBAmBD;AACC,SAAO,CACN,GACA,MACmD;AACnD,UAAM,EAAE,MAAM,OAAO,QAAI,qCAAoC,GAAG,CAAC;AACjE,WAAO,IAAI,sBAAsB,MAAwC,QAAQ,gBAAgB;AAAA,EAClG;AACD;","names":[]}
@@ -6,6 +6,7 @@ import type { SQL, SQLGenerator } from "../../sql/sql.cjs";
6
6
  import { type Equal } from "../../utils.cjs";
7
7
  import { PgColumn, PgColumnBuilder } from "./common.cjs";
8
8
  export type ConvertCustomConfig<T extends Partial<CustomTypeValues>> = {
9
+ name: string;
9
10
  dataType: 'custom';
10
11
  data: T['data'];
11
12
  driverParam: T['driverData'];
@@ -6,6 +6,7 @@ import type { SQL, SQLGenerator } from "../../sql/sql.js";
6
6
  import { type Equal } from "../../utils.js";
7
7
  import { PgColumn, PgColumnBuilder } from "./common.js";
8
8
  export type ConvertCustomConfig<T extends Partial<CustomTypeValues>> = {
9
+ name: string;
9
10
  dataType: 'custom';
10
11
  data: T['data'];
11
12
  driverParam: T['driverData'];
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/pg-core/columns/custom.ts"],"sourcesContent":["import type { ColumnBuilderBaseConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { PgTable } from '~/pg-core/table.ts';\nimport type { SQL, SQLGenerator } from '~/sql/sql.ts';\nimport { type Equal, getColumnNameAndConfig } from '~/utils.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport type ConvertCustomConfig<T extends Partial<CustomTypeValues>> =\n\t& {\n\t\tdataType: 'custom';\n\t\tdata: T['data'];\n\t\tdriverParam: T['driverData'];\n\t}\n\t& (T['notNull'] extends true ? { notNull: true } : {})\n\t& (T['default'] extends true ? { hasDefault: true } : {});\n\nexport interface PgCustomColumnInnerConfig {\n\tcustomTypeValues: CustomTypeValues;\n}\n\nexport class PgCustomColumnBuilder<T extends ColumnBuilderBaseConfig<'custom'>> extends PgColumnBuilder<\n\tT,\n\t{\n\t\tfieldConfig: CustomTypeValues['config'];\n\t\tcustomTypeParams: CustomTypeParams<any>;\n\t}\n> {\n\tstatic override readonly [entityKind]: string = 'PgCustomColumnBuilder';\n\n\tconstructor(\n\t\tname: string,\n\t\tfieldConfig: CustomTypeValues['config'],\n\t\tcustomTypeParams: CustomTypeParams<any>,\n\t) {\n\t\tsuper(name, 'custom', 'PgCustomColumn');\n\t\tthis.config.fieldConfig = fieldConfig;\n\t\tthis.config.customTypeParams = customTypeParams;\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgCustomColumn(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class PgCustomColumn<T extends ColumnBaseConfig<'custom'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgCustomColumn';\n\n\tprivate sqlName: string;\n\tprivate mapTo?: (value: T['data']) => T['driverParam'];\n\tprivate mapFrom?: (value: T['driverParam']) => T['data'];\n\tprivate mapJson?: (value: unknown) => T['data'];\n\tprivate forJsonSelect?: (identifier: SQL, sql: SQLGenerator, arrayDimensions?: number) => SQL;\n\n\tconstructor(\n\t\ttable: PgTable<any>,\n\t\tconfig: PgCustomColumnBuilder<T>['config'],\n\t) {\n\t\tsuper(table, config);\n\t\tthis.sqlName = config.customTypeParams.dataType(config.fieldConfig);\n\t\tthis.mapTo = config.customTypeParams.toDriver;\n\t\tthis.mapFrom = config.customTypeParams.fromDriver;\n\t\tthis.mapJson = config.customTypeParams.fromJson;\n\t\tthis.forJsonSelect = config.customTypeParams.forJsonSelect;\n\t}\n\n\tgetSQLType(): string {\n\t\treturn this.sqlName;\n\t}\n\n\toverride mapFromDriverValue(value: T['driverParam']): T['data'] {\n\t\treturn typeof this.mapFrom === 'function' ? this.mapFrom(value) : value as T['data'];\n\t}\n\n\tmapFromJsonValue(value: unknown): T['data'] {\n\t\treturn typeof this.mapJson === 'function' ? this.mapJson(value) : this.mapFromDriverValue(value) as T['data'];\n\t}\n\n\tjsonSelectIdentifier(identifier: SQL, sql: SQLGenerator, arrayDimensions?: number): SQL {\n\t\tif (typeof this.forJsonSelect === 'function') return this.forJsonSelect(identifier, sql, arrayDimensions);\n\n\t\tconst rawType = this.getSQLType().toLowerCase();\n\t\tconst parenPos = rawType.indexOf('(');\n\t\tconst type = (parenPos + 1) ? rawType.slice(0, parenPos) : rawType;\n\n\t\tswitch (type) {\n\t\t\tcase 'bytea':\n\t\t\tcase 'geometry':\n\t\t\tcase 'timestamp':\n\t\t\tcase 'numeric':\n\t\t\tcase 'bigint': {\n\t\t\t\tconst arrVal = '[]'.repeat(arrayDimensions ?? 0);\n\n\t\t\t\treturn sql`${identifier}::text${sql.raw(arrVal).if(arrayDimensions)}`;\n\t\t\t}\n\t\t\tdefault: {\n\t\t\t\treturn identifier;\n\t\t\t}\n\t\t}\n\t}\n\n\toverride mapToDriverValue(value: T['data']): T['driverParam'] {\n\t\treturn typeof this.mapTo === 'function' ? this.mapTo(value) : value as T['data'];\n\t}\n}\n\nexport interface CustomTypeValues {\n\t/**\n\t * Required type for custom column, that will infer proper type model\n\t *\n\t * Examples:\n\t *\n\t * If you want your column to be `string` type after selecting/or on inserting - use `data: string`. Like `text`, `varchar`\n\t *\n\t * If you want your column to be `number` type after selecting/or on inserting - use `data: number`. Like `integer`\n\t */\n\tdata: unknown;\n\n\t/**\n\t * Type helper, that represents what type database driver is accepting for specific database data type\n\t */\n\tdriverData?: unknown;\n\n\t/**\n\t * Type helper, that represents what type database driver is returning for specific database data type\n\t *\n\t * Needed only in case driver's output and input for type differ\n\t *\n\t * Defaults to {@link driverData}\n\t */\n\tdriverOutput?: unknown;\n\n\t/**\n\t * Type helper, that represents what type field returns after being aggregated to JSON\n\t */\n\tjsonData?: unknown;\n\n\t/**\n\t * What config type should be used for {@link CustomTypeParams} `dataType` generation\n\t */\n\tconfig?: Record<string, any>;\n\n\t/**\n\t * Whether the config argument should be required or not\n\t * @default false\n\t */\n\tconfigRequired?: boolean;\n\n\t/**\n\t * If your custom data type should be notNull by default you can use `notNull: true`\n\t *\n\t * @example\n\t * const customSerial = customType<{ data: number, notNull: true, default: true }>({\n\t * \t dataType() {\n\t * \t return 'serial';\n\t * },\n\t * });\n\t */\n\tnotNull?: boolean;\n\n\t/**\n\t * If your custom data type has default you can use `default: true`\n\t *\n\t * @example\n\t * const customSerial = customType<{ data: number, notNull: true, default: true }>({\n\t * \t dataType() {\n\t * \t return 'serial';\n\t * },\n\t * });\n\t */\n\tdefault?: boolean;\n}\n\nexport interface CustomTypeParams<T extends CustomTypeValues> {\n\t/**\n\t * Database data type string representation, that is used for migrations\n\t * @example\n\t * ```\n\t * `jsonb`, `text`\n\t * ```\n\t *\n\t * If database data type needs additional params you can use them from `config` param\n\t * @example\n\t * ```\n\t * `varchar(256)`, `numeric(2,3)`\n\t * ```\n\t *\n\t * To make `config` be of specific type please use config generic in {@link CustomTypeValues}\n\t *\n\t * @example\n\t * Usage example\n\t * ```\n\t * dataType() {\n\t * return 'boolean';\n\t * },\n\t * ```\n\t * Or\n\t * ```\n\t * dataType(config) {\n\t * \t return typeof config.length !== 'undefined' ? `varchar(${config.length})` : `varchar`;\n\t * \t }\n\t * ```\n\t */\n\tdataType: (config: T['config'] | (Equal<T['configRequired'], true> extends true ? never : undefined)) => string;\n\n\t/**\n\t * Optional mapping function, that is used to transform inputs from desired to be used in code format to one suitable for driver\n\t * @example\n\t * For example, when using jsonb we need to map JS/TS object to string before writing to database\n\t * ```\n\t * toDriver(value: TData): string {\n\t * \t return JSON.stringify(value);\n\t * }\n\t * ```\n\t */\n\ttoDriver?: (value: T['data']) => T['driverData'] | SQL;\n\n\t/**\n\t * Optional mapping function, that is used for transforming data returned by driver to desired column's output format\n\t * @example\n\t * For example, when using timestamp we need to map string Date representation to JS Date\n\t * ```\n\t * fromDriver(value: string): Date {\n\t * \treturn new Date(value);\n\t * }\n\t * ```\n\t *\n\t * It'll cause the returned data to change from:\n\t * ```\n\t * {\n\t * \tcustomField: \"2025-04-07T03:25:16.635Z\";\n\t * }\n\t * ```\n\t * to:\n\t * ```\n\t * {\n\t * \tcustomField: new Date(\"2025-04-07T03:25:16.635Z\");\n\t * }\n\t * ```\n\t */\n\tfromDriver?: (value: 'driverOutput' extends keyof T ? T['driverOutput'] : T['driverData']) => T['data'];\n\n\t/**\n\t * Optional mapping function, that is used for transforming data returned by transofmed to JSON in database data to desired format\n\t *\n\t * Used by [relational queries](https://orm.drizzle.team/docs/rqb-v2)\n\t *\n\t * Defaults to {@link fromDriver} function\n\t * @example\n\t * For example, when querying bigint column via [RQB](https://orm.drizzle.team/docs/rqb-v2) or [JSON functions](https://orm.drizzle.team/docs/json-functions), the result field will be returned as it's string representation, as opposed to bigint from regular query\n\t * To handle that, we need a separate function to handle such field's mapping:\n\t * ```\n\t * fromJson(value: string): bigint {\n\t * \treturn BigInt(value);\n\t * },\n\t * ```\n\t *\n\t * It'll cause the returned data to change from:\n\t * ```\n\t * {\n\t * \tcustomField: \"5044565289845416380\";\n\t * }\n\t * ```\n\t * to:\n\t * ```\n\t * {\n\t * \tcustomField: 5044565289845416380n;\n\t * }\n\t * ```\n\t */\n\tfromJson?: (value: T['jsonData']) => T['data'];\n\n\t/**\n\t * Optional selection modifier function, that is used for modifying selection of column inside [JSON functions](https://orm.drizzle.team/docs/json-functions)\n\t *\n\t * Additional mapping that could be required for such scenarios can be handled using {@link fromJson} function\n\t *\n\t * Used by [relational queries](https://orm.drizzle.team/docs/rqb-v2)\n\t *\n\t * Following types are being casted to text by default: `bytea`, `geometry`, `timestamp`, `numeric`, `bigint`\n\t * @example\n\t * For example, when using bigint we need to cast field to text to preserve data integrity\n\t * ```\n\t * forJsonSelect(identifier: SQL, sql: SQLGenerator, arrayDimensions?: number): SQL {\n\t * \treturn sql`${identifier}::text`\n\t * },\n\t * ```\n\t *\n\t * This will change query from:\n\t * ```\n\t * SELECT\n\t * \trow_to_json(\"t\".*)\n\t * \tFROM\n\t * \t(\n\t * \t\tSELECT\n\t * \t\t\"table\".\"custom_bigint\" AS \"bigint\"\n\t * \t\tFROM\n\t * \t\t\"table\"\n\t * \t) AS \"t\"\n\t * ```\n\t * to:\n\t * ```\n\t * SELECT\n\t * \trow_to_json(\"t\".*)\n\t * \tFROM\n\t * \t(\n\t * \t\tSELECT\n\t * \t\t\"table\".\"custom_bigint\"::text AS \"bigint\"\n\t * \t\tFROM\n\t * \t\t\"table\"\n\t * \t) AS \"t\"\n\t * ```\n\t *\n\t * Returned by query object will change from:\n\t * ```\n\t * {\n\t * \tbigint: 5044565289845416000; // Partial data loss due to direct conversion to JSON format\n\t * }\n\t * ```\n\t * to:\n\t * ```\n\t * {\n\t * \tbigint: \"5044565289845416380\"; // Data is preserved due to conversion of field to text before JSON-ification\n\t * }\n\t * ```\n\t */\n\tforJsonSelect?: (identifier: SQL, sql: SQLGenerator, arrayDimensions?: number) => SQL;\n}\n\n/**\n * Custom pg database data type generator\n */\nexport function customType<T extends CustomTypeValues = CustomTypeValues>(\n\tcustomTypeParams: CustomTypeParams<T>,\n): Equal<T['configRequired'], true> extends true ? {\n\t\t<TConfig extends Record<string, any> & T['config']>(\n\t\t\tfieldConfig: TConfig,\n\t\t): PgCustomColumnBuilder<ConvertCustomConfig<T>>;\n\t\t(\n\t\t\tdbName: string,\n\t\t\tfieldConfig: T['config'],\n\t\t): PgCustomColumnBuilder<ConvertCustomConfig<T>>;\n\t}\n\t: {\n\t\t<TConfig extends Record<string, any> & T['config']>(\n\t\t\tfieldConfig?: TConfig,\n\t\t): PgCustomColumnBuilder<ConvertCustomConfig<T>>;\n\t\t(\n\t\t\tdbName: string,\n\t\t\tfieldConfig?: T['config'],\n\t\t): PgCustomColumnBuilder<ConvertCustomConfig<T>>;\n\t}\n{\n\treturn (\n\t\ta?: string | T['config'],\n\t\tb?: T['config'],\n\t): PgCustomColumnBuilder<ConvertCustomConfig<T>> => {\n\t\tconst { name, config } = getColumnNameAndConfig<T['config']>(a, b);\n\t\treturn new PgCustomColumnBuilder(name, config, customTypeParams);\n\t};\n}\n"],"mappings":"AAEA,SAAS,kBAAkB;AAG3B,SAAqB,8BAA8B;AACnD,SAAS,UAAU,uBAAuB;AAenC,MAAM,8BAA2E,gBAMtF;AAAA,EACD,QAA0B,UAAU,IAAY;AAAA,EAEhD,YACC,MACA,aACA,kBACC;AACD,UAAM,MAAM,UAAU,gBAAgB;AACtC,SAAK,OAAO,cAAc;AAC1B,SAAK,OAAO,mBAAmB;AAAA,EAChC;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,uBAA6D,SAAY;AAAA,EACrF,QAA0B,UAAU,IAAY;AAAA,EAExC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EAER,YACC,OACA,QACC;AACD,UAAM,OAAO,MAAM;AACnB,SAAK,UAAU,OAAO,iBAAiB,SAAS,OAAO,WAAW;AAClE,SAAK,QAAQ,OAAO,iBAAiB;AACrC,SAAK,UAAU,OAAO,iBAAiB;AACvC,SAAK,UAAU,OAAO,iBAAiB;AACvC,SAAK,gBAAgB,OAAO,iBAAiB;AAAA,EAC9C;AAAA,EAEA,aAAqB;AACpB,WAAO,KAAK;AAAA,EACb;AAAA,EAES,mBAAmB,OAAoC;AAC/D,WAAO,OAAO,KAAK,YAAY,aAAa,KAAK,QAAQ,KAAK,IAAI;AAAA,EACnE;AAAA,EAEA,iBAAiB,OAA2B;AAC3C,WAAO,OAAO,KAAK,YAAY,aAAa,KAAK,QAAQ,KAAK,IAAI,KAAK,mBAAmB,KAAK;AAAA,EAChG;AAAA,EAEA,qBAAqB,YAAiB,KAAmB,iBAA+B;AACvF,QAAI,OAAO,KAAK,kBAAkB,WAAY,QAAO,KAAK,cAAc,YAAY,KAAK,eAAe;AAExG,UAAM,UAAU,KAAK,WAAW,EAAE,YAAY;AAC9C,UAAM,WAAW,QAAQ,QAAQ,GAAG;AACpC,UAAM,OAAQ,WAAW,IAAK,QAAQ,MAAM,GAAG,QAAQ,IAAI;AAE3D,YAAQ,MAAM;AAAA,MACb,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK,UAAU;AACd,cAAM,SAAS,KAAK,OAAO,mBAAmB,CAAC;AAE/C,eAAO,MAAM,UAAU,SAAS,IAAI,IAAI,MAAM,EAAE,GAAG,eAAe,CAAC;AAAA,MACpE;AAAA,MACA,SAAS;AACR,eAAO;AAAA,MACR;AAAA,IACD;AAAA,EACD;AAAA,EAES,iBAAiB,OAAoC;AAC7D,WAAO,OAAO,KAAK,UAAU,aAAa,KAAK,MAAM,KAAK,IAAI;AAAA,EAC/D;AACD;AAoOO,SAAS,WACf,kBAmBD;AACC,SAAO,CACN,GACA,MACmD;AACnD,UAAM,EAAE,MAAM,OAAO,IAAI,uBAAoC,GAAG,CAAC;AACjE,WAAO,IAAI,sBAAsB,MAAM,QAAQ,gBAAgB;AAAA,EAChE;AACD;","names":[]}
1
+ {"version":3,"sources":["../../../src/pg-core/columns/custom.ts"],"sourcesContent":["import type { ColumnBuilderBaseConfig } from '~/column-builder.ts';\nimport type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { PgTable } from '~/pg-core/table.ts';\nimport type { SQL, SQLGenerator } from '~/sql/sql.ts';\nimport { type Equal, getColumnNameAndConfig } from '~/utils.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport type ConvertCustomConfig<T extends Partial<CustomTypeValues>> =\n\t& {\n\t\tname: string;\n\t\tdataType: 'custom';\n\t\tdata: T['data'];\n\t\tdriverParam: T['driverData'];\n\t}\n\t& (T['notNull'] extends true ? { notNull: true } : {})\n\t& (T['default'] extends true ? { hasDefault: true } : {});\n\nexport interface PgCustomColumnInnerConfig {\n\tcustomTypeValues: CustomTypeValues;\n}\n\nexport class PgCustomColumnBuilder<T extends ColumnBuilderBaseConfig<'custom'>> extends PgColumnBuilder<\n\tT,\n\t{\n\t\tfieldConfig: CustomTypeValues['config'];\n\t\tcustomTypeParams: CustomTypeParams<any>;\n\t}\n> {\n\tstatic override readonly [entityKind]: string = 'PgCustomColumnBuilder';\n\n\tconstructor(\n\t\tname: string,\n\t\tfieldConfig: CustomTypeValues['config'],\n\t\tcustomTypeParams: CustomTypeParams<any>,\n\t) {\n\t\tsuper(name, 'custom', 'PgCustomColumn');\n\t\tthis.config.fieldConfig = fieldConfig;\n\t\tthis.config.customTypeParams = customTypeParams;\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgCustomColumn(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class PgCustomColumn<T extends ColumnBaseConfig<'custom'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgCustomColumn';\n\n\tprivate sqlName: string;\n\tprivate mapTo?: (value: T['data']) => T['driverParam'];\n\tprivate mapFrom?: (value: T['driverParam']) => T['data'];\n\tprivate mapJson?: (value: unknown) => T['data'];\n\tprivate forJsonSelect?: (identifier: SQL, sql: SQLGenerator, arrayDimensions?: number) => SQL;\n\n\tconstructor(\n\t\ttable: PgTable<any>,\n\t\tconfig: PgCustomColumnBuilder<T>['config'],\n\t) {\n\t\tsuper(table, config);\n\t\tthis.sqlName = config.customTypeParams.dataType(config.fieldConfig);\n\t\tthis.mapTo = config.customTypeParams.toDriver;\n\t\tthis.mapFrom = config.customTypeParams.fromDriver;\n\t\tthis.mapJson = config.customTypeParams.fromJson;\n\t\tthis.forJsonSelect = config.customTypeParams.forJsonSelect;\n\t}\n\n\tgetSQLType(): string {\n\t\treturn this.sqlName;\n\t}\n\n\toverride mapFromDriverValue(value: T['driverParam']): T['data'] {\n\t\treturn typeof this.mapFrom === 'function' ? this.mapFrom(value) : value as T['data'];\n\t}\n\n\tmapFromJsonValue(value: unknown): T['data'] {\n\t\treturn typeof this.mapJson === 'function' ? this.mapJson(value) : this.mapFromDriverValue(value) as T['data'];\n\t}\n\n\tjsonSelectIdentifier(identifier: SQL, sql: SQLGenerator, arrayDimensions?: number): SQL {\n\t\tif (typeof this.forJsonSelect === 'function') return this.forJsonSelect(identifier, sql, arrayDimensions);\n\n\t\tconst rawType = this.getSQLType().toLowerCase();\n\t\tconst parenPos = rawType.indexOf('(');\n\t\tconst type = (parenPos + 1) ? rawType.slice(0, parenPos) : rawType;\n\n\t\tswitch (type) {\n\t\t\tcase 'bytea':\n\t\t\tcase 'geometry':\n\t\t\tcase 'timestamp':\n\t\t\tcase 'numeric':\n\t\t\tcase 'bigint': {\n\t\t\t\tconst arrVal = '[]'.repeat(arrayDimensions ?? 0);\n\n\t\t\t\treturn sql`${identifier}::text${sql.raw(arrVal).if(arrayDimensions)}`;\n\t\t\t}\n\t\t\tdefault: {\n\t\t\t\treturn identifier;\n\t\t\t}\n\t\t}\n\t}\n\n\toverride mapToDriverValue(value: T['data']): T['driverParam'] {\n\t\treturn typeof this.mapTo === 'function' ? this.mapTo(value) : value as T['data'];\n\t}\n}\n\nexport interface CustomTypeValues {\n\t/**\n\t * Required type for custom column, that will infer proper type model\n\t *\n\t * Examples:\n\t *\n\t * If you want your column to be `string` type after selecting/or on inserting - use `data: string`. Like `text`, `varchar`\n\t *\n\t * If you want your column to be `number` type after selecting/or on inserting - use `data: number`. Like `integer`\n\t */\n\tdata: unknown;\n\n\t/**\n\t * Type helper, that represents what type database driver is accepting for specific database data type\n\t */\n\tdriverData?: unknown;\n\n\t/**\n\t * Type helper, that represents what type database driver is returning for specific database data type\n\t *\n\t * Needed only in case driver's output and input for type differ\n\t *\n\t * Defaults to {@link driverData}\n\t */\n\tdriverOutput?: unknown;\n\n\t/**\n\t * Type helper, that represents what type field returns after being aggregated to JSON\n\t */\n\tjsonData?: unknown;\n\n\t/**\n\t * What config type should be used for {@link CustomTypeParams} `dataType` generation\n\t */\n\tconfig?: Record<string, any>;\n\n\t/**\n\t * Whether the config argument should be required or not\n\t * @default false\n\t */\n\tconfigRequired?: boolean;\n\n\t/**\n\t * If your custom data type should be notNull by default you can use `notNull: true`\n\t *\n\t * @example\n\t * const customSerial = customType<{ data: number, notNull: true, default: true }>({\n\t * \t dataType() {\n\t * \t return 'serial';\n\t * },\n\t * });\n\t */\n\tnotNull?: boolean;\n\n\t/**\n\t * If your custom data type has default you can use `default: true`\n\t *\n\t * @example\n\t * const customSerial = customType<{ data: number, notNull: true, default: true }>({\n\t * \t dataType() {\n\t * \t return 'serial';\n\t * },\n\t * });\n\t */\n\tdefault?: boolean;\n}\n\nexport interface CustomTypeParams<T extends CustomTypeValues> {\n\t/**\n\t * Database data type string representation, that is used for migrations\n\t * @example\n\t * ```\n\t * `jsonb`, `text`\n\t * ```\n\t *\n\t * If database data type needs additional params you can use them from `config` param\n\t * @example\n\t * ```\n\t * `varchar(256)`, `numeric(2,3)`\n\t * ```\n\t *\n\t * To make `config` be of specific type please use config generic in {@link CustomTypeValues}\n\t *\n\t * @example\n\t * Usage example\n\t * ```\n\t * dataType() {\n\t * return 'boolean';\n\t * },\n\t * ```\n\t * Or\n\t * ```\n\t * dataType(config) {\n\t * \t return typeof config.length !== 'undefined' ? `varchar(${config.length})` : `varchar`;\n\t * \t }\n\t * ```\n\t */\n\tdataType: (config: T['config'] | (Equal<T['configRequired'], true> extends true ? never : undefined)) => string;\n\n\t/**\n\t * Optional mapping function, that is used to transform inputs from desired to be used in code format to one suitable for driver\n\t * @example\n\t * For example, when using jsonb we need to map JS/TS object to string before writing to database\n\t * ```\n\t * toDriver(value: TData): string {\n\t * \t return JSON.stringify(value);\n\t * }\n\t * ```\n\t */\n\ttoDriver?: (value: T['data']) => T['driverData'] | SQL;\n\n\t/**\n\t * Optional mapping function, that is used for transforming data returned by driver to desired column's output format\n\t * @example\n\t * For example, when using timestamp we need to map string Date representation to JS Date\n\t * ```\n\t * fromDriver(value: string): Date {\n\t * \treturn new Date(value);\n\t * }\n\t * ```\n\t *\n\t * It'll cause the returned data to change from:\n\t * ```\n\t * {\n\t * \tcustomField: \"2025-04-07T03:25:16.635Z\";\n\t * }\n\t * ```\n\t * to:\n\t * ```\n\t * {\n\t * \tcustomField: new Date(\"2025-04-07T03:25:16.635Z\");\n\t * }\n\t * ```\n\t */\n\tfromDriver?: (value: 'driverOutput' extends keyof T ? T['driverOutput'] : T['driverData']) => T['data'];\n\n\t/**\n\t * Optional mapping function, that is used for transforming data returned by transofmed to JSON in database data to desired format\n\t *\n\t * Used by [relational queries](https://orm.drizzle.team/docs/rqb-v2)\n\t *\n\t * Defaults to {@link fromDriver} function\n\t * @example\n\t * For example, when querying bigint column via [RQB](https://orm.drizzle.team/docs/rqb-v2) or [JSON functions](https://orm.drizzle.team/docs/json-functions), the result field will be returned as it's string representation, as opposed to bigint from regular query\n\t * To handle that, we need a separate function to handle such field's mapping:\n\t * ```\n\t * fromJson(value: string): bigint {\n\t * \treturn BigInt(value);\n\t * },\n\t * ```\n\t *\n\t * It'll cause the returned data to change from:\n\t * ```\n\t * {\n\t * \tcustomField: \"5044565289845416380\";\n\t * }\n\t * ```\n\t * to:\n\t * ```\n\t * {\n\t * \tcustomField: 5044565289845416380n;\n\t * }\n\t * ```\n\t */\n\tfromJson?: (value: T['jsonData']) => T['data'];\n\n\t/**\n\t * Optional selection modifier function, that is used for modifying selection of column inside [JSON functions](https://orm.drizzle.team/docs/json-functions)\n\t *\n\t * Additional mapping that could be required for such scenarios can be handled using {@link fromJson} function\n\t *\n\t * Used by [relational queries](https://orm.drizzle.team/docs/rqb-v2)\n\t *\n\t * Following types are being casted to text by default: `bytea`, `geometry`, `timestamp`, `numeric`, `bigint`\n\t * @example\n\t * For example, when using bigint we need to cast field to text to preserve data integrity\n\t * ```\n\t * forJsonSelect(identifier: SQL, sql: SQLGenerator, arrayDimensions?: number): SQL {\n\t * \treturn sql`${identifier}::text`\n\t * },\n\t * ```\n\t *\n\t * This will change query from:\n\t * ```\n\t * SELECT\n\t * \trow_to_json(\"t\".*)\n\t * \tFROM\n\t * \t(\n\t * \t\tSELECT\n\t * \t\t\"table\".\"custom_bigint\" AS \"bigint\"\n\t * \t\tFROM\n\t * \t\t\"table\"\n\t * \t) AS \"t\"\n\t * ```\n\t * to:\n\t * ```\n\t * SELECT\n\t * \trow_to_json(\"t\".*)\n\t * \tFROM\n\t * \t(\n\t * \t\tSELECT\n\t * \t\t\"table\".\"custom_bigint\"::text AS \"bigint\"\n\t * \t\tFROM\n\t * \t\t\"table\"\n\t * \t) AS \"t\"\n\t * ```\n\t *\n\t * Returned by query object will change from:\n\t * ```\n\t * {\n\t * \tbigint: 5044565289845416000; // Partial data loss due to direct conversion to JSON format\n\t * }\n\t * ```\n\t * to:\n\t * ```\n\t * {\n\t * \tbigint: \"5044565289845416380\"; // Data is preserved due to conversion of field to text before JSON-ification\n\t * }\n\t * ```\n\t */\n\tforJsonSelect?: (identifier: SQL, sql: SQLGenerator, arrayDimensions?: number) => SQL;\n}\n\n/**\n * Custom pg database data type generator\n */\nexport function customType<T extends CustomTypeValues = CustomTypeValues>(\n\tcustomTypeParams: CustomTypeParams<T>,\n): Equal<T['configRequired'], true> extends true ? {\n\t\t<TConfig extends Record<string, any> & T['config']>(\n\t\t\tfieldConfig: TConfig,\n\t\t): PgCustomColumnBuilder<ConvertCustomConfig<T>>;\n\t\t(\n\t\t\tdbName: string,\n\t\t\tfieldConfig: T['config'],\n\t\t): PgCustomColumnBuilder<ConvertCustomConfig<T>>;\n\t}\n\t: {\n\t\t<TConfig extends Record<string, any> & T['config']>(\n\t\t\tfieldConfig?: TConfig,\n\t\t): PgCustomColumnBuilder<ConvertCustomConfig<T>>;\n\t\t(\n\t\t\tdbName: string,\n\t\t\tfieldConfig?: T['config'],\n\t\t): PgCustomColumnBuilder<ConvertCustomConfig<T>>;\n\t}\n{\n\treturn (\n\t\ta?: string | T['config'],\n\t\tb?: T['config'],\n\t): PgCustomColumnBuilder<ConvertCustomConfig<T>> => {\n\t\tconst { name, config } = getColumnNameAndConfig<T['config']>(a, b);\n\t\treturn new PgCustomColumnBuilder(name as ConvertCustomConfig<T>['name'], config, customTypeParams);\n\t};\n}\n"],"mappings":"AAEA,SAAS,kBAAkB;AAG3B,SAAqB,8BAA8B;AACnD,SAAS,UAAU,uBAAuB;AAgBnC,MAAM,8BAA2E,gBAMtF;AAAA,EACD,QAA0B,UAAU,IAAY;AAAA,EAEhD,YACC,MACA,aACA,kBACC;AACD,UAAM,MAAM,UAAU,gBAAgB;AACtC,SAAK,OAAO,cAAc;AAC1B,SAAK,OAAO,mBAAmB;AAAA,EAChC;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,uBAA6D,SAAY;AAAA,EACrF,QAA0B,UAAU,IAAY;AAAA,EAExC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EAER,YACC,OACA,QACC;AACD,UAAM,OAAO,MAAM;AACnB,SAAK,UAAU,OAAO,iBAAiB,SAAS,OAAO,WAAW;AAClE,SAAK,QAAQ,OAAO,iBAAiB;AACrC,SAAK,UAAU,OAAO,iBAAiB;AACvC,SAAK,UAAU,OAAO,iBAAiB;AACvC,SAAK,gBAAgB,OAAO,iBAAiB;AAAA,EAC9C;AAAA,EAEA,aAAqB;AACpB,WAAO,KAAK;AAAA,EACb;AAAA,EAES,mBAAmB,OAAoC;AAC/D,WAAO,OAAO,KAAK,YAAY,aAAa,KAAK,QAAQ,KAAK,IAAI;AAAA,EACnE;AAAA,EAEA,iBAAiB,OAA2B;AAC3C,WAAO,OAAO,KAAK,YAAY,aAAa,KAAK,QAAQ,KAAK,IAAI,KAAK,mBAAmB,KAAK;AAAA,EAChG;AAAA,EAEA,qBAAqB,YAAiB,KAAmB,iBAA+B;AACvF,QAAI,OAAO,KAAK,kBAAkB,WAAY,QAAO,KAAK,cAAc,YAAY,KAAK,eAAe;AAExG,UAAM,UAAU,KAAK,WAAW,EAAE,YAAY;AAC9C,UAAM,WAAW,QAAQ,QAAQ,GAAG;AACpC,UAAM,OAAQ,WAAW,IAAK,QAAQ,MAAM,GAAG,QAAQ,IAAI;AAE3D,YAAQ,MAAM;AAAA,MACb,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK,UAAU;AACd,cAAM,SAAS,KAAK,OAAO,mBAAmB,CAAC;AAE/C,eAAO,MAAM,UAAU,SAAS,IAAI,IAAI,MAAM,EAAE,GAAG,eAAe,CAAC;AAAA,MACpE;AAAA,MACA,SAAS;AACR,eAAO;AAAA,MACR;AAAA,IACD;AAAA,EACD;AAAA,EAES,iBAAiB,OAAoC;AAC7D,WAAO,OAAO,KAAK,UAAU,aAAa,KAAK,MAAM,KAAK,IAAI;AAAA,EAC/D;AACD;AAoOO,SAAS,WACf,kBAmBD;AACC,SAAO,CACN,GACA,MACmD;AACnD,UAAM,EAAE,MAAM,OAAO,IAAI,uBAAoC,GAAG,CAAC;AACjE,WAAO,IAAI,sBAAsB,MAAwC,QAAQ,gBAAgB;AAAA,EAClG;AACD;","names":[]}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/pg-core/columns/date.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { PgTable } from '~/pg-core/table.ts';\nimport { type Equal, getColumnNameAndConfig } from '~/utils.ts';\nimport { PgColumn } from './common.ts';\nimport { PgDateColumnBaseBuilder } from './date.common.ts';\n\nexport class PgDateBuilder extends PgDateColumnBaseBuilder<{\n\tdataType: 'object date';\n\tdata: Date;\n\tdriverParam: string;\n}> {\n\tstatic override readonly [entityKind]: string = 'PgDateBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'object date', 'PgDate');\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgDate(table, this.config as any);\n\t}\n}\n\nexport class PgDate<T extends ColumnBaseConfig<'object date'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgDate';\n\n\tgetSQLType(): string {\n\t\treturn 'date';\n\t}\n\n\toverride mapFromDriverValue(value: string): Date {\n\t\treturn new Date(value);\n\t}\n\n\toverride mapToDriverValue(value: Date): string {\n\t\treturn value.toISOString();\n\t}\n}\n\nexport class PgDateStringBuilder extends PgDateColumnBaseBuilder<{\n\tdataType: 'string date';\n\tdata: string;\n\tdriverParam: string;\n}> {\n\tstatic override readonly [entityKind]: string = 'PgDateStringBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'string date', 'PgDateString');\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgDateString(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class PgDateString<T extends ColumnBaseConfig<'string date'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgDateString';\n\n\tgetSQLType(): string {\n\t\treturn 'date';\n\t}\n}\n\nexport interface PgDateConfig<T extends 'date' | 'string' = 'date' | 'string'> {\n\tmode: T;\n}\n\nexport function date<TMode extends PgDateConfig['mode'] & {}>(\n\tconfig?: PgDateConfig<TMode>,\n): Equal<TMode, 'date'> extends true ? PgDateBuilder : PgDateStringBuilder;\nexport function date<TMode extends PgDateConfig['mode'] & {}>(\n\tname: string,\n\tconfig?: PgDateConfig<TMode>,\n): Equal<TMode, 'date'> extends true ? PgDateBuilder : PgDateStringBuilder;\nexport function date(a?: string | PgDateConfig, b?: PgDateConfig) {\n\tconst { name, config } = getColumnNameAndConfig<PgDateConfig>(a, b);\n\tif (config?.mode === 'date') {\n\t\treturn new PgDateBuilder(name);\n\t}\n\treturn new PgDateStringBuilder(name);\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,oBAA2B;AAE3B,mBAAmD;AACnD,oBAAyB;AACzB,yBAAwC;AAEjC,MAAM,sBAAsB,2CAIhC;AAAA,EACF,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YAAY,MAAc;AACzB,UAAM,MAAM,eAAe,QAAQ;AAAA,EACpC;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI,OAAO,OAAO,KAAK,MAAa;AAAA,EAC5C;AACD;AAEO,MAAM,eAA0D,uBAAY;AAAA,EAClF,QAA0B,wBAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO;AAAA,EACR;AAAA,EAES,mBAAmB,OAAqB;AAChD,WAAO,IAAI,KAAK,KAAK;AAAA,EACtB;AAAA,EAES,iBAAiB,OAAqB;AAC9C,WAAO,MAAM,YAAY;AAAA,EAC1B;AACD;AAEO,MAAM,4BAA4B,2CAItC;AAAA,EACF,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YAAY,MAAc;AACzB,UAAM,MAAM,eAAe,cAAc;AAAA,EAC1C;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,qBAAgE,uBAAY;AAAA,EACxF,QAA0B,wBAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO;AAAA,EACR;AACD;AAaO,SAAS,KAAK,GAA2B,GAAkB;AACjE,QAAM,EAAE,MAAM,OAAO,QAAI,qCAAqC,GAAG,CAAC;AAClE,MAAI,QAAQ,SAAS,QAAQ;AAC5B,WAAO,IAAI,cAAc,IAAI;AAAA,EAC9B;AACA,SAAO,IAAI,oBAAoB,IAAI;AACpC;","names":[]}
1
+ {"version":3,"sources":["../../../src/pg-core/columns/date.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { PgTable } from '~/pg-core/table.ts';\nimport { type Equal, getColumnNameAndConfig } from '~/utils.ts';\nimport { PgColumn } from './common.ts';\nimport { PgDateColumnBaseBuilder } from './date.common.ts';\n\nexport class PgDateBuilder extends PgDateColumnBaseBuilder<{\n\tname: string;\n\tdataType: 'object date';\n\tdata: Date;\n\tdriverParam: string;\n}> {\n\tstatic override readonly [entityKind]: string = 'PgDateBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'object date', 'PgDate');\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgDate(table, this.config as any);\n\t}\n}\n\nexport class PgDate<T extends ColumnBaseConfig<'object date'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgDate';\n\n\tgetSQLType(): string {\n\t\treturn 'date';\n\t}\n\n\toverride mapFromDriverValue(value: string): Date {\n\t\treturn new Date(value);\n\t}\n\n\toverride mapToDriverValue(value: Date): string {\n\t\treturn value.toISOString();\n\t}\n}\n\nexport class PgDateStringBuilder extends PgDateColumnBaseBuilder<{\n\tname: string;\n\tdataType: 'string date';\n\tdata: string;\n\tdriverParam: string;\n}> {\n\tstatic override readonly [entityKind]: string = 'PgDateStringBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'string date', 'PgDateString');\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgDateString(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class PgDateString<T extends ColumnBaseConfig<'string date'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgDateString';\n\n\tgetSQLType(): string {\n\t\treturn 'date';\n\t}\n}\n\nexport interface PgDateConfig<T extends 'date' | 'string' = 'date' | 'string'> {\n\tmode: T;\n}\n\nexport function date<TMode extends PgDateConfig['mode'] & {}>(\n\tconfig?: PgDateConfig<TMode>,\n): Equal<TMode, 'date'> extends true ? PgDateBuilder : PgDateStringBuilder;\nexport function date<TMode extends PgDateConfig['mode'] & {}>(\n\tname: string,\n\tconfig?: PgDateConfig<TMode>,\n): Equal<TMode, 'date'> extends true ? PgDateBuilder : PgDateStringBuilder;\nexport function date(a?: string | PgDateConfig, b?: PgDateConfig) {\n\tconst { name, config } = getColumnNameAndConfig<PgDateConfig>(a, b);\n\tif (config?.mode === 'date') {\n\t\treturn new PgDateBuilder(name);\n\t}\n\treturn new PgDateStringBuilder(name);\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,oBAA2B;AAE3B,mBAAmD;AACnD,oBAAyB;AACzB,yBAAwC;AAEjC,MAAM,sBAAsB,2CAKhC;AAAA,EACF,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YAAY,MAAc;AACzB,UAAM,MAAM,eAAe,QAAQ;AAAA,EACpC;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI,OAAO,OAAO,KAAK,MAAa;AAAA,EAC5C;AACD;AAEO,MAAM,eAA0D,uBAAY;AAAA,EAClF,QAA0B,wBAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO;AAAA,EACR;AAAA,EAES,mBAAmB,OAAqB;AAChD,WAAO,IAAI,KAAK,KAAK;AAAA,EACtB;AAAA,EAES,iBAAiB,OAAqB;AAC9C,WAAO,MAAM,YAAY;AAAA,EAC1B;AACD;AAEO,MAAM,4BAA4B,2CAKtC;AAAA,EACF,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YAAY,MAAc;AACzB,UAAM,MAAM,eAAe,cAAc;AAAA,EAC1C;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,qBAAgE,uBAAY;AAAA,EACxF,QAA0B,wBAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO;AAAA,EACR;AACD;AAaO,SAAS,KAAK,GAA2B,GAAkB;AACjE,QAAM,EAAE,MAAM,OAAO,QAAI,qCAAqC,GAAG,CAAC;AAClE,MAAI,QAAQ,SAAS,QAAQ;AAC5B,WAAO,IAAI,cAAc,IAAI;AAAA,EAC9B;AACA,SAAO,IAAI,oBAAoB,IAAI;AACpC;","names":[]}
@@ -4,6 +4,7 @@ import { type Equal } from "../../utils.cjs";
4
4
  import { PgColumn } from "./common.cjs";
5
5
  import { PgDateColumnBaseBuilder } from "./date.common.cjs";
6
6
  export declare class PgDateBuilder extends PgDateColumnBaseBuilder<{
7
+ name: string;
7
8
  dataType: 'object date';
8
9
  data: Date;
9
10
  driverParam: string;
@@ -18,6 +19,7 @@ export declare class PgDate<T extends ColumnBaseConfig<'object date'>> extends P
18
19
  mapToDriverValue(value: Date): string;
19
20
  }
20
21
  export declare class PgDateStringBuilder extends PgDateColumnBaseBuilder<{
22
+ name: string;
21
23
  dataType: 'string date';
22
24
  data: string;
23
25
  driverParam: string;
@@ -4,6 +4,7 @@ import { type Equal } from "../../utils.js";
4
4
  import { PgColumn } from "./common.js";
5
5
  import { PgDateColumnBaseBuilder } from "./date.common.js";
6
6
  export declare class PgDateBuilder extends PgDateColumnBaseBuilder<{
7
+ name: string;
7
8
  dataType: 'object date';
8
9
  data: Date;
9
10
  driverParam: string;
@@ -18,6 +19,7 @@ export declare class PgDate<T extends ColumnBaseConfig<'object date'>> extends P
18
19
  mapToDriverValue(value: Date): string;
19
20
  }
20
21
  export declare class PgDateStringBuilder extends PgDateColumnBaseBuilder<{
22
+ name: string;
21
23
  dataType: 'string date';
22
24
  data: string;
23
25
  driverParam: string;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/pg-core/columns/date.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { PgTable } from '~/pg-core/table.ts';\nimport { type Equal, getColumnNameAndConfig } from '~/utils.ts';\nimport { PgColumn } from './common.ts';\nimport { PgDateColumnBaseBuilder } from './date.common.ts';\n\nexport class PgDateBuilder extends PgDateColumnBaseBuilder<{\n\tdataType: 'object date';\n\tdata: Date;\n\tdriverParam: string;\n}> {\n\tstatic override readonly [entityKind]: string = 'PgDateBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'object date', 'PgDate');\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgDate(table, this.config as any);\n\t}\n}\n\nexport class PgDate<T extends ColumnBaseConfig<'object date'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgDate';\n\n\tgetSQLType(): string {\n\t\treturn 'date';\n\t}\n\n\toverride mapFromDriverValue(value: string): Date {\n\t\treturn new Date(value);\n\t}\n\n\toverride mapToDriverValue(value: Date): string {\n\t\treturn value.toISOString();\n\t}\n}\n\nexport class PgDateStringBuilder extends PgDateColumnBaseBuilder<{\n\tdataType: 'string date';\n\tdata: string;\n\tdriverParam: string;\n}> {\n\tstatic override readonly [entityKind]: string = 'PgDateStringBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'string date', 'PgDateString');\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgDateString(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class PgDateString<T extends ColumnBaseConfig<'string date'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgDateString';\n\n\tgetSQLType(): string {\n\t\treturn 'date';\n\t}\n}\n\nexport interface PgDateConfig<T extends 'date' | 'string' = 'date' | 'string'> {\n\tmode: T;\n}\n\nexport function date<TMode extends PgDateConfig['mode'] & {}>(\n\tconfig?: PgDateConfig<TMode>,\n): Equal<TMode, 'date'> extends true ? PgDateBuilder : PgDateStringBuilder;\nexport function date<TMode extends PgDateConfig['mode'] & {}>(\n\tname: string,\n\tconfig?: PgDateConfig<TMode>,\n): Equal<TMode, 'date'> extends true ? PgDateBuilder : PgDateStringBuilder;\nexport function date(a?: string | PgDateConfig, b?: PgDateConfig) {\n\tconst { name, config } = getColumnNameAndConfig<PgDateConfig>(a, b);\n\tif (config?.mode === 'date') {\n\t\treturn new PgDateBuilder(name);\n\t}\n\treturn new PgDateStringBuilder(name);\n}\n"],"mappings":"AACA,SAAS,kBAAkB;AAE3B,SAAqB,8BAA8B;AACnD,SAAS,gBAAgB;AACzB,SAAS,+BAA+B;AAEjC,MAAM,sBAAsB,wBAIhC;AAAA,EACF,QAA0B,UAAU,IAAY;AAAA,EAEhD,YAAY,MAAc;AACzB,UAAM,MAAM,eAAe,QAAQ;AAAA,EACpC;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI,OAAO,OAAO,KAAK,MAAa;AAAA,EAC5C;AACD;AAEO,MAAM,eAA0D,SAAY;AAAA,EAClF,QAA0B,UAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO;AAAA,EACR;AAAA,EAES,mBAAmB,OAAqB;AAChD,WAAO,IAAI,KAAK,KAAK;AAAA,EACtB;AAAA,EAES,iBAAiB,OAAqB;AAC9C,WAAO,MAAM,YAAY;AAAA,EAC1B;AACD;AAEO,MAAM,4BAA4B,wBAItC;AAAA,EACF,QAA0B,UAAU,IAAY;AAAA,EAEhD,YAAY,MAAc;AACzB,UAAM,MAAM,eAAe,cAAc;AAAA,EAC1C;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,qBAAgE,SAAY;AAAA,EACxF,QAA0B,UAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO;AAAA,EACR;AACD;AAaO,SAAS,KAAK,GAA2B,GAAkB;AACjE,QAAM,EAAE,MAAM,OAAO,IAAI,uBAAqC,GAAG,CAAC;AAClE,MAAI,QAAQ,SAAS,QAAQ;AAC5B,WAAO,IAAI,cAAc,IAAI;AAAA,EAC9B;AACA,SAAO,IAAI,oBAAoB,IAAI;AACpC;","names":[]}
1
+ {"version":3,"sources":["../../../src/pg-core/columns/date.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { PgTable } from '~/pg-core/table.ts';\nimport { type Equal, getColumnNameAndConfig } from '~/utils.ts';\nimport { PgColumn } from './common.ts';\nimport { PgDateColumnBaseBuilder } from './date.common.ts';\n\nexport class PgDateBuilder extends PgDateColumnBaseBuilder<{\n\tname: string;\n\tdataType: 'object date';\n\tdata: Date;\n\tdriverParam: string;\n}> {\n\tstatic override readonly [entityKind]: string = 'PgDateBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'object date', 'PgDate');\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgDate(table, this.config as any);\n\t}\n}\n\nexport class PgDate<T extends ColumnBaseConfig<'object date'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgDate';\n\n\tgetSQLType(): string {\n\t\treturn 'date';\n\t}\n\n\toverride mapFromDriverValue(value: string): Date {\n\t\treturn new Date(value);\n\t}\n\n\toverride mapToDriverValue(value: Date): string {\n\t\treturn value.toISOString();\n\t}\n}\n\nexport class PgDateStringBuilder extends PgDateColumnBaseBuilder<{\n\tname: string;\n\tdataType: 'string date';\n\tdata: string;\n\tdriverParam: string;\n}> {\n\tstatic override readonly [entityKind]: string = 'PgDateStringBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'string date', 'PgDateString');\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgDateString(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class PgDateString<T extends ColumnBaseConfig<'string date'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgDateString';\n\n\tgetSQLType(): string {\n\t\treturn 'date';\n\t}\n}\n\nexport interface PgDateConfig<T extends 'date' | 'string' = 'date' | 'string'> {\n\tmode: T;\n}\n\nexport function date<TMode extends PgDateConfig['mode'] & {}>(\n\tconfig?: PgDateConfig<TMode>,\n): Equal<TMode, 'date'> extends true ? PgDateBuilder : PgDateStringBuilder;\nexport function date<TMode extends PgDateConfig['mode'] & {}>(\n\tname: string,\n\tconfig?: PgDateConfig<TMode>,\n): Equal<TMode, 'date'> extends true ? PgDateBuilder : PgDateStringBuilder;\nexport function date(a?: string | PgDateConfig, b?: PgDateConfig) {\n\tconst { name, config } = getColumnNameAndConfig<PgDateConfig>(a, b);\n\tif (config?.mode === 'date') {\n\t\treturn new PgDateBuilder(name);\n\t}\n\treturn new PgDateStringBuilder(name);\n}\n"],"mappings":"AACA,SAAS,kBAAkB;AAE3B,SAAqB,8BAA8B;AACnD,SAAS,gBAAgB;AACzB,SAAS,+BAA+B;AAEjC,MAAM,sBAAsB,wBAKhC;AAAA,EACF,QAA0B,UAAU,IAAY;AAAA,EAEhD,YAAY,MAAc;AACzB,UAAM,MAAM,eAAe,QAAQ;AAAA,EACpC;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI,OAAO,OAAO,KAAK,MAAa;AAAA,EAC5C;AACD;AAEO,MAAM,eAA0D,SAAY;AAAA,EAClF,QAA0B,UAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO;AAAA,EACR;AAAA,EAES,mBAAmB,OAAqB;AAChD,WAAO,IAAI,KAAK,KAAK;AAAA,EACtB;AAAA,EAES,iBAAiB,OAAqB;AAC9C,WAAO,MAAM,YAAY;AAAA,EAC1B;AACD;AAEO,MAAM,4BAA4B,wBAKtC;AAAA,EACF,QAA0B,UAAU,IAAY;AAAA,EAEhD,YAAY,MAAc;AACzB,UAAM,MAAM,eAAe,cAAc;AAAA,EAC1C;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,qBAAgE,SAAY;AAAA,EACxF,QAA0B,UAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO;AAAA,EACR;AACD;AAaO,SAAS,KAAK,GAA2B,GAAkB;AACjE,QAAM,EAAE,MAAM,OAAO,IAAI,uBAAqC,GAAG,CAAC;AAClE,MAAI,QAAQ,SAAS,QAAQ;AAC5B,WAAO,IAAI,cAAc,IAAI;AAAA,EAC9B;AACA,SAAO,IAAI,oBAAoB,IAAI;AACpC;","names":[]}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/pg-core/columns/double-precision.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { PgTable } from '~/pg-core/table.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport class PgDoublePrecisionBuilder extends PgColumnBuilder<{\n\tdataType: 'number double';\n\tdata: number;\n\tdriverParam: string | number;\n}> {\n\tstatic override readonly [entityKind]: string = 'PgDoublePrecisionBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'number double', 'PgDoublePrecision');\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgDoublePrecision(\n\t\t\ttable,\n\t\t\tthis.config,\n\t\t);\n\t}\n}\n\nexport class PgDoublePrecision<T extends ColumnBaseConfig<'number double'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgDoublePrecision';\n\n\tgetSQLType(): string {\n\t\treturn 'double precision';\n\t}\n\n\toverride mapFromDriverValue(value: string | number): number {\n\t\tif (typeof value === 'string') {\n\t\t\treturn Number.parseFloat(value);\n\t\t}\n\t\treturn value;\n\t}\n}\n\nexport function doublePrecision(name?: string): PgDoublePrecisionBuilder {\n\treturn new PgDoublePrecisionBuilder(name ?? '');\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,oBAA2B;AAE3B,oBAA0C;AAEnC,MAAM,iCAAiC,8BAI3C;AAAA,EACF,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YAAY,MAAc;AACzB,UAAM,MAAM,iBAAiB,mBAAmB;AAAA,EACjD;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,0BAAuE,uBAAY;AAAA,EAC/F,QAA0B,wBAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO;AAAA,EACR;AAAA,EAES,mBAAmB,OAAgC;AAC3D,QAAI,OAAO,UAAU,UAAU;AAC9B,aAAO,OAAO,WAAW,KAAK;AAAA,IAC/B;AACA,WAAO;AAAA,EACR;AACD;AAEO,SAAS,gBAAgB,MAAyC;AACxE,SAAO,IAAI,yBAAyB,QAAQ,EAAE;AAC/C;","names":[]}
1
+ {"version":3,"sources":["../../../src/pg-core/columns/double-precision.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { PgTable } from '~/pg-core/table.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport class PgDoublePrecisionBuilder extends PgColumnBuilder<{\n\tname: string;\n\tdataType: 'number double';\n\tdata: number;\n\tdriverParam: string | number;\n}> {\n\tstatic override readonly [entityKind]: string = 'PgDoublePrecisionBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'number double', 'PgDoublePrecision');\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgDoublePrecision(\n\t\t\ttable,\n\t\t\tthis.config,\n\t\t);\n\t}\n}\n\nexport class PgDoublePrecision<T extends ColumnBaseConfig<'number double'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgDoublePrecision';\n\n\tgetSQLType(): string {\n\t\treturn 'double precision';\n\t}\n\n\toverride mapFromDriverValue(value: string | number): number {\n\t\tif (typeof value === 'string') {\n\t\t\treturn Number.parseFloat(value);\n\t\t}\n\t\treturn value;\n\t}\n}\n\nexport function doublePrecision(name?: string): PgDoublePrecisionBuilder {\n\treturn new PgDoublePrecisionBuilder(name ?? '');\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,oBAA2B;AAE3B,oBAA0C;AAEnC,MAAM,iCAAiC,8BAK3C;AAAA,EACF,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YAAY,MAAc;AACzB,UAAM,MAAM,iBAAiB,mBAAmB;AAAA,EACjD;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,0BAAuE,uBAAY;AAAA,EAC/F,QAA0B,wBAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO;AAAA,EACR;AAAA,EAES,mBAAmB,OAAgC;AAC3D,QAAI,OAAO,UAAU,UAAU;AAC9B,aAAO,OAAO,WAAW,KAAK;AAAA,IAC/B;AACA,WAAO;AAAA,EACR;AACD;AAEO,SAAS,gBAAgB,MAAyC;AACxE,SAAO,IAAI,yBAAyB,QAAQ,EAAE;AAC/C;","names":[]}
@@ -2,6 +2,7 @@ import type { ColumnBaseConfig } from "../../column.cjs";
2
2
  import { entityKind } from "../../entity.cjs";
3
3
  import { PgColumn, PgColumnBuilder } from "./common.cjs";
4
4
  export declare class PgDoublePrecisionBuilder extends PgColumnBuilder<{
5
+ name: string;
5
6
  dataType: 'number double';
6
7
  data: number;
7
8
  driverParam: string | number;
@@ -2,6 +2,7 @@ import type { ColumnBaseConfig } from "../../column.js";
2
2
  import { entityKind } from "../../entity.js";
3
3
  import { PgColumn, PgColumnBuilder } from "./common.js";
4
4
  export declare class PgDoublePrecisionBuilder extends PgColumnBuilder<{
5
+ name: string;
5
6
  dataType: 'number double';
6
7
  data: number;
7
8
  driverParam: string | number;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/pg-core/columns/double-precision.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { PgTable } from '~/pg-core/table.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport class PgDoublePrecisionBuilder extends PgColumnBuilder<{\n\tdataType: 'number double';\n\tdata: number;\n\tdriverParam: string | number;\n}> {\n\tstatic override readonly [entityKind]: string = 'PgDoublePrecisionBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'number double', 'PgDoublePrecision');\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgDoublePrecision(\n\t\t\ttable,\n\t\t\tthis.config,\n\t\t);\n\t}\n}\n\nexport class PgDoublePrecision<T extends ColumnBaseConfig<'number double'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgDoublePrecision';\n\n\tgetSQLType(): string {\n\t\treturn 'double precision';\n\t}\n\n\toverride mapFromDriverValue(value: string | number): number {\n\t\tif (typeof value === 'string') {\n\t\t\treturn Number.parseFloat(value);\n\t\t}\n\t\treturn value;\n\t}\n}\n\nexport function doublePrecision(name?: string): PgDoublePrecisionBuilder {\n\treturn new PgDoublePrecisionBuilder(name ?? '');\n}\n"],"mappings":"AACA,SAAS,kBAAkB;AAE3B,SAAS,UAAU,uBAAuB;AAEnC,MAAM,iCAAiC,gBAI3C;AAAA,EACF,QAA0B,UAAU,IAAY;AAAA,EAEhD,YAAY,MAAc;AACzB,UAAM,MAAM,iBAAiB,mBAAmB;AAAA,EACjD;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,0BAAuE,SAAY;AAAA,EAC/F,QAA0B,UAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO;AAAA,EACR;AAAA,EAES,mBAAmB,OAAgC;AAC3D,QAAI,OAAO,UAAU,UAAU;AAC9B,aAAO,OAAO,WAAW,KAAK;AAAA,IAC/B;AACA,WAAO;AAAA,EACR;AACD;AAEO,SAAS,gBAAgB,MAAyC;AACxE,SAAO,IAAI,yBAAyB,QAAQ,EAAE;AAC/C;","names":[]}
1
+ {"version":3,"sources":["../../../src/pg-core/columns/double-precision.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { PgTable } from '~/pg-core/table.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport class PgDoublePrecisionBuilder extends PgColumnBuilder<{\n\tname: string;\n\tdataType: 'number double';\n\tdata: number;\n\tdriverParam: string | number;\n}> {\n\tstatic override readonly [entityKind]: string = 'PgDoublePrecisionBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'number double', 'PgDoublePrecision');\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgDoublePrecision(\n\t\t\ttable,\n\t\t\tthis.config,\n\t\t);\n\t}\n}\n\nexport class PgDoublePrecision<T extends ColumnBaseConfig<'number double'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgDoublePrecision';\n\n\tgetSQLType(): string {\n\t\treturn 'double precision';\n\t}\n\n\toverride mapFromDriverValue(value: string | number): number {\n\t\tif (typeof value === 'string') {\n\t\t\treturn Number.parseFloat(value);\n\t\t}\n\t\treturn value;\n\t}\n}\n\nexport function doublePrecision(name?: string): PgDoublePrecisionBuilder {\n\treturn new PgDoublePrecisionBuilder(name ?? '');\n}\n"],"mappings":"AACA,SAAS,kBAAkB;AAE3B,SAAS,UAAU,uBAAuB;AAEnC,MAAM,iCAAiC,gBAK3C;AAAA,EACF,QAA0B,UAAU,IAAY;AAAA,EAEhD,YAAY,MAAc;AACzB,UAAM,MAAM,iBAAiB,mBAAmB;AAAA,EACjD;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,0BAAuE,SAAY;AAAA,EAC/F,QAA0B,UAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO;AAAA,EACR;AAAA,EAES,mBAAmB,OAAgC;AAC3D,QAAI,OAAO,UAAU,UAAU;AAC9B,aAAO,OAAO,WAAW,KAAK;AAAA,IAC/B;AACA,WAAO;AAAA,EACR;AACD;AAEO,SAAS,gBAAgB,MAAyC;AACxE,SAAO,IAAI,yBAAyB,QAAQ,EAAE;AAC/C;","names":[]}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/pg-core/columns/enum.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { PgTable } from '~/pg-core/table.ts';\nimport type { NonArray, Writable } from '~/utils.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\n// Enum as ts enum\nexport interface PgEnumObject<TValues extends object> {\n\t(name?: string): PgEnumObjectColumnBuilder<TValues>;\n\n\treadonly enumName: string;\n\treadonly enumValues: string[];\n\treadonly schema: string | undefined;\n\t/** @internal */\n\t[isPgEnumSym]: true;\n}\n\nexport class PgEnumObjectColumnBuilder<\n\tTValues extends object,\n> extends PgColumnBuilder<{\n\tdataType: 'string enum';\n\tdata: TValues[keyof TValues];\n\tenumValues: string[];\n\tdriverParam: string;\n}, { enum: PgEnumObject<any> }> {\n\tstatic override readonly [entityKind]: string = 'PgEnumObjectColumnBuilder';\n\n\tconstructor(name: string, enumInstance: PgEnumObject<any>) {\n\t\tsuper(name, 'string enum', 'PgEnumObjectColumn');\n\t\tthis.config.enum = enumInstance;\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgEnumObjectColumn(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class PgEnumObjectColumn<T extends ColumnBaseConfig<'string enum'> & { enumValues: object }>\n\textends PgColumn<T, { enum: PgEnumObject<object> }>\n{\n\tstatic override readonly [entityKind]: string = 'PgEnumObjectColumn';\n\n\treadonly enum;\n\toverride readonly enumValues = this.config.enum.enumValues;\n\n\tconstructor(\n\t\ttable: PgTable<any>,\n\t\tconfig: PgEnumObjectColumnBuilder<T['enumValues']>['config'],\n\t) {\n\t\tsuper(table, config);\n\t\tthis.enum = config.enum;\n\t}\n\n\tgetSQLType(): string {\n\t\treturn this.enum.enumName;\n\t}\n}\n\n// Enum as string union\n\nconst isPgEnumSym = Symbol.for('drizzle:isPgEnum');\nexport interface PgEnum<TValues extends [string, ...string[]]> {\n\t(name?: string): PgEnumColumnBuilder<TValues>;\n\n\treadonly enumName: string;\n\treadonly enumValues: TValues;\n\treadonly schema: string | undefined;\n\t/** @internal */\n\t[isPgEnumSym]: true;\n}\n\nexport function isPgEnum(obj: unknown): obj is PgEnum<[string, ...string[]]> {\n\treturn !!obj && typeof obj === 'function' && isPgEnumSym in obj && obj[isPgEnumSym] === true;\n}\n\nexport class PgEnumColumnBuilder<\n\tTValues extends [string, ...string[]],\n> extends PgColumnBuilder<{\n\tdataType: 'string enum';\n\tdata: TValues[number];\n\tenumValues: TValues;\n\tdriverParam: string;\n}, { enum: PgEnum<TValues> }> {\n\tstatic override readonly [entityKind]: string = 'PgEnumColumnBuilder';\n\n\tconstructor(name: string, enumInstance: PgEnum<TValues>) {\n\t\tsuper(name, 'string enum', 'PgEnumColumn');\n\t\tthis.config.enum = enumInstance;\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgEnumColumn(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class PgEnumColumn<T extends ColumnBaseConfig<'string enum'> & { enumValues: [string, ...string[]] }>\n\textends PgColumn<T, { enum: PgEnum<T['enumValues']> }>\n{\n\tstatic override readonly [entityKind]: string = 'PgEnumColumn';\n\n\treadonly enum = this.config.enum;\n\toverride readonly enumValues = this.config.enum.enumValues;\n\n\tconstructor(\n\t\ttable: PgTable<any>,\n\t\tconfig: PgEnumColumnBuilder<T['enumValues']>['config'],\n\t) {\n\t\tsuper(table, config);\n\t\tthis.enum = config.enum;\n\t}\n\n\tgetSQLType(): string {\n\t\treturn this.enum.enumName;\n\t}\n}\n\nexport function pgEnum<U extends string, T extends Readonly<[U, ...U[]]>>(\n\tenumName: string,\n\tvalues: T | Writable<T>,\n): PgEnum<Writable<T>>;\n\nexport function pgEnum<E extends Record<string, string>>(\n\tenumName: string,\n\tenumObj: NonArray<E>,\n): PgEnumObject<E>;\n\nexport function pgEnum(\n\tenumName: any,\n\tinput: any,\n): any {\n\treturn Array.isArray(input)\n\t\t? pgEnumWithSchema(enumName, [...input] as [string, ...string[]], undefined)\n\t\t: pgEnumObjectWithSchema(enumName, input, undefined);\n}\n\n/** @internal */\nexport function pgEnumWithSchema<U extends string, T extends Readonly<[U, ...U[]]>>(\n\tenumName: string,\n\tvalues: T | Writable<T>,\n\tschema?: string,\n): PgEnum<Writable<T>> {\n\tconst enumInstance: PgEnum<Writable<T>> = Object.assign(\n\t\t(name?: string): PgEnumColumnBuilder<Writable<T>> => new PgEnumColumnBuilder(name ?? '', enumInstance),\n\t\t{\n\t\t\tenumName,\n\t\t\tenumValues: values,\n\t\t\tschema,\n\t\t\t[isPgEnumSym]: true,\n\t\t} as const,\n\t);\n\n\treturn enumInstance;\n}\n\n/** @internal */\nexport function pgEnumObjectWithSchema<T extends object>(\n\tenumName: string,\n\tvalues: T,\n\tschema?: string,\n): PgEnumObject<T> {\n\tconst enumInstance: PgEnumObject<T> = Object.assign(\n\t\t(name?: string): PgEnumObjectColumnBuilder<T> => new PgEnumObjectColumnBuilder(name ?? '', enumInstance),\n\t\t{\n\t\t\tenumName,\n\t\t\tenumValues: Object.values(values),\n\t\t\tschema,\n\t\t\t[isPgEnumSym]: true,\n\t\t} as const,\n\t);\n\n\treturn enumInstance;\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,oBAA2B;AAG3B,oBAA0C;AAanC,MAAM,kCAEH,8BAKsB;AAAA,EAC/B,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YAAY,MAAc,cAAiC;AAC1D,UAAM,MAAM,eAAe,oBAAoB;AAC/C,SAAK,OAAO,OAAO;AAAA,EACpB;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,2BACJ,uBACT;AAAA,EACC,QAA0B,wBAAU,IAAY;AAAA,EAEvC;AAAA,EACS,aAAa,KAAK,OAAO,KAAK;AAAA,EAEhD,YACC,OACA,QACC;AACD,UAAM,OAAO,MAAM;AACnB,SAAK,OAAO,OAAO;AAAA,EACpB;AAAA,EAEA,aAAqB;AACpB,WAAO,KAAK,KAAK;AAAA,EAClB;AACD;AAIA,MAAM,cAAc,OAAO,IAAI,kBAAkB;AAW1C,SAAS,SAAS,KAAoD;AAC5E,SAAO,CAAC,CAAC,OAAO,OAAO,QAAQ,cAAc,eAAe,OAAO,IAAI,WAAW,MAAM;AACzF;AAEO,MAAM,4BAEH,8BAKoB;AAAA,EAC7B,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YAAY,MAAc,cAA+B;AACxD,UAAM,MAAM,eAAe,cAAc;AACzC,SAAK,OAAO,OAAO;AAAA,EACpB;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,qBACJ,uBACT;AAAA,EACC,QAA0B,wBAAU,IAAY;AAAA,EAEvC,OAAO,KAAK,OAAO;AAAA,EACV,aAAa,KAAK,OAAO,KAAK;AAAA,EAEhD,YACC,OACA,QACC;AACD,UAAM,OAAO,MAAM;AACnB,SAAK,OAAO,OAAO;AAAA,EACpB;AAAA,EAEA,aAAqB;AACpB,WAAO,KAAK,KAAK;AAAA,EAClB;AACD;AAYO,SAAS,OACf,UACA,OACM;AACN,SAAO,MAAM,QAAQ,KAAK,IACvB,iBAAiB,UAAU,CAAC,GAAG,KAAK,GAA4B,MAAS,IACzE,uBAAuB,UAAU,OAAO,MAAS;AACrD;AAGO,SAAS,iBACf,UACA,QACA,QACsB;AACtB,QAAM,eAAoC,OAAO;AAAA,IAChD,CAAC,SAAoD,IAAI,oBAAoB,QAAQ,IAAI,YAAY;AAAA,IACrG;AAAA,MACC;AAAA,MACA,YAAY;AAAA,MACZ;AAAA,MACA,CAAC,WAAW,GAAG;AAAA,IAChB;AAAA,EACD;AAEA,SAAO;AACR;AAGO,SAAS,uBACf,UACA,QACA,QACkB;AAClB,QAAM,eAAgC,OAAO;AAAA,IAC5C,CAAC,SAAgD,IAAI,0BAA0B,QAAQ,IAAI,YAAY;AAAA,IACvG;AAAA,MACC;AAAA,MACA,YAAY,OAAO,OAAO,MAAM;AAAA,MAChC;AAAA,MACA,CAAC,WAAW,GAAG;AAAA,IAChB;AAAA,EACD;AAEA,SAAO;AACR;","names":[]}
1
+ {"version":3,"sources":["../../../src/pg-core/columns/enum.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { PgTable } from '~/pg-core/table.ts';\nimport type { NonArray, Writable } from '~/utils.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\n// Enum as ts enum\nexport interface PgEnumObject<TValues extends object> {\n\t(name?: string): PgEnumObjectColumnBuilder<TValues>;\n\n\treadonly enumName: string;\n\treadonly enumValues: string[];\n\treadonly schema: string | undefined;\n\t/** @internal */\n\t[isPgEnumSym]: true;\n}\n\nexport class PgEnumObjectColumnBuilder<\n\tTValues extends object,\n> extends PgColumnBuilder<{\n\tname: string;\n\tdataType: 'string enum';\n\tdata: TValues[keyof TValues];\n\tenumValues: string[];\n\tdriverParam: string;\n}, { enum: PgEnumObject<any> }> {\n\tstatic override readonly [entityKind]: string = 'PgEnumObjectColumnBuilder';\n\n\tconstructor(name: string, enumInstance: PgEnumObject<any>) {\n\t\tsuper(name, 'string enum', 'PgEnumObjectColumn');\n\t\tthis.config.enum = enumInstance;\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgEnumObjectColumn(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class PgEnumObjectColumn<T extends ColumnBaseConfig<'string enum'> & { enumValues: object }>\n\textends PgColumn<T, { enum: PgEnumObject<object> }>\n{\n\tstatic override readonly [entityKind]: string = 'PgEnumObjectColumn';\n\n\treadonly enum;\n\toverride readonly enumValues = this.config.enum.enumValues;\n\n\tconstructor(\n\t\ttable: PgTable<any>,\n\t\tconfig: PgEnumObjectColumnBuilder<T['enumValues']>['config'],\n\t) {\n\t\tsuper(table, config);\n\t\tthis.enum = config.enum;\n\t}\n\n\tgetSQLType(): string {\n\t\treturn this.enum.enumName;\n\t}\n}\n\n// Enum as string union\n\nconst isPgEnumSym = Symbol.for('drizzle:isPgEnum');\nexport interface PgEnum<TValues extends [string, ...string[]]> {\n\t(name?: string): PgEnumColumnBuilder<TValues>;\n\n\treadonly enumName: string;\n\treadonly enumValues: TValues;\n\treadonly schema: string | undefined;\n\t/** @internal */\n\t[isPgEnumSym]: true;\n}\n\nexport function isPgEnum(obj: unknown): obj is PgEnum<[string, ...string[]]> {\n\treturn !!obj && typeof obj === 'function' && isPgEnumSym in obj && obj[isPgEnumSym] === true;\n}\n\nexport class PgEnumColumnBuilder<\n\tTValues extends [string, ...string[]],\n> extends PgColumnBuilder<{\n\tname: string;\n\tdataType: 'string enum';\n\tdata: TValues[number];\n\tenumValues: TValues;\n\tdriverParam: string;\n}, { enum: PgEnum<TValues> }> {\n\tstatic override readonly [entityKind]: string = 'PgEnumColumnBuilder';\n\n\tconstructor(name: string, enumInstance: PgEnum<TValues>) {\n\t\tsuper(name, 'string enum', 'PgEnumColumn');\n\t\tthis.config.enum = enumInstance;\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgEnumColumn(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class PgEnumColumn<T extends ColumnBaseConfig<'string enum'> & { enumValues: [string, ...string[]] }>\n\textends PgColumn<T, { enum: PgEnum<T['enumValues']> }>\n{\n\tstatic override readonly [entityKind]: string = 'PgEnumColumn';\n\n\treadonly enum = this.config.enum;\n\toverride readonly enumValues = this.config.enum.enumValues;\n\n\tconstructor(\n\t\ttable: PgTable<any>,\n\t\tconfig: PgEnumColumnBuilder<T['enumValues']>['config'],\n\t) {\n\t\tsuper(table, config);\n\t\tthis.enum = config.enum;\n\t}\n\n\tgetSQLType(): string {\n\t\treturn this.enum.enumName;\n\t}\n}\n\nexport function pgEnum<U extends string, T extends Readonly<[U, ...U[]]>>(\n\tenumName: string,\n\tvalues: T | Writable<T>,\n): PgEnum<Writable<T>>;\n\nexport function pgEnum<E extends Record<string, string>>(\n\tenumName: string,\n\tenumObj: NonArray<E>,\n): PgEnumObject<E>;\n\nexport function pgEnum(\n\tenumName: any,\n\tinput: any,\n): any {\n\treturn Array.isArray(input)\n\t\t? pgEnumWithSchema(enumName, [...input] as [string, ...string[]], undefined)\n\t\t: pgEnumObjectWithSchema(enumName, input, undefined);\n}\n\n/** @internal */\nexport function pgEnumWithSchema<U extends string, T extends Readonly<[U, ...U[]]>>(\n\tenumName: string,\n\tvalues: T | Writable<T>,\n\tschema?: string,\n): PgEnum<Writable<T>> {\n\tconst enumInstance: PgEnum<Writable<T>> = Object.assign(\n\t\t(name?: string): PgEnumColumnBuilder<Writable<T>> => new PgEnumColumnBuilder(name ?? '', enumInstance),\n\t\t{\n\t\t\tenumName,\n\t\t\tenumValues: values,\n\t\t\tschema,\n\t\t\t[isPgEnumSym]: true,\n\t\t} as const,\n\t);\n\n\treturn enumInstance;\n}\n\n/** @internal */\nexport function pgEnumObjectWithSchema<T extends object>(\n\tenumName: string,\n\tvalues: T,\n\tschema?: string,\n): PgEnumObject<T> {\n\tconst enumInstance: PgEnumObject<T> = Object.assign(\n\t\t(name?: string): PgEnumObjectColumnBuilder<T> => new PgEnumObjectColumnBuilder(name ?? '', enumInstance),\n\t\t{\n\t\t\tenumName,\n\t\t\tenumValues: Object.values(values),\n\t\t\tschema,\n\t\t\t[isPgEnumSym]: true,\n\t\t} as const,\n\t);\n\n\treturn enumInstance;\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,oBAA2B;AAG3B,oBAA0C;AAanC,MAAM,kCAEH,8BAMsB;AAAA,EAC/B,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YAAY,MAAc,cAAiC;AAC1D,UAAM,MAAM,eAAe,oBAAoB;AAC/C,SAAK,OAAO,OAAO;AAAA,EACpB;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,2BACJ,uBACT;AAAA,EACC,QAA0B,wBAAU,IAAY;AAAA,EAEvC;AAAA,EACS,aAAa,KAAK,OAAO,KAAK;AAAA,EAEhD,YACC,OACA,QACC;AACD,UAAM,OAAO,MAAM;AACnB,SAAK,OAAO,OAAO;AAAA,EACpB;AAAA,EAEA,aAAqB;AACpB,WAAO,KAAK,KAAK;AAAA,EAClB;AACD;AAIA,MAAM,cAAc,OAAO,IAAI,kBAAkB;AAW1C,SAAS,SAAS,KAAoD;AAC5E,SAAO,CAAC,CAAC,OAAO,OAAO,QAAQ,cAAc,eAAe,OAAO,IAAI,WAAW,MAAM;AACzF;AAEO,MAAM,4BAEH,8BAMoB;AAAA,EAC7B,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YAAY,MAAc,cAA+B;AACxD,UAAM,MAAM,eAAe,cAAc;AACzC,SAAK,OAAO,OAAO;AAAA,EACpB;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,qBACJ,uBACT;AAAA,EACC,QAA0B,wBAAU,IAAY;AAAA,EAEvC,OAAO,KAAK,OAAO;AAAA,EACV,aAAa,KAAK,OAAO,KAAK;AAAA,EAEhD,YACC,OACA,QACC;AACD,UAAM,OAAO,MAAM;AACnB,SAAK,OAAO,OAAO;AAAA,EACpB;AAAA,EAEA,aAAqB;AACpB,WAAO,KAAK,KAAK;AAAA,EAClB;AACD;AAYO,SAAS,OACf,UACA,OACM;AACN,SAAO,MAAM,QAAQ,KAAK,IACvB,iBAAiB,UAAU,CAAC,GAAG,KAAK,GAA4B,MAAS,IACzE,uBAAuB,UAAU,OAAO,MAAS;AACrD;AAGO,SAAS,iBACf,UACA,QACA,QACsB;AACtB,QAAM,eAAoC,OAAO;AAAA,IAChD,CAAC,SAAoD,IAAI,oBAAoB,QAAQ,IAAI,YAAY;AAAA,IACrG;AAAA,MACC;AAAA,MACA,YAAY;AAAA,MACZ;AAAA,MACA,CAAC,WAAW,GAAG;AAAA,IAChB;AAAA,EACD;AAEA,SAAO;AACR;AAGO,SAAS,uBACf,UACA,QACA,QACkB;AAClB,QAAM,eAAgC,OAAO;AAAA,IAC5C,CAAC,SAAgD,IAAI,0BAA0B,QAAQ,IAAI,YAAY;AAAA,IACvG;AAAA,MACC;AAAA,MACA,YAAY,OAAO,OAAO,MAAM;AAAA,MAChC;AAAA,MACA,CAAC,WAAW,GAAG;AAAA,IAChB;AAAA,EACD;AAEA,SAAO;AACR;","names":[]}
@@ -10,6 +10,7 @@ export interface PgEnumObject<TValues extends object> {
10
10
  readonly schema: string | undefined;
11
11
  }
12
12
  export declare class PgEnumObjectColumnBuilder<TValues extends object> extends PgColumnBuilder<{
13
+ name: string;
13
14
  dataType: 'string enum';
14
15
  data: TValues[keyof TValues];
15
16
  enumValues: string[];
@@ -39,6 +40,7 @@ export interface PgEnum<TValues extends [string, ...string[]]> {
39
40
  }
40
41
  export declare function isPgEnum(obj: unknown): obj is PgEnum<[string, ...string[]]>;
41
42
  export declare class PgEnumColumnBuilder<TValues extends [string, ...string[]]> extends PgColumnBuilder<{
43
+ name: string;
42
44
  dataType: 'string enum';
43
45
  data: TValues[number];
44
46
  enumValues: TValues;
@@ -10,6 +10,7 @@ export interface PgEnumObject<TValues extends object> {
10
10
  readonly schema: string | undefined;
11
11
  }
12
12
  export declare class PgEnumObjectColumnBuilder<TValues extends object> extends PgColumnBuilder<{
13
+ name: string;
13
14
  dataType: 'string enum';
14
15
  data: TValues[keyof TValues];
15
16
  enumValues: string[];
@@ -39,6 +40,7 @@ export interface PgEnum<TValues extends [string, ...string[]]> {
39
40
  }
40
41
  export declare function isPgEnum(obj: unknown): obj is PgEnum<[string, ...string[]]>;
41
42
  export declare class PgEnumColumnBuilder<TValues extends [string, ...string[]]> extends PgColumnBuilder<{
43
+ name: string;
42
44
  dataType: 'string enum';
43
45
  data: TValues[number];
44
46
  enumValues: TValues;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/pg-core/columns/enum.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { PgTable } from '~/pg-core/table.ts';\nimport type { NonArray, Writable } from '~/utils.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\n// Enum as ts enum\nexport interface PgEnumObject<TValues extends object> {\n\t(name?: string): PgEnumObjectColumnBuilder<TValues>;\n\n\treadonly enumName: string;\n\treadonly enumValues: string[];\n\treadonly schema: string | undefined;\n\t/** @internal */\n\t[isPgEnumSym]: true;\n}\n\nexport class PgEnumObjectColumnBuilder<\n\tTValues extends object,\n> extends PgColumnBuilder<{\n\tdataType: 'string enum';\n\tdata: TValues[keyof TValues];\n\tenumValues: string[];\n\tdriverParam: string;\n}, { enum: PgEnumObject<any> }> {\n\tstatic override readonly [entityKind]: string = 'PgEnumObjectColumnBuilder';\n\n\tconstructor(name: string, enumInstance: PgEnumObject<any>) {\n\t\tsuper(name, 'string enum', 'PgEnumObjectColumn');\n\t\tthis.config.enum = enumInstance;\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgEnumObjectColumn(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class PgEnumObjectColumn<T extends ColumnBaseConfig<'string enum'> & { enumValues: object }>\n\textends PgColumn<T, { enum: PgEnumObject<object> }>\n{\n\tstatic override readonly [entityKind]: string = 'PgEnumObjectColumn';\n\n\treadonly enum;\n\toverride readonly enumValues = this.config.enum.enumValues;\n\n\tconstructor(\n\t\ttable: PgTable<any>,\n\t\tconfig: PgEnumObjectColumnBuilder<T['enumValues']>['config'],\n\t) {\n\t\tsuper(table, config);\n\t\tthis.enum = config.enum;\n\t}\n\n\tgetSQLType(): string {\n\t\treturn this.enum.enumName;\n\t}\n}\n\n// Enum as string union\n\nconst isPgEnumSym = Symbol.for('drizzle:isPgEnum');\nexport interface PgEnum<TValues extends [string, ...string[]]> {\n\t(name?: string): PgEnumColumnBuilder<TValues>;\n\n\treadonly enumName: string;\n\treadonly enumValues: TValues;\n\treadonly schema: string | undefined;\n\t/** @internal */\n\t[isPgEnumSym]: true;\n}\n\nexport function isPgEnum(obj: unknown): obj is PgEnum<[string, ...string[]]> {\n\treturn !!obj && typeof obj === 'function' && isPgEnumSym in obj && obj[isPgEnumSym] === true;\n}\n\nexport class PgEnumColumnBuilder<\n\tTValues extends [string, ...string[]],\n> extends PgColumnBuilder<{\n\tdataType: 'string enum';\n\tdata: TValues[number];\n\tenumValues: TValues;\n\tdriverParam: string;\n}, { enum: PgEnum<TValues> }> {\n\tstatic override readonly [entityKind]: string = 'PgEnumColumnBuilder';\n\n\tconstructor(name: string, enumInstance: PgEnum<TValues>) {\n\t\tsuper(name, 'string enum', 'PgEnumColumn');\n\t\tthis.config.enum = enumInstance;\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgEnumColumn(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class PgEnumColumn<T extends ColumnBaseConfig<'string enum'> & { enumValues: [string, ...string[]] }>\n\textends PgColumn<T, { enum: PgEnum<T['enumValues']> }>\n{\n\tstatic override readonly [entityKind]: string = 'PgEnumColumn';\n\n\treadonly enum = this.config.enum;\n\toverride readonly enumValues = this.config.enum.enumValues;\n\n\tconstructor(\n\t\ttable: PgTable<any>,\n\t\tconfig: PgEnumColumnBuilder<T['enumValues']>['config'],\n\t) {\n\t\tsuper(table, config);\n\t\tthis.enum = config.enum;\n\t}\n\n\tgetSQLType(): string {\n\t\treturn this.enum.enumName;\n\t}\n}\n\nexport function pgEnum<U extends string, T extends Readonly<[U, ...U[]]>>(\n\tenumName: string,\n\tvalues: T | Writable<T>,\n): PgEnum<Writable<T>>;\n\nexport function pgEnum<E extends Record<string, string>>(\n\tenumName: string,\n\tenumObj: NonArray<E>,\n): PgEnumObject<E>;\n\nexport function pgEnum(\n\tenumName: any,\n\tinput: any,\n): any {\n\treturn Array.isArray(input)\n\t\t? pgEnumWithSchema(enumName, [...input] as [string, ...string[]], undefined)\n\t\t: pgEnumObjectWithSchema(enumName, input, undefined);\n}\n\n/** @internal */\nexport function pgEnumWithSchema<U extends string, T extends Readonly<[U, ...U[]]>>(\n\tenumName: string,\n\tvalues: T | Writable<T>,\n\tschema?: string,\n): PgEnum<Writable<T>> {\n\tconst enumInstance: PgEnum<Writable<T>> = Object.assign(\n\t\t(name?: string): PgEnumColumnBuilder<Writable<T>> => new PgEnumColumnBuilder(name ?? '', enumInstance),\n\t\t{\n\t\t\tenumName,\n\t\t\tenumValues: values,\n\t\t\tschema,\n\t\t\t[isPgEnumSym]: true,\n\t\t} as const,\n\t);\n\n\treturn enumInstance;\n}\n\n/** @internal */\nexport function pgEnumObjectWithSchema<T extends object>(\n\tenumName: string,\n\tvalues: T,\n\tschema?: string,\n): PgEnumObject<T> {\n\tconst enumInstance: PgEnumObject<T> = Object.assign(\n\t\t(name?: string): PgEnumObjectColumnBuilder<T> => new PgEnumObjectColumnBuilder(name ?? '', enumInstance),\n\t\t{\n\t\t\tenumName,\n\t\t\tenumValues: Object.values(values),\n\t\t\tschema,\n\t\t\t[isPgEnumSym]: true,\n\t\t} as const,\n\t);\n\n\treturn enumInstance;\n}\n"],"mappings":"AACA,SAAS,kBAAkB;AAG3B,SAAS,UAAU,uBAAuB;AAanC,MAAM,kCAEH,gBAKsB;AAAA,EAC/B,QAA0B,UAAU,IAAY;AAAA,EAEhD,YAAY,MAAc,cAAiC;AAC1D,UAAM,MAAM,eAAe,oBAAoB;AAC/C,SAAK,OAAO,OAAO;AAAA,EACpB;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,2BACJ,SACT;AAAA,EACC,QAA0B,UAAU,IAAY;AAAA,EAEvC;AAAA,EACS,aAAa,KAAK,OAAO,KAAK;AAAA,EAEhD,YACC,OACA,QACC;AACD,UAAM,OAAO,MAAM;AACnB,SAAK,OAAO,OAAO;AAAA,EACpB;AAAA,EAEA,aAAqB;AACpB,WAAO,KAAK,KAAK;AAAA,EAClB;AACD;AAIA,MAAM,cAAc,OAAO,IAAI,kBAAkB;AAW1C,SAAS,SAAS,KAAoD;AAC5E,SAAO,CAAC,CAAC,OAAO,OAAO,QAAQ,cAAc,eAAe,OAAO,IAAI,WAAW,MAAM;AACzF;AAEO,MAAM,4BAEH,gBAKoB;AAAA,EAC7B,QAA0B,UAAU,IAAY;AAAA,EAEhD,YAAY,MAAc,cAA+B;AACxD,UAAM,MAAM,eAAe,cAAc;AACzC,SAAK,OAAO,OAAO;AAAA,EACpB;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,qBACJ,SACT;AAAA,EACC,QAA0B,UAAU,IAAY;AAAA,EAEvC,OAAO,KAAK,OAAO;AAAA,EACV,aAAa,KAAK,OAAO,KAAK;AAAA,EAEhD,YACC,OACA,QACC;AACD,UAAM,OAAO,MAAM;AACnB,SAAK,OAAO,OAAO;AAAA,EACpB;AAAA,EAEA,aAAqB;AACpB,WAAO,KAAK,KAAK;AAAA,EAClB;AACD;AAYO,SAAS,OACf,UACA,OACM;AACN,SAAO,MAAM,QAAQ,KAAK,IACvB,iBAAiB,UAAU,CAAC,GAAG,KAAK,GAA4B,MAAS,IACzE,uBAAuB,UAAU,OAAO,MAAS;AACrD;AAGO,SAAS,iBACf,UACA,QACA,QACsB;AACtB,QAAM,eAAoC,OAAO;AAAA,IAChD,CAAC,SAAoD,IAAI,oBAAoB,QAAQ,IAAI,YAAY;AAAA,IACrG;AAAA,MACC;AAAA,MACA,YAAY;AAAA,MACZ;AAAA,MACA,CAAC,WAAW,GAAG;AAAA,IAChB;AAAA,EACD;AAEA,SAAO;AACR;AAGO,SAAS,uBACf,UACA,QACA,QACkB;AAClB,QAAM,eAAgC,OAAO;AAAA,IAC5C,CAAC,SAAgD,IAAI,0BAA0B,QAAQ,IAAI,YAAY;AAAA,IACvG;AAAA,MACC;AAAA,MACA,YAAY,OAAO,OAAO,MAAM;AAAA,MAChC;AAAA,MACA,CAAC,WAAW,GAAG;AAAA,IAChB;AAAA,EACD;AAEA,SAAO;AACR;","names":[]}
1
+ {"version":3,"sources":["../../../src/pg-core/columns/enum.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { PgTable } from '~/pg-core/table.ts';\nimport type { NonArray, Writable } from '~/utils.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\n// Enum as ts enum\nexport interface PgEnumObject<TValues extends object> {\n\t(name?: string): PgEnumObjectColumnBuilder<TValues>;\n\n\treadonly enumName: string;\n\treadonly enumValues: string[];\n\treadonly schema: string | undefined;\n\t/** @internal */\n\t[isPgEnumSym]: true;\n}\n\nexport class PgEnumObjectColumnBuilder<\n\tTValues extends object,\n> extends PgColumnBuilder<{\n\tname: string;\n\tdataType: 'string enum';\n\tdata: TValues[keyof TValues];\n\tenumValues: string[];\n\tdriverParam: string;\n}, { enum: PgEnumObject<any> }> {\n\tstatic override readonly [entityKind]: string = 'PgEnumObjectColumnBuilder';\n\n\tconstructor(name: string, enumInstance: PgEnumObject<any>) {\n\t\tsuper(name, 'string enum', 'PgEnumObjectColumn');\n\t\tthis.config.enum = enumInstance;\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgEnumObjectColumn(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class PgEnumObjectColumn<T extends ColumnBaseConfig<'string enum'> & { enumValues: object }>\n\textends PgColumn<T, { enum: PgEnumObject<object> }>\n{\n\tstatic override readonly [entityKind]: string = 'PgEnumObjectColumn';\n\n\treadonly enum;\n\toverride readonly enumValues = this.config.enum.enumValues;\n\n\tconstructor(\n\t\ttable: PgTable<any>,\n\t\tconfig: PgEnumObjectColumnBuilder<T['enumValues']>['config'],\n\t) {\n\t\tsuper(table, config);\n\t\tthis.enum = config.enum;\n\t}\n\n\tgetSQLType(): string {\n\t\treturn this.enum.enumName;\n\t}\n}\n\n// Enum as string union\n\nconst isPgEnumSym = Symbol.for('drizzle:isPgEnum');\nexport interface PgEnum<TValues extends [string, ...string[]]> {\n\t(name?: string): PgEnumColumnBuilder<TValues>;\n\n\treadonly enumName: string;\n\treadonly enumValues: TValues;\n\treadonly schema: string | undefined;\n\t/** @internal */\n\t[isPgEnumSym]: true;\n}\n\nexport function isPgEnum(obj: unknown): obj is PgEnum<[string, ...string[]]> {\n\treturn !!obj && typeof obj === 'function' && isPgEnumSym in obj && obj[isPgEnumSym] === true;\n}\n\nexport class PgEnumColumnBuilder<\n\tTValues extends [string, ...string[]],\n> extends PgColumnBuilder<{\n\tname: string;\n\tdataType: 'string enum';\n\tdata: TValues[number];\n\tenumValues: TValues;\n\tdriverParam: string;\n}, { enum: PgEnum<TValues> }> {\n\tstatic override readonly [entityKind]: string = 'PgEnumColumnBuilder';\n\n\tconstructor(name: string, enumInstance: PgEnum<TValues>) {\n\t\tsuper(name, 'string enum', 'PgEnumColumn');\n\t\tthis.config.enum = enumInstance;\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgEnumColumn(\n\t\t\ttable,\n\t\t\tthis.config as any,\n\t\t);\n\t}\n}\n\nexport class PgEnumColumn<T extends ColumnBaseConfig<'string enum'> & { enumValues: [string, ...string[]] }>\n\textends PgColumn<T, { enum: PgEnum<T['enumValues']> }>\n{\n\tstatic override readonly [entityKind]: string = 'PgEnumColumn';\n\n\treadonly enum = this.config.enum;\n\toverride readonly enumValues = this.config.enum.enumValues;\n\n\tconstructor(\n\t\ttable: PgTable<any>,\n\t\tconfig: PgEnumColumnBuilder<T['enumValues']>['config'],\n\t) {\n\t\tsuper(table, config);\n\t\tthis.enum = config.enum;\n\t}\n\n\tgetSQLType(): string {\n\t\treturn this.enum.enumName;\n\t}\n}\n\nexport function pgEnum<U extends string, T extends Readonly<[U, ...U[]]>>(\n\tenumName: string,\n\tvalues: T | Writable<T>,\n): PgEnum<Writable<T>>;\n\nexport function pgEnum<E extends Record<string, string>>(\n\tenumName: string,\n\tenumObj: NonArray<E>,\n): PgEnumObject<E>;\n\nexport function pgEnum(\n\tenumName: any,\n\tinput: any,\n): any {\n\treturn Array.isArray(input)\n\t\t? pgEnumWithSchema(enumName, [...input] as [string, ...string[]], undefined)\n\t\t: pgEnumObjectWithSchema(enumName, input, undefined);\n}\n\n/** @internal */\nexport function pgEnumWithSchema<U extends string, T extends Readonly<[U, ...U[]]>>(\n\tenumName: string,\n\tvalues: T | Writable<T>,\n\tschema?: string,\n): PgEnum<Writable<T>> {\n\tconst enumInstance: PgEnum<Writable<T>> = Object.assign(\n\t\t(name?: string): PgEnumColumnBuilder<Writable<T>> => new PgEnumColumnBuilder(name ?? '', enumInstance),\n\t\t{\n\t\t\tenumName,\n\t\t\tenumValues: values,\n\t\t\tschema,\n\t\t\t[isPgEnumSym]: true,\n\t\t} as const,\n\t);\n\n\treturn enumInstance;\n}\n\n/** @internal */\nexport function pgEnumObjectWithSchema<T extends object>(\n\tenumName: string,\n\tvalues: T,\n\tschema?: string,\n): PgEnumObject<T> {\n\tconst enumInstance: PgEnumObject<T> = Object.assign(\n\t\t(name?: string): PgEnumObjectColumnBuilder<T> => new PgEnumObjectColumnBuilder(name ?? '', enumInstance),\n\t\t{\n\t\t\tenumName,\n\t\t\tenumValues: Object.values(values),\n\t\t\tschema,\n\t\t\t[isPgEnumSym]: true,\n\t\t} as const,\n\t);\n\n\treturn enumInstance;\n}\n"],"mappings":"AACA,SAAS,kBAAkB;AAG3B,SAAS,UAAU,uBAAuB;AAanC,MAAM,kCAEH,gBAMsB;AAAA,EAC/B,QAA0B,UAAU,IAAY;AAAA,EAEhD,YAAY,MAAc,cAAiC;AAC1D,UAAM,MAAM,eAAe,oBAAoB;AAC/C,SAAK,OAAO,OAAO;AAAA,EACpB;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,2BACJ,SACT;AAAA,EACC,QAA0B,UAAU,IAAY;AAAA,EAEvC;AAAA,EACS,aAAa,KAAK,OAAO,KAAK;AAAA,EAEhD,YACC,OACA,QACC;AACD,UAAM,OAAO,MAAM;AACnB,SAAK,OAAO,OAAO;AAAA,EACpB;AAAA,EAEA,aAAqB;AACpB,WAAO,KAAK,KAAK;AAAA,EAClB;AACD;AAIA,MAAM,cAAc,OAAO,IAAI,kBAAkB;AAW1C,SAAS,SAAS,KAAoD;AAC5E,SAAO,CAAC,CAAC,OAAO,OAAO,QAAQ,cAAc,eAAe,OAAO,IAAI,WAAW,MAAM;AACzF;AAEO,MAAM,4BAEH,gBAMoB;AAAA,EAC7B,QAA0B,UAAU,IAAY;AAAA,EAEhD,YAAY,MAAc,cAA+B;AACxD,UAAM,MAAM,eAAe,cAAc;AACzC,SAAK,OAAO,OAAO;AAAA,EACpB;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI;AAAA,MACV;AAAA,MACA,KAAK;AAAA,IACN;AAAA,EACD;AACD;AAEO,MAAM,qBACJ,SACT;AAAA,EACC,QAA0B,UAAU,IAAY;AAAA,EAEvC,OAAO,KAAK,OAAO;AAAA,EACV,aAAa,KAAK,OAAO,KAAK;AAAA,EAEhD,YACC,OACA,QACC;AACD,UAAM,OAAO,MAAM;AACnB,SAAK,OAAO,OAAO;AAAA,EACpB;AAAA,EAEA,aAAqB;AACpB,WAAO,KAAK,KAAK;AAAA,EAClB;AACD;AAYO,SAAS,OACf,UACA,OACM;AACN,SAAO,MAAM,QAAQ,KAAK,IACvB,iBAAiB,UAAU,CAAC,GAAG,KAAK,GAA4B,MAAS,IACzE,uBAAuB,UAAU,OAAO,MAAS;AACrD;AAGO,SAAS,iBACf,UACA,QACA,QACsB;AACtB,QAAM,eAAoC,OAAO;AAAA,IAChD,CAAC,SAAoD,IAAI,oBAAoB,QAAQ,IAAI,YAAY;AAAA,IACrG;AAAA,MACC;AAAA,MACA,YAAY;AAAA,MACZ;AAAA,MACA,CAAC,WAAW,GAAG;AAAA,IAChB;AAAA,EACD;AAEA,SAAO;AACR;AAGO,SAAS,uBACf,UACA,QACA,QACkB;AAClB,QAAM,eAAgC,OAAO;AAAA,IAC5C,CAAC,SAAgD,IAAI,0BAA0B,QAAQ,IAAI,YAAY;AAAA,IACvG;AAAA,MACC;AAAA,MACA,YAAY,OAAO,OAAO,MAAM;AAAA,MAChC;AAAA,MACA,CAAC,WAAW,GAAG;AAAA,IAChB;AAAA,EACD;AAEA,SAAO;AACR;","names":[]}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/pg-core/columns/inet.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { PgTable } from '../table.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport class PgInetBuilder extends PgColumnBuilder<{\n\tdataType: 'string inet';\n\tdata: string;\n\tdriverParam: string;\n}> {\n\tstatic override readonly [entityKind]: string = 'PgInetBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'string inet', 'PgInet');\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgInet(table, this.config as any);\n\t}\n}\n\nexport class PgInet<T extends ColumnBaseConfig<'string inet'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgInet';\n\n\tgetSQLType(): string {\n\t\treturn 'inet';\n\t}\n}\n\nexport function inet(name?: string): PgInetBuilder {\n\treturn new PgInetBuilder(name ?? '');\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,oBAA2B;AAE3B,oBAA0C;AAEnC,MAAM,sBAAsB,8BAIhC;AAAA,EACF,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YAAY,MAAc;AACzB,UAAM,MAAM,eAAe,QAAQ;AAAA,EACpC;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI,OAAO,OAAO,KAAK,MAAa;AAAA,EAC5C;AACD;AAEO,MAAM,eAA0D,uBAAY;AAAA,EAClF,QAA0B,wBAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO;AAAA,EACR;AACD;AAEO,SAAS,KAAK,MAA8B;AAClD,SAAO,IAAI,cAAc,QAAQ,EAAE;AACpC;","names":[]}
1
+ {"version":3,"sources":["../../../src/pg-core/columns/inet.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { PgTable } from '../table.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport class PgInetBuilder extends PgColumnBuilder<{\n\tname: string;\n\tdataType: 'string inet';\n\tdata: string;\n\tdriverParam: string;\n}> {\n\tstatic override readonly [entityKind]: string = 'PgInetBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'string inet', 'PgInet');\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgInet(table, this.config as any);\n\t}\n}\n\nexport class PgInet<T extends ColumnBaseConfig<'string inet'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgInet';\n\n\tgetSQLType(): string {\n\t\treturn 'inet';\n\t}\n}\n\nexport function inet(name?: string): PgInetBuilder {\n\treturn new PgInetBuilder(name ?? '');\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,oBAA2B;AAE3B,oBAA0C;AAEnC,MAAM,sBAAsB,8BAKhC;AAAA,EACF,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YAAY,MAAc;AACzB,UAAM,MAAM,eAAe,QAAQ;AAAA,EACpC;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI,OAAO,OAAO,KAAK,MAAa;AAAA,EAC5C;AACD;AAEO,MAAM,eAA0D,uBAAY;AAAA,EAClF,QAA0B,wBAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO;AAAA,EACR;AACD;AAEO,SAAS,KAAK,MAA8B;AAClD,SAAO,IAAI,cAAc,QAAQ,EAAE;AACpC;","names":[]}
@@ -2,6 +2,7 @@ import type { ColumnBaseConfig } from "../../column.cjs";
2
2
  import { entityKind } from "../../entity.cjs";
3
3
  import { PgColumn, PgColumnBuilder } from "./common.cjs";
4
4
  export declare class PgInetBuilder extends PgColumnBuilder<{
5
+ name: string;
5
6
  dataType: 'string inet';
6
7
  data: string;
7
8
  driverParam: string;
@@ -2,6 +2,7 @@ import type { ColumnBaseConfig } from "../../column.js";
2
2
  import { entityKind } from "../../entity.js";
3
3
  import { PgColumn, PgColumnBuilder } from "./common.js";
4
4
  export declare class PgInetBuilder extends PgColumnBuilder<{
5
+ name: string;
5
6
  dataType: 'string inet';
6
7
  data: string;
7
8
  driverParam: string;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/pg-core/columns/inet.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { PgTable } from '../table.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport class PgInetBuilder extends PgColumnBuilder<{\n\tdataType: 'string inet';\n\tdata: string;\n\tdriverParam: string;\n}> {\n\tstatic override readonly [entityKind]: string = 'PgInetBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'string inet', 'PgInet');\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgInet(table, this.config as any);\n\t}\n}\n\nexport class PgInet<T extends ColumnBaseConfig<'string inet'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgInet';\n\n\tgetSQLType(): string {\n\t\treturn 'inet';\n\t}\n}\n\nexport function inet(name?: string): PgInetBuilder {\n\treturn new PgInetBuilder(name ?? '');\n}\n"],"mappings":"AACA,SAAS,kBAAkB;AAE3B,SAAS,UAAU,uBAAuB;AAEnC,MAAM,sBAAsB,gBAIhC;AAAA,EACF,QAA0B,UAAU,IAAY;AAAA,EAEhD,YAAY,MAAc;AACzB,UAAM,MAAM,eAAe,QAAQ;AAAA,EACpC;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI,OAAO,OAAO,KAAK,MAAa;AAAA,EAC5C;AACD;AAEO,MAAM,eAA0D,SAAY;AAAA,EAClF,QAA0B,UAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO;AAAA,EACR;AACD;AAEO,SAAS,KAAK,MAA8B;AAClD,SAAO,IAAI,cAAc,QAAQ,EAAE;AACpC;","names":[]}
1
+ {"version":3,"sources":["../../../src/pg-core/columns/inet.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { PgTable } from '../table.ts';\nimport { PgColumn, PgColumnBuilder } from './common.ts';\n\nexport class PgInetBuilder extends PgColumnBuilder<{\n\tname: string;\n\tdataType: 'string inet';\n\tdata: string;\n\tdriverParam: string;\n}> {\n\tstatic override readonly [entityKind]: string = 'PgInetBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'string inet', 'PgInet');\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgInet(table, this.config as any);\n\t}\n}\n\nexport class PgInet<T extends ColumnBaseConfig<'string inet'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgInet';\n\n\tgetSQLType(): string {\n\t\treturn 'inet';\n\t}\n}\n\nexport function inet(name?: string): PgInetBuilder {\n\treturn new PgInetBuilder(name ?? '');\n}\n"],"mappings":"AACA,SAAS,kBAAkB;AAE3B,SAAS,UAAU,uBAAuB;AAEnC,MAAM,sBAAsB,gBAKhC;AAAA,EACF,QAA0B,UAAU,IAAY;AAAA,EAEhD,YAAY,MAAc;AACzB,UAAM,MAAM,eAAe,QAAQ;AAAA,EACpC;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI,OAAO,OAAO,KAAK,MAAa;AAAA,EAC5C;AACD;AAEO,MAAM,eAA0D,SAAY;AAAA,EAClF,QAA0B,UAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO;AAAA,EACR;AACD;AAEO,SAAS,KAAK,MAA8B;AAClD,SAAO,IAAI,cAAc,QAAQ,EAAE;AACpC;","names":[]}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/pg-core/columns/integer.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { PgTable } from '../table.ts';\nimport { PgColumn } from './common.ts';\nimport { PgIntColumnBaseBuilder } from './int.common.ts';\n\nexport class PgIntegerBuilder extends PgIntColumnBaseBuilder<{\n\tdataType: 'number int32';\n\tdata: number;\n\tdriverParam: number | string;\n}> {\n\tstatic override readonly [entityKind]: string = 'PgIntegerBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'number int32', 'PgInteger');\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgInteger(table, this.config as any);\n\t}\n}\n\nexport class PgInteger<T extends ColumnBaseConfig<'number int32'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgInteger';\n\n\tgetSQLType(): string {\n\t\treturn 'integer';\n\t}\n\n\toverride mapFromDriverValue(value: number | string): number {\n\t\tif (typeof value === 'string') {\n\t\t\treturn Number.parseInt(value);\n\t\t}\n\t\treturn value;\n\t}\n}\nexport function integer(name?: string): PgIntegerBuilder {\n\treturn new PgIntegerBuilder(name ?? '');\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,oBAA2B;AAE3B,oBAAyB;AACzB,wBAAuC;AAEhC,MAAM,yBAAyB,yCAInC;AAAA,EACF,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YAAY,MAAc;AACzB,UAAM,MAAM,gBAAgB,WAAW;AAAA,EACxC;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI,UAAU,OAAO,KAAK,MAAa;AAAA,EAC/C;AACD;AAEO,MAAM,kBAA8D,uBAAY;AAAA,EACtF,QAA0B,wBAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO;AAAA,EACR;AAAA,EAES,mBAAmB,OAAgC;AAC3D,QAAI,OAAO,UAAU,UAAU;AAC9B,aAAO,OAAO,SAAS,KAAK;AAAA,IAC7B;AACA,WAAO;AAAA,EACR;AACD;AACO,SAAS,QAAQ,MAAiC;AACxD,SAAO,IAAI,iBAAiB,QAAQ,EAAE;AACvC;","names":[]}
1
+ {"version":3,"sources":["../../../src/pg-core/columns/integer.ts"],"sourcesContent":["import type { ColumnBaseConfig } from '~/column.ts';\nimport { entityKind } from '~/entity.ts';\nimport type { PgTable } from '../table.ts';\nimport { PgColumn } from './common.ts';\nimport { PgIntColumnBaseBuilder } from './int.common.ts';\n\nexport class PgIntegerBuilder extends PgIntColumnBaseBuilder<{\n\tname: string;\n\tdataType: 'number int32';\n\tdata: number;\n\tdriverParam: number | string;\n}> {\n\tstatic override readonly [entityKind]: string = 'PgIntegerBuilder';\n\n\tconstructor(name: string) {\n\t\tsuper(name, 'number int32', 'PgInteger');\n\t}\n\n\t/** @internal */\n\toverride build(table: PgTable<any>) {\n\t\treturn new PgInteger(table, this.config as any);\n\t}\n}\n\nexport class PgInteger<T extends ColumnBaseConfig<'number int32'>> extends PgColumn<T> {\n\tstatic override readonly [entityKind]: string = 'PgInteger';\n\n\tgetSQLType(): string {\n\t\treturn 'integer';\n\t}\n\n\toverride mapFromDriverValue(value: number | string): number {\n\t\tif (typeof value === 'string') {\n\t\t\treturn Number.parseInt(value);\n\t\t}\n\t\treturn value;\n\t}\n}\nexport function integer(name?: string): PgIntegerBuilder {\n\treturn new PgIntegerBuilder(name ?? '');\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,oBAA2B;AAE3B,oBAAyB;AACzB,wBAAuC;AAEhC,MAAM,yBAAyB,yCAKnC;AAAA,EACF,QAA0B,wBAAU,IAAY;AAAA,EAEhD,YAAY,MAAc;AACzB,UAAM,MAAM,gBAAgB,WAAW;AAAA,EACxC;AAAA;AAAA,EAGS,MAAM,OAAqB;AACnC,WAAO,IAAI,UAAU,OAAO,KAAK,MAAa;AAAA,EAC/C;AACD;AAEO,MAAM,kBAA8D,uBAAY;AAAA,EACtF,QAA0B,wBAAU,IAAY;AAAA,EAEhD,aAAqB;AACpB,WAAO;AAAA,EACR;AAAA,EAES,mBAAmB,OAAgC;AAC3D,QAAI,OAAO,UAAU,UAAU;AAC9B,aAAO,OAAO,SAAS,KAAK;AAAA,IAC7B;AACA,WAAO;AAAA,EACR;AACD;AACO,SAAS,QAAQ,MAAiC;AACxD,SAAO,IAAI,iBAAiB,QAAQ,EAAE;AACvC;","names":[]}
@@ -3,6 +3,7 @@ import { entityKind } from "../../entity.cjs";
3
3
  import { PgColumn } from "./common.cjs";
4
4
  import { PgIntColumnBaseBuilder } from "./int.common.cjs";
5
5
  export declare class PgIntegerBuilder extends PgIntColumnBaseBuilder<{
6
+ name: string;
6
7
  dataType: 'number int32';
7
8
  data: number;
8
9
  driverParam: number | string;
@@ -3,6 +3,7 @@ import { entityKind } from "../../entity.js";
3
3
  import { PgColumn } from "./common.js";
4
4
  import { PgIntColumnBaseBuilder } from "./int.common.js";
5
5
  export declare class PgIntegerBuilder extends PgIntColumnBaseBuilder<{
6
+ name: string;
6
7
  dataType: 'number int32';
7
8
  data: number;
8
9
  driverParam: number | string;