From f14dcfd967404e197e7ec995ca8d6f2b090d3b7d Mon Sep 17 00:00:00 2001
From: xm <1271024303@qq.com>
Date: 星期五, 11 九月 2020 09:16:59 +0800
Subject: [PATCH] 优化多功能面板:绑定温湿度传感器目标,和设备列表回路显示。优化数据矫正功能温湿度度不设置的情况。优化门锁时间设置最后一天和最后最后一个月的时间显示等 细节

---
 ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlGatewayBackupLogic.cs |  106 ++++++++++++++++++++++++++++-------------------------
 1 files changed, 56 insertions(+), 50 deletions(-)

diff --git a/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlGatewayBackupLogic.cs b/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlGatewayBackupLogic.cs
index e07d3bc..12770b5 100755
--- a/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlGatewayBackupLogic.cs
+++ b/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlGatewayBackupLogic.cs
@@ -40,16 +40,16 @@
         /// </summary>
         /// <param name="realGateway">鐪熷疄鐗╃悊缃戝叧瀵硅薄</param>
         /// <param name="backupName">闇�瑕佸垱寤虹殑澶囦唤鐨勫悕瀛�</param>
-        public async void DoBackupGateway(ZbGateway realGateway, string backupName)
+        public void DoBackupGateway(ZbGateway realGateway, string backupName)
         {
             //灞曞紑杩涘害鏉�
             ProgressFormBar.Current.Start();
             //鍒涘缓澶囦唤鏂囦欢
             ProgressFormBar.Current.SetMsg(Language.StringByID(R.MyInternationalizationString.uCreatBackupFile));
-            await System.Threading.Tasks.Task.Delay(1000);
+            System.Threading.Thread.Sleep(1000);
 
             //鍒涘缓涓�涓浠藉悕瀛�
-            string backupClassId = await HdlBackupLogic.Current.CreatNewBackupNameToDB(backupName, 2, HdlGatewayLogic.Current.GetGatewayId(realGateway));
+            string backupClassId = HdlBackupLogic.Current.CreatNewBackupNameToDB(backupName, 2, realGateway.GwId);
             if (backupClassId == null)
             {
                 //鍏抽棴杩涘害鏉�
@@ -58,33 +58,33 @@
             }
 
             //淇濆瓨鍗忚皟鍣ㄧ殑nv鍒嗗尯缁勭綉淇℃伅
-            bool result = this.SaveNVFile(realGateway);
-            if (result == false)
-            {
-                //濡傛灉涓婁紶澶辫触鐨勮瘽锛屽氨鎶婂畠鍒犻櫎
-                await HdlBackupLogic.Current.DeleteDbBackupData(backupClassId);
-                //鍏抽棴杩涘害鏉�
-                ProgressFormBar.Current.Close();
-                return;
-            }
+            //bool result = this.SaveNVFile(realGateway);
+            //if (result == false)
+            //{
+            //    //濡傛灉涓婁紶澶辫触鐨勮瘽锛屽氨鎶婂畠鍒犻櫎
+            //    await HdlBackupLogic.Current.DeleteDbBackupData(backupClassId);
+            //    //鍏抽棴杩涘害鏉�
+            //    ProgressFormBar.Current.Close();
+            //    return;
+            //}
 
             //鎵撳紑鍗忚皟鍣ㄤ覆鍙e彂閫佸姛鑳�
-            result = this.OpenZbMsComSend(realGateway);
-            if (result == false)
-            {
-                //濡傛灉涓婁紶澶辫触鐨勮瘽锛屽氨鎶婂畠鍒犻櫎
-                await HdlBackupLogic.Current.DeleteDbBackupData(backupClassId);
-                //鍏抽棴杩涘害鏉�
-                ProgressFormBar.Current.Close();
-                return;
-            }
+            //result = this.OpenZbMsComSend(realGateway);
+            //if (result == false)
+            //{
+            //    //濡傛灉涓婁紶澶辫触鐨勮瘽锛屽氨鎶婂畠鍒犻櫎
+            //    await HdlBackupLogic.Current.DeleteDbBackupData(backupClassId);
+            //    //鍏抽棴杩涘害鏉�
+            //    ProgressFormBar.Current.Close();
+            //    return;
+            //}
 
             //寮�濮嬩笂浼犳暟鎹�
-            result = this.StartUpLoadData(realGateway, backupClassId);
+            bool result = this.StartUpLoadData(realGateway, backupClassId);
             if (result == false)
             {
                 //濡傛灉涓婁紶澶辫触鐨勮瘽锛屽氨鎶婂畠鍒犻櫎
-                await HdlBackupLogic.Current.DeleteDbBackupData(backupClassId);
+                HdlBackupLogic.Current.DeleteDbBackupData(backupClassId);
                 //鍏抽棴杩涘害鏉�
                 ProgressFormBar.Current.Close();
                 return;
@@ -308,6 +308,8 @@
                 this.ShowErrorMsg(msg);
                 return false;
             }
+            System.Threading.Thread.Sleep(1000);
+
             return success;
         }
 
