@codepso/rn-helper

Components, Helpers for React Native Projects.

Usage no npm install needed!

<script type="module">
  import codepsoRnHelper from 'https://cdn.skypack.dev/@codepso/rn-helper';
</script>

README

rn-helper

Components, Helpers for React Native Projects.

Table of content

Requirements

  • React Native 0.61+
  • React Navigation 5+
  • React Native Loading Spinner Overlay
  • Lodash 4.15+
  • React Native Paper 3.10+
yarn add react-native-loading-spinner-overlay
yarn add lodash

Installation

yarn add @codepso/rn-helper
yarn upgrade @codepso/rn-helper@latest

UI

blockUI(state, message, bgColor, txtColor)

  • state: bool | required
  • message: string | optional default: Loading...
  • bgColor: string | optional rgb value, default: rgba(0, 0, 0, 0.8)
  • txtColor: string | optional hex value, default: white

DialogUI(title, message, goTo, confirm)

React Native Paper

  • title: string | required
  • message: string | required
  • goTo: object | optional contains screen name and navigation 5 reference
  • confirm: bool | optional cancel button

AlertUI(title, message, goTo)

  • title: string | required
  • message: string | required
  • goTo: string | optional screen name with react navigation 5

Use

import {createRef} from 'react';
import {Text, View, Button} from 'react-native';
import {AlertUI, DialogUI, BlockUI, MainHelper} from '@codepso/rn-helper';

const alertUI = createRef();
const dialogUI = createRef();
const blockUI = createRef();
const sleep = (m) => new Promise((r) => setTimeout(r, m));

const WelcomeScreen = (props) => {
  const {navigation} = props;

  const onSend = async () => {
    // blockUI.current.open(true);
    // blockUI.current.open(true, 'Searching...');
    // blockUI.current.open(true, '', 'rgba(46, 139, 87, 0.8)');
    blockUI.current.open(true, '', 'rgba(255, 255, 255, 0.8)', 'black');

    try {
      await sleep(500);
      // throw {message: 'Can not update user info'};
      blockUI.current.open(false);
      dialogUI.current.open(
        'TestForm',
        'TestForm data has been sent',
        {navigation, screen: 'About'}
      );
      /*alertUI.current.open(
        'TestForm',
        'TestForm data has been sent',
        'About',
      );*/
    } catch (error) {
      blockUI.current.open(false);
      let message = MainHelper.getError(error);
      dialogUI.current.open('Snap!', message);
      // alertUI.current.open('Snap!', message);
    }
  };

  return (
    <>
      <DialogUI ref={dialogUI} />
      <BlockUI ref={blockUI} />
      <AlertUI ref={alertUI} />
      <View>
        <Text>Welcome</Text>
        <Button
          onPress={onSend}
          title="Test"
        />
      </View>
    </>
  );
};

export default WelcomeScreen;

Example

cd examples/TestRNHelper
yarn install

yarn remove @codepso/rn-helper
yarn cache clean @codepso/rn-helper --force

npm pack
yarn add ../../codepso-rn-helper-x.x.x.tgz

npx pod-install ios
npx react-native run-ios

License

The React Native Helper is licensed under the terms of the GPL Open Source license and is available for free.