From 9c8baf7e7e1169ebdf7d5f7ed33ab29dd5fcbf18 Mon Sep 17 00:00:00 2001
From: JLChen <551775569@qq.com>
Date: 星期一, 14 十二月 2020 17:45:17 +0800
Subject: [PATCH] 2020-12-14 1.解锁设置问题修复,增加面容ID验证。2.错误码对接增加。

---
 HDL_ON/Entity/FunctionList.cs |  101 ++++++++++++++++++++------------------------------
 1 files changed, 41 insertions(+), 60 deletions(-)

diff --git a/HDL_ON/Entity/FunctionList.cs b/HDL_ON/Entity/FunctionList.cs
index fcc971a..0610a77 100644
--- a/HDL_ON/Entity/FunctionList.cs
+++ b/HDL_ON/Entity/FunctionList.cs
@@ -97,7 +97,7 @@
         /// <summary>
         /// 鍔熻兘鍒楄〃
         /// </summary>
-        List<Function> deviceFunctionList;
+        List<Function> deviceFunctionList = new List<Function>();
 
 
         /// <summary>
@@ -131,19 +131,23 @@
                         case SPK.LightRGBW:
                         case SPK.LightCCT:
                             _FunctionList.lights.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<Light>(functionDataString));
+                            deviceFunctionList.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<Light>(functionDataString));
                             break;
                         case SPK.CurtainRoller:
                         case SPK.CurtainShades:
                         case SPK.CurtainSwitch:
                         case SPK.CurtainTrietex:
                             _FunctionList.curtains.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<Curtain>(functionDataString));
+                            deviceFunctionList.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<Curtain>(functionDataString));
                             break;
                         case SPK.AcStandard:
                             _FunctionList.aCs.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<AC>(functionDataString));
+                            deviceFunctionList.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<AC>(functionDataString));
                             break;
                         case SPK.FloorHeatStandard:
                             //鎭㈠鍦扮儹鏁版嵁
                             _FunctionList.floorHeatings.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<FloorHeating>(functionDataString));
+                            deviceFunctionList.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<FloorHeating>(functionDataString));
                             break;
                         case SPK.SensorPm25:
                         case SPK.SensorCO2:
@@ -152,18 +156,22 @@
                         case SPK.SensorHumidity:
                             //鎭㈠鐜鏁版嵁
                             _FunctionList.sensorsEnvironmentalScience.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<Sensor>(functionDataString));
+                            deviceFunctionList.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<Sensor>(functionDataString));
                             break;
                         case SPK.ElectricSocket:
                             //鎭㈠鎻掑骇鏁版嵁
                             _FunctionList.switchSockets.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<SwitchSocket>(functionDataString));
+                            deviceFunctionList.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<SwitchSocket>(functionDataString));
                             break;
                         case SPK.ElectricTV:
                             //鎭㈠鐢佃鏁版嵁
                             _FunctionList.tVs.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<TV>(functionDataString));
+                            deviceFunctionList.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<TV>(functionDataString));
                             break;
                         case SPK.ElectricFan:
                             //鎭㈠椋庢墖鏁版嵁
                             _FunctionList.fans.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<Fan>(functionDataString));
+                            deviceFunctionList.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<Fan>(functionDataString));
                             break;
                     }
                 }
@@ -177,23 +185,12 @@
             }
         }
 
-
-        /// <summary>
-        /// 鑾峰彇鎵�鏈夊姛鑳藉垪琛�
-        /// </summary>
-        public List<Function> GetAllFunction()
-        {
-            var fs = new List<Function>();
-            fs.AddRange(GetAllDeviceFunctionList());
-            return fs;
-        }
-
         /// <summary>
         /// 鑾峰彇璁惧鍔熻兘鍒楄〃
         /// </summary>
