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