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

@airship/rn-components

v0.2.4

Published

React Native components, from basic inputs to animated wrappers, created by Airship to build quality apps.

Downloads

94

Readme

@airship/rn-components

This is a component library created and used by Airship for quickly building out consistent and high quality React Native apps! It is made up of basic inputs and animated wrapper components. This library is included in all Airfoil templates by default.

Features

  • ✨ Easy to use, configurable components
  • 📱 Animations that use the UI thread for a consistent 60fps on iOS and Android
  • ⏳ Saves you from building basic components from scratch every project

Getting Started

To add to your project, run the command

yarn add @airship/rn-components

Directory 📚

API Reference

AnimatedFade

An animated View that can wrap a React Native component fade a component in or fade it out.

Example:

import { AnimatedFade } from '@airship/rn-components';

<AnimatedFade delay={1000}>
  {children}
</AnimatedFade>

| Prop | Type | Required | Default | Description | | --- | :--: | :--: | :--: | --- | | triggerFade | boolean | no | true | By default, animation is triggered on mount. triggerFade allows for controlled triggering. | | loop | boolean | no | false | Enables looping for the animation | | opacityStart | number | no | 0 | Defaults to 0. Values can range from 0.0 - 1.0 | | opacityEnd | number | no | 1 | Defaults to 1. Values can range from 0.0 - 1.0 | | duration | number | no | 800 | Specify in ms how long the fade animation lasts. | | delay | number | no | 0 | Specify in ms how long to wait until the fade animation occurs. | | style | ViewStyle | no | undefined | Pass React Native View styles to AnimatedFade. | | onEnd | () => void | no | undefined | When the animation finishes and this function exists, the onEnd function will be called. |

AnimatedMove

An animated View that can wrap a React Native component and move its position.

Example:

import { AnimatedMove } from '@airship/rn-components';

<AnimatedMove startY={-50} delay={1000}>
  {children}
</AnimatedMove>

| Prop | Type | Required | Default | Description | | --- | :--: | :--: | :--: | --- | | moveOnMount | boolean | no | true | AnimatedMove is set to start animating on render. Setting this to false in conjunction with triggerMove will allow you to control when the animation occurs. | | triggerMove | boolean | no | false | Setting to true will cause the move animation to start. | | tension | number | no | 18 | Controls the speed. Reference | | friction | number | no | 4 | Controls "bounciness"/overshoot. Reference | | toX | number | no | 0 | Move your component to a new X position. | | toY | number | no | 0 | Move your component to a new Y position. | | startX | number | no | 0 | Move your component to its X origin position (ex. setting to -10 will have the component move from the left to its position you have in your styles). | | startY | number | no | 0 | Move your component to its Y origin position (ex. setting to -10 will have the component move from the top to its position you have in your styles). | | delay | number | no | 0 | Specify in ms how long to wait until the animation occurs. | | style | ViewStyle | no | undefined | Pass React Native View styles to AnimatedMove. | | onEnd | () => void | no | undefined | When the animation finishes and this function exists, the onEnd function will be called. |

AnimatedPressable

An animated View that changes its scale on press, and returns to its original position on the press out. It can render out a component with props available to it such as color interpolation based on the pressed state.

Example:

import { AnimatedPressable } from '@airship/rn-components';

<View>
  <AnimatedPressable
    colorStart={'rgb(255, 255, 255)'}
    colorEnd={'rgb(255, 42, 19)'}
    renderComponent={(colorInterpolation) => (
      <ThumbsUpSVG
        height={54}
        width={63}
        stroke={colors.orange}
        fillColor={colorInterpolation}
      />
    )}
  />
  <AnimatedPressable
    toScaleValue={0.8}
    friction={12}
    tension={120}
    onPress={() => Alert.alert('Pressed!')}
    renderComponent={() => (
      <View
        style={{
          marginTop: 32,
          width: 100,
          height: 100,
          backgroundColor: colors.trueBlack,
          borderRadius: 12,
        }}
      />
    )}
  />
  <AnimatedPressable
    toScaleValue={1.5}
    renderComponent={() => (
      <View
        style={{
          marginTop: 32,
          width: 100,
          height: 100,
          backgroundColor: colors.orange,
          borderRadius: 12,
        }}
      />
    )}
  />