@@ -320,12 +322,13 @@
         /// </summary>
         /// <param name="realGateway">鐪熷疄鐗╃悊缃戝叧瀵硅薄</param>
         /// <param name="backupId">澶囦唤涓婚敭</param>
-        public bool RecoverGateway(ZbGateway realGateway, string backupId)
+        /// <param name="isAutoBack">0:鑾峰彇缃戝叧鎵嬪姩澶囦唤鏂囦欢鍒楄〃 1:鑾峰彇缃戝叧鑷姩澶囦唤鏂囦欢鍒楄〃</param>
+        public bool RecoverGateway(ZbGateway realGateway, string backupId, int isAutoBack)
         {
             //灞曞紑杩涘害鏉�
             ProgressFormBar.Current.Start();
             //浠庝簯绔幏鍙栧浠芥枃浠跺垪琛�
-            var result = this.GetGatewayFileList(realGateway, backupId);
+            var result = this.GetGatewayFileList(realGateway, backupId, isAutoBack);
             if (result == false)
             {
                 //鍏抽棴杩涘害鏉�
@@ -334,7 +337,7 @@
             }
 
             //浠庝簯绔笅杞藉浠芥枃浠�
-            result = this.DownloadGatewayFile(realGateway, backupId);
+            result = this.DownloadGatewayFile(realGateway, backupId, isAutoBack);
             if (result == false)
             {
                 //鍏抽棴杩涘害鏉�
@@ -342,23 +345,23 @@
                 return false;
             }
 
-            //鎭㈠鍗忚皟鍣╪v鍒嗗尯鐨勭粍缃戜俊鎭�
-            result = this.RestoreGatewayNV(realGateway);
-            if (result == false)
-            {
-                //鍏抽棴杩涘害鏉�
-                ProgressFormBar.Current.Close();
-                return false;
-            }
+            ////鎭㈠鍗忚皟鍣╪v鍒嗗尯鐨勭粍缃戜俊鎭�
+            //result = this.RestoreGatewayNV(realGateway);
+            //if (result == false)
+            //{
+            //    //鍏抽棴杩涘害鏉�
+            //    ProgressFormBar.Current.Close();
+            //    return false;
+            //}
 
             //鎵撳紑鍗忚皟鍣ㄤ覆鍙e彂閫佸姛鑳�
-            result = this.OpenZbMsComSend(realGateway);
-            if (result == false)
-            {
-                //鍏抽棴杩涘害鏉�
-                ProgressFormBar.Current.Close();
-                return false;
-            }
+            //result = this.OpenZbMsComSend(realGateway);
+            //if (result == false)
+            //{
+            //    //鍏抽棴杩涘害鏉�
+            //    ProgressFormBar.Current.Close();
+            //    return false;
+            //}
 
             //閲嶅惎缃戝叧绯荤粺
             result = this.GatewayReboot(realGateway);
@@ -377,7 +380,7 @@
         /// <param name="realGateway"></param>
         /// <param name="backupClassId"></param>
         /// <returns></returns>
-        private bool GetGatewayFileList(ZbGateway realGateway, string backupClassId)
+        private bool GetGatewayFileList(ZbGateway realGateway, string backupClassId, int isAutoBack)
         {
             //姝e湪鑾峰彇澶囦唤鏂囦欢鍒楄〃
             ProgressFormBar.Current.SetMsg(Language.StringByID(R.MyInternationalizationString.uBackupFileListGetting));
@@ -419,8 +422,8 @@
             var jObject = new Newtonsoft.Json.Linq.JObject { { "Cluster_ID", 0 }, { "Command", 6202 } };
             var data = new Newtonsoft.Json.Linq.JObject {
                 { "url", fullUrl }, { "RequestVersion", Common.CommonPage.RequestVersion },
-                { "LoginAccessToken", UserCenterLogic.GetConnectMainToken() }, { "IsGatewayAutoBackup", 0 },
-                { "BackupClassId", backupClassId },{ "GatewayUniqueId",HdlGatewayLogic.Current.GetGatewayId(realGateway)},
+                { "LoginAccessToken", UserCenterLogic.GetConnectMainToken() }, { "IsGatewayAutoBackup", isAutoBack },
+                { "BackupClassId", backupClassId },{ "GatewayUniqueId",realGateway.GwId},
                 { "IsOtherAccountCtrl",connectMode == HttpConnectMode.Admin?1:0}
             };
             jObject.Add("Data", data);
@@ -457,7 +460,7 @@
         /// <param name="realGateway"></param>
         /// <param name="backupClassId"></param>
         /// <returns></returns>
-        private bool DownloadGatewayFile(ZbGateway realGateway, string backupClassId)
+        private bool DownloadGatewayFile(ZbGateway realGateway, string backupClassId, int isAutoBack)
         {
             //姝e湪涓嬭浇澶囦唤鏂囦欢
             ProgressFormBar.Current.SetMsg(Language.StringByID(R.MyInternationalizationString.uBackupFileDownloading));
@@ -517,8 +520,8 @@
             var jObject = new Newtonsoft.Json.Linq.JObject { { "Cluster_ID", 0 }, { "Command", 6203 } };
             var data = new Newtonsoft.Json.Linq.JObject {
                 { "url", fullUrl }, { "RequestVersion", Common.CommonPage.RequestVersion },
-                { "LoginAccessToken", UserCenterLogic.GetConnectMainToken() }, { "IsGatewayAutoBackup", 0 },
-                { "BackupClassId", backupClassId },{ "GatewayUniqueId",HdlGatewayLogic.Current.GetGatewayId(realGateway)},
+                { "LoginAccessToken", UserCenterLogic.GetConnectMainToken() }, { "IsGatewayAutoBackup", isAutoBack },
+                { "BackupClassId", backupClassId },{ "GatewayUniqueId",realGateway.GwId},
                 { "IsOtherAccountCtrl",connectMode == HttpConnectMode.Admin?1:0}
             };
             jObject.Add("Data", data);
@@ -650,7 +653,7 @@
             //缃戝叧宸茬粡鎺ユ敹鍒伴噸鍚懡浠�,鎺ヤ笅鏉ュ幓鍒ゆ柇缃戝叧鏄惁閲嶅惎瀹屾垚
             bool gatewatAction = false;
             bool threadAction = true;
-            HdlThreadLogic.Current.RunThread(async () =>
+            HdlThreadLogic.Current.RunThread(() =>
             {
                 timeOut = 0;
                 while (gatewatAction == false)
@@ -659,7 +662,7 @@
                     if (timeOut >= 65 && timeOut % 5 == 0)
                     {
                         //5绉掍竴娆�,鍘昏幏鍙栫増鏈�
-                        var data = await HdlGatewayLogic.Current.GetGatewayNewInfoAsync(realGateway, ShowErrorMode.NO);
+                        var data = HdlGatewayLogic.Current.GetGatewayInfo(realGateway, false, ShowErrorMode.NO);
                         if (data != null)
                         {
                             gatewatAction = true;
@@ -667,7 +670,7 @@
                             break;
                         }
                     }
-                    await System.Threading.Tasks.Task.Delay(1000);
+                    System.Threading.Thread.Sleep(1000);
                     timeOut++;
                     //璁剧疆杩涘害鍊�
                     ProgressFormBar.Current.SetValue(timeOut, 180);
@@ -685,6 +688,9 @@
             }
             if (gatewatAction == true)
             {
+                //璁剧疆杩涘害鍊�:100%
+                ProgressFormBar.Current.SetValue(1, 1);
+                System.Threading.Thread.Sleep(1000);
                 //缃戝叧鏁版嵁鎭㈠鎴愬姛!
                 string msg = Language.StringByID(R.MyInternationalizationString.uRestoreGatewayDataSuccess);
                 this.ShowTipMsg(msg);

--
Gitblit v1.8.0