Releases: vonovak/react-navigation-header-buttons
v6.0.0
New features
- ensure that on android, all touchables have the same ripple size (no matter if you have a small icon or large text label in it) which is closer to native behavior
Breaking
- touchables update (removed an old touchables impl)
- requires RN 63 / expo 39
v5.0.2
v5.0.0
v4.0.3
v4.0.2
v4.0.1
v4.0.0
Welcome to v4!
This is, from a fair part, a rewrite. The basic usage remains the same, so migration should not be too hard. If you're using Flow or Typescript, that will make it even easier - both typings should be solid!
Improvements
✅Greater component reuse across screens:
Previously, if you used eg. <HiddenItem title="search" iconName="ios-search" onPress={() => alert('search')} />
in one screen, you couldn't really use it in another one. Now you can - just create a component that wraps it, eg. like this:
const ReusableHiddenItem = ({ onPress }) => <HiddenItem title="hidden2" onPress={onPress} />;
✅New overflow menu handler: Material dropdown menu
This is material dropdown menu adapted from react-native-paper, credit for amazing job goes to them. This Menu is bundled in this library (no dependency on react-native-paper).
To use it, pass overflowMenuPressHandlerDropdownMenu
as onPress
to OverflowMenu
(this is the default for Android and Web)
✅Cleaner api:
- new
OverflowMenu
component - some props have been moved to
OverflowMenu
✅Experimental web support
- for overflow menu, you need to use the Material Menu (pass
overflowMenuPressHandlerDropdownMenu
asonPress
toOverflowMenu
)
✅CI improvements
- Flow, Jest tests and ESLint run in CI. I'd like to check TS validity too (by checking the example project) - please open a PR if you're using TS.
Breaking Changes
Because so much has changed, this may not be complete list. Let me know if I forgot something.
❌ changed
show
prop is removed -> useItem
orHiddenItem
componentoverflowButtonWrapperStyle
-> passstyle
toOverflowMenu
onOverflowMenuPress
-> passonPress
toOverflowMenu
overflowButtonTestID
-> passtestID
toOverflowMenu
buttonWrapperStyle
-> renamed tostyle
- if you want an
Item
orHiddenItem
to be disabled, passdisabled={true}
prop
Known Issues
see https://github.com/vonovak/react-navigation-header-buttons#known-issues
v3.0.5
fixes #61 (ripple not being shown), but may have the side effect of ripple being extended to beyond the border of the bounding view. Please double-check if this is what you want.
A better way to do this was proposed in react-native core: facebook/react-native#28009