чекбокс expo реагировать на родной элемент - PullRequest
0 голосов
/ 20 ноября 2018

У меня есть некоторые флажки на основе значения true / false из базы данных sqlite.с кодом ниже sqlite обновлен, я ожидал, у меня есть проблема только в состоянии для проверено = {this.state.KUSENINS1}, проверено = {this.state.KUSENINS2} я получил ошибку, Ошибка типа проп: недопустимая поддержка checked типаstring поставлено на CheckBox, ожидается boolean.и флажок всегда проверен / истина, даже если в моей базе данных значение ложно, флажок продолжает проверяться. Любая помощь или ссылка для той же проблемы. thxu

import Expo, { SQLite } from 'expo';
import React from 'react';
import { StyleSheet, Text, View, ScrollView, ActivityIndicator, SafeAreaView, AppRegistry } from 'react-native';
import { CheckBox } from 'react-native-elements';
import database from './database';

export default class AreaSpecify extends React.Component {
    constructor(props) {
        super(props);
        this.state = {
            isLoading: true,
            numberOfRefresh: 0,
            //checked: null,
            data: null,
            NO: null,
            NOKAMAR: null,
            NP: null,
            LT: null,
            KUSENINS1: false,
            KUSENINS2: false,
            KUSENINS3: false,
            KUSENINS4: false,
            KUSENFIN1: false,
            KUSENFIN2: false,
            KUSENFIN3: false,
            KUSENFIN4: false,
            KUSENFIN5: false,
        };
    }

    componentDidMount(){
        const { navigation } = this.props;
        var NO = navigation.getParam('NO');

        //var datas = projectData;
        database.transaction(
            tx => {
                tx.executeSql('select * from List where NO = ?', [NO], (_, { rows: { _array } }) =>
                    {
                        //var data = rows._array;

                        this.setState({
                            isLoading: false,
                            data: _array,
                            NO: _array[0].NO,
                            NOKAMAR: _array[0].NOKAMAR,
                            NP: _array[0].NP,
                            LT: _array[0].LT,
                            KUSENINS1: _array[0].KUSENINS1,
                            KUSENINS2: _array[0].KUSENINS2,
                            KUSENINS3: _array[0].KUSENINS3,
                            KUSENINS4: _array[0].KUSENINS4,
                            KUSENFIN1: _array[0].KUSENFIN1,
                            KUSENFIN2: _array[0].KUSENFIN2,
                            KUSENFIN3: _array[0].KUSENFIN3,
                            KUSENFIN4: _array[0].KUSENFIN4,
                            KUSENFIN5: _array[0].KUSENFIN5,
                        });
                        console.log(this.state.data);
                        console.log(this.state.KUSENINS2);


                    }
                );
            },
            null
        );

    }



    render() {

        if (this.state.isLoading){

                return (
                    <SafeAreaView style={{flex: 1, flexDirection:'column'}}>
                        <View style={{flex: 1, flexDirection:'column'}}>
                            <ActivityIndicator size="small" color="#f7c744"/> 
                        </View>
                    </SafeAreaView>
                )

            }else{

                console.log(this.state.numberOfRefresh);

                    return (
                    <View style={{ flexDirection: 'column', flex: 1}}> 
                        <View style={styles.title}>
                            <Text style={styles.textTittle}>Project:{this.state.NP}</Text>
                            <Text style={styles.textTittle}>Area:{this.state.LT} | No.Kamar/Rumah:{this.state.NOKAMAR}</Text>
                        </View>
                        <ScrollView style={{ flex: 1, flexDirection: 'column'}}>
                        <View style={{height:30, padding: 7}}>
                            <Text style={styles.textTittle}>Instalasi Kusen</Text>
                        </View>
                        <View style={styles.row}>
                        <Text style={styles.text}>Selesai</Text>
                        <Text style={styles.text}>Control Job</Text>
                        </View>
                        <View style={styles.row}>
                            <CheckBox checked={this.state.KUSENINS1}
                            title='Konsistensi Leveling Kusen'
                            containerStyle={{backgroundColor: 'rgba(255,255,255,0.0)'}}
                            onPress={() => {

                                var NO = this.state.NO;
                                var check = !this.state.KUSENINS1;
                                database.transaction(
                                tx => {
                                    tx.executeSql("update List set KUSENINS1 = '"+ check +"' where NO = '"+ NO +"';");
                                    this.setState({KUSENINS1:!this.state.KUSENINS1})
                                    console.log(NO, !this.state.KUSENINS1);
                                },
                                null
                                );

                            }}/>
                        </View>
                        <View style={styles.row}>
                            <CheckBox checked={this.state.KUSENINS2}
                            title='Lot sudah tegak lurus'
                            containerStyle={{backgroundColor: 'rgba(255,255,255,0.0)'}}
                            onPress={() => {

                                var NO = this.state.NO;
                                var check = !this.state.KUSENINS2;
                                database.transaction(
                                tx => {
                                    tx.executeSql("update List set KUSENINS2 = '"+ check +"' where NO = '"+ NO +"';");
                                    this.setState({KUSENINS2:!this.state.KUSENINS2})
                                    console.log(NO, !this.state.KUSENINS2);
                                },
                                null
                                );

                            }}/>
                        </View>
                        </ScrollView>
                    </View>
                    );
        }

    }
}

