@hero-design/rn 8.90.1 → 8.91.0-alpha.0

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 (448) hide show
  1. package/CHANGELOG.md +14 -0
  2. package/coverage/clover.xml +4025 -0
  3. package/coverage/coverage-final.json +306 -0
  4. package/coverage/lcov-report/base.css +224 -0
  5. package/coverage/lcov-report/block-navigation.js +87 -0
  6. package/coverage/lcov-report/favicon.png +0 -0
  7. package/coverage/lcov-report/index.html +1301 -0
  8. package/coverage/lcov-report/prettify.css +1 -0
  9. package/coverage/lcov-report/prettify.js +2 -0
  10. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  11. package/coverage/lcov-report/sorter.js +196 -0
  12. package/coverage/lcov-report/src/components/Accordion/AccordionItem.tsx.html +232 -0
  13. package/coverage/lcov-report/src/components/Accordion/StyledAccordion.tsx.html +172 -0
  14. package/coverage/lcov-report/src/components/Accordion/index.html +146 -0
  15. package/coverage/lcov-report/src/components/Accordion/index.tsx.html +334 -0
  16. package/coverage/lcov-report/src/components/Alert/StyledAlert.tsx.html +301 -0
  17. package/coverage/lcov-report/src/components/Alert/index.html +131 -0
  18. package/coverage/lcov-report/src/components/Alert/index.tsx.html +556 -0
  19. package/coverage/lcov-report/src/components/AnimatedScroller/AnimatedFAB.tsx.html +550 -0
  20. package/coverage/lcov-report/src/components/AnimatedScroller/AnimatedScrollable.tsx.html +295 -0
  21. package/coverage/lcov-report/src/components/AnimatedScroller/FlatListWithFAB.tsx.html +154 -0
  22. package/coverage/lcov-report/src/components/AnimatedScroller/ScrollViewWithFAB.tsx.html +148 -0
  23. package/coverage/lcov-report/src/components/AnimatedScroller/SectionListWithFAB.tsx.html +163 -0
  24. package/coverage/lcov-report/src/components/AnimatedScroller/index.html +191 -0
  25. package/coverage/lcov-report/src/components/AnimatedScroller/index.tsx.html +100 -0
  26. package/coverage/lcov-report/src/components/Attachment/StyledAttachment.tsx.html +217 -0
  27. package/coverage/lcov-report/src/components/Attachment/index.html +131 -0
  28. package/coverage/lcov-report/src/components/Attachment/index.tsx.html +322 -0
  29. package/coverage/lcov-report/src/components/Avatar/Avatar.tsx.html +367 -0
  30. package/coverage/lcov-report/src/components/Avatar/AvatarStack/StyledAvatarStack.tsx.html +334 -0
  31. package/coverage/lcov-report/src/components/Avatar/AvatarStack/index.html +146 -0
  32. package/coverage/lcov-report/src/components/Avatar/AvatarStack/index.tsx.html +523 -0
  33. package/coverage/lcov-report/src/components/Avatar/AvatarStack/utils.ts.html +142 -0
  34. package/coverage/lcov-report/src/components/Avatar/StyledAvatar.tsx.html +286 -0
  35. package/coverage/lcov-report/src/components/Avatar/index.html +146 -0
  36. package/coverage/lcov-report/src/components/Avatar/index.ts.html +103 -0
  37. package/coverage/lcov-report/src/components/Badge/Status.tsx.html +322 -0
  38. package/coverage/lcov-report/src/components/Badge/StyledBadge.tsx.html +304 -0
  39. package/coverage/lcov-report/src/components/Badge/index.html +146 -0
  40. package/coverage/lcov-report/src/components/Badge/index.tsx.html +355 -0
  41. package/coverage/lcov-report/src/components/BottomNavigation/StyledBottomNavigation.tsx.html +265 -0
  42. package/coverage/lcov-report/src/components/BottomNavigation/index.html +131 -0
  43. package/coverage/lcov-report/src/components/BottomNavigation/index.tsx.html +571 -0
  44. package/coverage/lcov-report/src/components/BottomSheet/BottomSheetContext.ts.html +118 -0
  45. package/coverage/lcov-report/src/components/BottomSheet/Footer.tsx.html +145 -0
  46. package/coverage/lcov-report/src/components/BottomSheet/Header.tsx.html +304 -0
  47. package/coverage/lcov-report/src/components/BottomSheet/ScrollView.tsx.html +256 -0
  48. package/coverage/lcov-report/src/components/BottomSheet/StyledBottomSheet.tsx.html +433 -0
  49. package/coverage/lcov-report/src/components/BottomSheet/index.html +191 -0
  50. package/coverage/lcov-report/src/components/BottomSheet/index.tsx.html +787 -0
  51. package/coverage/lcov-report/src/components/Box/StyledBox.tsx.html +250 -0
  52. package/coverage/lcov-report/src/components/Box/config.ts.html +688 -0
  53. package/coverage/lcov-report/src/components/Box/index.html +146 -0
  54. package/coverage/lcov-report/src/components/Box/index.tsx.html +124 -0
  55. package/coverage/lcov-report/src/components/Button/Button.tsx.html +826 -0
  56. package/coverage/lcov-report/src/components/Button/IconButton.tsx.html +292 -0
  57. package/coverage/lcov-report/src/components/Button/LoadingIndicator/StyledLoadingIndicator.tsx.html +289 -0
  58. package/coverage/lcov-report/src/components/Button/LoadingIndicator/index.html +131 -0
  59. package/coverage/lcov-report/src/components/Button/LoadingIndicator/index.tsx.html +502 -0
  60. package/coverage/lcov-report/src/components/Button/StyledButton.tsx.html +856 -0
  61. package/coverage/lcov-report/src/components/Button/UtilityButton/StyledUtilityButton.tsx.html +154 -0
  62. package/coverage/lcov-report/src/components/Button/UtilityButton/index.html +131 -0
  63. package/coverage/lcov-report/src/components/Button/UtilityButton/index.tsx.html +259 -0
  64. package/coverage/lcov-report/src/components/Button/index.html +161 -0
  65. package/coverage/lcov-report/src/components/Button/index.tsx.html +136 -0
  66. package/coverage/lcov-report/src/components/Calendar/CalendarRowItem.tsx.html +253 -0
  67. package/coverage/lcov-report/src/components/Calendar/StyledCalendar.tsx.html +355 -0
  68. package/coverage/lcov-report/src/components/Calendar/helpers.ts.html +172 -0
  69. package/coverage/lcov-report/src/components/Calendar/index.html +161 -0
  70. package/coverage/lcov-report/src/components/Calendar/index.tsx.html +1153 -0
  71. package/coverage/lcov-report/src/components/Card/DataCard/StyledDataCard.tsx.html +157 -0
  72. package/coverage/lcov-report/src/components/Card/DataCard/index.html +131 -0
  73. package/coverage/lcov-report/src/components/Card/DataCard/index.tsx.html +193 -0
  74. package/coverage/lcov-report/src/components/Card/StyledCard.tsx.html +157 -0
  75. package/coverage/lcov-report/src/components/Card/index.html +131 -0
  76. package/coverage/lcov-report/src/components/Card/index.tsx.html +229 -0
  77. package/coverage/lcov-report/src/components/Carousel/CardCarousel.tsx.html +829 -0
  78. package/coverage/lcov-report/src/components/Carousel/CarouselItem.tsx.html +313 -0
  79. package/coverage/lcov-report/src/components/Carousel/StyledCardCarousel.tsx.html +160 -0
  80. package/coverage/lcov-report/src/components/Carousel/StyledCarousel.tsx.html +325 -0
  81. package/coverage/lcov-report/src/components/Carousel/contants.ts.html +115 -0
  82. package/coverage/lcov-report/src/components/Carousel/index.html +191 -0
  83. package/coverage/lcov-report/src/components/Carousel/index.tsx.html +775 -0
  84. package/coverage/lcov-report/src/components/Checkbox/StyledCheckbox.tsx.html +217 -0
  85. package/coverage/lcov-report/src/components/Checkbox/index.html +131 -0
  86. package/coverage/lcov-report/src/components/Checkbox/index.tsx.html +421 -0
  87. package/coverage/lcov-report/src/components/Chip/StyledChip.tsx.html +430 -0
  88. package/coverage/lcov-report/src/components/Chip/index.html +131 -0
  89. package/coverage/lcov-report/src/components/Chip/index.tsx.html +310 -0
  90. package/coverage/lcov-report/src/components/Collapse/StyledCollapse.tsx.html +157 -0
  91. package/coverage/lcov-report/src/components/Collapse/index.html +131 -0
  92. package/coverage/lcov-report/src/components/Collapse/index.tsx.html +370 -0
  93. package/coverage/lcov-report/src/components/ContentNavigator/StyledContentNavigator.tsx.html +115 -0
  94. package/coverage/lcov-report/src/components/ContentNavigator/index.html +131 -0
  95. package/coverage/lcov-report/src/components/ContentNavigator/index.tsx.html +397 -0
  96. package/coverage/lcov-report/src/components/DatePicker/DatePickerAndroid.tsx.html +295 -0
  97. package/coverage/lcov-report/src/components/DatePicker/DatePickerCalendar.tsx.html +514 -0
  98. package/coverage/lcov-report/src/components/DatePicker/DatePickerIOS.tsx.html +382 -0
  99. package/coverage/lcov-report/src/components/DatePicker/StyledDatePicker.tsx.html +112 -0
  100. package/coverage/lcov-report/src/components/DatePicker/index.html +191 -0
  101. package/coverage/lcov-report/src/components/DatePicker/index.tsx.html +142 -0
  102. package/coverage/lcov-report/src/components/DatePicker/useCalculateDate.tsx.html +187 -0
  103. package/coverage/lcov-report/src/components/Divider/StyledDivider.tsx.html +169 -0
  104. package/coverage/lcov-report/src/components/Divider/index.html +131 -0
  105. package/coverage/lcov-report/src/components/Divider/index.tsx.html +205 -0
  106. package/coverage/lcov-report/src/components/Drawer/DragableDrawer/helpers.ts.html +223 -0
  107. package/coverage/lcov-report/src/components/Drawer/DragableDrawer/index.html +131 -0
  108. package/coverage/lcov-report/src/components/Drawer/DragableDrawer/index.tsx.html +697 -0
  109. package/coverage/lcov-report/src/components/Drawer/StyledDrawer.tsx.html +337 -0
  110. package/coverage/lcov-report/src/components/Drawer/index.html +131 -0
  111. package/coverage/lcov-report/src/components/Drawer/index.tsx.html +376 -0
  112. package/coverage/lcov-report/src/components/Empty/StyledEmpty.tsx.html +196 -0
  113. package/coverage/lcov-report/src/components/Empty/index.html +131 -0
  114. package/coverage/lcov-report/src/components/Empty/index.tsx.html +304 -0
  115. package/coverage/lcov-report/src/components/Error/StyledError.tsx.html +352 -0
  116. package/coverage/lcov-report/src/components/Error/index.html +131 -0
  117. package/coverage/lcov-report/src/components/Error/index.tsx.html +865 -0
  118. package/coverage/lcov-report/src/components/FAB/ActionGroup/ActionItem.tsx.html +313 -0
  119. package/coverage/lcov-report/src/components/FAB/ActionGroup/StyledActionGroup.tsx.html +259 -0
  120. package/coverage/lcov-report/src/components/FAB/ActionGroup/StyledActionItem.tsx.html +175 -0
  121. package/coverage/lcov-report/src/components/FAB/ActionGroup/index.html +161 -0
  122. package/coverage/lcov-report/src/components/FAB/ActionGroup/index.tsx.html +682 -0
  123. package/coverage/lcov-report/src/components/FAB/AnimatedFABIcon.tsx.html +226 -0
  124. package/coverage/lcov-report/src/components/FAB/FAB.tsx.html +871 -0
  125. package/coverage/lcov-report/src/components/FAB/Pair/StyledFAB.tsx.html +142 -0
  126. package/coverage/lcov-report/src/components/FAB/Pair/index.html +131 -0
  127. package/coverage/lcov-report/src/components/FAB/Pair/index.tsx.html +223 -0
  128. package/coverage/lcov-report/src/components/FAB/StyledFAB.tsx.html +241 -0
  129. package/coverage/lcov-report/src/components/FAB/index.html +161 -0
  130. package/coverage/lcov-report/src/components/FAB/index.tsx.html +109 -0
  131. package/coverage/lcov-report/src/components/FloatingIsland/StyledFloatingIsland.tsx.html +181 -0
  132. package/coverage/lcov-report/src/components/FloatingIsland/index.html +131 -0
  133. package/coverage/lcov-report/src/components/FloatingIsland/index.tsx.html +367 -0
  134. package/coverage/lcov-report/src/components/HeroDesignProvider/index.html +116 -0
  135. package/coverage/lcov-report/src/components/HeroDesignProvider/index.tsx.html +127 -0
  136. package/coverage/lcov-report/src/components/Icon/AnimatedIcon.tsx.html +226 -0
  137. package/coverage/lcov-report/src/components/Icon/HeroIcon/index.html +116 -0
  138. package/coverage/lcov-report/src/components/Icon/HeroIcon/index.tsx.html +220 -0
  139. package/coverage/lcov-report/src/components/Icon/IconList.ts.html +1426 -0
  140. package/coverage/lcov-report/src/components/Icon/index.html +161 -0
  141. package/coverage/lcov-report/src/components/Icon/index.tsx.html +412 -0
  142. package/coverage/lcov-report/src/components/Icon/utils.ts.html +103 -0
  143. package/coverage/lcov-report/src/components/Image/index.html +116 -0
  144. package/coverage/lcov-report/src/components/Image/index.tsx.html +223 -0
  145. package/coverage/lcov-report/src/components/List/BasicListItem.tsx.html +442 -0
  146. package/coverage/lcov-report/src/components/List/ListItem.tsx.html +565 -0
  147. package/coverage/lcov-report/src/components/List/StyledBasicListItem.tsx.html +187 -0
  148. package/coverage/lcov-report/src/components/List/StyledListItem.tsx.html +337 -0
  149. package/coverage/lcov-report/src/components/List/index.html +176 -0
  150. package/coverage/lcov-report/src/components/List/index.tsx.html +127 -0
  151. package/coverage/lcov-report/src/components/MapPin/Focussed.tsx.html +169 -0
  152. package/coverage/lcov-report/src/components/MapPin/StyledMapPin.tsx.html +292 -0
  153. package/coverage/lcov-report/src/components/MapPin/index.html +146 -0
  154. package/coverage/lcov-report/src/components/MapPin/index.tsx.html +277 -0
  155. package/coverage/lcov-report/src/components/Modal/index.html +116 -0
  156. package/coverage/lcov-report/src/components/Modal/index.tsx.html +736 -0
  157. package/coverage/lcov-report/src/components/PageControl/StyledPageControl.tsx.html +136 -0
  158. package/coverage/lcov-report/src/components/PageControl/index.html +131 -0
  159. package/coverage/lcov-report/src/components/PageControl/index.tsx.html +319 -0
  160. package/coverage/lcov-report/src/components/PinInput/PinCell.tsx.html +193 -0
  161. package/coverage/lcov-report/src/components/PinInput/StyledPinInput.tsx.html +358 -0
  162. package/coverage/lcov-report/src/components/PinInput/index.html +146 -0
  163. package/coverage/lcov-report/src/components/PinInput/index.tsx.html +817 -0
  164. package/coverage/lcov-report/src/components/Portal/PortalHost.tsx.html +166 -0
  165. package/coverage/lcov-report/src/components/Portal/PortalProvider.tsx.html +190 -0
  166. package/coverage/lcov-report/src/components/Portal/constants.ts.html +115 -0
  167. package/coverage/lcov-report/src/components/Portal/contexts.ts.html +127 -0
  168. package/coverage/lcov-report/src/components/Portal/index.html +221 -0
  169. package/coverage/lcov-report/src/components/Portal/index.tsx.html +283 -0
  170. package/coverage/lcov-report/src/components/Portal/reducer.ts.html +403 -0
  171. package/coverage/lcov-report/src/components/Portal/usePortal.ts.html +235 -0
  172. package/coverage/lcov-report/src/components/Portal/usePortalState.ts.html +118 -0
  173. package/coverage/lcov-report/src/components/Progress/ProgressBar.tsx.html +358 -0
  174. package/coverage/lcov-report/src/components/Progress/ProgressCircle.tsx.html +628 -0
  175. package/coverage/lcov-report/src/components/Progress/ProgressStep.tsx.html +352 -0
  176. package/coverage/lcov-report/src/components/Progress/StyledProgressBar.tsx.html +172 -0
  177. package/coverage/lcov-report/src/components/Progress/StyledProgressCircle.tsx.html +331 -0
  178. package/coverage/lcov-report/src/components/Progress/StyledStep.tsx.html +235 -0
  179. package/coverage/lcov-report/src/components/Progress/constants.ts.html +133 -0
  180. package/coverage/lcov-report/src/components/Progress/index.html +221 -0
  181. package/coverage/lcov-report/src/components/Progress/index.tsx.html +118 -0
  182. package/coverage/lcov-report/src/components/Radio/Radio.tsx.html +313 -0
  183. package/coverage/lcov-report/src/components/Radio/RadioGroup.tsx.html +340 -0
  184. package/coverage/lcov-report/src/components/Radio/StyledRadio.tsx.html +211 -0
  185. package/coverage/lcov-report/src/components/Radio/index.html +161 -0
  186. package/coverage/lcov-report/src/components/Radio/index.tsx.html +100 -0
  187. package/coverage/lcov-report/src/components/Rate/StyledRate.tsx.html +133 -0
  188. package/coverage/lcov-report/src/components/Rate/index.html +131 -0
  189. package/coverage/lcov-report/src/components/Rate/index.tsx.html +355 -0
  190. package/coverage/lcov-report/src/components/RefreshControl/index.html +116 -0
  191. package/coverage/lcov-report/src/components/RefreshControl/index.tsx.html +160 -0
  192. package/coverage/lcov-report/src/components/RichTextEditor/EditorEvent.ts.html +106 -0
  193. package/coverage/lcov-report/src/components/RichTextEditor/EditorToolbar.tsx.html +736 -0
  194. package/coverage/lcov-report/src/components/RichTextEditor/MentionList.tsx.html +382 -0
  195. package/coverage/lcov-report/src/components/RichTextEditor/RichTextEditor.tsx.html +1402 -0
  196. package/coverage/lcov-report/src/components/RichTextEditor/StyledRichTextEditor.ts.html +139 -0
  197. package/coverage/lcov-report/src/components/RichTextEditor/StyledToolbar.ts.html +181 -0
  198. package/coverage/lcov-report/src/components/RichTextEditor/constants.ts.html +112 -0
  199. package/coverage/lcov-report/src/components/RichTextEditor/heroEditorApp.ts.html +94 -0
  200. package/coverage/lcov-report/src/components/RichTextEditor/index.html +236 -0
  201. package/coverage/lcov-report/src/components/RichTextEditor/index.tsx.html +118 -0
  202. package/coverage/lcov-report/src/components/RichTextEditor/utils/events.ts.html +178 -0
  203. package/coverage/lcov-report/src/components/RichTextEditor/utils/index.html +131 -0
  204. package/coverage/lcov-report/src/components/RichTextEditor/utils/rnWebView.ts.html +142 -0
  205. package/coverage/lcov-report/src/components/Search/SearchOneLine.tsx.html +781 -0
  206. package/coverage/lcov-report/src/components/Search/SearchSuffixIcon.tsx.html +229 -0
  207. package/coverage/lcov-report/src/components/Search/SearchTwoLine.tsx.html +295 -0
  208. package/coverage/lcov-report/src/components/Search/StyledSearch.tsx.html +364 -0
  209. package/coverage/lcov-report/src/components/Search/index.html +191 -0
  210. package/coverage/lcov-report/src/components/Search/index.tsx.html +136 -0
  211. package/coverage/lcov-report/src/components/Search/utils.tsx.html +178 -0
  212. package/coverage/lcov-report/src/components/SectionHeading/StyledHeading.tsx.html +190 -0
  213. package/coverage/lcov-report/src/components/SectionHeading/index.html +131 -0
  214. package/coverage/lcov-report/src/components/SectionHeading/index.tsx.html +445 -0
  215. package/coverage/lcov-report/src/components/Select/BaseOptionList.tsx.html +310 -0
  216. package/coverage/lcov-report/src/components/Select/Footer.tsx.html +109 -0
  217. package/coverage/lcov-report/src/components/Select/MultiSelect/Option.tsx.html +229 -0
  218. package/coverage/lcov-report/src/components/Select/MultiSelect/OptionList.tsx.html +295 -0
  219. package/coverage/lcov-report/src/components/Select/MultiSelect/index.html +146 -0
  220. package/coverage/lcov-report/src/components/Select/MultiSelect/index.tsx.html +694 -0
  221. package/coverage/lcov-report/src/components/Select/SingleSelect/Option.tsx.html +178 -0
  222. package/coverage/lcov-report/src/components/Select/SingleSelect/OptionList.tsx.html +322 -0
  223. package/coverage/lcov-report/src/components/Select/SingleSelect/StyledSingleSelect.tsx.html +103 -0
  224. package/coverage/lcov-report/src/components/Select/SingleSelect/index.html +161 -0
  225. package/coverage/lcov-report/src/components/Select/SingleSelect/index.tsx.html +577 -0
  226. package/coverage/lcov-report/src/components/Select/StyledSelect.tsx.html +151 -0
  227. package/coverage/lcov-report/src/components/Select/helpers.tsx.html +388 -0
  228. package/coverage/lcov-report/src/components/Select/index.html +176 -0
  229. package/coverage/lcov-report/src/components/Select/index.tsx.html +115 -0
  230. package/coverage/lcov-report/src/components/Skeleton/StyledSkeleton.tsx.html +160 -0
  231. package/coverage/lcov-report/src/components/Skeleton/index.html +131 -0
  232. package/coverage/lcov-report/src/components/Skeleton/index.tsx.html +475 -0
  233. package/coverage/lcov-report/src/components/Slider/index.html +116 -0
  234. package/coverage/lcov-report/src/components/Slider/index.tsx.html +352 -0
  235. package/coverage/lcov-report/src/components/Spinner/AnimatedSpinner.tsx.html +295 -0
  236. package/coverage/lcov-report/src/components/Spinner/StyledSpinner.tsx.html +304 -0
  237. package/coverage/lcov-report/src/components/Spinner/index.html +146 -0
  238. package/coverage/lcov-report/src/components/Spinner/index.tsx.html +190 -0
  239. package/coverage/lcov-report/src/components/Success/StyledSuccess.tsx.html +337 -0
  240. package/coverage/lcov-report/src/components/Success/index.html +131 -0
  241. package/coverage/lcov-report/src/components/Success/index.tsx.html +538 -0
  242. package/coverage/lcov-report/src/components/Swipeable/StyledSwipeable.tsx.html +118 -0
  243. package/coverage/lcov-report/src/components/Swipeable/SwipeableAction.tsx.html +220 -0
  244. package/coverage/lcov-report/src/components/Swipeable/index.html +146 -0
  245. package/coverage/lcov-report/src/components/Swipeable/index.tsx.html +646 -0
  246. package/coverage/lcov-report/src/components/Switch/SelectorSwitch/Option.tsx.html +352 -0
  247. package/coverage/lcov-report/src/components/Switch/SelectorSwitch/StyledSelectorSwitch.tsx.html +193 -0
  248. package/coverage/lcov-report/src/components/Switch/SelectorSwitch/index.html +146 -0
  249. package/coverage/lcov-report/src/components/Switch/SelectorSwitch/index.tsx.html +442 -0
  250. package/coverage/lcov-report/src/components/Switch/StyledSwitch.tsx.html +172 -0
  251. package/coverage/lcov-report/src/components/Switch/index.html +131 -0
  252. package/coverage/lcov-report/src/components/Switch/index.tsx.html +346 -0
  253. package/coverage/lcov-report/src/components/Tabs/ActiveTabIndicator.tsx.html +196 -0
  254. package/coverage/lcov-report/src/components/Tabs/SceneView.tsx.html +283 -0
  255. package/coverage/lcov-report/src/components/Tabs/ScrollableTabs.tsx.html +421 -0
  256. package/coverage/lcov-report/src/components/Tabs/ScrollableTabsHeader/ScrollableTabsHeader.tsx.html +814 -0
  257. package/coverage/lcov-report/src/components/Tabs/ScrollableTabsHeader/hooks/index.html +131 -0
  258. package/coverage/lcov-report/src/components/Tabs/ScrollableTabsHeader/hooks/useInitHighlightedAnimation.ts.html +220 -0
  259. package/coverage/lcov-report/src/components/Tabs/ScrollableTabsHeader/hooks/useInitUnderlinedAnimation.ts.html +358 -0
  260. package/coverage/lcov-report/src/components/Tabs/ScrollableTabsHeader/index.html +116 -0
  261. package/coverage/lcov-report/src/components/Tabs/StyledScrollableTabs.tsx.html +283 -0
  262. package/coverage/lcov-report/src/components/Tabs/StyledTabs.tsx.html +247 -0
  263. package/coverage/lcov-report/src/components/Tabs/TabWithBadge.tsx.html +247 -0
  264. package/coverage/lcov-report/src/components/Tabs/index.html +251 -0
  265. package/coverage/lcov-report/src/components/Tabs/index.tsx.html +850 -0
  266. package/coverage/lcov-report/src/components/Tabs/useHandlePageScroll.tsx.html +181 -0
  267. package/coverage/lcov-report/src/components/Tabs/useIsFocused.tsx.html +142 -0
  268. package/coverage/lcov-report/src/components/Tabs/utils.ts.html +124 -0
  269. package/coverage/lcov-report/src/components/Tag/StyledTag.tsx.html +190 -0
  270. package/coverage/lcov-report/src/components/Tag/index.html +131 -0
  271. package/coverage/lcov-report/src/components/Tag/index.tsx.html +268 -0
  272. package/coverage/lcov-report/src/components/TextInput/StyledTextInput.tsx.html +505 -0
  273. package/coverage/lcov-report/src/components/TextInput/index.html +131 -0
  274. package/coverage/lcov-report/src/components/TextInput/index.tsx.html +1759 -0
  275. package/coverage/lcov-report/src/components/TimePicker/StyledTimePicker.tsx.html +112 -0
  276. package/coverage/lcov-report/src/components/TimePicker/TimePickerAndroid.tsx.html +277 -0
  277. package/coverage/lcov-report/src/components/TimePicker/TimePickerIOS.tsx.html +364 -0
  278. package/coverage/lcov-report/src/components/TimePicker/index.html +161 -0
  279. package/coverage/lcov-report/src/components/TimePicker/index.tsx.html +130 -0
  280. package/coverage/lcov-report/src/components/Toast/StyledToast.tsx.html +283 -0
  281. package/coverage/lcov-report/src/components/Toast/Toast.tsx.html +535 -0
  282. package/coverage/lcov-report/src/components/Toast/ToastContainer.tsx.html +355 -0
  283. package/coverage/lcov-report/src/components/Toast/ToastContext.ts.html +214 -0
  284. package/coverage/lcov-report/src/components/Toast/ToastProvider.tsx.html +280 -0
  285. package/coverage/lcov-report/src/components/Toast/index.html +191 -0
  286. package/coverage/lcov-report/src/components/Toast/index.tsx.html +118 -0
  287. package/coverage/lcov-report/src/components/Toolbar/StyledToolbar.tsx.html +457 -0
  288. package/coverage/lcov-report/src/components/Toolbar/ToolbarGroup.tsx.html +196 -0
  289. package/coverage/lcov-report/src/components/Toolbar/ToolbarItem.tsx.html +448 -0
  290. package/coverage/lcov-report/src/components/Toolbar/ToolbarMessage.tsx.html +592 -0
  291. package/coverage/lcov-report/src/components/Toolbar/index.html +176 -0
  292. package/coverage/lcov-report/src/components/Toolbar/index.tsx.html +151 -0
  293. package/coverage/lcov-report/src/components/Typography/Body/StyledBody.tsx.html +223 -0
  294. package/coverage/lcov-report/src/components/Typography/Body/index.html +131 -0
  295. package/coverage/lcov-report/src/components/Typography/Body/index.tsx.html +301 -0
  296. package/coverage/lcov-report/src/components/Typography/Caption/StyledCaption.tsx.html +136 -0
  297. package/coverage/lcov-report/src/components/Typography/Caption/index.html +131 -0
  298. package/coverage/lcov-report/src/components/Typography/Caption/index.tsx.html +271 -0
  299. package/coverage/lcov-report/src/components/Typography/Label/StyledLabel.tsx.html +127 -0
  300. package/coverage/lcov-report/src/components/Typography/Label/index.html +131 -0
  301. package/coverage/lcov-report/src/components/Typography/Label/index.tsx.html +253 -0
  302. package/coverage/lcov-report/src/components/Typography/Text/StyledText.tsx.html +244 -0
  303. package/coverage/lcov-report/src/components/Typography/Text/index.html +131 -0
  304. package/coverage/lcov-report/src/components/Typography/Text/index.tsx.html +361 -0
  305. package/coverage/lcov-report/src/components/Typography/Title/StyledTitle.tsx.html +145 -0
  306. package/coverage/lcov-report/src/components/Typography/Title/index.html +131 -0
  307. package/coverage/lcov-report/src/components/Typography/Title/index.tsx.html +298 -0
  308. package/coverage/lcov-report/src/components/Typography/index.html +131 -0
  309. package/coverage/lcov-report/src/components/Typography/index.tsx.html +163 -0
  310. package/coverage/lcov-report/src/components/Typography/types.ts.html +142 -0
  311. package/coverage/lcov-report/src/index.html +131 -0
  312. package/coverage/lcov-report/src/index.ts.html +535 -0
  313. package/coverage/lcov-report/src/testHelpers/index.html +131 -0
  314. package/coverage/lcov-report/src/testHelpers/renderWithTheme.tsx.html +115 -0
  315. package/coverage/lcov-report/src/testHelpers/utils.ts.html +148 -0
  316. package/coverage/lcov-report/src/theme/ThemeProvider.ts.html +142 -0
  317. package/coverage/lcov-report/src/theme/ThemeSwitcher.tsx.html +283 -0
  318. package/coverage/lcov-report/src/theme/components/accordion.ts.html +142 -0
  319. package/coverage/lcov-report/src/theme/components/alert.ts.html +217 -0
  320. package/coverage/lcov-report/src/theme/components/attachment.ts.html +169 -0
  321. package/coverage/lcov-report/src/theme/components/avatar.ts.html +259 -0
  322. package/coverage/lcov-report/src/theme/components/badge.ts.html +283 -0
  323. package/coverage/lcov-report/src/theme/components/bottomNavigation.ts.html +166 -0
  324. package/coverage/lcov-report/src/theme/components/bottomSheet.ts.html +214 -0
  325. package/coverage/lcov-report/src/theme/components/button.ts.html +361 -0
  326. package/coverage/lcov-report/src/theme/components/calendar.ts.html +199 -0
  327. package/coverage/lcov-report/src/theme/components/card.ts.html +166 -0
  328. package/coverage/lcov-report/src/theme/components/cardCarousel.ts.html +148 -0
  329. package/coverage/lcov-report/src/theme/components/carousel.ts.html +217 -0
  330. package/coverage/lcov-report/src/theme/components/checkbox.ts.html +208 -0
  331. package/coverage/lcov-report/src/theme/components/chip.ts.html +220 -0
  332. package/coverage/lcov-report/src/theme/components/contentNavigator.ts.html +118 -0
  333. package/coverage/lcov-report/src/theme/components/datePicker.ts.html +118 -0
  334. package/coverage/lcov-report/src/theme/components/divider.ts.html +154 -0
  335. package/coverage/lcov-report/src/theme/components/drawer.ts.html +190 -0
  336. package/coverage/lcov-report/src/theme/components/empty.ts.html +223 -0
  337. package/coverage/lcov-report/src/theme/components/error.ts.html +268 -0
  338. package/coverage/lcov-report/src/theme/components/fab.ts.html +349 -0
  339. package/coverage/lcov-report/src/theme/components/floatingIsland.ts.html +178 -0
  340. package/coverage/lcov-report/src/theme/components/icon.ts.html +169 -0
  341. package/coverage/lcov-report/src/theme/components/image.ts.html +121 -0
  342. package/coverage/lcov-report/src/theme/components/index.html +836 -0
  343. package/coverage/lcov-report/src/theme/components/list.ts.html +241 -0
  344. package/coverage/lcov-report/src/theme/components/mapPin.ts.html +223 -0
  345. package/coverage/lcov-report/src/theme/components/pageControl.ts.html +160 -0
  346. package/coverage/lcov-report/src/theme/components/pinInput.ts.html +313 -0
  347. package/coverage/lcov-report/src/theme/components/progress.ts.html +280 -0
  348. package/coverage/lcov-report/src/theme/components/radio.ts.html +193 -0
  349. package/coverage/lcov-report/src/theme/components/rate.ts.html +133 -0
  350. package/coverage/lcov-report/src/theme/components/refreshControl.ts.html +118 -0
  351. package/coverage/lcov-report/src/theme/components/richTextEditor.ts.html +193 -0
  352. package/coverage/lcov-report/src/theme/components/search.ts.html +328 -0
  353. package/coverage/lcov-report/src/theme/components/sectionHeading.ts.html +142 -0
  354. package/coverage/lcov-report/src/theme/components/select.ts.html +154 -0
  355. package/coverage/lcov-report/src/theme/components/skeleton.ts.html +151 -0
  356. package/coverage/lcov-report/src/theme/components/slider.ts.html +124 -0
  357. package/coverage/lcov-report/src/theme/components/spinner.ts.html +184 -0
  358. package/coverage/lcov-report/src/theme/components/success.ts.html +241 -0
  359. package/coverage/lcov-report/src/theme/components/swipeable.ts.html +151 -0
  360. package/coverage/lcov-report/src/theme/components/switch.ts.html +235 -0
  361. package/coverage/lcov-report/src/theme/components/tabs.ts.html +199 -0
  362. package/coverage/lcov-report/src/theme/components/tag.ts.html +274 -0
  363. package/coverage/lcov-report/src/theme/components/textInput.ts.html +406 -0
  364. package/coverage/lcov-report/src/theme/components/timePicker.ts.html +118 -0
  365. package/coverage/lcov-report/src/theme/components/toast.ts.html +223 -0
  366. package/coverage/lcov-report/src/theme/components/toolbar.ts.html +259 -0
  367. package/coverage/lcov-report/src/theme/components/typography.ts.html +622 -0
  368. package/coverage/lcov-report/src/theme/getTheme.ts.html +598 -0
  369. package/coverage/lcov-report/src/theme/global/borders.ts.html +187 -0
  370. package/coverage/lcov-report/src/theme/global/colors/eBens.ts.html +154 -0
  371. package/coverage/lcov-report/src/theme/global/colors/global.ts.html +238 -0
  372. package/coverage/lcov-report/src/theme/global/colors/globalDark.ts.html +238 -0
  373. package/coverage/lcov-report/src/theme/global/colors/index.html +266 -0
  374. package/coverage/lcov-report/src/theme/global/colors/jobs.ts.html +154 -0
  375. package/coverage/lcov-report/src/theme/global/colors/swag.ts.html +160 -0
  376. package/coverage/lcov-report/src/theme/global/colors/swagDark.ts.html +160 -0
  377. package/coverage/lcov-report/src/theme/global/colors/swagLight.ts.html +157 -0
  378. package/coverage/lcov-report/src/theme/global/colors/swagLightGlobal.ts.html +127 -0
  379. package/coverage/lcov-report/src/theme/global/colors/swagLightJobs.ts.html +121 -0
  380. package/coverage/lcov-report/src/theme/global/colors/wallet.ts.html +154 -0
  381. package/coverage/lcov-report/src/theme/global/colors/work.ts.html +154 -0
  382. package/coverage/lcov-report/src/theme/global/index.html +206 -0
  383. package/coverage/lcov-report/src/theme/global/index.ts.html +262 -0
  384. package/coverage/lcov-report/src/theme/global/scale.ts.html +172 -0
  385. package/coverage/lcov-report/src/theme/global/shadows.ts.html +142 -0
  386. package/coverage/lcov-report/src/theme/global/sizes.ts.html +172 -0
  387. package/coverage/lcov-report/src/theme/global/space.ts.html +181 -0
  388. package/coverage/lcov-report/src/theme/global/typography.ts.html +376 -0
  389. package/coverage/lcov-report/src/theme/index.html +161 -0
  390. package/coverage/lcov-report/src/theme/index.ts.html +196 -0
  391. package/coverage/lcov-report/src/types.ts.html +202 -0
  392. package/coverage/lcov-report/src/utils/functions.ts.html +91 -0
  393. package/coverage/lcov-report/src/utils/helpers.ts.html +172 -0
  394. package/coverage/lcov-report/src/utils/hooks.ts.html +172 -0
  395. package/coverage/lcov-report/src/utils/index.html +161 -0
  396. package/coverage/lcov-report/src/utils/scale.ts.html +133 -0
  397. package/coverage/lcov.info +9341 -0
  398. package/es/index.js +73 -10
  399. package/lib/index.js +73 -9
  400. package/package.json +1 -1
  401. package/src/components/DatePicker/__tests__/__snapshots__/DatePicker.spec.tsx.snap +60 -3
  402. package/src/components/DatePicker/__tests__/__snapshots__/DatePickerAndroid.spec.tsx.snap +20 -1
  403. package/src/components/DatePicker/__tests__/__snapshots__/DatePickerCalendar.spec.tsx.snap +20 -1
  404. package/src/components/DatePicker/__tests__/__snapshots__/DatePickerIOS.spec.tsx.snap +40 -2
  405. package/src/components/Error/__tests__/__snapshots__/index.spec.tsx.snap +1 -1
  406. package/src/components/List/__tests__/__snapshots__/StyledBasicListItem.spec.tsx.snap +2 -2
  407. package/src/components/List/__tests__/__snapshots__/StyledListItem.spec.tsx.snap +2 -2
  408. package/src/components/Radio/__tests__/__snapshots__/Radio.spec.tsx.snap +2 -2
  409. package/src/components/Radio/__tests__/__snapshots__/RadioGroup.spec.tsx.snap +2 -2
  410. package/src/components/RichTextEditor/RichTextEditor.tsx +2 -1
  411. package/src/components/RichTextEditor/__tests__/__snapshots__/RichTextEditor.spec.tsx.snap +40 -2
  412. package/src/components/Select/MultiSelect/__tests__/__snapshots__/Option.spec.tsx.snap +1 -1
  413. package/src/components/Select/MultiSelect/__tests__/__snapshots__/OptionList.spec.tsx.snap +5 -5
  414. package/src/components/Select/MultiSelect/__tests__/__snapshots__/index.spec.tsx.snap +146 -13
  415. package/src/components/Select/SingleSelect/__tests__/__snapshots__/Option.spec.tsx.snap +1 -1
  416. package/src/components/Select/SingleSelect/__tests__/__snapshots__/OptionList.spec.tsx.snap +4 -4
  417. package/src/components/Select/SingleSelect/__tests__/__snapshots__/index.spec.tsx.snap +123 -9
  418. package/src/components/Success/__tests__/__snapshots__/index.spec.tsx.snap +1 -1
  419. package/src/components/TextInput/__tests__/__snapshots__/index.spec.tsx.snap +320 -16
  420. package/src/components/TextInput/index.tsx +2 -1
  421. package/src/components/TimePicker/__tests__/__snapshots__/TimePickerAndroid.spec.tsx.snap +40 -2
  422. package/src/components/TimePicker/__tests__/__snapshots__/TimePickerIOS.spec.tsx.snap +40 -2
  423. package/src/index.ts +2 -0
  424. package/src/theme/ThemeSwitcher.tsx +5 -1
  425. package/src/theme/__tests__/__snapshots__/index.spec.ts.snap +5 -6
  426. package/src/theme/components/attachment.ts +1 -1
  427. package/src/theme/components/error.ts +1 -1
  428. package/src/theme/components/list.ts +1 -1
  429. package/src/theme/components/success.ts +1 -1
  430. package/src/theme/components/toolbar.ts +1 -2
  431. package/src/theme/global/colors/__tests__/__snapshots__/swagLight.spec.ts.snap +2 -0
  432. package/src/theme/global/colors/ehWorkDark.ts +63 -0
  433. package/src/theme/global/colors/swagLight.ts +2 -0
  434. package/src/theme/global/colors/types.ts +3 -0
  435. package/src/theme/global/index.ts +2 -0
  436. package/src/theme/index.ts +2 -0
  437. package/stats/8.91.0/rn-stats.html +4844 -0
  438. package/types/index.d.ts +2 -2
  439. package/types/theme/ThemeSwitcher.d.ts +1 -1
  440. package/types/theme/components/attachment.d.ts +1 -1
  441. package/types/theme/components/list.d.ts +1 -1
  442. package/types/theme/components/toolbar.d.ts +0 -1
  443. package/types/theme/global/colors/ehWorkDark.d.ts +3 -0
  444. package/types/theme/global/colors/swagLightJobs.d.ts +2 -0
  445. package/types/theme/global/colors/types.d.ts +2 -0
  446. package/types/theme/global/index.d.ts +4 -1
  447. package/types/theme/index.d.ts +2 -2
  448. package/.turbo/turbo-build.log +0 -13
