Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
31 |
Tags
- borderRadius
- consumer
- user
- Swift
- changenotifierprovider
- ListView.builder
- enum
- Stream
- transform
- datetime
- provider
- platformexception
- 문법
- controller
- switch
- Camera
- divider
- runTransaction
- globalkey
- signout
- multiprovider
- setstate
- permission
- Navigator
- swift 문법
- changenotifier
- Snapshot
- reference
- snackbar
- Firebase
Archives
- Today
- Total
코딩하는 제리
[Flutter/Project](Instagram Clone) Firebase 상태 파일 변경 및 provider 적용 본문
Flutter/Project_InstaClone(완)
[Flutter/Project](Instagram Clone) Firebase 상태 파일 변경 및 provider 적용
JerryCho 2021. 2. 3. 12:44listen: false -> 해당 위젯에 변화를 줄 필요가 없을 때 사용.
소스코드 및 pubspec.yaml
// models/firebase_auth_state.dart
import 'package:firebase_auth/firebase_auth.dart';
import 'package:flutter/foundation.dart';
class FirebaseAuthState extends ChangeNotifier {
// 기본값은 로그아웃 상태
FirebaseAuthStatus _firebaseAuthStatus = FirebaseAuthStatus.signout;
FirebaseAuth _firebaseAuth = FirebaseAuth.instance;
FirebaseUser _firebaseUser;
void watchAuthChange() {
// onAuthStateChanged를 통해 firebaseUser를 보냄.
_firebaseAuth.onAuthStateChanged.listen((firebaseUser) {
if (firebaseUser == null && _firebaseUser == null) {
return;
} else if (firebaseUser != _firebaseUser) {
// 받아온 firebaseUser와 _firebaseUser가 같지 않으면
// 업데이트.
_firebaseUser = firebaseUser;
// 업데이트 후 changeFirebaseAuthStatus() 실행.
// firebaseAuthStatus 파라미터를 넣지 않았기에
// else if로 바로 넘어감.
changeFirebaseAuthStatus();
}
});
}
// [] -> 옵션
void changeFirebaseAuthStatus([FirebaseAuthStatus firebaseAuthStatus]) {
if (firebaseAuthStatus != null) {
_firebaseAuthStatus = firebaseAuthStatus;
} else if (_firebaseUser != null) {
// 유저 데이터가 있으면 singin
_firebaseAuthStatus = FirebaseAuthStatus.singin;
} else {
_firebaseAuthStatus = FirebaseAuthStatus.signout;
}
notifyListeners();
}
FirebaseAuthStatus get firebaseAuthStatus => _firebaseAuthStatus;
}
enum FirebaseAuthStatus { signout, progress, singin }
// main.dart
import 'package:flutter/material.dart';
import 'package:flutter_project_IJ/models/firebase_auth_state.dart';
import 'package:flutter_project_IJ/screens/auth_screen.dart';
import 'package:flutter_project_IJ/widgets/my_gallery.dart';
import 'package:flutter_project_IJ/widgets/my_progress_indicator.dart';
import 'package:provider/provider.dart';
import 'home_page.dart';
import 'constants/colors.dart';
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
FirebaseAuthState _firebaseAuthState = FirebaseAuthState();
@override
Widget build(BuildContext context) {
return ChangeNotifierProvider<FirebaseAuthState>.value(
value: _firebaseAuthState,
child: MaterialApp(
home: Consumer<FirebaseAuthState>(
builder: (BuildContext context, FirebaseAuthState firebaseAuthState,
Widget child) {
switch (firebaseAuthState.firebaseAuthStatus) {
case FirebaseAuthStatus.signout:
return AuthScreen();
case FirebaseAuthStatus.progress:
return MyProgressIndicator();
case FirebaseAuthStatus.singin:
return HomePage();
default:
return MyProgressIndicator();
}
},
child: HomePage(),
),
theme: ThemeData(primarySwatch: white),
),
);
}
}
'Flutter > Project_InstaClone(완)' 카테고리의 다른 글
[Flutter/Project](Instagram Clone) Firebase 로그아웃 구현 (0) | 2021.02.03 |
---|---|
[Flutter/Project](Instagram Clone) signin/signout 애니메이션 추가 (0) | 2021.02.03 |
[Flutter/Project](Instagram Clone) Firebase auth 상태 파일 (0) | 2021.02.02 |
[Flutter/Project](Instagram Clone) Firebase 프로젝트 생성 (0) | 2021.02.02 |
[Flutter/Project](Instagram Clone) follow 화면 레이아웃 (0) | 2021.02.02 |
Comments