@vandenberghinc/volt 1.2.5 → 1.2.6

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 (489) hide show
  1. package/frontend/assets/admin/admin.png +0 -0
  2. package/frontend/assets/admin/password.webp +0 -0
  3. package/frontend/assets/icons/arrow.v1.webp +0 -0
  4. package/frontend/assets/icons/copy.webp +0 -0
  5. package/frontend/assets/payments/arrow.long.webp +0 -0
  6. package/frontend/assets/payments/arrow.long2.webp +0 -0
  7. package/frontend/assets/payments/cancelled.webp +0 -0
  8. package/frontend/assets/payments/check.sign.webp +0 -0
  9. package/frontend/assets/payments/check.webp +0 -0
  10. package/frontend/assets/payments/close.webp +0 -0
  11. package/frontend/assets/payments/error.webp +0 -0
  12. package/frontend/assets/payments/exclamation.webp +0 -0
  13. package/frontend/assets/payments/minus.webp +0 -0
  14. package/frontend/assets/payments/party.webp +0 -0
  15. package/frontend/assets/payments/plus.webp +0 -0
  16. package/frontend/assets/payments/shopping_cart.webp +0 -0
  17. package/frontend/assets/payments/trash.webp +0 -0
  18. package/package.json +5 -1
  19. package/.libris/config.json +0 -82
  20. package/backend/dist/cjs/backend/src/blacklist.d.ts +0 -12
  21. package/backend/dist/cjs/backend/src/blacklist.js +0 -78
  22. package/backend/dist/cjs/backend/src/cli.d.ts +0 -2
  23. package/backend/dist/cjs/backend/src/cli.js +0 -198
  24. package/backend/dist/cjs/backend/src/database/collection.d.ts +0 -1765
  25. package/backend/dist/cjs/backend/src/database/collection.js +0 -3301
  26. package/backend/dist/cjs/backend/src/database/database.d.ts +0 -92
  27. package/backend/dist/cjs/backend/src/database/database.js +0 -170
  28. package/backend/dist/cjs/backend/src/database/document.d.ts +0 -1
  29. package/backend/dist/cjs/backend/src/database/document.js +0 -15
  30. package/backend/dist/cjs/backend/src/database/filters/filters.d.ts +0 -6
  31. package/backend/dist/cjs/backend/src/database/filters/filters.js +0 -15
  32. package/backend/dist/cjs/backend/src/database/filters/strict_filter.d.ts +0 -223
  33. package/backend/dist/cjs/backend/src/database/filters/strict_filter.js +0 -15
  34. package/backend/dist/cjs/backend/src/database/filters/strict_filter_test.d.ts +0 -1
  35. package/backend/dist/cjs/backend/src/database/filters/strict_filter_test.js +0 -443
  36. package/backend/dist/cjs/backend/src/database/filters/strict_filter_test_v0.d.ts +0 -1
  37. package/backend/dist/cjs/backend/src/database/filters/strict_filter_test_v0.js +0 -15
  38. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v0.d.ts +0 -50
  39. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v0.js +0 -15
  40. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v1.d.ts +0 -76
  41. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v1.js +0 -15
  42. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v2.d.ts +0 -75
  43. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v2.js +0 -15
  44. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v3.d.ts +0 -219
  45. package/backend/dist/cjs/backend/src/database/filters/strict_filter_v3.js +0 -15
  46. package/backend/dist/cjs/backend/src/database/filters/strict_update_filter.d.ts +0 -165
  47. package/backend/dist/cjs/backend/src/database/filters/strict_update_filter.js +0 -15
  48. package/backend/dist/cjs/backend/src/database/filters/strict_update_filter_test.d.ts +0 -5
  49. package/backend/dist/cjs/backend/src/database/filters/strict_update_filter_test.js +0 -355
  50. package/backend/dist/cjs/backend/src/database/flatten.d.ts +0 -78
  51. package/backend/dist/cjs/backend/src/database/flatten.js +0 -53
  52. package/backend/dist/cjs/backend/src/database/flatten_test.d.ts +0 -1
  53. package/backend/dist/cjs/backend/src/database/flatten_test.js +0 -175
  54. package/backend/dist/cjs/backend/src/database/quota/quoata_v2.d.ts +0 -533
  55. package/backend/dist/cjs/backend/src/database/quota/quoata_v2.js +0 -1046
  56. package/backend/dist/cjs/backend/src/database/quota/quota.d.ts +0 -551
  57. package/backend/dist/cjs/backend/src/database/quota/quota.js +0 -1108
  58. package/backend/dist/cjs/backend/src/database/quota/quota_v1.d.ts +0 -534
  59. package/backend/dist/cjs/backend/src/database/quota/quota_v1.js +0 -1087
  60. package/backend/dist/cjs/backend/src/database/quota/safe_int.d.ts +0 -412
  61. package/backend/dist/cjs/backend/src/database/quota/safe_int.js +0 -745
  62. package/backend/dist/cjs/backend/src/endpoint.d.ts +0 -346
  63. package/backend/dist/cjs/backend/src/endpoint.js +0 -468
  64. package/backend/dist/cjs/backend/src/errors/index.d.ts +0 -7
  65. package/backend/dist/cjs/backend/src/errors/index.js +0 -25
  66. package/backend/dist/cjs/backend/src/errors/internal_external.d.ts +0 -52
  67. package/backend/dist/cjs/backend/src/errors/internal_external.js +0 -95
  68. package/backend/dist/cjs/backend/src/errors/invalid_usage_error.d.ts +0 -41
  69. package/backend/dist/cjs/backend/src/errors/invalid_usage_error.js +0 -47
  70. package/backend/dist/cjs/backend/src/errors/system_error.d.ts +0 -261
  71. package/backend/dist/cjs/backend/src/errors/system_error.js +0 -436
  72. package/backend/dist/cjs/backend/src/events.d.ts +0 -97
  73. package/backend/dist/cjs/backend/src/events.js +0 -15
  74. package/backend/dist/cjs/backend/src/frontend.d.ts +0 -11
  75. package/backend/dist/cjs/backend/src/frontend.js +0 -37
  76. package/backend/dist/cjs/backend/src/image_endpoint.d.ts +0 -44
  77. package/backend/dist/cjs/backend/src/image_endpoint.js +0 -185
  78. package/backend/dist/cjs/backend/src/index.d.ts +0 -23
  79. package/backend/dist/cjs/backend/src/index.js +0 -70
  80. package/backend/dist/cjs/backend/src/logger.d.ts +0 -5
  81. package/backend/dist/cjs/backend/src/logger.js +0 -15
  82. package/backend/dist/cjs/backend/src/meta.d.ts +0 -112
  83. package/backend/dist/cjs/backend/src/meta.js +0 -181
  84. package/backend/dist/cjs/backend/src/payments/paddle.d.ts +0 -329
  85. package/backend/dist/cjs/backend/src/payments/paddle.js +0 -1996
  86. package/backend/dist/cjs/backend/src/payments/stripe/checkout.d.ts +0 -113
  87. package/backend/dist/cjs/backend/src/payments/stripe/checkout.js +0 -295
  88. package/backend/dist/cjs/backend/src/payments/stripe/customers.d.ts +0 -17
  89. package/backend/dist/cjs/backend/src/payments/stripe/customers.js +0 -164
  90. package/backend/dist/cjs/backend/src/payments/stripe/error.d.ts +0 -74
  91. package/backend/dist/cjs/backend/src/payments/stripe/error.js +0 -64
  92. package/backend/dist/cjs/backend/src/payments/stripe/events.d.ts +0 -155
  93. package/backend/dist/cjs/backend/src/payments/stripe/events.js +0 -15
  94. package/backend/dist/cjs/backend/src/payments/stripe/meters.d.ts +0 -105
  95. package/backend/dist/cjs/backend/src/payments/stripe/meters.js +0 -230
  96. package/backend/dist/cjs/backend/src/payments/stripe/payment_methods.d.ts +0 -58
  97. package/backend/dist/cjs/backend/src/payments/stripe/payment_methods.js +0 -109
  98. package/backend/dist/cjs/backend/src/payments/stripe/products.d.ts +0 -519
  99. package/backend/dist/cjs/backend/src/payments/stripe/products.js +0 -650
  100. package/backend/dist/cjs/backend/src/payments/stripe/stripe.d.ts +0 -215
  101. package/backend/dist/cjs/backend/src/payments/stripe/stripe.js +0 -468
  102. package/backend/dist/cjs/backend/src/payments/stripe/subscriptions.d.ts +0 -172
  103. package/backend/dist/cjs/backend/src/payments/stripe/subscriptions.js +0 -557
  104. package/backend/dist/cjs/backend/src/payments/stripe/utils.d.ts +0 -63
  105. package/backend/dist/cjs/backend/src/payments/stripe/utils.js +0 -118
  106. package/backend/dist/cjs/backend/src/payments/stripe/webhooks.d.ts +0 -105
  107. package/backend/dist/cjs/backend/src/payments/stripe/webhooks.js +0 -627
  108. package/backend/dist/cjs/backend/src/plugins/browser.d.ts +0 -1
  109. package/backend/dist/cjs/backend/src/plugins/browser.js +0 -15
  110. package/backend/dist/cjs/backend/src/plugins/communication.d.ts +0 -70
  111. package/backend/dist/cjs/backend/src/plugins/communication.js +0 -196
  112. package/backend/dist/cjs/backend/src/plugins/mail/mail.d.ts +0 -255
  113. package/backend/dist/cjs/backend/src/plugins/mail/mail.js +0 -381
  114. package/backend/dist/cjs/backend/src/plugins/mail/ui.d.ts +0 -297
  115. package/backend/dist/cjs/backend/src/plugins/mail/ui.js +0 -1370
  116. package/backend/dist/cjs/backend/src/plugins/pdf.d.ts +0 -1
  117. package/backend/dist/cjs/backend/src/plugins/pdf.js +0 -1456
  118. package/backend/dist/cjs/backend/src/plugins/thread_monitor.d.ts +0 -18
  119. package/backend/dist/cjs/backend/src/plugins/thread_monitor.js +0 -116
  120. package/backend/dist/cjs/backend/src/rate_limit.d.ts +0 -148
  121. package/backend/dist/cjs/backend/src/rate_limit.js +0 -543
  122. package/backend/dist/cjs/backend/src/route.d.ts +0 -39
  123. package/backend/dist/cjs/backend/src/route.js +0 -172
  124. package/backend/dist/cjs/backend/src/server.d.ts +0 -502
  125. package/backend/dist/cjs/backend/src/server.js +0 -1713
  126. package/backend/dist/cjs/backend/src/server.old.d.ts +0 -594
  127. package/backend/dist/cjs/backend/src/server.old.js +0 -2058
  128. package/backend/dist/cjs/backend/src/splash_screen.d.ts +0 -93
  129. package/backend/dist/cjs/backend/src/splash_screen.js +0 -119
  130. package/backend/dist/cjs/backend/src/status.d.ts +0 -89
  131. package/backend/dist/cjs/backend/src/status.js +0 -211
  132. package/backend/dist/cjs/backend/src/stream.d.ts +0 -494
  133. package/backend/dist/cjs/backend/src/stream.js +0 -1370
  134. package/backend/dist/cjs/backend/src/users.d.ts +0 -926
  135. package/backend/dist/cjs/backend/src/users.js +0 -2223
  136. package/backend/dist/cjs/backend/src/utils.d.ts +0 -22
  137. package/backend/dist/cjs/backend/src/utils.js +0 -626
  138. package/backend/dist/cjs/backend/src/view.d.ts +0 -115
  139. package/backend/dist/cjs/backend/src/view.js +0 -519
  140. package/backend/dist/cjs/backend/src/vinc.d.ts +0 -6
  141. package/backend/dist/cjs/backend/src/vinc.js +0 -40
  142. package/backend/dist/cjs/backend/src/volt.d.ts +0 -24
  143. package/backend/dist/cjs/backend/src/volt.js +0 -72
  144. package/backend/dist/cjs/frontend/src/modules/request.d.ts +0 -70
  145. package/backend/dist/cjs/frontend/src/modules/request.js +0 -99
  146. package/backend/dist/cjs/package.json +0 -1
  147. package/backend/dist/esm/backend/src/blacklist.d.ts +0 -12
  148. package/backend/dist/esm/backend/src/blacklist.js +0 -52
  149. package/backend/dist/esm/backend/src/cli.d.ts +0 -2
  150. package/backend/dist/esm/backend/src/cli.js +0 -211
  151. package/backend/dist/esm/backend/src/database/collection.d.ts +0 -1765
  152. package/backend/dist/esm/backend/src/database/collection.js +0 -3779
  153. package/backend/dist/esm/backend/src/database/database.d.ts +0 -92
  154. package/backend/dist/esm/backend/src/database/database.js +0 -214
  155. package/backend/dist/esm/backend/src/database/document.d.ts +0 -1
  156. package/backend/dist/esm/backend/src/database/document.js +0 -558
  157. package/backend/dist/esm/backend/src/database/filters/filters.d.ts +0 -6
  158. package/backend/dist/esm/backend/src/database/filters/filters.js +0 -1
  159. package/backend/dist/esm/backend/src/database/filters/strict_filter.d.ts +0 -223
  160. package/backend/dist/esm/backend/src/database/filters/strict_filter.js +0 -3
  161. package/backend/dist/esm/backend/src/database/filters/strict_filter_test.d.ts +0 -1
  162. package/backend/dist/esm/backend/src/database/filters/strict_filter_test.js +0 -505
  163. package/backend/dist/esm/backend/src/database/filters/strict_filter_test_v0.d.ts +0 -1
  164. package/backend/dist/esm/backend/src/database/filters/strict_filter_test_v0.js +0 -712
  165. package/backend/dist/esm/backend/src/database/filters/strict_filter_v0.d.ts +0 -50
  166. package/backend/dist/esm/backend/src/database/filters/strict_filter_v0.js +0 -5
  167. package/backend/dist/esm/backend/src/database/filters/strict_filter_v1.d.ts +0 -76
  168. package/backend/dist/esm/backend/src/database/filters/strict_filter_v1.js +0 -44
  169. package/backend/dist/esm/backend/src/database/filters/strict_filter_v2.d.ts +0 -75
  170. package/backend/dist/esm/backend/src/database/filters/strict_filter_v2.js +0 -5
  171. package/backend/dist/esm/backend/src/database/filters/strict_filter_v3.d.ts +0 -219
  172. package/backend/dist/esm/backend/src/database/filters/strict_filter_v3.js +0 -1
  173. package/backend/dist/esm/backend/src/database/filters/strict_update_filter.d.ts +0 -165
  174. package/backend/dist/esm/backend/src/database/filters/strict_update_filter.js +0 -5
  175. package/backend/dist/esm/backend/src/database/filters/strict_update_filter_test.d.ts +0 -5
  176. package/backend/dist/esm/backend/src/database/filters/strict_update_filter_test.js +0 -415
  177. package/backend/dist/esm/backend/src/database/flatten.d.ts +0 -78
  178. package/backend/dist/esm/backend/src/database/flatten.js +0 -22
  179. package/backend/dist/esm/backend/src/database/flatten_test.d.ts +0 -1
  180. package/backend/dist/esm/backend/src/database/flatten_test.js +0 -174
  181. package/backend/dist/esm/backend/src/database/quota/quoata_v2.d.ts +0 -533
  182. package/backend/dist/esm/backend/src/database/quota/quoata_v2.js +0 -1155
  183. package/backend/dist/esm/backend/src/database/quota/quota.d.ts +0 -551
  184. package/backend/dist/esm/backend/src/database/quota/quota.js +0 -1219
  185. package/backend/dist/esm/backend/src/database/quota/quota_v1.d.ts +0 -534
  186. package/backend/dist/esm/backend/src/database/quota/quota_v1.js +0 -1242
  187. package/backend/dist/esm/backend/src/database/quota/safe_int.d.ts +0 -412
  188. package/backend/dist/esm/backend/src/database/quota/safe_int.js +0 -810
  189. package/backend/dist/esm/backend/src/endpoint.d.ts +0 -346
  190. package/backend/dist/esm/backend/src/endpoint.js +0 -479
  191. package/backend/dist/esm/backend/src/errors/index.d.ts +0 -7
  192. package/backend/dist/esm/backend/src/errors/index.js +0 -7
  193. package/backend/dist/esm/backend/src/errors/internal_external.d.ts +0 -52
  194. package/backend/dist/esm/backend/src/errors/internal_external.js +0 -86
  195. package/backend/dist/esm/backend/src/errors/invalid_usage_error.d.ts +0 -41
  196. package/backend/dist/esm/backend/src/errors/invalid_usage_error.js +0 -33
  197. package/backend/dist/esm/backend/src/errors/system_error.d.ts +0 -261
  198. package/backend/dist/esm/backend/src/errors/system_error.js +0 -444
  199. package/backend/dist/esm/backend/src/events.d.ts +0 -97
  200. package/backend/dist/esm/backend/src/events.js +0 -5
  201. package/backend/dist/esm/backend/src/frontend.d.ts +0 -11
  202. package/backend/dist/esm/backend/src/frontend.js +0 -12
  203. package/backend/dist/esm/backend/src/image_endpoint.d.ts +0 -44
  204. package/backend/dist/esm/backend/src/image_endpoint.js +0 -196
  205. package/backend/dist/esm/backend/src/index.d.ts +0 -23
  206. package/backend/dist/esm/backend/src/index.js +0 -26
  207. package/backend/dist/esm/backend/src/logger.d.ts +0 -5
  208. package/backend/dist/esm/backend/src/logger.js +0 -8
  209. package/backend/dist/esm/backend/src/meta.d.ts +0 -112
  210. package/backend/dist/esm/backend/src/meta.js +0 -152
  211. package/backend/dist/esm/backend/src/payments/paddle.d.ts +0 -329
  212. package/backend/dist/esm/backend/src/payments/paddle.js +0 -2276
  213. package/backend/dist/esm/backend/src/payments/stripe/checkout.d.ts +0 -113
  214. package/backend/dist/esm/backend/src/payments/stripe/checkout.js +0 -356
  215. package/backend/dist/esm/backend/src/payments/stripe/customers.d.ts +0 -17
  216. package/backend/dist/esm/backend/src/payments/stripe/customers.js +0 -193
  217. package/backend/dist/esm/backend/src/payments/stripe/error.d.ts +0 -74
  218. package/backend/dist/esm/backend/src/payments/stripe/error.js +0 -51
  219. package/backend/dist/esm/backend/src/payments/stripe/events.d.ts +0 -155
  220. package/backend/dist/esm/backend/src/payments/stripe/events.js +0 -5
  221. package/backend/dist/esm/backend/src/payments/stripe/meters.d.ts +0 -105
  222. package/backend/dist/esm/backend/src/payments/stripe/meters.js +0 -318
  223. package/backend/dist/esm/backend/src/payments/stripe/payment_methods.d.ts +0 -58
  224. package/backend/dist/esm/backend/src/payments/stripe/payment_methods.js +0 -135
  225. package/backend/dist/esm/backend/src/payments/stripe/products.d.ts +0 -519
  226. package/backend/dist/esm/backend/src/payments/stripe/products.js +0 -896
  227. package/backend/dist/esm/backend/src/payments/stripe/stripe.d.ts +0 -215
  228. package/backend/dist/esm/backend/src/payments/stripe/stripe.js +0 -464
  229. package/backend/dist/esm/backend/src/payments/stripe/subscriptions.d.ts +0 -172
  230. package/backend/dist/esm/backend/src/payments/stripe/subscriptions.js +0 -754
  231. package/backend/dist/esm/backend/src/payments/stripe/utils.d.ts +0 -63
  232. package/backend/dist/esm/backend/src/payments/stripe/utils.js +0 -131
  233. package/backend/dist/esm/backend/src/payments/stripe/webhooks.d.ts +0 -105
  234. package/backend/dist/esm/backend/src/payments/stripe/webhooks.js +0 -752
  235. package/backend/dist/esm/backend/src/plugins/browser.d.ts +0 -1
  236. package/backend/dist/esm/backend/src/plugins/browser.js +0 -170
  237. package/backend/dist/esm/backend/src/plugins/communication.d.ts +0 -70
  238. package/backend/dist/esm/backend/src/plugins/communication.js +0 -169
  239. package/backend/dist/esm/backend/src/plugins/mail/mail.d.ts +0 -255
  240. package/backend/dist/esm/backend/src/plugins/mail/mail.js +0 -396
  241. package/backend/dist/esm/backend/src/plugins/mail/ui.d.ts +0 -297
  242. package/backend/dist/esm/backend/src/plugins/mail/ui.js +0 -1400
  243. package/backend/dist/esm/backend/src/plugins/pdf.d.ts +0 -1
  244. package/backend/dist/esm/backend/src/plugins/pdf.js +0 -1694
  245. package/backend/dist/esm/backend/src/plugins/thread_monitor.d.ts +0 -18
  246. package/backend/dist/esm/backend/src/plugins/thread_monitor.js +0 -120
  247. package/backend/dist/esm/backend/src/rate_limit.d.ts +0 -148
  248. package/backend/dist/esm/backend/src/rate_limit.js +0 -667
  249. package/backend/dist/esm/backend/src/route.d.ts +0 -39
  250. package/backend/dist/esm/backend/src/route.js +0 -222
  251. package/backend/dist/esm/backend/src/server.d.ts +0 -502
  252. package/backend/dist/esm/backend/src/server.js +0 -2034
  253. package/backend/dist/esm/backend/src/server.old.d.ts +0 -594
  254. package/backend/dist/esm/backend/src/server.old.js +0 -2630
  255. package/backend/dist/esm/backend/src/splash_screen.d.ts +0 -93
  256. package/backend/dist/esm/backend/src/splash_screen.js +0 -156
  257. package/backend/dist/esm/backend/src/status.d.ts +0 -89
  258. package/backend/dist/esm/backend/src/status.js +0 -213
  259. package/backend/dist/esm/backend/src/stream.d.ts +0 -494
  260. package/backend/dist/esm/backend/src/stream.js +0 -1611
  261. package/backend/dist/esm/backend/src/users.d.ts +0 -926
  262. package/backend/dist/esm/backend/src/users.js +0 -2423
  263. package/backend/dist/esm/backend/src/utils.d.ts +0 -22
  264. package/backend/dist/esm/backend/src/utils.js +0 -463
  265. package/backend/dist/esm/backend/src/view.d.ts +0 -115
  266. package/backend/dist/esm/backend/src/view.js +0 -584
  267. package/backend/dist/esm/backend/src/vinc.d.ts +0 -6
  268. package/backend/dist/esm/backend/src/vinc.js +0 -6
  269. package/backend/dist/esm/backend/src/volt.d.ts +0 -24
  270. package/backend/dist/esm/backend/src/volt.js +0 -27
  271. package/backend/dist/esm/frontend/src/modules/request.d.ts +0 -70
  272. package/backend/dist/esm/frontend/src/modules/request.js +0 -117
  273. package/backend/old/file_watcher.ts +0 -359
  274. package/backend/old/request.deprc.js +0 -626
  275. package/backend/old/response.deprc.js +0 -354
  276. package/frontend/dist/backend/src/database/collection.d.ts +0 -1765
  277. package/frontend/dist/backend/src/database/collection.js +0 -3779
  278. package/frontend/dist/backend/src/database/database.d.ts +0 -92
  279. package/frontend/dist/backend/src/database/database.js +0 -214
  280. package/frontend/dist/backend/src/database/filters/filters.d.ts +0 -6
  281. package/frontend/dist/backend/src/database/filters/filters.js +0 -1
  282. package/frontend/dist/backend/src/database/filters/strict_filter.d.ts +0 -223
  283. package/frontend/dist/backend/src/database/filters/strict_filter.js +0 -3
  284. package/frontend/dist/backend/src/database/filters/strict_update_filter.d.ts +0 -165
  285. package/frontend/dist/backend/src/database/filters/strict_update_filter.js +0 -5
  286. package/frontend/dist/backend/src/database/flatten.d.ts +0 -78
  287. package/frontend/dist/backend/src/database/flatten.js +0 -22
  288. package/frontend/dist/backend/src/endpoint.d.ts +0 -346
  289. package/frontend/dist/backend/src/endpoint.js +0 -479
  290. package/frontend/dist/backend/src/errors/index.d.ts +0 -7
  291. package/frontend/dist/backend/src/errors/index.js +0 -7
  292. package/frontend/dist/backend/src/errors/internal_external.d.ts +0 -52
  293. package/frontend/dist/backend/src/errors/internal_external.js +0 -86
  294. package/frontend/dist/backend/src/errors/invalid_usage_error.d.ts +0 -41
  295. package/frontend/dist/backend/src/errors/invalid_usage_error.js +0 -33
  296. package/frontend/dist/backend/src/errors/system_error.d.ts +0 -261
  297. package/frontend/dist/backend/src/errors/system_error.js +0 -444
  298. package/frontend/dist/backend/src/events.d.ts +0 -97
  299. package/frontend/dist/backend/src/events.js +0 -5
  300. package/frontend/dist/backend/src/frontend.d.ts +0 -11
  301. package/frontend/dist/backend/src/frontend.js +0 -12
  302. package/frontend/dist/backend/src/image_endpoint.d.ts +0 -44
  303. package/frontend/dist/backend/src/image_endpoint.js +0 -196
  304. package/frontend/dist/backend/src/meta.d.ts +0 -112
  305. package/frontend/dist/backend/src/meta.js +0 -152
  306. package/frontend/dist/backend/src/payments/paddle.d.ts +0 -329
  307. package/frontend/dist/backend/src/payments/paddle.js +0 -2276
  308. package/frontend/dist/backend/src/payments/stripe/checkout.d.ts +0 -113
  309. package/frontend/dist/backend/src/payments/stripe/checkout.js +0 -356
  310. package/frontend/dist/backend/src/payments/stripe/customers.d.ts +0 -17
  311. package/frontend/dist/backend/src/payments/stripe/customers.js +0 -193
  312. package/frontend/dist/backend/src/payments/stripe/error.d.ts +0 -74
  313. package/frontend/dist/backend/src/payments/stripe/error.js +0 -51
  314. package/frontend/dist/backend/src/payments/stripe/events.d.ts +0 -155
  315. package/frontend/dist/backend/src/payments/stripe/events.js +0 -5
  316. package/frontend/dist/backend/src/payments/stripe/meters.d.ts +0 -105
  317. package/frontend/dist/backend/src/payments/stripe/meters.js +0 -318
  318. package/frontend/dist/backend/src/payments/stripe/payment_methods.d.ts +0 -58
  319. package/frontend/dist/backend/src/payments/stripe/payment_methods.js +0 -135
  320. package/frontend/dist/backend/src/payments/stripe/products.d.ts +0 -519
  321. package/frontend/dist/backend/src/payments/stripe/products.js +0 -896
  322. package/frontend/dist/backend/src/payments/stripe/stripe.d.ts +0 -215
  323. package/frontend/dist/backend/src/payments/stripe/stripe.js +0 -464
  324. package/frontend/dist/backend/src/payments/stripe/subscriptions.d.ts +0 -172
  325. package/frontend/dist/backend/src/payments/stripe/subscriptions.js +0 -754
  326. package/frontend/dist/backend/src/payments/stripe/utils.d.ts +0 -63
  327. package/frontend/dist/backend/src/payments/stripe/utils.js +0 -131
  328. package/frontend/dist/backend/src/payments/stripe/webhooks.d.ts +0 -105
  329. package/frontend/dist/backend/src/payments/stripe/webhooks.js +0 -752
  330. package/frontend/dist/backend/src/plugins/mail/mail.d.ts +0 -255
  331. package/frontend/dist/backend/src/plugins/mail/mail.js +0 -396
  332. package/frontend/dist/backend/src/plugins/mail/ui.d.ts +0 -297
  333. package/frontend/dist/backend/src/plugins/mail/ui.js +0 -1400
  334. package/frontend/dist/backend/src/rate_limit.d.ts +0 -148
  335. package/frontend/dist/backend/src/rate_limit.js +0 -667
  336. package/frontend/dist/backend/src/route.d.ts +0 -39
  337. package/frontend/dist/backend/src/route.js +0 -222
  338. package/frontend/dist/backend/src/server.d.ts +0 -502
  339. package/frontend/dist/backend/src/server.js +0 -2034
  340. package/frontend/dist/backend/src/splash_screen.d.ts +0 -93
  341. package/frontend/dist/backend/src/splash_screen.js +0 -156
  342. package/frontend/dist/backend/src/status.d.ts +0 -89
  343. package/frontend/dist/backend/src/status.js +0 -213
  344. package/frontend/dist/backend/src/stream.d.ts +0 -494
  345. package/frontend/dist/backend/src/stream.js +0 -1611
  346. package/frontend/dist/backend/src/users.d.ts +0 -926
  347. package/frontend/dist/backend/src/users.js +0 -2423
  348. package/frontend/dist/backend/src/utils.d.ts +0 -22
  349. package/frontend/dist/backend/src/utils.js +0 -463
  350. package/frontend/dist/backend/src/view.d.ts +0 -115
  351. package/frontend/dist/backend/src/view.js +0 -584
  352. package/frontend/dist/frontend/src/elements/base.d.ts +0 -3743
  353. package/frontend/dist/frontend/src/elements/base.js +0 -12151
  354. package/frontend/dist/frontend/src/elements/module.d.ts +0 -95
  355. package/frontend/dist/frontend/src/elements/module.js +0 -216
  356. package/frontend/dist/frontend/src/elements/register_element.d.ts +0 -3
  357. package/frontend/dist/frontend/src/elements/register_element.js +0 -22
  358. package/frontend/dist/frontend/src/elements/resize_query_manager.d.ts +0 -0
  359. package/frontend/dist/frontend/src/elements/resize_query_manager.js +0 -150
  360. package/frontend/dist/frontend/src/elements/types.d.ts +0 -52
  361. package/frontend/dist/frontend/src/elements/types.js +0 -5
  362. package/frontend/dist/frontend/src/index.d.ts +0 -21
  363. package/frontend/dist/frontend/src/index.js +0 -29
  364. package/frontend/dist/frontend/src/modules/attachment.d.ts +0 -126
  365. package/frontend/dist/frontend/src/modules/attachment.js +0 -306
  366. package/frontend/dist/frontend/src/modules/auth.d.ts +0 -44
  367. package/frontend/dist/frontend/src/modules/auth.js +0 -80
  368. package/frontend/dist/frontend/src/modules/color.d.ts +0 -160
  369. package/frontend/dist/frontend/src/modules/color.js +0 -316
  370. package/frontend/dist/frontend/src/modules/compression.d.ts +0 -39
  371. package/frontend/dist/frontend/src/modules/compression.js +0 -102
  372. package/frontend/dist/frontend/src/modules/cookies.d.ts +0 -44
  373. package/frontend/dist/frontend/src/modules/cookies.js +0 -143
  374. package/frontend/dist/frontend/src/modules/events.d.ts +0 -31
  375. package/frontend/dist/frontend/src/modules/events.js +0 -79
  376. package/frontend/dist/frontend/src/modules/google.d.ts +0 -23
  377. package/frontend/dist/frontend/src/modules/google.js +0 -52
  378. package/frontend/dist/frontend/src/modules/meta.d.ts +0 -14
  379. package/frontend/dist/frontend/src/modules/meta.js +0 -48
  380. package/frontend/dist/frontend/src/modules/paddle.d.ts +0 -1207
  381. package/frontend/dist/frontend/src/modules/paddle.js +0 -2594
  382. package/frontend/dist/frontend/src/modules/request.d.ts +0 -70
  383. package/frontend/dist/frontend/src/modules/request.js +0 -117
  384. package/frontend/dist/frontend/src/modules/settings.d.ts +0 -3
  385. package/frontend/dist/frontend/src/modules/settings.js +0 -5
  386. package/frontend/dist/frontend/src/modules/statics.d.ts +0 -21
  387. package/frontend/dist/frontend/src/modules/statics.js +0 -43
  388. package/frontend/dist/frontend/src/modules/stripe/cart.d.ts +0 -112
  389. package/frontend/dist/frontend/src/modules/stripe/cart.js +0 -321
  390. package/frontend/dist/frontend/src/modules/stripe/checkout.d.ts +0 -7
  391. package/frontend/dist/frontend/src/modules/stripe/checkout.js +0 -37
  392. package/frontend/dist/frontend/src/modules/stripe/index.m.d.ts +0 -6
  393. package/frontend/dist/frontend/src/modules/stripe/index.m.js +0 -6
  394. package/frontend/dist/frontend/src/modules/stripe/payments.d.ts +0 -58
  395. package/frontend/dist/frontend/src/modules/stripe/payments.js +0 -92
  396. package/frontend/dist/frontend/src/modules/support.d.ts +0 -30
  397. package/frontend/dist/frontend/src/modules/support.js +0 -53
  398. package/frontend/dist/frontend/src/modules/theme.d.ts +0 -133
  399. package/frontend/dist/frontend/src/modules/theme.js +0 -406
  400. package/frontend/dist/frontend/src/modules/themes.d.ts +0 -12
  401. package/frontend/dist/frontend/src/modules/themes.js +0 -22
  402. package/frontend/dist/frontend/src/modules/user.d.ts +0 -164
  403. package/frontend/dist/frontend/src/modules/user.js +0 -270
  404. package/frontend/dist/frontend/src/modules/utils.d.ts +0 -176
  405. package/frontend/dist/frontend/src/modules/utils.js +0 -569
  406. package/frontend/dist/frontend/src/types/gradient.d.ts +0 -29
  407. package/frontend/dist/frontend/src/types/gradient.js +0 -79
  408. package/frontend/dist/frontend/src/ui/border_button.d.ts +0 -94
  409. package/frontend/dist/frontend/src/ui/border_button.js +0 -228
  410. package/frontend/dist/frontend/src/ui/button.d.ts +0 -241
  411. package/frontend/dist/frontend/src/ui/button.js +0 -682
  412. package/frontend/dist/frontend/src/ui/canvas.d.ts +0 -138
  413. package/frontend/dist/frontend/src/ui/canvas.js +0 -444
  414. package/frontend/dist/frontend/src/ui/checkbox.d.ts +0 -74
  415. package/frontend/dist/frontend/src/ui/checkbox.js +0 -321
  416. package/frontend/dist/frontend/src/ui/code.d.ts +0 -235
  417. package/frontend/dist/frontend/src/ui/code.js +0 -1007
  418. package/frontend/dist/frontend/src/ui/context_menu.d.ts +0 -36
  419. package/frontend/dist/frontend/src/ui/context_menu.js +0 -205
  420. package/frontend/dist/frontend/src/ui/css.d.ts +0 -16
  421. package/frontend/dist/frontend/src/ui/css.js +0 -48
  422. package/frontend/dist/frontend/src/ui/divider.d.ts +0 -15
  423. package/frontend/dist/frontend/src/ui/divider.js +0 -78
  424. package/frontend/dist/frontend/src/ui/dropdown.d.ts +0 -176
  425. package/frontend/dist/frontend/src/ui/dropdown.js +0 -481
  426. package/frontend/dist/frontend/src/ui/for_each.d.ts +0 -37
  427. package/frontend/dist/frontend/src/ui/for_each.js +0 -92
  428. package/frontend/dist/frontend/src/ui/form.d.ts +0 -34
  429. package/frontend/dist/frontend/src/ui/form.js +0 -233
  430. package/frontend/dist/frontend/src/ui/frame_modes.d.ts +0 -37
  431. package/frontend/dist/frontend/src/ui/frame_modes.js +0 -108
  432. package/frontend/dist/frontend/src/ui/google_map.d.ts +0 -24
  433. package/frontend/dist/frontend/src/ui/google_map.js +0 -106
  434. package/frontend/dist/frontend/src/ui/gradient.d.ts +0 -25
  435. package/frontend/dist/frontend/src/ui/gradient.js +0 -131
  436. package/frontend/dist/frontend/src/ui/image.d.ts +0 -111
  437. package/frontend/dist/frontend/src/ui/image.js +0 -576
  438. package/frontend/dist/frontend/src/ui/input.d.ts +0 -392
  439. package/frontend/dist/frontend/src/ui/input.js +0 -1201
  440. package/frontend/dist/frontend/src/ui/link.d.ts +0 -25
  441. package/frontend/dist/frontend/src/ui/link.js +0 -140
  442. package/frontend/dist/frontend/src/ui/list.d.ts +0 -37
  443. package/frontend/dist/frontend/src/ui/list.js +0 -170
  444. package/frontend/dist/frontend/src/ui/loader_button.d.ts +0 -80
  445. package/frontend/dist/frontend/src/ui/loader_button.js +0 -193
  446. package/frontend/dist/frontend/src/ui/loaders.d.ts +0 -57
  447. package/frontend/dist/frontend/src/ui/loaders.js +0 -157
  448. package/frontend/dist/frontend/src/ui/popup.d.ts +0 -94
  449. package/frontend/dist/frontend/src/ui/popup.js +0 -510
  450. package/frontend/dist/frontend/src/ui/pseudo.d.ts +0 -44
  451. package/frontend/dist/frontend/src/ui/pseudo.js +0 -154
  452. package/frontend/dist/frontend/src/ui/scroller.d.ts +0 -105
  453. package/frontend/dist/frontend/src/ui/scroller.js +0 -1253
  454. package/frontend/dist/frontend/src/ui/slider.d.ts +0 -45
  455. package/frontend/dist/frontend/src/ui/slider.js +0 -217
  456. package/frontend/dist/frontend/src/ui/spacer.d.ts +0 -15
  457. package/frontend/dist/frontend/src/ui/spacer.js +0 -78
  458. package/frontend/dist/frontend/src/ui/span.d.ts +0 -15
  459. package/frontend/dist/frontend/src/ui/span.js +0 -73
  460. package/frontend/dist/frontend/src/ui/stack.d.ts +0 -66
  461. package/frontend/dist/frontend/src/ui/stack.js +0 -335
  462. package/frontend/dist/frontend/src/ui/steps.d.ts +0 -131
  463. package/frontend/dist/frontend/src/ui/steps.js +0 -308
  464. package/frontend/dist/frontend/src/ui/style.d.ts +0 -17
  465. package/frontend/dist/frontend/src/ui/style.js +0 -73
  466. package/frontend/dist/frontend/src/ui/switch.d.ts +0 -69
  467. package/frontend/dist/frontend/src/ui/switch.js +0 -357
  468. package/frontend/dist/frontend/src/ui/table.d.ts +0 -100
  469. package/frontend/dist/frontend/src/ui/table.js +0 -405
  470. package/frontend/dist/frontend/src/ui/tabs.d.ts +0 -111
  471. package/frontend/dist/frontend/src/ui/tabs.js +0 -424
  472. package/frontend/dist/frontend/src/ui/text.d.ts +0 -15
  473. package/frontend/dist/frontend/src/ui/text.js +0 -83
  474. package/frontend/dist/frontend/src/ui/title.d.ts +0 -91
  475. package/frontend/dist/frontend/src/ui/title.js +0 -272
  476. package/frontend/dist/frontend/src/ui/ui.d.ts +0 -35
  477. package/frontend/dist/frontend/src/ui/ui.js +0 -38
  478. package/frontend/dist/frontend/src/ui/view.d.ts +0 -15
  479. package/frontend/dist/frontend/src/ui/view.js +0 -88
  480. package/frontend/dist/frontend/src/volt.d.ts +0 -20
  481. package/frontend/dist/frontend/src/volt.js +0 -27
  482. package/frontend/examples/theme/theme.ts +0 -58
  483. package/frontend/tools/bundle_d_ts.js +0 -71
  484. package/frontend/tools/convert_to_jsdoc_input.txt +0 -9452
  485. package/frontend/tools/convert_to_jsdoc_output.txt +0 -7626
  486. package/frontend/tools/convert_to_jsdoc_tmp.js +0 -345
  487. package/frontend/tools/scan_mixed_imports.js +0 -69
  488. /package/frontend/{dist/frontend/src/css → css}/adyen.css +0 -0
  489. /package/frontend/{dist/frontend/src/css → css}/volt.css +0 -0
