@unicom-cloud/ui 0.8.66 → 0.8.67

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (357) hide show
  1. package/Affix.js +79 -79
  2. package/Alert.js +46 -46
  3. package/Anchor.js +1 -1
  4. package/AutoComplete.js +74 -74
  5. package/Avatar.js +36 -36
  6. package/BackTop.js +35 -35
  7. package/Badge.js +55 -55
  8. package/Breadcrumb.js +42 -42
  9. package/Button.js +24 -24
  10. package/Calendar.js +230 -230
  11. package/Card.js +18 -18
  12. package/Carousel.js +165 -165
  13. package/Cascader.js +1 -1
  14. package/Checkbox.js +1 -1
  15. package/Collapse.js +1 -1
  16. package/ColorPicker.js +26 -26
  17. package/Comment.js +18 -18
  18. package/ConfigProvider.js +2 -2
  19. package/Copy.js +28 -27
  20. package/DatePicker.js +872 -871
  21. package/Descriptions.js +34 -34
  22. package/Divider.js +19 -19
  23. package/Draggable.js +27 -26
  24. package/Drawer.js +1 -1
  25. package/Dropdown.js +110 -110
  26. package/Empty.js +3 -3
  27. package/Form.js +984 -945
  28. package/Grid.js +34 -34
  29. package/Icon.js +16 -16
  30. package/IconHover.js +2 -2
  31. package/Image.js +2 -2
  32. package/Input.js +7 -6
  33. package/InputNumber.js +6 -6
  34. package/InputTag.js +1 -1
  35. package/Layout.js +24 -24
  36. package/Link.js +30 -30
  37. package/List.js +95 -95
  38. package/Mentions.js +85 -84
  39. package/Menu.js +2 -2
  40. package/Message.js +7 -6
  41. package/Modal.js +1 -1
  42. package/Notice.js +14 -3
  43. package/Notification.js +9 -7
  44. package/OverflowEllipsis.js +64 -62
  45. package/PageHeader.js +73 -73
  46. package/Pagination.js +1 -1
  47. package/Picker.js +1 -1
  48. package/Popconfirm.js +60 -60
  49. package/Popover.js +31 -31
  50. package/Portal.js +23 -31
  51. package/Progress.js +22 -22
  52. package/Radio.js +2 -2
  53. package/Rate.js +24 -24
  54. package/ResizeBox.js +274 -271
  55. package/Result.js +3 -3
  56. package/Select.js +4 -4
  57. package/SelectView.js +257 -238
  58. package/Skeleton.js +46 -46
  59. package/Slider.js +286 -283
  60. package/Space.js +28 -28
  61. package/SpeechSynthesis.js +62 -55
  62. package/Spin.js +23 -23
  63. package/Statistic.js +80 -80
  64. package/Steps.js +67 -67
  65. package/Switch.js +47 -47
  66. package/Table.js +1445 -1380
  67. package/Tabs.js +5 -5
  68. package/Tag.js +45 -45
  69. package/TimePicker.js +154 -154
  70. package/Timeline.js +2 -2
  71. package/Tooltip.js +80 -79
  72. package/Transfer.js +103 -102
  73. package/Tree.js +3 -2
  74. package/TreeSelect.js +2 -2
  75. package/Trigger.js +699 -772
  76. package/Typography.js +756 -6
  77. package/Upload.js +2 -2
  78. package/VerificationCode.js +1 -1
  79. package/Version.js +1 -1
  80. package/VirtualList.js +1 -1
  81. package/Watermark.js +1 -1
  82. package/chunk/{BHgJ5Y3T.js → -UuKKT0Z.js} +29 -29
  83. package/chunk/{B8QV6E2b.js → AwZqeapI.js} +5 -5
  84. package/chunk/B5gK1Idp.js +19 -0
  85. package/chunk/B7FlazNB.js +24 -0
  86. package/chunk/{DTBtQQ2H.js → BBvWDeuZ.js} +67 -67
  87. package/chunk/BCftTxEy.js +626 -0
  88. package/chunk/{CZOP_ZHJ.js → BGny4zSb.js} +60 -60
  89. package/chunk/BHF15Dog.js +98 -0
  90. package/chunk/BJQ5UNa-.js +1585 -0
  91. package/chunk/BP9sYyk9.js +8 -0
  92. package/chunk/BUdtVdnv.js +38 -0
  93. package/chunk/BVQlOzTS.js +11 -0
  94. package/chunk/B__a_gb_.js +519 -0
  95. package/chunk/BbEYToV1.js +10 -0
  96. package/chunk/BbdDQAnm.js +15 -0
  97. package/chunk/BdUcgWdu.js +11 -0
  98. package/chunk/BfbXSG70.js +26 -0
  99. package/chunk/BndfNLK4.js +186 -0
  100. package/chunk/BoMCZV6K.js +1098 -0
  101. package/chunk/Br0B6y1T.js +18 -0
  102. package/chunk/BrOW642m.js +130 -0
  103. package/chunk/BxUs8_Cr.js +9 -0
  104. package/chunk/{CcV4wQB1.js → C42LIMP9.js} +244 -242
  105. package/chunk/C4YkFMzC.js +778 -0
  106. package/chunk/{Bh23P4l7.js → C9Wcraj7.js} +21 -21
  107. package/chunk/{4-gvEY5y.js → CANgSlh3.js} +10 -10
  108. package/chunk/CJ_o9tZM.js +5 -0
  109. package/chunk/{DNAigumg.js → CK5m7rLl.js} +36 -36
  110. package/chunk/{CANaGbGR.js → CKNyIitu.js} +57 -56
  111. package/chunk/CLiqJm_T.js +10 -0
  112. package/chunk/{BnSVm1YC.js → CNmmhbCn.js} +32 -32
  113. package/chunk/{BFipyA67.js → CP0odX99.js} +51 -51
  114. package/chunk/CPT-OZH2.js +14 -0
  115. package/chunk/CVSF8p0O.js +698 -0
  116. package/chunk/C_agcwLN.js +31 -0
  117. package/chunk/{jhQQCFMn.js → C_gJWGGh.js} +201 -201
  118. package/chunk/{Bc7t9jkb.js → CaasmWg_.js} +11 -11
  119. package/chunk/Ce1j9KTi.js +6 -0
  120. package/chunk/{D_-UD4vO.js → Cf5QNhkG.js} +18 -18
  121. package/chunk/CkNSv2U7.js +56 -0
  122. package/chunk/Cp2f70gB.js +9 -0
  123. package/chunk/CpegYjdC.js +16 -0
  124. package/chunk/CucI3KZr.js +20 -0
  125. package/chunk/CwoFBTYz.js +11 -0
  126. package/chunk/D2KPqPhV.js +17 -0
  127. package/chunk/D7NyvE5f.js +17 -0
  128. package/chunk/D8oTPQ2H.js +384 -0
  129. package/chunk/{CLBavO5c.js → DC1iHEiy.js} +87 -87
  130. package/chunk/{DnvO8A0Z.js → DFrfrmfK.js} +120 -119
  131. package/chunk/DGTIZ_0O.js +6 -0
  132. package/chunk/DJfpiZn_.js +25 -0
  133. package/chunk/DKr2_PYd.js +34 -0
  134. package/chunk/DNUz6zgo.js +11 -0
  135. package/chunk/DRtM649q.js +11 -0
  136. package/chunk/DS_mUWn6.js +41 -0
  137. package/chunk/DU6bs_19.js +10 -0
  138. package/chunk/DWdbwz22.js +10 -0
  139. package/chunk/DcveZuqd.js +6 -0
  140. package/chunk/DdVFknul.js +24 -0
  141. package/chunk/DgRfikwe.js +16 -0
  142. package/chunk/{znkyQ-HR.js → DkyR2EfG.js} +66 -66
  143. package/chunk/{DUeHQKtx.js → DleQ5HwG.js} +42 -42
  144. package/chunk/DnrZEnQ_.js +27 -0
  145. package/chunk/DsRSHWtX.js +1025 -0
  146. package/chunk/Dz5BdmXo.js +270 -0
  147. package/chunk/EANe01DF.js +1030 -0
  148. package/chunk/{CwhPMMWy.js → Ey4YJCkX.js} +7 -7
  149. package/chunk/GoNx5R4F.js +873 -0
  150. package/chunk/HDUQku8d.js +20 -0
  151. package/chunk/HrAP__Hi.js +25 -0
  152. package/chunk/JPPo5nY_.js +9 -0
  153. package/chunk/{Du-bw6qA.js → SLWP34OR.js} +90 -85
  154. package/chunk/VVKtwaGf.js +278 -0
  155. package/chunk/WPNpLxSI.js +16 -0
  156. package/chunk/{CPvvjMwZ.js → WpO_DsK4.js} +49 -48
  157. package/chunk/fdU3ang6.js +14 -0
  158. package/chunk/{DQAot004.js → fkclKOAL.js} +298 -292
  159. package/chunk/flvYlqx3.js +22 -0
  160. package/chunk/kTDayEpF.js +288 -0
  161. package/chunk/{CssIjN1g.js → pZoNQ75H.js} +31 -31
  162. package/chunk/qFf1w_Jq.js +8 -0
  163. package/chunk/{CHnFKgbk.js → w-kM1L5W.js} +155 -155
  164. package/hooks/index.js +53 -49
  165. package/hooks/useComputedState.js +2 -10
  166. package/hooks/useCreate.js +2 -7
  167. package/hooks/useForceUpdate.js +2 -7
  168. package/hooks/useId.js +2 -10
  169. package/hooks/useInView.js +2 -30
  170. package/hooks/useIntersectionObserver.js +2 -23
  171. package/hooks/useInterval.js +2 -17
  172. package/hooks/useIsFirstRender.js +2 -9
  173. package/hooks/useIsomorphicLayoutEffect.js +2 -5
  174. package/hooks/useKeyboardEvent.js +2 -16
  175. package/hooks/useMedia.js +2 -15
  176. package/hooks/useMergeProps.js +2 -18
  177. package/hooks/useMergeValue.js +2 -19
  178. package/hooks/useOnlineStatus.js +4 -0
  179. package/hooks/useOverflowHidden.js +2 -25
  180. package/hooks/useOverrideRef.js +2 -13
  181. package/hooks/usePersistCallback.js +2 -13
  182. package/hooks/usePrefersColorSchemeDark.js +4 -0
  183. package/hooks/usePrevious.js +2 -9
  184. package/hooks/useRefs.js +2 -9
  185. package/hooks/useResizeObserver.js +2 -15
  186. package/hooks/useStateCallback.js +2 -15
  187. package/hooks/useStateWithPromise.js +2 -24
  188. package/hooks/useUpdateEffect.js +2 -9
  189. package/hooks/useVerificationCode.js +73 -0
  190. package/hooks/useWatch.js +2 -10
  191. package/hooks/{use-watermark.js → useWatermark.js} +27 -26
  192. package/hooks/useWindowSize.js +2 -20
  193. package/index.js +571 -584
  194. package/locale/en-US.js +4 -2
  195. package/locale/interface.js +1 -4
  196. package/locale/ja-JP.js +3 -1
  197. package/locale/tr-TR.js +1 -1
  198. package/locale/zh-CN.js +3 -1
  199. package/locale/zh-HK.js +3 -1
  200. package/locale/zh-TW.js +3 -1
  201. package/package.json +1 -1
  202. package/style.css +1 -1
  203. package/types/anchor/util.d.ts +1 -1
  204. package/types/button/index.d.ts +2 -2
  205. package/types/color-picker/hooks/useColorPicker.d.ts +2 -2
  206. package/types/form/Control-old.d.ts +56 -0
  207. package/types/form/Control.d.ts +6 -54
  208. package/types/form/FormItem.d.ts +1 -1
  209. package/types/form/store.d.ts +0 -1
  210. package/types/hooks/index.d.ts +2 -0
  211. package/types/hooks/useComputedState.d.ts +1 -4
  212. package/types/hooks/useCreate.d.ts +1 -2
  213. package/types/hooks/useForceUpdate.d.ts +1 -2
  214. package/types/hooks/useId.d.ts +1 -2
  215. package/types/hooks/useInView.d.ts +1 -11
  216. package/types/hooks/useIntersectionObserver.d.ts +1 -7
  217. package/types/hooks/useInterval.d.ts +1 -2
  218. package/types/hooks/useIsFirstRender.d.ts +1 -2
  219. package/types/hooks/useIsomorphicLayoutEffect.d.ts +1 -3
  220. package/types/hooks/useKeyboardEvent.d.ts +1 -8
  221. package/types/hooks/useMedia.d.ts +1 -2
  222. package/types/hooks/useMergeProps.d.ts +1 -5
  223. package/types/hooks/useMergeValue.d.ts +1 -6
  224. package/types/hooks/useOnlineStatus.d.ts +1 -0
  225. package/types/hooks/useOverflowHidden.d.ts +1 -5
  226. package/types/hooks/useOverrideRef.d.ts +1 -6
  227. package/types/hooks/usePersistCallback.d.ts +1 -2
  228. package/types/hooks/usePrefersColorSchemeDark.d.ts +1 -0
  229. package/types/hooks/usePrevious.d.ts +1 -3
  230. package/types/hooks/useRefs.d.ts +1 -2
  231. package/types/hooks/useResizeObserver.d.ts +1 -6
  232. package/types/hooks/useStateCallback.d.ts +1 -5
  233. package/types/hooks/useStateWithPromise.d.ts +1 -2
  234. package/types/hooks/useUpdateEffect.d.ts +1 -3
  235. package/types/hooks/useWatch.d.ts +1 -3
  236. package/types/hooks/useWindowSize.d.ts +1 -5
  237. package/types/image/interface.d.ts +1 -0
  238. package/types/index.d.ts +157 -86
  239. package/types/input/Input.d.ts +1 -1
  240. package/types/input/Textarea.d.ts +2 -2
  241. package/types/locale/en-US.d.ts +2 -0
  242. package/types/locale/interface.d.ts +1 -2
  243. package/types/locale/ja-JP.d.ts +2 -0
  244. package/types/locale/zh-CN.d.ts +2 -0
  245. package/types/locale/zh-HK.d.ts +2 -0
  246. package/types/locale/zh-TW.d.ts +2 -0
  247. package/types/menu/context.d.ts +1 -1
  248. package/types/message/index.d.ts +14 -14
  249. package/types/message/interface.d.ts +2 -0
  250. package/types/modal/config.d.ts +0 -1
  251. package/types/modal/interface.d.ts +0 -1
  252. package/types/notice/index.d.ts +2 -27
  253. package/types/notification/index.d.ts +15 -16
  254. package/types/notification/interface.d.ts +2 -0
  255. package/types/notification/withNotification.d.ts +2 -0
  256. package/types/select/util.d.ts +1 -2
  257. package/types/select-view/interface.d.ts +2 -1
  258. package/types/speech-synthesis/index.d.ts +1 -1
  259. package/types/table/constant.d.ts +2 -0
  260. package/types/table/hook/useThResizable.d.ts +7 -0
  261. package/types/table/index.d.ts +10 -1
  262. package/types/table/style/index.d.ts +1 -0
  263. package/types/table/th-resizable/index.d.ts +2 -0
  264. package/types/table/thead/Column.d.ts +1 -2
  265. package/types/tree/Tree.d.ts +12 -67
  266. package/types/tree-select/Select.d.ts +2 -2
  267. package/types/trigger/index.d.ts +2 -120
  268. package/types/trigger/interface.d.ts +2 -1
  269. package/types/utils/CSSTransition.d.ts +2 -3
  270. package/types/utils/caseName.d.ts +1 -1
  271. package/types/utils/className.d.ts +1 -1
  272. package/types/utils/constant.d.ts +2 -2
  273. package/types/utils/copy.d.ts +1 -1
  274. package/types/utils/dayjs.d.ts +1 -21
  275. package/types/utils/dom.d.ts +1 -6
  276. package/types/utils/fileToURL.d.ts +1 -1
  277. package/types/utils/fillNBSP.d.ts +1 -1
  278. package/types/utils/getHighlightText.d.ts +1 -5
  279. package/types/utils/getHotkeyHandler.d.ts +1 -8
  280. package/types/utils/getStringLength.d.ts +1 -1
  281. package/types/utils/include.d.ts +1 -1
  282. package/types/utils/index.d.ts +3 -4
  283. package/types/utils/is.d.ts +1 -16
  284. package/types/utils/keyboardCode.d.ts +3 -0
  285. package/types/utils/lodash.d.ts +1 -17
  286. package/types/utils/mergeProps.d.ts +1 -1
  287. package/types/utils/mergedToString.d.ts +1 -1
  288. package/types/utils/omit.d.ts +1 -1
  289. package/types/utils/pad.d.ts +1 -2
  290. package/types/utils/pick.d.ts +2 -4
  291. package/types/utils/reactDOM.d.ts +1 -7
  292. package/types/utils/resizeObserverEffect.d.ts +2 -0
  293. package/types/utils/saveAs.d.ts +1 -1
  294. package/types/utils/screenfull.d.ts +2 -0
  295. package/types/utils/scrollIntoView.d.ts +1 -2
  296. package/types/utils/style.d.ts +1 -3
  297. package/types/utils/throttleByRaf.d.ts +1 -5
  298. package/types/utils/throttleByRaf2.d.ts +1 -0
  299. package/types/utils/warning.d.ts +1 -2
  300. package/types/version/index.d.ts +1 -1
  301. package/utils/CSSTransition.js +2 -6
  302. package/utils/className.js +2 -2
  303. package/utils/constant.js +8 -9
  304. package/utils/contextHolder.js +1 -1
  305. package/utils/copy.js +1 -1
  306. package/utils/dayjs.js +14 -173
  307. package/utils/dom.js +33 -29
  308. package/utils/fillNBSP.js +2 -4
  309. package/utils/getHighlightText.js +2 -38
  310. package/utils/getHotkeyHandler.js +2 -25
  311. package/utils/getStringLength.js +2 -7
  312. package/utils/include.js +2 -7
  313. package/utils/index.js +237 -240
  314. package/utils/is.js +116 -156
  315. package/utils/keyboardCode.js +27 -0
  316. package/utils/mergeProps.js +2 -9
  317. package/utils/mergedToString.js +2 -13
  318. package/utils/omit.js +2 -9
  319. package/utils/pad.js +12 -12
  320. package/utils/pick.js +4 -15
  321. package/utils/reactDOM.js +3 -54
  322. package/utils/resizeObserverEffect.js +4 -0
  323. package/utils/saveAs.js +1 -1
  324. package/utils/screenfull.js +4 -0
  325. package/utils/scrollIntoView.js +2 -21
  326. package/utils/style.js +12 -11
  327. package/utils/throttleByRaf.js +13 -12
  328. package/utils/throttleByRaf2.js +5 -0
  329. package/utils/warning.js +5 -4
  330. package/NotificationBase.js +0 -53
  331. package/chunk/-zpSUpGE.js +0 -1501
  332. package/chunk/BAWsPQBM.js +0 -11
  333. package/chunk/BIT0j3HT.js +0 -269
  334. package/chunk/BbLKnaNO.js +0 -871
  335. package/chunk/Bfhv56O2.js +0 -638
  336. package/chunk/C2lIz2F9.js +0 -60
  337. package/chunk/C6QWSzsM.js +0 -376
  338. package/chunk/CVkHTbic.js +0 -995
  339. package/chunk/CeGEvXby.js +0 -278
  340. package/chunk/D3NFxdmG.js +0 -518
  341. package/chunk/DApXtulb.js +0 -1102
  342. package/chunk/DPByB1ab.js +0 -698
  343. package/chunk/DV1Ab_cG.js +0 -284
  344. package/chunk/dBnNCOIU.js +0 -778
  345. package/chunk/it8qlDZ3.js +0 -1032
  346. package/chunk/l0sNRNKZ.js +0 -1
  347. package/chunk/te_43YrB.js +0 -776
  348. package/hooks/use-verification-code.js +0 -73
  349. package/types/notification-base/index.d.ts +0 -15
  350. package/types/notification-base/style/index.d.ts +0 -2
  351. package/types/trigger/Portal.d.ts +0 -7
  352. package/types/utils/keyCode.d.ts +0 -45
  353. package/types/utils/raf.d.ts +0 -3
  354. package/types/utils/throttleByRafV2.d.ts +0 -5
  355. package/utils/keyCode.js +0 -12
  356. package/utils/raf.js +0 -19
  357. package/utils/throttleByRafV2.js +0 -16
