2017-12-31 47 views
0

Jedes Mal, wenn ich meine Simulation lösche/neustarte, erhalte ich die obige Fehlermeldung. Gibt es eine Möglichkeit, ein Dummy-Benutzerobjekt einzufügen, mit dem ich die 'const' analysieren und zur eigentlichen Anmeldung gelangen kann?Realm: Benutzer muss vom Typ 'Objekt' sein, bekam (undefiniert)

import React from 'react'; 
import { StyleSheet, AppRegistry, TextInput, Text, View, Alert, } from 'react-native'; 
import Realm from 'realm'; 

logBookSchema = {schema: [{ 
     name: 'LogBook', 
     properties: { 
     logNum: 'int', 
     }, 
    }] 
} 

class LogBook extends Realm.Object {} 

const realm = new Realm({sync: {user: Realm.Sync.User.current, url: 'realm://localhost:9080/~/logbook',error: err => alert(err)},logBookSchema}); 

export default class App extends React.Component { 
    render() { 
    Realm.Sync.User.login('http://localhost:9080', '[email protected]', 'test').then (user => { 
     Realm.open({logBookSchema, sync: {user: user, url: 'realm://localhost:9080/~/logbook',error: err => alert(err)}}); 
     }); 

    return (
    <View><Text></Text><Text>Logged in</Text></View> 
) 
    } 
} 

Antwort

1

Endlich verließ das Tal der Verdammnis. Hier mein Ansatz:

export default class LoginScreen extends React.Component { 
    constructor(props) { 
    super(props); 
    this.state = { realm: null }; 
    } 

    componentWillMount() { 
    Realm.Sync.User.login('http://192.168.2.105:9080', '[email protected]', 'test') 
    .then (user => { 
     Realm.open({schema: [LogBook], 
     sync: {user: user, url: 'realm://192.168.2.105:9080/~/logbook',error: err => alert(err)} 
     }) 
     .then(realm => { 
     this.setState({ realm }); 
     }); 
    }); 
    } 

    render() { 
    if (!this.state.realm) {return (
     <View><Text></Text><Text>Loading</Text></View> 
    )} 
    else { 
     return (
     <MyApp /> 
    ); 
    } 
    } 
} 
Verwandte Themen