И этот выбор данных из sqlite для строки

Array [
Object {
  "ARCDATE": "",
  "ARCHFIN1": "true",
  "ARCHFIN2": "true",
  "ARCHFIN3": "true",
  "ARCHFIN4": "true",
  "ARCHFIN5": "true",
  "ARCHINS1": "true",
  "ARCHINS2": "true",
  "ARCHITRAVE": "true",
  "DEFPINTULEBAR": 90,
  "DEFPINTUPANJANG": 200,
  "DOORSTOP": "false",
  "DSDATE": "",
  "ENDDATE": "2018-12-18T17:00:00.000Z",
  "GLOBALSTATUS": 0,
  "HANDATE": "",
  "HANDLE": "true",
  "KET": "",
  "KETARCHI": "",
  "KETDOORSTOP": "",
  "KETHANDLE": "",
  "KETKUSEN": "",
  "KETPINTU": "",
  "KUSDATE": "",
  "KUSEN": "true",
  "KUSENFIN1": "false",
  "KUSENFIN2": "true",
  "KUSENFIN3": "true",
  "KUSENFIN4": "true",
  "KUSENFIN5": "true",
  "KUSENGMBR": "",
  "KUSENINS1": "true",
  "KUSENINS2": "false",
  "KUSENINS3": "false",
  "KUSENINS4": "true",
  "LASTUPDATE": "2018-10-31T17:00:00.000Z",
  "LT": "1",
  "NO": 53,
  "NOKAMAR": 107,
  "NP": "Novotel",
  "PINTU": "true",
  "PINTUDATE": "",
  "PINTUFIN1": "true",
  "PINTUFIN2": "true",
  "PINTUFIN3": "true",
  "PINTUFIN4": "true",
  "PINTUFIN5": "true",
  "PINTUGMBR": "",
  "PINTUINS1": "true",
  "PINTUINS2": "true",
  "PINTUINS3": "true",
  "PINTUINS4": "true",
  "PINTUINS5": "true",
  "REV": "",
  "SEALENT": "true",
  "SEALENTRAPIH": "true",
  "STARTDATE": "2018-10-31T17:00:00.000Z",
  "STATUS": 0,
  "SUBKON": "SUBKON A",
  "UKURANPINTUST": 0,
  "UPINTULEBAR": 90,
  "UPINTULEBAR2": 90,
  "UPINTULEBAR3": 90,
  "UPINTUPANJANG": 200,
},
]

1 Ответ

0 голосов
/ 22 ноября 2018

Я решаю это путем изменения этой части кода, чтобы сделать состояние из значения базы данных как логическое

componentDidMount(){
        const { navigation } = this.props;
        var NO = navigation.getParam('NO');
        //var datas = projectData;
        database.transaction(
            tx => {
                tx.executeSql('select * from List where NO = ?', [NO], (_, { rows: { _array } }) =>
                    {
                        //var data = rows._array;

                        this.setState({
                            isLoading: false,
                            data: _array,
                            NO: _array[0].NO,
                            NOKAMAR: _array[0].NOKAMAR,
                            NP: _array[0].NP,
                            LT: _array[0].LT,  
                            KUSENINS1: _array[0].KUSENINS1 == 'true' ? true : false,
                            KUSENINS2: _array[0].KUSENINS2 == 'true' ? true : false,
                            KUSENINS3: _array[0].KUSENINS3 == 'true' ? true : false,
                            KUSENINS4: _array[0].KUSENINS4 == 'true' ? true : false,
                            KUSENFIN1: _array[0].KUSENFIN1 == 'true' ? true : false,
                            KUSENFIN2: _array[0].KUSENFIN2 == 'true' ? true : false,
                            KUSENFIN3: _array[0].KUSENFIN3 == 'true' ? true : false,
                            KUSENFIN4: _array[0].KUSENFIN4 == 'true' ? true : false,
                            KUSENFIN5: _array[0].KUSENFIN5 == 'true' ? true : false,
                        });
                        console.log(this.state.data);
                        console.log(this.state.KUSENINS1, this.state.KUSENINS2);


                    }
                );
            },
            null
        );
    }
...