From 323876bfe85fc2684871d5d95c213c6e2713f3f4 Mon Sep 17 00:00:00 2001
From: WJC <wjc@hdlchina.com.cn>
Date: 星期三, 15 四月 2020 16:07:32 +0800
Subject: [PATCH] 2020-04-15-1

---
 ZigbeeApp/Shared/Phone/Device/Logic/SkipView.cs |  156 ++++++++++++++++++++++++---------------------------
 1 files changed, 74 insertions(+), 82 deletions(-)

diff --git a/ZigbeeApp/Shared/Phone/Device/Logic/SkipView.cs b/ZigbeeApp/Shared/Phone/Device/Logic/SkipView.cs
index 0dda96c..833f0dd 100644
--- a/ZigbeeApp/Shared/Phone/Device/Logic/SkipView.cs
+++ b/ZigbeeApp/Shared/Phone/Device/Logic/SkipView.cs
@@ -13,12 +13,13 @@
         /// <summary>
         /// 鍏跺畠鐣岄潰璺宠繘鏉ョ殑鍏ュ彛
         /// </summary>
-        public static void SkipAddLogic(int intvalue,DoorLock doorLock=null,UserCenter.MemberInfoRes accountObj = null)
+        public static void SkipAddLogic(int intvalue, DoorLock doorLock = null, UserCenter.MemberInfoRes accountObj = null)
         {
             /// 0.姝e父鑷姩鍖�;1.闂ㄩ攣鑷姩鍖�;2.闂ㄩ攣甯稿紑.鍏�;
             switch (intvalue)
             {
-                case 0: {
+                case 0:
+                    {
                         //new涓�涓柊閫昏緫瀵硅薄锛�
                         //鏂板姝e父鑷姩鍖栧叆鍙�
                         Common.Logic.CurrentLogic = new Common.Logic();
@@ -29,15 +30,17 @@
                         UserView.HomePage.Instance.AddChidren(addLogicPage);
                         UserView.HomePage.Instance.PageIndex += 1;
                         addLogicPage.Show();
-                    } break;
-                case 1: {
+                    }
+                    break;
+                case 1:
+                    {
                         //杩涘叆闂ㄩ攣鑱斿姩浜嬩欢鍏ュ彛
                         Send.UserMemberInfoRes = accountObj;
                         Send.CurrentDoorLock = doorLock;
                         if (accountObj == null)
                         {
                             ///闃叉鎶涘紓甯�
-                            Send.UserMemberInfoRes = new UserCenter.MemberInfoRes(); 
+                            Send.UserMemberInfoRes = new UserCenter.MemberInfoRes();
                         }
                         if (doorLock == null)
                         {
@@ -54,8 +57,10 @@
                         UserView.HomePage.Instance.AddChidren(doorLockLogicList);
                         UserView.HomePage.Instance.PageIndex += 1;
                         doorLockLogicList.Show();
-                    } break;
-                case 2: {
+                    }
+                    break;
+                case 2:
+                    {
                         Common.Logic.LogicDviceList.Clear();
                         if (Common.Logic.LogicDviceList.Count == 0)
                         {
@@ -79,7 +84,7 @@
                         actionsInfo.Add("LinkType", 8);
                         actionsInfo.Add("DeviceAddr", doorLock.DeviceAddr);
                         actionsInfo.Add("Epoint", doorLock.DeviceEpoint);
-                        actionsInfo.Add("PassData", "055704010112");//榛樿闂ㄩ攣甯稿紑
+                        actionsInfo.Add("PassData", "055704010113");//榛樿闂ㄩ攣甯稿叧
 
                         //new涓�涓柊閫昏緫瀵硅薄锛�
                         //鏂板闂ㄩ攣甯稿紑妯″紡鑷姩鍖栧叆鍙o紱
@@ -93,7 +98,8 @@
                         UserView.HomePage.Instance.AddChidren(oneLogic);
                         UserView.HomePage.Instance.PageIndex += 1;
                         oneLogic.Show(false);
-                    } break;
+                    }
+                    break;
             }
 
         }
@@ -175,7 +181,7 @@
                 Y = scenehorizontalScrol.Bottom,
             };
             functionSceneAutoBodyView.AddChidren(logicScrolView);
-          
+
             logicScrolView.SetCornerWithSameRadius(Application.GetRealHeight(58), HDLUtils.RectCornerTopLeft);
             bool no = false;
             //鏄剧ず榛樿妯℃澘鐨勭晫闈簨浠�
@@ -282,8 +288,8 @@
                 logicScrolView.EndHeaderRefreshing();
             };
 
