@hero-design/rn 8.12.4 → 8.12.5-alpha.1

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 (255) hide show
  1. package/.turbo/turbo-build.log +9 -9
  2. package/.turbo/turbo-build:types.log +2 -0
  3. package/.turbo/turbo-lint.log +149 -0
  4. package/.turbo/turbo-publish:npm.log +9 -0
  5. package/es/index.js +38 -11
  6. package/lib/index.js +38 -11
  7. package/package.json +5 -5
  8. package/src/components/Tabs/ScrollableTabs.tsx +208 -167
  9. package/src/components/Tabs/__tests__/ScrollableTabs.spec.tsx +58 -11
  10. package/src/types.ts +2 -0
  11. package/types/components/Accordion/AccordionItem.d.ts +0 -0
  12. package/types/components/Accordion/StyledAccordion.d.ts +0 -0
  13. package/types/components/Accordion/index.d.ts +0 -0
  14. package/types/components/Alert/StyledAlert.d.ts +0 -0
  15. package/types/components/Alert/index.d.ts +0 -0
  16. package/types/components/Attachment/StyledAttachment.d.ts +0 -0
  17. package/types/components/Attachment/index.d.ts +0 -0
  18. package/types/components/Avatar/Avatar.d.ts +0 -0
  19. package/types/components/Avatar/AvatarStack/StyledAvatarStack.d.ts +0 -0
  20. package/types/components/Avatar/AvatarStack/index.d.ts +0 -0
  21. package/types/components/Avatar/AvatarStack/utils.d.ts +0 -0
  22. package/types/components/Avatar/StyledAvatar.d.ts +0 -0
  23. package/types/components/Avatar/index.d.ts +0 -0
  24. package/types/components/Badge/Status.d.ts +0 -0
  25. package/types/components/Badge/StyledBadge.d.ts +0 -0
  26. package/types/components/Badge/index.d.ts +0 -0
  27. package/types/components/BottomNavigation/StyledBottomNavigation.d.ts +0 -0
  28. package/types/components/BottomNavigation/index.d.ts +0 -0
  29. package/types/components/BottomSheet/BottomSheetContext.d.ts +0 -0
  30. package/types/components/BottomSheet/Footer.d.ts +0 -0
  31. package/types/components/BottomSheet/Header.d.ts +0 -0
  32. package/types/components/BottomSheet/ScrollView.d.ts +0 -0
  33. package/types/components/BottomSheet/StyledBottomSheet.d.ts +0 -0
  34. package/types/components/BottomSheet/index.d.ts +0 -0
  35. package/types/components/Box/StyledBox.d.ts +0 -0
  36. package/types/components/Box/config.d.ts +0 -0
  37. package/types/components/Box/index.d.ts +0 -0
  38. package/types/components/Box/types.d.ts +0 -0
  39. package/types/components/Button/Button.d.ts +0 -0
  40. package/types/components/Button/IconButton.d.ts +0 -0
  41. package/types/components/Button/LoadingIndicator/StyledLoadingIndicator.d.ts +0 -0
  42. package/types/components/Button/LoadingIndicator/index.d.ts +0 -0
  43. package/types/components/Button/StyledButton.d.ts +0 -0
  44. package/types/components/Button/UtilityButton/StyledUtilityButton.d.ts +0 -0
  45. package/types/components/Button/UtilityButton/index.d.ts +0 -0
  46. package/types/components/Button/index.d.ts +0 -0
  47. package/types/components/Calendar/CalendarRowItem.d.ts +0 -0
  48. package/types/components/Calendar/StyledCalendar.d.ts +0 -0
  49. package/types/components/Calendar/helpers.d.ts +0 -0
  50. package/types/components/Calendar/index.d.ts +0 -0
  51. package/types/components/Card/DataCard/StyledDataCard.d.ts +0 -0
  52. package/types/components/Card/DataCard/index.d.ts +0 -0
  53. package/types/components/Card/StyledCard.d.ts +0 -0
  54. package/types/components/Card/index.d.ts +0 -0
  55. package/types/components/Carousel/CardCarousel.d.ts +0 -0
  56. package/types/components/Carousel/CarouselItem.d.ts +0 -0
  57. package/types/components/Carousel/StyledCardCarousel.d.ts +0 -0
  58. package/types/components/Carousel/StyledCarousel.d.ts +0 -0
  59. package/types/components/Carousel/contants.d.ts +0 -0
  60. package/types/components/Carousel/index.d.ts +0 -0
  61. package/types/components/Carousel/types.d.ts +0 -0
  62. package/types/components/Checkbox/StyledCheckbox.d.ts +0 -0
  63. package/types/components/Checkbox/index.d.ts +0 -0
  64. package/types/components/Collapse/StyledCollapse.d.ts +0 -0
  65. package/types/components/Collapse/index.d.ts +0 -0
  66. package/types/components/ContentNavigator/StyledContentNavigator.d.ts +0 -0
  67. package/types/components/ContentNavigator/index.d.ts +0 -0
  68. package/types/components/DatePicker/DatePickerAndroid.d.ts +0 -0
  69. package/types/components/DatePicker/DatePickerIOS.d.ts +0 -0
  70. package/types/components/DatePicker/StyledDatePicker.d.ts +0 -0
  71. package/types/components/DatePicker/index.d.ts +0 -0
  72. package/types/components/DatePicker/types.d.ts +0 -0
  73. package/types/components/Divider/StyledDivider.d.ts +0 -0
  74. package/types/components/Divider/index.d.ts +0 -0
  75. package/types/components/Drawer/DragableDrawer/helpers.d.ts +0 -0
  76. package/types/components/Drawer/DragableDrawer/index.d.ts +0 -0
  77. package/types/components/Drawer/StyledDrawer.d.ts +0 -0
  78. package/types/components/Drawer/index.d.ts +0 -0
  79. package/types/components/Empty/StyledEmpty.d.ts +0 -0
  80. package/types/components/Empty/index.d.ts +0 -0
  81. package/types/components/FAB/ActionGroup/ActionItem.d.ts +0 -0
  82. package/types/components/FAB/ActionGroup/StyledActionGroup.d.ts +0 -0
  83. package/types/components/FAB/ActionGroup/StyledActionItem.d.ts +0 -0
  84. package/types/components/FAB/ActionGroup/index.d.ts +0 -0
  85. package/types/components/FAB/AnimatedFABIcon.d.ts +0 -0
  86. package/types/components/FAB/FAB.d.ts +0 -0
  87. package/types/components/FAB/StyledFAB.d.ts +0 -0
  88. package/types/components/FAB/index.d.ts +0 -0
  89. package/types/components/Icon/AnimatedIcon.d.ts +0 -0
  90. package/types/components/Icon/HeroIcon/index.d.ts +0 -0
  91. package/types/components/Icon/IconList.d.ts +0 -0
  92. package/types/components/Icon/index.d.ts +0 -0
  93. package/types/components/Icon/utils.d.ts +0 -0
  94. package/types/components/Image/index.d.ts +0 -0
  95. package/types/components/List/BasicListItem.d.ts +0 -0
  96. package/types/components/List/ListItem.d.ts +0 -0
  97. package/types/components/List/StyledBasicListItem.d.ts +0 -0
  98. package/types/components/List/StyledListItem.d.ts +0 -0
  99. package/types/components/List/index.d.ts +0 -0
  100. package/types/components/PageControl/StyledPageControl.d.ts +0 -0
  101. package/types/components/PageControl/index.d.ts +0 -0
  102. package/types/components/PinInput/PinCell.d.ts +0 -0
  103. package/types/components/PinInput/StyledPinInput.d.ts +0 -0
  104. package/types/components/PinInput/index.d.ts +0 -0
  105. package/types/components/Progress/ProgressBar.d.ts +0 -0
  106. package/types/components/Progress/ProgressCircle.d.ts +0 -0
  107. package/types/components/Progress/StyledProgressBar.d.ts +0 -0
  108. package/types/components/Progress/StyledProgressCircle.d.ts +0 -0
  109. package/types/components/Progress/__tests__/index.spec.d.ts +0 -0
  110. package/types/components/Progress/constants.d.ts +0 -0
  111. package/types/components/Progress/index.d.ts +0 -0
  112. package/types/components/Progress/types.d.ts +0 -0
  113. package/types/components/Radio/Radio.d.ts +0 -0
  114. package/types/components/Radio/RadioGroup.d.ts +0 -0
  115. package/types/components/Radio/StyledRadio.d.ts +0 -0
  116. package/types/components/Radio/index.d.ts +0 -0
  117. package/types/components/Radio/types.d.ts +0 -0
  118. package/types/components/RefreshControl/index.d.ts +0 -0
  119. package/types/components/RichTextEditor/EditorEvent.d.ts +0 -0
  120. package/types/components/RichTextEditor/EditorToolbar.d.ts +0 -0
  121. package/types/components/RichTextEditor/MentionList.d.ts +0 -0
  122. package/types/components/RichTextEditor/RichTextEditor.d.ts +0 -0
  123. package/types/components/RichTextEditor/StyledRichTextEditor.d.ts +0 -0
  124. package/types/components/RichTextEditor/StyledToolbar.d.ts +0 -0
  125. package/types/components/RichTextEditor/__mocks__/heroEditorApp.d.ts +0 -0
  126. package/types/components/RichTextEditor/constants.d.ts +0 -0
  127. package/types/components/RichTextEditor/heroEditorApp.d.ts +0 -0
  128. package/types/components/RichTextEditor/index.d.ts +0 -0
  129. package/types/components/RichTextEditor/types.d.ts +0 -0
  130. package/types/components/RichTextEditor/utils/events.d.ts +0 -0
  131. package/types/components/RichTextEditor/utils/rnWebView.d.ts +0 -0
  132. package/types/components/SectionHeading/StyledHeading.d.ts +0 -0
  133. package/types/components/SectionHeading/index.d.ts +0 -0
  134. package/types/components/Select/BaseOptionList.d.ts +0 -0
  135. package/types/components/Select/Footer.d.ts +0 -0
  136. package/types/components/Select/MultiSelect/Option.d.ts +0 -0
  137. package/types/components/Select/MultiSelect/OptionList.d.ts +0 -0
  138. package/types/components/Select/MultiSelect/index.d.ts +0 -0
  139. package/types/components/Select/SingleSelect/Option.d.ts +0 -0
  140. package/types/components/Select/SingleSelect/OptionList.d.ts +0 -0
  141. package/types/components/Select/SingleSelect/StyledSingleSelect.d.ts +0 -0
  142. package/types/components/Select/SingleSelect/index.d.ts +0 -0
  143. package/types/components/Select/StyledSelect.d.ts +0 -0
  144. package/types/components/Select/helpers.d.ts +0 -0
  145. package/types/components/Select/index.d.ts +0 -0
  146. package/types/components/Select/types.d.ts +0 -0
  147. package/types/components/Slider/index.d.ts +0 -0
  148. package/types/components/Spinner/AnimatedSpinner.d.ts +0 -0
  149. package/types/components/Spinner/StyledSpinner.d.ts +0 -0
  150. package/types/components/Spinner/index.d.ts +0 -0
  151. package/types/components/Swipeable/StyledSwipeable.d.ts +0 -0
  152. package/types/components/Swipeable/SwipeableAction.d.ts +0 -0
  153. package/types/components/Swipeable/index.d.ts +0 -0
  154. package/types/components/Switch/SelectorSwitch/Option.d.ts +0 -0
  155. package/types/components/Switch/SelectorSwitch/StyledSelectorSwitch.d.ts +0 -0
  156. package/types/components/Switch/SelectorSwitch/index.d.ts +0 -0
  157. package/types/components/Switch/StyledSwitch.d.ts +0 -0
  158. package/types/components/Switch/index.d.ts +0 -0
  159. package/types/components/Tabs/ActiveTabIndicator.d.ts +0 -0
  160. package/types/components/Tabs/ScrollableTabs.d.ts +8 -1
  161. package/types/components/Tabs/StyledScrollableTabs.d.ts +0 -0
  162. package/types/components/Tabs/StyledTabs.d.ts +0 -0
  163. package/types/components/Tabs/TabWithBadge.d.ts +0 -0
  164. package/types/components/Tabs/index.d.ts +2 -1
  165. package/types/components/Tabs/utils.d.ts +0 -0
  166. package/types/components/Tag/StyledTag.d.ts +0 -0
  167. package/types/components/Tag/index.d.ts +0 -0
  168. package/types/components/TextInput/StyledTextInput.d.ts +0 -0
  169. package/types/components/TextInput/index.d.ts +0 -0
  170. package/types/components/TimePicker/StyledTimePicker.d.ts +0 -0
  171. package/types/components/TimePicker/TimePickerAndroid.d.ts +0 -0
  172. package/types/components/TimePicker/TimePickerIOS.d.ts +0 -0
  173. package/types/components/TimePicker/index.d.ts +0 -0
  174. package/types/components/TimePicker/types.d.ts +0 -0
  175. package/types/components/Toast/StyledToast.d.ts +0 -0
  176. package/types/components/Toast/Toast.d.ts +0 -0
  177. package/types/components/Toast/ToastContainer.d.ts +0 -0
  178. package/types/components/Toast/ToastContext.d.ts +0 -0
  179. package/types/components/Toast/ToastProvider.d.ts +0 -0
  180. package/types/components/Toast/index.d.ts +0 -0
  181. package/types/components/Toast/types.d.ts +0 -0
  182. package/types/components/Toolbar/StyledToolbar.d.ts +0 -0
  183. package/types/components/Toolbar/ToolbarGroup.d.ts +0 -0
  184. package/types/components/Toolbar/ToolbarItem.d.ts +0 -0
  185. package/types/components/Toolbar/index.d.ts +0 -0
  186. package/types/components/Typography/Text/StyledText.d.ts +0 -0
  187. package/types/components/Typography/Text/index.d.ts +0 -0
  188. package/types/components/Typography/index.d.ts +0 -0
  189. package/types/index.d.ts +0 -0
  190. package/types/testHelpers/renderWithTheme.d.ts +0 -0
  191. package/types/theme/ThemeProvider.d.ts +0 -0
  192. package/types/theme/ThemeSwitcher.d.ts +0 -0
  193. package/types/theme/components/accordion.d.ts +0 -0
  194. package/types/theme/components/alert.d.ts +0 -0
  195. package/types/theme/components/attachment.d.ts +0 -0
  196. package/types/theme/components/avatar.d.ts +0 -0
  197. package/types/theme/components/badge.d.ts +0 -0
  198. package/types/theme/components/bottomNavigation.d.ts +0 -0
  199. package/types/theme/components/bottomSheet.d.ts +0 -0
  200. package/types/theme/components/button.d.ts +0 -0
  201. package/types/theme/components/calendar.d.ts +0 -0
  202. package/types/theme/components/card.d.ts +0 -0
  203. package/types/theme/components/cardCarousel.d.ts +0 -0
  204. package/types/theme/components/carousel.d.ts +0 -0
  205. package/types/theme/components/checkbox.d.ts +0 -0
  206. package/types/theme/components/contentNavigator.d.ts +0 -0
  207. package/types/theme/components/datePicker.d.ts +0 -0
  208. package/types/theme/components/divider.d.ts +0 -0
  209. package/types/theme/components/drawer.d.ts +0 -0
  210. package/types/theme/components/empty.d.ts +0 -0
  211. package/types/theme/components/fab.d.ts +0 -0
  212. package/types/theme/components/icon.d.ts +0 -0
  213. package/types/theme/components/image.d.ts +0 -0
  214. package/types/theme/components/list.d.ts +0 -0
  215. package/types/theme/components/pageControl.d.ts +0 -0
  216. package/types/theme/components/pinInput.d.ts +0 -0
  217. package/types/theme/components/progress.d.ts +0 -0
  218. package/types/theme/components/radio.d.ts +0 -0
  219. package/types/theme/components/refreshControl.d.ts +0 -0
  220. package/types/theme/components/richTextEditor.d.ts +0 -0
  221. package/types/theme/components/sectionHeading.d.ts +0 -0
  222. package/types/theme/components/select.d.ts +0 -0
  223. package/types/theme/components/slider.d.ts +0 -0
  224. package/types/theme/components/spinner.d.ts +0 -0
  225. package/types/theme/components/swipeable.d.ts +0 -0
  226. package/types/theme/components/switch.d.ts +0 -0
  227. package/types/theme/components/tabs.d.ts +0 -0
  228. package/types/theme/components/tag.d.ts +0 -0
  229. package/types/theme/components/textInput.d.ts +0 -0
  230. package/types/theme/components/timePicker.d.ts +0 -0
  231. package/types/theme/components/toast.d.ts +0 -0
  232. package/types/theme/components/toolbar.d.ts +0 -0
  233. package/types/theme/components/typography.d.ts +0 -0
  234. package/types/theme/getTheme.d.ts +0 -0
  235. package/types/theme/global/borders.d.ts +0 -0
  236. package/types/theme/global/colors/eBens.d.ts +0 -0
  237. package/types/theme/global/colors/global.d.ts +0 -0
  238. package/types/theme/global/colors/globalDark.d.ts +0 -0
  239. package/types/theme/global/colors/jobs.d.ts +0 -0
  240. package/types/theme/global/colors/swag.d.ts +0 -0
  241. package/types/theme/global/colors/swagDark.d.ts +0 -0
  242. package/types/theme/global/colors/types.d.ts +0 -0
  243. package/types/theme/global/colors/wallet.d.ts +0 -0
  244. package/types/theme/global/colors/work.d.ts +0 -0
  245. package/types/theme/global/index.d.ts +0 -0
  246. package/types/theme/global/scale.d.ts +0 -0
  247. package/types/theme/global/sizes.d.ts +0 -0
  248. package/types/theme/global/space.d.ts +0 -0
  249. package/types/theme/global/typography.d.ts +0 -0
  250. package/types/theme/index.d.ts +0 -0
  251. package/types/types.d.ts +2 -1
  252. package/types/utils/functions.d.ts +0 -0
  253. package/types/utils/helpers.d.ts +0 -0
  254. package/types/utils/hooks.d.ts +0 -0
  255. package/types/utils/scale.d.ts +0 -0
