Security News
cURL Project and Go Security Teams Reject CVSS as Broken
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
@geekie/navigator
Advanced tools
@geekie/navigator
A minimal navigator library for React Native.
We developed this navigator library at Geekie when developing our first React Native app and getting upset by the transitions of the (now deprecated) Navigator library that shipped with React Native. After evaluating some of the options, we decided that none had the APIs and transitions that would suit our needs.
Animated
API with the native driver option)This is a pure-JS library so there's no need to link/
yarn add @geekie/navigator
The navigation with this library is built on the concept of "stacks", which are a stack of screens of the app. You can present a new stack and push screens onto it when dismissing it, the navigation state returns to the last screen pushed to the previous stack. Below there's an image as an example:
The blue arrows are pushing new screens to a stack, the green arrow is presenting a new stack with a screen on it, and the red arrow is dismissing a whole stack and coming to back to the state right before presenting the new stack.
With that clear we can check what the API looks like.
Navigator
The library has a single default export which is the Navigator
component that manages the current rendered screen. It accepts the following props:
screensConfig
: (required) an object like { "ScreenName": ScreenComponent }
. The key will be used to reference the screen in the navigator commands, and the navigator will use the component defined when rendering the screen.initialState
: (required) the initial state of the navigator: an array of arrays of routes. A route is defined as an object with the keys: screen
(the name defined in screensConfig
) and props
(optional), an object that will be passed to the rendered component.screenStyle
: custom style to be applied the View wrapping the rendered screen.resetState
: a function that will be called when the navigator is rendered, with another function that can reset the whole state programatically. See an example below.onWillFocus
: a function that will be called right before a screen is focused.The example below shows how you use those props and an example of how to implement deep linking using the resetState
function.
import Navigator from "@geekie/navigator";
import Home from "./screens/Home";
import Login from "./screens/Login";
import Profile from "./screens/Profile";
import About from "./screens/About";
import { getCurrentUser } from "./user";
const screensConfig = {
Home: Home,
Login: Login,
Profile: Profile,
About: About
};
class App extends React.Component {
componentDidMount() {
// Deep linking support
Linking.addEventListener("url", event => {
if (event.url.endsWith("/about")) {
this.resetState([
[{ screen: "Home" }],
[{ screen: "Profile", props: { user: getCurrentUser() }, {screen: "About"} }]
]);
}
});
}
render() {
return (
<Navigator
screensConfig={screensConfig}
initialState={{ screen: "Home" }}
onWillFocus={route => {
console.log("Navigator will now focus the screen:", route);
}}
resetState={resetState => {
this.resetState = resetState;
}}
/>
);
}
}
The components rendered will receive a navigator
prop that contains the commands to navigate through screens.
NavigatorProvider
This is useful if you're rendering screens wrapped with withNavigator
or that use useNavigator
but doesn't want to render the whole navigator, or would like to pass a mocked navigator prop to check calls.
const test = render(
<NavigatorProvider navigator={mockedNavigator}>
<ScreenComponent />
</NavigatorProvider>
);
withNavigator(Component)
withNavigator
is a higher order component that injects the navigator
prop to the wrapped Component
. This is useful if you need it in a deeply nested component or you can't pass the prop from the screen component.
useNavigator()
This is a React Hook that returns the navigator
provided with NavigatorProvider
. This is a substitute to withNavigator()
.
navigator.present(route)
or navigator.present(routes)
Presents a new stack: if the argument is an array, will use that as the stack; if not an array, it will be equivalent as calling navigator.present([route])
.
The screen will be slide from the bottom.
navigator.dismiss()
Removes the whole current stack and renders the last route of the previous stack.
The screen will slide to the bottom.
navigator.push(route)
Pushes a new route ({screen: "ScreenName", props: { }}
) to the current stack.
The screen will slide from the right.
navigator.pop()
Returns to the previous route of the current stack. If there's a single route in the stack, the stack is dismissed (i.e. the same as calling navigator.dismiss()
).
The screen will slide to the right.
navigator.replace(route)
Replaces the current route but animates as push()
. This is useful if you want to navigate to a new screen, but doesn't want the next screen to navigate "back" to it.
Example: Home
-> push -> Screen A
-> replace -> Screen B
-> pop -> Home
navigator.reset(route)
Resets the current stack to [route]
.
The animation is the same as pop()
.
navigator.pushReset(route)
The same as navigator.reset()
but the animation will be the same as push()
.
The animations were based on the (now deprecated) React Native's Navigator.
FAQs
A minimal navigator library for React & React Native
We found that @geekie/navigator demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
Security News
Biden's executive order pushes for AI-driven cybersecurity, software supply chain transparency, and stronger protections for federal and open source systems.