@vandenberghinc/volt 1.1.26 → 1.1.28
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/backend/dist/cjs/{blacklist.d.ts → backend/src/blacklist.d.ts} +5 -3
- package/backend/dist/cjs/{blacklist.js → backend/src/blacklist.js} +8 -5
- package/backend/dist/cjs/{cli.js → backend/src/cli.js} +29 -47
- package/backend/dist/cjs/backend/src/database/collection.d.ts +1543 -0
- package/backend/dist/cjs/backend/src/database/collection.js +3042 -0
- package/backend/dist/cjs/backend/src/database/database.d.ts +66 -0
- package/backend/dist/cjs/{database → backend/src/database}/database.js +48 -43
- package/backend/dist/cjs/backend/src/database/filters/filters.d.ts +6 -0
- package/backend/dist/cjs/backend/src/database/filters/filters.js +15 -0
- package/backend/dist/cjs/backend/src/database/filters/strict_filter.d.ts +223 -0
- package/backend/dist/cjs/backend/src/database/filters/strict_filter.js +15 -0
- package/backend/dist/cjs/backend/src/database/filters/strict_filter_test.js +443 -0
- package/backend/dist/cjs/backend/src/database/filters/strict_filter_test_v0.js +15 -0
- package/backend/dist/cjs/backend/src/database/filters/strict_filter_v0.d.ts +50 -0
- package/backend/dist/cjs/backend/src/database/filters/strict_filter_v0.js +15 -0
- package/backend/dist/cjs/backend/src/database/filters/strict_filter_v1.d.ts +76 -0
- package/backend/dist/cjs/backend/src/database/filters/strict_filter_v1.js +15 -0
- package/backend/dist/cjs/backend/src/database/filters/strict_filter_v2.d.ts +75 -0
- package/backend/dist/cjs/backend/src/database/filters/strict_filter_v2.js +15 -0
- package/backend/dist/cjs/backend/src/database/filters/strict_filter_v3.d.ts +219 -0
- package/backend/dist/cjs/backend/src/database/filters/strict_filter_v3.js +15 -0
- package/backend/dist/cjs/backend/src/database/filters/strict_update_filter.d.ts +165 -0
- package/backend/dist/cjs/backend/src/database/filters/strict_update_filter.js +15 -0
- package/backend/dist/cjs/backend/src/database/filters/strict_update_filter_test.d.ts +5 -0
- package/backend/dist/cjs/backend/src/database/filters/strict_update_filter_test.js +355 -0
- package/backend/dist/cjs/backend/src/database/flatten.d.ts +75 -0
- package/backend/dist/cjs/{logger.js → backend/src/database/flatten.js} +18 -7
- package/backend/dist/cjs/backend/src/database/flatten_test.js +175 -0
- package/backend/dist/cjs/backend/src/database/quota/quota.d.ts +461 -0
- package/backend/dist/cjs/backend/src/database/quota/quota.js +1014 -0
- package/backend/dist/cjs/backend/src/database/quota/quota_v1.d.ts +534 -0
- package/backend/dist/cjs/backend/src/database/quota/quota_v1.js +1087 -0
- package/backend/dist/cjs/backend/src/database/quota/safe_int.d.ts +293 -0
- package/backend/dist/cjs/backend/src/database/quota/safe_int.js +573 -0
- package/backend/dist/{esm → cjs/backend/src}/endpoint.d.ts +69 -46
- package/backend/dist/cjs/{endpoint.js → backend/src/endpoint.js} +87 -101
- package/backend/dist/cjs/backend/src/errors/index.d.ts +7 -0
- package/backend/dist/cjs/backend/src/errors/index.js +25 -0
- package/backend/dist/{esm/utils.d.ts → cjs/backend/src/errors/internal_external.d.ts} +14 -22
- package/backend/dist/cjs/backend/src/errors/internal_external.js +85 -0
- package/backend/dist/cjs/backend/src/errors/invalid_usage_error.d.ts +38 -0
- package/backend/dist/cjs/{mutex.js → backend/src/errors/invalid_usage_error.js} +20 -37
- package/backend/dist/cjs/backend/src/errors/system_error.d.ts +230 -0
- package/backend/dist/cjs/backend/src/errors/system_error.js +393 -0
- package/backend/dist/cjs/backend/src/events.d.ts +54 -0
- package/backend/dist/cjs/backend/src/events.js +15 -0
- package/backend/dist/cjs/{frontend.js → backend/src/frontend.js} +1 -1
- package/backend/dist/cjs/{image_endpoint.d.ts → backend/src/image_endpoint.d.ts} +16 -1
- package/backend/dist/cjs/{image_endpoint.js → backend/src/image_endpoint.js} +3 -5
- package/backend/dist/cjs/backend/src/logger.d.ts +5 -0
- package/backend/dist/cjs/backend/src/logger.js +15 -0
- package/backend/dist/cjs/backend/src/meta.d.ts +64 -0
- package/backend/dist/cjs/{meta.js → backend/src/meta.js} +9 -12
- package/backend/dist/cjs/backend/src/payments/paddle.d.ts +326 -0
- package/backend/dist/cjs/{payments → backend/src/payments}/paddle.js +377 -327
- package/backend/dist/cjs/backend/src/plugins/browser.d.ts +1 -0
- package/backend/dist/cjs/backend/src/plugins/browser.js +15 -0
- package/backend/dist/cjs/backend/src/plugins/mail/mail.d.ts +248 -0
- package/backend/dist/cjs/backend/src/plugins/mail/mail.js +379 -0
- package/backend/dist/{esm → cjs/backend/src}/plugins/mail/ui.d.ts +23 -0
- package/backend/dist/cjs/backend/src/plugins/pdf.d.ts +1 -0
- package/backend/dist/cjs/backend/src/rate_limit.d.ts +145 -0
- package/backend/dist/cjs/backend/src/rate_limit.js +549 -0
- package/backend/dist/cjs/{route.d.ts → backend/src/route.d.ts} +3 -10
- package/backend/dist/cjs/{route.js → backend/src/route.js} +23 -21
- package/backend/dist/cjs/backend/src/server.d.ts +485 -0
- package/backend/dist/cjs/{server.js → backend/src/server.js} +688 -873
- package/backend/dist/cjs/backend/src/splash_screen.d.ts +80 -0
- package/backend/dist/cjs/{splash_screen.js → backend/src/splash_screen.js} +24 -3
- package/backend/dist/cjs/backend/src/status.d.ts +74 -0
- package/backend/dist/cjs/{status.js → backend/src/status.js} +64 -64
- package/backend/dist/cjs/backend/src/stream.d.ts +376 -0
- package/backend/dist/cjs/{stream.js → backend/src/stream.js} +299 -276
- package/backend/dist/cjs/backend/src/users.d.ts +807 -0
- package/backend/dist/cjs/backend/src/users.js +1971 -0
- package/backend/dist/cjs/backend/src/utils.d.ts +16 -0
- package/backend/dist/cjs/{utils.js → backend/src/utils.js} +14 -77
- package/backend/dist/{esm → cjs/backend/src}/view.d.ts +33 -11
- package/backend/dist/cjs/backend/src/view.js +508 -0
- package/backend/dist/{esm → cjs/backend/src}/volt.d.ts +10 -1
- package/backend/dist/cjs/{volt.js → backend/src/volt.js} +8 -5
- package/backend/dist/cjs/frontend/src/modules/request.d.ts +70 -0
- package/backend/dist/cjs/frontend/src/modules/request.js +99 -0
- package/backend/dist/esm/{blacklist.d.ts → backend/src/blacklist.d.ts} +5 -3
- package/backend/dist/esm/{blacklist.js → backend/src/blacklist.js} +9 -6
- package/backend/dist/esm/{cli.js → backend/src/cli.js} +43 -60
- package/backend/dist/esm/backend/src/database/collection.d.ts +1543 -0
- package/backend/dist/esm/backend/src/database/collection.js +3510 -0
- package/backend/dist/esm/backend/src/database/database.d.ts +66 -0
- package/backend/dist/esm/{database → backend/src/database}/database.js +62 -103
- package/backend/dist/esm/backend/src/database/document.d.ts +1 -0
- package/backend/dist/esm/backend/src/database/document.js +558 -0
- package/backend/dist/esm/backend/src/database/filters/filters.d.ts +6 -0
- package/backend/dist/esm/backend/src/database/filters/filters.js +1 -0
- package/backend/dist/esm/backend/src/database/filters/strict_filter.d.ts +223 -0
- package/backend/dist/esm/backend/src/database/filters/strict_filter.js +3 -0
- package/backend/dist/esm/backend/src/database/filters/strict_filter_test.d.ts +1 -0
- package/backend/dist/esm/backend/src/database/filters/strict_filter_test.js +505 -0
- package/backend/dist/esm/backend/src/database/filters/strict_filter_test_v0.d.ts +1 -0
- package/backend/dist/esm/backend/src/database/filters/strict_filter_test_v0.js +712 -0
- package/backend/dist/esm/backend/src/database/filters/strict_filter_v0.d.ts +50 -0
- package/backend/dist/esm/backend/src/database/filters/strict_filter_v0.js +5 -0
- package/backend/dist/esm/backend/src/database/filters/strict_filter_v1.d.ts +76 -0
- package/backend/dist/esm/backend/src/database/filters/strict_filter_v1.js +44 -0
- package/backend/dist/esm/backend/src/database/filters/strict_filter_v2.d.ts +75 -0
- package/backend/dist/esm/backend/src/database/filters/strict_filter_v2.js +5 -0
- package/backend/dist/esm/backend/src/database/filters/strict_filter_v3.d.ts +219 -0
- package/backend/dist/esm/backend/src/database/filters/strict_filter_v3.js +1 -0
- package/backend/dist/esm/backend/src/database/filters/strict_update_filter.d.ts +165 -0
- package/backend/dist/esm/backend/src/database/filters/strict_update_filter.js +5 -0
- package/backend/dist/esm/backend/src/database/filters/strict_update_filter_test.d.ts +5 -0
- package/backend/dist/esm/backend/src/database/filters/strict_update_filter_test.js +405 -0
- package/backend/dist/esm/backend/src/database/flatten.d.ts +75 -0
- package/backend/dist/esm/backend/src/database/flatten.js +22 -0
- package/backend/dist/esm/backend/src/database/flatten_test.d.ts +1 -0
- package/backend/dist/esm/backend/src/database/flatten_test.js +174 -0
- package/backend/dist/esm/backend/src/database/quota/quota.d.ts +461 -0
- package/backend/dist/esm/backend/src/database/quota/quota.js +1118 -0
- package/backend/dist/esm/backend/src/database/quota/quota_v1.d.ts +534 -0
- package/backend/dist/esm/backend/src/database/quota/quota_v1.js +1242 -0
- package/backend/dist/esm/backend/src/database/quota/safe_int.d.ts +293 -0
- package/backend/dist/esm/backend/src/database/quota/safe_int.js +602 -0
- package/backend/dist/{cjs → esm/backend/src}/endpoint.d.ts +69 -46
- package/backend/dist/esm/{endpoint.js → backend/src/endpoint.js} +136 -127
- package/backend/dist/esm/backend/src/errors/index.d.ts +7 -0
- package/backend/dist/esm/backend/src/errors/index.js +7 -0
- package/backend/dist/{cjs/utils.d.ts → esm/backend/src/errors/internal_external.d.ts} +14 -22
- package/backend/dist/esm/backend/src/errors/internal_external.js +70 -0
- package/backend/dist/esm/backend/src/errors/invalid_usage_error.d.ts +38 -0
- package/backend/dist/esm/backend/src/errors/invalid_usage_error.js +30 -0
- package/backend/dist/esm/backend/src/errors/system_error.d.ts +230 -0
- package/backend/dist/esm/backend/src/errors/system_error.js +402 -0
- package/backend/dist/esm/backend/src/events.d.ts +54 -0
- package/backend/dist/esm/backend/src/events.js +5 -0
- package/backend/dist/esm/{frontend.js → backend/src/frontend.js} +1 -1
- package/backend/dist/esm/{image_endpoint.d.ts → backend/src/image_endpoint.d.ts} +16 -1
- package/backend/dist/esm/{image_endpoint.js → backend/src/image_endpoint.js} +16 -20
- package/backend/dist/esm/backend/src/logger.d.ts +5 -0
- package/backend/dist/esm/backend/src/logger.js +8 -0
- package/backend/dist/esm/backend/src/meta.d.ts +64 -0
- package/backend/dist/esm/{meta.js → backend/src/meta.js} +15 -54
- package/backend/dist/esm/backend/src/payments/paddle.d.ts +326 -0
- package/backend/dist/esm/{payments → backend/src/payments}/paddle.js +417 -452
- package/backend/dist/esm/backend/src/plugins/browser.d.ts +1 -0
- package/backend/dist/esm/backend/src/plugins/browser.js +170 -0
- package/backend/dist/esm/backend/src/plugins/mail/mail.d.ts +248 -0
- package/backend/dist/esm/backend/src/plugins/mail/mail.js +389 -0
- package/backend/dist/{cjs → esm/backend/src}/plugins/mail/ui.d.ts +23 -0
- package/backend/dist/esm/{plugins → backend/src/plugins}/mail/ui.js +3 -6
- package/backend/dist/esm/backend/src/plugins/pdf.d.ts +1 -0
- package/backend/dist/esm/{plugins → backend/src/plugins}/pdf.js +3 -3
- package/backend/dist/esm/backend/src/rate_limit.d.ts +145 -0
- package/backend/dist/esm/backend/src/rate_limit.js +667 -0
- package/backend/dist/esm/{route.d.ts → backend/src/route.d.ts} +3 -10
- package/backend/dist/esm/{route.js → backend/src/route.js} +26 -21
- package/backend/dist/esm/backend/src/server.d.ts +485 -0
- package/backend/dist/esm/{server.js → backend/src/server.js} +891 -1441
- package/backend/dist/esm/backend/src/splash_screen.d.ts +80 -0
- package/backend/dist/esm/{splash_screen.js → backend/src/splash_screen.js} +42 -55
- package/backend/dist/esm/backend/src/status.d.ts +74 -0
- package/backend/dist/esm/backend/src/status.js +199 -0
- package/backend/dist/esm/backend/src/stream.d.ts +376 -0
- package/backend/dist/esm/{stream.js → backend/src/stream.js} +327 -292
- package/backend/dist/esm/backend/src/users.d.ts +809 -0
- package/backend/dist/esm/backend/src/users.js +2140 -0
- package/backend/dist/esm/backend/src/utils.d.ts +16 -0
- package/backend/dist/esm/{utils.js → backend/src/utils.js} +20 -81
- package/backend/dist/{cjs → esm/backend/src}/view.d.ts +33 -11
- package/backend/dist/esm/{view.js → backend/src/view.js} +266 -86
- package/backend/dist/{cjs → esm/backend/src}/volt.d.ts +10 -1
- package/backend/dist/esm/{volt.js → backend/src/volt.js} +7 -4
- package/backend/dist/esm/frontend/src/modules/request.d.ts +70 -0
- package/backend/dist/esm/frontend/src/modules/request.js +117 -0
- package/frontend/dist/backend/src/database/collection.d.ts +1543 -0
- package/frontend/dist/backend/src/database/collection.js +3510 -0
- package/frontend/dist/backend/src/database/database.d.ts +66 -0
- package/frontend/dist/backend/src/database/database.js +196 -0
- package/frontend/dist/backend/src/database/filters/filters.d.ts +6 -0
- package/frontend/dist/backend/src/database/filters/filters.js +1 -0
- package/frontend/dist/backend/src/database/filters/strict_filter.d.ts +223 -0
- package/frontend/dist/backend/src/database/filters/strict_filter.js +3 -0
- package/frontend/dist/backend/src/database/filters/strict_update_filter.d.ts +165 -0
- package/frontend/dist/backend/src/database/filters/strict_update_filter.js +5 -0
- package/frontend/dist/backend/src/database/flatten.d.ts +75 -0
- package/frontend/dist/backend/src/database/flatten.js +22 -0
- package/frontend/dist/backend/src/endpoint.d.ts +204 -0
- package/frontend/dist/backend/src/endpoint.js +570 -0
- package/frontend/dist/backend/src/errors/index.d.ts +7 -0
- package/frontend/dist/backend/src/errors/index.js +7 -0
- package/frontend/dist/backend/src/errors/internal_external.d.ts +38 -0
- package/frontend/dist/backend/src/errors/internal_external.js +70 -0
- package/frontend/dist/backend/src/errors/invalid_usage_error.d.ts +38 -0
- package/frontend/dist/backend/src/errors/invalid_usage_error.js +30 -0
- package/frontend/dist/backend/src/errors/system_error.d.ts +230 -0
- package/frontend/dist/backend/src/errors/system_error.js +402 -0
- package/frontend/dist/backend/src/events.d.ts +54 -0
- package/frontend/dist/backend/src/events.js +5 -0
- package/frontend/dist/backend/src/frontend.d.ts +11 -0
- package/frontend/dist/backend/src/frontend.js +12 -0
- package/frontend/dist/backend/src/image_endpoint.d.ts +39 -0
- package/frontend/dist/backend/src/image_endpoint.js +202 -0
- package/frontend/dist/backend/src/meta.d.ts +64 -0
- package/frontend/dist/backend/src/meta.js +110 -0
- package/frontend/dist/backend/src/payments/paddle.d.ts +326 -0
- package/frontend/dist/backend/src/payments/paddle.js +2256 -0
- package/frontend/dist/backend/src/plugins/mail/mail.d.ts +248 -0
- package/frontend/dist/backend/src/plugins/mail/mail.js +389 -0
- package/{backend/dist/esm/plugins/mail.d.ts → frontend/dist/backend/src/plugins/mail/ui.d.ts} +23 -0
- package/{backend/dist/esm/plugins/mail.js → frontend/dist/backend/src/plugins/mail/ui.js} +3 -6
- package/frontend/dist/backend/src/rate_limit.d.ts +145 -0
- package/frontend/dist/backend/src/rate_limit.js +673 -0
- package/frontend/dist/backend/src/route.d.ts +35 -0
- package/frontend/dist/backend/src/route.js +212 -0
- package/frontend/dist/backend/src/server.d.ts +485 -0
- package/frontend/dist/backend/src/server.js +2670 -0
- package/frontend/dist/backend/src/splash_screen.d.ts +80 -0
- package/frontend/dist/backend/src/splash_screen.js +135 -0
- package/frontend/dist/backend/src/status.d.ts +74 -0
- package/frontend/dist/backend/src/status.js +199 -0
- package/frontend/dist/backend/src/stream.d.ts +376 -0
- package/frontend/dist/backend/src/stream.js +1007 -0
- package/frontend/dist/backend/src/users.d.ts +807 -0
- package/frontend/dist/backend/src/users.js +2118 -0
- package/frontend/dist/backend/src/utils.d.ts +16 -0
- package/frontend/dist/backend/src/utils.js +241 -0
- package/frontend/dist/backend/src/view.d.ts +162 -0
- package/frontend/dist/backend/src/view.js +720 -0
- package/frontend/dist/frontend/src/elements/base.d.ts +4414 -0
- package/frontend/dist/{elements → frontend/src/elements}/base.js +3624 -260
- package/frontend/dist/frontend/src/elements/module.d.ts +95 -0
- package/frontend/dist/{elements → frontend/src/elements}/module.js +53 -52
- package/frontend/dist/frontend/src/elements/types.d.ts +52 -0
- package/frontend/dist/frontend/src/elements/types.js +5 -0
- package/frontend/dist/frontend/src/modules/attachment.d.ts +126 -0
- package/frontend/dist/frontend/src/modules/attachment.js +306 -0
- package/frontend/dist/frontend/src/modules/auth.d.ts +44 -0
- package/frontend/dist/frontend/src/modules/auth.js +80 -0
- package/frontend/dist/{modules → frontend/src/modules}/color.js +2 -2
- package/frontend/dist/frontend/src/modules/compression.d.ts +39 -0
- package/frontend/dist/frontend/src/modules/compression.js +102 -0
- package/frontend/dist/frontend/src/modules/cookies.d.ts +44 -0
- package/frontend/dist/frontend/src/modules/cookies.js +143 -0
- package/frontend/dist/frontend/src/modules/events.d.ts +31 -0
- package/frontend/dist/frontend/src/modules/events.js +74 -0
- package/frontend/dist/frontend/src/modules/google.d.ts +23 -0
- package/frontend/dist/frontend/src/modules/google.js +52 -0
- package/frontend/dist/frontend/src/modules/meta.d.ts +14 -0
- package/frontend/dist/{modules → frontend/src/modules}/meta.js +9 -7
- package/frontend/dist/{modules → frontend/src/modules}/paddle.d.ts +37 -134
- package/frontend/dist/{modules → frontend/src/modules}/paddle.js +620 -568
- package/frontend/dist/frontend/src/modules/request.d.ts +70 -0
- package/frontend/dist/frontend/src/modules/request.js +117 -0
- package/frontend/dist/frontend/src/modules/settings.d.ts +3 -0
- package/frontend/dist/frontend/src/modules/settings.js +5 -0
- package/frontend/dist/frontend/src/modules/statics.d.ts +21 -0
- package/frontend/dist/{modules → frontend/src/modules}/statics.js +15 -18
- package/frontend/dist/frontend/src/modules/support.d.ts +30 -0
- package/frontend/dist/frontend/src/modules/support.js +53 -0
- package/frontend/dist/{modules → frontend/src/modules}/theme.d.ts +67 -0
- package/frontend/dist/{modules → frontend/src/modules}/theme.js +68 -38
- package/frontend/dist/frontend/src/modules/themes.d.ts +12 -0
- package/frontend/dist/frontend/src/modules/themes.js +22 -0
- package/frontend/dist/frontend/src/modules/user.d.ts +164 -0
- package/frontend/dist/frontend/src/modules/user.js +268 -0
- package/frontend/dist/frontend/src/modules/utils.d.ts +176 -0
- package/frontend/dist/frontend/src/modules/utils.js +569 -0
- package/frontend/dist/frontend/src/types/gradient.d.ts +29 -0
- package/frontend/dist/{types → frontend/src/types}/gradient.js +14 -18
- package/frontend/dist/frontend/src/ui/border_button.d.ts +94 -0
- package/frontend/dist/{ui → frontend/src/ui}/border_button.js +7 -13
- package/frontend/dist/frontend/src/ui/button.d.ts +28 -0
- package/frontend/dist/{ui → frontend/src/ui}/button.js +21 -12
- package/frontend/dist/frontend/src/ui/canvas.d.ts +138 -0
- package/frontend/dist/{ui → frontend/src/ui}/canvas.js +88 -55
- package/frontend/dist/frontend/src/ui/checkbox.d.ts +74 -0
- package/frontend/dist/{ui → frontend/src/ui}/checkbox.js +80 -41
- package/frontend/dist/{ui → frontend/src/ui}/code.d.ts +73 -6
- package/frontend/dist/{ui → frontend/src/ui}/code.js +55 -52
- package/frontend/dist/{ui → frontend/src/ui}/context_menu.d.ts +4 -0
- package/frontend/dist/{ui → frontend/src/ui}/context_menu.js +12 -17
- package/frontend/dist/{ui → frontend/src/ui}/css.d.ts +4 -0
- package/frontend/dist/{ui → frontend/src/ui}/css.js +3 -3
- package/frontend/dist/{ui → frontend/src/ui}/divider.d.ts +4 -0
- package/frontend/dist/{ui → frontend/src/ui}/divider.js +3 -3
- package/frontend/dist/{ui → frontend/src/ui}/dropdown.d.ts +57 -2
- package/frontend/dist/{ui → frontend/src/ui}/dropdown.js +87 -94
- package/frontend/dist/{ui → frontend/src/ui}/for_each.d.ts +4 -0
- package/frontend/dist/{ui → frontend/src/ui}/for_each.js +3 -3
- package/frontend/dist/{ui → frontend/src/ui}/form.d.ts +6 -2
- package/frontend/dist/{ui → frontend/src/ui}/form.js +10 -7
- package/frontend/dist/frontend/src/ui/frame_modes.d.ts +37 -0
- package/frontend/dist/{ui → frontend/src/ui}/frame_modes.js +16 -22
- package/frontend/dist/{ui → frontend/src/ui}/google_map.d.ts +4 -0
- package/frontend/dist/{ui → frontend/src/ui}/google_map.js +4 -4
- package/frontend/dist/{ui → frontend/src/ui}/gradient.d.ts +4 -0
- package/frontend/dist/{ui → frontend/src/ui}/gradient.js +3 -3
- package/frontend/dist/{ui → frontend/src/ui}/image.d.ts +4 -0
- package/frontend/dist/{ui → frontend/src/ui}/image.js +5 -5
- package/frontend/dist/frontend/src/ui/input.d.ts +392 -0
- package/frontend/dist/{ui → frontend/src/ui}/input.js +346 -360
- package/frontend/dist/{ui → frontend/src/ui}/link.d.ts +4 -0
- package/frontend/dist/{ui → frontend/src/ui}/link.js +3 -3
- package/frontend/dist/{ui → frontend/src/ui}/list.d.ts +4 -0
- package/frontend/dist/{ui → frontend/src/ui}/list.js +12 -6
- package/frontend/dist/frontend/src/ui/loader_button.d.ts +80 -0
- package/frontend/dist/{ui → frontend/src/ui}/loader_button.js +35 -47
- package/frontend/dist/frontend/src/ui/loaders.d.ts +57 -0
- package/frontend/dist/{ui → frontend/src/ui}/loaders.js +11 -11
- package/frontend/dist/{ui → frontend/src/ui}/popup.d.ts +11 -6
- package/frontend/dist/{ui → frontend/src/ui}/popup.js +32 -18
- package/frontend/dist/frontend/src/ui/pseudo.d.ts +44 -0
- package/frontend/dist/{ui → frontend/src/ui}/pseudo.js +84 -8
- package/frontend/dist/{ui → frontend/src/ui}/scroller.d.ts +14 -2
- package/frontend/dist/{ui → frontend/src/ui}/scroller.js +37 -43
- package/frontend/dist/{ui → frontend/src/ui}/slider.d.ts +5 -1
- package/frontend/dist/{ui → frontend/src/ui}/slider.js +4 -4
- package/frontend/dist/{ui → frontend/src/ui}/spacer.d.ts +4 -0
- package/frontend/dist/{ui → frontend/src/ui}/spacer.js +3 -3
- package/frontend/dist/{ui → frontend/src/ui}/span.d.ts +4 -0
- package/frontend/dist/{ui → frontend/src/ui}/span.js +3 -3
- package/frontend/dist/{ui → frontend/src/ui}/stack.d.ts +4 -0
- package/frontend/dist/{ui → frontend/src/ui}/stack.js +3 -9
- package/frontend/dist/frontend/src/ui/steps.d.ts +131 -0
- package/frontend/dist/{ui → frontend/src/ui}/steps.js +30 -45
- package/frontend/dist/{ui → frontend/src/ui}/style.d.ts +4 -0
- package/frontend/dist/{ui → frontend/src/ui}/style.js +3 -3
- package/frontend/dist/{ui → frontend/src/ui}/switch.d.ts +5 -1
- package/frontend/dist/{ui → frontend/src/ui}/switch.js +4 -4
- package/frontend/dist/{ui → frontend/src/ui}/table.d.ts +4 -0
- package/frontend/dist/{ui → frontend/src/ui}/table.js +6 -6
- package/frontend/dist/{ui → frontend/src/ui}/tabs.d.ts +45 -3
- package/frontend/dist/{ui → frontend/src/ui}/tabs.js +65 -40
- package/frontend/dist/{ui → frontend/src/ui}/text.d.ts +4 -0
- package/frontend/dist/{ui → frontend/src/ui}/text.js +3 -3
- package/frontend/dist/frontend/src/ui/title.d.ts +91 -0
- package/frontend/dist/frontend/src/ui/title.js +272 -0
- package/frontend/dist/{ui → frontend/src/ui}/view.d.ts +4 -0
- package/frontend/dist/{ui → frontend/src/ui}/view.js +3 -3
- package/frontend/dist/{volt.d.ts → frontend/src/volt.d.ts} +3 -0
- package/frontend/dist/{volt.js → frontend/src/volt.js} +4 -0
- package/frontend/tools/bundle_d_ts.js +71 -0
- package/frontend/tools/convert_to_jsdoc_input.txt +9452 -0
- package/frontend/tools/convert_to_jsdoc_output.txt +7626 -0
- package/frontend/tools/convert_to_jsdoc_tmp.js +345 -0
- package/package.json +11 -12
- package/backend/dist/cjs/database/collection.d.ts +0 -160
- package/backend/dist/cjs/database/collection.js +0 -842
- package/backend/dist/cjs/database/database.d.ts +0 -121
- package/backend/dist/cjs/database/document.d.ts +0 -131
- package/backend/dist/cjs/database/document.js +0 -224
- package/backend/dist/cjs/database.d.ts +0 -502
- package/backend/dist/cjs/database.js +0 -2248
- package/backend/dist/cjs/logger.d.ts +0 -3
- package/backend/dist/cjs/meta.d.ts +0 -50
- package/backend/dist/cjs/mutex.d.ts +0 -24
- package/backend/dist/cjs/payments/paddle.d.ts +0 -160
- package/backend/dist/cjs/plugins/browser.d.ts +0 -36
- package/backend/dist/cjs/plugins/browser.js +0 -198
- package/backend/dist/cjs/plugins/css.d.ts +0 -11
- package/backend/dist/cjs/plugins/css.js +0 -80
- package/backend/dist/cjs/plugins/mail.d.ts +0 -277
- package/backend/dist/cjs/plugins/mail.js +0 -1370
- package/backend/dist/cjs/plugins/ts/compiler.d.ts +0 -139
- package/backend/dist/cjs/plugins/ts/compiler.js +0 -750
- package/backend/dist/cjs/plugins/ts/preprocessing.d.ts +0 -14
- package/backend/dist/cjs/plugins/ts/preprocessing.js +0 -440
- package/backend/dist/cjs/rate_limit.d.ts +0 -63
- package/backend/dist/cjs/rate_limit.js +0 -348
- package/backend/dist/cjs/request.deprc.d.ts +0 -48
- package/backend/dist/cjs/request.deprc.js +0 -572
- package/backend/dist/cjs/response.deprc.d.ts +0 -55
- package/backend/dist/cjs/response.deprc.js +0 -275
- package/backend/dist/cjs/server.d.ts +0 -342
- package/backend/dist/cjs/splash_screen.d.ts +0 -35
- package/backend/dist/cjs/status.d.ts +0 -61
- package/backend/dist/cjs/stream.d.ts +0 -79
- package/backend/dist/cjs/users.d.ts +0 -111
- package/backend/dist/cjs/users.js +0 -1817
- package/backend/dist/cjs/view.js +0 -352
- package/backend/dist/cjs/vinc.dev.d.ts +0 -3
- package/backend/dist/cjs/vinc.dev.js +0 -7
- package/backend/dist/css/adyen.css +0 -92
- package/backend/dist/css/volt.css +0 -70
- package/backend/dist/esm/database/collection.d.ts +0 -160
- package/backend/dist/esm/database/collection.js +0 -1328
- package/backend/dist/esm/database/database.d.ts +0 -121
- package/backend/dist/esm/database/document.d.ts +0 -131
- package/backend/dist/esm/database/document.js +0 -247
- package/backend/dist/esm/database.d.ts +0 -502
- package/backend/dist/esm/database.js +0 -2423
- package/backend/dist/esm/file_watcher.js +0 -329
- package/backend/dist/esm/logger.d.ts +0 -3
- package/backend/dist/esm/logger.js +0 -11
- package/backend/dist/esm/meta.d.ts +0 -50
- package/backend/dist/esm/mutex.d.ts +0 -24
- package/backend/dist/esm/mutex.js +0 -48
- package/backend/dist/esm/payments/paddle.d.ts +0 -160
- package/backend/dist/esm/plugins/browser.d.ts +0 -36
- package/backend/dist/esm/plugins/browser.js +0 -176
- package/backend/dist/esm/plugins/css.d.ts +0 -11
- package/backend/dist/esm/plugins/css.js +0 -90
- package/backend/dist/esm/plugins/ts/compiler.d.ts +0 -139
- package/backend/dist/esm/plugins/ts/compiler.js +0 -1194
- package/backend/dist/esm/plugins/ts/preprocessing.d.ts +0 -14
- package/backend/dist/esm/plugins/ts/preprocessing.js +0 -726
- package/backend/dist/esm/rate_limit.d.ts +0 -63
- package/backend/dist/esm/rate_limit.js +0 -417
- package/backend/dist/esm/request.deprc.d.ts +0 -48
- package/backend/dist/esm/request.deprc.js +0 -572
- package/backend/dist/esm/response.deprc.d.ts +0 -55
- package/backend/dist/esm/response.deprc.js +0 -275
- package/backend/dist/esm/server.d.ts +0 -342
- package/backend/dist/esm/splash_screen.d.ts +0 -35
- package/backend/dist/esm/status.d.ts +0 -61
- package/backend/dist/esm/status.js +0 -197
- package/backend/dist/esm/stream.d.ts +0 -79
- package/backend/dist/esm/users.d.ts +0 -111
- package/backend/dist/esm/users.js +0 -1935
- package/backend/dist/esm/vinc.dev.d.ts +0 -3
- package/backend/dist/esm/vinc.dev.js +0 -7
- package/frontend/dist/elements/base.d.ts +0 -9889
- package/frontend/dist/elements/module.d.ts +0 -30
- package/frontend/dist/modules/array.d.ts +0 -94
- package/frontend/dist/modules/array.js +0 -634
- package/frontend/dist/modules/auth.d.ts +0 -46
- package/frontend/dist/modules/auth.js +0 -139
- package/frontend/dist/modules/colors.d.ts +0 -1
- package/frontend/dist/modules/colors.js +0 -417
- package/frontend/dist/modules/compression.d.ts +0 -6
- package/frontend/dist/modules/compression.js +0 -999
- package/frontend/dist/modules/cookies.d.ts +0 -18
- package/frontend/dist/modules/cookies.js +0 -167
- package/frontend/dist/modules/date.d.ts +0 -142
- package/frontend/dist/modules/date.js +0 -493
- package/frontend/dist/modules/events.d.ts +0 -8
- package/frontend/dist/modules/events.js +0 -91
- package/frontend/dist/modules/google.d.ts +0 -11
- package/frontend/dist/modules/google.js +0 -54
- package/frontend/dist/modules/meta.d.ts +0 -10
- package/frontend/dist/modules/mutex.d.ts +0 -7
- package/frontend/dist/modules/mutex.js +0 -51
- package/frontend/dist/modules/number.d.ts +0 -16
- package/frontend/dist/modules/number.js +0 -23
- package/frontend/dist/modules/object.d.ts +0 -52
- package/frontend/dist/modules/object.js +0 -383
- package/frontend/dist/modules/scheme.d.ts +0 -227
- package/frontend/dist/modules/scheme.js +0 -531
- package/frontend/dist/modules/settings.d.ts +0 -3
- package/frontend/dist/modules/settings.js +0 -4
- package/frontend/dist/modules/statics.d.ts +0 -5
- package/frontend/dist/modules/string.d.ts +0 -124
- package/frontend/dist/modules/string.js +0 -745
- package/frontend/dist/modules/support.d.ts +0 -19
- package/frontend/dist/modules/support.js +0 -103
- package/frontend/dist/modules/themes.d.ts +0 -8
- package/frontend/dist/modules/themes.js +0 -18
- package/frontend/dist/modules/user.d.ts +0 -59
- package/frontend/dist/modules/user.js +0 -280
- package/frontend/dist/modules/utils.d.ts +0 -87
- package/frontend/dist/modules/utils.js +0 -923
- package/frontend/dist/types/gradient.d.ts +0 -12
- package/frontend/dist/ui/border_button.d.ts +0 -152
- package/frontend/dist/ui/button.d.ts +0 -21
- package/frontend/dist/ui/canvas.d.ts +0 -56
- package/frontend/dist/ui/checkbox.d.ts +0 -52
- package/frontend/dist/ui/frame_modes.d.ts +0 -25
- package/frontend/dist/ui/input.d.ts +0 -241
- package/frontend/dist/ui/loader_button.d.ts +0 -93
- package/frontend/dist/ui/loaders.d.ts +0 -57
- package/frontend/dist/ui/pseudo.d.ts +0 -16
- package/frontend/dist/ui/steps.d.ts +0 -59
- package/frontend/dist/ui/title.d.ts +0 -21
- package/frontend/dist/ui/title.js +0 -121
- package/frontend/examples/dashboard/dashboard.ts +0 -776
- /package/backend/dist/cjs/{cli.d.ts → backend/src/cli.d.ts} +0 -0
- /package/backend/dist/cjs/{file_watcher.d.ts → backend/src/database/document.d.ts} +0 -0
- /package/backend/dist/cjs/{file_watcher.js → backend/src/database/document.js} +0 -0
- /package/backend/dist/cjs/{plugins/pdf.d.ts → backend/src/database/filters/strict_filter_test.d.ts} +0 -0
- /package/backend/dist/{esm/file_watcher.d.ts → cjs/backend/src/database/filters/strict_filter_test_v0.d.ts} +0 -0
- /package/backend/dist/{esm/plugins/pdf.d.ts → cjs/backend/src/database/flatten_test.d.ts} +0 -0
- /package/backend/dist/cjs/{frontend.d.ts → backend/src/frontend.d.ts} +0 -0
- /package/backend/dist/cjs/{plugins → backend/src/plugins}/communication.d.ts +0 -0
- /package/backend/dist/cjs/{plugins → backend/src/plugins}/communication.js +0 -0
- /package/backend/dist/cjs/{plugins → backend/src/plugins}/mail/ui.js +0 -0
- /package/backend/dist/cjs/{plugins → backend/src/plugins}/pdf.js +0 -0
- /package/backend/dist/cjs/{plugins → backend/src/plugins}/thread_monitor.d.ts +0 -0
- /package/backend/dist/cjs/{plugins → backend/src/plugins}/thread_monitor.js +0 -0
- /package/backend/dist/cjs/{vinc.d.ts → backend/src/vinc.d.ts} +0 -0
- /package/backend/dist/cjs/{vinc.js → backend/src/vinc.js} +0 -0
- /package/backend/dist/esm/{cli.d.ts → backend/src/cli.d.ts} +0 -0
- /package/backend/dist/esm/{frontend.d.ts → backend/src/frontend.d.ts} +0 -0
- /package/backend/dist/esm/{plugins → backend/src/plugins}/communication.d.ts +0 -0
- /package/backend/dist/esm/{plugins → backend/src/plugins}/communication.js +0 -0
- /package/backend/dist/esm/{plugins → backend/src/plugins}/thread_monitor.d.ts +0 -0
- /package/backend/dist/esm/{plugins → backend/src/plugins}/thread_monitor.js +0 -0
- /package/backend/dist/esm/{vinc.d.ts → backend/src/vinc.d.ts} +0 -0
- /package/backend/dist/esm/{vinc.js → backend/src/vinc.js} +0 -0
- /package/frontend/dist/{elements → frontend/src/elements}/register_element.d.ts +0 -0
- /package/frontend/dist/{elements → frontend/src/elements}/register_element.js +0 -0
- /package/frontend/dist/{modules → frontend/src/modules}/color.d.ts +0 -0
- /package/frontend/dist/{ui → frontend/src/ui}/ui.d.ts +0 -0
- /package/frontend/dist/{ui → frontend/src/ui}/ui.js +0 -0
|
@@ -0,0 +1,602 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @author Daan …
|
|
3
|
+
* @copyright …
|
|
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 `mode` 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 a **safe JavaScript integer** (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.RoundingNode} `mode` to allow rounding.
|
|
24
|
+
* - Arithmetic is **same-scale only**: pass raw integers or another `SafeInt<S>`.
|
|
25
|
+
*/
|
|
26
|
+
export class SafeInt {
|
|
27
|
+
// ----------------------------------------------------------------
|
|
28
|
+
// Fields
|
|
29
|
+
// ----------------------------------------------------------------
|
|
30
|
+
/**
|
|
31
|
+
* The stored safe integer (may be negative) measured at {@link int_scale}.
|
|
32
|
+
*/
|
|
33
|
+
int_value;
|
|
34
|
+
/**
|
|
35
|
+
* The canonical integer scale for {@link int_value}.
|
|
36
|
+
*/
|
|
37
|
+
int_scale;
|
|
38
|
+
// ----------------------------------------------------------------
|
|
39
|
+
// Constructors
|
|
40
|
+
// ----------------------------------------------------------------
|
|
41
|
+
/**
|
|
42
|
+
* Construct by converting from `opts.from_scale` to `opts.to_scale`. **Exact by default**.
|
|
43
|
+
*
|
|
44
|
+
* @param value The numeric input at `opts.from_scale`.
|
|
45
|
+
* - If `from_scale === Base`, `value` may be a float. When `mode` is omitted,
|
|
46
|
+
* `value * to_scale` must be an integer. If `mode` is provided, that rounding is applied.
|
|
47
|
+
* - If `from_scale !== Base`, `value` must be a safe integer.
|
|
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.mode 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, mode: "round" }) // 1500
|
|
59
|
+
*
|
|
60
|
+
* @throws
|
|
61
|
+
* Error If inputs are invalid, conversion overflows, or exactness is required but not met.
|
|
62
|
+
*/
|
|
63
|
+
constructor(value, opts) {
|
|
64
|
+
// Already-at-scale (exact)
|
|
65
|
+
if (typeof opts === "number" || typeof opts === "string") {
|
|
66
|
+
const scale = typeof opts === "string"
|
|
67
|
+
? SafeInt.str_to_scale(opts)
|
|
68
|
+
: opts;
|
|
69
|
+
// validate scale (must be a positive safe integer)
|
|
70
|
+
if (!Number.isSafeInteger(scale) || scale <= 0) {
|
|
71
|
+
throw new Error(`Invalid scale: expected positive safe integer, got ${scale}`);
|
|
72
|
+
}
|
|
73
|
+
// value can be any safe integer (negative allowed)
|
|
74
|
+
if (!Number.isSafeInteger(value)) {
|
|
75
|
+
throw new Error(`Invalid value: expected safe integer, got ${value}`);
|
|
76
|
+
}
|
|
77
|
+
this.int_value = value;
|
|
78
|
+
this.int_scale = scale;
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
// Convert from -> to (exact by default; optional rounding)
|
|
82
|
+
let { to_scale, from_scale = SafeInt.Scale.Base, mode = "exact" } = opts;
|
|
83
|
+
if (typeof to_scale === "string") {
|
|
84
|
+
to_scale = SafeInt.str_to_scale(to_scale);
|
|
85
|
+
}
|
|
86
|
+
if (typeof from_scale === "string") {
|
|
87
|
+
from_scale = SafeInt.str_to_scale(from_scale);
|
|
88
|
+
}
|
|
89
|
+
// validate scales (must be positive safe integers)
|
|
90
|
+
if (!Number.isSafeInteger(from_scale) || from_scale <= 0) {
|
|
91
|
+
throw new Error(`Invalid from_scale: expected positive safe integer, got ${from_scale}`);
|
|
92
|
+
}
|
|
93
|
+
if (!Number.isSafeInteger(to_scale) || to_scale <= 0) {
|
|
94
|
+
throw new Error(`Invalid to_scale: expected positive safe integer, got ${to_scale}`);
|
|
95
|
+
}
|
|
96
|
+
let converted;
|
|
97
|
+
if (from_scale === to_scale) {
|
|
98
|
+
if (to_scale === SafeInt.Scale.Base) {
|
|
99
|
+
if (mode === "exact") {
|
|
100
|
+
if (!Number.isSafeInteger(value)) {
|
|
101
|
+
throw new Error(`Exact constructor requires integer at base scale, got ${value}`);
|
|
102
|
+
}
|
|
103
|
+
converted = value;
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
const rounded = SafeInt.apply_round(value, mode);
|
|
107
|
+
if (!Number.isSafeInteger(rounded)) {
|
|
108
|
+
throw new Error(`Rounding produced non-integer at base scale: ${rounded}`);
|
|
109
|
+
}
|
|
110
|
+
converted = rounded;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
else {
|
|
114
|
+
if (!Number.isSafeInteger(value)) {
|
|
115
|
+
throw new Error(`Invalid value: expected safe integer at scale=${to_scale}, got ${value}`);
|
|
116
|
+
}
|
|
117
|
+
converted = value;
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
else if (from_scale === SafeInt.Scale.Base) {
|
|
121
|
+
// base -> integer scale
|
|
122
|
+
const product = value * to_scale;
|
|
123
|
+
if (mode === "exact") {
|
|
124
|
+
if (!Number.isFinite(product) || !Number.isInteger(product)) {
|
|
125
|
+
throw new Error(`Exact conversion failed: ${value} * ${to_scale} is not an integer`);
|
|
126
|
+
}
|
|
127
|
+
if (!Number.isSafeInteger(product)) {
|
|
128
|
+
throw new Error(`Overflow converting base->${to_scale}: ${product}`);
|
|
129
|
+
}
|
|
130
|
+
converted = product;
|
|
131
|
+
}
|
|
132
|
+
else {
|
|
133
|
+
const rounded = SafeInt.apply_round(product, mode);
|
|
134
|
+
if (!Number.isSafeInteger(rounded)) {
|
|
135
|
+
throw new Error(`Overflow/invalid rounding converting base->${to_scale}: ${product} -> ${rounded}`);
|
|
136
|
+
}
|
|
137
|
+
converted = rounded;
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
else if (to_scale === SafeInt.Scale.Base) {
|
|
141
|
+
// integer scale -> base integer, possibly rounded
|
|
142
|
+
if (!Number.isSafeInteger(value)) {
|
|
143
|
+
throw new Error(`Invalid value: expected safe integer at scale=${from_scale}, got ${value}`);
|
|
144
|
+
}
|
|
145
|
+
converted = SafeInt.div_to_base(value, from_scale, mode);
|
|
146
|
+
}
|
|
147
|
+
else {
|
|
148
|
+
// integer-scale -> integer-scale
|
|
149
|
+
if (!Number.isSafeInteger(value)) {
|
|
150
|
+
throw new Error(`Invalid value: expected safe integer at scale=${from_scale}, got ${value}`);
|
|
151
|
+
}
|
|
152
|
+
converted = SafeInt.convert_int_scale(value, from_scale, to_scale, mode);
|
|
153
|
+
}
|
|
154
|
+
this.int_value = converted;
|
|
155
|
+
this.int_scale = to_scale;
|
|
156
|
+
}
|
|
157
|
+
// ----------------------------------------------------------------
|
|
158
|
+
// value & scale accessors
|
|
159
|
+
// ----------------------------------------------------------------
|
|
160
|
+
/**
|
|
161
|
+
* Retrieve the underlying integer (measured in {@link scale} units).
|
|
162
|
+
*
|
|
163
|
+
* @returns The stored safe integer.
|
|
164
|
+
*/
|
|
165
|
+
value() {
|
|
166
|
+
return this.int_value;
|
|
167
|
+
}
|
|
168
|
+
/**
|
|
169
|
+
* Alias of {@link value}. Provided for JavaScript numeric coercion.
|
|
170
|
+
*
|
|
171
|
+
* @returns The stored safe integer.
|
|
172
|
+
*/
|
|
173
|
+
valueOf() {
|
|
174
|
+
return this.int_value;
|
|
175
|
+
}
|
|
176
|
+
/**
|
|
177
|
+
* Retrieve this instance's canonical scale.
|
|
178
|
+
*
|
|
179
|
+
* @returns The positive integer scale for this value.
|
|
180
|
+
*/
|
|
181
|
+
scale() {
|
|
182
|
+
return this.int_scale;
|
|
183
|
+
}
|
|
184
|
+
// ----------------------------------------------------------------
|
|
185
|
+
// presentation conversion
|
|
186
|
+
// ----------------------------------------------------------------
|
|
187
|
+
/**
|
|
188
|
+
* Convert to base scale (1) as a floating-point number (presentation).
|
|
189
|
+
*
|
|
190
|
+
* @returns The amount in base units as a float.
|
|
191
|
+
*/
|
|
192
|
+
to_base_float() {
|
|
193
|
+
if (this.int_scale === SafeInt.Scale.Base)
|
|
194
|
+
return this.int_value;
|
|
195
|
+
return this.int_value / this.int_scale;
|
|
196
|
+
}
|
|
197
|
+
// ----------------------------------------------------------------
|
|
198
|
+
// scale conversion — strongly typed
|
|
199
|
+
// ----------------------------------------------------------------
|
|
200
|
+
/**
|
|
201
|
+
* Convert this instance to another integer scale.
|
|
202
|
+
* **Exact by default** — provide a {@link SafeInt.RoundingNode} to allow rounding.
|
|
203
|
+
*
|
|
204
|
+
* @typeParam T - Target scale (see {@link SafeInt.Scale}).
|
|
205
|
+
* @param to_scale The target canonical scale.
|
|
206
|
+
* @param mode Rounding mode for non-exact ratios (default `"exact"`).
|
|
207
|
+
*
|
|
208
|
+
* @returns A new {@link SafeInt} typed as `SafeInt<T>`, storing an integer at `to_scale`.
|
|
209
|
+
*/
|
|
210
|
+
to_scale(to_scale, mode = "exact") {
|
|
211
|
+
// validate target scale
|
|
212
|
+
if (!Number.isSafeInteger(to_scale) || to_scale <= 0) {
|
|
213
|
+
throw new Error(`Invalid to_scale: expected positive safe integer, got ${to_scale}`);
|
|
214
|
+
}
|
|
215
|
+
if (this.int_scale === to_scale) {
|
|
216
|
+
// Preserve type at call-site
|
|
217
|
+
return new SafeInt(this.int_value, to_scale);
|
|
218
|
+
}
|
|
219
|
+
if (to_scale === SafeInt.Scale.Base) {
|
|
220
|
+
const base_int = SafeInt.div_to_base(this.int_value, this.int_scale, mode);
|
|
221
|
+
return new SafeInt(base_int, SafeInt.Scale.Base);
|
|
222
|
+
}
|
|
223
|
+
if (this.int_scale === SafeInt.Scale.Base) {
|
|
224
|
+
const product = this.int_value * to_scale;
|
|
225
|
+
if (!Number.isSafeInteger(product)) {
|
|
226
|
+
throw new Error(`Overflow converting base->${to_scale}`);
|
|
227
|
+
}
|
|
228
|
+
return new SafeInt(product, to_scale);
|
|
229
|
+
}
|
|
230
|
+
const n = SafeInt.convert_int_scale(this.int_value, this.int_scale, to_scale, mode);
|
|
231
|
+
return new SafeInt(n, to_scale);
|
|
232
|
+
}
|
|
233
|
+
/**
|
|
234
|
+
* Rescale to base (1).
|
|
235
|
+
*
|
|
236
|
+
* @returns A new `SafeInt<SafeInt.Scale.Base>`.
|
|
237
|
+
*/
|
|
238
|
+
base() {
|
|
239
|
+
return this.to_scale(SafeInt.Scale.Base);
|
|
240
|
+
}
|
|
241
|
+
/**
|
|
242
|
+
* Rescale to milli (1e3).
|
|
243
|
+
*
|
|
244
|
+
* @returns A new `SafeInt<SafeInt.Scale.Milli>`.
|
|
245
|
+
*/
|
|
246
|
+
milli() {
|
|
247
|
+
return this.to_scale(SafeInt.Scale.Milli);
|
|
248
|
+
}
|
|
249
|
+
/**
|
|
250
|
+
* Rescale to micro (1e6).
|
|
251
|
+
*
|
|
252
|
+
* @returns A new `SafeInt<SafeInt.Scale.Micro>`.
|
|
253
|
+
*/
|
|
254
|
+
micro() {
|
|
255
|
+
return this.to_scale(SafeInt.Scale.Micro);
|
|
256
|
+
}
|
|
257
|
+
/**
|
|
258
|
+
* Rescale to nano (1e9).
|
|
259
|
+
*
|
|
260
|
+
* @returns A new `SafeInt<SafeInt.Scale.Nano>`.
|
|
261
|
+
*/
|
|
262
|
+
nano() {
|
|
263
|
+
return this.to_scale(SafeInt.Scale.Nano);
|
|
264
|
+
}
|
|
265
|
+
/**
|
|
266
|
+
* Rescale to pico (1e12).
|
|
267
|
+
*
|
|
268
|
+
* @returns A new `SafeInt<SafeInt.Scale.Pico>`.
|
|
269
|
+
*/
|
|
270
|
+
pico() {
|
|
271
|
+
return this.to_scale(SafeInt.Scale.Pico);
|
|
272
|
+
}
|
|
273
|
+
// ----------------------------------------------------------------
|
|
274
|
+
// arithmetic — same-scale only
|
|
275
|
+
// ----------------------------------------------------------------
|
|
276
|
+
/**
|
|
277
|
+
* Add an amount at the same scale.
|
|
278
|
+
*
|
|
279
|
+
* @param other The addend, as a raw safe integer or a `SafeInt<S>`.
|
|
280
|
+
* @returns A new `SafeInt<S>` with the sum.
|
|
281
|
+
*
|
|
282
|
+
* @throws Error If the operand is invalid or the sum overflows.
|
|
283
|
+
*/
|
|
284
|
+
add(other) {
|
|
285
|
+
const b = typeof other === "number" ? other : other.int_value;
|
|
286
|
+
if (!Number.isSafeInteger(b)) {
|
|
287
|
+
throw new Error(`Invalid 'addend': expected a safe integer, got ${b}`);
|
|
288
|
+
}
|
|
289
|
+
const sum = this.int_value + b;
|
|
290
|
+
if (!Number.isSafeInteger(sum)) {
|
|
291
|
+
throw new Error(`Overflow in add(): ${this.int_value} + ${b} = ${sum}`);
|
|
292
|
+
}
|
|
293
|
+
return new SafeInt(sum, this.int_scale);
|
|
294
|
+
}
|
|
295
|
+
/**
|
|
296
|
+
* Subtract an amount at the same scale.
|
|
297
|
+
*
|
|
298
|
+
* @param other The subtrahend, as a raw safe integer or a `SafeInt<S>`.
|
|
299
|
+
* @returns A new `SafeInt<S>` with the difference.
|
|
300
|
+
*
|
|
301
|
+
* @throws Error If the operand is invalid or subtraction overflows.
|
|
302
|
+
*/
|
|
303
|
+
sub(other) {
|
|
304
|
+
const b = typeof other === "number" ? other : other.int_value;
|
|
305
|
+
if (!Number.isSafeInteger(b)) {
|
|
306
|
+
throw new Error(`Invalid 'subtrahend': expected a safe integer, got ${b}`);
|
|
307
|
+
}
|
|
308
|
+
const diff = this.int_value - b;
|
|
309
|
+
if (!Number.isSafeInteger(diff)) {
|
|
310
|
+
throw new Error(`Overflow in sub(): ${this.int_value} - ${b} = ${diff}`);
|
|
311
|
+
}
|
|
312
|
+
return new SafeInt(diff, this.int_scale);
|
|
313
|
+
}
|
|
314
|
+
/**
|
|
315
|
+
* Multiply by an integer factor at the same scale.
|
|
316
|
+
*
|
|
317
|
+
* @param factor The factor as a raw safe integer or a `SafeInt<S>`.
|
|
318
|
+
* @returns A new `SafeInt<S>` with the product.
|
|
319
|
+
*
|
|
320
|
+
* @throws Error If the factor is invalid or the product overflows.
|
|
321
|
+
*/
|
|
322
|
+
mul(factor) {
|
|
323
|
+
const f = typeof factor === "number" ? factor : factor.int_value;
|
|
324
|
+
if (!Number.isSafeInteger(f)) {
|
|
325
|
+
throw new Error(`Invalid 'factor': expected a safe integer, got ${f}`);
|
|
326
|
+
}
|
|
327
|
+
const product = this.int_value * f;
|
|
328
|
+
if (!Number.isSafeInteger(product)) {
|
|
329
|
+
throw new Error(`Overflow in mul(): ${this.int_value} * ${f} = ${product}`);
|
|
330
|
+
}
|
|
331
|
+
return new SafeInt(product, this.int_scale);
|
|
332
|
+
}
|
|
333
|
+
/**
|
|
334
|
+
* Divide by a positive integer divisor at the same scale.
|
|
335
|
+
*
|
|
336
|
+
* @param divisor Positive safe integer or `SafeInt<S>` divisor.
|
|
337
|
+
* @param mode Rounding mode. Default `"exact"` requires no remainder.
|
|
338
|
+
* @returns A new `SafeInt<S>` with the integer quotient (per {@link mode}).
|
|
339
|
+
*
|
|
340
|
+
* @throws Error If the divisor is invalid, division by zero, non-exact remainder in `"exact"` mode, or overflow.
|
|
341
|
+
*/
|
|
342
|
+
div(divisor, mode = "exact") {
|
|
343
|
+
const d = typeof divisor === "number" ? divisor : divisor.int_value;
|
|
344
|
+
if (!Number.isSafeInteger(d) || d === 0) {
|
|
345
|
+
throw new Error(`Invalid 'divisor': expected a non-zero safe integer, got ${d}`);
|
|
346
|
+
}
|
|
347
|
+
const q = SafeInt.div_int_checked(this.int_value, d, mode);
|
|
348
|
+
return new SafeInt(q, this.int_scale);
|
|
349
|
+
}
|
|
350
|
+
// ----------------------------------------------------------------
|
|
351
|
+
// comparisons — same-scale only
|
|
352
|
+
// ----------------------------------------------------------------
|
|
353
|
+
/**
|
|
354
|
+
* Compare with another `SafeInt<S>`.
|
|
355
|
+
*
|
|
356
|
+
* @param other The other amount (same scale).
|
|
357
|
+
* @returns `-1` if this < other, `0` if equal, `1` if this > other.
|
|
358
|
+
*/
|
|
359
|
+
cmp(other) {
|
|
360
|
+
const rhs = other.int_value;
|
|
361
|
+
if (this.int_value < rhs)
|
|
362
|
+
return -1;
|
|
363
|
+
if (this.int_value > rhs)
|
|
364
|
+
return 1;
|
|
365
|
+
return 0;
|
|
366
|
+
}
|
|
367
|
+
/**
|
|
368
|
+
* Test equality with another `SafeInt<S>`.
|
|
369
|
+
*
|
|
370
|
+
* @param other The other amount (same scale).
|
|
371
|
+
* @returns `true` if equal, otherwise `false`.
|
|
372
|
+
*/
|
|
373
|
+
eq(other) {
|
|
374
|
+
return this.cmp(other) === 0;
|
|
375
|
+
}
|
|
376
|
+
// ----------------------------------------------------------------
|
|
377
|
+
// Member & static assertions.
|
|
378
|
+
// ----------------------------------------------------------------
|
|
379
|
+
/**
|
|
380
|
+
* Assert `value` is a `>=0` safe integer.
|
|
381
|
+
*/
|
|
382
|
+
assert_non_negative() {
|
|
383
|
+
if (!Number.isSafeInteger(this.int_value) || this.int_value < 0) {
|
|
384
|
+
throw new Error(`Invalid value: expected non-negative safe integer, got ${this.int_value}`);
|
|
385
|
+
}
|
|
386
|
+
}
|
|
387
|
+
/**
|
|
388
|
+
* Assert `value` is a `>0` safe integer.
|
|
389
|
+
*/
|
|
390
|
+
assert_positive() {
|
|
391
|
+
if (!Number.isSafeInteger(this.int_value) || this.int_value <= 0) {
|
|
392
|
+
throw new Error(`Invalid value: expected positive safe integer, got ${this.int_value}`);
|
|
393
|
+
}
|
|
394
|
+
}
|
|
395
|
+
/**
|
|
396
|
+
* Assert `value` is a `<=0` safe integer.
|
|
397
|
+
*/
|
|
398
|
+
assert_non_positive() {
|
|
399
|
+
if (!Number.isSafeInteger(this.int_value) || this.int_value > 0) {
|
|
400
|
+
throw new Error(`Invalid value: expected non-positive safe integer, got ${this.int_value}`);
|
|
401
|
+
}
|
|
402
|
+
}
|
|
403
|
+
/**
|
|
404
|
+
* Assert `value` is a `<0` safe integer.
|
|
405
|
+
*/
|
|
406
|
+
assert_negative() {
|
|
407
|
+
if (!Number.isSafeInteger(this.int_value) || this.int_value >= 0) {
|
|
408
|
+
throw new Error(`Invalid value: expected negative safe integer, got ${this.int_value}`);
|
|
409
|
+
}
|
|
410
|
+
}
|
|
411
|
+
/**
|
|
412
|
+
* Assert `value` is a `>=0` safe integer.
|
|
413
|
+
*/
|
|
414
|
+
static assert_non_negative(value, label) {
|
|
415
|
+
if (!Number.isSafeInteger(value) || value < 0) {
|
|
416
|
+
throw new Error(`Invalid '${label}': expected non-negative safe integer, got ${value}`);
|
|
417
|
+
}
|
|
418
|
+
}
|
|
419
|
+
/**
|
|
420
|
+
* Assert `value` is a `>0` safe integer.
|
|
421
|
+
*/
|
|
422
|
+
static assert_positive(value, label) {
|
|
423
|
+
if (!Number.isSafeInteger(value) || value <= 0) {
|
|
424
|
+
throw new Error(`Invalid '${label}': expected positive safe integer, got ${value}`);
|
|
425
|
+
}
|
|
426
|
+
}
|
|
427
|
+
/**
|
|
428
|
+
* Assert `value` is a `<=0` safe integer.
|
|
429
|
+
*/
|
|
430
|
+
static assert_non_positive(value, label) {
|
|
431
|
+
if (!Number.isSafeInteger(value) || value > 0) {
|
|
432
|
+
throw new Error(`Invalid '${label}': expected non-positive safe integer, got ${value}`);
|
|
433
|
+
}
|
|
434
|
+
}
|
|
435
|
+
/**
|
|
436
|
+
* Assert `value` is a `<0` safe integer.
|
|
437
|
+
*/
|
|
438
|
+
static assert_negative(value, label) {
|
|
439
|
+
if (!Number.isSafeInteger(value) || value >= 0) {
|
|
440
|
+
throw new Error(`Invalid '${label}': expected negative safe integer, got ${value}`);
|
|
441
|
+
}
|
|
442
|
+
}
|
|
443
|
+
// ----------------------------------------------------------------
|
|
444
|
+
// static helpers (internal)
|
|
445
|
+
// ----------------------------------------------------------------
|
|
446
|
+
/**
|
|
447
|
+
* Apply a rounding mode to a floating value.
|
|
448
|
+
*
|
|
449
|
+
* @param v Floating value to round.
|
|
450
|
+
* @param mode Rounding mode.
|
|
451
|
+
* @returns Rounded integer (validated by the caller).
|
|
452
|
+
* @internal
|
|
453
|
+
*/
|
|
454
|
+
static apply_round(v, mode) {
|
|
455
|
+
if (!Number.isFinite(v))
|
|
456
|
+
throw new Error(`Invalid value for rounding: ${v}`);
|
|
457
|
+
if (mode === "floor")
|
|
458
|
+
return Math.floor(v);
|
|
459
|
+
if (mode === "ceil")
|
|
460
|
+
return Math.ceil(v);
|
|
461
|
+
if (mode === "round")
|
|
462
|
+
return Math.round(v);
|
|
463
|
+
throw new Error(`apply_round() called with mode='exact' which forbids rounding`);
|
|
464
|
+
}
|
|
465
|
+
/**
|
|
466
|
+
* Convert integer-scale value → base **integer** using a rounding policy.
|
|
467
|
+
*
|
|
468
|
+
* @param value Safe integer at `from_scale` (may be negative).
|
|
469
|
+
* @param from_scale Source scale.
|
|
470
|
+
* @param mode Rounding (default exact).
|
|
471
|
+
* @returns Base-scale integer.
|
|
472
|
+
* @internal
|
|
473
|
+
*/
|
|
474
|
+
static div_to_base(value, from_scale, mode) {
|
|
475
|
+
if (mode === "exact") {
|
|
476
|
+
if (value % from_scale !== 0) {
|
|
477
|
+
throw new Error(`Exact conversion to base failed: ${value} % ${from_scale} !== 0`);
|
|
478
|
+
}
|
|
479
|
+
return value / from_scale;
|
|
480
|
+
}
|
|
481
|
+
return SafeInt.div_int_checked(value, from_scale, mode);
|
|
482
|
+
}
|
|
483
|
+
/**
|
|
484
|
+
* Integer division helper with selectable rounding semantics.
|
|
485
|
+
*
|
|
486
|
+
* @param numerator Safe integer (may be negative).
|
|
487
|
+
* @param denominator Positive safe integer.
|
|
488
|
+
* @param mode Rounding mode (default `"exact"`).
|
|
489
|
+
* @returns Integer quotient as per {@link mode}.
|
|
490
|
+
*
|
|
491
|
+
* @throws Error On invalid inputs, division by zero, non-exact remainder in `"exact"`, or overflow.
|
|
492
|
+
* @internal
|
|
493
|
+
*/
|
|
494
|
+
static div_int_checked(numerator, denominator, mode = "exact") {
|
|
495
|
+
if (!Number.isSafeInteger(numerator))
|
|
496
|
+
throw new Error(`Invalid numerator: ${numerator}`);
|
|
497
|
+
if (!Number.isSafeInteger(denominator) || denominator <= 0)
|
|
498
|
+
throw new Error(`Invalid denominator: ${denominator}`);
|
|
499
|
+
const q = Math.trunc(numerator / denominator);
|
|
500
|
+
const prod = q * denominator;
|
|
501
|
+
if (!Number.isSafeInteger(prod))
|
|
502
|
+
throw new Error(`Overflow computing remainder`);
|
|
503
|
+
const rem = numerator - prod;
|
|
504
|
+
if (mode === "exact") {
|
|
505
|
+
if (rem !== 0)
|
|
506
|
+
throw new Error(`Non-exact division: ${numerator} / ${denominator} leaves remainder ${rem}`);
|
|
507
|
+
return q;
|
|
508
|
+
}
|
|
509
|
+
if (mode === "floor")
|
|
510
|
+
return q; // truncate toward zero by design
|
|
511
|
+
if (mode === "ceil")
|
|
512
|
+
return rem === 0 ? q : (q + 1);
|
|
513
|
+
if (mode === "round") {
|
|
514
|
+
const twice = rem * 2;
|
|
515
|
+
if (!Number.isSafeInteger(twice))
|
|
516
|
+
throw new Error(`Overflow computing rounding threshold`);
|
|
517
|
+
return twice >= denominator ? (q + 1) : q;
|
|
518
|
+
}
|
|
519
|
+
throw new Error(`Invalid mode: ${mode}`);
|
|
520
|
+
}
|
|
521
|
+
/**
|
|
522
|
+
* Integer-only scale converter with rounding policy.
|
|
523
|
+
*
|
|
524
|
+
* @param value Safe integer at {@link from_scale} (may be negative).
|
|
525
|
+
* @param from_scale Integer source scale.
|
|
526
|
+
* @param to_scale Integer target scale.
|
|
527
|
+
* @param mode Rounding mode (default exact).
|
|
528
|
+
* @returns Safe integer at `to_scale`.
|
|
529
|
+
*
|
|
530
|
+
* @throws Error On invalid inputs or overflow.
|
|
531
|
+
* @internal
|
|
532
|
+
*/
|
|
533
|
+
static convert_int_scale(value, from_scale, to_scale, mode) {
|
|
534
|
+
if (!Number.isSafeInteger(value)) {
|
|
535
|
+
throw new Error(`Invalid value: expected safe integer, got ${value}`);
|
|
536
|
+
}
|
|
537
|
+
if (!Number.isSafeInteger(from_scale) || from_scale <= 0) {
|
|
538
|
+
throw new Error(`Invalid from_scale: expected positive safe integer, got ${from_scale}`);
|
|
539
|
+
}
|
|
540
|
+
if (!Number.isSafeInteger(to_scale) || to_scale <= 0) {
|
|
541
|
+
throw new Error(`Invalid to_scale: expected positive safe integer, got ${to_scale}`);
|
|
542
|
+
}
|
|
543
|
+
if (from_scale === to_scale)
|
|
544
|
+
return value;
|
|
545
|
+
// exact divisor path
|
|
546
|
+
if (from_scale % to_scale === 0) {
|
|
547
|
+
const divisor = Math.trunc(from_scale / to_scale);
|
|
548
|
+
return SafeInt.div_int_checked(value, divisor, mode);
|
|
549
|
+
}
|
|
550
|
+
// exact multiplier path
|
|
551
|
+
if (to_scale % from_scale === 0) {
|
|
552
|
+
const multiplier = Math.trunc(to_scale / from_scale);
|
|
553
|
+
const product = value * multiplier;
|
|
554
|
+
if (!Number.isSafeInteger(product)) {
|
|
555
|
+
throw new Error(`Overflow in multiplication: ${value} * ${multiplier} = ${product}`);
|
|
556
|
+
}
|
|
557
|
+
return product;
|
|
558
|
+
}
|
|
559
|
+
// general ratio: (value * to_scale) / from_scale with chosen rounding
|
|
560
|
+
const numerator = value * to_scale;
|
|
561
|
+
if (!Number.isSafeInteger(numerator)) {
|
|
562
|
+
throw new Error(`Overflow computing numerator in convert_int_scale(${value}, ${from_scale} -> ${to_scale})`);
|
|
563
|
+
}
|
|
564
|
+
return SafeInt.div_int_checked(numerator, from_scale, mode);
|
|
565
|
+
}
|
|
566
|
+
}
|
|
567
|
+
/* ============================================================================
|
|
568
|
+
Namespace: shared types & constants for SafeInt
|
|
569
|
+
========================================================================== */
|
|
570
|
+
(function (SafeInt) {
|
|
571
|
+
/**
|
|
572
|
+
* Canonical integer scales (units-per-base).
|
|
573
|
+
*
|
|
574
|
+
* @example
|
|
575
|
+
* Base = 1, Milli = 1e3, Micro = 1e6, Nano = 1e9, Pico = 1e12
|
|
576
|
+
*/
|
|
577
|
+
let Scale;
|
|
578
|
+
(function (Scale) {
|
|
579
|
+
/** Base units (whole units). */
|
|
580
|
+
Scale[Scale["Base"] = 1] = "Base";
|
|
581
|
+
/** Milli units (1e3 per base). */
|
|
582
|
+
Scale[Scale["Milli"] = 1000] = "Milli";
|
|
583
|
+
/** Micro units (1e6 per base). */
|
|
584
|
+
Scale[Scale["Micro"] = 1000000] = "Micro";
|
|
585
|
+
/** Nano units (1e9 per base). */
|
|
586
|
+
Scale[Scale["Nano"] = 1000000000] = "Nano";
|
|
587
|
+
/** Pico units (1e12 per base). */
|
|
588
|
+
Scale[Scale["Pico"] = 1000000000000] = "Pico";
|
|
589
|
+
})(Scale = SafeInt.Scale || (SafeInt.Scale = {}));
|
|
590
|
+
/** Convert a string scale to the actual scale. */
|
|
591
|
+
function str_to_scale(scale) {
|
|
592
|
+
switch (scale) {
|
|
593
|
+
case "base": return Scale.Base;
|
|
594
|
+
case "milli": return Scale.Milli;
|
|
595
|
+
case "micro": return Scale.Micro;
|
|
596
|
+
case "nano": return Scale.Nano;
|
|
597
|
+
case "pico": return Scale.Pico;
|
|
598
|
+
default: throw new Error(`Unknown scale: ${scale}`);
|
|
599
|
+
}
|
|
600
|
+
}
|
|
601
|
+
SafeInt.str_to_scale = str_to_scale;
|
|
602
|
+
})(SafeInt || (SafeInt = {}));
|