mirror of
https://github.com/AppFlowy-IO/AppFlowy.git
synced 2025-07-22 08:27:12 +00:00

* feat: integrate supabase auth service * chore: ignore the sercet * feat: separate and inject the auth service * chore: integrate auth service into sign in/up page * feat: integrate github and google sign in * chore: update user trait * feat: box any params in UserCloudService trait * feat: add flowy-server crate * refactor: user trait * docs: doc ThirdPartyAuthPB * feat: server provider * feat: pass the uuid to rust side * feat: pass supabase config to rust side * feat: integrate env file * feat: implement login as guest * feat: impl postgrest * test: use env * chore: upper case key * feat: optimize the file storage * fix: don't call set auth when user login in local * docs: add docs * feat: create/update/get user using postgrest * feat: optimize the login as guest * feat: create user workspace * feat: create user default workspace * feat: redesign the setting path location page * feat: use uuid as view id * feat: send auth info to rust backend * fix: sign up * fix: skip to wrong page after login * fix: integrate test error * fix: indent command error * feat: add discord login in type * fix: flutter analyze * ci: fix rust tests * ci: fix tauri build * ci: fix tauri build --------- Co-authored-by: nathan <nathan@appflowy.io>
41 lines
1.1 KiB
Dart
41 lines
1.1 KiB
Dart
import 'package:appflowy/startup/startup.dart';
|
|
import 'package:appflowy/user/application/auth/auth_service.dart';
|
|
import 'package:appflowy/user/domain/auth_state.dart';
|
|
import 'package:flutter_bloc/flutter_bloc.dart';
|
|
import 'package:freezed_annotation/freezed_annotation.dart';
|
|
|
|
part 'splash_bloc.freezed.dart';
|
|
|
|
class SplashBloc extends Bloc<SplashEvent, SplashState> {
|
|
SplashBloc() : super(SplashState.initial()) {
|
|
on<SplashEvent>((event, emit) async {
|
|
await event.map(
|
|
getUser: (val) async {
|
|
final response = await getIt<AuthService>().getUser();
|
|
final authState = response.fold(
|
|
(error) => AuthState.unauthenticated(error),
|
|
(user) => AuthState.authenticated(user),
|
|
);
|
|
emit(state.copyWith(auth: authState));
|
|
},
|
|
);
|
|
});
|
|
}
|
|
}
|
|
|
|
@freezed
|
|
class SplashEvent with _$SplashEvent {
|
|
const factory SplashEvent.getUser() = _GetUser;
|
|
}
|
|
|
|
@freezed
|
|
class SplashState with _$SplashState {
|
|
const factory SplashState({
|
|
required AuthState auth,
|
|
}) = _SplashState;
|
|
|
|
factory SplashState.initial() => const SplashState(
|
|
auth: AuthState.initial(),
|
|
);
|
|
}
|