@roomstay/core 0.1.78-2 → 0.1.78

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 (247) hide show
  1. package/dist/browser/index.js +3901 -0
  2. package/dist/browser/index.js.map +1 -0
  3. package/dist/node/index.cjs +25 -0
  4. package/dist/node/index.cjs.map +1 -0
  5. package/dist/node/index.mjs +3901 -0
  6. package/dist/node/index.mjs.map +1 -0
  7. package/dist/node.js +1 -1
  8. package/dist/types/AnalyticsEvents/IAnalyticsEvent.type.d.ts +12 -38
  9. package/dist/types/AnalyticsEvents/IRoomstayEventData.type.d.ts +2 -27
  10. package/dist/types/AnalyticsEvents/MetaCapiTransformer.d.ts +2 -6
  11. package/dist/types/Booking/IBookingExtraFields.type.d.ts +8 -4
  12. package/dist/types/Booking/PlaceBooking.types.d.ts +0 -1
  13. package/dist/types/Company/ECompanyProvider.enum.d.ts +1 -2
  14. package/dist/types/Company/IAdminCompany.type.d.ts +0 -6
  15. package/dist/types/GiftCards/GiftCard.types.d.ts +0 -9
  16. package/dist/types/Maintenance/IMaintenanceStatus.type.d.ts +1 -4
  17. package/dist/types/Member/IRoomstayMember.type.d.ts +1 -2
  18. package/dist/types/Policies/EGuaranteePolicy.enum.d.ts +0 -5
  19. package/dist/types/index.d.ts +2 -19
  20. package/dist/types/index.d.ts.map +1 -0
  21. package/dist/types/types/Addons/Addon.enum.d.ts +3 -0
  22. package/dist/types/types/Addons/Addon.enum.d.ts.map +1 -0
  23. package/dist/types/{Addon/Addon.d.ts → types/Addons/Addon.types.d.ts} +21 -3
  24. package/dist/types/types/Addons/Addon.types.d.ts.map +1 -0
  25. package/dist/types/types/Analytics/IBigQueryResults.type.d.ts +46 -0
  26. package/dist/types/types/Analytics/IBigQueryResults.type.d.ts.map +1 -0
  27. package/dist/types/types/AnalyticsEvents/IAnalyticsEvent.type.d.ts +65 -0
  28. package/dist/types/types/AnalyticsEvents/IAnalyticsEvent.type.d.ts.map +1 -0
  29. package/dist/types/types/AnalyticsEvents/IAnalyticsSession.type.d.ts +21 -0
  30. package/dist/types/types/AnalyticsEvents/IAnalyticsSession.type.d.ts.map +1 -0
  31. package/dist/types/types/AnalyticsEvents/IRoomstayEventData.type.d.ts +66 -0
  32. package/dist/types/types/AnalyticsEvents/IRoomstayEventData.type.d.ts.map +1 -0
  33. package/dist/types/types/AnalyticsEvents/MetaCapiTransformer.d.ts +22 -0
  34. package/dist/types/types/AnalyticsEvents/MetaCapiTransformer.d.ts.map +1 -0
  35. package/dist/types/{Api/ReservationsDTO.d.ts → types/Api/Reservations.type.d.ts} +11 -28
  36. package/dist/types/types/Api/Reservations.type.d.ts.map +1 -0
  37. package/dist/types/{Api/RoomNightRateDTO.d.ts → types/Api/RoomNightRate.type.d.ts} +1 -0
  38. package/dist/types/types/Api/RoomNightRate.type.d.ts.map +1 -0
  39. package/dist/types/types/Availability/Availability.types.d.ts +122 -0
  40. package/dist/types/types/Availability/Availability.types.d.ts.map +1 -0
  41. package/dist/types/types/Booking/ConfirmBooking.types.d.ts +22 -0
  42. package/dist/types/types/Booking/ConfirmBooking.types.d.ts.map +1 -0
  43. package/dist/types/types/Booking/EBooking.types.d.ts +13 -0
  44. package/dist/types/types/Booking/EBooking.types.d.ts.map +1 -0
  45. package/dist/types/types/Booking/GetBooking.types.d.ts +8 -0
  46. package/dist/types/types/Booking/GetBooking.types.d.ts.map +1 -0
  47. package/dist/types/{Booking/IBookingCreateErrorResponse.d.ts → types/Booking/IBookingCreateErrorResponse.type.d.ts} +3 -0
  48. package/dist/types/types/Booking/IBookingCreateErrorResponse.type.d.ts.map +1 -0
  49. package/dist/types/types/Booking/IBookingExtraFields.type.d.ts +6 -0
  50. package/dist/types/types/Booking/IBookingExtraFields.type.d.ts.map +1 -0
  51. package/dist/types/types/Booking/IBookingPayment.type.d.ts +106 -0
  52. package/dist/types/types/Booking/IBookingPayment.type.d.ts.map +1 -0
  53. package/dist/types/types/Booking/IBookingQuote.type.d.ts +31 -0
  54. package/dist/types/types/Booking/IBookingQuote.type.d.ts.map +1 -0
  55. package/dist/types/types/Booking/ICommonQueryParameters.type.d.ts +4 -0
  56. package/dist/types/types/Booking/ICommonQueryParameters.type.d.ts.map +1 -0
  57. package/dist/types/types/Booking/Itinerary.types.d.ts +100 -0
  58. package/dist/types/types/Booking/Itinerary.types.d.ts.map +1 -0
  59. package/dist/types/types/Booking/PencilReservation.types.d.ts +20 -0
  60. package/dist/types/types/Booking/PencilReservation.types.d.ts.map +1 -0
  61. package/dist/types/types/Booking/PlaceBooking.types.d.ts +90 -0
  62. package/dist/types/types/Booking/PlaceBooking.types.d.ts.map +1 -0
  63. package/dist/types/types/Company/ECompanyProvider.enum.d.ts +9 -0
  64. package/dist/types/types/Company/ECompanyProvider.enum.d.ts.map +1 -0
  65. package/dist/types/types/Company/IAdminCompany.type.d.ts +47 -0
  66. package/dist/types/types/Company/IAdminCompany.type.d.ts.map +1 -0
  67. package/dist/types/types/Company/IAdminCompanyUser.type.d.ts +16 -0
  68. package/dist/types/types/Company/IAdminCompanyUser.type.d.ts.map +1 -0
  69. package/dist/types/types/Events/ERoomstayEventSource.enum.d.ts +5 -0
  70. package/dist/types/types/Events/ERoomstayEventSource.enum.d.ts.map +1 -0
  71. package/dist/types/types/Events/IRoomstayEvent.type.d.ts +51 -0
  72. package/dist/types/types/Events/IRoomstayEvent.type.d.ts.map +1 -0
  73. package/dist/types/types/Fees/EFeeType.enum.d.ts +8 -0
  74. package/dist/types/types/Fees/EFeeType.enum.d.ts.map +1 -0
  75. package/dist/types/types/Fees/IFee.type.d.ts +12 -0
  76. package/dist/types/types/Fees/IFee.type.d.ts.map +1 -0
  77. package/dist/types/types/Fees/IFeeConfigurationOptions.type.d.ts +7 -0
  78. package/dist/types/types/Fees/IFeeConfigurationOptions.type.d.ts.map +1 -0
  79. package/dist/types/types/General/Format.types.d.ts +2 -0
  80. package/dist/types/types/General/Format.types.d.ts.map +1 -0
  81. package/dist/types/types/General/HttpMethod.enum.d.ts +10 -0
  82. package/dist/types/types/General/HttpMethod.enum.d.ts.map +1 -0
  83. package/dist/types/types/General/IMessage.type.d.ts +7 -0
  84. package/dist/types/types/General/IMessage.type.d.ts.map +1 -0
  85. package/dist/types/types/General/Pagination.types.d.ts +21 -0
  86. package/dist/types/types/General/Pagination.types.d.ts.map +1 -0
  87. package/dist/types/types/General/Warning.type.d.ts +15 -0
  88. package/dist/types/types/General/Warning.type.d.ts.map +1 -0
  89. package/dist/types/types/GiftCards/GiftCard.types.d.ts +346 -0
  90. package/dist/types/types/GiftCards/GiftCard.types.d.ts.map +1 -0
  91. package/dist/types/types/GiftCards/GiftCardAuth.types.d.ts +32 -0
  92. package/dist/types/types/GiftCards/GiftCardAuth.types.d.ts.map +1 -0
  93. package/dist/types/types/GiftCards/GiftCardLogs.enum.d.ts +35 -0
  94. package/dist/types/types/GiftCards/GiftCardLogs.enum.d.ts.map +1 -0
  95. package/dist/types/types/Hotel/EHotelAddressRequirement.enum.d.ts +6 -0
  96. package/dist/types/types/Hotel/EHotelAddressRequirement.enum.d.ts.map +1 -0
  97. package/dist/types/types/Hotel/EHotelPriceModel.enum.d.ts +6 -0
  98. package/dist/types/types/Hotel/EHotelPriceModel.enum.d.ts.map +1 -0
  99. package/dist/types/types/Hotel/EHotelStateFieldConfiguration.enum.d.ts +6 -0
  100. package/dist/types/types/Hotel/EHotelStateFieldConfiguration.enum.d.ts.map +1 -0
  101. package/dist/types/types/Hotel/EHotelWeekdayStartsOn.enum.d.ts +5 -0
  102. package/dist/types/types/Hotel/EHotelWeekdayStartsOn.enum.d.ts.map +1 -0
  103. package/dist/types/types/Hotel/EIntegration.enum.d.ts +10 -0
  104. package/dist/types/types/Hotel/EIntegration.enum.d.ts.map +1 -0
  105. package/dist/types/types/Hotel/IAuxiliaryFilter.type.d.ts +25 -0
  106. package/dist/types/types/Hotel/IAuxiliaryFilter.type.d.ts.map +1 -0
  107. package/dist/types/types/Hotel/IHotelColorScheme.type.d.ts +30 -0
  108. package/dist/types/types/Hotel/IHotelColorScheme.type.d.ts.map +1 -0
  109. package/dist/types/types/Hotel/IHotelOverrides.type.d.ts +29 -0
  110. package/dist/types/types/Hotel/IHotelOverrides.type.d.ts.map +1 -0
  111. package/dist/types/types/Hotel/IHotelReplica.type.d.ts +57 -0
  112. package/dist/types/types/Hotel/IHotelReplica.type.d.ts.map +1 -0
  113. package/dist/types/types/Hotel/IHotelService.type.d.ts +7 -0
  114. package/dist/types/types/Hotel/IHotelService.type.d.ts.map +1 -0
  115. package/dist/types/types/Image/IRoomstayImage.type.d.ts +9 -0
  116. package/dist/types/types/Image/IRoomstayImage.type.d.ts.map +1 -0
  117. package/dist/types/types/Maintenance/IMaintenanceStatus.type.d.ts +27 -0
  118. package/dist/types/types/Maintenance/IMaintenanceStatus.type.d.ts.map +1 -0
  119. package/dist/types/types/Media/IMedia.type.d.ts +11 -0
  120. package/dist/types/types/Media/IMedia.type.d.ts.map +1 -0
  121. package/dist/types/types/Member/IMember.type.d.ts +8 -0
  122. package/dist/types/types/Member/IMember.type.d.ts.map +1 -0
  123. package/dist/types/types/Member/IMemberVerification.type.d.ts +11 -0
  124. package/dist/types/types/Member/IMemberVerification.type.d.ts.map +1 -0
  125. package/dist/types/types/Member/IRoomstayCognitoMember.type.d.ts +5 -0
  126. package/dist/types/types/Member/IRoomstayCognitoMember.type.d.ts.map +1 -0
  127. package/dist/types/types/Member/IRoomstayMember.type.d.ts +19 -0
  128. package/dist/types/types/Member/IRoomstayMember.type.d.ts.map +1 -0
  129. package/dist/types/types/Member/IRoomstayMemberBooking.type.d.ts +29 -0
  130. package/dist/types/types/Member/IRoomstayMemberBooking.type.d.ts.map +1 -0
  131. package/dist/types/types/Member/IRoomstayMemberBookingAddress.type.d.ts +10 -0
  132. package/dist/types/types/Member/IRoomstayMemberBookingAddress.type.d.ts.map +1 -0
  133. package/dist/types/types/Member/IRoomstayMemberBookingItem.type.d.ts +26 -0
  134. package/dist/types/types/Member/IRoomstayMemberBookingItem.type.d.ts.map +1 -0
  135. package/dist/types/types/Member/IRoomstayMemberBookingProfile.type.d.ts +12 -0
  136. package/dist/types/types/Member/IRoomstayMemberBookingProfile.type.d.ts.map +1 -0
  137. package/dist/types/types/Member/IRoomstayMemberCards.type.d.ts +13 -0
  138. package/dist/types/types/Member/IRoomstayMemberCards.type.d.ts.map +1 -0
  139. package/dist/types/types/Member/IRoomstayMemberJWTData.type.d.ts +4 -0
  140. package/dist/types/types/Member/IRoomstayMemberJWTData.type.d.ts.map +1 -0
  141. package/dist/types/types/Member/ISession.type.d.ts +5 -0
  142. package/dist/types/types/Member/ISession.type.d.ts.map +1 -0
  143. package/dist/types/types/OHIP/IOHIPConfiguration.types.d.ts +13 -0
  144. package/dist/types/types/OHIP/IOHIPConfiguration.types.d.ts.map +1 -0
  145. package/dist/types/types/OHIP/index.d.ts +2 -0
  146. package/dist/types/types/OHIP/index.d.ts.map +1 -0
  147. package/dist/types/types/Package/Package.types.d.ts +105 -0
  148. package/dist/types/types/Package/Package.types.d.ts.map +1 -0
  149. package/dist/types/types/Policies/EGuaranteePolicy.enum.d.ts +7 -0
  150. package/dist/types/types/Policies/EGuaranteePolicy.enum.d.ts.map +1 -0
  151. package/dist/types/types/PromoCode/EPromoCodeDiscountType.enum.d.ts +6 -0
  152. package/dist/types/types/PromoCode/EPromoCodeDiscountType.enum.d.ts.map +1 -0
  153. package/dist/types/types/PromoCode/PromoCodeStayDateRangeType.enum.d.ts +12 -0
  154. package/dist/types/types/PromoCode/PromoCodeStayDateRangeType.enum.d.ts.map +1 -0
  155. package/dist/types/{PMSSync/EPMSSyncStatus.enum.d.ts → types/RMS/ERMSAuthSyncHistoryStatus.type.d.ts} +4 -3
  156. package/dist/types/types/RMS/ERMSAuthSyncHistoryStatus.type.d.ts.map +1 -0
  157. package/dist/types/types/RMS/ERMSDiscountType.enum.d.ts +7 -0
  158. package/dist/types/types/RMS/ERMSDiscountType.enum.d.ts.map +1 -0
  159. package/dist/types/types/RMS/ERMSSyncStrategy.enum.d.ts +39 -0
  160. package/dist/types/types/RMS/ERMSSyncStrategy.enum.d.ts.map +1 -0
  161. package/dist/types/types/RMS/IRMSPropertyDiscount.type.d.ts +34 -0
  162. package/dist/types/types/RMS/IRMSPropertyDiscount.type.d.ts.map +1 -0
  163. package/dist/types/types/RMS/IRMSRequirement.type.d.ts +21 -0
  164. package/dist/types/types/RMS/IRMSRequirement.type.d.ts.map +1 -0
  165. package/dist/types/types/RMS/IRMSSyncResponse.type.d.ts +9 -0
  166. package/dist/types/types/RMS/IRMSSyncResponse.type.d.ts.map +1 -0
  167. package/dist/types/types/RMS/RMSBookingSource.type.d.ts +8 -0
  168. package/dist/types/types/RMS/RMSBookingSource.type.d.ts.map +1 -0
  169. package/dist/types/types/Room/IRoomGroup.type.d.ts +19 -0
  170. package/dist/types/types/Room/IRoomGroup.type.d.ts.map +1 -0
  171. package/dist/types/types/index.d.ts +139 -0
  172. package/dist/types/types/index.d.ts.map +1 -0
  173. package/dist/types/utils/TotalCalculator.d.ts +73 -0
  174. package/dist/types/utils/TotalCalculator.d.ts.map +1 -0
  175. package/dist/types/utils/bookingTotal.d.ts +8 -0
  176. package/dist/types/utils/bookingTotal.d.ts.map +1 -0
  177. package/dist/types/utils/calculateFee.d.ts +11 -0
  178. package/dist/types/utils/calculateFee.d.ts.map +1 -0
  179. package/dist/types/utils/feeTypes.d.ts +6 -0
  180. package/dist/types/utils/feeTypes.d.ts.map +1 -0
  181. package/dist/types/utils/index.d.ts +11 -0
  182. package/dist/types/utils/index.d.ts.map +1 -0
  183. package/dist/types/utils/reflection.d.ts +10 -0
  184. package/dist/types/utils/reflection.d.ts.map +1 -0
  185. package/dist/types/utils/roomstayImageResize.d.ts +15 -0
  186. package/dist/types/utils/roomstayImageResize.d.ts.map +1 -0
  187. package/dist/types/utils/roundMoney.d.ts +11 -0
  188. package/dist/types/utils/roundMoney.d.ts.map +1 -0
  189. package/dist/types/utils/typeUtils.d.ts +2 -0
  190. package/dist/types/utils/typeUtils.d.ts.map +1 -0
  191. package/dist/types/utils/uppercaseString.d.ts +2 -0
  192. package/dist/types/utils/uppercaseString.d.ts.map +1 -0
  193. package/dist/types/utils/zodUtils.d.ts +20 -0
  194. package/dist/types/utils/zodUtils.d.ts.map +1 -0
  195. package/dist/utils/roundMoney.d.ts +1 -11
  196. package/dist/web.js +1 -1
  197. package/package.json +1 -1
  198. package/dist/components/DateRangePicker/DateRangePicker.d.ts +0 -16
  199. package/dist/components/DateRangePicker/DateRangePicker.type.d.ts +0 -16
  200. package/dist/components/DateRangePicker/DateRangePickerContext.d.ts +0 -16
  201. package/dist/components/DateRangePicker/DateRangePickerDay.d.ts +0 -22
  202. package/dist/components/DateRangePicker/DateRangePickerDays.d.ts +0 -7
  203. package/dist/components/DateRangePicker/DateRangePickerMonth.d.ts +0 -9
  204. package/dist/components/DateRangePicker/FloatingDateRangePicker.d.ts +0 -26
  205. package/dist/components/DateRangePicker/index.d.ts +0 -3
  206. package/dist/components/Icon/Icon.d.ts +0 -19
  207. package/dist/components/Icon/index.d.ts +0 -1
  208. package/dist/components/Overlay/Overlay.d.ts +0 -21
  209. package/dist/components/Overlay/index.d.ts +0 -1
  210. package/dist/components/RoomstayPortal/RoomstayPortal.d.ts +0 -8
  211. package/dist/components/RoomstayPortal/index.d.ts +0 -1
  212. package/dist/components/Text/Text.d.ts +0 -18
  213. package/dist/components/Text/Text.type.d.ts +0 -14
  214. package/dist/components/Text/index.d.ts +0 -2
  215. package/dist/components/animations/AutoAutoHeight.d.ts +0 -9
  216. package/dist/components/animations/Fade.d.ts +0 -13
  217. package/dist/components/animations/index.d.ts +0 -1
  218. package/dist/components/index.d.ts +0 -6
  219. package/dist/hooks/BodyClickHook.d.ts +0 -8
  220. package/dist/index.node.d.ts +0 -2
  221. package/dist/index.web.d.ts +0 -3
  222. package/dist/node.js.map +0 -1
  223. package/dist/roomstay-core-0.1.26.tgz +0 -0
  224. package/dist/stories/DateRangePicker.stories.d.ts +0 -8
  225. package/dist/stories/FloatingDateRangePicker.stories.d.ts +0 -5
  226. package/dist/types/Addon/Addon.enum.d.ts +0 -14
  227. package/dist/types/Addon/Addon.type.d.ts +0 -24
  228. package/dist/types/Booking/IBookingStatus.type.d.ts +0 -5
  229. package/dist/types/Booking/IPrice.type.d.ts +0 -7
  230. package/dist/types/Hotel/IHotel.enum.d.ts +0 -32
  231. package/dist/types/Hotel/IHotel.type.d.ts +0 -275
  232. package/dist/types/Hotel/IntegrationConfigs.type.d.ts +0 -76
  233. package/dist/types/Hotel/InternalMemberSignInModal.type.d.ts +0 -13
  234. package/dist/types/Hotel/InternalMemberSignInModal.types.d.ts +0 -13
  235. package/dist/types/Member/IRoomstayMemberLoyalty.type.d.ts +0 -16
  236. package/dist/types/Newbook/ENewbookRegion.enum.d.ts +0 -7
  237. package/dist/types/Newbook/ENewbookSyncStrategy.enum.d.ts +0 -5
  238. package/dist/types/Newbook/index.d.ts +0 -2
  239. package/dist/types/PMSSync/IPMSSyncResponse.type.d.ts +0 -10
  240. package/dist/types/PMSSync/index.d.ts +0 -17
  241. package/dist/types/Room/HotelRoom.type.d.ts +0 -24
  242. package/dist/types/Room/SynxisRoom.type.d.ts +0 -35
  243. package/dist/utils/CalendarHelper.d.ts +0 -16
  244. package/dist/utils/color.d.ts +0 -17
  245. package/dist/utils/index.node.d.ts +0 -2
  246. package/dist/utils/index.web.d.ts +0 -4
  247. package/dist/web.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../src/types/Booking/EBooking.types.ts","../../src/types/Booking/IBookingPayment.type.ts","../../src/types/Booking/Itinerary.types.ts","../../src/types/Company/ECompanyProvider.enum.ts","../../src/types/Company/IAdminCompanyUser.type.ts","../../src/types/Hotel/EHotelAddressRequirement.enum.ts","../../src/types/Hotel/EHotelPriceModel.enum.ts","../../src/types/Hotel/EHotelStateFieldConfiguration.enum.ts","../../src/types/Hotel/EHotelWeekdayStartsOn.enum.ts","../../src/types/Hotel/EIntegration.enum.ts","../../src/types/Hotel/IAuxiliaryFilter.type.ts","../../src/types/Hotel/IHotelOverrides.type.ts","../../src/types/RMS/ERMSAuthSyncHistoryStatus.type.ts","../../src/types/RMS/ERMSDiscountType.enum.ts","../../src/types/RMS/ERMSSyncStrategy.enum.ts","../../src/types/Image/IRoomstayImage.type.ts","../../src/types/Maintenance/IMaintenanceStatus.type.ts","../../src/types/Package/Package.types.ts","../../src/types/Policies/EGuaranteePolicy.enum.ts","../../src/types/PromoCode/EPromoCodeDiscountType.enum.ts","../../src/types/PromoCode/PromoCodeStayDateRangeType.enum.ts","../../src/types/Events/ERoomstayEventSource.enum.ts","../../src/types/General/Format.types.ts","../../src/types/General/HttpMethod.enum.ts","../../src/types/Fees/EFeeType.enum.ts","../../src/types/AnalyticsEvents/IAnalyticsEvent.type.ts","../../src/types/AnalyticsEvents/MetaCapiTransformer.ts","../../src/types/Addons/Addon.types.ts","../../src/types/Addons/Addon.enum.ts","../../node_modules/zod/v4/core/core.js","../../node_modules/zod/v4/core/util.js","../../node_modules/zod/v4/core/errors.js","../../node_modules/zod/v4/core/parse.js","../../node_modules/zod/v4/core/regexes.js","../../node_modules/zod/v4/core/checks.js","../../node_modules/zod/v4/core/doc.js","../../node_modules/zod/v4/core/versions.js","../../node_modules/zod/v4/core/schemas.js","../../node_modules/zod/v4/core/registries.js","../../node_modules/zod/v4/core/api.js","../../node_modules/zod/v4/classic/iso.js","../../node_modules/zod/v4/classic/errors.js","../../node_modules/zod/v4/classic/parse.js","../../node_modules/zod/v4/classic/schemas.js","../../node_modules/zod/v4/classic/coerce.js","../../src/utils/zodUtils.ts","../../src/types/GiftCards/GiftCard.types.ts","../../src/types/GiftCards/GiftCardAuth.types.ts","../../src/types/GiftCards/GiftCardLogs.enum.ts","../../src/utils/bookingTotal.ts","../../node_modules/decimal.js/decimal.mjs","../../src/utils/roundMoney.ts","../../src/utils/calculateFee.ts","../../src/utils/feeTypes.ts","../../src/utils/reflection.ts","../../src/utils/roomstayImageResize.ts","../../src/utils/TotalCalculator.ts","../../src/utils/uppercaseString.ts"],"sourcesContent":["export enum EBookingStatus {\n Pending = 'Pending',\n Processing = 'Processing',\n Committed = 'Committed',\n Cancelled = 'Cancelled',\n Reverted = 'Reverted',\n}\n\nexport enum EBookingFlow {\n Default = 'Default',\n PreCheckoutPencil = 'PreCheckoutPencil',\n PostCheckoutPencil = 'PostCheckoutPencil',\n}\n","export enum EBookingPaymentMethod {\n Card = 'Card',\n SavedCard = 'SavedCard',\n Planpay = 'Planpay',\n Adyen = 'Adyen',\n Afterpay = 'Afterpay',\n PCIBookingCard = 'PCIBookingCard',\n TrueRewards = 'TrueRewards',\n}\n\n/**\n * This enum is used to determine which payment processor to use for the booking.\n *\n * Usually only applies if the payment method is Card, SavedCard, or PCIBookingCard.\n *\n * Other payment methods will generate their own checkout flow that will differ from this.\n */\nexport enum EHotelCardProcessor {\n Passthrough = 'Passthrough',\n Adyen = 'Adyen',\n Till = 'Till',\n RMSPay = 'RMSPay',\n Windcave = 'Windcave',\n Mastercard = 'Mastercard',\n Stripe = 'Stripe',\n PayPal = 'PayPal',\n}\n\nexport enum EPlanpayBookingStatus {\n Unknown = 'unknown', // incase plan.deposit.status is unavailable\n Unpaid = 'unpaid',\n Accepted = 'accepted',\n Cancelled = 'cancelled',\n Refunded = 'refunded',\n Rejected = 'rejected',\n}\n\nexport const PCIBookingCardProcessorTypes = [];\nexport type PCIBookingCardProcessorType = undefined;\n\nexport type IBookingPaymentTokenizedCard = {\n Type: string;\n Number: string;\n Expiry: number;\n CVV: string;\n Name: string;\n};\n\ntype IPCIBookingCardNotificationData = {\n CaptureCardRequestID: string;\n CaptureCardRequestStatus: string;\n CardUri: string;\n};\n\n/**\n * Booking payment attached to a booking.\n *\n * Could be either Card or Planpay\n */\nexport type IBookingPayment = {\n Method: EBookingPaymentMethod;\n SavedCardID?: string;\n PlanpayCheckoutId?: string;\n PaymentCard?: IBookingPaymentTokenizedCard;\n PCICardDetails?: IPCIBookingCardNotificationData;\n RedirectUrl?: string;\n SplitPaymentAmount?: number;\n};\n\nexport type IPaymentCheckoutDetails = {\n planpay?: {\n id: string;\n checkoutWorkflow: {\n type: string;\n id: string;\n scriptUrl: string;\n };\n };\n external?: {\n id: string;\n redirectUrl: string;\n };\n adyen?: {\n roomstayId: string;\n sessionData: string;\n sessionId: string;\n clientKey: string;\n isLive: boolean;\n currency: string;\n amount: string;\n countryCode: string;\n };\n mastercard?: {\n sessionId: string;\n paymentMode: 'EmbeddedPage' | 'PaymentPage';\n baseUrl: string;\n };\n stripe?: {\n clientSecret: string;\n publishableApiKey: string;\n successUrl: string;\n };\n paypal?: {\n orderId: string;\n clientId: string;\n successUrl: string;\n currencyCode: string;\n };\n isSplitPayment?: boolean;\n totalAuthorizedAmount?: number;\n};","import { EBookingPaymentMethod, IPaymentCheckoutDetails } from './IBookingPayment.type';\nimport { ReservedPackage } from '../Package/Package.types';\n\nexport class ItineraryResponse {\n roomstayId: string;\n itineraryNumber?: string;\n total?: IAmount;\n hotelFrontendId?: string;\n reservations: Reservation[] = [];\n payment?: IPaymentCheckoutDetails;\n feesSummary?: IItemisedBookingFeeResponse[];\n itemisedFees?: IItemisedBookingFeeResponse[];\n warnings?: string[];\n}\n\nexport class Reservation {\n reservationNumber: string;\n roomType: string;\n roomCode: string;\n rate: string;\n rateCode?: string;\n images: string[];\n guaranteePolicy?: string;\n cancellationPolicy?: string;\n checkInDate: string;\n checkOutDate: string;\n nights: { [date: string]: IPrice } = {};\n guestCounts = {\n adults: 1,\n children: 0,\n };\n guest = new GuestProfile();\n paymentCard: {\n type: string | undefined;\n last4: string;\n expiry: string;\n name: string;\n };\n paymentMethod: EBookingPaymentMethod;\n total: IAmount;\n status: string;\n isCancelable: boolean;\n addons: ReservedPackage[] | undefined;\n comments?: string[];\n specialRequests?: string[];\n promoCode?: string;\n guaranteePolicyLongDescription?: string;\n cancellationPolicyLongDescription?: string;\n itemisedFees?: IItemisedBookingFeeResponse[];\n}\n\nexport class GuestProfile {\n title?: string;\n firstName?: string;\n middleName?: string;\n lastName?: string;\n nameSuffix?: string;\n phone?: string;\n email?: string;\n address: IAddress = {};\n marketingOptIn?: boolean;\n country: string;\n}\n\nexport type IGuestCounts = {\n adults: number;\n children: number;\n};\n\nexport type IAddress = {\n line1?: string;\n line2?: string;\n line3?: string;\n city?: string;\n postalCode?: string;\n state?: string;\n country?: string;\n};\n\nexport type IAmount = {\n beforeTax: number;\n afterTax: number;\n beforeFees?: number;\n};\n\nexport type ICheckoutWorkflowType = {\n sdkWidget: {\n type: string;\n id: string;\n scriptUrl: string;\n };\n};\n\nexport type IItemisedBookingFeeResponse = {\n name: string;\n description?: string;\n amount: number;\n};\n\nexport type IPrice = {\n cost: number;\n discount: number;\n tax: number;\n fee: number;\n total: number;\n};\n","export enum ECompanyProvider {\n Synxis = 'Synxis',\n Availpro = 'Availpro',\n RMS = 'RMS',\n Siteminder = 'Siteminder',\n Roomstay = 'Roomstay',\n OHIP = 'OHIP',\n}\n","export enum EAdminCompanyUserRole {\n SuperAdmin = 'SuperAdmin',\n Admin = 'Admin',\n Limited = 'Limited',\n}\n\nexport type IAdminCompanyUser = {\n id: number;\n email: string;\n title: string;\n firstName: string;\n lastName: string;\n\n newPassword?: string;\n deletedDate?: Date;\n\n role?: EAdminCompanyUserRole;\n};\n","export enum EHotelAddressRequirement {\n FullAddressRequired = 'FullAddressRequired',\n AddressOptionalCountryRequired = 'AddressOptionalCountryRequired',\n AddressOptional = 'AddressOptional',\n}\n","export enum EHotelPriceModel {\n PerPerson = 'PerPerson',\n PerDay = 'PerDay',\n PerOccupancy = 'PerOccupancy',\n}\n","export enum EHotelStateFieldConfiguration {\n NotIncluded = 'NotIncluded',\n Optional = 'Optional',\n Required = 'Required',\n}\n","export enum EHotelWeekdayStartsOn {\n Monday = 'monday',\n Sunday = 'sunday',\n}\n","export enum EIntegration {\n Big4 = 'Big4',\n RmsTop10 = 'Top10',\n Top10 = 'NewTop10',\n Gday = 'Gday',\n Salesforce = 'Salesforce',\n RAC = 'RAC',\n AnalyticsEvents = 'AnalyticsEvents',\n}","/**\n * These filters can be applied to room groups currently,\n * they add a way to add custom props on rooms, that in turn let you filter\n * them in the front end further\n */\nexport type IAuxiliaryFilter = {\n type: 'select';\n\n /**\n * If the target value can have multiple values specified (i.e if room can both have \"tend\", and \"caravan\" as a type)\n */\n allowSourceMultiple?: boolean;\n /** If a room is selected with this value, require that the user enters the specific value at checkout */\n requireInput?: boolean;\n /** If set to true, and user decides to filter by 3rd entry, 1st & 2nd also works */\n includeAllAbove: boolean;\n options: { value: string | number; label: string }[];\n};\n\nexport enum IAuxiliaryFilterType {\n AreaDwellingLength = 'AreaDwellingLength',\n AreaDwellingType = 'AreaDwellingType',\n}\n","export enum EDistanceUnitType {\n Metric = 'metric',\n Imperial = 'imperial',\n}\n\nexport type ITransportDistances = {\n plane?: string;\n train?: string;\n bus?: string;\n taxi?: string;\n};\n\nexport type IOverrideMessage = {\n enable: boolean;\n BestRatePerks: string;\n BestRatePerksAlert: string;\n PreSignUp: string;\n PostSignUp: string;\n pricesIncludeFeesMessage?:string;\n}\n\nexport type IHotelOverrides = {\n hideByLine?: boolean;\n overrideDistanceUnitType?: boolean;\n distanceUnitType?: EDistanceUnitType;\n transportDistances?: ITransportDistances;\n phoneNumberInSummary?: boolean;\n enabledEventIds?: string[];\n showPromoCodeDescription?: boolean;\n messages?: IOverrideMessage;\n};\n","export enum ERMSAuthSyncHistoryStatus {\n Success = 'success',\n Failure = 'failure',\n New = 'new',\n Queued = 'queued',\n InProgress = 'in_progress',\n RequireResume = 'require_resume',\n}","export enum ERMSDiscountType {\n Percentage = 'Percentage',\n Amount = 'Amount',\n Bogo = 'BOGO',\n NightlyRateOverride = 'NightlyRateOverride',\n}\n","export enum ERMSSyncStrategy {\n /**\n * Super-admin granular sync strategies\n */\n Hotel = 'hotel',\n HotelImages = 'hotelImages',\n Cancellation = 'cancellation',\n Room = 'room',\n Rates = 'rates',\n OneGuaranteePolicy = 'oneGuaranteePolicy',\n RoomRates = 'roomRates',\n RoomImages = 'roomImages',\n BookingSources = 'booking-sources',\n Areas = 'areas',\n Dwellings = 'dwellings',\n AreaDwellings = 'areaDwellings',\n ConvertDwellingConfigToAuxInput = 'convertDwellingConfigToAuxInput',\n Discounts = 'discounts',\n PropertyDiscounts = 'propertyDiscounts',\n RoomDiscounts = 'roomDiscounts',\n PropertySundries = 'propertySundries',\n PropertyFees = 'propertyFees',\n PropertyCards = 'property-cards',\n Countries = 'countries',\n Addons = 'addons',\n Requirements = 'requirements',\n RoomAddons = 'room-addons',\n\n /**\n * Client-facing sync strategies\n */\n ClientFacingPromoSync = 'clientFacingPromoSync',\n ClientFacingRoomSync = 'clientFacingRoomSync',\n ClientFacingRateSync = 'clientFacingRateSync',\n\n /**\n * Other sync strategies\n */\n NewRateFetch = 'newRateFetch',\n\n // TODO: sync everything in one\n // MegaHotelSync: 'megaHotelSync',\n}","export enum ERoomstayImageSize {\n Icon = 128,\n Tiny = 256,\n Small = 512,\n Medium = 768,\n Large = 1024,\n ExtraLarge = 1600,\n}\n","export type IMaintenanceStatus = {\n uuid: string;\n\n /**\n * Which service is currently experiencing issues.\n */\n service: IMaintenanceStatusService;\n\n /**\n * The start time of the maintenance window in ISO 8601 format\n *\n * @example 2023-10-01T00:00:00Z\n */\n startDate: string;\n endDate: string;\n /**\n * Whether the status is currently in effect or not\n */\n isActive: boolean;\n\n status: 'error' | 'maintenance';\n\n title: string;\n message: string;\n};\n\nexport enum IMaintenanceStatusService {\n Frontend = 'frontend',\n Hotel = 'hotel',\n Events = 'events',\n}\n","import { IAddonPriceDetailsFee } from '../Addons/Addon.types';\nimport { ICommonQueryParameters } from '../Booking/ICommonQueryParameters.type';\nimport { IItemisedBookingFeeResponse } from '../Booking/Itinerary.types';\n\nexport class Package {\n /**\n * The SynXis CR RatePlan Code associated with the Package if the Package is restricted to certain RatePlans\n */\n public ratePlanCode?: string;\n\n public name: string;\n\n public description: string;\n\n /**\n * Whether the price for this package is included in the room rate.\n * (Always `false` unless the price is zero)\n */\n public inclusive: boolean;\n\n public image: string[];\n\n public url?: string;\n\n /**\n * Defines how a service is priced.\n * Values:\n * Per Stay\n * Per Night\n * Per Person\n * Per Person Per Night\n */\n public pricingType: string;\n\n /**\n * Number of available items for sale.\n */\n public quantity?: number;\n\n public category: string;\n\n public cancelPenalty?: string | null;\n\n public guaranteeDescription?: string | null;\n\n public availability: { [date: string]: IPriceInfo } = {};\n}\n\nexport class ReservedPackage extends Package {\n public code?: string | undefined;\n\n public price?: number;\n public fees?: number;\n public itemisedFees?: IItemisedBookingFeeResponse[];\n\n public adultQuantity?: number;\n public childQuantity?: number;\n public adultPrice?: number;\n public childPrice?: number;\n public startDate?: string;\n public startTime?: string;\n\n public hideDatePicker?: boolean = false;\n public hideQuantity?: boolean = false;\n public order?: number;\n\n public discount?: number;\n public total?: number;\n}\n\nexport type IPriceInfo = {\n /**\n * Number of available items for sale.\n */\n quantity: number;\n\n /**\n * Price per quantity\n */\n price?: number;\n\n adultPrice?: number;\n childPrice?: number;\n\n fees?: IAddonPriceDetailsFee[];\n adultFees?: IAddonPriceDetailsFee[];\n childFees?: IAddonPriceDetailsFee[];\n\n timeSlots?: ITimeSlot[];\n};\n\nexport type ITimeSlot = {\n /**\n The start date and time when the package is available.\n If the package applies during the whole stay, this node is not returned unless the time needs to be selected. In that case, the Start and End dates do not\n include the date: @Start=\"T07:30:00\" and @End=\"T17:30:00\" and @Increment=\"00:60:00\"\n Type: DateTime\n **/\n startTime?: string;\n\n /**\n The end date / time when the package is available.\n If the package component applies during the whole stay, this node is not returned unless the time needs to be selected. In that case, the Start and End dates\n do not include the date: @Start=\"T07:30:00\" and @End=\"T17:30:00\" and @Increment=\"00:60:00\"\n Type: DateTime\n */\n endTime?: string;\n\n /**\n Used with @Start and @End. Indicates the interval when the package or service is available.\n For example, a package with golf lessons from 7:30 am to 5:30 pm with instructions and available hourly has the TimeSpan attributes set as: @Start=\"2015-\n 010-28T07:30:00\" and @End=\"2015-10-28T17:30:00\" and @Increment=\"00:60:00\"\n Type: Time\n */\n increment?: string;\n};\n\nexport type IGetPackagesRequest = {\n adults?: number;\n children?: number;\n\n checkInDate: Date;\n checkOutDate: Date;\n\n rate: string;\n room?: string;\n} & ICommonQueryParameters;\n\nexport type IGetPackagesResponse = {\n [packageName: string]: ReservedPackage;\n};\n","export enum EGuaranteePolicyDepositMode {\n Full = 'Full',\n Percentage = 'Percentage',\n FirstNight = 'FirstNight',\n None = 'None',\n}\n","export enum EPromoCodeDiscountType {\n FlatPercent = 'flatPercent',\n FlatQuantity = 'flatQuantity',\n FlatQuantityPerStay = 'flatQuantityPerStay',\n}","export enum EPromoCodeStayDateRangeType {\n Allowed = 'Allowed',\n Blocked = 'Blocked',\n}\n\nexport enum EPromoCodeStayDateRangeRepeatType {\n None = 'None',\n Weekly = 'Weekly',\n MonthlyDayOfWeek = 'MonthlyDayOfWeek',\n MonthlyDate = 'MonthlyDate',\n Yearly = 'Yearly',\n}\n","export enum ERoomstayEventSource {\n Eventbrite = 'eventbrite',\n ATDW = 'atdw'\n}\n","export const DATE_FORMAT = 'DD/MM/YYYY';\n","export enum HttpMethod {\n GET = \"GET\",\n POST = \"POST\",\n PUT = \"PUT\",\n DELETE = \"DELETE\",\n PATCH = \"PATCH\",\n OPTIONS = \"OPTIONS\",\n HEAD = \"HEAD\"\n}","export enum EFeeType {\n PercentageOfBooking = 'PercentageOfBooking',\n FixedChargePerRoom = 'FixedChargePerRoom',\n NightlyChargePerRoom = 'NightlyChargePerRoom',\n FixedChargePerBooking = 'FixedChargePerBooking',\n DepositSurcharge = 'DepositSurcharge',\n}\n","import { IRoomstayEventData } from './IRoomstayEventData.type';\n\n/**\n * Roomstay event names\n */\nexport enum ERoomstayEventName {\n BasketAdd = 'Basket/Add',\n ViewCheckout = 'View/Checkout',\n BookingCommitted = 'Booking/Committed',\n}\n\n/**\n * Meta custom_data format\n */\nexport interface IMetaEventData {\n currency: string;\n value: number;\n content_ids?: string[];\n content_type?: string;\n contents?: Array<{ id: string; quantity: number; item_price: number }>;\n num_items?: number;\n}\n\n/**\n * Meta user data format\n */\nexport interface IMetaUserData {\n em?: string; // hashed email\n ph?: string; // hashed phone\n fn?: string; // hashed first name\n ln?: string; // hashed last name\n ct?: string; // hashed city\n st?: string; // hashed state\n zp?: string; // hashed zip\n country?: string; // hashed country\n external_id?: string; // not hashed\n}\n\n/**\n * Analytics event request payload\n */\nexport interface IAnalyticsEventRequest {\n eventId: string;\n sessionId: string;\n eventName: ERoomstayEventName;\n eventTime: number;\n hotelFrontendId: string;\n fbc?: string;\n fbp?: string;\n eventData: IRoomstayEventData;\n}\n\n/**\n * Analytics event stored in DynamoDB\n */\nexport interface IAnalyticsEvent {\n eventId: string;\n sessionId: string;\n hotelFrontendId: string;\n eventName: ERoomstayEventName;\n eventTime: number;\n eventData: IRoomstayEventData;\n createdAt: number;\n ttl: number;\n}\n","/**\n * Meta CAPI Transformer\n *\n * Transforms Roomstay event data to Meta CAPI format.\n * Used both client-side (for Meta Pixel) and server-side (for Meta CAPI).\n */\n\nimport { ERoomstayEventName, IMetaEventData, IMetaUserData } from './IAnalyticsEvent.type';\nimport { IRoomstayEventData, IRoomstayBasketItem, IRoomstayGuestData } from './IRoomstayEventData.type';\n\n/**\n * Maps Roomstay event names to Meta CAPI event names\n */\nexport function toMetaEventName(eventName: ERoomstayEventName): string {\n const mapping: Record<ERoomstayEventName, string> = {\n [ERoomstayEventName.BasketAdd]: 'AddToCart',\n [ERoomstayEventName.ViewCheckout]: 'InitiateCheckout',\n [ERoomstayEventName.BookingCommitted]: 'Purchase',\n };\n return mapping[eventName];\n}\n\n/**\n * Transforms basket items to Meta custom_data format\n */\nfunction transformItemsToMetaEventData(items: IRoomstayBasketItem[], currency: string): IMetaEventData {\n let totalValue = 0;\n const contentIds: string[] = [];\n const contents: IMetaEventData['contents'] = [];\n\n for (const item of items) {\n totalValue += item.totalPrice;\n\n if (item.roomCode) {\n contentIds.push(item.roomCode);\n contents.push({\n id: item.roomCode,\n quantity: 1,\n item_price: item.totalPrice,\n });\n }\n }\n\n return {\n currency,\n value: totalValue,\n content_ids: contentIds,\n content_type: 'hotel',\n contents,\n num_items: items.length,\n };\n}\n\n/**\n * Transform roomstay event to Meta pixel/CAPI event.\n * Note: ViewBookingEngine events should not be transformed - they are for session init only.\n */\nexport function transformToMetaEventData(eventData: IRoomstayEventData): IMetaEventData {\n // BasketAdd: has single 'item'\n if ('item' in eventData) {\n return transformItemsToMetaEventData([eventData.item], eventData.currency);\n }\n\n // ViewCheckout / BookingCommitted: has 'items' array\n if ('items' in eventData) {\n return transformItemsToMetaEventData(eventData.items, eventData.currency);\n }\n\n throw new Error('Invalid event data');\n}\n\n/**\n * Transform guest data to Meta user_data format.\n */\nexport function transformToMetaUserData(guest: IRoomstayGuestData): IMetaUserData {\n return {\n em: guest.email,\n ph: guest.phone,\n fn: guest.firstName,\n ln: guest.lastName,\n ct: guest.city,\n st: guest.state,\n zp: guest.postalCode,\n country: guest.country,\n external_id: guest.externalId,\n };\n}\n","import { SimpleItemisedFee } from '../Fees/IFee.type';\n\nexport enum EAddonPricingType {\n PER_STAY = 'Per stay',\n PER_NIGHT = 'Per night',\n PER_PERSON = 'Per person',\n PER_PERSON_PER_NIGHT = 'Per person per night',\n\n PER_ALL_PERSONS = 'Per all persons',\n PER_ALL_PERSONS_PER_NIGHT = 'Per all persons per night',\n\n // Synxis Basic addon types\n PER_QUANTITY_NAME_PER_NIGHT = 'Per Quantity Name Per Night',\n PER_ROOM_QUANTITY_PER_NIGHT = 'Per Room Quantity Per Night',\n PER_PERSON_OCCUPANCY_PER_NIGHT = 'Per Person Occupancy Per Night',\n PER_ADULT_OCCUPANCY_PER_NIGHT = 'Per Adult Occupancy Per Night',\n PER_CHILD_OCCUPANCY_PER_NIGHT = 'Per Child Occupancy Per Night',\n}\n\nexport type IAddonPriceDetails = {\n adultPrice: number;\n childPrice: number;\n price: number;\n\n // TODO: Deprecate/remove these old fee fields.\n adultFee: number;\n childFee: number;\n fee: number;\n\n adultFees?: IAddonPriceDetailsFee[];\n childFees?: IAddonPriceDetailsFee[];\n fees?: IAddonPriceDetailsFee[];\n\n discount?: number;\n\n pricingType: EAddonPricingType;\n};\n\nexport type IAddonPriceDetailsFee = {\n name: string;\n amount: number;\n};\n\nexport type BasketAddonDTO = {\n availability: any;\n code: string;\n inclusive: false;\n pricingType: string;\n quantity: number;\n adultQuantity: number;\n childQuantity?: number;\n description: string;\n name: string;\n category: string;\n image: string;\n\n price: number;\n adultPrice?: number;\n childPrice?: number;\n\n fee: number;\n adultFee?: number;\n childFee?: number;\n\n fees?: SimpleItemisedFee[];\n adultFees?: SimpleItemisedFee[];\n childFees?: SimpleItemisedFee[];\n\n // Promo code discount applied to this addon\n discount?: number;\n\n nights?: number;\n};\n","import { EAddonPricingType } from './Addon.types';\n\nexport const ADDON_PER_NIGHT_TYPES = [\n EAddonPricingType.PER_NIGHT,\n EAddonPricingType.PER_PERSON_PER_NIGHT,\n\n EAddonPricingType.PER_QUANTITY_NAME_PER_NIGHT,\n EAddonPricingType.PER_ROOM_QUANTITY_PER_NIGHT,\n EAddonPricingType.PER_PERSON_OCCUPANCY_PER_NIGHT,\n EAddonPricingType.PER_ADULT_OCCUPANCY_PER_NIGHT,\n EAddonPricingType.PER_CHILD_OCCUPANCY_PER_NIGHT,\n\n EAddonPricingType.PER_ALL_PERSONS_PER_NIGHT,\n];\n","/** A special constant with type `never` */\nexport const NEVER = Object.freeze({\n status: \"aborted\",\n});\nexport /*@__NO_SIDE_EFFECTS__*/ function $constructor(name, initializer, params) {\n function init(inst, def) {\n var _a;\n Object.defineProperty(inst, \"_zod\", {\n value: inst._zod ?? {},\n enumerable: false,\n });\n (_a = inst._zod).traits ?? (_a.traits = new Set());\n inst._zod.traits.add(name);\n initializer(inst, def);\n // support prototype modifications\n for (const k in _.prototype) {\n if (!(k in inst))\n Object.defineProperty(inst, k, { value: _.prototype[k].bind(inst) });\n }\n inst._zod.constr = _;\n inst._zod.def = def;\n }\n // doesn't work if Parent has a constructor with arguments\n const Parent = params?.Parent ?? Object;\n class Definition extends Parent {\n }\n Object.defineProperty(Definition, \"name\", { value: name });\n function _(def) {\n var _a;\n const inst = params?.Parent ? new Definition() : this;\n init(inst, def);\n (_a = inst._zod).deferred ?? (_a.deferred = []);\n for (const fn of inst._zod.deferred) {\n fn();\n }\n return inst;\n }\n Object.defineProperty(_, \"init\", { value: init });\n Object.defineProperty(_, Symbol.hasInstance, {\n value: (inst) => {\n if (params?.Parent && inst instanceof params.Parent)\n return true;\n return inst?._zod?.traits?.has(name);\n },\n });\n Object.defineProperty(_, \"name\", { value: name });\n return _;\n}\n////////////////////////////// UTILITIES ///////////////////////////////////////\nexport const $brand = Symbol(\"zod_brand\");\nexport class $ZodAsyncError extends Error {\n constructor() {\n super(`Encountered Promise during synchronous parse. Use .parseAsync() instead.`);\n }\n}\nexport class $ZodEncodeError extends Error {\n constructor(name) {\n super(`Encountered unidirectional transform during encode: ${name}`);\n this.name = \"ZodEncodeError\";\n }\n}\nexport const globalConfig = {};\nexport function config(newConfig) {\n if (newConfig)\n Object.assign(globalConfig, newConfig);\n return globalConfig;\n}\n","// functions\nexport function assertEqual(val) {\n return val;\n}\nexport function assertNotEqual(val) {\n return val;\n}\nexport function assertIs(_arg) { }\nexport function assertNever(_x) {\n throw new Error();\n}\nexport function assert(_) { }\nexport function getEnumValues(entries) {\n const numericValues = Object.values(entries).filter((v) => typeof v === \"number\");\n const values = Object.entries(entries)\n .filter(([k, _]) => numericValues.indexOf(+k) === -1)\n .map(([_, v]) => v);\n return values;\n}\nexport function joinValues(array, separator = \"|\") {\n return array.map((val) => stringifyPrimitive(val)).join(separator);\n}\nexport function jsonStringifyReplacer(_, value) {\n if (typeof value === \"bigint\")\n return value.toString();\n return value;\n}\nexport function cached(getter) {\n const set = false;\n return {\n get value() {\n if (!set) {\n const value = getter();\n Object.defineProperty(this, \"value\", { value });\n return value;\n }\n throw new Error(\"cached value already set\");\n },\n };\n}\nexport function nullish(input) {\n return input === null || input === undefined;\n}\nexport function cleanRegex(source) {\n const start = source.startsWith(\"^\") ? 1 : 0;\n const end = source.endsWith(\"$\") ? source.length - 1 : source.length;\n return source.slice(start, end);\n}\nexport function floatSafeRemainder(val, step) {\n const valDecCount = (val.toString().split(\".\")[1] || \"\").length;\n const stepString = step.toString();\n let stepDecCount = (stepString.split(\".\")[1] || \"\").length;\n if (stepDecCount === 0 && /\\d?e-\\d?/.test(stepString)) {\n const match = stepString.match(/\\d?e-(\\d?)/);\n if (match?.[1]) {\n stepDecCount = Number.parseInt(match[1]);\n }\n }\n const decCount = valDecCount > stepDecCount ? valDecCount : stepDecCount;\n const valInt = Number.parseInt(val.toFixed(decCount).replace(\".\", \"\"));\n const stepInt = Number.parseInt(step.toFixed(decCount).replace(\".\", \"\"));\n return (valInt % stepInt) / 10 ** decCount;\n}\nconst EVALUATING = Symbol(\"evaluating\");\nexport function defineLazy(object, key, getter) {\n let value = undefined;\n Object.defineProperty(object, key, {\n get() {\n if (value === EVALUATING) {\n // Circular reference detected, return undefined to break the cycle\n return undefined;\n }\n if (value === undefined) {\n value = EVALUATING;\n value = getter();\n }\n return value;\n },\n set(v) {\n Object.defineProperty(object, key, {\n value: v,\n // configurable: true,\n });\n // object[key] = v;\n },\n configurable: true,\n });\n}\nexport function objectClone(obj) {\n return Object.create(Object.getPrototypeOf(obj), Object.getOwnPropertyDescriptors(obj));\n}\nexport function assignProp(target, prop, value) {\n Object.defineProperty(target, prop, {\n value,\n writable: true,\n enumerable: true,\n configurable: true,\n });\n}\nexport function mergeDefs(...defs) {\n const mergedDescriptors = {};\n for (const def of defs) {\n const descriptors = Object.getOwnPropertyDescriptors(def);\n Object.assign(mergedDescriptors, descriptors);\n }\n return Object.defineProperties({}, mergedDescriptors);\n}\nexport function cloneDef(schema) {\n return mergeDefs(schema._zod.def);\n}\nexport function getElementAtPath(obj, path) {\n if (!path)\n return obj;\n return path.reduce((acc, key) => acc?.[key], obj);\n}\nexport function promiseAllObject(promisesObj) {\n const keys = Object.keys(promisesObj);\n const promises = keys.map((key) => promisesObj[key]);\n return Promise.all(promises).then((results) => {\n const resolvedObj = {};\n for (let i = 0; i < keys.length; i++) {\n resolvedObj[keys[i]] = results[i];\n }\n return resolvedObj;\n });\n}\nexport function randomString(length = 10) {\n const chars = \"abcdefghijklmnopqrstuvwxyz\";\n let str = \"\";\n for (let i = 0; i < length; i++) {\n str += chars[Math.floor(Math.random() * chars.length)];\n }\n return str;\n}\nexport function esc(str) {\n return JSON.stringify(str);\n}\nexport const captureStackTrace = (\"captureStackTrace\" in Error ? Error.captureStackTrace : (..._args) => { });\nexport function isObject(data) {\n return typeof data === \"object\" && data !== null && !Array.isArray(data);\n}\nexport const allowsEval = cached(() => {\n // @ts-ignore\n if (typeof navigator !== \"undefined\" && navigator?.userAgent?.includes(\"Cloudflare\")) {\n return false;\n }\n try {\n const F = Function;\n new F(\"\");\n return true;\n }\n catch (_) {\n return false;\n }\n});\nexport function isPlainObject(o) {\n if (isObject(o) === false)\n return false;\n // modified constructor\n const ctor = o.constructor;\n if (ctor === undefined)\n return true;\n // modified prototype\n const prot = ctor.prototype;\n if (isObject(prot) === false)\n return false;\n // ctor doesn't have static `isPrototypeOf`\n if (Object.prototype.hasOwnProperty.call(prot, \"isPrototypeOf\") === false) {\n return false;\n }\n return true;\n}\nexport function shallowClone(o) {\n if (isPlainObject(o))\n return { ...o };\n return o;\n}\nexport function numKeys(data) {\n let keyCount = 0;\n for (const key in data) {\n if (Object.prototype.hasOwnProperty.call(data, key)) {\n keyCount++;\n }\n }\n return keyCount;\n}\nexport const getParsedType = (data) => {\n const t = typeof data;\n switch (t) {\n case \"undefined\":\n return \"undefined\";\n case \"string\":\n return \"string\";\n case \"number\":\n return Number.isNaN(data) ? \"nan\" : \"number\";\n case \"boolean\":\n return \"boolean\";\n case \"function\":\n return \"function\";\n case \"bigint\":\n return \"bigint\";\n case \"symbol\":\n return \"symbol\";\n case \"object\":\n if (Array.isArray(data)) {\n return \"array\";\n }\n if (data === null) {\n return \"null\";\n }\n if (data.then && typeof data.then === \"function\" && data.catch && typeof data.catch === \"function\") {\n return \"promise\";\n }\n if (typeof Map !== \"undefined\" && data instanceof Map) {\n return \"map\";\n }\n if (typeof Set !== \"undefined\" && data instanceof Set) {\n return \"set\";\n }\n if (typeof Date !== \"undefined\" && data instanceof Date) {\n return \"date\";\n }\n // @ts-ignore\n if (typeof File !== \"undefined\" && data instanceof File) {\n return \"file\";\n }\n return \"object\";\n default:\n throw new Error(`Unknown data type: ${t}`);\n }\n};\nexport const propertyKeyTypes = new Set([\"string\", \"number\", \"symbol\"]);\nexport const primitiveTypes = new Set([\"string\", \"number\", \"bigint\", \"boolean\", \"symbol\", \"undefined\"]);\nexport function escapeRegex(str) {\n return str.replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\");\n}\n// zod-specific utils\nexport function clone(inst, def, params) {\n const cl = new inst._zod.constr(def ?? inst._zod.def);\n if (!def || params?.parent)\n cl._zod.parent = inst;\n return cl;\n}\nexport function normalizeParams(_params) {\n const params = _params;\n if (!params)\n return {};\n if (typeof params === \"string\")\n return { error: () => params };\n if (params?.message !== undefined) {\n if (params?.error !== undefined)\n throw new Error(\"Cannot specify both `message` and `error` params\");\n params.error = params.message;\n }\n delete params.message;\n if (typeof params.error === \"string\")\n return { ...params, error: () => params.error };\n return params;\n}\nexport function createTransparentProxy(getter) {\n let target;\n return new Proxy({}, {\n get(_, prop, receiver) {\n target ?? (target = getter());\n return Reflect.get(target, prop, receiver);\n },\n set(_, prop, value, receiver) {\n target ?? (target = getter());\n return Reflect.set(target, prop, value, receiver);\n },\n has(_, prop) {\n target ?? (target = getter());\n return Reflect.has(target, prop);\n },\n deleteProperty(_, prop) {\n target ?? (target = getter());\n return Reflect.deleteProperty(target, prop);\n },\n ownKeys(_) {\n target ?? (target = getter());\n return Reflect.ownKeys(target);\n },\n getOwnPropertyDescriptor(_, prop) {\n target ?? (target = getter());\n return Reflect.getOwnPropertyDescriptor(target, prop);\n },\n defineProperty(_, prop, descriptor) {\n target ?? (target = getter());\n return Reflect.defineProperty(target, prop, descriptor);\n },\n });\n}\nexport function stringifyPrimitive(value) {\n if (typeof value === \"bigint\")\n return value.toString() + \"n\";\n if (typeof value === \"string\")\n return `\"${value}\"`;\n return `${value}`;\n}\nexport function optionalKeys(shape) {\n return Object.keys(shape).filter((k) => {\n return shape[k]._zod.optin === \"optional\" && shape[k]._zod.optout === \"optional\";\n });\n}\nexport const NUMBER_FORMAT_RANGES = {\n safeint: [Number.MIN_SAFE_INTEGER, Number.MAX_SAFE_INTEGER],\n int32: [-2147483648, 2147483647],\n uint32: [0, 4294967295],\n float32: [-3.4028234663852886e38, 3.4028234663852886e38],\n float64: [-Number.MAX_VALUE, Number.MAX_VALUE],\n};\nexport const BIGINT_FORMAT_RANGES = {\n int64: [/* @__PURE__*/ BigInt(\"-9223372036854775808\"), /* @__PURE__*/ BigInt(\"9223372036854775807\")],\n uint64: [/* @__PURE__*/ BigInt(0), /* @__PURE__*/ BigInt(\"18446744073709551615\")],\n};\nexport function pick(schema, mask) {\n const currDef = schema._zod.def;\n const def = mergeDefs(schema._zod.def, {\n get shape() {\n const newShape = {};\n for (const key in mask) {\n if (!(key in currDef.shape)) {\n throw new Error(`Unrecognized key: \"${key}\"`);\n }\n if (!mask[key])\n continue;\n newShape[key] = currDef.shape[key];\n }\n assignProp(this, \"shape\", newShape); // self-caching\n return newShape;\n },\n checks: [],\n });\n return clone(schema, def);\n}\nexport function omit(schema, mask) {\n const currDef = schema._zod.def;\n const def = mergeDefs(schema._zod.def, {\n get shape() {\n const newShape = { ...schema._zod.def.shape };\n for (const key in mask) {\n if (!(key in currDef.shape)) {\n throw new Error(`Unrecognized key: \"${key}\"`);\n }\n if (!mask[key])\n continue;\n delete newShape[key];\n }\n assignProp(this, \"shape\", newShape); // self-caching\n return newShape;\n },\n checks: [],\n });\n return clone(schema, def);\n}\nexport function extend(schema, shape) {\n if (!isPlainObject(shape)) {\n throw new Error(\"Invalid input to extend: expected a plain object\");\n }\n const checks = schema._zod.def.checks;\n const hasChecks = checks && checks.length > 0;\n if (hasChecks) {\n throw new Error(\"Object schemas containing refinements cannot be extended. Use `.safeExtend()` instead.\");\n }\n const def = mergeDefs(schema._zod.def, {\n get shape() {\n const _shape = { ...schema._zod.def.shape, ...shape };\n assignProp(this, \"shape\", _shape); // self-caching\n return _shape;\n },\n checks: [],\n });\n return clone(schema, def);\n}\nexport function safeExtend(schema, shape) {\n if (!isPlainObject(shape)) {\n throw new Error(\"Invalid input to safeExtend: expected a plain object\");\n }\n const def = {\n ...schema._zod.def,\n get shape() {\n const _shape = { ...schema._zod.def.shape, ...shape };\n assignProp(this, \"shape\", _shape); // self-caching\n return _shape;\n },\n checks: schema._zod.def.checks,\n };\n return clone(schema, def);\n}\nexport function merge(a, b) {\n const def = mergeDefs(a._zod.def, {\n get shape() {\n const _shape = { ...a._zod.def.shape, ...b._zod.def.shape };\n assignProp(this, \"shape\", _shape); // self-caching\n return _shape;\n },\n get catchall() {\n return b._zod.def.catchall;\n },\n checks: [], // delete existing checks\n });\n return clone(a, def);\n}\nexport function partial(Class, schema, mask) {\n const def = mergeDefs(schema._zod.def, {\n get shape() {\n const oldShape = schema._zod.def.shape;\n const shape = { ...oldShape };\n if (mask) {\n for (const key in mask) {\n if (!(key in oldShape)) {\n throw new Error(`Unrecognized key: \"${key}\"`);\n }\n if (!mask[key])\n continue;\n // if (oldShape[key]!._zod.optin === \"optional\") continue;\n shape[key] = Class\n ? new Class({\n type: \"optional\",\n innerType: oldShape[key],\n })\n : oldShape[key];\n }\n }\n else {\n for (const key in oldShape) {\n // if (oldShape[key]!._zod.optin === \"optional\") continue;\n shape[key] = Class\n ? new Class({\n type: \"optional\",\n innerType: oldShape[key],\n })\n : oldShape[key];\n }\n }\n assignProp(this, \"shape\", shape); // self-caching\n return shape;\n },\n checks: [],\n });\n return clone(schema, def);\n}\nexport function required(Class, schema, mask) {\n const def = mergeDefs(schema._zod.def, {\n get shape() {\n const oldShape = schema._zod.def.shape;\n const shape = { ...oldShape };\n if (mask) {\n for (const key in mask) {\n if (!(key in shape)) {\n throw new Error(`Unrecognized key: \"${key}\"`);\n }\n if (!mask[key])\n continue;\n // overwrite with non-optional\n shape[key] = new Class({\n type: \"nonoptional\",\n innerType: oldShape[key],\n });\n }\n }\n else {\n for (const key in oldShape) {\n // overwrite with non-optional\n shape[key] = new Class({\n type: \"nonoptional\",\n innerType: oldShape[key],\n });\n }\n }\n assignProp(this, \"shape\", shape); // self-caching\n return shape;\n },\n checks: [],\n });\n return clone(schema, def);\n}\n// invalid_type | too_big | too_small | invalid_format | not_multiple_of | unrecognized_keys | invalid_union | invalid_key | invalid_element | invalid_value | custom\nexport function aborted(x, startIndex = 0) {\n if (x.aborted === true)\n return true;\n for (let i = startIndex; i < x.issues.length; i++) {\n if (x.issues[i]?.continue !== true) {\n return true;\n }\n }\n return false;\n}\nexport function prefixIssues(path, issues) {\n return issues.map((iss) => {\n var _a;\n (_a = iss).path ?? (_a.path = []);\n iss.path.unshift(path);\n return iss;\n });\n}\nexport function unwrapMessage(message) {\n return typeof message === \"string\" ? message : message?.message;\n}\nexport function finalizeIssue(iss, ctx, config) {\n const full = { ...iss, path: iss.path ?? [] };\n // for backwards compatibility\n if (!iss.message) {\n const message = unwrapMessage(iss.inst?._zod.def?.error?.(iss)) ??\n unwrapMessage(ctx?.error?.(iss)) ??\n unwrapMessage(config.customError?.(iss)) ??\n unwrapMessage(config.localeError?.(iss)) ??\n \"Invalid input\";\n full.message = message;\n }\n // delete (full as any).def;\n delete full.inst;\n delete full.continue;\n if (!ctx?.reportInput) {\n delete full.input;\n }\n return full;\n}\nexport function getSizableOrigin(input) {\n if (input instanceof Set)\n return \"set\";\n if (input instanceof Map)\n return \"map\";\n // @ts-ignore\n if (input instanceof File)\n return \"file\";\n return \"unknown\";\n}\nexport function getLengthableOrigin(input) {\n if (Array.isArray(input))\n return \"array\";\n if (typeof input === \"string\")\n return \"string\";\n return \"unknown\";\n}\nexport function issue(...args) {\n const [iss, input, inst] = args;\n if (typeof iss === \"string\") {\n return {\n message: iss,\n code: \"custom\",\n input,\n inst,\n };\n }\n return { ...iss };\n}\nexport function cleanEnum(obj) {\n return Object.entries(obj)\n .filter(([k, _]) => {\n // return true if NaN, meaning it's not a number, thus a string key\n return Number.isNaN(Number.parseInt(k, 10));\n })\n .map((el) => el[1]);\n}\n// Codec utility functions\nexport function base64ToUint8Array(base64) {\n const binaryString = atob(base64);\n const bytes = new Uint8Array(binaryString.length);\n for (let i = 0; i < binaryString.length; i++) {\n bytes[i] = binaryString.charCodeAt(i);\n }\n return bytes;\n}\nexport function uint8ArrayToBase64(bytes) {\n let binaryString = \"\";\n for (let i = 0; i < bytes.length; i++) {\n binaryString += String.fromCharCode(bytes[i]);\n }\n return btoa(binaryString);\n}\nexport function base64urlToUint8Array(base64url) {\n const base64 = base64url.replace(/-/g, \"+\").replace(/_/g, \"/\");\n const padding = \"=\".repeat((4 - (base64.length % 4)) % 4);\n return base64ToUint8Array(base64 + padding);\n}\nexport function uint8ArrayToBase64url(bytes) {\n return uint8ArrayToBase64(bytes).replace(/\\+/g, \"-\").replace(/\\//g, \"_\").replace(/=/g, \"\");\n}\nexport function hexToUint8Array(hex) {\n const cleanHex = hex.replace(/^0x/, \"\");\n if (cleanHex.length % 2 !== 0) {\n throw new Error(\"Invalid hex string length\");\n }\n const bytes = new Uint8Array(cleanHex.length / 2);\n for (let i = 0; i < cleanHex.length; i += 2) {\n bytes[i / 2] = Number.parseInt(cleanHex.slice(i, i + 2), 16);\n }\n return bytes;\n}\nexport function uint8ArrayToHex(bytes) {\n return Array.from(bytes)\n .map((b) => b.toString(16).padStart(2, \"0\"))\n .join(\"\");\n}\n// instanceof\nexport class Class {\n constructor(..._args) { }\n}\n","import { $constructor } from \"./core.js\";\nimport * as util from \"./util.js\";\nconst initializer = (inst, def) => {\n inst.name = \"$ZodError\";\n Object.defineProperty(inst, \"_zod\", {\n value: inst._zod,\n enumerable: false,\n });\n Object.defineProperty(inst, \"issues\", {\n value: def,\n enumerable: false,\n });\n inst.message = JSON.stringify(def, util.jsonStringifyReplacer, 2);\n Object.defineProperty(inst, \"toString\", {\n value: () => inst.message,\n enumerable: false,\n });\n};\nexport const $ZodError = $constructor(\"$ZodError\", initializer);\nexport const $ZodRealError = $constructor(\"$ZodError\", initializer, { Parent: Error });\nexport function flattenError(error, mapper = (issue) => issue.message) {\n const fieldErrors = {};\n const formErrors = [];\n for (const sub of error.issues) {\n if (sub.path.length > 0) {\n fieldErrors[sub.path[0]] = fieldErrors[sub.path[0]] || [];\n fieldErrors[sub.path[0]].push(mapper(sub));\n }\n else {\n formErrors.push(mapper(sub));\n }\n }\n return { formErrors, fieldErrors };\n}\nexport function formatError(error, _mapper) {\n const mapper = _mapper ||\n function (issue) {\n return issue.message;\n };\n const fieldErrors = { _errors: [] };\n const processError = (error) => {\n for (const issue of error.issues) {\n if (issue.code === \"invalid_union\" && issue.errors.length) {\n issue.errors.map((issues) => processError({ issues }));\n }\n else if (issue.code === \"invalid_key\") {\n processError({ issues: issue.issues });\n }\n else if (issue.code === \"invalid_element\") {\n processError({ issues: issue.issues });\n }\n else if (issue.path.length === 0) {\n fieldErrors._errors.push(mapper(issue));\n }\n else {\n let curr = fieldErrors;\n let i = 0;\n while (i < issue.path.length) {\n const el = issue.path[i];\n const terminal = i === issue.path.length - 1;\n if (!terminal) {\n curr[el] = curr[el] || { _errors: [] };\n }\n else {\n curr[el] = curr[el] || { _errors: [] };\n curr[el]._errors.push(mapper(issue));\n }\n curr = curr[el];\n i++;\n }\n }\n }\n };\n processError(error);\n return fieldErrors;\n}\nexport function treeifyError(error, _mapper) {\n const mapper = _mapper ||\n function (issue) {\n return issue.message;\n };\n const result = { errors: [] };\n const processError = (error, path = []) => {\n var _a, _b;\n for (const issue of error.issues) {\n if (issue.code === \"invalid_union\" && issue.errors.length) {\n // regular union error\n issue.errors.map((issues) => processError({ issues }, issue.path));\n }\n else if (issue.code === \"invalid_key\") {\n processError({ issues: issue.issues }, issue.path);\n }\n else if (issue.code === \"invalid_element\") {\n processError({ issues: issue.issues }, issue.path);\n }\n else {\n const fullpath = [...path, ...issue.path];\n if (fullpath.length === 0) {\n result.errors.push(mapper(issue));\n continue;\n }\n let curr = result;\n let i = 0;\n while (i < fullpath.length) {\n const el = fullpath[i];\n const terminal = i === fullpath.length - 1;\n if (typeof el === \"string\") {\n curr.properties ?? (curr.properties = {});\n (_a = curr.properties)[el] ?? (_a[el] = { errors: [] });\n curr = curr.properties[el];\n }\n else {\n curr.items ?? (curr.items = []);\n (_b = curr.items)[el] ?? (_b[el] = { errors: [] });\n curr = curr.items[el];\n }\n if (terminal) {\n curr.errors.push(mapper(issue));\n }\n i++;\n }\n }\n }\n };\n processError(error);\n return result;\n}\n/** Format a ZodError as a human-readable string in the following form.\n *\n * From\n *\n * ```ts\n * ZodError {\n * issues: [\n * {\n * expected: 'string',\n * code: 'invalid_type',\n * path: [ 'username' ],\n * message: 'Invalid input: expected string'\n * },\n * {\n * expected: 'number',\n * code: 'invalid_type',\n * path: [ 'favoriteNumbers', 1 ],\n * message: 'Invalid input: expected number'\n * }\n * ];\n * }\n * ```\n *\n * to\n *\n * ```\n * username\n * ✖ Expected number, received string at \"username\n * favoriteNumbers[0]\n * ✖ Invalid input: expected number\n * ```\n */\nexport function toDotPath(_path) {\n const segs = [];\n const path = _path.map((seg) => (typeof seg === \"object\" ? seg.key : seg));\n for (const seg of path) {\n if (typeof seg === \"number\")\n segs.push(`[${seg}]`);\n else if (typeof seg === \"symbol\")\n segs.push(`[${JSON.stringify(String(seg))}]`);\n else if (/[^\\w$]/.test(seg))\n segs.push(`[${JSON.stringify(seg)}]`);\n else {\n if (segs.length)\n segs.push(\".\");\n segs.push(seg);\n }\n }\n return segs.join(\"\");\n}\nexport function prettifyError(error) {\n const lines = [];\n // sort by path length\n const issues = [...error.issues].sort((a, b) => (a.path ?? []).length - (b.path ?? []).length);\n // Process each issue\n for (const issue of issues) {\n lines.push(`✖ ${issue.message}`);\n if (issue.path?.length)\n lines.push(` → at ${toDotPath(issue.path)}`);\n }\n // Convert Map to formatted string\n return lines.join(\"\\n\");\n}\n","import * as core from \"./core.js\";\nimport * as errors from \"./errors.js\";\nimport * as util from \"./util.js\";\nexport const _parse = (_Err) => (schema, value, _ctx, _params) => {\n const ctx = _ctx ? Object.assign(_ctx, { async: false }) : { async: false };\n const result = schema._zod.run({ value, issues: [] }, ctx);\n if (result instanceof Promise) {\n throw new core.$ZodAsyncError();\n }\n if (result.issues.length) {\n const e = new (_params?.Err ?? _Err)(result.issues.map((iss) => util.finalizeIssue(iss, ctx, core.config())));\n util.captureStackTrace(e, _params?.callee);\n throw e;\n }\n return result.value;\n};\nexport const parse = /* @__PURE__*/ _parse(errors.$ZodRealError);\nexport const _parseAsync = (_Err) => async (schema, value, _ctx, params) => {\n const ctx = _ctx ? Object.assign(_ctx, { async: true }) : { async: true };\n let result = schema._zod.run({ value, issues: [] }, ctx);\n if (result instanceof Promise)\n result = await result;\n if (result.issues.length) {\n const e = new (params?.Err ?? _Err)(result.issues.map((iss) => util.finalizeIssue(iss, ctx, core.config())));\n util.captureStackTrace(e, params?.callee);\n throw e;\n }\n return result.value;\n};\nexport const parseAsync = /* @__PURE__*/ _parseAsync(errors.$ZodRealError);\nexport const _safeParse = (_Err) => (schema, value, _ctx) => {\n const ctx = _ctx ? { ..._ctx, async: false } : { async: false };\n const result = schema._zod.run({ value, issues: [] }, ctx);\n if (result instanceof Promise) {\n throw new core.$ZodAsyncError();\n }\n return result.issues.length\n ? {\n success: false,\n error: new (_Err ?? errors.$ZodError)(result.issues.map((iss) => util.finalizeIssue(iss, ctx, core.config()))),\n }\n : { success: true, data: result.value };\n};\nexport const safeParse = /* @__PURE__*/ _safeParse(errors.$ZodRealError);\nexport const _safeParseAsync = (_Err) => async (schema, value, _ctx) => {\n const ctx = _ctx ? Object.assign(_ctx, { async: true }) : { async: true };\n let result = schema._zod.run({ value, issues: [] }, ctx);\n if (result instanceof Promise)\n result = await result;\n return result.issues.length\n ? {\n success: false,\n error: new _Err(result.issues.map((iss) => util.finalizeIssue(iss, ctx, core.config()))),\n }\n : { success: true, data: result.value };\n};\nexport const safeParseAsync = /* @__PURE__*/ _safeParseAsync(errors.$ZodRealError);\nexport const _encode = (_Err) => (schema, value, _ctx) => {\n const ctx = _ctx ? Object.assign(_ctx, { direction: \"backward\" }) : { direction: \"backward\" };\n return _parse(_Err)(schema, value, ctx);\n};\nexport const encode = /* @__PURE__*/ _encode(errors.$ZodRealError);\nexport const _decode = (_Err) => (schema, value, _ctx) => {\n return _parse(_Err)(schema, value, _ctx);\n};\nexport const decode = /* @__PURE__*/ _decode(errors.$ZodRealError);\nexport const _encodeAsync = (_Err) => async (schema, value, _ctx) => {\n const ctx = _ctx ? Object.assign(_ctx, { direction: \"backward\" }) : { direction: \"backward\" };\n return _parseAsync(_Err)(schema, value, ctx);\n};\nexport const encodeAsync = /* @__PURE__*/ _encodeAsync(errors.$ZodRealError);\nexport const _decodeAsync = (_Err) => async (schema, value, _ctx) => {\n return _parseAsync(_Err)(schema, value, _ctx);\n};\nexport const decodeAsync = /* @__PURE__*/ _decodeAsync(errors.$ZodRealError);\nexport const _safeEncode = (_Err) => (schema, value, _ctx) => {\n const ctx = _ctx ? Object.assign(_ctx, { direction: \"backward\" }) : { direction: \"backward\" };\n return _safeParse(_Err)(schema, value, ctx);\n};\nexport const safeEncode = /* @__PURE__*/ _safeEncode(errors.$ZodRealError);\nexport const _safeDecode = (_Err) => (schema, value, _ctx) => {\n return _safeParse(_Err)(schema, value, _ctx);\n};\nexport const safeDecode = /* @__PURE__*/ _safeDecode(errors.$ZodRealError);\nexport const _safeEncodeAsync = (_Err) => async (schema, value, _ctx) => {\n const ctx = _ctx ? Object.assign(_ctx, { direction: \"backward\" }) : { direction: \"backward\" };\n return _safeParseAsync(_Err)(schema, value, ctx);\n};\nexport const safeEncodeAsync = /* @__PURE__*/ _safeEncodeAsync(errors.$ZodRealError);\nexport const _safeDecodeAsync = (_Err) => async (schema, value, _ctx) => {\n return _safeParseAsync(_Err)(schema, value, _ctx);\n};\nexport const safeDecodeAsync = /* @__PURE__*/ _safeDecodeAsync(errors.$ZodRealError);\n","export const cuid = /^[cC][^\\s-]{8,}$/;\nexport const cuid2 = /^[0-9a-z]+$/;\nexport const ulid = /^[0-9A-HJKMNP-TV-Za-hjkmnp-tv-z]{26}$/;\nexport const xid = /^[0-9a-vA-V]{20}$/;\nexport const ksuid = /^[A-Za-z0-9]{27}$/;\nexport const nanoid = /^[a-zA-Z0-9_-]{21}$/;\n/** ISO 8601-1 duration regex. Does not support the 8601-2 extensions like negative durations or fractional/negative components. */\nexport const duration = /^P(?:(\\d+W)|(?!.*W)(?=\\d|T\\d)(\\d+Y)?(\\d+M)?(\\d+D)?(T(?=\\d)(\\d+H)?(\\d+M)?(\\d+([.,]\\d+)?S)?)?)$/;\n/** Implements ISO 8601-2 extensions like explicit +- prefixes, mixing weeks with other units, and fractional/negative components. */\nexport const extendedDuration = /^[-+]?P(?!$)(?:(?:[-+]?\\d+Y)|(?:[-+]?\\d+[.,]\\d+Y$))?(?:(?:[-+]?\\d+M)|(?:[-+]?\\d+[.,]\\d+M$))?(?:(?:[-+]?\\d+W)|(?:[-+]?\\d+[.,]\\d+W$))?(?:(?:[-+]?\\d+D)|(?:[-+]?\\d+[.,]\\d+D$))?(?:T(?=[\\d+-])(?:(?:[-+]?\\d+H)|(?:[-+]?\\d+[.,]\\d+H$))?(?:(?:[-+]?\\d+M)|(?:[-+]?\\d+[.,]\\d+M$))?(?:[-+]?\\d+(?:[.,]\\d+)?S)?)??$/;\n/** A regex for any UUID-like identifier: 8-4-4-4-12 hex pattern */\nexport const guid = /^([0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12})$/;\n/** Returns a regex for validating an RFC 9562/4122 UUID.\n *\n * @param version Optionally specify a version 1-8. If no version is specified, all versions are supported. */\nexport const uuid = (version) => {\n if (!version)\n return /^([0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[1-8][0-9a-fA-F]{3}-[89abAB][0-9a-fA-F]{3}-[0-9a-fA-F]{12}|00000000-0000-0000-0000-000000000000|ffffffff-ffff-ffff-ffff-ffffffffffff)$/;\n return new RegExp(`^([0-9a-fA-F]{8}-[0-9a-fA-F]{4}-${version}[0-9a-fA-F]{3}-[89abAB][0-9a-fA-F]{3}-[0-9a-fA-F]{12})$`);\n};\nexport const uuid4 = /*@__PURE__*/ uuid(4);\nexport const uuid6 = /*@__PURE__*/ uuid(6);\nexport const uuid7 = /*@__PURE__*/ uuid(7);\n/** Practical email validation */\nexport const email = /^(?!\\.)(?!.*\\.\\.)([A-Za-z0-9_'+\\-\\.]*)[A-Za-z0-9_+-]@([A-Za-z0-9][A-Za-z0-9\\-]*\\.)+[A-Za-z]{2,}$/;\n/** Equivalent to the HTML5 input[type=email] validation implemented by browsers. Source: https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/email */\nexport const html5Email = /^[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/;\n/** The classic emailregex.com regex for RFC 5322-compliant emails */\nexport const rfc5322Email = /^(([^<>()\\[\\]\\\\.,;:\\s@\"]+(\\.[^<>()\\[\\]\\\\.,;:\\s@\"]+)*)|(\".+\"))@((\\[[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}])|(([a-zA-Z\\-0-9]+\\.)+[a-zA-Z]{2,}))$/;\n/** A loose regex that allows Unicode characters, enforces length limits, and that's about it. */\nexport const unicodeEmail = /^[^\\s@\"]{1,64}@[^\\s@]{1,255}$/u;\nexport const idnEmail = /^[^\\s@\"]{1,64}@[^\\s@]{1,255}$/u;\nexport const browserEmail = /^[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/;\n// from https://thekevinscott.com/emojis-in-javascript/#writing-a-regular-expression\nconst _emoji = `^(\\\\p{Extended_Pictographic}|\\\\p{Emoji_Component})+$`;\nexport function emoji() {\n return new RegExp(_emoji, \"u\");\n}\nexport const ipv4 = /^(?:(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\\.){3}(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])$/;\nexport const ipv6 = /^(([0-9a-fA-F]{1,4}:){7}[0-9a-fA-F]{1,4}|::|([0-9a-fA-F]{1,4})?::([0-9a-fA-F]{1,4}:?){0,6})$/;\nexport const cidrv4 = /^((25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\\.){3}(25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\\/([0-9]|[1-2][0-9]|3[0-2])$/;\nexport const cidrv6 = /^(([0-9a-fA-F]{1,4}:){7}[0-9a-fA-F]{1,4}|::|([0-9a-fA-F]{1,4})?::([0-9a-fA-F]{1,4}:?){0,6})\\/(12[0-8]|1[01][0-9]|[1-9]?[0-9])$/;\n// https://stackoverflow.com/questions/7860392/determine-if-string-is-in-base64-using-javascript\nexport const base64 = /^$|^(?:[0-9a-zA-Z+/]{4})*(?:(?:[0-9a-zA-Z+/]{2}==)|(?:[0-9a-zA-Z+/]{3}=))?$/;\nexport const base64url = /^[A-Za-z0-9_-]*$/;\n// based on https://stackoverflow.com/questions/106179/regular-expression-to-match-dns-hostname-or-ip-address\n// export const hostname: RegExp = /^([a-zA-Z0-9-]+\\.)*[a-zA-Z0-9-]+$/;\nexport const hostname = /^(?=.{1,253}\\.?$)[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\\.[a-zA-Z0-9](?:[-0-9a-zA-Z]{0,61}[0-9a-zA-Z])?)*\\.?$/;\nexport const domain = /^([a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?\\.)+[a-zA-Z]{2,}$/;\n// https://blog.stevenlevithan.com/archives/validate-phone-number#r4-3 (regex sans spaces)\nexport const e164 = /^\\+(?:[0-9]){6,14}[0-9]$/;\n// const dateSource = `((\\\\d\\\\d[2468][048]|\\\\d\\\\d[13579][26]|\\\\d\\\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\\\d{4}-((0[13578]|1[02])-(0[1-9]|[12]\\\\d|3[01])|(0[469]|11)-(0[1-9]|[12]\\\\d|30)|(02)-(0[1-9]|1\\\\d|2[0-8])))`;\nconst dateSource = `(?:(?:\\\\d\\\\d[2468][048]|\\\\d\\\\d[13579][26]|\\\\d\\\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\\\d|30)|(?:02)-(?:0[1-9]|1\\\\d|2[0-8])))`;\nexport const date = /*@__PURE__*/ new RegExp(`^${dateSource}$`);\nfunction timeSource(args) {\n const hhmm = `(?:[01]\\\\d|2[0-3]):[0-5]\\\\d`;\n const regex = typeof args.precision === \"number\"\n ? args.precision === -1\n ? `${hhmm}`\n : args.precision === 0\n ? `${hhmm}:[0-5]\\\\d`\n : `${hhmm}:[0-5]\\\\d\\\\.\\\\d{${args.precision}}`\n : `${hhmm}(?::[0-5]\\\\d(?:\\\\.\\\\d+)?)?`;\n return regex;\n}\nexport function time(args) {\n return new RegExp(`^${timeSource(args)}$`);\n}\n// Adapted from https://stackoverflow.com/a/3143231\nexport function datetime(args) {\n const time = timeSource({ precision: args.precision });\n const opts = [\"Z\"];\n if (args.local)\n opts.push(\"\");\n // if (args.offset) opts.push(`([+-]\\\\d{2}:\\\\d{2})`);\n if (args.offset)\n opts.push(`([+-](?:[01]\\\\d|2[0-3]):[0-5]\\\\d)`);\n const timeRegex = `${time}(?:${opts.join(\"|\")})`;\n return new RegExp(`^${dateSource}T(?:${timeRegex})$`);\n}\nexport const string = (params) => {\n const regex = params ? `[\\\\s\\\\S]{${params?.minimum ?? 0},${params?.maximum ?? \"\"}}` : `[\\\\s\\\\S]*`;\n return new RegExp(`^${regex}$`);\n};\nexport const bigint = /^\\d+n?$/;\nexport const integer = /^\\d+$/;\nexport const number = /^-?\\d+(?:\\.\\d+)?/i;\nexport const boolean = /true|false/i;\nconst _null = /null/i;\nexport { _null as null };\nconst _undefined = /undefined/i;\nexport { _undefined as undefined };\n// regex for string with no uppercase letters\nexport const lowercase = /^[^A-Z]*$/;\n// regex for string with no lowercase letters\nexport const uppercase = /^[^a-z]*$/;\n// regex for hexadecimal strings (any length)\nexport const hex = /^[0-9a-fA-F]*$/;\n// Hash regexes for different algorithms and encodings\n// Helper function to create base64 regex with exact length and padding\nfunction fixedBase64(bodyLength, padding) {\n return new RegExp(`^[A-Za-z0-9+/]{${bodyLength}}${padding}$`);\n}\n// Helper function to create base64url regex with exact length (no padding)\nfunction fixedBase64url(length) {\n return new RegExp(`^[A-Za-z0-9-_]{${length}}$`);\n}\n// MD5 (16 bytes): base64 = 24 chars total (22 + \"==\")\nexport const md5_hex = /^[0-9a-fA-F]{32}$/;\nexport const md5_base64 = /*@__PURE__*/ fixedBase64(22, \"==\");\nexport const md5_base64url = /*@__PURE__*/ fixedBase64url(22);\n// SHA1 (20 bytes): base64 = 28 chars total (27 + \"=\")\nexport const sha1_hex = /^[0-9a-fA-F]{40}$/;\nexport const sha1_base64 = /*@__PURE__*/ fixedBase64(27, \"=\");\nexport const sha1_base64url = /*@__PURE__*/ fixedBase64url(27);\n// SHA256 (32 bytes): base64 = 44 chars total (43 + \"=\")\nexport const sha256_hex = /^[0-9a-fA-F]{64}$/;\nexport const sha256_base64 = /*@__PURE__*/ fixedBase64(43, \"=\");\nexport const sha256_base64url = /*@__PURE__*/ fixedBase64url(43);\n// SHA384 (48 bytes): base64 = 64 chars total (no padding)\nexport const sha384_hex = /^[0-9a-fA-F]{96}$/;\nexport const sha384_base64 = /*@__PURE__*/ fixedBase64(64, \"\");\nexport const sha384_base64url = /*@__PURE__*/ fixedBase64url(64);\n// SHA512 (64 bytes): base64 = 88 chars total (86 + \"==\")\nexport const sha512_hex = /^[0-9a-fA-F]{128}$/;\nexport const sha512_base64 = /*@__PURE__*/ fixedBase64(86, \"==\");\nexport const sha512_base64url = /*@__PURE__*/ fixedBase64url(86);\n","// import { $ZodType } from \"./schemas.js\";\nimport * as core from \"./core.js\";\nimport * as regexes from \"./regexes.js\";\nimport * as util from \"./util.js\";\nexport const $ZodCheck = /*@__PURE__*/ core.$constructor(\"$ZodCheck\", (inst, def) => {\n var _a;\n inst._zod ?? (inst._zod = {});\n inst._zod.def = def;\n (_a = inst._zod).onattach ?? (_a.onattach = []);\n});\nconst numericOriginMap = {\n number: \"number\",\n bigint: \"bigint\",\n object: \"date\",\n};\nexport const $ZodCheckLessThan = /*@__PURE__*/ core.$constructor(\"$ZodCheckLessThan\", (inst, def) => {\n $ZodCheck.init(inst, def);\n const origin = numericOriginMap[typeof def.value];\n inst._zod.onattach.push((inst) => {\n const bag = inst._zod.bag;\n const curr = (def.inclusive ? bag.maximum : bag.exclusiveMaximum) ?? Number.POSITIVE_INFINITY;\n if (def.value < curr) {\n if (def.inclusive)\n bag.maximum = def.value;\n else\n bag.exclusiveMaximum = def.value;\n }\n });\n inst._zod.check = (payload) => {\n if (def.inclusive ? payload.value <= def.value : payload.value < def.value) {\n return;\n }\n payload.issues.push({\n origin,\n code: \"too_big\",\n maximum: def.value,\n input: payload.value,\n inclusive: def.inclusive,\n inst,\n continue: !def.abort,\n });\n };\n});\nexport const $ZodCheckGreaterThan = /*@__PURE__*/ core.$constructor(\"$ZodCheckGreaterThan\", (inst, def) => {\n $ZodCheck.init(inst, def);\n const origin = numericOriginMap[typeof def.value];\n inst._zod.onattach.push((inst) => {\n const bag = inst._zod.bag;\n const curr = (def.inclusive ? bag.minimum : bag.exclusiveMinimum) ?? Number.NEGATIVE_INFINITY;\n if (def.value > curr) {\n if (def.inclusive)\n bag.minimum = def.value;\n else\n bag.exclusiveMinimum = def.value;\n }\n });\n inst._zod.check = (payload) => {\n if (def.inclusive ? payload.value >= def.value : payload.value > def.value) {\n return;\n }\n payload.issues.push({\n origin,\n code: \"too_small\",\n minimum: def.value,\n input: payload.value,\n inclusive: def.inclusive,\n inst,\n continue: !def.abort,\n });\n };\n});\nexport const $ZodCheckMultipleOf = \n/*@__PURE__*/ core.$constructor(\"$ZodCheckMultipleOf\", (inst, def) => {\n $ZodCheck.init(inst, def);\n inst._zod.onattach.push((inst) => {\n var _a;\n (_a = inst._zod.bag).multipleOf ?? (_a.multipleOf = def.value);\n });\n inst._zod.check = (payload) => {\n if (typeof payload.value !== typeof def.value)\n throw new Error(\"Cannot mix number and bigint in multiple_of check.\");\n const isMultiple = typeof payload.value === \"bigint\"\n ? payload.value % def.value === BigInt(0)\n : util.floatSafeRemainder(payload.value, def.value) === 0;\n if (isMultiple)\n return;\n payload.issues.push({\n origin: typeof payload.value,\n code: \"not_multiple_of\",\n divisor: def.value,\n input: payload.value,\n inst,\n continue: !def.abort,\n });\n };\n});\nexport const $ZodCheckNumberFormat = /*@__PURE__*/ core.$constructor(\"$ZodCheckNumberFormat\", (inst, def) => {\n $ZodCheck.init(inst, def); // no format checks\n def.format = def.format || \"float64\";\n const isInt = def.format?.includes(\"int\");\n const origin = isInt ? \"int\" : \"number\";\n const [minimum, maximum] = util.NUMBER_FORMAT_RANGES[def.format];\n inst._zod.onattach.push((inst) => {\n const bag = inst._zod.bag;\n bag.format = def.format;\n bag.minimum = minimum;\n bag.maximum = maximum;\n if (isInt)\n bag.pattern = regexes.integer;\n });\n inst._zod.check = (payload) => {\n const input = payload.value;\n if (isInt) {\n if (!Number.isInteger(input)) {\n // invalid_format issue\n // payload.issues.push({\n // expected: def.format,\n // format: def.format,\n // code: \"invalid_format\",\n // input,\n // inst,\n // });\n // invalid_type issue\n payload.issues.push({\n expected: origin,\n format: def.format,\n code: \"invalid_type\",\n continue: false,\n input,\n inst,\n });\n return;\n // not_multiple_of issue\n // payload.issues.push({\n // code: \"not_multiple_of\",\n // origin: \"number\",\n // input,\n // inst,\n // divisor: 1,\n // });\n }\n if (!Number.isSafeInteger(input)) {\n if (input > 0) {\n // too_big\n payload.issues.push({\n input,\n code: \"too_big\",\n maximum: Number.MAX_SAFE_INTEGER,\n note: \"Integers must be within the safe integer range.\",\n inst,\n origin,\n continue: !def.abort,\n });\n }\n else {\n // too_small\n payload.issues.push({\n input,\n code: \"too_small\",\n minimum: Number.MIN_SAFE_INTEGER,\n note: \"Integers must be within the safe integer range.\",\n inst,\n origin,\n continue: !def.abort,\n });\n }\n return;\n }\n }\n if (input < minimum) {\n payload.issues.push({\n origin: \"number\",\n input,\n code: \"too_small\",\n minimum,\n inclusive: true,\n inst,\n continue: !def.abort,\n });\n }\n if (input > maximum) {\n payload.issues.push({\n origin: \"number\",\n input,\n code: \"too_big\",\n maximum,\n inst,\n });\n }\n };\n});\nexport const $ZodCheckBigIntFormat = /*@__PURE__*/ core.$constructor(\"$ZodCheckBigIntFormat\", (inst, def) => {\n $ZodCheck.init(inst, def); // no format checks\n const [minimum, maximum] = util.BIGINT_FORMAT_RANGES[def.format];\n inst._zod.onattach.push((inst) => {\n const bag = inst._zod.bag;\n bag.format = def.format;\n bag.minimum = minimum;\n bag.maximum = maximum;\n });\n inst._zod.check = (payload) => {\n const input = payload.value;\n if (input < minimum) {\n payload.issues.push({\n origin: \"bigint\",\n input,\n code: \"too_small\",\n minimum: minimum,\n inclusive: true,\n inst,\n continue: !def.abort,\n });\n }\n if (input > maximum) {\n payload.issues.push({\n origin: \"bigint\",\n input,\n code: \"too_big\",\n maximum,\n inst,\n });\n }\n };\n});\nexport const $ZodCheckMaxSize = /*@__PURE__*/ core.$constructor(\"$ZodCheckMaxSize\", (inst, def) => {\n var _a;\n $ZodCheck.init(inst, def);\n (_a = inst._zod.def).when ?? (_a.when = (payload) => {\n const val = payload.value;\n return !util.nullish(val) && val.size !== undefined;\n });\n inst._zod.onattach.push((inst) => {\n const curr = (inst._zod.bag.maximum ?? Number.POSITIVE_INFINITY);\n if (def.maximum < curr)\n inst._zod.bag.maximum = def.maximum;\n });\n inst._zod.check = (payload) => {\n const input = payload.value;\n const size = input.size;\n if (size <= def.maximum)\n return;\n payload.issues.push({\n origin: util.getSizableOrigin(input),\n code: \"too_big\",\n maximum: def.maximum,\n inclusive: true,\n input,\n inst,\n continue: !def.abort,\n });\n };\n});\nexport const $ZodCheckMinSize = /*@__PURE__*/ core.$constructor(\"$ZodCheckMinSize\", (inst, def) => {\n var _a;\n $ZodCheck.init(inst, def);\n (_a = inst._zod.def).when ?? (_a.when = (payload) => {\n const val = payload.value;\n return !util.nullish(val) && val.size !== undefined;\n });\n inst._zod.onattach.push((inst) => {\n const curr = (inst._zod.bag.minimum ?? Number.NEGATIVE_INFINITY);\n if (def.minimum > curr)\n inst._zod.bag.minimum = def.minimum;\n });\n inst._zod.check = (payload) => {\n const input = payload.value;\n const size = input.size;\n if (size >= def.minimum)\n return;\n payload.issues.push({\n origin: util.getSizableOrigin(input),\n code: \"too_small\",\n minimum: def.minimum,\n inclusive: true,\n input,\n inst,\n continue: !def.abort,\n });\n };\n});\nexport const $ZodCheckSizeEquals = /*@__PURE__*/ core.$constructor(\"$ZodCheckSizeEquals\", (inst, def) => {\n var _a;\n $ZodCheck.init(inst, def);\n (_a = inst._zod.def).when ?? (_a.when = (payload) => {\n const val = payload.value;\n return !util.nullish(val) && val.size !== undefined;\n });\n inst._zod.onattach.push((inst) => {\n const bag = inst._zod.bag;\n bag.minimum = def.size;\n bag.maximum = def.size;\n bag.size = def.size;\n });\n inst._zod.check = (payload) => {\n const input = payload.value;\n const size = input.size;\n if (size === def.size)\n return;\n const tooBig = size > def.size;\n payload.issues.push({\n origin: util.getSizableOrigin(input),\n ...(tooBig ? { code: \"too_big\", maximum: def.size } : { code: \"too_small\", minimum: def.size }),\n inclusive: true,\n exact: true,\n input: payload.value,\n inst,\n continue: !def.abort,\n });\n };\n});\nexport const $ZodCheckMaxLength = /*@__PURE__*/ core.$constructor(\"$ZodCheckMaxLength\", (inst, def) => {\n var _a;\n $ZodCheck.init(inst, def);\n (_a = inst._zod.def).when ?? (_a.when = (payload) => {\n const val = payload.value;\n return !util.nullish(val) && val.length !== undefined;\n });\n inst._zod.onattach.push((inst) => {\n const curr = (inst._zod.bag.maximum ?? Number.POSITIVE_INFINITY);\n if (def.maximum < curr)\n inst._zod.bag.maximum = def.maximum;\n });\n inst._zod.check = (payload) => {\n const input = payload.value;\n const length = input.length;\n if (length <= def.maximum)\n return;\n const origin = util.getLengthableOrigin(input);\n payload.issues.push({\n origin,\n code: \"too_big\",\n maximum: def.maximum,\n inclusive: true,\n input,\n inst,\n continue: !def.abort,\n });\n };\n});\nexport const $ZodCheckMinLength = /*@__PURE__*/ core.$constructor(\"$ZodCheckMinLength\", (inst, def) => {\n var _a;\n $ZodCheck.init(inst, def);\n (_a = inst._zod.def).when ?? (_a.when = (payload) => {\n const val = payload.value;\n return !util.nullish(val) && val.length !== undefined;\n });\n inst._zod.onattach.push((inst) => {\n const curr = (inst._zod.bag.minimum ?? Number.NEGATIVE_INFINITY);\n if (def.minimum > curr)\n inst._zod.bag.minimum = def.minimum;\n });\n inst._zod.check = (payload) => {\n const input = payload.value;\n const length = input.length;\n if (length >= def.minimum)\n return;\n const origin = util.getLengthableOrigin(input);\n payload.issues.push({\n origin,\n code: \"too_small\",\n minimum: def.minimum,\n inclusive: true,\n input,\n inst,\n continue: !def.abort,\n });\n };\n});\nexport const $ZodCheckLengthEquals = /*@__PURE__*/ core.$constructor(\"$ZodCheckLengthEquals\", (inst, def) => {\n var _a;\n $ZodCheck.init(inst, def);\n (_a = inst._zod.def).when ?? (_a.when = (payload) => {\n const val = payload.value;\n return !util.nullish(val) && val.length !== undefined;\n });\n inst._zod.onattach.push((inst) => {\n const bag = inst._zod.bag;\n bag.minimum = def.length;\n bag.maximum = def.length;\n bag.length = def.length;\n });\n inst._zod.check = (payload) => {\n const input = payload.value;\n const length = input.length;\n if (length === def.length)\n return;\n const origin = util.getLengthableOrigin(input);\n const tooBig = length > def.length;\n payload.issues.push({\n origin,\n ...(tooBig ? { code: \"too_big\", maximum: def.length } : { code: \"too_small\", minimum: def.length }),\n inclusive: true,\n exact: true,\n input: payload.value,\n inst,\n continue: !def.abort,\n });\n };\n});\nexport const $ZodCheckStringFormat = /*@__PURE__*/ core.$constructor(\"$ZodCheckStringFormat\", (inst, def) => {\n var _a, _b;\n $ZodCheck.init(inst, def);\n inst._zod.onattach.push((inst) => {\n const bag = inst._zod.bag;\n bag.format = def.format;\n if (def.pattern) {\n bag.patterns ?? (bag.patterns = new Set());\n bag.patterns.add(def.pattern);\n }\n });\n if (def.pattern)\n (_a = inst._zod).check ?? (_a.check = (payload) => {\n def.pattern.lastIndex = 0;\n if (def.pattern.test(payload.value))\n return;\n payload.issues.push({\n origin: \"string\",\n code: \"invalid_format\",\n format: def.format,\n input: payload.value,\n ...(def.pattern ? { pattern: def.pattern.toString() } : {}),\n inst,\n continue: !def.abort,\n });\n });\n else\n (_b = inst._zod).check ?? (_b.check = () => { });\n});\nexport const $ZodCheckRegex = /*@__PURE__*/ core.$constructor(\"$ZodCheckRegex\", (inst, def) => {\n $ZodCheckStringFormat.init(inst, def);\n inst._zod.check = (payload) => {\n def.pattern.lastIndex = 0;\n if (def.pattern.test(payload.value))\n return;\n payload.issues.push({\n origin: \"string\",\n code: \"invalid_format\",\n format: \"regex\",\n input: payload.value,\n pattern: def.pattern.toString(),\n inst,\n continue: !def.abort,\n });\n };\n});\nexport const $ZodCheckLowerCase = /*@__PURE__*/ core.$constructor(\"$ZodCheckLowerCase\", (inst, def) => {\n def.pattern ?? (def.pattern = regexes.lowercase);\n $ZodCheckStringFormat.init(inst, def);\n});\nexport const $ZodCheckUpperCase = /*@__PURE__*/ core.$constructor(\"$ZodCheckUpperCase\", (inst, def) => {\n def.pattern ?? (def.pattern = regexes.uppercase);\n $ZodCheckStringFormat.init(inst, def);\n});\nexport const $ZodCheckIncludes = /*@__PURE__*/ core.$constructor(\"$ZodCheckIncludes\", (inst, def) => {\n $ZodCheck.init(inst, def);\n const escapedRegex = util.escapeRegex(def.includes);\n const pattern = new RegExp(typeof def.position === \"number\" ? `^.{${def.position}}${escapedRegex}` : escapedRegex);\n def.pattern = pattern;\n inst._zod.onattach.push((inst) => {\n const bag = inst._zod.bag;\n bag.patterns ?? (bag.patterns = new Set());\n bag.patterns.add(pattern);\n });\n inst._zod.check = (payload) => {\n if (payload.value.includes(def.includes, def.position))\n return;\n payload.issues.push({\n origin: \"string\",\n code: \"invalid_format\",\n format: \"includes\",\n includes: def.includes,\n input: payload.value,\n inst,\n continue: !def.abort,\n });\n };\n});\nexport const $ZodCheckStartsWith = /*@__PURE__*/ core.$constructor(\"$ZodCheckStartsWith\", (inst, def) => {\n $ZodCheck.init(inst, def);\n const pattern = new RegExp(`^${util.escapeRegex(def.prefix)}.*`);\n def.pattern ?? (def.pattern = pattern);\n inst._zod.onattach.push((inst) => {\n const bag = inst._zod.bag;\n bag.patterns ?? (bag.patterns = new Set());\n bag.patterns.add(pattern);\n });\n inst._zod.check = (payload) => {\n if (payload.value.startsWith(def.prefix))\n return;\n payload.issues.push({\n origin: \"string\",\n code: \"invalid_format\",\n format: \"starts_with\",\n prefix: def.prefix,\n input: payload.value,\n inst,\n continue: !def.abort,\n });\n };\n});\nexport const $ZodCheckEndsWith = /*@__PURE__*/ core.$constructor(\"$ZodCheckEndsWith\", (inst, def) => {\n $ZodCheck.init(inst, def);\n const pattern = new RegExp(`.*${util.escapeRegex(def.suffix)}$`);\n def.pattern ?? (def.pattern = pattern);\n inst._zod.onattach.push((inst) => {\n const bag = inst._zod.bag;\n bag.patterns ?? (bag.patterns = new Set());\n bag.patterns.add(pattern);\n });\n inst._zod.check = (payload) => {\n if (payload.value.endsWith(def.suffix))\n return;\n payload.issues.push({\n origin: \"string\",\n code: \"invalid_format\",\n format: \"ends_with\",\n suffix: def.suffix,\n input: payload.value,\n inst,\n continue: !def.abort,\n });\n };\n});\n///////////////////////////////////\n///// $ZodCheckProperty /////\n///////////////////////////////////\nfunction handleCheckPropertyResult(result, payload, property) {\n if (result.issues.length) {\n payload.issues.push(...util.prefixIssues(property, result.issues));\n }\n}\nexport const $ZodCheckProperty = /*@__PURE__*/ core.$constructor(\"$ZodCheckProperty\", (inst, def) => {\n $ZodCheck.init(inst, def);\n inst._zod.check = (payload) => {\n const result = def.schema._zod.run({\n value: payload.value[def.property],\n issues: [],\n }, {});\n if (result instanceof Promise) {\n return result.then((result) => handleCheckPropertyResult(result, payload, def.property));\n }\n handleCheckPropertyResult(result, payload, def.property);\n return;\n };\n});\nexport const $ZodCheckMimeType = /*@__PURE__*/ core.$constructor(\"$ZodCheckMimeType\", (inst, def) => {\n $ZodCheck.init(inst, def);\n const mimeSet = new Set(def.mime);\n inst._zod.onattach.push((inst) => {\n inst._zod.bag.mime = def.mime;\n });\n inst._zod.check = (payload) => {\n if (mimeSet.has(payload.value.type))\n return;\n payload.issues.push({\n code: \"invalid_value\",\n values: def.mime,\n input: payload.value.type,\n inst,\n continue: !def.abort,\n });\n };\n});\nexport const $ZodCheckOverwrite = /*@__PURE__*/ core.$constructor(\"$ZodCheckOverwrite\", (inst, def) => {\n $ZodCheck.init(inst, def);\n inst._zod.check = (payload) => {\n payload.value = def.tx(payload.value);\n };\n});\n","export class Doc {\n constructor(args = []) {\n this.content = [];\n this.indent = 0;\n if (this)\n this.args = args;\n }\n indented(fn) {\n this.indent += 1;\n fn(this);\n this.indent -= 1;\n }\n write(arg) {\n if (typeof arg === \"function\") {\n arg(this, { execution: \"sync\" });\n arg(this, { execution: \"async\" });\n return;\n }\n const content = arg;\n const lines = content.split(\"\\n\").filter((x) => x);\n const minIndent = Math.min(...lines.map((x) => x.length - x.trimStart().length));\n const dedented = lines.map((x) => x.slice(minIndent)).map((x) => \" \".repeat(this.indent * 2) + x);\n for (const line of dedented) {\n this.content.push(line);\n }\n }\n compile() {\n const F = Function;\n const args = this?.args;\n const content = this?.content ?? [``];\n const lines = [...content.map((x) => ` ${x}`)];\n // console.log(lines.join(\"\\n\"));\n return new F(...args, lines.join(\"\\n\"));\n }\n}\n","export const version = {\n major: 4,\n minor: 1,\n patch: 5,\n};\n","import * as checks from \"./checks.js\";\nimport * as core from \"./core.js\";\nimport { Doc } from \"./doc.js\";\nimport { parse, parseAsync, safeParse, safeParseAsync } from \"./parse.js\";\nimport * as regexes from \"./regexes.js\";\nimport * as util from \"./util.js\";\nimport { version } from \"./versions.js\";\nexport const $ZodType = /*@__PURE__*/ core.$constructor(\"$ZodType\", (inst, def) => {\n var _a;\n inst ?? (inst = {});\n inst._zod.def = def; // set _def property\n inst._zod.bag = inst._zod.bag || {}; // initialize _bag object\n inst._zod.version = version;\n const checks = [...(inst._zod.def.checks ?? [])];\n // if inst is itself a checks.$ZodCheck, run it as a check\n if (inst._zod.traits.has(\"$ZodCheck\")) {\n checks.unshift(inst);\n }\n for (const ch of checks) {\n for (const fn of ch._zod.onattach) {\n fn(inst);\n }\n }\n if (checks.length === 0) {\n // deferred initializer\n // inst._zod.parse is not yet defined\n (_a = inst._zod).deferred ?? (_a.deferred = []);\n inst._zod.deferred?.push(() => {\n inst._zod.run = inst._zod.parse;\n });\n }\n else {\n const runChecks = (payload, checks, ctx) => {\n let isAborted = util.aborted(payload);\n let asyncResult;\n for (const ch of checks) {\n if (ch._zod.def.when) {\n const shouldRun = ch._zod.def.when(payload);\n if (!shouldRun)\n continue;\n }\n else if (isAborted) {\n continue;\n }\n const currLen = payload.issues.length;\n const _ = ch._zod.check(payload);\n if (_ instanceof Promise && ctx?.async === false) {\n throw new core.$ZodAsyncError();\n }\n if (asyncResult || _ instanceof Promise) {\n asyncResult = (asyncResult ?? Promise.resolve()).then(async () => {\n await _;\n const nextLen = payload.issues.length;\n if (nextLen === currLen)\n return;\n if (!isAborted)\n isAborted = util.aborted(payload, currLen);\n });\n }\n else {\n const nextLen = payload.issues.length;\n if (nextLen === currLen)\n continue;\n if (!isAborted)\n isAborted = util.aborted(payload, currLen);\n }\n }\n if (asyncResult) {\n return asyncResult.then(() => {\n return payload;\n });\n }\n return payload;\n };\n // const handleChecksResult = (\n // checkResult: ParsePayload,\n // originalResult: ParsePayload,\n // ctx: ParseContextInternal\n // ): util.MaybeAsync<ParsePayload> => {\n // // if the checks mutated the value && there are no issues, re-parse the result\n // if (checkResult.value !== originalResult.value && !checkResult.issues.length)\n // return inst._zod.parse(checkResult, ctx);\n // return originalResult;\n // };\n const handleCanaryResult = (canary, payload, ctx) => {\n // abort if the canary is aborted\n if (util.aborted(canary)) {\n canary.aborted = true;\n return canary;\n }\n // run checks first, then\n const checkResult = runChecks(payload, checks, ctx);\n if (checkResult instanceof Promise) {\n if (ctx.async === false)\n throw new core.$ZodAsyncError();\n return checkResult.then((checkResult) => inst._zod.parse(checkResult, ctx));\n }\n return inst._zod.parse(checkResult, ctx);\n };\n inst._zod.run = (payload, ctx) => {\n if (ctx.skipChecks) {\n return inst._zod.parse(payload, ctx);\n }\n if (ctx.direction === \"backward\") {\n // run canary\n // initial pass (no checks)\n const canary = inst._zod.parse({ value: payload.value, issues: [] }, { ...ctx, skipChecks: true });\n if (canary instanceof Promise) {\n return canary.then((canary) => {\n return handleCanaryResult(canary, payload, ctx);\n });\n }\n return handleCanaryResult(canary, payload, ctx);\n }\n // forward\n const result = inst._zod.parse(payload, ctx);\n if (result instanceof Promise) {\n if (ctx.async === false)\n throw new core.$ZodAsyncError();\n return result.then((result) => runChecks(result, checks, ctx));\n }\n return runChecks(result, checks, ctx);\n };\n }\n inst[\"~standard\"] = {\n validate: (value) => {\n try {\n const r = safeParse(inst, value);\n return r.success ? { value: r.data } : { issues: r.error?.issues };\n }\n catch (_) {\n return safeParseAsync(inst, value).then((r) => (r.success ? { value: r.data } : { issues: r.error?.issues }));\n }\n },\n vendor: \"zod\",\n version: 1,\n };\n});\nexport { clone } from \"./util.js\";\nexport const $ZodString = /*@__PURE__*/ core.$constructor(\"$ZodString\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._zod.pattern = [...(inst?._zod.bag?.patterns ?? [])].pop() ?? regexes.string(inst._zod.bag);\n inst._zod.parse = (payload, _) => {\n if (def.coerce)\n try {\n payload.value = String(payload.value);\n }\n catch (_) { }\n if (typeof payload.value === \"string\")\n return payload;\n payload.issues.push({\n expected: \"string\",\n code: \"invalid_type\",\n input: payload.value,\n inst,\n });\n return payload;\n };\n});\nexport const $ZodStringFormat = /*@__PURE__*/ core.$constructor(\"$ZodStringFormat\", (inst, def) => {\n // check initialization must come first\n checks.$ZodCheckStringFormat.init(inst, def);\n $ZodString.init(inst, def);\n});\nexport const $ZodGUID = /*@__PURE__*/ core.$constructor(\"$ZodGUID\", (inst, def) => {\n def.pattern ?? (def.pattern = regexes.guid);\n $ZodStringFormat.init(inst, def);\n});\nexport const $ZodUUID = /*@__PURE__*/ core.$constructor(\"$ZodUUID\", (inst, def) => {\n if (def.version) {\n const versionMap = {\n v1: 1,\n v2: 2,\n v3: 3,\n v4: 4,\n v5: 5,\n v6: 6,\n v7: 7,\n v8: 8,\n };\n const v = versionMap[def.version];\n if (v === undefined)\n throw new Error(`Invalid UUID version: \"${def.version}\"`);\n def.pattern ?? (def.pattern = regexes.uuid(v));\n }\n else\n def.pattern ?? (def.pattern = regexes.uuid());\n $ZodStringFormat.init(inst, def);\n});\nexport const $ZodEmail = /*@__PURE__*/ core.$constructor(\"$ZodEmail\", (inst, def) => {\n def.pattern ?? (def.pattern = regexes.email);\n $ZodStringFormat.init(inst, def);\n});\nexport const $ZodURL = /*@__PURE__*/ core.$constructor(\"$ZodURL\", (inst, def) => {\n $ZodStringFormat.init(inst, def);\n inst._zod.check = (payload) => {\n try {\n // Trim whitespace from input\n const trimmed = payload.value.trim();\n // @ts-ignore\n const url = new URL(trimmed);\n if (def.hostname) {\n def.hostname.lastIndex = 0;\n if (!def.hostname.test(url.hostname)) {\n payload.issues.push({\n code: \"invalid_format\",\n format: \"url\",\n note: \"Invalid hostname\",\n pattern: regexes.hostname.source,\n input: payload.value,\n inst,\n continue: !def.abort,\n });\n }\n }\n if (def.protocol) {\n def.protocol.lastIndex = 0;\n if (!def.protocol.test(url.protocol.endsWith(\":\") ? url.protocol.slice(0, -1) : url.protocol)) {\n payload.issues.push({\n code: \"invalid_format\",\n format: \"url\",\n note: \"Invalid protocol\",\n pattern: def.protocol.source,\n input: payload.value,\n inst,\n continue: !def.abort,\n });\n }\n }\n // Set the output value based on normalize flag\n if (def.normalize) {\n // Use normalized URL\n payload.value = url.href;\n }\n else {\n // Preserve the original input (trimmed)\n payload.value = trimmed;\n }\n return;\n }\n catch (_) {\n payload.issues.push({\n code: \"invalid_format\",\n format: \"url\",\n input: payload.value,\n inst,\n continue: !def.abort,\n });\n }\n };\n});\nexport const $ZodEmoji = /*@__PURE__*/ core.$constructor(\"$ZodEmoji\", (inst, def) => {\n def.pattern ?? (def.pattern = regexes.emoji());\n $ZodStringFormat.init(inst, def);\n});\nexport const $ZodNanoID = /*@__PURE__*/ core.$constructor(\"$ZodNanoID\", (inst, def) => {\n def.pattern ?? (def.pattern = regexes.nanoid);\n $ZodStringFormat.init(inst, def);\n});\nexport const $ZodCUID = /*@__PURE__*/ core.$constructor(\"$ZodCUID\", (inst, def) => {\n def.pattern ?? (def.pattern = regexes.cuid);\n $ZodStringFormat.init(inst, def);\n});\nexport const $ZodCUID2 = /*@__PURE__*/ core.$constructor(\"$ZodCUID2\", (inst, def) => {\n def.pattern ?? (def.pattern = regexes.cuid2);\n $ZodStringFormat.init(inst, def);\n});\nexport const $ZodULID = /*@__PURE__*/ core.$constructor(\"$ZodULID\", (inst, def) => {\n def.pattern ?? (def.pattern = regexes.ulid);\n $ZodStringFormat.init(inst, def);\n});\nexport const $ZodXID = /*@__PURE__*/ core.$constructor(\"$ZodXID\", (inst, def) => {\n def.pattern ?? (def.pattern = regexes.xid);\n $ZodStringFormat.init(inst, def);\n});\nexport const $ZodKSUID = /*@__PURE__*/ core.$constructor(\"$ZodKSUID\", (inst, def) => {\n def.pattern ?? (def.pattern = regexes.ksuid);\n $ZodStringFormat.init(inst, def);\n});\nexport const $ZodISODateTime = /*@__PURE__*/ core.$constructor(\"$ZodISODateTime\", (inst, def) => {\n def.pattern ?? (def.pattern = regexes.datetime(def));\n $ZodStringFormat.init(inst, def);\n});\nexport const $ZodISODate = /*@__PURE__*/ core.$constructor(\"$ZodISODate\", (inst, def) => {\n def.pattern ?? (def.pattern = regexes.date);\n $ZodStringFormat.init(inst, def);\n});\nexport const $ZodISOTime = /*@__PURE__*/ core.$constructor(\"$ZodISOTime\", (inst, def) => {\n def.pattern ?? (def.pattern = regexes.time(def));\n $ZodStringFormat.init(inst, def);\n});\nexport const $ZodISODuration = /*@__PURE__*/ core.$constructor(\"$ZodISODuration\", (inst, def) => {\n def.pattern ?? (def.pattern = regexes.duration);\n $ZodStringFormat.init(inst, def);\n});\nexport const $ZodIPv4 = /*@__PURE__*/ core.$constructor(\"$ZodIPv4\", (inst, def) => {\n def.pattern ?? (def.pattern = regexes.ipv4);\n $ZodStringFormat.init(inst, def);\n inst._zod.onattach.push((inst) => {\n const bag = inst._zod.bag;\n bag.format = `ipv4`;\n });\n});\nexport const $ZodIPv6 = /*@__PURE__*/ core.$constructor(\"$ZodIPv6\", (inst, def) => {\n def.pattern ?? (def.pattern = regexes.ipv6);\n $ZodStringFormat.init(inst, def);\n inst._zod.onattach.push((inst) => {\n const bag = inst._zod.bag;\n bag.format = `ipv6`;\n });\n inst._zod.check = (payload) => {\n try {\n // @ts-ignore\n new URL(`http://[${payload.value}]`);\n // return;\n }\n catch {\n payload.issues.push({\n code: \"invalid_format\",\n format: \"ipv6\",\n input: payload.value,\n inst,\n continue: !def.abort,\n });\n }\n };\n});\nexport const $ZodCIDRv4 = /*@__PURE__*/ core.$constructor(\"$ZodCIDRv4\", (inst, def) => {\n def.pattern ?? (def.pattern = regexes.cidrv4);\n $ZodStringFormat.init(inst, def);\n});\nexport const $ZodCIDRv6 = /*@__PURE__*/ core.$constructor(\"$ZodCIDRv6\", (inst, def) => {\n def.pattern ?? (def.pattern = regexes.cidrv6); // not used for validation\n $ZodStringFormat.init(inst, def);\n inst._zod.check = (payload) => {\n const [address, prefix] = payload.value.split(\"/\");\n try {\n if (!prefix)\n throw new Error();\n const prefixNum = Number(prefix);\n if (`${prefixNum}` !== prefix)\n throw new Error();\n if (prefixNum < 0 || prefixNum > 128)\n throw new Error();\n // @ts-ignore\n new URL(`http://[${address}]`);\n }\n catch {\n payload.issues.push({\n code: \"invalid_format\",\n format: \"cidrv6\",\n input: payload.value,\n inst,\n continue: !def.abort,\n });\n }\n };\n});\n////////////////////////////// ZodBase64 //////////////////////////////\nexport function isValidBase64(data) {\n if (data === \"\")\n return true;\n if (data.length % 4 !== 0)\n return false;\n try {\n // @ts-ignore\n atob(data);\n return true;\n }\n catch {\n return false;\n }\n}\nexport const $ZodBase64 = /*@__PURE__*/ core.$constructor(\"$ZodBase64\", (inst, def) => {\n def.pattern ?? (def.pattern = regexes.base64);\n $ZodStringFormat.init(inst, def);\n inst._zod.onattach.push((inst) => {\n inst._zod.bag.contentEncoding = \"base64\";\n });\n inst._zod.check = (payload) => {\n if (isValidBase64(payload.value))\n return;\n payload.issues.push({\n code: \"invalid_format\",\n format: \"base64\",\n input: payload.value,\n inst,\n continue: !def.abort,\n });\n };\n});\n////////////////////////////// ZodBase64 //////////////////////////////\nexport function isValidBase64URL(data) {\n if (!regexes.base64url.test(data))\n return false;\n const base64 = data.replace(/[-_]/g, (c) => (c === \"-\" ? \"+\" : \"/\"));\n const padded = base64.padEnd(Math.ceil(base64.length / 4) * 4, \"=\");\n return isValidBase64(padded);\n}\nexport const $ZodBase64URL = /*@__PURE__*/ core.$constructor(\"$ZodBase64URL\", (inst, def) => {\n def.pattern ?? (def.pattern = regexes.base64url);\n $ZodStringFormat.init(inst, def);\n inst._zod.onattach.push((inst) => {\n inst._zod.bag.contentEncoding = \"base64url\";\n });\n inst._zod.check = (payload) => {\n if (isValidBase64URL(payload.value))\n return;\n payload.issues.push({\n code: \"invalid_format\",\n format: \"base64url\",\n input: payload.value,\n inst,\n continue: !def.abort,\n });\n };\n});\nexport const $ZodE164 = /*@__PURE__*/ core.$constructor(\"$ZodE164\", (inst, def) => {\n def.pattern ?? (def.pattern = regexes.e164);\n $ZodStringFormat.init(inst, def);\n});\n////////////////////////////// ZodJWT //////////////////////////////\nexport function isValidJWT(token, algorithm = null) {\n try {\n const tokensParts = token.split(\".\");\n if (tokensParts.length !== 3)\n return false;\n const [header] = tokensParts;\n if (!header)\n return false;\n // @ts-ignore\n const parsedHeader = JSON.parse(atob(header));\n if (\"typ\" in parsedHeader && parsedHeader?.typ !== \"JWT\")\n return false;\n if (!parsedHeader.alg)\n return false;\n if (algorithm && (!(\"alg\" in parsedHeader) || parsedHeader.alg !== algorithm))\n return false;\n return true;\n }\n catch {\n return false;\n }\n}\nexport const $ZodJWT = /*@__PURE__*/ core.$constructor(\"$ZodJWT\", (inst, def) => {\n $ZodStringFormat.init(inst, def);\n inst._zod.check = (payload) => {\n if (isValidJWT(payload.value, def.alg))\n return;\n payload.issues.push({\n code: \"invalid_format\",\n format: \"jwt\",\n input: payload.value,\n inst,\n continue: !def.abort,\n });\n };\n});\nexport const $ZodCustomStringFormat = /*@__PURE__*/ core.$constructor(\"$ZodCustomStringFormat\", (inst, def) => {\n $ZodStringFormat.init(inst, def);\n inst._zod.check = (payload) => {\n if (def.fn(payload.value))\n return;\n payload.issues.push({\n code: \"invalid_format\",\n format: def.format,\n input: payload.value,\n inst,\n continue: !def.abort,\n });\n };\n});\nexport const $ZodNumber = /*@__PURE__*/ core.$constructor(\"$ZodNumber\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._zod.pattern = inst._zod.bag.pattern ?? regexes.number;\n inst._zod.parse = (payload, _ctx) => {\n if (def.coerce)\n try {\n payload.value = Number(payload.value);\n }\n catch (_) { }\n const input = payload.value;\n if (typeof input === \"number\" && !Number.isNaN(input) && Number.isFinite(input)) {\n return payload;\n }\n const received = typeof input === \"number\"\n ? Number.isNaN(input)\n ? \"NaN\"\n : !Number.isFinite(input)\n ? \"Infinity\"\n : undefined\n : undefined;\n payload.issues.push({\n expected: \"number\",\n code: \"invalid_type\",\n input,\n inst,\n ...(received ? { received } : {}),\n });\n return payload;\n };\n});\nexport const $ZodNumberFormat = /*@__PURE__*/ core.$constructor(\"$ZodNumber\", (inst, def) => {\n checks.$ZodCheckNumberFormat.init(inst, def);\n $ZodNumber.init(inst, def); // no format checksp\n});\nexport const $ZodBoolean = /*@__PURE__*/ core.$constructor(\"$ZodBoolean\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._zod.pattern = regexes.boolean;\n inst._zod.parse = (payload, _ctx) => {\n if (def.coerce)\n try {\n payload.value = Boolean(payload.value);\n }\n catch (_) { }\n const input = payload.value;\n if (typeof input === \"boolean\")\n return payload;\n payload.issues.push({\n expected: \"boolean\",\n code: \"invalid_type\",\n input,\n inst,\n });\n return payload;\n };\n});\nexport const $ZodBigInt = /*@__PURE__*/ core.$constructor(\"$ZodBigInt\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._zod.pattern = regexes.bigint;\n inst._zod.parse = (payload, _ctx) => {\n if (def.coerce)\n try {\n payload.value = BigInt(payload.value);\n }\n catch (_) { }\n if (typeof payload.value === \"bigint\")\n return payload;\n payload.issues.push({\n expected: \"bigint\",\n code: \"invalid_type\",\n input: payload.value,\n inst,\n });\n return payload;\n };\n});\nexport const $ZodBigIntFormat = /*@__PURE__*/ core.$constructor(\"$ZodBigInt\", (inst, def) => {\n checks.$ZodCheckBigIntFormat.init(inst, def);\n $ZodBigInt.init(inst, def); // no format checks\n});\nexport const $ZodSymbol = /*@__PURE__*/ core.$constructor(\"$ZodSymbol\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._zod.parse = (payload, _ctx) => {\n const input = payload.value;\n if (typeof input === \"symbol\")\n return payload;\n payload.issues.push({\n expected: \"symbol\",\n code: \"invalid_type\",\n input,\n inst,\n });\n return payload;\n };\n});\nexport const $ZodUndefined = /*@__PURE__*/ core.$constructor(\"$ZodUndefined\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._zod.pattern = regexes.undefined;\n inst._zod.values = new Set([undefined]);\n inst._zod.optin = \"optional\";\n inst._zod.optout = \"optional\";\n inst._zod.parse = (payload, _ctx) => {\n const input = payload.value;\n if (typeof input === \"undefined\")\n return payload;\n payload.issues.push({\n expected: \"undefined\",\n code: \"invalid_type\",\n input,\n inst,\n });\n return payload;\n };\n});\nexport const $ZodNull = /*@__PURE__*/ core.$constructor(\"$ZodNull\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._zod.pattern = regexes.null;\n inst._zod.values = new Set([null]);\n inst._zod.parse = (payload, _ctx) => {\n const input = payload.value;\n if (input === null)\n return payload;\n payload.issues.push({\n expected: \"null\",\n code: \"invalid_type\",\n input,\n inst,\n });\n return payload;\n };\n});\nexport const $ZodAny = /*@__PURE__*/ core.$constructor(\"$ZodAny\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._zod.parse = (payload) => payload;\n});\nexport const $ZodUnknown = /*@__PURE__*/ core.$constructor(\"$ZodUnknown\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._zod.parse = (payload) => payload;\n});\nexport const $ZodNever = /*@__PURE__*/ core.$constructor(\"$ZodNever\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._zod.parse = (payload, _ctx) => {\n payload.issues.push({\n expected: \"never\",\n code: \"invalid_type\",\n input: payload.value,\n inst,\n });\n return payload;\n };\n});\nexport const $ZodVoid = /*@__PURE__*/ core.$constructor(\"$ZodVoid\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._zod.parse = (payload, _ctx) => {\n const input = payload.value;\n if (typeof input === \"undefined\")\n return payload;\n payload.issues.push({\n expected: \"void\",\n code: \"invalid_type\",\n input,\n inst,\n });\n return payload;\n };\n});\nexport const $ZodDate = /*@__PURE__*/ core.$constructor(\"$ZodDate\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._zod.parse = (payload, _ctx) => {\n if (def.coerce) {\n try {\n payload.value = new Date(payload.value);\n }\n catch (_err) { }\n }\n const input = payload.value;\n const isDate = input instanceof Date;\n const isValidDate = isDate && !Number.isNaN(input.getTime());\n if (isValidDate)\n return payload;\n payload.issues.push({\n expected: \"date\",\n code: \"invalid_type\",\n input,\n ...(isDate ? { received: \"Invalid Date\" } : {}),\n inst,\n });\n return payload;\n };\n});\nfunction handleArrayResult(result, final, index) {\n if (result.issues.length) {\n final.issues.push(...util.prefixIssues(index, result.issues));\n }\n final.value[index] = result.value;\n}\nexport const $ZodArray = /*@__PURE__*/ core.$constructor(\"$ZodArray\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._zod.parse = (payload, ctx) => {\n const input = payload.value;\n if (!Array.isArray(input)) {\n payload.issues.push({\n expected: \"array\",\n code: \"invalid_type\",\n input,\n inst,\n });\n return payload;\n }\n payload.value = Array(input.length);\n const proms = [];\n for (let i = 0; i < input.length; i++) {\n const item = input[i];\n const result = def.element._zod.run({\n value: item,\n issues: [],\n }, ctx);\n if (result instanceof Promise) {\n proms.push(result.then((result) => handleArrayResult(result, payload, i)));\n }\n else {\n handleArrayResult(result, payload, i);\n }\n }\n if (proms.length) {\n return Promise.all(proms).then(() => payload);\n }\n return payload; //handleArrayResultsAsync(parseResults, final);\n };\n});\nfunction handlePropertyResult(result, final, key, input) {\n if (result.issues.length) {\n final.issues.push(...util.prefixIssues(key, result.issues));\n }\n if (result.value === undefined) {\n if (key in input) {\n final.value[key] = undefined;\n }\n }\n else {\n final.value[key] = result.value;\n }\n}\nfunction normalizeDef(def) {\n const keys = Object.keys(def.shape);\n for (const k of keys) {\n if (!def.shape[k]._zod.traits.has(\"$ZodType\")) {\n throw new Error(`Invalid element at key \"${k}\": expected a Zod schema`);\n }\n }\n const okeys = util.optionalKeys(def.shape);\n return {\n ...def,\n keys,\n keySet: new Set(keys),\n numKeys: keys.length,\n optionalKeys: new Set(okeys),\n };\n}\nfunction handleCatchall(proms, input, payload, ctx, def, inst) {\n const unrecognized = [];\n // iterate over input keys\n const keySet = def.keySet;\n const _catchall = def.catchall._zod;\n const t = _catchall.def.type;\n for (const key of Object.keys(input)) {\n if (keySet.has(key))\n continue;\n if (t === \"never\") {\n unrecognized.push(key);\n continue;\n }\n const r = _catchall.run({ value: input[key], issues: [] }, ctx);\n if (r instanceof Promise) {\n proms.push(r.then((r) => handlePropertyResult(r, payload, key, input)));\n }\n else {\n handlePropertyResult(r, payload, key, input);\n }\n }\n if (unrecognized.length) {\n payload.issues.push({\n code: \"unrecognized_keys\",\n keys: unrecognized,\n input,\n inst,\n });\n }\n if (!proms.length)\n return payload;\n return Promise.all(proms).then(() => {\n return payload;\n });\n}\nexport const $ZodObject = /*@__PURE__*/ core.$constructor(\"$ZodObject\", (inst, def) => {\n // requires cast because technically $ZodObject doesn't extend\n $ZodType.init(inst, def);\n const _normalized = util.cached(() => normalizeDef(def));\n util.defineLazy(inst._zod, \"propValues\", () => {\n const shape = def.shape;\n const propValues = {};\n for (const key in shape) {\n const field = shape[key]._zod;\n if (field.values) {\n propValues[key] ?? (propValues[key] = new Set());\n for (const v of field.values)\n propValues[key].add(v);\n }\n }\n return propValues;\n });\n const isObject = util.isObject;\n const catchall = def.catchall;\n let value;\n inst._zod.parse = (payload, ctx) => {\n value ?? (value = _normalized.value);\n const input = payload.value;\n if (!isObject(input)) {\n payload.issues.push({\n expected: \"object\",\n code: \"invalid_type\",\n input,\n inst,\n });\n return payload;\n }\n payload.value = {};\n const proms = [];\n const shape = value.shape;\n for (const key of value.keys) {\n const el = shape[key];\n const r = el._zod.run({ value: input[key], issues: [] }, ctx);\n if (r instanceof Promise) {\n proms.push(r.then((r) => handlePropertyResult(r, payload, key, input)));\n }\n else {\n handlePropertyResult(r, payload, key, input);\n }\n }\n if (!catchall) {\n return proms.length ? Promise.all(proms).then(() => payload) : payload;\n }\n return handleCatchall(proms, input, payload, ctx, _normalized.value, inst);\n };\n});\nexport const $ZodObjectJIT = /*@__PURE__*/ core.$constructor(\"$ZodObjectJIT\", (inst, def) => {\n // requires cast because technically $ZodObject doesn't extend\n $ZodObject.init(inst, def);\n const superParse = inst._zod.parse;\n const _normalized = util.cached(() => normalizeDef(def));\n const generateFastpass = (shape) => {\n const doc = new Doc([\"shape\", \"payload\", \"ctx\"]);\n const normalized = _normalized.value;\n const parseStr = (key) => {\n const k = util.esc(key);\n return `shape[${k}]._zod.run({ value: input[${k}], issues: [] }, ctx)`;\n };\n doc.write(`const input = payload.value;`);\n const ids = Object.create(null);\n let counter = 0;\n for (const key of normalized.keys) {\n ids[key] = `key_${counter++}`;\n }\n // A: preserve key order {\n doc.write(`const newResult = {}`);\n for (const key of normalized.keys) {\n const id = ids[key];\n const k = util.esc(key);\n doc.write(`const ${id} = ${parseStr(key)};`);\n doc.write(`\n if (${id}.issues.length) {\n payload.issues = payload.issues.concat(${id}.issues.map(iss => ({\n ...iss,\n path: iss.path ? [${k}, ...iss.path] : [${k}]\n })));\n }\n \n if (${id}.value === undefined) {\n if (${k} in input) {\n newResult[${k}] = undefined;\n }\n } else {\n newResult[${k}] = ${id}.value;\n }\n `);\n }\n doc.write(`payload.value = newResult;`);\n doc.write(`return payload;`);\n const fn = doc.compile();\n return (payload, ctx) => fn(shape, payload, ctx);\n };\n let fastpass;\n const isObject = util.isObject;\n const jit = !core.globalConfig.jitless;\n const allowsEval = util.allowsEval;\n const fastEnabled = jit && allowsEval.value; // && !def.catchall;\n const catchall = def.catchall;\n let value;\n inst._zod.parse = (payload, ctx) => {\n value ?? (value = _normalized.value);\n const input = payload.value;\n if (!isObject(input)) {\n payload.issues.push({\n expected: \"object\",\n code: \"invalid_type\",\n input,\n inst,\n });\n return payload;\n }\n if (jit && fastEnabled && ctx?.async === false && ctx.jitless !== true) {\n // always synchronous\n if (!fastpass)\n fastpass = generateFastpass(def.shape);\n payload = fastpass(payload, ctx);\n if (!catchall)\n return payload;\n return handleCatchall([], input, payload, ctx, value, inst);\n }\n return superParse(payload, ctx);\n };\n});\nfunction handleUnionResults(results, final, inst, ctx) {\n for (const result of results) {\n if (result.issues.length === 0) {\n final.value = result.value;\n return final;\n }\n }\n const nonaborted = results.filter((r) => !util.aborted(r));\n if (nonaborted.length === 1) {\n final.value = nonaborted[0].value;\n return nonaborted[0];\n }\n final.issues.push({\n code: \"invalid_union\",\n input: final.value,\n inst,\n errors: results.map((result) => result.issues.map((iss) => util.finalizeIssue(iss, ctx, core.config()))),\n });\n return final;\n}\nexport const $ZodUnion = /*@__PURE__*/ core.$constructor(\"$ZodUnion\", (inst, def) => {\n $ZodType.init(inst, def);\n util.defineLazy(inst._zod, \"optin\", () => def.options.some((o) => o._zod.optin === \"optional\") ? \"optional\" : undefined);\n util.defineLazy(inst._zod, \"optout\", () => def.options.some((o) => o._zod.optout === \"optional\") ? \"optional\" : undefined);\n util.defineLazy(inst._zod, \"values\", () => {\n if (def.options.every((o) => o._zod.values)) {\n return new Set(def.options.flatMap((option) => Array.from(option._zod.values)));\n }\n return undefined;\n });\n util.defineLazy(inst._zod, \"pattern\", () => {\n if (def.options.every((o) => o._zod.pattern)) {\n const patterns = def.options.map((o) => o._zod.pattern);\n return new RegExp(`^(${patterns.map((p) => util.cleanRegex(p.source)).join(\"|\")})$`);\n }\n return undefined;\n });\n const single = def.options.length === 1;\n const first = def.options[0]._zod.run;\n inst._zod.parse = (payload, ctx) => {\n if (single) {\n return first(payload, ctx);\n }\n let async = false;\n const results = [];\n for (const option of def.options) {\n const result = option._zod.run({\n value: payload.value,\n issues: [],\n }, ctx);\n if (result instanceof Promise) {\n results.push(result);\n async = true;\n }\n else {\n if (result.issues.length === 0)\n return result;\n results.push(result);\n }\n }\n if (!async)\n return handleUnionResults(results, payload, inst, ctx);\n return Promise.all(results).then((results) => {\n return handleUnionResults(results, payload, inst, ctx);\n });\n };\n});\nexport const $ZodDiscriminatedUnion = \n/*@__PURE__*/\ncore.$constructor(\"$ZodDiscriminatedUnion\", (inst, def) => {\n $ZodUnion.init(inst, def);\n const _super = inst._zod.parse;\n util.defineLazy(inst._zod, \"propValues\", () => {\n const propValues = {};\n for (const option of def.options) {\n const pv = option._zod.propValues;\n if (!pv || Object.keys(pv).length === 0)\n throw new Error(`Invalid discriminated union option at index \"${def.options.indexOf(option)}\"`);\n for (const [k, v] of Object.entries(pv)) {\n if (!propValues[k])\n propValues[k] = new Set();\n for (const val of v) {\n propValues[k].add(val);\n }\n }\n }\n return propValues;\n });\n const disc = util.cached(() => {\n const opts = def.options;\n const map = new Map();\n for (const o of opts) {\n const values = o._zod.propValues?.[def.discriminator];\n if (!values || values.size === 0)\n throw new Error(`Invalid discriminated union option at index \"${def.options.indexOf(o)}\"`);\n for (const v of values) {\n if (map.has(v)) {\n throw new Error(`Duplicate discriminator value \"${String(v)}\"`);\n }\n map.set(v, o);\n }\n }\n return map;\n });\n inst._zod.parse = (payload, ctx) => {\n const input = payload.value;\n if (!util.isObject(input)) {\n payload.issues.push({\n code: \"invalid_type\",\n expected: \"object\",\n input,\n inst,\n });\n return payload;\n }\n const opt = disc.value.get(input?.[def.discriminator]);\n if (opt) {\n return opt._zod.run(payload, ctx);\n }\n if (def.unionFallback) {\n return _super(payload, ctx);\n }\n // no matching discriminator\n payload.issues.push({\n code: \"invalid_union\",\n errors: [],\n note: \"No matching discriminator\",\n discriminator: def.discriminator,\n input,\n path: [def.discriminator],\n inst,\n });\n return payload;\n };\n});\nexport const $ZodIntersection = /*@__PURE__*/ core.$constructor(\"$ZodIntersection\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._zod.parse = (payload, ctx) => {\n const input = payload.value;\n const left = def.left._zod.run({ value: input, issues: [] }, ctx);\n const right = def.right._zod.run({ value: input, issues: [] }, ctx);\n const async = left instanceof Promise || right instanceof Promise;\n if (async) {\n return Promise.all([left, right]).then(([left, right]) => {\n return handleIntersectionResults(payload, left, right);\n });\n }\n return handleIntersectionResults(payload, left, right);\n };\n});\nfunction mergeValues(a, b) {\n // const aType = parse.t(a);\n // const bType = parse.t(b);\n if (a === b) {\n return { valid: true, data: a };\n }\n if (a instanceof Date && b instanceof Date && +a === +b) {\n return { valid: true, data: a };\n }\n if (util.isPlainObject(a) && util.isPlainObject(b)) {\n const bKeys = Object.keys(b);\n const sharedKeys = Object.keys(a).filter((key) => bKeys.indexOf(key) !== -1);\n const newObj = { ...a, ...b };\n for (const key of sharedKeys) {\n const sharedValue = mergeValues(a[key], b[key]);\n if (!sharedValue.valid) {\n return {\n valid: false,\n mergeErrorPath: [key, ...sharedValue.mergeErrorPath],\n };\n }\n newObj[key] = sharedValue.data;\n }\n return { valid: true, data: newObj };\n }\n if (Array.isArray(a) && Array.isArray(b)) {\n if (a.length !== b.length) {\n return { valid: false, mergeErrorPath: [] };\n }\n const newArray = [];\n for (let index = 0; index < a.length; index++) {\n const itemA = a[index];\n const itemB = b[index];\n const sharedValue = mergeValues(itemA, itemB);\n if (!sharedValue.valid) {\n return {\n valid: false,\n mergeErrorPath: [index, ...sharedValue.mergeErrorPath],\n };\n }\n newArray.push(sharedValue.data);\n }\n return { valid: true, data: newArray };\n }\n return { valid: false, mergeErrorPath: [] };\n}\nfunction handleIntersectionResults(result, left, right) {\n if (left.issues.length) {\n result.issues.push(...left.issues);\n }\n if (right.issues.length) {\n result.issues.push(...right.issues);\n }\n if (util.aborted(result))\n return result;\n const merged = mergeValues(left.value, right.value);\n if (!merged.valid) {\n throw new Error(`Unmergable intersection. Error path: ` + `${JSON.stringify(merged.mergeErrorPath)}`);\n }\n result.value = merged.data;\n return result;\n}\nexport const $ZodTuple = /*@__PURE__*/ core.$constructor(\"$ZodTuple\", (inst, def) => {\n $ZodType.init(inst, def);\n const items = def.items;\n const optStart = items.length - [...items].reverse().findIndex((item) => item._zod.optin !== \"optional\");\n inst._zod.parse = (payload, ctx) => {\n const input = payload.value;\n if (!Array.isArray(input)) {\n payload.issues.push({\n input,\n inst,\n expected: \"tuple\",\n code: \"invalid_type\",\n });\n return payload;\n }\n payload.value = [];\n const proms = [];\n if (!def.rest) {\n const tooBig = input.length > items.length;\n const tooSmall = input.length < optStart - 1;\n if (tooBig || tooSmall) {\n payload.issues.push({\n ...(tooBig ? { code: \"too_big\", maximum: items.length } : { code: \"too_small\", minimum: items.length }),\n input,\n inst,\n origin: \"array\",\n });\n return payload;\n }\n }\n let i = -1;\n for (const item of items) {\n i++;\n if (i >= input.length)\n if (i >= optStart)\n continue;\n const result = item._zod.run({\n value: input[i],\n issues: [],\n }, ctx);\n if (result instanceof Promise) {\n proms.push(result.then((result) => handleTupleResult(result, payload, i)));\n }\n else {\n handleTupleResult(result, payload, i);\n }\n }\n if (def.rest) {\n const rest = input.slice(items.length);\n for (const el of rest) {\n i++;\n const result = def.rest._zod.run({\n value: el,\n issues: [],\n }, ctx);\n if (result instanceof Promise) {\n proms.push(result.then((result) => handleTupleResult(result, payload, i)));\n }\n else {\n handleTupleResult(result, payload, i);\n }\n }\n }\n if (proms.length)\n return Promise.all(proms).then(() => payload);\n return payload;\n };\n});\nfunction handleTupleResult(result, final, index) {\n if (result.issues.length) {\n final.issues.push(...util.prefixIssues(index, result.issues));\n }\n final.value[index] = result.value;\n}\nexport const $ZodRecord = /*@__PURE__*/ core.$constructor(\"$ZodRecord\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._zod.parse = (payload, ctx) => {\n const input = payload.value;\n if (!util.isPlainObject(input)) {\n payload.issues.push({\n expected: \"record\",\n code: \"invalid_type\",\n input,\n inst,\n });\n return payload;\n }\n const proms = [];\n if (def.keyType._zod.values) {\n const values = def.keyType._zod.values;\n payload.value = {};\n for (const key of values) {\n if (typeof key === \"string\" || typeof key === \"number\" || typeof key === \"symbol\") {\n const result = def.valueType._zod.run({ value: input[key], issues: [] }, ctx);\n if (result instanceof Promise) {\n proms.push(result.then((result) => {\n if (result.issues.length) {\n payload.issues.push(...util.prefixIssues(key, result.issues));\n }\n payload.value[key] = result.value;\n }));\n }\n else {\n if (result.issues.length) {\n payload.issues.push(...util.prefixIssues(key, result.issues));\n }\n payload.value[key] = result.value;\n }\n }\n }\n let unrecognized;\n for (const key in input) {\n if (!values.has(key)) {\n unrecognized = unrecognized ?? [];\n unrecognized.push(key);\n }\n }\n if (unrecognized && unrecognized.length > 0) {\n payload.issues.push({\n code: \"unrecognized_keys\",\n input,\n inst,\n keys: unrecognized,\n });\n }\n }\n else {\n payload.value = {};\n for (const key of Reflect.ownKeys(input)) {\n if (key === \"__proto__\")\n continue;\n const keyResult = def.keyType._zod.run({ value: key, issues: [] }, ctx);\n if (keyResult instanceof Promise) {\n throw new Error(\"Async schemas not supported in object keys currently\");\n }\n if (keyResult.issues.length) {\n payload.issues.push({\n code: \"invalid_key\",\n origin: \"record\",\n issues: keyResult.issues.map((iss) => util.finalizeIssue(iss, ctx, core.config())),\n input: key,\n path: [key],\n inst,\n });\n payload.value[keyResult.value] = keyResult.value;\n continue;\n }\n const result = def.valueType._zod.run({ value: input[key], issues: [] }, ctx);\n if (result instanceof Promise) {\n proms.push(result.then((result) => {\n if (result.issues.length) {\n payload.issues.push(...util.prefixIssues(key, result.issues));\n }\n payload.value[keyResult.value] = result.value;\n }));\n }\n else {\n if (result.issues.length) {\n payload.issues.push(...util.prefixIssues(key, result.issues));\n }\n payload.value[keyResult.value] = result.value;\n }\n }\n }\n if (proms.length) {\n return Promise.all(proms).then(() => payload);\n }\n return payload;\n };\n});\nexport const $ZodMap = /*@__PURE__*/ core.$constructor(\"$ZodMap\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._zod.parse = (payload, ctx) => {\n const input = payload.value;\n if (!(input instanceof Map)) {\n payload.issues.push({\n expected: \"map\",\n code: \"invalid_type\",\n input,\n inst,\n });\n return payload;\n }\n const proms = [];\n payload.value = new Map();\n for (const [key, value] of input) {\n const keyResult = def.keyType._zod.run({ value: key, issues: [] }, ctx);\n const valueResult = def.valueType._zod.run({ value: value, issues: [] }, ctx);\n if (keyResult instanceof Promise || valueResult instanceof Promise) {\n proms.push(Promise.all([keyResult, valueResult]).then(([keyResult, valueResult]) => {\n handleMapResult(keyResult, valueResult, payload, key, input, inst, ctx);\n }));\n }\n else {\n handleMapResult(keyResult, valueResult, payload, key, input, inst, ctx);\n }\n }\n if (proms.length)\n return Promise.all(proms).then(() => payload);\n return payload;\n };\n});\nfunction handleMapResult(keyResult, valueResult, final, key, input, inst, ctx) {\n if (keyResult.issues.length) {\n if (util.propertyKeyTypes.has(typeof key)) {\n final.issues.push(...util.prefixIssues(key, keyResult.issues));\n }\n else {\n final.issues.push({\n code: \"invalid_key\",\n origin: \"map\",\n input,\n inst,\n issues: keyResult.issues.map((iss) => util.finalizeIssue(iss, ctx, core.config())),\n });\n }\n }\n if (valueResult.issues.length) {\n if (util.propertyKeyTypes.has(typeof key)) {\n final.issues.push(...util.prefixIssues(key, valueResult.issues));\n }\n else {\n final.issues.push({\n origin: \"map\",\n code: \"invalid_element\",\n input,\n inst,\n key: key,\n issues: valueResult.issues.map((iss) => util.finalizeIssue(iss, ctx, core.config())),\n });\n }\n }\n final.value.set(keyResult.value, valueResult.value);\n}\nexport const $ZodSet = /*@__PURE__*/ core.$constructor(\"$ZodSet\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._zod.parse = (payload, ctx) => {\n const input = payload.value;\n if (!(input instanceof Set)) {\n payload.issues.push({\n input,\n inst,\n expected: \"set\",\n code: \"invalid_type\",\n });\n return payload;\n }\n const proms = [];\n payload.value = new Set();\n for (const item of input) {\n const result = def.valueType._zod.run({ value: item, issues: [] }, ctx);\n if (result instanceof Promise) {\n proms.push(result.then((result) => handleSetResult(result, payload)));\n }\n else\n handleSetResult(result, payload);\n }\n if (proms.length)\n return Promise.all(proms).then(() => payload);\n return payload;\n };\n});\nfunction handleSetResult(result, final) {\n if (result.issues.length) {\n final.issues.push(...result.issues);\n }\n final.value.add(result.value);\n}\nexport const $ZodEnum = /*@__PURE__*/ core.$constructor(\"$ZodEnum\", (inst, def) => {\n $ZodType.init(inst, def);\n const values = util.getEnumValues(def.entries);\n const valuesSet = new Set(values);\n inst._zod.values = valuesSet;\n inst._zod.pattern = new RegExp(`^(${values\n .filter((k) => util.propertyKeyTypes.has(typeof k))\n .map((o) => (typeof o === \"string\" ? util.escapeRegex(o) : o.toString()))\n .join(\"|\")})$`);\n inst._zod.parse = (payload, _ctx) => {\n const input = payload.value;\n if (valuesSet.has(input)) {\n return payload;\n }\n payload.issues.push({\n code: \"invalid_value\",\n values,\n input,\n inst,\n });\n return payload;\n };\n});\nexport const $ZodLiteral = /*@__PURE__*/ core.$constructor(\"$ZodLiteral\", (inst, def) => {\n $ZodType.init(inst, def);\n if (def.values.length === 0) {\n throw new Error(\"Cannot create literal schema with no valid values\");\n }\n inst._zod.values = new Set(def.values);\n inst._zod.pattern = new RegExp(`^(${def.values\n .map((o) => (typeof o === \"string\" ? util.escapeRegex(o) : o ? util.escapeRegex(o.toString()) : String(o)))\n .join(\"|\")})$`);\n inst._zod.parse = (payload, _ctx) => {\n const input = payload.value;\n if (inst._zod.values.has(input)) {\n return payload;\n }\n payload.issues.push({\n code: \"invalid_value\",\n values: def.values,\n input,\n inst,\n });\n return payload;\n };\n});\nexport const $ZodFile = /*@__PURE__*/ core.$constructor(\"$ZodFile\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._zod.parse = (payload, _ctx) => {\n const input = payload.value;\n // @ts-ignore\n if (input instanceof File)\n return payload;\n payload.issues.push({\n expected: \"file\",\n code: \"invalid_type\",\n input,\n inst,\n });\n return payload;\n };\n});\nexport const $ZodTransform = /*@__PURE__*/ core.$constructor(\"$ZodTransform\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._zod.parse = (payload, ctx) => {\n if (ctx.direction === \"backward\") {\n throw new core.$ZodEncodeError(inst.constructor.name);\n }\n const _out = def.transform(payload.value, payload);\n if (ctx.async) {\n const output = _out instanceof Promise ? _out : Promise.resolve(_out);\n return output.then((output) => {\n payload.value = output;\n return payload;\n });\n }\n if (_out instanceof Promise) {\n throw new core.$ZodAsyncError();\n }\n payload.value = _out;\n return payload;\n };\n});\nfunction handleOptionalResult(result, input) {\n if (result.issues.length && input === undefined) {\n return { issues: [], value: undefined };\n }\n return result;\n}\nexport const $ZodOptional = /*@__PURE__*/ core.$constructor(\"$ZodOptional\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._zod.optin = \"optional\";\n inst._zod.optout = \"optional\";\n util.defineLazy(inst._zod, \"values\", () => {\n return def.innerType._zod.values ? new Set([...def.innerType._zod.values, undefined]) : undefined;\n });\n util.defineLazy(inst._zod, \"pattern\", () => {\n const pattern = def.innerType._zod.pattern;\n return pattern ? new RegExp(`^(${util.cleanRegex(pattern.source)})?$`) : undefined;\n });\n inst._zod.parse = (payload, ctx) => {\n if (def.innerType._zod.optin === \"optional\") {\n const result = def.innerType._zod.run(payload, ctx);\n if (result instanceof Promise)\n return result.then((r) => handleOptionalResult(r, payload.value));\n return handleOptionalResult(result, payload.value);\n }\n if (payload.value === undefined) {\n return payload;\n }\n return def.innerType._zod.run(payload, ctx);\n };\n});\nexport const $ZodNullable = /*@__PURE__*/ core.$constructor(\"$ZodNullable\", (inst, def) => {\n $ZodType.init(inst, def);\n util.defineLazy(inst._zod, \"optin\", () => def.innerType._zod.optin);\n util.defineLazy(inst._zod, \"optout\", () => def.innerType._zod.optout);\n util.defineLazy(inst._zod, \"pattern\", () => {\n const pattern = def.innerType._zod.pattern;\n return pattern ? new RegExp(`^(${util.cleanRegex(pattern.source)}|null)$`) : undefined;\n });\n util.defineLazy(inst._zod, \"values\", () => {\n return def.innerType._zod.values ? new Set([...def.innerType._zod.values, null]) : undefined;\n });\n inst._zod.parse = (payload, ctx) => {\n // Forward direction (decode): allow null to pass through\n if (payload.value === null)\n return payload;\n return def.innerType._zod.run(payload, ctx);\n };\n});\nexport const $ZodDefault = /*@__PURE__*/ core.$constructor(\"$ZodDefault\", (inst, def) => {\n $ZodType.init(inst, def);\n // inst._zod.qin = \"true\";\n inst._zod.optin = \"optional\";\n util.defineLazy(inst._zod, \"values\", () => def.innerType._zod.values);\n inst._zod.parse = (payload, ctx) => {\n if (ctx.direction === \"backward\") {\n return def.innerType._zod.run(payload, ctx);\n }\n // Forward direction (decode): apply defaults for undefined input\n if (payload.value === undefined) {\n payload.value = def.defaultValue;\n /**\n * $ZodDefault returns the default value immediately in forward direction.\n * It doesn't pass the default value into the validator (\"prefault\"). There's no reason to pass the default value through validation. The validity of the default is enforced by TypeScript statically. Otherwise, it's the responsibility of the user to ensure the default is valid. In the case of pipes with divergent in/out types, you can specify the default on the `in` schema of your ZodPipe to set a \"prefault\" for the pipe. */\n return payload;\n }\n // Forward direction: continue with default handling\n const result = def.innerType._zod.run(payload, ctx);\n if (result instanceof Promise) {\n return result.then((result) => handleDefaultResult(result, def));\n }\n return handleDefaultResult(result, def);\n };\n});\nfunction handleDefaultResult(payload, def) {\n if (payload.value === undefined) {\n payload.value = def.defaultValue;\n }\n return payload;\n}\nexport const $ZodPrefault = /*@__PURE__*/ core.$constructor(\"$ZodPrefault\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._zod.optin = \"optional\";\n util.defineLazy(inst._zod, \"values\", () => def.innerType._zod.values);\n inst._zod.parse = (payload, ctx) => {\n if (ctx.direction === \"backward\") {\n return def.innerType._zod.run(payload, ctx);\n }\n // Forward direction (decode): apply prefault for undefined input\n if (payload.value === undefined) {\n payload.value = def.defaultValue;\n }\n return def.innerType._zod.run(payload, ctx);\n };\n});\nexport const $ZodNonOptional = /*@__PURE__*/ core.$constructor(\"$ZodNonOptional\", (inst, def) => {\n $ZodType.init(inst, def);\n util.defineLazy(inst._zod, \"values\", () => {\n const v = def.innerType._zod.values;\n return v ? new Set([...v].filter((x) => x !== undefined)) : undefined;\n });\n inst._zod.parse = (payload, ctx) => {\n const result = def.innerType._zod.run(payload, ctx);\n if (result instanceof Promise) {\n return result.then((result) => handleNonOptionalResult(result, inst));\n }\n return handleNonOptionalResult(result, inst);\n };\n});\nfunction handleNonOptionalResult(payload, inst) {\n if (!payload.issues.length && payload.value === undefined) {\n payload.issues.push({\n code: \"invalid_type\",\n expected: \"nonoptional\",\n input: payload.value,\n inst,\n });\n }\n return payload;\n}\nexport const $ZodSuccess = /*@__PURE__*/ core.$constructor(\"$ZodSuccess\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._zod.parse = (payload, ctx) => {\n if (ctx.direction === \"backward\") {\n throw new core.$ZodEncodeError(\"ZodSuccess\");\n }\n const result = def.innerType._zod.run(payload, ctx);\n if (result instanceof Promise) {\n return result.then((result) => {\n payload.value = result.issues.length === 0;\n return payload;\n });\n }\n payload.value = result.issues.length === 0;\n return payload;\n };\n});\nexport const $ZodCatch = /*@__PURE__*/ core.$constructor(\"$ZodCatch\", (inst, def) => {\n $ZodType.init(inst, def);\n util.defineLazy(inst._zod, \"optin\", () => def.innerType._zod.optin);\n util.defineLazy(inst._zod, \"optout\", () => def.innerType._zod.optout);\n util.defineLazy(inst._zod, \"values\", () => def.innerType._zod.values);\n inst._zod.parse = (payload, ctx) => {\n if (ctx.direction === \"backward\") {\n return def.innerType._zod.run(payload, ctx);\n }\n // Forward direction (decode): apply catch logic\n const result = def.innerType._zod.run(payload, ctx);\n if (result instanceof Promise) {\n return result.then((result) => {\n payload.value = result.value;\n if (result.issues.length) {\n payload.value = def.catchValue({\n ...payload,\n error: {\n issues: result.issues.map((iss) => util.finalizeIssue(iss, ctx, core.config())),\n },\n input: payload.value,\n });\n payload.issues = [];\n }\n return payload;\n });\n }\n payload.value = result.value;\n if (result.issues.length) {\n payload.value = def.catchValue({\n ...payload,\n error: {\n issues: result.issues.map((iss) => util.finalizeIssue(iss, ctx, core.config())),\n },\n input: payload.value,\n });\n payload.issues = [];\n }\n return payload;\n };\n});\nexport const $ZodNaN = /*@__PURE__*/ core.$constructor(\"$ZodNaN\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._zod.parse = (payload, _ctx) => {\n if (typeof payload.value !== \"number\" || !Number.isNaN(payload.value)) {\n payload.issues.push({\n input: payload.value,\n inst,\n expected: \"nan\",\n code: \"invalid_type\",\n });\n return payload;\n }\n return payload;\n };\n});\nexport const $ZodPipe = /*@__PURE__*/ core.$constructor(\"$ZodPipe\", (inst, def) => {\n $ZodType.init(inst, def);\n util.defineLazy(inst._zod, \"values\", () => def.in._zod.values);\n util.defineLazy(inst._zod, \"optin\", () => def.in._zod.optin);\n util.defineLazy(inst._zod, \"optout\", () => def.out._zod.optout);\n util.defineLazy(inst._zod, \"propValues\", () => def.in._zod.propValues);\n inst._zod.parse = (payload, ctx) => {\n if (ctx.direction === \"backward\") {\n const right = def.out._zod.run(payload, ctx);\n if (right instanceof Promise) {\n return right.then((right) => handlePipeResult(right, def.in, ctx));\n }\n return handlePipeResult(right, def.in, ctx);\n }\n const left = def.in._zod.run(payload, ctx);\n if (left instanceof Promise) {\n return left.then((left) => handlePipeResult(left, def.out, ctx));\n }\n return handlePipeResult(left, def.out, ctx);\n };\n});\nfunction handlePipeResult(left, next, ctx) {\n if (left.issues.length) {\n // prevent further checks\n left.aborted = true;\n return left;\n }\n return next._zod.run({ value: left.value, issues: left.issues }, ctx);\n}\nexport const $ZodCodec = /*@__PURE__*/ core.$constructor(\"$ZodCodec\", (inst, def) => {\n $ZodType.init(inst, def);\n util.defineLazy(inst._zod, \"values\", () => def.in._zod.values);\n util.defineLazy(inst._zod, \"optin\", () => def.in._zod.optin);\n util.defineLazy(inst._zod, \"optout\", () => def.out._zod.optout);\n util.defineLazy(inst._zod, \"propValues\", () => def.in._zod.propValues);\n inst._zod.parse = (payload, ctx) => {\n const direction = ctx.direction || \"forward\";\n if (direction === \"forward\") {\n const left = def.in._zod.run(payload, ctx);\n if (left instanceof Promise) {\n return left.then((left) => handleCodecAResult(left, def, ctx));\n }\n return handleCodecAResult(left, def, ctx);\n }\n else {\n const right = def.out._zod.run(payload, ctx);\n if (right instanceof Promise) {\n return right.then((right) => handleCodecAResult(right, def, ctx));\n }\n return handleCodecAResult(right, def, ctx);\n }\n };\n});\nfunction handleCodecAResult(result, def, ctx) {\n if (result.issues.length) {\n // prevent further checks\n result.aborted = true;\n return result;\n }\n const direction = ctx.direction || \"forward\";\n if (direction === \"forward\") {\n const transformed = def.transform(result.value, result);\n if (transformed instanceof Promise) {\n return transformed.then((value) => handleCodecTxResult(result, value, def.out, ctx));\n }\n return handleCodecTxResult(result, transformed, def.out, ctx);\n }\n else {\n const transformed = def.reverseTransform(result.value, result);\n if (transformed instanceof Promise) {\n return transformed.then((value) => handleCodecTxResult(result, value, def.in, ctx));\n }\n return handleCodecTxResult(result, transformed, def.in, ctx);\n }\n}\nfunction handleCodecTxResult(left, value, nextSchema, ctx) {\n // Check if transform added any issues\n if (left.issues.length) {\n left.aborted = true;\n return left;\n }\n return nextSchema._zod.run({ value, issues: left.issues }, ctx);\n}\nexport const $ZodReadonly = /*@__PURE__*/ core.$constructor(\"$ZodReadonly\", (inst, def) => {\n $ZodType.init(inst, def);\n util.defineLazy(inst._zod, \"propValues\", () => def.innerType._zod.propValues);\n util.defineLazy(inst._zod, \"values\", () => def.innerType._zod.values);\n util.defineLazy(inst._zod, \"optin\", () => def.innerType._zod.optin);\n util.defineLazy(inst._zod, \"optout\", () => def.innerType._zod.optout);\n inst._zod.parse = (payload, ctx) => {\n if (ctx.direction === \"backward\") {\n return def.innerType._zod.run(payload, ctx);\n }\n const result = def.innerType._zod.run(payload, ctx);\n if (result instanceof Promise) {\n return result.then(handleReadonlyResult);\n }\n return handleReadonlyResult(result);\n };\n});\nfunction handleReadonlyResult(payload) {\n payload.value = Object.freeze(payload.value);\n return payload;\n}\nexport const $ZodTemplateLiteral = /*@__PURE__*/ core.$constructor(\"$ZodTemplateLiteral\", (inst, def) => {\n $ZodType.init(inst, def);\n const regexParts = [];\n for (const part of def.parts) {\n if (typeof part === \"object\" && part !== null) {\n // is Zod schema\n if (!part._zod.pattern) {\n // if (!source)\n throw new Error(`Invalid template literal part, no pattern found: ${[...part._zod.traits].shift()}`);\n }\n const source = part._zod.pattern instanceof RegExp ? part._zod.pattern.source : part._zod.pattern;\n if (!source)\n throw new Error(`Invalid template literal part: ${part._zod.traits}`);\n const start = source.startsWith(\"^\") ? 1 : 0;\n const end = source.endsWith(\"$\") ? source.length - 1 : source.length;\n regexParts.push(source.slice(start, end));\n }\n else if (part === null || util.primitiveTypes.has(typeof part)) {\n regexParts.push(util.escapeRegex(`${part}`));\n }\n else {\n throw new Error(`Invalid template literal part: ${part}`);\n }\n }\n inst._zod.pattern = new RegExp(`^${regexParts.join(\"\")}$`);\n inst._zod.parse = (payload, _ctx) => {\n if (typeof payload.value !== \"string\") {\n payload.issues.push({\n input: payload.value,\n inst,\n expected: \"template_literal\",\n code: \"invalid_type\",\n });\n return payload;\n }\n inst._zod.pattern.lastIndex = 0;\n if (!inst._zod.pattern.test(payload.value)) {\n payload.issues.push({\n input: payload.value,\n inst,\n code: \"invalid_format\",\n format: def.format ?? \"template_literal\",\n pattern: inst._zod.pattern.source,\n });\n return payload;\n }\n return payload;\n };\n});\nexport const $ZodFunction = /*@__PURE__*/ core.$constructor(\"$ZodFunction\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._def = def;\n inst._zod.def = def;\n inst.implement = (func) => {\n if (typeof func !== \"function\") {\n throw new Error(\"implement() must be called with a function\");\n }\n return function (...args) {\n const parsedArgs = inst._def.input ? parse(inst._def.input, args) : args;\n const result = Reflect.apply(func, this, parsedArgs);\n if (inst._def.output) {\n return parse(inst._def.output, result);\n }\n return result;\n };\n };\n inst.implementAsync = (func) => {\n if (typeof func !== \"function\") {\n throw new Error(\"implementAsync() must be called with a function\");\n }\n return async function (...args) {\n const parsedArgs = inst._def.input ? await parseAsync(inst._def.input, args) : args;\n const result = await Reflect.apply(func, this, parsedArgs);\n if (inst._def.output) {\n return await parseAsync(inst._def.output, result);\n }\n return result;\n };\n };\n inst._zod.parse = (payload, _ctx) => {\n if (typeof payload.value !== \"function\") {\n payload.issues.push({\n code: \"invalid_type\",\n expected: \"function\",\n input: payload.value,\n inst,\n });\n return payload;\n }\n // Check if output is a promise type to determine if we should use async implementation\n const hasPromiseOutput = inst._def.output && inst._def.output._zod.def.type === \"promise\";\n if (hasPromiseOutput) {\n payload.value = inst.implementAsync(payload.value);\n }\n else {\n payload.value = inst.implement(payload.value);\n }\n return payload;\n };\n inst.input = (...args) => {\n const F = inst.constructor;\n if (Array.isArray(args[0])) {\n return new F({\n type: \"function\",\n input: new $ZodTuple({\n type: \"tuple\",\n items: args[0],\n rest: args[1],\n }),\n output: inst._def.output,\n });\n }\n return new F({\n type: \"function\",\n input: args[0],\n output: inst._def.output,\n });\n };\n inst.output = (output) => {\n const F = inst.constructor;\n return new F({\n type: \"function\",\n input: inst._def.input,\n output,\n });\n };\n return inst;\n});\nexport const $ZodPromise = /*@__PURE__*/ core.$constructor(\"$ZodPromise\", (inst, def) => {\n $ZodType.init(inst, def);\n inst._zod.parse = (payload, ctx) => {\n return Promise.resolve(payload.value).then((inner) => def.innerType._zod.run({ value: inner, issues: [] }, ctx));\n };\n});\nexport const $ZodLazy = /*@__PURE__*/ core.$constructor(\"$ZodLazy\", (inst, def) => {\n $ZodType.init(inst, def);\n // let _innerType!: any;\n // util.defineLazy(def, \"getter\", () => {\n // if (!_innerType) {\n // _innerType = def.getter();\n // }\n // return () => _innerType;\n // });\n util.defineLazy(inst._zod, \"innerType\", () => def.getter());\n util.defineLazy(inst._zod, \"pattern\", () => inst._zod.innerType._zod.pattern);\n util.defineLazy(inst._zod, \"propValues\", () => inst._zod.innerType._zod.propValues);\n util.defineLazy(inst._zod, \"optin\", () => inst._zod.innerType._zod.optin ?? undefined);\n util.defineLazy(inst._zod, \"optout\", () => inst._zod.innerType._zod.optout ?? undefined);\n inst._zod.parse = (payload, ctx) => {\n const inner = inst._zod.innerType;\n return inner._zod.run(payload, ctx);\n };\n});\nexport const $ZodCustom = /*@__PURE__*/ core.$constructor(\"$ZodCustom\", (inst, def) => {\n checks.$ZodCheck.init(inst, def);\n $ZodType.init(inst, def);\n inst._zod.parse = (payload, _) => {\n return payload;\n };\n inst._zod.check = (payload) => {\n const input = payload.value;\n const r = def.fn(input);\n if (r instanceof Promise) {\n return r.then((r) => handleRefineResult(r, payload, input, inst));\n }\n handleRefineResult(r, payload, input, inst);\n return;\n };\n});\nfunction handleRefineResult(result, payload, input, inst) {\n if (!result) {\n const _iss = {\n code: \"custom\",\n input,\n inst, // incorporates params.error into issue reporting\n path: [...(inst._zod.def.path ?? [])], // incorporates params.error into issue reporting\n continue: !inst._zod.def.abort,\n // params: inst._zod.def.params,\n };\n if (inst._zod.def.params)\n _iss.params = inst._zod.def.params;\n payload.issues.push(util.issue(_iss));\n }\n}\n","export const $output = Symbol(\"ZodOutput\");\nexport const $input = Symbol(\"ZodInput\");\nexport class $ZodRegistry {\n constructor() {\n this._map = new Map();\n this._idmap = new Map();\n }\n add(schema, ..._meta) {\n const meta = _meta[0];\n this._map.set(schema, meta);\n if (meta && typeof meta === \"object\" && \"id\" in meta) {\n if (this._idmap.has(meta.id)) {\n throw new Error(`ID ${meta.id} already exists in the registry`);\n }\n this._idmap.set(meta.id, schema);\n }\n return this;\n }\n clear() {\n this._map = new Map();\n this._idmap = new Map();\n return this;\n }\n remove(schema) {\n const meta = this._map.get(schema);\n if (meta && typeof meta === \"object\" && \"id\" in meta) {\n this._idmap.delete(meta.id);\n }\n this._map.delete(schema);\n return this;\n }\n get(schema) {\n // return this._map.get(schema) as any;\n // inherit metadata\n const p = schema._zod.parent;\n if (p) {\n const pm = { ...(this.get(p) ?? {}) };\n delete pm.id; // do not inherit id\n const f = { ...pm, ...this._map.get(schema) };\n return Object.keys(f).length ? f : undefined;\n }\n return this._map.get(schema);\n }\n has(schema) {\n return this._map.has(schema);\n }\n}\n// registries\nexport function registry() {\n return new $ZodRegistry();\n}\nexport const globalRegistry = /*@__PURE__*/ registry();\n","import * as checks from \"./checks.js\";\nimport * as schemas from \"./schemas.js\";\nimport * as util from \"./util.js\";\nexport function _string(Class, params) {\n return new Class({\n type: \"string\",\n ...util.normalizeParams(params),\n });\n}\nexport function _coercedString(Class, params) {\n return new Class({\n type: \"string\",\n coerce: true,\n ...util.normalizeParams(params),\n });\n}\nexport function _email(Class, params) {\n return new Class({\n type: \"string\",\n format: \"email\",\n check: \"string_format\",\n abort: false,\n ...util.normalizeParams(params),\n });\n}\nexport function _guid(Class, params) {\n return new Class({\n type: \"string\",\n format: \"guid\",\n check: \"string_format\",\n abort: false,\n ...util.normalizeParams(params),\n });\n}\nexport function _uuid(Class, params) {\n return new Class({\n type: \"string\",\n format: \"uuid\",\n check: \"string_format\",\n abort: false,\n ...util.normalizeParams(params),\n });\n}\nexport function _uuidv4(Class, params) {\n return new Class({\n type: \"string\",\n format: \"uuid\",\n check: \"string_format\",\n abort: false,\n version: \"v4\",\n ...util.normalizeParams(params),\n });\n}\nexport function _uuidv6(Class, params) {\n return new Class({\n type: \"string\",\n format: \"uuid\",\n check: \"string_format\",\n abort: false,\n version: \"v6\",\n ...util.normalizeParams(params),\n });\n}\nexport function _uuidv7(Class, params) {\n return new Class({\n type: \"string\",\n format: \"uuid\",\n check: \"string_format\",\n abort: false,\n version: \"v7\",\n ...util.normalizeParams(params),\n });\n}\nexport function _url(Class, params) {\n return new Class({\n type: \"string\",\n format: \"url\",\n check: \"string_format\",\n abort: false,\n ...util.normalizeParams(params),\n });\n}\nexport function _emoji(Class, params) {\n return new Class({\n type: \"string\",\n format: \"emoji\",\n check: \"string_format\",\n abort: false,\n ...util.normalizeParams(params),\n });\n}\nexport function _nanoid(Class, params) {\n return new Class({\n type: \"string\",\n format: \"nanoid\",\n check: \"string_format\",\n abort: false,\n ...util.normalizeParams(params),\n });\n}\nexport function _cuid(Class, params) {\n return new Class({\n type: \"string\",\n format: \"cuid\",\n check: \"string_format\",\n abort: false,\n ...util.normalizeParams(params),\n });\n}\nexport function _cuid2(Class, params) {\n return new Class({\n type: \"string\",\n format: \"cuid2\",\n check: \"string_format\",\n abort: false,\n ...util.normalizeParams(params),\n });\n}\nexport function _ulid(Class, params) {\n return new Class({\n type: \"string\",\n format: \"ulid\",\n check: \"string_format\",\n abort: false,\n ...util.normalizeParams(params),\n });\n}\nexport function _xid(Class, params) {\n return new Class({\n type: \"string\",\n format: \"xid\",\n check: \"string_format\",\n abort: false,\n ...util.normalizeParams(params),\n });\n}\nexport function _ksuid(Class, params) {\n return new Class({\n type: \"string\",\n format: \"ksuid\",\n check: \"string_format\",\n abort: false,\n ...util.normalizeParams(params),\n });\n}\nexport function _ipv4(Class, params) {\n return new Class({\n type: \"string\",\n format: \"ipv4\",\n check: \"string_format\",\n abort: false,\n ...util.normalizeParams(params),\n });\n}\nexport function _ipv6(Class, params) {\n return new Class({\n type: \"string\",\n format: \"ipv6\",\n check: \"string_format\",\n abort: false,\n ...util.normalizeParams(params),\n });\n}\nexport function _cidrv4(Class, params) {\n return new Class({\n type: \"string\",\n format: \"cidrv4\",\n check: \"string_format\",\n abort: false,\n ...util.normalizeParams(params),\n });\n}\nexport function _cidrv6(Class, params) {\n return new Class({\n type: \"string\",\n format: \"cidrv6\",\n check: \"string_format\",\n abort: false,\n ...util.normalizeParams(params),\n });\n}\nexport function _base64(Class, params) {\n return new Class({\n type: \"string\",\n format: \"base64\",\n check: \"string_format\",\n abort: false,\n ...util.normalizeParams(params),\n });\n}\nexport function _base64url(Class, params) {\n return new Class({\n type: \"string\",\n format: \"base64url\",\n check: \"string_format\",\n abort: false,\n ...util.normalizeParams(params),\n });\n}\nexport function _e164(Class, params) {\n return new Class({\n type: \"string\",\n format: \"e164\",\n check: \"string_format\",\n abort: false,\n ...util.normalizeParams(params),\n });\n}\nexport function _jwt(Class, params) {\n return new Class({\n type: \"string\",\n format: \"jwt\",\n check: \"string_format\",\n abort: false,\n ...util.normalizeParams(params),\n });\n}\nexport const TimePrecision = {\n Any: null,\n Minute: -1,\n Second: 0,\n Millisecond: 3,\n Microsecond: 6,\n};\nexport function _isoDateTime(Class, params) {\n return new Class({\n type: \"string\",\n format: \"datetime\",\n check: \"string_format\",\n offset: false,\n local: false,\n precision: null,\n ...util.normalizeParams(params),\n });\n}\nexport function _isoDate(Class, params) {\n return new Class({\n type: \"string\",\n format: \"date\",\n check: \"string_format\",\n ...util.normalizeParams(params),\n });\n}\nexport function _isoTime(Class, params) {\n return new Class({\n type: \"string\",\n format: \"time\",\n check: \"string_format\",\n precision: null,\n ...util.normalizeParams(params),\n });\n}\nexport function _isoDuration(Class, params) {\n return new Class({\n type: \"string\",\n format: \"duration\",\n check: \"string_format\",\n ...util.normalizeParams(params),\n });\n}\nexport function _number(Class, params) {\n return new Class({\n type: \"number\",\n checks: [],\n ...util.normalizeParams(params),\n });\n}\nexport function _coercedNumber(Class, params) {\n return new Class({\n type: \"number\",\n coerce: true,\n checks: [],\n ...util.normalizeParams(params),\n });\n}\nexport function _int(Class, params) {\n return new Class({\n type: \"number\",\n check: \"number_format\",\n abort: false,\n format: \"safeint\",\n ...util.normalizeParams(params),\n });\n}\nexport function _float32(Class, params) {\n return new Class({\n type: \"number\",\n check: \"number_format\",\n abort: false,\n format: \"float32\",\n ...util.normalizeParams(params),\n });\n}\nexport function _float64(Class, params) {\n return new Class({\n type: \"number\",\n check: \"number_format\",\n abort: false,\n format: \"float64\",\n ...util.normalizeParams(params),\n });\n}\nexport function _int32(Class, params) {\n return new Class({\n type: \"number\",\n check: \"number_format\",\n abort: false,\n format: \"int32\",\n ...util.normalizeParams(params),\n });\n}\nexport function _uint32(Class, params) {\n return new Class({\n type: \"number\",\n check: \"number_format\",\n abort: false,\n format: \"uint32\",\n ...util.normalizeParams(params),\n });\n}\nexport function _boolean(Class, params) {\n return new Class({\n type: \"boolean\",\n ...util.normalizeParams(params),\n });\n}\nexport function _coercedBoolean(Class, params) {\n return new Class({\n type: \"boolean\",\n coerce: true,\n ...util.normalizeParams(params),\n });\n}\nexport function _bigint(Class, params) {\n return new Class({\n type: \"bigint\",\n ...util.normalizeParams(params),\n });\n}\nexport function _coercedBigint(Class, params) {\n return new Class({\n type: \"bigint\",\n coerce: true,\n ...util.normalizeParams(params),\n });\n}\nexport function _int64(Class, params) {\n return new Class({\n type: \"bigint\",\n check: \"bigint_format\",\n abort: false,\n format: \"int64\",\n ...util.normalizeParams(params),\n });\n}\nexport function _uint64(Class, params) {\n return new Class({\n type: \"bigint\",\n check: \"bigint_format\",\n abort: false,\n format: \"uint64\",\n ...util.normalizeParams(params),\n });\n}\nexport function _symbol(Class, params) {\n return new Class({\n type: \"symbol\",\n ...util.normalizeParams(params),\n });\n}\nexport function _undefined(Class, params) {\n return new Class({\n type: \"undefined\",\n ...util.normalizeParams(params),\n });\n}\nexport function _null(Class, params) {\n return new Class({\n type: \"null\",\n ...util.normalizeParams(params),\n });\n}\nexport function _any(Class) {\n return new Class({\n type: \"any\",\n });\n}\nexport function _unknown(Class) {\n return new Class({\n type: \"unknown\",\n });\n}\nexport function _never(Class, params) {\n return new Class({\n type: \"never\",\n ...util.normalizeParams(params),\n });\n}\nexport function _void(Class, params) {\n return new Class({\n type: \"void\",\n ...util.normalizeParams(params),\n });\n}\nexport function _date(Class, params) {\n return new Class({\n type: \"date\",\n ...util.normalizeParams(params),\n });\n}\nexport function _coercedDate(Class, params) {\n return new Class({\n type: \"date\",\n coerce: true,\n ...util.normalizeParams(params),\n });\n}\nexport function _nan(Class, params) {\n return new Class({\n type: \"nan\",\n ...util.normalizeParams(params),\n });\n}\nexport function _lt(value, params) {\n return new checks.$ZodCheckLessThan({\n check: \"less_than\",\n ...util.normalizeParams(params),\n value,\n inclusive: false,\n });\n}\nexport function _lte(value, params) {\n return new checks.$ZodCheckLessThan({\n check: \"less_than\",\n ...util.normalizeParams(params),\n value,\n inclusive: true,\n });\n}\nexport { \n/** @deprecated Use `z.lte()` instead. */\n_lte as _max, };\nexport function _gt(value, params) {\n return new checks.$ZodCheckGreaterThan({\n check: \"greater_than\",\n ...util.normalizeParams(params),\n value,\n inclusive: false,\n });\n}\nexport function _gte(value, params) {\n return new checks.$ZodCheckGreaterThan({\n check: \"greater_than\",\n ...util.normalizeParams(params),\n value,\n inclusive: true,\n });\n}\nexport { \n/** @deprecated Use `z.gte()` instead. */\n_gte as _min, };\nexport function _positive(params) {\n return _gt(0, params);\n}\n// negative\nexport function _negative(params) {\n return _lt(0, params);\n}\n// nonpositive\nexport function _nonpositive(params) {\n return _lte(0, params);\n}\n// nonnegative\nexport function _nonnegative(params) {\n return _gte(0, params);\n}\nexport function _multipleOf(value, params) {\n return new checks.$ZodCheckMultipleOf({\n check: \"multiple_of\",\n ...util.normalizeParams(params),\n value,\n });\n}\nexport function _maxSize(maximum, params) {\n return new checks.$ZodCheckMaxSize({\n check: \"max_size\",\n ...util.normalizeParams(params),\n maximum,\n });\n}\nexport function _minSize(minimum, params) {\n return new checks.$ZodCheckMinSize({\n check: \"min_size\",\n ...util.normalizeParams(params),\n minimum,\n });\n}\nexport function _size(size, params) {\n return new checks.$ZodCheckSizeEquals({\n check: \"size_equals\",\n ...util.normalizeParams(params),\n size,\n });\n}\nexport function _maxLength(maximum, params) {\n const ch = new checks.$ZodCheckMaxLength({\n check: \"max_length\",\n ...util.normalizeParams(params),\n maximum,\n });\n return ch;\n}\nexport function _minLength(minimum, params) {\n return new checks.$ZodCheckMinLength({\n check: \"min_length\",\n ...util.normalizeParams(params),\n minimum,\n });\n}\nexport function _length(length, params) {\n return new checks.$ZodCheckLengthEquals({\n check: \"length_equals\",\n ...util.normalizeParams(params),\n length,\n });\n}\nexport function _regex(pattern, params) {\n return new checks.$ZodCheckRegex({\n check: \"string_format\",\n format: \"regex\",\n ...util.normalizeParams(params),\n pattern,\n });\n}\nexport function _lowercase(params) {\n return new checks.$ZodCheckLowerCase({\n check: \"string_format\",\n format: \"lowercase\",\n ...util.normalizeParams(params),\n });\n}\nexport function _uppercase(params) {\n return new checks.$ZodCheckUpperCase({\n check: \"string_format\",\n format: \"uppercase\",\n ...util.normalizeParams(params),\n });\n}\nexport function _includes(includes, params) {\n return new checks.$ZodCheckIncludes({\n check: \"string_format\",\n format: \"includes\",\n ...util.normalizeParams(params),\n includes,\n });\n}\nexport function _startsWith(prefix, params) {\n return new checks.$ZodCheckStartsWith({\n check: \"string_format\",\n format: \"starts_with\",\n ...util.normalizeParams(params),\n prefix,\n });\n}\nexport function _endsWith(suffix, params) {\n return new checks.$ZodCheckEndsWith({\n check: \"string_format\",\n format: \"ends_with\",\n ...util.normalizeParams(params),\n suffix,\n });\n}\nexport function _property(property, schema, params) {\n return new checks.$ZodCheckProperty({\n check: \"property\",\n property,\n schema,\n ...util.normalizeParams(params),\n });\n}\nexport function _mime(types, params) {\n return new checks.$ZodCheckMimeType({\n check: \"mime_type\",\n mime: types,\n ...util.normalizeParams(params),\n });\n}\nexport function _overwrite(tx) {\n return new checks.$ZodCheckOverwrite({\n check: \"overwrite\",\n tx,\n });\n}\n// normalize\nexport function _normalize(form) {\n return _overwrite((input) => input.normalize(form));\n}\n// trim\nexport function _trim() {\n return _overwrite((input) => input.trim());\n}\n// toLowerCase\nexport function _toLowerCase() {\n return _overwrite((input) => input.toLowerCase());\n}\n// toUpperCase\nexport function _toUpperCase() {\n return _overwrite((input) => input.toUpperCase());\n}\nexport function _array(Class, element, params) {\n return new Class({\n type: \"array\",\n element,\n // get element() {\n // return element;\n // },\n ...util.normalizeParams(params),\n });\n}\nexport function _union(Class, options, params) {\n return new Class({\n type: \"union\",\n options,\n ...util.normalizeParams(params),\n });\n}\nexport function _discriminatedUnion(Class, discriminator, options, params) {\n return new Class({\n type: \"union\",\n options,\n discriminator,\n ...util.normalizeParams(params),\n });\n}\nexport function _intersection(Class, left, right) {\n return new Class({\n type: \"intersection\",\n left,\n right,\n });\n}\n// export function _tuple(\n// Class: util.SchemaClass<schemas.$ZodTuple>,\n// items: [],\n// params?: string | $ZodTupleParams\n// ): schemas.$ZodTuple<[], null>;\nexport function _tuple(Class, items, _paramsOrRest, _params) {\n const hasRest = _paramsOrRest instanceof schemas.$ZodType;\n const params = hasRest ? _params : _paramsOrRest;\n const rest = hasRest ? _paramsOrRest : null;\n return new Class({\n type: \"tuple\",\n items,\n rest,\n ...util.normalizeParams(params),\n });\n}\nexport function _record(Class, keyType, valueType, params) {\n return new Class({\n type: \"record\",\n keyType,\n valueType,\n ...util.normalizeParams(params),\n });\n}\nexport function _map(Class, keyType, valueType, params) {\n return new Class({\n type: \"map\",\n keyType,\n valueType,\n ...util.normalizeParams(params),\n });\n}\nexport function _set(Class, valueType, params) {\n return new Class({\n type: \"set\",\n valueType,\n ...util.normalizeParams(params),\n });\n}\nexport function _enum(Class, values, params) {\n const entries = Array.isArray(values) ? Object.fromEntries(values.map((v) => [v, v])) : values;\n // if (Array.isArray(values)) {\n // for (const value of values) {\n // entries[value] = value;\n // }\n // } else {\n // Object.assign(entries, values);\n // }\n // const entries: util.EnumLike = {};\n // for (const val of values) {\n // entries[val] = val;\n // }\n return new Class({\n type: \"enum\",\n entries,\n ...util.normalizeParams(params),\n });\n}\n/** @deprecated This API has been merged into `z.enum()`. Use `z.enum()` instead.\n *\n * ```ts\n * enum Colors { red, green, blue }\n * z.enum(Colors);\n * ```\n */\nexport function _nativeEnum(Class, entries, params) {\n return new Class({\n type: \"enum\",\n entries,\n ...util.normalizeParams(params),\n });\n}\nexport function _literal(Class, value, params) {\n return new Class({\n type: \"literal\",\n values: Array.isArray(value) ? value : [value],\n ...util.normalizeParams(params),\n });\n}\nexport function _file(Class, params) {\n return new Class({\n type: \"file\",\n ...util.normalizeParams(params),\n });\n}\nexport function _transform(Class, fn) {\n return new Class({\n type: \"transform\",\n transform: fn,\n });\n}\nexport function _optional(Class, innerType) {\n return new Class({\n type: \"optional\",\n innerType,\n });\n}\nexport function _nullable(Class, innerType) {\n return new Class({\n type: \"nullable\",\n innerType,\n });\n}\nexport function _default(Class, innerType, defaultValue) {\n return new Class({\n type: \"default\",\n innerType,\n get defaultValue() {\n return typeof defaultValue === \"function\" ? defaultValue() : util.shallowClone(defaultValue);\n },\n });\n}\nexport function _nonoptional(Class, innerType, params) {\n return new Class({\n type: \"nonoptional\",\n innerType,\n ...util.normalizeParams(params),\n });\n}\nexport function _success(Class, innerType) {\n return new Class({\n type: \"success\",\n innerType,\n });\n}\nexport function _catch(Class, innerType, catchValue) {\n return new Class({\n type: \"catch\",\n innerType,\n catchValue: (typeof catchValue === \"function\" ? catchValue : () => catchValue),\n });\n}\nexport function _pipe(Class, in_, out) {\n return new Class({\n type: \"pipe\",\n in: in_,\n out,\n });\n}\nexport function _readonly(Class, innerType) {\n return new Class({\n type: \"readonly\",\n innerType,\n });\n}\nexport function _templateLiteral(Class, parts, params) {\n return new Class({\n type: \"template_literal\",\n parts,\n ...util.normalizeParams(params),\n });\n}\nexport function _lazy(Class, getter) {\n return new Class({\n type: \"lazy\",\n getter,\n });\n}\nexport function _promise(Class, innerType) {\n return new Class({\n type: \"promise\",\n innerType,\n });\n}\nexport function _custom(Class, fn, _params) {\n const norm = util.normalizeParams(_params);\n norm.abort ?? (norm.abort = true); // default to abort:false\n const schema = new Class({\n type: \"custom\",\n check: \"custom\",\n fn: fn,\n ...norm,\n });\n return schema;\n}\n// same as _custom but defaults to abort:false\nexport function _refine(Class, fn, _params) {\n const schema = new Class({\n type: \"custom\",\n check: \"custom\",\n fn: fn,\n ...util.normalizeParams(_params),\n });\n return schema;\n}\nexport function _superRefine(fn) {\n const ch = _check((payload) => {\n payload.addIssue = (issue) => {\n if (typeof issue === \"string\") {\n payload.issues.push(util.issue(issue, payload.value, ch._zod.def));\n }\n else {\n // for Zod 3 backwards compatibility\n const _issue = issue;\n if (_issue.fatal)\n _issue.continue = false;\n _issue.code ?? (_issue.code = \"custom\");\n _issue.input ?? (_issue.input = payload.value);\n _issue.inst ?? (_issue.inst = ch);\n _issue.continue ?? (_issue.continue = !ch._zod.def.abort); // abort is always undefined, so this is always true...\n payload.issues.push(util.issue(_issue));\n }\n };\n return fn(payload.value, payload);\n });\n return ch;\n}\nexport function _check(fn, params) {\n const ch = new checks.$ZodCheck({\n check: \"custom\",\n ...util.normalizeParams(params),\n });\n ch._zod.check = fn;\n return ch;\n}\nexport function _stringbool(Classes, _params) {\n const params = util.normalizeParams(_params);\n let truthyArray = params.truthy ?? [\"true\", \"1\", \"yes\", \"on\", \"y\", \"enabled\"];\n let falsyArray = params.falsy ?? [\"false\", \"0\", \"no\", \"off\", \"n\", \"disabled\"];\n if (params.case !== \"sensitive\") {\n truthyArray = truthyArray.map((v) => (typeof v === \"string\" ? v.toLowerCase() : v));\n falsyArray = falsyArray.map((v) => (typeof v === \"string\" ? v.toLowerCase() : v));\n }\n const truthySet = new Set(truthyArray);\n const falsySet = new Set(falsyArray);\n const _Codec = Classes.Codec ?? schemas.$ZodCodec;\n const _Boolean = Classes.Boolean ?? schemas.$ZodBoolean;\n const _String = Classes.String ?? schemas.$ZodString;\n const stringSchema = new _String({ type: \"string\", error: params.error });\n const booleanSchema = new _Boolean({ type: \"boolean\", error: params.error });\n const codec = new _Codec({\n type: \"pipe\",\n in: stringSchema,\n out: booleanSchema,\n transform: ((input, payload) => {\n let data = input;\n if (params.case !== \"sensitive\")\n data = data.toLowerCase();\n if (truthySet.has(data)) {\n return true;\n }\n else if (falsySet.has(data)) {\n return false;\n }\n else {\n payload.issues.push({\n code: \"invalid_value\",\n expected: \"stringbool\",\n values: [...truthySet, ...falsySet],\n input: payload.value,\n inst: codec,\n continue: false,\n });\n return {};\n }\n }),\n reverseTransform: ((input, _payload) => {\n if (input === true) {\n return truthyArray[0] || \"true\";\n }\n else {\n return falsyArray[0] || \"false\";\n }\n }),\n error: params.error,\n });\n return codec;\n}\nexport function _stringFormat(Class, format, fnOrRegex, _params = {}) {\n const params = util.normalizeParams(_params);\n const def = {\n ...util.normalizeParams(_params),\n check: \"string_format\",\n type: \"string\",\n format,\n fn: typeof fnOrRegex === \"function\" ? fnOrRegex : (val) => fnOrRegex.test(val),\n ...params,\n };\n if (fnOrRegex instanceof RegExp) {\n def.pattern = fnOrRegex;\n }\n const inst = new Class(def);\n return inst;\n}\n","import * as core from \"../core/index.js\";\nimport * as schemas from \"./schemas.js\";\nexport const ZodISODateTime = /*@__PURE__*/ core.$constructor(\"ZodISODateTime\", (inst, def) => {\n core.$ZodISODateTime.init(inst, def);\n schemas.ZodStringFormat.init(inst, def);\n});\nexport function datetime(params) {\n return core._isoDateTime(ZodISODateTime, params);\n}\nexport const ZodISODate = /*@__PURE__*/ core.$constructor(\"ZodISODate\", (inst, def) => {\n core.$ZodISODate.init(inst, def);\n schemas.ZodStringFormat.init(inst, def);\n});\nexport function date(params) {\n return core._isoDate(ZodISODate, params);\n}\nexport const ZodISOTime = /*@__PURE__*/ core.$constructor(\"ZodISOTime\", (inst, def) => {\n core.$ZodISOTime.init(inst, def);\n schemas.ZodStringFormat.init(inst, def);\n});\nexport function time(params) {\n return core._isoTime(ZodISOTime, params);\n}\nexport const ZodISODuration = /*@__PURE__*/ core.$constructor(\"ZodISODuration\", (inst, def) => {\n core.$ZodISODuration.init(inst, def);\n schemas.ZodStringFormat.init(inst, def);\n});\nexport function duration(params) {\n return core._isoDuration(ZodISODuration, params);\n}\n","import * as core from \"../core/index.js\";\nimport { $ZodError } from \"../core/index.js\";\nimport * as util from \"../core/util.js\";\nconst initializer = (inst, issues) => {\n $ZodError.init(inst, issues);\n inst.name = \"ZodError\";\n Object.defineProperties(inst, {\n format: {\n value: (mapper) => core.formatError(inst, mapper),\n // enumerable: false,\n },\n flatten: {\n value: (mapper) => core.flattenError(inst, mapper),\n // enumerable: false,\n },\n addIssue: {\n value: (issue) => {\n inst.issues.push(issue);\n inst.message = JSON.stringify(inst.issues, util.jsonStringifyReplacer, 2);\n },\n // enumerable: false,\n },\n addIssues: {\n value: (issues) => {\n inst.issues.push(...issues);\n inst.message = JSON.stringify(inst.issues, util.jsonStringifyReplacer, 2);\n },\n // enumerable: false,\n },\n isEmpty: {\n get() {\n return inst.issues.length === 0;\n },\n // enumerable: false,\n },\n });\n // Object.defineProperty(inst, \"isEmpty\", {\n // get() {\n // return inst.issues.length === 0;\n // },\n // });\n};\nexport const ZodError = core.$constructor(\"ZodError\", initializer);\nexport const ZodRealError = core.$constructor(\"ZodError\", initializer, {\n Parent: Error,\n});\n// /** @deprecated Use `z.core.$ZodErrorMapCtx` instead. */\n// export type ErrorMapCtx = core.$ZodErrorMapCtx;\n","import * as core from \"../core/index.js\";\nimport { ZodRealError } from \"./errors.js\";\nexport const parse = /* @__PURE__ */ core._parse(ZodRealError);\nexport const parseAsync = /* @__PURE__ */ core._parseAsync(ZodRealError);\nexport const safeParse = /* @__PURE__ */ core._safeParse(ZodRealError);\nexport const safeParseAsync = /* @__PURE__ */ core._safeParseAsync(ZodRealError);\n// Codec functions\nexport const encode = /* @__PURE__ */ core._encode(ZodRealError);\nexport const decode = /* @__PURE__ */ core._decode(ZodRealError);\nexport const encodeAsync = /* @__PURE__ */ core._encodeAsync(ZodRealError);\nexport const decodeAsync = /* @__PURE__ */ core._decodeAsync(ZodRealError);\nexport const safeEncode = /* @__PURE__ */ core._safeEncode(ZodRealError);\nexport const safeDecode = /* @__PURE__ */ core._safeDecode(ZodRealError);\nexport const safeEncodeAsync = /* @__PURE__ */ core._safeEncodeAsync(ZodRealError);\nexport const safeDecodeAsync = /* @__PURE__ */ core._safeDecodeAsync(ZodRealError);\n","import * as core from \"../core/index.js\";\nimport { util } from \"../core/index.js\";\nimport * as checks from \"./checks.js\";\nimport * as iso from \"./iso.js\";\nimport * as parse from \"./parse.js\";\nexport const ZodType = /*@__PURE__*/ core.$constructor(\"ZodType\", (inst, def) => {\n core.$ZodType.init(inst, def);\n inst.def = def;\n inst.type = def.type;\n Object.defineProperty(inst, \"_def\", { value: def });\n // base methods\n inst.check = (...checks) => {\n return inst.clone({\n ...def,\n checks: [\n ...(def.checks ?? []),\n ...checks.map((ch) => typeof ch === \"function\" ? { _zod: { check: ch, def: { check: \"custom\" }, onattach: [] } } : ch),\n ],\n }\n // { parent: true }\n );\n };\n inst.clone = (def, params) => core.clone(inst, def, params);\n inst.brand = () => inst;\n inst.register = ((reg, meta) => {\n reg.add(inst, meta);\n return inst;\n });\n // parsing\n inst.parse = (data, params) => parse.parse(inst, data, params, { callee: inst.parse });\n inst.safeParse = (data, params) => parse.safeParse(inst, data, params);\n inst.parseAsync = async (data, params) => parse.parseAsync(inst, data, params, { callee: inst.parseAsync });\n inst.safeParseAsync = async (data, params) => parse.safeParseAsync(inst, data, params);\n inst.spa = inst.safeParseAsync;\n // encoding/decoding\n inst.encode = (data, params) => parse.encode(inst, data, params);\n inst.decode = (data, params) => parse.decode(inst, data, params);\n inst.encodeAsync = async (data, params) => parse.encodeAsync(inst, data, params);\n inst.decodeAsync = async (data, params) => parse.decodeAsync(inst, data, params);\n inst.safeEncode = (data, params) => parse.safeEncode(inst, data, params);\n inst.safeDecode = (data, params) => parse.safeDecode(inst, data, params);\n inst.safeEncodeAsync = async (data, params) => parse.safeEncodeAsync(inst, data, params);\n inst.safeDecodeAsync = async (data, params) => parse.safeDecodeAsync(inst, data, params);\n // refinements\n inst.refine = (check, params) => inst.check(refine(check, params));\n inst.superRefine = (refinement) => inst.check(superRefine(refinement));\n inst.overwrite = (fn) => inst.check(checks.overwrite(fn));\n // wrappers\n inst.optional = () => optional(inst);\n inst.nullable = () => nullable(inst);\n inst.nullish = () => optional(nullable(inst));\n inst.nonoptional = (params) => nonoptional(inst, params);\n inst.array = () => array(inst);\n inst.or = (arg) => union([inst, arg]);\n inst.and = (arg) => intersection(inst, arg);\n inst.transform = (tx) => pipe(inst, transform(tx));\n inst.default = (def) => _default(inst, def);\n inst.prefault = (def) => prefault(inst, def);\n // inst.coalesce = (def, params) => coalesce(inst, def, params);\n inst.catch = (params) => _catch(inst, params);\n inst.pipe = (target) => pipe(inst, target);\n inst.readonly = () => readonly(inst);\n // meta\n inst.describe = (description) => {\n const cl = inst.clone();\n core.globalRegistry.add(cl, { description });\n return cl;\n };\n Object.defineProperty(inst, \"description\", {\n get() {\n return core.globalRegistry.get(inst)?.description;\n },\n configurable: true,\n });\n inst.meta = (...args) => {\n if (args.length === 0) {\n return core.globalRegistry.get(inst);\n }\n const cl = inst.clone();\n core.globalRegistry.add(cl, args[0]);\n return cl;\n };\n // helpers\n inst.isOptional = () => inst.safeParse(undefined).success;\n inst.isNullable = () => inst.safeParse(null).success;\n return inst;\n});\n/** @internal */\nexport const _ZodString = /*@__PURE__*/ core.$constructor(\"_ZodString\", (inst, def) => {\n core.$ZodString.init(inst, def);\n ZodType.init(inst, def);\n const bag = inst._zod.bag;\n inst.format = bag.format ?? null;\n inst.minLength = bag.minimum ?? null;\n inst.maxLength = bag.maximum ?? null;\n // validations\n inst.regex = (...args) => inst.check(checks.regex(...args));\n inst.includes = (...args) => inst.check(checks.includes(...args));\n inst.startsWith = (...args) => inst.check(checks.startsWith(...args));\n inst.endsWith = (...args) => inst.check(checks.endsWith(...args));\n inst.min = (...args) => inst.check(checks.minLength(...args));\n inst.max = (...args) => inst.check(checks.maxLength(...args));\n inst.length = (...args) => inst.check(checks.length(...args));\n inst.nonempty = (...args) => inst.check(checks.minLength(1, ...args));\n inst.lowercase = (params) => inst.check(checks.lowercase(params));\n inst.uppercase = (params) => inst.check(checks.uppercase(params));\n // transforms\n inst.trim = () => inst.check(checks.trim());\n inst.normalize = (...args) => inst.check(checks.normalize(...args));\n inst.toLowerCase = () => inst.check(checks.toLowerCase());\n inst.toUpperCase = () => inst.check(checks.toUpperCase());\n});\nexport const ZodString = /*@__PURE__*/ core.$constructor(\"ZodString\", (inst, def) => {\n core.$ZodString.init(inst, def);\n _ZodString.init(inst, def);\n inst.email = (params) => inst.check(core._email(ZodEmail, params));\n inst.url = (params) => inst.check(core._url(ZodURL, params));\n inst.jwt = (params) => inst.check(core._jwt(ZodJWT, params));\n inst.emoji = (params) => inst.check(core._emoji(ZodEmoji, params));\n inst.guid = (params) => inst.check(core._guid(ZodGUID, params));\n inst.uuid = (params) => inst.check(core._uuid(ZodUUID, params));\n inst.uuidv4 = (params) => inst.check(core._uuidv4(ZodUUID, params));\n inst.uuidv6 = (params) => inst.check(core._uuidv6(ZodUUID, params));\n inst.uuidv7 = (params) => inst.check(core._uuidv7(ZodUUID, params));\n inst.nanoid = (params) => inst.check(core._nanoid(ZodNanoID, params));\n inst.guid = (params) => inst.check(core._guid(ZodGUID, params));\n inst.cuid = (params) => inst.check(core._cuid(ZodCUID, params));\n inst.cuid2 = (params) => inst.check(core._cuid2(ZodCUID2, params));\n inst.ulid = (params) => inst.check(core._ulid(ZodULID, params));\n inst.base64 = (params) => inst.check(core._base64(ZodBase64, params));\n inst.base64url = (params) => inst.check(core._base64url(ZodBase64URL, params));\n inst.xid = (params) => inst.check(core._xid(ZodXID, params));\n inst.ksuid = (params) => inst.check(core._ksuid(ZodKSUID, params));\n inst.ipv4 = (params) => inst.check(core._ipv4(ZodIPv4, params));\n inst.ipv6 = (params) => inst.check(core._ipv6(ZodIPv6, params));\n inst.cidrv4 = (params) => inst.check(core._cidrv4(ZodCIDRv4, params));\n inst.cidrv6 = (params) => inst.check(core._cidrv6(ZodCIDRv6, params));\n inst.e164 = (params) => inst.check(core._e164(ZodE164, params));\n // iso\n inst.datetime = (params) => inst.check(iso.datetime(params));\n inst.date = (params) => inst.check(iso.date(params));\n inst.time = (params) => inst.check(iso.time(params));\n inst.duration = (params) => inst.check(iso.duration(params));\n});\nexport function string(params) {\n return core._string(ZodString, params);\n}\nexport const ZodStringFormat = /*@__PURE__*/ core.$constructor(\"ZodStringFormat\", (inst, def) => {\n core.$ZodStringFormat.init(inst, def);\n _ZodString.init(inst, def);\n});\nexport const ZodEmail = /*@__PURE__*/ core.$constructor(\"ZodEmail\", (inst, def) => {\n // ZodStringFormat.init(inst, def);\n core.$ZodEmail.init(inst, def);\n ZodStringFormat.init(inst, def);\n});\nexport function email(params) {\n return core._email(ZodEmail, params);\n}\nexport const ZodGUID = /*@__PURE__*/ core.$constructor(\"ZodGUID\", (inst, def) => {\n // ZodStringFormat.init(inst, def);\n core.$ZodGUID.init(inst, def);\n ZodStringFormat.init(inst, def);\n});\nexport function guid(params) {\n return core._guid(ZodGUID, params);\n}\nexport const ZodUUID = /*@__PURE__*/ core.$constructor(\"ZodUUID\", (inst, def) => {\n // ZodStringFormat.init(inst, def);\n core.$ZodUUID.init(inst, def);\n ZodStringFormat.init(inst, def);\n});\nexport function uuid(params) {\n return core._uuid(ZodUUID, params);\n}\nexport function uuidv4(params) {\n return core._uuidv4(ZodUUID, params);\n}\n// ZodUUIDv6\nexport function uuidv6(params) {\n return core._uuidv6(ZodUUID, params);\n}\n// ZodUUIDv7\nexport function uuidv7(params) {\n return core._uuidv7(ZodUUID, params);\n}\nexport const ZodURL = /*@__PURE__*/ core.$constructor(\"ZodURL\", (inst, def) => {\n // ZodStringFormat.init(inst, def);\n core.$ZodURL.init(inst, def);\n ZodStringFormat.init(inst, def);\n});\nexport function url(params) {\n return core._url(ZodURL, params);\n}\nexport function httpUrl(params) {\n return core._url(ZodURL, {\n protocol: /^https?$/,\n hostname: core.regexes.domain,\n ...util.normalizeParams(params),\n });\n}\nexport const ZodEmoji = /*@__PURE__*/ core.$constructor(\"ZodEmoji\", (inst, def) => {\n // ZodStringFormat.init(inst, def);\n core.$ZodEmoji.init(inst, def);\n ZodStringFormat.init(inst, def);\n});\nexport function emoji(params) {\n return core._emoji(ZodEmoji, params);\n}\nexport const ZodNanoID = /*@__PURE__*/ core.$constructor(\"ZodNanoID\", (inst, def) => {\n // ZodStringFormat.init(inst, def);\n core.$ZodNanoID.init(inst, def);\n ZodStringFormat.init(inst, def);\n});\nexport function nanoid(params) {\n return core._nanoid(ZodNanoID, params);\n}\nexport const ZodCUID = /*@__PURE__*/ core.$constructor(\"ZodCUID\", (inst, def) => {\n // ZodStringFormat.init(inst, def);\n core.$ZodCUID.init(inst, def);\n ZodStringFormat.init(inst, def);\n});\nexport function cuid(params) {\n return core._cuid(ZodCUID, params);\n}\nexport const ZodCUID2 = /*@__PURE__*/ core.$constructor(\"ZodCUID2\", (inst, def) => {\n // ZodStringFormat.init(inst, def);\n core.$ZodCUID2.init(inst, def);\n ZodStringFormat.init(inst, def);\n});\nexport function cuid2(params) {\n return core._cuid2(ZodCUID2, params);\n}\nexport const ZodULID = /*@__PURE__*/ core.$constructor(\"ZodULID\", (inst, def) => {\n // ZodStringFormat.init(inst, def);\n core.$ZodULID.init(inst, def);\n ZodStringFormat.init(inst, def);\n});\nexport function ulid(params) {\n return core._ulid(ZodULID, params);\n}\nexport const ZodXID = /*@__PURE__*/ core.$constructor(\"ZodXID\", (inst, def) => {\n // ZodStringFormat.init(inst, def);\n core.$ZodXID.init(inst, def);\n ZodStringFormat.init(inst, def);\n});\nexport function xid(params) {\n return core._xid(ZodXID, params);\n}\nexport const ZodKSUID = /*@__PURE__*/ core.$constructor(\"ZodKSUID\", (inst, def) => {\n // ZodStringFormat.init(inst, def);\n core.$ZodKSUID.init(inst, def);\n ZodStringFormat.init(inst, def);\n});\nexport function ksuid(params) {\n return core._ksuid(ZodKSUID, params);\n}\nexport const ZodIPv4 = /*@__PURE__*/ core.$constructor(\"ZodIPv4\", (inst, def) => {\n // ZodStringFormat.init(inst, def);\n core.$ZodIPv4.init(inst, def);\n ZodStringFormat.init(inst, def);\n});\nexport function ipv4(params) {\n return core._ipv4(ZodIPv4, params);\n}\nexport const ZodIPv6 = /*@__PURE__*/ core.$constructor(\"ZodIPv6\", (inst, def) => {\n // ZodStringFormat.init(inst, def);\n core.$ZodIPv6.init(inst, def);\n ZodStringFormat.init(inst, def);\n});\nexport function ipv6(params) {\n return core._ipv6(ZodIPv6, params);\n}\nexport const ZodCIDRv4 = /*@__PURE__*/ core.$constructor(\"ZodCIDRv4\", (inst, def) => {\n core.$ZodCIDRv4.init(inst, def);\n ZodStringFormat.init(inst, def);\n});\nexport function cidrv4(params) {\n return core._cidrv4(ZodCIDRv4, params);\n}\nexport const ZodCIDRv6 = /*@__PURE__*/ core.$constructor(\"ZodCIDRv6\", (inst, def) => {\n core.$ZodCIDRv6.init(inst, def);\n ZodStringFormat.init(inst, def);\n});\nexport function cidrv6(params) {\n return core._cidrv6(ZodCIDRv6, params);\n}\nexport const ZodBase64 = /*@__PURE__*/ core.$constructor(\"ZodBase64\", (inst, def) => {\n // ZodStringFormat.init(inst, def);\n core.$ZodBase64.init(inst, def);\n ZodStringFormat.init(inst, def);\n});\nexport function base64(params) {\n return core._base64(ZodBase64, params);\n}\nexport const ZodBase64URL = /*@__PURE__*/ core.$constructor(\"ZodBase64URL\", (inst, def) => {\n // ZodStringFormat.init(inst, def);\n core.$ZodBase64URL.init(inst, def);\n ZodStringFormat.init(inst, def);\n});\nexport function base64url(params) {\n return core._base64url(ZodBase64URL, params);\n}\nexport const ZodE164 = /*@__PURE__*/ core.$constructor(\"ZodE164\", (inst, def) => {\n // ZodStringFormat.init(inst, def);\n core.$ZodE164.init(inst, def);\n ZodStringFormat.init(inst, def);\n});\nexport function e164(params) {\n return core._e164(ZodE164, params);\n}\nexport const ZodJWT = /*@__PURE__*/ core.$constructor(\"ZodJWT\", (inst, def) => {\n // ZodStringFormat.init(inst, def);\n core.$ZodJWT.init(inst, def);\n ZodStringFormat.init(inst, def);\n});\nexport function jwt(params) {\n return core._jwt(ZodJWT, params);\n}\nexport const ZodCustomStringFormat = /*@__PURE__*/ core.$constructor(\"ZodCustomStringFormat\", (inst, def) => {\n // ZodStringFormat.init(inst, def);\n core.$ZodCustomStringFormat.init(inst, def);\n ZodStringFormat.init(inst, def);\n});\nexport function stringFormat(format, fnOrRegex, _params = {}) {\n return core._stringFormat(ZodCustomStringFormat, format, fnOrRegex, _params);\n}\nexport function hostname(_params) {\n return core._stringFormat(ZodCustomStringFormat, \"hostname\", core.regexes.hostname, _params);\n}\nexport function hex(_params) {\n return core._stringFormat(ZodCustomStringFormat, \"hex\", core.regexes.hex, _params);\n}\nexport function hash(alg, params) {\n const enc = params?.enc ?? \"hex\";\n const format = `${alg}_${enc}`;\n const regex = core.regexes[format];\n if (!regex)\n throw new Error(`Unrecognized hash format: ${format}`);\n return core._stringFormat(ZodCustomStringFormat, format, regex, params);\n}\nexport const ZodNumber = /*@__PURE__*/ core.$constructor(\"ZodNumber\", (inst, def) => {\n core.$ZodNumber.init(inst, def);\n ZodType.init(inst, def);\n inst.gt = (value, params) => inst.check(checks.gt(value, params));\n inst.gte = (value, params) => inst.check(checks.gte(value, params));\n inst.min = (value, params) => inst.check(checks.gte(value, params));\n inst.lt = (value, params) => inst.check(checks.lt(value, params));\n inst.lte = (value, params) => inst.check(checks.lte(value, params));\n inst.max = (value, params) => inst.check(checks.lte(value, params));\n inst.int = (params) => inst.check(int(params));\n inst.safe = (params) => inst.check(int(params));\n inst.positive = (params) => inst.check(checks.gt(0, params));\n inst.nonnegative = (params) => inst.check(checks.gte(0, params));\n inst.negative = (params) => inst.check(checks.lt(0, params));\n inst.nonpositive = (params) => inst.check(checks.lte(0, params));\n inst.multipleOf = (value, params) => inst.check(checks.multipleOf(value, params));\n inst.step = (value, params) => inst.check(checks.multipleOf(value, params));\n // inst.finite = (params) => inst.check(core.finite(params));\n inst.finite = () => inst;\n const bag = inst._zod.bag;\n inst.minValue =\n Math.max(bag.minimum ?? Number.NEGATIVE_INFINITY, bag.exclusiveMinimum ?? Number.NEGATIVE_INFINITY) ?? null;\n inst.maxValue =\n Math.min(bag.maximum ?? Number.POSITIVE_INFINITY, bag.exclusiveMaximum ?? Number.POSITIVE_INFINITY) ?? null;\n inst.isInt = (bag.format ?? \"\").includes(\"int\") || Number.isSafeInteger(bag.multipleOf ?? 0.5);\n inst.isFinite = true;\n inst.format = bag.format ?? null;\n});\nexport function number(params) {\n return core._number(ZodNumber, params);\n}\nexport const ZodNumberFormat = /*@__PURE__*/ core.$constructor(\"ZodNumberFormat\", (inst, def) => {\n core.$ZodNumberFormat.init(inst, def);\n ZodNumber.init(inst, def);\n});\nexport function int(params) {\n return core._int(ZodNumberFormat, params);\n}\nexport function float32(params) {\n return core._float32(ZodNumberFormat, params);\n}\nexport function float64(params) {\n return core._float64(ZodNumberFormat, params);\n}\nexport function int32(params) {\n return core._int32(ZodNumberFormat, params);\n}\nexport function uint32(params) {\n return core._uint32(ZodNumberFormat, params);\n}\nexport const ZodBoolean = /*@__PURE__*/ core.$constructor(\"ZodBoolean\", (inst, def) => {\n core.$ZodBoolean.init(inst, def);\n ZodType.init(inst, def);\n});\nexport function boolean(params) {\n return core._boolean(ZodBoolean, params);\n}\nexport const ZodBigInt = /*@__PURE__*/ core.$constructor(\"ZodBigInt\", (inst, def) => {\n core.$ZodBigInt.init(inst, def);\n ZodType.init(inst, def);\n inst.gte = (value, params) => inst.check(checks.gte(value, params));\n inst.min = (value, params) => inst.check(checks.gte(value, params));\n inst.gt = (value, params) => inst.check(checks.gt(value, params));\n inst.gte = (value, params) => inst.check(checks.gte(value, params));\n inst.min = (value, params) => inst.check(checks.gte(value, params));\n inst.lt = (value, params) => inst.check(checks.lt(value, params));\n inst.lte = (value, params) => inst.check(checks.lte(value, params));\n inst.max = (value, params) => inst.check(checks.lte(value, params));\n inst.positive = (params) => inst.check(checks.gt(BigInt(0), params));\n inst.negative = (params) => inst.check(checks.lt(BigInt(0), params));\n inst.nonpositive = (params) => inst.check(checks.lte(BigInt(0), params));\n inst.nonnegative = (params) => inst.check(checks.gte(BigInt(0), params));\n inst.multipleOf = (value, params) => inst.check(checks.multipleOf(value, params));\n const bag = inst._zod.bag;\n inst.minValue = bag.minimum ?? null;\n inst.maxValue = bag.maximum ?? null;\n inst.format = bag.format ?? null;\n});\nexport function bigint(params) {\n return core._bigint(ZodBigInt, params);\n}\nexport const ZodBigIntFormat = /*@__PURE__*/ core.$constructor(\"ZodBigIntFormat\", (inst, def) => {\n core.$ZodBigIntFormat.init(inst, def);\n ZodBigInt.init(inst, def);\n});\n// int64\nexport function int64(params) {\n return core._int64(ZodBigIntFormat, params);\n}\n// uint64\nexport function uint64(params) {\n return core._uint64(ZodBigIntFormat, params);\n}\nexport const ZodSymbol = /*@__PURE__*/ core.$constructor(\"ZodSymbol\", (inst, def) => {\n core.$ZodSymbol.init(inst, def);\n ZodType.init(inst, def);\n});\nexport function symbol(params) {\n return core._symbol(ZodSymbol, params);\n}\nexport const ZodUndefined = /*@__PURE__*/ core.$constructor(\"ZodUndefined\", (inst, def) => {\n core.$ZodUndefined.init(inst, def);\n ZodType.init(inst, def);\n});\nfunction _undefined(params) {\n return core._undefined(ZodUndefined, params);\n}\nexport { _undefined as undefined };\nexport const ZodNull = /*@__PURE__*/ core.$constructor(\"ZodNull\", (inst, def) => {\n core.$ZodNull.init(inst, def);\n ZodType.init(inst, def);\n});\nfunction _null(params) {\n return core._null(ZodNull, params);\n}\nexport { _null as null };\nexport const ZodAny = /*@__PURE__*/ core.$constructor(\"ZodAny\", (inst, def) => {\n core.$ZodAny.init(inst, def);\n ZodType.init(inst, def);\n});\nexport function any() {\n return core._any(ZodAny);\n}\nexport const ZodUnknown = /*@__PURE__*/ core.$constructor(\"ZodUnknown\", (inst, def) => {\n core.$ZodUnknown.init(inst, def);\n ZodType.init(inst, def);\n});\nexport function unknown() {\n return core._unknown(ZodUnknown);\n}\nexport const ZodNever = /*@__PURE__*/ core.$constructor(\"ZodNever\", (inst, def) => {\n core.$ZodNever.init(inst, def);\n ZodType.init(inst, def);\n});\nexport function never(params) {\n return core._never(ZodNever, params);\n}\nexport const ZodVoid = /*@__PURE__*/ core.$constructor(\"ZodVoid\", (inst, def) => {\n core.$ZodVoid.init(inst, def);\n ZodType.init(inst, def);\n});\nfunction _void(params) {\n return core._void(ZodVoid, params);\n}\nexport { _void as void };\nexport const ZodDate = /*@__PURE__*/ core.$constructor(\"ZodDate\", (inst, def) => {\n core.$ZodDate.init(inst, def);\n ZodType.init(inst, def);\n inst.min = (value, params) => inst.check(checks.gte(value, params));\n inst.max = (value, params) => inst.check(checks.lte(value, params));\n const c = inst._zod.bag;\n inst.minDate = c.minimum ? new Date(c.minimum) : null;\n inst.maxDate = c.maximum ? new Date(c.maximum) : null;\n});\nexport function date(params) {\n return core._date(ZodDate, params);\n}\nexport const ZodArray = /*@__PURE__*/ core.$constructor(\"ZodArray\", (inst, def) => {\n core.$ZodArray.init(inst, def);\n ZodType.init(inst, def);\n inst.element = def.element;\n inst.min = (minLength, params) => inst.check(checks.minLength(minLength, params));\n inst.nonempty = (params) => inst.check(checks.minLength(1, params));\n inst.max = (maxLength, params) => inst.check(checks.maxLength(maxLength, params));\n inst.length = (len, params) => inst.check(checks.length(len, params));\n inst.unwrap = () => inst.element;\n});\nexport function array(element, params) {\n return core._array(ZodArray, element, params);\n}\n// .keyof\nexport function keyof(schema) {\n const shape = schema._zod.def.shape;\n return _enum(Object.keys(shape));\n}\nexport const ZodObject = /*@__PURE__*/ core.$constructor(\"ZodObject\", (inst, def) => {\n core.$ZodObjectJIT.init(inst, def);\n ZodType.init(inst, def);\n util.defineLazy(inst, \"shape\", () => def.shape);\n inst.keyof = () => _enum(Object.keys(inst._zod.def.shape));\n inst.catchall = (catchall) => inst.clone({ ...inst._zod.def, catchall: catchall });\n inst.passthrough = () => inst.clone({ ...inst._zod.def, catchall: unknown() });\n inst.loose = () => inst.clone({ ...inst._zod.def, catchall: unknown() });\n inst.strict = () => inst.clone({ ...inst._zod.def, catchall: never() });\n inst.strip = () => inst.clone({ ...inst._zod.def, catchall: undefined });\n inst.extend = (incoming) => {\n return util.extend(inst, incoming);\n };\n inst.safeExtend = (incoming) => {\n return util.safeExtend(inst, incoming);\n };\n inst.merge = (other) => util.merge(inst, other);\n inst.pick = (mask) => util.pick(inst, mask);\n inst.omit = (mask) => util.omit(inst, mask);\n inst.partial = (...args) => util.partial(ZodOptional, inst, args[0]);\n inst.required = (...args) => util.required(ZodNonOptional, inst, args[0]);\n});\nexport function object(shape, params) {\n const def = {\n type: \"object\",\n get shape() {\n util.assignProp(this, \"shape\", shape ? util.objectClone(shape) : {});\n return this.shape;\n },\n ...util.normalizeParams(params),\n };\n return new ZodObject(def);\n}\n// strictObject\nexport function strictObject(shape, params) {\n return new ZodObject({\n type: \"object\",\n get shape() {\n util.assignProp(this, \"shape\", util.objectClone(shape));\n return this.shape;\n },\n catchall: never(),\n ...util.normalizeParams(params),\n });\n}\n// looseObject\nexport function looseObject(shape, params) {\n return new ZodObject({\n type: \"object\",\n get shape() {\n util.assignProp(this, \"shape\", util.objectClone(shape));\n return this.shape;\n },\n catchall: unknown(),\n ...util.normalizeParams(params),\n });\n}\nexport const ZodUnion = /*@__PURE__*/ core.$constructor(\"ZodUnion\", (inst, def) => {\n core.$ZodUnion.init(inst, def);\n ZodType.init(inst, def);\n inst.options = def.options;\n});\nexport function union(options, params) {\n return new ZodUnion({\n type: \"union\",\n options: options,\n ...util.normalizeParams(params),\n });\n}\nexport const ZodDiscriminatedUnion = /*@__PURE__*/ core.$constructor(\"ZodDiscriminatedUnion\", (inst, def) => {\n ZodUnion.init(inst, def);\n core.$ZodDiscriminatedUnion.init(inst, def);\n});\nexport function discriminatedUnion(discriminator, options, params) {\n // const [options, params] = args;\n return new ZodDiscriminatedUnion({\n type: \"union\",\n options,\n discriminator,\n ...util.normalizeParams(params),\n });\n}\nexport const ZodIntersection = /*@__PURE__*/ core.$constructor(\"ZodIntersection\", (inst, def) => {\n core.$ZodIntersection.init(inst, def);\n ZodType.init(inst, def);\n});\nexport function intersection(left, right) {\n return new ZodIntersection({\n type: \"intersection\",\n left: left,\n right: right,\n });\n}\nexport const ZodTuple = /*@__PURE__*/ core.$constructor(\"ZodTuple\", (inst, def) => {\n core.$ZodTuple.init(inst, def);\n ZodType.init(inst, def);\n inst.rest = (rest) => inst.clone({\n ...inst._zod.def,\n rest: rest,\n });\n});\nexport function tuple(items, _paramsOrRest, _params) {\n const hasRest = _paramsOrRest instanceof core.$ZodType;\n const params = hasRest ? _params : _paramsOrRest;\n const rest = hasRest ? _paramsOrRest : null;\n return new ZodTuple({\n type: \"tuple\",\n items: items,\n rest,\n ...util.normalizeParams(params),\n });\n}\nexport const ZodRecord = /*@__PURE__*/ core.$constructor(\"ZodRecord\", (inst, def) => {\n core.$ZodRecord.init(inst, def);\n ZodType.init(inst, def);\n inst.keyType = def.keyType;\n inst.valueType = def.valueType;\n});\nexport function record(keyType, valueType, params) {\n return new ZodRecord({\n type: \"record\",\n keyType,\n valueType: valueType,\n ...util.normalizeParams(params),\n });\n}\n// type alksjf = core.output<core.$ZodRecordKey>;\nexport function partialRecord(keyType, valueType, params) {\n const k = core.clone(keyType);\n k._zod.values = undefined;\n return new ZodRecord({\n type: \"record\",\n keyType: k,\n valueType: valueType,\n ...util.normalizeParams(params),\n });\n}\nexport const ZodMap = /*@__PURE__*/ core.$constructor(\"ZodMap\", (inst, def) => {\n core.$ZodMap.init(inst, def);\n ZodType.init(inst, def);\n inst.keyType = def.keyType;\n inst.valueType = def.valueType;\n});\nexport function map(keyType, valueType, params) {\n return new ZodMap({\n type: \"map\",\n keyType: keyType,\n valueType: valueType,\n ...util.normalizeParams(params),\n });\n}\nexport const ZodSet = /*@__PURE__*/ core.$constructor(\"ZodSet\", (inst, def) => {\n core.$ZodSet.init(inst, def);\n ZodType.init(inst, def);\n inst.min = (...args) => inst.check(core._minSize(...args));\n inst.nonempty = (params) => inst.check(core._minSize(1, params));\n inst.max = (...args) => inst.check(core._maxSize(...args));\n inst.size = (...args) => inst.check(core._size(...args));\n});\nexport function set(valueType, params) {\n return new ZodSet({\n type: \"set\",\n valueType: valueType,\n ...util.normalizeParams(params),\n });\n}\nexport const ZodEnum = /*@__PURE__*/ core.$constructor(\"ZodEnum\", (inst, def) => {\n core.$ZodEnum.init(inst, def);\n ZodType.init(inst, def);\n inst.enum = def.entries;\n inst.options = Object.values(def.entries);\n const keys = new Set(Object.keys(def.entries));\n inst.extract = (values, params) => {\n const newEntries = {};\n for (const value of values) {\n if (keys.has(value)) {\n newEntries[value] = def.entries[value];\n }\n else\n throw new Error(`Key ${value} not found in enum`);\n }\n return new ZodEnum({\n ...def,\n checks: [],\n ...util.normalizeParams(params),\n entries: newEntries,\n });\n };\n inst.exclude = (values, params) => {\n const newEntries = { ...def.entries };\n for (const value of values) {\n if (keys.has(value)) {\n delete newEntries[value];\n }\n else\n throw new Error(`Key ${value} not found in enum`);\n }\n return new ZodEnum({\n ...def,\n checks: [],\n ...util.normalizeParams(params),\n entries: newEntries,\n });\n };\n});\nfunction _enum(values, params) {\n const entries = Array.isArray(values) ? Object.fromEntries(values.map((v) => [v, v])) : values;\n return new ZodEnum({\n type: \"enum\",\n entries,\n ...util.normalizeParams(params),\n });\n}\nexport { _enum as enum };\n/** @deprecated This API has been merged into `z.enum()`. Use `z.enum()` instead.\n *\n * ```ts\n * enum Colors { red, green, blue }\n * z.enum(Colors);\n * ```\n */\nexport function nativeEnum(entries, params) {\n return new ZodEnum({\n type: \"enum\",\n entries,\n ...util.normalizeParams(params),\n });\n}\nexport const ZodLiteral = /*@__PURE__*/ core.$constructor(\"ZodLiteral\", (inst, def) => {\n core.$ZodLiteral.init(inst, def);\n ZodType.init(inst, def);\n inst.values = new Set(def.values);\n Object.defineProperty(inst, \"value\", {\n get() {\n if (def.values.length > 1) {\n throw new Error(\"This schema contains multiple valid literal values. Use `.values` instead.\");\n }\n return def.values[0];\n },\n });\n});\nexport function literal(value, params) {\n return new ZodLiteral({\n type: \"literal\",\n values: Array.isArray(value) ? value : [value],\n ...util.normalizeParams(params),\n });\n}\nexport const ZodFile = /*@__PURE__*/ core.$constructor(\"ZodFile\", (inst, def) => {\n core.$ZodFile.init(inst, def);\n ZodType.init(inst, def);\n inst.min = (size, params) => inst.check(core._minSize(size, params));\n inst.max = (size, params) => inst.check(core._maxSize(size, params));\n inst.mime = (types, params) => inst.check(core._mime(Array.isArray(types) ? types : [types], params));\n});\nexport function file(params) {\n return core._file(ZodFile, params);\n}\nexport const ZodTransform = /*@__PURE__*/ core.$constructor(\"ZodTransform\", (inst, def) => {\n core.$ZodTransform.init(inst, def);\n ZodType.init(inst, def);\n inst._zod.parse = (payload, _ctx) => {\n if (_ctx.direction === \"backward\") {\n throw new core.$ZodEncodeError(inst.constructor.name);\n }\n payload.addIssue = (issue) => {\n if (typeof issue === \"string\") {\n payload.issues.push(util.issue(issue, payload.value, def));\n }\n else {\n // for Zod 3 backwards compatibility\n const _issue = issue;\n if (_issue.fatal)\n _issue.continue = false;\n _issue.code ?? (_issue.code = \"custom\");\n _issue.input ?? (_issue.input = payload.value);\n _issue.inst ?? (_issue.inst = inst);\n // _issue.continue ??= true;\n payload.issues.push(util.issue(_issue));\n }\n };\n const output = def.transform(payload.value, payload);\n if (output instanceof Promise) {\n return output.then((output) => {\n payload.value = output;\n return payload;\n });\n }\n payload.value = output;\n return payload;\n };\n});\nexport function transform(fn) {\n return new ZodTransform({\n type: \"transform\",\n transform: fn,\n });\n}\nexport const ZodOptional = /*@__PURE__*/ core.$constructor(\"ZodOptional\", (inst, def) => {\n core.$ZodOptional.init(inst, def);\n ZodType.init(inst, def);\n inst.unwrap = () => inst._zod.def.innerType;\n});\nexport function optional(innerType) {\n return new ZodOptional({\n type: \"optional\",\n innerType: innerType,\n });\n}\nexport const ZodNullable = /*@__PURE__*/ core.$constructor(\"ZodNullable\", (inst, def) => {\n core.$ZodNullable.init(inst, def);\n ZodType.init(inst, def);\n inst.unwrap = () => inst._zod.def.innerType;\n});\nexport function nullable(innerType) {\n return new ZodNullable({\n type: \"nullable\",\n innerType: innerType,\n });\n}\n// nullish\nexport function nullish(innerType) {\n return optional(nullable(innerType));\n}\nexport const ZodDefault = /*@__PURE__*/ core.$constructor(\"ZodDefault\", (inst, def) => {\n core.$ZodDefault.init(inst, def);\n ZodType.init(inst, def);\n inst.unwrap = () => inst._zod.def.innerType;\n inst.removeDefault = inst.unwrap;\n});\nexport function _default(innerType, defaultValue) {\n return new ZodDefault({\n type: \"default\",\n innerType: innerType,\n get defaultValue() {\n return typeof defaultValue === \"function\" ? defaultValue() : util.shallowClone(defaultValue);\n },\n });\n}\nexport const ZodPrefault = /*@__PURE__*/ core.$constructor(\"ZodPrefault\", (inst, def) => {\n core.$ZodPrefault.init(inst, def);\n ZodType.init(inst, def);\n inst.unwrap = () => inst._zod.def.innerType;\n});\nexport function prefault(innerType, defaultValue) {\n return new ZodPrefault({\n type: \"prefault\",\n innerType: innerType,\n get defaultValue() {\n return typeof defaultValue === \"function\" ? defaultValue() : util.shallowClone(defaultValue);\n },\n });\n}\nexport const ZodNonOptional = /*@__PURE__*/ core.$constructor(\"ZodNonOptional\", (inst, def) => {\n core.$ZodNonOptional.init(inst, def);\n ZodType.init(inst, def);\n inst.unwrap = () => inst._zod.def.innerType;\n});\nexport function nonoptional(innerType, params) {\n return new ZodNonOptional({\n type: \"nonoptional\",\n innerType: innerType,\n ...util.normalizeParams(params),\n });\n}\nexport const ZodSuccess = /*@__PURE__*/ core.$constructor(\"ZodSuccess\", (inst, def) => {\n core.$ZodSuccess.init(inst, def);\n ZodType.init(inst, def);\n inst.unwrap = () => inst._zod.def.innerType;\n});\nexport function success(innerType) {\n return new ZodSuccess({\n type: \"success\",\n innerType: innerType,\n });\n}\nexport const ZodCatch = /*@__PURE__*/ core.$constructor(\"ZodCatch\", (inst, def) => {\n core.$ZodCatch.init(inst, def);\n ZodType.init(inst, def);\n inst.unwrap = () => inst._zod.def.innerType;\n inst.removeCatch = inst.unwrap;\n});\nfunction _catch(innerType, catchValue) {\n return new ZodCatch({\n type: \"catch\",\n innerType: innerType,\n catchValue: (typeof catchValue === \"function\" ? catchValue : () => catchValue),\n });\n}\nexport { _catch as catch };\nexport const ZodNaN = /*@__PURE__*/ core.$constructor(\"ZodNaN\", (inst, def) => {\n core.$ZodNaN.init(inst, def);\n ZodType.init(inst, def);\n});\nexport function nan(params) {\n return core._nan(ZodNaN, params);\n}\nexport const ZodPipe = /*@__PURE__*/ core.$constructor(\"ZodPipe\", (inst, def) => {\n core.$ZodPipe.init(inst, def);\n ZodType.init(inst, def);\n inst.in = def.in;\n inst.out = def.out;\n});\nexport function pipe(in_, out) {\n return new ZodPipe({\n type: \"pipe\",\n in: in_,\n out: out,\n // ...util.normalizeParams(params),\n });\n}\nexport const ZodCodec = /*@__PURE__*/ core.$constructor(\"ZodCodec\", (inst, def) => {\n ZodPipe.init(inst, def);\n core.$ZodCodec.init(inst, def);\n});\nexport function codec(in_, out, params) {\n return new ZodCodec({\n type: \"pipe\",\n in: in_,\n out: out,\n transform: params.decode,\n reverseTransform: params.encode,\n });\n}\nexport const ZodReadonly = /*@__PURE__*/ core.$constructor(\"ZodReadonly\", (inst, def) => {\n core.$ZodReadonly.init(inst, def);\n ZodType.init(inst, def);\n inst.unwrap = () => inst._zod.def.innerType;\n});\nexport function readonly(innerType) {\n return new ZodReadonly({\n type: \"readonly\",\n innerType: innerType,\n });\n}\nexport const ZodTemplateLiteral = /*@__PURE__*/ core.$constructor(\"ZodTemplateLiteral\", (inst, def) => {\n core.$ZodTemplateLiteral.init(inst, def);\n ZodType.init(inst, def);\n});\nexport function templateLiteral(parts, params) {\n return new ZodTemplateLiteral({\n type: \"template_literal\",\n parts,\n ...util.normalizeParams(params),\n });\n}\nexport const ZodLazy = /*@__PURE__*/ core.$constructor(\"ZodLazy\", (inst, def) => {\n core.$ZodLazy.init(inst, def);\n ZodType.init(inst, def);\n inst.unwrap = () => inst._zod.def.getter();\n});\nexport function lazy(getter) {\n return new ZodLazy({\n type: \"lazy\",\n getter: getter,\n });\n}\nexport const ZodPromise = /*@__PURE__*/ core.$constructor(\"ZodPromise\", (inst, def) => {\n core.$ZodPromise.init(inst, def);\n ZodType.init(inst, def);\n inst.unwrap = () => inst._zod.def.innerType;\n});\nexport function promise(innerType) {\n return new ZodPromise({\n type: \"promise\",\n innerType: innerType,\n });\n}\nexport const ZodFunction = /*@__PURE__*/ core.$constructor(\"ZodFunction\", (inst, def) => {\n core.$ZodFunction.init(inst, def);\n ZodType.init(inst, def);\n});\nexport function _function(params) {\n return new ZodFunction({\n type: \"function\",\n input: Array.isArray(params?.input) ? tuple(params?.input) : (params?.input ?? array(unknown())),\n output: params?.output ?? unknown(),\n });\n}\nexport { _function as function };\nexport const ZodCustom = /*@__PURE__*/ core.$constructor(\"ZodCustom\", (inst, def) => {\n core.$ZodCustom.init(inst, def);\n ZodType.init(inst, def);\n});\n// custom checks\nexport function check(fn) {\n const ch = new core.$ZodCheck({\n check: \"custom\",\n // ...util.normalizeParams(params),\n });\n ch._zod.check = fn;\n return ch;\n}\nexport function custom(fn, _params) {\n return core._custom(ZodCustom, fn ?? (() => true), _params);\n}\nexport function refine(fn, _params = {}) {\n return core._refine(ZodCustom, fn, _params);\n}\n// superRefine\nexport function superRefine(fn) {\n return core._superRefine(fn);\n}\nfunction _instanceof(cls, params = {\n error: `Input not instance of ${cls.name}`,\n}) {\n const inst = new ZodCustom({\n type: \"custom\",\n check: \"custom\",\n fn: (data) => data instanceof cls,\n abort: true,\n ...util.normalizeParams(params),\n });\n inst._zod.bag.Class = cls;\n return inst;\n}\nexport { _instanceof as instanceof };\n// stringbool\nexport const stringbool = (...args) => core._stringbool({\n Codec: ZodCodec,\n Boolean: ZodBoolean,\n String: ZodString,\n}, ...args);\nexport function json(params) {\n const jsonSchema = lazy(() => {\n return union([string(params), number(), boolean(), _null(), array(jsonSchema), record(string(), jsonSchema)]);\n });\n return jsonSchema;\n}\n// preprocess\n// /** @deprecated Use `z.pipe()` and `z.transform()` instead. */\nexport function preprocess(fn, schema) {\n return pipe(transform(fn), schema);\n}\n","import * as core from \"../core/index.js\";\nimport * as schemas from \"./schemas.js\";\nexport function string(params) {\n return core._coercedString(schemas.ZodString, params);\n}\nexport function number(params) {\n return core._coercedNumber(schemas.ZodNumber, params);\n}\nexport function boolean(params) {\n return core._coercedBoolean(schemas.ZodBoolean, params);\n}\nexport function bigint(params) {\n return core._coercedBigint(schemas.ZodBigInt, params);\n}\nexport function date(params) {\n return core._coercedDate(schemas.ZodDate, params);\n}\n","import { FieldValues, Path, UseFormReturn } from 'react-hook-form';\nimport * as z from 'zod';\n\n/**\n * Processes a form submission using Zod for validation.\n */\nexport function validateFormWithZod<T extends FieldValues>(\n formMethods: UseFormReturn<T>,\n schema: z.ZodType<T>,\n data: any\n) {\n const result = schema.safeParse(data);\n\n if (!result.success) {\n result.error.issues.forEach((err) => {\n const fieldName = err.path.join('.');\n const fieldState = formMethods.getFieldState(fieldName as Path<T>);\n\n if (fieldState) {\n // Set the error on the form\n formMethods.setError(fieldName as Path<T>, {\n type: 'manual',\n message: err.message,\n });\n } else {\n formMethods.setError('root', {\n type: 'manual',\n message: err.message,\n });\n }\n });\n\n return null;\n }\n\n return result.data;\n}\n\n/**\n * Preprocesses a form input to convert string values to numbers.\n */\nexport const preprocessNumber = (schema: z.ZodType<number>) => {\n return z.preprocess((val) => {\n if (!val) {\n return undefined;\n }\n\n if (typeof val === 'string') {\n const parsed = Number(val);\n return isNaN(parsed) ? val : parsed;\n }\n\n return val;\n }, schema);\n};\n\n/**\n * Preprocesses a form input to convert string values to dates.\n */\nexport const preprocessDate = (schema: z.ZodType<Date>) => {\n return z.preprocess((val) => {\n if (!val) {\n return undefined;\n }\n\n let date: Date;\n\n if (typeof val === 'string') {\n date = new Date(val);\n }\n\n if (val instanceof Date) {\n date = val;\n }\n\n if (date) {\n date.setUTCHours(0, 0, 0, 0); // Remove time component in UTC\n return date;\n }\n\n return val;\n }, schema);\n};\n\nexport const requireString = (max: number) =>\n z\n .string()\n .min(1, { error: 'Required' })\n .max(max, `Maximum length is ${max} characters`);\n\nexport const requireEmail = () =>\n z.email('Invalid email address').min(1, 'Required');\n\nexport const requirePositiveAmount = () =>\n preprocessNumber(\n z.number('Valid amount required').positive('Positive amount required')\n );\n\nexport const requireFutureDate = () =>\n preprocessDate(\n z\n .date('Valid date required')\n .min(new Date(), 'Date must be in the future')\n );\n\nexport const maxString = (max: number) =>\n z.string().max(max, `Maximum length is ${max} characters`);\n","import {\n maxString,\n requireString,\n requireEmail,\n requireFutureDate,\n requirePositiveAmount,\n} from '../../utils/zodUtils';\nimport * as z from 'zod';\nimport { ELogCategory, ELogSeverity, ELogType } from './GiftCardLogs.enum';\n\n/**\n * Schema for validating international addresses.\n */\nexport const InternationalAddressSchema = z.object({\n address1: requireString(100), // Primary address line\n address2: maxString(100).optional(), // Secondary address line (optional)\n city: requireString(50), // City name\n state: maxString(50).optional(), // State/Province (optional for some countries)\n postcode: maxString(20).optional(), // Postal/ZIP code (optional for some countries)\n country: requireString(50), // Country name\n});\n\n/**\n * Basic details of a gift card that can be shared with customers.\n */\nexport type IGiftCardDTO = {\n code: string;\n amount: number;\n balance: number;\n expiry: Date;\n giverFirstName: string;\n giverLastName: string;\n cardHolder: string;\n message?: string | null;\n};\n\n/**\n * Details of a gift card that can be shared with admins.\n */\nexport type IAdminGiftCardDTO = IGiftCardDTO & {\n createdBy?: string | null;\n giverEmail: string;\n giverPhone: string;\n recipientEmail: string;\n recipientPhone?: string | null;\n notes?: string | null;\n deletedDate?: string | null;\n paymentStatus?: EGiftCardPaymentStatus | null;\n};\n\n/**\n * Extended details of a gift card for the details view in admin.\n */\nexport type IAdminGiftCardDetailsDTO = IAdminGiftCardDTO & {\n createdAt: Date;\n};\n\n/**\n * Base schema for validating a new gift card.\n */\nexport const BaseGiftCardSchema = z.object({\n amount: requirePositiveAmount(),\n message: maxString(500).nullish(),\n\n giverFirstName: requireString(50),\n giverLastName: requireString(50),\n giverEmail: requireEmail(),\n giverPhone: requireString(31),\n giverAddress: InternationalAddressSchema, // Use the international address schema\n\n cardHolder: requireString(101),\n recipientFirstName: maxString(50).nullish(),\n recipientLastName: maxString(50).nullish(),\n recipientEmail: z.email('Invalid email address').nullish(),\n recipientPhone: maxString(31).nullish(),\n});\n\n/**\n * Schema for validated adding a new gift card from admin.\n */\nexport const AddGiftCardSchema = BaseGiftCardSchema.extend({\n expiry: requireFutureDate(),\n notes: maxString(500).nullish(),\n});\n\nexport type IAddGiftCardRequest = z.infer<typeof AddGiftCardSchema>;\n\nexport type IAddGiftCardResponse = IAdminGiftCardDTO & {\n password: string;\n};\n\n/**\n * Schema for validating editing an existing gift card from admin.\n * Note: Edits the balance (not amount), as amount represents the original purchase value.\n */\nexport const EditGiftCardSchema = z.object({\n balance: requirePositiveAmount(),\n expiry: requireFutureDate(),\n message: maxString(500).nullish(),\n notes: maxString(500).nullish(),\n\n giverFirstName: requireString(50),\n giverLastName: requireString(50),\n giverEmail: requireEmail(),\n giverPhone: requireString(31),\n\n cardHolder: requireString(101),\n recipientEmail: z.email('Invalid email address').nullish(),\n recipientPhone: maxString(31).nullish(),\n});\n\nexport type IEditGiftCardRequest = z.infer<typeof EditGiftCardSchema>;\n\n/**\n * Payment type enum - defines how payment is processed\n */\nexport enum EGiftCardPaymentType {\n Passthrough = 'Passthrough', // VGS tokenization\n PaymentProcessor = 'PaymentProcessor', // Adyen or other payment processors\n}\n\n/**\n * Schema for validating purchasing a gift card.\n */\nexport const CreatePaymentSessionSchema = z.object({\n companyId: z.number().int().positive(),\n amount: requirePositiveAmount(),\n currency: requireString(3).default('AUD'),\n});\n\nexport type ICreatePaymentSessionRequest = z.infer<\n typeof CreatePaymentSessionSchema\n>;\n\nexport type ICreatePaymentSessionResponse = {\n sessionId: string;\n sessionData: string;\n clientKey: string;\n};\n\n// Payment processor data (Adyen)\nexport const PaymentProcessorDataSchema = z.object({\n sessionId: requireString(100),\n resultCode: requireString(50),\n pspReference: maxString(100).optional(),\n});\n\nexport type IPaymentProcessorData = z.infer<typeof PaymentProcessorDataSchema>;\n\n// Passthrough payment data (VGS)\nexport const PassthroughPaymentDataSchema = z.object({\n cardHolder: requireString(100),\n cardNumberToken: maxString(200),\n cardCvcToken: maxString(200),\n cardExpiry: maxString(5), // MM/YY format\n});\n\nexport type IPassthroughPaymentData = z.infer<\n typeof PassthroughPaymentDataSchema\n>;\n\nexport const PurchaseGiftCardSchema = BaseGiftCardSchema.extend({\n companyId: z.number().int().positive(),\n sendViaEmail: z.boolean().default(true),\n\n // Payment processor data (Adyen) - provided if using payment processor\n payment: PaymentProcessorDataSchema.optional(),\n\n // Passthrough payment data (VGS) - provided if using passthrough tokenization\n passthroughPayment: PassthroughPaymentDataSchema.optional(),\n});\n\nexport type IPurchaseGiftCardRequest = z.infer<typeof PurchaseGiftCardSchema>;\n\nexport type IPurchasePaymentData =\n | { payment: IPaymentProcessorData }\n | { passthroughPayment: IPassthroughPaymentData };\n\nexport type IPurchaseGiftCardResponse = IGiftCardDTO & {\n password: string | null;\n};\n\nexport const RefundGiftCardSchema = z.object({\n giftCardId: z.number().int().positive(),\n reason: maxString(500).optional(),\n});\n\nexport type IRefundGiftCardRequest = z.infer<typeof RefundGiftCardSchema>;\n\nexport type IRefundGiftCardResponse = {\n success: boolean;\n refundReference: string;\n};\n\nexport const ValidateGiftCardSchema = z.object({\n companyId: z.number().int().positive().nullish(),\n code: requireString(10),\n password: requireString(10),\n});\n\nexport type IValidateGiftCardRequest = z.infer<typeof ValidateGiftCardSchema>;\n\nexport const RedeemGiftCardSchema = ValidateGiftCardSchema.extend({\n amount: requirePositiveAmount(),\n description: requireString(200),\n});\n\nexport type IRedeemGiftCardRequest = z.infer<typeof RedeemGiftCardSchema>;\n\nexport enum EGiftCardPaymentProvider {\n Adyen = 'Adyen',\n}\n\nexport enum EGiftCardPaymentStatus {\n Pending = 'Pending',\n Authorized = 'Authorized',\n Captured = 'Captured',\n Failed = 'Failed',\n Refunded = 'Refunded',\n}\n\nexport enum AdyenResultCode {\n Authorised = 'Authorised',\n Refused = 'Refused',\n Cancelled = 'Cancelled',\n Pending = 'Pending',\n Received = 'Received',\n Error = 'Error',\n IdentifyShopper = 'IdentifyShopper',\n ChallengeShopper = 'ChallengeShopper',\n}\n\nexport enum AdyenEventCode {\n AUTHORISATION = 'AUTHORISATION',\n CAPTURE = 'CAPTURE',\n REFUND = 'REFUND',\n CANCELLATION = 'CANCELLATION',\n REFUND_FAILED = 'REFUND_FAILED',\n CAPTURE_FAILED = 'CAPTURE_FAILED',\n}\n\nexport enum EGiftCardTransactionType {\n Purchase = 'Purchase',\n Redemption = 'Redemption',\n Adjustment = 'Adjustment',\n}\n\nexport enum ETransactionStatus {\n Pending = 'Pending',\n Complete = 'Complete',\n Cancelled = 'Cancelled',\n Expired = 'Expired',\n}\n\n/**\n * Basic details of a gift card transaction that can be shared with customers.\n */\nexport type IGiftCardTransactionDTO = {\n id: string;\n giftCard: IGiftCardDTO;\n date: Date;\n type: EGiftCardTransactionType;\n amount: number;\n};\n\n/**\n * Extended transaction details for admin view including description and running balance.\n */\nexport type IAdminGiftCardTransactionDTO = IGiftCardTransactionDTO & {\n description: string;\n runningBalance: number;\n status: ETransactionStatus;\n};\n\n/**\n * Details of a preauthorised redemption including the token necessary for completion.\n */\nexport type IGiftCardPreauthorisationDTO = IGiftCardTransactionDTO & {\n token: string;\n expiry: Date;\n};\n\n/**\n * Schema for validating a request to complete a preauthorised gift card transaction.\n */\nexport const CompleteGiftCardTransactionSchema = z.object({\n code: requireString(10),\n token: requireString(128),\n});\n\nexport type ICompleteGiftCardTransactionRequest = z.infer<\n typeof CompleteGiftCardTransactionSchema\n>;\n\n/**\n * Schema for validating a request to cancel a preauthorised gift card transaction.\n */\nexport const CancelGiftCardTransactionSchema = z.object({\n companyId: z.number().int().positive(),\n code: requireString(10),\n token: requireString(128),\n});\n\nexport type ICancelGiftCardTransactionRequest = z.infer<\n typeof CancelGiftCardTransactionSchema\n>;\n\n/**\n * Log entry details for admin.\n */\nexport type IAdminGiftCardLogDTO = {\n id: number;\n date: Date;\n severity: ELogSeverity;\n category: ELogCategory;\n type: ELogType;\n message?: string | null;\n ip?: string | null;\n url?: string | null;\n username?: string | null;\n userId?: string | null;\n changedFields?: Record<string, { old: string; new: string }> | null;\n};\n\n/**\n * Schema for getting company gift card config (path parameters).\n */\nexport const GetCompanyConfigSchema = z.object({\n companyId: z.coerce.number().int().positive(),\n});\n\nexport type IGetCompanyConfigRequest = z.infer<typeof GetCompanyConfigSchema>;\n\n/**\n * Schema for updating company gift card config.\n */\nexport const UpdateCompanyConfigSchema = z.object({\n giftCardPaymentType: z.enum([\n EGiftCardPaymentType.Passthrough,\n EGiftCardPaymentType.PaymentProcessor,\n ]),\n});\n\nexport type IUpdateCompanyConfigRequest = z.infer<\n typeof UpdateCompanyConfigSchema\n>;\n\n/**\n * Schema for updating Adyen configuration.\n * apiKey and webhookHmacKey are optional for updates (only required on create).\n */\nexport const UpdateAdyenConfigSchema = z.object({\n merchantAccount: requireString(100),\n clientKey: requireString(100),\n apiKey: maxString(200).optional(),\n webhookHmacKey: maxString(200).optional(),\n});\n\nexport type IUpdateAdyenConfigRequest = z.infer<typeof UpdateAdyenConfigSchema>;\n","import * as z from 'zod';\n\nexport const RefreshGiftCardTokenSchema = z.object({\n grant_type: z.string().readonly().default('refresh_token'),\n client_id: z.uuid(),\n client_secret: z.string(),\n refresh_token: z.string(),\n scope: z.string().optional(),\n});\n\nexport type IRefreshGiftCardTokenRequest = z.infer<\n typeof RefreshGiftCardTokenSchema\n>;\n\n/**\n * Response from the Gift Card Engine when refreshing a token.\n */\nexport type IGiftCardTokenResponse = {\n token_type: string;\n access_token: string;\n refresh_token?: string;\n expires_in: number;\n scope: string;\n user?: string;\n};\n\n/**\n * Request to register a new user on the gift card admin.\n */\nexport const RegisterGiftCardAdminSchema = z.object({\n email: z.email(),\n firstName: z.string().max(100).optional(),\n lastName: z.string().max(100).optional(),\n phone: z.string().max(20).optional(),\n scopes: z.array(z.string()).optional(),\n});\n\nexport type IRegisterGiftCardAdminRequest = z.infer<\n typeof RegisterGiftCardAdminSchema\n>;\n","/**\n * Log severity levels.\n */\nexport enum ELogSeverity {\n Critical = 'Critical',\n Error = 'Error',\n Warn = 'Warn',\n Info = 'Info',\n}\n\n/**\n * Log category types.\n */\nexport enum ELogCategory {\n Debug = 'Diagnostics',\n Security = 'Security',\n Audit = 'Audit',\n}\n\n/**\n * Log event types.\n */\nexport enum ELogType {\n General = 'General',\n Authenticated = 'Token Authenticated',\n Unauthorized = 'Unauthorized Access',\n RefreshToken = 'Refresh Token Created',\n AccessToken = 'Access Token Created',\n Revoked = 'Token Revoked',\n UserCreated = 'User Created',\n UserLinked = 'User Linked to Company',\n Purchase = 'Gift Card Purchased',\n Payment = 'Payment',\n Email = 'Email Delivery',\n Transaction = 'Gift Card Transaction',\n}\n","import { IRoomstayMemberBooking } from '@types';\n\n/**\n * Calculates the total AFTER tax of the booking.\n *\n * @param reservation IRoomstayMemberBooking\n */\nexport const calculateTotalForMemberBooking = (reservation: IRoomstayMemberBooking) => {\n let total = 0;\n\n const itinerary = Object.values(reservation.itinerary);\n\n for (const item of itinerary) {\n const nightsArray = Object.keys(item.nights);\n\n for (const night of nightsArray) {\n total += item.nights[night].total;\n }\n }\n\n return total;\n};\n","/*!\r\n * decimal.js v10.4.3\r\n * An arbitrary-precision Decimal type for JavaScript.\r\n * https://github.com/MikeMcl/decimal.js\r\n * Copyright (c) 2022 Michael Mclaughlin <M8ch88l@gmail.com>\r\n * MIT Licence\r\n */\r\n\r\n\r\n// ----------------------------------- EDITABLE DEFAULTS ------------------------------------ //\r\n\r\n\r\n // The maximum exponent magnitude.\r\n // The limit on the value of `toExpNeg`, `toExpPos`, `minE` and `maxE`.\r\nvar EXP_LIMIT = 9e15, // 0 to 9e15\r\n\r\n // The limit on the value of `precision`, and on the value of the first argument to\r\n // `toDecimalPlaces`, `toExponential`, `toFixed`, `toPrecision` and `toSignificantDigits`.\r\n MAX_DIGITS = 1e9, // 0 to 1e9\r\n\r\n // Base conversion alphabet.\r\n NUMERALS = '0123456789abcdef',\r\n\r\n // The natural logarithm of 10 (1025 digits).\r\n LN10 = '2.3025850929940456840179914546843642076011014886287729760333279009675726096773524802359972050895982983419677840422862486334095254650828067566662873690987816894829072083255546808437998948262331985283935053089653777326288461633662222876982198867465436674744042432743651550489343149393914796194044002221051017141748003688084012647080685567743216228355220114804663715659121373450747856947683463616792101806445070648000277502684916746550586856935673420670581136429224554405758925724208241314695689016758940256776311356919292033376587141660230105703089634572075440370847469940168269282808481184289314848524948644871927809676271275775397027668605952496716674183485704422507197965004714951050492214776567636938662976979522110718264549734772662425709429322582798502585509785265383207606726317164309505995087807523710333101197857547331541421808427543863591778117054309827482385045648019095610299291824318237525357709750539565187697510374970888692180205189339507238539205144634197265287286965110862571492198849978748873771345686209167058',\r\n\r\n // Pi (1025 digits).\r\n PI = '3.1415926535897932384626433832795028841971693993751058209749445923078164062862089986280348253421170679821480865132823066470938446095505822317253594081284811174502841027019385211055596446229489549303819644288109756659334461284756482337867831652712019091456485669234603486104543266482133936072602491412737245870066063155881748815209209628292540917153643678925903600113305305488204665213841469519415116094330572703657595919530921861173819326117931051185480744623799627495673518857527248912279381830119491298336733624406566430860213949463952247371907021798609437027705392171762931767523846748184676694051320005681271452635608277857713427577896091736371787214684409012249534301465495853710507922796892589235420199561121290219608640344181598136297747713099605187072113499999983729780499510597317328160963185950244594553469083026425223082533446850352619311881710100031378387528865875332083814206171776691473035982534904287554687311595628638823537875937519577818577805321712268066130019278766111959092164201989380952572010654858632789',\r\n\r\n\r\n // The initial configuration properties of the Decimal constructor.\r\n DEFAULTS = {\r\n\r\n // These values must be integers within the stated ranges (inclusive).\r\n // Most of these values can be changed at run-time using the `Decimal.config` method.\r\n\r\n // The maximum number of significant digits of the result of a calculation or base conversion.\r\n // E.g. `Decimal.config({ precision: 20 });`\r\n precision: 20, // 1 to MAX_DIGITS\r\n\r\n // The rounding mode used when rounding to `precision`.\r\n //\r\n // ROUND_UP 0 Away from zero.\r\n // ROUND_DOWN 1 Towards zero.\r\n // ROUND_CEIL 2 Towards +Infinity.\r\n // ROUND_FLOOR 3 Towards -Infinity.\r\n // ROUND_HALF_UP 4 Towards nearest neighbour. If equidistant, up.\r\n // ROUND_HALF_DOWN 5 Towards nearest neighbour. If equidistant, down.\r\n // ROUND_HALF_EVEN 6 Towards nearest neighbour. If equidistant, towards even neighbour.\r\n // ROUND_HALF_CEIL 7 Towards nearest neighbour. If equidistant, towards +Infinity.\r\n // ROUND_HALF_FLOOR 8 Towards nearest neighbour. If equidistant, towards -Infinity.\r\n //\r\n // E.g.\r\n // `Decimal.rounding = 4;`\r\n // `Decimal.rounding = Decimal.ROUND_HALF_UP;`\r\n rounding: 4, // 0 to 8\r\n\r\n // The modulo mode used when calculating the modulus: a mod n.\r\n // The quotient (q = a / n) is calculated according to the corresponding rounding mode.\r\n // The remainder (r) is calculated as: r = a - n * q.\r\n //\r\n // UP 0 The remainder is positive if the dividend is negative, else is negative.\r\n // DOWN 1 The remainder has the same sign as the dividend (JavaScript %).\r\n // FLOOR 3 The remainder has the same sign as the divisor (Python %).\r\n // HALF_EVEN 6 The IEEE 754 remainder function.\r\n // EUCLID 9 Euclidian division. q = sign(n) * floor(a / abs(n)). Always positive.\r\n //\r\n // Truncated division (1), floored division (3), the IEEE 754 remainder (6), and Euclidian\r\n // division (9) are commonly used for the modulus operation. The other rounding modes can also\r\n // be used, but they may not give useful results.\r\n modulo: 1, // 0 to 9\r\n\r\n // The exponent value at and beneath which `toString` returns exponential notation.\r\n // JavaScript numbers: -7\r\n toExpNeg: -7, // 0 to -EXP_LIMIT\r\n\r\n // The exponent value at and above which `toString` returns exponential notation.\r\n // JavaScript numbers: 21\r\n toExpPos: 21, // 0 to EXP_LIMIT\r\n\r\n // The minimum exponent value, beneath which underflow to zero occurs.\r\n // JavaScript numbers: -324 (5e-324)\r\n minE: -EXP_LIMIT, // -1 to -EXP_LIMIT\r\n\r\n // The maximum exponent value, above which overflow to Infinity occurs.\r\n // JavaScript numbers: 308 (1.7976931348623157e+308)\r\n maxE: EXP_LIMIT, // 1 to EXP_LIMIT\r\n\r\n // Whether to use cryptographically-secure random number generation, if available.\r\n crypto: false // true/false\r\n },\r\n\r\n\r\n// ----------------------------------- END OF EDITABLE DEFAULTS ------------------------------- //\r\n\r\n\r\n inexact, quadrant,\r\n external = true,\r\n\r\n decimalError = '[DecimalError] ',\r\n invalidArgument = decimalError + 'Invalid argument: ',\r\n precisionLimitExceeded = decimalError + 'Precision limit exceeded',\r\n cryptoUnavailable = decimalError + 'crypto unavailable',\r\n tag = '[object Decimal]',\r\n\r\n mathfloor = Math.floor,\r\n mathpow = Math.pow,\r\n\r\n isBinary = /^0b([01]+(\\.[01]*)?|\\.[01]+)(p[+-]?\\d+)?$/i,\r\n isHex = /^0x([0-9a-f]+(\\.[0-9a-f]*)?|\\.[0-9a-f]+)(p[+-]?\\d+)?$/i,\r\n isOctal = /^0o([0-7]+(\\.[0-7]*)?|\\.[0-7]+)(p[+-]?\\d+)?$/i,\r\n isDecimal = /^(\\d+(\\.\\d*)?|\\.\\d+)(e[+-]?\\d+)?$/i,\r\n\r\n BASE = 1e7,\r\n LOG_BASE = 7,\r\n MAX_SAFE_INTEGER = 9007199254740991,\r\n\r\n LN10_PRECISION = LN10.length - 1,\r\n PI_PRECISION = PI.length - 1,\r\n\r\n // Decimal.prototype object\r\n P = { toStringTag: tag };\r\n\r\n\r\n// Decimal prototype methods\r\n\r\n\r\n/*\r\n * absoluteValue abs\r\n * ceil\r\n * clampedTo clamp\r\n * comparedTo cmp\r\n * cosine cos\r\n * cubeRoot cbrt\r\n * decimalPlaces dp\r\n * dividedBy div\r\n * dividedToIntegerBy divToInt\r\n * equals eq\r\n * floor\r\n * greaterThan gt\r\n * greaterThanOrEqualTo gte\r\n * hyperbolicCosine cosh\r\n * hyperbolicSine sinh\r\n * hyperbolicTangent tanh\r\n * inverseCosine acos\r\n * inverseHyperbolicCosine acosh\r\n * inverseHyperbolicSine asinh\r\n * inverseHyperbolicTangent atanh\r\n * inverseSine asin\r\n * inverseTangent atan\r\n * isFinite\r\n * isInteger isInt\r\n * isNaN\r\n * isNegative isNeg\r\n * isPositive isPos\r\n * isZero\r\n * lessThan lt\r\n * lessThanOrEqualTo lte\r\n * logarithm log\r\n * [maximum] [max]\r\n * [minimum] [min]\r\n * minus sub\r\n * modulo mod\r\n * naturalExponential exp\r\n * naturalLogarithm ln\r\n * negated neg\r\n * plus add\r\n * precision sd\r\n * round\r\n * sine sin\r\n * squareRoot sqrt\r\n * tangent tan\r\n * times mul\r\n * toBinary\r\n * toDecimalPlaces toDP\r\n * toExponential\r\n * toFixed\r\n * toFraction\r\n * toHexadecimal toHex\r\n * toNearest\r\n * toNumber\r\n * toOctal\r\n * toPower pow\r\n * toPrecision\r\n * toSignificantDigits toSD\r\n * toString\r\n * truncated trunc\r\n * valueOf toJSON\r\n */\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the absolute value of this Decimal.\r\n *\r\n */\r\nP.absoluteValue = P.abs = function () {\r\n var x = new this.constructor(this);\r\n if (x.s < 0) x.s = 1;\r\n return finalise(x);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal rounded to a whole number in the\r\n * direction of positive Infinity.\r\n *\r\n */\r\nP.ceil = function () {\r\n return finalise(new this.constructor(this), this.e + 1, 2);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal clamped to the range\r\n * delineated by `min` and `max`.\r\n *\r\n * min {number|string|Decimal}\r\n * max {number|string|Decimal}\r\n *\r\n */\r\nP.clampedTo = P.clamp = function (min, max) {\r\n var k,\r\n x = this,\r\n Ctor = x.constructor;\r\n min = new Ctor(min);\r\n max = new Ctor(max);\r\n if (!min.s || !max.s) return new Ctor(NaN);\r\n if (min.gt(max)) throw Error(invalidArgument + max);\r\n k = x.cmp(min);\r\n return k < 0 ? min : x.cmp(max) > 0 ? max : new Ctor(x);\r\n};\r\n\r\n\r\n/*\r\n * Return\r\n * 1 if the value of this Decimal is greater than the value of `y`,\r\n * -1 if the value of this Decimal is less than the value of `y`,\r\n * 0 if they have the same value,\r\n * NaN if the value of either Decimal is NaN.\r\n *\r\n */\r\nP.comparedTo = P.cmp = function (y) {\r\n var i, j, xdL, ydL,\r\n x = this,\r\n xd = x.d,\r\n yd = (y = new x.constructor(y)).d,\r\n xs = x.s,\r\n ys = y.s;\r\n\r\n // Either NaN or ±Infinity?\r\n if (!xd || !yd) {\r\n return !xs || !ys ? NaN : xs !== ys ? xs : xd === yd ? 0 : !xd ^ xs < 0 ? 1 : -1;\r\n }\r\n\r\n // Either zero?\r\n if (!xd[0] || !yd[0]) return xd[0] ? xs : yd[0] ? -ys : 0;\r\n\r\n // Signs differ?\r\n if (xs !== ys) return xs;\r\n\r\n // Compare exponents.\r\n if (x.e !== y.e) return x.e > y.e ^ xs < 0 ? 1 : -1;\r\n\r\n xdL = xd.length;\r\n ydL = yd.length;\r\n\r\n // Compare digit by digit.\r\n for (i = 0, j = xdL < ydL ? xdL : ydL; i < j; ++i) {\r\n if (xd[i] !== yd[i]) return xd[i] > yd[i] ^ xs < 0 ? 1 : -1;\r\n }\r\n\r\n // Compare lengths.\r\n return xdL === ydL ? 0 : xdL > ydL ^ xs < 0 ? 1 : -1;\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the cosine of the value in radians of this Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-1, 1]\r\n *\r\n * cos(0) = 1\r\n * cos(-0) = 1\r\n * cos(Infinity) = NaN\r\n * cos(-Infinity) = NaN\r\n * cos(NaN) = NaN\r\n *\r\n */\r\nP.cosine = P.cos = function () {\r\n var pr, rm,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (!x.d) return new Ctor(NaN);\r\n\r\n // cos(0) = cos(-0) = 1\r\n if (!x.d[0]) return new Ctor(1);\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n Ctor.precision = pr + Math.max(x.e, x.sd()) + LOG_BASE;\r\n Ctor.rounding = 1;\r\n\r\n x = cosine(Ctor, toLessThanHalfPi(Ctor, x));\r\n\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return finalise(quadrant == 2 || quadrant == 3 ? x.neg() : x, pr, rm, true);\r\n};\r\n\r\n\r\n/*\r\n *\r\n * Return a new Decimal whose value is the cube root of the value of this Decimal, rounded to\r\n * `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * cbrt(0) = 0\r\n * cbrt(-0) = -0\r\n * cbrt(1) = 1\r\n * cbrt(-1) = -1\r\n * cbrt(N) = N\r\n * cbrt(-I) = -I\r\n * cbrt(I) = I\r\n *\r\n * Math.cbrt(x) = (x < 0 ? -Math.pow(-x, 1/3) : Math.pow(x, 1/3))\r\n *\r\n */\r\nP.cubeRoot = P.cbrt = function () {\r\n var e, m, n, r, rep, s, sd, t, t3, t3plusx,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (!x.isFinite() || x.isZero()) return new Ctor(x);\r\n external = false;\r\n\r\n // Initial estimate.\r\n s = x.s * mathpow(x.s * x, 1 / 3);\r\n\r\n // Math.cbrt underflow/overflow?\r\n // Pass x to Math.pow as integer, then adjust the exponent of the result.\r\n if (!s || Math.abs(s) == 1 / 0) {\r\n n = digitsToString(x.d);\r\n e = x.e;\r\n\r\n // Adjust n exponent so it is a multiple of 3 away from x exponent.\r\n if (s = (e - n.length + 1) % 3) n += (s == 1 || s == -2 ? '0' : '00');\r\n s = mathpow(n, 1 / 3);\r\n\r\n // Rarely, e may be one less than the result exponent value.\r\n e = mathfloor((e + 1) / 3) - (e % 3 == (e < 0 ? -1 : 2));\r\n\r\n if (s == 1 / 0) {\r\n n = '5e' + e;\r\n } else {\r\n n = s.toExponential();\r\n n = n.slice(0, n.indexOf('e') + 1) + e;\r\n }\r\n\r\n r = new Ctor(n);\r\n r.s = x.s;\r\n } else {\r\n r = new Ctor(s.toString());\r\n }\r\n\r\n sd = (e = Ctor.precision) + 3;\r\n\r\n // Halley's method.\r\n // TODO? Compare Newton's method.\r\n for (;;) {\r\n t = r;\r\n t3 = t.times(t).times(t);\r\n t3plusx = t3.plus(x);\r\n r = divide(t3plusx.plus(x).times(t), t3plusx.plus(t3), sd + 2, 1);\r\n\r\n // TODO? Replace with for-loop and checkRoundingDigits.\r\n if (digitsToString(t.d).slice(0, sd) === (n = digitsToString(r.d)).slice(0, sd)) {\r\n n = n.slice(sd - 3, sd + 1);\r\n\r\n // The 4th rounding digit may be in error by -1 so if the 4 rounding digits are 9999 or 4999\r\n // , i.e. approaching a rounding boundary, continue the iteration.\r\n if (n == '9999' || !rep && n == '4999') {\r\n\r\n // On the first iteration only, check to see if rounding up gives the exact result as the\r\n // nines may infinitely repeat.\r\n if (!rep) {\r\n finalise(t, e + 1, 0);\r\n\r\n if (t.times(t).times(t).eq(x)) {\r\n r = t;\r\n break;\r\n }\r\n }\r\n\r\n sd += 4;\r\n rep = 1;\r\n } else {\r\n\r\n // If the rounding digits are null, 0{0,4} or 50{0,3}, check for an exact result.\r\n // If not, then there are further digits and m will be truthy.\r\n if (!+n || !+n.slice(1) && n.charAt(0) == '5') {\r\n\r\n // Truncate to the first rounding digit.\r\n finalise(r, e + 1, 1);\r\n m = !r.times(r).times(r).eq(x);\r\n }\r\n\r\n break;\r\n }\r\n }\r\n }\r\n\r\n external = true;\r\n\r\n return finalise(r, e, Ctor.rounding, m);\r\n};\r\n\r\n\r\n/*\r\n * Return the number of decimal places of the value of this Decimal.\r\n *\r\n */\r\nP.decimalPlaces = P.dp = function () {\r\n var w,\r\n d = this.d,\r\n n = NaN;\r\n\r\n if (d) {\r\n w = d.length - 1;\r\n n = (w - mathfloor(this.e / LOG_BASE)) * LOG_BASE;\r\n\r\n // Subtract the number of trailing zeros of the last word.\r\n w = d[w];\r\n if (w) for (; w % 10 == 0; w /= 10) n--;\r\n if (n < 0) n = 0;\r\n }\r\n\r\n return n;\r\n};\r\n\r\n\r\n/*\r\n * n / 0 = I\r\n * n / N = N\r\n * n / I = 0\r\n * 0 / n = 0\r\n * 0 / 0 = N\r\n * 0 / N = N\r\n * 0 / I = 0\r\n * N / n = N\r\n * N / 0 = N\r\n * N / N = N\r\n * N / I = N\r\n * I / n = I\r\n * I / 0 = I\r\n * I / N = N\r\n * I / I = N\r\n *\r\n * Return a new Decimal whose value is the value of this Decimal divided by `y`, rounded to\r\n * `precision` significant digits using rounding mode `rounding`.\r\n *\r\n */\r\nP.dividedBy = P.div = function (y) {\r\n return divide(this, new this.constructor(y));\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the integer part of dividing the value of this Decimal\r\n * by the value of `y`, rounded to `precision` significant digits using rounding mode `rounding`.\r\n *\r\n */\r\nP.dividedToIntegerBy = P.divToInt = function (y) {\r\n var x = this,\r\n Ctor = x.constructor;\r\n return finalise(divide(x, new Ctor(y), 0, 1, 1), Ctor.precision, Ctor.rounding);\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is equal to the value of `y`, otherwise return false.\r\n *\r\n */\r\nP.equals = P.eq = function (y) {\r\n return this.cmp(y) === 0;\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal rounded to a whole number in the\r\n * direction of negative Infinity.\r\n *\r\n */\r\nP.floor = function () {\r\n return finalise(new this.constructor(this), this.e + 1, 3);\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is greater than the value of `y`, otherwise return\r\n * false.\r\n *\r\n */\r\nP.greaterThan = P.gt = function (y) {\r\n return this.cmp(y) > 0;\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is greater than or equal to the value of `y`,\r\n * otherwise return false.\r\n *\r\n */\r\nP.greaterThanOrEqualTo = P.gte = function (y) {\r\n var k = this.cmp(y);\r\n return k == 1 || k === 0;\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the hyperbolic cosine of the value in radians of this\r\n * Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [1, Infinity]\r\n *\r\n * cosh(x) = 1 + x^2/2! + x^4/4! + x^6/6! + ...\r\n *\r\n * cosh(0) = 1\r\n * cosh(-0) = 1\r\n * cosh(Infinity) = Infinity\r\n * cosh(-Infinity) = Infinity\r\n * cosh(NaN) = NaN\r\n *\r\n * x time taken (ms) result\r\n * 1000 9 9.8503555700852349694e+433\r\n * 10000 25 4.4034091128314607936e+4342\r\n * 100000 171 1.4033316802130615897e+43429\r\n * 1000000 3817 1.5166076984010437725e+434294\r\n * 10000000 abandoned after 2 minute wait\r\n *\r\n * TODO? Compare performance of cosh(x) = 0.5 * (exp(x) + exp(-x))\r\n *\r\n */\r\nP.hyperbolicCosine = P.cosh = function () {\r\n var k, n, pr, rm, len,\r\n x = this,\r\n Ctor = x.constructor,\r\n one = new Ctor(1);\r\n\r\n if (!x.isFinite()) return new Ctor(x.s ? 1 / 0 : NaN);\r\n if (x.isZero()) return one;\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n Ctor.precision = pr + Math.max(x.e, x.sd()) + 4;\r\n Ctor.rounding = 1;\r\n len = x.d.length;\r\n\r\n // Argument reduction: cos(4x) = 1 - 8cos^2(x) + 8cos^4(x) + 1\r\n // i.e. cos(x) = 1 - cos^2(x/4)(8 - 8cos^2(x/4))\r\n\r\n // Estimate the optimum number of times to use the argument reduction.\r\n // TODO? Estimation reused from cosine() and may not be optimal here.\r\n if (len < 32) {\r\n k = Math.ceil(len / 3);\r\n n = (1 / tinyPow(4, k)).toString();\r\n } else {\r\n k = 16;\r\n n = '2.3283064365386962890625e-10';\r\n }\r\n\r\n x = taylorSeries(Ctor, 1, x.times(n), new Ctor(1), true);\r\n\r\n // Reverse argument reduction\r\n var cosh2_x,\r\n i = k,\r\n d8 = new Ctor(8);\r\n for (; i--;) {\r\n cosh2_x = x.times(x);\r\n x = one.minus(cosh2_x.times(d8.minus(cosh2_x.times(d8))));\r\n }\r\n\r\n return finalise(x, Ctor.precision = pr, Ctor.rounding = rm, true);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the hyperbolic sine of the value in radians of this\r\n * Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-Infinity, Infinity]\r\n *\r\n * sinh(x) = x + x^3/3! + x^5/5! + x^7/7! + ...\r\n *\r\n * sinh(0) = 0\r\n * sinh(-0) = -0\r\n * sinh(Infinity) = Infinity\r\n * sinh(-Infinity) = -Infinity\r\n * sinh(NaN) = NaN\r\n *\r\n * x time taken (ms)\r\n * 10 2 ms\r\n * 100 5 ms\r\n * 1000 14 ms\r\n * 10000 82 ms\r\n * 100000 886 ms 1.4033316802130615897e+43429\r\n * 200000 2613 ms\r\n * 300000 5407 ms\r\n * 400000 8824 ms\r\n * 500000 13026 ms 8.7080643612718084129e+217146\r\n * 1000000 48543 ms\r\n *\r\n * TODO? Compare performance of sinh(x) = 0.5 * (exp(x) - exp(-x))\r\n *\r\n */\r\nP.hyperbolicSine = P.sinh = function () {\r\n var k, pr, rm, len,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (!x.isFinite() || x.isZero()) return new Ctor(x);\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n Ctor.precision = pr + Math.max(x.e, x.sd()) + 4;\r\n Ctor.rounding = 1;\r\n len = x.d.length;\r\n\r\n if (len < 3) {\r\n x = taylorSeries(Ctor, 2, x, x, true);\r\n } else {\r\n\r\n // Alternative argument reduction: sinh(3x) = sinh(x)(3 + 4sinh^2(x))\r\n // i.e. sinh(x) = sinh(x/3)(3 + 4sinh^2(x/3))\r\n // 3 multiplications and 1 addition\r\n\r\n // Argument reduction: sinh(5x) = sinh(x)(5 + sinh^2(x)(20 + 16sinh^2(x)))\r\n // i.e. sinh(x) = sinh(x/5)(5 + sinh^2(x/5)(20 + 16sinh^2(x/5)))\r\n // 4 multiplications and 2 additions\r\n\r\n // Estimate the optimum number of times to use the argument reduction.\r\n k = 1.4 * Math.sqrt(len);\r\n k = k > 16 ? 16 : k | 0;\r\n\r\n x = x.times(1 / tinyPow(5, k));\r\n x = taylorSeries(Ctor, 2, x, x, true);\r\n\r\n // Reverse argument reduction\r\n var sinh2_x,\r\n d5 = new Ctor(5),\r\n d16 = new Ctor(16),\r\n d20 = new Ctor(20);\r\n for (; k--;) {\r\n sinh2_x = x.times(x);\r\n x = x.times(d5.plus(sinh2_x.times(d16.times(sinh2_x).plus(d20))));\r\n }\r\n }\r\n\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return finalise(x, pr, rm, true);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the hyperbolic tangent of the value in radians of this\r\n * Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-1, 1]\r\n *\r\n * tanh(x) = sinh(x) / cosh(x)\r\n *\r\n * tanh(0) = 0\r\n * tanh(-0) = -0\r\n * tanh(Infinity) = 1\r\n * tanh(-Infinity) = -1\r\n * tanh(NaN) = NaN\r\n *\r\n */\r\nP.hyperbolicTangent = P.tanh = function () {\r\n var pr, rm,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (!x.isFinite()) return new Ctor(x.s);\r\n if (x.isZero()) return new Ctor(x);\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n Ctor.precision = pr + 7;\r\n Ctor.rounding = 1;\r\n\r\n return divide(x.sinh(), x.cosh(), Ctor.precision = pr, Ctor.rounding = rm);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the arccosine (inverse cosine) in radians of the value of\r\n * this Decimal.\r\n *\r\n * Domain: [-1, 1]\r\n * Range: [0, pi]\r\n *\r\n * acos(x) = pi/2 - asin(x)\r\n *\r\n * acos(0) = pi/2\r\n * acos(-0) = pi/2\r\n * acos(1) = 0\r\n * acos(-1) = pi\r\n * acos(1/2) = pi/3\r\n * acos(-1/2) = 2*pi/3\r\n * acos(|x| > 1) = NaN\r\n * acos(NaN) = NaN\r\n *\r\n */\r\nP.inverseCosine = P.acos = function () {\r\n var halfPi,\r\n x = this,\r\n Ctor = x.constructor,\r\n k = x.abs().cmp(1),\r\n pr = Ctor.precision,\r\n rm = Ctor.rounding;\r\n\r\n if (k !== -1) {\r\n return k === 0\r\n // |x| is 1\r\n ? x.isNeg() ? getPi(Ctor, pr, rm) : new Ctor(0)\r\n // |x| > 1 or x is NaN\r\n : new Ctor(NaN);\r\n }\r\n\r\n if (x.isZero()) return getPi(Ctor, pr + 4, rm).times(0.5);\r\n\r\n // TODO? Special case acos(0.5) = pi/3 and acos(-0.5) = 2*pi/3\r\n\r\n Ctor.precision = pr + 6;\r\n Ctor.rounding = 1;\r\n\r\n x = x.asin();\r\n halfPi = getPi(Ctor, pr + 4, rm).times(0.5);\r\n\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return halfPi.minus(x);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the inverse of the hyperbolic cosine in radians of the\r\n * value of this Decimal.\r\n *\r\n * Domain: [1, Infinity]\r\n * Range: [0, Infinity]\r\n *\r\n * acosh(x) = ln(x + sqrt(x^2 - 1))\r\n *\r\n * acosh(x < 1) = NaN\r\n * acosh(NaN) = NaN\r\n * acosh(Infinity) = Infinity\r\n * acosh(-Infinity) = NaN\r\n * acosh(0) = NaN\r\n * acosh(-0) = NaN\r\n * acosh(1) = 0\r\n * acosh(-1) = NaN\r\n *\r\n */\r\nP.inverseHyperbolicCosine = P.acosh = function () {\r\n var pr, rm,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (x.lte(1)) return new Ctor(x.eq(1) ? 0 : NaN);\r\n if (!x.isFinite()) return new Ctor(x);\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n Ctor.precision = pr + Math.max(Math.abs(x.e), x.sd()) + 4;\r\n Ctor.rounding = 1;\r\n external = false;\r\n\r\n x = x.times(x).minus(1).sqrt().plus(x);\r\n\r\n external = true;\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return x.ln();\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the inverse of the hyperbolic sine in radians of the value\r\n * of this Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-Infinity, Infinity]\r\n *\r\n * asinh(x) = ln(x + sqrt(x^2 + 1))\r\n *\r\n * asinh(NaN) = NaN\r\n * asinh(Infinity) = Infinity\r\n * asinh(-Infinity) = -Infinity\r\n * asinh(0) = 0\r\n * asinh(-0) = -0\r\n *\r\n */\r\nP.inverseHyperbolicSine = P.asinh = function () {\r\n var pr, rm,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (!x.isFinite() || x.isZero()) return new Ctor(x);\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n Ctor.precision = pr + 2 * Math.max(Math.abs(x.e), x.sd()) + 6;\r\n Ctor.rounding = 1;\r\n external = false;\r\n\r\n x = x.times(x).plus(1).sqrt().plus(x);\r\n\r\n external = true;\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return x.ln();\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the inverse of the hyperbolic tangent in radians of the\r\n * value of this Decimal.\r\n *\r\n * Domain: [-1, 1]\r\n * Range: [-Infinity, Infinity]\r\n *\r\n * atanh(x) = 0.5 * ln((1 + x) / (1 - x))\r\n *\r\n * atanh(|x| > 1) = NaN\r\n * atanh(NaN) = NaN\r\n * atanh(Infinity) = NaN\r\n * atanh(-Infinity) = NaN\r\n * atanh(0) = 0\r\n * atanh(-0) = -0\r\n * atanh(1) = Infinity\r\n * atanh(-1) = -Infinity\r\n *\r\n */\r\nP.inverseHyperbolicTangent = P.atanh = function () {\r\n var pr, rm, wpr, xsd,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (!x.isFinite()) return new Ctor(NaN);\r\n if (x.e >= 0) return new Ctor(x.abs().eq(1) ? x.s / 0 : x.isZero() ? x : NaN);\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n xsd = x.sd();\r\n\r\n if (Math.max(xsd, pr) < 2 * -x.e - 1) return finalise(new Ctor(x), pr, rm, true);\r\n\r\n Ctor.precision = wpr = xsd - x.e;\r\n\r\n x = divide(x.plus(1), new Ctor(1).minus(x), wpr + pr, 1);\r\n\r\n Ctor.precision = pr + 4;\r\n Ctor.rounding = 1;\r\n\r\n x = x.ln();\r\n\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return x.times(0.5);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the arcsine (inverse sine) in radians of the value of this\r\n * Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-pi/2, pi/2]\r\n *\r\n * asin(x) = 2*atan(x/(1 + sqrt(1 - x^2)))\r\n *\r\n * asin(0) = 0\r\n * asin(-0) = -0\r\n * asin(1/2) = pi/6\r\n * asin(-1/2) = -pi/6\r\n * asin(1) = pi/2\r\n * asin(-1) = -pi/2\r\n * asin(|x| > 1) = NaN\r\n * asin(NaN) = NaN\r\n *\r\n * TODO? Compare performance of Taylor series.\r\n *\r\n */\r\nP.inverseSine = P.asin = function () {\r\n var halfPi, k,\r\n pr, rm,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (x.isZero()) return new Ctor(x);\r\n\r\n k = x.abs().cmp(1);\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n\r\n if (k !== -1) {\r\n\r\n // |x| is 1\r\n if (k === 0) {\r\n halfPi = getPi(Ctor, pr + 4, rm).times(0.5);\r\n halfPi.s = x.s;\r\n return halfPi;\r\n }\r\n\r\n // |x| > 1 or x is NaN\r\n return new Ctor(NaN);\r\n }\r\n\r\n // TODO? Special case asin(1/2) = pi/6 and asin(-1/2) = -pi/6\r\n\r\n Ctor.precision = pr + 6;\r\n Ctor.rounding = 1;\r\n\r\n x = x.div(new Ctor(1).minus(x.times(x)).sqrt().plus(1)).atan();\r\n\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return x.times(2);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the arctangent (inverse tangent) in radians of the value\r\n * of this Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-pi/2, pi/2]\r\n *\r\n * atan(x) = x - x^3/3 + x^5/5 - x^7/7 + ...\r\n *\r\n * atan(0) = 0\r\n * atan(-0) = -0\r\n * atan(1) = pi/4\r\n * atan(-1) = -pi/4\r\n * atan(Infinity) = pi/2\r\n * atan(-Infinity) = -pi/2\r\n * atan(NaN) = NaN\r\n *\r\n */\r\nP.inverseTangent = P.atan = function () {\r\n var i, j, k, n, px, t, r, wpr, x2,\r\n x = this,\r\n Ctor = x.constructor,\r\n pr = Ctor.precision,\r\n rm = Ctor.rounding;\r\n\r\n if (!x.isFinite()) {\r\n if (!x.s) return new Ctor(NaN);\r\n if (pr + 4 <= PI_PRECISION) {\r\n r = getPi(Ctor, pr + 4, rm).times(0.5);\r\n r.s = x.s;\r\n return r;\r\n }\r\n } else if (x.isZero()) {\r\n return new Ctor(x);\r\n } else if (x.abs().eq(1) && pr + 4 <= PI_PRECISION) {\r\n r = getPi(Ctor, pr + 4, rm).times(0.25);\r\n r.s = x.s;\r\n return r;\r\n }\r\n\r\n Ctor.precision = wpr = pr + 10;\r\n Ctor.rounding = 1;\r\n\r\n // TODO? if (x >= 1 && pr <= PI_PRECISION) atan(x) = halfPi * x.s - atan(1 / x);\r\n\r\n // Argument reduction\r\n // Ensure |x| < 0.42\r\n // atan(x) = 2 * atan(x / (1 + sqrt(1 + x^2)))\r\n\r\n k = Math.min(28, wpr / LOG_BASE + 2 | 0);\r\n\r\n for (i = k; i; --i) x = x.div(x.times(x).plus(1).sqrt().plus(1));\r\n\r\n external = false;\r\n\r\n j = Math.ceil(wpr / LOG_BASE);\r\n n = 1;\r\n x2 = x.times(x);\r\n r = new Ctor(x);\r\n px = x;\r\n\r\n // atan(x) = x - x^3/3 + x^5/5 - x^7/7 + ...\r\n for (; i !== -1;) {\r\n px = px.times(x2);\r\n t = r.minus(px.div(n += 2));\r\n\r\n px = px.times(x2);\r\n r = t.plus(px.div(n += 2));\r\n\r\n if (r.d[j] !== void 0) for (i = j; r.d[i] === t.d[i] && i--;);\r\n }\r\n\r\n if (k) r = r.times(2 << (k - 1));\r\n\r\n external = true;\r\n\r\n return finalise(r, Ctor.precision = pr, Ctor.rounding = rm, true);\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is a finite number, otherwise return false.\r\n *\r\n */\r\nP.isFinite = function () {\r\n return !!this.d;\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is an integer, otherwise return false.\r\n *\r\n */\r\nP.isInteger = P.isInt = function () {\r\n return !!this.d && mathfloor(this.e / LOG_BASE) > this.d.length - 2;\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is NaN, otherwise return false.\r\n *\r\n */\r\nP.isNaN = function () {\r\n return !this.s;\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is negative, otherwise return false.\r\n *\r\n */\r\nP.isNegative = P.isNeg = function () {\r\n return this.s < 0;\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is positive, otherwise return false.\r\n *\r\n */\r\nP.isPositive = P.isPos = function () {\r\n return this.s > 0;\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is 0 or -0, otherwise return false.\r\n *\r\n */\r\nP.isZero = function () {\r\n return !!this.d && this.d[0] === 0;\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is less than `y`, otherwise return false.\r\n *\r\n */\r\nP.lessThan = P.lt = function (y) {\r\n return this.cmp(y) < 0;\r\n};\r\n\r\n\r\n/*\r\n * Return true if the value of this Decimal is less than or equal to `y`, otherwise return false.\r\n *\r\n */\r\nP.lessThanOrEqualTo = P.lte = function (y) {\r\n return this.cmp(y) < 1;\r\n};\r\n\r\n\r\n/*\r\n * Return the logarithm of the value of this Decimal to the specified base, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * If no base is specified, return log[10](arg).\r\n *\r\n * log[base](arg) = ln(arg) / ln(base)\r\n *\r\n * The result will always be correctly rounded if the base of the log is 10, and 'almost always'\r\n * otherwise:\r\n *\r\n * Depending on the rounding mode, the result may be incorrectly rounded if the first fifteen\r\n * rounding digits are [49]99999999999999 or [50]00000000000000. In that case, the maximum error\r\n * between the result and the correctly rounded result will be one ulp (unit in the last place).\r\n *\r\n * log[-b](a) = NaN\r\n * log[0](a) = NaN\r\n * log[1](a) = NaN\r\n * log[NaN](a) = NaN\r\n * log[Infinity](a) = NaN\r\n * log[b](0) = -Infinity\r\n * log[b](-0) = -Infinity\r\n * log[b](-a) = NaN\r\n * log[b](1) = 0\r\n * log[b](Infinity) = Infinity\r\n * log[b](NaN) = NaN\r\n *\r\n * [base] {number|string|Decimal} The base of the logarithm.\r\n *\r\n */\r\nP.logarithm = P.log = function (base) {\r\n var isBase10, d, denominator, k, inf, num, sd, r,\r\n arg = this,\r\n Ctor = arg.constructor,\r\n pr = Ctor.precision,\r\n rm = Ctor.rounding,\r\n guard = 5;\r\n\r\n // Default base is 10.\r\n if (base == null) {\r\n base = new Ctor(10);\r\n isBase10 = true;\r\n } else {\r\n base = new Ctor(base);\r\n d = base.d;\r\n\r\n // Return NaN if base is negative, or non-finite, or is 0 or 1.\r\n if (base.s < 0 || !d || !d[0] || base.eq(1)) return new Ctor(NaN);\r\n\r\n isBase10 = base.eq(10);\r\n }\r\n\r\n d = arg.d;\r\n\r\n // Is arg negative, non-finite, 0 or 1?\r\n if (arg.s < 0 || !d || !d[0] || arg.eq(1)) {\r\n return new Ctor(d && !d[0] ? -1 / 0 : arg.s != 1 ? NaN : d ? 0 : 1 / 0);\r\n }\r\n\r\n // The result will have a non-terminating decimal expansion if base is 10 and arg is not an\r\n // integer power of 10.\r\n if (isBase10) {\r\n if (d.length > 1) {\r\n inf = true;\r\n } else {\r\n for (k = d[0]; k % 10 === 0;) k /= 10;\r\n inf = k !== 1;\r\n }\r\n }\r\n\r\n external = false;\r\n sd = pr + guard;\r\n num = naturalLogarithm(arg, sd);\r\n denominator = isBase10 ? getLn10(Ctor, sd + 10) : naturalLogarithm(base, sd);\r\n\r\n // The result will have 5 rounding digits.\r\n r = divide(num, denominator, sd, 1);\r\n\r\n // If at a rounding boundary, i.e. the result's rounding digits are [49]9999 or [50]0000,\r\n // calculate 10 further digits.\r\n //\r\n // If the result is known to have an infinite decimal expansion, repeat this until it is clear\r\n // that the result is above or below the boundary. Otherwise, if after calculating the 10\r\n // further digits, the last 14 are nines, round up and assume the result is exact.\r\n // Also assume the result is exact if the last 14 are zero.\r\n //\r\n // Example of a result that will be incorrectly rounded:\r\n // log[1048576](4503599627370502) = 2.60000000000000009610279511444746...\r\n // The above result correctly rounded using ROUND_CEIL to 1 decimal place should be 2.7, but it\r\n // will be given as 2.6 as there are 15 zeros immediately after the requested decimal place, so\r\n // the exact result would be assumed to be 2.6, which rounded using ROUND_CEIL to 1 decimal\r\n // place is still 2.6.\r\n if (checkRoundingDigits(r.d, k = pr, rm)) {\r\n\r\n do {\r\n sd += 10;\r\n num = naturalLogarithm(arg, sd);\r\n denominator = isBase10 ? getLn10(Ctor, sd + 10) : naturalLogarithm(base, sd);\r\n r = divide(num, denominator, sd, 1);\r\n\r\n if (!inf) {\r\n\r\n // Check for 14 nines from the 2nd rounding digit, as the first may be 4.\r\n if (+digitsToString(r.d).slice(k + 1, k + 15) + 1 == 1e14) {\r\n r = finalise(r, pr + 1, 0);\r\n }\r\n\r\n break;\r\n }\r\n } while (checkRoundingDigits(r.d, k += 10, rm));\r\n }\r\n\r\n external = true;\r\n\r\n return finalise(r, pr, rm);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the maximum of the arguments and the value of this Decimal.\r\n *\r\n * arguments {number|string|Decimal}\r\n *\r\nP.max = function () {\r\n Array.prototype.push.call(arguments, this);\r\n return maxOrMin(this.constructor, arguments, 'lt');\r\n};\r\n */\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the minimum of the arguments and the value of this Decimal.\r\n *\r\n * arguments {number|string|Decimal}\r\n *\r\nP.min = function () {\r\n Array.prototype.push.call(arguments, this);\r\n return maxOrMin(this.constructor, arguments, 'gt');\r\n};\r\n */\r\n\r\n\r\n/*\r\n * n - 0 = n\r\n * n - N = N\r\n * n - I = -I\r\n * 0 - n = -n\r\n * 0 - 0 = 0\r\n * 0 - N = N\r\n * 0 - I = -I\r\n * N - n = N\r\n * N - 0 = N\r\n * N - N = N\r\n * N - I = N\r\n * I - n = I\r\n * I - 0 = I\r\n * I - N = N\r\n * I - I = N\r\n *\r\n * Return a new Decimal whose value is the value of this Decimal minus `y`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n */\r\nP.minus = P.sub = function (y) {\r\n var d, e, i, j, k, len, pr, rm, xd, xe, xLTy, yd,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n y = new Ctor(y);\r\n\r\n // If either is not finite...\r\n if (!x.d || !y.d) {\r\n\r\n // Return NaN if either is NaN.\r\n if (!x.s || !y.s) y = new Ctor(NaN);\r\n\r\n // Return y negated if x is finite and y is ±Infinity.\r\n else if (x.d) y.s = -y.s;\r\n\r\n // Return x if y is finite and x is ±Infinity.\r\n // Return x if both are ±Infinity with different signs.\r\n // Return NaN if both are ±Infinity with the same sign.\r\n else y = new Ctor(y.d || x.s !== y.s ? x : NaN);\r\n\r\n return y;\r\n }\r\n\r\n // If signs differ...\r\n if (x.s != y.s) {\r\n y.s = -y.s;\r\n return x.plus(y);\r\n }\r\n\r\n xd = x.d;\r\n yd = y.d;\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n\r\n // If either is zero...\r\n if (!xd[0] || !yd[0]) {\r\n\r\n // Return y negated if x is zero and y is non-zero.\r\n if (yd[0]) y.s = -y.s;\r\n\r\n // Return x if y is zero and x is non-zero.\r\n else if (xd[0]) y = new Ctor(x);\r\n\r\n // Return zero if both are zero.\r\n // From IEEE 754 (2008) 6.3: 0 - 0 = -0 - -0 = -0 when rounding to -Infinity.\r\n else return new Ctor(rm === 3 ? -0 : 0);\r\n\r\n return external ? finalise(y, pr, rm) : y;\r\n }\r\n\r\n // x and y are finite, non-zero numbers with the same sign.\r\n\r\n // Calculate base 1e7 exponents.\r\n e = mathfloor(y.e / LOG_BASE);\r\n xe = mathfloor(x.e / LOG_BASE);\r\n\r\n xd = xd.slice();\r\n k = xe - e;\r\n\r\n // If base 1e7 exponents differ...\r\n if (k) {\r\n xLTy = k < 0;\r\n\r\n if (xLTy) {\r\n d = xd;\r\n k = -k;\r\n len = yd.length;\r\n } else {\r\n d = yd;\r\n e = xe;\r\n len = xd.length;\r\n }\r\n\r\n // Numbers with massively different exponents would result in a very high number of\r\n // zeros needing to be prepended, but this can be avoided while still ensuring correct\r\n // rounding by limiting the number of zeros to `Math.ceil(pr / LOG_BASE) + 2`.\r\n i = Math.max(Math.ceil(pr / LOG_BASE), len) + 2;\r\n\r\n if (k > i) {\r\n k = i;\r\n d.length = 1;\r\n }\r\n\r\n // Prepend zeros to equalise exponents.\r\n d.reverse();\r\n for (i = k; i--;) d.push(0);\r\n d.reverse();\r\n\r\n // Base 1e7 exponents equal.\r\n } else {\r\n\r\n // Check digits to determine which is the bigger number.\r\n\r\n i = xd.length;\r\n len = yd.length;\r\n xLTy = i < len;\r\n if (xLTy) len = i;\r\n\r\n for (i = 0; i < len; i++) {\r\n if (xd[i] != yd[i]) {\r\n xLTy = xd[i] < yd[i];\r\n break;\r\n }\r\n }\r\n\r\n k = 0;\r\n }\r\n\r\n if (xLTy) {\r\n d = xd;\r\n xd = yd;\r\n yd = d;\r\n y.s = -y.s;\r\n }\r\n\r\n len = xd.length;\r\n\r\n // Append zeros to `xd` if shorter.\r\n // Don't add zeros to `yd` if shorter as subtraction only needs to start at `yd` length.\r\n for (i = yd.length - len; i > 0; --i) xd[len++] = 0;\r\n\r\n // Subtract yd from xd.\r\n for (i = yd.length; i > k;) {\r\n\r\n if (xd[--i] < yd[i]) {\r\n for (j = i; j && xd[--j] === 0;) xd[j] = BASE - 1;\r\n --xd[j];\r\n xd[i] += BASE;\r\n }\r\n\r\n xd[i] -= yd[i];\r\n }\r\n\r\n // Remove trailing zeros.\r\n for (; xd[--len] === 0;) xd.pop();\r\n\r\n // Remove leading zeros and adjust exponent accordingly.\r\n for (; xd[0] === 0; xd.shift()) --e;\r\n\r\n // Zero?\r\n if (!xd[0]) return new Ctor(rm === 3 ? -0 : 0);\r\n\r\n y.d = xd;\r\n y.e = getBase10Exponent(xd, e);\r\n\r\n return external ? finalise(y, pr, rm) : y;\r\n};\r\n\r\n\r\n/*\r\n * n % 0 = N\r\n * n % N = N\r\n * n % I = n\r\n * 0 % n = 0\r\n * -0 % n = -0\r\n * 0 % 0 = N\r\n * 0 % N = N\r\n * 0 % I = 0\r\n * N % n = N\r\n * N % 0 = N\r\n * N % N = N\r\n * N % I = N\r\n * I % n = N\r\n * I % 0 = N\r\n * I % N = N\r\n * I % I = N\r\n *\r\n * Return a new Decimal whose value is the value of this Decimal modulo `y`, rounded to\r\n * `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * The result depends on the modulo mode.\r\n *\r\n */\r\nP.modulo = P.mod = function (y) {\r\n var q,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n y = new Ctor(y);\r\n\r\n // Return NaN if x is ±Infinity or NaN, or y is NaN or ±0.\r\n if (!x.d || !y.s || y.d && !y.d[0]) return new Ctor(NaN);\r\n\r\n // Return x if y is ±Infinity or x is ±0.\r\n if (!y.d || x.d && !x.d[0]) {\r\n return finalise(new Ctor(x), Ctor.precision, Ctor.rounding);\r\n }\r\n\r\n // Prevent rounding of intermediate calculations.\r\n external = false;\r\n\r\n if (Ctor.modulo == 9) {\r\n\r\n // Euclidian division: q = sign(y) * floor(x / abs(y))\r\n // result = x - q * y where 0 <= result < abs(y)\r\n q = divide(x, y.abs(), 0, 3, 1);\r\n q.s *= y.s;\r\n } else {\r\n q = divide(x, y, 0, Ctor.modulo, 1);\r\n }\r\n\r\n q = q.times(y);\r\n\r\n external = true;\r\n\r\n return x.minus(q);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the natural exponential of the value of this Decimal,\r\n * i.e. the base e raised to the power the value of this Decimal, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n */\r\nP.naturalExponential = P.exp = function () {\r\n return naturalExponential(this);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the natural logarithm of the value of this Decimal,\r\n * rounded to `precision` significant digits using rounding mode `rounding`.\r\n *\r\n */\r\nP.naturalLogarithm = P.ln = function () {\r\n return naturalLogarithm(this);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal negated, i.e. as if multiplied by\r\n * -1.\r\n *\r\n */\r\nP.negated = P.neg = function () {\r\n var x = new this.constructor(this);\r\n x.s = -x.s;\r\n return finalise(x);\r\n};\r\n\r\n\r\n/*\r\n * n + 0 = n\r\n * n + N = N\r\n * n + I = I\r\n * 0 + n = n\r\n * 0 + 0 = 0\r\n * 0 + N = N\r\n * 0 + I = I\r\n * N + n = N\r\n * N + 0 = N\r\n * N + N = N\r\n * N + I = N\r\n * I + n = I\r\n * I + 0 = I\r\n * I + N = N\r\n * I + I = I\r\n *\r\n * Return a new Decimal whose value is the value of this Decimal plus `y`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n */\r\nP.plus = P.add = function (y) {\r\n var carry, d, e, i, k, len, pr, rm, xd, yd,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n y = new Ctor(y);\r\n\r\n // If either is not finite...\r\n if (!x.d || !y.d) {\r\n\r\n // Return NaN if either is NaN.\r\n if (!x.s || !y.s) y = new Ctor(NaN);\r\n\r\n // Return x if y is finite and x is ±Infinity.\r\n // Return x if both are ±Infinity with the same sign.\r\n // Return NaN if both are ±Infinity with different signs.\r\n // Return y if x is finite and y is ±Infinity.\r\n else if (!x.d) y = new Ctor(y.d || x.s === y.s ? x : NaN);\r\n\r\n return y;\r\n }\r\n\r\n // If signs differ...\r\n if (x.s != y.s) {\r\n y.s = -y.s;\r\n return x.minus(y);\r\n }\r\n\r\n xd = x.d;\r\n yd = y.d;\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n\r\n // If either is zero...\r\n if (!xd[0] || !yd[0]) {\r\n\r\n // Return x if y is zero.\r\n // Return y if y is non-zero.\r\n if (!yd[0]) y = new Ctor(x);\r\n\r\n return external ? finalise(y, pr, rm) : y;\r\n }\r\n\r\n // x and y are finite, non-zero numbers with the same sign.\r\n\r\n // Calculate base 1e7 exponents.\r\n k = mathfloor(x.e / LOG_BASE);\r\n e = mathfloor(y.e / LOG_BASE);\r\n\r\n xd = xd.slice();\r\n i = k - e;\r\n\r\n // If base 1e7 exponents differ...\r\n if (i) {\r\n\r\n if (i < 0) {\r\n d = xd;\r\n i = -i;\r\n len = yd.length;\r\n } else {\r\n d = yd;\r\n e = k;\r\n len = xd.length;\r\n }\r\n\r\n // Limit number of zeros prepended to max(ceil(pr / LOG_BASE), len) + 1.\r\n k = Math.ceil(pr / LOG_BASE);\r\n len = k > len ? k + 1 : len + 1;\r\n\r\n if (i > len) {\r\n i = len;\r\n d.length = 1;\r\n }\r\n\r\n // Prepend zeros to equalise exponents. Note: Faster to use reverse then do unshifts.\r\n d.reverse();\r\n for (; i--;) d.push(0);\r\n d.reverse();\r\n }\r\n\r\n len = xd.length;\r\n i = yd.length;\r\n\r\n // If yd is longer than xd, swap xd and yd so xd points to the longer array.\r\n if (len - i < 0) {\r\n i = len;\r\n d = yd;\r\n yd = xd;\r\n xd = d;\r\n }\r\n\r\n // Only start adding at yd.length - 1 as the further digits of xd can be left as they are.\r\n for (carry = 0; i;) {\r\n carry = (xd[--i] = xd[i] + yd[i] + carry) / BASE | 0;\r\n xd[i] %= BASE;\r\n }\r\n\r\n if (carry) {\r\n xd.unshift(carry);\r\n ++e;\r\n }\r\n\r\n // Remove trailing zeros.\r\n // No need to check for zero, as +x + +y != 0 && -x + -y != 0\r\n for (len = xd.length; xd[--len] == 0;) xd.pop();\r\n\r\n y.d = xd;\r\n y.e = getBase10Exponent(xd, e);\r\n\r\n return external ? finalise(y, pr, rm) : y;\r\n};\r\n\r\n\r\n/*\r\n * Return the number of significant digits of the value of this Decimal.\r\n *\r\n * [z] {boolean|number} Whether to count integer-part trailing zeros: true, false, 1 or 0.\r\n *\r\n */\r\nP.precision = P.sd = function (z) {\r\n var k,\r\n x = this;\r\n\r\n if (z !== void 0 && z !== !!z && z !== 1 && z !== 0) throw Error(invalidArgument + z);\r\n\r\n if (x.d) {\r\n k = getPrecision(x.d);\r\n if (z && x.e + 1 > k) k = x.e + 1;\r\n } else {\r\n k = NaN;\r\n }\r\n\r\n return k;\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal rounded to a whole number using\r\n * rounding mode `rounding`.\r\n *\r\n */\r\nP.round = function () {\r\n var x = this,\r\n Ctor = x.constructor;\r\n\r\n return finalise(new Ctor(x), x.e + 1, Ctor.rounding);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the sine of the value in radians of this Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-1, 1]\r\n *\r\n * sin(x) = x - x^3/3! + x^5/5! - ...\r\n *\r\n * sin(0) = 0\r\n * sin(-0) = -0\r\n * sin(Infinity) = NaN\r\n * sin(-Infinity) = NaN\r\n * sin(NaN) = NaN\r\n *\r\n */\r\nP.sine = P.sin = function () {\r\n var pr, rm,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (!x.isFinite()) return new Ctor(NaN);\r\n if (x.isZero()) return new Ctor(x);\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n Ctor.precision = pr + Math.max(x.e, x.sd()) + LOG_BASE;\r\n Ctor.rounding = 1;\r\n\r\n x = sine(Ctor, toLessThanHalfPi(Ctor, x));\r\n\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return finalise(quadrant > 2 ? x.neg() : x, pr, rm, true);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the square root of this Decimal, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * sqrt(-n) = N\r\n * sqrt(N) = N\r\n * sqrt(-I) = N\r\n * sqrt(I) = I\r\n * sqrt(0) = 0\r\n * sqrt(-0) = -0\r\n *\r\n */\r\nP.squareRoot = P.sqrt = function () {\r\n var m, n, sd, r, rep, t,\r\n x = this,\r\n d = x.d,\r\n e = x.e,\r\n s = x.s,\r\n Ctor = x.constructor;\r\n\r\n // Negative/NaN/Infinity/zero?\r\n if (s !== 1 || !d || !d[0]) {\r\n return new Ctor(!s || s < 0 && (!d || d[0]) ? NaN : d ? x : 1 / 0);\r\n }\r\n\r\n external = false;\r\n\r\n // Initial estimate.\r\n s = Math.sqrt(+x);\r\n\r\n // Math.sqrt underflow/overflow?\r\n // Pass x to Math.sqrt as integer, then adjust the exponent of the result.\r\n if (s == 0 || s == 1 / 0) {\r\n n = digitsToString(d);\r\n\r\n if ((n.length + e) % 2 == 0) n += '0';\r\n s = Math.sqrt(n);\r\n e = mathfloor((e + 1) / 2) - (e < 0 || e % 2);\r\n\r\n if (s == 1 / 0) {\r\n n = '5e' + e;\r\n } else {\r\n n = s.toExponential();\r\n n = n.slice(0, n.indexOf('e') + 1) + e;\r\n }\r\n\r\n r = new Ctor(n);\r\n } else {\r\n r = new Ctor(s.toString());\r\n }\r\n\r\n sd = (e = Ctor.precision) + 3;\r\n\r\n // Newton-Raphson iteration.\r\n for (;;) {\r\n t = r;\r\n r = t.plus(divide(x, t, sd + 2, 1)).times(0.5);\r\n\r\n // TODO? Replace with for-loop and checkRoundingDigits.\r\n if (digitsToString(t.d).slice(0, sd) === (n = digitsToString(r.d)).slice(0, sd)) {\r\n n = n.slice(sd - 3, sd + 1);\r\n\r\n // The 4th rounding digit may be in error by -1 so if the 4 rounding digits are 9999 or\r\n // 4999, i.e. approaching a rounding boundary, continue the iteration.\r\n if (n == '9999' || !rep && n == '4999') {\r\n\r\n // On the first iteration only, check to see if rounding up gives the exact result as the\r\n // nines may infinitely repeat.\r\n if (!rep) {\r\n finalise(t, e + 1, 0);\r\n\r\n if (t.times(t).eq(x)) {\r\n r = t;\r\n break;\r\n }\r\n }\r\n\r\n sd += 4;\r\n rep = 1;\r\n } else {\r\n\r\n // If the rounding digits are null, 0{0,4} or 50{0,3}, check for an exact result.\r\n // If not, then there are further digits and m will be truthy.\r\n if (!+n || !+n.slice(1) && n.charAt(0) == '5') {\r\n\r\n // Truncate to the first rounding digit.\r\n finalise(r, e + 1, 1);\r\n m = !r.times(r).eq(x);\r\n }\r\n\r\n break;\r\n }\r\n }\r\n }\r\n\r\n external = true;\r\n\r\n return finalise(r, e, Ctor.rounding, m);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the tangent of the value in radians of this Decimal.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-Infinity, Infinity]\r\n *\r\n * tan(0) = 0\r\n * tan(-0) = -0\r\n * tan(Infinity) = NaN\r\n * tan(-Infinity) = NaN\r\n * tan(NaN) = NaN\r\n *\r\n */\r\nP.tangent = P.tan = function () {\r\n var pr, rm,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (!x.isFinite()) return new Ctor(NaN);\r\n if (x.isZero()) return new Ctor(x);\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n Ctor.precision = pr + 10;\r\n Ctor.rounding = 1;\r\n\r\n x = x.sin();\r\n x.s = 1;\r\n x = divide(x, new Ctor(1).minus(x.times(x)).sqrt(), pr + 10, 0);\r\n\r\n Ctor.precision = pr;\r\n Ctor.rounding = rm;\r\n\r\n return finalise(quadrant == 2 || quadrant == 4 ? x.neg() : x, pr, rm, true);\r\n};\r\n\r\n\r\n/*\r\n * n * 0 = 0\r\n * n * N = N\r\n * n * I = I\r\n * 0 * n = 0\r\n * 0 * 0 = 0\r\n * 0 * N = N\r\n * 0 * I = N\r\n * N * n = N\r\n * N * 0 = N\r\n * N * N = N\r\n * N * I = N\r\n * I * n = I\r\n * I * 0 = N\r\n * I * N = N\r\n * I * I = I\r\n *\r\n * Return a new Decimal whose value is this Decimal times `y`, rounded to `precision` significant\r\n * digits using rounding mode `rounding`.\r\n *\r\n */\r\nP.times = P.mul = function (y) {\r\n var carry, e, i, k, r, rL, t, xdL, ydL,\r\n x = this,\r\n Ctor = x.constructor,\r\n xd = x.d,\r\n yd = (y = new Ctor(y)).d;\r\n\r\n y.s *= x.s;\r\n\r\n // If either is NaN, ±Infinity or ±0...\r\n if (!xd || !xd[0] || !yd || !yd[0]) {\r\n\r\n return new Ctor(!y.s || xd && !xd[0] && !yd || yd && !yd[0] && !xd\r\n\r\n // Return NaN if either is NaN.\r\n // Return NaN if x is ±0 and y is ±Infinity, or y is ±0 and x is ±Infinity.\r\n ? NaN\r\n\r\n // Return ±Infinity if either is ±Infinity.\r\n // Return ±0 if either is ±0.\r\n : !xd || !yd ? y.s / 0 : y.s * 0);\r\n }\r\n\r\n e = mathfloor(x.e / LOG_BASE) + mathfloor(y.e / LOG_BASE);\r\n xdL = xd.length;\r\n ydL = yd.length;\r\n\r\n // Ensure xd points to the longer array.\r\n if (xdL < ydL) {\r\n r = xd;\r\n xd = yd;\r\n yd = r;\r\n rL = xdL;\r\n xdL = ydL;\r\n ydL = rL;\r\n }\r\n\r\n // Initialise the result array with zeros.\r\n r = [];\r\n rL = xdL + ydL;\r\n for (i = rL; i--;) r.push(0);\r\n\r\n // Multiply!\r\n for (i = ydL; --i >= 0;) {\r\n carry = 0;\r\n for (k = xdL + i; k > i;) {\r\n t = r[k] + yd[i] * xd[k - i - 1] + carry;\r\n r[k--] = t % BASE | 0;\r\n carry = t / BASE | 0;\r\n }\r\n\r\n r[k] = (r[k] + carry) % BASE | 0;\r\n }\r\n\r\n // Remove trailing zeros.\r\n for (; !r[--rL];) r.pop();\r\n\r\n if (carry) ++e;\r\n else r.shift();\r\n\r\n y.d = r;\r\n y.e = getBase10Exponent(r, e);\r\n\r\n return external ? finalise(y, Ctor.precision, Ctor.rounding) : y;\r\n};\r\n\r\n\r\n/*\r\n * Return a string representing the value of this Decimal in base 2, round to `sd` significant\r\n * digits using rounding mode `rm`.\r\n *\r\n * If the optional `sd` argument is present then return binary exponential notation.\r\n *\r\n * [sd] {number} Significant digits. Integer, 1 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n */\r\nP.toBinary = function (sd, rm) {\r\n return toStringBinary(this, 2, sd, rm);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal rounded to a maximum of `dp`\r\n * decimal places using rounding mode `rm` or `rounding` if `rm` is omitted.\r\n *\r\n * If `dp` is omitted, return a new Decimal whose value is the value of this Decimal.\r\n *\r\n * [dp] {number} Decimal places. Integer, 0 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n */\r\nP.toDecimalPlaces = P.toDP = function (dp, rm) {\r\n var x = this,\r\n Ctor = x.constructor;\r\n\r\n x = new Ctor(x);\r\n if (dp === void 0) return x;\r\n\r\n checkInt32(dp, 0, MAX_DIGITS);\r\n\r\n if (rm === void 0) rm = Ctor.rounding;\r\n else checkInt32(rm, 0, 8);\r\n\r\n return finalise(x, dp + x.e + 1, rm);\r\n};\r\n\r\n\r\n/*\r\n * Return a string representing the value of this Decimal in exponential notation rounded to\r\n * `dp` fixed decimal places using rounding mode `rounding`.\r\n *\r\n * [dp] {number} Decimal places. Integer, 0 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n */\r\nP.toExponential = function (dp, rm) {\r\n var str,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (dp === void 0) {\r\n str = finiteToString(x, true);\r\n } else {\r\n checkInt32(dp, 0, MAX_DIGITS);\r\n\r\n if (rm === void 0) rm = Ctor.rounding;\r\n else checkInt32(rm, 0, 8);\r\n\r\n x = finalise(new Ctor(x), dp + 1, rm);\r\n str = finiteToString(x, true, dp + 1);\r\n }\r\n\r\n return x.isNeg() && !x.isZero() ? '-' + str : str;\r\n};\r\n\r\n\r\n/*\r\n * Return a string representing the value of this Decimal in normal (fixed-point) notation to\r\n * `dp` fixed decimal places and rounded using rounding mode `rm` or `rounding` if `rm` is\r\n * omitted.\r\n *\r\n * As with JavaScript numbers, (-0).toFixed(0) is '0', but e.g. (-0.00001).toFixed(0) is '-0'.\r\n *\r\n * [dp] {number} Decimal places. Integer, 0 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n * (-0).toFixed(0) is '0', but (-0.1).toFixed(0) is '-0'.\r\n * (-0).toFixed(1) is '0.0', but (-0.01).toFixed(1) is '-0.0'.\r\n * (-0).toFixed(3) is '0.000'.\r\n * (-0.5).toFixed(0) is '-0'.\r\n *\r\n */\r\nP.toFixed = function (dp, rm) {\r\n var str, y,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (dp === void 0) {\r\n str = finiteToString(x);\r\n } else {\r\n checkInt32(dp, 0, MAX_DIGITS);\r\n\r\n if (rm === void 0) rm = Ctor.rounding;\r\n else checkInt32(rm, 0, 8);\r\n\r\n y = finalise(new Ctor(x), dp + x.e + 1, rm);\r\n str = finiteToString(y, false, dp + y.e + 1);\r\n }\r\n\r\n // To determine whether to add the minus sign look at the value before it was rounded,\r\n // i.e. look at `x` rather than `y`.\r\n return x.isNeg() && !x.isZero() ? '-' + str : str;\r\n};\r\n\r\n\r\n/*\r\n * Return an array representing the value of this Decimal as a simple fraction with an integer\r\n * numerator and an integer denominator.\r\n *\r\n * The denominator will be a positive non-zero value less than or equal to the specified maximum\r\n * denominator. If a maximum denominator is not specified, the denominator will be the lowest\r\n * value necessary to represent the number exactly.\r\n *\r\n * [maxD] {number|string|Decimal} Maximum denominator. Integer >= 1 and < Infinity.\r\n *\r\n */\r\nP.toFraction = function (maxD) {\r\n var d, d0, d1, d2, e, k, n, n0, n1, pr, q, r,\r\n x = this,\r\n xd = x.d,\r\n Ctor = x.constructor;\r\n\r\n if (!xd) return new Ctor(x);\r\n\r\n n1 = d0 = new Ctor(1);\r\n d1 = n0 = new Ctor(0);\r\n\r\n d = new Ctor(d1);\r\n e = d.e = getPrecision(xd) - x.e - 1;\r\n k = e % LOG_BASE;\r\n d.d[0] = mathpow(10, k < 0 ? LOG_BASE + k : k);\r\n\r\n if (maxD == null) {\r\n\r\n // d is 10**e, the minimum max-denominator needed.\r\n maxD = e > 0 ? d : n1;\r\n } else {\r\n n = new Ctor(maxD);\r\n if (!n.isInt() || n.lt(n1)) throw Error(invalidArgument + n);\r\n maxD = n.gt(d) ? (e > 0 ? d : n1) : n;\r\n }\r\n\r\n external = false;\r\n n = new Ctor(digitsToString(xd));\r\n pr = Ctor.precision;\r\n Ctor.precision = e = xd.length * LOG_BASE * 2;\r\n\r\n for (;;) {\r\n q = divide(n, d, 0, 1, 1);\r\n d2 = d0.plus(q.times(d1));\r\n if (d2.cmp(maxD) == 1) break;\r\n d0 = d1;\r\n d1 = d2;\r\n d2 = n1;\r\n n1 = n0.plus(q.times(d2));\r\n n0 = d2;\r\n d2 = d;\r\n d = n.minus(q.times(d2));\r\n n = d2;\r\n }\r\n\r\n d2 = divide(maxD.minus(d0), d1, 0, 1, 1);\r\n n0 = n0.plus(d2.times(n1));\r\n d0 = d0.plus(d2.times(d1));\r\n n0.s = n1.s = x.s;\r\n\r\n // Determine which fraction is closer to x, n0/d0 or n1/d1?\r\n r = divide(n1, d1, e, 1).minus(x).abs().cmp(divide(n0, d0, e, 1).minus(x).abs()) < 1\r\n ? [n1, d1] : [n0, d0];\r\n\r\n Ctor.precision = pr;\r\n external = true;\r\n\r\n return r;\r\n};\r\n\r\n\r\n/*\r\n * Return a string representing the value of this Decimal in base 16, round to `sd` significant\r\n * digits using rounding mode `rm`.\r\n *\r\n * If the optional `sd` argument is present then return binary exponential notation.\r\n *\r\n * [sd] {number} Significant digits. Integer, 1 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n */\r\nP.toHexadecimal = P.toHex = function (sd, rm) {\r\n return toStringBinary(this, 16, sd, rm);\r\n};\r\n\r\n\r\n/*\r\n * Returns a new Decimal whose value is the nearest multiple of `y` in the direction of rounding\r\n * mode `rm`, or `Decimal.rounding` if `rm` is omitted, to the value of this Decimal.\r\n *\r\n * The return value will always have the same sign as this Decimal, unless either this Decimal\r\n * or `y` is NaN, in which case the return value will be also be NaN.\r\n *\r\n * The return value is not affected by the value of `precision`.\r\n *\r\n * y {number|string|Decimal} The magnitude to round to a multiple of.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n * 'toNearest() rounding mode not an integer: {rm}'\r\n * 'toNearest() rounding mode out of range: {rm}'\r\n *\r\n */\r\nP.toNearest = function (y, rm) {\r\n var x = this,\r\n Ctor = x.constructor;\r\n\r\n x = new Ctor(x);\r\n\r\n if (y == null) {\r\n\r\n // If x is not finite, return x.\r\n if (!x.d) return x;\r\n\r\n y = new Ctor(1);\r\n rm = Ctor.rounding;\r\n } else {\r\n y = new Ctor(y);\r\n if (rm === void 0) {\r\n rm = Ctor.rounding;\r\n } else {\r\n checkInt32(rm, 0, 8);\r\n }\r\n\r\n // If x is not finite, return x if y is not NaN, else NaN.\r\n if (!x.d) return y.s ? x : y;\r\n\r\n // If y is not finite, return Infinity with the sign of x if y is Infinity, else NaN.\r\n if (!y.d) {\r\n if (y.s) y.s = x.s;\r\n return y;\r\n }\r\n }\r\n\r\n // If y is not zero, calculate the nearest multiple of y to x.\r\n if (y.d[0]) {\r\n external = false;\r\n x = divide(x, y, 0, rm, 1).times(y);\r\n external = true;\r\n finalise(x);\r\n\r\n // If y is zero, return zero with the sign of x.\r\n } else {\r\n y.s = x.s;\r\n x = y;\r\n }\r\n\r\n return x;\r\n};\r\n\r\n\r\n/*\r\n * Return the value of this Decimal converted to a number primitive.\r\n * Zero keeps its sign.\r\n *\r\n */\r\nP.toNumber = function () {\r\n return +this;\r\n};\r\n\r\n\r\n/*\r\n * Return a string representing the value of this Decimal in base 8, round to `sd` significant\r\n * digits using rounding mode `rm`.\r\n *\r\n * If the optional `sd` argument is present then return binary exponential notation.\r\n *\r\n * [sd] {number} Significant digits. Integer, 1 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n */\r\nP.toOctal = function (sd, rm) {\r\n return toStringBinary(this, 8, sd, rm);\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal raised to the power `y`, rounded\r\n * to `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * ECMAScript compliant.\r\n *\r\n * pow(x, NaN) = NaN\r\n * pow(x, ±0) = 1\r\n\r\n * pow(NaN, non-zero) = NaN\r\n * pow(abs(x) > 1, +Infinity) = +Infinity\r\n * pow(abs(x) > 1, -Infinity) = +0\r\n * pow(abs(x) == 1, ±Infinity) = NaN\r\n * pow(abs(x) < 1, +Infinity) = +0\r\n * pow(abs(x) < 1, -Infinity) = +Infinity\r\n * pow(+Infinity, y > 0) = +Infinity\r\n * pow(+Infinity, y < 0) = +0\r\n * pow(-Infinity, odd integer > 0) = -Infinity\r\n * pow(-Infinity, even integer > 0) = +Infinity\r\n * pow(-Infinity, odd integer < 0) = -0\r\n * pow(-Infinity, even integer < 0) = +0\r\n * pow(+0, y > 0) = +0\r\n * pow(+0, y < 0) = +Infinity\r\n * pow(-0, odd integer > 0) = -0\r\n * pow(-0, even integer > 0) = +0\r\n * pow(-0, odd integer < 0) = -Infinity\r\n * pow(-0, even integer < 0) = +Infinity\r\n * pow(finite x < 0, finite non-integer) = NaN\r\n *\r\n * For non-integer or very large exponents pow(x, y) is calculated using\r\n *\r\n * x^y = exp(y*ln(x))\r\n *\r\n * Assuming the first 15 rounding digits are each equally likely to be any digit 0-9, the\r\n * probability of an incorrectly rounded result\r\n * P([49]9{14} | [50]0{14}) = 2 * 0.2 * 10^-14 = 4e-15 = 1/2.5e+14\r\n * i.e. 1 in 250,000,000,000,000\r\n *\r\n * If a result is incorrectly rounded the maximum error will be 1 ulp (unit in last place).\r\n *\r\n * y {number|string|Decimal} The power to which to raise this Decimal.\r\n *\r\n */\r\nP.toPower = P.pow = function (y) {\r\n var e, k, pr, r, rm, s,\r\n x = this,\r\n Ctor = x.constructor,\r\n yn = +(y = new Ctor(y));\r\n\r\n // Either ±Infinity, NaN or ±0?\r\n if (!x.d || !y.d || !x.d[0] || !y.d[0]) return new Ctor(mathpow(+x, yn));\r\n\r\n x = new Ctor(x);\r\n\r\n if (x.eq(1)) return x;\r\n\r\n pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n\r\n if (y.eq(1)) return finalise(x, pr, rm);\r\n\r\n // y exponent\r\n e = mathfloor(y.e / LOG_BASE);\r\n\r\n // If y is a small integer use the 'exponentiation by squaring' algorithm.\r\n if (e >= y.d.length - 1 && (k = yn < 0 ? -yn : yn) <= MAX_SAFE_INTEGER) {\r\n r = intPow(Ctor, x, k, pr);\r\n return y.s < 0 ? new Ctor(1).div(r) : finalise(r, pr, rm);\r\n }\r\n\r\n s = x.s;\r\n\r\n // if x is negative\r\n if (s < 0) {\r\n\r\n // if y is not an integer\r\n if (e < y.d.length - 1) return new Ctor(NaN);\r\n\r\n // Result is positive if x is negative and the last digit of integer y is even.\r\n if ((y.d[e] & 1) == 0) s = 1;\r\n\r\n // if x.eq(-1)\r\n if (x.e == 0 && x.d[0] == 1 && x.d.length == 1) {\r\n x.s = s;\r\n return x;\r\n }\r\n }\r\n\r\n // Estimate result exponent.\r\n // x^y = 10^e, where e = y * log10(x)\r\n // log10(x) = log10(x_significand) + x_exponent\r\n // log10(x_significand) = ln(x_significand) / ln(10)\r\n k = mathpow(+x, yn);\r\n e = k == 0 || !isFinite(k)\r\n ? mathfloor(yn * (Math.log('0.' + digitsToString(x.d)) / Math.LN10 + x.e + 1))\r\n : new Ctor(k + '').e;\r\n\r\n // Exponent estimate may be incorrect e.g. x: 0.999999999999999999, y: 2.29, e: 0, r.e: -1.\r\n\r\n // Overflow/underflow?\r\n if (e > Ctor.maxE + 1 || e < Ctor.minE - 1) return new Ctor(e > 0 ? s / 0 : 0);\r\n\r\n external = false;\r\n Ctor.rounding = x.s = 1;\r\n\r\n // Estimate the extra guard digits needed to ensure five correct rounding digits from\r\n // naturalLogarithm(x). Example of failure without these extra digits (precision: 10):\r\n // new Decimal(2.32456).pow('2087987436534566.46411')\r\n // should be 1.162377823e+764914905173815, but is 1.162355823e+764914905173815\r\n k = Math.min(12, (e + '').length);\r\n\r\n // r = x^y = exp(y*ln(x))\r\n r = naturalExponential(y.times(naturalLogarithm(x, pr + k)), pr);\r\n\r\n // r may be Infinity, e.g. (0.9999999999999999).pow(-1e+40)\r\n if (r.d) {\r\n\r\n // Truncate to the required precision plus five rounding digits.\r\n r = finalise(r, pr + 5, 1);\r\n\r\n // If the rounding digits are [49]9999 or [50]0000 increase the precision by 10 and recalculate\r\n // the result.\r\n if (checkRoundingDigits(r.d, pr, rm)) {\r\n e = pr + 10;\r\n\r\n // Truncate to the increased precision plus five rounding digits.\r\n r = finalise(naturalExponential(y.times(naturalLogarithm(x, e + k)), e), e + 5, 1);\r\n\r\n // Check for 14 nines from the 2nd rounding digit (the first rounding digit may be 4 or 9).\r\n if (+digitsToString(r.d).slice(pr + 1, pr + 15) + 1 == 1e14) {\r\n r = finalise(r, pr + 1, 0);\r\n }\r\n }\r\n }\r\n\r\n r.s = s;\r\n external = true;\r\n Ctor.rounding = rm;\r\n\r\n return finalise(r, pr, rm);\r\n};\r\n\r\n\r\n/*\r\n * Return a string representing the value of this Decimal rounded to `sd` significant digits\r\n * using rounding mode `rounding`.\r\n *\r\n * Return exponential notation if `sd` is less than the number of digits necessary to represent\r\n * the integer part of the value in normal notation.\r\n *\r\n * [sd] {number} Significant digits. Integer, 1 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n */\r\nP.toPrecision = function (sd, rm) {\r\n var str,\r\n x = this,\r\n Ctor = x.constructor;\r\n\r\n if (sd === void 0) {\r\n str = finiteToString(x, x.e <= Ctor.toExpNeg || x.e >= Ctor.toExpPos);\r\n } else {\r\n checkInt32(sd, 1, MAX_DIGITS);\r\n\r\n if (rm === void 0) rm = Ctor.rounding;\r\n else checkInt32(rm, 0, 8);\r\n\r\n x = finalise(new Ctor(x), sd, rm);\r\n str = finiteToString(x, sd <= x.e || x.e <= Ctor.toExpNeg, sd);\r\n }\r\n\r\n return x.isNeg() && !x.isZero() ? '-' + str : str;\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal rounded to a maximum of `sd`\r\n * significant digits using rounding mode `rm`, or to `precision` and `rounding` respectively if\r\n * omitted.\r\n *\r\n * [sd] {number} Significant digits. Integer, 1 to MAX_DIGITS inclusive.\r\n * [rm] {number} Rounding mode. Integer, 0 to 8 inclusive.\r\n *\r\n * 'toSD() digits out of range: {sd}'\r\n * 'toSD() digits not an integer: {sd}'\r\n * 'toSD() rounding mode not an integer: {rm}'\r\n * 'toSD() rounding mode out of range: {rm}'\r\n *\r\n */\r\nP.toSignificantDigits = P.toSD = function (sd, rm) {\r\n var x = this,\r\n Ctor = x.constructor;\r\n\r\n if (sd === void 0) {\r\n sd = Ctor.precision;\r\n rm = Ctor.rounding;\r\n } else {\r\n checkInt32(sd, 1, MAX_DIGITS);\r\n\r\n if (rm === void 0) rm = Ctor.rounding;\r\n else checkInt32(rm, 0, 8);\r\n }\r\n\r\n return finalise(new Ctor(x), sd, rm);\r\n};\r\n\r\n\r\n/*\r\n * Return a string representing the value of this Decimal.\r\n *\r\n * Return exponential notation if this Decimal has a positive exponent equal to or greater than\r\n * `toExpPos`, or a negative exponent equal to or less than `toExpNeg`.\r\n *\r\n */\r\nP.toString = function () {\r\n var x = this,\r\n Ctor = x.constructor,\r\n str = finiteToString(x, x.e <= Ctor.toExpNeg || x.e >= Ctor.toExpPos);\r\n\r\n return x.isNeg() && !x.isZero() ? '-' + str : str;\r\n};\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of this Decimal truncated to a whole number.\r\n *\r\n */\r\nP.truncated = P.trunc = function () {\r\n return finalise(new this.constructor(this), this.e + 1, 1);\r\n};\r\n\r\n\r\n/*\r\n * Return a string representing the value of this Decimal.\r\n * Unlike `toString`, negative zero will include the minus sign.\r\n *\r\n */\r\nP.valueOf = P.toJSON = function () {\r\n var x = this,\r\n Ctor = x.constructor,\r\n str = finiteToString(x, x.e <= Ctor.toExpNeg || x.e >= Ctor.toExpPos);\r\n\r\n return x.isNeg() ? '-' + str : str;\r\n};\r\n\r\n\r\n// Helper functions for Decimal.prototype (P) and/or Decimal methods, and their callers.\r\n\r\n\r\n/*\r\n * digitsToString P.cubeRoot, P.logarithm, P.squareRoot, P.toFraction, P.toPower,\r\n * finiteToString, naturalExponential, naturalLogarithm\r\n * checkInt32 P.toDecimalPlaces, P.toExponential, P.toFixed, P.toNearest,\r\n * P.toPrecision, P.toSignificantDigits, toStringBinary, random\r\n * checkRoundingDigits P.logarithm, P.toPower, naturalExponential, naturalLogarithm\r\n * convertBase toStringBinary, parseOther\r\n * cos P.cos\r\n * divide P.atanh, P.cubeRoot, P.dividedBy, P.dividedToIntegerBy,\r\n * P.logarithm, P.modulo, P.squareRoot, P.tan, P.tanh, P.toFraction,\r\n * P.toNearest, toStringBinary, naturalExponential, naturalLogarithm,\r\n * taylorSeries, atan2, parseOther\r\n * finalise P.absoluteValue, P.atan, P.atanh, P.ceil, P.cos, P.cosh,\r\n * P.cubeRoot, P.dividedToIntegerBy, P.floor, P.logarithm, P.minus,\r\n * P.modulo, P.negated, P.plus, P.round, P.sin, P.sinh, P.squareRoot,\r\n * P.tan, P.times, P.toDecimalPlaces, P.toExponential, P.toFixed,\r\n * P.toNearest, P.toPower, P.toPrecision, P.toSignificantDigits,\r\n * P.truncated, divide, getLn10, getPi, naturalExponential,\r\n * naturalLogarithm, ceil, floor, round, trunc\r\n * finiteToString P.toExponential, P.toFixed, P.toPrecision, P.toString, P.valueOf,\r\n * toStringBinary\r\n * getBase10Exponent P.minus, P.plus, P.times, parseOther\r\n * getLn10 P.logarithm, naturalLogarithm\r\n * getPi P.acos, P.asin, P.atan, toLessThanHalfPi, atan2\r\n * getPrecision P.precision, P.toFraction\r\n * getZeroString digitsToString, finiteToString\r\n * intPow P.toPower, parseOther\r\n * isOdd toLessThanHalfPi\r\n * maxOrMin max, min\r\n * naturalExponential P.naturalExponential, P.toPower\r\n * naturalLogarithm P.acosh, P.asinh, P.atanh, P.logarithm, P.naturalLogarithm,\r\n * P.toPower, naturalExponential\r\n * nonFiniteToString finiteToString, toStringBinary\r\n * parseDecimal Decimal\r\n * parseOther Decimal\r\n * sin P.sin\r\n * taylorSeries P.cosh, P.sinh, cos, sin\r\n * toLessThanHalfPi P.cos, P.sin\r\n * toStringBinary P.toBinary, P.toHexadecimal, P.toOctal\r\n * truncate intPow\r\n *\r\n * Throws: P.logarithm, P.precision, P.toFraction, checkInt32, getLn10, getPi,\r\n * naturalLogarithm, config, parseOther, random, Decimal\r\n */\r\n\r\n\r\nfunction digitsToString(d) {\r\n var i, k, ws,\r\n indexOfLastWord = d.length - 1,\r\n str = '',\r\n w = d[0];\r\n\r\n if (indexOfLastWord > 0) {\r\n str += w;\r\n for (i = 1; i < indexOfLastWord; i++) {\r\n ws = d[i] + '';\r\n k = LOG_BASE - ws.length;\r\n if (k) str += getZeroString(k);\r\n str += ws;\r\n }\r\n\r\n w = d[i];\r\n ws = w + '';\r\n k = LOG_BASE - ws.length;\r\n if (k) str += getZeroString(k);\r\n } else if (w === 0) {\r\n return '0';\r\n }\r\n\r\n // Remove trailing zeros of last w.\r\n for (; w % 10 === 0;) w /= 10;\r\n\r\n return str + w;\r\n}\r\n\r\n\r\nfunction checkInt32(i, min, max) {\r\n if (i !== ~~i || i < min || i > max) {\r\n throw Error(invalidArgument + i);\r\n }\r\n}\r\n\r\n\r\n/*\r\n * Check 5 rounding digits if `repeating` is null, 4 otherwise.\r\n * `repeating == null` if caller is `log` or `pow`,\r\n * `repeating != null` if caller is `naturalLogarithm` or `naturalExponential`.\r\n */\r\nfunction checkRoundingDigits(d, i, rm, repeating) {\r\n var di, k, r, rd;\r\n\r\n // Get the length of the first word of the array d.\r\n for (k = d[0]; k >= 10; k /= 10) --i;\r\n\r\n // Is the rounding digit in the first word of d?\r\n if (--i < 0) {\r\n i += LOG_BASE;\r\n di = 0;\r\n } else {\r\n di = Math.ceil((i + 1) / LOG_BASE);\r\n i %= LOG_BASE;\r\n }\r\n\r\n // i is the index (0 - 6) of the rounding digit.\r\n // E.g. if within the word 3487563 the first rounding digit is 5,\r\n // then i = 4, k = 1000, rd = 3487563 % 1000 = 563\r\n k = mathpow(10, LOG_BASE - i);\r\n rd = d[di] % k | 0;\r\n\r\n if (repeating == null) {\r\n if (i < 3) {\r\n if (i == 0) rd = rd / 100 | 0;\r\n else if (i == 1) rd = rd / 10 | 0;\r\n r = rm < 4 && rd == 99999 || rm > 3 && rd == 49999 || rd == 50000 || rd == 0;\r\n } else {\r\n r = (rm < 4 && rd + 1 == k || rm > 3 && rd + 1 == k / 2) &&\r\n (d[di + 1] / k / 100 | 0) == mathpow(10, i - 2) - 1 ||\r\n (rd == k / 2 || rd == 0) && (d[di + 1] / k / 100 | 0) == 0;\r\n }\r\n } else {\r\n if (i < 4) {\r\n if (i == 0) rd = rd / 1000 | 0;\r\n else if (i == 1) rd = rd / 100 | 0;\r\n else if (i == 2) rd = rd / 10 | 0;\r\n r = (repeating || rm < 4) && rd == 9999 || !repeating && rm > 3 && rd == 4999;\r\n } else {\r\n r = ((repeating || rm < 4) && rd + 1 == k ||\r\n (!repeating && rm > 3) && rd + 1 == k / 2) &&\r\n (d[di + 1] / k / 1000 | 0) == mathpow(10, i - 3) - 1;\r\n }\r\n }\r\n\r\n return r;\r\n}\r\n\r\n\r\n// Convert string of `baseIn` to an array of numbers of `baseOut`.\r\n// Eg. convertBase('255', 10, 16) returns [15, 15].\r\n// Eg. convertBase('ff', 16, 10) returns [2, 5, 5].\r\nfunction convertBase(str, baseIn, baseOut) {\r\n var j,\r\n arr = [0],\r\n arrL,\r\n i = 0,\r\n strL = str.length;\r\n\r\n for (; i < strL;) {\r\n for (arrL = arr.length; arrL--;) arr[arrL] *= baseIn;\r\n arr[0] += NUMERALS.indexOf(str.charAt(i++));\r\n for (j = 0; j < arr.length; j++) {\r\n if (arr[j] > baseOut - 1) {\r\n if (arr[j + 1] === void 0) arr[j + 1] = 0;\r\n arr[j + 1] += arr[j] / baseOut | 0;\r\n arr[j] %= baseOut;\r\n }\r\n }\r\n }\r\n\r\n return arr.reverse();\r\n}\r\n\r\n\r\n/*\r\n * cos(x) = 1 - x^2/2! + x^4/4! - ...\r\n * |x| < pi/2\r\n *\r\n */\r\nfunction cosine(Ctor, x) {\r\n var k, len, y;\r\n\r\n if (x.isZero()) return x;\r\n\r\n // Argument reduction: cos(4x) = 8*(cos^4(x) - cos^2(x)) + 1\r\n // i.e. cos(x) = 8*(cos^4(x/4) - cos^2(x/4)) + 1\r\n\r\n // Estimate the optimum number of times to use the argument reduction.\r\n len = x.d.length;\r\n if (len < 32) {\r\n k = Math.ceil(len / 3);\r\n y = (1 / tinyPow(4, k)).toString();\r\n } else {\r\n k = 16;\r\n y = '2.3283064365386962890625e-10';\r\n }\r\n\r\n Ctor.precision += k;\r\n\r\n x = taylorSeries(Ctor, 1, x.times(y), new Ctor(1));\r\n\r\n // Reverse argument reduction\r\n for (var i = k; i--;) {\r\n var cos2x = x.times(x);\r\n x = cos2x.times(cos2x).minus(cos2x).times(8).plus(1);\r\n }\r\n\r\n Ctor.precision -= k;\r\n\r\n return x;\r\n}\r\n\r\n\r\n/*\r\n * Perform division in the specified base.\r\n */\r\nvar divide = (function () {\r\n\r\n // Assumes non-zero x and k, and hence non-zero result.\r\n function multiplyInteger(x, k, base) {\r\n var temp,\r\n carry = 0,\r\n i = x.length;\r\n\r\n for (x = x.slice(); i--;) {\r\n temp = x[i] * k + carry;\r\n x[i] = temp % base | 0;\r\n carry = temp / base | 0;\r\n }\r\n\r\n if (carry) x.unshift(carry);\r\n\r\n return x;\r\n }\r\n\r\n function compare(a, b, aL, bL) {\r\n var i, r;\r\n\r\n if (aL != bL) {\r\n r = aL > bL ? 1 : -1;\r\n } else {\r\n for (i = r = 0; i < aL; i++) {\r\n if (a[i] != b[i]) {\r\n r = a[i] > b[i] ? 1 : -1;\r\n break;\r\n }\r\n }\r\n }\r\n\r\n return r;\r\n }\r\n\r\n function subtract(a, b, aL, base) {\r\n var i = 0;\r\n\r\n // Subtract b from a.\r\n for (; aL--;) {\r\n a[aL] -= i;\r\n i = a[aL] < b[aL] ? 1 : 0;\r\n a[aL] = i * base + a[aL] - b[aL];\r\n }\r\n\r\n // Remove leading zeros.\r\n for (; !a[0] && a.length > 1;) a.shift();\r\n }\r\n\r\n return function (x, y, pr, rm, dp, base) {\r\n var cmp, e, i, k, logBase, more, prod, prodL, q, qd, rem, remL, rem0, sd, t, xi, xL, yd0,\r\n yL, yz,\r\n Ctor = x.constructor,\r\n sign = x.s == y.s ? 1 : -1,\r\n xd = x.d,\r\n yd = y.d;\r\n\r\n // Either NaN, Infinity or 0?\r\n if (!xd || !xd[0] || !yd || !yd[0]) {\r\n\r\n return new Ctor(// Return NaN if either NaN, or both Infinity or 0.\r\n !x.s || !y.s || (xd ? yd && xd[0] == yd[0] : !yd) ? NaN :\r\n\r\n // Return ±0 if x is 0 or y is ±Infinity, or return ±Infinity as y is 0.\r\n xd && xd[0] == 0 || !yd ? sign * 0 : sign / 0);\r\n }\r\n\r\n if (base) {\r\n logBase = 1;\r\n e = x.e - y.e;\r\n } else {\r\n base = BASE;\r\n logBase = LOG_BASE;\r\n e = mathfloor(x.e / logBase) - mathfloor(y.e / logBase);\r\n }\r\n\r\n yL = yd.length;\r\n xL = xd.length;\r\n q = new Ctor(sign);\r\n qd = q.d = [];\r\n\r\n // Result exponent may be one less than e.\r\n // The digit array of a Decimal from toStringBinary may have trailing zeros.\r\n for (i = 0; yd[i] == (xd[i] || 0); i++);\r\n\r\n if (yd[i] > (xd[i] || 0)) e--;\r\n\r\n if (pr == null) {\r\n sd = pr = Ctor.precision;\r\n rm = Ctor.rounding;\r\n } else if (dp) {\r\n sd = pr + (x.e - y.e) + 1;\r\n } else {\r\n sd = pr;\r\n }\r\n\r\n if (sd < 0) {\r\n qd.push(1);\r\n more = true;\r\n } else {\r\n\r\n // Convert precision in number of base 10 digits to base 1e7 digits.\r\n sd = sd / logBase + 2 | 0;\r\n i = 0;\r\n\r\n // divisor < 1e7\r\n if (yL == 1) {\r\n k = 0;\r\n yd = yd[0];\r\n sd++;\r\n\r\n // k is the carry.\r\n for (; (i < xL || k) && sd--; i++) {\r\n t = k * base + (xd[i] || 0);\r\n qd[i] = t / yd | 0;\r\n k = t % yd | 0;\r\n }\r\n\r\n more = k || i < xL;\r\n\r\n // divisor >= 1e7\r\n } else {\r\n\r\n // Normalise xd and yd so highest order digit of yd is >= base/2\r\n k = base / (yd[0] + 1) | 0;\r\n\r\n if (k > 1) {\r\n yd = multiplyInteger(yd, k, base);\r\n xd = multiplyInteger(xd, k, base);\r\n yL = yd.length;\r\n xL = xd.length;\r\n }\r\n\r\n xi = yL;\r\n rem = xd.slice(0, yL);\r\n remL = rem.length;\r\n\r\n // Add zeros to make remainder as long as divisor.\r\n for (; remL < yL;) rem[remL++] = 0;\r\n\r\n yz = yd.slice();\r\n yz.unshift(0);\r\n yd0 = yd[0];\r\n\r\n if (yd[1] >= base / 2) ++yd0;\r\n\r\n do {\r\n k = 0;\r\n\r\n // Compare divisor and remainder.\r\n cmp = compare(yd, rem, yL, remL);\r\n\r\n // If divisor < remainder.\r\n if (cmp < 0) {\r\n\r\n // Calculate trial digit, k.\r\n rem0 = rem[0];\r\n if (yL != remL) rem0 = rem0 * base + (rem[1] || 0);\r\n\r\n // k will be how many times the divisor goes into the current remainder.\r\n k = rem0 / yd0 | 0;\r\n\r\n // Algorithm:\r\n // 1. product = divisor * trial digit (k)\r\n // 2. if product > remainder: product -= divisor, k--\r\n // 3. remainder -= product\r\n // 4. if product was < remainder at 2:\r\n // 5. compare new remainder and divisor\r\n // 6. If remainder > divisor: remainder -= divisor, k++\r\n\r\n if (k > 1) {\r\n if (k >= base) k = base - 1;\r\n\r\n // product = divisor * trial digit.\r\n prod = multiplyInteger(yd, k, base);\r\n prodL = prod.length;\r\n remL = rem.length;\r\n\r\n // Compare product and remainder.\r\n cmp = compare(prod, rem, prodL, remL);\r\n\r\n // product > remainder.\r\n if (cmp == 1) {\r\n k--;\r\n\r\n // Subtract divisor from product.\r\n subtract(prod, yL < prodL ? yz : yd, prodL, base);\r\n }\r\n } else {\r\n\r\n // cmp is -1.\r\n // If k is 0, there is no need to compare yd and rem again below, so change cmp to 1\r\n // to avoid it. If k is 1 there is a need to compare yd and rem again below.\r\n if (k == 0) cmp = k = 1;\r\n prod = yd.slice();\r\n }\r\n\r\n prodL = prod.length;\r\n if (prodL < remL) prod.unshift(0);\r\n\r\n // Subtract product from remainder.\r\n subtract(rem, prod, remL, base);\r\n\r\n // If product was < previous remainder.\r\n if (cmp == -1) {\r\n remL = rem.length;\r\n\r\n // Compare divisor and new remainder.\r\n cmp = compare(yd, rem, yL, remL);\r\n\r\n // If divisor < new remainder, subtract divisor from remainder.\r\n if (cmp < 1) {\r\n k++;\r\n\r\n // Subtract divisor from remainder.\r\n subtract(rem, yL < remL ? yz : yd, remL, base);\r\n }\r\n }\r\n\r\n remL = rem.length;\r\n } else if (cmp === 0) {\r\n k++;\r\n rem = [0];\r\n } // if cmp === 1, k will be 0\r\n\r\n // Add the next digit, k, to the result array.\r\n qd[i++] = k;\r\n\r\n // Update the remainder.\r\n if (cmp && rem[0]) {\r\n rem[remL++] = xd[xi] || 0;\r\n } else {\r\n rem = [xd[xi]];\r\n remL = 1;\r\n }\r\n\r\n } while ((xi++ < xL || rem[0] !== void 0) && sd--);\r\n\r\n more = rem[0] !== void 0;\r\n }\r\n\r\n // Leading zero?\r\n if (!qd[0]) qd.shift();\r\n }\r\n\r\n // logBase is 1 when divide is being used for base conversion.\r\n if (logBase == 1) {\r\n q.e = e;\r\n inexact = more;\r\n } else {\r\n\r\n // To calculate q.e, first get the number of digits of qd[0].\r\n for (i = 1, k = qd[0]; k >= 10; k /= 10) i++;\r\n q.e = i + e * logBase - 1;\r\n\r\n finalise(q, dp ? pr + q.e + 1 : pr, rm, more);\r\n }\r\n\r\n return q;\r\n };\r\n})();\r\n\r\n\r\n/*\r\n * Round `x` to `sd` significant digits using rounding mode `rm`.\r\n * Check for over/under-flow.\r\n */\r\n function finalise(x, sd, rm, isTruncated) {\r\n var digits, i, j, k, rd, roundUp, w, xd, xdi,\r\n Ctor = x.constructor;\r\n\r\n // Don't round if sd is null or undefined.\r\n out: if (sd != null) {\r\n xd = x.d;\r\n\r\n // Infinity/NaN.\r\n if (!xd) return x;\r\n\r\n // rd: the rounding digit, i.e. the digit after the digit that may be rounded up.\r\n // w: the word of xd containing rd, a base 1e7 number.\r\n // xdi: the index of w within xd.\r\n // digits: the number of digits of w.\r\n // i: what would be the index of rd within w if all the numbers were 7 digits long (i.e. if\r\n // they had leading zeros)\r\n // j: if > 0, the actual index of rd within w (if < 0, rd is a leading zero).\r\n\r\n // Get the length of the first word of the digits array xd.\r\n for (digits = 1, k = xd[0]; k >= 10; k /= 10) digits++;\r\n i = sd - digits;\r\n\r\n // Is the rounding digit in the first word of xd?\r\n if (i < 0) {\r\n i += LOG_BASE;\r\n j = sd;\r\n w = xd[xdi = 0];\r\n\r\n // Get the rounding digit at index j of w.\r\n rd = w / mathpow(10, digits - j - 1) % 10 | 0;\r\n } else {\r\n xdi = Math.ceil((i + 1) / LOG_BASE);\r\n k = xd.length;\r\n if (xdi >= k) {\r\n if (isTruncated) {\r\n\r\n // Needed by `naturalExponential`, `naturalLogarithm` and `squareRoot`.\r\n for (; k++ <= xdi;) xd.push(0);\r\n w = rd = 0;\r\n digits = 1;\r\n i %= LOG_BASE;\r\n j = i - LOG_BASE + 1;\r\n } else {\r\n break out;\r\n }\r\n } else {\r\n w = k = xd[xdi];\r\n\r\n // Get the number of digits of w.\r\n for (digits = 1; k >= 10; k /= 10) digits++;\r\n\r\n // Get the index of rd within w.\r\n i %= LOG_BASE;\r\n\r\n // Get the index of rd within w, adjusted for leading zeros.\r\n // The number of leading zeros of w is given by LOG_BASE - digits.\r\n j = i - LOG_BASE + digits;\r\n\r\n // Get the rounding digit at index j of w.\r\n rd = j < 0 ? 0 : w / mathpow(10, digits - j - 1) % 10 | 0;\r\n }\r\n }\r\n\r\n // Are there any non-zero digits after the rounding digit?\r\n isTruncated = isTruncated || sd < 0 ||\r\n xd[xdi + 1] !== void 0 || (j < 0 ? w : w % mathpow(10, digits - j - 1));\r\n\r\n // The expression `w % mathpow(10, digits - j - 1)` returns all the digits of w to the right\r\n // of the digit at (left-to-right) index j, e.g. if w is 908714 and j is 2, the expression\r\n // will give 714.\r\n\r\n roundUp = rm < 4\r\n ? (rd || isTruncated) && (rm == 0 || rm == (x.s < 0 ? 3 : 2))\r\n : rd > 5 || rd == 5 && (rm == 4 || isTruncated || rm == 6 &&\r\n\r\n // Check whether the digit to the left of the rounding digit is odd.\r\n ((i > 0 ? j > 0 ? w / mathpow(10, digits - j) : 0 : xd[xdi - 1]) % 10) & 1 ||\r\n rm == (x.s < 0 ? 8 : 7));\r\n\r\n if (sd < 1 || !xd[0]) {\r\n xd.length = 0;\r\n if (roundUp) {\r\n\r\n // Convert sd to decimal places.\r\n sd -= x.e + 1;\r\n\r\n // 1, 0.1, 0.01, 0.001, 0.0001 etc.\r\n xd[0] = mathpow(10, (LOG_BASE - sd % LOG_BASE) % LOG_BASE);\r\n x.e = -sd || 0;\r\n } else {\r\n\r\n // Zero.\r\n xd[0] = x.e = 0;\r\n }\r\n\r\n return x;\r\n }\r\n\r\n // Remove excess digits.\r\n if (i == 0) {\r\n xd.length = xdi;\r\n k = 1;\r\n xdi--;\r\n } else {\r\n xd.length = xdi + 1;\r\n k = mathpow(10, LOG_BASE - i);\r\n\r\n // E.g. 56700 becomes 56000 if 7 is the rounding digit.\r\n // j > 0 means i > number of leading zeros of w.\r\n xd[xdi] = j > 0 ? (w / mathpow(10, digits - j) % mathpow(10, j) | 0) * k : 0;\r\n }\r\n\r\n if (roundUp) {\r\n for (;;) {\r\n\r\n // Is the digit to be rounded up in the first word of xd?\r\n if (xdi == 0) {\r\n\r\n // i will be the length of xd[0] before k is added.\r\n for (i = 1, j = xd[0]; j >= 10; j /= 10) i++;\r\n j = xd[0] += k;\r\n for (k = 1; j >= 10; j /= 10) k++;\r\n\r\n // if i != k the length has increased.\r\n if (i != k) {\r\n x.e++;\r\n if (xd[0] == BASE) xd[0] = 1;\r\n }\r\n\r\n break;\r\n } else {\r\n xd[xdi] += k;\r\n if (xd[xdi] != BASE) break;\r\n xd[xdi--] = 0;\r\n k = 1;\r\n }\r\n }\r\n }\r\n\r\n // Remove trailing zeros.\r\n for (i = xd.length; xd[--i] === 0;) xd.pop();\r\n }\r\n\r\n if (external) {\r\n\r\n // Overflow?\r\n if (x.e > Ctor.maxE) {\r\n\r\n // Infinity.\r\n x.d = null;\r\n x.e = NaN;\r\n\r\n // Underflow?\r\n } else if (x.e < Ctor.minE) {\r\n\r\n // Zero.\r\n x.e = 0;\r\n x.d = [0];\r\n // Ctor.underflow = true;\r\n } // else Ctor.underflow = false;\r\n }\r\n\r\n return x;\r\n}\r\n\r\n\r\nfunction finiteToString(x, isExp, sd) {\r\n if (!x.isFinite()) return nonFiniteToString(x);\r\n var k,\r\n e = x.e,\r\n str = digitsToString(x.d),\r\n len = str.length;\r\n\r\n if (isExp) {\r\n if (sd && (k = sd - len) > 0) {\r\n str = str.charAt(0) + '.' + str.slice(1) + getZeroString(k);\r\n } else if (len > 1) {\r\n str = str.charAt(0) + '.' + str.slice(1);\r\n }\r\n\r\n str = str + (x.e < 0 ? 'e' : 'e+') + x.e;\r\n } else if (e < 0) {\r\n str = '0.' + getZeroString(-e - 1) + str;\r\n if (sd && (k = sd - len) > 0) str += getZeroString(k);\r\n } else if (e >= len) {\r\n str += getZeroString(e + 1 - len);\r\n if (sd && (k = sd - e - 1) > 0) str = str + '.' + getZeroString(k);\r\n } else {\r\n if ((k = e + 1) < len) str = str.slice(0, k) + '.' + str.slice(k);\r\n if (sd && (k = sd - len) > 0) {\r\n if (e + 1 === len) str += '.';\r\n str += getZeroString(k);\r\n }\r\n }\r\n\r\n return str;\r\n}\r\n\r\n\r\n// Calculate the base 10 exponent from the base 1e7 exponent.\r\nfunction getBase10Exponent(digits, e) {\r\n var w = digits[0];\r\n\r\n // Add the number of digits of the first word of the digits array.\r\n for ( e *= LOG_BASE; w >= 10; w /= 10) e++;\r\n return e;\r\n}\r\n\r\n\r\nfunction getLn10(Ctor, sd, pr) {\r\n if (sd > LN10_PRECISION) {\r\n\r\n // Reset global state in case the exception is caught.\r\n external = true;\r\n if (pr) Ctor.precision = pr;\r\n throw Error(precisionLimitExceeded);\r\n }\r\n return finalise(new Ctor(LN10), sd, 1, true);\r\n}\r\n\r\n\r\nfunction getPi(Ctor, sd, rm) {\r\n if (sd > PI_PRECISION) throw Error(precisionLimitExceeded);\r\n return finalise(new Ctor(PI), sd, rm, true);\r\n}\r\n\r\n\r\nfunction getPrecision(digits) {\r\n var w = digits.length - 1,\r\n len = w * LOG_BASE + 1;\r\n\r\n w = digits[w];\r\n\r\n // If non-zero...\r\n if (w) {\r\n\r\n // Subtract the number of trailing zeros of the last word.\r\n for (; w % 10 == 0; w /= 10) len--;\r\n\r\n // Add the number of digits of the first word.\r\n for (w = digits[0]; w >= 10; w /= 10) len++;\r\n }\r\n\r\n return len;\r\n}\r\n\r\n\r\nfunction getZeroString(k) {\r\n var zs = '';\r\n for (; k--;) zs += '0';\r\n return zs;\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the value of Decimal `x` to the power `n`, where `n` is an\r\n * integer of type number.\r\n *\r\n * Implements 'exponentiation by squaring'. Called by `pow` and `parseOther`.\r\n *\r\n */\r\nfunction intPow(Ctor, x, n, pr) {\r\n var isTruncated,\r\n r = new Ctor(1),\r\n\r\n // Max n of 9007199254740991 takes 53 loop iterations.\r\n // Maximum digits array length; leaves [28, 34] guard digits.\r\n k = Math.ceil(pr / LOG_BASE + 4);\r\n\r\n external = false;\r\n\r\n for (;;) {\r\n if (n % 2) {\r\n r = r.times(x);\r\n if (truncate(r.d, k)) isTruncated = true;\r\n }\r\n\r\n n = mathfloor(n / 2);\r\n if (n === 0) {\r\n\r\n // To ensure correct rounding when r.d is truncated, increment the last word if it is zero.\r\n n = r.d.length - 1;\r\n if (isTruncated && r.d[n] === 0) ++r.d[n];\r\n break;\r\n }\r\n\r\n x = x.times(x);\r\n truncate(x.d, k);\r\n }\r\n\r\n external = true;\r\n\r\n return r;\r\n}\r\n\r\n\r\nfunction isOdd(n) {\r\n return n.d[n.d.length - 1] & 1;\r\n}\r\n\r\n\r\n/*\r\n * Handle `max` and `min`. `ltgt` is 'lt' or 'gt'.\r\n */\r\nfunction maxOrMin(Ctor, args, ltgt) {\r\n var y,\r\n x = new Ctor(args[0]),\r\n i = 0;\r\n\r\n for (; ++i < args.length;) {\r\n y = new Ctor(args[i]);\r\n if (!y.s) {\r\n x = y;\r\n break;\r\n } else if (x[ltgt](y)) {\r\n x = y;\r\n }\r\n }\r\n\r\n return x;\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the natural exponential of `x` rounded to `sd` significant\r\n * digits.\r\n *\r\n * Taylor/Maclaurin series.\r\n *\r\n * exp(x) = x^0/0! + x^1/1! + x^2/2! + x^3/3! + ...\r\n *\r\n * Argument reduction:\r\n * Repeat x = x / 32, k += 5, until |x| < 0.1\r\n * exp(x) = exp(x / 2^k)^(2^k)\r\n *\r\n * Previously, the argument was initially reduced by\r\n * exp(x) = exp(r) * 10^k where r = x - k * ln10, k = floor(x / ln10)\r\n * to first put r in the range [0, ln10], before dividing by 32 until |x| < 0.1, but this was\r\n * found to be slower than just dividing repeatedly by 32 as above.\r\n *\r\n * Max integer argument: exp('20723265836946413') = 6.3e+9000000000000000\r\n * Min integer argument: exp('-20723265836946411') = 1.2e-9000000000000000\r\n * (Math object integer min/max: Math.exp(709) = 8.2e+307, Math.exp(-745) = 5e-324)\r\n *\r\n * exp(Infinity) = Infinity\r\n * exp(-Infinity) = 0\r\n * exp(NaN) = NaN\r\n * exp(±0) = 1\r\n *\r\n * exp(x) is non-terminating for any finite, non-zero x.\r\n *\r\n * The result will always be correctly rounded.\r\n *\r\n */\r\nfunction naturalExponential(x, sd) {\r\n var denominator, guard, j, pow, sum, t, wpr,\r\n rep = 0,\r\n i = 0,\r\n k = 0,\r\n Ctor = x.constructor,\r\n rm = Ctor.rounding,\r\n pr = Ctor.precision;\r\n\r\n // 0/NaN/Infinity?\r\n if (!x.d || !x.d[0] || x.e > 17) {\r\n\r\n return new Ctor(x.d\r\n ? !x.d[0] ? 1 : x.s < 0 ? 0 : 1 / 0\r\n : x.s ? x.s < 0 ? 0 : x : 0 / 0);\r\n }\r\n\r\n if (sd == null) {\r\n external = false;\r\n wpr = pr;\r\n } else {\r\n wpr = sd;\r\n }\r\n\r\n t = new Ctor(0.03125);\r\n\r\n // while abs(x) >= 0.1\r\n while (x.e > -2) {\r\n\r\n // x = x / 2^5\r\n x = x.times(t);\r\n k += 5;\r\n }\r\n\r\n // Use 2 * log10(2^k) + 5 (empirically derived) to estimate the increase in precision\r\n // necessary to ensure the first 4 rounding digits are correct.\r\n guard = Math.log(mathpow(2, k)) / Math.LN10 * 2 + 5 | 0;\r\n wpr += guard;\r\n denominator = pow = sum = new Ctor(1);\r\n Ctor.precision = wpr;\r\n\r\n for (;;) {\r\n pow = finalise(pow.times(x), wpr, 1);\r\n denominator = denominator.times(++i);\r\n t = sum.plus(divide(pow, denominator, wpr, 1));\r\n\r\n if (digitsToString(t.d).slice(0, wpr) === digitsToString(sum.d).slice(0, wpr)) {\r\n j = k;\r\n while (j--) sum = finalise(sum.times(sum), wpr, 1);\r\n\r\n // Check to see if the first 4 rounding digits are [49]999.\r\n // If so, repeat the summation with a higher precision, otherwise\r\n // e.g. with precision: 18, rounding: 1\r\n // exp(18.404272462595034083567793919843761) = 98372560.1229999999 (should be 98372560.123)\r\n // `wpr - guard` is the index of first rounding digit.\r\n if (sd == null) {\r\n\r\n if (rep < 3 && checkRoundingDigits(sum.d, wpr - guard, rm, rep)) {\r\n Ctor.precision = wpr += 10;\r\n denominator = pow = t = new Ctor(1);\r\n i = 0;\r\n rep++;\r\n } else {\r\n return finalise(sum, Ctor.precision = pr, rm, external = true);\r\n }\r\n } else {\r\n Ctor.precision = pr;\r\n return sum;\r\n }\r\n }\r\n\r\n sum = t;\r\n }\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the natural logarithm of `x` rounded to `sd` significant\r\n * digits.\r\n *\r\n * ln(-n) = NaN\r\n * ln(0) = -Infinity\r\n * ln(-0) = -Infinity\r\n * ln(1) = 0\r\n * ln(Infinity) = Infinity\r\n * ln(-Infinity) = NaN\r\n * ln(NaN) = NaN\r\n *\r\n * ln(n) (n != 1) is non-terminating.\r\n *\r\n */\r\nfunction naturalLogarithm(y, sd) {\r\n var c, c0, denominator, e, numerator, rep, sum, t, wpr, x1, x2,\r\n n = 1,\r\n guard = 10,\r\n x = y,\r\n xd = x.d,\r\n Ctor = x.constructor,\r\n rm = Ctor.rounding,\r\n pr = Ctor.precision;\r\n\r\n // Is x negative or Infinity, NaN, 0 or 1?\r\n if (x.s < 0 || !xd || !xd[0] || !x.e && xd[0] == 1 && xd.length == 1) {\r\n return new Ctor(xd && !xd[0] ? -1 / 0 : x.s != 1 ? NaN : xd ? 0 : x);\r\n }\r\n\r\n if (sd == null) {\r\n external = false;\r\n wpr = pr;\r\n } else {\r\n wpr = sd;\r\n }\r\n\r\n Ctor.precision = wpr += guard;\r\n c = digitsToString(xd);\r\n c0 = c.charAt(0);\r\n\r\n if (Math.abs(e = x.e) < 1.5e15) {\r\n\r\n // Argument reduction.\r\n // The series converges faster the closer the argument is to 1, so using\r\n // ln(a^b) = b * ln(a), ln(a) = ln(a^b) / b\r\n // multiply the argument by itself until the leading digits of the significand are 7, 8, 9,\r\n // 10, 11, 12 or 13, recording the number of multiplications so the sum of the series can\r\n // later be divided by this number, then separate out the power of 10 using\r\n // ln(a*10^b) = ln(a) + b*ln(10).\r\n\r\n // max n is 21 (gives 0.9, 1.0 or 1.1) (9e15 / 21 = 4.2e14).\r\n //while (c0 < 9 && c0 != 1 || c0 == 1 && c.charAt(1) > 1) {\r\n // max n is 6 (gives 0.7 - 1.3)\r\n while (c0 < 7 && c0 != 1 || c0 == 1 && c.charAt(1) > 3) {\r\n x = x.times(y);\r\n c = digitsToString(x.d);\r\n c0 = c.charAt(0);\r\n n++;\r\n }\r\n\r\n e = x.e;\r\n\r\n if (c0 > 1) {\r\n x = new Ctor('0.' + c);\r\n e++;\r\n } else {\r\n x = new Ctor(c0 + '.' + c.slice(1));\r\n }\r\n } else {\r\n\r\n // The argument reduction method above may result in overflow if the argument y is a massive\r\n // number with exponent >= 1500000000000000 (9e15 / 6 = 1.5e15), so instead recall this\r\n // function using ln(x*10^e) = ln(x) + e*ln(10).\r\n t = getLn10(Ctor, wpr + 2, pr).times(e + '');\r\n x = naturalLogarithm(new Ctor(c0 + '.' + c.slice(1)), wpr - guard).plus(t);\r\n Ctor.precision = pr;\r\n\r\n return sd == null ? finalise(x, pr, rm, external = true) : x;\r\n }\r\n\r\n // x1 is x reduced to a value near 1.\r\n x1 = x;\r\n\r\n // Taylor series.\r\n // ln(y) = ln((1 + x)/(1 - x)) = 2(x + x^3/3 + x^5/5 + x^7/7 + ...)\r\n // where x = (y - 1)/(y + 1) (|x| < 1)\r\n sum = numerator = x = divide(x.minus(1), x.plus(1), wpr, 1);\r\n x2 = finalise(x.times(x), wpr, 1);\r\n denominator = 3;\r\n\r\n for (;;) {\r\n numerator = finalise(numerator.times(x2), wpr, 1);\r\n t = sum.plus(divide(numerator, new Ctor(denominator), wpr, 1));\r\n\r\n if (digitsToString(t.d).slice(0, wpr) === digitsToString(sum.d).slice(0, wpr)) {\r\n sum = sum.times(2);\r\n\r\n // Reverse the argument reduction. Check that e is not 0 because, besides preventing an\r\n // unnecessary calculation, -0 + 0 = +0 and to ensure correct rounding -0 needs to stay -0.\r\n if (e !== 0) sum = sum.plus(getLn10(Ctor, wpr + 2, pr).times(e + ''));\r\n sum = divide(sum, new Ctor(n), wpr, 1);\r\n\r\n // Is rm > 3 and the first 4 rounding digits 4999, or rm < 4 (or the summation has\r\n // been repeated previously) and the first 4 rounding digits 9999?\r\n // If so, restart the summation with a higher precision, otherwise\r\n // e.g. with precision: 12, rounding: 1\r\n // ln(135520028.6126091714265381533) = 18.7246299999 when it should be 18.72463.\r\n // `wpr - guard` is the index of first rounding digit.\r\n if (sd == null) {\r\n if (checkRoundingDigits(sum.d, wpr - guard, rm, rep)) {\r\n Ctor.precision = wpr += guard;\r\n t = numerator = x = divide(x1.minus(1), x1.plus(1), wpr, 1);\r\n x2 = finalise(x.times(x), wpr, 1);\r\n denominator = rep = 1;\r\n } else {\r\n return finalise(sum, Ctor.precision = pr, rm, external = true);\r\n }\r\n } else {\r\n Ctor.precision = pr;\r\n return sum;\r\n }\r\n }\r\n\r\n sum = t;\r\n denominator += 2;\r\n }\r\n}\r\n\r\n\r\n// ±Infinity, NaN.\r\nfunction nonFiniteToString(x) {\r\n // Unsigned.\r\n return String(x.s * x.s / 0);\r\n}\r\n\r\n\r\n/*\r\n * Parse the value of a new Decimal `x` from string `str`.\r\n */\r\nfunction parseDecimal(x, str) {\r\n var e, i, len;\r\n\r\n // Decimal point?\r\n if ((e = str.indexOf('.')) > -1) str = str.replace('.', '');\r\n\r\n // Exponential form?\r\n if ((i = str.search(/e/i)) > 0) {\r\n\r\n // Determine exponent.\r\n if (e < 0) e = i;\r\n e += +str.slice(i + 1);\r\n str = str.substring(0, i);\r\n } else if (e < 0) {\r\n\r\n // Integer.\r\n e = str.length;\r\n }\r\n\r\n // Determine leading zeros.\r\n for (i = 0; str.charCodeAt(i) === 48; i++);\r\n\r\n // Determine trailing zeros.\r\n for (len = str.length; str.charCodeAt(len - 1) === 48; --len);\r\n str = str.slice(i, len);\r\n\r\n if (str) {\r\n len -= i;\r\n x.e = e = e - i - 1;\r\n x.d = [];\r\n\r\n // Transform base\r\n\r\n // e is the base 10 exponent.\r\n // i is where to slice str to get the first word of the digits array.\r\n i = (e + 1) % LOG_BASE;\r\n if (e < 0) i += LOG_BASE;\r\n\r\n if (i < len) {\r\n if (i) x.d.push(+str.slice(0, i));\r\n for (len -= LOG_BASE; i < len;) x.d.push(+str.slice(i, i += LOG_BASE));\r\n str = str.slice(i);\r\n i = LOG_BASE - str.length;\r\n } else {\r\n i -= len;\r\n }\r\n\r\n for (; i--;) str += '0';\r\n x.d.push(+str);\r\n\r\n if (external) {\r\n\r\n // Overflow?\r\n if (x.e > x.constructor.maxE) {\r\n\r\n // Infinity.\r\n x.d = null;\r\n x.e = NaN;\r\n\r\n // Underflow?\r\n } else if (x.e < x.constructor.minE) {\r\n\r\n // Zero.\r\n x.e = 0;\r\n x.d = [0];\r\n // x.constructor.underflow = true;\r\n } // else x.constructor.underflow = false;\r\n }\r\n } else {\r\n\r\n // Zero.\r\n x.e = 0;\r\n x.d = [0];\r\n }\r\n\r\n return x;\r\n}\r\n\r\n\r\n/*\r\n * Parse the value of a new Decimal `x` from a string `str`, which is not a decimal value.\r\n */\r\nfunction parseOther(x, str) {\r\n var base, Ctor, divisor, i, isFloat, len, p, xd, xe;\r\n\r\n if (str.indexOf('_') > -1) {\r\n str = str.replace(/(\\d)_(?=\\d)/g, '$1');\r\n if (isDecimal.test(str)) return parseDecimal(x, str);\r\n } else if (str === 'Infinity' || str === 'NaN') {\r\n if (!+str) x.s = NaN;\r\n x.e = NaN;\r\n x.d = null;\r\n return x;\r\n }\r\n\r\n if (isHex.test(str)) {\r\n base = 16;\r\n str = str.toLowerCase();\r\n } else if (isBinary.test(str)) {\r\n base = 2;\r\n } else if (isOctal.test(str)) {\r\n base = 8;\r\n } else {\r\n throw Error(invalidArgument + str);\r\n }\r\n\r\n // Is there a binary exponent part?\r\n i = str.search(/p/i);\r\n\r\n if (i > 0) {\r\n p = +str.slice(i + 1);\r\n str = str.substring(2, i);\r\n } else {\r\n str = str.slice(2);\r\n }\r\n\r\n // Convert `str` as an integer then divide the result by `base` raised to a power such that the\r\n // fraction part will be restored.\r\n i = str.indexOf('.');\r\n isFloat = i >= 0;\r\n Ctor = x.constructor;\r\n\r\n if (isFloat) {\r\n str = str.replace('.', '');\r\n len = str.length;\r\n i = len - i;\r\n\r\n // log[10](16) = 1.2041... , log[10](88) = 1.9444....\r\n divisor = intPow(Ctor, new Ctor(base), i, i * 2);\r\n }\r\n\r\n xd = convertBase(str, base, BASE);\r\n xe = xd.length - 1;\r\n\r\n // Remove trailing zeros.\r\n for (i = xe; xd[i] === 0; --i) xd.pop();\r\n if (i < 0) return new Ctor(x.s * 0);\r\n x.e = getBase10Exponent(xd, xe);\r\n x.d = xd;\r\n external = false;\r\n\r\n // At what precision to perform the division to ensure exact conversion?\r\n // maxDecimalIntegerPartDigitCount = ceil(log[10](b) * otherBaseIntegerPartDigitCount)\r\n // log[10](2) = 0.30103, log[10](8) = 0.90309, log[10](16) = 1.20412\r\n // E.g. ceil(1.2 * 3) = 4, so up to 4 decimal digits are needed to represent 3 hex int digits.\r\n // maxDecimalFractionPartDigitCount = {Hex:4|Oct:3|Bin:1} * otherBaseFractionPartDigitCount\r\n // Therefore using 4 * the number of digits of str will always be enough.\r\n if (isFloat) x = divide(x, divisor, len * 4);\r\n\r\n // Multiply by the binary exponent part if present.\r\n if (p) x = x.times(Math.abs(p) < 54 ? mathpow(2, p) : Decimal.pow(2, p));\r\n external = true;\r\n\r\n return x;\r\n}\r\n\r\n\r\n/*\r\n * sin(x) = x - x^3/3! + x^5/5! - ...\r\n * |x| < pi/2\r\n *\r\n */\r\nfunction sine(Ctor, x) {\r\n var k,\r\n len = x.d.length;\r\n\r\n if (len < 3) {\r\n return x.isZero() ? x : taylorSeries(Ctor, 2, x, x);\r\n }\r\n\r\n // Argument reduction: sin(5x) = 16*sin^5(x) - 20*sin^3(x) + 5*sin(x)\r\n // i.e. sin(x) = 16*sin^5(x/5) - 20*sin^3(x/5) + 5*sin(x/5)\r\n // and sin(x) = sin(x/5)(5 + sin^2(x/5)(16sin^2(x/5) - 20))\r\n\r\n // Estimate the optimum number of times to use the argument reduction.\r\n k = 1.4 * Math.sqrt(len);\r\n k = k > 16 ? 16 : k | 0;\r\n\r\n x = x.times(1 / tinyPow(5, k));\r\n x = taylorSeries(Ctor, 2, x, x);\r\n\r\n // Reverse argument reduction\r\n var sin2_x,\r\n d5 = new Ctor(5),\r\n d16 = new Ctor(16),\r\n d20 = new Ctor(20);\r\n for (; k--;) {\r\n sin2_x = x.times(x);\r\n x = x.times(d5.plus(sin2_x.times(d16.times(sin2_x).minus(d20))));\r\n }\r\n\r\n return x;\r\n}\r\n\r\n\r\n// Calculate Taylor series for `cos`, `cosh`, `sin` and `sinh`.\r\nfunction taylorSeries(Ctor, n, x, y, isHyperbolic) {\r\n var j, t, u, x2,\r\n i = 1,\r\n pr = Ctor.precision,\r\n k = Math.ceil(pr / LOG_BASE);\r\n\r\n external = false;\r\n x2 = x.times(x);\r\n u = new Ctor(y);\r\n\r\n for (;;) {\r\n t = divide(u.times(x2), new Ctor(n++ * n++), pr, 1);\r\n u = isHyperbolic ? y.plus(t) : y.minus(t);\r\n y = divide(t.times(x2), new Ctor(n++ * n++), pr, 1);\r\n t = u.plus(y);\r\n\r\n if (t.d[k] !== void 0) {\r\n for (j = k; t.d[j] === u.d[j] && j--;);\r\n if (j == -1) break;\r\n }\r\n\r\n j = u;\r\n u = y;\r\n y = t;\r\n t = j;\r\n i++;\r\n }\r\n\r\n external = true;\r\n t.d.length = k + 1;\r\n\r\n return t;\r\n}\r\n\r\n\r\n// Exponent e must be positive and non-zero.\r\nfunction tinyPow(b, e) {\r\n var n = b;\r\n while (--e) n *= b;\r\n return n;\r\n}\r\n\r\n\r\n// Return the absolute value of `x` reduced to less than or equal to half pi.\r\nfunction toLessThanHalfPi(Ctor, x) {\r\n var t,\r\n isNeg = x.s < 0,\r\n pi = getPi(Ctor, Ctor.precision, 1),\r\n halfPi = pi.times(0.5);\r\n\r\n x = x.abs();\r\n\r\n if (x.lte(halfPi)) {\r\n quadrant = isNeg ? 4 : 1;\r\n return x;\r\n }\r\n\r\n t = x.divToInt(pi);\r\n\r\n if (t.isZero()) {\r\n quadrant = isNeg ? 3 : 2;\r\n } else {\r\n x = x.minus(t.times(pi));\r\n\r\n // 0 <= x < pi\r\n if (x.lte(halfPi)) {\r\n quadrant = isOdd(t) ? (isNeg ? 2 : 3) : (isNeg ? 4 : 1);\r\n return x;\r\n }\r\n\r\n quadrant = isOdd(t) ? (isNeg ? 1 : 4) : (isNeg ? 3 : 2);\r\n }\r\n\r\n return x.minus(pi).abs();\r\n}\r\n\r\n\r\n/*\r\n * Return the value of Decimal `x` as a string in base `baseOut`.\r\n *\r\n * If the optional `sd` argument is present include a binary exponent suffix.\r\n */\r\nfunction toStringBinary(x, baseOut, sd, rm) {\r\n var base, e, i, k, len, roundUp, str, xd, y,\r\n Ctor = x.constructor,\r\n isExp = sd !== void 0;\r\n\r\n if (isExp) {\r\n checkInt32(sd, 1, MAX_DIGITS);\r\n if (rm === void 0) rm = Ctor.rounding;\r\n else checkInt32(rm, 0, 8);\r\n } else {\r\n sd = Ctor.precision;\r\n rm = Ctor.rounding;\r\n }\r\n\r\n if (!x.isFinite()) {\r\n str = nonFiniteToString(x);\r\n } else {\r\n str = finiteToString(x);\r\n i = str.indexOf('.');\r\n\r\n // Use exponential notation according to `toExpPos` and `toExpNeg`? No, but if required:\r\n // maxBinaryExponent = floor((decimalExponent + 1) * log[2](10))\r\n // minBinaryExponent = floor(decimalExponent * log[2](10))\r\n // log[2](10) = 3.321928094887362347870319429489390175864\r\n\r\n if (isExp) {\r\n base = 2;\r\n if (baseOut == 16) {\r\n sd = sd * 4 - 3;\r\n } else if (baseOut == 8) {\r\n sd = sd * 3 - 2;\r\n }\r\n } else {\r\n base = baseOut;\r\n }\r\n\r\n // Convert the number as an integer then divide the result by its base raised to a power such\r\n // that the fraction part will be restored.\r\n\r\n // Non-integer.\r\n if (i >= 0) {\r\n str = str.replace('.', '');\r\n y = new Ctor(1);\r\n y.e = str.length - i;\r\n y.d = convertBase(finiteToString(y), 10, base);\r\n y.e = y.d.length;\r\n }\r\n\r\n xd = convertBase(str, 10, base);\r\n e = len = xd.length;\r\n\r\n // Remove trailing zeros.\r\n for (; xd[--len] == 0;) xd.pop();\r\n\r\n if (!xd[0]) {\r\n str = isExp ? '0p+0' : '0';\r\n } else {\r\n if (i < 0) {\r\n e--;\r\n } else {\r\n x = new Ctor(x);\r\n x.d = xd;\r\n x.e = e;\r\n x = divide(x, y, sd, rm, 0, base);\r\n xd = x.d;\r\n e = x.e;\r\n roundUp = inexact;\r\n }\r\n\r\n // The rounding digit, i.e. the digit after the digit that may be rounded up.\r\n i = xd[sd];\r\n k = base / 2;\r\n roundUp = roundUp || xd[sd + 1] !== void 0;\r\n\r\n roundUp = rm < 4\r\n ? (i !== void 0 || roundUp) && (rm === 0 || rm === (x.s < 0 ? 3 : 2))\r\n : i > k || i === k && (rm === 4 || roundUp || rm === 6 && xd[sd - 1] & 1 ||\r\n rm === (x.s < 0 ? 8 : 7));\r\n\r\n xd.length = sd;\r\n\r\n if (roundUp) {\r\n\r\n // Rounding up may mean the previous digit has to be rounded up and so on.\r\n for (; ++xd[--sd] > base - 1;) {\r\n xd[sd] = 0;\r\n if (!sd) {\r\n ++e;\r\n xd.unshift(1);\r\n }\r\n }\r\n }\r\n\r\n // Determine trailing zeros.\r\n for (len = xd.length; !xd[len - 1]; --len);\r\n\r\n // E.g. [4, 11, 15] becomes 4bf.\r\n for (i = 0, str = ''; i < len; i++) str += NUMERALS.charAt(xd[i]);\r\n\r\n // Add binary exponent suffix?\r\n if (isExp) {\r\n if (len > 1) {\r\n if (baseOut == 16 || baseOut == 8) {\r\n i = baseOut == 16 ? 4 : 3;\r\n for (--len; len % i; len++) str += '0';\r\n xd = convertBase(str, base, baseOut);\r\n for (len = xd.length; !xd[len - 1]; --len);\r\n\r\n // xd[0] will always be be 1\r\n for (i = 1, str = '1.'; i < len; i++) str += NUMERALS.charAt(xd[i]);\r\n } else {\r\n str = str.charAt(0) + '.' + str.slice(1);\r\n }\r\n }\r\n\r\n str = str + (e < 0 ? 'p' : 'p+') + e;\r\n } else if (e < 0) {\r\n for (; ++e;) str = '0' + str;\r\n str = '0.' + str;\r\n } else {\r\n if (++e > len) for (e -= len; e-- ;) str += '0';\r\n else if (e < len) str = str.slice(0, e) + '.' + str.slice(e);\r\n }\r\n }\r\n\r\n str = (baseOut == 16 ? '0x' : baseOut == 2 ? '0b' : baseOut == 8 ? '0o' : '') + str;\r\n }\r\n\r\n return x.s < 0 ? '-' + str : str;\r\n}\r\n\r\n\r\n// Does not strip trailing zeros.\r\nfunction truncate(arr, len) {\r\n if (arr.length > len) {\r\n arr.length = len;\r\n return true;\r\n }\r\n}\r\n\r\n\r\n// Decimal methods\r\n\r\n\r\n/*\r\n * abs\r\n * acos\r\n * acosh\r\n * add\r\n * asin\r\n * asinh\r\n * atan\r\n * atanh\r\n * atan2\r\n * cbrt\r\n * ceil\r\n * clamp\r\n * clone\r\n * config\r\n * cos\r\n * cosh\r\n * div\r\n * exp\r\n * floor\r\n * hypot\r\n * ln\r\n * log\r\n * log2\r\n * log10\r\n * max\r\n * min\r\n * mod\r\n * mul\r\n * pow\r\n * random\r\n * round\r\n * set\r\n * sign\r\n * sin\r\n * sinh\r\n * sqrt\r\n * sub\r\n * sum\r\n * tan\r\n * tanh\r\n * trunc\r\n */\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the absolute value of `x`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction abs(x) {\r\n return new this(x).abs();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the arccosine in radians of `x`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction acos(x) {\r\n return new this(x).acos();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the inverse of the hyperbolic cosine of `x`, rounded to\r\n * `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\nfunction acosh(x) {\r\n return new this(x).acosh();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the sum of `x` and `y`, rounded to `precision` significant\r\n * digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n * y {number|string|Decimal}\r\n *\r\n */\r\nfunction add(x, y) {\r\n return new this(x).plus(y);\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the arcsine in radians of `x`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction asin(x) {\r\n return new this(x).asin();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the inverse of the hyperbolic sine of `x`, rounded to\r\n * `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\nfunction asinh(x) {\r\n return new this(x).asinh();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the arctangent in radians of `x`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction atan(x) {\r\n return new this(x).atan();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the inverse of the hyperbolic tangent of `x`, rounded to\r\n * `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\nfunction atanh(x) {\r\n return new this(x).atanh();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the arctangent in radians of `y/x` in the range -pi to pi\r\n * (inclusive), rounded to `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * Domain: [-Infinity, Infinity]\r\n * Range: [-pi, pi]\r\n *\r\n * y {number|string|Decimal} The y-coordinate.\r\n * x {number|string|Decimal} The x-coordinate.\r\n *\r\n * atan2(±0, -0) = ±pi\r\n * atan2(±0, +0) = ±0\r\n * atan2(±0, -x) = ±pi for x > 0\r\n * atan2(±0, x) = ±0 for x > 0\r\n * atan2(-y, ±0) = -pi/2 for y > 0\r\n * atan2(y, ±0) = pi/2 for y > 0\r\n * atan2(±y, -Infinity) = ±pi for finite y > 0\r\n * atan2(±y, +Infinity) = ±0 for finite y > 0\r\n * atan2(±Infinity, x) = ±pi/2 for finite x\r\n * atan2(±Infinity, -Infinity) = ±3*pi/4\r\n * atan2(±Infinity, +Infinity) = ±pi/4\r\n * atan2(NaN, x) = NaN\r\n * atan2(y, NaN) = NaN\r\n *\r\n */\r\nfunction atan2(y, x) {\r\n y = new this(y);\r\n x = new this(x);\r\n var r,\r\n pr = this.precision,\r\n rm = this.rounding,\r\n wpr = pr + 4;\r\n\r\n // Either NaN\r\n if (!y.s || !x.s) {\r\n r = new this(NaN);\r\n\r\n // Both ±Infinity\r\n } else if (!y.d && !x.d) {\r\n r = getPi(this, wpr, 1).times(x.s > 0 ? 0.25 : 0.75);\r\n r.s = y.s;\r\n\r\n // x is ±Infinity or y is ±0\r\n } else if (!x.d || y.isZero()) {\r\n r = x.s < 0 ? getPi(this, pr, rm) : new this(0);\r\n r.s = y.s;\r\n\r\n // y is ±Infinity or x is ±0\r\n } else if (!y.d || x.isZero()) {\r\n r = getPi(this, wpr, 1).times(0.5);\r\n r.s = y.s;\r\n\r\n // Both non-zero and finite\r\n } else if (x.s < 0) {\r\n this.precision = wpr;\r\n this.rounding = 1;\r\n r = this.atan(divide(y, x, wpr, 1));\r\n x = getPi(this, wpr, 1);\r\n this.precision = pr;\r\n this.rounding = rm;\r\n r = y.s < 0 ? r.minus(x) : r.plus(x);\r\n } else {\r\n r = this.atan(divide(y, x, wpr, 1));\r\n }\r\n\r\n return r;\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the cube root of `x`, rounded to `precision` significant\r\n * digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction cbrt(x) {\r\n return new this(x).cbrt();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is `x` rounded to an integer using `ROUND_CEIL`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction ceil(x) {\r\n return finalise(x = new this(x), x.e + 1, 2);\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is `x` clamped to the range delineated by `min` and `max`.\r\n *\r\n * x {number|string|Decimal}\r\n * min {number|string|Decimal}\r\n * max {number|string|Decimal}\r\n *\r\n */\r\nfunction clamp(x, min, max) {\r\n return new this(x).clamp(min, max);\r\n}\r\n\r\n\r\n/*\r\n * Configure global settings for a Decimal constructor.\r\n *\r\n * `obj` is an object with one or more of the following properties,\r\n *\r\n * precision {number}\r\n * rounding {number}\r\n * toExpNeg {number}\r\n * toExpPos {number}\r\n * maxE {number}\r\n * minE {number}\r\n * modulo {number}\r\n * crypto {boolean|number}\r\n * defaults {true}\r\n *\r\n * E.g. Decimal.config({ precision: 20, rounding: 4 })\r\n *\r\n */\r\nfunction config(obj) {\r\n if (!obj || typeof obj !== 'object') throw Error(decimalError + 'Object expected');\r\n var i, p, v,\r\n useDefaults = obj.defaults === true,\r\n ps = [\r\n 'precision', 1, MAX_DIGITS,\r\n 'rounding', 0, 8,\r\n 'toExpNeg', -EXP_LIMIT, 0,\r\n 'toExpPos', 0, EXP_LIMIT,\r\n 'maxE', 0, EXP_LIMIT,\r\n 'minE', -EXP_LIMIT, 0,\r\n 'modulo', 0, 9\r\n ];\r\n\r\n for (i = 0; i < ps.length; i += 3) {\r\n if (p = ps[i], useDefaults) this[p] = DEFAULTS[p];\r\n if ((v = obj[p]) !== void 0) {\r\n if (mathfloor(v) === v && v >= ps[i + 1] && v <= ps[i + 2]) this[p] = v;\r\n else throw Error(invalidArgument + p + ': ' + v);\r\n }\r\n }\r\n\r\n if (p = 'crypto', useDefaults) this[p] = DEFAULTS[p];\r\n if ((v = obj[p]) !== void 0) {\r\n if (v === true || v === false || v === 0 || v === 1) {\r\n if (v) {\r\n if (typeof crypto != 'undefined' && crypto &&\r\n (crypto.getRandomValues || crypto.randomBytes)) {\r\n this[p] = true;\r\n } else {\r\n throw Error(cryptoUnavailable);\r\n }\r\n } else {\r\n this[p] = false;\r\n }\r\n } else {\r\n throw Error(invalidArgument + p + ': ' + v);\r\n }\r\n }\r\n\r\n return this;\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the cosine of `x`, rounded to `precision` significant\r\n * digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\nfunction cos(x) {\r\n return new this(x).cos();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the hyperbolic cosine of `x`, rounded to precision\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\nfunction cosh(x) {\r\n return new this(x).cosh();\r\n}\r\n\r\n\r\n/*\r\n * Create and return a Decimal constructor with the same configuration properties as this Decimal\r\n * constructor.\r\n *\r\n */\r\nfunction clone(obj) {\r\n var i, p, ps;\r\n\r\n /*\r\n * The Decimal constructor and exported function.\r\n * Return a new Decimal instance.\r\n *\r\n * v {number|string|Decimal} A numeric value.\r\n *\r\n */\r\n function Decimal(v) {\r\n var e, i, t,\r\n x = this;\r\n\r\n // Decimal called without new.\r\n if (!(x instanceof Decimal)) return new Decimal(v);\r\n\r\n // Retain a reference to this Decimal constructor, and shadow Decimal.prototype.constructor\r\n // which points to Object.\r\n x.constructor = Decimal;\r\n\r\n // Duplicate.\r\n if (isDecimalInstance(v)) {\r\n x.s = v.s;\r\n\r\n if (external) {\r\n if (!v.d || v.e > Decimal.maxE) {\r\n\r\n // Infinity.\r\n x.e = NaN;\r\n x.d = null;\r\n } else if (v.e < Decimal.minE) {\r\n\r\n // Zero.\r\n x.e = 0;\r\n x.d = [0];\r\n } else {\r\n x.e = v.e;\r\n x.d = v.d.slice();\r\n }\r\n } else {\r\n x.e = v.e;\r\n x.d = v.d ? v.d.slice() : v.d;\r\n }\r\n\r\n return;\r\n }\r\n\r\n t = typeof v;\r\n\r\n if (t === 'number') {\r\n if (v === 0) {\r\n x.s = 1 / v < 0 ? -1 : 1;\r\n x.e = 0;\r\n x.d = [0];\r\n return;\r\n }\r\n\r\n if (v < 0) {\r\n v = -v;\r\n x.s = -1;\r\n } else {\r\n x.s = 1;\r\n }\r\n\r\n // Fast path for small integers.\r\n if (v === ~~v && v < 1e7) {\r\n for (e = 0, i = v; i >= 10; i /= 10) e++;\r\n\r\n if (external) {\r\n if (e > Decimal.maxE) {\r\n x.e = NaN;\r\n x.d = null;\r\n } else if (e < Decimal.minE) {\r\n x.e = 0;\r\n x.d = [0];\r\n } else {\r\n x.e = e;\r\n x.d = [v];\r\n }\r\n } else {\r\n x.e = e;\r\n x.d = [v];\r\n }\r\n\r\n return;\r\n\r\n // Infinity, NaN.\r\n } else if (v * 0 !== 0) {\r\n if (!v) x.s = NaN;\r\n x.e = NaN;\r\n x.d = null;\r\n return;\r\n }\r\n\r\n return parseDecimal(x, v.toString());\r\n\r\n } else if (t !== 'string') {\r\n throw Error(invalidArgument + v);\r\n }\r\n\r\n // Minus sign?\r\n if ((i = v.charCodeAt(0)) === 45) {\r\n v = v.slice(1);\r\n x.s = -1;\r\n } else {\r\n // Plus sign?\r\n if (i === 43) v = v.slice(1);\r\n x.s = 1;\r\n }\r\n\r\n return isDecimal.test(v) ? parseDecimal(x, v) : parseOther(x, v);\r\n }\r\n\r\n Decimal.prototype = P;\r\n\r\n Decimal.ROUND_UP = 0;\r\n Decimal.ROUND_DOWN = 1;\r\n Decimal.ROUND_CEIL = 2;\r\n Decimal.ROUND_FLOOR = 3;\r\n Decimal.ROUND_HALF_UP = 4;\r\n Decimal.ROUND_HALF_DOWN = 5;\r\n Decimal.ROUND_HALF_EVEN = 6;\r\n Decimal.ROUND_HALF_CEIL = 7;\r\n Decimal.ROUND_HALF_FLOOR = 8;\r\n Decimal.EUCLID = 9;\r\n\r\n Decimal.config = Decimal.set = config;\r\n Decimal.clone = clone;\r\n Decimal.isDecimal = isDecimalInstance;\r\n\r\n Decimal.abs = abs;\r\n Decimal.acos = acos;\r\n Decimal.acosh = acosh; // ES6\r\n Decimal.add = add;\r\n Decimal.asin = asin;\r\n Decimal.asinh = asinh; // ES6\r\n Decimal.atan = atan;\r\n Decimal.atanh = atanh; // ES6\r\n Decimal.atan2 = atan2;\r\n Decimal.cbrt = cbrt; // ES6\r\n Decimal.ceil = ceil;\r\n Decimal.clamp = clamp;\r\n Decimal.cos = cos;\r\n Decimal.cosh = cosh; // ES6\r\n Decimal.div = div;\r\n Decimal.exp = exp;\r\n Decimal.floor = floor;\r\n Decimal.hypot = hypot; // ES6\r\n Decimal.ln = ln;\r\n Decimal.log = log;\r\n Decimal.log10 = log10; // ES6\r\n Decimal.log2 = log2; // ES6\r\n Decimal.max = max;\r\n Decimal.min = min;\r\n Decimal.mod = mod;\r\n Decimal.mul = mul;\r\n Decimal.pow = pow;\r\n Decimal.random = random;\r\n Decimal.round = round;\r\n Decimal.sign = sign; // ES6\r\n Decimal.sin = sin;\r\n Decimal.sinh = sinh; // ES6\r\n Decimal.sqrt = sqrt;\r\n Decimal.sub = sub;\r\n Decimal.sum = sum;\r\n Decimal.tan = tan;\r\n Decimal.tanh = tanh; // ES6\r\n Decimal.trunc = trunc; // ES6\r\n\r\n if (obj === void 0) obj = {};\r\n if (obj) {\r\n if (obj.defaults !== true) {\r\n ps = ['precision', 'rounding', 'toExpNeg', 'toExpPos', 'maxE', 'minE', 'modulo', 'crypto'];\r\n for (i = 0; i < ps.length;) if (!obj.hasOwnProperty(p = ps[i++])) obj[p] = this[p];\r\n }\r\n }\r\n\r\n Decimal.config(obj);\r\n\r\n return Decimal;\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is `x` divided by `y`, rounded to `precision` significant\r\n * digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n * y {number|string|Decimal}\r\n *\r\n */\r\nfunction div(x, y) {\r\n return new this(x).div(y);\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the natural exponential of `x`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} The power to which to raise the base of the natural log.\r\n *\r\n */\r\nfunction exp(x) {\r\n return new this(x).exp();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is `x` round to an integer using `ROUND_FLOOR`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction floor(x) {\r\n return finalise(x = new this(x), x.e + 1, 3);\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the square root of the sum of the squares of the arguments,\r\n * rounded to `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * hypot(a, b, ...) = sqrt(a^2 + b^2 + ...)\r\n *\r\n * arguments {number|string|Decimal}\r\n *\r\n */\r\nfunction hypot() {\r\n var i, n,\r\n t = new this(0);\r\n\r\n external = false;\r\n\r\n for (i = 0; i < arguments.length;) {\r\n n = new this(arguments[i++]);\r\n if (!n.d) {\r\n if (n.s) {\r\n external = true;\r\n return new this(1 / 0);\r\n }\r\n t = n;\r\n } else if (t.d) {\r\n t = t.plus(n.times(n));\r\n }\r\n }\r\n\r\n external = true;\r\n\r\n return t.sqrt();\r\n}\r\n\r\n\r\n/*\r\n * Return true if object is a Decimal instance (where Decimal is any Decimal constructor),\r\n * otherwise return false.\r\n *\r\n */\r\nfunction isDecimalInstance(obj) {\r\n return obj instanceof Decimal || obj && obj.toStringTag === tag || false;\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the natural logarithm of `x`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction ln(x) {\r\n return new this(x).ln();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the log of `x` to the base `y`, or to base 10 if no base\r\n * is specified, rounded to `precision` significant digits using rounding mode `rounding`.\r\n *\r\n * log[y](x)\r\n *\r\n * x {number|string|Decimal} The argument of the logarithm.\r\n * y {number|string|Decimal} The base of the logarithm.\r\n *\r\n */\r\nfunction log(x, y) {\r\n return new this(x).log(y);\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the base 2 logarithm of `x`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction log2(x) {\r\n return new this(x).log(2);\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the base 10 logarithm of `x`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction log10(x) {\r\n return new this(x).log(10);\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the maximum of the arguments.\r\n *\r\n * arguments {number|string|Decimal}\r\n *\r\n */\r\nfunction max() {\r\n return maxOrMin(this, arguments, 'lt');\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the minimum of the arguments.\r\n *\r\n * arguments {number|string|Decimal}\r\n *\r\n */\r\nfunction min() {\r\n return maxOrMin(this, arguments, 'gt');\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is `x` modulo `y`, rounded to `precision` significant digits\r\n * using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n * y {number|string|Decimal}\r\n *\r\n */\r\nfunction mod(x, y) {\r\n return new this(x).mod(y);\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is `x` multiplied by `y`, rounded to `precision` significant\r\n * digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n * y {number|string|Decimal}\r\n *\r\n */\r\nfunction mul(x, y) {\r\n return new this(x).mul(y);\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is `x` raised to the power `y`, rounded to precision\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} The base.\r\n * y {number|string|Decimal} The exponent.\r\n *\r\n */\r\nfunction pow(x, y) {\r\n return new this(x).pow(y);\r\n}\r\n\r\n\r\n/*\r\n * Returns a new Decimal with a random value equal to or greater than 0 and less than 1, and with\r\n * `sd`, or `Decimal.precision` if `sd` is omitted, significant digits (or less if trailing zeros\r\n * are produced).\r\n *\r\n * [sd] {number} Significant digits. Integer, 0 to MAX_DIGITS inclusive.\r\n *\r\n */\r\nfunction random(sd) {\r\n var d, e, k, n,\r\n i = 0,\r\n r = new this(1),\r\n rd = [];\r\n\r\n if (sd === void 0) sd = this.precision;\r\n else checkInt32(sd, 1, MAX_DIGITS);\r\n\r\n k = Math.ceil(sd / LOG_BASE);\r\n\r\n if (!this.crypto) {\r\n for (; i < k;) rd[i++] = Math.random() * 1e7 | 0;\r\n\r\n // Browsers supporting crypto.getRandomValues.\r\n } else if (crypto.getRandomValues) {\r\n d = crypto.getRandomValues(new Uint32Array(k));\r\n\r\n for (; i < k;) {\r\n n = d[i];\r\n\r\n // 0 <= n < 4294967296\r\n // Probability n >= 4.29e9, is 4967296 / 4294967296 = 0.00116 (1 in 865).\r\n if (n >= 4.29e9) {\r\n d[i] = crypto.getRandomValues(new Uint32Array(1))[0];\r\n } else {\r\n\r\n // 0 <= n <= 4289999999\r\n // 0 <= (n % 1e7) <= 9999999\r\n rd[i++] = n % 1e7;\r\n }\r\n }\r\n\r\n // Node.js supporting crypto.randomBytes.\r\n } else if (crypto.randomBytes) {\r\n\r\n // buffer\r\n d = crypto.randomBytes(k *= 4);\r\n\r\n for (; i < k;) {\r\n\r\n // 0 <= n < 2147483648\r\n n = d[i] + (d[i + 1] << 8) + (d[i + 2] << 16) + ((d[i + 3] & 0x7f) << 24);\r\n\r\n // Probability n >= 2.14e9, is 7483648 / 2147483648 = 0.0035 (1 in 286).\r\n if (n >= 2.14e9) {\r\n crypto.randomBytes(4).copy(d, i);\r\n } else {\r\n\r\n // 0 <= n <= 2139999999\r\n // 0 <= (n % 1e7) <= 9999999\r\n rd.push(n % 1e7);\r\n i += 4;\r\n }\r\n }\r\n\r\n i = k / 4;\r\n } else {\r\n throw Error(cryptoUnavailable);\r\n }\r\n\r\n k = rd[--i];\r\n sd %= LOG_BASE;\r\n\r\n // Convert trailing digits to zeros according to sd.\r\n if (k && sd) {\r\n n = mathpow(10, LOG_BASE - sd);\r\n rd[i] = (k / n | 0) * n;\r\n }\r\n\r\n // Remove trailing words which are zero.\r\n for (; rd[i] === 0; i--) rd.pop();\r\n\r\n // Zero?\r\n if (i < 0) {\r\n e = 0;\r\n rd = [0];\r\n } else {\r\n e = -1;\r\n\r\n // Remove leading words which are zero and adjust exponent accordingly.\r\n for (; rd[0] === 0; e -= LOG_BASE) rd.shift();\r\n\r\n // Count the digits of the first word of rd to determine leading zeros.\r\n for (k = 1, n = rd[0]; n >= 10; n /= 10) k++;\r\n\r\n // Adjust the exponent for leading zeros of the first word of rd.\r\n if (k < LOG_BASE) e -= LOG_BASE - k;\r\n }\r\n\r\n r.e = e;\r\n r.d = rd;\r\n\r\n return r;\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is `x` rounded to an integer using rounding mode `rounding`.\r\n *\r\n * To emulate `Math.round`, set rounding to 7 (ROUND_HALF_CEIL).\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction round(x) {\r\n return finalise(x = new this(x), x.e + 1, this.rounding);\r\n}\r\n\r\n\r\n/*\r\n * Return\r\n * 1 if x > 0,\r\n * -1 if x < 0,\r\n * 0 if x is 0,\r\n * -0 if x is -0,\r\n * NaN otherwise\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction sign(x) {\r\n x = new this(x);\r\n return x.d ? (x.d[0] ? x.s : 0 * x.s) : x.s || NaN;\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the sine of `x`, rounded to `precision` significant digits\r\n * using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\nfunction sin(x) {\r\n return new this(x).sin();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the hyperbolic sine of `x`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\nfunction sinh(x) {\r\n return new this(x).sinh();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the square root of `x`, rounded to `precision` significant\r\n * digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction sqrt(x) {\r\n return new this(x).sqrt();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is `x` minus `y`, rounded to `precision` significant digits\r\n * using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal}\r\n * y {number|string|Decimal}\r\n *\r\n */\r\nfunction sub(x, y) {\r\n return new this(x).sub(y);\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the sum of the arguments, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * Only the result is rounded, not the intermediate calculations.\r\n *\r\n * arguments {number|string|Decimal}\r\n *\r\n */\r\nfunction sum() {\r\n var i = 0,\r\n args = arguments,\r\n x = new this(args[i]);\r\n\r\n external = false;\r\n for (; x.s && ++i < args.length;) x = x.plus(args[i]);\r\n external = true;\r\n\r\n return finalise(x, this.precision, this.rounding);\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the tangent of `x`, rounded to `precision` significant\r\n * digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\nfunction tan(x) {\r\n return new this(x).tan();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is the hyperbolic tangent of `x`, rounded to `precision`\r\n * significant digits using rounding mode `rounding`.\r\n *\r\n * x {number|string|Decimal} A value in radians.\r\n *\r\n */\r\nfunction tanh(x) {\r\n return new this(x).tanh();\r\n}\r\n\r\n\r\n/*\r\n * Return a new Decimal whose value is `x` truncated to an integer.\r\n *\r\n * x {number|string|Decimal}\r\n *\r\n */\r\nfunction trunc(x) {\r\n return finalise(x = new this(x), x.e + 1, 1);\r\n}\r\n\r\n\r\nP[Symbol.for('nodejs.util.inspect.custom')] = P.toString;\r\nP[Symbol.toStringTag] = 'Decimal';\r\n\r\n// Create and configure initial Decimal constructor.\r\nexport var Decimal = P.constructor = clone(DEFAULTS);\r\n\r\n// Create the internal constants from their string values.\r\nLN10 = new Decimal(LN10);\r\nPI = new Decimal(PI);\r\n\r\nexport default Decimal;\r\n","import Decimal from \"decimal.js\"\n\n/**\n * Rounds a monetary amount to two decimal places.\n * \n * This is used to avoid issues with floating point arithmetic, which can lead to integration problems\n * with some systems, such as RMS.\n * \n * @param amount a string or number to be rounded\n * @returns the rounded amount as a number\n */\nexport const roundMoney = (amount: string | number) => {\n return new Decimal(amount).toDecimalPlaces(2).toNumber();\n}\n","import { IFee, EFeeType } from '@types';\nimport { roundMoney } from './roundMoney';\n\ninterface FeeCalculationParams {\n baseAmount?: number;\n numberOfNights?: number;\n feeIncludedInBaseAmount?: boolean;\n\n extractedFromRates?: boolean; // When true, calculate what the fee amount would have been before it was removed\n removedPercentages?: number[]; // Array of removed percentages, required when using extractedFromRates.\n}\n\nexport function calculateFeeAmount(fee: IFee, params: FeeCalculationParams = {}): number {\n const { baseAmount = 0, numberOfNights = 1, feeIncludedInBaseAmount = false, extractedFromRates = false, removedPercentages = [] } = params;\n\n const baseAmountRounded = roundMoney(baseAmount);\n\n switch (fee.feeType) {\n case EFeeType.PercentageOfBooking:\n if (feeIncludedInBaseAmount) {\n // Removing a fee that was included in the base amount. Note that this is only used by the API.\n return roundMoney((baseAmountRounded * fee.amount) / (100 + fee.amount));\n } else if (extractedFromRates) {\n // Calculating a fee that was removed from rates. This is used when calculating fees on the frontend,\n // and when calculating fee amounts for a booking.\n const removedFraction = removedPercentages.reduce((sum, r) => sum + r / (100 + r), 0);\n const originalPrice = baseAmountRounded / (1 - removedFraction);\n return roundMoney((originalPrice * fee.amount) / (100 + fee.amount));\n } else {\n return roundMoney(baseAmountRounded * (fee.amount / 100));\n }\n\n case EFeeType.FixedChargePerRoom:\n case EFeeType.FixedChargePerBooking:\n return fee.amount;\n\n case EFeeType.NightlyChargePerRoom:\n return roundMoney(fee.amount * numberOfNights);\n\n default:\n return 0;\n }\n}\n","import { EFeeType, IFee, IFeeConfigurationOptions } from '@types';\n\nconst BOOKING_FEE_TYPES = [EFeeType.FixedChargePerBooking];\n\nconst BOOKING_RATE_FEE_TYPES = [EFeeType.PercentageOfBooking, EFeeType.FixedChargePerRoom, EFeeType.NightlyChargePerRoom];\n\nconst BOOKING_ADDON_FEE_TYPES = [EFeeType.PercentageOfBooking];\n\nfunction filterFeesByType<T extends IFee>(fees: T[], feeTypes: EFeeType[]): T[] {\n return fees.filter((fee) => feeTypes.includes(fee.feeType));\n}\n\nexport function getFilteredBookingFees<T extends IFee>(fees: T[]): T[] {\n return filterFeesByType(fees, BOOKING_FEE_TYPES);\n}\n\nexport function getFilteredBookingRateFees<T extends IFee>(fees: T[]): T[] {\n return filterFeesByType(fees, BOOKING_RATE_FEE_TYPES);\n}\n\nexport function getFilteredBookingAddonFees<T extends IFee>(fees: T[]): T[] {\n return filterFeesByType(fees, BOOKING_ADDON_FEE_TYPES);\n}\n\nexport function getFeeOptionValidity(feeType: EFeeType): Record<keyof IFeeConfigurationOptions, boolean> {\n return {\n includeInRates: [EFeeType.PercentageOfBooking, EFeeType.NightlyChargePerRoom].includes(feeType),\n extractFeeFromRates: feeType === EFeeType.PercentageOfBooking,\n appliesToAddons: feeType === EFeeType.PercentageOfBooking,\n includePreviousFeesInCalculation: feeType === EFeeType.PercentageOfBooking,\n };\n}\n","/**\n * \n * @param name Type-safe way to get the name of a property\n */\nexport const nameof = <T>(name: Extract<keyof T, string>): string => name;\n\n/**\n * Create a subset of an object based on the provided keys.\n */\nexport const subset = <T extends object, K extends keyof T>(source: T, keys: K[]): Pick<T, K> => {\n const result = {} as Pick<T, K>;\n\n keys.forEach(key => {\n if (key in source) {\n result[key] = source[key];\n }\n });\n\n return result;\n}","import { ERoomstayImageSize } from '@types';\n\n/**\n * Converts an Image URL to a resized image URL.\n *\n * Right now we can only manipulate Roomstay hosted images in S3, so only where the source\n * image URL contains cdn.app.roomstay.io can we add the resize parameters.\n *\n * This function will simply pass through any URL not matching the criteria\n *\n * @param url string\n * @param size ImageSize\n * @returns\n */\nexport const resizeRoomstayImageUrl = (url: string, size: ERoomstayImageSize): string => {\n // Only check if source is from roomstay cdn\n if (url.includes('cdn.app.roomstay.io')) {\n return url + '?w=' + size;\n }\n\n return url;\n};\n","import { ADDON_PER_NIGHT_TYPES } from '../types/Addons/Addon.enum';\nimport { BasketAddonDTO, EAddonPricingType } from '../types/Addons/Addon.types';\nimport { ReservationAddonDTO, ReservationsDTO } from '../types/Api/Reservations.type';\nimport { roundMoney } from './roundMoney';\n\n/**\n * A utility class to perform calculations related to addon pricing and reservation totals.\n */\nexport class TotalCalculator {\n /**\n * Calculates the base total cost for a single addon, without considering any additional fees.\n *\n * @param addon - A `BasketAddonDTO` or `ReservationAddonDTO` representing the addon details.\n * @param dismissAddonNightCount - If true, skips multiplying totals by the number of nights.\n * @returns An object containing:\n * - `indPrice`: Total price without per adult/child pricing.\n * - `indAdultPrice`: Price calculated based on adult quantities.\n * - `indChildPrice`: Price calculated based on child quantities.\n * - `addonTotal`: Sum of the above prices, optionally multiplied by nights.\n */\n static calculateBaseAddonTotal = (\n addon: Partial<BasketAddonDTO> | Partial<ReservationAddonDTO>,\n dismissAddonNightCount: boolean\n ): {\n indPrice: number;\n indAdultPrice: number;\n indChildPrice: number;\n addonTotal: number;\n } => {\n let indPrice = 0;\n let indAdultPrice = 0;\n let indChildPrice = 0;\n\n if (addon.price && addon.quantity) {\n indPrice = addon.quantity * Number(addon.price);\n }\n\n if (addon.pricingType === EAddonPricingType.PER_ADULT_OCCUPANCY_PER_NIGHT && addon.adultQuantity) {\n indPrice *= addon.adultQuantity;\n } else if (addon.pricingType === EAddonPricingType.PER_CHILD_OCCUPANCY_PER_NIGHT && addon.childQuantity) {\n indPrice *= addon.childQuantity;\n }\n\n if (addon.adultPrice && addon.adultQuantity) {\n indAdultPrice = addon.adultQuantity * Number(addon.adultPrice);\n }\n\n if (addon.childPrice && addon.childQuantity) {\n indChildPrice = addon.childQuantity * Number(addon.childPrice);\n }\n\n let addonTotal = indPrice + indAdultPrice + indChildPrice;\n if (\n ADDON_PER_NIGHT_TYPES.includes(addon.pricingType as EAddonPricingType) &&\n addon.nights &&\n !dismissAddonNightCount\n ) {\n addonTotal *= addon.nights;\n }\n\n return {\n indPrice,\n indAdultPrice,\n indChildPrice,\n addonTotal,\n };\n };\n\n /**\n * Calculates the total for one or more basket addons, including all associated fees.\n *\n * @param addons - A single or an array of `BasketAddonDTO` objects.\n * @param dismissAddonNightCount - If true, disables night-based multiplier for addons.\n * @returns An object with:\n * - `price`: Total base price (excluding adult/child prices).\n * - `adultPrice`: Total based on adult quantities and prices.\n * - `childPrice`: Total based on child quantities and prices.\n * - `totalFees`: Total of all applicable addon fees.\n * - `total`: Sum of prices and fees.\n */\n static calculateBasketAddonTotal = (\n addons: BasketAddonDTO | BasketAddonDTO[],\n dismissAddonNightCount = false\n ): {\n price: number;\n adultPrice: number;\n childPrice: number;\n totalFees: number;\n total: number;\n } => {\n if (!Array.isArray(addons)) {\n addons = [addons];\n }\n\n // TODO: This function is chaos! It will be slightly better when we remove the old fee fields.\n\n const result = addons.reduce(\n (acc, addon) => {\n const base = TotalCalculator.calculateBaseAddonTotal(addon, dismissAddonNightCount);\n let addonFees = 0;\n\n // Calculate fees specific to BasketAddonDTO\n if ((addon.fee || addon.fees?.length) && addon.quantity) {\n // There are no separate adult/child fees\n if (addon.fees?.length) {\n // New Itemised fees\n addon.fees.forEach((fee) => {\n addonFees += addon.quantity * fee.amount;\n });\n } else {\n // Old fees (to be removed/deprecated)\n addonFees = addon.quantity * Number(addon.fee);\n }\n } else {\n // There are separate adult/child fees, so we need to calculate them separately.\n if ((addon.adultFee || addon.adultFees?.length) && addon.adultQuantity) {\n if (addon.adultFees?.length) {\n addon.adultFees.forEach((fee) => {\n addonFees += addon.adultQuantity * fee.amount;\n });\n } else {\n addonFees += addon.adultQuantity ?? 1 * Number(addon.adultFee);\n }\n }\n\n if ((addon.childFee || addon.childFees?.length) && addon.childQuantity) {\n if (addon.childFees?.length) {\n addon.childFees.forEach((fee) => {\n addonFees += addon.childQuantity ?? 1 * fee.amount;\n });\n } else {\n addonFees += addon.childQuantity * Number(addon.childFee);\n }\n }\n }\n\n // Multiply the fees by the number of nights if it's a per-night addon.\n if (\n ADDON_PER_NIGHT_TYPES.includes(addon.pricingType as EAddonPricingType) &&\n addon.nights &&\n !dismissAddonNightCount\n ) {\n addonFees *= addon.nights;\n }\n\n return {\n price: acc.price + base.indPrice,\n adultPrice: acc.adultPrice + base.indAdultPrice,\n childPrice: acc.childPrice + base.indChildPrice,\n totalFees: acc.totalFees + addonFees,\n total: acc.total + base.addonTotal + addonFees,\n };\n },\n { price: 0, adultPrice: 0, childPrice: 0, totalFees: 0, total: 0 }\n );\n\n return result;\n };\n\n /**\n * Calculates the total for one or more reservation addons, including itemised fees.\n *\n * @param addons - A single or an array of `ReservationAddonDTO` objects.\n * @param dismissAddonNightCount - If true, disables night-based multiplier for addons.\n * @returns An object with:\n * - `price`: Base addon price without adult/child multipliers.\n * - `adultPrice`: Addon cost based on adult rates.\n * - `childPrice`: Addon cost based on child rates.\n * - `totalFees`: Total of all fees (itemised if available).\n * - `total`: Final addon cost including fees.\n * - `displayPrice`: Price displayed to the user (varies depending on fee breakdown).\n */\n static calculateReservationAddonTotal = (\n addons: ReservationAddonDTO | ReservationAddonDTO[],\n dismissAddonNightCount = false\n ): {\n price: number;\n adultPrice: number;\n childPrice: number;\n totalFees: number;\n total: number;\n displayPrice: number;\n } => {\n if (!Array.isArray(addons)) {\n addons = [addons];\n }\n\n const result = addons.reduce(\n (acc, addon) => {\n const base = TotalCalculator.calculateBaseAddonTotal(addon, dismissAddonNightCount);\n\n // If the addon has a pre-calculated total (with discount applied), use it\n // Otherwise use the calculated base total\n let addonTotal: number;\n let addonDiscount = addon.discount || 0;\n\n if (addon.total !== undefined && addon.total !== null) {\n // Backend has already calculated the total with discount applied\n addonTotal = addon.total;\n } else {\n // Fall back to calculating from base price and apply discount if present\n addonTotal = base.addonTotal - addonDiscount;\n }\n\n // For a ReservationAddonDTO, the fees have already been calculated as a part of the booking process.\n let addonFees = addon.fees || 0;\n\n // But they might be superceded by itemised fees.\n if (addon.itemisedFees?.length) {\n addonFees = addon.itemisedFees.reduce((acc, fee) => acc + fee.amount, 0);\n }\n\n // If we have Itemised Fees, the display price will be excluding fees.\n const displayPrice = addon.itemisedFees?.length ? addonTotal : addonTotal + addonFees;\n\n return {\n price: acc.price + base.indPrice,\n adultPrice: acc.adultPrice + base.indAdultPrice,\n childPrice: acc.childPrice + base.indChildPrice,\n totalFees: acc.totalFees + addonFees,\n total: acc.total + addonTotal + addonFees,\n displayPrice: acc.displayPrice + displayPrice,\n };\n },\n {\n price: 0,\n adultPrice: 0,\n childPrice: 0,\n totalFees: 0,\n total: 0,\n displayPrice: 0,\n }\n );\n\n return result;\n };\n\n /**\n * Calculates the total cost for a reservation, including individual reservation totals and global itemised fees.\n *\n * @param reservation - The full reservation data in `ReservationsDTO` format.\n * @param dismissAddonNightCount - If true, disables night-based multipliers on addons.\n * @returns The rounded total cost of the reservation.\n */\n static calculateTotalForReservation = (reservation: ReservationsDTO, dismissAddonNightCount = false): number => {\n let total = 0;\n\n reservation.itemisedFees?.forEach((fee) => {\n total += fee.amount;\n });\n\n reservation.reservations.forEach((individualRes) => {\n total += individualRes.total.afterTax;\n const resNights = Object.keys(individualRes.nights)?.length ?? 0;\n total += individualRes.fees ?? 0;\n\n if (individualRes.addons?.length) {\n const addons = (individualRes.addons ?? []).map((addon) => {\n return { ...addon, nights: resNights };\n });\n\n total += TotalCalculator.calculateReservationAddonTotal(addons, dismissAddonNightCount)?.total;\n }\n });\n\n return roundMoney(total);\n };\n}\n","export function uppercaseString(toUppercase: string) {\n return toUppercase.toUpperCase();\n}\n"],"names":["EBookingStatus","EBookingFlow","EBookingPaymentMethod","EHotelCardProcessor","EPlanpayBookingStatus","PCIBookingCardProcessorTypes","ItineraryResponse","Reservation","GuestProfile","ECompanyProvider","EAdminCompanyUserRole","EHotelAddressRequirement","EHotelPriceModel","EHotelStateFieldConfiguration","EHotelWeekdayStartsOn","EIntegration","IAuxiliaryFilterType","EDistanceUnitType","ERMSAuthSyncHistoryStatus","ERMSDiscountType","ERMSSyncStrategy","ERoomstayImageSize","IMaintenanceStatusService","Package","ReservedPackage","EGuaranteePolicyDepositMode","EPromoCodeDiscountType","EPromoCodeStayDateRangeType","EPromoCodeStayDateRangeRepeatType","ERoomstayEventSource","DATE_FORMAT","HttpMethod","EFeeType","ERoomstayEventName","toMetaEventName","eventName","transformItemsToMetaEventData","items","currency","totalValue","contentIds","contents","item","transformToMetaEventData","eventData","transformToMetaUserData","guest","EAddonPricingType","ADDON_PER_NIGHT_TYPES","$constructor","name","initializer","params","init","inst","def","_a","k","_","Parent","Definition","fn","_b","$ZodAsyncError","$ZodEncodeError","globalConfig","config","newConfig","getEnumValues","entries","numericValues","v","jsonStringifyReplacer","value","cached","getter","nullish","input","cleanRegex","source","start","end","floatSafeRemainder","val","step","valDecCount","stepString","stepDecCount","match","decCount","valInt","stepInt","EVALUATING","defineLazy","object","key","objectClone","obj","assignProp","target","prop","mergeDefs","defs","mergedDescriptors","descriptors","esc","str","captureStackTrace","_args","isObject","data","allowsEval","F","isPlainObject","o","ctor","prot","shallowClone","propertyKeyTypes","escapeRegex","clone","cl","normalizeParams","_params","optionalKeys","shape","NUMBER_FORMAT_RANGES","pick","schema","mask","currDef","newShape","omit","extend","checks","_shape","safeExtend","merge","a","b","partial","Class","oldShape","required","aborted","x","startIndex","i","prefixIssues","path","issues","iss","unwrapMessage","message","finalizeIssue","ctx","_c","_d","_e","_f","full","getLengthableOrigin","issue","args","util.jsonStringifyReplacer","$ZodError","$ZodRealError","flattenError","error","mapper","fieldErrors","formErrors","sub","formatError","_mapper","processError","curr","el","_parse","_Err","_ctx","result","core.$ZodAsyncError","e","util.finalizeIssue","core.config","util.captureStackTrace","_parseAsync","_safeParse","errors.$ZodError","safeParse","errors.$ZodRealError","_safeParseAsync","safeParseAsync","_encode","_decode","_encodeAsync","_decodeAsync","_safeEncode","_safeDecode","_safeEncodeAsync","_safeDecodeAsync","cuid","cuid2","ulid","xid","ksuid","nanoid","duration","guid","uuid","version","email","_emoji","emoji","ipv4","ipv6","cidrv4","cidrv6","base64","base64url","hostname","e164","dateSource","date","timeSource","hhmm","time","datetime","opts","timeRegex","string","regex","integer","number","boolean","lowercase","uppercase","$ZodCheck","core.$constructor","numericOriginMap","$ZodCheckLessThan","origin","bag","payload","$ZodCheckGreaterThan","$ZodCheckMultipleOf","util.floatSafeRemainder","$ZodCheckNumberFormat","isInt","minimum","maximum","util.NUMBER_FORMAT_RANGES","regexes.integer","$ZodCheckMaxLength","util.nullish","util.getLengthableOrigin","$ZodCheckMinLength","$ZodCheckLengthEquals","length","tooBig","$ZodCheckStringFormat","$ZodCheckRegex","$ZodCheckLowerCase","regexes.lowercase","$ZodCheckUpperCase","regexes.uppercase","$ZodCheckIncludes","escapedRegex","util.escapeRegex","pattern","$ZodCheckStartsWith","$ZodCheckEndsWith","$ZodCheckOverwrite","Doc","arg","lines","minIndent","dedented","line","$ZodType","ch","runChecks","isAborted","util.aborted","asyncResult","currLen","handleCanaryResult","canary","checkResult","r","$ZodString","regexes.string","$ZodStringFormat","checks.$ZodCheckStringFormat","$ZodGUID","regexes.guid","$ZodUUID","regexes.uuid","$ZodEmail","regexes.email","$ZodURL","trimmed","url","regexes.hostname","$ZodEmoji","regexes.emoji","$ZodNanoID","regexes.nanoid","$ZodCUID","regexes.cuid","$ZodCUID2","regexes.cuid2","$ZodULID","regexes.ulid","$ZodXID","regexes.xid","$ZodKSUID","regexes.ksuid","$ZodISODateTime","regexes.datetime","$ZodISODate","regexes.date","$ZodISOTime","regexes.time","$ZodISODuration","regexes.duration","$ZodIPv4","regexes.ipv4","$ZodIPv6","regexes.ipv6","$ZodCIDRv4","regexes.cidrv4","$ZodCIDRv6","regexes.cidrv6","address","prefix","prefixNum","isValidBase64","$ZodBase64","regexes.base64","isValidBase64URL","regexes.base64url","c","padded","$ZodBase64URL","$ZodE164","regexes.e164","isValidJWT","token","algorithm","tokensParts","header","parsedHeader","$ZodJWT","$ZodNumber","regexes.number","received","$ZodNumberFormat","checks.$ZodCheckNumberFormat","$ZodBoolean","regexes.boolean","$ZodUnknown","$ZodNever","$ZodDate","isDate","handleArrayResult","final","index","util.prefixIssues","$ZodArray","proms","handlePropertyResult","normalizeDef","keys","okeys","util.optionalKeys","handleCatchall","unrecognized","keySet","_catchall","t","$ZodObject","_normalized","util.cached","util.defineLazy","propValues","field","util.isObject","catchall","$ZodObjectJIT","superParse","generateFastpass","doc","normalized","parseStr","util.esc","ids","counter","id","fastpass","jit","core.globalConfig","fastEnabled","util.allowsEval","handleUnionResults","results","nonaborted","$ZodUnion","option","patterns","p","util.cleanRegex","single","first","async","$ZodIntersection","left","right","handleIntersectionResults","mergeValues","util.isPlainObject","bKeys","sharedKeys","newObj","sharedValue","newArray","itemA","itemB","merged","$ZodEnum","values","util.getEnumValues","valuesSet","util.propertyKeyTypes","$ZodTransform","core.$ZodEncodeError","_out","output","handleOptionalResult","$ZodOptional","$ZodNullable","$ZodDefault","handleDefaultResult","$ZodPrefault","$ZodNonOptional","handleNonOptionalResult","$ZodCatch","$ZodPipe","handlePipeResult","next","$ZodReadonly","handleReadonlyResult","$ZodCustom","checks.$ZodCheck","handleRefineResult","_iss","util.issue","$ZodRegistry","_meta","meta","pm","f","registry","globalRegistry","_string","util.normalizeParams","_email","_guid","_uuid","_uuidv4","_uuidv6","_uuidv7","_url","_nanoid","_cuid","_cuid2","_ulid","_xid","_ksuid","_ipv4","_ipv6","_cidrv4","_cidrv6","_base64","_base64url","_e164","_jwt","_isoDateTime","_isoDate","_isoTime","_isoDuration","_number","_coercedNumber","_int","_boolean","_unknown","_never","_date","_lt","checks.$ZodCheckLessThan","_lte","_gt","checks.$ZodCheckGreaterThan","_gte","_multipleOf","checks.$ZodCheckMultipleOf","_maxLength","checks.$ZodCheckMaxLength","_minLength","checks.$ZodCheckMinLength","_length","checks.$ZodCheckLengthEquals","_regex","checks.$ZodCheckRegex","_lowercase","checks.$ZodCheckLowerCase","_uppercase","checks.$ZodCheckUpperCase","_includes","includes","checks.$ZodCheckIncludes","_startsWith","checks.$ZodCheckStartsWith","_endsWith","suffix","checks.$ZodCheckEndsWith","_overwrite","tx","checks.$ZodCheckOverwrite","_normalize","form","_trim","_toLowerCase","_toUpperCase","_array","element","_refine","_superRefine","_check","_issue","ZodISODateTime","core.$ZodISODateTime","schemas.ZodStringFormat","core._isoDateTime","ZodISODate","core.$ZodISODate","core._isoDate","ZodISOTime","core.$ZodISOTime","core._isoTime","ZodISODuration","core.$ZodISODuration","core._isoDuration","core.formatError","core.flattenError","ZodRealError","parse","core._parse","parseAsync","core._parseAsync","core._safeParse","core._safeParseAsync","encode","core._encode","decode","core._decode","encodeAsync","core._encodeAsync","decodeAsync","core._decodeAsync","safeEncode","core._safeEncode","safeDecode","core._safeDecode","safeEncodeAsync","core._safeEncodeAsync","safeDecodeAsync","core._safeDecodeAsync","ZodType","core.$ZodType","core.clone","reg","parse.parse","parse.safeParse","parse.parseAsync","parse.safeParseAsync","parse.encode","parse.decode","parse.encodeAsync","parse.decodeAsync","parse.safeEncode","parse.safeDecode","parse.safeEncodeAsync","parse.safeDecodeAsync","check","refine","refinement","superRefine","checks.overwrite","optional","nullable","nonoptional","array","union","intersection","pipe","transform","_default","prefault","_catch","readonly","description","core.globalRegistry","_ZodString","core.$ZodString","checks.regex","checks.includes","checks.startsWith","checks.endsWith","checks.minLength","checks.maxLength","checks.length","checks.lowercase","checks.uppercase","checks.trim","checks.normalize","checks.toLowerCase","checks.toUpperCase","ZodString","core._email","ZodEmail","core._url","ZodURL","core._jwt","ZodJWT","core._emoji","ZodEmoji","core._guid","ZodGUID","core._uuid","ZodUUID","core._uuidv4","core._uuidv6","core._uuidv7","core._nanoid","ZodNanoID","core._cuid","ZodCUID","core._cuid2","ZodCUID2","core._ulid","ZodULID","core._base64","ZodBase64","core._base64url","ZodBase64URL","core._xid","ZodXID","core._ksuid","ZodKSUID","core._ipv4","ZodIPv4","core._ipv6","ZodIPv6","core._cidrv4","ZodCIDRv4","core._cidrv6","ZodCIDRv6","core._e164","ZodE164","iso.datetime","iso.date","iso.time","iso.duration","core._string","ZodStringFormat","core.$ZodStringFormat","core.$ZodEmail","core.$ZodGUID","core.$ZodUUID","core.$ZodURL","core.$ZodEmoji","core.$ZodNanoID","core.$ZodCUID","core.$ZodCUID2","core.$ZodULID","core.$ZodXID","core.$ZodKSUID","core.$ZodIPv4","core.$ZodIPv6","core.$ZodCIDRv4","core.$ZodCIDRv6","core.$ZodBase64","core.$ZodBase64URL","core.$ZodE164","core.$ZodJWT","ZodNumber","core.$ZodNumber","checks.gt","checks.gte","checks.lt","checks.lte","int","checks.multipleOf","core._number","ZodNumberFormat","core.$ZodNumberFormat","core._int","ZodBoolean","core.$ZodBoolean","core._boolean","ZodUnknown","core.$ZodUnknown","unknown","core._unknown","ZodNever","core.$ZodNever","never","core._never","ZodDate","core.$ZodDate","core._date","ZodArray","core.$ZodArray","minLength","maxLength","len","core._array","ZodObject","core.$ZodObjectJIT","_enum","incoming","util.extend","util.safeExtend","other","util.merge","util.pick","util.omit","util.partial","ZodOptional","util.required","ZodNonOptional","util.assignProp","util.objectClone","ZodUnion","core.$ZodUnion","options","ZodIntersection","core.$ZodIntersection","ZodEnum","core.$ZodEnum","newEntries","ZodTransform","core.$ZodTransform","core.$ZodOptional","innerType","ZodNullable","core.$ZodNullable","ZodDefault","core.$ZodDefault","defaultValue","util.shallowClone","ZodPrefault","core.$ZodPrefault","core.$ZodNonOptional","ZodCatch","core.$ZodCatch","catchValue","ZodPipe","core.$ZodPipe","in_","out","ZodReadonly","core.$ZodReadonly","ZodCustom","core.$ZodCustom","core._refine","core._superRefine","preprocess","core._coercedNumber","schemas.ZodNumber","validateFormWithZod","formMethods","err","fieldName","preprocessNumber","z.preprocess","parsed","preprocessDate","requireString","max","z.string","requireEmail","z.email","requirePositiveAmount","z.number","requireFutureDate","z.date","maxString","InternationalAddressSchema","z.object","BaseGiftCardSchema","AddGiftCardSchema","EditGiftCardSchema","EGiftCardPaymentType","CreatePaymentSessionSchema","PaymentProcessorDataSchema","PassthroughPaymentDataSchema","PurchaseGiftCardSchema","z.boolean","RefundGiftCardSchema","ValidateGiftCardSchema","RedeemGiftCardSchema","EGiftCardPaymentProvider","EGiftCardPaymentStatus","AdyenResultCode","AdyenEventCode","EGiftCardTransactionType","ETransactionStatus","CompleteGiftCardTransactionSchema","CancelGiftCardTransactionSchema","GetCompanyConfigSchema","z.coerce.number","UpdateCompanyConfigSchema","z.enum","UpdateAdyenConfigSchema","RefreshGiftCardTokenSchema","z.uuid","RegisterGiftCardAdminSchema","z.array","ELogSeverity","ELogCategory","ELogType","calculateTotalForMemberBooking","reservation","total","itinerary","nightsArray","night","EXP_LIMIT","MAX_DIGITS","NUMERALS","LN10","PI","DEFAULTS","inexact","quadrant","external","decimalError","invalidArgument","precisionLimitExceeded","cryptoUnavailable","tag","mathfloor","mathpow","isBinary","isHex","isOctal","isDecimal","BASE","LOG_BASE","MAX_SAFE_INTEGER","LN10_PRECISION","PI_PRECISION","P","finalise","min","Ctor","y","j","xdL","ydL","xd","yd","xs","ys","pr","rm","cosine","toLessThanHalfPi","m","n","rep","s","sd","t3","t3plusx","digitsToString","divide","w","d","one","tinyPow","taylorSeries","cosh2_x","d8","sinh2_x","d5","d16","d20","halfPi","getPi","wpr","xsd","px","x2","base","isBase10","denominator","inf","num","guard","naturalLogarithm","getLn10","checkRoundingDigits","xe","xLTy","getBase10Exponent","q","naturalExponential","carry","z","getPrecision","sine","rL","toStringBinary","dp","checkInt32","finiteToString","maxD","d0","d1","d2","n0","n1","yn","intPow","ws","indexOfLastWord","getZeroString","repeating","di","rd","convertBase","baseIn","baseOut","arr","arrL","strL","cos2x","multiplyInteger","temp","compare","aL","bL","subtract","cmp","logBase","more","prod","prodL","qd","rem","remL","rem0","xi","xL","yd0","yL","yz","sign","isTruncated","digits","roundUp","xdi","isExp","nonFiniteToString","zs","truncate","isOdd","maxOrMin","ltgt","pow","sum","c0","numerator","x1","parseDecimal","parseOther","divisor","isFloat","Decimal","sin2_x","isHyperbolic","isNeg","pi","abs","acos","acosh","add","asin","asinh","atan","atanh","atan2","cbrt","ceil","clamp","useDefaults","ps","cos","cosh","isDecimalInstance","div","exp","floor","hypot","ln","log","log10","log2","mod","mul","random","round","sin","sinh","sqrt","tan","tanh","trunc","roundMoney","amount","calculateFeeAmount","fee","baseAmount","numberOfNights","feeIncludedInBaseAmount","extractedFromRates","removedPercentages","baseAmountRounded","removedFraction","originalPrice","BOOKING_FEE_TYPES","BOOKING_RATE_FEE_TYPES","BOOKING_ADDON_FEE_TYPES","filterFeesByType","fees","feeTypes","getFilteredBookingFees","getFilteredBookingRateFees","getFilteredBookingAddonFees","getFeeOptionValidity","feeType","nameof","subset","resizeRoomstayImageUrl","size","_TotalCalculator","addon","dismissAddonNightCount","indPrice","indAdultPrice","indChildPrice","addonTotal","addons","acc","addonFees","addonDiscount","displayPrice","individualRes","resNights","TotalCalculator","uppercaseString","toUppercase"],"mappings":"AAAY,IAAAA,uBAAAA,OACRA,EAAA,UAAU,WACVA,EAAA,aAAa,cACbA,EAAA,YAAY,aACZA,EAAA,YAAY,aACZA,EAAA,WAAW,YALHA,IAAAA,MAAA,CAAA,CAAA,GAQAC,uBAAAA,OACRA,EAAA,UAAU,WACVA,EAAA,oBAAoB,qBACpBA,EAAA,qBAAqB,sBAHbA,IAAAA,MAAA,CAAA,CAAA,GCRAC,uBAAAA,OACRA,EAAA,OAAO,QACPA,EAAA,YAAY,aACZA,EAAA,UAAU,WACVA,EAAA,QAAQ,SACRA,EAAA,WAAW,YACXA,EAAA,iBAAiB,kBACjBA,EAAA,cAAc,eAPNA,IAAAA,MAAA,CAAA,CAAA,GAiBAC,uBAAAA,OACRA,EAAA,cAAc,eACdA,EAAA,QAAQ,SACRA,EAAA,OAAO,QACPA,EAAA,SAAS,UACTA,EAAA,WAAW,YACXA,EAAA,aAAa,cACbA,EAAA,SAAS,UACTA,EAAA,SAAS,UARDA,IAAAA,MAAA,CAAA,CAAA,GAWAC,uBAAAA,OACRA,EAAA,UAAU,WACVA,EAAA,SAAS,UACTA,EAAA,WAAW,YACXA,EAAA,YAAY,aACZA,EAAA,WAAW,YACXA,EAAA,WAAW,YANHA,IAAAA,MAAA,CAAA,CAAA;AASL,MAAMC,KAA+B,CAAA;AClCrC,MAAMC,GAAkB;AAAA,EAAxB,cAAA;AAKH,SAAA,eAA8B;EAAC;AAKnC;AAEO,MAAMC,GAAY;AAAA,EAAlB,cAAA;AAWH,SAAA,SAAqC,IACvB,KAAA,cAAA;AAAA,MACV,QAAQ;AAAA,MACR,UAAU;AAAA,IAAA,GAEd,KAAA,QAAQ,IAAIC;EAAa;AAkB7B;AAEO,MAAMA,GAAa;AAAA,EAAnB,cAAA;AAQH,SAAA,UAAoB;EAAC;AAGzB;AC9DY,IAAAC,uBAAAA,OACRA,EAAA,SAAS,UACTA,EAAA,WAAW,YACXA,EAAA,MAAM,OACNA,EAAA,aAAa,cACbA,EAAA,WAAW,YACXA,EAAA,OAAO,QANCA,IAAAA,MAAA,CAAA,CAAA,GCAAC,uBAAAA,OACRA,EAAA,aAAa,cACbA,EAAA,QAAQ,SACRA,EAAA,UAAU,WAHFA,IAAAA,MAAA,CAAA,CAAA,GCAAC,uBAAAA,OACRA,EAAA,sBAAsB,uBACtBA,EAAA,iCAAiC,kCACjCA,EAAA,kBAAkB,mBAHVA,IAAAA,MAAA,CAAA,CAAA,GCAAC,uBAAAA,OACRA,EAAA,YAAY,aACZA,EAAA,SAAS,UACTA,EAAA,eAAe,gBAHPA,IAAAA,MAAA,CAAA,CAAA,GCAAC,uBAAAA,OACRA,EAAA,cAAc,eACdA,EAAA,WAAW,YACXA,EAAA,WAAW,YAHHA,IAAAA,MAAA,CAAA,CAAA,GCAAC,uBAAAA,OACRA,EAAA,SAAS,UACTA,EAAA,SAAS,UAFDA,IAAAA,MAAA,CAAA,CAAA,GCAAC,uBAAAA,OACRA,EAAA,OAAO,QACPA,EAAA,WAAW,SACXA,EAAA,QAAQ,YACRA,EAAA,OAAO,QACPA,EAAA,aAAa,cACbA,EAAA,MAAM,OACNA,EAAA,kBAAkB,mBAPVA,IAAAA,MAAA,CAAA,CAAA,GCmBAC,uBAAAA,OACRA,EAAA,qBAAqB,sBACrBA,EAAA,mBAAmB,oBAFXA,IAAAA,MAAA,CAAA,CAAA,GCnBAC,uBAAAA,OACRA,EAAA,SAAS,UACTA,EAAA,WAAW,YAFHA,IAAAA,MAAA,CAAA,CAAA,GCAAC,uBAAAA,OACRA,EAAA,UAAU,WACVA,EAAA,UAAU,WACVA,EAAA,MAAM,OACNA,EAAA,SAAS,UACTA,EAAA,aAAa,eACbA,EAAA,gBAAgB,kBANRA,IAAAA,MAAA,CAAA,CAAA,GCAAC,uBAAAA,OACVA,EAAA,aAAa,cACbA,EAAA,SAAS,UACTA,EAAA,OAAO,QACPA,EAAA,sBAAsB,uBAJZA,IAAAA,MAAA,CAAA,CAAA,GCAAC,uBAAAA,OAIRA,EAAA,QAAQ,SACRA,EAAA,cAAc,eACdA,EAAA,eAAe,gBACfA,EAAA,OAAO,QACPA,EAAA,QAAQ,SACRA,EAAA,qBAAqB,sBACrBA,EAAA,YAAY,aACZA,EAAA,aAAa,cACbA,EAAA,iBAAiB,mBACjBA,EAAA,QAAQ,SACRA,EAAA,YAAY,aACZA,EAAA,gBAAgB,iBAChBA,EAAA,kCAAkC,mCAClCA,EAAA,YAAY,aACZA,EAAA,oBAAoB,qBACpBA,EAAA,gBAAgB,iBAChBA,EAAA,mBAAmB,oBACnBA,EAAA,eAAe,gBACfA,EAAA,gBAAgB,kBAChBA,EAAA,YAAY,aACZA,EAAA,SAAS,UACTA,EAAA,eAAe,gBACfA,EAAA,aAAa,eAKbA,EAAA,wBAAwB,yBACxBA,EAAA,uBAAuB,wBACvBA,EAAA,uBAAuB,wBAKvBA,EAAA,eAAe,gBAtCPA,IAAAA,MAAA,CAAA,CAAA,GCAAC,uBAAAA,OACRA,EAAAA,EAAA,OAAO,GAAP,IAAA,QACAA,EAAAA,EAAA,OAAO,GAAP,IAAA,QACAA,EAAAA,EAAA,QAAQ,GAAR,IAAA,SACAA,EAAAA,EAAA,SAAS,GAAT,IAAA,UACAA,EAAAA,EAAA,QAAQ,IAAR,IAAA,SACAA,EAAAA,EAAA,aAAa,IAAb,IAAA,cANQA,IAAAA,MAAA,CAAA,CAAA,GC0BAC,uBAAAA,OACRA,EAAA,WAAW,YACXA,EAAA,QAAQ,SACRA,EAAA,SAAS,UAHDA,IAAAA,MAAA,CAAA,CAAA;ACtBL,MAAMC,GAAQ;AAAA,EAAd,cAAA;AAyCH,SAAO,eAA+C;EAAC;AAC3D;AAEO,MAAMC,WAAwBD,GAAQ;AAAA,EAAtC,cAAA;AAAA,UAAA,GAAA,SAAA,GAcH,KAAO,iBAA2B,IAClC,KAAO,eAAyB;AAAA,EAAA;AAKpC;ACpEY,IAAAE,uBAAAA,OACRA,EAAA,OAAO,QACPA,EAAA,aAAa,cACbA,EAAA,aAAa,cACbA,EAAA,OAAO,QAJCA,IAAAA,MAAA,CAAA,CAAA,GCAAC,uBAAAA,OACRA,EAAA,cAAc,eACdA,EAAA,eAAe,gBACfA,EAAA,sBAAsB,uBAHdA,IAAAA,MAAA,CAAA,CAAA,GCAAC,uBAAAA,OACRA,EAAA,UAAU,WACVA,EAAA,UAAU,WAFFA,IAAAA,MAAA,CAAA,CAAA,GAKAC,uBAAAA,OACRA,EAAA,OAAO,QACPA,EAAA,SAAS,UACTA,EAAA,mBAAmB,oBACnBA,EAAA,cAAc,eACdA,EAAA,SAAS,UALDA,IAAAA,MAAA,CAAA,CAAA,GCLAC,uBAAAA,OACRA,EAAA,aAAa,cACbA,EAAA,OAAO,QAFCA,IAAAA,MAAA,CAAA,CAAA;ACAL,MAAMC,KAAc;ACAf,IAAAC,uBAAAA,OACRA,EAAA,MAAM,OACNA,EAAA,OAAO,QACPA,EAAA,MAAM,OACNA,EAAA,SAAS,UACTA,EAAA,QAAQ,SACRA,EAAA,UAAU,WACVA,EAAA,OAAO,QAPCA,IAAAA,MAAA,CAAA,CAAA,GCAAC,sBAAAA,OACRA,EAAA,sBAAsB,uBACtBA,EAAA,qBAAqB,sBACrBA,EAAA,uBAAuB,wBACvBA,EAAA,wBAAwB,yBACxBA,EAAA,mBAAmB,oBALXA,IAAAA,KAAA,CAAA,CAAA,GCKAC,uBAAAA,OACRA,EAAA,YAAY,cACZA,EAAA,eAAe,iBACfA,EAAA,mBAAmB,qBAHXA,IAAAA,MAAA,CAAA,CAAA;ACQL,SAASC,GAAgBC,GAAuC;AAMnE,SALoD;AAAA,IAChD,CAACF,GAAmB,SAAS,GAAG;AAAA,IAChC,CAACA,GAAmB,YAAY,GAAG;AAAA,IACnC,CAACA,GAAmB,gBAAgB,GAAG;AAAA,EAAA,EAE5BE,CAAS;AAC5B;AAKA,SAASC,GAA8BC,GAA8BC,GAAkC;AACnG,MAAIC,IAAa;AACjB,QAAMC,IAAuB,CAAA,GACvBC,IAAuC,CAAA;AAE7C,aAAWC,KAAQL;AACf,IAAAE,KAAcG,EAAK,YAEfA,EAAK,aACMF,EAAA,KAAKE,EAAK,QAAQ,GAC7BD,EAAS,KAAK;AAAA,MACV,IAAIC,EAAK;AAAA,MACT,UAAU;AAAA,MACV,YAAYA,EAAK;AAAA,IAAA,CACpB;AAIF,SAAA;AAAA,IACH,UAAAJ;AAAA,IACA,OAAOC;AAAA,IACP,aAAaC;AAAA,IACb,cAAc;AAAA,IACd,UAAAC;AAAA,IACA,WAAWJ,EAAM;AAAA,EAAA;AAEzB;AAMO,SAASM,GAAyBC,GAA+C;AAEpF,MAAI,UAAUA;AACV,WAAOR,GAA8B,CAACQ,EAAU,IAAI,GAAGA,EAAU,QAAQ;AAI7E,MAAI,WAAWA;AACX,WAAOR,GAA8BQ,EAAU,OAAOA,EAAU,QAAQ;AAGtE,QAAA,IAAI,MAAM,oBAAoB;AACxC;AAKO,SAASC,GAAwBC,GAA0C;AACvE,SAAA;AAAA,IACH,IAAIA,EAAM;AAAA,IACV,IAAIA,EAAM;AAAA,IACV,IAAIA,EAAM;AAAA,IACV,IAAIA,EAAM;AAAA,IACV,IAAIA,EAAM;AAAA,IACV,IAAIA,EAAM;AAAA,IACV,IAAIA,EAAM;AAAA,IACV,SAASA,EAAM;AAAA,IACf,aAAaA,EAAM;AAAA,EAAA;AAE3B;ACpFY,IAAAC,sBAAAA,OACVA,EAAA,WAAW,YACXA,EAAA,YAAY,aACZA,EAAA,aAAa,cACbA,EAAA,uBAAuB,wBAEvBA,EAAA,kBAAkB,mBAClBA,EAAA,4BAA4B,6BAG5BA,EAAA,8BAA8B,+BAC9BA,EAAA,8BAA8B,+BAC9BA,EAAA,iCAAiC,kCACjCA,EAAA,gCAAgC,iCAChCA,EAAA,gCAAgC,iCAdtBA,IAAAA,KAAA,CAAA,CAAA;ACAL,MAAMC,KAAwB;AAAA,EACnCD,EAAkB;AAAA,EAClBA,EAAkB;AAAA,EAElBA,EAAkB;AAAA,EAClBA,EAAkB;AAAA,EAClBA,EAAkB;AAAA,EAClBA,EAAkB;AAAA,EAClBA,EAAkB;AAAA,EAElBA,EAAkB;AACpB;ACTgC,SAASE,EAAaC,GAAMC,GAAaC,GAAQ;AAC7E,WAASC,EAAKC,GAAMC,GAAK;AACrB,QAAIC;AACJ,WAAO,eAAeF,GAAM,QAAQ;AAAA,MAChC,OAAOA,EAAK,QAAQ,CAAE;AAAA,MACtB,YAAY;AAAA,IACxB,CAAS,IACAE,IAAKF,EAAK,MAAM,WAAWE,EAAG,SAAS,oBAAI,IAAG,IAC/CF,EAAK,KAAK,OAAO,IAAIJ,CAAI,GACzBC,EAAYG,GAAMC,CAAG;AAErB,eAAWE,KAAKC,EAAE;AACd,MAAMD,KAAKH,KACP,OAAO,eAAeA,GAAMG,GAAG,EAAE,OAAOC,EAAE,UAAUD,CAAC,EAAE,KAAKH,CAAI,EAAG,CAAA;AAE3E,IAAAA,EAAK,KAAK,SAASI,GACnBJ,EAAK,KAAK,MAAMC;AAAA,EACnB;AAED,QAAMI,KAASP,KAAA,gBAAAA,EAAQ,WAAU;AAAA,EACjC,MAAMQ,UAAmBD,EAAO;AAAA,EAC/B;AACD,SAAO,eAAeC,GAAY,QAAQ,EAAE,OAAOV,EAAI,CAAE;AACzD,WAASQ,EAAEH,GAAK;AACZ,QAAIC;AACJ,UAAMF,IAAOF,KAAA,QAAAA,EAAQ,SAAS,IAAIQ,EAAU,IAAK;AACjD,IAAAP,EAAKC,GAAMC,CAAG,IACbC,IAAKF,EAAK,MAAM,aAAaE,EAAG,WAAW,CAAA;AAC5C,eAAWK,KAAMP,EAAK,KAAK;AACvB,MAAAO;AAEJ,WAAOP;AAAA,EACV;AACD,gBAAO,eAAeI,GAAG,QAAQ,EAAE,OAAOL,EAAI,CAAE,GAChD,OAAO,eAAeK,GAAG,OAAO,aAAa;AAAA,IACzC,OAAO,CAACJ,MAAS;A7BvCb,UAAAE,GAAAM;A6BwCA,aAAIV,KAAA,QAAAA,EAAQ,UAAUE,aAAgBF,EAAO,SAClC,MACJU,KAAAN,IAAAF,KAAA,gBAAAA,EAAM,SAAN,gBAAAE,EAAY,WAAZ,gBAAAM,EAAoB,IAAIZ;AAAA,IAClC;AAAA,EACT,CAAK,GACD,OAAO,eAAeQ,GAAG,QAAQ,EAAE,OAAOR,EAAI,CAAE,GACzCQ;AACX;AAGO,MAAMK,WAAuB,MAAM;AAAA,EACtC,cAAc;AACV,UAAM,0EAA0E;AAAA,EACnF;AACL;AACO,MAAMC,WAAwB,MAAM;AAAA,EACvC,YAAYd,GAAM;AACd,UAAM,uDAAuDA,CAAI,EAAE,GACnE,KAAK,OAAO;AAAA,EACf;AACL;AACO,MAAMe,KAAe,CAAA;AACrB,SAASC,GAAOC,GAAW;AAC9B,SAAIA,KACA,OAAO,OAAOF,IAAcE,CAAS,GAClCF;AACX;ACtDO,SAASG,GAAcC,GAAS;AACnC,QAAMC,IAAgB,OAAO,OAAOD,CAAO,EAAE,OAAO,CAACE,MAAM,OAAOA,KAAM,QAAQ;AAIhF,SAHe,OAAO,QAAQF,CAAO,EAChC,OAAO,CAAC,CAACZ,GAAGC,CAAC,MAAMY,EAAc,QAAQ,CAACb,CAAC,MAAM,EAAE,EACnD,IAAI,CAAC,CAACC,GAAGa,CAAC,MAAMA,CAAC;AAE1B;AAIO,SAASC,GAAsBd,GAAGe,GAAO;AAC5C,SAAI,OAAOA,KAAU,WACVA,EAAM,aACVA;AACX;AACO,SAASC,GAAOC,GAAQ;AAE3B,SAAO;AAAA,IACH,IAAI,QAAQ;AACE;AACN,cAAMF,IAAQE;AACd,sBAAO,eAAe,MAAM,SAAS,EAAE,OAAAF,EAAO,CAAA,GACvCA;AAAA,MACV;AAAA,IAEJ;AAAA,EACT;AACA;AACO,SAASG,GAAQC,GAAO;AAC3B,SAAOA,KAAU;AACrB;AACO,SAASC,GAAWC,GAAQ;AAC/B,QAAMC,IAAQD,EAAO,WAAW,GAAG,IAAI,IAAI,GACrCE,IAAMF,EAAO,SAAS,GAAG,IAAIA,EAAO,SAAS,IAAIA,EAAO;AAC9D,SAAOA,EAAO,MAAMC,GAAOC,CAAG;AAClC;AACO,SAASC,GAAmBC,GAAKC,GAAM;AAC1C,QAAMC,KAAeF,EAAI,WAAW,MAAM,GAAG,EAAE,CAAC,KAAK,IAAI,QACnDG,IAAaF,EAAK;AACxB,MAAIG,KAAgBD,EAAW,MAAM,GAAG,EAAE,CAAC,KAAK,IAAI;AACpD,MAAIC,MAAiB,KAAK,WAAW,KAAKD,CAAU,GAAG;AACnD,UAAME,IAAQF,EAAW,MAAM,YAAY;AAC3C,IAAIE,KAAA,QAAAA,EAAQ,OACRD,IAAe,OAAO,SAASC,EAAM,CAAC,CAAC;AAAA,EAE9C;AACD,QAAMC,IAAWJ,IAAcE,IAAeF,IAAcE,GACtDG,IAAS,OAAO,SAASP,EAAI,QAAQM,CAAQ,EAAE,QAAQ,KAAK,EAAE,CAAC,GAC/DE,IAAU,OAAO,SAASP,EAAK,QAAQK,CAAQ,EAAE,QAAQ,KAAK,EAAE,CAAC;AACvE,SAAQC,IAASC,IAAW,MAAMF;AACtC;AACA,MAAMG,KAAa,OAAO,YAAY;AAC/B,SAASC,EAAWC,GAAQC,GAAKpB,GAAQ;AAC5C,MAAIF;AACJ,SAAO,eAAeqB,GAAQC,GAAK;AAAA,IAC/B,MAAM;AACF,UAAItB,MAAUmB;AAId,eAAInB,MAAU,WACVA,IAAQmB,IACRnB,IAAQE,EAAM,IAEXF;AAAA,IACV;AAAA,IACD,IAAIF,GAAG;AACH,aAAO,eAAeuB,GAAQC,GAAK;AAAA,QAC/B,OAAOxB;AAAA;AAAA,MAEvB,CAAa;AAAA,IAEJ;AAAA,IACD,cAAc;AAAA,EACtB,CAAK;AACL;AACO,SAASyB,GAAYC,GAAK;AAC7B,SAAO,OAAO,OAAO,OAAO,eAAeA,CAAG,GAAG,OAAO,0BAA0BA,CAAG,CAAC;AAC1F;AACO,SAASC,GAAWC,GAAQC,GAAM3B,GAAO;AAC5C,SAAO,eAAe0B,GAAQC,GAAM;AAAA,IAChC,OAAA3B;AAAA,IACA,UAAU;AAAA,IACV,YAAY;AAAA,IACZ,cAAc;AAAA,EACtB,CAAK;AACL;AACO,SAAS4B,MAAaC,GAAM;AAC/B,QAAMC,IAAoB,CAAA;AAC1B,aAAWhD,KAAO+C,GAAM;AACpB,UAAME,IAAc,OAAO,0BAA0BjD,CAAG;AACxD,WAAO,OAAOgD,GAAmBC,CAAW;AAAA,EAC/C;AACD,SAAO,OAAO,iBAAiB,CAAE,GAAED,CAAiB;AACxD;AA4BO,SAASE,GAAIC,GAAK;AACrB,SAAO,KAAK,UAAUA,CAAG;AAC7B;AACO,MAAMC,KAAqB,uBAAuB,QAAQ,MAAM,oBAAoB,IAAIC,MAAU;AAAA;AAClG,SAASC,GAASC,GAAM;AAC3B,SAAO,OAAOA,KAAS,YAAYA,MAAS,QAAQ,CAAC,MAAM,QAAQA,CAAI;AAC3E;AACO,MAAMC,KAAarC,GAAO,MAAM;A9B7I3B,MAAAlB;A8B+IR,MAAI,OAAO,YAAc,SAAeA,IAAA,uCAAW,cAAX,QAAAA,EAAsB,SAAS;AACnE,WAAO;AAEX,MAAI;AACA,UAAMwD,IAAI;AACV,eAAIA,EAAE,EAAE,GACD;AAAA,EACV,QACS;AACN,WAAO;AAAA,EACV;AACL,CAAC;AACM,SAASC,GAAcC,GAAG;AAC7B,MAAIL,GAASK,CAAC,MAAM;AAChB,WAAO;AAEX,QAAMC,IAAOD,EAAE;AACf,MAAIC,MAAS;AACT,WAAO;AAEX,QAAMC,IAAOD,EAAK;AAIlB,SAHI,EAAAN,GAASO,CAAI,MAAM,MAGnB,OAAO,UAAU,eAAe,KAAKA,GAAM,eAAe,MAAM;AAIxE;AACO,SAASC,GAAaH,GAAG;AAC5B,SAAID,GAAcC,CAAC,IACR,EAAE,GAAGA,MACTA;AACX;AAuDO,MAAMI,KAAmB,oBAAI,IAAI,CAAC,UAAU,UAAU,QAAQ,CAAC;AAE/D,SAASC,GAAYb,GAAK;AAC7B,SAAOA,EAAI,QAAQ,uBAAuB,MAAM;AACpD;AAEO,SAASc,GAAMlE,GAAMC,GAAKH,GAAQ;AACrC,QAAMqE,IAAK,IAAInE,EAAK,KAAK,OAAOC,KAAOD,EAAK,KAAK,GAAG;AACpD,UAAI,CAACC,KAAOH,KAAA,QAAAA,EAAQ,YAChBqE,EAAG,KAAK,SAASnE,IACdmE;AACX;AACO,SAASC,EAAgBC,GAAS;AACrC,QAAMvE,IAASuE;AACf,MAAI,CAACvE;AACD,WAAO;AACX,MAAI,OAAOA,KAAW;AAClB,WAAO,EAAE,OAAO,MAAMA;AAC1B,OAAIA,KAAA,gBAAAA,EAAQ,aAAY,QAAW;AAC/B,SAAIA,KAAA,gBAAAA,EAAQ,WAAU;AAClB,YAAM,IAAI,MAAM,kDAAkD;AACtE,IAAAA,EAAO,QAAQA,EAAO;AAAA,EACzB;AAED,SADA,OAAOA,EAAO,SACV,OAAOA,EAAO,SAAU,WACjB,EAAE,GAAGA,GAAQ,OAAO,MAAMA,EAAO,MAAK,IAC1CA;AACX;AAyCO,SAASwE,GAAaC,GAAO;AAChC,SAAO,OAAO,KAAKA,CAAK,EAAE,OAAO,CAACpE,MACvBoE,EAAMpE,CAAC,EAAE,KAAK,UAAU,cAAcoE,EAAMpE,CAAC,EAAE,KAAK,WAAW,UACzE;AACL;AACO,MAAMqE,KAAuB;AAAA,EAChC,SAAS,CAAC,OAAO,kBAAkB,OAAO,gBAAgB;AAAA,EAC1D,OAAO,CAAC,aAAa,UAAU;AAAA,EAC/B,QAAQ,CAAC,GAAG,UAAU;AAAA,EACtB,SAAS,CAAC,uBAAwB,oBAAqB;AAAA,EACvD,SAAS,CAAC,CAAC,OAAO,WAAW,OAAO,SAAS;AACjD;AAKO,SAASC,GAAKC,GAAQC,GAAM;AAC/B,QAAMC,IAAUF,EAAO,KAAK,KACtBzE,IAAM8C,GAAU2B,EAAO,KAAK,KAAK;AAAA,IACnC,IAAI,QAAQ;AACR,YAAMG,IAAW,CAAA;AACjB,iBAAWpC,KAAOkC,GAAM;AACpB,YAAI,EAAElC,KAAOmC,EAAQ;AACjB,gBAAM,IAAI,MAAM,sBAAsBnC,CAAG,GAAG;AAEhD,QAAKkC,EAAKlC,CAAG,MAEboC,EAASpC,CAAG,IAAImC,EAAQ,MAAMnC,CAAG;AAAA,MACpC;AACD,aAAAG,GAAW,MAAM,SAASiC,CAAQ,GAC3BA;AAAA,IACV;AAAA,IACD,QAAQ,CAAE;AAAA,EAClB,CAAK;AACD,SAAOX,GAAMQ,GAAQzE,CAAG;AAC5B;AACO,SAAS6E,GAAKJ,GAAQC,GAAM;AAC/B,QAAMC,IAAUF,EAAO,KAAK,KACtBzE,IAAM8C,GAAU2B,EAAO,KAAK,KAAK;AAAA,IACnC,IAAI,QAAQ;AACR,YAAMG,IAAW,EAAE,GAAGH,EAAO,KAAK,IAAI;AACtC,iBAAWjC,KAAOkC,GAAM;AACpB,YAAI,EAAElC,KAAOmC,EAAQ;AACjB,gBAAM,IAAI,MAAM,sBAAsBnC,CAAG,GAAG;AAEhD,QAAKkC,EAAKlC,CAAG,KAEb,OAAOoC,EAASpC,CAAG;AAAA,MACtB;AACD,aAAAG,GAAW,MAAM,SAASiC,CAAQ,GAC3BA;AAAA,IACV;AAAA,IACD,QAAQ,CAAE;AAAA,EAClB,CAAK;AACD,SAAOX,GAAMQ,GAAQzE,CAAG;AAC5B;AACO,SAAS8E,GAAOL,GAAQH,GAAO;AAClC,MAAI,CAACZ,GAAcY,CAAK;AACpB,UAAM,IAAI,MAAM,kDAAkD;AAEtE,QAAMS,IAASN,EAAO,KAAK,IAAI;AAE/B,MADkBM,KAAUA,EAAO,SAAS;AAExC,UAAM,IAAI,MAAM,wFAAwF;AAE5G,QAAM/E,IAAM8C,GAAU2B,EAAO,KAAK,KAAK;AAAA,IACnC,IAAI,QAAQ;AACR,YAAMO,IAAS,EAAE,GAAGP,EAAO,KAAK,IAAI,OAAO,GAAGH;AAC9C,aAAA3B,GAAW,MAAM,SAASqC,CAAM,GACzBA;AAAA,IACV;AAAA,IACD,QAAQ,CAAE;AAAA,EAClB,CAAK;AACD,SAAOf,GAAMQ,GAAQzE,CAAG;AAC5B;AACO,SAASiF,GAAWR,GAAQH,GAAO;AACtC,MAAI,CAACZ,GAAcY,CAAK;AACpB,UAAM,IAAI,MAAM,sDAAsD;AAE1E,QAAMtE,IAAM;AAAA,IACR,GAAGyE,EAAO,KAAK;AAAA,IACf,IAAI,QAAQ;AACR,YAAMO,IAAS,EAAE,GAAGP,EAAO,KAAK,IAAI,OAAO,GAAGH;AAC9C,aAAA3B,GAAW,MAAM,SAASqC,CAAM,GACzBA;AAAA,IACV;AAAA,IACD,QAAQP,EAAO,KAAK,IAAI;AAAA,EAChC;AACI,SAAOR,GAAMQ,GAAQzE,CAAG;AAC5B;AACO,SAASkF,GAAMC,GAAGC,GAAG;AACxB,QAAMpF,IAAM8C,GAAUqC,EAAE,KAAK,KAAK;AAAA,IAC9B,IAAI,QAAQ;AACR,YAAMH,IAAS,EAAE,GAAGG,EAAE,KAAK,IAAI,OAAO,GAAGC,EAAE,KAAK,IAAI,MAAK;AACzD,aAAAzC,GAAW,MAAM,SAASqC,CAAM,GACzBA;AAAA,IACV;AAAA,IACD,IAAI,WAAW;AACX,aAAOI,EAAE,KAAK,IAAI;AAAA,IACrB;AAAA,IACD,QAAQ,CAAE;AAAA;AAAA,EAClB,CAAK;AACD,SAAOnB,GAAMkB,GAAGnF,CAAG;AACvB;AACO,SAASqF,GAAQC,GAAOb,GAAQC,GAAM;AACzC,QAAM1E,IAAM8C,GAAU2B,EAAO,KAAK,KAAK;AAAA,IACnC,IAAI,QAAQ;AACR,YAAMc,IAAWd,EAAO,KAAK,IAAI,OAC3BH,IAAQ,EAAE,GAAGiB;AACnB,UAAIb;AACA,mBAAWlC,KAAOkC,GAAM;AACpB,cAAI,EAAElC,KAAO+C;AACT,kBAAM,IAAI,MAAM,sBAAsB/C,CAAG,GAAG;AAEhD,UAAKkC,EAAKlC,CAAG,MAGb8B,EAAM9B,CAAG,IAAI8C,IACP,IAAIA,EAAM;AAAA,YACR,MAAM;AAAA,YACN,WAAWC,EAAS/C,CAAG;AAAA,UACnD,CAAyB,IACC+C,EAAS/C,CAAG;AAAA,QACrB;AAAA;AAGD,mBAAWA,KAAO+C;AAEd,UAAAjB,EAAM9B,CAAG,IAAI8C,IACP,IAAIA,EAAM;AAAA,YACR,MAAM;AAAA,YACN,WAAWC,EAAS/C,CAAG;AAAA,UACnD,CAAyB,IACC+C,EAAS/C,CAAG;AAG1B,aAAAG,GAAW,MAAM,SAAS2B,CAAK,GACxBA;AAAA,IACV;AAAA,IACD,QAAQ,CAAE;AAAA,EAClB,CAAK;AACD,SAAOL,GAAMQ,GAAQzE,CAAG;AAC5B;AACO,SAASwF,GAASF,GAAOb,GAAQC,GAAM;AAC1C,QAAM1E,IAAM8C,GAAU2B,EAAO,KAAK,KAAK;AAAA,IACnC,IAAI,QAAQ;AACR,YAAMc,IAAWd,EAAO,KAAK,IAAI,OAC3BH,IAAQ,EAAE,GAAGiB;AACnB,UAAIb;AACA,mBAAWlC,KAAOkC,GAAM;AACpB,cAAI,EAAElC,KAAO8B;AACT,kBAAM,IAAI,MAAM,sBAAsB9B,CAAG,GAAG;AAEhD,UAAKkC,EAAKlC,CAAG,MAGb8B,EAAM9B,CAAG,IAAI,IAAI8C,EAAM;AAAA,YACnB,MAAM;AAAA,YACN,WAAWC,EAAS/C,CAAG;AAAA,UAC/C,CAAqB;AAAA,QACJ;AAAA;AAGD,mBAAWA,KAAO+C;AAEd,UAAAjB,EAAM9B,CAAG,IAAI,IAAI8C,EAAM;AAAA,YACnB,MAAM;AAAA,YACN,WAAWC,EAAS/C,CAAG;AAAA,UAC/C,CAAqB;AAGT,aAAAG,GAAW,MAAM,SAAS2B,CAAK,GACxBA;AAAA,IACV;AAAA,IACD,QAAQ,CAAE;AAAA,EAClB,CAAK;AACD,SAAOL,GAAMQ,GAAQzE,CAAG;AAC5B;AAEO,SAASyF,GAAQC,GAAGC,IAAa,GAAG;A9B9d/B,MAAA1F;A8B+dR,MAAIyF,EAAE,YAAY;AACd,WAAO;AACX,WAASE,IAAID,GAAYC,IAAIF,EAAE,OAAO,QAAQE;AAC1C,UAAI3F,IAAAyF,EAAE,OAAOE,CAAC,MAAV,gBAAA3F,EAAa,cAAa;AAC1B,aAAO;AAGf,SAAO;AACX;AACO,SAAS4F,GAAaC,GAAMC,GAAQ;AACvC,SAAOA,EAAO,IAAI,CAACC,MAAQ;AACvB,QAAI/F;AACJ,YAACA,IAAK+F,GAAK,SAAS/F,EAAG,OAAO,CAAA,IAC9B+F,EAAI,KAAK,QAAQF,CAAI,GACdE;AAAA,EACf,CAAK;AACL;AACO,SAASC,GAAcC,GAAS;AACnC,SAAO,OAAOA,KAAY,WAAWA,IAAUA,KAAA,gBAAAA,EAAS;AAC5D;AACO,SAASC,GAAcH,GAAKI,GAAKzF,GAAQ;A9BnfpC,MAAAV,GAAAM,GAAA8F,GAAAC,GAAAC,GAAAC;A8BofR,QAAMC,IAAO,EAAE,GAAGT,GAAK,MAAMA,EAAI,QAAQ,CAAA;AAEzC,MAAI,CAACA,EAAI,SAAS;AACd,UAAME,IAAUD,IAAcI,KAAA9F,KAAAN,IAAA+F,EAAI,SAAJ,gBAAA/F,EAAU,KAAK,QAAf,gBAAAM,EAAoB,UAApB,gBAAA8F,EAAA,KAAA9F,GAA4ByF,EAAI,KAC1DC,IAAcK,IAAAF,KAAA,gBAAAA,EAAK,UAAL,gBAAAE,EAAA,KAAAF,GAAaJ,EAAI,KAC/BC,IAAcM,IAAA5F,EAAO,gBAAP,gBAAA4F,EAAA,KAAA5F,GAAqBqF,EAAI,KACvCC,IAAcO,IAAA7F,EAAO,gBAAP,gBAAA6F,EAAA,KAAA7F,GAAqBqF,EAAI,KACvC;AACJ,IAAAS,EAAK,UAAUP;AAAA,EAClB;AAED,gBAAOO,EAAK,MACZ,OAAOA,EAAK,UACPL,KAAA,QAAAA,EAAK,eACN,OAAOK,EAAK,OAETA;AACX;AAWO,SAASC,GAAoBpF,GAAO;AACvC,SAAI,MAAM,QAAQA,CAAK,IACZ,UACP,OAAOA,KAAU,WACV,WACJ;AACX;AACO,SAASqF,MAASC,GAAM;AAC3B,QAAM,CAACZ,GAAK1E,GAAOvB,CAAI,IAAI6G;AAC3B,SAAI,OAAOZ,KAAQ,WACR;AAAA,IACH,SAASA;AAAA,IACT,MAAM;AAAA,IACN,OAAA1E;AAAA,IACA,MAAAvB;AAAA,EACZ,IAEW,EAAE,GAAGiG;AAChB;AChiBA,MAAMpG,KAAc,CAACG,GAAMC,MAAQ;AAC/B,EAAAD,EAAK,OAAO,aACZ,OAAO,eAAeA,GAAM,QAAQ;AAAA,IAChC,OAAOA,EAAK;AAAA,IACZ,YAAY;AAAA,EACpB,CAAK,GACD,OAAO,eAAeA,GAAM,UAAU;AAAA,IAClC,OAAOC;AAAA,IACP,YAAY;AAAA,EACpB,CAAK,GACDD,EAAK,UAAU,KAAK,UAAUC,GAAK6G,IAA4B,CAAC,GAChE,OAAO,eAAe9G,GAAM,YAAY;AAAA,IACpC,OAAO,MAAMA,EAAK;AAAA,IAClB,YAAY;AAAA,EACpB,CAAK;AACL,GACa+G,KAAYpH,EAAa,aAAaE,EAAW,GACjDmH,KAAgBrH,EAAa,aAAaE,IAAa,EAAE,QAAQ,MAAK,CAAE;AAC9E,SAASoH,GAAaC,GAAOC,IAAS,CAACP,MAAUA,EAAM,SAAS;AACnE,QAAMQ,IAAc,CAAA,GACdC,IAAa,CAAA;AACnB,aAAWC,KAAOJ,EAAM;AACpB,IAAII,EAAI,KAAK,SAAS,KAClBF,EAAYE,EAAI,KAAK,CAAC,CAAC,IAAIF,EAAYE,EAAI,KAAK,CAAC,CAAC,KAAK,CAAA,GACvDF,EAAYE,EAAI,KAAK,CAAC,CAAC,EAAE,KAAKH,EAAOG,CAAG,CAAC,KAGzCD,EAAW,KAAKF,EAAOG,CAAG,CAAC;AAGnC,SAAO,EAAE,YAAAD,GAAY,aAAAD;AACzB;AACO,SAASG,GAAYL,GAAOM,GAAS;AACxC,QAAML,IAASK,KACX,SAAUZ,GAAO;AACb,WAAOA,EAAM;AAAA,EACzB,GACUQ,IAAc,EAAE,SAAS,CAAA,KACzBK,IAAe,CAACP,MAAU;AAC5B,eAAWN,KAASM,EAAM;AACtB,UAAIN,EAAM,SAAS,mBAAmBA,EAAM,OAAO;AAC/C,QAAAA,EAAM,OAAO,IAAI,CAACZ,MAAWyB,EAAa,EAAE,QAAAzB,EAAQ,CAAA,CAAC;AAAA,eAEhDY,EAAM,SAAS;AACpB,QAAAa,EAAa,EAAE,QAAQb,EAAM,OAAQ,CAAA;AAAA,eAEhCA,EAAM,SAAS;AACpB,QAAAa,EAAa,EAAE,QAAQb,EAAM,OAAQ,CAAA;AAAA,eAEhCA,EAAM,KAAK,WAAW;AAC3B,QAAAQ,EAAY,QAAQ,KAAKD,EAAOP,CAAK,CAAC;AAAA,WAErC;AACD,YAAIc,IAAON,GACPvB,IAAI;AACR,eAAOA,IAAIe,EAAM,KAAK,UAAQ;AAC1B,gBAAMe,IAAKf,EAAM,KAAKf,CAAC;AAEvB,UADiBA,MAAMe,EAAM,KAAK,SAAS,KAKvCc,EAAKC,CAAE,IAAID,EAAKC,CAAE,KAAK,EAAE,SAAS,CAAA,KAClCD,EAAKC,CAAE,EAAE,QAAQ,KAAKR,EAAOP,CAAK,CAAC,KAJnCc,EAAKC,CAAE,IAAID,EAAKC,CAAE,KAAK,EAAE,SAAS,CAAA,KAMtCD,IAAOA,EAAKC,CAAE,GACd9B;AAAA,QACH;AAAA,MACJ;AAAA,EAEb;AACI,SAAA4B,EAAaP,CAAK,GACXE;AACX;ACxEO,MAAMQ,KAAS,CAACC,MAAS,CAACnD,GAAQvD,GAAO2G,GAAMzD,MAAY;AAC9D,QAAMgC,IAAMyB,IAAO,OAAO,OAAOA,GAAM,EAAE,OAAO,GAAK,CAAE,IAAI,EAAE,OAAO,GAAK,GACnEC,IAASrD,EAAO,KAAK,IAAI,EAAE,OAAAvD,GAAO,QAAQ,CAAA,KAAMkF,CAAG;AACzD,MAAI0B,aAAkB;AAClB,UAAM,IAAIC,GAAmB;AAEjC,MAAID,EAAO,OAAO,QAAQ;AACtB,UAAME,IAAI,MAAK5D,KAAA,gBAAAA,EAAS,QAAOwD,GAAME,EAAO,OAAO,IAAI,CAAC9B,MAAQiC,GAAmBjC,GAAKI,GAAK8B,GAAW,CAAE,CAAC,CAAC;AAC5GC,UAAAA,GAAuBH,GAAG5D,KAAA,gBAAAA,EAAS,MAAM,GACnC4D;AAAA,EACT;AACD,SAAOF,EAAO;AAClB,GAEaM,KAAc,CAACR,MAAS,OAAOnD,GAAQvD,GAAO2G,GAAMhI,MAAW;AACxE,QAAMuG,IAAMyB,IAAO,OAAO,OAAOA,GAAM,EAAE,OAAO,GAAI,CAAE,IAAI,EAAE,OAAO,GAAI;AACvE,MAAIC,IAASrD,EAAO,KAAK,IAAI,EAAE,OAAAvD,GAAO,QAAQ,CAAA,KAAMkF,CAAG;AAGvD,MAFI0B,aAAkB,YAClBA,IAAS,MAAMA,IACfA,EAAO,OAAO,QAAQ;AACtB,UAAME,IAAI,MAAKnI,KAAA,gBAAAA,EAAQ,QAAO+H,GAAME,EAAO,OAAO,IAAI,CAAC9B,MAAQiC,GAAmBjC,GAAKI,GAAK8B,GAAW,CAAE,CAAC,CAAC;AAC3GC,UAAAA,GAAuBH,GAAGnI,KAAA,gBAAAA,EAAQ,MAAM,GAClCmI;AAAA,EACT;AACD,SAAOF,EAAO;AAClB,GAEaO,KAAa,CAACT,MAAS,CAACnD,GAAQvD,GAAO2G,MAAS;AACzD,QAAMzB,IAAMyB,IAAO,EAAE,GAAGA,GAAM,OAAO,OAAU,EAAE,OAAO,MAClDC,IAASrD,EAAO,KAAK,IAAI,EAAE,OAAAvD,GAAO,QAAQ,CAAA,KAAMkF,CAAG;AACzD,MAAI0B,aAAkB;AAClB,UAAM,IAAIC,GAAmB;AAEjC,SAAOD,EAAO,OAAO,SACf;AAAA,IACE,SAAS;AAAA,IACT,OAAO,KAAKF,KAAQU,IAAkBR,EAAO,OAAO,IAAI,CAAC9B,MAAQiC,GAAmBjC,GAAKI,GAAK8B,GAAW,CAAE,CAAC,CAAC;AAAA,EAChH,IACC,EAAE,SAAS,IAAM,MAAMJ,EAAO,MAAK;AAC7C,GACaS,KAA2B,gBAAAF,GAAWG,EAAoB,GAC1DC,KAAkB,CAACb,MAAS,OAAOnD,GAAQvD,GAAO2G,MAAS;AACpE,QAAMzB,IAAMyB,IAAO,OAAO,OAAOA,GAAM,EAAE,OAAO,GAAI,CAAE,IAAI,EAAE,OAAO,GAAI;AACvE,MAAIC,IAASrD,EAAO,KAAK,IAAI,EAAE,OAAAvD,GAAO,QAAQ,CAAA,KAAMkF,CAAG;AACvD,SAAI0B,aAAkB,YAClBA,IAAS,MAAMA,IACZA,EAAO,OAAO,SACf;AAAA,IACE,SAAS;AAAA,IACT,OAAO,IAAIF,EAAKE,EAAO,OAAO,IAAI,CAAC9B,MAAQiC,GAAmBjC,GAAKI,GAAK8B,GAAW,CAAE,CAAC,CAAC;AAAA,EAC1F,IACC,EAAE,SAAS,IAAM,MAAMJ,EAAO,MAAK;AAC7C,GACaY,KAAgC,gBAAAD,GAAgBD,EAAoB,GACpEG,KAAU,CAACf,MAAS,CAACnD,GAAQvD,GAAO2G,MAAS;AACtD,QAAMzB,IAAMyB,IAAO,OAAO,OAAOA,GAAM,EAAE,WAAW,WAAU,CAAE,IAAI,EAAE,WAAW,WAAU;AAC3F,SAAOF,GAAOC,CAAI,EAAEnD,GAAQvD,GAAOkF,CAAG;AAC1C,GAEawC,KAAU,CAAChB,MAAS,CAACnD,GAAQvD,GAAO2G,MACtCF,GAAOC,CAAI,EAAEnD,GAAQvD,GAAO2G,CAAI,GAG9BgB,KAAe,CAACjB,MAAS,OAAOnD,GAAQvD,GAAO2G,MAAS;AACjE,QAAMzB,IAAMyB,IAAO,OAAO,OAAOA,GAAM,EAAE,WAAW,WAAU,CAAE,IAAI,EAAE,WAAW,WAAU;AAC3F,SAAOO,GAAYR,CAAI,EAAEnD,GAAQvD,GAAOkF,CAAG;AAC/C,GAEa0C,KAAe,CAAClB,MAAS,OAAOnD,GAAQvD,GAAO2G,MACjDO,GAAYR,CAAI,EAAEnD,GAAQvD,GAAO2G,CAAI,GAGnCkB,KAAc,CAACnB,MAAS,CAACnD,GAAQvD,GAAO2G,MAAS;AAC1D,QAAMzB,IAAMyB,IAAO,OAAO,OAAOA,GAAM,EAAE,WAAW,WAAU,CAAE,IAAI,EAAE,WAAW,WAAU;AAC3F,SAAOQ,GAAWT,CAAI,EAAEnD,GAAQvD,GAAOkF,CAAG;AAC9C,GAEa4C,KAAc,CAACpB,MAAS,CAACnD,GAAQvD,GAAO2G,MAC1CQ,GAAWT,CAAI,EAAEnD,GAAQvD,GAAO2G,CAAI,GAGlCoB,KAAmB,CAACrB,MAAS,OAAOnD,GAAQvD,GAAO2G,MAAS;AACrE,QAAMzB,IAAMyB,IAAO,OAAO,OAAOA,GAAM,EAAE,WAAW,WAAU,CAAE,IAAI,EAAE,WAAW,WAAU;AAC3F,SAAOY,GAAgBb,CAAI,EAAEnD,GAAQvD,GAAOkF,CAAG;AACnD,GAEa8C,KAAmB,CAACtB,MAAS,OAAOnD,GAAQvD,GAAO2G,MACrDY,GAAgBb,CAAI,EAAEnD,GAAQvD,GAAO2G,CAAI,GC1FvCsB,KAAO,oBACPC,KAAQ,eACRC,KAAO,yCACPC,KAAM,qBACNC,KAAQ,qBACRC,KAAS,uBAETC,KAAW,iGAIXC,KAAO,mFAIPC,KAAO,CAACC,MACZA,IAEE,IAAI,OAAO,mCAAmCA,CAAO,yDAAyD,IAD1G,0KAOFC,KAAQ,oGAUfC,KAAS;AACR,SAASC,KAAQ;AACpB,SAAO,IAAI,OAAOD,IAAQ,GAAG;AACjC;AACO,MAAME,KAAO,uHACPC,KAAO,gGACPC,KAAS,4IACTC,KAAS,kIAETC,KAAS,+EACTC,KAAY,oBAGZC,KAAW,0HAGXC,KAAO,4BAEdC,KAAa,uNACNC,KAAqB,oBAAI,OAAO,IAAID,EAAU,GAAG;AAC9D,SAASE,GAAW9D,GAAM;AACtB,QAAM+D,IAAO;AAQb,SAPc,OAAO/D,EAAK,aAAc,WAClCA,EAAK,cAAc,KACf,GAAG+D,CAAI,KACP/D,EAAK,cAAc,IACf,GAAG+D,CAAI,cACP,GAAGA,CAAI,mBAAmB/D,EAAK,SAAS,MAChD,GAAG+D,CAAI;AAEjB;AACO,SAASC,GAAKhE,GAAM;AACvB,SAAO,IAAI,OAAO,IAAI8D,GAAW9D,CAAI,CAAC,GAAG;AAC7C;AAEO,SAASiE,GAASjE,GAAM;AAC3B,QAAMgE,IAAOF,GAAW,EAAE,WAAW9D,EAAK,UAAS,CAAE,GAC/CkE,IAAO,CAAC,GAAG;AACjB,EAAIlE,EAAK,SACLkE,EAAK,KAAK,EAAE,GAEZlE,EAAK,UACLkE,EAAK,KAAK,mCAAmC;AACjD,QAAMC,IAAY,GAAGH,CAAI,MAAME,EAAK,KAAK,GAAG,CAAC;AAC7C,SAAO,IAAI,OAAO,IAAIN,EAAU,OAAOO,CAAS,IAAI;AACxD;AACO,MAAMC,KAAS,CAACnL,MAAW;AAC9B,QAAMoL,IAAQpL,IAAS,aAAYA,KAAA,gBAAAA,EAAQ,YAAW,CAAC,KAAIA,KAAA,gBAAAA,EAAQ,YAAW,EAAE,MAAM;AACtF,SAAO,IAAI,OAAO,IAAIoL,CAAK,GAAG;AAClC,GAEaC,KAAU,SACVC,KAAS,qBACTC,KAAU,eAMVC,KAAY,aAEZC,KAAY,aC3FZC,IAA0BC,gBAAAA,EAAkB,aAAa,CAACzL,GAAMC,MAAQ;AACjF,MAAIC;AACJ,EAAAF,EAAK,SAASA,EAAK,OAAO,CAAE,IAC5BA,EAAK,KAAK,MAAMC,IACfC,IAAKF,EAAK,MAAM,aAAaE,EAAG,WAAW,CAAA;AAChD,CAAC,GACKwL,KAAmB;AAAA,EACrB,QAAQ;AAAA,EACR,QAAQ;AAAA,EACR,QAAQ;AACZ,GACaC,KAAkCF,gBAAAA,EAAkB,qBAAqB,CAACzL,GAAMC,MAAQ;AACjG,EAAAuL,EAAU,KAAKxL,GAAMC,CAAG;AACxB,QAAM2L,IAASF,GAAiB,OAAOzL,EAAI,KAAK;AAChD,EAAAD,EAAK,KAAK,SAAS,KAAK,CAACA,MAAS;AAC9B,UAAM6L,IAAM7L,EAAK,KAAK,KAChB0H,KAAQzH,EAAI,YAAY4L,EAAI,UAAUA,EAAI,qBAAqB,OAAO;AAC5E,IAAI5L,EAAI,QAAQyH,MACRzH,EAAI,YACJ4L,EAAI,UAAU5L,EAAI,QAElB4L,EAAI,mBAAmB5L,EAAI;AAAA,EAE3C,CAAK,GACDD,EAAK,KAAK,QAAQ,CAAC8L,MAAY;AAC3B,KAAI7L,EAAI,YAAY6L,EAAQ,SAAS7L,EAAI,QAAQ6L,EAAQ,QAAQ7L,EAAI,UAGrE6L,EAAQ,OAAO,KAAK;AAAA,MAChB,QAAAF;AAAA,MACA,MAAM;AAAA,MACN,SAAS3L,EAAI;AAAA,MACb,OAAO6L,EAAQ;AAAA,MACf,WAAW7L,EAAI;AAAA,MACf,MAAAD;AAAA,MACA,UAAU,CAACC,EAAI;AAAA,IAC3B,CAAS;AAAA,EACT;AACA,CAAC,GACY8L,KAAqCN,gBAAAA,EAAkB,wBAAwB,CAACzL,GAAMC,MAAQ;AACvG,EAAAuL,EAAU,KAAKxL,GAAMC,CAAG;AACxB,QAAM2L,IAASF,GAAiB,OAAOzL,EAAI,KAAK;AAChD,EAAAD,EAAK,KAAK,SAAS,KAAK,CAACA,MAAS;AAC9B,UAAM6L,IAAM7L,EAAK,KAAK,KAChB0H,KAAQzH,EAAI,YAAY4L,EAAI,UAAUA,EAAI,qBAAqB,OAAO;AAC5E,IAAI5L,EAAI,QAAQyH,MACRzH,EAAI,YACJ4L,EAAI,UAAU5L,EAAI,QAElB4L,EAAI,mBAAmB5L,EAAI;AAAA,EAE3C,CAAK,GACDD,EAAK,KAAK,QAAQ,CAAC8L,MAAY;AAC3B,KAAI7L,EAAI,YAAY6L,EAAQ,SAAS7L,EAAI,QAAQ6L,EAAQ,QAAQ7L,EAAI,UAGrE6L,EAAQ,OAAO,KAAK;AAAA,MAChB,QAAAF;AAAA,MACA,MAAM;AAAA,MACN,SAAS3L,EAAI;AAAA,MACb,OAAO6L,EAAQ;AAAA,MACf,WAAW7L,EAAI;AAAA,MACf,MAAAD;AAAA,MACA,UAAU,CAACC,EAAI;AAAA,IAC3B,CAAS;AAAA,EACT;AACA,CAAC,GACY+L,KACCP,gBAAAA,EAAkB,uBAAuB,CAACzL,GAAMC,MAAQ;AAClE,EAAAuL,EAAU,KAAKxL,GAAMC,CAAG,GACxBD,EAAK,KAAK,SAAS,KAAK,CAACA,MAAS;AAC9B,QAAIE;AACJ,KAACA,IAAKF,EAAK,KAAK,KAAK,eAAeE,EAAG,aAAaD,EAAI;AAAA,EAChE,CAAK,GACDD,EAAK,KAAK,QAAQ,CAAC8L,MAAY;AAC3B,QAAI,OAAOA,EAAQ,SAAU,OAAO7L,EAAI;AACpC,YAAM,IAAI,MAAM,oDAAoD;AAIxE,KAHmB,OAAO6L,EAAQ,SAAU,WACtCA,EAAQ,QAAQ7L,EAAI,UAAU,OAAO,CAAC,IACtCgM,GAAwBH,EAAQ,OAAO7L,EAAI,KAAK,MAAM,MAG5D6L,EAAQ,OAAO,KAAK;AAAA,MAChB,QAAQ,OAAOA,EAAQ;AAAA,MACvB,MAAM;AAAA,MACN,SAAS7L,EAAI;AAAA,MACb,OAAO6L,EAAQ;AAAA,MACf,MAAA9L;AAAA,MACA,UAAU,CAACC,EAAI;AAAA,IAC3B,CAAS;AAAA,EACT;AACA,CAAC,GACYiM,KAAsCT,gBAAAA,EAAkB,yBAAyB,CAACzL,GAAMC,MAAQ;AlChGjG,MAAAC;AkCiGR,EAAAsL,EAAU,KAAKxL,GAAMC,CAAG,GACxBA,EAAI,SAASA,EAAI,UAAU;AAC3B,QAAMkM,KAAQjM,IAAAD,EAAI,WAAJ,gBAAAC,EAAY,SAAS,QAC7B0L,IAASO,IAAQ,QAAQ,UACzB,CAACC,GAASC,CAAO,IAAIC,GAA0BrM,EAAI,MAAM;AAC/D,EAAAD,EAAK,KAAK,SAAS,KAAK,CAACA,MAAS;AAC9B,UAAM6L,IAAM7L,EAAK,KAAK;AACtB,IAAA6L,EAAI,SAAS5L,EAAI,QACjB4L,EAAI,UAAUO,GACdP,EAAI,UAAUQ,GACVF,MACAN,EAAI,UAAUU;AAAAA,EAC1B,CAAK,GACDvM,EAAK,KAAK,QAAQ,CAAC8L,MAAY;AAC3B,UAAMvK,IAAQuK,EAAQ;AACtB,QAAIK,GAAO;AACP,UAAI,CAAC,OAAO,UAAU5K,CAAK,GAAG;AAU1B,QAAAuK,EAAQ,OAAO,KAAK;AAAA,UAChB,UAAUF;AAAA,UACV,QAAQ3L,EAAI;AAAA,UACZ,MAAM;AAAA,UACN,UAAU;AAAA,UACV,OAAAsB;AAAA,UACA,MAAAvB;AAAA,QACpB,CAAiB;AACD;AAAA,MASH;AACD,UAAI,CAAC,OAAO,cAAcuB,CAAK,GAAG;AAC9B,QAAIA,IAAQ,IAERuK,EAAQ,OAAO,KAAK;AAAA,UAChB,OAAAvK;AAAA,UACA,MAAM;AAAA,UACN,SAAS,OAAO;AAAA,UAChB,MAAM;AAAA,UACN,MAAAvB;AAAA,UACA,QAAA4L;AAAA,UACA,UAAU,CAAC3L,EAAI;AAAA,QACvC,CAAqB,IAID6L,EAAQ,OAAO,KAAK;AAAA,UAChB,OAAAvK;AAAA,UACA,MAAM;AAAA,UACN,SAAS,OAAO;AAAA,UAChB,MAAM;AAAA,UACN,MAAAvB;AAAA,UACA,QAAA4L;AAAA,UACA,UAAU,CAAC3L,EAAI;AAAA,QACvC,CAAqB;AAEL;AAAA,MACH;AAAA,IACJ;AACD,IAAIsB,IAAQ6K,KACRN,EAAQ,OAAO,KAAK;AAAA,MAChB,QAAQ;AAAA,MACR,OAAAvK;AAAA,MACA,MAAM;AAAA,MACN,SAAA6K;AAAA,MACA,WAAW;AAAA,MACX,MAAApM;AAAA,MACA,UAAU,CAACC,EAAI;AAAA,IAC/B,CAAa,GAEDsB,IAAQ8K,KACRP,EAAQ,OAAO,KAAK;AAAA,MAChB,QAAQ;AAAA,MACR,OAAAvK;AAAA,MACA,MAAM;AAAA,MACN,SAAA8K;AAAA,MACA,MAAArM;AAAA,IAChB,CAAa;AAAA,EAEb;AACA,CAAC,GAwHYwM,KAAmCf,gBAAAA,EAAkB,sBAAsB,CAACzL,GAAMC,MAAQ;AACnG,MAAIC;AACJ,EAAAsL,EAAU,KAAKxL,GAAMC,CAAG,IACvBC,IAAKF,EAAK,KAAK,KAAK,SAASE,EAAG,OAAO,CAAC4L,MAAY;AACjD,UAAMjK,IAAMiK,EAAQ;AACpB,WAAO,CAACW,GAAa5K,CAAG,KAAKA,EAAI,WAAW;AAAA,EACpD,IACI7B,EAAK,KAAK,SAAS,KAAK,CAACA,MAAS;AAC9B,UAAM0H,IAAQ1H,EAAK,KAAK,IAAI,WAAW,OAAO;AAC9C,IAAIC,EAAI,UAAUyH,MACd1H,EAAK,KAAK,IAAI,UAAUC,EAAI;AAAA,EACxC,CAAK,GACDD,EAAK,KAAK,QAAQ,CAAC8L,MAAY;AAC3B,UAAMvK,IAAQuK,EAAQ;AAEtB,QADevK,EAAM,UACPtB,EAAI;AACd;AACJ,UAAM2L,IAASc,GAAyBnL,CAAK;AAC7C,IAAAuK,EAAQ,OAAO,KAAK;AAAA,MAChB,QAAAF;AAAA,MACA,MAAM;AAAA,MACN,SAAS3L,EAAI;AAAA,MACb,WAAW;AAAA,MACX,OAAAsB;AAAA,MACA,MAAAvB;AAAA,MACA,UAAU,CAACC,EAAI;AAAA,IAC3B,CAAS;AAAA,EACT;AACA,CAAC,GACY0M,KAAmClB,gBAAAA,EAAkB,sBAAsB,CAACzL,GAAMC,MAAQ;AACnG,MAAIC;AACJ,EAAAsL,EAAU,KAAKxL,GAAMC,CAAG,IACvBC,IAAKF,EAAK,KAAK,KAAK,SAASE,EAAG,OAAO,CAAC4L,MAAY;AACjD,UAAMjK,IAAMiK,EAAQ;AACpB,WAAO,CAACW,GAAa5K,CAAG,KAAKA,EAAI,WAAW;AAAA,EACpD,IACI7B,EAAK,KAAK,SAAS,KAAK,CAACA,MAAS;AAC9B,UAAM0H,IAAQ1H,EAAK,KAAK,IAAI,WAAW,OAAO;AAC9C,IAAIC,EAAI,UAAUyH,MACd1H,EAAK,KAAK,IAAI,UAAUC,EAAI;AAAA,EACxC,CAAK,GACDD,EAAK,KAAK,QAAQ,CAAC8L,MAAY;AAC3B,UAAMvK,IAAQuK,EAAQ;AAEtB,QADevK,EAAM,UACPtB,EAAI;AACd;AACJ,UAAM2L,IAASc,GAAyBnL,CAAK;AAC7C,IAAAuK,EAAQ,OAAO,KAAK;AAAA,MAChB,QAAAF;AAAA,MACA,MAAM;AAAA,MACN,SAAS3L,EAAI;AAAA,MACb,WAAW;AAAA,MACX,OAAAsB;AAAA,MACA,MAAAvB;AAAA,MACA,UAAU,CAACC,EAAI;AAAA,IAC3B,CAAS;AAAA,EACT;AACA,CAAC,GACY2M,KAAsCnB,gBAAAA,EAAkB,yBAAyB,CAACzL,GAAMC,MAAQ;AACzG,MAAIC;AACJ,EAAAsL,EAAU,KAAKxL,GAAMC,CAAG,IACvBC,IAAKF,EAAK,KAAK,KAAK,SAASE,EAAG,OAAO,CAAC4L,MAAY;AACjD,UAAMjK,IAAMiK,EAAQ;AACpB,WAAO,CAACW,GAAa5K,CAAG,KAAKA,EAAI,WAAW;AAAA,EACpD,IACI7B,EAAK,KAAK,SAAS,KAAK,CAACA,MAAS;AAC9B,UAAM6L,IAAM7L,EAAK,KAAK;AACtB,IAAA6L,EAAI,UAAU5L,EAAI,QAClB4L,EAAI,UAAU5L,EAAI,QAClB4L,EAAI,SAAS5L,EAAI;AAAA,EACzB,CAAK,GACDD,EAAK,KAAK,QAAQ,CAAC8L,MAAY;AAC3B,UAAMvK,IAAQuK,EAAQ,OAChBe,IAAStL,EAAM;AACrB,QAAIsL,MAAW5M,EAAI;AACf;AACJ,UAAM2L,IAASc,GAAyBnL,CAAK,GACvCuL,IAASD,IAAS5M,EAAI;AAC5B,IAAA6L,EAAQ,OAAO,KAAK;AAAA,MAChB,QAAAF;AAAA,MACA,GAAIkB,IAAS,EAAE,MAAM,WAAW,SAAS7M,EAAI,WAAW,EAAE,MAAM,aAAa,SAASA,EAAI,OAAM;AAAA,MAChG,WAAW;AAAA,MACX,OAAO;AAAA,MACP,OAAO6L,EAAQ;AAAA,MACf,MAAA9L;AAAA,MACA,UAAU,CAACC,EAAI;AAAA,IAC3B,CAAS;AAAA,EACT;AACA,CAAC,GACY8M,KAAsCtB,gBAAAA,EAAkB,yBAAyB,CAACzL,GAAMC,MAAQ;AACzG,MAAIC,GAAIM;AACR,EAAAgL,EAAU,KAAKxL,GAAMC,CAAG,GACxBD,EAAK,KAAK,SAAS,KAAK,CAACA,MAAS;AAC9B,UAAM6L,IAAM7L,EAAK,KAAK;AACtB,IAAA6L,EAAI,SAAS5L,EAAI,QACbA,EAAI,YACJ4L,EAAI,aAAaA,EAAI,WAAW,oBAAI,IAAK,IACzCA,EAAI,SAAS,IAAI5L,EAAI,OAAO;AAAA,EAExC,CAAK,GACGA,EAAI,WACHC,IAAKF,EAAK,MAAM,UAAUE,EAAG,QAAQ,CAAC4L,MAAY;AAE/C,IADA7L,EAAI,QAAQ,YAAY,GACpB,CAAAA,EAAI,QAAQ,KAAK6L,EAAQ,KAAK,KAElCA,EAAQ,OAAO,KAAK;AAAA,MAChB,QAAQ;AAAA,MACR,MAAM;AAAA,MACN,QAAQ7L,EAAI;AAAA,MACZ,OAAO6L,EAAQ;AAAA,MACf,GAAI7L,EAAI,UAAU,EAAE,SAASA,EAAI,QAAQ,WAAY,IAAG;MACxD,MAAAD;AAAA,MACA,UAAU,CAACC,EAAI;AAAA,IAC/B,CAAa;AAAA,EACb,MAESO,IAAKR,EAAK,MAAM,UAAUQ,EAAG,QAAQ,MAAM;AAAA,EAAA;AACpD,CAAC,GACYwM,KAA+BvB,gBAAAA,EAAkB,kBAAkB,CAACzL,GAAMC,MAAQ;AAC3F,EAAA8M,GAAsB,KAAK/M,GAAMC,CAAG,GACpCD,EAAK,KAAK,QAAQ,CAAC8L,MAAY;AAE3B,IADA7L,EAAI,QAAQ,YAAY,GACpB,CAAAA,EAAI,QAAQ,KAAK6L,EAAQ,KAAK,KAElCA,EAAQ,OAAO,KAAK;AAAA,MAChB,QAAQ;AAAA,MACR,MAAM;AAAA,MACN,QAAQ;AAAA,MACR,OAAOA,EAAQ;AAAA,MACf,SAAS7L,EAAI,QAAQ,SAAU;AAAA,MAC/B,MAAAD;AAAA,MACA,UAAU,CAACC,EAAI;AAAA,IAC3B,CAAS;AAAA,EACT;AACA,CAAC,GACYgN,KAAmCxB,gBAAAA,EAAkB,sBAAsB,CAACzL,GAAMC,MAAQ;AACnG,EAAAA,EAAI,YAAYA,EAAI,UAAUiN,KAC9BH,GAAsB,KAAK/M,GAAMC,CAAG;AACxC,CAAC,GACYkN,KAAmC1B,gBAAAA,EAAkB,sBAAsB,CAACzL,GAAMC,MAAQ;AACnG,EAAAA,EAAI,YAAYA,EAAI,UAAUmN,KAC9BL,GAAsB,KAAK/M,GAAMC,CAAG;AACxC,CAAC,GACYoN,KAAkC5B,gBAAAA,EAAkB,qBAAqB,CAACzL,GAAMC,MAAQ;AACjG,EAAAuL,EAAU,KAAKxL,GAAMC,CAAG;AACxB,QAAMqN,IAAeC,GAAiBtN,EAAI,QAAQ,GAC5CuN,IAAU,IAAI,OAAO,OAAOvN,EAAI,YAAa,WAAW,MAAMA,EAAI,QAAQ,IAAIqN,CAAY,KAAKA,CAAY;AACjH,EAAArN,EAAI,UAAUuN,GACdxN,EAAK,KAAK,SAAS,KAAK,CAACA,MAAS;AAC9B,UAAM6L,IAAM7L,EAAK,KAAK;AACtB,IAAA6L,EAAI,aAAaA,EAAI,WAAW,oBAAI,IAAK,IACzCA,EAAI,SAAS,IAAI2B,CAAO;AAAA,EAChC,CAAK,GACDxN,EAAK,KAAK,QAAQ,CAAC8L,MAAY;AAC3B,IAAIA,EAAQ,MAAM,SAAS7L,EAAI,UAAUA,EAAI,QAAQ,KAErD6L,EAAQ,OAAO,KAAK;AAAA,MAChB,QAAQ;AAAA,MACR,MAAM;AAAA,MACN,QAAQ;AAAA,MACR,UAAU7L,EAAI;AAAA,MACd,OAAO6L,EAAQ;AAAA,MACf,MAAA9L;AAAA,MACA,UAAU,CAACC,EAAI;AAAA,IAC3B,CAAS;AAAA,EACT;AACA,CAAC,GACYwN,KAAoChC,gBAAAA,EAAkB,uBAAuB,CAACzL,GAAMC,MAAQ;AACrG,EAAAuL,EAAU,KAAKxL,GAAMC,CAAG;AACxB,QAAMuN,IAAU,IAAI,OAAO,IAAID,GAAiBtN,EAAI,MAAM,CAAC,IAAI;AAC/D,EAAAA,EAAI,YAAYA,EAAI,UAAUuN,IAC9BxN,EAAK,KAAK,SAAS,KAAK,CAACA,MAAS;AAC9B,UAAM6L,IAAM7L,EAAK,KAAK;AACtB,IAAA6L,EAAI,aAAaA,EAAI,WAAW,oBAAI,IAAK,IACzCA,EAAI,SAAS,IAAI2B,CAAO;AAAA,EAChC,CAAK,GACDxN,EAAK,KAAK,QAAQ,CAAC8L,MAAY;AAC3B,IAAIA,EAAQ,MAAM,WAAW7L,EAAI,MAAM,KAEvC6L,EAAQ,OAAO,KAAK;AAAA,MAChB,QAAQ;AAAA,MACR,MAAM;AAAA,MACN,QAAQ;AAAA,MACR,QAAQ7L,EAAI;AAAA,MACZ,OAAO6L,EAAQ;AAAA,MACf,MAAA9L;AAAA,MACA,UAAU,CAACC,EAAI;AAAA,IAC3B,CAAS;AAAA,EACT;AACA,CAAC,GACYyN,KAAkCjC,gBAAAA,EAAkB,qBAAqB,CAACzL,GAAMC,MAAQ;AACjG,EAAAuL,EAAU,KAAKxL,GAAMC,CAAG;AACxB,QAAMuN,IAAU,IAAI,OAAO,KAAKD,GAAiBtN,EAAI,MAAM,CAAC,GAAG;AAC/D,EAAAA,EAAI,YAAYA,EAAI,UAAUuN,IAC9BxN,EAAK,KAAK,SAAS,KAAK,CAACA,MAAS;AAC9B,UAAM6L,IAAM7L,EAAK,KAAK;AACtB,IAAA6L,EAAI,aAAaA,EAAI,WAAW,oBAAI,IAAK,IACzCA,EAAI,SAAS,IAAI2B,CAAO;AAAA,EAChC,CAAK,GACDxN,EAAK,KAAK,QAAQ,CAAC8L,MAAY;AAC3B,IAAIA,EAAQ,MAAM,SAAS7L,EAAI,MAAM,KAErC6L,EAAQ,OAAO,KAAK;AAAA,MAChB,QAAQ;AAAA,MACR,MAAM;AAAA,MACN,QAAQ;AAAA,MACR,QAAQ7L,EAAI;AAAA,MACZ,OAAO6L,EAAQ;AAAA,MACf,MAAA9L;AAAA,MACA,UAAU,CAACC,EAAI;AAAA,IAC3B,CAAS;AAAA,EACT;AACA,CAAC,GAyCY0N,KAAmClC,gBAAAA,EAAkB,sBAAsB,CAACzL,GAAMC,MAAQ;AACnG,EAAAuL,EAAU,KAAKxL,GAAMC,CAAG,GACxBD,EAAK,KAAK,QAAQ,CAAC8L,MAAY;AAC3B,IAAAA,EAAQ,QAAQ7L,EAAI,GAAG6L,EAAQ,KAAK;AAAA,EAC5C;AACA,CAAC;ACxjBM,MAAM8B,GAAI;AAAA,EACb,YAAY/G,IAAO,IAAI;AACnB,SAAK,UAAU,IACf,KAAK,SAAS,GACV,SACA,KAAK,OAAOA;AAAA,EACnB;AAAA,EACD,SAAStG,GAAI;AACT,SAAK,UAAU,GACfA,EAAG,IAAI,GACP,KAAK,UAAU;AAAA,EAClB;AAAA,EACD,MAAMsN,GAAK;AACP,QAAI,OAAOA,KAAQ,YAAY;AAC3B,MAAAA,EAAI,MAAM,EAAE,WAAW,OAAQ,CAAA,GAC/BA,EAAI,MAAM,EAAE,WAAW,QAAS,CAAA;AAChC;AAAA,IACH;AAED,UAAMC,IADUD,EACM,MAAM;AAAA,CAAI,EAAE,OAAO,CAAClI,MAAMA,CAAC,GAC3CoI,IAAY,KAAK,IAAI,GAAGD,EAAM,IAAI,CAACnI,MAAMA,EAAE,SAASA,EAAE,UAAS,EAAG,MAAM,CAAC,GACzEqI,IAAWF,EAAM,IAAI,CAACnI,MAAMA,EAAE,MAAMoI,CAAS,CAAC,EAAE,IAAI,CAACpI,MAAM,IAAI,OAAO,KAAK,SAAS,CAAC,IAAIA,CAAC;AAChG,eAAWsI,KAAQD;AACf,WAAK,QAAQ,KAAKC,CAAI;AAAA,EAE7B;AAAA,EACD,UAAU;AACN,UAAMvK,IAAI,UACJmD,IAAO,6BAAM,MAEbiH,IAAQ,CAAC,KADC,6BAAM,YAAW,CAAC,EAAE,GACV,IAAI,CAACnI,MAAM,KAAKA,CAAC,EAAE,CAAC;AAE9C,WAAO,IAAIjC,EAAE,GAAGmD,GAAMiH,EAAM,KAAK;AAAA,CAAI,CAAC;AAAA,EACzC;AACL;AClCO,MAAMjE,KAAU;AAAA,EACnB,OAAO;AAAA,EACP,OAAO;AAAA,EACP,OAAO;AACX,GCGaqE,IAAyBzC,gBAAAA,EAAkB,YAAY,CAACzL,GAAMC,MAAQ;ArCPvE,MAAAC;AqCQR,MAAIA;AACJ,EAAAF,MAASA,IAAO,CAAA,IAChBA,EAAK,KAAK,MAAMC,GAChBD,EAAK,KAAK,MAAMA,EAAK,KAAK,OAAO,IACjCA,EAAK,KAAK,UAAU6J;AACpB,QAAM7E,IAAS,CAAC,GAAIhF,EAAK,KAAK,IAAI,UAAU,CAAE,CAAC;AAE/C,EAAIA,EAAK,KAAK,OAAO,IAAI,WAAW,KAChCgF,EAAO,QAAQhF,CAAI;AAEvB,aAAWmO,KAAMnJ;AACb,eAAWzE,KAAM4N,EAAG,KAAK;AACrB,MAAA5N,EAAGP,CAAI;AAGf,MAAIgF,EAAO,WAAW;AAGlB,KAAC9E,IAAKF,EAAK,MAAM,aAAaE,EAAG,WAAW,CAAA,KAC5CA,IAAAF,EAAK,KAAK,aAAV,QAAAE,EAAoB,KAAK,MAAM;AAC3B,MAAAF,EAAK,KAAK,MAAMA,EAAK,KAAK;AAAA,IACtC;AAAA,OAES;AACD,UAAMoO,IAAY,CAACtC,GAAS9G,GAAQqB,MAAQ;AACxC,UAAIgI,IAAYC,GAAaxC,CAAO,GAChCyC;AACJ,iBAAWJ,KAAMnJ,GAAQ;AACrB,YAAImJ,EAAG,KAAK,IAAI;AAEZ,cAAI,CADcA,EAAG,KAAK,IAAI,KAAKrC,CAAO;AAEtC;AAAA,mBAECuC;AACL;AAEJ,cAAMG,IAAU1C,EAAQ,OAAO,QACzB1L,IAAI+N,EAAG,KAAK,MAAMrC,CAAO;AAC/B,YAAI1L,aAAa,YAAWiG,KAAA,gBAAAA,EAAK,WAAU;AACvC,gBAAM,IAAI2B,GAAmB;AAEjC,YAAIuG,KAAenO,aAAa;AAC5B,UAAAmO,KAAeA,KAAe,QAAQ,QAAS,GAAE,KAAK,YAAY;AAG9D,YAFA,MAAMnO,GACU0L,EAAQ,OAAO,WACf0C,MAEXH,MACDA,IAAYC,GAAaxC,GAAS0C,CAAO;AAAA,UACrE,CAAqB;AAAA,aAEA;AAED,cADgB1C,EAAQ,OAAO,WACf0C;AACZ;AACJ,UAAKH,MACDA,IAAYC,GAAaxC,GAAS0C,CAAO;AAAA,QAChD;AAAA,MACJ;AACD,aAAID,IACOA,EAAY,KAAK,MACbzC,CACV,IAEEA;AAAA,IACnB,GAWc2C,IAAqB,CAACC,GAAQ5C,GAASzF,MAAQ;AAEjD,UAAIiI,GAAaI,CAAM;AACnB,eAAAA,EAAO,UAAU,IACVA;AAGX,YAAMC,IAAcP,EAAUtC,GAAS9G,GAAQqB,CAAG;AAClD,UAAIsI,aAAuB,SAAS;AAChC,YAAItI,EAAI,UAAU;AACd,gBAAM,IAAI2B,GAAmB;AACjC,eAAO2G,EAAY,KAAK,CAACA,MAAgB3O,EAAK,KAAK,MAAM2O,GAAatI,CAAG,CAAC;AAAA,MAC7E;AACD,aAAOrG,EAAK,KAAK,MAAM2O,GAAatI,CAAG;AAAA,IACnD;AACQ,IAAArG,EAAK,KAAK,MAAM,CAAC8L,GAASzF,MAAQ;AAC9B,UAAIA,EAAI;AACJ,eAAOrG,EAAK,KAAK,MAAM8L,GAASzF,CAAG;AAEvC,UAAIA,EAAI,cAAc,YAAY;AAG9B,cAAMqI,IAAS1O,EAAK,KAAK,MAAM,EAAE,OAAO8L,EAAQ,OAAO,QAAQ,CAAA,EAAI,GAAE,EAAE,GAAGzF,GAAK,YAAY,GAAI,CAAE;AACjG,eAAIqI,aAAkB,UACXA,EAAO,KAAK,CAACA,MACTD,EAAmBC,GAAQ5C,GAASzF,CAAG,CACjD,IAEEoI,EAAmBC,GAAQ5C,GAASzF,CAAG;AAAA,MACjD;AAED,YAAM0B,IAAS/H,EAAK,KAAK,MAAM8L,GAASzF,CAAG;AAC3C,UAAI0B,aAAkB,SAAS;AAC3B,YAAI1B,EAAI,UAAU;AACd,gBAAM,IAAI2B,GAAmB;AACjC,eAAOD,EAAO,KAAK,CAACA,MAAWqG,EAAUrG,GAAQ/C,GAAQqB,CAAG,CAAC;AAAA,MAChE;AACD,aAAO+H,EAAUrG,GAAQ/C,GAAQqB,CAAG;AAAA,IAChD;AAAA,EACK;AACD,EAAArG,EAAK,WAAW,IAAI;AAAA,IAChB,UAAU,CAACmB,MAAU;ArC7HjB,UAAAjB;AqC8HA,UAAI;AACA,cAAM0O,IAAIpG,GAAUxI,GAAMmB,CAAK;AAC/B,eAAOyN,EAAE,UAAU,EAAE,OAAOA,EAAE,SAAS,EAAE,SAAQ1O,IAAA0O,EAAE,UAAF,gBAAA1O,EAAS,OAAM;AAAA,MACnE,QACS;AACN,eAAOyI,GAAe3I,GAAMmB,CAAK,EAAE,KAAK,CAACyN,MAAC;ArCnI9C,cAAA1O;AqCmIoD,iBAAA0O,EAAE,UAAU,EAAE,OAAOA,EAAE,KAAM,IAAG,EAAE,SAAQ1O,IAAA0O,EAAE,UAAF,gBAAA1O,EAAS,OAAQ;AAAA,SAAC;AAAA,MAC/G;AAAA,IACJ;AAAA,IACD,QAAQ;AAAA,IACR,SAAS;AAAA,EACjB;AACA,CAAC,GAEY2O,KAA2BpD,gBAAAA,EAAkB,cAAc,CAACzL,GAAMC,MAAQ;ArC3I3E,MAAAC;AqC4IR,EAAAgO,EAAS,KAAKlO,GAAMC,CAAG,GACvBD,EAAK,KAAK,UAAU,CAAC,KAAIE,IAAAF,KAAA,gBAAAA,EAAM,KAAK,QAAX,gBAAAE,EAAgB,aAAY,CAAA,CAAG,EAAE,SAAS4O,GAAe9O,EAAK,KAAK,GAAG,GAC/FA,EAAK,KAAK,QAAQ,CAAC8L,GAAS1L,MAAM;AAC9B,QAAIH,EAAI;AACJ,UAAI;AACA,QAAA6L,EAAQ,QAAQ,OAAOA,EAAQ,KAAK;AAAA,MACvC,QACS;AAAA,MAAG;AACjB,WAAI,OAAOA,EAAQ,SAAU,YAE7BA,EAAQ,OAAO,KAAK;AAAA,MAChB,UAAU;AAAA,MACV,MAAM;AAAA,MACN,OAAOA,EAAQ;AAAA,MACf,MAAA9L;AAAA,IACZ,CAAS,GACM8L;AAAA,EACf;AACA,CAAC,GACYiD,IAAiCtD,gBAAAA,EAAkB,oBAAoB,CAACzL,GAAMC,MAAQ;AAE/F+O,EAAAA,GAA6B,KAAKhP,GAAMC,CAAG,GAC3C4O,GAAW,KAAK7O,GAAMC,CAAG;AAC7B,CAAC,GACYgP,KAAyBxD,gBAAAA,EAAkB,YAAY,CAACzL,GAAMC,MAAQ;AAC/E,EAAAA,EAAI,YAAYA,EAAI,UAAUiP,KAC9BH,EAAiB,KAAK/O,GAAMC,CAAG;AACnC,CAAC,GACYkP,KAAyB1D,gBAAAA,EAAkB,YAAY,CAACzL,GAAMC,MAAQ;AAC/E,MAAIA,EAAI,SAAS;AAWb,UAAMgB,IAVa;AAAA,MACf,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,IAChB,EAC6BhB,EAAI,OAAO;AAChC,QAAIgB,MAAM;AACN,YAAM,IAAI,MAAM,0BAA0BhB,EAAI,OAAO,GAAG;AAC5D,IAAAA,EAAI,YAAYA,EAAI,UAAUmP,GAAanO,CAAC;AAAA,EAC/C;AAEG,IAAAhB,EAAI,YAAYA,EAAI,UAAUmP,GAAc;AAChD,EAAAL,EAAiB,KAAK/O,GAAMC,CAAG;AACnC,CAAC,GACYoP,KAA0B5D,gBAAAA,EAAkB,aAAa,CAACzL,GAAMC,MAAQ;AACjF,EAAAA,EAAI,YAAYA,EAAI,UAAUqP,KAC9BP,EAAiB,KAAK/O,GAAMC,CAAG;AACnC,CAAC,GACYsP,KAAwB9D,gBAAAA,EAAkB,WAAW,CAACzL,GAAMC,MAAQ;AAC7E,EAAA8O,EAAiB,KAAK/O,GAAMC,CAAG,GAC/BD,EAAK,KAAK,QAAQ,CAAC8L,MAAY;AAC3B,QAAI;AAEA,YAAM0D,IAAU1D,EAAQ,MAAM,KAAI,GAE5B2D,IAAM,IAAI,IAAID,CAAO;AAC3B,MAAIvP,EAAI,aACJA,EAAI,SAAS,YAAY,GACpBA,EAAI,SAAS,KAAKwP,EAAI,QAAQ,KAC/B3D,EAAQ,OAAO,KAAK;AAAA,QAChB,MAAM;AAAA,QACN,QAAQ;AAAA,QACR,MAAM;AAAA,QACN,SAAS4D,GAAiB;AAAA,QAC1B,OAAO5D,EAAQ;AAAA,QACf,MAAA9L;AAAA,QACA,UAAU,CAACC,EAAI;AAAA,MACvC,CAAqB,IAGLA,EAAI,aACJA,EAAI,SAAS,YAAY,GACpBA,EAAI,SAAS,KAAKwP,EAAI,SAAS,SAAS,GAAG,IAAIA,EAAI,SAAS,MAAM,GAAG,EAAE,IAAIA,EAAI,QAAQ,KACxF3D,EAAQ,OAAO,KAAK;AAAA,QAChB,MAAM;AAAA,QACN,QAAQ;AAAA,QACR,MAAM;AAAA,QACN,SAAS7L,EAAI,SAAS;AAAA,QACtB,OAAO6L,EAAQ;AAAA,QACf,MAAA9L;AAAA,QACA,UAAU,CAACC,EAAI;AAAA,MACvC,CAAqB,IAILA,EAAI,YAEJ6L,EAAQ,QAAQ2D,EAAI,OAIpB3D,EAAQ,QAAQ0D;AAEpB;AAAA,IACH,QACS;AACN,MAAA1D,EAAQ,OAAO,KAAK;AAAA,QAChB,MAAM;AAAA,QACN,QAAQ;AAAA,QACR,OAAOA,EAAQ;AAAA,QACf,MAAA9L;AAAA,QACA,UAAU,CAACC,EAAI;AAAA,MAC/B,CAAa;AAAA,IACJ;AAAA,EACT;AACA,CAAC,GACY0P,KAA0BlE,gBAAAA,EAAkB,aAAa,CAACzL,GAAMC,MAAQ;AACjF,EAAAA,EAAI,YAAYA,EAAI,UAAU2P,GAAe,IAC7Cb,EAAiB,KAAK/O,GAAMC,CAAG;AACnC,CAAC,GACY4P,KAA2BpE,gBAAAA,EAAkB,cAAc,CAACzL,GAAMC,MAAQ;AACnF,EAAAA,EAAI,YAAYA,EAAI,UAAU6P,KAC9Bf,EAAiB,KAAK/O,GAAMC,CAAG;AACnC,CAAC,GACY8P,KAAyBtE,gBAAAA,EAAkB,YAAY,CAACzL,GAAMC,MAAQ;AAC/E,EAAAA,EAAI,YAAYA,EAAI,UAAU+P,KAC9BjB,EAAiB,KAAK/O,GAAMC,CAAG;AACnC,CAAC,GACYgQ,KAA0BxE,gBAAAA,EAAkB,aAAa,CAACzL,GAAMC,MAAQ;AACjF,EAAAA,EAAI,YAAYA,EAAI,UAAUiQ,KAC9BnB,EAAiB,KAAK/O,GAAMC,CAAG;AACnC,CAAC,GACYkQ,KAAyB1E,gBAAAA,EAAkB,YAAY,CAACzL,GAAMC,MAAQ;AAC/E,EAAAA,EAAI,YAAYA,EAAI,UAAUmQ,KAC9BrB,EAAiB,KAAK/O,GAAMC,CAAG;AACnC,CAAC,GACYoQ,KAAwB5E,gBAAAA,EAAkB,WAAW,CAACzL,GAAMC,MAAQ;AAC7E,EAAAA,EAAI,YAAYA,EAAI,UAAUqQ,KAC9BvB,EAAiB,KAAK/O,GAAMC,CAAG;AACnC,CAAC,GACYsQ,KAA0B9E,gBAAAA,EAAkB,aAAa,CAACzL,GAAMC,MAAQ;AACjF,EAAAA,EAAI,YAAYA,EAAI,UAAUuQ,KAC9BzB,EAAiB,KAAK/O,GAAMC,CAAG;AACnC,CAAC,GACYwQ,KAAgChF,gBAAAA,EAAkB,mBAAmB,CAACzL,GAAMC,MAAQ;AAC7F,EAAAA,EAAI,YAAYA,EAAI,UAAUyQ,GAAiBzQ,CAAG,IAClD8O,EAAiB,KAAK/O,GAAMC,CAAG;AACnC,CAAC,GACY0Q,KAA4BlF,gBAAAA,EAAkB,eAAe,CAACzL,GAAMC,MAAQ;AACrF,EAAAA,EAAI,YAAYA,EAAI,UAAU2Q,KAC9B7B,EAAiB,KAAK/O,GAAMC,CAAG;AACnC,CAAC,GACY4Q,KAA4BpF,gBAAAA,EAAkB,eAAe,CAACzL,GAAMC,MAAQ;AACrF,EAAAA,EAAI,YAAYA,EAAI,UAAU6Q,GAAa7Q,CAAG,IAC9C8O,EAAiB,KAAK/O,GAAMC,CAAG;AACnC,CAAC,GACY8Q,KAAgCtF,gBAAAA,EAAkB,mBAAmB,CAACzL,GAAMC,MAAQ;AAC7F,EAAAA,EAAI,YAAYA,EAAI,UAAU+Q,KAC9BjC,EAAiB,KAAK/O,GAAMC,CAAG;AACnC,CAAC,GACYgR,KAAyBxF,gBAAAA,EAAkB,YAAY,CAACzL,GAAMC,MAAQ;AAC/E,EAAAA,EAAI,YAAYA,EAAI,UAAUiR,KAC9BnC,EAAiB,KAAK/O,GAAMC,CAAG,GAC/BD,EAAK,KAAK,SAAS,KAAK,CAACA,MAAS;AAC9B,UAAM6L,IAAM7L,EAAK,KAAK;AACtB,IAAA6L,EAAI,SAAS;AAAA,EACrB,CAAK;AACL,CAAC,GACYsF,KAAyB1F,gBAAAA,EAAkB,YAAY,CAACzL,GAAMC,MAAQ;AAC/E,EAAAA,EAAI,YAAYA,EAAI,UAAUmR,KAC9BrC,EAAiB,KAAK/O,GAAMC,CAAG,GAC/BD,EAAK,KAAK,SAAS,KAAK,CAACA,MAAS;AAC9B,UAAM6L,IAAM7L,EAAK,KAAK;AACtB,IAAA6L,EAAI,SAAS;AAAA,EACrB,CAAK,GACD7L,EAAK,KAAK,QAAQ,CAAC8L,MAAY;AAC3B,QAAI;AAEA,UAAI,IAAI,WAAWA,EAAQ,KAAK,GAAG;AAAA,IAEtC,QACK;AACF,MAAAA,EAAQ,OAAO,KAAK;AAAA,QAChB,MAAM;AAAA,QACN,QAAQ;AAAA,QACR,OAAOA,EAAQ;AAAA,QACf,MAAA9L;AAAA,QACA,UAAU,CAACC,EAAI;AAAA,MAC/B,CAAa;AAAA,IACJ;AAAA,EACT;AACA,CAAC,GACYoR,KAA2B5F,gBAAAA,EAAkB,cAAc,CAACzL,GAAMC,MAAQ;AACnF,EAAAA,EAAI,YAAYA,EAAI,UAAUqR,KAC9BvC,EAAiB,KAAK/O,GAAMC,CAAG;AACnC,CAAC,GACYsR,KAA2B9F,gBAAAA,EAAkB,cAAc,CAACzL,GAAMC,MAAQ;AACnF,EAAAA,EAAI,YAAYA,EAAI,UAAUuR,KAC9BzC,EAAiB,KAAK/O,GAAMC,CAAG,GAC/BD,EAAK,KAAK,QAAQ,CAAC8L,MAAY;AAC3B,UAAM,CAAC2F,GAASC,CAAM,IAAI5F,EAAQ,MAAM,MAAM,GAAG;AACjD,QAAI;AACA,UAAI,CAAC4F;AACD,cAAM,IAAI,MAAK;AACnB,YAAMC,IAAY,OAAOD,CAAM;AAC/B,UAAI,GAAGC,CAAS,OAAOD;AACnB,cAAM,IAAI,MAAK;AACnB,UAAIC,IAAY,KAAKA,IAAY;AAC7B,cAAM,IAAI,MAAK;AAEnB,UAAI,IAAI,WAAWF,CAAO,GAAG;AAAA,IAChC,QACK;AACF,MAAA3F,EAAQ,OAAO,KAAK;AAAA,QAChB,MAAM;AAAA,QACN,QAAQ;AAAA,QACR,OAAOA,EAAQ;AAAA,QACf,MAAA9L;AAAA,QACA,UAAU,CAACC,EAAI;AAAA,MAC/B,CAAa;AAAA,IACJ;AAAA,EACT;AACA,CAAC;AAEM,SAAS2R,GAAcpO,GAAM;AAChC,MAAIA,MAAS;AACT,WAAO;AACX,MAAIA,EAAK,SAAS,MAAM;AACpB,WAAO;AACX,MAAI;AAEA,gBAAKA,CAAI,GACF;AAAA,EACV,QACK;AACF,WAAO;AAAA,EACV;AACL;AACO,MAAMqO,KAA2BpG,gBAAAA,EAAkB,cAAc,CAACzL,GAAMC,MAAQ;AACnF,EAAAA,EAAI,YAAYA,EAAI,UAAU6R,KAC9B/C,EAAiB,KAAK/O,GAAMC,CAAG,GAC/BD,EAAK,KAAK,SAAS,KAAK,CAACA,MAAS;AAC9B,IAAAA,EAAK,KAAK,IAAI,kBAAkB;AAAA,EACxC,CAAK,GACDA,EAAK,KAAK,QAAQ,CAAC8L,MAAY;AAC3B,IAAI8F,GAAc9F,EAAQ,KAAK,KAE/BA,EAAQ,OAAO,KAAK;AAAA,MAChB,MAAM;AAAA,MACN,QAAQ;AAAA,MACR,OAAOA,EAAQ;AAAA,MACf,MAAA9L;AAAA,MACA,UAAU,CAACC,EAAI;AAAA,IAC3B,CAAS;AAAA,EACT;AACA,CAAC;AAEM,SAAS8R,GAAiBvO,GAAM;AACnC,MAAI,CAACwO,GAAkB,KAAKxO,CAAI;AAC5B,WAAO;AACX,QAAM6G,IAAS7G,EAAK,QAAQ,SAAS,CAACyO,MAAOA,MAAM,MAAM,MAAM,GAAI,GAC7DC,IAAS7H,EAAO,OAAO,KAAK,KAAKA,EAAO,SAAS,CAAC,IAAI,GAAG,GAAG;AAClE,SAAOuH,GAAcM,CAAM;AAC/B;AACO,MAAMC,KAA8B1G,gBAAAA,EAAkB,iBAAiB,CAACzL,GAAMC,MAAQ;AACzF,EAAAA,EAAI,YAAYA,EAAI,UAAU+R,KAC9BjD,EAAiB,KAAK/O,GAAMC,CAAG,GAC/BD,EAAK,KAAK,SAAS,KAAK,CAACA,MAAS;AAC9B,IAAAA,EAAK,KAAK,IAAI,kBAAkB;AAAA,EACxC,CAAK,GACDA,EAAK,KAAK,QAAQ,CAAC8L,MAAY;AAC3B,IAAIiG,GAAiBjG,EAAQ,KAAK,KAElCA,EAAQ,OAAO,KAAK;AAAA,MAChB,MAAM;AAAA,MACN,QAAQ;AAAA,MACR,OAAOA,EAAQ;AAAA,MACf,MAAA9L;AAAA,MACA,UAAU,CAACC,EAAI;AAAA,IAC3B,CAAS;AAAA,EACT;AACA,CAAC,GACYmS,KAAyB3G,gBAAAA,EAAkB,YAAY,CAACzL,GAAMC,MAAQ;AAC/E,EAAAA,EAAI,YAAYA,EAAI,UAAUoS,KAC9BtD,EAAiB,KAAK/O,GAAMC,CAAG;AACnC,CAAC;AAEM,SAASqS,GAAWC,GAAOC,IAAY,MAAM;AAChD,MAAI;AACA,UAAMC,IAAcF,EAAM,MAAM,GAAG;AACnC,QAAIE,EAAY,WAAW;AACvB,aAAO;AACX,UAAM,CAACC,CAAM,IAAID;AACjB,QAAI,CAACC;AACD,aAAO;AAEX,UAAMC,IAAe,KAAK,MAAM,KAAKD,CAAM,CAAC;AAK5C,WAJI,WAASC,MAAgBA,KAAA,gBAAAA,EAAc,SAAQ,SAE/C,CAACA,EAAa,OAEdH,MAAc,EAAE,SAASG,MAAiBA,EAAa,QAAQH;AAAA,EAGtE,QACK;AACF,WAAO;AAAA,EACV;AACL;AACO,MAAMI,KAAwBnH,gBAAAA,EAAkB,WAAW,CAACzL,GAAMC,MAAQ;AAC7E,EAAA8O,EAAiB,KAAK/O,GAAMC,CAAG,GAC/BD,EAAK,KAAK,QAAQ,CAAC8L,MAAY;AAC3B,IAAIwG,GAAWxG,EAAQ,OAAO7L,EAAI,GAAG,KAErC6L,EAAQ,OAAO,KAAK;AAAA,MAChB,MAAM;AAAA,MACN,QAAQ;AAAA,MACR,OAAOA,EAAQ;AAAA,MACf,MAAA9L;AAAA,MACA,UAAU,CAACC,EAAI;AAAA,IAC3B,CAAS;AAAA,EACT;AACA,CAAC,GAeY4S,KAA2BpH,gBAAAA,EAAkB,cAAc,CAACzL,GAAMC,MAAQ;AACnF,EAAAiO,EAAS,KAAKlO,GAAMC,CAAG,GACvBD,EAAK,KAAK,UAAUA,EAAK,KAAK,IAAI,WAAW8S,IAC7C9S,EAAK,KAAK,QAAQ,CAAC8L,GAAShE,MAAS;AACjC,QAAI7H,EAAI;AACJ,UAAI;AACA,QAAA6L,EAAQ,QAAQ,OAAOA,EAAQ,KAAK;AAAA,MACvC,QACS;AAAA,MAAG;AACjB,UAAMvK,IAAQuK,EAAQ;AACtB,QAAI,OAAOvK,KAAU,YAAY,CAAC,OAAO,MAAMA,CAAK,KAAK,OAAO,SAASA,CAAK;AAC1E,aAAOuK;AAEX,UAAMiH,IAAW,OAAOxR,KAAU,WAC5B,OAAO,MAAMA,CAAK,IACd,QACC,OAAO,SAASA,CAAK,IAElB,SADA,aAER;AACN,WAAAuK,EAAQ,OAAO,KAAK;AAAA,MAChB,UAAU;AAAA,MACV,MAAM;AAAA,MACN,OAAAvK;AAAA,MACA,MAAAvB;AAAA,MACA,GAAI+S,IAAW,EAAE,UAAAA,EAAU,IAAG;IAC1C,CAAS,GACMjH;AAAA,EACf;AACA,CAAC,GACYkH,KAAiCvH,gBAAAA,EAAkB,cAAc,CAACzL,GAAMC,MAAQ;AACzFgT,EAAAA,GAA6B,KAAKjT,GAAMC,CAAG,GAC3C4S,GAAW,KAAK7S,GAAMC,CAAG;AAC7B,CAAC,GACYiT,KAA4BzH,gBAAAA,EAAkB,eAAe,CAACzL,GAAMC,MAAQ;AACrF,EAAAiO,EAAS,KAAKlO,GAAMC,CAAG,GACvBD,EAAK,KAAK,UAAUmT,IACpBnT,EAAK,KAAK,QAAQ,CAAC8L,GAAShE,MAAS;AACjC,QAAI7H,EAAI;AACJ,UAAI;AACA,QAAA6L,EAAQ,QAAQ,EAAQA,EAAQ;AAAA,MACnC,QACS;AAAA,MAAG;AACjB,UAAMvK,IAAQuK,EAAQ;AACtB,WAAI,OAAOvK,KAAU,aAErBuK,EAAQ,OAAO,KAAK;AAAA,MAChB,UAAU;AAAA,MACV,MAAM;AAAA,MACN,OAAAvK;AAAA,MACA,MAAAvB;AAAA,IACZ,CAAS,GACM8L;AAAA,EACf;AACA,CAAC,GAgFYsH,KAA4B3H,gBAAAA,EAAkB,eAAe,CAACzL,GAAMC,MAAQ;AACrF,EAAAiO,EAAS,KAAKlO,GAAMC,CAAG,GACvBD,EAAK,KAAK,QAAQ,CAAC8L,MAAYA;AACnC,CAAC,GACYuH,KAA0B5H,gBAAAA,EAAkB,aAAa,CAACzL,GAAMC,MAAQ;AACjF,EAAAiO,EAAS,KAAKlO,GAAMC,CAAG,GACvBD,EAAK,KAAK,QAAQ,CAAC8L,GAAShE,OACxBgE,EAAQ,OAAO,KAAK;AAAA,IAChB,UAAU;AAAA,IACV,MAAM;AAAA,IACN,OAAOA,EAAQ;AAAA,IACf,MAAA9L;AAAA,EACZ,CAAS,GACM8L;AAEf,CAAC,GAgBYwH,KAAyB7H,gBAAAA,EAAkB,YAAY,CAACzL,GAAMC,MAAQ;AAC/E,EAAAiO,EAAS,KAAKlO,GAAMC,CAAG,GACvBD,EAAK,KAAK,QAAQ,CAAC8L,GAAShE,MAAS;AACjC,QAAI7H,EAAI;AACJ,UAAI;AACA,QAAA6L,EAAQ,QAAQ,IAAI,KAAKA,EAAQ,KAAK;AAAA,MACzC,QACY;AAAA,MAAG;AAEpB,UAAMvK,IAAQuK,EAAQ,OAChByH,IAAShS,aAAiB;AAEhC,WADoBgS,KAAU,CAAC,OAAO,MAAMhS,EAAM,QAAO,CAAE,KAG3DuK,EAAQ,OAAO,KAAK;AAAA,MAChB,UAAU;AAAA,MACV,MAAM;AAAA,MACN,OAAAvK;AAAA,MACA,GAAIgS,IAAS,EAAE,UAAU,eAAc,IAAK,CAAA;AAAA,MAC5C,MAAAvT;AAAA,IACZ,CAAS,GACM8L;AAAA,EACf;AACA,CAAC;AACD,SAAS0H,GAAkBzL,GAAQ0L,GAAOC,GAAO;AAC7C,EAAI3L,EAAO,OAAO,UACd0L,EAAM,OAAO,KAAK,GAAGE,GAAkBD,GAAO3L,EAAO,MAAM,CAAC,GAEhE0L,EAAM,MAAMC,CAAK,IAAI3L,EAAO;AAChC;AACO,MAAM6L,KAA0BnI,gBAAAA,EAAkB,aAAa,CAACzL,GAAMC,MAAQ;AACjF,EAAAiO,EAAS,KAAKlO,GAAMC,CAAG,GACvBD,EAAK,KAAK,QAAQ,CAAC8L,GAASzF,MAAQ;AAChC,UAAM9E,IAAQuK,EAAQ;AACtB,QAAI,CAAC,MAAM,QAAQvK,CAAK;AACpB,aAAAuK,EAAQ,OAAO,KAAK;AAAA,QAChB,UAAU;AAAA,QACV,MAAM;AAAA,QACN,OAAAvK;AAAA,QACA,MAAAvB;AAAA,MAChB,CAAa,GACM8L;AAEX,IAAAA,EAAQ,QAAQ,MAAMvK,EAAM,MAAM;AAClC,UAAMsS,IAAQ,CAAA;AACd,aAAShO,IAAI,GAAGA,IAAItE,EAAM,QAAQsE,KAAK;AACnC,YAAMzG,IAAOmC,EAAMsE,CAAC,GACdkC,IAAS9H,EAAI,QAAQ,KAAK,IAAI;AAAA,QAChC,OAAOb;AAAA,QACP,QAAQ,CAAE;AAAA,MACb,GAAEiH,CAAG;AACN,MAAI0B,aAAkB,UAClB8L,EAAM,KAAK9L,EAAO,KAAK,CAACA,MAAWyL,GAAkBzL,GAAQ+D,GAASjG,CAAC,CAAC,CAAC,IAGzE2N,GAAkBzL,GAAQ+D,GAASjG,CAAC;AAAA,IAE3C;AACD,WAAIgO,EAAM,SACC,QAAQ,IAAIA,CAAK,EAAE,KAAK,MAAM/H,CAAO,IAEzCA;AAAA,EACf;AACA,CAAC;AACD,SAASgI,GAAqB/L,GAAQ0L,GAAOhR,GAAKlB,GAAO;AACrD,EAAIwG,EAAO,OAAO,UACd0L,EAAM,OAAO,KAAK,GAAGE,GAAkBlR,GAAKsF,EAAO,MAAM,CAAC,GAE1DA,EAAO,UAAU,SACbtF,KAAOlB,MACPkS,EAAM,MAAMhR,CAAG,IAAI,UAIvBgR,EAAM,MAAMhR,CAAG,IAAIsF,EAAO;AAElC;AACA,SAASgM,GAAa9T,GAAK;AACvB,QAAM+T,IAAO,OAAO,KAAK/T,EAAI,KAAK;AAClC,aAAWE,KAAK6T;AACZ,QAAI,CAAC/T,EAAI,MAAME,CAAC,EAAE,KAAK,OAAO,IAAI,UAAU;AACxC,YAAM,IAAI,MAAM,2BAA2BA,CAAC,0BAA0B;AAG9E,QAAM8T,IAAQC,GAAkBjU,EAAI,KAAK;AACzC,SAAO;AAAA,IACH,GAAGA;AAAA,IACH,MAAA+T;AAAA,IACA,QAAQ,IAAI,IAAIA,CAAI;AAAA,IACpB,SAASA,EAAK;AAAA,IACd,cAAc,IAAI,IAAIC,CAAK;AAAA,EACnC;AACA;AACA,SAASE,GAAeN,GAAOtS,GAAOuK,GAASzF,GAAKpG,GAAKD,GAAM;AAC3D,QAAMoU,IAAe,CAAA,GAEfC,IAASpU,EAAI,QACbqU,IAAYrU,EAAI,SAAS,MACzBsU,IAAID,EAAU,IAAI;AACxB,aAAW7R,KAAO,OAAO,KAAKlB,CAAK,GAAG;AAClC,QAAI8S,EAAO,IAAI5R,CAAG;AACd;AACJ,QAAI8R,MAAM,SAAS;AACf,MAAAH,EAAa,KAAK3R,CAAG;AACrB;AAAA,IACH;AACD,UAAMmM,IAAI0F,EAAU,IAAI,EAAE,OAAO/S,EAAMkB,CAAG,GAAG,QAAQ,GAAI,GAAE4D,CAAG;AAC9D,IAAIuI,aAAa,UACbiF,EAAM,KAAKjF,EAAE,KAAK,CAACA,MAAMkF,GAAqBlF,GAAG9C,GAASrJ,GAAKlB,CAAK,CAAC,CAAC,IAGtEuS,GAAqBlF,GAAG9C,GAASrJ,GAAKlB,CAAK;AAAA,EAElD;AASD,SARI6S,EAAa,UACbtI,EAAQ,OAAO,KAAK;AAAA,IAChB,MAAM;AAAA,IACN,MAAMsI;AAAA,IACN,OAAA7S;AAAA,IACA,MAAAvB;AAAA,EACZ,CAAS,GAEA6T,EAAM,SAEJ,QAAQ,IAAIA,CAAK,EAAE,KAAK,MACpB/H,CACV,IAHUA;AAIf;AACO,MAAM0I,KAA2B/I,gBAAAA,EAAkB,cAAc,CAACzL,GAAMC,MAAQ;AAEnF,EAAAiO,EAAS,KAAKlO,GAAMC,CAAG;AACvB,QAAMwU,IAAcC,GAAY,MAAMX,GAAa9T,CAAG,CAAC;AACvD0U,EAAAA,EAAgB3U,EAAK,MAAM,cAAc,MAAM;AAC3C,UAAMuE,IAAQtE,EAAI,OACZ2U,IAAa,CAAA;AACnB,eAAWnS,KAAO8B,GAAO;AACrB,YAAMsQ,IAAQtQ,EAAM9B,CAAG,EAAE;AACzB,UAAIoS,EAAM,QAAQ;AACd,QAAAD,EAAWnS,CAAG,MAAMmS,EAAWnS,CAAG,IAAI,oBAAI,IAAG;AAC7C,mBAAWxB,KAAK4T,EAAM;AAClB,UAAAD,EAAWnS,CAAG,EAAE,IAAIxB,CAAC;AAAA,MAC5B;AAAA,IACJ;AACD,WAAO2T;AAAA,EACf,CAAK;AACD,QAAMrR,IAAWuR,IACXC,IAAW9U,EAAI;AACrB,MAAIkB;AACJ,EAAAnB,EAAK,KAAK,QAAQ,CAAC8L,GAASzF,MAAQ;AAChC,IAAAlF,MAAUA,IAAQsT,EAAY;AAC9B,UAAMlT,IAAQuK,EAAQ;AACtB,QAAI,CAACvI,EAAShC,CAAK;AACf,aAAAuK,EAAQ,OAAO,KAAK;AAAA,QAChB,UAAU;AAAA,QACV,MAAM;AAAA,QACN,OAAAvK;AAAA,QACA,MAAAvB;AAAA,MAChB,CAAa,GACM8L;AAEX,IAAAA,EAAQ,QAAQ;AAChB,UAAM+H,IAAQ,CAAA,GACRtP,IAAQpD,EAAM;AACpB,eAAWsB,KAAOtB,EAAM,MAAM;AAE1B,YAAMyN,IADKrK,EAAM9B,CAAG,EACP,KAAK,IAAI,EAAE,OAAOlB,EAAMkB,CAAG,GAAG,QAAQ,GAAI,GAAE4D,CAAG;AAC5D,MAAIuI,aAAa,UACbiF,EAAM,KAAKjF,EAAE,KAAK,CAACA,MAAMkF,GAAqBlF,GAAG9C,GAASrJ,GAAKlB,CAAK,CAAC,CAAC,IAGtEuS,GAAqBlF,GAAG9C,GAASrJ,GAAKlB,CAAK;AAAA,IAElD;AACD,WAAKwT,IAGEZ,GAAeN,GAAOtS,GAAOuK,GAASzF,GAAKoO,EAAY,OAAOzU,CAAI,IAF9D6T,EAAM,SAAS,QAAQ,IAAIA,CAAK,EAAE,KAAK,MAAM/H,CAAO,IAAIA;AAAA,EAG3E;AACA,CAAC,GACYkJ,KAA8BvJ,gBAAAA,EAAkB,iBAAiB,CAACzL,GAAMC,MAAQ;AAEzF,EAAAuU,GAAW,KAAKxU,GAAMC,CAAG;AACzB,QAAMgV,IAAajV,EAAK,KAAK,OACvByU,IAAcC,GAAY,MAAMX,GAAa9T,CAAG,CAAC,GACjDiV,IAAmB,CAAC3Q,MAAU;AAChC,UAAM4Q,IAAM,IAAIvH,GAAI,CAAC,SAAS,WAAW,KAAK,CAAC,GACzCwH,IAAaX,EAAY,OACzBY,IAAW,CAAC5S,MAAQ;AACtB,YAAMtC,IAAImV,GAAS7S,CAAG;AACtB,aAAO,SAAStC,CAAC,6BAA6BA,CAAC;AAAA,IAC3D;AACQ,IAAAgV,EAAI,MAAM,8BAA8B;AACxC,UAAMI,IAAM,uBAAO,OAAO,IAAI;AAC9B,QAAIC,IAAU;AACd,eAAW/S,KAAO2S,EAAW;AACzB,MAAAG,EAAI9S,CAAG,IAAI,OAAO+S,GAAS;AAG/B,IAAAL,EAAI,MAAM,sBAAsB;AAChC,eAAW1S,KAAO2S,EAAW,MAAM;AAC/B,YAAMK,IAAKF,EAAI9S,CAAG,GACZtC,IAAImV,GAAS7S,CAAG;AACtB,MAAA0S,EAAI,MAAM,SAASM,CAAE,MAAMJ,EAAS5S,CAAG,CAAC,GAAG,GAC3C0S,EAAI,MAAM;AAAA,cACRM,CAAE;AAAA,mDACmCA,CAAE;AAAA;AAAA,gCAErBtV,CAAC,qBAAqBA,CAAC;AAAA;AAAA;AAAA;AAAA,cAIzCsV,CAAE;AAAA,gBACAtV,CAAC;AAAA,wBACOA,CAAC;AAAA;AAAA;AAAA,sBAGHA,CAAC,OAAOsV,CAAE;AAAA;AAAA,OAEzB;AAAA,IACE;AACD,IAAAN,EAAI,MAAM,4BAA4B,GACtCA,EAAI,MAAM,iBAAiB;AAC3B,UAAM5U,IAAK4U,EAAI;AACf,WAAO,CAACrJ,GAASzF,MAAQ9F,EAAGgE,GAAOuH,GAASzF,CAAG;AAAA,EACvD;AACI,MAAIqP;AACJ,QAAMnS,IAAWuR,IACXa,IAAM,CAACC,GAAkB,SAEzBC,IAAcF,KADDG,GACmB,OAChCf,IAAW9U,EAAI;AACrB,MAAIkB;AACJ,EAAAnB,EAAK,KAAK,QAAQ,CAAC8L,GAASzF,MAAQ;AAChC,IAAAlF,MAAUA,IAAQsT,EAAY;AAC9B,UAAMlT,IAAQuK,EAAQ;AACtB,WAAKvI,EAAShC,CAAK,IASfoU,KAAOE,MAAexP,KAAA,gBAAAA,EAAK,WAAU,MAASA,EAAI,YAAY,MAEzDqP,MACDA,IAAWR,EAAiBjV,EAAI,KAAK,IACzC6L,IAAU4J,EAAS5J,GAASzF,CAAG,GAC1B0O,IAEEZ,GAAe,CAAA,GAAI5S,GAAOuK,GAASzF,GAAKlF,GAAOnB,CAAI,IAD/C8L,KAGRmJ,EAAWnJ,GAASzF,CAAG,KAjB1ByF,EAAQ,OAAO,KAAK;AAAA,MAChB,UAAU;AAAA,MACV,MAAM;AAAA,MACN,OAAAvK;AAAA,MACA,MAAAvB;AAAA,IAChB,CAAa,GACM8L;AAAA,EAYnB;AACA,CAAC;AACD,SAASiK,GAAmBC,GAASvC,GAAOzT,GAAMqG,GAAK;AACnD,aAAW0B,KAAUiO;AACjB,QAAIjO,EAAO,OAAO,WAAW;AACzB,aAAA0L,EAAM,QAAQ1L,EAAO,OACd0L;AAGf,QAAMwC,IAAaD,EAAQ,OAAO,CAACpH,MAAM,CAACN,GAAaM,CAAC,CAAC;AACzD,SAAIqH,EAAW,WAAW,KACtBxC,EAAM,QAAQwC,EAAW,CAAC,EAAE,OACrBA,EAAW,CAAC,MAEvBxC,EAAM,OAAO,KAAK;AAAA,IACd,MAAM;AAAA,IACN,OAAOA,EAAM;AAAA,IACb,MAAAzT;AAAA,IACA,QAAQgW,EAAQ,IAAI,CAACjO,MAAWA,EAAO,OAAO,IAAI,CAAC9B,MAAQiC,GAAmBjC,GAAKI,GAAK8B,GAAW,CAAE,CAAC,CAAC;AAAA,EAC/G,CAAK,GACMsL;AACX;AACO,MAAMyC,KAA0BzK,gBAAAA,EAAkB,aAAa,CAACzL,GAAMC,MAAQ;AACjF,EAAAiO,EAAS,KAAKlO,GAAMC,CAAG,GACvB0U,EAAgB3U,EAAK,MAAM,SAAS,MAAMC,EAAI,QAAQ,KAAK,CAAC2D,MAAMA,EAAE,KAAK,UAAU,UAAU,IAAI,aAAa,MAAS,GACvH+Q,EAAgB3U,EAAK,MAAM,UAAU,MAAMC,EAAI,QAAQ,KAAK,CAAC2D,MAAMA,EAAE,KAAK,WAAW,UAAU,IAAI,aAAa,MAAS,GACzH+Q,EAAgB3U,EAAK,MAAM,UAAU,MAAM;AACvC,QAAIC,EAAI,QAAQ,MAAM,CAAC2D,MAAMA,EAAE,KAAK,MAAM;AACtC,aAAO,IAAI,IAAI3D,EAAI,QAAQ,QAAQ,CAACkW,MAAW,MAAM,KAAKA,EAAO,KAAK,MAAM,CAAC,CAAC;AAAA,EAG1F,CAAK,GACDxB,EAAgB3U,EAAK,MAAM,WAAW,MAAM;AACxC,QAAIC,EAAI,QAAQ,MAAM,CAAC2D,MAAMA,EAAE,KAAK,OAAO,GAAG;AAC1C,YAAMwS,IAAWnW,EAAI,QAAQ,IAAI,CAAC,MAAM,EAAE,KAAK,OAAO;AACtD,aAAO,IAAI,OAAO,KAAKmW,EAAS,IAAI,CAACC,MAAMC,GAAgBD,EAAE,MAAM,CAAC,EAAE,KAAK,GAAG,CAAC,IAAI;AAAA,IACtF;AAAA,EAET,CAAK;AACD,QAAME,IAAStW,EAAI,QAAQ,WAAW,GAChCuW,IAAQvW,EAAI,QAAQ,CAAC,EAAE,KAAK;AAClC,EAAAD,EAAK,KAAK,QAAQ,CAAC8L,GAASzF,MAAQ;AAChC,QAAIkQ;AACA,aAAOC,EAAM1K,GAASzF,CAAG;AAE7B,QAAIoQ,IAAQ;AACZ,UAAMT,IAAU,CAAA;AAChB,eAAWG,KAAUlW,EAAI,SAAS;AAC9B,YAAM8H,IAASoO,EAAO,KAAK,IAAI;AAAA,QAC3B,OAAOrK,EAAQ;AAAA,QACf,QAAQ,CAAE;AAAA,MACb,GAAEzF,CAAG;AACN,UAAI0B,aAAkB;AAClB,QAAAiO,EAAQ,KAAKjO,CAAM,GACnB0O,IAAQ;AAAA,WAEP;AACD,YAAI1O,EAAO,OAAO,WAAW;AACzB,iBAAOA;AACX,QAAAiO,EAAQ,KAAKjO,CAAM;AAAA,MACtB;AAAA,IACJ;AACD,WAAK0O,IAEE,QAAQ,IAAIT,CAAO,EAAE,KAAK,CAACA,MACvBD,GAAmBC,GAASlK,GAAS9L,GAAMqG,CAAG,CACxD,IAHU0P,GAAmBC,GAASlK,GAAS9L,GAAMqG,CAAG;AAAA,EAIjE;AACA,CAAC,GAqEYqQ,KAAiCjL,gBAAAA,EAAkB,oBAAoB,CAACzL,GAAMC,MAAQ;AAC/F,EAAAiO,EAAS,KAAKlO,GAAMC,CAAG,GACvBD,EAAK,KAAK,QAAQ,CAAC8L,GAASzF,MAAQ;AAChC,UAAM9E,IAAQuK,EAAQ,OAChB6K,IAAO1W,EAAI,KAAK,KAAK,IAAI,EAAE,OAAOsB,GAAO,QAAQ,GAAI,GAAE8E,CAAG,GAC1DuQ,IAAQ3W,EAAI,MAAM,KAAK,IAAI,EAAE,OAAOsB,GAAO,QAAQ,GAAI,GAAE8E,CAAG;AAElE,WADcsQ,aAAgB,WAAWC,aAAiB,UAE/C,QAAQ,IAAI,CAACD,GAAMC,CAAK,CAAC,EAAE,KAAK,CAAC,CAACD,GAAMC,CAAK,MACzCC,GAA0B/K,GAAS6K,GAAMC,CAAK,CACxD,IAEEC,GAA0B/K,GAAS6K,GAAMC,CAAK;AAAA,EAC7D;AACA,CAAC;AACD,SAASE,GAAY1R,GAAGC,GAAG;AAGvB,MAAID,MAAMC;AACN,WAAO,EAAE,OAAO,IAAM,MAAMD,EAAC;AAEjC,MAAIA,aAAa,QAAQC,aAAa,QAAQ,CAACD,KAAM,CAACC;AAClD,WAAO,EAAE,OAAO,IAAM,MAAMD,EAAC;AAEjC,MAAI2R,GAAmB3R,CAAC,KAAK2R,GAAmB1R,CAAC,GAAG;AAChD,UAAM2R,IAAQ,OAAO,KAAK3R,CAAC,GACrB4R,IAAa,OAAO,KAAK7R,CAAC,EAAE,OAAO,CAAC3C,MAAQuU,EAAM,QAAQvU,CAAG,MAAM,EAAE,GACrEyU,IAAS,EAAE,GAAG9R,GAAG,GAAGC,EAAC;AAC3B,eAAW5C,KAAOwU,GAAY;AAC1B,YAAME,IAAcL,GAAY1R,EAAE3C,CAAG,GAAG4C,EAAE5C,CAAG,CAAC;AAC9C,UAAI,CAAC0U,EAAY;AACb,eAAO;AAAA,UACH,OAAO;AAAA,UACP,gBAAgB,CAAC1U,GAAK,GAAG0U,EAAY,cAAc;AAAA,QACvE;AAEY,MAAAD,EAAOzU,CAAG,IAAI0U,EAAY;AAAA,IAC7B;AACD,WAAO,EAAE,OAAO,IAAM,MAAMD,EAAM;AAAA,EACrC;AACD,MAAI,MAAM,QAAQ9R,CAAC,KAAK,MAAM,QAAQC,CAAC,GAAG;AACtC,QAAID,EAAE,WAAWC,EAAE;AACf,aAAO,EAAE,OAAO,IAAO,gBAAgB,CAAE,EAAA;AAE7C,UAAM+R,IAAW,CAAA;AACjB,aAAS1D,IAAQ,GAAGA,IAAQtO,EAAE,QAAQsO,KAAS;AAC3C,YAAM2D,IAAQjS,EAAEsO,CAAK,GACf4D,IAAQjS,EAAEqO,CAAK,GACfyD,IAAcL,GAAYO,GAAOC,CAAK;AAC5C,UAAI,CAACH,EAAY;AACb,eAAO;AAAA,UACH,OAAO;AAAA,UACP,gBAAgB,CAACzD,GAAO,GAAGyD,EAAY,cAAc;AAAA,QACzE;AAEY,MAAAC,EAAS,KAAKD,EAAY,IAAI;AAAA,IACjC;AACD,WAAO,EAAE,OAAO,IAAM,MAAMC,EAAQ;AAAA,EACvC;AACD,SAAO,EAAE,OAAO,IAAO,gBAAgB,CAAE,EAAA;AAC7C;AACA,SAASP,GAA0B9O,GAAQ4O,GAAMC,GAAO;AAOpD,MANID,EAAK,OAAO,UACZ5O,EAAO,OAAO,KAAK,GAAG4O,EAAK,MAAM,GAEjCC,EAAM,OAAO,UACb7O,EAAO,OAAO,KAAK,GAAG6O,EAAM,MAAM,GAElCtI,GAAavG,CAAM;AACnB,WAAOA;AACX,QAAMwP,IAAST,GAAYH,EAAK,OAAOC,EAAM,KAAK;AAClD,MAAI,CAACW,EAAO;AACR,UAAM,IAAI,MAAM,wCAA6C,KAAK,UAAUA,EAAO,cAAc,CAAC,EAAE;AAExG,SAAAxP,EAAO,QAAQwP,EAAO,MACfxP;AACX;AA6QO,MAAMyP,KAAyB/L,gBAAAA,EAAkB,YAAY,CAACzL,GAAMC,MAAQ;AAC/E,EAAAiO,EAAS,KAAKlO,GAAMC,CAAG;AACvB,QAAMwX,IAASC,GAAmBzX,EAAI,OAAO,GACvC0X,IAAY,IAAI,IAAIF,CAAM;AAChC,EAAAzX,EAAK,KAAK,SAAS2X,GACnB3X,EAAK,KAAK,UAAU,IAAI,OAAO,KAAKyX,EAC/B,OAAO,CAACtX,MAAMyX,GAAsB,IAAI,OAAOzX,CAAC,CAAC,EACjD,IAAI,CAACyD,MAAO,OAAOA,KAAM,WAAW2J,GAAiB3J,CAAC,IAAIA,EAAE,SAAQ,CAAG,EACvE,KAAK,GAAG,CAAC,IAAI,GAClB5D,EAAK,KAAK,QAAQ,CAAC8L,GAAShE,MAAS;AACjC,UAAMvG,IAAQuK,EAAQ;AACtB,WAAI6L,EAAU,IAAIpW,CAAK,KAGvBuK,EAAQ,OAAO,KAAK;AAAA,MAChB,MAAM;AAAA,MACN,QAAA2L;AAAA,MACA,OAAAlW;AAAA,MACA,MAAAvB;AAAA,IACZ,CAAS,GACM8L;AAAA,EACf;AACA,CAAC,GAwCY+L,KAA8BpM,gBAAAA,EAAkB,iBAAiB,CAACzL,GAAMC,MAAQ;AACzF,EAAAiO,EAAS,KAAKlO,GAAMC,CAAG,GACvBD,EAAK,KAAK,QAAQ,CAAC8L,GAASzF,MAAQ;AAChC,QAAIA,EAAI,cAAc;AAClB,YAAM,IAAIyR,GAAqB9X,EAAK,YAAY,IAAI;AAExD,UAAM+X,IAAO9X,EAAI,UAAU6L,EAAQ,OAAOA,CAAO;AACjD,QAAIzF,EAAI;AAEJ,cADe0R,aAAgB,UAAUA,IAAO,QAAQ,QAAQA,CAAI,GACtD,KAAK,CAACC,OAChBlM,EAAQ,QAAQkM,GACTlM,EACV;AAEL,QAAIiM,aAAgB;AAChB,YAAM,IAAI/P,GAAmB;AAEjC,WAAA8D,EAAQ,QAAQiM,GACTjM;AAAA,EACf;AACA,CAAC;AACD,SAASmM,GAAqBlQ,GAAQxG,GAAO;AACzC,SAAIwG,EAAO,OAAO,UAAUxG,MAAU,SAC3B,EAAE,QAAQ,CAAA,GAAI,OAAO,OAAS,IAElCwG;AACX;AACO,MAAMmQ,KAA6BzM,gBAAAA,EAAkB,gBAAgB,CAACzL,GAAMC,MAAQ;AACvF,EAAAiO,EAAS,KAAKlO,GAAMC,CAAG,GACvBD,EAAK,KAAK,QAAQ,YAClBA,EAAK,KAAK,SAAS,YACnB2U,EAAgB3U,EAAK,MAAM,UAAU,MAC1BC,EAAI,UAAU,KAAK,SAAS,oBAAI,IAAI,CAAC,GAAGA,EAAI,UAAU,KAAK,QAAQ,MAAS,CAAC,IAAI,MAC3F,GACD0U,EAAgB3U,EAAK,MAAM,WAAW,MAAM;AACxC,UAAMwN,IAAUvN,EAAI,UAAU,KAAK;AACnC,WAAOuN,IAAU,IAAI,OAAO,KAAK8I,GAAgB9I,EAAQ,MAAM,CAAC,KAAK,IAAI;AAAA,EACjF,CAAK,GACDxN,EAAK,KAAK,QAAQ,CAAC8L,GAASzF,MAAQ;AAChC,QAAIpG,EAAI,UAAU,KAAK,UAAU,YAAY;AACzC,YAAM8H,IAAS9H,EAAI,UAAU,KAAK,IAAI6L,GAASzF,CAAG;AAClD,aAAI0B,aAAkB,UACXA,EAAO,KAAK,CAAC6G,MAAMqJ,GAAqBrJ,GAAG9C,EAAQ,KAAK,CAAC,IAC7DmM,GAAqBlQ,GAAQ+D,EAAQ,KAAK;AAAA,IACpD;AACD,WAAIA,EAAQ,UAAU,SACXA,IAEJ7L,EAAI,UAAU,KAAK,IAAI6L,GAASzF,CAAG;AAAA,EAClD;AACA,CAAC,GACY8R,KAA6B1M,gBAAAA,EAAkB,gBAAgB,CAACzL,GAAMC,MAAQ;AACvF,EAAAiO,EAAS,KAAKlO,GAAMC,CAAG,GACvB0U,EAAgB3U,EAAK,MAAM,SAAS,MAAMC,EAAI,UAAU,KAAK,KAAK,GAClE0U,EAAgB3U,EAAK,MAAM,UAAU,MAAMC,EAAI,UAAU,KAAK,MAAM,GACpE0U,EAAgB3U,EAAK,MAAM,WAAW,MAAM;AACxC,UAAMwN,IAAUvN,EAAI,UAAU,KAAK;AACnC,WAAOuN,IAAU,IAAI,OAAO,KAAK8I,GAAgB9I,EAAQ,MAAM,CAAC,SAAS,IAAI;AAAA,EACrF,CAAK,GACDmH,EAAgB3U,EAAK,MAAM,UAAU,MAC1BC,EAAI,UAAU,KAAK,SAAS,oBAAI,IAAI,CAAC,GAAGA,EAAI,UAAU,KAAK,QAAQ,IAAI,CAAC,IAAI,MACtF,GACDD,EAAK,KAAK,QAAQ,CAAC8L,GAASzF,MAEpByF,EAAQ,UAAU,OACXA,IACJ7L,EAAI,UAAU,KAAK,IAAI6L,GAASzF,CAAG;AAElD,CAAC,GACY+R,KAA4B3M,gBAAAA,EAAkB,eAAe,CAACzL,GAAMC,MAAQ;AACrF,EAAAiO,EAAS,KAAKlO,GAAMC,CAAG,GAEvBD,EAAK,KAAK,QAAQ,YAClB2U,EAAgB3U,EAAK,MAAM,UAAU,MAAMC,EAAI,UAAU,KAAK,MAAM,GACpED,EAAK,KAAK,QAAQ,CAAC8L,GAASzF,MAAQ;AAChC,QAAIA,EAAI,cAAc;AAClB,aAAOpG,EAAI,UAAU,KAAK,IAAI6L,GAASzF,CAAG;AAG9C,QAAIyF,EAAQ,UAAU;AAClB,aAAAA,EAAQ,QAAQ7L,EAAI,cAIb6L;AAGX,UAAM/D,IAAS9H,EAAI,UAAU,KAAK,IAAI6L,GAASzF,CAAG;AAClD,WAAI0B,aAAkB,UACXA,EAAO,KAAK,CAACA,MAAWsQ,GAAoBtQ,GAAQ9H,CAAG,CAAC,IAE5DoY,GAAoBtQ,GAAQ9H,CAAG;AAAA,EAC9C;AACA,CAAC;AACD,SAASoY,GAAoBvM,GAAS7L,GAAK;AACvC,SAAI6L,EAAQ,UAAU,WAClBA,EAAQ,QAAQ7L,EAAI,eAEjB6L;AACX;AACO,MAAMwM,KAA6B7M,gBAAAA,EAAkB,gBAAgB,CAACzL,GAAMC,MAAQ;AACvF,EAAAiO,EAAS,KAAKlO,GAAMC,CAAG,GACvBD,EAAK,KAAK,QAAQ,YAClB2U,EAAgB3U,EAAK,MAAM,UAAU,MAAMC,EAAI,UAAU,KAAK,MAAM,GACpED,EAAK,KAAK,QAAQ,CAAC8L,GAASzF,OACpBA,EAAI,cAAc,cAIlByF,EAAQ,UAAU,WAClBA,EAAQ,QAAQ7L,EAAI,eAEjBA,EAAI,UAAU,KAAK,IAAI6L,GAASzF,CAAG;AAElD,CAAC,GACYkS,KAAgC9M,gBAAAA,EAAkB,mBAAmB,CAACzL,GAAMC,MAAQ;AAC7F,EAAAiO,EAAS,KAAKlO,GAAMC,CAAG,GACvB0U,EAAgB3U,EAAK,MAAM,UAAU,MAAM;AACvC,UAAMiB,IAAIhB,EAAI,UAAU,KAAK;AAC7B,WAAOgB,IAAI,IAAI,IAAI,CAAC,GAAGA,CAAC,EAAE,OAAO,CAAC0E,MAAMA,MAAM,MAAS,CAAC,IAAI;AAAA,EACpE,CAAK,GACD3F,EAAK,KAAK,QAAQ,CAAC8L,GAASzF,MAAQ;AAChC,UAAM0B,IAAS9H,EAAI,UAAU,KAAK,IAAI6L,GAASzF,CAAG;AAClD,WAAI0B,aAAkB,UACXA,EAAO,KAAK,CAACA,MAAWyQ,GAAwBzQ,GAAQ/H,CAAI,CAAC,IAEjEwY,GAAwBzQ,GAAQ/H,CAAI;AAAA,EACnD;AACA,CAAC;AACD,SAASwY,GAAwB1M,GAAS9L,GAAM;AAC5C,SAAI,CAAC8L,EAAQ,OAAO,UAAUA,EAAQ,UAAU,UAC5CA,EAAQ,OAAO,KAAK;AAAA,IAChB,MAAM;AAAA,IACN,UAAU;AAAA,IACV,OAAOA,EAAQ;AAAA,IACf,MAAA9L;AAAA,EACZ,CAAS,GAEE8L;AACX;AAkBO,MAAM2M,KAA0BhN,gBAAAA,EAAkB,aAAa,CAACzL,GAAMC,MAAQ;AACjF,EAAAiO,EAAS,KAAKlO,GAAMC,CAAG,GACvB0U,EAAgB3U,EAAK,MAAM,SAAS,MAAMC,EAAI,UAAU,KAAK,KAAK,GAClE0U,EAAgB3U,EAAK,MAAM,UAAU,MAAMC,EAAI,UAAU,KAAK,MAAM,GACpE0U,EAAgB3U,EAAK,MAAM,UAAU,MAAMC,EAAI,UAAU,KAAK,MAAM,GACpED,EAAK,KAAK,QAAQ,CAAC8L,GAASzF,MAAQ;AAChC,QAAIA,EAAI,cAAc;AAClB,aAAOpG,EAAI,UAAU,KAAK,IAAI6L,GAASzF,CAAG;AAG9C,UAAM0B,IAAS9H,EAAI,UAAU,KAAK,IAAI6L,GAASzF,CAAG;AAClD,WAAI0B,aAAkB,UACXA,EAAO,KAAK,CAACA,OAChB+D,EAAQ,QAAQ/D,EAAO,OACnBA,EAAO,OAAO,WACd+D,EAAQ,QAAQ7L,EAAI,WAAW;AAAA,MAC3B,GAAG6L;AAAA,MACH,OAAO;AAAA,QACH,QAAQ/D,EAAO,OAAO,IAAI,CAAC9B,MAAQiC,GAAmBjC,GAAKI,GAAK8B,GAAW,CAAE,CAAC;AAAA,MACjF;AAAA,MACD,OAAO2D,EAAQ;AAAA,IACvC,CAAqB,GACDA,EAAQ,SAAS,KAEdA,EACV,KAELA,EAAQ,QAAQ/D,EAAO,OACnBA,EAAO,OAAO,WACd+D,EAAQ,QAAQ7L,EAAI,WAAW;AAAA,MAC3B,GAAG6L;AAAA,MACH,OAAO;AAAA,QACH,QAAQ/D,EAAO,OAAO,IAAI,CAAC9B,MAAQiC,GAAmBjC,GAAKI,GAAK8B,GAAW,CAAE,CAAC;AAAA,MACjF;AAAA,MACD,OAAO2D,EAAQ;AAAA,IAC/B,CAAa,GACDA,EAAQ,SAAS,KAEdA;AAAA,EACf;AACA,CAAC,GAgBY4M,KAAyBjN,gBAAAA,EAAkB,YAAY,CAACzL,GAAMC,MAAQ;AAC/E,EAAAiO,EAAS,KAAKlO,GAAMC,CAAG,GACvB0U,EAAgB3U,EAAK,MAAM,UAAU,MAAMC,EAAI,GAAG,KAAK,MAAM,GAC7D0U,EAAgB3U,EAAK,MAAM,SAAS,MAAMC,EAAI,GAAG,KAAK,KAAK,GAC3D0U,EAAgB3U,EAAK,MAAM,UAAU,MAAMC,EAAI,IAAI,KAAK,MAAM,GAC9D0U,EAAgB3U,EAAK,MAAM,cAAc,MAAMC,EAAI,GAAG,KAAK,UAAU,GACrED,EAAK,KAAK,QAAQ,CAAC8L,GAASzF,MAAQ;AAChC,QAAIA,EAAI,cAAc,YAAY;AAC9B,YAAMuQ,IAAQ3W,EAAI,IAAI,KAAK,IAAI6L,GAASzF,CAAG;AAC3C,aAAIuQ,aAAiB,UACVA,EAAM,KAAK,CAACA,MAAU+B,GAAiB/B,GAAO3W,EAAI,IAAIoG,CAAG,CAAC,IAE9DsS,GAAiB/B,GAAO3W,EAAI,IAAIoG,CAAG;AAAA,IAC7C;AACD,UAAMsQ,IAAO1W,EAAI,GAAG,KAAK,IAAI6L,GAASzF,CAAG;AACzC,WAAIsQ,aAAgB,UACTA,EAAK,KAAK,CAACA,MAASgC,GAAiBhC,GAAM1W,EAAI,KAAKoG,CAAG,CAAC,IAE5DsS,GAAiBhC,GAAM1W,EAAI,KAAKoG,CAAG;AAAA,EAClD;AACA,CAAC;AACD,SAASsS,GAAiBhC,GAAMiC,GAAMvS,GAAK;AACvC,SAAIsQ,EAAK,OAAO,UAEZA,EAAK,UAAU,IACRA,KAEJiC,EAAK,KAAK,IAAI,EAAE,OAAOjC,EAAK,OAAO,QAAQA,EAAK,OAAQ,GAAEtQ,CAAG;AACxE;AAuDO,MAAMwS,KAA6BpN,gBAAAA,EAAkB,gBAAgB,CAACzL,GAAMC,MAAQ;AACvF,EAAAiO,EAAS,KAAKlO,GAAMC,CAAG,GACvB0U,EAAgB3U,EAAK,MAAM,cAAc,MAAMC,EAAI,UAAU,KAAK,UAAU,GAC5E0U,EAAgB3U,EAAK,MAAM,UAAU,MAAMC,EAAI,UAAU,KAAK,MAAM,GACpE0U,EAAgB3U,EAAK,MAAM,SAAS,MAAMC,EAAI,UAAU,KAAK,KAAK,GAClE0U,EAAgB3U,EAAK,MAAM,UAAU,MAAMC,EAAI,UAAU,KAAK,MAAM,GACpED,EAAK,KAAK,QAAQ,CAAC8L,GAASzF,MAAQ;AAChC,QAAIA,EAAI,cAAc;AAClB,aAAOpG,EAAI,UAAU,KAAK,IAAI6L,GAASzF,CAAG;AAE9C,UAAM0B,IAAS9H,EAAI,UAAU,KAAK,IAAI6L,GAASzF,CAAG;AAClD,WAAI0B,aAAkB,UACXA,EAAO,KAAK+Q,EAAoB,IAEpCA,GAAqB/Q,CAAM;AAAA,EAC1C;AACA,CAAC;AACD,SAAS+Q,GAAqBhN,GAAS;AACnC,SAAAA,EAAQ,QAAQ,OAAO,OAAOA,EAAQ,KAAK,GACpCA;AACX;AA0JO,MAAMiN,KAA2BtN,gBAAAA,EAAkB,cAAc,CAACzL,GAAMC,MAAQ;AACnF+Y,EAAAA,EAAiB,KAAKhZ,GAAMC,CAAG,GAC/BiO,EAAS,KAAKlO,GAAMC,CAAG,GACvBD,EAAK,KAAK,QAAQ,CAAC8L,GAAS1L,MACjB0L,GAEX9L,EAAK,KAAK,QAAQ,CAAC8L,MAAY;AAC3B,UAAMvK,IAAQuK,EAAQ,OAChB8C,IAAI3O,EAAI,GAAGsB,CAAK;AACtB,QAAIqN,aAAa;AACb,aAAOA,EAAE,KAAK,CAACA,MAAMqK,GAAmBrK,GAAG9C,GAASvK,GAAOvB,CAAI,CAAC;AAEpE,IAAAiZ,GAAmBrK,GAAG9C,GAASvK,GAAOvB,CAAI;AAAA,EAElD;AACA,CAAC;AACD,SAASiZ,GAAmBlR,GAAQ+D,GAASvK,GAAOvB,GAAM;AACtD,MAAI,CAAC+H,GAAQ;AACT,UAAMmR,IAAO;AAAA,MACT,MAAM;AAAA,MACN,OAAA3X;AAAA,MACA,MAAAvB;AAAA;AAAA,MACA,MAAM,CAAC,GAAIA,EAAK,KAAK,IAAI,QAAQ,CAAA,CAAG;AAAA;AAAA,MACpC,UAAU,CAACA,EAAK,KAAK,IAAI;AAAA;AAAA,IAErC;AACQ,IAAIA,EAAK,KAAK,IAAI,WACdkZ,EAAK,SAASlZ,EAAK,KAAK,IAAI,SAChC8L,EAAQ,OAAO,KAAKqN,GAAWD,CAAI,CAAC;AAAA,EACvC;AACL;AC74DO,MAAME,GAAa;AAAA,EACtB,cAAc;AACV,SAAK,OAAO,oBAAI,OAChB,KAAK,SAAS,oBAAI;EACrB;AAAA,EACD,IAAI1U,MAAW2U,GAAO;AAClB,UAAMC,IAAOD,EAAM,CAAC;AAEpB,QADA,KAAK,KAAK,IAAI3U,GAAQ4U,CAAI,GACtBA,KAAQ,OAAOA,KAAS,YAAY,QAAQA,GAAM;AAClD,UAAI,KAAK,OAAO,IAAIA,EAAK,EAAE;AACvB,cAAM,IAAI,MAAM,MAAMA,EAAK,EAAE,iCAAiC;AAElE,WAAK,OAAO,IAAIA,EAAK,IAAI5U,CAAM;AAAA,IAClC;AACD,WAAO;AAAA,EACV;AAAA,EACD,QAAQ;AACJ,gBAAK,OAAO,oBAAI,OAChB,KAAK,SAAS,oBAAI,OACX;AAAA,EACV;AAAA,EACD,OAAOA,GAAQ;AACX,UAAM4U,IAAO,KAAK,KAAK,IAAI5U,CAAM;AACjC,WAAI4U,KAAQ,OAAOA,KAAS,YAAY,QAAQA,KAC5C,KAAK,OAAO,OAAOA,EAAK,EAAE,GAE9B,KAAK,KAAK,OAAO5U,CAAM,GAChB;AAAA,EACV;AAAA,EACD,IAAIA,GAAQ;AAGR,UAAM2R,IAAI3R,EAAO,KAAK;AACtB,QAAI2R,GAAG;AACH,YAAMkD,IAAK,EAAE,GAAI,KAAK,IAAIlD,CAAC,KAAK,CAAE;AAClC,aAAOkD,EAAG;AACV,YAAMC,IAAI,EAAE,GAAGD,GAAI,GAAG,KAAK,KAAK,IAAI7U,CAAM;AAC1C,aAAO,OAAO,KAAK8U,CAAC,EAAE,SAASA,IAAI;AAAA,IACtC;AACD,WAAO,KAAK,KAAK,IAAI9U,CAAM;AAAA,EAC9B;AAAA,EACD,IAAIA,GAAQ;AACR,WAAO,KAAK,KAAK,IAAIA,CAAM;AAAA,EAC9B;AACL;AAEO,SAAS+U,KAAW;AACvB,SAAO,IAAIL,GAAY;AAC3B;AACO,MAAMM,KAA+B,gBAAAD,GAAU;AChD/C,SAASE,GAAQpU,GAAOzF,GAAQ;AACnC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AAQO,SAAS+Z,GAAOtU,GAAOzF,GAAQ;AAClC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAASga,GAAMvU,GAAOzF,GAAQ;AACjC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAASia,GAAMxU,GAAOzF,GAAQ;AACjC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAASka,GAAQzU,GAAOzF,GAAQ;AACnC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,SAAS;AAAA,IACT,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAASma,GAAQ1U,GAAOzF,GAAQ;AACnC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,SAAS;AAAA,IACT,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAASoa,GAAQ3U,GAAOzF,GAAQ;AACnC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,SAAS;AAAA,IACT,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAASqa,GAAK5U,GAAOzF,GAAQ;AAChC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAASiK,GAAOxE,GAAOzF,GAAQ;AAClC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAASsa,GAAQ7U,GAAOzF,GAAQ;AACnC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAASua,GAAM9U,GAAOzF,GAAQ;AACjC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAASwa,GAAO/U,GAAOzF,GAAQ;AAClC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAASya,GAAMhV,GAAOzF,GAAQ;AACjC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAAS0a,GAAKjV,GAAOzF,GAAQ;AAChC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAAS2a,GAAOlV,GAAOzF,GAAQ;AAClC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAAS4a,GAAMnV,GAAOzF,GAAQ;AACjC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAAS6a,GAAMpV,GAAOzF,GAAQ;AACjC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAAS8a,GAAQrV,GAAOzF,GAAQ;AACnC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAAS+a,GAAQtV,GAAOzF,GAAQ;AACnC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAASgb,GAAQvV,GAAOzF,GAAQ;AACnC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAASib,GAAWxV,GAAOzF,GAAQ;AACtC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAASkb,GAAMzV,GAAOzF,GAAQ;AACjC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAASmb,GAAK1V,GAAOzF,GAAQ;AAChC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,OAAO;AAAA,IACP,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AAQO,SAASob,GAAa3V,GAAOzF,GAAQ;AACxC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,WAAW;AAAA,IACX,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAASqb,GAAS5V,GAAOzF,GAAQ;AACpC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAASsb,GAAS7V,GAAOzF,GAAQ;AACpC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,WAAW;AAAA,IACX,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAASub,GAAa9V,GAAOzF,GAAQ;AACxC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAASwb,GAAQ/V,GAAOzF,GAAQ;AACnC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ,CAAE;AAAA,IACV,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAASyb,GAAehW,GAAOzF,GAAQ;AAC1C,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,QAAQ;AAAA,IACR,QAAQ,CAAE;AAAA,IACV,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAAS0b,GAAKjW,GAAOzF,GAAQ;AAChC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AAqCO,SAAS2b,GAASlW,GAAOzF,GAAQ;AACpC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AA8DO,SAAS4b,GAASnW,GAAO;AAC5B,SAAO,IAAIA,EAAM;AAAA,IACb,MAAM;AAAA,EACd,CAAK;AACL;AACO,SAASoW,GAAOpW,GAAOzF,GAAQ;AAClC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AAOO,SAAS8b,GAAMrW,GAAOzF,GAAQ;AACjC,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,GAAGqU,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AAcO,SAAS+b,GAAI1a,GAAOrB,GAAQ;AAC/B,SAAO,IAAIgc,GAAyB;AAAA,IAChC,OAAO;AAAA,IACP,GAAGlC,EAAqB9Z,CAAM;AAAA,IAC9B,OAAAqB;AAAA,IACA,WAAW;AAAA,EACnB,CAAK;AACL;AACO,SAAS4a,GAAK5a,GAAOrB,GAAQ;AAChC,SAAO,IAAIgc,GAAyB;AAAA,IAChC,OAAO;AAAA,IACP,GAAGlC,EAAqB9Z,CAAM;AAAA,IAC9B,OAAAqB;AAAA,IACA,WAAW;AAAA,EACnB,CAAK;AACL;AAIO,SAAS6a,GAAI7a,GAAOrB,GAAQ;AAC/B,SAAO,IAAImc,GAA4B;AAAA,IACnC,OAAO;AAAA,IACP,GAAGrC,EAAqB9Z,CAAM;AAAA,IAC9B,OAAAqB;AAAA,IACA,WAAW;AAAA,EACnB,CAAK;AACL;AACO,SAAS+a,GAAK/a,GAAOrB,GAAQ;AAChC,SAAO,IAAImc,GAA4B;AAAA,IACnC,OAAO;AAAA,IACP,GAAGrC,EAAqB9Z,CAAM;AAAA,IAC9B,OAAAqB;AAAA,IACA,WAAW;AAAA,EACnB,CAAK;AACL;AAmBO,SAASgb,GAAYhb,GAAOrB,GAAQ;AACvC,SAAO,IAAIsc,GAA2B;AAAA,IAClC,OAAO;AAAA,IACP,GAAGxC,EAAqB9Z,CAAM;AAAA,IAC9B,OAAAqB;AAAA,EACR,CAAK;AACL;AAsBO,SAASkb,GAAWhQ,GAASvM,GAAQ;AAMxC,SALW,IAAIwc,GAA0B;AAAA,IACrC,OAAO;AAAA,IACP,GAAG1C,EAAqB9Z,CAAM;AAAA,IAC9B,SAAAuM;AAAA,EACR,CAAK;AAEL;AACO,SAASkQ,GAAWnQ,GAAStM,GAAQ;AACxC,SAAO,IAAI0c,GAA0B;AAAA,IACjC,OAAO;AAAA,IACP,GAAG5C,EAAqB9Z,CAAM;AAAA,IAC9B,SAAAsM;AAAA,EACR,CAAK;AACL;AACO,SAASqQ,GAAQ5P,GAAQ/M,GAAQ;AACpC,SAAO,IAAI4c,GAA6B;AAAA,IACpC,OAAO;AAAA,IACP,GAAG9C,EAAqB9Z,CAAM;AAAA,IAC9B,QAAA+M;AAAA,EACR,CAAK;AACL;AACO,SAAS8P,GAAOnP,GAAS1N,GAAQ;AACpC,SAAO,IAAI8c,GAAsB;AAAA,IAC7B,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,GAAGhD,EAAqB9Z,CAAM;AAAA,IAC9B,SAAA0N;AAAA,EACR,CAAK;AACL;AACO,SAASqP,GAAW/c,GAAQ;AAC/B,SAAO,IAAIgd,GAA0B;AAAA,IACjC,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,GAAGlD,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAASid,GAAWjd,GAAQ;AAC/B,SAAO,IAAIkd,GAA0B;AAAA,IACjC,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,GAAGpD,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AACO,SAASmd,GAAUC,GAAUpd,GAAQ;AACxC,SAAO,IAAIqd,GAAyB;AAAA,IAChC,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,GAAGvD,EAAqB9Z,CAAM;AAAA,IAC9B,UAAAod;AAAA,EACR,CAAK;AACL;AACO,SAASE,GAAY1L,GAAQ5R,GAAQ;AACxC,SAAO,IAAIud,GAA2B;AAAA,IAClC,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,GAAGzD,EAAqB9Z,CAAM;AAAA,IAC9B,QAAA4R;AAAA,EACR,CAAK;AACL;AACO,SAAS4L,GAAUC,GAAQzd,GAAQ;AACtC,SAAO,IAAI0d,GAAyB;AAAA,IAChC,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,GAAG5D,EAAqB9Z,CAAM;AAAA,IAC9B,QAAAyd;AAAA,EACR,CAAK;AACL;AAgBO,SAASE,GAAWC,GAAI;AAC3B,SAAO,IAAIC,GAA0B;AAAA,IACjC,OAAO;AAAA,IACP,IAAAD;AAAA,EACR,CAAK;AACL;AAEO,SAASE,GAAWC,GAAM;AAC7B,SAAOJ,GAAW,CAAClc,MAAUA,EAAM,UAAUsc,CAAI,CAAC;AACtD;AAEO,SAASC,KAAQ;AACpB,SAAOL,GAAW,CAAClc,MAAUA,EAAM,KAAM,CAAA;AAC7C;AAEO,SAASwc,KAAe;AAC3B,SAAON,GAAW,CAAClc,MAAUA,EAAM,YAAa,CAAA;AACpD;AAEO,SAASyc,KAAe;AAC3B,SAAOP,GAAW,CAAClc,MAAUA,EAAM,YAAa,CAAA;AACpD;AACO,SAAS0c,GAAO1Y,GAAO2Y,GAASpe,GAAQ;AAC3C,SAAO,IAAIyF,EAAM;AAAA,IACb,MAAM;AAAA,IACN,SAAA2Y;AAAA;AAAA;AAAA;AAAA,IAIA,GAAGtE,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AAuMO,SAASqe,GAAQ5Y,GAAOhF,GAAI8D,GAAS;AAOxC,SANe,IAAIkB,EAAM;AAAA,IACrB,MAAM;AAAA,IACN,OAAO;AAAA,IACP,IAAIhF;AAAA,IACJ,GAAGqZ,EAAqBvV,CAAO;AAAA,EACvC,CAAK;AAEL;AACO,SAAS+Z,GAAa7d,GAAI;AAC7B,QAAM4N,IAAKkQ,GAAO,CAACvS,OACfA,EAAQ,WAAW,CAAClF,MAAU;AAC1B,QAAI,OAAOA,KAAU;AACjB,MAAAkF,EAAQ,OAAO,KAAKqN,GAAWvS,GAAOkF,EAAQ,OAAOqC,EAAG,KAAK,GAAG,CAAC;AAAA,SAEhE;AAED,YAAMmQ,IAAS1X;AACf,MAAI0X,EAAO,UACPA,EAAO,WAAW,KACtBA,EAAO,SAASA,EAAO,OAAO,WAC9BA,EAAO,UAAUA,EAAO,QAAQxS,EAAQ,QACxCwS,EAAO,SAASA,EAAO,OAAOnQ,IAC9BmQ,EAAO,aAAaA,EAAO,WAAW,CAACnQ,EAAG,KAAK,IAAI,QACnDrC,EAAQ,OAAO,KAAKqN,GAAWmF,CAAM,CAAC;AAAA,IACzC;AAAA,EACb,GACe/d,EAAGuL,EAAQ,OAAOA,CAAO,EACnC;AACD,SAAOqC;AACX;AACO,SAASkQ,GAAO9d,GAAIT,GAAQ;AAC/B,QAAMqO,IAAK,IAAI6K,EAAiB;AAAA,IAC5B,OAAO;AAAA,IACP,GAAGY,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACD,SAAAqO,EAAG,KAAK,QAAQ5N,GACT4N;AACX;ACr1BO,MAAMoQ,KAA+B9S,gBAAAA,EAAkB,kBAAkB,CAACzL,GAAMC,MAAQ;AAC3Fue,EAAAA,GAAqB,KAAKxe,GAAMC,CAAG,GACnCwe,EAAwB,KAAKze,GAAMC,CAAG;AAC1C,CAAC;AACM,SAAS6K,GAAShL,GAAQ;AAC7B,SAAO4e,GAAkBH,IAAgBze,CAAM;AACnD;AACO,MAAM6e,KAA2BlT,gBAAAA,EAAkB,cAAc,CAACzL,GAAMC,MAAQ;AACnF2e,EAAAA,GAAiB,KAAK5e,GAAMC,CAAG,GAC/Bwe,EAAwB,KAAKze,GAAMC,CAAG;AAC1C,CAAC;AACM,SAASyK,GAAK5K,GAAQ;AACzB,SAAO+e,GAAcF,IAAY7e,CAAM;AAC3C;AACO,MAAMgf,KAA2BrT,gBAAAA,EAAkB,cAAc,CAACzL,GAAMC,MAAQ;AACnF8e,EAAAA,GAAiB,KAAK/e,GAAMC,CAAG,GAC/Bwe,EAAwB,KAAKze,GAAMC,CAAG;AAC1C,CAAC;AACM,SAAS4K,GAAK/K,GAAQ;AACzB,SAAOkf,GAAcF,IAAYhf,CAAM;AAC3C;AACO,MAAMmf,KAA+BxT,gBAAAA,EAAkB,kBAAkB,CAACzL,GAAMC,MAAQ;AAC3Fif,EAAAA,GAAqB,KAAKlf,GAAMC,CAAG,GACnCwe,EAAwB,KAAKze,GAAMC,CAAG;AAC1C,CAAC;AACM,SAASyJ,GAAS5J,GAAQ;AAC7B,SAAOqf,GAAkBF,IAAgBnf,CAAM;AACnD;AC1BA,MAAMD,KAAc,CAACG,GAAMgG,MAAW;AAClC,EAAAe,GAAU,KAAK/G,GAAMgG,CAAM,GAC3BhG,EAAK,OAAO,YACZ,OAAO,iBAAiBA,GAAM;AAAA,IAC1B,QAAQ;AAAA,MACJ,OAAO,CAACmH,MAAWiY,GAAiBpf,GAAMmH,CAAM;AAAA;AAAA,IAEnD;AAAA,IACD,SAAS;AAAA,MACL,OAAO,CAACA,MAAWkY,GAAkBrf,GAAMmH,CAAM;AAAA;AAAA,IAEpD;AAAA,IACD,UAAU;AAAA,MACN,OAAO,CAACP,MAAU;AACd,QAAA5G,EAAK,OAAO,KAAK4G,CAAK,GACtB5G,EAAK,UAAU,KAAK,UAAUA,EAAK,QAAQ8G,IAA4B,CAAC;AAAA,MAC3E;AAAA;AAAA,IAEJ;AAAA,IACD,WAAW;AAAA,MACP,OAAO,CAACd,MAAW;AACf,QAAAhG,EAAK,OAAO,KAAK,GAAGgG,CAAM,GAC1BhG,EAAK,UAAU,KAAK,UAAUA,EAAK,QAAQ8G,IAA4B,CAAC;AAAA,MAC3E;AAAA;AAAA,IAEJ;AAAA,IACD,SAAS;AAAA,MACL,MAAM;AACF,eAAO9G,EAAK,OAAO,WAAW;AAAA,MACjC;AAAA;AAAA,IAEJ;AAAA,EACT,CAAK;AAML,GAEasf,IAAe7T,EAAkB,YAAY5L,IAAa;AAAA,EACnE,QAAQ;AACZ,CAAC,GC3CY0f,KAAwBC,gBAAAA,GAAYF,CAAY,GAChDG,KAA6BC,gBAAAA,GAAiBJ,CAAY,GAC1D9W,KAA4BmX,gBAAAA,GAAgBL,CAAY,GACxD3W,KAAiCiX,gBAAAA,GAAqBN,CAAY,GAElEO,KAAyBC,gBAAAA,GAAaR,CAAY,GAClDS,KAAyBC,gBAAAA,GAAaV,CAAY,GAClDW,KAA8BC,gBAAAA,GAAkBZ,CAAY,GAC5Da,KAA8BC,gBAAAA,GAAkBd,CAAY,GAC5De,KAA6BC,gBAAAA,GAAiBhB,CAAY,GAC1DiB,KAA6BC,gBAAAA,GAAiBlB,CAAY,GAC1DmB,KAAkCC,gBAAAA,GAAsBpB,CAAY,GACpEqB,KAAkCC,gBAAAA,GAAsBtB,CAAY,GCTpEuB,IAAwBpV,gBAAAA,EAAkB,WAAW,CAACzL,GAAMC,OACrE6gB,EAAc,KAAK9gB,GAAMC,CAAG,GAC5BD,EAAK,MAAMC,GACXD,EAAK,OAAOC,EAAI,MAChB,OAAO,eAAeD,GAAM,QAAQ,EAAE,OAAOC,EAAG,CAAE,GAElDD,EAAK,QAAQ,IAAIgF,MACNhF,EAAK;AAAA,EAAM;AAAA,IACd,GAAGC;AAAA,IACH,QAAQ;AAAA,MACJ,GAAIA,EAAI,UAAU;MAClB,GAAG+E,EAAO,IAAI,CAACmJ,MAAO,OAAOA,KAAO,aAAa,EAAE,MAAM,EAAE,OAAOA,GAAI,KAAK,EAAE,OAAO,SAAQ,GAAI,UAAU,CAAE,EAAA,EAAI,IAAGA,CAAE;AAAA,IACxH;AAAA,EACJ;AAAA;AAET,GAEInO,EAAK,QAAQ,CAACC,GAAKH,MAAWihB,GAAW/gB,GAAMC,GAAKH,CAAM,GAC1DE,EAAK,QAAQ,MAAMA,GACnBA,EAAK,WAAY,CAACghB,GAAK1H,OACnB0H,EAAI,IAAIhhB,GAAMsZ,CAAI,GACXtZ,IAGXA,EAAK,QAAQ,CAACwD,GAAM1D,MAAWmhB,GAAYjhB,GAAMwD,GAAM1D,GAAQ,EAAE,QAAQE,EAAK,MAAO,CAAA,GACrFA,EAAK,YAAY,CAACwD,GAAM1D,MAAWohB,GAAgBlhB,GAAMwD,GAAM1D,CAAM,GACrEE,EAAK,aAAa,OAAOwD,GAAM1D,MAAWqhB,GAAiBnhB,GAAMwD,GAAM1D,GAAQ,EAAE,QAAQE,EAAK,WAAY,CAAA,GAC1GA,EAAK,iBAAiB,OAAOwD,GAAM1D,MAAWshB,GAAqBphB,GAAMwD,GAAM1D,CAAM,GACrFE,EAAK,MAAMA,EAAK,gBAEhBA,EAAK,SAAS,CAACwD,GAAM1D,MAAWuhB,GAAarhB,GAAMwD,GAAM1D,CAAM,GAC/DE,EAAK,SAAS,CAACwD,GAAM1D,MAAWwhB,GAAathB,GAAMwD,GAAM1D,CAAM,GAC/DE,EAAK,cAAc,OAAOwD,GAAM1D,MAAWyhB,GAAkBvhB,GAAMwD,GAAM1D,CAAM,GAC/EE,EAAK,cAAc,OAAOwD,GAAM1D,MAAW0hB,GAAkBxhB,GAAMwD,GAAM1D,CAAM,GAC/EE,EAAK,aAAa,CAACwD,GAAM1D,MAAW2hB,GAAiBzhB,GAAMwD,GAAM1D,CAAM,GACvEE,EAAK,aAAa,CAACwD,GAAM1D,MAAW4hB,GAAiB1hB,GAAMwD,GAAM1D,CAAM,GACvEE,EAAK,kBAAkB,OAAOwD,GAAM1D,MAAW6hB,GAAsB3hB,GAAMwD,GAAM1D,CAAM,GACvFE,EAAK,kBAAkB,OAAOwD,GAAM1D,MAAW8hB,GAAsB5hB,GAAMwD,GAAM1D,CAAM,GAEvFE,EAAK,SAAS,CAAC6hB,GAAO/hB,MAAWE,EAAK,MAAM8hB,GAAOD,GAAO/hB,CAAM,CAAC,GACjEE,EAAK,cAAc,CAAC+hB,MAAe/hB,EAAK,MAAMgiB,GAAYD,CAAU,CAAC,GACrE/hB,EAAK,YAAY,CAACO,MAAOP,EAAK,MAAMiiB,GAAiB1hB,CAAE,CAAC,GAExDP,EAAK,WAAW,MAAMkiB,GAASliB,CAAI,GACnCA,EAAK,WAAW,MAAMmiB,GAASniB,CAAI,GACnCA,EAAK,UAAU,MAAMkiB,GAASC,GAASniB,CAAI,CAAC,GAC5CA,EAAK,cAAc,CAACF,MAAWsiB,GAAYpiB,GAAMF,CAAM,GACvDE,EAAK,QAAQ,MAAMqiB,GAAMriB,CAAI,GAC7BA,EAAK,KAAK,CAAC6N,MAAQyU,GAAM,CAACtiB,GAAM6N,CAAG,CAAC,GACpC7N,EAAK,MAAM,CAAC6N,MAAQ0U,GAAaviB,GAAM6N,CAAG,GAC1C7N,EAAK,YAAY,CAAC0d,MAAO8E,GAAKxiB,GAAMyiB,GAAU/E,CAAE,CAAC,GACjD1d,EAAK,UAAU,CAACC,MAAQyiB,GAAS1iB,GAAMC,CAAG,GAC1CD,EAAK,WAAW,CAACC,MAAQ0iB,GAAS3iB,GAAMC,CAAG,GAE3CD,EAAK,QAAQ,CAACF,MAAW8iB,GAAO5iB,GAAMF,CAAM,GAC5CE,EAAK,OAAO,CAAC6C,MAAW2f,GAAKxiB,GAAM6C,CAAM,GACzC7C,EAAK,WAAW,MAAM6iB,GAAS7iB,CAAI,GAEnCA,EAAK,WAAW,CAAC8iB,MAAgB;AAC7B,QAAM3e,IAAKnE,EAAK;AAChB+iB,SAAAA,GAAoB,IAAI5e,GAAI,EAAE,aAAA2e,EAAa,CAAA,GACpC3e;AACf,GACI,OAAO,eAAenE,GAAM,eAAe;AAAA,EACvC,MAAM;A3CrEF,QAAAE;A2CsEA,YAAO6iB,IAAAA,GAAoB,IAAI/iB,CAAI,MAA5B+iB,gBAAAA,EAA+B;AAAA,EACzC;AAAA,EACD,cAAc;AACtB,CAAK,GACD/iB,EAAK,OAAO,IAAI6G,MAAS;AACrB,MAAIA,EAAK,WAAW;AAChB,WAAOkc,GAAoB,IAAI/iB,CAAI;AAEvC,QAAMmE,IAAKnE,EAAK;AAChB+iB,SAAAA,GAAoB,IAAI5e,GAAI0C,EAAK,CAAC,CAAC,GAC5B1C;AACf,GAEInE,EAAK,aAAa,MAAMA,EAAK,UAAU,MAAS,EAAE,SAClDA,EAAK,aAAa,MAAMA,EAAK,UAAU,IAAI,EAAE,SACtCA,EACV,GAEYgjB,KAA2BvX,gBAAAA,EAAkB,cAAc,CAACzL,GAAMC,MAAQ;AACnFgjB,EAAAA,GAAgB,KAAKjjB,GAAMC,CAAG,GAC9B4gB,EAAQ,KAAK7gB,GAAMC,CAAG;AACtB,QAAM4L,IAAM7L,EAAK,KAAK;AACtB,EAAAA,EAAK,SAAS6L,EAAI,UAAU,MAC5B7L,EAAK,YAAY6L,EAAI,WAAW,MAChC7L,EAAK,YAAY6L,EAAI,WAAW,MAEhC7L,EAAK,QAAQ,IAAI6G,MAAS7G,EAAK,MAAMkjB,GAAa,GAAGrc,CAAI,CAAC,GAC1D7G,EAAK,WAAW,IAAI6G,MAAS7G,EAAK,MAAMmjB,GAAgB,GAAGtc,CAAI,CAAC,GAChE7G,EAAK,aAAa,IAAI6G,MAAS7G,EAAK,MAAMojB,GAAkB,GAAGvc,CAAI,CAAC,GACpE7G,EAAK,WAAW,IAAI6G,MAAS7G,EAAK,MAAMqjB,GAAgB,GAAGxc,CAAI,CAAC,GAChE7G,EAAK,MAAM,IAAI6G,MAAS7G,EAAK,MAAMsjB,GAAiB,GAAGzc,CAAI,CAAC,GAC5D7G,EAAK,MAAM,IAAI6G,MAAS7G,EAAK,MAAMujB,GAAiB,GAAG1c,CAAI,CAAC,GAC5D7G,EAAK,SAAS,IAAI6G,MAAS7G,EAAK,MAAMwjB,GAAc,GAAG3c,CAAI,CAAC,GAC5D7G,EAAK,WAAW,IAAI6G,MAAS7G,EAAK,MAAMsjB,GAAiB,GAAG,GAAGzc,CAAI,CAAC,GACpE7G,EAAK,YAAY,CAACF,MAAWE,EAAK,MAAMyjB,GAAiB3jB,CAAM,CAAC,GAChEE,EAAK,YAAY,CAACF,MAAWE,EAAK,MAAM0jB,GAAiB5jB,CAAM,CAAC,GAEhEE,EAAK,OAAO,MAAMA,EAAK,MAAM2jB,GAAa,CAAA,GAC1C3jB,EAAK,YAAY,IAAI6G,MAAS7G,EAAK,MAAM4jB,GAAiB,GAAG/c,CAAI,CAAC,GAClE7G,EAAK,cAAc,MAAMA,EAAK,MAAM6jB,GAAoB,CAAA,GACxD7jB,EAAK,cAAc,MAAMA,EAAK,MAAM8jB,GAAoB,CAAA;AAC5D,CAAC,GACYC,KAA0BtY,gBAAAA,EAAkB,aAAa,CAACzL,GAAMC,MAAQ;AACjFgjB,EAAAA,GAAgB,KAAKjjB,GAAMC,CAAG,GAC9B+iB,GAAW,KAAKhjB,GAAMC,CAAG,GACzBD,EAAK,QAAQ,CAACF,MAAWE,EAAK,MAAMgkB,GAAYC,IAAUnkB,CAAM,CAAC,GACjEE,EAAK,MAAM,CAACF,MAAWE,EAAK,MAAMkkB,GAAUC,IAAQrkB,CAAM,CAAC,GAC3DE,EAAK,MAAM,CAACF,MAAWE,EAAK,MAAMokB,GAAUC,IAAQvkB,CAAM,CAAC,GAC3DE,EAAK,QAAQ,CAACF,MAAWE,EAAK,MAAMskB,GAAYC,IAAUzkB,CAAM,CAAC,GACjEE,EAAK,OAAO,CAACF,MAAWE,EAAK,MAAMwkB,GAAWC,IAAS3kB,CAAM,CAAC,GAC9DE,EAAK,OAAO,CAACF,MAAWE,EAAK,MAAM0kB,GAAWC,IAAS7kB,CAAM,CAAC,GAC9DE,EAAK,SAAS,CAACF,MAAWE,EAAK,MAAM4kB,GAAaD,IAAS7kB,CAAM,CAAC,GAClEE,EAAK,SAAS,CAACF,MAAWE,EAAK,MAAM6kB,GAAaF,IAAS7kB,CAAM,CAAC,GAClEE,EAAK,SAAS,CAACF,MAAWE,EAAK,MAAM8kB,GAAaH,IAAS7kB,CAAM,CAAC,GAClEE,EAAK,SAAS,CAACF,MAAWE,EAAK,MAAM+kB,GAAaC,IAAWllB,CAAM,CAAC,GACpEE,EAAK,OAAO,CAACF,MAAWE,EAAK,MAAMwkB,GAAWC,IAAS3kB,CAAM,CAAC,GAC9DE,EAAK,OAAO,CAACF,MAAWE,EAAK,MAAMilB,GAAWC,IAASplB,CAAM,CAAC,GAC9DE,EAAK,QAAQ,CAACF,MAAWE,EAAK,MAAMmlB,GAAYC,IAAUtlB,CAAM,CAAC,GACjEE,EAAK,OAAO,CAACF,MAAWE,EAAK,MAAMqlB,GAAWC,IAASxlB,CAAM,CAAC,GAC9DE,EAAK,SAAS,CAACF,MAAWE,EAAK,MAAMulB,GAAaC,IAAW1lB,CAAM,CAAC,GACpEE,EAAK,YAAY,CAACF,MAAWE,EAAK,MAAMylB,GAAgBC,IAAc5lB,CAAM,CAAC,GAC7EE,EAAK,MAAM,CAACF,MAAWE,EAAK,MAAM2lB,GAAUC,IAAQ9lB,CAAM,CAAC,GAC3DE,EAAK,QAAQ,CAACF,MAAWE,EAAK,MAAM6lB,GAAYC,IAAUhmB,CAAM,CAAC,GACjEE,EAAK,OAAO,CAACF,MAAWE,EAAK,MAAM+lB,GAAWC,IAASlmB,CAAM,CAAC,GAC9DE,EAAK,OAAO,CAACF,MAAWE,EAAK,MAAMimB,GAAWC,IAASpmB,CAAM,CAAC,GAC9DE,EAAK,SAAS,CAACF,MAAWE,EAAK,MAAMmmB,GAAaC,IAAWtmB,CAAM,CAAC,GACpEE,EAAK,SAAS,CAACF,MAAWE,EAAK,MAAMqmB,GAAaC,IAAWxmB,CAAM,CAAC,GACpEE,EAAK,OAAO,CAACF,MAAWE,EAAK,MAAMumB,GAAWC,IAAS1mB,CAAM,CAAC,GAE9DE,EAAK,WAAW,CAACF,MAAWE,EAAK,MAAMymB,GAAa3mB,CAAM,CAAC,GAC3DE,EAAK,OAAO,CAACF,MAAWE,EAAK,MAAM0mB,GAAS5mB,CAAM,CAAC,GACnDE,EAAK,OAAO,CAACF,MAAWE,EAAK,MAAM2mB,GAAS7mB,CAAM,CAAC,GACnDE,EAAK,WAAW,CAACF,MAAWE,EAAK,MAAM4mB,GAAa9mB,CAAM,CAAC;AAC/D,CAAC;AACM,SAASmL,EAAOnL,GAAQ;AAC3B,SAAO+mB,GAAa9C,IAAWjkB,CAAM;AACzC;AACO,MAAMgnB,IAAgCrb,gBAAAA,EAAkB,mBAAmB,CAACzL,GAAMC,MAAQ;AAC7F8mB,EAAAA,EAAsB,KAAK/mB,GAAMC,CAAG,GACpC+iB,GAAW,KAAKhjB,GAAMC,CAAG;AAC7B,CAAC,GACYgkB,KAAyBxY,gBAAAA,EAAkB,YAAY,CAACzL,GAAMC,MAAQ;AAE/E+mB,EAAAA,GAAe,KAAKhnB,GAAMC,CAAG,GAC7B6mB,EAAgB,KAAK9mB,GAAMC,CAAG;AAClC,CAAC;AACM,SAAS6J,GAAMhK,GAAQ;AAC1B,SAAOkkB,GAAYC,IAAUnkB,CAAM;AACvC;AACO,MAAM2kB,KAAwBhZ,gBAAAA,EAAkB,WAAW,CAACzL,GAAMC,MAAQ;AAE7EgnB,EAAAA,GAAc,KAAKjnB,GAAMC,CAAG,GAC5B6mB,EAAgB,KAAK9mB,GAAMC,CAAG;AAClC,CAAC,GAIY0kB,KAAwBlZ,gBAAAA,EAAkB,WAAW,CAACzL,GAAMC,MAAQ;AAE7EinB,EAAAA,GAAc,KAAKlnB,GAAMC,CAAG,GAC5B6mB,EAAgB,KAAK9mB,GAAMC,CAAG;AAClC,CAAC;AACM,SAAS2J,GAAK9J,GAAQ;AACzB,SAAO4kB,GAAWC,IAAS7kB,CAAM;AACrC;AAYO,MAAMqkB,KAAuB1Y,gBAAAA,EAAkB,UAAU,CAACzL,GAAMC,MAAQ;AAE3EknB,EAAAA,GAAa,KAAKnnB,GAAMC,CAAG,GAC3B6mB,EAAgB,KAAK9mB,GAAMC,CAAG;AAClC,CAAC,GAWYskB,KAAyB9Y,gBAAAA,EAAkB,YAAY,CAACzL,GAAMC,MAAQ;AAE/EmnB,EAAAA,GAAe,KAAKpnB,GAAMC,CAAG,GAC7B6mB,EAAgB,KAAK9mB,GAAMC,CAAG;AAClC,CAAC,GAIY+kB,KAA0BvZ,gBAAAA,EAAkB,aAAa,CAACzL,GAAMC,MAAQ;AAEjFonB,EAAAA,GAAgB,KAAKrnB,GAAMC,CAAG,GAC9B6mB,EAAgB,KAAK9mB,GAAMC,CAAG;AAClC,CAAC,GAIYilB,KAAwBzZ,gBAAAA,EAAkB,WAAW,CAACzL,GAAMC,MAAQ;AAE7EqnB,EAAAA,GAAc,KAAKtnB,GAAMC,CAAG,GAC5B6mB,EAAgB,KAAK9mB,GAAMC,CAAG;AAClC,CAAC,GAIYmlB,KAAyB3Z,gBAAAA,EAAkB,YAAY,CAACzL,GAAMC,MAAQ;AAE/EsnB,EAAAA,GAAe,KAAKvnB,GAAMC,CAAG,GAC7B6mB,EAAgB,KAAK9mB,GAAMC,CAAG;AAClC,CAAC,GAIYqlB,KAAwB7Z,gBAAAA,EAAkB,WAAW,CAACzL,GAAMC,MAAQ;AAE7EunB,EAAAA,GAAc,KAAKxnB,GAAMC,CAAG,GAC5B6mB,EAAgB,KAAK9mB,GAAMC,CAAG;AAClC,CAAC,GAIY2lB,KAAuBna,gBAAAA,EAAkB,UAAU,CAACzL,GAAMC,MAAQ;AAE3EwnB,EAAAA,GAAa,KAAKznB,GAAMC,CAAG,GAC3B6mB,EAAgB,KAAK9mB,GAAMC,CAAG;AAClC,CAAC,GAIY6lB,KAAyBra,gBAAAA,EAAkB,YAAY,CAACzL,GAAMC,MAAQ;AAE/EynB,EAAAA,GAAe,KAAK1nB,GAAMC,CAAG,GAC7B6mB,EAAgB,KAAK9mB,GAAMC,CAAG;AAClC,CAAC,GAIY+lB,KAAwBva,gBAAAA,EAAkB,WAAW,CAACzL,GAAMC,MAAQ;AAE7E0nB,EAAAA,GAAc,KAAK3nB,GAAMC,CAAG,GAC5B6mB,EAAgB,KAAK9mB,GAAMC,CAAG;AAClC,CAAC,GAIYimB,KAAwBza,gBAAAA,EAAkB,WAAW,CAACzL,GAAMC,MAAQ;AAE7E2nB,EAAAA,GAAc,KAAK5nB,GAAMC,CAAG,GAC5B6mB,EAAgB,KAAK9mB,GAAMC,CAAG;AAClC,CAAC,GAIYmmB,KAA0B3a,gBAAAA,EAAkB,aAAa,CAACzL,GAAMC,MAAQ;AACjF4nB,EAAAA,GAAgB,KAAK7nB,GAAMC,CAAG,GAC9B6mB,EAAgB,KAAK9mB,GAAMC,CAAG;AAClC,CAAC,GAIYqmB,KAA0B7a,gBAAAA,EAAkB,aAAa,CAACzL,GAAMC,MAAQ;AACjF6nB,EAAAA,GAAgB,KAAK9nB,GAAMC,CAAG,GAC9B6mB,EAAgB,KAAK9mB,GAAMC,CAAG;AAClC,CAAC,GAIYulB,KAA0B/Z,gBAAAA,EAAkB,aAAa,CAACzL,GAAMC,MAAQ;AAEjF8nB,EAAAA,GAAgB,KAAK/nB,GAAMC,CAAG,GAC9B6mB,EAAgB,KAAK9mB,GAAMC,CAAG;AAClC,CAAC,GAIYylB,KAA6Bja,gBAAAA,EAAkB,gBAAgB,CAACzL,GAAMC,MAAQ;AAEvF+nB,EAAAA,GAAmB,KAAKhoB,GAAMC,CAAG,GACjC6mB,EAAgB,KAAK9mB,GAAMC,CAAG;AAClC,CAAC,GAIYumB,KAAwB/a,gBAAAA,EAAkB,WAAW,CAACzL,GAAMC,MAAQ;AAE7EgoB,EAAAA,GAAc,KAAKjoB,GAAMC,CAAG,GAC5B6mB,EAAgB,KAAK9mB,GAAMC,CAAG;AAClC,CAAC,GAIYokB,KAAuB5Y,gBAAAA,EAAkB,UAAU,CAACzL,GAAMC,MAAQ;AAE3EioB,EAAAA,GAAa,KAAKloB,GAAMC,CAAG,GAC3B6mB,EAAgB,KAAK9mB,GAAMC,CAAG;AAClC,CAAC,GA0BYkoB,KAA0B1c,gBAAAA,EAAkB,aAAa,CAACzL,GAAMC,MAAQ;AACjFmoB,EAAAA,GAAgB,KAAKpoB,GAAMC,CAAG,GAC9B4gB,EAAQ,KAAK7gB,GAAMC,CAAG,GACtBD,EAAK,KAAK,CAACmB,GAAOrB,MAAWE,EAAK,MAAMqoB,GAAUlnB,GAAOrB,CAAM,CAAC,GAChEE,EAAK,MAAM,CAACmB,GAAOrB,MAAWE,EAAK,MAAMsoB,GAAWnnB,GAAOrB,CAAM,CAAC,GAClEE,EAAK,MAAM,CAACmB,GAAOrB,MAAWE,EAAK,MAAMsoB,GAAWnnB,GAAOrB,CAAM,CAAC,GAClEE,EAAK,KAAK,CAACmB,GAAOrB,MAAWE,EAAK,MAAMuoB,GAAUpnB,GAAOrB,CAAM,CAAC,GAChEE,EAAK,MAAM,CAACmB,GAAOrB,MAAWE,EAAK,MAAMwoB,GAAWrnB,GAAOrB,CAAM,CAAC,GAClEE,EAAK,MAAM,CAACmB,GAAOrB,MAAWE,EAAK,MAAMwoB,GAAWrnB,GAAOrB,CAAM,CAAC,GAClEE,EAAK,MAAM,CAACF,MAAWE,EAAK,MAAMyoB,GAAI3oB,CAAM,CAAC,GAC7CE,EAAK,OAAO,CAACF,MAAWE,EAAK,MAAMyoB,GAAI3oB,CAAM,CAAC,GAC9CE,EAAK,WAAW,CAACF,MAAWE,EAAK,MAAMqoB,GAAU,GAAGvoB,CAAM,CAAC,GAC3DE,EAAK,cAAc,CAACF,MAAWE,EAAK,MAAMsoB,GAAW,GAAGxoB,CAAM,CAAC,GAC/DE,EAAK,WAAW,CAACF,MAAWE,EAAK,MAAMuoB,GAAU,GAAGzoB,CAAM,CAAC,GAC3DE,EAAK,cAAc,CAACF,MAAWE,EAAK,MAAMwoB,GAAW,GAAG1oB,CAAM,CAAC,GAC/DE,EAAK,aAAa,CAACmB,GAAOrB,MAAWE,EAAK,MAAM0oB,GAAkBvnB,GAAOrB,CAAM,CAAC,GAChFE,EAAK,OAAO,CAACmB,GAAOrB,MAAWE,EAAK,MAAM0oB,GAAkBvnB,GAAOrB,CAAM,CAAC,GAE1EE,EAAK,SAAS,MAAMA;AACpB,QAAM6L,IAAM7L,EAAK,KAAK;AACtB,EAAAA,EAAK,WACD,KAAK,IAAI6L,EAAI,WAAW,OAAO,mBAAmBA,EAAI,oBAAoB,OAAO,iBAAiB,KAAK,MAC3G7L,EAAK,WACD,KAAK,IAAI6L,EAAI,WAAW,OAAO,mBAAmBA,EAAI,oBAAoB,OAAO,iBAAiB,KAAK,MAC3G7L,EAAK,SAAS6L,EAAI,UAAU,IAAI,SAAS,KAAK,KAAK,OAAO,cAAcA,EAAI,cAAc,GAAG,GAC7F7L,EAAK,WAAW,IAChBA,EAAK,SAAS6L,EAAI,UAAU;AAChC,CAAC;AACM,SAAST,GAAOtL,GAAQ;AAC3B,SAAO6oB,GAAaR,IAAWroB,CAAM;AACzC;AACO,MAAM8oB,KAAgCnd,gBAAAA,EAAkB,mBAAmB,CAACzL,GAAMC,MAAQ;AAC7F4oB,EAAAA,GAAsB,KAAK7oB,GAAMC,CAAG,GACpCkoB,GAAU,KAAKnoB,GAAMC,CAAG;AAC5B,CAAC;AACM,SAASwoB,GAAI3oB,GAAQ;AACxB,SAAOgpB,GAAUF,IAAiB9oB,CAAM;AAC5C;AAaO,MAAMipB,KAA2Btd,gBAAAA,EAAkB,cAAc,CAACzL,GAAMC,MAAQ;AACnF+oB,EAAAA,GAAiB,KAAKhpB,GAAMC,CAAG,GAC/B4gB,EAAQ,KAAK7gB,GAAMC,CAAG;AAC1B,CAAC;AACM,SAASoL,GAAQvL,GAAQ;AAC5B,SAAOmpB,GAAcF,IAAYjpB,CAAM;AAC3C;AAmEO,MAAMopB,KAA2Bzd,gBAAAA,EAAkB,cAAc,CAACzL,GAAMC,MAAQ;AACnFkpB,EAAAA,GAAiB,KAAKnpB,GAAMC,CAAG,GAC/B4gB,EAAQ,KAAK7gB,GAAMC,CAAG;AAC1B,CAAC;AACM,SAASmpB,KAAU;AACtB,SAAOC,GAAcH,EAAU;AACnC;AACO,MAAMI,KAAyB7d,gBAAAA,EAAkB,YAAY,CAACzL,GAAMC,MAAQ;AAC/EspB,EAAAA,GAAe,KAAKvpB,GAAMC,CAAG,GAC7B4gB,EAAQ,KAAK7gB,GAAMC,CAAG;AAC1B,CAAC;AACM,SAASupB,GAAM1pB,GAAQ;AAC1B,SAAO2pB,GAAYH,IAAUxpB,CAAM;AACvC;AASO,MAAM4pB,KAAwBje,gBAAAA,EAAkB,WAAW,CAACzL,GAAMC,MAAQ;AAC7E0pB,EAAAA,GAAc,KAAK3pB,GAAMC,CAAG,GAC5B4gB,EAAQ,KAAK7gB,GAAMC,CAAG,GACtBD,EAAK,MAAM,CAACmB,GAAOrB,MAAWE,EAAK,MAAMsoB,GAAWnnB,GAAOrB,CAAM,CAAC,GAClEE,EAAK,MAAM,CAACmB,GAAOrB,MAAWE,EAAK,MAAMwoB,GAAWrnB,GAAOrB,CAAM,CAAC;AAClE,QAAMmS,IAAIjS,EAAK,KAAK;AACpB,EAAAA,EAAK,UAAUiS,EAAE,UAAU,IAAI,KAAKA,EAAE,OAAO,IAAI,MACjDjS,EAAK,UAAUiS,EAAE,UAAU,IAAI,KAAKA,EAAE,OAAO,IAAI;AACrD,CAAC;AACM,SAASvH,GAAK5K,GAAQ;AACzB,SAAO8pB,GAAWF,IAAS5pB,CAAM;AACrC;AACO,MAAM+pB,KAAyBpe,gBAAAA,EAAkB,YAAY,CAACzL,GAAMC,MAAQ;AAC/E6pB,EAAAA,GAAe,KAAK9pB,GAAMC,CAAG,GAC7B4gB,EAAQ,KAAK7gB,GAAMC,CAAG,GACtBD,EAAK,UAAUC,EAAI,SACnBD,EAAK,MAAM,CAAC+pB,GAAWjqB,MAAWE,EAAK,MAAMsjB,GAAiByG,GAAWjqB,CAAM,CAAC,GAChFE,EAAK,WAAW,CAACF,MAAWE,EAAK,MAAMsjB,GAAiB,GAAGxjB,CAAM,CAAC,GAClEE,EAAK,MAAM,CAACgqB,GAAWlqB,MAAWE,EAAK,MAAMujB,GAAiByG,GAAWlqB,CAAM,CAAC,GAChFE,EAAK,SAAS,CAACiqB,GAAKnqB,MAAWE,EAAK,MAAMwjB,GAAcyG,GAAKnqB,CAAM,CAAC,GACpEE,EAAK,SAAS,MAAMA,EAAK;AAC7B,CAAC;AACM,SAASqiB,GAAMnE,GAASpe,GAAQ;AACnC,SAAOoqB,GAAYL,IAAU3L,GAASpe,CAAM;AAChD;AAMO,MAAMqqB,KAA0B1e,gBAAAA,EAAkB,aAAa,CAACzL,GAAMC,MAAQ;AACjFmqB,EAAAA,GAAmB,KAAKpqB,GAAMC,CAAG,GACjC4gB,EAAQ,KAAK7gB,GAAMC,CAAG,GACtB0U,EAAgB3U,GAAM,SAAS,MAAMC,EAAI,KAAK,GAC9CD,EAAK,QAAQ,MAAMqqB,GAAM,OAAO,KAAKrqB,EAAK,KAAK,IAAI,KAAK,CAAC,GACzDA,EAAK,WAAW,CAAC+U,MAAa/U,EAAK,MAAM,EAAE,GAAGA,EAAK,KAAK,KAAK,UAAU+U,EAAU,CAAA,GACjF/U,EAAK,cAAc,MAAMA,EAAK,MAAM,EAAE,GAAGA,EAAK,KAAK,KAAK,UAAUopB,GAAO,EAAI,CAAA,GAC7EppB,EAAK,QAAQ,MAAMA,EAAK,MAAM,EAAE,GAAGA,EAAK,KAAK,KAAK,UAAUopB,GAAO,EAAI,CAAA,GACvEppB,EAAK,SAAS,MAAMA,EAAK,MAAM,EAAE,GAAGA,EAAK,KAAK,KAAK,UAAUwpB,GAAK,EAAI,CAAA,GACtExpB,EAAK,QAAQ,MAAMA,EAAK,MAAM,EAAE,GAAGA,EAAK,KAAK,KAAK,UAAU,OAAW,CAAA,GACvEA,EAAK,SAAS,CAACsqB,MACJC,GAAYvqB,GAAMsqB,CAAQ,GAErCtqB,EAAK,aAAa,CAACsqB,MACRE,GAAgBxqB,GAAMsqB,CAAQ,GAEzCtqB,EAAK,QAAQ,CAACyqB,MAAUC,GAAW1qB,GAAMyqB,CAAK,GAC9CzqB,EAAK,OAAO,CAAC2E,MAASgmB,GAAU3qB,GAAM2E,CAAI,GAC1C3E,EAAK,OAAO,CAAC2E,MAASimB,GAAU5qB,GAAM2E,CAAI,GAC1C3E,EAAK,UAAU,IAAI6G,MAASgkB,GAAaC,IAAa9qB,GAAM6G,EAAK,CAAC,CAAC,GACnE7G,EAAK,WAAW,IAAI6G,MAASkkB,GAAcC,IAAgBhrB,GAAM6G,EAAK,CAAC,CAAC;AAC5E,CAAC;AACM,SAASrE,EAAO+B,GAAOzE,GAAQ;AAClC,QAAMG,IAAM;AAAA,IACR,MAAM;AAAA,IACN,IAAI,QAAQ;AACRgrB,aAAAA,GAAgB,MAAM,SAAS1mB,IAAQ2mB,GAAiB3mB,CAAK,IAAI,CAAA,CAAE,GAC5D,KAAK;AAAA,IACf;AAAA,IACD,GAAGqV,EAAqB9Z,CAAM;AAAA,EACtC;AACI,SAAO,IAAIqqB,GAAUlqB,CAAG;AAC5B;AAyBO,MAAMkrB,KAAyB1f,gBAAAA,EAAkB,YAAY,CAACzL,GAAMC,MAAQ;AAC/EmrB,EAAAA,GAAe,KAAKprB,GAAMC,CAAG,GAC7B4gB,EAAQ,KAAK7gB,GAAMC,CAAG,GACtBD,EAAK,UAAUC,EAAI;AACvB,CAAC;AACM,SAASqiB,GAAM+I,GAASvrB,GAAQ;AACnC,SAAO,IAAIqrB,GAAS;AAAA,IAChB,MAAM;AAAA,IACN,SAASE;AAAA,IACT,GAAGzR,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AAcO,MAAMwrB,KAAgC7f,gBAAAA,EAAkB,mBAAmB,CAACzL,GAAMC,MAAQ;AAC7FsrB,EAAAA,GAAsB,KAAKvrB,GAAMC,CAAG,GACpC4gB,EAAQ,KAAK7gB,GAAMC,CAAG;AAC1B,CAAC;AACM,SAASsiB,GAAa5L,GAAMC,GAAO;AACtC,SAAO,IAAI0U,GAAgB;AAAA,IACvB,MAAM;AAAA,IACN,MAAM3U;AAAA,IACN,OAAOC;AAAA,EACf,CAAK;AACL;AA0EO,MAAM4U,KAAwB/f,gBAAAA,EAAkB,WAAW,CAACzL,GAAMC,MAAQ;AAC7EwrB,EAAAA,GAAc,KAAKzrB,GAAMC,CAAG,GAC5B4gB,EAAQ,KAAK7gB,GAAMC,CAAG,GACtBD,EAAK,OAAOC,EAAI,SAChBD,EAAK,UAAU,OAAO,OAAOC,EAAI,OAAO;AACxC,QAAM+T,IAAO,IAAI,IAAI,OAAO,KAAK/T,EAAI,OAAO,CAAC;AAC7C,EAAAD,EAAK,UAAU,CAACyX,GAAQ3X,MAAW;AAC/B,UAAM4rB,IAAa,CAAA;AACnB,eAAWvqB,KAASsW;AAChB,UAAIzD,EAAK,IAAI7S,CAAK;AACd,QAAAuqB,EAAWvqB,CAAK,IAAIlB,EAAI,QAAQkB,CAAK;AAAA;AAGrC,cAAM,IAAI,MAAM,OAAOA,CAAK,oBAAoB;AAExD,WAAO,IAAIqqB,GAAQ;AAAA,MACf,GAAGvrB;AAAA,MACH,QAAQ,CAAE;AAAA,MACV,GAAG2Z,EAAqB9Z,CAAM;AAAA,MAC9B,SAAS4rB;AAAA,IACrB,CAAS;AAAA,EACT,GACI1rB,EAAK,UAAU,CAACyX,GAAQ3X,MAAW;AAC/B,UAAM4rB,IAAa,EAAE,GAAGzrB,EAAI,QAAO;AACnC,eAAWkB,KAASsW;AAChB,UAAIzD,EAAK,IAAI7S,CAAK;AACd,eAAOuqB,EAAWvqB,CAAK;AAAA;AAGvB,cAAM,IAAI,MAAM,OAAOA,CAAK,oBAAoB;AAExD,WAAO,IAAIqqB,GAAQ;AAAA,MACf,GAAGvrB;AAAA,MACH,QAAQ,CAAE;AAAA,MACV,GAAG2Z,EAAqB9Z,CAAM;AAAA,MAC9B,SAAS4rB;AAAA,IACrB,CAAS;AAAA,EACT;AACA,CAAC;AACD,SAASrB,GAAM5S,GAAQ3X,GAAQ;AAC3B,QAAMiB,IAAU,MAAM,QAAQ0W,CAAM,IAAI,OAAO,YAAYA,EAAO,IAAI,CAACxW,MAAM,CAACA,GAAGA,CAAC,CAAC,CAAC,IAAIwW;AACxF,SAAO,IAAI+T,GAAQ;AAAA,IACf,MAAM;AAAA,IACN,SAAAzqB;AAAA,IACA,GAAG6Y,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AA8CO,MAAM6rB,KAA6BlgB,gBAAAA,EAAkB,gBAAgB,CAACzL,GAAMC,MAAQ;AACvF2rB,EAAAA,GAAmB,KAAK5rB,GAAMC,CAAG,GACjC4gB,EAAQ,KAAK7gB,GAAMC,CAAG,GACtBD,EAAK,KAAK,QAAQ,CAAC8L,GAAShE,MAAS;AACjC,QAAIA,EAAK,cAAc;AACnB,YAAM,IAAIgQ,GAAqB9X,EAAK,YAAY,IAAI;AAExD,IAAA8L,EAAQ,WAAW,CAAClF,MAAU;AAC1B,UAAI,OAAOA,KAAU;AACjB,QAAAkF,EAAQ,OAAO,KAAKqN,GAAWvS,GAAOkF,EAAQ,OAAO7L,CAAG,CAAC;AAAA,WAExD;AAED,cAAMqe,IAAS1X;AACf,QAAI0X,EAAO,UACPA,EAAO,WAAW,KACtBA,EAAO,SAASA,EAAO,OAAO,WAC9BA,EAAO,UAAUA,EAAO,QAAQxS,EAAQ,QACxCwS,EAAO,SAASA,EAAO,OAAOte,IAE9B8L,EAAQ,OAAO,KAAKqN,GAAWmF,CAAM,CAAC;AAAA,MACzC;AAAA,IACb;AACQ,UAAMtG,IAAS/X,EAAI,UAAU6L,EAAQ,OAAOA,CAAO;AACnD,WAAIkM,aAAkB,UACXA,EAAO,KAAK,CAACA,OAChBlM,EAAQ,QAAQkM,GACTlM,EACV,KAELA,EAAQ,QAAQkM,GACTlM;AAAA,EACf;AACA,CAAC;AACM,SAAS2W,GAAUliB,GAAI;AAC1B,SAAO,IAAIorB,GAAa;AAAA,IACpB,MAAM;AAAA,IACN,WAAWprB;AAAA,EACnB,CAAK;AACL;AACO,MAAMuqB,KAA4Brf,gBAAAA,EAAkB,eAAe,CAACzL,GAAMC,MAAQ;AACrF4rB,EAAAA,GAAkB,KAAK7rB,GAAMC,CAAG,GAChC4gB,EAAQ,KAAK7gB,GAAMC,CAAG,GACtBD,EAAK,SAAS,MAAMA,EAAK,KAAK,IAAI;AACtC,CAAC;AACM,SAASkiB,GAAS4J,GAAW;AAChC,SAAO,IAAIhB,GAAY;AAAA,IACnB,MAAM;AAAA,IACN,WAAWgB;AAAA,EACnB,CAAK;AACL;AACO,MAAMC,KAA4BtgB,gBAAAA,EAAkB,eAAe,CAACzL,GAAMC,MAAQ;AACrF+rB,EAAAA,GAAkB,KAAKhsB,GAAMC,CAAG,GAChC4gB,EAAQ,KAAK7gB,GAAMC,CAAG,GACtBD,EAAK,SAAS,MAAMA,EAAK,KAAK,IAAI;AACtC,CAAC;AACM,SAASmiB,GAAS2J,GAAW;AAChC,SAAO,IAAIC,GAAY;AAAA,IACnB,MAAM;AAAA,IACN,WAAWD;AAAA,EACnB,CAAK;AACL;AAKO,MAAMG,KAA2BxgB,gBAAAA,EAAkB,cAAc,CAACzL,GAAMC,MAAQ;AACnFisB,EAAAA,GAAiB,KAAKlsB,GAAMC,CAAG,GAC/B4gB,EAAQ,KAAK7gB,GAAMC,CAAG,GACtBD,EAAK,SAAS,MAAMA,EAAK,KAAK,IAAI,WAClCA,EAAK,gBAAgBA,EAAK;AAC9B,CAAC;AACM,SAAS0iB,GAASoJ,GAAWK,GAAc;AAC9C,SAAO,IAAIF,GAAW;AAAA,IAClB,MAAM;AAAA,IACN,WAAWH;AAAA,IACX,IAAI,eAAe;AACf,aAAO,OAAOK,KAAiB,aAAaA,EAAY,IAAKC,GAAkBD,CAAY;AAAA,IAC9F;AAAA,EACT,CAAK;AACL;AACO,MAAME,KAA4B5gB,gBAAAA,EAAkB,eAAe,CAACzL,GAAMC,MAAQ;AACrFqsB,EAAAA,GAAkB,KAAKtsB,GAAMC,CAAG,GAChC4gB,EAAQ,KAAK7gB,GAAMC,CAAG,GACtBD,EAAK,SAAS,MAAMA,EAAK,KAAK,IAAI;AACtC,CAAC;AACM,SAAS2iB,GAASmJ,GAAWK,GAAc;AAC9C,SAAO,IAAIE,GAAY;AAAA,IACnB,MAAM;AAAA,IACN,WAAWP;AAAA,IACX,IAAI,eAAe;AACf,aAAO,OAAOK,KAAiB,aAAaA,EAAY,IAAKC,GAAkBD,CAAY;AAAA,IAC9F;AAAA,EACT,CAAK;AACL;AACO,MAAMnB,KAA+Bvf,gBAAAA,EAAkB,kBAAkB,CAACzL,GAAMC,MAAQ;AAC3FssB,EAAAA,GAAqB,KAAKvsB,GAAMC,CAAG,GACnC4gB,EAAQ,KAAK7gB,GAAMC,CAAG,GACtBD,EAAK,SAAS,MAAMA,EAAK,KAAK,IAAI;AACtC,CAAC;AACM,SAASoiB,GAAY0J,GAAWhsB,GAAQ;AAC3C,SAAO,IAAIkrB,GAAe;AAAA,IACtB,MAAM;AAAA,IACN,WAAWc;AAAA,IACX,GAAGlS,EAAqB9Z,CAAM;AAAA,EACtC,CAAK;AACL;AAYO,MAAM0sB,KAAyB/gB,gBAAAA,EAAkB,YAAY,CAACzL,GAAMC,MAAQ;AAC/EwsB,EAAAA,GAAe,KAAKzsB,GAAMC,CAAG,GAC7B4gB,EAAQ,KAAK7gB,GAAMC,CAAG,GACtBD,EAAK,SAAS,MAAMA,EAAK,KAAK,IAAI,WAClCA,EAAK,cAAcA,EAAK;AAC5B,CAAC;AACD,SAAS4iB,GAAOkJ,GAAWY,GAAY;AACnC,SAAO,IAAIF,GAAS;AAAA,IAChB,MAAM;AAAA,IACN,WAAWV;AAAA,IACX,YAAa,OAAOY,KAAe,aAAaA,IAAa,MAAMA;AAAA,EAC3E,CAAK;AACL;AASO,MAAMC,KAAwBlhB,gBAAAA,EAAkB,WAAW,CAACzL,GAAMC,MAAQ;AAC7E2sB,EAAAA,GAAc,KAAK5sB,GAAMC,CAAG,GAC5B4gB,EAAQ,KAAK7gB,GAAMC,CAAG,GACtBD,EAAK,KAAKC,EAAI,IACdD,EAAK,MAAMC,EAAI;AACnB,CAAC;AACM,SAASuiB,GAAKqK,GAAKC,GAAK;AAC3B,SAAO,IAAIH,GAAQ;AAAA,IACf,MAAM;AAAA,IACN,IAAIE;AAAA,IACJ,KAAKC;AAAA;AAAA,EAEb,CAAK;AACL;AAcO,MAAMC,KAA4BthB,gBAAAA,EAAkB,eAAe,CAACzL,GAAMC,MAAQ;AACrF+sB,EAAAA,GAAkB,KAAKhtB,GAAMC,CAAG,GAChC4gB,EAAQ,KAAK7gB,GAAMC,CAAG,GACtBD,EAAK,SAAS,MAAMA,EAAK,KAAK,IAAI;AACtC,CAAC;AACM,SAAS6iB,GAASiJ,GAAW;AAChC,SAAO,IAAIiB,GAAY;AAAA,IACnB,MAAM;AAAA,IACN,WAAWjB;AAAA,EACnB,CAAK;AACL;AA8CO,MAAMmB,KAA0BxhB,gBAAAA,EAAkB,aAAa,CAACzL,GAAMC,MAAQ;AACjFitB,EAAAA,GAAgB,KAAKltB,GAAMC,CAAG,GAC9B4gB,EAAQ,KAAK7gB,GAAMC,CAAG;AAC1B,CAAC;AAaM,SAAS6hB,GAAOvhB,GAAI8D,IAAU,IAAI;AACrC,SAAO8oB,GAAaF,IAAW1sB,GAAI8D,CAAO;AAC9C;AAEO,SAAS2d,GAAYzhB,GAAI;AAC5B,SAAO6sB,GAAkB7sB,CAAE;AAC/B;AA6BO,SAAS8sB,GAAW9sB,GAAImE,GAAQ;AACnC,SAAO8d,GAAKC,GAAUliB,CAAE,GAAGmE,CAAM;AACrC;ACphCO,SAAS0G,GAAOtL,GAAQ;AAC3B,SAAOwtB,GAAoBC,IAAmBztB,CAAM;AACxD;ACDgB,SAAA0tB,GACZC,GACA/oB,GACAlB,GACF;AACQ,QAAAuE,IAASrD,EAAO,UAAUlB,CAAI;AAEhC,SAACuE,EAAO,UAsBLA,EAAO,QArBVA,EAAO,MAAM,OAAO,QAAQ,CAAC2lB,MAAQ;AACjC,UAAMC,IAAYD,EAAI,KAAK,KAAK,GAAG;AAGnC,IAFmBD,EAAY,cAAcE,CAAoB,IAI7DF,EAAY,SAASE,GAAsB;AAAA,MACvC,MAAM;AAAA,MACN,SAASD,EAAI;AAAA,IAAA,CAChB,IAEDD,EAAY,SAAS,QAAQ;AAAA,MACzB,MAAM;AAAA,MACN,SAASC,EAAI;AAAA,IAAA,CAChB;AAAA,EACL,CACH,GAEM;AAIf;AAKa,MAAAE,KAAmB,CAAClpB,MACtBmpB,GAAa,CAAChsB,MAAQ;AACzB,MAAKA,GAID;AAAA,QAAA,OAAOA,KAAQ,UAAU;AACnB,YAAAisB,IAAS,OAAOjsB,CAAG;AAClB,aAAA,MAAMisB,CAAM,IAAIjsB,IAAMisB;AAAA,IACjC;AAEO,WAAAjsB;AAAA;GACR6C,CAAM,GAMAqpB,KAAiB,CAACrpB,MACpBmpB,GAAa,CAAChsB,MAAQ;AACzB,MAAI,CAACA;AACM;AAGP,MAAA6I;AAUJ,SARI,OAAO7I,KAAQ,aACR6I,IAAA,IAAI,KAAK7I,CAAG,IAGnBA,aAAe,SACR6I,IAAA7I,IAGP6I,KACAA,EAAK,YAAY,GAAG,GAAG,GAAG,CAAC,GACpBA,KAGJ7I;GACR6C,CAAM,GAGAspB,IAAgB,CAACC,MAC1BC,IAEK,IAAI,GAAG,EAAE,OAAO,YAAY,EAC5B,IAAID,GAAK,qBAAqBA,CAAG,aAAa,GAE1CE,KAAe,MACxBC,GAAQ,uBAAuB,EAAE,IAAI,GAAG,UAAU,GAEzCC,KAAwB,MACjCT;AAAA,EACIU,GAAS,uBAAuB,EAAE,SAAS,0BAA0B;AACzE,GAESC,KAAoB,MAC7BR;AAAA,EACIS,GACU,qBAAqB,EAC1B,IAAQ,oBAAA,KAAA,GAAQ,4BAA4B;AACrD,GAESC,IAAY,CAACR,MACtBC,IAAW,IAAID,GAAK,qBAAqBA,CAAG,aAAa,GC7FhDS,KAA6BC,EAAS;AAAA,EAC/C,UAAUX,EAAc,GAAG;AAAA;AAAA,EAC3B,UAAUS,EAAU,GAAG,EAAE,SAAS;AAAA;AAAA,EAClC,MAAMT,EAAc,EAAE;AAAA;AAAA,EACtB,OAAOS,EAAU,EAAE,EAAE,SAAS;AAAA;AAAA,EAC9B,UAAUA,EAAU,EAAE,EAAE,SAAS;AAAA;AAAA,EACjC,SAAST,EAAc,EAAE;AAAA;AAC7B,CAAC,GAwCYY,KAAqBD,EAAS;AAAA,EACvC,QAAQN,GAAsB;AAAA,EAC9B,SAASI,EAAU,GAAG,EAAE,QAAQ;AAAA,EAEhC,gBAAgBT,EAAc,EAAE;AAAA,EAChC,eAAeA,EAAc,EAAE;AAAA,EAC/B,YAAYG,GAAa;AAAA,EACzB,YAAYH,EAAc,EAAE;AAAA,EAC5B,cAAcU;AAAA;AAAA,EAEd,YAAYV,EAAc,GAAG;AAAA,EAC7B,oBAAoBS,EAAU,EAAE,EAAE,QAAQ;AAAA,EAC1C,mBAAmBA,EAAU,EAAE,EAAE,QAAQ;AAAA,EACzC,gBAAgBL,GAAQ,uBAAuB,EAAE,QAAQ;AAAA,EACzD,gBAAgBK,EAAU,EAAE,EAAE,QAAQ;AAC1C,CAAC,GAKYI,KAAoBD,GAAmB,OAAO;AAAA,EACvD,QAAQL,GAAkB;AAAA,EAC1B,OAAOE,EAAU,GAAG,EAAE,QAAQ;AAClC,CAAC,GAYYK,KAAqBH,EAAS;AAAA,EACvC,SAASN,GAAsB;AAAA,EAC/B,QAAQE,GAAkB;AAAA,EAC1B,SAASE,EAAU,GAAG,EAAE,QAAQ;AAAA,EAChC,OAAOA,EAAU,GAAG,EAAE,QAAQ;AAAA,EAE9B,gBAAgBT,EAAc,EAAE;AAAA,EAChC,eAAeA,EAAc,EAAE;AAAA,EAC/B,YAAYG,GAAa;AAAA,EACzB,YAAYH,EAAc,EAAE;AAAA,EAE5B,YAAYA,EAAc,GAAG;AAAA,EAC7B,gBAAgBI,GAAQ,uBAAuB,EAAE,QAAQ;AAAA,EACzD,gBAAgBK,EAAU,EAAE,EAAE,QAAQ;AAC1C,CAAC;AAOW,IAAAM,uBAAAA,OACRA,EAAA,cAAc,eACdA,EAAA,mBAAmB,oBAFXA,IAAAA,MAAA,CAAA,CAAA;AAQC,MAAAC,KAA6BL,EAAS;AAAA,EAC/C,WAAWL,GAAE,EAAS,IAAA,EAAM,SAAS;AAAA,EACrC,QAAQD,GAAsB;AAAA,EAC9B,UAAUL,EAAc,CAAC,EAAE,QAAQ,KAAK;AAC5C,CAAC,GAaYiB,KAA6BN,EAAS;AAAA,EAC/C,WAAWX,EAAc,GAAG;AAAA,EAC5B,YAAYA,EAAc,EAAE;AAAA,EAC5B,cAAcS,EAAU,GAAG,EAAE,SAAS;AAC1C,CAAC,GAKYS,KAA+BP,EAAS;AAAA,EACjD,YAAYX,EAAc,GAAG;AAAA,EAC7B,iBAAiBS,EAAU,GAAG;AAAA,EAC9B,cAAcA,EAAU,GAAG;AAAA,EAC3B,YAAYA,EAAU,CAAC;AAAA;AAC3B,CAAC,GAMYU,KAAyBP,GAAmB,OAAO;AAAA,EAC5D,WAAWN,GAAE,EAAS,IAAA,EAAM,SAAS;AAAA,EACrC,cAAcc,GAAU,EAAE,QAAQ,EAAI;AAAA;AAAA,EAGtC,SAASH,GAA2B,SAAS;AAAA;AAAA,EAG7C,oBAAoBC,GAA6B,SAAS;AAC9D,CAAC,GAYYG,KAAuBV,EAAS;AAAA,EACzC,YAAYL,GAAE,EAAS,IAAA,EAAM,SAAS;AAAA,EACtC,QAAQG,EAAU,GAAG,EAAE,SAAS;AACpC,CAAC,GASYa,KAAyBX,EAAS;AAAA,EAC3C,WAAWL,GAAS,EAAE,IAAM,EAAA,SAAA,EAAW,QAAQ;AAAA,EAC/C,MAAMN,EAAc,EAAE;AAAA,EACtB,UAAUA,EAAc,EAAE;AAC9B,CAAC,GAIYuB,KAAuBD,GAAuB,OAAO;AAAA,EAC9D,QAAQjB,GAAsB;AAAA,EAC9B,aAAaL,EAAc,GAAG;AAClC,CAAC;AAIW,IAAAwB,uBAAAA,OACRA,EAAA,QAAQ,SADAA,IAAAA,MAAA,CAAA,CAAA,GAIAC,uBAAAA,OACRA,EAAA,UAAU,WACVA,EAAA,aAAa,cACbA,EAAA,WAAW,YACXA,EAAA,SAAS,UACTA,EAAA,WAAW,YALHA,IAAAA,MAAA,CAAA,CAAA,GAQAC,uBAAAA,OACRA,EAAA,aAAa,cACbA,EAAA,UAAU,WACVA,EAAA,YAAY,aACZA,EAAA,UAAU,WACVA,EAAA,WAAW,YACXA,EAAA,QAAQ,SACRA,EAAA,kBAAkB,mBAClBA,EAAA,mBAAmB,oBARXA,IAAAA,MAAA,CAAA,CAAA,GAWAC,uBAAAA,OACRA,EAAA,gBAAgB,iBAChBA,EAAA,UAAU,WACVA,EAAA,SAAS,UACTA,EAAA,eAAe,gBACfA,EAAA,gBAAgB,iBAChBA,EAAA,iBAAiB,kBANTA,IAAAA,MAAA,CAAA,CAAA,GASAC,uBAAAA,OACRA,EAAA,WAAW,YACXA,EAAA,aAAa,cACbA,EAAA,aAAa,cAHLA,IAAAA,MAAA,CAAA,CAAA,GAMAC,uBAAAA,OACRA,EAAA,UAAU,WACVA,EAAA,WAAW,YACXA,EAAA,YAAY,aACZA,EAAA,UAAU,WAJFA,IAAAA,MAAA,CAAA,CAAA;AAsCC,MAAAC,KAAoCnB,EAAS;AAAA,EACtD,MAAMX,EAAc,EAAE;AAAA,EACtB,OAAOA,EAAc,GAAG;AAC5B,CAAC,GASY+B,KAAkCpB,EAAS;AAAA,EACpD,WAAWL,GAAE,EAAS,IAAA,EAAM,SAAS;AAAA,EACrC,MAAMN,EAAc,EAAE;AAAA,EACtB,OAAOA,EAAc,GAAG;AAC5B,CAAC,GA0BYgC,KAAyBrB,EAAS;AAAA,EAC3C,WAAWsB,KAAkB,IAAA,EAAM,SAAS;AAChD,CAAC,GAOYC,KAA4BvB,EAAS;AAAA,EAC9C,qBAAqBwB,GAAO;AAAA,IACxB;AAAA,IACA;AAAA;AAAA,EAAA,CACH;AACL,CAAC,GAUYC,KAA0BzB,EAAS;AAAA,EAC5C,iBAAiBX,EAAc,GAAG;AAAA,EAClC,WAAWA,EAAc,GAAG;AAAA,EAC5B,QAAQS,EAAU,GAAG,EAAE,SAAS;AAAA,EAChC,gBAAgBA,EAAU,GAAG,EAAE,SAAS;AAC5C,CAAC,GClWY4B,KAA6B1B,EAAS;AAAA,EAC/C,YAAYT,IAAW,SAAS,EAAE,QAAQ,eAAe;AAAA,EACzD,WAAWoC,GAAO;AAAA,EAClB,eAAepC,EAAS;AAAA,EACxB,eAAeA,EAAS;AAAA,EACxB,OAAOA,EAAS,EAAE,SAAS;AAC/B,CAAC,GAqBYqC,KAA8B5B,EAAS;AAAA,EAChD,OAAOP,GAAQ;AAAA,EACf,WAAWF,IAAW,IAAI,GAAG,EAAE,SAAS;AAAA,EACxC,UAAUA,IAAW,IAAI,GAAG,EAAE,SAAS;AAAA,EACvC,OAAOA,IAAW,IAAI,EAAE,EAAE,SAAS;AAAA,EACnC,QAAQsC,GAAQtC,EAAU,CAAA,EAAE,SAAS;AACzC,CAAC;AChCW,IAAAuC,uBAAAA,OACRA,EAAA,WAAW,YACXA,EAAA,QAAQ,SACRA,EAAA,OAAO,QACPA,EAAA,OAAO,QAJCA,IAAAA,MAAA,CAAA,CAAA,GAUAC,uBAAAA,OACRA,EAAA,QAAQ,eACRA,EAAA,WAAW,YACXA,EAAA,QAAQ,SAHAA,IAAAA,MAAA,CAAA,CAAA,GASAC,uBAAAA,OACRA,EAAA,UAAU,WACVA,EAAA,gBAAgB,uBAChBA,EAAA,eAAe,uBACfA,EAAA,eAAe,yBACfA,EAAA,cAAc,wBACdA,EAAA,UAAU,iBACVA,EAAA,cAAc,gBACdA,EAAA,aAAa,0BACbA,EAAA,WAAW,uBACXA,EAAA,UAAU,WACVA,EAAA,QAAQ,kBACRA,EAAA,cAAc,yBAZNA,IAAAA,MAAA,CAAA,CAAA;ACfC,MAAAC,KAAiC,CAACC,MAAwC;AACnF,MAAIC,IAAQ;AAEZ,QAAMC,IAAY,OAAO,OAAOF,EAAY,SAAS;AAErD,aAAWzxB,KAAQ2xB,GAAW;AAC1B,UAAMC,IAAc,OAAO,KAAK5xB,EAAK,MAAM;AAE3C,eAAW6xB,KAASD;AACP,MAAAF,KAAA1xB,EAAK,OAAO6xB,CAAK,EAAE;AAAA,EAEpC;AAEO,SAAAH;AACX;ACrBA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAcA,IAAII,KAAY,MAIdC,KAAa,KAGbC,KAAW,oBAGXC,KAAO,sgCAGPC,KAAK,sgCAILC,KAAW;AAAA;AAAA;AAAA;AAAA;AAAA,EAOT,WAAW;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAiBX,UAAU;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAeV,QAAQ;AAAA;AAAA;AAAA;AAAA,EAIR,UAAU;AAAA;AAAA;AAAA;AAAA,EAIV,UAAW;AAAA;AAAA;AAAA;AAAA,EAIX,MAAM,CAACL;AAAA;AAAA;AAAA;AAAA,EAIP,MAAMA;AAAA;AAAA;AAAA,EAGN,QAAQ;AAAA;AACT,GAMDM,IAASC,GACTC,IAAW,IAEXC,KAAe,mBACfC,KAAkBD,KAAe,sBACjCE,KAAyBF,KAAe,4BACxCG,KAAoBH,KAAe,sBACnCI,KAAM,oBAENC,IAAY,KAAK,OACjBC,IAAU,KAAK,KAEfC,KAAW,8CACXC,KAAQ,0DACRC,KAAU,iDACVC,KAAY,sCAEZC,IAAO,KACPC,IAAW,GACXC,KAAmB,kBAEnBC,KAAiBpB,GAAK,SAAS,GAC/BqB,KAAepB,GAAG,SAAS,GAG3BqB,IAAI,EAAE,aAAaZ;AA0ErBY,EAAE,gBAAgBA,EAAE,MAAM,WAAY;AACpC,MAAIhtB,IAAI,IAAI,KAAK,YAAY,IAAI;AACjC,SAAIA,EAAE,IAAI,MAAGA,EAAE,IAAI,IACZitB,EAASjtB,CAAC;AACnB;AAQAgtB,EAAE,OAAO,WAAY;AACnB,SAAOC,EAAS,IAAI,KAAK,YAAY,IAAI,GAAG,KAAK,IAAI,GAAG,CAAC;AAC3D;AAWAD,EAAE,YAAYA,EAAE,QAAQ,SAAUE,GAAK5E,GAAK;AAC1C,MAAI9tB,GACFwF,IAAI,MACJmtB,IAAOntB,EAAE;AAGX,MAFAktB,IAAM,IAAIC,EAAKD,CAAG,GAClB5E,IAAM,IAAI6E,EAAK7E,CAAG,GACd,CAAC4E,EAAI,KAAK,CAAC5E,EAAI;AAAG,WAAO,IAAI6E,EAAK,GAAG;AACzC,MAAID,EAAI,GAAG5E,CAAG;AAAG,UAAM,MAAM2D,KAAkB3D,CAAG;AAClD,SAAA9tB,IAAIwF,EAAE,IAAIktB,CAAG,GACN1yB,IAAI,IAAI0yB,IAAMltB,EAAE,IAAIsoB,CAAG,IAAI,IAAIA,IAAM,IAAI6E,EAAKntB,CAAC;AACxD;AAWAgtB,EAAE,aAAaA,EAAE,MAAM,SAAUI,GAAG;AAClC,MAAIltB,GAAGmtB,GAAGC,GAAKC,GACbvtB,IAAI,MACJwtB,IAAKxtB,EAAE,GACPytB,KAAML,IAAI,IAAIptB,EAAE,YAAYotB,CAAC,GAAG,GAChCM,IAAK1tB,EAAE,GACP2tB,IAAKP,EAAE;AAGT,MAAI,CAACI,KAAM,CAACC;AACV,WAAO,CAACC,KAAM,CAACC,IAAK,MAAMD,MAAOC,IAAKD,IAAKF,MAAOC,IAAK,IAAI,CAACD,IAAKE,IAAK,IAAI,IAAI;AAIhF,MAAI,CAACF,EAAG,CAAC,KAAK,CAACC,EAAG,CAAC;AAAG,WAAOD,EAAG,CAAC,IAAIE,IAAKD,EAAG,CAAC,IAAI,CAACE,IAAK;AAGxD,MAAID,MAAOC;AAAI,WAAOD;AAGtB,MAAI1tB,EAAE,MAAMotB,EAAE;AAAG,WAAOptB,EAAE,IAAIotB,EAAE,IAAIM,IAAK,IAAI,IAAI;AAMjD,OAJAJ,IAAME,EAAG,QACTD,IAAME,EAAG,QAGJvtB,IAAI,GAAGmtB,IAAIC,IAAMC,IAAMD,IAAMC,GAAKrtB,IAAImtB,GAAG,EAAEntB;AAC9C,QAAIstB,EAAGttB,CAAC,MAAMutB,EAAGvtB,CAAC;AAAG,aAAOstB,EAAGttB,CAAC,IAAIutB,EAAGvtB,CAAC,IAAIwtB,IAAK,IAAI,IAAI;AAI3D,SAAOJ,MAAQC,IAAM,IAAID,IAAMC,IAAMG,IAAK,IAAI,IAAI;AACpD;AAgBAV,EAAE,SAASA,EAAE,MAAM,WAAY;AAC7B,MAAIY,GAAIC,GACN7tB,IAAI,MACJmtB,IAAOntB,EAAE;AAEX,SAAKA,EAAE,IAGFA,EAAE,EAAE,CAAC,KAEV4tB,IAAKT,EAAK,WACVU,IAAKV,EAAK,UACVA,EAAK,YAAYS,IAAK,KAAK,IAAI5tB,EAAE,GAAGA,EAAE,GAAI,CAAA,IAAI4sB,GAC9CO,EAAK,WAAW,GAEhBntB,IAAI8tB,GAAOX,GAAMY,GAAiBZ,GAAMntB,CAAC,CAAC,GAE1CmtB,EAAK,YAAYS,GACjBT,EAAK,WAAWU,GAETZ,EAASnB,KAAY,KAAKA,KAAY,IAAI9rB,EAAE,IAAG,IAAKA,GAAG4tB,GAAIC,GAAI,EAAI,KAZtD,IAAIV,EAAK,CAAC,IAHb,IAAIA,EAAK,GAAG;AAgB/B;AAmBAH,EAAE,WAAWA,EAAE,OAAO,WAAY;AAChC,MAAI,GAAGgB,GAAGC,GAAG,GAAGC,GAAKC,GAAGC,GAAIxf,GAAGyf,GAAIC,GACjCtuB,IAAI,MACJmtB,IAAOntB,EAAE;AAEX,MAAI,CAACA,EAAE,SAAQ,KAAMA,EAAE,OAAM;AAAI,WAAO,IAAImtB,EAAKntB,CAAC;AAoClD,OAnCA+rB,IAAW,IAGXoC,IAAInuB,EAAE,IAAIssB,EAAQtsB,EAAE,IAAIA,GAAG,IAAI,CAAC,GAI5B,CAACmuB,KAAK,KAAK,IAAIA,CAAC,KAAK,IAAI,KAC3BF,IAAIM,EAAevuB,EAAE,CAAC,GACtB,IAAIA,EAAE,IAGFmuB,KAAK,IAAIF,EAAE,SAAS,KAAK,OAAGA,KAAME,KAAK,KAAKA,KAAK,KAAK,MAAM,OAChEA,IAAI7B,EAAQ2B,GAAG,IAAI,CAAC,GAGpB,IAAI5B,GAAW,IAAI,KAAK,CAAC,KAAK,IAAI,MAAM,IAAI,IAAI,KAAK,KAEjD8B,KAAK,IAAI,IACXF,IAAI,OAAO,KAEXA,IAAIE,EAAE,iBACNF,IAAIA,EAAE,MAAM,GAAGA,EAAE,QAAQ,GAAG,IAAI,CAAC,IAAI,IAGvC,IAAI,IAAId,EAAKc,CAAC,GACd,EAAE,IAAIjuB,EAAE,KAER,IAAI,IAAImtB,EAAKgB,EAAE,SAAU,CAAA,GAG3BC,KAAM,IAAIjB,EAAK,aAAa;AAW1B,QANAve,IAAI,GACJyf,IAAKzf,EAAE,MAAMA,CAAC,EAAE,MAAMA,CAAC,GACvB0f,IAAUD,EAAG,KAAKruB,CAAC,GACnB,IAAIwuB,EAAOF,EAAQ,KAAKtuB,CAAC,EAAE,MAAM4O,CAAC,GAAG0f,EAAQ,KAAKD,CAAE,GAAGD,IAAK,GAAG,CAAC,GAG5DG,EAAe3f,EAAE,CAAC,EAAE,MAAM,GAAGwf,CAAE,OAAOH,IAAIM,EAAe,EAAE,CAAC,GAAG,MAAM,GAAGH,CAAE;AAK5E,UAJAH,IAAIA,EAAE,MAAMG,IAAK,GAAGA,IAAK,CAAC,GAItBH,KAAK,UAAU,CAACC,KAAOD,KAAK,QAAQ;AAItC,YAAI,CAACC,MACHjB,EAASre,GAAG,IAAI,GAAG,CAAC,GAEhBA,EAAE,MAAMA,CAAC,EAAE,MAAMA,CAAC,EAAE,GAAG5O,CAAC,IAAG;AAC7B,cAAI4O;AACJ;AAAA,QACD;AAGH,QAAAwf,KAAM,GACNF,IAAM;AAAA,MACd,OAAa;AAIL,SAAI,CAAC,CAACD,KAAK,CAAC,CAACA,EAAE,MAAM,CAAC,KAAKA,EAAE,OAAO,CAAC,KAAK,SAGxChB,EAAS,GAAG,IAAI,GAAG,CAAC,GACpBe,IAAI,CAAC,EAAE,MAAM,CAAC,EAAE,MAAM,CAAC,EAAE,GAAGhuB,CAAC;AAG/B;AAAA,MACD;AAIL,SAAA+rB,IAAW,IAEJkB,EAAS,GAAG,GAAGE,EAAK,UAAUa,CAAC;AACxC;AAOAhB,EAAE,gBAAgBA,EAAE,KAAK,WAAY;AACnC,MAAIyB,GACFC,IAAI,KAAK,GACTT,IAAI;AAEN,MAAIS,GAAG;AAML,QALAD,IAAIC,EAAE,SAAS,GACfT,KAAKQ,IAAIpC,EAAU,KAAK,IAAIO,CAAQ,KAAKA,GAGzC6B,IAAIC,EAAED,CAAC,GACHA;AAAG,aAAOA,IAAI,MAAM,GAAGA,KAAK;AAAI,QAAAR;AACpC,IAAIA,IAAI,MAAGA,IAAI;AAAA,EAChB;AAED,SAAOA;AACT;AAwBAjB,EAAE,YAAYA,EAAE,MAAM,SAAUI,GAAG;AACjC,SAAOoB,EAAO,MAAM,IAAI,KAAK,YAAYpB,CAAC,CAAC;AAC7C;AAQAJ,EAAE,qBAAqBA,EAAE,WAAW,SAAUI,GAAG;AAC/C,MAAIptB,IAAI,MACNmtB,IAAOntB,EAAE;AACX,SAAOitB,EAASuB,EAAOxuB,GAAG,IAAImtB,EAAKC,CAAC,GAAG,GAAG,GAAG,CAAC,GAAGD,EAAK,WAAWA,EAAK,QAAQ;AAChF;AAOAH,EAAE,SAASA,EAAE,KAAK,SAAUI,GAAG;AAC7B,SAAO,KAAK,IAAIA,CAAC,MAAM;AACzB;AAQAJ,EAAE,QAAQ,WAAY;AACpB,SAAOC,EAAS,IAAI,KAAK,YAAY,IAAI,GAAG,KAAK,IAAI,GAAG,CAAC;AAC3D;AAQAD,EAAE,cAAcA,EAAE,KAAK,SAAUI,GAAG;AAClC,SAAO,KAAK,IAAIA,CAAC,IAAI;AACvB;AAQAJ,EAAE,uBAAuBA,EAAE,MAAM,SAAUI,GAAG;AAC5C,MAAI5yB,IAAI,KAAK,IAAI4yB,CAAC;AAClB,SAAO5yB,KAAK,KAAKA,MAAM;AACzB;AA4BAwyB,EAAE,mBAAmBA,EAAE,OAAO,WAAY;AACxC,MAAIxyB,GAAG,GAAGozB,GAAIC,GAAIvJ,GAChBtkB,IAAI,MACJmtB,IAAOntB,EAAE,aACT2uB,IAAM,IAAIxB,EAAK,CAAC;AAElB,MAAI,CAACntB,EAAE,SAAU;AAAE,WAAO,IAAImtB,EAAKntB,EAAE,IAAI,IAAI,IAAI,GAAG;AACpD,MAAIA,EAAE;AAAU,WAAO2uB;AAEvB,EAAAf,IAAKT,EAAK,WACVU,IAAKV,EAAK,UACVA,EAAK,YAAYS,IAAK,KAAK,IAAI5tB,EAAE,GAAGA,EAAE,GAAI,CAAA,IAAI,GAC9CmtB,EAAK,WAAW,GAChB7I,IAAMtkB,EAAE,EAAE,QAONskB,IAAM,MACR9pB,IAAI,KAAK,KAAK8pB,IAAM,CAAC,GACrB,KAAK,IAAIsK,GAAQ,GAAGp0B,CAAC,GAAG,eAExBA,IAAI,IACJ,IAAI,iCAGNwF,IAAI6uB,GAAa1B,GAAM,GAAGntB,EAAE,MAAM,CAAC,GAAG,IAAImtB,EAAK,CAAC,GAAG,EAAI;AAMvD,WAHI2B,GACF5uB,IAAI1F,GACJu0B,IAAK,IAAI5B,EAAK,CAAC,GACVjtB;AACL,IAAA4uB,IAAU9uB,EAAE,MAAMA,CAAC,GACnBA,IAAI2uB,EAAI,MAAMG,EAAQ,MAAMC,EAAG,MAAMD,EAAQ,MAAMC,CAAE,CAAC,CAAC,CAAC;AAG1D,SAAO9B,EAASjtB,GAAGmtB,EAAK,YAAYS,GAAIT,EAAK,WAAWU,GAAI,EAAI;AAClE;AAiCAb,EAAE,iBAAiBA,EAAE,OAAO,WAAY;AACtC,MAAIxyB,GAAGozB,GAAIC,GAAIvJ,GACbtkB,IAAI,MACJmtB,IAAOntB,EAAE;AAEX,MAAI,CAACA,EAAE,SAAQ,KAAMA,EAAE,OAAM;AAAI,WAAO,IAAImtB,EAAKntB,CAAC;AAQlD,MANA4tB,IAAKT,EAAK,WACVU,IAAKV,EAAK,UACVA,EAAK,YAAYS,IAAK,KAAK,IAAI5tB,EAAE,GAAGA,EAAE,GAAI,CAAA,IAAI,GAC9CmtB,EAAK,WAAW,GAChB7I,IAAMtkB,EAAE,EAAE,QAENskB,IAAM;AACR,IAAAtkB,IAAI6uB,GAAa1B,GAAM,GAAGntB,GAAGA,GAAG,EAAI;AAAA,OAC/B;AAWL,IAAAxF,IAAI,MAAM,KAAK,KAAK8pB,CAAG,GACvB9pB,IAAIA,IAAI,KAAK,KAAKA,IAAI,GAEtBwF,IAAIA,EAAE,MAAM,IAAI4uB,GAAQ,GAAGp0B,CAAC,CAAC,GAC7BwF,IAAI6uB,GAAa1B,GAAM,GAAGntB,GAAGA,GAAG,EAAI;AAOpC,aAJIgvB,GACFC,IAAK,IAAI9B,EAAK,CAAC,GACf+B,IAAM,IAAI/B,EAAK,EAAE,GACjBgC,IAAM,IAAIhC,EAAK,EAAE,GACZ3yB;AACL,MAAAw0B,IAAUhvB,EAAE,MAAMA,CAAC,GACnBA,IAAIA,EAAE,MAAMivB,EAAG,KAAKD,EAAQ,MAAME,EAAI,MAAMF,CAAO,EAAE,KAAKG,CAAG,CAAC,CAAC,CAAC;AAAA,EAEnE;AAED,SAAAhC,EAAK,YAAYS,GACjBT,EAAK,WAAWU,GAETZ,EAASjtB,GAAG4tB,GAAIC,GAAI,EAAI;AACjC;AAmBAb,EAAE,oBAAoBA,EAAE,OAAO,WAAY;AACzC,MAAIY,GAAIC,GACN7tB,IAAI,MACJmtB,IAAOntB,EAAE;AAEX,SAAKA,EAAE,SAAU,IACbA,EAAE,OAAQ,IAAS,IAAImtB,EAAKntB,CAAC,KAEjC4tB,IAAKT,EAAK,WACVU,IAAKV,EAAK,UACVA,EAAK,YAAYS,IAAK,GACtBT,EAAK,WAAW,GAETqB,EAAOxuB,EAAE,KAAM,GAAEA,EAAE,KAAI,GAAImtB,EAAK,YAAYS,GAAIT,EAAK,WAAWU,CAAE,KAR/C,IAAIV,EAAKntB,EAAE,CAAC;AASxC;AAsBAgtB,EAAE,gBAAgBA,EAAE,OAAO,WAAY;AACrC,MAAIoC,GACFpvB,IAAI,MACJmtB,IAAOntB,EAAE,aACTxF,IAAIwF,EAAE,MAAM,IAAI,CAAC,GACjB4tB,IAAKT,EAAK,WACVU,IAAKV,EAAK;AAEZ,SAAI3yB,MAAM,KACDA,MAAM,IAETwF,EAAE,UAAUqvB,EAAMlC,GAAMS,GAAIC,CAAE,IAAI,IAAIV,EAAK,CAAC,IAE5C,IAAIA,EAAK,GAAG,IAGdntB,EAAE,WAAiBqvB,EAAMlC,GAAMS,IAAK,GAAGC,CAAE,EAAE,MAAM,GAAG,KAIxDV,EAAK,YAAYS,IAAK,GACtBT,EAAK,WAAW,GAEhBntB,IAAIA,EAAE,QACNovB,IAASC,EAAMlC,GAAMS,IAAK,GAAGC,CAAE,EAAE,MAAM,GAAG,GAE1CV,EAAK,YAAYS,GACjBT,EAAK,WAAWU,GAETuB,EAAO,MAAMpvB,CAAC;AACvB;AAsBAgtB,EAAE,0BAA0BA,EAAE,QAAQ,WAAY;AAChD,MAAIY,GAAIC,GACN7tB,IAAI,MACJmtB,IAAOntB,EAAE;AAEX,SAAIA,EAAE,IAAI,CAAC,IAAU,IAAImtB,EAAKntB,EAAE,GAAG,CAAC,IAAI,IAAI,GAAG,IAC1CA,EAAE,SAAQ,KAEf4tB,IAAKT,EAAK,WACVU,IAAKV,EAAK,UACVA,EAAK,YAAYS,IAAK,KAAK,IAAI,KAAK,IAAI5tB,EAAE,CAAC,GAAGA,EAAE,GAAI,CAAA,IAAI,GACxDmtB,EAAK,WAAW,GAChBpB,IAAW,IAEX/rB,IAAIA,EAAE,MAAMA,CAAC,EAAE,MAAM,CAAC,EAAE,KAAI,EAAG,KAAKA,CAAC,GAErC+rB,IAAW,IACXoB,EAAK,YAAYS,GACjBT,EAAK,WAAWU,GAET7tB,EAAE,QAdiB,IAAImtB,EAAKntB,CAAC;AAetC;AAmBAgtB,EAAE,wBAAwBA,EAAE,QAAQ,WAAY;AAC9C,MAAIY,GAAIC,GACN7tB,IAAI,MACJmtB,IAAOntB,EAAE;AAEX,SAAI,CAACA,EAAE,SAAQ,KAAMA,EAAE,OAAM,IAAW,IAAImtB,EAAKntB,CAAC,KAElD4tB,IAAKT,EAAK,WACVU,IAAKV,EAAK,UACVA,EAAK,YAAYS,IAAK,IAAI,KAAK,IAAI,KAAK,IAAI5tB,EAAE,CAAC,GAAGA,EAAE,GAAI,CAAA,IAAI,GAC5DmtB,EAAK,WAAW,GAChBpB,IAAW,IAEX/rB,IAAIA,EAAE,MAAMA,CAAC,EAAE,KAAK,CAAC,EAAE,KAAI,EAAG,KAAKA,CAAC,GAEpC+rB,IAAW,IACXoB,EAAK,YAAYS,GACjBT,EAAK,WAAWU,GAET7tB,EAAE;AACX;AAsBAgtB,EAAE,2BAA2BA,EAAE,QAAQ,WAAY;AACjD,MAAIY,GAAIC,GAAIyB,GAAKC,GACfvvB,IAAI,MACJmtB,IAAOntB,EAAE;AAEX,SAAKA,EAAE,SAAQ,IACXA,EAAE,KAAK,IAAU,IAAImtB,EAAKntB,EAAE,IAAG,EAAG,GAAG,CAAC,IAAIA,EAAE,IAAI,IAAIA,EAAE,WAAWA,IAAI,GAAG,KAE5E4tB,IAAKT,EAAK,WACVU,IAAKV,EAAK,UACVoC,IAAMvvB,EAAE,MAEJ,KAAK,IAAIuvB,GAAK3B,CAAE,IAAI,IAAI,CAAC5tB,EAAE,IAAI,IAAUitB,EAAS,IAAIE,EAAKntB,CAAC,GAAG4tB,GAAIC,GAAI,EAAI,KAE/EV,EAAK,YAAYmC,IAAMC,IAAMvvB,EAAE,GAE/BA,IAAIwuB,EAAOxuB,EAAE,KAAK,CAAC,GAAG,IAAImtB,EAAK,CAAC,EAAE,MAAMntB,CAAC,GAAGsvB,IAAM1B,GAAI,CAAC,GAEvDT,EAAK,YAAYS,IAAK,GACtBT,EAAK,WAAW,GAEhBntB,IAAIA,EAAE,MAENmtB,EAAK,YAAYS,GACjBT,EAAK,WAAWU,GAET7tB,EAAE,MAAM,GAAG,MArBQ,IAAImtB,EAAK,GAAG;AAsBxC;AAwBAH,EAAE,cAAcA,EAAE,OAAO,WAAY;AACnC,MAAIoC,GAAQ50B,GACVozB,GAAIC,GACJ7tB,IAAI,MACJmtB,IAAOntB,EAAE;AAEX,SAAIA,EAAE,OAAQ,IAAS,IAAImtB,EAAKntB,CAAC,KAEjCxF,IAAIwF,EAAE,IAAK,EAAC,IAAI,CAAC,GACjB4tB,IAAKT,EAAK,WACVU,IAAKV,EAAK,UAEN3yB,MAAM,KAGJA,MAAM,KACR40B,IAASC,EAAMlC,GAAMS,IAAK,GAAGC,CAAE,EAAE,MAAM,GAAG,GAC1CuB,EAAO,IAAIpvB,EAAE,GACNovB,KAIF,IAAIjC,EAAK,GAAG,KAKrBA,EAAK,YAAYS,IAAK,GACtBT,EAAK,WAAW,GAEhBntB,IAAIA,EAAE,IAAI,IAAImtB,EAAK,CAAC,EAAE,MAAMntB,EAAE,MAAMA,CAAC,CAAC,EAAE,KAAM,EAAC,KAAK,CAAC,CAAC,EAAE,QAExDmtB,EAAK,YAAYS,GACjBT,EAAK,WAAWU,GAET7tB,EAAE,MAAM,CAAC;AAClB;AAqBAgtB,EAAE,iBAAiBA,EAAE,OAAO,WAAY;AACtC,MAAI9sB,GAAGmtB,GAAG7yB,GAAGyzB,GAAGuB,GAAI5gB,GAAG3F,GAAGqmB,GAAKG,GAC7BzvB,IAAI,MACJmtB,IAAOntB,EAAE,aACT4tB,IAAKT,EAAK,WACVU,IAAKV,EAAK;AAEZ,MAAKntB,EAAE,YAOA;AAAA,QAAIA,EAAE;AACX,aAAO,IAAImtB,EAAKntB,CAAC;AACZ,QAAIA,EAAE,MAAM,GAAG,CAAC,KAAK4tB,IAAK,KAAKb;AACpC,aAAA9jB,IAAIomB,EAAMlC,GAAMS,IAAK,GAAGC,CAAE,EAAE,MAAM,IAAI,GACtC5kB,EAAE,IAAIjJ,EAAE,GACDiJ;AAAA,SAZU;AACjB,QAAI,CAACjJ,EAAE;AAAG,aAAO,IAAImtB,EAAK,GAAG;AAC7B,QAAIS,IAAK,KAAKb;AACZ,aAAA9jB,IAAIomB,EAAMlC,GAAMS,IAAK,GAAGC,CAAE,EAAE,MAAM,GAAG,GACrC5kB,EAAE,IAAIjJ,EAAE,GACDiJ;AAAA,EAEb;AAmBE,OAXAkkB,EAAK,YAAYmC,IAAM1B,IAAK,IAC5BT,EAAK,WAAW,GAQhB3yB,IAAI,KAAK,IAAI,IAAI80B,IAAM1C,IAAW,IAAI,CAAC,GAElC1sB,IAAI1F,GAAG0F,GAAG,EAAEA;AAAG,IAAAF,IAAIA,EAAE,IAAIA,EAAE,MAAMA,CAAC,EAAE,KAAK,CAAC,EAAE,KAAI,EAAG,KAAK,CAAC,CAAC;AAW/D,OATA+rB,IAAW,IAEXsB,IAAI,KAAK,KAAKiC,IAAM1C,CAAQ,GAC5BqB,IAAI,GACJwB,IAAKzvB,EAAE,MAAMA,CAAC,GACdiJ,IAAI,IAAIkkB,EAAKntB,CAAC,GACdwvB,IAAKxvB,GAGEE,MAAM;AAOX,QANAsvB,IAAKA,EAAG,MAAMC,CAAE,GAChB7gB,IAAI3F,EAAE,MAAMumB,EAAG,IAAIvB,KAAK,CAAC,CAAC,GAE1BuB,IAAKA,EAAG,MAAMC,CAAE,GAChBxmB,IAAI2F,EAAE,KAAK4gB,EAAG,IAAIvB,KAAK,CAAC,CAAC,GAErBhlB,EAAE,EAAEokB,CAAC,MAAM;AAAQ,WAAKntB,IAAImtB,GAAGpkB,EAAE,EAAE/I,CAAC,MAAM0O,EAAE,EAAE1O,CAAC,KAAKA;AAAK;AAG/D,SAAI1F,MAAGyO,IAAIA,EAAE,MAAM,KAAMzO,IAAI,CAAE,IAE/BuxB,IAAW,IAEJkB,EAAShkB,GAAGkkB,EAAK,YAAYS,GAAIT,EAAK,WAAWU,GAAI,EAAI;AAClE;AAOAb,EAAE,WAAW,WAAY;AACvB,SAAO,CAAC,CAAC,KAAK;AAChB;AAOAA,EAAE,YAAYA,EAAE,QAAQ,WAAY;AAClC,SAAO,CAAC,CAAC,KAAK,KAAKX,EAAU,KAAK,IAAIO,CAAQ,IAAI,KAAK,EAAE,SAAS;AACpE;AAOAI,EAAE,QAAQ,WAAY;AACpB,SAAO,CAAC,KAAK;AACf;AAOAA,EAAE,aAAaA,EAAE,QAAQ,WAAY;AACnC,SAAO,KAAK,IAAI;AAClB;AAOAA,EAAE,aAAaA,EAAE,QAAQ,WAAY;AACnC,SAAO,KAAK,IAAI;AAClB;AAOAA,EAAE,SAAS,WAAY;AACrB,SAAO,CAAC,CAAC,KAAK,KAAK,KAAK,EAAE,CAAC,MAAM;AACnC;AAOAA,EAAE,WAAWA,EAAE,KAAK,SAAUI,GAAG;AAC/B,SAAO,KAAK,IAAIA,CAAC,IAAI;AACvB;AAOAJ,EAAE,oBAAoBA,EAAE,MAAM,SAAUI,GAAG;AACzC,SAAO,KAAK,IAAIA,CAAC,IAAI;AACvB;AAiCAJ,EAAE,YAAYA,EAAE,MAAM,SAAU0C,GAAM;AACpC,MAAIC,GAAUjB,GAAGkB,GAAap1B,GAAGq1B,GAAKC,GAAK1B,GAAInlB,GAC7Cf,IAAM,MACNilB,IAAOjlB,EAAI,aACX0lB,IAAKT,EAAK,WACVU,IAAKV,EAAK,UACV4C,IAAQ;AAGV,MAAIL,KAAQ;AACV,IAAAA,IAAO,IAAIvC,EAAK,EAAE,GAClBwC,IAAW;AAAA,OACN;AAKL,QAJAD,IAAO,IAAIvC,EAAKuC,CAAI,GACpBhB,IAAIgB,EAAK,GAGLA,EAAK,IAAI,KAAK,CAAChB,KAAK,CAACA,EAAE,CAAC,KAAKgB,EAAK,GAAG,CAAC;AAAG,aAAO,IAAIvC,EAAK,GAAG;AAEhE,IAAAwC,IAAWD,EAAK,GAAG,EAAE;AAAA,EACtB;AAKD,MAHAhB,IAAIxmB,EAAI,GAGJA,EAAI,IAAI,KAAK,CAACwmB,KAAK,CAACA,EAAE,CAAC,KAAKxmB,EAAI,GAAG,CAAC;AACtC,WAAO,IAAIilB,EAAKuB,KAAK,CAACA,EAAE,CAAC,IAAI,KAAK,IAAIxmB,EAAI,KAAK,IAAI,MAAMwmB,IAAI,IAAI,IAAI,CAAC;AAKxE,MAAIiB;AACF,QAAIjB,EAAE,SAAS;AACb,MAAAmB,IAAM;AAAA,SACD;AACL,WAAKr1B,IAAIk0B,EAAE,CAAC,GAAGl0B,IAAI,OAAO;AAAI,QAAAA,KAAK;AACnC,MAAAq1B,IAAMr1B,MAAM;AAAA,IACb;AAyBH,MAtBAuxB,IAAW,IACXqC,IAAKR,IAAKmC,GACVD,IAAME,GAAiB9nB,GAAKkmB,CAAE,GAC9BwB,IAAcD,IAAWM,GAAQ9C,GAAMiB,IAAK,EAAE,IAAI4B,GAAiBN,GAAMtB,CAAE,GAG3EnlB,IAAIulB,EAAOsB,GAAKF,GAAaxB,GAAI,CAAC,GAgB9B8B,GAAoBjnB,EAAE,GAAGzO,IAAIozB,GAAIC,CAAE;AAErC;AAME,UALAO,KAAM,IACN0B,IAAME,GAAiB9nB,GAAKkmB,CAAE,GAC9BwB,IAAcD,IAAWM,GAAQ9C,GAAMiB,IAAK,EAAE,IAAI4B,GAAiBN,GAAMtB,CAAE,GAC3EnlB,IAAIulB,EAAOsB,GAAKF,GAAaxB,GAAI,CAAC,GAE9B,CAACyB,GAAK;AAGR,QAAI,CAACtB,EAAetlB,EAAE,CAAC,EAAE,MAAMzO,IAAI,GAAGA,IAAI,EAAE,IAAI,KAAK,SACnDyO,IAAIgkB,EAAShkB,GAAG2kB,IAAK,GAAG,CAAC;AAG3B;AAAA,MACD;AAAA,WACMsC,GAAoBjnB,EAAE,GAAGzO,KAAK,IAAIqzB,CAAE;AAG/C,SAAA9B,IAAW,IAEJkB,EAAShkB,GAAG2kB,GAAIC,CAAE;AAC3B;AAgDAb,EAAE,QAAQA,EAAE,MAAM,SAAUI,GAAG;AAC7B,MAAIsB,GAAGpsB,GAAGpC,GAAGmtB,GAAG7yB,GAAG8pB,GAAKsJ,GAAIC,GAAIL,GAAI2C,GAAIC,GAAM3C,GAC5CztB,IAAI,MACJmtB,IAAOntB,EAAE;AAKX,MAHAotB,IAAI,IAAID,EAAKC,CAAC,GAGV,CAACptB,EAAE,KAAK,CAACotB,EAAE;AAGb,WAAI,CAACptB,EAAE,KAAK,CAACotB,EAAE,IAAGA,IAAI,IAAID,EAAK,GAAG,IAGzBntB,EAAE,IAAGotB,EAAE,IAAI,CAACA,EAAE,IAKlBA,IAAI,IAAID,EAAKC,EAAE,KAAKptB,EAAE,MAAMotB,EAAE,IAAIptB,IAAI,GAAG,GAEvCotB;AAIT,MAAIptB,EAAE,KAAKotB,EAAE;AACX,WAAAA,EAAE,IAAI,CAACA,EAAE,GACFptB,EAAE,KAAKotB,CAAC;AASjB,MANAI,IAAKxtB,EAAE,GACPytB,IAAKL,EAAE,GACPQ,IAAKT,EAAK,WACVU,IAAKV,EAAK,UAGN,CAACK,EAAG,CAAC,KAAK,CAACC,EAAG,CAAC,GAAG;AAGpB,QAAIA,EAAG,CAAC;AAAG,MAAAL,EAAE,IAAI,CAACA,EAAE;AAAA,aAGXI,EAAG,CAAC;AAAG,MAAAJ,IAAI,IAAID,EAAKntB,CAAC;AAAA;AAIzB,aAAO,IAAImtB,EAAKU,MAAO,IAAI,KAAK,CAAC;AAEtC,WAAO9B,IAAWkB,EAASG,GAAGQ,GAAIC,CAAE,IAAIT;AAAA,EACzC;AAYD,MAPA9qB,IAAI+pB,EAAUe,EAAE,IAAIR,CAAQ,GAC5BuD,IAAK9D,EAAUrsB,EAAE,IAAI4sB,CAAQ,GAE7BY,IAAKA,EAAG,SACRhzB,IAAI21B,IAAK7tB,GAGL9H,GAAG;AAyBL,SAxBA41B,IAAO51B,IAAI,GAEP41B,KACF1B,IAAIlB,GACJhzB,IAAI,CAACA,GACL8pB,IAAMmJ,EAAG,WAETiB,IAAIjB,GACJnrB,IAAI6tB,GACJ7L,IAAMkJ,EAAG,SAMXttB,IAAI,KAAK,IAAI,KAAK,KAAK0tB,IAAKhB,CAAQ,GAAGtI,CAAG,IAAI,GAE1C9pB,IAAI0F,MACN1F,IAAI0F,GACJwuB,EAAE,SAAS,IAIbA,EAAE,QAAO,GACJxuB,IAAI1F,GAAG0F;AAAM,MAAAwuB,EAAE,KAAK,CAAC;AAC1B,IAAAA,EAAE,QAAO;AAAA,EAGb,OAAS;AASL,SALAxuB,IAAIstB,EAAG,QACPlJ,IAAMmJ,EAAG,QACT2C,IAAOlwB,IAAIokB,GACP8L,MAAM9L,IAAMpkB,IAEXA,IAAI,GAAGA,IAAIokB,GAAKpkB;AACnB,UAAIstB,EAAGttB,CAAC,KAAKutB,EAAGvtB,CAAC,GAAG;AAClB,QAAAkwB,IAAO5C,EAAGttB,CAAC,IAAIutB,EAAGvtB,CAAC;AACnB;AAAA,MACD;AAGH,IAAA1F,IAAI;AAAA,EACL;AAaD,OAXI41B,MACF1B,IAAIlB,GACJA,IAAKC,GACLA,IAAKiB,GACLtB,EAAE,IAAI,CAACA,EAAE,IAGX9I,IAAMkJ,EAAG,QAIJttB,IAAIutB,EAAG,SAASnJ,GAAKpkB,IAAI,GAAG,EAAEA;AAAG,IAAAstB,EAAGlJ,GAAK,IAAI;AAGlD,OAAKpkB,IAAIutB,EAAG,QAAQvtB,IAAI1F,KAAI;AAE1B,QAAIgzB,EAAG,EAAEttB,CAAC,IAAIutB,EAAGvtB,CAAC,GAAG;AACnB,WAAKmtB,IAAIntB,GAAGmtB,KAAKG,EAAG,EAAEH,CAAC,MAAM;AAAI,QAAAG,EAAGH,CAAC,IAAIV,IAAO;AAChD,QAAEa,EAAGH,CAAC,GACNG,EAAGttB,CAAC,KAAKysB;AAAA,IACV;AAED,IAAAa,EAAGttB,CAAC,KAAKutB,EAAGvtB,CAAC;AAAA,EACd;AAGD,SAAOstB,EAAG,EAAElJ,CAAG,MAAM;AAAI,IAAAkJ,EAAG;AAG5B,SAAOA,EAAG,CAAC,MAAM,GAAGA,EAAG,MAAK;AAAI,MAAElrB;AAGlC,SAAKkrB,EAAG,CAAC,KAETJ,EAAE,IAAII,GACNJ,EAAE,IAAIiD,GAAkB7C,GAAIlrB,CAAC,GAEtBypB,IAAWkB,EAASG,GAAGQ,GAAIC,CAAE,IAAIT,KALrB,IAAID,EAAKU,MAAO,IAAI,KAAK,CAAC;AAM/C;AA2BAb,EAAE,SAASA,EAAE,MAAM,SAAUI,GAAG;AAC9B,MAAIkD,GACFtwB,IAAI,MACJmtB,IAAOntB,EAAE;AAKX,SAHAotB,IAAI,IAAID,EAAKC,CAAC,GAGV,CAACptB,EAAE,KAAK,CAACotB,EAAE,KAAKA,EAAE,KAAK,CAACA,EAAE,EAAE,CAAC,IAAU,IAAID,EAAK,GAAG,IAGnD,CAACC,EAAE,KAAKptB,EAAE,KAAK,CAACA,EAAE,EAAE,CAAC,IAChBitB,EAAS,IAAIE,EAAKntB,CAAC,GAAGmtB,EAAK,WAAWA,EAAK,QAAQ,KAI5DpB,IAAW,IAEPoB,EAAK,UAAU,KAIjBmD,IAAI9B,EAAOxuB,GAAGotB,EAAE,IAAG,GAAI,GAAG,GAAG,CAAC,GAC9BkD,EAAE,KAAKlD,EAAE,KAETkD,IAAI9B,EAAOxuB,GAAGotB,GAAG,GAAGD,EAAK,QAAQ,CAAC,GAGpCmD,IAAIA,EAAE,MAAMlD,CAAC,GAEbrB,IAAW,IAEJ/rB,EAAE,MAAMswB,CAAC;AAClB;AASAtD,EAAE,qBAAqBA,EAAE,MAAM,WAAY;AACzC,SAAOuD,GAAmB,IAAI;AAChC;AAQAvD,EAAE,mBAAmBA,EAAE,KAAK,WAAY;AACtC,SAAOgD,GAAiB,IAAI;AAC9B;AAQAhD,EAAE,UAAUA,EAAE,MAAM,WAAY;AAC9B,MAAIhtB,IAAI,IAAI,KAAK,YAAY,IAAI;AACjC,SAAAA,EAAE,IAAI,CAACA,EAAE,GACFitB,EAASjtB,CAAC;AACnB;AAwBAgtB,EAAE,OAAOA,EAAE,MAAM,SAAUI,GAAG;AAC5B,MAAIoD,GAAO9B,GAAGpsB,GAAG,GAAG9H,GAAG8pB,GAAKsJ,GAAIC,GAAIL,GAAIC,GACtCztB,IAAI,MACJmtB,IAAOntB,EAAE;AAKX,MAHAotB,IAAI,IAAID,EAAKC,CAAC,GAGV,CAACptB,EAAE,KAAK,CAACotB,EAAE;AAGb,WAAI,CAACptB,EAAE,KAAK,CAACotB,EAAE,IAAGA,IAAI,IAAID,EAAK,GAAG,IAMxBntB,EAAE,MAAGotB,IAAI,IAAID,EAAKC,EAAE,KAAKptB,EAAE,MAAMotB,EAAE,IAAIptB,IAAI,GAAG,IAEjDotB;AAIT,MAAIptB,EAAE,KAAKotB,EAAE;AACX,WAAAA,EAAE,IAAI,CAACA,EAAE,GACFptB,EAAE,MAAMotB,CAAC;AASlB,MANAI,IAAKxtB,EAAE,GACPytB,IAAKL,EAAE,GACPQ,IAAKT,EAAK,WACVU,IAAKV,EAAK,UAGN,CAACK,EAAG,CAAC,KAAK,CAACC,EAAG,CAAC;AAIjB,WAAKA,EAAG,CAAC,MAAGL,IAAI,IAAID,EAAKntB,CAAC,IAEnB+rB,IAAWkB,EAASG,GAAGQ,GAAIC,CAAE,IAAIT;AAa1C,MAPA5yB,IAAI6xB,EAAUrsB,EAAE,IAAI4sB,CAAQ,GAC5BtqB,IAAI+pB,EAAUe,EAAE,IAAIR,CAAQ,GAE5BY,IAAKA,EAAG,SACR,IAAIhzB,IAAI8H,GAGJ,GAAG;AAuBL,SArBI,IAAI,KACNosB,IAAIlB,GACJ,IAAI,CAAC,GACLlJ,IAAMmJ,EAAG,WAETiB,IAAIjB,GACJnrB,IAAI9H,GACJ8pB,IAAMkJ,EAAG,SAIXhzB,IAAI,KAAK,KAAKozB,IAAKhB,CAAQ,GAC3BtI,IAAM9pB,IAAI8pB,IAAM9pB,IAAI,IAAI8pB,IAAM,GAE1B,IAAIA,MACN,IAAIA,GACJoK,EAAE,SAAS,IAIbA,EAAE,QAAO,GACF;AAAM,MAAAA,EAAE,KAAK,CAAC;AACrB,IAAAA,EAAE,QAAO;AAAA,EACV;AAcD,OAZApK,IAAMkJ,EAAG,QACT,IAAIC,EAAG,QAGHnJ,IAAM,IAAI,MACZ,IAAIA,GACJoK,IAAIjB,GACJA,IAAKD,GACLA,IAAKkB,IAIF8B,IAAQ,GAAG;AACd,IAAAA,KAAShD,EAAG,EAAE,CAAC,IAAIA,EAAG,CAAC,IAAIC,EAAG,CAAC,IAAI+C,KAAS7D,IAAO,GACnDa,EAAG,CAAC,KAAKb;AAUX,OAPI6D,MACFhD,EAAG,QAAQgD,CAAK,GAChB,EAAEluB,IAKCgiB,IAAMkJ,EAAG,QAAQA,EAAG,EAAElJ,CAAG,KAAK;AAAI,IAAAkJ,EAAG;AAE1C,SAAAJ,EAAE,IAAII,GACNJ,EAAE,IAAIiD,GAAkB7C,GAAIlrB,CAAC,GAEtBypB,IAAWkB,EAASG,GAAGQ,GAAIC,CAAE,IAAIT;AAC1C;AASAJ,EAAE,YAAYA,EAAE,KAAK,SAAUyD,GAAG;AAChC,MAAIj2B,GACFwF,IAAI;AAEN,MAAIywB,MAAM,UAAUA,MAAM,CAAC,CAACA,KAAKA,MAAM,KAAKA,MAAM;AAAG,UAAM,MAAMxE,KAAkBwE,CAAC;AAEpF,SAAIzwB,EAAE,KACJxF,IAAIk2B,GAAa1wB,EAAE,CAAC,GAChBywB,KAAKzwB,EAAE,IAAI,IAAIxF,MAAGA,IAAIwF,EAAE,IAAI,MAEhCxF,IAAI,KAGCA;AACT;AAQAwyB,EAAE,QAAQ,WAAY;AACpB,MAAIhtB,IAAI,MACNmtB,IAAOntB,EAAE;AAEX,SAAOitB,EAAS,IAAIE,EAAKntB,CAAC,GAAGA,EAAE,IAAI,GAAGmtB,EAAK,QAAQ;AACrD;AAkBAH,EAAE,OAAOA,EAAE,MAAM,WAAY;AAC3B,MAAIY,GAAIC,GACN7tB,IAAI,MACJmtB,IAAOntB,EAAE;AAEX,SAAKA,EAAE,SAAQ,IACXA,EAAE,OAAQ,IAAS,IAAImtB,EAAKntB,CAAC,KAEjC4tB,IAAKT,EAAK,WACVU,IAAKV,EAAK,UACVA,EAAK,YAAYS,IAAK,KAAK,IAAI5tB,EAAE,GAAGA,EAAE,GAAI,CAAA,IAAI4sB,GAC9CO,EAAK,WAAW,GAEhBntB,IAAI2wB,GAAKxD,GAAMY,GAAiBZ,GAAMntB,CAAC,CAAC,GAExCmtB,EAAK,YAAYS,GACjBT,EAAK,WAAWU,GAETZ,EAASnB,IAAW,IAAI9rB,EAAE,QAAQA,GAAG4tB,GAAIC,GAAI,EAAI,KAb9B,IAAIV,EAAK,GAAG;AAcxC;AAeAH,EAAE,aAAaA,EAAE,OAAO,WAAY;AAClC,MAAIgB,GAAG,GAAGI,GAAI,GAAGF,GAAKtf,GACpB5O,IAAI,MACJ0uB,IAAI1uB,EAAE,GACNsC,IAAItC,EAAE,GACNmuB,IAAInuB,EAAE,GACNmtB,IAAOntB,EAAE;AAGX,MAAImuB,MAAM,KAAK,CAACO,KAAK,CAACA,EAAE,CAAC;AACvB,WAAO,IAAIvB,EAAK,CAACgB,KAAKA,IAAI,MAAM,CAACO,KAAKA,EAAE,CAAC,KAAK,MAAMA,IAAI1uB,IAAI,IAAI,CAAC;AAgCnE,OA7BA+rB,IAAW,IAGXoC,IAAI,KAAK,KAAK,CAACnuB,CAAC,GAIZmuB,KAAK,KAAKA,KAAK,IAAI,KACrB,IAAII,EAAeG,CAAC,IAEf,EAAE,SAASpsB,KAAK,KAAK,MAAG,KAAK,MAClC6rB,IAAI,KAAK,KAAK,CAAC,GACf7rB,IAAI+pB,GAAW/pB,IAAI,KAAK,CAAC,KAAKA,IAAI,KAAKA,IAAI,IAEvC6rB,KAAK,IAAI,IACX,IAAI,OAAO7rB,KAEX,IAAI6rB,EAAE,iBACN,IAAI,EAAE,MAAM,GAAG,EAAE,QAAQ,GAAG,IAAI,CAAC,IAAI7rB,IAGvC,IAAI,IAAI6qB,EAAK,CAAC,KAEd,IAAI,IAAIA,EAAKgB,EAAE,SAAU,CAAA,GAG3BC,KAAM9rB,IAAI6qB,EAAK,aAAa;AAQ1B,QAJAve,IAAI,GACJ,IAAIA,EAAE,KAAK4f,EAAOxuB,GAAG4O,GAAGwf,IAAK,GAAG,CAAC,CAAC,EAAE,MAAM,GAAG,GAGzCG,EAAe3f,EAAE,CAAC,EAAE,MAAM,GAAGwf,CAAE,OAAO,IAAIG,EAAe,EAAE,CAAC,GAAG,MAAM,GAAGH,CAAE;AAK5E,UAJA,IAAI,EAAE,MAAMA,IAAK,GAAGA,IAAK,CAAC,GAItB,KAAK,UAAU,CAACF,KAAO,KAAK,QAAQ;AAItC,YAAI,CAACA,MACHjB,EAASre,GAAGtM,IAAI,GAAG,CAAC,GAEhBsM,EAAE,MAAMA,CAAC,EAAE,GAAG5O,CAAC,IAAG;AACpB,cAAI4O;AACJ;AAAA,QACD;AAGH,QAAAwf,KAAM,GACNF,IAAM;AAAA,MACd,OAAa;AAIL,SAAI,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,KAAK,EAAE,OAAO,CAAC,KAAK,SAGxCjB,EAAS,GAAG3qB,IAAI,GAAG,CAAC,GACpB0rB,IAAI,CAAC,EAAE,MAAM,CAAC,EAAE,GAAGhuB,CAAC;AAGtB;AAAA,MACD;AAIL,SAAA+rB,IAAW,IAEJkB,EAAS,GAAG3qB,GAAG6qB,EAAK,UAAUa,CAAC;AACxC;AAgBAhB,EAAE,UAAUA,EAAE,MAAM,WAAY;AAC9B,MAAIY,GAAIC,GACN7tB,IAAI,MACJmtB,IAAOntB,EAAE;AAEX,SAAKA,EAAE,SAAQ,IACXA,EAAE,OAAQ,IAAS,IAAImtB,EAAKntB,CAAC,KAEjC4tB,IAAKT,EAAK,WACVU,IAAKV,EAAK,UACVA,EAAK,YAAYS,IAAK,IACtBT,EAAK,WAAW,GAEhBntB,IAAIA,EAAE,OACNA,EAAE,IAAI,GACNA,IAAIwuB,EAAOxuB,GAAG,IAAImtB,EAAK,CAAC,EAAE,MAAMntB,EAAE,MAAMA,CAAC,CAAC,EAAE,KAAI,GAAI4tB,IAAK,IAAI,CAAC,GAE9DT,EAAK,YAAYS,GACjBT,EAAK,WAAWU,GAETZ,EAASnB,KAAY,KAAKA,KAAY,IAAI9rB,EAAE,IAAG,IAAKA,GAAG4tB,GAAIC,GAAI,EAAI,KAfhD,IAAIV,EAAK,GAAG;AAgBxC;AAwBAH,EAAE,QAAQA,EAAE,MAAM,SAAUI,GAAG;AAC7B,MAAIoD,GAAOluB,GAAGpC,GAAG1F,GAAGyO,GAAG2nB,GAAIhiB,GAAG0e,GAAKC,GACjCvtB,IAAI,MACJmtB,IAAOntB,EAAE,aACTwtB,IAAKxtB,EAAE,GACPytB,KAAML,IAAI,IAAID,EAAKC,CAAC,GAAG;AAKzB,MAHAA,EAAE,KAAKptB,EAAE,GAGL,CAACwtB,KAAM,CAACA,EAAG,CAAC,KAAK,CAACC,KAAM,CAACA,EAAG,CAAC;AAE/B,WAAO,IAAIN,EAAK,CAACC,EAAE,KAAKI,KAAM,CAACA,EAAG,CAAC,KAAK,CAACC,KAAMA,KAAM,CAACA,EAAG,CAAC,KAAK,CAACD,IAI5D,MAIA,CAACA,KAAM,CAACC,IAAKL,EAAE,IAAI,IAAIA,EAAE,IAAI,CAAC;AAoBpC,OAjBA9qB,IAAI+pB,EAAUrsB,EAAE,IAAI4sB,CAAQ,IAAIP,EAAUe,EAAE,IAAIR,CAAQ,GACxDU,IAAME,EAAG,QACTD,IAAME,EAAG,QAGLH,IAAMC,MACRtkB,IAAIukB,GACJA,IAAKC,GACLA,IAAKxkB,GACL2nB,IAAKtD,GACLA,IAAMC,GACNA,IAAMqD,IAIR3nB,IAAI,CAAA,GACJ2nB,IAAKtD,IAAMC,GACNrtB,IAAI0wB,GAAI1wB;AAAM,IAAA+I,EAAE,KAAK,CAAC;AAG3B,OAAK/I,IAAIqtB,GAAK,EAAErtB,KAAK,KAAI;AAEvB,SADAswB,IAAQ,GACHh2B,IAAI8yB,IAAMptB,GAAG1F,IAAI0F;AACpB,MAAA0O,IAAI3F,EAAEzO,CAAC,IAAIizB,EAAGvtB,CAAC,IAAIstB,EAAGhzB,IAAI0F,IAAI,CAAC,IAAIswB,GACnCvnB,EAAEzO,GAAG,IAAIoU,IAAI+d,IAAO,GACpB6D,IAAQ5hB,IAAI+d,IAAO;AAGrB,IAAA1jB,EAAEzO,CAAC,KAAKyO,EAAEzO,CAAC,IAAIg2B,KAAS7D,IAAO;AAAA,EAChC;AAGD,SAAO,CAAC1jB,EAAE,EAAE2nB,CAAE;AAAI,IAAA3nB,EAAE,IAAG;AAEvB,SAAIunB,IAAO,EAAEluB,IACR2G,EAAE,MAAK,GAEZmkB,EAAE,IAAInkB,GACNmkB,EAAE,IAAIiD,GAAkBpnB,GAAG3G,CAAC,GAErBypB,IAAWkB,EAASG,GAAGD,EAAK,WAAWA,EAAK,QAAQ,IAAIC;AACjE;AAaAJ,EAAE,WAAW,SAAUoB,GAAIP,GAAI;AAC7B,SAAOgD,GAAe,MAAM,GAAGzC,GAAIP,CAAE;AACvC;AAaAb,EAAE,kBAAkBA,EAAE,OAAO,SAAU8D,GAAIjD,GAAI;AAC7C,MAAI7tB,IAAI,MACNmtB,IAAOntB,EAAE;AAGX,SADAA,IAAI,IAAImtB,EAAKntB,CAAC,GACV8wB,MAAO,SAAe9wB,KAE1B+wB,EAAWD,GAAI,GAAGtF,EAAU,GAExBqC,MAAO,SAAQA,IAAKV,EAAK,WACxB4D,EAAWlD,GAAI,GAAG,CAAC,GAEjBZ,EAASjtB,GAAG8wB,IAAK9wB,EAAE,IAAI,GAAG6tB,CAAE;AACrC;AAWAb,EAAE,gBAAgB,SAAU8D,GAAIjD,GAAI;AAClC,MAAIpwB,GACFuC,IAAI,MACJmtB,IAAOntB,EAAE;AAEX,SAAI8wB,MAAO,SACTrzB,IAAMuzB,EAAehxB,GAAG,EAAI,KAE5B+wB,EAAWD,GAAI,GAAGtF,EAAU,GAExBqC,MAAO,SAAQA,IAAKV,EAAK,WACxB4D,EAAWlD,GAAI,GAAG,CAAC,GAExB7tB,IAAIitB,EAAS,IAAIE,EAAKntB,CAAC,GAAG8wB,IAAK,GAAGjD,CAAE,GACpCpwB,IAAMuzB,EAAehxB,GAAG,IAAM8wB,IAAK,CAAC,IAG/B9wB,EAAE,MAAK,KAAM,CAACA,EAAE,WAAW,MAAMvC,IAAMA;AAChD;AAmBAuvB,EAAE,UAAU,SAAU8D,GAAIjD,GAAI;AAC5B,MAAIpwB,GAAK2vB,GACPptB,IAAI,MACJmtB,IAAOntB,EAAE;AAEX,SAAI8wB,MAAO,SACTrzB,IAAMuzB,EAAehxB,CAAC,KAEtB+wB,EAAWD,GAAI,GAAGtF,EAAU,GAExBqC,MAAO,SAAQA,IAAKV,EAAK,WACxB4D,EAAWlD,GAAI,GAAG,CAAC,GAExBT,IAAIH,EAAS,IAAIE,EAAKntB,CAAC,GAAG8wB,IAAK9wB,EAAE,IAAI,GAAG6tB,CAAE,GAC1CpwB,IAAMuzB,EAAe5D,GAAG,IAAO0D,IAAK1D,EAAE,IAAI,CAAC,IAKtCptB,EAAE,MAAK,KAAM,CAACA,EAAE,WAAW,MAAMvC,IAAMA;AAChD;AAcAuvB,EAAE,aAAa,SAAUiE,GAAM;AAC7B,MAAIvC,GAAGwC,GAAIC,GAAIC,GAAI9uB,GAAG9H,GAAGyzB,GAAGoD,GAAIC,GAAI1D,GAAI0C,GAAGrnB,GACzCjJ,IAAI,MACJwtB,IAAKxtB,EAAE,GACPmtB,IAAOntB,EAAE;AAEX,MAAI,CAACwtB;AAAI,WAAO,IAAIL,EAAKntB,CAAC;AAU1B,MARAsxB,IAAKJ,IAAK,IAAI/D,EAAK,CAAC,GACpBgE,IAAKE,IAAK,IAAIlE,EAAK,CAAC,GAEpBuB,IAAI,IAAIvB,EAAKgE,CAAE,GACf7uB,IAAIosB,EAAE,IAAIgC,GAAalD,CAAE,IAAIxtB,EAAE,IAAI,GACnCxF,IAAI8H,IAAIsqB,GACR8B,EAAE,EAAE,CAAC,IAAIpC,EAAQ,IAAI9xB,IAAI,IAAIoyB,IAAWpyB,IAAIA,CAAC,GAEzCy2B,KAAQ;AAGV,IAAAA,IAAO3uB,IAAI,IAAIosB,IAAI4C;AAAA,OACd;AAEL,QADArD,IAAI,IAAId,EAAK8D,CAAI,GACb,CAAChD,EAAE,MAAO,KAAIA,EAAE,GAAGqD,CAAE;AAAG,YAAM,MAAMrF,KAAkBgC,CAAC;AAC3D,IAAAgD,IAAOhD,EAAE,GAAGS,CAAC,IAAKpsB,IAAI,IAAIosB,IAAI4C,IAAMrD;AAAA,EACrC;AAOD,OALAlC,IAAW,IACXkC,IAAI,IAAId,EAAKoB,EAAef,CAAE,CAAC,GAC/BI,IAAKT,EAAK,WACVA,EAAK,YAAY7qB,IAAIkrB,EAAG,SAASZ,IAAW,GAG1C0D,IAAI9B,EAAOP,GAAGS,GAAG,GAAG,GAAG,CAAC,GACxB0C,IAAKF,EAAG,KAAKZ,EAAE,MAAMa,CAAE,CAAC,GACpBC,EAAG,IAAIH,CAAI,KAAK;AACpB,IAAAC,IAAKC,GACLA,IAAKC,GACLA,IAAKE,GACLA,IAAKD,EAAG,KAAKf,EAAE,MAAMc,CAAE,CAAC,GACxBC,IAAKD,GACLA,IAAK1C,GACLA,IAAIT,EAAE,MAAMqC,EAAE,MAAMc,CAAE,CAAC,GACvBnD,IAAImD;AAGN,SAAAA,IAAK5C,EAAOyC,EAAK,MAAMC,CAAE,GAAGC,GAAI,GAAG,GAAG,CAAC,GACvCE,IAAKA,EAAG,KAAKD,EAAG,MAAME,CAAE,CAAC,GACzBJ,IAAKA,EAAG,KAAKE,EAAG,MAAMD,CAAE,CAAC,GACzBE,EAAG,IAAIC,EAAG,IAAItxB,EAAE,GAGhBiJ,IAAIulB,EAAO8C,GAAIH,GAAI7uB,GAAG,CAAC,EAAE,MAAMtC,CAAC,EAAE,IAAK,EAAC,IAAIwuB,EAAO6C,GAAIH,GAAI5uB,GAAG,CAAC,EAAE,MAAMtC,CAAC,EAAE,IAAK,CAAA,IAAI,IAC7E,CAACsxB,GAAIH,CAAE,IAAI,CAACE,GAAIH,CAAE,GAExB/D,EAAK,YAAYS,GACjB7B,IAAW,IAEJ9iB;AACT;AAaA+jB,EAAE,gBAAgBA,EAAE,QAAQ,SAAUoB,GAAIP,GAAI;AAC5C,SAAOgD,GAAe,MAAM,IAAIzC,GAAIP,CAAE;AACxC;AAmBAb,EAAE,YAAY,SAAUI,GAAGS,GAAI;AAC7B,MAAI7tB,IAAI,MACNmtB,IAAOntB,EAAE;AAIX,MAFAA,IAAI,IAAImtB,EAAKntB,CAAC,GAEVotB,KAAK,MAAM;AAGb,QAAI,CAACptB,EAAE;AAAG,aAAOA;AAEjB,IAAAotB,IAAI,IAAID,EAAK,CAAC,GACdU,IAAKV,EAAK;AAAA,EACd,OAAS;AASL,QARAC,IAAI,IAAID,EAAKC,CAAC,GACVS,MAAO,SACTA,IAAKV,EAAK,WAEV4D,EAAWlD,GAAI,GAAG,CAAC,GAIjB,CAAC7tB,EAAE;AAAG,aAAOotB,EAAE,IAAIptB,IAAIotB;AAG3B,QAAI,CAACA,EAAE;AACL,aAAIA,EAAE,MAAGA,EAAE,IAAIptB,EAAE,IACVotB;AAAA,EAEV;AAGD,SAAIA,EAAE,EAAE,CAAC,KACPrB,IAAW,IACX/rB,IAAIwuB,EAAOxuB,GAAGotB,GAAG,GAAGS,GAAI,CAAC,EAAE,MAAMT,CAAC,GAClCrB,IAAW,IACXkB,EAASjtB,CAAC,MAIVotB,EAAE,IAAIptB,EAAE,GACRA,IAAIotB,IAGCptB;AACT;AAQAgtB,EAAE,WAAW,WAAY;AACvB,SAAO,CAAC;AACV;AAaAA,EAAE,UAAU,SAAUoB,GAAIP,GAAI;AAC5B,SAAOgD,GAAe,MAAM,GAAGzC,GAAIP,CAAE;AACvC;AA8CAb,EAAE,UAAUA,EAAE,MAAM,SAAUI,GAAG;AAC/B,MAAI9qB,GAAG9H,GAAGozB,GAAI3kB,GAAG4kB,GAAI,GACnB7tB,IAAI,MACJmtB,IAAOntB,EAAE,aACTuxB,IAAK,EAAEnE,IAAI,IAAID,EAAKC,CAAC;AAGvB,MAAI,CAACptB,EAAE,KAAK,CAACotB,EAAE,KAAK,CAACptB,EAAE,EAAE,CAAC,KAAK,CAACotB,EAAE,EAAE,CAAC;AAAG,WAAO,IAAID,EAAKb,EAAQ,CAACtsB,GAAGuxB,CAAE,CAAC;AAIvE,MAFAvxB,IAAI,IAAImtB,EAAKntB,CAAC,GAEVA,EAAE,GAAG,CAAC;AAAG,WAAOA;AAKpB,MAHA4tB,IAAKT,EAAK,WACVU,IAAKV,EAAK,UAENC,EAAE,GAAG,CAAC;AAAG,WAAOH,EAASjtB,GAAG4tB,GAAIC,CAAE;AAMtC,MAHAvrB,IAAI+pB,EAAUe,EAAE,IAAIR,CAAQ,GAGxBtqB,KAAK8qB,EAAE,EAAE,SAAS,MAAM5yB,IAAI+2B,IAAK,IAAI,CAACA,IAAKA,MAAO1E;AACpD,WAAA5jB,IAAIuoB,GAAOrE,GAAMntB,GAAGxF,GAAGozB,CAAE,GAClBR,EAAE,IAAI,IAAI,IAAID,EAAK,CAAC,EAAE,IAAIlkB,CAAC,IAAIgkB,EAAShkB,GAAG2kB,GAAIC,CAAE;AAM1D,MAHA,IAAI7tB,EAAE,GAGF,IAAI,GAAG;AAGT,QAAIsC,IAAI8qB,EAAE,EAAE,SAAS;AAAG,aAAO,IAAID,EAAK,GAAG;AAM3C,QAHKC,EAAE,EAAE9qB,CAAC,IAAI,MAAS,IAAI,IAGvBtC,EAAE,KAAK,KAAKA,EAAE,EAAE,CAAC,KAAK,KAAKA,EAAE,EAAE,UAAU;AAC3C,aAAAA,EAAE,IAAI,GACCA;AAAA,EAEV;AAcD,SARAxF,IAAI8xB,EAAQ,CAACtsB,GAAGuxB,CAAE,GAClBjvB,IAAI9H,KAAK,KAAK,CAAC,SAASA,CAAC,IACrB6xB,EAAUkF,KAAM,KAAK,IAAI,OAAOhD,EAAevuB,EAAE,CAAC,CAAC,IAAI,KAAK,OAAOA,EAAE,IAAI,EAAE,IAC3E,IAAImtB,EAAK3yB,IAAI,EAAE,EAAE,GAKjB8H,IAAI6qB,EAAK,OAAO,KAAK7qB,IAAI6qB,EAAK,OAAO,IAAU,IAAIA,EAAK7qB,IAAI,IAAI,IAAI,IAAI,CAAC,KAE7EypB,IAAW,IACXoB,EAAK,WAAWntB,EAAE,IAAI,GAMtBxF,IAAI,KAAK,IAAI,KAAK8H,IAAI,IAAI,MAAM,GAGhC2G,IAAIsnB,GAAmBnD,EAAE,MAAM4C,GAAiBhwB,GAAG4tB,IAAKpzB,CAAC,CAAC,GAAGozB,CAAE,GAG3D3kB,EAAE,MAGJA,IAAIgkB,EAAShkB,GAAG2kB,IAAK,GAAG,CAAC,GAIrBsC,GAAoBjnB,EAAE,GAAG2kB,GAAIC,CAAE,MACjCvrB,IAAIsrB,IAAK,IAGT3kB,IAAIgkB,EAASsD,GAAmBnD,EAAE,MAAM4C,GAAiBhwB,GAAGsC,IAAI9H,CAAC,CAAC,GAAG8H,CAAC,GAAGA,IAAI,GAAG,CAAC,GAG7E,CAACisB,EAAetlB,EAAE,CAAC,EAAE,MAAM2kB,IAAK,GAAGA,IAAK,EAAE,IAAI,KAAK,SACrD3kB,IAAIgkB,EAAShkB,GAAG2kB,IAAK,GAAG,CAAC,MAK/B3kB,EAAE,IAAI,GACN8iB,IAAW,IACXoB,EAAK,WAAWU,GAETZ,EAAShkB,GAAG2kB,GAAIC,CAAE;AAC3B;AAcAb,EAAE,cAAc,SAAUoB,GAAIP,GAAI;AAChC,MAAIpwB,GACFuC,IAAI,MACJmtB,IAAOntB,EAAE;AAEX,SAAIouB,MAAO,SACT3wB,IAAMuzB,EAAehxB,GAAGA,EAAE,KAAKmtB,EAAK,YAAYntB,EAAE,KAAKmtB,EAAK,QAAQ,KAEpE4D,EAAW3C,GAAI,GAAG5C,EAAU,GAExBqC,MAAO,SAAQA,IAAKV,EAAK,WACxB4D,EAAWlD,GAAI,GAAG,CAAC,GAExB7tB,IAAIitB,EAAS,IAAIE,EAAKntB,CAAC,GAAGouB,GAAIP,CAAE,GAChCpwB,IAAMuzB,EAAehxB,GAAGouB,KAAMpuB,EAAE,KAAKA,EAAE,KAAKmtB,EAAK,UAAUiB,CAAE,IAGxDpuB,EAAE,MAAK,KAAM,CAACA,EAAE,WAAW,MAAMvC,IAAMA;AAChD;AAiBAuvB,EAAE,sBAAsBA,EAAE,OAAO,SAAUoB,GAAIP,GAAI;AACjD,MAAI7tB,IAAI,MACNmtB,IAAOntB,EAAE;AAEX,SAAIouB,MAAO,UACTA,IAAKjB,EAAK,WACVU,IAAKV,EAAK,aAEV4D,EAAW3C,GAAI,GAAG5C,EAAU,GAExBqC,MAAO,SAAQA,IAAKV,EAAK,WACxB4D,EAAWlD,GAAI,GAAG,CAAC,IAGnBZ,EAAS,IAAIE,EAAKntB,CAAC,GAAGouB,GAAIP,CAAE;AACrC;AAUAb,EAAE,WAAW,WAAY;AACvB,MAAIhtB,IAAI,MACNmtB,IAAOntB,EAAE,aACTvC,IAAMuzB,EAAehxB,GAAGA,EAAE,KAAKmtB,EAAK,YAAYntB,EAAE,KAAKmtB,EAAK,QAAQ;AAEtE,SAAOntB,EAAE,MAAK,KAAM,CAACA,EAAE,WAAW,MAAMvC,IAAMA;AAChD;AAOAuvB,EAAE,YAAYA,EAAE,QAAQ,WAAY;AAClC,SAAOC,EAAS,IAAI,KAAK,YAAY,IAAI,GAAG,KAAK,IAAI,GAAG,CAAC;AAC3D;AAQAD,EAAE,UAAUA,EAAE,SAAS,WAAY;AACjC,MAAIhtB,IAAI,MACNmtB,IAAOntB,EAAE,aACTvC,IAAMuzB,EAAehxB,GAAGA,EAAE,KAAKmtB,EAAK,YAAYntB,EAAE,KAAKmtB,EAAK,QAAQ;AAEtE,SAAOntB,EAAE,MAAK,IAAK,MAAMvC,IAAMA;AACjC;AAoDA,SAAS8wB,EAAeG,GAAG;AACzB,MAAIxuB,GAAG1F,GAAGi3B,GACRC,IAAkBhD,EAAE,SAAS,GAC7BjxB,IAAM,IACNgxB,IAAIC,EAAE,CAAC;AAET,MAAIgD,IAAkB,GAAG;AAEvB,SADAj0B,KAAOgxB,GACFvuB,IAAI,GAAGA,IAAIwxB,GAAiBxxB;AAC/B,MAAAuxB,IAAK/C,EAAExuB,CAAC,IAAI,IACZ1F,IAAIoyB,IAAW6E,EAAG,QACdj3B,MAAGiD,KAAOk0B,GAAcn3B,CAAC,IAC7BiD,KAAOg0B;AAGT,IAAAhD,IAAIC,EAAExuB,CAAC,GACPuxB,IAAKhD,IAAI,IACTj0B,IAAIoyB,IAAW6E,EAAG,QACdj3B,MAAGiD,KAAOk0B,GAAcn3B,CAAC;AAAA,EACjC,WAAai0B,MAAM;AACf,WAAO;AAIT,SAAOA,IAAI,OAAO;AAAI,IAAAA,KAAK;AAE3B,SAAOhxB,IAAMgxB;AACf;AAGA,SAASsC,EAAW7wB,GAAGgtB,GAAK5E,GAAK;AAC/B,MAAIpoB,MAAM,CAAC,CAACA,KAAKA,IAAIgtB,KAAOhtB,IAAIooB;AAC9B,UAAM,MAAM2D,KAAkB/rB,CAAC;AAEnC;AAQA,SAASgwB,GAAoBxB,GAAGxuB,GAAG2tB,GAAI+D,GAAW;AAChD,MAAIC,GAAIr3B,GAAGyO,GAAG6oB;AAGd,OAAKt3B,IAAIk0B,EAAE,CAAC,GAAGl0B,KAAK,IAAIA,KAAK;AAAI,MAAE0F;AAGnC,SAAI,EAAEA,IAAI,KACRA,KAAK0sB,GACLiF,IAAK,MAELA,IAAK,KAAK,MAAM3xB,IAAI,KAAK0sB,CAAQ,GACjC1sB,KAAK0sB,IAMPpyB,IAAI8xB,EAAQ,IAAIM,IAAW1sB,CAAC,GAC5B4xB,IAAKpD,EAAEmD,CAAE,IAAIr3B,IAAI,GAEbo3B,KAAa,OACX1xB,IAAI,KACFA,KAAK,IAAG4xB,IAAKA,IAAK,MAAM,IACnB5xB,KAAK,MAAG4xB,IAAKA,IAAK,KAAK,IAChC7oB,IAAI4kB,IAAK,KAAKiE,KAAM,SAASjE,IAAK,KAAKiE,KAAM,SAASA,KAAM,OAASA,KAAM,KAE3E7oB,KAAK4kB,IAAK,KAAKiE,IAAK,KAAKt3B,KAAKqzB,IAAK,KAAKiE,IAAK,KAAKt3B,IAAI,OACnDk0B,EAAEmD,IAAK,CAAC,IAAIr3B,IAAI,MAAM,MAAM8xB,EAAQ,IAAIpsB,IAAI,CAAC,IAAI,MAC/C4xB,KAAMt3B,IAAI,KAAKs3B,KAAM,OAAOpD,EAAEmD,IAAK,CAAC,IAAIr3B,IAAI,MAAM,MAAM,IAG3D0F,IAAI,KACFA,KAAK,IAAG4xB,IAAKA,IAAK,MAAO,IACpB5xB,KAAK,IAAG4xB,IAAKA,IAAK,MAAM,IACxB5xB,KAAK,MAAG4xB,IAAKA,IAAK,KAAK,IAChC7oB,KAAK2oB,KAAa/D,IAAK,MAAMiE,KAAM,QAAQ,CAACF,KAAa/D,IAAK,KAAKiE,KAAM,QAEzE7oB,MAAM2oB,KAAa/D,IAAK,MAAMiE,IAAK,KAAKt3B,KACvC,CAACo3B,KAAa/D,IAAK,KAAMiE,IAAK,KAAKt3B,IAAI,OACrCk0B,EAAEmD,IAAK,CAAC,IAAIr3B,IAAI,MAAO,MAAM8xB,EAAQ,IAAIpsB,IAAI,CAAC,IAAI,GAIlD+I;AACT;AAMA,SAAS8oB,GAAYt0B,GAAKu0B,GAAQC,GAAS;AAOzC,WANI5E,GACF6E,IAAM,CAAC,CAAC,GACRC,GACAjyB,IAAI,GACJkyB,IAAO30B,EAAI,QAENyC,IAAIkyB,KAAO;AAChB,SAAKD,IAAOD,EAAI,QAAQC;AAAS,MAAAD,EAAIC,CAAI,KAAKH;AAE9C,SADAE,EAAI,CAAC,KAAKzG,GAAS,QAAQhuB,EAAI,OAAOyC,GAAG,CAAC,GACrCmtB,IAAI,GAAGA,IAAI6E,EAAI,QAAQ7E;AAC1B,MAAI6E,EAAI7E,CAAC,IAAI4E,IAAU,MACjBC,EAAI7E,IAAI,CAAC,MAAM,WAAQ6E,EAAI7E,IAAI,CAAC,IAAI,IACxC6E,EAAI7E,IAAI,CAAC,KAAK6E,EAAI7E,CAAC,IAAI4E,IAAU,GACjCC,EAAI7E,CAAC,KAAK4E;AAAA,EAGf;AAED,SAAOC,EAAI;AACb;AAQA,SAASpE,GAAOX,GAAMntB,GAAG;AACvB,MAAIxF,GAAG8pB,GAAK8I;AAEZ,MAAIptB,EAAE;AAAU,WAAOA;AAMvB,EAAAskB,IAAMtkB,EAAE,EAAE,QACNskB,IAAM,MACR9pB,IAAI,KAAK,KAAK8pB,IAAM,CAAC,GACrB8I,KAAK,IAAIwB,GAAQ,GAAGp0B,CAAC,GAAG,eAExBA,IAAI,IACJ4yB,IAAI,iCAGND,EAAK,aAAa3yB,GAElBwF,IAAI6uB,GAAa1B,GAAM,GAAGntB,EAAE,MAAMotB,CAAC,GAAG,IAAID,EAAK,CAAC,CAAC;AAGjD,WAASjtB,IAAI1F,GAAG0F,OAAM;AACpB,QAAImyB,IAAQryB,EAAE,MAAMA,CAAC;AACrB,IAAAA,IAAIqyB,EAAM,MAAMA,CAAK,EAAE,MAAMA,CAAK,EAAE,MAAM,CAAC,EAAE,KAAK,CAAC;AAAA,EACpD;AAED,SAAAlF,EAAK,aAAa3yB,GAEXwF;AACT;AAMA,IAAIwuB,IAAU,WAAY;AAGxB,WAAS8D,EAAgBtyB,GAAGxF,GAAGk1B,GAAM;AACnC,QAAI6C,GACF/B,IAAQ,GACRtwB,IAAIF,EAAE;AAER,SAAKA,IAAIA,EAAE,MAAO,GAAEE;AAClB,MAAAqyB,IAAOvyB,EAAEE,CAAC,IAAI1F,IAAIg2B,GAClBxwB,EAAEE,CAAC,IAAIqyB,IAAO7C,IAAO,GACrBc,IAAQ+B,IAAO7C,IAAO;AAGxB,WAAIc,KAAOxwB,EAAE,QAAQwwB,CAAK,GAEnBxwB;AAAA,EACR;AAED,WAASwyB,EAAQ/yB,GAAGC,GAAG+yB,GAAIC,GAAI;AAC7B,QAAIxyB,GAAG+I;AAEP,QAAIwpB,KAAMC;AACR,MAAAzpB,IAAIwpB,IAAKC,IAAK,IAAI;AAAA;AAElB,WAAKxyB,IAAI+I,IAAI,GAAG/I,IAAIuyB,GAAIvyB;AACtB,YAAIT,EAAES,CAAC,KAAKR,EAAEQ,CAAC,GAAG;AAChB,UAAA+I,IAAIxJ,EAAES,CAAC,IAAIR,EAAEQ,CAAC,IAAI,IAAI;AACtB;AAAA,QACD;AAIL,WAAO+I;AAAA,EACR;AAED,WAAS0pB,EAASlzB,GAAGC,GAAG+yB,GAAI/C,GAAM;AAIhC,aAHIxvB,IAAI,GAGDuyB;AACL,MAAAhzB,EAAEgzB,CAAE,KAAKvyB,GACTA,IAAIT,EAAEgzB,CAAE,IAAI/yB,EAAE+yB,CAAE,IAAI,IAAI,GACxBhzB,EAAEgzB,CAAE,IAAIvyB,IAAIwvB,IAAOjwB,EAAEgzB,CAAE,IAAI/yB,EAAE+yB,CAAE;AAIjC,WAAO,CAAChzB,EAAE,CAAC,KAAKA,EAAE,SAAS;AAAI,MAAAA,EAAE;EAClC;AAED,SAAO,SAAUO,GAAGotB,GAAGQ,GAAIC,GAAIiD,GAAIpB,GAAM;AACvC,QAAIkD,GAAKtwB,GAAGpC,GAAG1F,GAAGq4B,GAASC,GAAMC,GAAMC,GAAO1C,GAAG2C,GAAIC,GAAKC,GAAMC,GAAMhF,GAAIxf,IAAGykB,IAAIC,IAAIC,IACnFC,GAAIC,IACJtG,KAAOntB,EAAE,aACT0zB,KAAO1zB,EAAE,KAAKotB,EAAE,IAAI,IAAI,IACxBI,IAAKxtB,EAAE,GACPytB,IAAKL,EAAE;AAGT,QAAI,CAACI,KAAM,CAACA,EAAG,CAAC,KAAK,CAACC,KAAM,CAACA,EAAG,CAAC;AAE/B,aAAO,IAAIN;AAAA;AAAA,QACT,CAACntB,EAAE,KAAK,CAACotB,EAAE,MAAMI,IAAKC,KAAMD,EAAG,CAAC,KAAKC,EAAG,CAAC,IAAI,CAACA,KAAM;AAAA;AAAA,UAGpDD,KAAMA,EAAG,CAAC,KAAK,KAAK,CAACC,IAAKiG,KAAO,IAAIA,KAAO;AAAA;AAAA,MAAC;AAmBjD,SAhBIhE,KACFmD,IAAU,GACVvwB,IAAItC,EAAE,IAAIotB,EAAE,MAEZsC,IAAO/C,GACPkG,IAAUjG,GACVtqB,IAAI+pB,EAAUrsB,EAAE,IAAI6yB,CAAO,IAAIxG,EAAUe,EAAE,IAAIyF,CAAO,IAGxDW,IAAK/F,EAAG,QACR6F,KAAK9F,EAAG,QACR8C,IAAI,IAAInD,GAAKuG,EAAI,GACjBT,IAAK3C,EAAE,IAAI,IAINpwB,IAAI,GAAGutB,EAAGvtB,CAAC,MAAMstB,EAAGttB,CAAC,KAAK,IAAIA;AAAI;AAavC,QAXIutB,EAAGvtB,CAAC,KAAKstB,EAAGttB,CAAC,KAAK,MAAIoC,KAEtBsrB,KAAM,QACRQ,IAAKR,IAAKT,GAAK,WACfU,IAAKV,GAAK,YACD2D,IACT1C,IAAKR,KAAM5tB,EAAE,IAAIotB,EAAE,KAAK,IAExBgB,IAAKR,GAGHQ,IAAK;AACP,MAAA6E,EAAG,KAAK,CAAC,GACTH,IAAO;AAAA,SACF;AAOL,UAJA1E,IAAKA,IAAKyE,IAAU,IAAI,GACxB3yB,IAAI,GAGAszB,KAAM,GAAG;AAMX,aALAh5B,IAAI,GACJizB,IAAKA,EAAG,CAAC,GACTW,MAGQluB,IAAIozB,MAAM94B,MAAM4zB,KAAMluB;AAC5B,UAAA0O,KAAIpU,IAAIk1B,KAAQlC,EAAGttB,CAAC,KAAK,IACzB+yB,EAAG/yB,CAAC,IAAI0O,KAAI6e,IAAK,GACjBjzB,IAAIoU,KAAI6e,IAAK;AAGf,QAAAqF,IAAOt4B,KAAK0F,IAAIozB;AAAA,MAGxB,OAAa;AAiBL,aAdA94B,IAAIk1B,KAAQjC,EAAG,CAAC,IAAI,KAAK,GAErBjzB,IAAI,MACNizB,IAAK6E,EAAgB7E,GAAIjzB,GAAGk1B,CAAI,GAChClC,IAAK8E,EAAgB9E,GAAIhzB,GAAGk1B,CAAI,GAChC8D,IAAK/F,EAAG,QACR6F,KAAK9F,EAAG,SAGV6F,KAAKG,GACLN,IAAM1F,EAAG,MAAM,GAAGgG,CAAE,GACpBL,IAAOD,EAAI,QAGJC,IAAOK;AAAK,UAAAN,EAAIC,GAAM,IAAI;AAEjC,QAAAM,KAAKhG,EAAG,SACRgG,GAAG,QAAQ,CAAC,GACZF,KAAM9F,EAAG,CAAC,GAENA,EAAG,CAAC,KAAKiC,IAAO,KAAG,EAAE6D;AAEzB;AACE,UAAA/4B,IAAI,GAGJo4B,IAAMJ,EAAQ/E,GAAIyF,GAAKM,GAAIL,CAAI,GAG3BP,IAAM,KAGRQ,IAAOF,EAAI,CAAC,GACRM,KAAML,MAAMC,IAAOA,IAAO1D,KAAQwD,EAAI,CAAC,KAAK,KAGhD14B,IAAI44B,IAAOG,KAAM,GAUb/4B,IAAI,KACFA,KAAKk1B,MAAMl1B,IAAIk1B,IAAO,IAG1BqD,IAAOT,EAAgB7E,GAAIjzB,GAAGk1B,CAAI,GAClCsD,IAAQD,EAAK,QACbI,IAAOD,EAAI,QAGXN,IAAMJ,EAAQO,GAAMG,GAAKF,GAAOG,CAAI,GAGhCP,KAAO,MACTp4B,KAGAm4B,EAASI,GAAMS,IAAKR,IAAQS,KAAKhG,GAAIuF,GAAOtD,CAAI,OAO9Cl1B,KAAK,MAAGo4B,IAAMp4B,IAAI,IACtBu4B,IAAOtF,EAAG,UAGZuF,IAAQD,EAAK,QACTC,IAAQG,KAAMJ,EAAK,QAAQ,CAAC,GAGhCJ,EAASO,GAAKH,GAAMI,GAAMzD,CAAI,GAG1BkD,KAAO,OACTO,IAAOD,EAAI,QAGXN,IAAMJ,EAAQ/E,GAAIyF,GAAKM,GAAIL,CAAI,GAG3BP,IAAM,MACRp4B,KAGAm4B,EAASO,GAAKM,IAAKL,IAAOM,KAAKhG,GAAI0F,GAAMzD,CAAI,KAIjDyD,IAAOD,EAAI,UACFN,MAAQ,MACjBp4B,KACA04B,IAAM,CAAC,CAAC,IAIVD,EAAG/yB,GAAG,IAAI1F,GAGNo4B,KAAOM,EAAI,CAAC,IACdA,EAAIC,GAAM,IAAI3F,EAAG6F,EAAE,KAAK,KAExBH,IAAM,CAAC1F,EAAG6F,EAAE,CAAC,GACbF,IAAO;AAAA,gBAGDE,OAAOC,MAAMJ,EAAI,CAAC,MAAM,WAAW9E;AAE7C,QAAA0E,IAAOI,EAAI,CAAC,MAAM;AAAA,MACnB;AAGD,MAAKD,EAAG,CAAC,KAAGA,EAAG,MAAK;AAAA,IACrB;AAGD,QAAIJ,KAAW;AACb,MAAAvC,EAAE,IAAIhuB,GACNupB,KAAUiH;AAAA,SACL;AAGL,WAAK5yB,IAAI,GAAG1F,IAAIy4B,EAAG,CAAC,GAAGz4B,KAAK,IAAIA,KAAK;AAAI,QAAA0F;AACzC,MAAAowB,EAAE,IAAIpwB,IAAIoC,IAAIuwB,IAAU,GAExB5F,EAASqD,GAAGQ,IAAKlD,IAAK0C,EAAE,IAAI,IAAI1C,GAAIC,GAAIiF,CAAI;AAAA,IAC7C;AAED,WAAOxC;AAAA,EACX;AACA;AAOC,SAASrD,EAASjtB,GAAGouB,GAAIP,GAAI8F,GAAa;AACzC,MAAIC,GAAQ1zB,GAAGmtB,GAAG7yB,GAAGs3B,GAAI+B,GAASpF,GAAGjB,GAAIsG,GACvC3G,IAAOntB,EAAE;AAGX,EAAAmnB;AAAK,QAAIiH,KAAM,MAAM;AAInB,UAHAZ,IAAKxtB,EAAE,GAGH,CAACwtB;AAAI,eAAOxtB;AAWhB,WAAK4zB,IAAS,GAAGp5B,IAAIgzB,EAAG,CAAC,GAAGhzB,KAAK,IAAIA,KAAK;AAAI,QAAAo5B;AAI9C,UAHA1zB,IAAIkuB,IAAKwF,GAGL1zB,IAAI;AACN,QAAAA,KAAK0sB,GACLS,IAAIe,GACJK,IAAIjB,EAAGsG,IAAM,CAAC,GAGdhC,IAAKrD,IAAInC,EAAQ,IAAIsH,IAASvG,IAAI,CAAC,IAAI,KAAK;AAAA,eAE5CyG,IAAM,KAAK,MAAM5zB,IAAI,KAAK0sB,CAAQ,GAClCpyB,IAAIgzB,EAAG,QACHsG,KAAOt5B;AACT,YAAIm5B,GAAa;AAGf,iBAAOn5B,OAAOs5B;AAAM,YAAAtG,EAAG,KAAK,CAAC;AAC7B,UAAAiB,IAAIqD,IAAK,GACT8B,IAAS,GACT1zB,KAAK0sB,GACLS,IAAIntB,IAAI0sB,IAAW;AAAA,QAC7B;AACU,gBAAMzF;AAAA,WAEH;AAIL,aAHAsH,IAAIj0B,IAAIgzB,EAAGsG,CAAG,GAGTF,IAAS,GAAGp5B,KAAK,IAAIA,KAAK;AAAI,UAAAo5B;AAGnC,QAAA1zB,KAAK0sB,GAILS,IAAIntB,IAAI0sB,IAAWgH,GAGnB9B,IAAKzE,IAAI,IAAI,IAAIoB,IAAInC,EAAQ,IAAIsH,IAASvG,IAAI,CAAC,IAAI,KAAK;AAAA,MACzD;AAmBH,UAfAsG,IAAcA,KAAevF,IAAK,KAChCZ,EAAGsG,IAAM,CAAC,MAAM,WAAWzG,IAAI,IAAIoB,IAAIA,IAAInC,EAAQ,IAAIsH,IAASvG,IAAI,CAAC,IAMvEwG,IAAUhG,IAAK,KACViE,KAAM6B,OAAiB9F,KAAM,KAAKA,MAAO7tB,EAAE,IAAI,IAAI,IAAI,MACxD8xB,IAAK,KAAKA,KAAM,MAAMjE,KAAM,KAAK8F,KAAe9F,KAAM;AAAA,OAGpD3tB,IAAI,IAAImtB,IAAI,IAAIoB,IAAInC,EAAQ,IAAIsH,IAASvG,CAAC,IAAI,IAAIG,EAAGsG,IAAM,CAAC,KAAK,KAAM,KACvEjG,MAAO7tB,EAAE,IAAI,IAAI,IAAI,KAEvBouB,IAAK,KAAK,CAACZ,EAAG,CAAC;AACjB,eAAAA,EAAG,SAAS,GACRqG,KAGFzF,KAAMpuB,EAAE,IAAI,GAGZwtB,EAAG,CAAC,IAAIlB,EAAQ,KAAKM,IAAWwB,IAAKxB,KAAYA,CAAQ,GACzD5sB,EAAE,IAAI,CAACouB,KAAM,KAIbZ,EAAG,CAAC,IAAIxtB,EAAE,IAAI,GAGTA;AAiBT,UAbIE,KAAK,KACPstB,EAAG,SAASsG,GACZt5B,IAAI,GACJs5B,QAEAtG,EAAG,SAASsG,IAAM,GAClBt5B,IAAI8xB,EAAQ,IAAIM,IAAW1sB,CAAC,GAI5BstB,EAAGsG,CAAG,IAAIzG,IAAI,KAAKoB,IAAInC,EAAQ,IAAIsH,IAASvG,CAAC,IAAIf,EAAQ,IAAIe,CAAC,IAAI,KAAK7yB,IAAI,IAGzEq5B;AACF;AAGE,cAAIC,KAAO,GAAG;AAGZ,iBAAK5zB,IAAI,GAAGmtB,IAAIG,EAAG,CAAC,GAAGH,KAAK,IAAIA,KAAK;AAAI,cAAAntB;AAEzC,iBADAmtB,IAAIG,EAAG,CAAC,KAAKhzB,GACRA,IAAI,GAAG6yB,KAAK,IAAIA,KAAK;AAAI,cAAA7yB;AAG9B,YAAI0F,KAAK1F,MACPwF,EAAE,KACEwtB,EAAG,CAAC,KAAKb,MAAMa,EAAG,CAAC,IAAI;AAG7B;AAAA,UACV,OAAe;AAEL,gBADAA,EAAGsG,CAAG,KAAKt5B,GACPgzB,EAAGsG,CAAG,KAAKnH;AAAM;AACrB,YAAAa,EAAGsG,GAAK,IAAI,GACZt5B,IAAI;AAAA,UACL;AAKL,WAAK0F,IAAIstB,EAAG,QAAQA,EAAG,EAAEttB,CAAC,MAAM;AAAI,QAAAstB,EAAG;IACxC;AAED,SAAIzB,MAGE/rB,EAAE,IAAImtB,EAAK,QAGbntB,EAAE,IAAI,MACNA,EAAE,IAAI,OAGGA,EAAE,IAAImtB,EAAK,SAGpBntB,EAAE,IAAI,GACNA,EAAE,IAAI,CAAC,CAAC,KAKLA;AACT;AAGA,SAASgxB,EAAehxB,GAAG+zB,GAAO3F,GAAI;AACpC,MAAI,CAACpuB,EAAE,SAAQ;AAAI,WAAOg0B,GAAkBh0B,CAAC;AAC7C,MAAIxF,GACF8H,IAAItC,EAAE,GACNvC,IAAM8wB,EAAevuB,EAAE,CAAC,GACxBskB,IAAM7mB,EAAI;AAEZ,SAAIs2B,KACE3F,MAAO5zB,IAAI4zB,IAAK9J,KAAO,IACzB7mB,IAAMA,EAAI,OAAO,CAAC,IAAI,MAAMA,EAAI,MAAM,CAAC,IAAIk0B,GAAcn3B,CAAC,IACjD8pB,IAAM,MACf7mB,IAAMA,EAAI,OAAO,CAAC,IAAI,MAAMA,EAAI,MAAM,CAAC,IAGzCA,IAAMA,KAAOuC,EAAE,IAAI,IAAI,MAAM,QAAQA,EAAE,KAC9BsC,IAAI,KACb7E,IAAM,OAAOk0B,GAAc,CAACrvB,IAAI,CAAC,IAAI7E,GACjC2wB,MAAO5zB,IAAI4zB,IAAK9J,KAAO,MAAG7mB,KAAOk0B,GAAcn3B,CAAC,MAC3C8H,KAAKgiB,KACd7mB,KAAOk0B,GAAcrvB,IAAI,IAAIgiB,CAAG,GAC5B8J,MAAO5zB,IAAI4zB,IAAK9rB,IAAI,KAAK,MAAG7E,IAAMA,IAAM,MAAMk0B,GAAcn3B,CAAC,QAE5DA,IAAI8H,IAAI,KAAKgiB,MAAK7mB,IAAMA,EAAI,MAAM,GAAGjD,CAAC,IAAI,MAAMiD,EAAI,MAAMjD,CAAC,IAC5D4zB,MAAO5zB,IAAI4zB,IAAK9J,KAAO,MACrBhiB,IAAI,MAAMgiB,MAAK7mB,KAAO,MAC1BA,KAAOk0B,GAAcn3B,CAAC,KAInBiD;AACT;AAIA,SAAS4yB,GAAkBuD,GAAQtxB,GAAG;AACpC,MAAImsB,IAAImF,EAAO,CAAC;AAGhB,OAAMtxB,KAAKsqB,GAAU6B,KAAK,IAAIA,KAAK;AAAI,IAAAnsB;AACvC,SAAOA;AACT;AAGA,SAAS2tB,GAAQ9C,GAAMiB,GAAIR,GAAI;AAC7B,MAAIQ,IAAKtB;AAGP,UAAAf,IAAW,IACP6B,MAAIT,EAAK,YAAYS,IACnB,MAAM1B,EAAsB;AAEpC,SAAOe,EAAS,IAAIE,EAAKzB,EAAI,GAAG0C,GAAI,GAAG,EAAI;AAC7C;AAGA,SAASiB,EAAMlC,GAAMiB,GAAIP,GAAI;AAC3B,MAAIO,IAAKrB;AAAc,UAAM,MAAMb,EAAsB;AACzD,SAAOe,EAAS,IAAIE,EAAKxB,EAAE,GAAGyC,GAAIP,GAAI,EAAI;AAC5C;AAGA,SAAS6C,GAAakD,GAAQ;AAC5B,MAAInF,IAAImF,EAAO,SAAS,GACtBtP,IAAMmK,IAAI7B,IAAW;AAKvB,MAHA6B,IAAImF,EAAOnF,CAAC,GAGRA,GAAG;AAGL,WAAOA,IAAI,MAAM,GAAGA,KAAK;AAAI,MAAAnK;AAG7B,SAAKmK,IAAImF,EAAO,CAAC,GAAGnF,KAAK,IAAIA,KAAK;AAAI,MAAAnK;AAAA,EACvC;AAED,SAAOA;AACT;AAGA,SAASqN,GAAcn3B,GAAG;AAExB,WADIy5B,IAAK,IACFz5B;AAAM,IAAAy5B,KAAM;AACnB,SAAOA;AACT;AAUA,SAASzC,GAAOrE,GAAMntB,GAAGiuB,GAAGL,GAAI;AAC9B,MAAI+F,GACF1qB,IAAI,IAAIkkB,EAAK,CAAC,GAId3yB,IAAI,KAAK,KAAKozB,IAAKhB,IAAW,CAAC;AAIjC,OAFAb,IAAW,QAEF;AAOP,QANIkC,IAAI,MACNhlB,IAAIA,EAAE,MAAMjJ,CAAC,GACTk0B,GAASjrB,EAAE,GAAGzO,CAAC,MAAGm5B,IAAc,MAGtC1F,IAAI5B,EAAU4B,IAAI,CAAC,GACfA,MAAM,GAAG;AAGX,MAAAA,IAAIhlB,EAAE,EAAE,SAAS,GACb0qB,KAAe1qB,EAAE,EAAEglB,CAAC,MAAM,KAAG,EAAEhlB,EAAE,EAAEglB,CAAC;AACxC;AAAA,IACD;AAED,IAAAjuB,IAAIA,EAAE,MAAMA,CAAC,GACbk0B,GAASl0B,EAAE,GAAGxF,CAAC;AAAA,EAChB;AAED,SAAAuxB,IAAW,IAEJ9iB;AACT;AAGA,SAASkrB,GAAMlG,GAAG;AAChB,SAAOA,EAAE,EAAEA,EAAE,EAAE,SAAS,CAAC,IAAI;AAC/B;AAMA,SAASmG,GAASjH,GAAMjsB,GAAMmzB,GAAM;AAKlC,WAJIjH,GACFptB,IAAI,IAAImtB,EAAKjsB,EAAK,CAAC,CAAC,GACpBhB,IAAI,GAEC,EAAEA,IAAIgB,EAAK;AAEhB,QADAksB,IAAI,IAAID,EAAKjsB,EAAKhB,CAAC,CAAC,GACfktB,EAAE;AAGA,MAAIptB,EAAEq0B,CAAI,EAAEjH,CAAC,MAClBptB,IAAIotB;AAAA,SAJI;AACR,MAAAptB,IAAIotB;AACJ;AAAA,IACD;AAKH,SAAOptB;AACT;AAkCA,SAASuwB,GAAmBvwB,GAAGouB,GAAI;AACjC,MAAIwB,GAAaG,GAAO1C,GAAGiH,GAAKC,GAAK3lB,GAAG0gB,GACtCpB,IAAM,GACNhuB,IAAI,GACJ1F,IAAI,GACJ2yB,IAAOntB,EAAE,aACT6tB,IAAKV,EAAK,UACVS,IAAKT,EAAK;AAGZ,MAAI,CAACntB,EAAE,KAAK,CAACA,EAAE,EAAE,CAAC,KAAKA,EAAE,IAAI;AAE3B,WAAO,IAAImtB,EAAKntB,EAAE,IACbA,EAAE,EAAE,CAAC,IAAQA,EAAE,IAAI,IAAI,IAAI,IAAI,IAAtB,IACVA,EAAE,IAAIA,EAAE,IAAI,IAAI,IAAIA,IAAI,IAAI,CAAC;AAanC,OAVIouB,KAAM,QACRrC,IAAW,IACXuD,IAAM1B,KAEN0B,IAAMlB,GAGRxf,IAAI,IAAIue,EAAK,OAAO,GAGbntB,EAAE,IAAI;AAGX,IAAAA,IAAIA,EAAE,MAAM4O,CAAC,GACbpU,KAAK;AAUP,OALAu1B,IAAQ,KAAK,IAAIzD,EAAQ,GAAG9xB,CAAC,CAAC,IAAI,KAAK,OAAO,IAAI,IAAI,GACtD80B,KAAOS,GACPH,IAAc0E,IAAMC,IAAM,IAAIpH,EAAK,CAAC,GACpCA,EAAK,YAAYmC,OAER;AAKP,QAJAgF,IAAMrH,EAASqH,EAAI,MAAMt0B,CAAC,GAAGsvB,GAAK,CAAC,GACnCM,IAAcA,EAAY,MAAM,EAAE1vB,CAAC,GACnC0O,IAAI2lB,EAAI,KAAK/F,EAAO8F,GAAK1E,GAAaN,GAAK,CAAC,CAAC,GAEzCf,EAAe3f,EAAE,CAAC,EAAE,MAAM,GAAG0gB,CAAG,MAAMf,EAAegG,EAAI,CAAC,EAAE,MAAM,GAAGjF,CAAG,GAAG;AAE7E,WADAjC,IAAI7yB,GACG6yB;AAAK,QAAAkH,IAAMtH,EAASsH,EAAI,MAAMA,CAAG,GAAGjF,GAAK,CAAC;AAOjD,UAAIlB,KAAM;AAER,YAAIF,IAAM,KAAKgC,GAAoBqE,EAAI,GAAGjF,IAAMS,GAAOlC,GAAIK,CAAG;AAC5D,UAAAf,EAAK,YAAYmC,KAAO,IACxBM,IAAc0E,IAAM1lB,IAAI,IAAIue,EAAK,CAAC,GAClCjtB,IAAI,GACJguB;AAAA;AAEA,iBAAOjB,EAASsH,GAAKpH,EAAK,YAAYS,GAAIC,GAAI9B,IAAW,EAAI;AAAA;AAG/D,eAAAoB,EAAK,YAAYS,GACV2G;AAAA,IAEV;AAED,IAAAA,IAAM3lB;AAAA,EACP;AACH;AAkBA,SAASohB,GAAiB5C,GAAGgB,GAAI;AAC/B,MAAI9hB,GAAGkoB,GAAI5E,GAAattB,GAAGmyB,GAAWvG,GAAKqG,GAAK3lB,GAAG0gB,GAAKoF,GAAIjF,GAC1DxB,IAAI,GACJ8B,IAAQ,IACR/vB,IAAIotB,GACJI,IAAKxtB,EAAE,GACPmtB,IAAOntB,EAAE,aACT6tB,IAAKV,EAAK,UACVS,IAAKT,EAAK;AAGZ,MAAIntB,EAAE,IAAI,KAAK,CAACwtB,KAAM,CAACA,EAAG,CAAC,KAAK,CAACxtB,EAAE,KAAKwtB,EAAG,CAAC,KAAK,KAAKA,EAAG,UAAU;AACjE,WAAO,IAAIL,EAAKK,KAAM,CAACA,EAAG,CAAC,IAAI,KAAK,IAAIxtB,EAAE,KAAK,IAAI,MAAMwtB,IAAK,IAAIxtB,CAAC;AAcrE,MAXIouB,KAAM,QACRrC,IAAW,IACXuD,IAAM1B,KAEN0B,IAAMlB,GAGRjB,EAAK,YAAYmC,KAAOS,GACxBzjB,IAAIiiB,EAAef,CAAE,GACrBgH,IAAKloB,EAAE,OAAO,CAAC,GAEX,KAAK,IAAIhK,IAAItC,EAAE,CAAC,IAAI,OAAQ;AAa9B,WAAOw0B,IAAK,KAAKA,KAAM,KAAKA,KAAM,KAAKloB,EAAE,OAAO,CAAC,IAAI;AACnD,MAAAtM,IAAIA,EAAE,MAAMotB,CAAC,GACb9gB,IAAIiiB,EAAevuB,EAAE,CAAC,GACtBw0B,IAAKloB,EAAE,OAAO,CAAC,GACf2hB;AAGF,IAAA3rB,IAAItC,EAAE,GAEFw0B,IAAK,KACPx0B,IAAI,IAAImtB,EAAK,OAAO7gB,CAAC,GACrBhK,OAEAtC,IAAI,IAAImtB,EAAKqH,IAAK,MAAMloB,EAAE,MAAM,CAAC,CAAC;AAAA,EAExC;AAKI,WAAAsC,IAAIqhB,GAAQ9C,GAAMmC,IAAM,GAAG1B,CAAE,EAAE,MAAMtrB,IAAI,EAAE,GAC3CtC,IAAIgwB,GAAiB,IAAI7C,EAAKqH,IAAK,MAAMloB,EAAE,MAAM,CAAC,CAAC,GAAGgjB,IAAMS,CAAK,EAAE,KAAKnhB,CAAC,GACzEue,EAAK,YAAYS,GAEVQ,KAAM,OAAOnB,EAASjtB,GAAG4tB,GAAIC,GAAI9B,IAAW,EAAI,IAAI/rB;AAa7D,OATA00B,IAAK10B,GAKLu0B,IAAME,IAAYz0B,IAAIwuB,EAAOxuB,EAAE,MAAM,CAAC,GAAGA,EAAE,KAAK,CAAC,GAAGsvB,GAAK,CAAC,GAC1DG,IAAKxC,EAASjtB,EAAE,MAAMA,CAAC,GAAGsvB,GAAK,CAAC,GAChCM,IAAc,OAEL;AAIP,QAHA6E,IAAYxH,EAASwH,EAAU,MAAMhF,CAAE,GAAGH,GAAK,CAAC,GAChD1gB,IAAI2lB,EAAI,KAAK/F,EAAOiG,GAAW,IAAItH,EAAKyC,CAAW,GAAGN,GAAK,CAAC,CAAC,GAEzDf,EAAe3f,EAAE,CAAC,EAAE,MAAM,GAAG0gB,CAAG,MAAMf,EAAegG,EAAI,CAAC,EAAE,MAAM,GAAGjF,CAAG;AAc1E,UAbAiF,IAAMA,EAAI,MAAM,CAAC,GAIbjyB,MAAM,MAAGiyB,IAAMA,EAAI,KAAKtE,GAAQ9C,GAAMmC,IAAM,GAAG1B,CAAE,EAAE,MAAMtrB,IAAI,EAAE,CAAC,IACpEiyB,IAAM/F,EAAO+F,GAAK,IAAIpH,EAAKc,CAAC,GAAGqB,GAAK,CAAC,GAQjClB,KAAM;AACR,YAAI8B,GAAoBqE,EAAI,GAAGjF,IAAMS,GAAOlC,GAAIK,CAAG;AACjD,UAAAf,EAAK,YAAYmC,KAAOS,GACxBnhB,IAAI6lB,IAAYz0B,IAAIwuB,EAAOkG,EAAG,MAAM,CAAC,GAAGA,EAAG,KAAK,CAAC,GAAGpF,GAAK,CAAC,GAC1DG,IAAKxC,EAASjtB,EAAE,MAAMA,CAAC,GAAGsvB,GAAK,CAAC,GAChCM,IAAc1B,IAAM;AAAA;AAEpB,iBAAOjB,EAASsH,GAAKpH,EAAK,YAAYS,GAAIC,GAAI9B,IAAW,EAAI;AAAA;AAG/D,eAAAoB,EAAK,YAAYS,GACV2G;AAIX,IAAAA,IAAM3lB,GACNghB,KAAe;AAAA,EAChB;AACH;AAIA,SAASoE,GAAkBh0B,GAAG;AAE5B,SAAO,OAAOA,EAAE,IAAIA,EAAE,IAAI,CAAC;AAC7B;AAMA,SAAS20B,GAAa30B,GAAGvC,GAAK;AAC5B,MAAI6E,GAAGpC,GAAGokB;AAmBV,QAhBKhiB,IAAI7E,EAAI,QAAQ,GAAG,KAAK,OAAIA,IAAMA,EAAI,QAAQ,KAAK,EAAE,KAGrDyC,IAAIzC,EAAI,OAAO,IAAI,KAAK,KAGvB6E,IAAI,MAAGA,IAAIpC,IACfoC,KAAK,CAAC7E,EAAI,MAAMyC,IAAI,CAAC,GACrBzC,IAAMA,EAAI,UAAU,GAAGyC,CAAC,KACfoC,IAAI,MAGbA,IAAI7E,EAAI,SAILyC,IAAI,GAAGzC,EAAI,WAAWyC,CAAC,MAAM,IAAIA;AAAI;AAG1C,OAAKokB,IAAM7mB,EAAI,QAAQA,EAAI,WAAW6mB,IAAM,CAAC,MAAM,IAAI,EAAEA;AAAI;AAG7D,MAFA7mB,IAAMA,EAAI,MAAMyC,GAAGokB,CAAG,GAElB7mB,GAAK;AAYP,QAXA6mB,KAAOpkB,GACPF,EAAE,IAAIsC,IAAIA,IAAIpC,IAAI,GAClBF,EAAE,IAAI,IAMNE,KAAKoC,IAAI,KAAKsqB,GACVtqB,IAAI,MAAGpC,KAAK0sB,IAEZ1sB,IAAIokB,GAAK;AAEX,WADIpkB,KAAGF,EAAE,EAAE,KAAK,CAACvC,EAAI,MAAM,GAAGyC,CAAC,CAAC,GAC3BokB,KAAOsI,GAAU1sB,IAAIokB;AAAM,QAAAtkB,EAAE,EAAE,KAAK,CAACvC,EAAI,MAAMyC,GAAGA,KAAK0sB,CAAQ,CAAC;AACrE,MAAAnvB,IAAMA,EAAI,MAAMyC,CAAC,GACjBA,IAAI0sB,IAAWnvB,EAAI;AAAA,IACzB;AACM,MAAAyC,KAAKokB;AAGP,WAAOpkB;AAAM,MAAAzC,KAAO;AACpB,IAAAuC,EAAE,EAAE,KAAK,CAACvC,CAAG,GAETsuB,MAGE/rB,EAAE,IAAIA,EAAE,YAAY,QAGtBA,EAAE,IAAI,MACNA,EAAE,IAAI,OAGGA,EAAE,IAAIA,EAAE,YAAY,SAG7BA,EAAE,IAAI,GACNA,EAAE,IAAI,CAAC,CAAC;AAAA,EAIhB;AAGI,IAAAA,EAAE,IAAI,GACNA,EAAE,IAAI,CAAC,CAAC;AAGV,SAAOA;AACT;AAMA,SAAS40B,GAAW50B,GAAGvC,GAAK;AAC1B,MAAIiyB,GAAMvC,GAAM0H,GAAS30B,GAAG40B,GAASxQ,GAAK5T,GAAG8c,GAAI2C;AAEjD,MAAI1yB,EAAI,QAAQ,GAAG,IAAI;AAErB,QADAA,IAAMA,EAAI,QAAQ,gBAAgB,IAAI,GAClCivB,GAAU,KAAKjvB,CAAG;AAAG,aAAOk3B,GAAa30B,GAAGvC,CAAG;AAAA,aAC1CA,MAAQ,cAAcA,MAAQ;AACvC,WAAK,CAACA,MAAKuC,EAAE,IAAI,MACjBA,EAAE,IAAI,KACNA,EAAE,IAAI,MACCA;AAGT,MAAIwsB,GAAM,KAAK/uB,CAAG;AAChB,IAAAiyB,IAAO,IACPjyB,IAAMA,EAAI;WACD8uB,GAAS,KAAK9uB,CAAG;AAC1B,IAAAiyB,IAAO;AAAA,WACEjD,GAAQ,KAAKhvB,CAAG;AACzB,IAAAiyB,IAAO;AAAA;AAEP,UAAM,MAAMzD,KAAkBxuB,CAAG;AAgCnC,OA5BAyC,IAAIzC,EAAI,OAAO,IAAI,GAEfyC,IAAI,KACNwQ,IAAI,CAACjT,EAAI,MAAMyC,IAAI,CAAC,GACpBzC,IAAMA,EAAI,UAAU,GAAGyC,CAAC,KAExBzC,IAAMA,EAAI,MAAM,CAAC,GAKnByC,IAAIzC,EAAI,QAAQ,GAAG,GACnBq3B,IAAU50B,KAAK,GACfitB,IAAOntB,EAAE,aAEL80B,MACFr3B,IAAMA,EAAI,QAAQ,KAAK,EAAE,GACzB6mB,IAAM7mB,EAAI,QACVyC,IAAIokB,IAAMpkB,GAGV20B,IAAUrD,GAAOrE,GAAM,IAAIA,EAAKuC,CAAI,GAAGxvB,GAAGA,IAAI,CAAC,IAGjDstB,IAAKuE,GAAYt0B,GAAKiyB,GAAM/C,CAAI,GAChCwD,IAAK3C,EAAG,SAAS,GAGZttB,IAAIiwB,GAAI3C,EAAGttB,CAAC,MAAM,GAAG,EAAEA;AAAG,IAAAstB,EAAG;AAClC,SAAIttB,IAAI,IAAU,IAAIitB,EAAKntB,EAAE,IAAI,CAAC,KAClCA,EAAE,IAAIqwB,GAAkB7C,GAAI2C,CAAE,GAC9BnwB,EAAE,IAAIwtB,GACNzB,IAAW,IAQP+I,MAAS90B,IAAIwuB,EAAOxuB,GAAG60B,GAASvQ,IAAM,CAAC,IAGvC5T,MAAG1Q,IAAIA,EAAE,MAAM,KAAK,IAAI0Q,CAAC,IAAI,KAAK4b,EAAQ,GAAG5b,CAAC,IAAIqkB,GAAQ,IAAI,GAAGrkB,CAAC,CAAC,IACvEqb,IAAW,IAEJ/rB;AACT;AAQA,SAAS2wB,GAAKxD,GAAMntB,GAAG;AACrB,MAAIxF,GACF8pB,IAAMtkB,EAAE,EAAE;AAEZ,MAAIskB,IAAM;AACR,WAAOtkB,EAAE,OAAQ,IAAGA,IAAI6uB,GAAa1B,GAAM,GAAGntB,GAAGA,CAAC;AAQpD,EAAAxF,IAAI,MAAM,KAAK,KAAK8pB,CAAG,GACvB9pB,IAAIA,IAAI,KAAK,KAAKA,IAAI,GAEtBwF,IAAIA,EAAE,MAAM,IAAI4uB,GAAQ,GAAGp0B,CAAC,CAAC,GAC7BwF,IAAI6uB,GAAa1B,GAAM,GAAGntB,GAAGA,CAAC;AAO9B,WAJIg1B,GACF/F,IAAK,IAAI9B,EAAK,CAAC,GACf+B,IAAM,IAAI/B,EAAK,EAAE,GACjBgC,IAAM,IAAIhC,EAAK,EAAE,GACZ3yB;AACL,IAAAw6B,IAASh1B,EAAE,MAAMA,CAAC,GAClBA,IAAIA,EAAE,MAAMivB,EAAG,KAAK+F,EAAO,MAAM9F,EAAI,MAAM8F,CAAM,EAAE,MAAM7F,CAAG,CAAC,CAAC,CAAC;AAGjE,SAAOnvB;AACT;AAIA,SAAS6uB,GAAa1B,GAAM,GAAGntB,GAAGotB,GAAG6H,GAAc;AAC9C,MAAC5H,GAAGze,GAAG,GAAG6gB,GAEX7B,IAAKT,EAAK,WACV3yB,IAAI,KAAK,KAAKozB,IAAKhB,CAAQ;AAM7B,OAJAb,IAAW,IACX0D,IAAKzvB,EAAE,MAAMA,CAAC,GACd,IAAI,IAAImtB,EAAKC,CAAC,OAEL;AAMP,QALAxe,IAAI4f,EAAO,EAAE,MAAMiB,CAAE,GAAG,IAAItC,EAAK,MAAM,GAAG,GAAGS,GAAI,CAAC,GAClD,IAAIqH,IAAe7H,EAAE,KAAKxe,CAAC,IAAIwe,EAAE,MAAMxe,CAAC,GACxCwe,IAAIoB,EAAO5f,EAAE,MAAM6gB,CAAE,GAAG,IAAItC,EAAK,MAAM,GAAG,GAAGS,GAAI,CAAC,GAClDhf,IAAI,EAAE,KAAKwe,CAAC,GAERxe,EAAE,EAAEpU,CAAC,MAAM,QAAQ;AACrB,WAAK6yB,IAAI7yB,GAAGoU,EAAE,EAAEye,CAAC,MAAM,EAAE,EAAEA,CAAC,KAAKA;AAAK;AACtC,UAAIA,KAAK;AAAI;AAAA,IACd;AAED,IAAAA,IAAI,GACJ,IAAID,GACJA,IAAIxe,GACJA,IAAIye;AAAA,EAEL;AAED,SAAAtB,IAAW,IACXnd,EAAE,EAAE,SAASpU,IAAI,GAEVoU;AACT;AAIA,SAASggB,GAAQlvB,GAAG4C,GAAG;AAErB,WADI2rB,IAAIvuB,GACD,EAAE4C;AAAG,IAAA2rB,KAAKvuB;AACjB,SAAOuuB;AACT;AAIA,SAASF,GAAiBZ,GAAMntB,GAAG;AACjC,MAAI,GACFk1B,IAAQl1B,EAAE,IAAI,GACdm1B,IAAK9F,EAAMlC,GAAMA,EAAK,WAAW,CAAC,GAClCiC,IAAS+F,EAAG,MAAM,GAAG;AAIvB,MAFAn1B,IAAIA,EAAE,OAEFA,EAAE,IAAIovB,CAAM;AACd,WAAAtD,IAAWoJ,IAAQ,IAAI,GAChBl1B;AAKT,MAFA,IAAIA,EAAE,SAASm1B,CAAE,GAEb,EAAE;AACJ,IAAArJ,IAAWoJ,IAAQ,IAAI;AAAA,OAClB;AAIL,QAHAl1B,IAAIA,EAAE,MAAM,EAAE,MAAMm1B,CAAE,CAAC,GAGnBn1B,EAAE,IAAIovB,CAAM;AACd,aAAAtD,IAAWqI,GAAM,CAAC,IAAKe,IAAQ,IAAI,IAAMA,IAAQ,IAAI,GAC9Cl1B;AAGT,IAAA8rB,IAAWqI,GAAM,CAAC,IAAKe,IAAQ,IAAI,IAAMA,IAAQ,IAAI;AAAA,EACtD;AAED,SAAOl1B,EAAE,MAAMm1B,CAAE,EAAE,IAAG;AACxB;AAQA,SAAStE,GAAe7wB,GAAGiyB,GAAS7D,GAAIP,GAAI;AAC1C,MAAI6B,GAAMptB,GAAGpC,GAAG1F,GAAG8pB,GAAKuP,GAASp2B,GAAK+vB,GAAIJ,GACxCD,IAAOntB,EAAE,aACT+zB,IAAQ3F,MAAO;AAWjB,MATI2F,KACFhD,EAAW3C,GAAI,GAAG5C,EAAU,GACxBqC,MAAO,SAAQA,IAAKV,EAAK,WACxB4D,EAAWlD,GAAI,GAAG,CAAC,MAExBO,IAAKjB,EAAK,WACVU,IAAKV,EAAK,WAGR,CAACntB,EAAE;AACL,IAAAvC,IAAMu2B,GAAkBh0B,CAAC;AAAA,OACpB;AAoCL,SAnCAvC,IAAMuzB,EAAehxB,CAAC,GACtBE,IAAIzC,EAAI,QAAQ,GAAG,GAOfs2B,KACFrE,IAAO,GACHuC,KAAW,KACb7D,IAAKA,IAAK,IAAI,IACL6D,KAAW,MACpB7D,IAAKA,IAAK,IAAI,MAGhBsB,IAAOuC,GAOL/xB,KAAK,MACPzC,IAAMA,EAAI,QAAQ,KAAK,EAAE,GACzB2vB,IAAI,IAAID,EAAK,CAAC,GACdC,EAAE,IAAI3vB,EAAI,SAASyC,GACnBktB,EAAE,IAAI2E,GAAYf,EAAe5D,CAAC,GAAG,IAAIsC,CAAI,GAC7CtC,EAAE,IAAIA,EAAE,EAAE,SAGZI,IAAKuE,GAAYt0B,GAAK,IAAIiyB,CAAI,GAC9BptB,IAAIgiB,IAAMkJ,EAAG,QAGNA,EAAG,EAAElJ,CAAG,KAAK;AAAI,MAAAkJ,EAAG;AAE3B,QAAI,CAACA,EAAG,CAAC;AACP,MAAA/vB,IAAMs2B,IAAQ,SAAS;AAAA,SAClB;AAyBL,UAxBI7zB,IAAI,IACNoC,OAEAtC,IAAI,IAAImtB,EAAKntB,CAAC,GACdA,EAAE,IAAIwtB,GACNxtB,EAAE,IAAIsC,GACNtC,IAAIwuB,EAAOxuB,GAAGotB,GAAGgB,GAAIP,GAAI,GAAG6B,CAAI,GAChClC,IAAKxtB,EAAE,GACPsC,IAAItC,EAAE,GACN6zB,IAAUhI,KAIZ3rB,IAAIstB,EAAGY,CAAE,GACT5zB,IAAIk1B,IAAO,GACXmE,IAAUA,KAAWrG,EAAGY,IAAK,CAAC,MAAM,QAEpCyF,IAAUhG,IAAK,KACV3tB,MAAM,UAAU2zB,OAAahG,MAAO,KAAKA,OAAQ7tB,EAAE,IAAI,IAAI,IAAI,MAChEE,IAAI1F,KAAK0F,MAAM1F,MAAMqzB,MAAO,KAAKgG,KAAWhG,MAAO,KAAKL,EAAGY,IAAK,CAAC,IAAI,KACrEP,OAAQ7tB,EAAE,IAAI,IAAI,IAAI,KAE1BwtB,EAAG,SAASY,GAERyF;AAGF,eAAO,EAAErG,EAAG,EAAEY,CAAE,IAAIsB,IAAO;AACzB,UAAAlC,EAAGY,CAAE,IAAI,GACJA,MACH,EAAE9rB,GACFkrB,EAAG,QAAQ,CAAC;AAMlB,WAAKlJ,IAAMkJ,EAAG,QAAQ,CAACA,EAAGlJ,IAAM,CAAC,GAAG,EAAEA;AAAI;AAG1C,WAAKpkB,IAAI,GAAGzC,IAAM,IAAIyC,IAAIokB,GAAKpkB;AAAK,QAAAzC,KAAOguB,GAAS,OAAO+B,EAAGttB,CAAC,CAAC;AAGhE,UAAI6zB,GAAO;AACT,YAAIzP,IAAM;AACR,cAAI2N,KAAW,MAAMA,KAAW,GAAG;AAEjC,iBADA/xB,IAAI+xB,KAAW,KAAK,IAAI,GACnB,EAAE3N,GAAKA,IAAMpkB,GAAGokB;AAAO,cAAA7mB,KAAO;AAEnC,iBADA+vB,IAAKuE,GAAYt0B,GAAKiyB,GAAMuC,CAAO,GAC9B3N,IAAMkJ,EAAG,QAAQ,CAACA,EAAGlJ,IAAM,CAAC,GAAG,EAAEA;AAAI;AAG1C,iBAAKpkB,IAAI,GAAGzC,IAAM,MAAMyC,IAAIokB,GAAKpkB;AAAK,cAAAzC,KAAOguB,GAAS,OAAO+B,EAAGttB,CAAC,CAAC;AAAA,UAC9E;AACY,YAAAzC,IAAMA,EAAI,OAAO,CAAC,IAAI,MAAMA,EAAI,MAAM,CAAC;AAI3C,QAAAA,IAAOA,KAAO6E,IAAI,IAAI,MAAM,QAAQA;AAAA,MAC5C,WAAiBA,IAAI,GAAG;AAChB,eAAO,EAAEA;AAAI,UAAA7E,IAAM,MAAMA;AACzB,QAAAA,IAAM,OAAOA;AAAA,MACrB,WACY,EAAE6E,IAAIgiB;AAAK,aAAKhiB,KAAKgiB,GAAKhiB;AAAO,UAAA7E,KAAO;AAAA;AACvC,QAAI6E,IAAIgiB,MAAK7mB,IAAMA,EAAI,MAAM,GAAG6E,CAAC,IAAI,MAAM7E,EAAI,MAAM6E,CAAC;AAAA,IAE9D;AAED,IAAA7E,KAAOw0B,KAAW,KAAK,OAAOA,KAAW,IAAI,OAAOA,KAAW,IAAI,OAAO,MAAMx0B;AAAA,EACjF;AAED,SAAOuC,EAAE,IAAI,IAAI,MAAMvC,IAAMA;AAC/B;AAIA,SAASy2B,GAAShC,GAAK5N,GAAK;AAC1B,MAAI4N,EAAI,SAAS5N;AACf,WAAA4N,EAAI,SAAS5N,GACN;AAEX;AAyDA,SAAS8Q,GAAIp1B,GAAG;AACd,SAAO,IAAI,KAAKA,CAAC,EAAE,IAAG;AACxB;AASA,SAASq1B,GAAKr1B,GAAG;AACf,SAAO,IAAI,KAAKA,CAAC,EAAE,KAAI;AACzB;AAUA,SAASs1B,GAAMt1B,GAAG;AAChB,SAAO,IAAI,KAAKA,CAAC,EAAE,MAAK;AAC1B;AAWA,SAASu1B,GAAIv1B,GAAGotB,GAAG;AACjB,SAAO,IAAI,KAAKptB,CAAC,EAAE,KAAKotB,CAAC;AAC3B;AAUA,SAASoI,GAAKx1B,GAAG;AACf,SAAO,IAAI,KAAKA,CAAC,EAAE,KAAI;AACzB;AAUA,SAASy1B,GAAMz1B,GAAG;AAChB,SAAO,IAAI,KAAKA,CAAC,EAAE,MAAK;AAC1B;AAUA,SAAS01B,GAAK11B,GAAG;AACf,SAAO,IAAI,KAAKA,CAAC,EAAE,KAAI;AACzB;AAUA,SAAS21B,GAAM31B,GAAG;AAChB,SAAO,IAAI,KAAKA,CAAC,EAAE,MAAK;AAC1B;AA4BA,SAAS41B,GAAMxI,GAAGptB,GAAG;AACnB,EAAAotB,IAAI,IAAI,KAAKA,CAAC,GACdptB,IAAI,IAAI,KAAKA,CAAC;AACd,MAAIiJ,GACF2kB,IAAK,KAAK,WACVC,IAAK,KAAK,UACVyB,IAAM1B,IAAK;AAGb,SAAI,CAACR,EAAE,KAAK,CAACptB,EAAE,IACbiJ,IAAI,IAAI,KAAK,GAAG,IAGP,CAACmkB,EAAE,KAAK,CAACptB,EAAE,KACpBiJ,IAAIomB,EAAM,MAAMC,GAAK,CAAC,EAAE,MAAMtvB,EAAE,IAAI,IAAI,OAAO,IAAI,GACnDiJ,EAAE,IAAImkB,EAAE,KAGC,CAACptB,EAAE,KAAKotB,EAAE,OAAM,KACzBnkB,IAAIjJ,EAAE,IAAI,IAAIqvB,EAAM,MAAMzB,GAAIC,CAAE,IAAI,IAAI,KAAK,CAAC,GAC9C5kB,EAAE,IAAImkB,EAAE,KAGC,CAACA,EAAE,KAAKptB,EAAE,OAAM,KACzBiJ,IAAIomB,EAAM,MAAMC,GAAK,CAAC,EAAE,MAAM,GAAG,GACjCrmB,EAAE,IAAImkB,EAAE,KAGCptB,EAAE,IAAI,KACf,KAAK,YAAYsvB,GACjB,KAAK,WAAW,GAChBrmB,IAAI,KAAK,KAAKulB,EAAOpB,GAAGptB,GAAGsvB,GAAK,CAAC,CAAC,GAClCtvB,IAAIqvB,EAAM,MAAMC,GAAK,CAAC,GACtB,KAAK,YAAY1B,GACjB,KAAK,WAAWC,GAChB5kB,IAAImkB,EAAE,IAAI,IAAInkB,EAAE,MAAMjJ,CAAC,IAAIiJ,EAAE,KAAKjJ,CAAC,KAEnCiJ,IAAI,KAAK,KAAKulB,EAAOpB,GAAGptB,GAAGsvB,GAAK,CAAC,CAAC,GAG7BrmB;AACT;AAUA,SAAS4sB,GAAK71B,GAAG;AACf,SAAO,IAAI,KAAKA,CAAC,EAAE,KAAI;AACzB;AASA,SAAS81B,GAAK91B,GAAG;AACf,SAAOitB,EAASjtB,IAAI,IAAI,KAAKA,CAAC,GAAGA,EAAE,IAAI,GAAG,CAAC;AAC7C;AAWA,SAAS+1B,GAAM/1B,GAAGktB,GAAK5E,GAAK;AAC1B,SAAO,IAAI,KAAKtoB,CAAC,EAAE,MAAMktB,GAAK5E,CAAG;AACnC;AAqBA,SAASrtB,GAAO+B,GAAK;AACnB,MAAI,CAACA,KAAO,OAAOA,KAAQ;AAAU,UAAM,MAAMgvB,KAAe,iBAAiB;AACjF,MAAI9rB,GAAGwQ,GAAGpV,GACR06B,IAAch5B,EAAI,aAAa,IAC/Bi5B,IAAK;AAAA,IACH;AAAA,IAAa;AAAA,IAAGzK;AAAA,IAChB;AAAA,IAAY;AAAA,IAAG;AAAA,IACf;AAAA,IAAY,CAACD;AAAA,IAAW;AAAA,IACxB;AAAA,IAAY;AAAA,IAAGA;AAAA,IACf;AAAA,IAAQ;AAAA,IAAGA;AAAA,IACX;AAAA,IAAQ,CAACA;AAAA,IAAW;AAAA,IACpB;AAAA,IAAU;AAAA,IAAG;AAAA,EACnB;AAEE,OAAKrrB,IAAI,GAAGA,IAAI+1B,EAAG,QAAQ/1B,KAAK;AAE9B,QADIwQ,IAAIulB,EAAG/1B,CAAC,GAAG81B,MAAa,KAAKtlB,CAAC,IAAIkb,GAASlb,CAAC,KAC3CpV,IAAI0B,EAAI0T,CAAC,OAAO;AACnB,UAAI2b,EAAU/wB,CAAC,MAAMA,KAAKA,KAAK26B,EAAG/1B,IAAI,CAAC,KAAK5E,KAAK26B,EAAG/1B,IAAI,CAAC;AAAG,aAAKwQ,CAAC,IAAIpV;AAAA;AACjE,cAAM,MAAM2wB,KAAkBvb,IAAI,OAAOpV,CAAC;AAKnD,MADIoV,IAAI,UAAUslB,MAAa,KAAKtlB,CAAC,IAAIkb,GAASlb,CAAC,KAC9CpV,IAAI0B,EAAI0T,CAAC,OAAO;AACnB,QAAIpV,MAAM,MAAQA,MAAM,MAASA,MAAM,KAAKA,MAAM;AAChD,UAAIA;AACF,YAAI,OAAO,SAAU,OAAe,WACjC,OAAO,mBAAmB,OAAO;AAClC,eAAKoV,CAAC,IAAI;AAAA;AAEV,gBAAM,MAAMyb,EAAiB;AAAA;AAG/B,aAAKzb,CAAC,IAAI;AAAA;AAGZ,YAAM,MAAMub,KAAkBvb,IAAI,OAAOpV,CAAC;AAI9C,SAAO;AACT;AAUA,SAAS46B,GAAIl2B,GAAG;AACd,SAAO,IAAI,KAAKA,CAAC,EAAE,IAAG;AACxB;AAUA,SAASm2B,GAAKn2B,GAAG;AACf,SAAO,IAAI,KAAKA,CAAC,EAAE,KAAI;AACzB;AAQA,SAASzB,GAAMvB,GAAK;AAClB,MAAIkD,GAAGwQ,GAAGulB;AASV,WAASlB,EAAQz5B,GAAG;AAClB,QAAIgH,GAAGpC,GAAG0O,GACR5O,IAAI;AAGN,QAAI,EAAEA,aAAa+0B;AAAU,aAAO,IAAIA,EAAQz5B,CAAC;AAOjD,QAHA0E,EAAE,cAAc+0B,GAGZqB,GAAkB96B,CAAC,GAAG;AACxB,MAAA0E,EAAE,IAAI1E,EAAE,GAEJywB,IACE,CAACzwB,EAAE,KAAKA,EAAE,IAAIy5B,EAAQ,QAGxB/0B,EAAE,IAAI,KACNA,EAAE,IAAI,QACG1E,EAAE,IAAIy5B,EAAQ,QAGvB/0B,EAAE,IAAI,GACNA,EAAE,IAAI,CAAC,CAAC,MAERA,EAAE,IAAI1E,EAAE,GACR0E,EAAE,IAAI1E,EAAE,EAAE,MAAK,MAGjB0E,EAAE,IAAI1E,EAAE,GACR0E,EAAE,IAAI1E,EAAE,IAAIA,EAAE,EAAE,MAAK,IAAKA,EAAE;AAG9B;AAAA,IACD;AAID,QAFAsT,IAAI,OAAOtT,GAEPsT,MAAM,UAAU;AAClB,UAAItT,MAAM,GAAG;AACX,QAAA0E,EAAE,IAAI,IAAI1E,IAAI,IAAI,KAAK,GACvB0E,EAAE,IAAI,GACNA,EAAE,IAAI,CAAC,CAAC;AACR;AAAA,MACD;AAUD,UARI1E,IAAI,KACNA,IAAI,CAACA,GACL0E,EAAE,IAAI,MAENA,EAAE,IAAI,GAIJ1E,MAAM,CAAC,CAACA,KAAKA,IAAI,KAAK;AACxB,aAAKgH,IAAI,GAAGpC,IAAI5E,GAAG4E,KAAK,IAAIA,KAAK;AAAI,UAAAoC;AAErC,QAAIypB,IACEzpB,IAAIyyB,EAAQ,QACd/0B,EAAE,IAAI,KACNA,EAAE,IAAI,QACGsC,IAAIyyB,EAAQ,QACrB/0B,EAAE,IAAI,GACNA,EAAE,IAAI,CAAC,CAAC,MAERA,EAAE,IAAIsC,GACNtC,EAAE,IAAI,CAAC1E,CAAC,MAGV0E,EAAE,IAAIsC,GACNtC,EAAE,IAAI,CAAC1E,CAAC;AAGV;AAAA,MAGR,WAAiBA,IAAI,MAAM,GAAG;AACtB,QAAKA,MAAG0E,EAAE,IAAI,MACdA,EAAE,IAAI,KACNA,EAAE,IAAI;AACN;AAAA,MACD;AAED,aAAO20B,GAAa30B,GAAG1E,EAAE,SAAU,CAAA;AAAA,IAEzC,WAAesT,MAAM;AACf,YAAM,MAAMqd,KAAkB3wB,CAAC;AAIjC,YAAK4E,IAAI5E,EAAE,WAAW,CAAC,OAAO,MAC5BA,IAAIA,EAAE,MAAM,CAAC,GACb0E,EAAE,IAAI,OAGFE,MAAM,OAAI5E,IAAIA,EAAE,MAAM,CAAC,IAC3B0E,EAAE,IAAI,IAGD0sB,GAAU,KAAKpxB,CAAC,IAAIq5B,GAAa30B,GAAG1E,CAAC,IAAIs5B,GAAW50B,GAAG1E,CAAC;AAAA,EAChE;AA2DD,MAzDAy5B,EAAQ,YAAY/H,GAEpB+H,EAAQ,WAAW,GACnBA,EAAQ,aAAa,GACrBA,EAAQ,aAAa,GACrBA,EAAQ,cAAc,GACtBA,EAAQ,gBAAgB,GACxBA,EAAQ,kBAAkB,GAC1BA,EAAQ,kBAAkB,GAC1BA,EAAQ,kBAAkB,GAC1BA,EAAQ,mBAAmB,GAC3BA,EAAQ,SAAS,GAEjBA,EAAQ,SAASA,EAAQ,MAAM95B,IAC/B85B,EAAQ,QAAQx2B,IAChBw2B,EAAQ,YAAYqB,IAEpBrB,EAAQ,MAAMK,IACdL,EAAQ,OAAOM,IACfN,EAAQ,QAAQO,IAChBP,EAAQ,MAAMQ,IACdR,EAAQ,OAAOS,IACfT,EAAQ,QAAQU,IAChBV,EAAQ,OAAOW,IACfX,EAAQ,QAAQY,IAChBZ,EAAQ,QAAQa,IAChBb,EAAQ,OAAOc,IACfd,EAAQ,OAAOe,IACff,EAAQ,QAAQgB,IAChBhB,EAAQ,MAAMmB,IACdnB,EAAQ,OAAOoB,IACfpB,EAAQ,MAAMsB,IACdtB,EAAQ,MAAMuB,IACdvB,EAAQ,QAAQwB,IAChBxB,EAAQ,QAAQyB,IAChBzB,EAAQ,KAAK0B,IACb1B,EAAQ,MAAM2B,IACd3B,EAAQ,QAAQ4B,IAChB5B,EAAQ,OAAO6B,IACf7B,EAAQ,MAAMzM,IACdyM,EAAQ,MAAM7H,IACd6H,EAAQ,MAAM8B,IACd9B,EAAQ,MAAM+B,IACd/B,EAAQ,MAAMT,IACdS,EAAQ,SAASgC,IACjBhC,EAAQ,QAAQiC,IAChBjC,EAAQ,OAAOrB,IACfqB,EAAQ,MAAMkC,IACdlC,EAAQ,OAAOmC,IACfnC,EAAQ,OAAOoC,IACfpC,EAAQ,MAAMpzB,IACdozB,EAAQ,MAAMR,IACdQ,EAAQ,MAAMqC,IACdrC,EAAQ,OAAOsC,IACftC,EAAQ,QAAQuC,IAEZt6B,MAAQ,WAAQA,IAAM,CAAA,IACtBA,KACEA,EAAI,aAAa;AAEnB,SADAi5B,IAAK,CAAC,aAAa,YAAY,YAAY,YAAY,QAAQ,QAAQ,UAAU,QAAQ,GACpF/1B,IAAI,GAAGA,IAAI+1B,EAAG;AAAS,MAAKj5B,EAAI,eAAe0T,IAAIulB,EAAG/1B,GAAG,CAAC,MAAGlD,EAAI0T,CAAC,IAAI,KAAKA,CAAC;AAIrF,SAAAqkB,EAAQ,OAAO/3B,CAAG,GAEX+3B;AACT;AAWA,SAASsB,GAAIr2B,GAAGotB,GAAG;AACjB,SAAO,IAAI,KAAKptB,CAAC,EAAE,IAAIotB,CAAC;AAC1B;AAUA,SAASkJ,GAAIt2B,GAAG;AACd,SAAO,IAAI,KAAKA,CAAC,EAAE,IAAG;AACxB;AASA,SAASu2B,GAAMv2B,GAAG;AAChB,SAAOitB,EAASjtB,IAAI,IAAI,KAAKA,CAAC,GAAGA,EAAE,IAAI,GAAG,CAAC;AAC7C;AAYA,SAASw2B,KAAQ;AACf,MAAIt2B,GAAG,GACL,IAAI,IAAI,KAAK,CAAC;AAIhB,OAFA6rB,IAAW,IAEN7rB,IAAI,GAAGA,IAAI,UAAU;AAExB,QADA,IAAI,IAAI,KAAK,UAAUA,GAAG,CAAC,GACtB,EAAE;AAMA,MAAI,EAAE,MACX,IAAI,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;AAAA,SAPb;AACR,UAAI,EAAE;AACJ,eAAA6rB,IAAW,IACJ,IAAI,KAAK,IAAI,CAAC;AAEvB,UAAI;AAAA,IACV;AAKE,SAAAA,IAAW,IAEJ,EAAE;AACX;AAQA,SAASqK,GAAkBp5B,GAAK;AAC9B,SAAOA,aAAe+3B,MAAW/3B,KAAOA,EAAI,gBAAgBovB,MAAO;AACrE;AAUA,SAASqK,GAAGz2B,GAAG;AACb,SAAO,IAAI,KAAKA,CAAC,EAAE,GAAE;AACvB;AAaA,SAAS02B,GAAI12B,GAAGotB,GAAG;AACjB,SAAO,IAAI,KAAKptB,CAAC,EAAE,IAAIotB,CAAC;AAC1B;AAUA,SAASwJ,GAAK52B,GAAG;AACf,SAAO,IAAI,KAAKA,CAAC,EAAE,IAAI,CAAC;AAC1B;AAUA,SAAS22B,GAAM32B,GAAG;AAChB,SAAO,IAAI,KAAKA,CAAC,EAAE,IAAI,EAAE;AAC3B;AASA,SAASsoB,KAAM;AACb,SAAO8L,GAAS,MAAM,WAAW,IAAI;AACvC;AASA,SAASlH,KAAM;AACb,SAAOkH,GAAS,MAAM,WAAW,IAAI;AACvC;AAWA,SAASyC,GAAI72B,GAAGotB,GAAG;AACjB,SAAO,IAAI,KAAKptB,CAAC,EAAE,IAAIotB,CAAC;AAC1B;AAWA,SAAS0J,GAAI92B,GAAGotB,GAAG;AACjB,SAAO,IAAI,KAAKptB,CAAC,EAAE,IAAIotB,CAAC;AAC1B;AAWA,SAASkH,GAAIt0B,GAAGotB,GAAG;AACjB,SAAO,IAAI,KAAKptB,CAAC,EAAE,IAAIotB,CAAC;AAC1B;AAWA,SAAS2J,GAAO3I,GAAI;AAClB,MAAIM,GAAGpsB,GAAG9H,GAAGyzB,GACX/tB,IAAI,GACJ+I,IAAI,IAAI,KAAK,CAAC,GACd6oB,IAAK,CAAA;AAOP,MALI1D,MAAO,SAAQA,IAAK,KAAK,YACxB2C,EAAW3C,GAAI,GAAG5C,EAAU,GAEjChxB,IAAI,KAAK,KAAK4zB,IAAKxB,CAAQ,GAEtB,KAAK;AAIH,QAAI,OAAO;AAGhB,WAFA8B,IAAI,OAAO,gBAAgB,IAAI,YAAYl0B,CAAC,CAAC,GAEtC0F,IAAI1F;AACT,QAAAyzB,IAAIS,EAAExuB,CAAC,GAIH+tB,KAAK,QACPS,EAAExuB,CAAC,IAAI,OAAO,gBAAgB,IAAI,YAAY,CAAC,CAAC,EAAE,CAAC,IAKnD4xB,EAAG5xB,GAAG,IAAI+tB,IAAI;AAAA,aAKT,OAAO,aAAa;AAK7B,WAFAS,IAAI,OAAO,YAAYl0B,KAAK,CAAC,GAEtB0F,IAAI1F;AAGT,QAAAyzB,IAAIS,EAAExuB,CAAC,KAAKwuB,EAAExuB,IAAI,CAAC,KAAK,MAAMwuB,EAAExuB,IAAI,CAAC,KAAK,QAAQwuB,EAAExuB,IAAI,CAAC,IAAI,QAAS,KAGlE+tB,KAAK,QACP,OAAO,YAAY,CAAC,EAAE,KAAKS,GAAGxuB,CAAC,KAK/B4xB,EAAG,KAAK7D,IAAI,GAAG,GACf/tB,KAAK;AAIT,MAAAA,IAAI1F,IAAI;AAAA,IACZ;AACI,YAAM,MAAM2xB,EAAiB;AAAA;AA9C7B,WAAOjsB,IAAI1F;AAAI,MAAAs3B,EAAG5xB,GAAG,IAAI,KAAK,OAAM,IAAK,MAAM;AA2DjD,OAVA1F,IAAIs3B,EAAG,EAAE5xB,CAAC,GACVkuB,KAAMxB,GAGFpyB,KAAK4zB,MACPH,IAAI3B,EAAQ,IAAIM,IAAWwB,CAAE,GAC7B0D,EAAG5xB,CAAC,KAAK1F,IAAIyzB,IAAI,KAAKA,IAIjB6D,EAAG5xB,CAAC,MAAM,GAAGA;AAAK,IAAA4xB,EAAG;AAG5B,MAAI5xB,IAAI;AACN,IAAAoC,IAAI,GACJwvB,IAAK,CAAC,CAAC;AAAA,OACF;AAIL,SAHAxvB,IAAI,IAGGwvB,EAAG,CAAC,MAAM,GAAGxvB,KAAKsqB;AAAU,MAAAkF,EAAG;AAGtC,SAAKt3B,IAAI,GAAGyzB,IAAI6D,EAAG,CAAC,GAAG7D,KAAK,IAAIA,KAAK;AAAI,MAAAzzB;AAGzC,IAAIA,IAAIoyB,MAAUtqB,KAAKsqB,IAAWpyB;AAAA,EACnC;AAED,SAAAyO,EAAE,IAAI3G,GACN2G,EAAE,IAAI6oB,GAEC7oB;AACT;AAWA,SAAS+tB,GAAMh3B,GAAG;AAChB,SAAOitB,EAASjtB,IAAI,IAAI,KAAKA,CAAC,GAAGA,EAAE,IAAI,GAAG,KAAK,QAAQ;AACzD;AAcA,SAAS0zB,GAAK1zB,GAAG;AACf,SAAAA,IAAI,IAAI,KAAKA,CAAC,GACPA,EAAE,IAAKA,EAAE,EAAE,CAAC,IAAIA,EAAE,IAAI,IAAIA,EAAE,IAAKA,EAAE,KAAK;AACjD;AAUA,SAASi3B,GAAIj3B,GAAG;AACd,SAAO,IAAI,KAAKA,CAAC,EAAE,IAAG;AACxB;AAUA,SAASk3B,GAAKl3B,GAAG;AACf,SAAO,IAAI,KAAKA,CAAC,EAAE,KAAI;AACzB;AAUA,SAASm3B,GAAKn3B,GAAG;AACf,SAAO,IAAI,KAAKA,CAAC,EAAE,KAAI;AACzB;AAWA,SAAS2B,GAAI3B,GAAGotB,GAAG;AACjB,SAAO,IAAI,KAAKptB,CAAC,EAAE,IAAIotB,CAAC;AAC1B;AAYA,SAASmH,KAAM;AACb,MAAIr0B,IAAI,GACNgB,IAAO,WACPlB,IAAI,IAAI,KAAKkB,EAAKhB,CAAC,CAAC;AAGtB,OADA6rB,IAAW,IACJ/rB,EAAE,KAAK,EAAEE,IAAIgB,EAAK;AAAS,IAAAlB,IAAIA,EAAE,KAAKkB,EAAKhB,CAAC,CAAC;AACpD,SAAA6rB,IAAW,IAEJkB,EAASjtB,GAAG,KAAK,WAAW,KAAK,QAAQ;AAClD;AAUA,SAASo3B,GAAIp3B,GAAG;AACd,SAAO,IAAI,KAAKA,CAAC,EAAE,IAAG;AACxB;AAUA,SAASq3B,GAAKr3B,GAAG;AACf,SAAO,IAAI,KAAKA,CAAC,EAAE,KAAI;AACzB;AASA,SAASs3B,GAAMt3B,GAAG;AAChB,SAAOitB,EAASjtB,IAAI,IAAI,KAAKA,CAAC,GAAGA,EAAE,IAAI,GAAG,CAAC;AAC7C;AAGAgtB,EAAE,OAAO,IAAI,4BAA4B,CAAC,IAAIA,EAAE;AAChDA,EAAE,OAAO,WAAW,IAAI;AAGjB,IAAI+H,KAAU/H,EAAE,cAAczuB,GAAMqtB,EAAQ;AAGnDF,KAAO,IAAIqJ,GAAQrJ,EAAI;AACvBC,KAAK,IAAIoJ,GAAQpJ,EAAE;ACpxJN,MAAA4L,KAAa,CAACC,MAChB,IAAIzC,GAAQyC,CAAM,EAAE,gBAAgB,CAAC,EAAE;ACA3C,SAASC,GAAmBC,GAAWv9B,IAA+B,IAAY;AACrF,QAAM,EAAE,YAAAw9B,IAAa,GAAG,gBAAAC,IAAiB,GAAG,yBAAAC,IAA0B,IAAO,oBAAAC,IAAqB,IAAO,oBAAAC,IAAqB,CAAC,EAAA,IAAM59B,GAE/H69B,IAAoBT,GAAWI,CAAU;AAE/C,UAAQD,EAAI,SAAS;AAAA,IACjB,KAAK3+B,EAAS;AACV,UAAI8+B;AAEA,eAAON,GAAYS,IAAoBN,EAAI,UAAW,MAAMA,EAAI,OAAO;UAChEI,GAAoB;AAGrB,cAAAG,IAAkBF,EAAmB,OAAO,CAACxD,GAAKtrB,MAAMsrB,IAAMtrB,KAAK,MAAMA,IAAI,CAAC,GAC9EivB,IAAgBF,KAAqB,IAAIC;AAC/C,eAAOV,GAAYW,IAAgBR,EAAI,UAAW,MAAMA,EAAI,OAAO;AAAA,MAAA;AAEnE,eAAOH,GAAWS,KAAqBN,EAAI,SAAS,IAAI;AAAA,IAGhE,KAAK3+B,EAAS;AAAA,IACd,KAAKA,EAAS;AACV,aAAO2+B,EAAI;AAAA,IAEf,KAAK3+B,EAAS;AACH,aAAAw+B,GAAWG,EAAI,SAASE,CAAc;AAAA,IAEjD;AACW,aAAA;AAAA,EACf;AACJ;ACxCA,MAAMO,KAAoB,CAACp/B,EAAS,qBAAqB,GAEnDq/B,KAAyB,CAACr/B,EAAS,qBAAqBA,EAAS,oBAAoBA,EAAS,oBAAoB,GAElHs/B,KAA0B,CAACt/B,EAAS,mBAAmB;AAE7D,SAASu/B,GAAiCC,GAAWC,GAA2B;AACrE,SAAAD,EAAK,OAAO,CAACb,MAAQc,EAAS,SAASd,EAAI,OAAO,CAAC;AAC9D;AAEO,SAASe,GAAuCF,GAAgB;AAC5D,SAAAD,GAAiBC,GAAMJ,EAAiB;AACnD;AAEO,SAASO,GAA2CH,GAAgB;AAChE,SAAAD,GAAiBC,GAAMH,EAAsB;AACxD;AAEO,SAASO,GAA4CJ,GAAgB;AACjE,SAAAD,GAAiBC,GAAMF,EAAuB;AACzD;AAEO,SAASO,GAAqBC,GAAoE;AAC9F,SAAA;AAAA,IACH,gBAAgB,CAAC9/B,EAAS,qBAAqBA,EAAS,oBAAoB,EAAE,SAAS8/B,CAAO;AAAA,IAC9F,qBAAqBA,MAAY9/B,EAAS;AAAA,IAC1C,iBAAiB8/B,MAAY9/B,EAAS;AAAA,IACtC,kCAAkC8/B,MAAY9/B,EAAS;AAAA,EAAA;AAE/D;AC3Ba,MAAA+/B,KAAS,CAAI7+B,MAA2CA,GAKxD8+B,KAAS,CAAsCj9B,GAAWuS,MAA0B;AAC7F,QAAMjM,IAAS,CAAA;AAEf,SAAAiM,EAAK,QAAQ,CAAOvR,MAAA;AAChB,IAAIA,KAAOhB,MACAsG,EAAAtF,CAAG,IAAIhB,EAAOgB,CAAG;AAAA,EAC5B,CACH,GAEMsF;AACX,GCLa42B,KAAyB,CAAClvB,GAAamvB,MAE5CnvB,EAAI,SAAS,qBAAqB,IAC3BA,IAAM,QAAQmvB,IAGlBnvB,GCZEovB,KAAN,MAAsB;AAmQ7B;AAnQaA,GAYJ,0BAA0B,CAC/BC,GACAC,MAMG;AACH,MAAIC,IAAW,GACXC,IAAgB,GAChBC,IAAgB;AAEhB,EAAAJ,EAAM,SAASA,EAAM,aACvBE,IAAWF,EAAM,WAAW,OAAOA,EAAM,KAAK,IAG5CA,EAAM,gBAAgBr/B,EAAkB,iCAAiCq/B,EAAM,gBACjFE,KAAYF,EAAM,gBACTA,EAAM,gBAAgBr/B,EAAkB,iCAAiCq/B,EAAM,kBACxFE,KAAYF,EAAM,gBAGhBA,EAAM,cAAcA,EAAM,kBAC5BG,IAAgBH,EAAM,gBAAgB,OAAOA,EAAM,UAAU,IAG3DA,EAAM,cAAcA,EAAM,kBAC5BI,IAAgBJ,EAAM,gBAAgB,OAAOA,EAAM,UAAU;AAG3D,MAAAK,IAAaH,IAAWC,IAAgBC;AAE1C,SAAAx/B,GAAsB,SAASo/B,EAAM,WAAgC,KACrEA,EAAM,UACN,CAACC,MAEDI,KAAcL,EAAM,SAGf;AAAA,IACL,UAAAE;AAAA,IACA,eAAAC;AAAA,IACA,eAAAC;AAAA,IACA,YAAAC;AAAA,EAAA;AAEJ;AA1DWN,GAwEJ,4BAA4B,CACjCO,GACAL,IAAyB,QAQpB,MAAM,QAAQK,CAAM,MACvBA,IAAS,CAACA,CAAM,IAKHA,EAAO;AAAA,EACpB,CAACC,GAAKP,MAAU;AxDjGV,QAAA5+B,GAAAM,GAAA8F,GAAAC,GAAAC,GAAAC;AwDkGJ,UAAM4uB,IAAOwJ,GAAgB,wBAAwBC,GAAOC,CAAsB;AAClF,QAAIO,IAAY;AAGhB,YAAKR,EAAM,QAAO5+B,IAAA4+B,EAAM,SAAN,QAAA5+B,EAAY,WAAW4+B,EAAM,YAEzCt+B,IAAAs+B,EAAM,SAAN,QAAAt+B,EAAY,SAERs+B,EAAA,KAAK,QAAQ,CAACzB,MAAQ;AACb,MAAAiC,KAAAR,EAAM,WAAWzB,EAAI;AAAA,IAAA,CACnC,IAGDiC,IAAYR,EAAM,WAAW,OAAOA,EAAM,GAAG,MAI1CA,EAAM,aAAYx4B,IAAAw4B,EAAM,cAAN,QAAAx4B,EAAiB,WAAWw4B,EAAM,mBACnDv4B,IAAAu4B,EAAM,cAAN,QAAAv4B,EAAiB,SACbu4B,EAAA,UAAU,QAAQ,CAACzB,MAAQ;AAClB,MAAAiC,KAAAR,EAAM,gBAAgBzB,EAAI;AAAA,IAAA,CACxC,IAEDiC,KAAaR,EAAM,iBAAiB,IAAI,OAAOA,EAAM,QAAQ,KAI5DA,EAAM,aAAYt4B,IAAAs4B,EAAM,cAAN,QAAAt4B,EAAiB,WAAWs4B,EAAM,mBACnDr4B,IAAAq4B,EAAM,cAAN,QAAAr4B,EAAiB,SACbq4B,EAAA,UAAU,QAAQ,CAACzB,MAAQ;AAClB,MAAAiC,KAAAR,EAAM,iBAAiB,IAAIzB,EAAI;AAAA,IAAA,CAC7C,IAEDiC,KAAaR,EAAM,gBAAgB,OAAOA,EAAM,QAAQ,KAO5Dp/B,GAAsB,SAASo/B,EAAM,WAAgC,KACrEA,EAAM,UACN,CAACC,MAEDO,KAAaR,EAAM,SAGd;AAAA,MACL,OAAOO,EAAI,QAAQhK,EAAK;AAAA,MACxB,YAAYgK,EAAI,aAAahK,EAAK;AAAA,MAClC,YAAYgK,EAAI,aAAahK,EAAK;AAAA,MAClC,WAAWgK,EAAI,YAAYC;AAAA,MAC3B,OAAOD,EAAI,QAAQhK,EAAK,aAAaiK;AAAA,IAAA;AAAA,EAEzC;AAAA,EACA,EAAE,OAAO,GAAG,YAAY,GAAG,YAAY,GAAG,WAAW,GAAG,OAAO,EAAE;AAAA;AAjJ1DT,GAoKJ,iCAAiC,CACtCO,GACAL,IAAyB,QASpB,MAAM,QAAQK,CAAM,MACvBA,IAAS,CAACA,CAAM,IAGHA,EAAO;AAAA,EACpB,CAACC,GAAKP,MAAU;AxD5LV,QAAA5+B,GAAAM;AwD6LJ,UAAM60B,IAAOwJ,GAAgB,wBAAwBC,GAAOC,CAAsB;AAI9E,QAAAI,GACAI,IAAgBT,EAAM,YAAY;AAEtC,IAAIA,EAAM,UAAU,UAAaA,EAAM,UAAU,OAE/CK,IAAaL,EAAM,QAGnBK,IAAa9J,EAAK,aAAakK;AAI7B,QAAAD,IAAYR,EAAM,QAAQ;AAG1B,KAAA5+B,IAAA4+B,EAAM,iBAAN,QAAA5+B,EAAoB,WACVo/B,IAAAR,EAAM,aAAa,OAAO,CAACO,GAAKhC,MAAQgC,IAAMhC,EAAI,QAAQ,CAAC;AAIzE,UAAMmC,KAAeh/B,IAAAs+B,EAAM,iBAAN,QAAAt+B,EAAoB,SAAS2+B,IAAaA,IAAaG;AAErE,WAAA;AAAA,MACL,OAAOD,EAAI,QAAQhK,EAAK;AAAA,MACxB,YAAYgK,EAAI,aAAahK,EAAK;AAAA,MAClC,YAAYgK,EAAI,aAAahK,EAAK;AAAA,MAClC,WAAWgK,EAAI,YAAYC;AAAA,MAC3B,OAAOD,EAAI,QAAQF,IAAaG;AAAA,MAChC,cAAcD,EAAI,eAAeG;AAAA,IAAA;AAAA,EAErC;AAAA,EACA;AAAA,IACE,OAAO;AAAA,IACP,YAAY;AAAA,IACZ,YAAY;AAAA,IACZ,WAAW;AAAA,IACX,OAAO;AAAA,IACP,cAAc;AAAA,EAChB;AAAA;AA/NOX,GA4OJ,+BAA+B,CAAChO,GAA8BkO,IAAyB,OAAkB;AxDpPtG,MAAA7+B;AwDqPR,MAAI4wB,IAAQ;AAEA,UAAA5wB,IAAA2wB,EAAA,iBAAA,QAAA3wB,EAAc,QAAQ,CAACm9B,MAAQ;AACzC,IAAAvM,KAASuM,EAAI;AAAA,EAAA,IAGHxM,EAAA,aAAa,QAAQ,CAAC4O,MAAkB;AxD3P5C,QAAAv/B,GAAAM,GAAA8F;AwD4PN,IAAAwqB,KAAS2O,EAAc,MAAM;AAC7B,UAAMC,MAAYx/B,IAAA,OAAO,KAAKu/B,EAAc,MAAM,MAAhC,gBAAAv/B,EAAmC,WAAU;AAG3D,QAFJ4wB,KAAS2O,EAAc,QAAQ,IAE3Bj/B,IAAAi/B,EAAc,WAAd,QAAAj/B,EAAsB,QAAQ;AAChC,YAAM4+B,KAAUK,EAAc,UAAU,CAAA,GAAI,IAAI,CAACX,OACxC,EAAE,GAAGA,GAAO,QAAQY,EAAU,EACtC;AAED,MAAA5O,MAASxqB,IAAAu4B,GAAgB,+BAA+BO,GAAQL,CAAsB,MAA7E,gBAAAz4B,EAAgF;AAAA,IAC3F;AAAA,EAAA,CACD,GAEM42B,GAAWpM,CAAK;AACzB;AAlQK,IAAM6O,KAANd;ACRA,SAASe,GAAgBC,GAAqB;AACjD,SAAOA,EAAY;AACvB;","x_google_ignoreList":[29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,50]}