</View>

| Prop | Type | Required | Default | Description | | --- | :--: | :--: | :--: | --- | | toScaleValue | number | no | 0.5 | This number controls how much the Animated.View will scale. It can be lower or higher than 1. | | tension | number | no | 18 | Controls the speed. Reference | | friction | number | no | 4 | Controls "bounciness"/overshoot. Reference | | colorStart | string | no | null | Initial color value, must be given as a rgb string. Color interpolation does not work with hexes. NOTE: Works off of pressed. Think of it as a "like" button. If pressed has a true value, that means the current color is colorEnd. | | colorEnd | string | no | null | End color value, must be given as a rgb string. Color interpolation does not work with hexes. NOTE: Works off of pressed. Think of it as a "like" button. If pressed has a true value, that means the current color is colorEnd. | | isPressed | boolean | no | false | The current state of AnimatedPressable. Can be passed a value such as starting with pressed set to true, which means the colorEnd is the starting color. | | onPress | () => void | no | undefined | When the animation finishes (press out) and this function exists, the onPress function will be called. | | callFunctionOnPressIn | boolean | no | false | Setting to true will cause the onPress function to call on the press in of the tap instead of the press out default. | | renderComponent | (colorInterpolation: Animated.AnimatedInterpolation) => React.ReactElement | no | undefined | This render function allows for a child component to be passed with access to the colorInterpolation values IF a colorStart and colorEnd have been set. Otherwise the value will not exist and will render the component without value to colorInterpolation. | | style | ViewStyle | no | undefined | Pass React Native View styles to AnimatedPressable. |

SegmentedControl

An animated tab controller for selections in an app with customizable color schemes.

Example:

import React, { useState } from 'react';
import { StyleSheet } from 'react-native';
import { SegmentedControl } from '@airship/rn-components';

export const App = () => {
  const [currIdx, setCurrIdx] = useState(0);
  const [currIdx2, setCurrIdx2] = useState(0);
  const [currIdx3, setCurrIdx3] = useState(0);

  return (
    <View>
      <SegmentedControl
        tabs={['First', 'Second']}
        onChange={(idx) => setCurrIdx(idx)}
        currentIndex={currIdx}
        activeSegmentBackgroundColor={colors.background}
        containerStyle={styles.segmentContainer}
        textStyle={styles.textStyle}
      />
      <SegmentedControl
        tabs={['First', 'Second', 'Third']}
        onChange={(idx) => setCurrIdx2(idx)}
        currentIndex={currIdx2}
        activeSegmentBackgroundColor={colors.background}
        containerStyle={styles.segmentContainer}
        textStyle={styles.textStyle}
      />
      <SegmentedControl
        tabs={['First', 'Second']}
        onChange={(idx) => setCurrIdx3(idx)}
        currentIndex={currIdx3}
        activeSegmentBackgroundColor={colors.orange}
        containerStyle={styles.segmentContainerCustom}
        textStyle={styles.textStyle}
        activeTextColor={'#FFF'}
        activeContainerStyles={styles.activeContainer}
      />
    </View>
  )

  const styles = StyleSheet.create({
    segmentContainer: {
      backgroundColor: colors.background3,
    },
    segmentContainerCustom: {
      backgroundColor: colors.background3,
      borderRadius: 50,
    },
    textStyle: {
      color: colors.text,
    },
    activeContainer: { borderRadius: 50 },
  })
}

| Prop | Type | Required | Default | Description | | --- | :--: | :--: | :--: | --- | | tabs | string[] | yes | [] | An array of strings, with each one being a label for each tab. | | onChange | (index: number) => void | yes | null | Exposes the current index when changing tabs for state management. | | currentIndex | number | yes | null | This is the currently selected tab. | | activeSegmentBackgroundColor | string | yes | '' | Color for the currently selected tab. | | containerStyle | ViewStyle | no | null | Add additional/override styling to the segment container. | | textStyle | TextStyle | no | null | Add additional/override styling to the text components. | | activeTextColor | string | no | #20242B | Color of the text in the active selected tab. | | activeContainerStyles | ViewStyle | no | null | Add additional/override styling to the active selected tab container. |