@@ -0,0 +1,736 @@
1
+
2
+ <!doctype html>
3
+ <html lang="en">
4
+
5
+ <head>
6
+ <title>Code coverage report for src/components/Modal/index.tsx</title>
7
+ <meta charset="utf-8" />
8
+ <link rel="stylesheet" href="../../../prettify.css" />
9
+ <link rel="stylesheet" href="../../../base.css" />
10
+ <link rel="shortcut icon" type="image/x-icon" href="../../../favicon.png" />
11
+ <meta name="viewport" content="width=device-width, initial-scale=1" />
12
+ <style type='text/css'>
13
+ .coverage-summary .sorter {
14
+ background-image: url(../../../sort-arrow-sprite.png);
15
+ }
16
+ </style>
17
+ </head>
18
+
19
+ <body>
20
+ <div class='wrapper'>
21
+ <div class='pad1'>
22
+ <h1><a href="../../../index.html">All files</a> / <a href="index.html">src/components/Modal</a> index.tsx</h1>
23
+ <div class='clearfix'>
24
+
25
+ <div class='fl pad1y space-right2'>
26
+ <span class="strong">100% </span>
27
+ <span class="quiet">Statements</span>
28
+ <span class='fraction'>40/40</span>
29
+ </div>
30
+
31
+
32
+ <div class='fl pad1y space-right2'>
33
+ <span class="strong">88% </span>
34
+ <span class="quiet">Branches</span>
35
+ <span class='fraction'>22/25</span>
36
+ </div>
37
+
38
+
39
+ <div class='fl pad1y space-right2'>
40
+ <span class="strong">100% </span>
41
+ <span class="quiet">Functions</span>
42
+ <span class='fraction'>13/13</span>
43
+ </div>
44
+
45
+
46
+ <div class='fl pad1y space-right2'>
47
+ <span class="strong">100% </span>
48
+ <span class="quiet">Lines</span>
49
+ <span class='fraction'>38/38</span>
50
+ </div>
51
+
52
+
53
+ </div>
54
+ <p class="quiet">
55
+ Press <em>n</em> or <em>j</em> to go to the next uncovered block, <em>b</em>, <em>p</em> or <em>k</em> for the previous block.
56
+ </p>
57
+ <template id="filterTemplate">
58
+ <div class="quiet">
59
+ Filter:
60
+ <input oninput="onInput()" type="search" id="fileSearch">
61
+ </div>
62
+ </template>
63
+ </div>
64
+ <div class='status-line high'></div>
65
+ <pre><table class="coverage">
66
+ <tr><td class="line-count quiet"><a name='L1'></a><a href='#L1'>1</a>
67
+ <a name='L2'></a><a href='#L2'>2</a>
68
+ <a name='L3'></a><a href='#L3'>3</a>
69
+ <a name='L4'></a><a href='#L4'>4</a>
70
+ <a name='L5'></a><a href='#L5'>5</a>
71
+ <a name='L6'></a><a href='#L6'>6</a>
72
+ <a name='L7'></a><a href='#L7'>7</a>
73
+ <a name='L8'></a><a href='#L8'>8</a>
74
+ <a name='L9'></a><a href='#L9'>9</a>
75
+ <a name='L10'></a><a href='#L10'>10</a>
76
+ <a name='L11'></a><a href='#L11'>11</a>
77
+ <a name='L12'></a><a href='#L12'>12</a>
78
+ <a name='L13'></a><a href='#L13'>13</a>
79
+ <a name='L14'></a><a href='#L14'>14</a>
80
+ <a name='L15'></a><a href='#L15'>15</a>
81
+ <a name='L16'></a><a href='#L16'>16</a>
82
+ <a name='L17'></a><a href='#L17'>17</a>
83
+ <a name='L18'></a><a href='#L18'>18</a>
84
+ <a name='L19'></a><a href='#L19'>19</a>
85
+ <a name='L20'></a><a href='#L20'>20</a>
86
+ <a name='L21'></a><a href='#L21'>21</a>
87
+ <a name='L22'></a><a href='#L22'>22</a>
88
+ <a name='L23'></a><a href='#L23'>23</a>
89
+ <a name='L24'></a><a href='#L24'>24</a>
90
+ <a name='L25'></a><a href='#L25'>25</a>
91
+ <a name='L26'></a><a href='#L26'>26</a>
92
+ <a name='L27'></a><a href='#L27'>27</a>
93
+ <a name='L28'></a><a href='#L28'>28</a>
94
+ <a name='L29'></a><a href='#L29'>29</a>
95
+ <a name='L30'></a><a href='#L30'>30</a>
96
+ <a name='L31'></a><a href='#L31'>31</a>
97
+ <a name='L32'></a><a href='#L32'>32</a>
98
+ <a name='L33'></a><a href='#L33'>33</a>
99
+ <a name='L34'></a><a href='#L34'>34</a>
100
+ <a name='L35'></a><a href='#L35'>35</a>
101
+ <a name='L36'></a><a href='#L36'>36</a>
102
+ <a name='L37'></a><a href='#L37'>37</a>
103
+ <a name='L38'></a><a href='#L38'>38</a>
104
+ <a name='L39'></a><a href='#L39'>39</a>
105
+ <a name='L40'></a><a href='#L40'>40</a>
106
+ <a name='L41'></a><a href='#L41'>41</a>
107
+ <a name='L42'></a><a href='#L42'>42</a>
108
+ <a name='L43'></a><a href='#L43'>43</a>
109
+ <a name='L44'></a><a href='#L44'>44</a>
110
+ <a name='L45'></a><a href='#L45'>45</a>
111
+ <a name='L46'></a><a href='#L46'>46</a>
112
+ <a name='L47'></a><a href='#L47'>47</a>
113
+ <a name='L48'></a><a href='#L48'>48</a>
114
+ <a name='L49'></a><a href='#L49'>49</a>
115
+ <a name='L50'></a><a href='#L50'>50</a>
116
+ <a name='L51'></a><a href='#L51'>51</a>
117
+ <a name='L52'></a><a href='#L52'>52</a>
118
+ <a name='L53'></a><a href='#L53'>53</a>
119
+ <a name='L54'></a><a href='#L54'>54</a>
120
+ <a name='L55'></a><a href='#L55'>55</a>
121
+ <a name='L56'></a><a href='#L56'>56</a>
122
+ <a name='L57'></a><a href='#L57'>57</a>
123
+ <a name='L58'></a><a href='#L58'>58</a>
124
+ <a name='L59'></a><a href='#L59'>59</a>
125
+ <a name='L60'></a><a href='#L60'>60</a>
126
+ <a name='L61'></a><a href='#L61'>61</a>
127
+ <a name='L62'></a><a href='#L62'>62</a>
128
+ <a name='L63'></a><a href='#L63'>63</a>
129
+ <a name='L64'></a><a href='#L64'>64</a>
130
+ <a name='L65'></a><a href='#L65'>65</a>
131
+ <a name='L66'></a><a href='#L66'>66</a>
132
+ <a name='L67'></a><a href='#L67'>67</a>
133
+ <a name='L68'></a><a href='#L68'>68</a>
134
+ <a name='L69'></a><a href='#L69'>69</a>
135
+ <a name='L70'></a><a href='#L70'>70</a>
136
+ <a name='L71'></a><a href='#L71'>71</a>
137
+ <a name='L72'></a><a href='#L72'>72</a>
138
+ <a name='L73'></a><a href='#L73'>73</a>
139
+ <a name='L74'></a><a href='#L74'>74</a>
140
+ <a name='L75'></a><a href='#L75'>75</a>
141
+ <a name='L76'></a><a href='#L76'>76</a>
142
+ <a name='L77'></a><a href='#L77'>77</a>
143
+ <a name='L78'></a><a href='#L78'>78</a>
144
+ <a name='L79'></a><a href='#L79'>79</a>
145
+ <a name='L80'></a><a href='#L80'>80</a>
146
+ <a name='L81'></a><a href='#L81'>81</a>
147
+ <a name='L82'></a><a href='#L82'>82</a>
148
+ <a name='L83'></a><a href='#L83'>83</a>
149
+ <a name='L84'></a><a href='#L84'>84</a>
150
+ <a name='L85'></a><a href='#L85'>85</a>
151
+ <a name='L86'></a><a href='#L86'>86</a>
152
+ <a name='L87'></a><a href='#L87'>87</a>
153
+ <a name='L88'></a><a href='#L88'>88</a>
154
+ <a name='L89'></a><a href='#L89'>89</a>
155
+ <a name='L90'></a><a href='#L90'>90</a>
156
+ <a name='L91'></a><a href='#L91'>91</a>
157
+ <a name='L92'></a><a href='#L92'>92</a>
158
+ <a name='L93'></a><a href='#L93'>93</a>
159
+ <a name='L94'></a><a href='#L94'>94</a>
160
+ <a name='L95'></a><a href='#L95'>95</a>
161
+ <a name='L96'></a><a href='#L96'>96</a>
162
+ <a name='L97'></a><a href='#L97'>97</a>
163
+ <a name='L98'></a><a href='#L98'>98</a>
164
+ <a name='L99'></a><a href='#L99'>99</a>
165
+ <a name='L100'></a><a href='#L100'>100</a>
166
+ <a name='L101'></a><a href='#L101'>101</a>
167
+ <a name='L102'></a><a href='#L102'>102</a>
168
+ <a name='L103'></a><a href='#L103'>103</a>
169
+ <a name='L104'></a><a href='#L104'>104</a>
170
+ <a name='L105'></a><a href='#L105'>105</a>
171
+ <a name='L106'></a><a href='#L106'>106</a>
172
+ <a name='L107'></a><a href='#L107'>107</a>
173
+ <a name='L108'></a><a href='#L108'>108</a>
174
+ <a name='L109'></a><a href='#L109'>109</a>
175
+ <a name='L110'></a><a href='#L110'>110</a>
176
+ <a name='L111'></a><a href='#L111'>111</a>
177
+ <a name='L112'></a><a href='#L112'>112</a>
178
+ <a name='L113'></a><a href='#L113'>113</a>
179
+ <a name='L114'></a><a href='#L114'>114</a>
180
+ <a name='L115'></a><a href='#L115'>115</a>
181
+ <a name='L116'></a><a href='#L116'>116</a>
182
+ <a name='L117'></a><a href='#L117'>117</a>
183
+ <a name='L118'></a><a href='#L118'>118</a>
184
+ <a name='L119'></a><a href='#L119'>119</a>
185
+ <a name='L120'></a><a href='#L120'>120</a>
186
+ <a name='L121'></a><a href='#L121'>121</a>
187
+ <a name='L122'></a><a href='#L122'>122</a>
188
+ <a name='L123'></a><a href='#L123'>123</a>
189
+ <a name='L124'></a><a href='#L124'>124</a>
190
+ <a name='L125'></a><a href='#L125'>125</a>
191
+ <a name='L126'></a><a href='#L126'>126</a>
192
+ <a name='L127'></a><a href='#L127'>127</a>
193
+ <a name='L128'></a><a href='#L128'>128</a>
194
+ <a name='L129'></a><a href='#L129'>129</a>
195
+ <a name='L130'></a><a href='#L130'>130</a>
196
+ <a name='L131'></a><a href='#L131'>131</a>
197
+ <a name='L132'></a><a href='#L132'>132</a>
198
+ <a name='L133'></a><a href='#L133'>133</a>
199
+ <a name='L134'></a><a href='#L134'>134</a>
200
+ <a name='L135'></a><a href='#L135'>135</a>
201
+ <a name='L136'></a><a href='#L136'>136</a>
202
+ <a name='L137'></a><a href='#L137'>137</a>
203
+ <a name='L138'></a><a href='#L138'>138</a>
204
+ <a name='L139'></a><a href='#L139'>139</a>
205
+ <a name='L140'></a><a href='#L140'>140</a>
206
+ <a name='L141'></a><a href='#L141'>141</a>
207
+ <a name='L142'></a><a href='#L142'>142</a>
208
+ <a name='L143'></a><a href='#L143'>143</a>
209
+ <a name='L144'></a><a href='#L144'>144</a>
210
+ <a name='L145'></a><a href='#L145'>145</a>
211
+ <a name='L146'></a><a href='#L146'>146</a>
212
+ <a name='L147'></a><a href='#L147'>147</a>
213
+ <a name='L148'></a><a href='#L148'>148</a>
214
+ <a name='L149'></a><a href='#L149'>149</a>
215
+ <a name='L150'></a><a href='#L150'>150</a>
216
+ <a name='L151'></a><a href='#L151'>151</a>
217
+ <a name='L152'></a><a href='#L152'>152</a>
218
+ <a name='L153'></a><a href='#L153'>153</a>
219
+ <a name='L154'></a><a href='#L154'>154</a>
220
+ <a name='L155'></a><a href='#L155'>155</a>
221
+ <a name='L156'></a><a href='#L156'>156</a>
222
+ <a name='L157'></a><a href='#L157'>157</a>
223
+ <a name='L158'></a><a href='#L158'>158</a>
224
+ <a name='L159'></a><a href='#L159'>159</a>
225
+ <a name='L160'></a><a href='#L160'>160</a>
226
+ <a name='L161'></a><a href='#L161'>161</a>
227
+ <a name='L162'></a><a href='#L162'>162</a>
228
+ <a name='L163'></a><a href='#L163'>163</a>
229
+ <a name='L164'></a><a href='#L164'>164</a>
230
+ <a name='L165'></a><a href='#L165'>165</a>
231
+ <a name='L166'></a><a href='#L166'>166</a>
232
+ <a name='L167'></a><a href='#L167'>167</a>
233
+ <a name='L168'></a><a href='#L168'>168</a>
234
+ <a name='L169'></a><a href='#L169'>169</a>
235
+ <a name='L170'></a><a href='#L170'>170</a>
236
+ <a name='L171'></a><a href='#L171'>171</a>
237
+ <a name='L172'></a><a href='#L172'>172</a>
238
+ <a name='L173'></a><a href='#L173'>173</a>
239
+ <a name='L174'></a><a href='#L174'>174</a>
240
+ <a name='L175'></a><a href='#L175'>175</a>
241
+ <a name='L176'></a><a href='#L176'>176</a>
242
+ <a name='L177'></a><a href='#L177'>177</a>
243
+ <a name='L178'></a><a href='#L178'>178</a>
244
+ <a name='L179'></a><a href='#L179'>179</a>
245
+ <a name='L180'></a><a href='#L180'>180</a>
246
+ <a name='L181'></a><a href='#L181'>181</a>
247
+ <a name='L182'></a><a href='#L182'>182</a>
248
+ <a name='L183'></a><a href='#L183'>183</a>
249
+ <a name='L184'></a><a href='#L184'>184</a>
250
+ <a name='L185'></a><a href='#L185'>185</a>
251
+ <a name='L186'></a><a href='#L186'>186</a>
252
+ <a name='L187'></a><a href='#L187'>187</a>
253
+ <a name='L188'></a><a href='#L188'>188</a>
254
+ <a name='L189'></a><a href='#L189'>189</a>
255
+ <a name='L190'></a><a href='#L190'>190</a>
256
+ <a name='L191'></a><a href='#L191'>191</a>
257
+ <a name='L192'></a><a href='#L192'>192</a>
258
+ <a name='L193'></a><a href='#L193'>193</a>
259
+ <a name='L194'></a><a href='#L194'>194</a>
260
+ <a name='L195'></a><a href='#L195'>195</a>
261
+ <a name='L196'></a><a href='#L196'>196</a>
262
+ <a name='L197'></a><a href='#L197'>197</a>
263
+ <a name='L198'></a><a href='#L198'>198</a>
264
+ <a name='L199'></a><a href='#L199'>199</a>
265
+ <a name='L200'></a><a href='#L200'>200</a>
266
+ <a name='L201'></a><a href='#L201'>201</a>
267
+ <a name='L202'></a><a href='#L202'>202</a>
268
+ <a name='L203'></a><a href='#L203'>203</a>
269
+ <a name='L204'></a><a href='#L204'>204</a>
270
+ <a name='L205'></a><a href='#L205'>205</a>
271
+ <a name='L206'></a><a href='#L206'>206</a>
272
+ <a name='L207'></a><a href='#L207'>207</a>
273
+ <a name='L208'></a><a href='#L208'>208</a>
274
+ <a name='L209'></a><a href='#L209'>209</a>
275
+ <a name='L210'></a><a href='#L210'>210</a>
276
+ <a name='L211'></a><a href='#L211'>211</a>
277
+ <a name='L212'></a><a href='#L212'>212</a>
278
+ <a name='L213'></a><a href='#L213'>213</a>
279
+ <a name='L214'></a><a href='#L214'>214</a>
280
+ <a name='L215'></a><a href='#L215'>215</a>
281
+ <a name='L216'></a><a href='#L216'>216</a>
282
+ <a name='L217'></a><a href='#L217'>217</a>
283
+ <a name='L218'></a><a href='#L218'>218</a></td><td class="line-coverage quiet"><span class="cline-any cline-neutral">&nbsp;</span>
284
+ <span class="cline-any cline-neutral">&nbsp;</span>
285
+ <span class="cline-any cline-neutral">&nbsp;</span>
286
+ <span class="cline-any cline-neutral">&nbsp;</span>
287
+ <span class="cline-any cline-neutral">&nbsp;</span>
288
+ <span class="cline-any cline-neutral">&nbsp;</span>
289
+ <span class="cline-any cline-neutral">&nbsp;</span>
290
+ <span class="cline-any cline-neutral">&nbsp;</span>
291
+ <span class="cline-any cline-neutral">&nbsp;</span>
292
+ <span class="cline-any cline-neutral">&nbsp;</span>
293
+ <span class="cline-any cline-neutral">&nbsp;</span>
294
+ <span class="cline-any cline-neutral">&nbsp;</span>
295
+ <span class="cline-any cline-neutral">&nbsp;</span>
296
+ <span class="cline-any cline-neutral">&nbsp;</span>
297
+ <span class="cline-any cline-neutral">&nbsp;</span>
298
+ <span class="cline-any cline-neutral">&nbsp;</span>
299
+ <span class="cline-any cline-neutral">&nbsp;</span>
300
+ <span class="cline-any cline-neutral">&nbsp;</span>
301
+ <span class="cline-any cline-neutral">&nbsp;</span>
302
+ <span class="cline-any cline-neutral">&nbsp;</span>
303
+ <span class="cline-any cline-neutral">&nbsp;</span>
304
+ <span class="cline-any cline-neutral">&nbsp;</span>
305
+ <span class="cline-any cline-neutral">&nbsp;</span>
306
+ <span class="cline-any cline-neutral">&nbsp;</span>
307
+ <span class="cline-any cline-neutral">&nbsp;</span>
308
+ <span class="cline-any cline-yes">131x</span>
309
+ <span class="cline-any cline-neutral">&nbsp;</span>
310
+ <span class="cline-any cline-yes">131x</span>
311
+ <span class="cline-any cline-neutral">&nbsp;</span>
312
+ <span class="cline-any cline-neutral">&nbsp;</span>
313
+ <span class="cline-any cline-neutral">&nbsp;</span>
314
+ <span class="cline-any cline-neutral">&nbsp;</span>
315
+ <span class="cline-any cline-neutral">&nbsp;</span>
316
+ <span class="cline-any cline-neutral">&nbsp;</span>
317
+ <span class="cline-any cline-neutral">&nbsp;</span>
318
+ <span class="cline-any cline-neutral">&nbsp;</span>
319
+ <span class="cline-any cline-neutral">&nbsp;</span>
320
+ <span class="cline-any cline-neutral">&nbsp;</span>
321
+ <span class="cline-any cline-neutral">&nbsp;</span>
322
+ <span class="cline-any cline-neutral">&nbsp;</span>
323
+ <span class="cline-any cline-neutral">&nbsp;</span>
324
+ <span class="cline-any cline-neutral">&nbsp;</span>
325
+ <span class="cline-any cline-neutral">&nbsp;</span>
326
+ <span class="cline-any cline-neutral">&nbsp;</span>
327
+ <span class="cline-any cline-neutral">&nbsp;</span>
328
+ <span class="cline-any cline-neutral">&nbsp;</span>
329
+ <span class="cline-any cline-neutral">&nbsp;</span>
330
+ <span class="cline-any cline-neutral">&nbsp;</span>
331
+ <span class="cline-any cline-neutral">&nbsp;</span>
332
+ <span class="cline-any cline-neutral">&nbsp;</span>
333
+ <span class="cline-any cline-neutral">&nbsp;</span>
334
+ <span class="cline-any cline-neutral">&nbsp;</span>
335
+ <span class="cline-any cline-neutral">&nbsp;</span>
336
+ <span class="cline-any cline-neutral">&nbsp;</span>
337
+ <span class="cline-any cline-neutral">&nbsp;</span>
338
+ <span class="cline-any cline-neutral">&nbsp;</span>
339
+ <span class="cline-any cline-neutral">&nbsp;</span>
340
+ <span class="cline-any cline-neutral">&nbsp;</span>
341
+ <span class="cline-any cline-neutral">&nbsp;</span>
342
+ <span class="cline-any cline-neutral">&nbsp;</span>
343
+ <span class="cline-any cline-neutral">&nbsp;</span>
344
+ <span class="cline-any cline-neutral">&nbsp;</span>
345
+ <span class="cline-any cline-neutral">&nbsp;</span>
346
+ <span class="cline-any cline-neutral">&nbsp;</span>
347
+ <span class="cline-any cline-neutral">&nbsp;</span>
348
+ <span class="cline-any cline-neutral">&nbsp;</span>
349
+ <span class="cline-any cline-neutral">&nbsp;</span>
350
+ <span class="cline-any cline-neutral">&nbsp;</span>
351
+ <span class="cline-any cline-yes">131x</span>
352
+ <span class="cline-any cline-neutral">&nbsp;</span>
353
+ <span class="cline-any cline-neutral">&nbsp;</span>
354
+ <span class="cline-any cline-neutral">&nbsp;</span>
355
+ <span class="cline-any cline-neutral">&nbsp;</span>
356
+ <span class="cline-any cline-neutral">&nbsp;</span>
357
+ <span class="cline-any cline-neutral">&nbsp;</span>
358
+ <span class="cline-any cline-neutral">&nbsp;</span>
359
+ <span class="cline-any cline-neutral">&nbsp;</span>
360
+ <span class="cline-any cline-neutral">&nbsp;</span>
361
+ <span class="cline-any cline-neutral">&nbsp;</span>
362
+ <span class="cline-any cline-neutral">&nbsp;</span>
363
+ <span class="cline-any cline-neutral">&nbsp;</span>
364
+ <span class="cline-any cline-yes">8x</span>
365
+ <span class="cline-any cline-yes">8x</span>
366
+ <span class="cline-any cline-yes">8x</span>
367
+ <span class="cline-any cline-neutral">&nbsp;</span>
368
+ <span class="cline-any cline-neutral">&nbsp;</span>
369
+ <span class="cline-any cline-yes">8x</span>
370
+ <span class="cline-any cline-neutral">&nbsp;</span>
371
+ <span class="cline-any cline-yes">8x</span>
372
+ <span class="cline-any cline-neutral">&nbsp;</span>
373
+ <span class="cline-any cline-yes">2x</span>
374
+ <span class="cline-any cline-yes">2x</span>
375
+ <span class="cline-any cline-neutral">&nbsp;</span>
376
+ <span class="cline-any cline-neutral">&nbsp;</span>
377
+ <span class="cline-any cline-neutral">&nbsp;</span>
378
+ <span class="cline-any cline-neutral">&nbsp;</span>
379
+ <span class="cline-any cline-neutral">&nbsp;</span>
380
+ <span class="cline-any cline-neutral">&nbsp;</span>
381
+ <span class="cline-any cline-yes">2x</span>
382
+ <span class="cline-any cline-neutral">&nbsp;</span>
383
+ <span class="cline-any cline-neutral">&nbsp;</span>
384
+ <span class="cline-any cline-neutral">&nbsp;</span>
385
+ <span class="cline-any cline-neutral">&nbsp;</span>
386
+ <span class="cline-any cline-yes">6x</span>
387
+ <span class="cline-any cline-neutral">&nbsp;</span>
388
+ <span class="cline-any cline-neutral">&nbsp;</span>
389
+ <span class="cline-any cline-neutral">&nbsp;</span>
390
+ <span class="cline-any cline-neutral">&nbsp;</span>
391
+ <span class="cline-any cline-neutral">&nbsp;</span>
392
+ <span class="cline-any cline-yes">8x</span>
393
+ <span class="cline-any cline-neutral">&nbsp;</span>
394
+ <span class="cline-any cline-neutral">&nbsp;</span>
395
+ <span class="cline-any cline-neutral">&nbsp;</span>
396
+ <span class="cline-any cline-neutral">&nbsp;</span>
397
+ <span class="cline-any cline-yes">8x</span>
398
+ <span class="cline-any cline-neutral">&nbsp;</span>
399
+ <span class="cline-any cline-neutral">&nbsp;</span>
400
+ <span class="cline-any cline-neutral">&nbsp;</span>
401
+ <span class="cline-any cline-neutral">&nbsp;</span>
402
+ <span class="cline-any cline-neutral">&nbsp;</span>
403
+ <span class="cline-any cline-neutral">&nbsp;</span>
404
+ <span class="cline-any cline-neutral">&nbsp;</span>
405
+ <span class="cline-any cline-yes">8x</span>
406
+ <span class="cline-any cline-neutral">&nbsp;</span>
407
+ <span class="cline-any cline-neutral">&nbsp;</span>
408
+ <span class="cline-any cline-yes">7x</span>
409
+ <span class="cline-any cline-neutral">&nbsp;</span>
410
+ <span class="cline-any cline-yes">7x</span>
411
+ <span class="cline-any cline-neutral">&nbsp;</span>
412
+ <span class="cline-any cline-neutral">&nbsp;</span>
413
+ <span class="cline-any cline-neutral">&nbsp;</span>
414
+ <span class="cline-any cline-yes">1x</span>
415
+ <span class="cline-any cline-neutral">&nbsp;</span>
416
+ <span class="cline-any cline-neutral">&nbsp;</span>
417
+ <span class="cline-any cline-yes">1x</span>
418
+ <span class="cline-any cline-yes">1x</span>
419
+ <span class="cline-any cline-neutral">&nbsp;</span>
420
+ <span class="cline-any cline-neutral">&nbsp;</span>
421
+ <span class="cline-any cline-yes">1x</span>
422
+ <span class="cline-any cline-neutral">&nbsp;</span>
423
+ <span class="cline-any cline-neutral">&nbsp;</span>
424
+ <span class="cline-any cline-neutral">&nbsp;</span>
425
+ <span class="cline-any cline-neutral">&nbsp;</span>
426
+ <span class="cline-any cline-neutral">&nbsp;</span>
427
+ <span class="cline-any cline-neutral">&nbsp;</span>
428
+ <span class="cline-any cline-neutral">&nbsp;</span>
429
+ <span class="cline-any cline-neutral">&nbsp;</span>
430
+ <span class="cline-any cline-neutral">&nbsp;</span>
431
+ <span class="cline-any cline-yes">8x</span>
432
+ <span class="cline-any cline-yes">7x</span>
433
+ <span class="cline-any cline-neutral">&nbsp;</span>
434
+ <span class="cline-any cline-neutral">&nbsp;</span>
435
+ <span class="cline-any cline-yes">1x</span>
436
+ <span class="cline-any cline-yes">1x</span>
437
+ <span class="cline-any cline-neutral">&nbsp;</span>
438
+ <span class="cline-any cline-neutral">&nbsp;</span>
439
+ <span class="cline-any cline-neutral">&nbsp;</span>
440
+ <span class="cline-any cline-yes">7x</span>
441
+ <span class="cline-any cline-neutral">&nbsp;</span>
442
+ <span class="cline-any cline-neutral">&nbsp;</span>
443
+ <span class="cline-any cline-yes">8x</span>
444
+ <span class="cline-any cline-neutral">&nbsp;</span>
445
+ <span class="cline-any cline-neutral">&nbsp;</span>
446
+ <span class="cline-any cline-neutral">&nbsp;</span>
447
+ <span class="cline-any cline-neutral">&nbsp;</span>
448
+ <span class="cline-any cline-neutral">&nbsp;</span>
449
+ <span class="cline-any cline-neutral">&nbsp;</span>
450
+ <span class="cline-any cline-neutral">&nbsp;</span>
451
+ <span class="cline-any cline-neutral">&nbsp;</span>
452
+ <span class="cline-any cline-neutral">&nbsp;</span>
453
+ <span class="cline-any cline-neutral">&nbsp;</span>
454
+ <span class="cline-any cline-neutral">&nbsp;</span>
455
+ <span class="cline-any cline-neutral">&nbsp;</span>
456
+ <span class="cline-any cline-neutral">&nbsp;</span>
457
+ <span class="cline-any cline-neutral">&nbsp;</span>
458
+ <span class="cline-any cline-neutral">&nbsp;</span>
459
+ <span class="cline-any cline-neutral">&nbsp;</span>
460
+ <span class="cline-any cline-neutral">&nbsp;</span>
461
+ <span class="cline-any cline-neutral">&nbsp;</span>
462
+ <span class="cline-any cline-neutral">&nbsp;</span>
463
+ <span class="cline-any cline-neutral">&nbsp;</span>
464
+ <span class="cline-any cline-neutral">&nbsp;</span>
465
+ <span class="cline-any cline-neutral">&nbsp;</span>
466
+ <span class="cline-any cline-neutral">&nbsp;</span>
467
+ <span class="cline-any cline-neutral">&nbsp;</span>
468
+ <span class="cline-any cline-neutral">&nbsp;</span>
469
+ <span class="cline-any cline-neutral">&nbsp;</span>
470
+ <span class="cline-any cline-neutral">&nbsp;</span>
471
+ <span class="cline-any cline-neutral">&nbsp;</span>
472
+ <span class="cline-any cline-neutral">&nbsp;</span>
473
+ <span class="cline-any cline-neutral">&nbsp;</span>
474
+ <span class="cline-any cline-neutral">&nbsp;</span>
475
+ <span class="cline-any cline-neutral">&nbsp;</span>
476
+ <span class="cline-any cline-neutral">&nbsp;</span>
477
+ <span class="cline-any cline-yes">131x</span>
478
+ <span class="cline-any cline-yes">9x</span>
479
+ <span class="cline-any cline-yes">9x</span>
480
+ <span class="cline-any cline-neutral">&nbsp;</span>
481
+ <span class="cline-any cline-yes">9x</span>
482
+ <span class="cline-any cline-yes">8x</span>
483
+ <span class="cline-any cline-yes">7x</span>
484
+ <span class="cline-any cline-neutral">&nbsp;</span>
485
+ <span class="cline-any cline-neutral">&nbsp;</span>
486
+ <span class="cline-any cline-yes">1x</span>
487
+ <span class="cline-any cline-neutral">&nbsp;</span>
488
+ <span class="cline-any cline-neutral">&nbsp;</span>
489
+ <span class="cline-any cline-neutral">&nbsp;</span>
490
+ <span class="cline-any cline-yes">9x</span>
491
+ <span class="cline-any cline-yes">8x</span>
492
+ <span class="cline-any cline-yes">7x</span>
493
+ <span class="cline-any cline-neutral">&nbsp;</span>
494
+ <span class="cline-any cline-neutral">&nbsp;</span>
495
+ <span class="cline-any cline-neutral">&nbsp;</span>
496
+ <span class="cline-any cline-yes">9x</span>
497
+ <span class="cline-any cline-neutral">&nbsp;</span>
498
+ <span class="cline-any cline-neutral">&nbsp;</span>
499
+ <span class="cline-any cline-neutral">&nbsp;</span>
500
+ <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js">import React, {
501
+ ReactNode,
502
+ forwardRef,
503
+ useEffect,
504
+ useImperativeHandle,
505
+ useRef,
506
+ useState,
507
+ useCallback,
508
+ } from 'react';
509
+ import {
510
+ Animated,
511
+ BackHandler,
512
+ Dimensions,
513
+ Easing,
514
+ Platform,
515
+ StyleSheet,
516
+ } from 'react-native';
517
+ import { useTheme } from '../../theme';
518
+ import Portal from '../Portal';
519
+ &nbsp;
520
+ type ModalHandles = {
521
+ show: () =&gt; void;
522
+ hide: (callback: () =&gt; void) =&gt; void;
523
+ };
524
+ &nbsp;
525
+ const DEFAULT_BACKDROP_OPACITY = 0.4;
526
+ &nbsp;
527
+ const DEFAULT_ANIMATION_CONFIG = {
528
+ easing: Easing.inOut(Easing.cubic),
529
+ useNativeDriver: Platform.OS !== 'web',
530
+ duration: 400,
531
+ };
532
+ &nbsp;
533
+ export interface ModalProps {
534
+ /**
535
+ * Content of the modal.
536
+ */
537
+ children: ReactNode;
538
+ /**
539
+ * Visibility of the modal
540
+ */
541
+ visible?: boolean;
542
+ /**
543
+ * Callback when the modal is shown.
544
+ */
545
+ onShow?: () =&gt; void;
546
+ /**
547
+ * Callback when the user taps the hardware back button.
548
+ */
549
+ onRequestClose?: () =&gt; void;
550
+ /**
551
+ * TestID of the modal.
552
+ */
553
+ testID?: string;
554
+ /**
555
+ * Animation type of the modal content.
556
+ */
557
+ animationType?: 'none' | 'slide' | 'fade';
558
+ /**
559
+ * Whether to show the modal backdrop
560
+ */
561
+ transparent?: boolean;
562
+ /**
563
+ * Callback when the modal is dismissed. iOS only.
564
+ */
565
+ onDismiss?: () =&gt; void;
566
+ }
567
+ &nbsp;
568
+ const Modal = forwardRef&lt;ModalHandles, Omit&lt;ModalProps, 'visible'&gt;&gt;(
569
+ (
570
+ {
571
+ children,
572
+ onShow,
573
+ onRequestClose,
574
+ testID,
575
+ animationType = 'none',
576
+ transparent = false,
577
+ onDismiss,
578
+ },
579
+ ref
580
+ ) =&gt; {
581
+ const theme = useTheme();
582
+ const animatedBackdropValue = useRef(new Animated.Value(0)).current;
583
+ const animatedModalValue = useRef(new Animated.Value(0)).current;
584
+ &nbsp;
585
+ // Show or hide the backdrop and modal content
586
+ const animateBackdropAndContent = useCallback(
587
+ ({ toValue, callback }: { toValue: number; callback?: () =&gt; void }) =&gt; {
588
+ if (animationType !== 'none') {
589
+ // Backdrop animation
590
+ <span class="missing-if-branch" title="else path not taken" >E</span>if (!transparent) {
591
+ Animated.timing(animatedBackdropValue, {
592
+ toValue,
593
+ ...DEFAULT_ANIMATION_CONFIG,
594
+ }).start();
595
+ }
596
+ &nbsp;
597
+ // Modal content animation
598
+ Animated.timing(animatedModalValue, {
599
+ toValue,
600
+ ...DEFAULT_ANIMATION_CONFIG,
601
+ }).start(callback);
602
+ } else {
603
+ callback?.();
604
+ }
605
+ },
606
+ [animationType, onShow, transparent]
607
+ );
608
+ &nbsp;
609
+ const backdropOpacityAnimation = animatedBackdropValue.interpolate({
610
+ inputRange: [0, 1],
611
+ outputRange: [0, DEFAULT_BACKDROP_OPACITY],
612
+ });
613
+ &nbsp;
614
+ const modalAnimation = animatedModalValue.interpolate({
615
+ inputRange: [0, 1],
616
+ outputRange:
617
+ animationType === 'slide'
618
+ ? [Dimensions.get('window').height, 0]
619
+ : [0, 1],
620
+ });
621
+ &nbsp;
622
+ useImperativeHandle(
623
+ ref,
624
+ () =&gt; {
625
+ return {
626
+ show: () =&gt; {
627
+ animateBackdropAndContent({ toValue: 1, callback: onShow });
628
+ },
629
+ &nbsp;
630
+ hide: (wrapperCallback) =&gt; {
631
+ animateBackdropAndContent({
632
+ toValue: 0,
633
+ callback: () =&gt; {
634
+ <span class="missing-if-branch" title="else path not taken" >E</span>if (Platform.OS === 'ios') {
635
+ onDismiss?.();
636
+ }
637
+ &nbsp;
638
+ wrapperCallback();
639
+ },
640
+ });
641
+ },
642
+ };
643
+ },
644
+ [onDismiss, onShow, animateBackdropAndContent]
645
+ );
646
+ &nbsp;
647
+ // Back button handler
648
+ useEffect(() =&gt; {
649
+ const backHandler = BackHandler.addEventListener(
650
+ 'hardwareBackPress',
651
+ () =&gt; {
652
+ onRequestClose?.();
653
+ return true;
654
+ }
655
+ );
656
+ &nbsp;
657
+ return () =&gt; backHandler.remove();
658
+ }, [onRequestClose]);
659
+ &nbsp;
660
+ return (
661
+ &lt;Portal&gt;
662
+ &lt;Animated.View
663
+ style={{
664
+ ...StyleSheet.absoluteFillObject,
665
+ backgroundColor: transparent
666
+ ? 'transparent'
667
+ : theme.colors.overlayGlobalSurface,
668
+ opacity:
669
+ animationType !== 'none'
670
+ ? backdropOpacityAnimation
671
+ : DEFAULT_BACKDROP_OPACITY,
672
+ }}
673
+ /&gt;
674
+ &nbsp;
675
+ &lt;Animated.View
676
+ testID={testID}
677
+ style={{
678
+ ...StyleSheet.absoluteFillObject,
679
+ opacity: animationType === 'fade' ? <span class="branch-0 cbranch-no" title="branch not covered" >modalAnimation </span>: 1,
680
+ transform: [
681
+ {
682
+ translateY: animationType === 'slide' ? modalAnimation : 0,
683
+ },
684
+ ],
685
+ }}
686
+ &gt;
687
+ {children}
688
+ &lt;/Animated.View&gt;
689
+ &lt;/Portal&gt;
690
+ );
691
+ }
692
+ );
693
+ &nbsp;
694
+ const ModalWrapper = ({ visible = true, ...props }: ModalProps) =&gt; {
695
+ const modalRef = useRef&lt;ModalHandles&gt;(null);
696
+ const [internalVisible, setInternalVisible] = useState(visible);
697
+ &nbsp;
698
+ useEffect(() =&gt; {
699
+ if (visible) {
700
+ setInternalVisible(true);
701
+ } else {
702
+ // Wait for animation to finish before hiding the modal
703
+ modalRef.current?.hide(() =&gt; setInternalVisible(false));
704
+ }
705
+ }, [visible]);
706
+ &nbsp;
707
+ useEffect(() =&gt; {
708
+ if (internalVisible) {
709
+ modalRef.current?.show();
710
+ }
711
+ }, [internalVisible]);
712
+ &nbsp;
713
+ return internalVisible ? &lt;Modal ref={modalRef} {...props} /&gt; : null;
714
+ };
715
+ &nbsp;
716
+ export default ModalWrapper;
717
+ &nbsp;</pre></td></tr></table></pre>
718
+
719
+ <div class='push'></div><!-- for sticky footer -->
720
+ </div><!-- /wrapper -->
721
+ <div class='footer quiet pad2 space-top1 center small'>
722
+ Code coverage generated by
723
+ <a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
724
+ at 2024-12-16T04:25:53.879Z
725
+ </div>
726
+ <script src="../../../prettify.js"></script>
727
+ <script>
728
+ window.onload = function () {
729
+ prettyPrint();
730
+ };
731
+ </script>
732
+ <script src="../../../sorter.js"></script>
733
+ <script src="../../../block-navigation.js"></script>
734
+ </body>
735
+ </html>
736
+