Giter VIP home page Giter VIP logo

react-native-scl-alert's Introduction

react-native-scl-alert

npm version

A pure react native javascript implementation of the package https://github.com/vikmeup/SCLAlertView-Swift

Road Map

  • Documentation to customize styles
  • Handle orientation
  • Default images for header
  • Text Field Component
  • More transitions

Features

  • Declarative API
  • High customizable UI
  • Built in themes inspired on bootstrap

Demo

You can try on expo: https://exp.host/@rafaelmotta021/react-native-scl-alert-demo

or just check the images bellow:

Setup

yarn add react-native-scl-alert

or

npm install --save react-native-scl-alert

Usage

import React from 'react'
import {
  View,
  Button,
  StyleSheet
} from 'react-native'

import {
  SCLAlert,
  SCLAlertButton
} from 'react-native-scl-alert'

export default class App extends React.Component {
  state = {
    show: false
  }

  handleOpen = () => {
    this.setState({ show: true })
  }

  handleClose = () => {
    this.setState({ show: false })
  }

  render() {
    return (
      <View style={styles.container}>
        <Button title="Show" onPress={this.handleOpen} />
        <SCLAlert
          theme="info"
          show={this.state.show}
          title="Lorem"
          subtitle="Lorem ipsum dolor"
        >
          <SCLAlertButton theme="info" onPress={this.handleClose}>Done</SCLAlertButton>
        </SCLAlert>
      </View>
    )
  }
}

const styles = StyleSheet.create({
  container: {
    flex: 1,
    backgroundColor: '#fff',
    alignItems: 'center',
    justifyContent: 'center'
  }
})

Demo

You can customized the look and feel of this library the way you want, but, if you prefer, we ship 6 themes for you:

  • default
  • inverse
  • success
  • info
  • danger
  • warning

SCLAlert

Name Type Default Description
show PropTypes.bool false Show the alert
cancellable PropTypes.bool true If user press in the overlay, will trigger onRequestClose func
onRequestClose PropTypes.func null Trigger a function asking to close the alert
slideAnimationDuration PropTypes.number 250 Duration in ms of the alert animation
overlayStyle ViewPropTypes.style {} Extends the overlay view style
title PropTypes.string REQUIRED A string to render in the modal title
titleContainerStyle ViewPropTypes.style {} Extends the title container view style
titleStyle Text.propTypes.style {} Extends the title text style
subtitle PropTypes.string REQUIRED A string to render in the modal subtitle
subtitleContainerStyle ViewPropTypes.style {} Extends the subtitle container view style
subtitleStyle Text.propTypes.style {} Extends the subtitle text style
headerContainerStyles ViewPropTypes.style {} Extends the title headerContainer view style
headerInnerStyles ViewPropTypes.style {} Extends the title headerInner view style
headerIconComponent PropTypes.node null A component to render inside the header
children PropTypes.node null Custom content. Put here buttons and text inputs

SCLAlertButton

Name Type Default Description
children PropTypes.string or PropTypes.node REQUIRED String or react node
containerStyle ViewPropTypes.style {}
textStyle Text.propTypes.style {}
theme PropTypes.string 'default' Check options above
onPress PropTypes.func REQUIRED Callback after user press in the button

react-native-scl-alert's People

Contributors

rafaelmotta avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

react-native-scl-alert's Issues

undefined is not a function '_this.props.onRequestClose()'

Hi 👋
I appreciate your effort to design this awesome library. I found an error could you please tell me why this behavior occurred. The alert box is working fine with done button but when I clicked on overlay background then this error pop up.

err6r

Crashes on RN 0.62.2

i installed via yarn
used it as a component and it just crashes the whole app for no reason!

import React from 'react';

import {SCLAlert, SCLAlertButton} from 'react-native-scl-alert';

export const WMGAlert = (props) => {
  return (
    <SCLAlert
      theme="info"
      show={props.show}
      title="Lorem"
      useNativeDriver
      subtitle="Lorem ipsum dolor">
      <SCLAlertButton theme="info" onPress={props.handleClose}>
        Done
      </SCLAlertButton>
    </SCLAlert>
  );
};

this error/warning comes up in flipper and app freezes then crashes

Animated: useNativeDriverwas not specified. This is a required option and must be explicitly set totrueorfalse SCLAlert@http://localhost:8081/node_modules/react-native-scl-alert/src/components/SCLAlert.bundle?platform=ios&dev=true&minify=false&modulesOnly=true&runModule=false&shallow=true:55:36 WMGAlert@http://localhost:8081/src/services/WMGAlert.bundle?platform=ios&dev=true&minify=false&modulesOnly=true&runModule=false&shallow=true:31:21 RCTView RCTScrollContentView RCTScrollView ScrollView@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:63010:36 Settings@http://localhost:8081/src/scenes/Settings/Settings.bundle?platform=ios&dev=true&minify=false&modulesOnly=true&runModule=false&shallow=true:47:47 ConnectFunction@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:109409:43 StaticContainer@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:161868:17 EnsureSingleNavigator@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:160542:24 SceneView@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:161746:22 RCTView RCTView RCTView CardSheet@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:169424:23 RCTView AnimatedComponent@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:62289:24 AnimatedComponentWrapper PanGestureHandler@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:105532:38 PanGestureHandler@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:166315:34 RCTView AnimatedComponent@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:62289:24 AnimatedComponentWrapper RCTView Card@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:168898:36 CardContainer@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:168621:22 RCTView MaybeScreen@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:166975:24 RCTView MaybeScreenContainer@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:166948:23 CardStack@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:166516:36 KeyboardManager@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:169593:36 RNCSafeAreaView SafeAreaProvider@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:166174:24 SafeAreaProviderCompat@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:170053:24 RCTView StackView@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:165734:36 StackNavigator@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:165611:32 EnsureSingleNavigator@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:160542:24 BaseNavigationContainer@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:160308:28 ThemeProvider@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:164048:21 NavigationContainer@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:163967:26 SceneNavigator@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:158622:21 PersistGate@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:108204:22 ThemeProvider@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:128013:36 Provider@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:108997:21 App@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:107940:41 RCTView RCTView AppContainer@http://localhost:8081/index.bundle?platform=ios&dev=true&minify=false:68960:22

what did I try:

  1. reverted to 1.2.0 version still crash
  2. added the animated and native driver prop result none

any help will be appreciated

Slow performance

I am using version 1.2.1. It takes long time to display alert on android when setting the show property true.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.