Я из ReactJS и React Native. Я хочу попробовать Флаттер. Пока что я хочу иметь экран входа в систему. Поэтому я хочу проверить, если пользователь уже вошел в систему. Если это так, перейдите на главный экран. Если нет, покажите экран входа в систему.
В React с TypeScript и Firebase я бы сделал так:
interface RootScreenState {
isLoading: boolean;
user: firebase.User | null;
}
class RootScreen extends React.Component<{}, RootScreenState> {
constructor(props) {
super(props);
this.state = {
isLoading: true,
user: null
}
}
componentDidMount() {
// make an async call to some firebase libraries to look for stored user credentials
// if some credentials are found try to login
// of no credentials are found or login fails return null
// otherwise the user is returned
tryToLogin().then((currentUser: firebase.User | null) => {
this.setState({
isLoading: false,
user: currentUser
}).catch(err => { /* do some error handling */});
}
render() {
const { isLoading, user } = this.state;
if(isLoading) return ( /* loading screen */ );
else if(user === null) return ( /* login screen */ );
else return ( /* home screen */ );
}
}
Как мне работать с Flutter? Я не мог найти ничего о эквиваленте compnentDidMount()
, я должен сделать это в конструкторе? В React это не получится.