@@ -1,9 +1,9 @@
1
- @hero-design/rn:build: cache hit, replaying output c1ce0a6dbcd003d9
2
- @hero-design/rn:build: $ yarn build:js && yarn build:types
3
- @hero-design/rn:build: $ rollup -c
4
- @hero-design/rn:build: 
5
- @hero-design/rn:build: src/index.ts → lib/index.js, es/index.js...
6
- @hero-design/rn:build: (!) Plugin replace: @rollup/plugin-replace: 'preventAssignment' currently defaults to false. It is recommended to set this option to `true`, as the next major version will default this option to `true`.
7
- @hero-design/rn:build: (!) Plugin node-resolve: preferring built-in module 'events' over local alternative at '/root/hero-design/node_modules/events/events.js', pass 'preferBuiltins: false' to disable this behavior or 'preferBuiltins: true' to disable this warning
8
- @hero-design/rn:build: created lib/index.js, es/index.js in 26.9s
9
- @hero-design/rn:build: $ tsc --noEmit false --emitDeclarationOnly --project tsconfig.prod.json
1
+ @hero-design/rn:build: cache hit, replaying output f482b851404033d4
2
+ @hero-design/rn:build: $ yarn build:js && yarn build:types
3
+ @hero-design/rn:build: $ rollup -c
4
+ @hero-design/rn:build: 
5
+ @hero-design/rn:build: src/index.ts → lib/index.js, es/index.js...
6
+ @hero-design/rn:build: (!) Plugin replace: @rollup/plugin-replace: 'preventAssignment' currently defaults to false. It is recommended to set this option to `true`, as the next major version will default this option to `true`.
7
+ @hero-design/rn:build: (!) Plugin node-resolve: preferring built-in module 'events' over local alternative at '/Volumes/Data/Projects/hero-design/node_modules/events/events.js', pass 'preferBuiltins: false' to disable this behavior or 'preferBuiltins: true' to disable this warning
8
+ @hero-design/rn:build: created lib/index.js, es/index.js in 30s
9
+ @hero-design/rn:build: $ tsc --noEmit false --emitDeclarationOnly --project tsconfig.prod.json
@@ -0,0 +1,2 @@
1
+ @hero-design/rn:build:types: cache hit, replaying output 469c355cf5f8f229
2
+ @hero-design/rn:build:types: $ tsc --noEmit false --emitDeclarationOnly --project tsconfig.prod.json
@@ -0,0 +1,149 @@
1
+ @hero-design/rn:lint: cache hit, replaying output 6363842493954154
2
+ @hero-design/rn:lint: $ eslint src --ext .js,.jsx,.ts,.tsx --ignore-path ../../.gitignore
3
+ @hero-design/rn:lint: 
4
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/BottomSheet/ScrollView.tsx
5
+ @hero-design/rn:lint:  25:5 warning React Hook useCallback has missing dependencies: 'props' and 'setInternalShowDivider'. Either include them or remove the dependency array. However, 'props' will change when *any* prop changes, so the preferred fix is to destructure the 'props' object outside of the useCallback call and refer to those specific props inside useCallback react-hooks/exhaustive-deps
6
+ @hero-design/rn:lint:  34:5 warning React Hook useCallback has missing dependencies: 'props' and 'setInternalShowDivider'. Either include them or remove the dependency array. However, 'props' will change when *any* prop changes, so the preferred fix is to destructure the 'props' object outside of the useCallback call and refer to those specific props inside useCallback react-hooks/exhaustive-deps
7
+ @hero-design/rn:lint:  43:5 warning React Hook useCallback has missing dependencies: 'props' and 'setInternalShowDivider'. Either include them or remove the dependency array. However, 'props' will change when *any* prop changes, so the preferred fix is to destructure the 'props' object outside of the useCallback call and refer to those specific props inside useCallback react-hooks/exhaustive-deps
8
+ @hero-design/rn:lint: 
9
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/BottomSheet/index.tsx
10
+ @hero-design/rn:lint:  123:32 warning The ref value 'animatedValue.current' will likely have changed by the time this effect cleanup function runs. If this ref points to a node rendered by React, copy 'animatedValue.current' to a variable inside the effect, and use that variable in the cleanup function react-hooks/exhaustive-deps
11
+ @hero-design/rn:lint:  124:6 warning React Hook useEffect has missing dependencies: 'onDismiss' and 'visible'. Either include them or remove the dependency array. If 'onDismiss' changes too often, find the parent component that defines it and wrap that definition in useCallback react-hooks/exhaustive-deps
12
+ @hero-design/rn:lint:  137:6 warning React Hook useEffect has a missing dependency: 'onAnimationEnd'. Either include it or remove the dependency array react-hooks/exhaustive-deps
13
+ @hero-design/rn:lint: 
14
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/Button/LoadingIndicator/index.tsx
15
+ @hero-design/rn:lint:  118:36 warning Unexpected any. Specify a different type @typescript-eslint/no-explicit-any
16
+ @hero-design/rn:lint: 
17
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/Carousel/CardCarousel.tsx
18
+ @hero-design/rn:lint:  105:7 warning React Hook useCallback has a missing dependency: 'items.length'. Either include it or remove the dependency array react-hooks/exhaustive-deps
19
+ @hero-design/rn:lint:  121:8 warning React Hook useCallback has an unnecessary dependency: 'itemWidth'. Either exclude it or remove the dependency array react-hooks/exhaustive-deps
20
+ @hero-design/rn:lint: 
21
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/Carousel/__tests__/CardCarousel.spec.tsx
22
+ @hero-design/rn:lint:  47:27 warning Forbidden non-null assertion @typescript-eslint/no-non-null-assertion
23
+ @hero-design/rn:lint:  47:27 warning Forbidden non-null assertion @typescript-eslint/no-non-null-assertion
24
+ @hero-design/rn:lint:  93:27 warning Forbidden non-null assertion @typescript-eslint/no-non-null-assertion
25
+ @hero-design/rn:lint:  93:27 warning Forbidden non-null assertion @typescript-eslint/no-non-null-assertion
26
+ @hero-design/rn:lint: 
27
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/Carousel/index.tsx
28
+ @hero-design/rn:lint:  108:6 warning React Hook useEffect has missing dependencies: 'scrollX' and 'width'. Either include them or remove the dependency array react-hooks/exhaustive-deps
29
+ @hero-design/rn:lint:  114:6 warning React Hook useCallback has a missing dependency: 'internalOnItemIndexChange'. Either include it or remove the dependency array react-hooks/exhaustive-deps
30
+ @hero-design/rn:lint: 
31
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/Collapse/index.tsx
32
+ @hero-design/rn:lint:  48:6 warning React Hook useEffect has a missing dependency: 'collapseAnim'. Either include it or remove the dependency array react-hooks/exhaustive-deps
33
+ @hero-design/rn:lint: 
34
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/DatePicker/DatePickerAndroid.tsx
35
+ @hero-design/rn:lint:  53:25 warning Unexpected any. Specify a different type @typescript-eslint/no-explicit-any
36
+ @hero-design/rn:lint: 
37
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/DatePicker/DatePickerIOS.tsx
38
+ @hero-design/rn:lint:  75:27 warning Unexpected any. Specify a different type @typescript-eslint/no-explicit-any
39
+ @hero-design/rn:lint: 
40
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/Drawer/DragableDrawer/index.tsx
41
+ @hero-design/rn:lint:  78:6 warning React Hook useEffect has a missing dependency: 'pan'. Either include it or remove the dependency array react-hooks/exhaustive-deps
42
+ @hero-design/rn:lint:  88:6 warning React Hook useEffect has missing dependencies: 'initialHeightPercentage' and 'minimumHeightPercentage'. Either include them or remove the dependency array react-hooks/exhaustive-deps
43
+ @hero-design/rn:lint:  104:6 warning React Hook useEffect has missing dependencies: 'pan' and 'snapPoints'. Either include them or remove the dependency array react-hooks/exhaustive-deps
44
+ @hero-design/rn:lint:  127:6 warning React Hook useEffect has missing dependencies: 'height', 'minimumHeightPercentage', 'onCollapsed', 'onExpanded', and 'pan'. Either include them or remove the dependency array. If 'onExpanded' changes too often, find the parent component that defines it and wrap that definition in useCallback react-hooks/exhaustive-deps
45
+ @hero-design/rn:lint: 
46
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/Drawer/index.tsx
47
+ @hero-design/rn:lint:  69:6 warning React Hook useEffect has a missing dependency: 'animatedValue'. Either include it or remove the dependency array react-hooks/exhaustive-deps
48
+ @hero-design/rn:lint: 
49
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/Icon/utils.ts
50
+ @hero-design/rn:lint:  3:24 warning Unexpected any. Specify a different type @typescript-eslint/no-explicit-any
51
+ @hero-design/rn:lint: 
52
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/PageControl/index.tsx
53
+ @hero-design/rn:lint:  40:6 warning React Hook React.useEffect has a missing dependency: 'animatedValue'. Either include it or remove the dependency array react-hooks/exhaustive-deps
54
+ @hero-design/rn:lint: 
55
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/PinInput/index.tsx
56
+ @hero-design/rn:lint:  114:6 warning React Hook useCallback has missing dependencies: 'length', 'onChangeText', and 'onFulfill'. Either include them or remove the dependency array. If 'onChangeText' changes too often, find the parent component that defines it and wrap that definition in useCallback react-hooks/exhaustive-deps
57
+ @hero-design/rn:lint:  121:6 warning React Hook useEffect has missing dependencies: 'autoFocus' and 'focus'. Either include them or remove the dependency array react-hooks/exhaustive-deps
58
+ @hero-design/rn:lint: 
59
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/RichTextEditor/EditorToolbar.tsx
60
+ @hero-design/rn:lint:  147:6 warning React Hook useEffect has a missing dependency: 'normalizeEventName'. Either include it or remove the dependency array react-hooks/exhaustive-deps
61
+ @hero-design/rn:lint:  208:5 warning React Hook useMemo has missing dependencies: 'normalizeEventName' and 'toggleToolbarButton'. Either include them or remove the dependency array react-hooks/exhaustive-deps
62
+ @hero-design/rn:lint: 
63
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/RichTextEditor/MentionList.tsx
64
+ @hero-design/rn:lint:  63:6 warning React Hook useEffect has a missing dependency: 'normalizeEventName'. Either include it or remove the dependency array react-hooks/exhaustive-deps
65
+ @hero-design/rn:lint: 
66
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/RichTextEditor/RichTextEditor.tsx
67
+ @hero-design/rn:lint:  50:13 warning Unexpected any. Specify a different type @typescript-eslint/no-explicit-any
68
+ @hero-design/rn:lint:  145:6 warning React Hook useMemo has an unnecessary dependency: 'isFocused'. Either exclude it or remove the dependency array react-hooks/exhaustive-deps
69
+ @hero-design/rn:lint:  171:6 warning React Hook useEffect has a missing dependency: 'normalizeEventName'. Either include it or remove the dependency array react-hooks/exhaustive-deps
70
+ @hero-design/rn:lint:  207:6 warning React Hook useMemo has missing dependencies: 'autoFocus', 'placeholder', 'theme.__hd__.richTextEditor.colors.text', 'theme.__hd__.richTextEditor.fontSizes.editor', and 'value'. Either include them or remove the dependency array react-hooks/exhaustive-deps
71
+ @hero-design/rn:lint:  244:6 warning React Hook useEffect has a missing dependency: 'normalizeEventName'. Either include it or remove the dependency array react-hooks/exhaustive-deps
72
+ @hero-design/rn:lint:  246:61 warning Unexpected any. Specify a different type @typescript-eslint/no-explicit-any
73
+ @hero-design/rn:lint:  306:5 warning React Hook useCallback has missing dependencies: 'handleEditorLayoutEvent', 'normalizeEventName', 'onChange', and 'onCursorChange'. Either include them or remove the dependency array. If 'onCursorChange' changes too often, find the parent component that defines it and wrap that definition in useCallback react-hooks/exhaustive-deps
74
+ @hero-design/rn:lint: 
75
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/RichTextEditor/__tests__/MentionList.spec.tsx
76
+ @hero-design/rn:lint:  93:20 warning Unexpected any. Specify a different type @typescript-eslint/no-explicit-any
77
+ @hero-design/rn:lint: 
78
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/RichTextEditor/hero-editor.d.ts
79
+ @hero-design/rn:lint:  7:43 warning Unexpected any. Specify a different type @typescript-eslint/no-explicit-any
80
+ @hero-design/rn:lint: 
81
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/RichTextEditor/utils/rnWebView.ts
82
+ @hero-design/rn:lint:  11:9 warning Unexpected any. Specify a different type @typescript-eslint/no-explicit-any
83
+ @hero-design/rn:lint: 
84
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/Select/MultiSelect/index.tsx
85
+ @hero-design/rn:lint:  86:6 warning React Hook useEffect has a missing dependency: 'value'. Either include it or remove the dependency array. If 'setSelectingValue' needs the current value of 'value', you can also switch to useReducer instead of useState and read 'value' in the reducer react-hooks/exhaustive-deps
86
+ @hero-design/rn:lint: 
87
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/Switch/index.tsx
88
+ @hero-design/rn:lint:  70:6 warning React Hook useEffect has missing dependencies: 'animatedOffset' and 'offset'. Either include them or remove the dependency array react-hooks/exhaustive-deps
89
+ @hero-design/rn:lint: 
90
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/Tabs/ScrollableTabs.tsx
91
+ @hero-design/rn:lint:  117:7 warning React Hook React.useImperativeHandle has a missing dependency: 'onTabPress'. Either include it or remove the dependency array. If 'onTabPress' changes too often, find the parent component that defines it and wrap that definition in useCallback react-hooks/exhaustive-deps
92
+ @hero-design/rn:lint:  152:8 warning React Hook React.useEffect has missing dependencies: 'tabs' and 'tabsAnims'. Either include them or remove the dependency array react-hooks/exhaustive-deps
93
+ @hero-design/rn:lint: 
94
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/Tabs/__tests__/ScrollableTabs.spec.tsx
95
+ @hero-design/rn:lint:  140:27 warning Forbidden non-null assertion @typescript-eslint/no-non-null-assertion
96
+ @hero-design/rn:lint:  140:27 warning Forbidden non-null assertion @typescript-eslint/no-non-null-assertion
97
+ @hero-design/rn:lint:  141:28 warning Forbidden non-null assertion @typescript-eslint/no-non-null-assertion
98
+ @hero-design/rn:lint:  141:28 warning Forbidden non-null assertion @typescript-eslint/no-non-null-assertion
99
+ @hero-design/rn:lint: 
100
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/TextInput/StyledTextInput.tsx
101
+ @hero-design/rn:lint:  33:62 warning Unexpected any. Specify a different type @typescript-eslint/no-explicit-any
102
+ @hero-design/rn:lint: 
103
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/TextInput/__tests__/index.spec.tsx
104
+ @hero-design/rn:lint:  436:34 warning Forbidden non-null assertion @typescript-eslint/no-non-null-assertion
105
+ @hero-design/rn:lint: 
106
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/TimePicker/TimePickerAndroid.tsx
107
+ @hero-design/rn:lint:  51:25 warning Unexpected any. Specify a different type @typescript-eslint/no-explicit-any
108
+ @hero-design/rn:lint: 
109
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/TimePicker/TimePickerIOS.tsx
110
+ @hero-design/rn:lint:  76:27 warning Unexpected any. Specify a different type @typescript-eslint/no-explicit-any
111
+ @hero-design/rn:lint: 
112
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/Toast/Toast.tsx
113
+ @hero-design/rn:lint:  69:6 warning React Hook useEffect has missing dependencies: 'autoDismiss', 'duration', and 'onDismiss'. Either include them or remove the dependency array. If 'onDismiss' changes too often, find the parent component that defines it and wrap that definition in useCallback react-hooks/exhaustive-deps
114
+ @hero-design/rn:lint:  80:6 warning React Hook useEffect has a missing dependency: 'animatedValue'. Either include it or remove the dependency array react-hooks/exhaustive-deps
115
+ @hero-design/rn:lint: 
116
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/components/Toast/__tests__/index.spec.tsx
117
+ @hero-design/rn:lint:  19:10 warning React Hook useEffect has a missing dependency: 'toast'. Either include it or remove the dependency array react-hooks/exhaustive-deps
118
+ @hero-design/rn:lint:  82:10 warning React Hook useEffect has a missing dependency: 'toast'. Either include it or remove the dependency array react-hooks/exhaustive-deps
119
+ @hero-design/rn:lint: 
120
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/theme/components/progress.ts
121
+ @hero-design/rn:lint:  1:10 warning Importing "mixColor" from "@hero-design/colors" is not recommended. Please use colors from useTheme hook instead @hero-design/not-recommended-import
122
+ @hero-design/rn:lint: 
123
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/theme/global/colors/eBens.ts
124
+ @hero-design/rn:lint:  1:10 warning Importing "eBensPalette" from "@hero-design/colors" is not recommended. Please use colors from useTheme hook instead @hero-design/not-recommended-import
125
+ @hero-design/rn:lint: 
126
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/theme/global/colors/global.ts
127
+ @hero-design/rn:lint:  1:10 warning Importing "defaultMobilePalette" from "@hero-design/colors" is not recommended. Please use colors from useTheme hook instead @hero-design/not-recommended-import
128
+ @hero-design/rn:lint: 
129
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/theme/global/colors/jobs.ts
130
+ @hero-design/rn:lint:  1:10 warning Importing "jobsPalette" from "@hero-design/colors" is not recommended. Please use colors from useTheme hook instead @hero-design/not-recommended-import
131
+ @hero-design/rn:lint: 
132
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/theme/global/colors/swag.ts
133
+ @hero-design/rn:lint:  1:10 warning Importing "swagPalette" from "@hero-design/colors" is not recommended. Please use colors from useTheme hook instead @hero-design/not-recommended-import
134
+ @hero-design/rn:lint: 
135
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/theme/global/colors/wallet.ts
136
+ @hero-design/rn:lint:  1:10 warning Importing "walletPalette" from "@hero-design/colors" is not recommended. Please use colors from useTheme hook instead @hero-design/not-recommended-import
137
+ @hero-design/rn:lint: 
138
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/theme/global/colors/work.ts
139
+ @hero-design/rn:lint:  1:10 warning Importing "workPalette" from "@hero-design/colors" is not recommended. Please use colors from useTheme hook instead @hero-design/not-recommended-import
140
+ @hero-design/rn:lint: 
141
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/utils/__tests__/helpers.spec.ts
142
+ @hero-design/rn:lint:  15:18 warning Unexpected any. Specify a different type @typescript-eslint/no-explicit-any
143
+ @hero-design/rn:lint:  37:18 warning Unexpected any. Specify a different type @typescript-eslint/no-explicit-any
144
+ @hero-design/rn:lint: 
145
+ @hero-design/rn:lint: /Volumes/Data/Projects/hero-design/packages/rn/src/utils/hooks.ts
146
+ @hero-design/rn:lint:  26:7 warning Unexpected console statement no-console
147
+ @hero-design/rn:lint: 
148
+ @hero-design/rn:lint: ✖ 66 problems (0 errors, 66 warnings)
149
+ @hero-design/rn:lint: 
@@ -0,0 +1,9 @@
1
+ @hero-design/rn:publish:npm: cache hit, replaying output 507c34f3e0a508f6
2
+ @hero-design/rn:publish:npm: $ yarn publish --access public
3
+ @hero-design/rn:publish:npm: [1/4] Bumping version...
4
+ @hero-design/rn:publish:npm: info Current version: 8.12.0-rc.0
5
+ @hero-design/rn:publish:npm: [2/4] Logging in...
6
+ @hero-design/rn:publish:npm: [3/4] Publishing...
7
+ @hero-design/rn:publish:npm: success Published.
8
+ @hero-design/rn:publish:npm: [4/4] Revoking token...
9
+ @hero-design/rn:publish:npm: info Not revoking login token, specified via config file.
package/es/index.js CHANGED
@@ -14528,8 +14528,9 @@ var getTabItem$1 = function getTabItem(_ref) {
14528
14528
  color: color
14529
14529
  });
