Commit b15fde72f848da4e48abb74731892ac5aef33e80
1 parent
9efff6ae
feat:头像上传功能完善逻辑
Showing
7 changed files
with
54 additions
and
31 deletions
lib/pages/user/bloc/user_bloc.dart
... | ... | @@ -37,6 +37,15 @@ class UserBloc extends Bloc<UserEvent, UserState> { |
37 | 37 | UserEntity user = UserUtil.getUser()!; |
38 | 38 | switch (event.type) { |
39 | 39 | case ModifyUserInformationType.avatar: |
40 | + String avatarUrl = event.content; | |
41 | + try { | |
42 | + await UserDao.updateUserInfoField(avatarUrl: avatarUrl); | |
43 | + // 修改成功,更新本地缓存及UI | |
44 | + user.avatarUrl = avatarUrl; | |
45 | + emitter(UserInfoUpdated()); | |
46 | + } catch (e) { | |
47 | + Log.e('_updateUser avatarUrl, e: $e'); | |
48 | + } | |
40 | 49 | break; |
41 | 50 | case ModifyUserInformationType.name: |
42 | 51 | String name = event.content; | ... | ... |
lib/pages/user/information/user_information_page.dart
... | ... | @@ -54,7 +54,7 @@ class _UserInformationContentView extends StatelessWidget { |
54 | 54 | backgroundImage: ImageUtil.getImageProviderOnDefault(user.avatarUrl), |
55 | 55 | ), |
56 | 56 | ), |
57 | - onTap: () => pushNamed(AppRouteName.userAvatar) | |
57 | + onTap: () => pushNamed(AppRouteName.userAvatar,arguments: {'pageType':'1'}) | |
58 | 58 | ), |
59 | 59 | 11.verticalSpace, |
60 | 60 | _buildContentRow( | ... | ... |
lib/pages/user/modify/modify_user_avatar_page.dart
... | ... | @@ -8,8 +8,11 @@ import 'package:wow_english/common/widgets/ow_image_widget.dart'; |
8 | 8 | import 'package:wow_english/common/widgets/we_app_bar.dart'; |
9 | 9 | import 'package:wow_english/pages/user/bloc/user_bloc.dart'; |
10 | 10 | import 'package:wow_english/pages/user/modify/user_avatar_bloc/user_avatar_bloc.dart'; |
11 | +import 'package:wow_english/route/route.dart'; | |
11 | 12 | import 'package:wow_english/utils/toast_util.dart'; |
12 | 13 | |
14 | +import 'modify_user_information_page.dart'; | |
15 | + | |
13 | 16 | class ModifyUserAvatarPage extends StatelessWidget { |
14 | 17 | const ModifyUserAvatarPage({super.key, required this.pageType}); |
15 | 18 | |
... | ... | @@ -36,13 +39,18 @@ class _ModifyUserAvatarPage extends StatelessWidget { |
36 | 39 | BlocListener<UserBloc,UserState>( |
37 | 40 | listener: (context, state){ |
38 | 41 | if (state is UserInfoUpdated) { |
39 | - showToast('修改成功'); | |
42 | + if (pageType == 1) { | |
43 | + showToast('修改成功'); | |
44 | + popPage(); | |
45 | + } else { | |
46 | + context.read<UserAvatarBloc>().add(ChangeUserEnterAppStateEvent()); | |
47 | + } | |
40 | 48 | } |
41 | 49 | }), |
42 | 50 | BlocListener<UserAvatarBloc,UserAvatarState>( |
43 | 51 | listener: (context,state){ |
44 | 52 | if (state is ChangeImageState) { |
45 | - showToast('上传图片'); | |
53 | + context.read<UserBloc>().add(UserUpdate(ModifyUserInformationType.avatar,state.imageUrl)); | |
46 | 54 | } |
47 | 55 | },) |
48 | 56 | ], | ... | ... |
lib/pages/user/modify/user_avatar_bloc/user_avatar_bloc.dart
1 | 1 | import 'package:flutter/cupertino.dart'; |
2 | 2 | import 'package:flutter_bloc/flutter_bloc.dart'; |
3 | +import 'package:flutter_easyloading/flutter_easyloading.dart'; | |
3 | 4 | import 'package:image_picker/image_picker.dart'; |
4 | 5 | import 'package:permission_handler/permission_handler.dart'; |
5 | 6 | import 'package:wow_english/common/core/assets_const.dart'; |
... | ... | @@ -12,7 +13,7 @@ part 'user_avatar_event.dart'; |
12 | 13 | part 'user_avatar_state.dart'; |
13 | 14 | |
14 | 15 | class UserAvatarBloc extends Bloc<UserAvatarEvent, UserAvatarState> { |
15 | - String _imageUrl = UserUtil.getUser()!.avatarUrl ?? AssetsConst.wowLogo; | |
16 | + final String _imageUrl = UserUtil.getUser()!.avatarUrl ?? AssetsConst.wowLogo; | |
16 | 17 | |
17 | 18 | String get imageUrl => _imageUrl; |
18 | 19 | |
... | ... | @@ -27,27 +28,18 @@ class UserAvatarBloc extends Bloc<UserAvatarEvent, UserAvatarState> { |
27 | 28 | final ImagePicker picker = ImagePicker(); |
28 | 29 | |
29 | 30 | UserAvatarBloc() : super(UserAvatarInitial()) { |
30 | - on<ChangeImageEvent>(_changeImage); | |
31 | 31 | on<GetImageFromPhotoEvent>(_getImageFromPhoto); |
32 | 32 | on<GetImageFromCameraEvent>(_getImageFromCamera); |
33 | + on<ChangeUserEnterAppStateEvent>(_changeUserEnterAppState); | |
33 | 34 | } |
34 | 35 | |
35 | - Future<void> _uploadAvatar(String imagePath) async { | |
36 | + Future<String> _uploadAvatar(String imagePath) async { | |
36 | 37 | // todo 加个loading UI |
37 | 38 | String avatarUrl = await AliyunOssUtil.uploadFile(imagePath); |
39 | + debugPrint('>>>>>>>>>>阿里云图片地址$avatarUrl'); | |
38 | 40 | // 上传服务器 |
39 | - await UserDao.updateUserInfoField(avatarUrl: avatarUrl); | |
40 | - _imageUrl = avatarUrl; | |
41 | - } | |
42 | - | |
43 | - void _changeImage(ChangeImageEvent event, Emitter<UserAvatarState> emitter) async { | |
44 | - //_imageUrl = event.imagePath; | |
45 | - try { | |
46 | - await _uploadAvatar(event.imagePath); | |
47 | - emitter(ChangeImageState()); | |
48 | - } catch (e) { | |
49 | - Log.e('上传头像失败:$e'); | |
50 | - } | |
41 | + // await UserDao.updateUserInfoField(avatarUrl: avatarUrl); | |
42 | + return avatarUrl; | |
51 | 43 | } |
52 | 44 | |
53 | 45 | void _getImageFromPhoto(GetImageFromPhotoEvent event, Emitter<UserAvatarState> emitter) async { |
... | ... | @@ -58,12 +50,11 @@ class UserAvatarBloc extends Bloc<UserAvatarEvent, UserAvatarState> { |
58 | 50 | } |
59 | 51 | _file = await picker.pickImage(source: ImageSource.gallery); |
60 | 52 | try { |
61 | - await _uploadAvatar(_file!.path); | |
62 | - emitter(ChangeImageState()); | |
53 | + final urlStr = await _uploadAvatar(_file!.path); | |
54 | + emitter(ChangeImageState(urlStr)); | |
63 | 55 | } catch (e) { |
64 | 56 | Log.e('上传头像失败:$e'); |
65 | 57 | } |
66 | - //emitter(ChangeImageState()); | |
67 | 58 | }); |
68 | 59 | } |
69 | 60 | |
... | ... | @@ -75,8 +66,8 @@ class UserAvatarBloc extends Bloc<UserAvatarEvent, UserAvatarState> { |
75 | 66 | } |
76 | 67 | _file = await picker.pickImage(source: ImageSource.camera); |
77 | 68 | try { |
78 | - await _uploadAvatar(_file!.path); | |
79 | - emitter(ChangeImageState()); | |
69 | + final urlStr = await _uploadAvatar(_file!.path); | |
70 | + emitter(ChangeImageState(urlStr)); | |
80 | 71 | } catch (e) { |
81 | 72 | Log.e('上传头像失败:$e'); |
82 | 73 | } |
... | ... | @@ -84,6 +75,11 @@ class UserAvatarBloc extends Bloc<UserAvatarEvent, UserAvatarState> { |
84 | 75 | }); |
85 | 76 | } |
86 | 77 | |
78 | + void _changeUserEnterAppState(ChangeUserEnterAppStateEvent event,Emitter<UserAvatarState> emitter) async { | |
79 | + _canInsertApp = true; | |
80 | + emitter(ChangeUserEnterAppState()); | |
81 | + } | |
82 | + | |
87 | 83 | ///获取相机权限 |
88 | 84 | Future<bool> getCameraPermissionStatus() async { |
89 | 85 | Permission permission = Permission.camera; | ... | ... |
lib/pages/user/modify/user_avatar_bloc/user_avatar_event.dart
... | ... | @@ -7,7 +7,5 @@ class GetImageFromPhotoEvent extends UserAvatarEvent {} |
7 | 7 | |
8 | 8 | class GetImageFromCameraEvent extends UserAvatarEvent {} |
9 | 9 | |
10 | -class ChangeImageEvent extends UserAvatarEvent { | |
11 | - final String imagePath; | |
12 | - ChangeImageEvent(this.imagePath); | |
13 | -} | |
10 | +class ChangeUserEnterAppStateEvent extends UserAvatarEvent {} | |
11 | + | ... | ... |
lib/pages/user/modify/user_avatar_bloc/user_avatar_state.dart
... | ... | @@ -5,4 +5,9 @@ abstract class UserAvatarState {} |
5 | 5 | |
6 | 6 | class UserAvatarInitial extends UserAvatarState {} |
7 | 7 | |
8 | -class ChangeImageState extends UserAvatarState {} | |
8 | +class ChangeImageState extends UserAvatarState { | |
9 | + final String imageUrl; | |
10 | + ChangeImageState(this.imageUrl); | |
11 | +} | |
12 | + | |
13 | +class ChangeUserEnterAppState extends UserAvatarState{} | |
9 | 14 | \ No newline at end of file | ... | ... |
lib/utils/aliyun_oss_util.dart
1 | 1 | import 'package:dio/dio.dart'; |
2 | +import 'package:flutter/cupertino.dart'; | |
2 | 3 | import 'package:flutter_oss_aliyun/flutter_oss_aliyun.dart'; |
3 | 4 | import 'package:wow_english/common/request/request_client.dart'; |
4 | 5 | import 'package:wow_english/models/aliyun_oss_upload_sts_entity.dart'; |
... | ... | @@ -12,7 +13,12 @@ class AliyunOssUtil { |
12 | 13 | String fileName = filePath.substring(filePath.lastIndexOf("/") + 1, filePath.length); |
13 | 14 | Log.d("待上传文件fileName: $fileName"); |
14 | 15 | // 获取鉴权信息 |
15 | - AliyunOssUploadStsEntity stsEntity = await _getSts(fileName); | |
16 | + AliyunOssUploadStsEntity? stsEntity = await _getSts(fileName); | |
17 | + if(stsEntity == null) { | |
18 | + // todo 为空的情况抛出错误 | |
19 | + return ''; | |
20 | + } | |
21 | + debugPrint('鉴权信息$stsEntity'); | |
16 | 22 | // 鉴权 |
17 | 23 | Client.init( |
18 | 24 | ossEndpoint: stsEntity.endpoint, |
... | ... | @@ -43,8 +49,9 @@ class AliyunOssUtil { |
43 | 49 | } |
44 | 50 | |
45 | 51 | /// 获取鉴权信息 |
46 | - static Future<AliyunOssUploadStsEntity> _getSts(String fileName) async { | |
47 | - var result = await requestClient.get(Apis.aliyunOssSts, queryParameters: {'fileName': fileName}); | |
52 | + static Future<AliyunOssUploadStsEntity?> _getSts(String fileName) async { | |
53 | + var result = await requestClient.get<AliyunOssUploadStsEntity>(Apis.aliyunOssSts, queryParameters: {'fileName': fileName}); | |
54 | + debugPrint('鉴权结果$result'); | |
48 | 55 | return result; |
49 | 56 | } |
50 | 57 | } | ... | ... |