From a051c37a96a4b518b1bf1689252649c32430194f Mon Sep 17 00:00:00 2001
From: WJC <wjc@hdlchina.com.cn>
Date: 星期五, 10 四月 2020 15:49:12 +0800
Subject: [PATCH] 2020-04-10-0-1

---
 ZigbeeApp/Shared/Phone/Device/Logic/SkipView.cs |  207 +++++++++++++++++++++++++++++----------------------
 1 files changed, 118 insertions(+), 89 deletions(-)

diff --git a/ZigbeeApp/Shared/Phone/Device/Logic/SkipView.cs b/ZigbeeApp/Shared/Phone/Device/Logic/SkipView.cs
index 66a6f74..0dda96c 100644
--- a/ZigbeeApp/Shared/Phone/Device/Logic/SkipView.cs
+++ b/ZigbeeApp/Shared/Phone/Device/Logic/SkipView.cs
@@ -61,40 +61,33 @@
                         {
                             Common.Logic.LogicDviceList.AddRange(LocalDevice.Current.listAllDevice.ToArray());
                         }
-                        int h =int.Parse(DateTime.Now.ToString("hh"));
-                        int m = int.Parse(DateTime.Now.ToString("mm"));
-                        //榛樿涓�涓椂闂存(寮�濮嬫椂闂翠负:绯荤粺褰撳墠锛岀粨鏉熸椂闂翠负:寮�濮嬫椂闂�+1涓椂闂�)
-                        Dictionary<string, string> timeDictionary = new Dictionary<string, string>();
-                        timeDictionary.Add("Type", "5");
-                        timeDictionary.Add("IsValid", "1");
-                        timeDictionary.Add("StartHour", h.ToString());
-                        timeDictionary.Add("StartMin", m.ToString());
-                        if (h + 1 == 24)
-                        {
-                            //缁撴潫鏃堕棿瓒呭嚭24灏忔椂澶勭悊鏂规硶;
-                            timeDictionary.Add("StopHour", h.ToString());
-                            timeDictionary.Add("StopMin", "59");
-                        }
-                        else
-                        {
-                            timeDictionary.Add("StopHour", (h + 1).ToString());
-                            timeDictionary.Add("StopMin", m.ToString());
-                        }
+                        //璇诲彇绯荤粺褰撳墠鏃堕棿锛氭椂-鍒�
+                        //璇诲彇绯荤粺褰撳墠鏃堕棿锛氭椂-鍒�
+                        var h = DateTime.Now.ToString("HH");
+                        var m = DateTime.Now.ToString("mm");
+                        Dictionary<string, string> timeConditionsInfo = new Dictionary<string, string>();
+                        timeConditionsInfo.Add("Type", "0");
+                        timeConditionsInfo.Add("IsValid", "1");
+                        timeConditionsInfo.Add("DateType", "0");
+                        timeConditionsInfo.Add("RemindTime", "0");
+                        timeConditionsInfo.Add("EnDelay", "0");
+                        timeConditionsInfo.Add("DelayTime", "0");
+                        timeConditionsInfo.Add("DoorLockOpenDelayTime", "0");
+                        timeConditionsInfo.Add("StartHour", h);
+                        timeConditionsInfo.Add("StartMin", m);
                         Dictionary<string, object> actionsInfo = new Dictionary<string, object>();
                         actionsInfo.Add("LinkType", 8);
-                        //actionsInfo.Add("DeviceAddr", doorLock.DeviceAddr);
-                        //actionsInfo.Add("Epoint", doorLock.DeviceEpoint);
-                        actionsInfo.Add("DeviceAddr","jtghkh123");
-                        actionsInfo.Add("Epoint", "1");
+                        actionsInfo.Add("DeviceAddr", doorLock.DeviceAddr);
+                        actionsInfo.Add("Epoint", doorLock.DeviceEpoint);
                         actionsInfo.Add("PassData", "055704010112");//榛樿闂ㄩ攣甯稿紑
-                  
+
                         //new涓�涓柊閫昏緫瀵硅薄锛�
                         //鏂板闂ㄩ攣甯稿紑妯″紡鑷姩鍖栧叆鍙o紱
                         Common.Logic.CurrentLogic = new Common.Logic();
                         Common.Logic.CurrentLogic.IsEnable = 1;//榛樿涓哄紑
                         Common.Logic.CurrentLogic.LogicType = 2;//鏍囪閫昏緫绫诲瀷