14530
14530
  };
14531
- var ScrollableTab = function ScrollableTab(_ref2) {
14532
- var onTabPress = _ref2.onTabPress,
14531
+ var ScrollableTab = /*#__PURE__*/forwardRef(function (_ref2, ref) {
14532
+ var _ref2$onTabPress = _ref2.onTabPress,
14533
+ onTabPress = _ref2$onTabPress === void 0 ? noop : _ref2$onTabPress,
14533
14534
  selectedTabKey = _ref2.selectedTabKey,
14534
14535
  tabs = _ref2.tabs,
14535
14536
  containerStyle = _ref2.containerStyle,
@@ -14551,20 +14552,46 @@ var ScrollableTab = function ScrollableTab(_ref2) {
14551
14552
  var tabsAnims = useAnimatedValueArray(tabs.map(function (_, i) {
14552
14553
  return i === selectedTabIndex ? 1 : 0;
14553
14554
  }));
14555
+ React.useImperativeHandle(ref, function () {
14556
+ return {
14557
+ selectTabKey: function selectTabKey(tabKey) {
14558
+ var index = tabs.findIndex(function (item) {
14559
+ return item.key === tabKey;
14560
+ });
14561
+ if (index !== -1) {
14562
+ var _flatListRef$current, _pagerViewRef$current;
14563
+ (_flatListRef$current = flatListRef.current) === null || _flatListRef$current === void 0 ? void 0 : _flatListRef$current.scrollToIndex({
14564
+ index: index,
14565
+ viewPosition: 0.5
14566
+ });
14567
+ (_pagerViewRef$current = pagerViewRef.current) === null || _pagerViewRef$current === void 0 ? void 0 : _pagerViewRef$current.setPage(index);
14568
+ if (onTabPress) {
14569
+ onTabPress(tabKey);
14570
+ }
14571
+ }
14572
+ },
14573
+ getFlatListRef: function getFlatListRef() {
14574
+ return flatListRef.current;
14575
+ },
14576
+ getPagerViewRef: function getPagerViewRef() {
14577
+ return pagerViewRef.current;
14578
+ }
14579
+ };
14580
+ }, [pagerViewRef, flatListRef, tabs]);
14554
14581
  React.useEffect(function () {
14555
14582
  var timeoutHandle = null;
14556
14583
  if (selectedTabIndex !== -1) {
14557
- var _flatListRef$current;
14558
- (_flatListRef$current = flatListRef.current) === null || _flatListRef$current === void 0 ? void 0 : _flatListRef$current.scrollToIndex({
14584
+ var _flatListRef$current2;
14585
+ (_flatListRef$current2 = flatListRef.current) === null || _flatListRef$current2 === void 0 ? void 0 : _flatListRef$current2.scrollToIndex({
14559
14586
  index: selectedTabIndex,
14560
14587
  viewPosition: 0.5
14561
14588
  });
14562
14589
  // If the selected tab is changed too quickly, the setPage is crashed and not work anymore
14563
14590
  // We apply throttle to prevent this issue https://github.com/Thinkei/hero-design/issues/1715
14564
14591
  timeoutHandle = setTimeout(function () {
14565
- var _pagerViewRef$current;
14592
+ var _pagerViewRef$current2;
14566
14593
  // use no animation to prevent unexpected behavior if users select tab too quickly
14567
- (_pagerViewRef$current = pagerViewRef.current) === null || _pagerViewRef$current === void 0 ? void 0 : _pagerViewRef$current.setPageWithoutAnimation(selectedTabIndex);
14594
+ (_pagerViewRef$current2 = pagerViewRef.current) === null || _pagerViewRef$current2 === void 0 ? void 0 : _pagerViewRef$current2.setPageWithoutAnimation(selectedTabIndex);
14568
14595
  }, 200);
14569
14596
  }
14570
14597
  var animation = Animated.parallel(_toConsumableArray(tabs.map(function (_, i) {
@@ -14581,7 +14608,7 @@ var ScrollableTab = function ScrollableTab(_ref2) {
14581
14608
  clearTimeout(timeoutHandle);
14582
14609
  }
14583
14610
  };
14584
- }, [selectedTabIndex, pagerViewRef]);
14611
+ }, [selectedTabIndex, selectedTabKey, pagerViewRef]);
14585
14612
  return /*#__PURE__*/React.createElement(TabContainer, {
14586
14613
  style: containerStyle,
14587
14614
  testID: componentTestID
@@ -14600,8 +14627,8 @@ var ScrollableTab = function ScrollableTab(_ref2) {
14600
14627
  onScrollToIndexFailed: function onScrollToIndexFailed(_ref3) {
14601
14628
  var index = _ref3.index;
14602
14629
  setTimeout(function () {
14603
- var _flatListRef$current2;
14604
- return (_flatListRef$current2 = flatListRef.current) === null || _flatListRef$current2 === void 0 ? void 0 : _flatListRef$current2.scrollToIndex({
14630
+ var _flatListRef$current3;
14631
+ return (_flatListRef$current3 = flatListRef.current) === null || _flatListRef$current3 === void 0 ? void 0 : _flatListRef$current3.scrollToIndex({
14605
14632
  index: index,
14606
14633
  viewPosition: 0.5
14607
14634
  });
@@ -14657,7 +14684,7 @@ var ScrollableTab = function ScrollableTab(_ref2) {
14657
14684
  onPageSelected: function onPageSelected(e) {
14658
14685
  var index = e.nativeEvent.position;
14659
14686
  var selectedItem = tabs[index];
14660
- if (selectedItem) {
14687
+ if (selectedItem && selectedItem.key !== selectedTabKey) {
14661
14688
  onTabPress(selectedItem.key);
14662
14689
  }
14663
14690
  },
@@ -14677,7 +14704,7 @@ var ScrollableTab = function ScrollableTab(_ref2) {
14677
14704
  collapsable: false
14678
14705
  }, isLazyScreen ? null : component);
14679
14706
  })));
14680
- };
14707
+ });
14681
14708
 
14682
14709
  var getTabItem = function getTabItem(_ref) {
14683
14710
  var item = _ref.item,
package/lib/index.js CHANGED
@@ -14557,8 +14557,9 @@ var getTabItem$1 = function getTabItem(_ref) {
14557
14557
  color: color
14558
14558
  });
14559
14559
  };
14560
- var ScrollableTab = function ScrollableTab(_ref2) {
14561
- var onTabPress = _ref2.onTabPress,
14560
+ var ScrollableTab = /*#__PURE__*/React.forwardRef(function (_ref2, ref) {
14561
+ var _ref2$onTabPress = _ref2.onTabPress,
14562
+ onTabPress = _ref2$onTabPress === void 0 ? noop : _ref2$onTabPress,
14562
14563
  selectedTabKey = _ref2.selectedTabKey,
14563
14564
  tabs = _ref2.tabs,
14564
14565
  containerStyle = _ref2.containerStyle,
@@ -14580,20 +14581,46 @@ var ScrollableTab = function ScrollableTab(_ref2) {
14580
14581
  var tabsAnims = useAnimatedValueArray(tabs.map(function (_, i) {
14581
14582
  return i === selectedTabIndex ? 1 : 0;
14582
14583
  }));
14584
+ React__default["default"].useImperativeHandle(ref, function () {
14585
+ return {
14586
+ selectTabKey: function selectTabKey(tabKey) {
14587
+ var index = tabs.findIndex(function (item) {
14588
+ return item.key === tabKey;
14589
+ });
14590
+ if (index !== -1) {
14591
+ var _flatListRef$current, _pagerViewRef$current;
14592
+ (_flatListRef$current = flatListRef.current) === null || _flatListRef$current === void 0 ? void 0 : _flatListRef$current.scrollToIndex({
14593
+ index: index,
14594
+ viewPosition: 0.5
14595
+ });
14596
+ (_pagerViewRef$current = pagerViewRef.current) === null || _pagerViewRef$current === void 0 ? void 0 : _pagerViewRef$current.setPage(index);
14597
+ if (onTabPress) {
14598
+ onTabPress(tabKey);
14599
+ }
14600
+ }
14601
+ },
14602
+ getFlatListRef: function getFlatListRef() {
14603
+ return flatListRef.current;
14604
+ },
14605
+ getPagerViewRef: function getPagerViewRef() {
14606
+ return pagerViewRef.current;
14607
+ }
14608
+ };
14609
+ }, [pagerViewRef, flatListRef, tabs]);
14583
14610
  React__default["default"].useEffect(function () {
14584
14611
  var timeoutHandle = null;
14585
14612
  if (selectedTabIndex !== -1) {
14586
- var _flatListRef$current;
14587
- (_flatListRef$current = flatListRef.current) === null || _flatListRef$current === void 0 ? void 0 : _flatListRef$current.scrollToIndex({
14613
+ var _flatListRef$current2;
14614
+ (_flatListRef$current2 = flatListRef.current) === null || _flatListRef$current2 === void 0 ? void 0 : _flatListRef$current2.scrollToIndex({
14588
14615
  index: selectedTabIndex,
14589
14616
  viewPosition: 0.5
14590
14617
  });
14591
14618
  // If the selected tab is changed too quickly, the setPage is crashed and not work anymore
14592
14619
  // We apply throttle to prevent this issue https://github.com/Thinkei/hero-design/issues/1715
14593
14620
  timeoutHandle = setTimeout(function () {
14594
- var _pagerViewRef$current;
14621
+ var _pagerViewRef$current2;
14595
14622
  // use no animation to prevent unexpected behavior if users select tab too quickly
14596
- (_pagerViewRef$current = pagerViewRef.current) === null || _pagerViewRef$current === void 0 ? void 0 : _pagerViewRef$current.setPageWithoutAnimation(selectedTabIndex);
14623
+ (_pagerViewRef$current2 = pagerViewRef.current) === null || _pagerViewRef$current2 === void 0 ? void 0 : _pagerViewRef$current2.setPageWithoutAnimation(selectedTabIndex);
14597
14624
  }, 200);
14598
14625
  }
14599
14626
  var animation = reactNative.Animated.parallel(_toConsumableArray(tabs.map(function (_, i) {
@@ -14610,7 +14637,7 @@ var ScrollableTab = function ScrollableTab(_ref2) {
14610
14637
  clearTimeout(timeoutHandle);
14611
14638
  }
14612
14639
  };
14613
- }, [selectedTabIndex, pagerViewRef]);
14640
+ }, [selectedTabIndex, selectedTabKey, pagerViewRef]);
14614
14641
  return /*#__PURE__*/React__default["default"].createElement(TabContainer, {
14615
14642
  style: containerStyle,
14616
14643
  testID: componentTestID
@@ -14629,8 +14656,8 @@ var ScrollableTab = function ScrollableTab(_ref2) {
14629
14656
  onScrollToIndexFailed: function onScrollToIndexFailed(_ref3) {
14630
14657
  var index = _ref3.index;
14631
14658
  setTimeout(function () {
14632
- var _flatListRef$current2;
14633
- return (_flatListRef$current2 = flatListRef.current) === null || _flatListRef$current2 === void 0 ? void 0 : _flatListRef$current2.scrollToIndex({
14659
+ var _flatListRef$current3;
14660
+ return (_flatListRef$current3 = flatListRef.current) === null || _flatListRef$current3 === void 0 ? void 0 : _flatListRef$current3.scrollToIndex({
14634
14661
  index: index,
14635
14662
  viewPosition: 0.5
14636
14663
  });
@@ -14686,7 +14713,7 @@ var ScrollableTab = function ScrollableTab(_ref2) {
14686
14713
  onPageSelected: function onPageSelected(e) {
14687
14714
  var index = e.nativeEvent.position;
14688
14715
  var selectedItem = tabs[index];
14689
- if (selectedItem) {
14716
+ if (selectedItem && selectedItem.key !== selectedTabKey) {
14690
14717
  onTabPress(selectedItem.key);
14691
14718
  }
14692
14719
  },
@@ -14706,7 +14733,7 @@ var ScrollableTab = function ScrollableTab(_ref2) {
14706
14733
  collapsable: false
14707
14734
  }, isLazyScreen ? null : component);
14708
14735
  })));
14709
- };
14736
+ });
14710
14737
 
14711
14738
  var getTabItem = function getTabItem(_ref) {
14712
14739
  var item = _ref.item,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@hero-design/rn",
3
- "version": "8.12.4",
3
+ "version": "8.12.5-alpha.1",
4
4
  "license": "MIT",
5
5
  "main": "lib/index.js",
6
6
  "module": "es/index.js",
@@ -21,7 +21,7 @@
21
21
  "dependencies": {
22
22
  "@emotion/native": "^11.9.3",
23
23
  "@emotion/react": "^11.9.3",
24
- "@hero-design/colors": "8.12.4",
24
+ "@hero-design/colors": "8.12.5",
25
25
  "date-fns": "^2.16.1",
26
26
  "events": "^3.2.0",
27
27
  "hero-editor": "^1.9.21"
@@ -44,7 +44,7 @@
44
44
  "@babel/preset-typescript": "^7.17.12",
45
45
  "@babel/runtime": "^7.18.9",
46
46
  "@emotion/jest": "^11.9.3",
47
- "@hero-design/eslint-plugin": "8.12.4",
47
+ "@hero-design/eslint-plugin": "8.12.5",
48
48
  "@react-native-community/datetimepicker": "^3.5.2",
49
49
  "@react-native-community/slider": "4.1.12",
50
50
  "@rollup/plugin-babel": "^5.3.1",
@@ -60,9 +60,9 @@
60
60
  "@types/react-native": "^0.67.7",
61
61
  "@types/react-native-vector-icons": "^6.4.10",
62
62
  "babel-plugin-inline-import": "^3.0.0",
63
- "eslint-config-hd": "8.12.4",
63
+ "eslint-config-hd": "8.12.5",
64
64
  "jest": "^27.3.1",
65
- "prettier-config-hd": "8.12.4",
65
+ "prettier-config-hd": "8.12.5",
66
66
  "react": "18.0.0",
67
67
  "react-native": "0.69.7",
68
68
  "react-native-gesture-handler": "~2.1.0",