@@ -0,0 +1,1098 @@
1
+ /*!
2
+ * decimal.js v10.5.0
3
+ * An arbitrary-precision Decimal type for JavaScript.
4
+ * https://github.com/MikeMcl/decimal.js
5
+ * Copyright (c) 2025 Michael Mclaughlin <M8ch88l@gmail.com>
6
+ * MIT Licence
7
+ */
8
+ var cn = 9e15, B = 1e9, fn = "0123456789abcdef", X = "2.3025850929940456840179914546843642076011014886287729760333279009675726096773524802359972050895982983419677840422862486334095254650828067566662873690987816894829072083255546808437998948262331985283935053089653777326288461633662222876982198867465436674744042432743651550489343149393914796194044002221051017141748003688084012647080685567743216228355220114804663715659121373450747856947683463616792101806445070648000277502684916746550586856935673420670581136429224554405758925724208241314695689016758940256776311356919292033376587141660230105703089634572075440370847469940168269282808481184289314848524948644871927809676271275775397027668605952496716674183485704422507197965004714951050492214776567636938662976979522110718264549734772662425709429322582798502585509785265383207606726317164309505995087807523710333101197857547331541421808427543863591778117054309827482385045648019095610299291824318237525357709750539565187697510374970888692180205189339507238539205144634197265287286965110862571492198849978748873771345686209167058", Y = "3.1415926535897932384626433832795028841971693993751058209749445923078164062862089986280348253421170679821480865132823066470938446095505822317253594081284811174502841027019385211055596446229489549303819644288109756659334461284756482337867831652712019091456485669234603486104543266482133936072602491412737245870066063155881748815209209628292540917153643678925903600113305305488204665213841469519415116094330572703657595919530921861173819326117931051185480744623799627495673518857527248912279381830119491298336733624406566430860213949463952247371907021798609437027705392171762931767523846748184676694051320005681271452635608277857713427577896091736371787214684409012249534301465495853710507922796892589235420199561121290219608640344181598136297747713099605187072113499999983729780499510597317328160963185950244594553469083026425223082533446850352619311881710100031378387528865875332083814206171776691473035982534904287554687311595628638823537875937519577818577805321712268066130019278766111959092164201989380952572010654858632789", an = {
9
+ // These values must be integers within the stated ranges (inclusive).
10
+ // Most of these values can be changed at run-time using the `Decimal.config` method.
11
+ // The maximum number of significant digits of the result of a calculation or base conversion.
12
+ // E.g. `Decimal.config({ precision: 20 });`
13
+ precision: 20,
14
+ // 1 to MAX_DIGITS
15
+ // The rounding mode used when rounding to `precision`.
16
+ //
17
+ // ROUND_UP 0 Away from zero.
18
+ // ROUND_DOWN 1 Towards zero.
19
+ // ROUND_CEIL 2 Towards +Infinity.
20
+ // ROUND_FLOOR 3 Towards -Infinity.
21
+ // ROUND_HALF_UP 4 Towards nearest neighbour. If equidistant, up.
22
+ // ROUND_HALF_DOWN 5 Towards nearest neighbour. If equidistant, down.
23
+ // ROUND_HALF_EVEN 6 Towards nearest neighbour. If equidistant, towards even neighbour.
24
+ // ROUND_HALF_CEIL 7 Towards nearest neighbour. If equidistant, towards +Infinity.
25
+ // ROUND_HALF_FLOOR 8 Towards nearest neighbour. If equidistant, towards -Infinity.
26
+ //
27
+ // E.g.
28
+ // `Decimal.rounding = 4;`
29
+ // `Decimal.rounding = Decimal.ROUND_HALF_UP;`
30
+ rounding: 4,
31
+ // 0 to 8
32
+ // The modulo mode used when calculating the modulus: a mod n.
33
+ // The quotient (q = a / n) is calculated according to the corresponding rounding mode.
34
+ // The remainder (r) is calculated as: r = a - n * q.
35
+ //
36
+ // UP 0 The remainder is positive if the dividend is negative, else is negative.
37
+ // DOWN 1 The remainder has the same sign as the dividend (JavaScript %).
38
+ // FLOOR 3 The remainder has the same sign as the divisor (Python %).
39
+ // HALF_EVEN 6 The IEEE 754 remainder function.
40
+ // EUCLID 9 Euclidian division. q = sign(n) * floor(a / abs(n)). Always positive.
41
+ //
42
+ // Truncated division (1), floored division (3), the IEEE 754 remainder (6), and Euclidian
43
+ // division (9) are commonly used for the modulus operation. The other rounding modes can also
44
+ // be used, but they may not give useful results.
45
+ modulo: 1,
46
+ // 0 to 9
47
+ // The exponent value at and beneath which `toString` returns exponential notation.
48
+ // JavaScript numbers: -7
49
+ toExpNeg: -7,
50
+ // 0 to -EXP_LIMIT
51
+ // The exponent value at and above which `toString` returns exponential notation.
52
+ // JavaScript numbers: 21
53
+ toExpPos: 21,
54
+ // 0 to EXP_LIMIT
55
+ // The minimum exponent value, beneath which underflow to zero occurs.
56
+ // JavaScript numbers: -324 (5e-324)
57
+ minE: -9e15,
58
+ // -1 to -EXP_LIMIT
59
+ // The maximum exponent value, above which overflow to Infinity occurs.
60
+ // JavaScript numbers: 308 (1.7976931348623157e+308)
61
+ maxE: cn,
62
+ // 1 to EXP_LIMIT
63
+ // Whether to use cryptographically-secure random number generation, if available.
64
+ crypto: !1
65
+ // true/false
66
+ }, Z, wn, k, w = !0, rn = "[DecimalError] ", H = rn + "Invalid argument: ", Nn = rn + "Precision limit exceeded", vn = rn + "crypto unavailable", bn = "[object Decimal]", A = Math.floor, M = Math.pow, Rn = /^0b([01]+(\.[01]*)?|\.[01]+)(p[+-]?\d+)?$/i, Sn = /^0x([0-9a-f]+(\.[0-9a-f]*)?|\.[0-9a-f]+)(p[+-]?\d+)?$/i, Tn = /^0o([0-7]+(\.[0-7]*)?|\.[0-7]+)(p[+-]?\d+)?$/i, En = /^(\d+(\.\d*)?|\.\d+)(e[+-]?\d+)?$/i, T = 1e7, m = 7, _n = 9007199254740991, Ln = X.length - 1, ln = Y.length - 1, h = { toStringTag: bn };
67
+ h.absoluteValue = h.abs = function() {
68
+ var n = new this.constructor(this);
69
+ return n.s < 0 && (n.s = 1), g(n);
70
+ };
71
+ h.ceil = function() {
72
+ return g(new this.constructor(this), this.e + 1, 2);
73
+ };
74
+ h.clampedTo = h.clamp = function(n, r) {
75
+ var i, e = this, s = e.constructor;
76
+ if (n = new s(n), r = new s(r), !n.s || !r.s) return new s(NaN);
77
+ if (n.gt(r)) throw Error(H + r);
78
+ return i = e.cmp(n), i < 0 ? n : e.cmp(r) > 0 ? r : new s(e);
79
+ };
80
+ h.comparedTo = h.cmp = function(n) {
81
+ var r, i, e, s, t = this, o = t.d, u = (n = new t.constructor(n)).d, f = t.s, c = n.s;
82
+ if (!o || !u)
83
+ return !f || !c ? NaN : f !== c ? f : o === u ? 0 : !o ^ f < 0 ? 1 : -1;
84
+ if (!o[0] || !u[0]) return o[0] ? f : u[0] ? -c : 0;
85
+ if (f !== c) return f;
86
+ if (t.e !== n.e) return t.e > n.e ^ f < 0 ? 1 : -1;
87
+ for (e = o.length, s = u.length, r = 0, i = e < s ? e : s; r < i; ++r)
88
+ if (o[r] !== u[r]) return o[r] > u[r] ^ f < 0 ? 1 : -1;
89
+ return e === s ? 0 : e > s ^ f < 0 ? 1 : -1;
90
+ };
91
+ h.cosine = h.cos = function() {
92
+ var n, r, i = this, e = i.constructor;
93
+ return i.d ? i.d[0] ? (n = e.precision, r = e.rounding, e.precision = n + Math.max(i.e, i.sd()) + m, e.rounding = 1, i = Un(e, On(e, i)), e.precision = n, e.rounding = r, g(k == 2 || k == 3 ? i.neg() : i, n, r, !0)) : new e(1) : new e(NaN);
94
+ };
95
+ h.cubeRoot = h.cbrt = function() {
96
+ var n, r, i, e, s, t, o, u, f, c, a = this, l = a.constructor;
97
+ if (!a.isFinite() || a.isZero()) return new l(a);
98
+ for (w = !1, t = a.s * M(a.s * a, 1 / 3), !t || Math.abs(t) == 1 / 0 ? (i = q(a.d), n = a.e, (t = (n - i.length + 1) % 3) && (i += t == 1 || t == -2 ? "0" : "00"), t = M(i, 1 / 3), n = A((n + 1) / 3) - (n % 3 == (n < 0 ? -1 : 2)), t == 1 / 0 ? i = "5e" + n : (i = t.toExponential(), i = i.slice(0, i.indexOf("e") + 1) + n), e = new l(i), e.s = a.s) : e = new l(t.toString()), o = (n = l.precision) + 3; ; )
99
+ if (u = e, f = u.times(u).times(u), c = f.plus(a), e = E(c.plus(a).times(u), c.plus(f), o + 2, 1), q(u.d).slice(0, o) === (i = q(e.d)).slice(0, o))
100
+ if (i = i.slice(o - 3, o + 1), i == "9999" || !s && i == "4999") {
101
+ if (!s && (g(u, n + 1, 0), u.times(u).times(u).eq(a))) {
102
+ e = u;
103
+ break;
104
+ }
105
+ o += 4, s = 1;
106
+ } else {
107
+ (!+i || !+i.slice(1) && i.charAt(0) == "5") && (g(e, n + 1, 1), r = !e.times(e).times(e).eq(a));
108
+ break;
109
+ }
110
+ return w = !0, g(e, n, l.rounding, r);
111
+ };
112
+ h.decimalPlaces = h.dp = function() {
113
+ var n, r = this.d, i = NaN;
114
+ if (r) {
115
+ if (n = r.length - 1, i = (n - A(this.e / m)) * m, n = r[n], n) for (; n % 10 == 0; n /= 10) i--;
116
+ i < 0 && (i = 0);
117
+ }
118
+ return i;
119
+ };
120
+ h.dividedBy = h.div = function(n) {
121
+ return E(this, new this.constructor(n));
122
+ };
123
+ h.dividedToIntegerBy = h.divToInt = function(n) {
124
+ var r = this, i = r.constructor;
125
+ return g(
126
+ E(r, new i(n), 0, 1, 1),
127
+ i.precision,
128
+ i.rounding
129
+ );
130
+ };
131
+ h.equals = h.eq = function(n) {
132
+ return this.cmp(n) === 0;
133
+ };
134
+ h.floor = function() {
135
+ return g(new this.constructor(this), this.e + 1, 3);
136
+ };
137
+ h.greaterThan = h.gt = function(n) {
138
+ return this.cmp(n) > 0;
139
+ };
140
+ h.greaterThanOrEqualTo = h.gte = function(n) {
141
+ var r = this.cmp(n);
142
+ return r == 1 || r === 0;
143
+ };
144
+ h.hyperbolicCosine = h.cosh = function() {
145
+ var n, r, i, e, s, t = this, o = t.constructor, u = new o(1);
146
+ if (!t.isFinite()) return new o(t.s ? 1 / 0 : NaN);
147
+ if (t.isZero()) return u;
148
+ i = o.precision, e = o.rounding, o.precision = i + Math.max(t.e, t.sd()) + 4, o.rounding = 1, s = t.d.length, s < 32 ? (n = Math.ceil(s / 3), r = (1 / tn(4, n)).toString()) : (n = 16, r = "2.3283064365386962890625e-10"), t = V(o, 1, t.times(r), new o(1), !0);
149
+ for (var f, c = n, a = new o(8); c--; )
150
+ f = t.times(t), t = u.minus(f.times(a.minus(f.times(a))));
151
+ return g(t, o.precision = i, o.rounding = e, !0);
152
+ };
153
+ h.hyperbolicSine = h.sinh = function() {
154
+ var n, r, i, e, s = this, t = s.constructor;
155
+ if (!s.isFinite() || s.isZero()) return new t(s);
156
+ if (r = t.precision, i = t.rounding, t.precision = r + Math.max(s.e, s.sd()) + 4, t.rounding = 1, e = s.d.length, e < 3)
157
+ s = V(t, 2, s, s, !0);
158
+ else {
159
+ n = 1.4 * Math.sqrt(e), n = n > 16 ? 16 : n | 0, s = s.times(1 / tn(5, n)), s = V(t, 2, s, s, !0);
160
+ for (var o, u = new t(5), f = new t(16), c = new t(20); n--; )
161
+ o = s.times(s), s = s.times(u.plus(o.times(f.times(o).plus(c))));
162
+ }
163
+ return t.precision = r, t.rounding = i, g(s, r, i, !0);
164
+ };
165
+ h.hyperbolicTangent = h.tanh = function() {
166
+ var n, r, i = this, e = i.constructor;
167
+ return i.isFinite() ? i.isZero() ? new e(i) : (n = e.precision, r = e.rounding, e.precision = n + 7, e.rounding = 1, E(
168
+ i.sinh(),
169
+ i.cosh(),
170
+ e.precision = n,
171
+ e.rounding = r
172
+ )) : new e(i.s);
173
+ };
174
+ h.inverseCosine = h.acos = function() {
175
+ var n = this, r = n.constructor, i = n.abs().cmp(1), e = r.precision, s = r.rounding;
176
+ return i !== -1 ? i === 0 ? (
177
+ // |x| is 1
178
+ n.isNeg() ? _(r, e, s) : new r(0)
179
+ ) : (
180
+ // |x| > 1 or x is NaN
181
+ new r(NaN)
182
+ ) : n.isZero() ? _(r, e + 4, s).times(0.5) : (r.precision = e + 6, r.rounding = 1, n = new r(1).minus(n).div(n.plus(1)).sqrt().atan(), r.precision = e, r.rounding = s, n.times(2));
183
+ };
184
+ h.inverseHyperbolicCosine = h.acosh = function() {
185
+ var n, r, i = this, e = i.constructor;
186
+ return i.lte(1) ? new e(i.eq(1) ? 0 : NaN) : i.isFinite() ? (n = e.precision, r = e.rounding, e.precision = n + Math.max(Math.abs(i.e), i.sd()) + 4, e.rounding = 1, w = !1, i = i.times(i).minus(1).sqrt().plus(i), w = !0, e.precision = n, e.rounding = r, i.ln()) : new e(i);
187
+ };
188
+ h.inverseHyperbolicSine = h.asinh = function() {
189
+ var n, r, i = this, e = i.constructor;
190
+ return !i.isFinite() || i.isZero() ? new e(i) : (n = e.precision, r = e.rounding, e.precision = n + 2 * Math.max(Math.abs(i.e), i.sd()) + 6, e.rounding = 1, w = !1, i = i.times(i).plus(1).sqrt().plus(i), w = !0, e.precision = n, e.rounding = r, i.ln());
191
+ };
192
+ h.inverseHyperbolicTangent = h.atanh = function() {
193
+ var n, r, i, e, s = this, t = s.constructor;
194
+ return s.isFinite() ? s.e >= 0 ? new t(s.abs().eq(1) ? s.s / 0 : s.isZero() ? s : NaN) : (n = t.precision, r = t.rounding, e = s.sd(), Math.max(e, n) < 2 * -s.e - 1 ? g(new t(s), n, r, !0) : (t.precision = i = e - s.e, s = E(s.plus(1), new t(1).minus(s), i + n, 1), t.precision = n + 4, t.rounding = 1, s = s.ln(), t.precision = n, t.rounding = r, s.times(0.5))) : new t(NaN);
195
+ };
196
+ h.inverseSine = h.asin = function() {
197
+ var n, r, i, e, s = this, t = s.constructor;
198
+ return s.isZero() ? new t(s) : (r = s.abs().cmp(1), i = t.precision, e = t.rounding, r !== -1 ? r === 0 ? (n = _(t, i + 4, e).times(0.5), n.s = s.s, n) : new t(NaN) : (t.precision = i + 6, t.rounding = 1, s = s.div(new t(1).minus(s.times(s)).sqrt().plus(1)).atan(), t.precision = i, t.rounding = e, s.times(2)));
199
+ };
200
+ h.inverseTangent = h.atan = function() {
201
+ var n, r, i, e, s, t, o, u, f, c = this, a = c.constructor, l = a.precision, d = a.rounding;
202
+ if (c.isFinite()) {
203
+ if (c.isZero())
204
+ return new a(c);
205
+ if (c.abs().eq(1) && l + 4 <= ln)
206
+ return o = _(a, l + 4, d).times(0.25), o.s = c.s, o;
207
+ } else {
208
+ if (!c.s) return new a(NaN);
209
+ if (l + 4 <= ln)
210
+ return o = _(a, l + 4, d).times(0.5), o.s = c.s, o;
211
+ }
212
+ for (a.precision = u = l + 10, a.rounding = 1, i = Math.min(28, u / m + 2 | 0), n = i; n; --n) c = c.div(c.times(c).plus(1).sqrt().plus(1));
213
+ for (w = !1, r = Math.ceil(u / m), e = 1, f = c.times(c), o = new a(c), s = c; n !== -1; )
214
+ if (s = s.times(f), t = o.minus(s.div(e += 2)), s = s.times(f), o = t.plus(s.div(e += 2)), o.d[r] !== void 0) for (n = r; o.d[n] === t.d[n] && n--; ) ;
215
+ return i && (o = o.times(2 << i - 1)), w = !0, g(o, a.precision = l, a.rounding = d, !0);
216
+ };
217
+ h.isFinite = function() {
218
+ return !!this.d;
219
+ };
220
+ h.isInteger = h.isInt = function() {
221
+ return !!this.d && A(this.e / m) > this.d.length - 2;
222
+ };
223
+ h.isNaN = function() {
224
+ return !this.s;
225
+ };
226
+ h.isNegative = h.isNeg = function() {
227
+ return this.s < 0;
228
+ };
229
+ h.isPositive = h.isPos = function() {
230
+ return this.s > 0;
231
+ };
232
+ h.isZero = function() {
233
+ return !!this.d && this.d[0] === 0;
234
+ };
235
+ h.lessThan = h.lt = function(n) {
236
+ return this.cmp(n) < 0;
237
+ };
238
+ h.lessThanOrEqualTo = h.lte = function(n) {
239
+ return this.cmp(n) < 1;
240
+ };
241
+ h.logarithm = h.log = function(n) {
242
+ var r, i, e, s, t, o, u, f, c = this, a = c.constructor, l = a.precision, d = a.rounding, p = 5;
243
+ if (n == null)
244
+ n = new a(10), r = !0;
245
+ else {
246
+ if (n = new a(n), i = n.d, n.s < 0 || !i || !i[0] || n.eq(1)) return new a(NaN);
247
+ r = n.eq(10);
248
+ }
249
+ if (i = c.d, c.s < 0 || !i || !i[0] || c.eq(1))
250
+ return new a(i && !i[0] ? -1 / 0 : c.s != 1 ? NaN : i ? 0 : 1 / 0);
251
+ if (r)
252
+ if (i.length > 1)
253
+ t = !0;
254
+ else {
255
+ for (s = i[0]; s % 10 === 0; ) s /= 10;
256
+ t = s !== 1;
257
+ }
258
+ if (w = !1, u = l + p, o = C(c, u), e = r ? nn(a, u + 10) : C(n, u), f = E(o, e, u, 1), j(f.d, s = l, d))
259
+ do
260
+ if (u += 10, o = C(c, u), e = r ? nn(a, u + 10) : C(n, u), f = E(o, e, u, 1), !t) {
261
+ +q(f.d).slice(s + 1, s + 15) + 1 == 1e14 && (f = g(f, l + 1, 0));
262
+ break;
263
+ }
264
+ while (j(f.d, s += 10, d));
265
+ return w = !0, g(f, l, d);
266
+ };
267
+ h.minus = h.sub = function(n) {
268
+ var r, i, e, s, t, o, u, f, c, a, l, d, p = this, v = p.constructor;
269
+ if (n = new v(n), !p.d || !n.d)
270
+ return !p.s || !n.s ? n = new v(NaN) : p.d ? n.s = -n.s : n = new v(n.d || p.s !== n.s ? p : NaN), n;
271
+ if (p.s != n.s)
272
+ return n.s = -n.s, p.plus(n);
273
+ if (c = p.d, d = n.d, u = v.precision, f = v.rounding, !c[0] || !d[0]) {
274
+ if (d[0]) n.s = -n.s;
275
+ else if (c[0]) n = new v(p);
276
+ else return new v(f === 3 ? -0 : 0);
277
+ return w ? g(n, u, f) : n;
278
+ }
279
+ if (i = A(n.e / m), a = A(p.e / m), c = c.slice(), t = a - i, t) {
280
+ for (l = t < 0, l ? (r = c, t = -t, o = d.length) : (r = d, i = a, o = c.length), e = Math.max(Math.ceil(u / m), o) + 2, t > e && (t = e, r.length = 1), r.reverse(), e = t; e--; ) r.push(0);
281
+ r.reverse();
282
+ } else {
283
+ for (e = c.length, o = d.length, l = e < o, l && (o = e), e = 0; e < o; e++)
284
+ if (c[e] != d[e]) {
285
+ l = c[e] < d[e];
286
+ break;
287
+ }
288
+ t = 0;
289
+ }
290
+ for (l && (r = c, c = d, d = r, n.s = -n.s), o = c.length, e = d.length - o; e > 0; --e) c[o++] = 0;
291
+ for (e = d.length; e > t; ) {
292
+ if (c[--e] < d[e]) {
293
+ for (s = e; s && c[--s] === 0; ) c[s] = T - 1;
294
+ --c[s], c[e] += T;
295
+ }
296
+ c[e] -= d[e];
297
+ }
298
+ for (; c[--o] === 0; ) c.pop();
299
+ for (; c[0] === 0; c.shift()) --i;
300
+ return c[0] ? (n.d = c, n.e = en(c, i), w ? g(n, u, f) : n) : new v(f === 3 ? -0 : 0);
301
+ };
302
+ h.modulo = h.mod = function(n) {
303
+ var r, i = this, e = i.constructor;
304
+ return n = new e(n), !i.d || !n.s || n.d && !n.d[0] ? new e(NaN) : !n.d || i.d && !i.d[0] ? g(new e(i), e.precision, e.rounding) : (w = !1, e.modulo == 9 ? (r = E(i, n.abs(), 0, 3, 1), r.s *= n.s) : r = E(i, n, 0, e.modulo, 1), r = r.times(n), w = !0, i.minus(r));
305
+ };
306
+ h.naturalExponential = h.exp = function() {
307
+ return dn(this);
308
+ };
309
+ h.naturalLogarithm = h.ln = function() {
310
+ return C(this);
311
+ };
312
+ h.negated = h.neg = function() {
313
+ var n = new this.constructor(this);
314
+ return n.s = -n.s, g(n);
315
+ };
316
+ h.plus = h.add = function(n) {
317
+ var r, i, e, s, t, o, u, f, c, a, l = this, d = l.constructor;
318
+ if (n = new d(n), !l.d || !n.d)
319
+ return !l.s || !n.s ? n = new d(NaN) : l.d || (n = new d(n.d || l.s === n.s ? l : NaN)), n;
320
+ if (l.s != n.s)
321
+ return n.s = -n.s, l.minus(n);
322
+ if (c = l.d, a = n.d, u = d.precision, f = d.rounding, !c[0] || !a[0])
323
+ return a[0] || (n = new d(l)), w ? g(n, u, f) : n;
324
+ if (t = A(l.e / m), e = A(n.e / m), c = c.slice(), s = t - e, s) {
325
+ for (s < 0 ? (i = c, s = -s, o = a.length) : (i = a, e = t, o = c.length), t = Math.ceil(u / m), o = t > o ? t + 1 : o + 1, s > o && (s = o, i.length = 1), i.reverse(); s--; ) i.push(0);
326
+ i.reverse();
327
+ }
328
+ for (o = c.length, s = a.length, o - s < 0 && (s = o, i = a, a = c, c = i), r = 0; s; )
329
+ r = (c[--s] = c[s] + a[s] + r) / T | 0, c[s] %= T;
330
+ for (r && (c.unshift(r), ++e), o = c.length; c[--o] == 0; ) c.pop();
331
+ return n.d = c, n.e = en(c, e), w ? g(n, u, f) : n;
332
+ };
333
+ h.precision = h.sd = function(n) {
334
+ var r, i = this;
335
+ if (n !== void 0 && n !== !!n && n !== 1 && n !== 0)
336
+ throw Error(H + n);
337
+ return i.d ? (r = xn(i.d), n && i.e + 1 > r && (r = i.e + 1)) : r = NaN, r;
338
+ };
339
+ h.round = function() {
340
+ var n = this, r = n.constructor;
341
+ return g(new r(n), n.e + 1, r.rounding);
342
+ };
343
+ h.sine = h.sin = function() {
344
+ var n, r, i = this, e = i.constructor;
345
+ return i.isFinite() ? i.isZero() ? new e(i) : (n = e.precision, r = e.rounding, e.precision = n + Math.max(i.e, i.sd()) + m, e.rounding = 1, i = In(e, On(e, i)), e.precision = n, e.rounding = r, g(k > 2 ? i.neg() : i, n, r, !0)) : new e(NaN);
346
+ };
347
+ h.squareRoot = h.sqrt = function() {
348
+ var n, r, i, e, s, t, o = this, u = o.d, f = o.e, c = o.s, a = o.constructor;
349
+ if (c !== 1 || !u || !u[0])
350
+ return new a(!c || c < 0 && (!u || u[0]) ? NaN : u ? o : 1 / 0);
351
+ for (w = !1, c = Math.sqrt(+o), c == 0 || c == 1 / 0 ? (r = q(u), (r.length + f) % 2 == 0 && (r += "0"), c = Math.sqrt(r), f = A((f + 1) / 2) - (f < 0 || f % 2), c == 1 / 0 ? r = "5e" + f : (r = c.toExponential(), r = r.slice(0, r.indexOf("e") + 1) + f), e = new a(r)) : e = new a(c.toString()), i = (f = a.precision) + 3; ; )
352
+ if (t = e, e = t.plus(E(o, t, i + 2, 1)).times(0.5), q(t.d).slice(0, i) === (r = q(e.d)).slice(0, i))
353
+ if (r = r.slice(i - 3, i + 1), r == "9999" || !s && r == "4999") {
354
+ if (!s && (g(t, f + 1, 0), t.times(t).eq(o))) {
355
+ e = t;
356
+ break;
357
+ }
358
+ i += 4, s = 1;
359
+ } else {
360
+ (!+r || !+r.slice(1) && r.charAt(0) == "5") && (g(e, f + 1, 1), n = !e.times(e).eq(o));
361
+ break;
362
+ }
363
+ return w = !0, g(e, f, a.rounding, n);
364
+ };
365
+ h.tangent = h.tan = function() {
366
+ var n, r, i = this, e = i.constructor;
367
+ return i.isFinite() ? i.isZero() ? new e(i) : (n = e.precision, r = e.rounding, e.precision = n + 10, e.rounding = 1, i = i.sin(), i.s = 1, i = E(i, new e(1).minus(i.times(i)).sqrt(), n + 10, 0), e.precision = n, e.rounding = r, g(k == 2 || k == 4 ? i.neg() : i, n, r, !0)) : new e(NaN);
368
+ };
369
+ h.times = h.mul = function(n) {
370
+ var r, i, e, s, t, o, u, f, c, a = this, l = a.constructor, d = a.d, p = (n = new l(n)).d;
371
+ if (n.s *= a.s, !d || !d[0] || !p || !p[0])
372
+ return new l(
373
+ !n.s || d && !d[0] && !p || p && !p[0] && !d ? (
374
+ // Return NaN if either is NaN.
375
+ // Return NaN if x is ±0 and y is ±Infinity, or y is ±0 and x is ±Infinity.
376
+ NaN
377
+ ) : (
378
+ // Return ±Infinity if either is ±Infinity.
379
+ // Return ±0 if either is ±0.
380
+ !d || !p ? n.s / 0 : n.s * 0
381
+ )
382
+ );
383
+ for (i = A(a.e / m) + A(n.e / m), f = d.length, c = p.length, f < c && (t = d, d = p, p = t, o = f, f = c, c = o), t = [], o = f + c, e = o; e--; ) t.push(0);
384
+ for (e = c; --e >= 0; ) {
385
+ for (r = 0, s = f + e; s > e; )
386
+ u = t[s] + p[e] * d[s - e - 1] + r, t[s--] = u % T | 0, r = u / T | 0;
387
+ t[s] = (t[s] + r) % T | 0;
388
+ }
389
+ for (; !t[--o]; ) t.pop();
390
+ return r ? ++i : t.shift(), n.d = t, n.e = en(t, i), w ? g(n, l.precision, l.rounding) : n;
391
+ };
392
+ h.toBinary = function(n, r) {
393
+ return hn(this, 2, n, r);
394
+ };
395
+ h.toDecimalPlaces = h.toDP = function(n, r) {
396
+ var i = this, e = i.constructor;
397
+ return i = new e(i), n === void 0 ? i : (P(n, 0, B), r === void 0 ? r = e.rounding : P(r, 0, 8), g(i, n + i.e + 1, r));
398
+ };
399
+ h.toExponential = function(n, r) {
400
+ var i, e = this, s = e.constructor;
401
+ return n === void 0 ? i = L(e, !0) : (P(n, 0, B), r === void 0 ? r = s.rounding : P(r, 0, 8), e = g(new s(e), n + 1, r), i = L(e, !0, n + 1)), e.isNeg() && !e.isZero() ? "-" + i : i;
402
+ };
403
+ h.toFixed = function(n, r) {
404
+ var i, e, s = this, t = s.constructor;
405
+ return n === void 0 ? i = L(s) : (P(n, 0, B), r === void 0 ? r = t.rounding : P(r, 0, 8), e = g(new t(s), n + s.e + 1, r), i = L(e, !1, n + e.e + 1)), s.isNeg() && !s.isZero() ? "-" + i : i;
406
+ };
407
+ h.toFraction = function(n) {
408
+ var r, i, e, s, t, o, u, f, c, a, l, d, p = this, v = p.d, N = p.constructor;
409
+ if (!v) return new N(p);
410
+ if (c = i = new N(1), e = f = new N(0), r = new N(e), t = r.e = xn(v) - p.e - 1, o = t % m, r.d[0] = M(10, o < 0 ? m + o : o), n == null)
411
+ n = t > 0 ? r : c;
412
+ else {
413
+ if (u = new N(n), !u.isInt() || u.lt(c)) throw Error(H + u);
414
+ n = u.gt(r) ? t > 0 ? r : c : u;
415
+ }
416
+ for (w = !1, u = new N(q(v)), a = N.precision, N.precision = t = v.length * m * 2; l = E(u, r, 0, 1, 1), s = i.plus(l.times(e)), s.cmp(n) != 1; )
417
+ i = e, e = s, s = c, c = f.plus(l.times(s)), f = s, s = r, r = u.minus(l.times(s)), u = s;
418
+ return s = E(n.minus(i), e, 0, 1, 1), f = f.plus(s.times(c)), i = i.plus(s.times(e)), f.s = c.s = p.s, d = E(c, e, t, 1).minus(p).abs().cmp(E(f, i, t, 1).minus(p).abs()) < 1 ? [c, e] : [f, i], N.precision = a, w = !0, d;
419
+ };
420
+ h.toHexadecimal = h.toHex = function(n, r) {
421
+ return hn(this, 16, n, r);
422
+ };
423
+ h.toNearest = function(n, r) {
424
+ var i = this, e = i.constructor;
425
+ if (i = new e(i), n == null) {
426
+ if (!i.d) return i;
427
+ n = new e(1), r = e.rounding;
428
+ } else {
429
+ if (n = new e(n), r === void 0 ? r = e.rounding : P(r, 0, 8), !i.d) return n.s ? i : n;
430
+ if (!n.d)
431
+ return n.s && (n.s = i.s), n;
432
+ }
433
+ return n.d[0] ? (w = !1, i = E(i, n, 0, r, 1).times(n), w = !0, g(i)) : (n.s = i.s, i = n), i;
434
+ };
435
+ h.toNumber = function() {
436
+ return +this;
437
+ };
438
+ h.toOctal = function(n, r) {
439
+ return hn(this, 8, n, r);
440
+ };
441
+ h.toPower = h.pow = function(n) {
442
+ var r, i, e, s, t, o, u = this, f = u.constructor, c = +(n = new f(n));
443
+ if (!u.d || !n.d || !u.d[0] || !n.d[0]) return new f(M(+u, c));
444
+ if (u = new f(u), u.eq(1)) return u;
445
+ if (e = f.precision, t = f.rounding, n.eq(1)) return g(u, e, t);
446
+ if (r = A(n.e / m), r >= n.d.length - 1 && (i = c < 0 ? -c : c) <= _n)
447
+ return s = yn(f, u, i, e), n.s < 0 ? new f(1).div(s) : g(s, e, t);
448
+ if (o = u.s, o < 0) {
449
+ if (r < n.d.length - 1) return new f(NaN);
450
+ if ((n.d[r] & 1) == 0 && (o = 1), u.e == 0 && u.d[0] == 1 && u.d.length == 1)
451
+ return u.s = o, u;
452
+ }
453
+ return i = M(+u, c), r = i == 0 || !isFinite(i) ? A(
454
+ c * (Math.log("0." + q(u.d)) / Math.LN10 + u.e + 1)
455
+ ) : new f(i + "").e, r > f.maxE + 1 || r < f.minE - 1 ? new f(r > 0 ? o / 0 : 0) : (w = !1, f.rounding = u.s = 1, i = Math.min(12, (r + "").length), s = dn(n.times(C(u, e + i)), e), s.d && (s = g(s, e + 5, 1), j(s.d, e, t) && (r = e + 10, s = g(
456
+ dn(n.times(C(u, r + i)), r),
457
+ r + 5,
458
+ 1
459
+ ), +q(s.d).slice(e + 1, e + 15) + 1 == 1e14 && (s = g(s, e + 1, 0)))), s.s = o, w = !0, f.rounding = t, g(s, e, t));
460
+ };
461
+ h.toPrecision = function(n, r) {
462
+ var i, e = this, s = e.constructor;
463
+ return n === void 0 ? i = L(e, e.e <= s.toExpNeg || e.e >= s.toExpPos) : (P(n, 1, B), r === void 0 ? r = s.rounding : P(r, 0, 8), e = g(new s(e), n, r), i = L(e, n <= e.e || e.e <= s.toExpNeg, n)), e.isNeg() && !e.isZero() ? "-" + i : i;
464
+ };
465
+ h.toSignificantDigits = h.toSD = function(n, r) {
466
+ var i = this, e = i.constructor;
467
+ return n === void 0 ? (n = e.precision, r = e.rounding) : (P(n, 1, B), r === void 0 ? r = e.rounding : P(r, 0, 8)), g(new e(i), n, r);
468
+ };
469
+ h.toString = function() {
470
+ var n = this, r = n.constructor, i = L(n, n.e <= r.toExpNeg || n.e >= r.toExpPos);
471
+ return n.isNeg() && !n.isZero() ? "-" + i : i;
472
+ };
473
+ h.truncated = h.trunc = function() {
474
+ return g(new this.constructor(this), this.e + 1, 1);
475
+ };
476
+ h.valueOf = h.toJSON = function() {
477
+ var n = this, r = n.constructor, i = L(n, n.e <= r.toExpNeg || n.e >= r.toExpPos);
478
+ return n.isNeg() ? "-" + i : i;
479
+ };
480
+ function q(n) {
481
+ var r, i, e, s = n.length - 1, t = "", o = n[0];
482
+ if (s > 0) {
483
+ for (t += o, r = 1; r < s; r++)
484
+ e = n[r] + "", i = m - e.length, i && (t += I(i)), t += e;
485
+ o = n[r], e = o + "", i = m - e.length, i && (t += I(i));
486
+ } else if (o === 0)
487
+ return "0";
488
+ for (; o % 10 === 0; ) o /= 10;
489
+ return t + o;
490
+ }
491
+ function P(n, r, i) {
492
+ if (n !== ~~n || n < r || n > i)
493
+ throw Error(H + n);
494
+ }
495
+ function j(n, r, i, e) {
496
+ var s, t, o, u;
497
+ for (t = n[0]; t >= 10; t /= 10) --r;
498
+ return --r < 0 ? (r += m, s = 0) : (s = Math.ceil((r + 1) / m), r %= m), t = M(10, m - r), u = n[s] % t | 0, e == null ? r < 3 ? (r == 0 ? u = u / 100 | 0 : r == 1 && (u = u / 10 | 0), o = i < 4 && u == 99999 || i > 3 && u == 49999 || u == 5e4 || u == 0) : o = (i < 4 && u + 1 == t || i > 3 && u + 1 == t / 2) && (n[s + 1] / t / 100 | 0) == M(10, r - 2) - 1 || (u == t / 2 || u == 0) && (n[s + 1] / t / 100 | 0) == 0 : r < 4 ? (r == 0 ? u = u / 1e3 | 0 : r == 1 ? u = u / 100 | 0 : r == 2 && (u = u / 10 | 0), o = (e || i < 4) && u == 9999 || !e && i > 3 && u == 4999) : o = ((e || i < 4) && u + 1 == t || !e && i > 3 && u + 1 == t / 2) && (n[s + 1] / t / 1e3 | 0) == M(10, r - 3) - 1, o;
499
+ }
500
+ function K(n, r, i) {
501
+ for (var e, s = [0], t, o = 0, u = n.length; o < u; ) {
502
+ for (t = s.length; t--; ) s[t] *= r;
503
+ for (s[0] += fn.indexOf(n.charAt(o++)), e = 0; e < s.length; e++)
504
+ s[e] > i - 1 && (s[e + 1] === void 0 && (s[e + 1] = 0), s[e + 1] += s[e] / i | 0, s[e] %= i);
505
+ }
506
+ return s.reverse();
507
+ }
508
+ function Un(n, r) {
509
+ var i, e, s;
510
+ if (r.isZero()) return r;
511
+ e = r.d.length, e < 32 ? (i = Math.ceil(e / 3), s = (1 / tn(4, i)).toString()) : (i = 16, s = "2.3283064365386962890625e-10"), n.precision += i, r = V(n, 1, r.times(s), new n(1));
512
+ for (var t = i; t--; ) {
513
+ var o = r.times(r);
514
+ r = o.times(o).minus(o).times(8).plus(1);
515
+ }
516
+ return n.precision -= i, r;
517
+ }
518
+ var E = /* @__PURE__ */ function() {
519
+ function n(e, s, t) {
520
+ var o, u = 0, f = e.length;
521
+ for (e = e.slice(); f--; )
522
+ o = e[f] * s + u, e[f] = o % t | 0, u = o / t | 0;
523
+ return u && e.unshift(u), e;
524
+ }
525
+ function r(e, s, t, o) {
526
+ var u, f;
527
+ if (t != o)
528
+ f = t > o ? 1 : -1;
529
+ else
530
+ for (u = f = 0; u < t; u++)
531
+ if (e[u] != s[u]) {
532
+ f = e[u] > s[u] ? 1 : -1;
533
+ break;
534
+ }
535
+ return f;
536
+ }
537
+ function i(e, s, t, o) {
538
+ for (var u = 0; t--; )
539
+ e[t] -= u, u = e[t] < s[t] ? 1 : 0, e[t] = u * o + e[t] - s[t];
540
+ for (; !e[0] && e.length > 1; ) e.shift();
541
+ }
542
+ return function(e, s, t, o, u, f) {
543
+ var c, a, l, d, p, v, N, D, y, R, b, O, W, U, sn, J, $, on, S, z, G = e.constructor, un = e.s == s.s ? 1 : -1, F = e.d, x = s.d;
544
+ if (!F || !F[0] || !x || !x[0])
545
+ return new G(
546
+ // Return NaN if either NaN, or both Infinity or 0.
547
+ !e.s || !s.s || (F ? x && F[0] == x[0] : !x) ? NaN : (
548
+ // Return ±0 if x is 0 or y is ±Infinity, or return ±Infinity as y is 0.
549
+ F && F[0] == 0 || !x ? un * 0 : un / 0
550
+ )
551
+ );
552
+ for (f ? (p = 1, a = e.e - s.e) : (f = T, p = m, a = A(e.e / p) - A(s.e / p)), S = x.length, $ = F.length, y = new G(un), R = y.d = [], l = 0; x[l] == (F[l] || 0); l++) ;
553
+ if (x[l] > (F[l] || 0) && a--, t == null ? (U = t = G.precision, o = G.rounding) : u ? U = t + (e.e - s.e) + 1 : U = t, U < 0)
554
+ R.push(1), v = !0;
555
+ else {
556
+ if (U = U / p + 2 | 0, l = 0, S == 1) {
557
+ for (d = 0, x = x[0], U++; (l < $ || d) && U--; l++)
558
+ sn = d * f + (F[l] || 0), R[l] = sn / x | 0, d = sn % x | 0;
559
+ v = d || l < $;
560
+ } else {
561
+ for (d = f / (x[0] + 1) | 0, d > 1 && (x = n(x, d, f), F = n(F, d, f), S = x.length, $ = F.length), J = S, b = F.slice(0, S), O = b.length; O < S; ) b[O++] = 0;
562
+ z = x.slice(), z.unshift(0), on = x[0], x[1] >= f / 2 && ++on;
563
+ do
564
+ d = 0, c = r(x, b, S, O), c < 0 ? (W = b[0], S != O && (W = W * f + (b[1] || 0)), d = W / on | 0, d > 1 ? (d >= f && (d = f - 1), N = n(x, d, f), D = N.length, O = b.length, c = r(N, b, D, O), c == 1 && (d--, i(N, S < D ? z : x, D, f))) : (d == 0 && (c = d = 1), N = x.slice()), D = N.length, D < O && N.unshift(0), i(b, N, O, f), c == -1 && (O = b.length, c = r(x, b, S, O), c < 1 && (d++, i(b, S < O ? z : x, O, f))), O = b.length) : c === 0 && (d++, b = [0]), R[l++] = d, c && b[0] ? b[O++] = F[J] || 0 : (b = [F[J]], O = 1);
565
+ while ((J++ < $ || b[0] !== void 0) && U--);
566
+ v = b[0] !== void 0;
567
+ }
568
+ R[0] || R.shift();
569
+ }
570
+ if (p == 1)
571
+ y.e = a, wn = v;
572
+ else {
573
+ for (l = 1, d = R[0]; d >= 10; d /= 10) l++;
574
+ y.e = l + a * p - 1, g(y, u ? t + y.e + 1 : t, o, v);
575
+ }
576
+ return y;
577
+ };
578
+ }();
579
+ function g(n, r, i, e) {
580
+ var s, t, o, u, f, c, a, l, d, p = n.constructor;
581
+ n: if (r != null) {
582
+ if (l = n.d, !l) return n;
583
+ for (s = 1, u = l[0]; u >= 10; u /= 10) s++;
584
+ if (t = r - s, t < 0)
585
+ t += m, o = r, a = l[d = 0], f = a / M(10, s - o - 1) % 10 | 0;
586
+ else if (d = Math.ceil((t + 1) / m), u = l.length, d >= u)
587
+ if (e) {
588
+ for (; u++ <= d; ) l.push(0);
589
+ a = f = 0, s = 1, t %= m, o = t - m + 1;
590
+ } else
591
+ break n;
592
+ else {
593
+ for (a = u = l[d], s = 1; u >= 10; u /= 10) s++;
594
+ t %= m, o = t - m + s, f = o < 0 ? 0 : a / M(10, s - o - 1) % 10 | 0;
595
+ }
596
+ if (e = e || r < 0 || l[d + 1] !== void 0 || (o < 0 ? a : a % M(10, s - o - 1)), c = i < 4 ? (f || e) && (i == 0 || i == (n.s < 0 ? 3 : 2)) : f > 5 || f == 5 && (i == 4 || e || i == 6 && // Check whether the digit to the left of the rounding digit is odd.
597
+ (t > 0 ? o > 0 ? a / M(10, s - o) : 0 : l[d - 1]) % 10 & 1 || i == (n.s < 0 ? 8 : 7)), r < 1 || !l[0])
598
+ return l.length = 0, c ? (r -= n.e + 1, l[0] = M(10, (m - r % m) % m), n.e = -r || 0) : l[0] = n.e = 0, n;
599
+ if (t == 0 ? (l.length = d, u = 1, d--) : (l.length = d + 1, u = M(10, m - t), l[d] = o > 0 ? (a / M(10, s - o) % M(10, o) | 0) * u : 0), c)
600
+ for (; ; )
601
+ if (d == 0) {
602
+ for (t = 1, o = l[0]; o >= 10; o /= 10) t++;
603
+ for (o = l[0] += u, u = 1; o >= 10; o /= 10) u++;
604
+ t != u && (n.e++, l[0] == T && (l[0] = 1));
605
+ break;
606
+ } else {
607
+ if (l[d] += u, l[d] != T) break;
608
+ l[d--] = 0, u = 1;
609
+ }
610
+ for (t = l.length; l[--t] === 0; ) l.pop();
611
+ }
612
+ return w && (n.e > p.maxE ? (n.d = null, n.e = NaN) : n.e < p.minE && (n.e = 0, n.d = [0])), n;
613
+ }
614
+ function L(n, r, i) {
615
+ if (!n.isFinite()) return qn(n);
616
+ var e, s = n.e, t = q(n.d), o = t.length;
617
+ return r ? (i && (e = i - o) > 0 ? t = t.charAt(0) + "." + t.slice(1) + I(e) : o > 1 && (t = t.charAt(0) + "." + t.slice(1)), t = t + (n.e < 0 ? "e" : "e+") + n.e) : s < 0 ? (t = "0." + I(-s - 1) + t, i && (e = i - o) > 0 && (t += I(e))) : s >= o ? (t += I(s + 1 - o), i && (e = i - s - 1) > 0 && (t = t + "." + I(e))) : ((e = s + 1) < o && (t = t.slice(0, e) + "." + t.slice(e)), i && (e = i - o) > 0 && (s + 1 === o && (t += "."), t += I(e))), t;
618
+ }
619
+ function en(n, r) {
620
+ var i = n[0];
621
+ for (r *= m; i >= 10; i /= 10) r++;
622
+ return r;
623
+ }
624
+ function nn(n, r, i) {
625
+ if (r > Ln)
626
+ throw w = !0, i && (n.precision = i), Error(Nn);
627
+ return g(new n(X), r, 1, !0);
628
+ }
629
+ function _(n, r, i) {
630
+ if (r > ln) throw Error(Nn);
631
+ return g(new n(Y), r, i, !0);
632
+ }
633
+ function xn(n) {
634
+ var r = n.length - 1, i = r * m + 1;
635
+ if (r = n[r], r) {
636
+ for (; r % 10 == 0; r /= 10) i--;
637
+ for (r = n[0]; r >= 10; r /= 10) i++;
638
+ }
639
+ return i;
640
+ }
641
+ function I(n) {
642
+ for (var r = ""; n--; ) r += "0";
643
+ return r;
644
+ }
645
+ function yn(n, r, i, e) {
646
+ var s, t = new n(1), o = Math.ceil(e / m + 4);
647
+ for (w = !1; ; ) {
648
+ if (i % 2 && (t = t.times(r), pn(t.d, o) && (s = !0)), i = A(i / 2), i === 0) {
649
+ i = t.d.length - 1, s && t.d[i] === 0 && ++t.d[i];
650
+ break;
651
+ }
652
+ r = r.times(r), pn(r.d, o);
653
+ }
654
+ return w = !0, t;
655
+ }
656
+ function gn(n) {
657
+ return n.d[n.d.length - 1] & 1;
658
+ }
659
+ function Mn(n, r, i) {
660
+ for (var e, s, t = new n(r[0]), o = 0; ++o < r.length; ) {
661
+ if (s = new n(r[o]), !s.s) {
662
+ t = s;
663
+ break;
664
+ }
665
+ e = t.cmp(s), (e === i || e === 0 && t.s === i) && (t = s);
666
+ }
667
+ return t;
668
+ }
669
+ function dn(n, r) {
670
+ var i, e, s, t, o, u, f, c = 0, a = 0, l = 0, d = n.constructor, p = d.rounding, v = d.precision;
671
+ if (!n.d || !n.d[0] || n.e > 17)
672
+ return new d(
673
+ n.d ? n.d[0] ? n.s < 0 ? 0 : 1 / 0 : 1 : n.s ? n.s < 0 ? 0 : n : NaN
674
+ );
675
+ for (r == null ? (w = !1, f = v) : f = r, u = new d(0.03125); n.e > -2; )
676
+ n = n.times(u), l += 5;
677
+ for (e = Math.log(M(2, l)) / Math.LN10 * 2 + 5 | 0, f += e, i = t = o = new d(1), d.precision = f; ; ) {
678
+ if (t = g(t.times(n), f, 1), i = i.times(++a), u = o.plus(E(t, i, f, 1)), q(u.d).slice(0, f) === q(o.d).slice(0, f)) {
679
+ for (s = l; s--; ) o = g(o.times(o), f, 1);
680
+ if (r == null)
681
+ if (c < 3 && j(o.d, f - e, p, c))
682
+ d.precision = f += 10, i = t = u = new d(1), a = 0, c++;
683
+ else
684
+ return g(o, d.precision = v, p, w = !0);
685
+ else
686
+ return d.precision = v, o;
687
+ }
688
+ o = u;
689
+ }
690
+ }
691
+ function C(n, r) {
692
+ var i, e, s, t, o, u, f, c, a, l, d, p = 1, v = 10, N = n, D = N.d, y = N.constructor, R = y.rounding, b = y.precision;
693
+ if (N.s < 0 || !D || !D[0] || !N.e && D[0] == 1 && D.length == 1)
694
+ return new y(D && !D[0] ? -1 / 0 : N.s != 1 ? NaN : D ? 0 : N);
695
+ if (r == null ? (w = !1, a = b) : a = r, y.precision = a += v, i = q(D), e = i.charAt(0), Math.abs(t = N.e) < 15e14) {
696
+ for (; e < 7 && e != 1 || e == 1 && i.charAt(1) > 3; )
697
+ N = N.times(n), i = q(N.d), e = i.charAt(0), p++;
698
+ t = N.e, e > 1 ? (N = new y("0." + i), t++) : N = new y(e + "." + i.slice(1));
699
+ } else
700
+ return c = nn(y, a + 2, b).times(t + ""), N = C(new y(e + "." + i.slice(1)), a - v).plus(c), y.precision = b, r == null ? g(N, b, R, w = !0) : N;
701
+ for (l = N, f = o = N = E(N.minus(1), N.plus(1), a, 1), d = g(N.times(N), a, 1), s = 3; ; ) {
702
+ if (o = g(o.times(d), a, 1), c = f.plus(E(o, new y(s), a, 1)), q(c.d).slice(0, a) === q(f.d).slice(0, a))
703
+ if (f = f.times(2), t !== 0 && (f = f.plus(nn(y, a + 2, b).times(t + ""))), f = E(f, new y(p), a, 1), r == null)
704
+ if (j(f.d, a - v, R, u))
705
+ y.precision = a += v, c = o = N = E(l.minus(1), l.plus(1), a, 1), d = g(N.times(N), a, 1), s = u = 1;
706
+ else
707
+ return g(f, y.precision = b, R, w = !0);
708
+ else
709
+ return y.precision = b, f;
710
+ f = c, s += 2;
711
+ }
712
+ }
713
+ function qn(n) {
714
+ return String(n.s * n.s / 0);
715
+ }
716
+ function Q(n, r) {
717
+ var i, e, s;
718
+ for ((i = r.indexOf(".")) > -1 && (r = r.replace(".", "")), (e = r.search(/e/i)) > 0 ? (i < 0 && (i = e), i += +r.slice(e + 1), r = r.substring(0, e)) : i < 0 && (i = r.length), e = 0; r.charCodeAt(e) === 48; e++) ;
719
+ for (s = r.length; r.charCodeAt(s - 1) === 48; --s) ;
720
+ if (r = r.slice(e, s), r) {
721
+ if (s -= e, n.e = i = i - e - 1, n.d = [], e = (i + 1) % m, i < 0 && (e += m), e < s) {
722
+ for (e && n.d.push(+r.slice(0, e)), s -= m; e < s; ) n.d.push(+r.slice(e, e += m));
723
+ r = r.slice(e), e = m - r.length;
724
+ } else
725
+ e -= s;
726
+ for (; e--; ) r += "0";
727
+ n.d.push(+r), w && (n.e > n.constructor.maxE ? (n.d = null, n.e = NaN) : n.e < n.constructor.minE && (n.e = 0, n.d = [0]));
728
+ } else
729
+ n.e = 0, n.d = [0];
730
+ return n;
731
+ }
732
+ function kn(n, r) {
733
+ var i, e, s, t, o, u, f, c, a;
734
+ if (r.indexOf("_") > -1) {
735
+ if (r = r.replace(/(\d)_(?=\d)/g, "$1"), En.test(r)) return Q(n, r);
736
+ } else if (r === "Infinity" || r === "NaN")
737
+ return +r || (n.s = NaN), n.e = NaN, n.d = null, n;
738
+ if (Sn.test(r))
739
+ i = 16, r = r.toLowerCase();
740
+ else if (Rn.test(r))
741
+ i = 2;
742
+ else if (Tn.test(r))
743
+ i = 8;
744
+ else
745
+ throw Error(H + r);
746
+ for (t = r.search(/p/i), t > 0 ? (f = +r.slice(t + 1), r = r.substring(2, t)) : r = r.slice(2), t = r.indexOf("."), o = t >= 0, e = n.constructor, o && (r = r.replace(".", ""), u = r.length, t = u - t, s = yn(e, new e(i), t, t * 2)), c = K(r, i, T), a = c.length - 1, t = a; c[t] === 0; --t) c.pop();
747
+ return t < 0 ? new e(n.s * 0) : (n.e = en(c, a), n.d = c, w = !1, o && (n = E(n, s, u * 4)), f && (n = n.times(Math.abs(f) < 54 ? M(2, f) : Z.pow(2, f))), w = !0, n);
748
+ }
749
+ function In(n, r) {
750
+ var i, e = r.d.length;
751
+ if (e < 3)
752
+ return r.isZero() ? r : V(n, 2, r, r);
753
+ i = 1.4 * Math.sqrt(e), i = i > 16 ? 16 : i | 0, r = r.times(1 / tn(5, i)), r = V(n, 2, r, r);
754
+ for (var s, t = new n(5), o = new n(16), u = new n(20); i--; )
755
+ s = r.times(r), r = r.times(t.plus(s.times(o.times(s).minus(u))));
756
+ return r;
757
+ }
758
+ function V(n, r, i, e, s) {
759
+ var t, o, u, f, c = n.precision, a = Math.ceil(c / m);
760
+ for (w = !1, f = i.times(i), u = new n(e); ; ) {
761
+ if (o = E(u.times(f), new n(r++ * r++), c, 1), u = s ? e.plus(o) : e.minus(o), e = E(o.times(f), new n(r++ * r++), c, 1), o = u.plus(e), o.d[a] !== void 0) {
762
+ for (t = a; o.d[t] === u.d[t] && t--; ) ;
763
+ if (t == -1) break;
764
+ }
765
+ t = u, u = e, e = o, o = t;
766
+ }
767
+ return w = !0, o.d.length = a + 1, o;
768
+ }
769
+ function tn(n, r) {
770
+ for (var i = n; --r; ) i *= n;
771
+ return i;
772
+ }
773
+ function On(n, r) {
774
+ var i, e = r.s < 0, s = _(n, n.precision, 1), t = s.times(0.5);
775
+ if (r = r.abs(), r.lte(t))
776
+ return k = e ? 4 : 1, r;
777
+ if (i = r.divToInt(s), i.isZero())
778
+ k = e ? 3 : 2;
779
+ else {
780
+ if (r = r.minus(i.times(s)), r.lte(t))
781
+ return k = gn(i) ? e ? 2 : 3 : e ? 4 : 1, r;
782
+ k = gn(i) ? e ? 1 : 4 : e ? 3 : 2;
783
+ }
784
+ return r.minus(s).abs();
785
+ }
786
+ function hn(n, r, i, e) {
787
+ var s, t, o, u, f, c, a, l, d, p = n.constructor, v = i !== void 0;
788
+ if (v ? (P(i, 1, B), e === void 0 ? e = p.rounding : P(e, 0, 8)) : (i = p.precision, e = p.rounding), !n.isFinite())
789
+ a = qn(n);
790
+ else {
791
+ for (a = L(n), o = a.indexOf("."), v ? (s = 2, r == 16 ? i = i * 4 - 3 : r == 8 && (i = i * 3 - 2)) : s = r, o >= 0 && (a = a.replace(".", ""), d = new p(1), d.e = a.length - o, d.d = K(L(d), 10, s), d.e = d.d.length), l = K(a, 10, s), t = f = l.length; l[--f] == 0; ) l.pop();
792
+ if (!l[0])
793
+ a = v ? "0p+0" : "0";
794
+ else {
795
+ if (o < 0 ? t-- : (n = new p(n), n.d = l, n.e = t, n = E(n, d, i, e, 0, s), l = n.d, t = n.e, c = wn), o = l[i], u = s / 2, c = c || l[i + 1] !== void 0, c = e < 4 ? (o !== void 0 || c) && (e === 0 || e === (n.s < 0 ? 3 : 2)) : o > u || o === u && (e === 4 || c || e === 6 && l[i - 1] & 1 || e === (n.s < 0 ? 8 : 7)), l.length = i, c)
796
+ for (; ++l[--i] > s - 1; )
797
+ l[i] = 0, i || (++t, l.unshift(1));
798
+ for (f = l.length; !l[f - 1]; --f) ;
799
+ for (o = 0, a = ""; o < f; o++) a += fn.charAt(l[o]);
800
+ if (v) {
801
+ if (f > 1)
802
+ if (r == 16 || r == 8) {
803
+ for (o = r == 16 ? 4 : 3, --f; f % o; f++) a += "0";
804
+ for (l = K(a, s, r), f = l.length; !l[f - 1]; --f) ;
805
+ for (o = 1, a = "1."; o < f; o++) a += fn.charAt(l[o]);
806
+ } else
807
+ a = a.charAt(0) + "." + a.slice(1);
808
+ a = a + (t < 0 ? "p" : "p+") + t;
809
+ } else if (t < 0) {
810
+ for (; ++t; ) a = "0" + a;
811
+ a = "0." + a;
812
+ } else if (++t > f) for (t -= f; t--; ) a += "0";
813
+ else t < f && (a = a.slice(0, t) + "." + a.slice(t));
814
+ }
815
+ a = (r == 16 ? "0x" : r == 2 ? "0b" : r == 8 ? "0o" : "") + a;
816
+ }
817
+ return n.s < 0 ? "-" + a : a;
818
+ }
819
+ function pn(n, r) {
820
+ if (n.length > r)
821
+ return n.length = r, !0;
822
+ }
823
+ function Cn(n) {
824
+ return new this(n).abs();
825
+ }
826
+ function Hn(n) {
827
+ return new this(n).acos();
828
+ }
829
+ function Bn(n) {
830
+ return new this(n).acosh();
831
+ }
832
+ function Vn(n, r) {
833
+ return new this(n).plus(r);
834
+ }
835
+ function $n(n) {
836
+ return new this(n).asin();
837
+ }
838
+ function jn(n) {
839
+ return new this(n).asinh();
840
+ }
841
+ function Wn(n) {
842
+ return new this(n).atan();
843
+ }
844
+ function Jn(n) {
845
+ return new this(n).atanh();
846
+ }
847
+ function zn(n, r) {
848
+ n = new this(n), r = new this(r);
849
+ var i, e = this.precision, s = this.rounding, t = e + 4;
850
+ return !n.s || !r.s ? i = new this(NaN) : !n.d && !r.d ? (i = _(this, t, 1).times(r.s > 0 ? 0.25 : 0.75), i.s = n.s) : !r.d || n.isZero() ? (i = r.s < 0 ? _(this, e, s) : new this(0), i.s = n.s) : !n.d || r.isZero() ? (i = _(this, t, 1).times(0.5), i.s = n.s) : r.s < 0 ? (this.precision = t, this.rounding = 1, i = this.atan(E(n, r, t, 1)), r = _(this, t, 1), this.precision = e, this.rounding = s, i = n.s < 0 ? i.minus(r) : i.plus(r)) : i = this.atan(E(n, r, t, 1)), i;
851
+ }
852
+ function Gn(n) {
853
+ return new this(n).cbrt();
854
+ }
855
+ function Kn(n) {
856
+ return g(n = new this(n), n.e + 1, 2);
857
+ }
858
+ function Qn(n, r, i) {
859
+ return new this(n).clamp(r, i);
860
+ }
861
+ function Xn(n) {
862
+ if (!n || typeof n != "object")
863
+ throw Error(rn + "Object expected");
864
+ var r, i, e, s = n.defaults === !0, t = [
865
+ "precision",
866
+ 1,
867
+ B,
868
+ "rounding",
869
+ 0,
870
+ 8,
871
+ "toExpNeg",
872
+ -9e15,
873
+ 0,
874
+ "toExpPos",
875
+ 0,
876
+ cn,
877
+ "maxE",
878
+ 0,
879
+ cn,
880
+ "minE",
881
+ -9e15,
882
+ 0,
883
+ "modulo",
884
+ 0,
885
+ 9
886
+ ];
887
+ for (r = 0; r < t.length; r += 3)
888
+ if (i = t[r], s && (this[i] = an[i]), (e = n[i]) !== void 0)
889
+ if (A(e) === e && e >= t[r + 1] && e <= t[r + 2]) this[i] = e;
890
+ else throw Error(H + i + ": " + e);
891
+ if (i = "crypto", s && (this[i] = an[i]), (e = n[i]) !== void 0)
892
+ if (e === !0 || e === !1 || e === 0 || e === 1)
893
+ if (e)
894
+ if (typeof crypto < "u" && crypto && (crypto.getRandomValues || crypto.randomBytes))
895
+ this[i] = !0;
896
+ else
897
+ throw Error(vn);
898
+ else
899
+ this[i] = !1;
900
+ else
901
+ throw Error(H + i + ": " + e);
902
+ return this;
903
+ }
904
+ function Yn(n) {
905
+ return new this(n).cos();
906
+ }
907
+ function nr(n) {
908
+ return new this(n).cosh();
909
+ }
910
+ function Fn(n) {
911
+ var r, i, e;
912
+ function s(t) {
913
+ var o, u, f, c = this;
914
+ if (!(c instanceof s)) return new s(t);
915
+ if (c.constructor = s, mn(t)) {
916
+ c.s = t.s, w ? !t.d || t.e > s.maxE ? (c.e = NaN, c.d = null) : t.e < s.minE ? (c.e = 0, c.d = [0]) : (c.e = t.e, c.d = t.d.slice()) : (c.e = t.e, c.d = t.d ? t.d.slice() : t.d);
917
+ return;
918
+ }
919
+ if (f = typeof t, f === "number") {
920
+ if (t === 0) {
921
+ c.s = 1 / t < 0 ? -1 : 1, c.e = 0, c.d = [0];
922
+ return;
923
+ }
924
+ if (t < 0 ? (t = -t, c.s = -1) : c.s = 1, t === ~~t && t < 1e7) {
925
+ for (o = 0, u = t; u >= 10; u /= 10) o++;
926
+ w ? o > s.maxE ? (c.e = NaN, c.d = null) : o < s.minE ? (c.e = 0, c.d = [0]) : (c.e = o, c.d = [t]) : (c.e = o, c.d = [t]);
927
+ return;
928
+ }
929
+ if (t * 0 !== 0) {
930
+ t || (c.s = NaN), c.e = NaN, c.d = null;
931
+ return;
932
+ }
933
+ return Q(c, t.toString());
934
+ }
935
+ if (f === "string")
936
+ return (u = t.charCodeAt(0)) === 45 ? (t = t.slice(1), c.s = -1) : (u === 43 && (t = t.slice(1)), c.s = 1), En.test(t) ? Q(c, t) : kn(c, t);
937
+ if (f === "bigint")
938
+ return t < 0 ? (t = -t, c.s = -1) : c.s = 1, Q(c, t.toString());
939
+ throw Error(H + t);
940
+ }
941
+ if (s.prototype = h, s.ROUND_UP = 0, s.ROUND_DOWN = 1, s.ROUND_CEIL = 2, s.ROUND_FLOOR = 3, s.ROUND_HALF_UP = 4, s.ROUND_HALF_DOWN = 5, s.ROUND_HALF_EVEN = 6, s.ROUND_HALF_CEIL = 7, s.ROUND_HALF_FLOOR = 8, s.EUCLID = 9, s.config = s.set = Xn, s.clone = Fn, s.isDecimal = mn, s.abs = Cn, s.acos = Hn, s.acosh = Bn, s.add = Vn, s.asin = $n, s.asinh = jn, s.atan = Wn, s.atanh = Jn, s.atan2 = zn, s.cbrt = Gn, s.ceil = Kn, s.clamp = Qn, s.cos = Yn, s.cosh = nr, s.div = rr, s.exp = ir, s.floor = er, s.hypot = tr, s.ln = sr, s.log = or, s.log10 = cr, s.log2 = ur, s.max = fr, s.min = ar, s.mod = lr, s.mul = dr, s.pow = hr, s.random = gr, s.round = pr, s.sign = mr, s.sin = wr, s.sinh = Nr, s.sqrt = vr, s.sub = br, s.sum = Er, s.tan = xr, s.tanh = yr, s.trunc = Mr, n === void 0 && (n = {}), n && n.defaults !== !0)
942
+ for (e = [
943
+ "precision",
944
+ "rounding",
945
+ "toExpNeg",
946
+ "toExpPos",
947
+ "maxE",
948
+ "minE",
949
+ "modulo",
950
+ "crypto"
951
+ ], r = 0; r < e.length; )
952
+ n.hasOwnProperty(i = e[r++]) || (n[i] = this[i]);
953
+ return s.config(n), s;
954
+ }
955
+ function rr(n, r) {
956
+ return new this(n).div(r);
957
+ }
958
+ function ir(n) {
959
+ return new this(n).exp();
960
+ }
961
+ function er(n) {
962
+ return g(n = new this(n), n.e + 1, 3);
963
+ }
964
+ function tr() {
965
+ var n, r, i = new this(0);
966
+ for (w = !1, n = 0; n < arguments.length; )
967
+ if (r = new this(arguments[n++]), r.d)
968
+ i.d && (i = i.plus(r.times(r)));
969
+ else {
970
+ if (r.s)
971
+ return w = !0, new this(1 / 0);
972
+ i = r;
973
+ }
974
+ return w = !0, i.sqrt();
975
+ }
976
+ function mn(n) {
977
+ return n instanceof Z || n && n.toStringTag === bn || !1;
978
+ }
979
+ function sr(n) {
980
+ return new this(n).ln();
981
+ }
982
+ function or(n, r) {
983
+ return new this(n).log(r);
984
+ }
985
+ function ur(n) {
986
+ return new this(n).log(2);
987
+ }
988
+ function cr(n) {
989
+ return new this(n).log(10);
990
+ }
991
+ function fr() {
992
+ return Mn(this, arguments, -1);
993
+ }
994
+ function ar() {
995
+ return Mn(this, arguments, 1);
996
+ }
997
+ function lr(n, r) {
998
+ return new this(n).mod(r);
999
+ }
1000
+ function dr(n, r) {
1001
+ return new this(n).mul(r);
1002
+ }
1003
+ function hr(n, r) {
1004
+ return new this(n).pow(r);
1005
+ }
1006
+ function gr(n) {
1007
+ var r, i, e, s, t = 0, o = new this(1), u = [];
1008
+ if (n === void 0 ? n = this.precision : P(n, 1, B), e = Math.ceil(n / m), this.crypto)
1009
+ if (crypto.getRandomValues)
1010
+ for (r = crypto.getRandomValues(new Uint32Array(e)); t < e; )
1011
+ s = r[t], s >= 429e7 ? r[t] = crypto.getRandomValues(new Uint32Array(1))[0] : u[t++] = s % 1e7;
1012
+ else if (crypto.randomBytes) {
1013
+ for (r = crypto.randomBytes(e *= 4); t < e; )
1014
+ s = r[t] + (r[t + 1] << 8) + (r[t + 2] << 16) + ((r[t + 3] & 127) << 24), s >= 214e7 ? crypto.randomBytes(4).copy(r, t) : (u.push(s % 1e7), t += 4);
1015
+ t = e / 4;
1016
+ } else
1017
+ throw Error(vn);
1018
+ else for (; t < e; ) u[t++] = Math.random() * 1e7 | 0;
1019
+ for (e = u[--t], n %= m, e && n && (s = M(10, m - n), u[t] = (e / s | 0) * s); u[t] === 0; t--) u.pop();
1020
+ if (t < 0)
1021
+ i = 0, u = [0];
1022
+ else {
1023
+ for (i = -1; u[0] === 0; i -= m) u.shift();
1024
+ for (e = 1, s = u[0]; s >= 10; s /= 10) e++;
1025
+ e < m && (i -= m - e);
1026
+ }
1027
+ return o.e = i, o.d = u, o;
1028
+ }
1029
+ function pr(n) {
1030
+ return g(n = new this(n), n.e + 1, this.rounding);
1031
+ }
1032
+ function mr(n) {
1033
+ return n = new this(n), n.d ? n.d[0] ? n.s : 0 * n.s : n.s || NaN;
1034
+ }
1035
+ function wr(n) {
1036
+ return new this(n).sin();
1037
+ }
1038
+ function Nr(n) {
1039
+ return new this(n).sinh();
1040
+ }
1041
+ function vr(n) {
1042
+ return new this(n).sqrt();
1043
+ }
1044
+ function br(n, r) {
1045
+ return new this(n).sub(r);
1046
+ }
1047
+ function Er() {
1048
+ var n = 0, r = arguments, i = new this(r[n]);
1049
+ for (w = !1; i.s && ++n < r.length; ) i = i.plus(r[n]);
1050
+ return w = !0, g(i, this.precision, this.rounding);
1051
+ }
1052
+ function xr(n) {
1053
+ return new this(n).tan();
1054
+ }
1055
+ function yr(n) {
1056
+ return new this(n).tanh();
1057
+ }
1058
+ function Mr(n) {
1059
+ return g(n = new this(n), n.e + 1, 1);
1060
+ }
1061
+ Z = Fn(an);
1062
+ Z.prototype.constructor = Z;
1063
+ Z.default = Z.Decimal = Z;
1064
+ X = new Z(X);
1065
+ Y = new Z(Y);
1066
+ function An(n, r) {
1067
+ return new Z(n).plus(r).toNumber();
1068
+ }
1069
+ function Dn(n, r) {
1070
+ return new Z(n).minus(r).toNumber();
1071
+ }
1072
+ function Zn(n, r) {
1073
+ return new Z(n).times(r).toNumber();
1074
+ }
1075
+ function Pn(n, r) {
1076
+ return new Z(n).div(r).toNumber();
1077
+ }
1078
+ const qr = An, Or = Dn, Fr = Zn, Ar = Pn, Dr = {
1079
+ plus: An,
1080
+ minus: Dn,
1081
+ times: Zn,
1082
+ div: Pn,
1083
+ add: qr,
1084
+ subtract: Or,
1085
+ multiply: Fr,
1086
+ divide: Ar
1087
+ };
1088
+ export {
1089
+ Fr as c,
1090
+ Ar as d,
1091
+ Dn as i,
1092
+ Dr as l,
1093
+ Or as m,
1094
+ Zn as o,
1095
+ Pn as r,
1096
+ qr as s,
1097
+ An as u
1098
+ };