import React, { useState } from "react";
import { StyleSheet, Text, Image, View } from "react-native";
import * as Yup from "yup";

import { Form, SubmitButton, FormField } from "../components/forms";
import FormImagePicker from "../components/forms/FormImagePicker";
import useLocation from "../hooks/useLocation";
import colors from "../config/colors";
import { scaleDimsFromWidth } from "../config/dimensions";
import { TouchableNativeFeedback } from "react-native-gesture-handler";
import { insertFloodZone } from "../database/databaseLoader";
import { showMessage } from "react-native-flash-message";
import { KeyboardAwareScrollView } from "react-native-keyboard-aware-scroll-view";
import Screen from "../components/Screen";
import assets from "../config/assets";

function submitForm(props) {
  // console.log(props);
  insertFloodZone(props);
}

const validationSchema = Yup.object().shape({
  images: Yup.array().min(1, "Por favor, selecione ao menos uma imagem"),
  description: Yup.string()
    .label("Description")
    .required("Por favor, forneça uma descrição"),
});

function SharingFloodZonesScreen(props) {
  const [passable, setPassable] = useState(0);
  const location = useLocation();

  return (
    <Screen style={styles.container}>
      <Text
        style={{
          fontSize: 18,
          fontWeight: "bold",
          color: colors.primary,
          textAlign: "center",
          marginBottom: 30,
        }}
      >
        Pontos de alagamento
      </Text>
      <KeyboardAwareScrollView
        resetScrollToCoords={{ x: 0, y: 0 }}
        contentContainerStyle={styles.container}
        scrollEnabled={true}
      >
        <Form
          initialValues={{
            images: [],
            description: "",
          }}
          onSubmit={(values) => {
            submitForm({ ...values, passable, location });
            showMessage({
              message: "Informação enviada!",
              duration: 1950,
              icon: "success",
              type: "success",
            });
            props.navigation.goBack(null);
          }}
          validationSchema={validationSchema}
        >
          <View style={styles.imgs_container}>
            <TouchableNativeFeedback onPress={() => setPassable(1)}>
              <View
                style={styles.img_block}
                borderWidth={passable == 1 ? borderWidth : 0}
              >
                <Image
                  style={styles.image}
                  source={assets.floodZones.passable}
                />
                <Text style={styles.text}>Transitável</Text>
              </View>
            </TouchableNativeFeedback>

            <TouchableNativeFeedback onPress={() => setPassable(0)}>
              <View
                style={styles.img_block}
                borderWidth={passable == 0 ? borderWidth : 0}
              >
                <Image
                  style={styles.image}
                  source={assets.floodZones.notPassable}
                />
                <Text style={styles.text}>Intransitável</Text>
              </View>
            </TouchableNativeFeedback>
          </View>

          <FormImagePicker name="images" height={10} />
          <FormField
            maxLength={255}
            multiline
            name="description"
            numberOfLines={3}
            placeholder="Descrição"
          />
          <SubmitButton title="Enviar" backgroundColor={colors.primary} />
        </Form>
      </KeyboardAwareScrollView>
    </Screen>
  );
}
const borderWidth = 3;

const styles = StyleSheet.create({
  container: {
    padding: 10,
  },

  header: {
    fontSize: 18,
    color: colors.primary,
    fontWeight: "500",
  },
  image: {
    ...scaleDimsFromWidth(150, 80, 35.0),
    resizeMode: "contain",
  },
  img_block: {
    padding: 10,
    borderRadius: 5,
    borderStyle: "dotted",
    borderColor: colors.primary,
    justifyContent: "center",
    alignItems: "center",
  },
  imgs_container: {
    alignSelf: "center",
    flexGrow: 1,
    flexDirection: "row",
    justifyContent: "space-between",
  },

  text: {
    fontSize: 14,
  },
});

export default SharingFloodZonesScreen;