-        public List<Function> GetAllDeviceFunctionList()
+        public List<Function> GetDeviceFunctionList()
         {
-            //if (deviceFunctionList == null)
+            if (deviceFunctionList == null || deviceFunctionList.Count == 0)
             {
                 deviceFunctionList = new List<Function>();
                 deviceFunctionList.AddRange(aCs);
@@ -217,18 +214,19 @@
         /// <summary>
         /// 娓呯┖璁惧鍔熻兘鍒楄〃
         /// </summary>
-        public void ClearAllDeviceFunctionList()
+        public void Clear()
         {
-            aCs = new List<AC>();
-            lights = new List<Light>();
-            curtains = new List<Curtain>();
-            floorHeatings = new List<FloorHeating>();
-            tVs = new List<TV>();
-            switchSockets = new List<SwitchSocket>();
-            fans = new List<Fan>();
-            sensorsEnvironmentalScience = new List<Sensor>();
-            scenes = new List<Scene>();
-            deviceFunctionList = null;
+            _FunctionList.aCs = new List<AC>();
+            _FunctionList.lights = new List<Light>();
+            _FunctionList.curtains = new List<Curtain>();
+            _FunctionList.floorHeatings = new List<FloorHeating>();
+            _FunctionList.tVs = new List<TV>();
+            _FunctionList.switchSockets = new List<SwitchSocket>();
+            _FunctionList.fans = new List<Fan>();
+            _FunctionList.sensorsEnvironmentalScience = new List<Sensor>();
+            _FunctionList.scenes = new List<Scene>();
+            _FunctionList.deviceFunctionList = null;
+            _FunctionList = null;
         }
 
         /// <summary>
@@ -242,41 +240,41 @@
             {
                 case FunctionType.AC:
                     var sidObj =  Newtonsoft.Json.JsonConvert.DeserializeObject<AC>(Newtonsoft.Json.JsonConvert.SerializeObject(sidObj0));
-                    DB_ResidenceData.functionList.aCs.Add(sidObj);
+                    List.aCs.Add(sidObj);
                     sidObj.SaveFunctionData(false);
                     break;
                 case FunctionType.FloorHeating:
                     var sidObj1 =  Newtonsoft.Json.JsonConvert.DeserializeObject<FloorHeating>(Newtonsoft.Json.JsonConvert.SerializeObject(sidObj0));
-                    DB_ResidenceData.functionList.floorHeatings.Add(sidObj1);
+                    List.floorHeatings.Add(sidObj1);
                     sidObj1.SaveFunctionData(false);
                     break;
                 case FunctionType.Dimmer:
                 case FunctionType.RGB:
                 case FunctionType.Relay:
                     var sidObj2 =  Newtonsoft.Json.JsonConvert.DeserializeObject<Light>(Newtonsoft.Json.JsonConvert.SerializeObject(sidObj0));
-                    DB_ResidenceData.functionList.lights.Add(sidObj2);
+                    List.lights.Add(sidObj2);
                     sidObj2.SaveFunctionData(false);
                     break;
                 case FunctionType.Curtain:
                 case FunctionType.RollingShutter:
                 case FunctionType.MotorCurtain:
                     var sidObj3 =  Newtonsoft.Json.JsonConvert.DeserializeObject<Curtain>(Newtonsoft.Json.JsonConvert.SerializeObject(sidObj0));
-                    DB_ResidenceData.functionList.curtains.Add(sidObj3 );
+                    List.curtains.Add(sidObj3 );
                     sidObj3.SaveFunctionData(false);
                     break;
                 case FunctionType.TV:
                     var sidObj4 =  Newtonsoft.Json.JsonConvert.DeserializeObject<TV>(Newtonsoft.Json.JsonConvert.SerializeObject(sidObj0));
-                    DB_ResidenceData.functionList.tVs.Add(sidObj4);
+                    List.tVs.Add(sidObj4);
                     sidObj4.SaveFunctionData(false);
                     break;
                 case FunctionType.Socket:
                     var sidObj5 =  Newtonsoft.Json.JsonConvert.DeserializeObject<SwitchSocket>(Newtonsoft.Json.JsonConvert.SerializeObject(sidObj0));
-                    DB_ResidenceData.functionList.switchSockets.Add(sidObj5);
+                    List.switchSockets.Add(sidObj5);
                     sidObj5.SaveFunctionData(false);
                     break;
                 case FunctionType.Fan:
                     var sidObj6 =  Newtonsoft.Json.JsonConvert.DeserializeObject<Fan>(Newtonsoft.Json.JsonConvert.SerializeObject(sidObj0));
-                    DB_ResidenceData.functionList.fans.Add(sidObj6);
+                    List.fans.Add(sidObj6);
                     sidObj6.SaveFunctionData(false);
                     break;
                 case FunctionType.CO2:
@@ -285,7 +283,7 @@
                 case FunctionType.Temp:
                 case FunctionType.Humidity:
                     var sidObj7 =  Newtonsoft.Json.JsonConvert.DeserializeObject<Sensor>(Newtonsoft.Json.JsonConvert.SerializeObject(sidObj0));
-                    DB_ResidenceData.functionList.sensorsEnvironmentalScience.Add(sidObj7);
+                    List.sensorsEnvironmentalScience.Add(sidObj7);
                     sidObj7.SaveFunctionData(false);
                     break;
             }
@@ -380,17 +378,9 @@
                     var deviceList = Newtonsoft.Json.JsonConvert.DeserializeObject<DevcieApiPack>(pack.Data.ToString());
                     if (deviceList != null)
                     {
-                        ////灏嗕笅杞藉埌鍒版暟鎹叏閮ㄤ繚瀛�
-                        //new Thread(() => {
-                        //    foreach (var temp in deviceList.list)
-                        //    {
-                        //        temp.SaveFunctionData();
-                        //    }
-                        //})
-                        //{ IsBackground = true }.Start();
-                        for (int i =0;i < List.GetAllDeviceFunctionList().Count;)
+                        for (int i =0;i < List.GetDeviceFunctionList().Count;)
                         {
-                            var localFunction = List.GetAllDeviceFunctionList()[i];
+                            var localFunction = List.GetDeviceFunctionList()[i];
                             var newFunction = deviceList.list.Find((obj) => obj.deviceId == localFunction.deviceId);
                             if (newFunction == null)//濡傛灉浜戠鏈�鏂版暟鎹病鏈夎鏉℃暟鎹紝鍒欐湰鍦伴渶瑕佸垹鎺夎鏁版嵁璁板綍
                             {
@@ -401,6 +391,7 @@
                                 i++;
                                 if (localFunction.modifyTime != newFunction.modifyTime)
                                 {
+                                    MainPage.Log($"local:{localFunction.modifyTime}\r\n server:{newFunction.modifyTime}");
                                     localFunction.name = newFunction.name;
                                     localFunction.collect = newFunction.collect;
                                     localFunction.modifyTime = newFunction.modifyTime;
@@ -491,21 +482,6 @@
 
 
         /// <summary>
-        /// 鍒犻櫎鎵嬫満瀛樺偍閮芥墍鏈夌紦瀛樺姛鑳芥暟鎹�
-        /// </summary>
-        public void DelAllFunctionData()
-        {
-            var filePathList = Common.FileUtlis.Files.ReadFiles();
-            foreach (var filePath in filePathList)
-            {
-                if (filePath.StartsWith("FunctionData_") && filePath.Length == 13 + 28)
-                {
-                    Common.FileUtlis.Files.DeleteFile(filePath);
-                }
-            }
-            _FunctionList = new FunctionList();
-        }
-        /// <summary>
         /// 鍒犻櫎鍦烘櫙
         /// </summary>
         public void DeleteScene(Scene scene,bool upSevser)
@@ -573,6 +549,11 @@
                     _FunctionList.fans.Remove(_FunctionList.fans.Find((obj) => obj.deviceId == delTemp.deviceId));
                     break;
             }
+            var removeTemp = deviceFunctionList.Find((obj) => obj.deviceId == delTemp.deviceId);
+            if(removeTemp!= null)
+            {
+                deviceFunctionList.Remove(removeTemp);
+            }
             Common.FileUtlis.Files.DeleteFile(delTemp.savePath);
         }
 
@@ -601,7 +582,7 @@
                     if (DriverLayer.Control.Ins.IsRemote)
                     {
                         var functionIds = new List<string>();
-                        foreach (var function in GetAllDeviceFunctionList())
+                        foreach (var function in GetDeviceFunctionList())
                         {
                             functionIds.Add(function.deviceId);
                         }
@@ -609,7 +590,7 @@
                     }
                     else
                     {
-                        foreach (var function in GetAllDeviceFunctionList())
+                        foreach (var function in GetDeviceFunctionList())
                         {
                             switch (function.functionCategory)
                             {

--
Gitblit v1.8.0