-           //鑷姩鍖�
-           Read(logicScrolView, no);
+            //鑷姩鍖�
+            Read(logicScrolView, no);
 
         }
         /// <summary>
@@ -339,6 +345,9 @@
         /// 鍔犺浇鑷姩鍖栧垪琛ㄧ晫闈�
         /// </summary>
         /// <param name="refresview">Refresview.</param>
+        
+        static  RowLayout selectedRow = new RowLayout() { Tag="0"};//璁板綍宸︽粦鐘舵��
+        
         private static async void Automationview(VerticalRefreshLayout refresview, bool no)
         {
             refresview.RemoveAll();
@@ -348,7 +357,7 @@
                 refresview.BackgroundColor = 0x00000000;
                 var noFrameLayout = new FrameLayout
                 {
-                    Height = Application.GetRealHeight(434 + 200 + 32 + 294-55),
+                    Height = Application.GetRealHeight(434 + 200 + 32 + 294 - 55),
                     //BackgroundColor = ZigbeeColor.Current.LogicMiddleBackgroundColor,
                 };
                 refresview.AddChidren(noFrameLayout);
@@ -356,9 +365,9 @@
 
                 var noIconBtn = new Button
                 {
-                    Y = Application.GetRealHeight(294-55),
-                    Width = Application.GetMinRealAverage(756),
-                    Height = Application.GetMinRealAverage(434),
+                    Y = Application.GetRealHeight(294 - 55),
+                    Width = Application.GetMinRealAverage(757),
+                    Height = Application.GetMinRealAverage(435),
                     UnSelectedImagePath = "Item/NoFunction.png",
                     X = Application.GetRealWidth(104),
                 };
@@ -411,17 +420,27 @@
                     LineColor = ZigbeeColor.Current.LogicBackgroundColor,
                     BackgroundColor = ZigbeeColor.Current.LogicBackgroundColor,
                     SubViewWidth = Application.GetRealWidth(184),//鏀瑰彉缂栬緫鎺т欢瀹藉害澶氬皯锛�
+                    Tag = i.ToString(),
 
                 };
                 fLayout.AddChidren(logicRowlayout);
+                //宸︽粦鑿滃崟浜嬩欢
+                logicRowlayout.OpenMenuAction += () =>
+                {
+                    if (selectedRow.Tag.ToString() != logicRowlayout.Tag.ToString())
+                    {   //淇濈暀宸︽粦鍙湁涓�涓�;
+                        selectedRow.HideMenu();//
+                    }
+                    selectedRow = logicRowlayout;
+                };
                 if (i == 1)
                 {
                     //瀹炵幇android鏄剧ず閫昏緫鍒楄〃鐨勫渾瑙�;
                     fLayout.SetCornerWithSameRadius(Application.GetRealHeight(58), HDLUtils.RectCornerTopLeft);
                     logicRowlayout.SetCornerWithSameRadius(Application.GetRealHeight(58), HDLUtils.RectCornerTopLeft);
-                    i = 2;
+                   
                 }
-               
+                i++;
                 var logicnameBtn = new Button
                 {
                     Height = Application.GetRealHeight(58),
@@ -537,8 +556,8 @@
                     BackgroundColor = ZigbeeColor.Current.LogicRowLayoutLineColor,
                 };
                 fLayout.AddChidren(line);
-                
-              
+
+
             }
 
         }
@@ -577,8 +596,8 @@
                     indexlist.Add(linkType);
                 }
             }
