react-native-1app
Version: 
253 lines (246 loc) • 5.9 kB
JavaScript
import React from "react";
import { StyleSheet, Text, ScrollView } from "react-native";
import TextInput from "./TextInput";
import { View, TouchableOpacity } from "react-native";
import PopupDialog, {
  DialogTitle,
  DialogButton,
  SlideAnimation,
  ScaleAnimation,
  FadeAnimation
} from "react-native-popup-dialog";
const fadeAnimation = new FadeAnimation({ animationDuration: 150 });
const scaleAnimation = new ScaleAnimation();
const slideAnimation = new SlideAnimation({ slideFrom: "bottom" });
let _ref = null;
export default class DialogAlert extends React.Component {
  constructor(props) {
    super(props);
    _ref = this;
    this.state = {
      title: "",
      descricao: "",
      actions: [],
      body: [],
      styleDescricao: {},
      styleTitle: {},
      action: [],
      renderHead: null,
      styleTextButton: {},
      texto: "",
      input: null,
      dialogStyle: {},
      center: "center",
      containerStyle: {}
    };
    this.showScaleAnimationDialog = ({
      title = "",
      descricao = "",
      actions = [],
      body = [],
      align = "center",
      styleDescricao = {},
      styleTitle = {},
      action = [],
      renderHead = null,
      styleTextButton = {},
      texto = "",
      input = null,
      dialogStyle = {},
      containerStyle = {}
    }) => {
      // console.log(actions);
      this.setState(
        {
          title,
          descricao,
          actions,
          body,
          align,
          styleDescricao,
          styleTitle,
          action,
          containerStyle,
          renderHead,
          texto,
          input,
          dialogStyle
        },
        () => this.scaleAnimationDialog.show()
      );
      // this.scaleAnimationDialog.show();
    };
  }
  closeDialog() {
    this.scaleAnimationDialog.dismiss();
    this.setState({ input: null });
  }
  render() {
    const {
      title,
      descricao,
      actions,
      body,
      styleDescricao,
      styleTitle,
      action,
      renderHead,
      styleTextButton,
      input,
      dialogStyle,
      align,
      containerStyle
    } = this.state;
    return (
      <PopupDialog
        ref={popupDialog => {
          this.scaleAnimationDialog = popupDialog;
        }}
        dialogAnimation={slideAnimation}
        width={0.91}
        height={0.8}
        containerStyle={[containerStyle, styles[align]]}
        dismissOnTouchOutside={false}
        dialogStyle={[styles.dialogStyle, dialogStyle]}
        dialogTitle={
          (title && <DialogTitle title={title} />) || renderHead || <View />
        }
        actions={
          <View style={styles.actionButton}>
            {actions.map((prop, index) => (
              <TouchableOpacity
                style={styles.button}
                onPress={() => {
                  if (prop.onPress) prop.onPress();
                  this.closeDialog();
                }}
                key={"button" + index}
              >
                <View style={styles.borderB} />
                <Text style={[styles.textButton, styleTextButton]}>
                  {prop.title}
                </Text>
                <View style={styles.borderB} />
              </TouchableOpacity>
            ))}
          </View>
        }
      >
        <ScrollView style={styles.scroll}>
          <Text style={[styles.text, styleDescricao]}>{descricao}</Text>
          {body}
        </ScrollView>
        {input && <View style={styles.viewInput} />}
        {input && (
          <TextInput
            {...input}
            style={[styles.textinput, input.style]}
            value={this.state.texto}
            onChange={texto => {
              if (input.onChange) input.onChange(texto);
              this.setState({ texto });
            }}
            // autoFocus={true}
            onSubmitEditing={() => {
              if (input.onSubmitEditing) {
                input.onSubmitEditing();
                this.closeDialog();
              }
            }}
          />
        )}
      </PopupDialog>
    );
  }
}
var styles = StyleSheet.create({
  top: {
    paddingTop: 90,
    justifyContent: "flex-start"
  },
  center: {},
  viewInput: {
    height: 1,
    backgroundColor: "rgba(187,177,177,0.53)",
    alignSelf: "stretch"
  },
  text: {
    textAlign: "center",
    alignSelf: "stretch",
    color: "rgba(55,55,55,1)",
    alignSelf: "auto",
    fontWeight: "normal",
    fontSize: 14,
    margin: 20
  },
  textinput: {
    color: "rgba(0,0,0,1)",
    alignSelf: "stretch",
    textAlign: "left",
    fontWeight: "normal",
    borderStyle: "solid",
    borderWidth: 0,
    borderTopWidth: 1,
    marginLeft: 10,
    marginRight: 10,
    borderColor: "rgba(187,177,177,0.53)"
  },
  textContainer: {
    paddingHorizontal: 1,
    paddingVertical: 1,
    height: 40
  },
  button: {
    borderStyle: "solid",
    borderWidth: 0,
    borderTopWidth: 1,
    borderColor: "rgba(187,177,177,0.53)",
    flex: 1,
    alignItems: "center",
    justifyContent: "center",
    minWidth: 100,
    height: 40,
    flexDirection: "row"
  },
  borderB: {
    width: 0.5,
    height: 25,
    backgroundColor: "rgba(187,177,177,0.53)"
  },
  textButton: {
    fontWeight: "400",
    fontSize: 18,
    flex: 1,
    flexWrap: "nowrap",
    textAlign: "center",
    color: "rgb(0, 85, 255)"
  },
  scroll: {
    alignSelf: "stretch",
    // flex: 1,
    maxHeight: 500,
    flexDirection: "column"
  },
  actionButton: {
    flexWrap: "wrap",
    flexDirection: "row",
    justifyContent: "space-around",
    alignSelf: "stretch"
  },
  dialogStyle: {
    height: null,
    minHeight: 200
  }
});
export function openDialog(...args) {
  // const ref = App.getDefault();
  if (_ref) {
    _ref.showScaleAnimationDialog(...args);
  }
}
export function closeDialog(...args) {
  // const ref = App.getDefault();
  if (_ref) {
    _ref.closeDialog(...args);
  }
}