avoid call refreshCurrentUser twice at startup (#8848)
refreshCurrentUser will be called at these 2 position: 1. runMainApp or runMobileApp in main.dart 2. when connect status is ready Both of these two happens at startup, when connect status is ready and startup time < 5 seconds, not call refreshCurrentUser Signed-off-by: 21pages <sunboeasy@gmail.com>
This commit is contained in:
		
							parent
							
								
									9f0985c842
								
							
						
					
					
						commit
						30a5d1e0e1
					
				| @ -34,6 +34,7 @@ class _OnlineStatusWidgetState extends State<OnlineStatusWidget> { | |||||||
|   final _svcStopped = Get.find<RxBool>(tag: 'stop-service'); |   final _svcStopped = Get.find<RxBool>(tag: 'stop-service'); | ||||||
|   final _svcIsUsingPublicServer = true.obs; |   final _svcIsUsingPublicServer = true.obs; | ||||||
|   Timer? _updateTimer; |   Timer? _updateTimer; | ||||||
|  |   final DateTime _appStartTime = DateTime.now(); | ||||||
| 
 | 
 | ||||||
|   double get em => 14.0; |   double get em => 14.0; | ||||||
|   double? get height => bind.isIncomingOnly() ? null : em * 3; |   double? get height => bind.isIncomingOnly() ? null : em * 3; | ||||||
| @ -176,7 +177,8 @@ class _OnlineStatusWidgetState extends State<OnlineStatusWidget> { | |||||||
|       stateGlobal.svcStatus.value = SvcStatus.notReady; |       stateGlobal.svcStatus.value = SvcStatus.notReady; | ||||||
|     } else if (statusNum == 1) { |     } else if (statusNum == 1) { | ||||||
|       stateGlobal.svcStatus.value = SvcStatus.ready; |       stateGlobal.svcStatus.value = SvcStatus.ready; | ||||||
|       if (preStatus != SvcStatus.ready) { |       if (preStatus != SvcStatus.ready && | ||||||
|  |           DateTime.now().difference(_appStartTime) > Duration(seconds: 5)) { | ||||||
|         gFFI.userModel.refreshCurrentUser(); |         gFFI.userModel.refreshCurrentUser(); | ||||||
|       } |       } | ||||||
|     } else { |     } else { | ||||||
|  | |||||||
| @ -111,9 +111,9 @@ class AbModel { | |||||||
|   Future<void> _pullAb( |   Future<void> _pullAb( | ||||||
|       {required ForcePullAb? force, required bool quiet}) async { |       {required ForcePullAb? force, required bool quiet}) async { | ||||||
|     if (bind.isDisableAb()) return; |     if (bind.isDisableAb()) return; | ||||||
|     debugPrint("pullAb, force: $force, quiet: $quiet"); |  | ||||||
|     if (!gFFI.userModel.isLogin) return; |     if (!gFFI.userModel.isLogin) return; | ||||||
|     if (force == null && listInitialized && current.initialized) return; |     if (force == null && listInitialized && current.initialized) return; | ||||||
|  |     debugPrint("pullAb, force: $force, quiet: $quiet"); | ||||||
|     if (!listInitialized || force == ForcePullAb.listAndCurrent) { |     if (!listInitialized || force == ForcePullAb.listAndCurrent) { | ||||||
|       try { |       try { | ||||||
|         // Read personal guid every time to avoid upgrading the server without closing the main window |         // Read personal guid every time to avoid upgrading the server without closing the main window | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user