-                        Common.Logic.CurrentLogic.LogicName = Language.StringByID(MyInternationalizationString.automation1);
-                        Common.Logic.CurrentLogic.Conditions.Add(timeDictionary);//娣诲姞鏉′欢
+                        Common.Logic.CurrentLogic.LogicName = Language.StringByID(MyInternationalizationString.openmode);
+                        Common.Logic.CurrentLogic.Conditions.Add(timeConditionsInfo);//娣诲姞鏉′欢
                         Common.Logic.CurrentLogic.Actions.Add(actionsInfo);//娣诲姞鐩爣
                         var oneLogic = new OneLogic();
                         UserView.HomePage.Instance.AddChidren(oneLogic);
@@ -300,36 +293,43 @@
         private static async void Read(VerticalRefreshLayout logicScrolView, bool no)
         {
             CommonPage.Loading.Start();
-            if (Common.Logic.LogicList.Count == 0)
+            try
             {
-                var Idlist1 = await Send.GetLogicId(0);//
-                var Idlist2 = await Send.GetLogicId(2);//闂ㄩ攣甯稿紑妯″紡
-                if (Idlist1.Count != 0)
+                if (Common.Logic.LogicList.Count == 0)
                 {
-                    var listlogic1 = await Send.ReadList(Idlist1.Count, 0);
-                    for (int j = 0; j < listlogic1.Count; j++)
+                    var Idlist1 = await Send.GetLogicId(0);//
+                    var Idlist2 = await Send.GetLogicId(2);//闂ㄩ攣甯稿紑妯″紡
+                    if (Idlist1.Count != 0)
                     {
-                        var logic = listlogic1[j];
-                        if (logic.LogicType != 0)
+                        var listlogic1 = await Send.ReadList(Idlist1.Count, 0);
+                        for (int j = 0; j < listlogic1.Count; j++)
                         {
-                            continue;
+                            var logic = listlogic1[j];
+                            if (logic.LogicType != 0)
+                            {
+                                continue;
+                            }
+                            Common.Logic.LogicList.Add(logic);
                         }
-                        Common.Logic.LogicList.Add(logic);
+                    }
+                    if (Idlist2.Count != 0)
+                    {
+                        var listlogic2 = await Send.ReadList(Idlist2.Count, 2);
+                        for (int j = 0; j < listlogic2.Count; j++)
+                        {
+                            var logic = listlogic2[j];
+                            if (logic.LogicType != 2)
+                            {
+                                continue;
+                            }
+                            Common.Logic.LogicList.Add(logic);
+                        }
                     }
                 }
-                if (Idlist2.Count != 0)
-                {
-                    var listlogic2 = await Send.ReadList(Idlist2.Count, 2);
-                    for (int j = 0; j < listlogic2.Count; j++)
-                    {
-                        var logic = listlogic2[j];
-                        if (logic.LogicType != 2)
-                        {
-                            continue;
-                        }
-                        Common.Logic.LogicList.Add(logic);
-                    }
-                }
+            }
+            catch (Exception e)
+            {
+                var dd = e.Message;
             }
             //鑷姩鍖�
             Automationview(logicScrolView, no);
@@ -395,7 +395,7 @@
             int i = 1;//灞�閮ㄥ彉閲忥紝榛樿鏄涓�鏉¢�昏緫;
             foreach (var logic in Common.Logic.LogicList)
             {
-               
+
                 var fLayout = new FrameLayout
                 {
                     Height = Application.GetRealHeight(190 + 30),
@@ -403,7 +403,7 @@
                     BackgroundColor = ZigbeeColor.Current.LogicBackgroundColor,
                 };
                 refresview.AddChidren(fLayout);
-            
+
                 var logicRowlayout = new RowLayout
                 {
                     Height = Application.GetRealHeight(190 + 30),
@@ -421,7 +421,7 @@
                     logicRowlayout.SetCornerWithSameRadius(Application.GetRealHeight(58), HDLUtils.RectCornerTopLeft);
                     i = 2;
                 }
-              
+               
                 var logicnameBtn = new Button
                 {
                     Height = Application.GetRealHeight(58),
@@ -462,7 +462,7 @@
                         logic.IsEnable = 0;
                         StatusColor(logic, logicRowlayout, 0);
                     }
-                   Send.LogicControlSwitch(logic);
+                    Send.LogicControlSwitch(logic);
                     //Logic.Send.AddModifyLogic(logic);
                 };
                 if (logic.IsEnable == 1)
@@ -483,6 +483,10 @@
                     TextColor = ZigbeeColor.Current.LogicBtnSaveTextColor,
                 };
                 logicRowlayout.AddRightView(edit);
