npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

react-urlstack

v0.3.34

Published

A responsive navigator for react-native based on URLs

Downloads

44

Readme

react-urlstack

A responsive navigator for react-native based on URLs.

Installation

npm install --save react-urlstack

Usage

In your root component

import React from 'react'
import {Navigator} from 'react-urlstack'
import routes from './routes'

export default function App(){
  return <Navigator routes={ routes } />
}

The routes are defined like:

// routes.js
export default [

  // Simple screen
  { path: '/', component: WelcomeScreen },

  { // Nested navigation
    path: '/people',
    componenent: PeopleListScreen,
    children: [
      { path: '/:id', component: PersonDetail }
    ]
  },

  { // Tabs
    path: '/tabs',
    component: TabContainerScreen,
    isTabs: true,
    children: [
      { path: '/tab1', component: Tab1Screen },
		  { path: '/tab2', component: Tab2Screen },
    ]
  },

  // Modal
  { path: '/modal', component: Modal, isModal: true },

  // Default route
  { path: '/*', component: Screen404 }
]

To know more about the route definition see urlstack docs.

Screens As we have seen in the routes, we pass the components that will render the screens for every path.

Those screen components will receive the following props:

  • router: The router will allow to navigate programmatically with router.navigate.
  • drawer: Will allow to open or close the drawer using drawer.open() or drawer.close().
  • layout: The current dimensions of the screen {x, y, width, height}.
  • location: The location object from when the last time the screen was active. With urlstack we can have more than one screen mounted at the same time in order to have nice transitions when the URL changes. So there is the chance that the current URL doesn't have the parameters expected by a mounted screen, that's why the screens receive a location prop that retains the paramaters from when the screen was active. A screen is active when is the one currently shown by the navigator, or it's parent of the one shown.
  • indexes: Contains information of what's the current status of the screen in the stack. indexes.transition is an AnimatedValue that will be animated when the transitions happen, so we can use it internally to animate the content when the screen is leaving/appearing.
  • *breakPoint: The current breakPoint that depends on the transition definition in the <Navigator> component and the current layout.
  • Any other prop passed to Navigator: If we pass any prop to the <Navigator> object, those will be passed down to our screens, so we can inject dependencies from outside.

API

Navigator Top level wrapper that will react to the URL changes showing the proper screen.

import {Navigator} from 'react-urlstack';

//...

<Navigator

  // The route definition seen above
  routes={ routeDefinition }

  // Route interception as seen at https://github.com/arqex/url-navigation/tree/master/packages/urlhub#intercepting-route-changes
  interceptor={ location => location.pathname === '/foo' ? '/bar' : location }

  // If given, there will be a collapsible drawer showing the given component
  DrawerComponent={ SideMenu }

  // Transition functions (see the screen transitions section)
  // We can create breakpoints to define differnt transitions
  // for different horizontal screen resolutions
  // the currentBreakPoint will be passed to the pages and the
  // transitions
  transitions={{
    0: mobileTransition,
    800: desktopTransition
  }}
/>

SharedElement Two different pages can share elements that will remain on the screen when navigating from one to another. We can animate those elements to create beautiful transitions when navigating.

Two screen share an element when they both define a <SharedElement> with the same sharedId, the are called sibling elements.

By default in a transition, the SharedElement will be translated and scaled from its position/size in the origin screen to the position/size in the target screen, but that animation can be customized.

import {SharedElement} from 'react-urlstack'
import {Image} from 'react-native'

// SharedElement need to be rendered in both pages
<SharedElement

  // The elements that will remain on the screen need to have the same
  // `sharedId` (siblings) in both pages. Other `SharedElement`s that don't have
  // a brother with the same `sharedId` in the page that enters will go
  // away with the page that leaves
  sharedId="avatar"

  // The transition uses an AnimatedValue
  // https://facebook.github.io/react-native/docs/animated
  // that is passed to the transition function in order to animate the element
  // The value will go from the `transitionState` prop of the `SharedElement`
  // that leaves to the `transitionState` of the one that enters.
  // We can use those values to create nice interpolations
  transitionState={ 0 }

  // The transition function, it receives an object with
  // {
  //   breakPoint, the current screen width breakpoint
  //   entering {props, box {x,y,width,height} },
  //   leaving {props, box {x,y,width,height} },
  //   defaultTransition, the transition declaration by default
  // }
  // 
  // It needs to return an object with a transition declaration,
  // that contains a style and the attributes to animate in the form
  // of an interpolation declaration
  // see https://github.com/arqex/url-navigation/blob/master/packages/react-urlstack-playground/src/screens/transitionExamples/checks/checkTransition.js
  transition={ niceTransition }

  // Accept some styles
  style={ elementStyles } />
  <Image source={ imageFile } />
</SharedElement>

stagger A helper to build apply the same animation in different elements but starting with some delay between elements.

The staging is not based in time, but in an AnimatedValue, so we can apply the effect to the screen transitions.

import {stagger} from 'react-urlstack';

// It receives an animatedValue
// The value delay
// The number of elements to animate
// the interpolation definition
let buttonStages = stagger( animatedValue, .1, 2, {
  translateY: {
    inputRange: [ -1, -.3, -.1, 0 ],
    outputRange: [ 100, 100, 0, 0 ]
  }
})

// Then the output of the stagger method can be used directly in the styles of
// animated elements

// this animation starts when animatedValue is -.4
// and finishes when is -.1
<Animated.View style={ buttonStages[0] }>
  <Button />
</Animated.View>

// this animation starts when animatedValue is -.3
// and finishes when is 0
<Animated.View style={ buttonStages[1] }>
  <Button />
</Animated.View>