-             //鎺掑垪鍥炬爣椤哄簭;
-            if (indexlist.Contains("0")|| indexlist.Contains("8"))
+            //鎺掑垪鍥炬爣椤哄簭;
+            if (indexlist.Contains("0") || indexlist.Contains("8"))
             {
                 iconIndexlist.Add("0");
             }
@@ -706,7 +725,7 @@
         /// <param name="timeVlaue">鏃堕棿鍊�</param>
         /// <param name="common">璁惧</param>
         /// <returns></returns>
-        public  static void LockAddModifyLogic(int timeVlaue, CommonDevice common)
+        public static async System.Threading.Tasks.Task<bool> LockAddModifyLogic(int timeVlaue, CommonDevice common)
         {
             //璇诲彇绯荤粺褰撳墠鏃堕棿锛氭椂-鍒�
             var h = DateTime.Now.ToString("HH");
@@ -735,78 +754,51 @@
             currentLogic.Conditions.Add(timeConditionsInfo);
             currentLogic.Actions.Add(actionsInfo);
             Exist(3);//鏌ユ壘鏄惁瀛樺湪璁剧疆杩囧け鏁堟椂闂�(鏈夌殑璇濆垹闄わ紝鍐嶆坊鍔�)
-            Send.AddModifyLogic(currentLogic);
-
+            var logicIfon = await Send.AddModifyLogic(currentLogic);
+            if (logicIfon != null && logicIfon.LogicId != 0)
+            {
+                return true;
+            }
+            return false;
         }
 
-        ///<summary>
-        /// s-one闂ㄩ攣鏄惁瀛樺湪鑷姩鍖栫殑鏂规硶(true涓哄瓨鍦�)
-        /// </summary>
-        public static async System.Threading.Tasks.Task<bool> Exist(int valueInt=2)
+		///<summary>
+		/// s-one闂ㄩ攣鏄惁瀛樺湪鑷姩鍖栫殑鏂规硶;
+		/// 娉ㄦ剰锛堝弬鏁�2锛�3锛夛細valueInt=3鏄垹闄よ缃け鏁堟椂闂磋嚜鍔ㄥ寲锛泇alueInt=2鍒ゆ柇鏄惁瀛樺湪鑷姩鍖栵紱
+		/// 杩斿洖鍊硷細0涓嶅瓨鍦�;1瀛樺湪;2鍒犻櫎鎴愬姛;3鍒犻櫎澶辫触;
+		/// </summary>
+		public static async System.Threading.Tasks.Task<int> Exist(int valueInt = 2)
         {
-            bool exist = false;
+            int exist = 0;
             var Idlist = await Send.GetLogicId(valueInt);
             if (Idlist.Count != 0)
             {
-                if (valueInt==3) {
+                if (valueInt == 3)
+                {
                     for (int i = 0; i < Idlist.Count; i++)
                     {
                         //valueInt=3涓�鏉$壒娈婄殑鑷姩鍖�(鐢ㄦ潵璁剧疆澶辨晥鏃堕棿)
-                        Send.DelLogic(Idlist[i]);
-                    }
-                }
-                exist = true;
+                        var d=await Send.DelLogic(Idlist[i]);
+						if (d != 0)
+						{
+							//鍒犻櫎鎴愬姛
+							exist = 2;
+						}
+						else
+						{
+							//鍒犻櫎澶辫触
+							exist = 3;
+						}
+						return exist;
+
+					}
+				}
+                exist = 1;
             }
             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 list = await Send.ReadList(Idlist.Count, 2);
-                for (int j = 0; j < list.Count; j++)
-                {
-                    var logic = list[j];
-                    foreach (var conditions in logic.Conditions)
-                    {
-                        var linkType = conditions["Type"];
-                        if (linkType == "5")
-                        {
-                            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);
-                            }
-                        }
-                    }
-                  
-                }
-            }
-            foreach (var logic in logicList)
-            {
-                logic.IsEnable = 3;//鏀瑰彉閫昏緫浣胯兘鐘舵��;
-                //鐢╢oreach鍙戦�佸懡浠わ紱
-                Send.AddModifyLogic(logic);
-            }
-        }
+     
     }
 }
 

--
Gitblit v1.8.0