Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Arguments inside "onChange" its no compatble with "NativeSyntheticEvent<TextInputChangeEventData>"

I am new with react native and when i try do this

        <TextInput
          style={styles.input}
          onChange={(text) => setPontoValue(text)}
        />

i receive this error

TS2345: Argument of type 'NativeSyntheticEvent<TextInputChangeEventData>' is not assignable to parameter of type 'SetStateAction<undefined>'.   Type 'NativeSyntheticEvent<TextInputChangeEventData>' provides no match for the signature '(prevState: undefined): undefined'.

all code is below

import React, { useState } from 'react'

import {
  TextInput,
  TouchableOpacity,
  StyleSheet,
  SafeAreaView,
  Text,
  View, Button,
} from 'react-native'


export default function App() {
  const [pontoValue, setPontoValue] = useState()
  const [dataValue, setDataValue] = useState()

  return (
    <SafeAreaView style={styles.container}>
      <View style={styles.repositoryContainer}>
        <TextInput
          style={styles.input}
          onChange={(text) => setPontoValue(text)}
        />
        <TextInput
          style={styles.input}
          value={dataValue}
        />
        <TouchableOpacity>
          <Button
            title="Calcular"
            onPress={teste}>Converter
          </Button>
        </TouchableOpacity>

      </View>
    </SafeAreaView>
  )

  function teste() {
    if (pontoValue) {
      setDataValue(pontoValue.replace(/[ .]+/g, ''))
    }
  }
}


const styles = StyleSheet.create({
  container: {
    flex: 1,
    justifyContent: 'center',
    alignContent: 'center',
    backgroundColor: '#7199c1',
  },
  repositoryContainer: {
    marginBottom: 15,
    marginHorizontal: 15,
    backgroundColor: '#fff',
    padding: 20,
  },
  input: {
    height: 40,
    padding: 5,
    borderColor: 'gray',
    borderWidth: 1,
  },
  buttonText: {
    marginVertical: 11,
    fontSize: 14,
    fontWeight: 'bold',
    color: '#fff',
    backgroundColor: '#7159c1',
    padding: 15,
  },
})
like image 340
Mauricio Crispim Avatar asked Oct 22 '25 07:10

Mauricio Crispim


1 Answers

onChange event returns an event object which has nativeEvent function which providers access to the following properties: { eventCount, target, text}

you need the text property, so you can use:

onChange={(event) => setPontoValue(event.nativeEvent.text)}

or

onChangeText={(text) => setPontoValue(text)}
like image 179
Mohammad Fasha Avatar answered Oct 23 '25 20:10

Mohammad Fasha



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!