+                if (logic.LogicType == 2)
+                {
+                    edit.TextID = MyInternationalizationString.look;
+                }
                 edit.MouseUpEventHandler += (sender, e) =>
                 {
                     Common.Logic.CurrentLogic = logic;
@@ -533,6 +537,8 @@
                     BackgroundColor = ZigbeeColor.Current.LogicRowLayoutLineColor,
                 };
                 fLayout.AddChidren(line);
+                
+              
             }
 
         }
@@ -695,14 +701,15 @@
         #endregion
 
         /// <summary>
-        /// 闂ㄩ攣鍙栨秷璁剧疆鐢ㄧ殑鏂规硶(鐩稿綋涓�涓叧闂父寮�妯″紡鎸夐挳,涓嶉渶瑕佹樉绀鸿鑷姩鍖�)
+        /// 闂ㄩ攣鍙栨秷璁剧疆鐢ㄧ殑鏂规硶(鐩稿綋涓�涓叧闂父寮�妯″紡鎸夐挳,鍒嗙被-鑷姩鍖�-涓嶉渶瑕佹樉绀鸿鑷姩鍖�)
         /// </summary>
         /// <param name="timeVlaue">鏃堕棿鍊�</param>
         /// <param name="common">璁惧</param>
         /// <returns></returns>
-        public static void LockAddModifyLogic(int timeVlaue, CommonDevice common)
+        public  static void LockAddModifyLogic(int timeVlaue, CommonDevice common)
         {
-            var h = DateTime.Now.ToString("hh");
+            //璇诲彇绯荤粺褰撳墠鏃堕棿锛氭椂-鍒�
+            var h = DateTime.Now.ToString("HH");
             var m = DateTime.Now.ToString("mm");
             Dictionary<string, string> timeConditionsInfo = new Dictionary<string, string>();
             timeConditionsInfo.Add("Type", "0");
@@ -710,7 +717,7 @@
             timeConditionsInfo.Add("DateType", "0");
             timeConditionsInfo.Add("RemindTime", "0");
             timeConditionsInfo.Add("EnDelay", "0");
-            timeConditionsInfo.Add("DelayTime", "0"); 
+            timeConditionsInfo.Add("DelayTime", "0");
             timeConditionsInfo.Add("StartHour", h);
             timeConditionsInfo.Add("StartMin", m);
             timeConditionsInfo.Add("DoorLockOpenDelayTime", timeVlaue.ToString());
@@ -727,57 +734,79 @@
             currentLogic.LogicName = Language.StringByID(R.MyInternationalizationString.openmode);
             currentLogic.Conditions.Add(timeConditionsInfo);
             currentLogic.Actions.Add(actionsInfo);
-            //淇敼鎴栬�呮坊鍔犳槸鏍规嵁閫昏緫id鍊硷紙0鏂板锛�1锛屼慨鏀癸級
+            Exist(3);//鏌ユ壘鏄惁瀛樺湪璁剧疆杩囧け鏁堟椂闂�(鏈夌殑璇濆垹闄わ紝鍐嶆坊鍔�)
             Send.AddModifyLogic(currentLogic);
 
         }
+
         ///<summary>
-        /// 闂ㄩ攣鍒犻櫎閫昏緫
+        /// s-one闂ㄩ攣鏄惁瀛樺湪鑷姩鍖栫殑鏂规硶(true涓哄瓨鍦�)
         /// </summary>