@@ -1,810 +0,0 @@
1
- /**
2
- * @author Daan van den Bergh
3
- * @copyright © 2022 - 2025 Daan van den Bergh. All rights reserved
4
- */
5
- /* ============================================================================
6
- SafeInt — a single, generic, integer-only amount class
7
- ----------------------------------------------------------------------------
8
- - **No derived classes.** A single generic class parameterized by its scale `S`.
9
- - **Exact-by-default.** No silent rounding anywhere; rounding only when `round` is provided.
10
- - **Same-scale arithmetic only.** Operations accept raw numbers or the same generic `SafeInt<S>`.
11
- - **Strong typing for rescaling.** `to_scale<T>()` and helpers (`base/milli/micro/nano/pico`)
12
- return `SafeInt<T>` with the correct type at compile time.
13
- - **Constructor defaults to Base scale.** Multiple signatures are provided as requested.
14
- ========================================================================== */
15
- /**
16
- * Scaled, integer-only amount with explicit, type-safe scale semantics.
17
- *
18
- * @template S The canonical integer scale (see {@link SafeInt.Scale}) at which this instance stores its value.
19
- *
20
- * @remarks
21
- * - The stored value is always an **integer (`bigint`)** (may be negative) measured in units of `S`.
22
- * - Instances are **immutable**; all arithmetic returns new `SafeInt` instances.
23
- * - Conversions are **exact by default**. Provide a {@link SafeInt.Rounding} `round` to allow rounding.
24
- * - Arithmetic is **same-scale only**: pass raw integers or another `SafeInt<S>`.
25
- *
26
- * @nav Database
27
- * @docs
28
- */
29
- export class SafeInt {
30
- // ----------------------------------------------------------------
31
- // Fields
32
- // ----------------------------------------------------------------
33
- /**
34
- * The stored integer (may be negative) measured at {@link int_scale}.
35
- */
36
- int_value;
37
- /**
38
- * The canonical integer scale for {@link int_value}.
39
- */
40
- int_scale;
41
- // ----------------------------------------------------------------
42
- // Constructors
43
- // ----------------------------------------------------------------
44
- /**
45
- * Construct by converting from `opts.from_scale` to `opts.to_scale`. **Exact by default**.
46
- *
47
- * @param value The numeric input at `opts.from_scale`.
48
- * - If `from_scale === Base`, `value` may be a float. When `round` is omitted,
49
- * `value * to_scale` must be an integer. If `round` is provided, that rounding is applied.
50
- * - If `from_scale !== Base`, `value` must be a safe integer.
51
- * - If `value` is a string:
52
- * - If `from_scale === Base`, it may be a decimal string (exact parsing).
53
- * - Otherwise it must be an integer string.
54
- * @param opts The canonical scale or scale options.
55
- * @param opts.to_scale The target scale for storage (the resulting instance type is `SafeInt<opts.to_scale>`).
56
- * @param opts.from_scale The source scale of {@link value}, defaults to {@link SafeInt.Scale.Base}.
57
- * @param opts.round Optional rounding mode for non-exact conversions (default: `"exact"`).
58
- *
59
- * @example
60
- * new SafeInt(123_000, SafeInt.Scale.Nano)
61
- * @example
62
- * new SafeInt(123_000, "nano")
63
- * @example
64
- * new SafeInt(1.5, { from_scale: SafeInt.Scale.Base, to_scale: SafeInt.Scale.Milli, round: "round" }) // 1500
65
- * @example
66
- * new SafeInt(2n, { from_scale: SafeInt.Scale.Base, to_scale: SafeInt.Scale.Nano }) // 2_000_000_000n
67
- * @example
68
- * // Exact, decimal-safe parsing (no float surprises)
69
- * new SafeInt("1.005", { from_scale: "base", to_scale: "milli", round: "round" }) // 1005
70
- * @example
71
- * // Integer string at already-at-scale (underscores allowed)
72
- * new SafeInt("123_000", "nano")
73
- *
74
- * @throws
75
- * Error If inputs are invalid, conversion overflows, or exactness is required but not met.
76
- *
77
- * @docs
78
- */
79
- constructor(value, opts) {
80
- // Already-at-scale (exact)
81
- if (typeof opts === "number" || typeof opts === "string") {
82
- const scale = typeof opts === "string"
83
- ? SafeInt.str_to_scale(opts)
84
- : opts;
85
- // validate scale (must be a positive safe integer)
86
- if (!Number.isSafeInteger(scale) || scale <= 0) {
87
- throw new Error(`Invalid scale: expected positive safe integer, got ${scale}`);
88
- }
89
- // value can be any integer (negative allowed); validate number inputs are safe integers
90
- if (typeof value === "string") {
91
- // already-at-scale string must be an integer string (no decimal point)
92
- this.int_value = SafeInt.parse_int_str(value, "value");
93
- }
94
- else if (typeof value === "number") {
95
- if (!Number.isSafeInteger(value)) {
96
- throw new Error(`Invalid value: expected safe integer, got ${value}`);
97
- }
98
- this.int_value = BigInt(value);
99
- }
100
- else {
101
- this.int_value = value;
102
- }
103
- this.int_scale = scale;
104
- return;
105
- }
106
- // Convert from -> to (exact by default; optional rounding)
107
- let { to_scale, from_scale = SafeInt.Scale.Base, round = "exact" } = opts;
108
- if (typeof to_scale === "string") {
109
- to_scale = SafeInt.str_to_scale(to_scale);
110
- }
111
- if (typeof from_scale === "string") {
112
- from_scale = SafeInt.str_to_scale(from_scale);
113
- }
114
- // validate scales (must be positive safe integers)
115
- if (!Number.isSafeInteger(from_scale) || from_scale <= 0) {
116
- throw new Error(`Invalid from_scale: expected positive safe integer, got ${from_scale}`);
117
- }
118
- if (!Number.isSafeInteger(to_scale) || to_scale <= 0) {
119
- throw new Error(`Invalid to_scale: expected positive safe integer, got ${to_scale}`);
120
- }
121
- let converted;
122
- if (from_scale === to_scale) {
123
- if (to_scale === SafeInt.Scale.Base) {
124
- // Base scale can accept:
125
- // - number input (may be float; exactness/rounding rules apply)
126
- // - bigint input (always an integer; rounding is a no-op)
127
- if (typeof value === "string") {
128
- // base->base stores integer base units; string must be integer
129
- converted = SafeInt.parse_int_str(value, "value");
130
- }
131
- else if (typeof value === "bigint") {
132
- converted = value;
133
- }
134
- else {
135
- const n = value;
136
- if (round === "exact") {
137
- if (!Number.isSafeInteger(n)) {
138
- throw new Error(`Exact constructor requires integer at base scale, got ${n}`);
139
- }
140
- converted = BigInt(n);
141
- }
142
- else {
143
- const rounded = SafeInt.apply_round(n, round);
144
- if (!Number.isSafeInteger(rounded)) {
145
- throw new Error(`Rounding produced non-integer at base scale: ${rounded}`);
146
- }
147
- converted = BigInt(rounded);
148
- }
149
- }
150
- }
151
- else {
152
- if (typeof value === "string") {
153
- // non-base, same-scale: must be integer
154
- converted = SafeInt.parse_int_str(value, "value");
155
- }
156
- else if (typeof value === "number") {
157
- if (!Number.isSafeInteger(value)) {
158
- throw new Error(`Invalid value: expected safe integer at scale=${to_scale}, got ${value}`);
159
- }
160
- converted = BigInt(value);
161
- }
162
- else {
163
- converted = value;
164
- }
165
- }
166
- }
167
- else if (from_scale === SafeInt.Scale.Base) {
168
- // base -> integer scale
169
- // - number input may be float; exactness/rounding rules apply
170
- // - bigint input represents an integer base amount; conversion is exact bigint math (rounding is a no-op)
171
- if (typeof value === "string") {
172
- // Decimal-safe path: parse base string exactly, then scale in bigint space.
173
- converted = SafeInt.parse_base_decimal_to_scaled(value, to_scale, round);
174
- }
175
- else if (typeof value === "bigint") {
176
- converted = value * BigInt(to_scale);
177
- }
178
- else {
179
- const n = value;
180
- const product = n * to_scale;
181
- if (round === "exact") {
182
- if (!Number.isFinite(product) || !Number.isInteger(product)) {
183
- throw new Error(`Exact conversion failed: ${n} * ${to_scale} is not an integer`);
184
- }
185
- if (!Number.isSafeInteger(product)) {
186
- throw new Error(`Overflow converting base->${to_scale}: ${product}`);
187
- }
188
- converted = BigInt(product);
189
- }
190
- else {
191
- const rounded = SafeInt.apply_round(product, round);
192
- if (!Number.isSafeInteger(rounded)) {
193
- throw new Error(`Overflow/invalid rounding converting base->${to_scale}: ${product} -> ${rounded}`);
194
- }
195
- converted = BigInt(rounded);
196
- }
197
- }
198
- }
199
- else if (to_scale === SafeInt.Scale.Base) {
200
- // integer scale -> base integer, possibly rounded
201
- if (typeof value === "string") {
202
- const v = SafeInt.parse_int_str(value, "value");
203
- converted = SafeInt.div_to_base(v, from_scale, round);
204
- }
205
- else if (typeof value === "number") {
206
- if (!Number.isSafeInteger(value)) {
207
- throw new Error(`Invalid value: expected safe integer at scale=${from_scale}, got ${value}`);
208
- }
209
- converted = SafeInt.div_to_base(BigInt(value), from_scale, round);
210
- }
211
- else {
212
- converted = SafeInt.div_to_base(value, from_scale, round);
213
- }
214
- }
215
- else {
216
- // integer-scale -> integer-scale
217
- if (typeof value === "number") {
218
- if (!Number.isSafeInteger(value)) {
219
- throw new Error(`Invalid value: expected safe integer at scale=${from_scale}, got ${value}`);
220
- }
221
- }
222
- const v = typeof value === "string" ? SafeInt.parse_int_str(value, "value")
223
- : typeof value === "number" ? BigInt(value)
224
- : value;
225
- converted = SafeInt.convert_int_scale(v, from_scale, to_scale, round);
226
- }
227
- this.int_value = converted;
228
- this.int_scale = to_scale;
229
- }
230
- // ----------------------------------------------------------------
231
- // value & scale accessors
232
- // ----------------------------------------------------------------
233
- /**
234
- * Retrieve the underlying integer (measured in {@link scale} units).
235
- *
236
- * @returns The stored integer.
237
- *
238
- * @docs
239
- */
240
- value() {
241
- return this.int_value;
242
- }
243
- /**
244
- * Conver the stored integer to a `number`.
245
- *
246
- * @returns The amount in stored integer units as `number` instead of `bigint`.
247
- * @throws Error if the stored integer cannot be represented safely as a `number`.
248
- *
249
- * @docs
250
- */
251
- to_number() {
252
- // Convert to number only when the stored integer can be represented safely as a JS number.
253
- const max_safe = BigInt(Number.MAX_SAFE_INTEGER);
254
- if (this.int_value > max_safe || this.int_value < -max_safe) {
255
- throw new Error(`Cannot represent value as number safely for to_number(): ${this.int_value.toString()}`);
256
- }
257
- return Number(this.int_value);
258
- }
259
- /**
260
- * Alias of {@link value}. Provided for JavaScript numeric coercion.
261
- *
262
- * @returns The stored integer.
263
- *
264
- * @docs
265
- */
266
- valueOf() {
267
- return this.int_value;
268
- }
269
- /**
270
- * Retrieve this instance's canonical scale.
271
- *
272
- * @returns The positive integer scale for this value.
273
- *
274
- * @docs
275
- */
276
- scale() {
277
- return this.int_scale;
278
- }
279
- // ----------------------------------------------------------------
280
- // presentation conversion
281
- // ----------------------------------------------------------------
282
- /**
283
- * Convert to base scale (1) as a floating-point number (presentation).
284
- *
285
- * @returns The amount in base units as a float.
286
- *
287
- * @docs
288
- */
289
- to_base_float() {
290
- if (this.int_scale === SafeInt.Scale.Base)
291
- return this.to_number();
292
- const denom = BigInt(this.int_scale);
293
- const q = this.int_value / denom;
294
- const r = this.int_value % denom;
295
- const max_safe = BigInt(Number.MAX_SAFE_INTEGER);
296
- if (q > max_safe || q < -max_safe) {
297
- throw new Error(`Cannot represent base float safely: quotient ${q.toString()} out of range`);
298
- }
299
- // r fits in denom; denom is a safe integer scale, so Number(denom) is safe
300
- return Number(q) + Number(r) / Number(denom);
301
- }
302
- // ----------------------------------------------------------------
303
- // scale conversion — strongly typed
304
- // ----------------------------------------------------------------
305
- /**
306
- * Convert this instance to another integer scale.
307
- * **Exact by default** — provide a {@link SafeInt.Rounding} to allow rounding.
308
- *
309
- * @typeParam T - Target scale (see {@link SafeInt.Scale}).
310
- * @param to_scale The target canonical scale.
311
- * @param round Rounding mode for non-exact ratios (default `"exact"`).
312
- *
313
- * @returns A new {@link SafeInt} typed as `SafeInt<T>`, storing an integer at `to_scale`.
314
- *
315
- * @docs
316
- */
317
- to_scale(to_scale, round = "exact") {
318
- // validate target scale
319
- if (!Number.isSafeInteger(to_scale) || to_scale <= 0) {
320
- throw new Error(`Invalid to_scale: expected positive safe integer, got ${to_scale}`);
321
- }
322
- if (this.int_scale === to_scale) {
323
- // Preserve type at call-site
324
- return new SafeInt(this.int_value, to_scale);
325
- }
326
- if (to_scale === SafeInt.Scale.Base) {
327
- const base_int = SafeInt.div_to_base(this.int_value, this.int_scale, round);
328
- return new SafeInt(base_int, SafeInt.Scale.Base);
329
- }
330
- if (this.int_scale === SafeInt.Scale.Base) {
331
- // base-scale values are stored as integers; multiplying by `to_scale` stays integer-safe in bigint space
332
- const product = this.int_value * BigInt(to_scale);
333
- return new SafeInt(product, to_scale);
334
- }
335
- const n = SafeInt.convert_int_scale(this.int_value, this.int_scale, to_scale, round);
336
- return new SafeInt(n, to_scale);
337
- }
338
- /**
339
- * Rescale to base (1).
340
- *
341
- * @returns A new `SafeInt<SafeInt.Scale.Base>`.
342
- *
343
- * @docs
344
- */
345
- base() {
346
- return this.to_scale(SafeInt.Scale.Base);
347
- }
348
- /**
349
- * Rescale to milli (1e3).
350
- *
351
- * @returns A new `SafeInt<SafeInt.Scale.Milli>`.
352
- *
353
- * @docs
354
- */
355
- milli() {
356
- return this.to_scale(SafeInt.Scale.Milli);
357
- }
358
- /**
359
- * Rescale to micro (1e6).
360
- *
361
- * @returns A new `SafeInt<SafeInt.Scale.Micro>`.
362
- *
363
- * @docs
364
- */
365
- micro() {
366
- return this.to_scale(SafeInt.Scale.Micro);
367
- }
368
- /**
369
- * Rescale to nano (1e9).
370
- *
371
- * @returns A new `SafeInt<SafeInt.Scale.Nano>`.
372
- *
373
- * @docs
374
- */
375
- nano() {
376
- return this.to_scale(SafeInt.Scale.Nano);
377
- }
378
- /**
379
- * Rescale to pico (1e12).
380
- *
381
- * @returns A new `SafeInt<SafeInt.Scale.Pico>`.
382
- *
383
- * @docs
384
- */
385
- pico() {
386
- return this.to_scale(SafeInt.Scale.Pico);
387
- }
388
- // ----------------------------------------------------------------
389
- // arithmetic — same-scale only
390
- // ----------------------------------------------------------------
391
- /**
392
- * Add an amount at the same scale.
393
- *
394
- * @param other The addend, as a raw safe integer or a `SafeInt<S>`.
395
- * @returns A new `SafeInt<S>` with the sum.
396
- *
397
- * @throws Error If the operand is invalid.
398
- *
399
- * @docs
400
- */
401
- add(other) {
402
- const b = typeof other === "number"
403
- ? (Number.isSafeInteger(other) ? BigInt(other) : (() => { throw new Error(`Invalid 'addend': expected a safe integer, got ${other}`); })())
404
- : (typeof other === "bigint" ? other : other.int_value);
405
- const sum = this.int_value + b;
406
- return new SafeInt(sum, this.int_scale);
407
- }
408
- /**
409
- * Subtract an amount at the same scale.
410
- *
411
- * @param other The subtrahend, as a raw safe integer or a `SafeInt<S>`.
412
- * @returns A new `SafeInt<S>` with the difference.
413
- *
414
- * @throws Error If the operand is invalid.
415
- *
416
- * @docs
417
- */
418
- sub(other) {
419
- const b = typeof other === "number"
420
- ? (Number.isSafeInteger(other) ? BigInt(other) : (() => { throw new Error(`Invalid 'subtrahend': expected a safe integer, got ${other}`); })())
421
- : (typeof other === "bigint" ? other : other.int_value);
422
- const diff = this.int_value - b;
423
- return new SafeInt(diff, this.int_scale);
424
- }
425
- /**
426
- * Multiply by an integer factor at the same scale.
427
- *
428
- * @param factor The factor as a raw safe integer or a `SafeInt<S>`.
429
- * @returns A new `SafeInt<S>` with the product.
430
- *
431
- * @throws Error If the factor is invalid.
432
- *
433
- * @docs
434
- */
435
- mul(factor) {
436
- const f = typeof factor === "number"
437
- ? (Number.isSafeInteger(factor) ? BigInt(factor) : (() => { throw new Error(`Invalid 'factor': expected a safe integer, got ${factor}`); })())
438
- : (typeof factor === "bigint" ? factor : factor.int_value);
439
- const product = this.int_value * f;
440
- return new SafeInt(product, this.int_scale);
441
- }
442
- /**
443
- * Divide by a positive integer divisor at the same scale.
444
- *
445
- * @param divisor Positive safe integer or `SafeInt<S>` divisor.
446
- * @param round Rounding mode. Default `"exact"` requires no remainder.
447
- * @returns A new `SafeInt<S>` with the integer quotient (per {@link round}).
448
- *
449
- * @throws Error If the divisor is invalid, division by zero, or non-exact remainder in `"exact"` round.
450
- *
451
- * @docs
452
- */
453
- div(divisor, round = "exact") {
454
- const d = typeof divisor === "number"
455
- ? (Number.isSafeInteger(divisor) ? BigInt(divisor) : (() => { throw new Error(`Invalid 'divisor': expected a non-zero safe integer, got ${divisor}`); })())
456
- : (typeof divisor === "bigint" ? divisor : divisor.int_value);
457
- if (d === 0n) {
458
- throw new Error(`Invalid 'divisor': expected a non-zero safe integer, got 0`);
459
- }
460
- const q = SafeInt.div_int_checked(this.int_value, d, round);
461
- return new SafeInt(q, this.int_scale);
462
- }
463
- // ----------------------------------------------------------------
464
- // comparisons — same-scale only
465
- // ----------------------------------------------------------------
466
- /**
467
- * Compare with another `SafeInt<S>`.
468
- *
469
- * @param other The other amount (same scale).
470
- * @returns `-1` if this < other, `0` if equal, `1` if this > other.
471
- *
472
- * @docs
473
- */
474
- cmp(other) {
475
- const rhs = other.int_value;
476
- if (this.int_value < rhs)
477
- return -1;
478
- if (this.int_value > rhs)
479
- return 1;
480
- return 0;
481
- }
482
- /**
483
- * Test equality with another `SafeInt<S>`.
484
- *
485
- * @param other The other amount (same scale).
486
- * @returns `true` if equal, otherwise `false`.
487
- *
488
- * @docs
489
- */
490
- eq(other) {
491
- return this.cmp(other) === 0;
492
- }
493
- // ----------------------------------------------------------------
494
- // Member & static assertions.
495
- // ----------------------------------------------------------------
496
- /**
497
- * Assert `value` is a `>=0` integer.
498
- *
499
- * @docs
500
- */
501
- assert_non_negative() {
502
- if (this.int_value < 0n) {
503
- throw new Error(`Invalid value: expected non-negative integer, got ${this.int_value.toString()}`);
504
- }
505
- }
506
- /**
507
- * Assert `value` is a `>0` integer.
508
- *
509
- * @docs
510
- */
511
- assert_positive() {
512
- if (this.int_value <= 0n) {
513
- throw new Error(`Invalid value: expected positive integer, got ${this.int_value.toString()}`);
514
- }
515
- }
516
- /**
517
- * Assert `value` is a `<=0` integer.
518
- *
519
- * @docs
520
- */
521
- assert_non_positive() {
522
- if (this.int_value > 0n) {
523
- throw new Error(`Invalid value: expected non-positive integer, got ${this.int_value.toString()}`);
524
- }
525
- }
526
- /**
527
- * Assert `value` is a `<0` integer.
528
- *
529
- * @docs
530
- */
531
- assert_negative() {
532
- if (this.int_value >= 0n) {
533
- throw new Error(`Invalid value: expected negative integer, got ${this.int_value.toString()}`);
534
- }
535
- }
536
- /**
537
- * Assert `value` is a `>=0` safe integer.
538
- *
539
- * @docs
540
- */
541
- static assert_non_negative(value, label) {
542
- if (!Number.isSafeInteger(value) || value < 0) {
543
- throw new Error(`Invalid '${label}': expected non-negative safe integer, got ${value}`);
544
- }
545
- }
546
- /**
547
- * Assert `value` is a `>0` safe integer.
548
- *
549
- * @docs
550
- */
551
- static assert_positive(value, label) {
552
- if (!Number.isSafeInteger(value) || value <= 0) {
553
- throw new Error(`Invalid '${label}': expected positive safe integer, got ${value}`);
554
- }
555
- }
556
- /**
557
- * Assert `value` is a `<=0` safe integer.
558
- *
559
- * @docs
560
- */
561
- static assert_non_positive(value, label) {
562
- if (!Number.isSafeInteger(value) || value > 0) {
563
- throw new Error(`Invalid '${label}': expected non-positive safe integer, got ${value}`);
564
- }
565
- }
566
- /**
567
- * Assert `value` is a `<0` safe integer.
568
- *
569
- * @docs
570
- */
571
- static assert_negative(value, label) {
572
- if (!Number.isSafeInteger(value) || value >= 0) {
573
- throw new Error(`Invalid '${label}': expected negative safe integer, got ${value}`);
574
- }
575
- }
576
- // ----------------------------------------------------------------
577
- // static helpers (internal)
578
- // ----------------------------------------------------------------
579
- /**
580
- * Apply a rounding to a floating value.
581
- *
582
- * @param v Floating value to round.
583
- * @param round Rounding mode.
584
- * @returns Rounded integer (validated by the caller).
585
- * @internal
586
- */
587
- static apply_round(v, round) {
588
- if (!Number.isFinite(v))
589
- throw new Error(`Invalid value for rounding: ${v}`);
590
- if (round === "floor")
591
- return Math.floor(v);
592
- if (round === "ceil")
593
- return Math.ceil(v);
594
- if (round === "round")
595
- return Math.round(v);
596
- throw new Error(`apply_round() called with round='exact' which forbids rounding`);
597
- }
598
- /**
599
- * Parse an integer string into bigint.
600
- * - Allows optional leading +/-.
601
- * - Allows underscores as separators.
602
- * - Rejects decimals.
603
- *
604
- * @internal
605
- */
606
- static parse_int_str(text, label) {
607
- const s = text.trim().replace(/_/g, "");
608
- if (s.length === 0)
609
- throw new Error(`Invalid '${label}': empty string`);
610
- if (!/^[+-]?\d+$/.test(s)) {
611
- throw new Error(`Invalid '${label}': expected integer string, got '${text}'`);
612
- }
613
- // BigInt() accepts leading +/- and digits.
614
- return BigInt(s);
615
- }
616
- /**
617
- * Parse a base-scale decimal string and convert to an integer at `to_scale` using bigint math.
618
- *
619
- * Examples:
620
- * "1.5" with to_scale=1000 => 1500
621
- * "-0.001" with to_scale=1000 => -1
622
- *
623
- * - Underscores are allowed.
624
- * - Exact by default; non-exact requires a rounding mode.
625
- *
626
- * @internal
627
- */
628
- static parse_base_decimal_to_scaled(text, to_scale, round) {
629
- const raw = text.trim().replace(/_/g, "");
630
- if (raw.length === 0)
631
- throw new Error(`Invalid 'value': empty string`);
632
- let sign = 1n;
633
- let s = raw;
634
- if (s[0] === "+")
635
- s = s.slice(1);
636
- else if (s[0] === "-") {
637
- sign = -1n;
638
- s = s.slice(1);
639
- }
640
- if (s.length === 0)
641
- throw new Error(`Invalid 'value': expected digits, got '${text}'`);
642
- const parts = s.split(".");
643
- if (parts.length > 2)
644
- throw new Error(`Invalid 'value': too many decimal points in '${text}'`);
645
- const int_part = parts[0] === "" ? "0" : parts[0];
646
- const frac_part = parts.length === 2 ? (parts[1] ?? "") : "";
647
- if (!/^\d+$/.test(int_part)) {
648
- throw new Error(`Invalid 'value': invalid integer part in '${text}'`);
649
- }
650
- if (frac_part !== "" && !/^\d+$/.test(frac_part)) {
651
- throw new Error(`Invalid 'value': invalid fractional part in '${text}'`);
652
- }
653
- const k = frac_part.length;
654
- const denom = k === 0 ? 1n : SafeInt.pow10(k);
655
- const whole = BigInt(int_part);
656
- const frac = frac_part === "" ? 0n : BigInt(frac_part);
657
- const numerator = (whole * denom + frac) * sign; // value = numerator / denom
658
- // scaled = (numerator * to_scale) / denom with rounding
659
- const scaled_num = numerator * BigInt(to_scale);
660
- return SafeInt.div_int_checked(scaled_num, denom, round);
661
- }
662
- /**
663
- * Compute 10^n as bigint.
664
- * @internal
665
- */
666
- static pow10(n) {
667
- if (!Number.isSafeInteger(n) || n < 0) {
668
- throw new Error(`Invalid pow10 exponent: ${n}`);
669
- }
670
- // Guard against pathological inputs (optional; adjust as you like)
671
- if (n > 1_000) {
672
- throw new Error(`Invalid decimal precision: ${n} (too large)`);
673
- }
674
- // Fast enough for typical precision values; avoids floating-point.
675
- return BigInt("1" + "0".repeat(n));
676
- }
677
- /**
678
- * Convert integer-scale value → base **integer** using a rounding policy.
679
- *
680
- * @param value Integer at `from_scale` (may be negative).
681
- * @param from_scale Source scale.
682
- * @param round Rounding (default exact).
683
- * @returns Base-scale integer.
684
- * @internal
685
- */
686
- static div_to_base(value, from_scale, round) {
687
- const denom = BigInt(from_scale);
688
- if (round === "exact") {
689
- if (value % denom !== 0n) {
690
- throw new Error(`Exact conversion to base failed: ${value.toString()} % ${from_scale} !== 0`);
691
- }
692
- return value / denom;
693
- }
694
- return SafeInt.div_int_checked(value, denom, round);
695
- }
696
- /**
697
- * Integer division helper with selectable rounding semantics.
698
- *
699
- * @param numerator Integer (may be negative).
700
- * @param denominator Positive integer.
701
- * @param round Rounding mode (default `"exact"`).
702
- * @returns Integer quotient as per {@link round}.
703
- *
704
- * @throws Error On invalid inputs, division by zero, or non-exact remainder in `"exact"`.
705
- * @internal
706
- */
707
- static div_int_checked(numerator, denominator, round = "exact") {
708
- if (denominator <= 0n)
709
- throw new Error(`Invalid denominator: ${denominator.toString()}`);
710
- const q = numerator / denominator; // trunc toward 0
711
- const rem = numerator % denominator; // same sign as numerator
712
- if (round === "exact") {
713
- if (rem !== 0n)
714
- throw new Error(`Non-exact division: ${numerator.toString()} / ${denominator.toString()} leaves remainder ${rem.toString()}`);
715
- return q;
716
- }
717
- if (rem === 0n)
718
- return q;
719
- if (round === "floor") {
720
- // if numerator is negative, trunc is "too high" (closer to 0) compared to floor
721
- return numerator < 0n ? q - 1n : q;
722
- }
723
- if (round === "ceil") {
724
- // if numerator is positive, trunc is "too low" compared to ceil
725
- return numerator > 0n ? q + 1n : q;
726
- }
727
- if (round === "round") {
728
- const absRem = rem < 0n ? -rem : rem;
729
- const twice = absRem * 2n;
730
- if (twice < denominator)
731
- return q;
732
- // ties + above: move away from zero
733
- return numerator >= 0n ? q + 1n : q - 1n;
734
- }
735
- throw new Error(`Invalid round: ${round}`);
736
- }
737
- /**
738
- * Integer-only scale converter with rounding policy.
739
- *
740
- * @param value Integer at {@link from_scale} (may be negative).
741
- * @param from_scale Integer source scale.
742
- * @param to_scale Integer target scale.
743
- * @param round Rounding mode (default exact).
744
- * @returns Integer at `to_scale`.
745
- *
746
- * @throws Error On invalid inputs.
747
- * @internal
748
- */
749
- static convert_int_scale(value, from_scale, to_scale, round) {
750
- if (!Number.isSafeInteger(from_scale) || from_scale <= 0) {
751
- throw new Error(`Invalid from_scale: expected positive safe integer, got ${from_scale}`);
752
- }
753
- if (!Number.isSafeInteger(to_scale) || to_scale <= 0) {
754
- throw new Error(`Invalid to_scale: expected positive safe integer, got ${to_scale}`);
755
- }
756
- if (from_scale === to_scale)
757
- return value;
758
- // exact divisor path
759
- if (from_scale % to_scale === 0) {
760
- const divisor = BigInt(Math.trunc(from_scale / to_scale));
761
- return SafeInt.div_int_checked(value, divisor, round);
762
- }
763
- // exact multiplier path
764
- if (to_scale % from_scale === 0) {
765
- const multiplier = BigInt(Math.trunc(to_scale / from_scale));
766
- return value * multiplier;
767
- }
768
- // general ratio: (value * to_scale) / from_scale with chosen rounding
769
- const numerator = value * BigInt(to_scale);
770
- return SafeInt.div_int_checked(numerator, BigInt(from_scale), round);
771
- }
772
- }
773
- /* ============================================================================
774
- Namespace: shared types & constants for SafeInt
775
- ========================================================================== */
776
- (function (SafeInt) {
777
- /**
778
- * Canonical integer scales (units-per-base).
779
- *
780
- * @example
781
- * Base = 1, Milli = 1e3, Micro = 1e6, Nano = 1e9, Pico = 1e12
782
- *
783
- * @docs
784
- */
785
- let Scale;
786
- (function (Scale) {
787
- /** Base units (whole units). */
788
- Scale[Scale["Base"] = 1] = "Base";
789
- /** Milli units (1e3 per base). */
790
- Scale[Scale["Milli"] = 1000] = "Milli";
791
- /** Micro units (1e6 per base). */
792
- Scale[Scale["Micro"] = 1000000] = "Micro";
793
- /** Nano units (1e9 per base). */
794
- Scale[Scale["Nano"] = 1000000000] = "Nano";
795
- /** Pico units (1e12 per base). */
796
- Scale[Scale["Pico"] = 1000000000000] = "Pico";
797
- })(Scale = SafeInt.Scale || (SafeInt.Scale = {}));
798
- /** Convert a string scale to the actual scale. */
799
- function str_to_scale(scale) {
800
- switch (scale) {
801
- case "base": return Scale.Base;
802
- case "milli": return Scale.Milli;
803
- case "micro": return Scale.Micro;
804
- case "nano": return Scale.Nano;
805
- case "pico": return Scale.Pico;
806
- default: throw new Error(`Unknown scale: ${scale}`);
807
- }
808
- }
809
- SafeInt.str_to_scale = str_to_scale;
810
- })(SafeInt || (SafeInt = {}));