-        public static async void LockDelLogic(CommonDevice common)
+        public static async System.Threading.Tasks.Task<bool> Exist(int valueInt=2)
         {
-            int logicId = 0;
+            bool exist = false;
+            var Idlist = await Send.GetLogicId(valueInt);
+            if (Idlist.Count != 0)
+            {
+                if (valueInt==3) {
+                    for (int i = 0; i < Idlist.Count; i++)
+                    {
+                        //valueInt=3涓�鏉$壒娈婄殑鑷姩鍖�(鐢ㄦ潵璁剧疆澶辨晥鏃堕棿)
+                        Send.DelLogic(Idlist[i]);
+                    }
+                }
+                exist = true;
+            }
+            return exist;
+        }
+
+        ///<summary>
+        /// s-one闂ㄩ攣纭鍙栨秷(浣挎弧瓒虫潯浠舵墍鏈夐�昏緫澶辫兘涓�娆�)鍙戦�佺殑鏂规硶
+        /// </summary>
+        public static async void LockCloseLogic(CommonDevice common)
+        {
+            //璇诲彇绯荤粺褰撳墠鏃堕棿锛氭椂-鍒�
+            int h =int.Parse(DateTime.Now.ToString("HH"));
+            int m= int.Parse(DateTime.Now.ToString("mm"));
+            //杞寲涓哄灏戝垎閽�;
+            int s = h * 60 + m;
+            var logicList = new List<Common.Logic>();
+            logicList.Clear();
             var Idlist = await Send.GetLogicId(2);
             if (Idlist.Count != 0)
             {   //鍏堝幓璇诲彇缃戝叧鐪嬫槸鍚﹀瓨鍦ㄦ暟鎹�;
-                var listlogic = await Send.ReadList(Idlist.Count, 2);
-                for (int j = 0; j < listlogic.Count; j++)
+                var list = await Send.ReadList(Idlist.Count, 2);
+                for (int j = 0; j < list.Count; j++)
                 {
-                    var logic = listlogic[j];
-                    foreach (var actions in logic.Actions)
+                    var logic = list[j];
+                    foreach (var conditions in logic.Conditions)
                     {
-                        var linkType = actions["LinkType"].ToString();
-                        if (linkType != "8")
+                        var linkType = conditions["Type"];
+                        if (linkType == "5")
                         {
-                            //鐢ㄦ埛鏈夊彲鑳藉湪鑷姩鍖栭偅閲屽啀娆$紪杈�;
-                            //蹇呴』杩囨护鎺変笉闇�瑕佺殑淇℃伅(杈撳嚭鍔熻兘寤舵椂:鏄病鏈塂eviceAddr鍜孍point),鍚﹀垯鏈夊紓甯�;
-                            continue;
+                            int startMin = int.Parse(conditions["StartMin"]);
+                            int startHour = int.Parse(conditions["StartHour"]);
+                            int stopMin = int.Parse(conditions["StopMin"]);
+                            int stopHour = int.Parse(conditions["StopHour"]);
+                            int s1 = startMin + startHour * 60;//寮�濮嬫椂闂村��
+                            int s2 = stopMin + stopHour * 60;//缁撴潫鏃堕棿鍊�
+                            if (s >= s1&&s<=s2)
+                            {
+                                //鏌ユ壘绯荤粺鏃堕棿鍊兼槸鍚﹀睘浜庤繖涓寖鍥达紱
+                                logicList.Add(logic);
+                            }
                         }
-                        var obj1 = actions["DeviceAddr"].ToString();
-                        var obj2 = actions["Epoint"].ToString();
-                        if (common.DeviceAddr == obj1 && common.DeviceEpoint.ToString() == obj2)
-                        {
-                            logicId = logic.LogicId;
-                            break;
-                            //鎵惧埌璺冲嚭寰幆浣�
-                        }
-
                     }
-                    if (logicId != 0)
-                    {
-                        break;
-                        //鎵惧埌璺冲嚭寰幆浣�
-                    }
+                  
                 }
             }
-            if (logicId == 0)
+            foreach (var logic in logicList)
             {
-                //娌℃湁鎵惧埌logicId鍒犻櫎娌℃湁鎰忎箟;
-                return;
+                logic.IsEnable = 3;//鏀瑰彉閫昏緫浣胯兘鐘舵��;
+                //鐢╢oreach鍙戦�佸懡浠わ紱
+                Send.AddModifyLogic(logic);
             }
-            Send.DelLogic(logicId);
         }
-
     }
 }
 

--
Gitblit v1.8.0