From 3272ca5b51e19f7f8a827b0f68400570a547fe60 Mon Sep 17 00:00:00 2001
From: 陈嘉乐 <cjl@hdlchina.com.cn>
Date: 星期二, 28 四月 2020 15:02:44 +0800
Subject: [PATCH] 2020-04-28-1

---
 ZigbeeApp/Shared/Phone/Device/Logic/SkipView.cs |  284 ++++++++++++++++++++++++++++++++------------------------
 1 files changed, 164 insertions(+), 120 deletions(-)

diff --git a/ZigbeeApp/Shared/Phone/Device/Logic/SkipView.cs b/ZigbeeApp/Shared/Phone/Device/Logic/SkipView.cs
index 8bb854a..61313e9 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,UserCenter.MemberInfoRes accountObj = null,DoorLock doorLock=null)
+        public static void SkipAddLogic(int intvalue, DoorLock doorLock = null, UserCenter.MemberInfoRes accountObj = null)
         {
-            /// 0.姝e父鑷姩鍖�;1.闂ㄩ攣鑷姩鍖�;2.闂ㄩ攣甯稿紑.鍏�;
+            /// 0.姝e父鑷姩鍖�;1.闂ㄩ攣鑷姩鍖�;2.Sone闂ㄩ攣;
             switch (intvalue)
             {
-                case 0: {
+                case 0:
+                    {
                         //new涓�涓柊閫昏緫瀵硅薄锛�
                         //鏂板姝e父鑷姩鍖栧叆鍙�
                         Common.Logic.CurrentLogic = new Common.Logic();
@@ -29,15 +30,18 @@
                         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,26 +58,36 @@
                         UserView.HomePage.Instance.AddChidren(doorLockLogicList);
                         UserView.HomePage.Instance.PageIndex += 1;
                         doorLockLogicList.Show();
-                    } break;
-                case 2: {
-                        //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.openmode);
-                        var logicCommunalPage = new LogicCommunalPage();
-                        UserView.HomePage.Instance.AddChidren(logicCommunalPage);
+                    }
+                    break;
+                case 2:
+                    {
+                        ///Sone闂ㄩ攣涓诲叆鍙�
+                        if (doorLock == null)
+                        {
+                            ///闃叉鎶涘紓甯�
+                            doorLock = new DoorLock();
+                        }
+                        Send.CurrentDoorLock = doorLock;
+                        ///杩涙潵鍒锋柊涓�娆¤澶囧垪琛紱
+                        Common.Logic.LogicDviceList.Clear();
+                        if (Common.Logic.LogicDviceList.Count == 0)
+                        {
+                            Common.Logic.LogicDviceList.AddRange(LocalDevice.Current.listAllDevice.ToArray());
+                        }
+                        var addLogicPage = new SoneLogicList();
+                        UserView.HomePage.Instance.AddChidren(addLogicPage);
                         UserView.HomePage.Instance.PageIndex += 1;
-                        logicCommunalPage.Show(() => { });
-                    } break;
+                        addLogicPage.Show();
+                     
+                    }
+                    break;
             }
 
         }
 
 
         #region 鈼� 鑷姩鍖朹_________________________
-
         /// <summary>
         /// 鑷姩鍖栧姛鑳戒唬鐮佸叆鍙�
         /// </summary>
@@ -147,8 +161,8 @@
                 X = Application.GetRealWidth(58),
                 Y = scenehorizontalScrol.Bottom,
             };
-            functionSceneAutoBodyView.AddChidren(logicScrolView);
-          
+            functionSceneAutoBodyView.AddChidren(logicScrolView);
+
             logicScrolView.SetCornerWithSameRadius(Application.GetRealHeight(58), HDLUtils.RectCornerTopLeft);
             bool no = false;
             //鏄剧ず榛樿妯℃澘鐨勭晫闈簨浠�
@@ -253,10 +267,10 @@
                 Read(logicScrolView, no);
                 //鍏抽棴鍒锋柊View锛�
                 logicScrolView.EndHeaderRefreshing();
-            };
-
-           //鑷姩鍖�
-           Read(logicScrolView, no);
+            };
+
+            //鑷姩鍖�
+            Read(logicScrolView, no);
 
         }
         /// <summary>
@@ -266,41 +280,49 @@
         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);
             CommonPage.Loading.Hide();
         }
+        static RowLayout selectedRow = new RowLayout() { Tag = "0" };//璁板綍宸︽粦鐘舵��
         /// <summary>
         /// 鍔犺浇鑷姩鍖栧垪琛ㄧ晫闈�
         /// </summary>
@@ -314,7 +336,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);
@@ -322,9 +344,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),
                 };
@@ -361,7 +383,7 @@
             int i = 1;//灞�閮ㄥ彉閲忥紝榛樿鏄涓�鏉¢�昏緫;
             foreach (var logic in Common.Logic.LogicList)
             {
-               
+
                 var fLayout = new FrameLayout
                 {
                     Height = Application.GetRealHeight(190 + 30),
@@ -369,7 +391,7 @@
                     BackgroundColor = ZigbeeColor.Current.LogicBackgroundColor,
                 };
                 refresview.AddChidren(fLayout);
-            
+
                 var logicRowlayout = new RowLayout
                 {
                     Height = Application.GetRealHeight(190 + 30),
@@ -377,17 +399,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),
@@ -428,7 +460,7 @@
                         logic.IsEnable = 0;
                         StatusColor(logic, logicRowlayout, 0);
                     }
-                   Send.LogicControlSwitch(logic);
+                    Send.LogicControlSwitch(logic);
                     //Logic.Send.AddModifyLogic(logic);
                 };
                 if (logic.IsEnable == 1)
@@ -449,14 +481,27 @@
                     TextColor = ZigbeeColor.Current.LogicBtnSaveTextColor,
                 };
                 logicRowlayout.AddRightView(edit);
+                if (logic.LogicType == 2)
+                {
+                    edit.TextID = MyInternationalizationString.look;
+                }
                 edit.MouseUpEventHandler += (sender, e) =>
                 {
                     Common.Logic.CurrentLogic = logic;
-                    var logicCommunalPage = new LogicCommunalPage();
-                    HomePage.Instance.AddChidren(logicCommunalPage);
-                    HomePage.Instance.PageIndex += 1;
-                    logicCommunalPage.Show(() => { logicnameBtn.Text = logic.LogicName; Automationview(refresview, no); });
-
+                    if (Common.Logic.CurrentLogic.LogicType == 2)
+                    {
+                        var oneLogic = new OneLogic();
+                        UserView.HomePage.Instance.AddChidren(oneLogic);
+                        UserView.HomePage.Instance.PageIndex += 1;
+                        oneLogic.Show(true);
+                    }
+                    else
+                    {
+                        var logicCommunalPage = new LogicCommunalPage();
+                        HomePage.Instance.AddChidren(logicCommunalPage);
+                        HomePage.Instance.PageIndex += 1;
+                        logicCommunalPage.Show(() => { logicnameBtn.Text = logic.LogicName; Automationview(refresview, no); });
+                    }
                 };
 
                 ///鍒犻櫎
@@ -489,7 +534,9 @@
                     Width = Application.GetRealWidth(1080 - 58),
                     BackgroundColor = ZigbeeColor.Current.LogicRowLayoutLineColor,
                 };
-                fLayout.AddChidren(line);
+                fLayout.AddChidren(line);
+
+
             }
 
         }
@@ -527,8 +574,9 @@
                 {
                     indexlist.Add(linkType);
                 }
-            }
-            if (indexlist.Contains("0"))
+            }
+            //鎺掑垪鍥炬爣椤哄簭;
+            if (indexlist.Contains("0") || indexlist.Contains("8"))
             {
                 iconIndexlist.Add("0");
             }
@@ -647,91 +695,87 @@
                 }
             }
         }
-
         #endregion
 
         /// <summary>
-        /// 闂ㄩ攣鍙栨秷璁剧疆鐢ㄧ殑鏂规硶
+        /// 闂ㄩ攣鍙栨秷璁剧疆鐢ㄧ殑鏂规硶(鐩稿綋涓�涓叧闂父寮�妯″紡鎸夐挳,鍒嗙被-鑷姩鍖�-涓嶉渶瑕佹樉绀鸿鑷姩鍖�)
         /// </summary>
         /// <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)
         {
-
-            int hour = timeVlaue / 60;
-            int min = timeVlaue % 60;
+            //璇诲彇绯荤粺褰撳墠鏃堕棿锛氭椂-鍒�
+            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("StartHour", hour.ToString());
-            timeConditionsInfo.Add("StartMin", min.ToString());
+            timeConditionsInfo.Add("StartHour", h);
+            timeConditionsInfo.Add("StartMin", m);
+            timeConditionsInfo.Add("DoorLockOpenDelayTime", timeVlaue.ToString());
             Dictionary<string, object> actionsInfo = new Dictionary<string, object>();
             actionsInfo.Add("LinkType", 8);
             actionsInfo.Add("DeviceAddr", common.DeviceAddr);
             actionsInfo.Add("Epoint", common.DeviceEpoint);
-            actionsInfo.Add("PassData", "055704010112");//榛樿闂ㄩ攣甯稿紑
+            actionsInfo.Add("PassData", "055704010113");//榛樿闂ㄩ攣甯稿叧
 
             Common.Logic currentLogic = new Common.Logic();
-            currentLogic.IsEnable = 0;//榛樿绂佺敤
+            currentLogic.IsEnable = 1;//榛樿涓哄紑
             currentLogic.TimeAttribute.Repeat = 0;//鎵ц涓�娆�
+            currentLogic.LogicType = 3;//鏍囪閫昏緫绫诲瀷
             currentLogic.LogicName = Language.StringByID(R.MyInternationalizationString.openmode);
             currentLogic.Conditions.Add(timeConditionsInfo);
             currentLogic.Actions.Add(actionsInfo);
-            //淇敼鎴栬�呮坊鍔犳槸鏍规嵁閫昏緫id鍊硷紙0鏂板锛�1锛屼慨鏀癸級
-            Send.AddModifyLogic(currentLogic);
+            var logicIfon = await Send.AddModifyLogic(currentLogic);
+            if (logicIfon != null && logicIfon.LogicId != 0)
+            {
+                //娣诲姞闂ㄩ攣澶辨晥鏃堕棿鐨勫巻鍙茶褰�
+                UserCenter.HdlDeviceDoorLockLogic.Current.AddDoorHistoryLog((DoorLock)common, 9003, timeVlaue.ToString());
+                return true;//琛ㄧず娣诲姞鎴愬姛;
+            }
+            return false;//琛ㄧず娣诲姞澶辫触;
 
         }
-        ///<summary>
-        /// 闂ㄩ攣鍒犻櫎閫昏緫
-        /// </summary>
-        public static async void LockDelLogic(CommonDevice common)
-        {
-            int logicId = 0;
-            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 logic = listlogic[j];
-                    foreach (var actions in logic.Actions)
-                    {
-                        var linkType = actions["LinkType"].ToString();
-                        if (linkType != "8")
-                        {
-                            //鐢ㄦ埛鏈夊彲鑳藉湪鑷姩鍖栭偅閲屽啀娆$紪杈�;
-                            //蹇呴』杩囨护鎺変笉闇�瑕佺殑淇℃伅(杈撳嚭鍔熻兘寤舵椂:鏄病鏈塂eviceAddr鍜孍point),鍚﹀垯鏈夊紓甯�;
-                            continue;
-                        }
-                        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)
+        ///<summary>
+        /// s-one闂ㄩ攣鏄惁瀛樺湪鑷姩鍖栫殑鏂规硶;
+        /// 娉ㄦ剰(鍙傛暟:2-鑷姩鍖�;3-澶辨晥鏃堕棿鑷姩鍖�);
+        /// 杩斿洖鍊硷細0涓嶅瓨鍦�;鍏跺畠鍊奸兘瀛樺湪;
+        /// </summary>
+        public static async System.Threading.Tasks.Task<int> Exist(int valueInt=2)
+        {
+            int exist = 0;
+            var Idlist = await Send.GetLogicId(valueInt);
+            if (Idlist.Count != 0)
             {
-                //娌℃湁鎵惧埌logicId鍒犻櫎娌℃湁鎰忎箟;
-                return;
+                //榛樿鍙栫涓�涓�昏緫ID
+                exist = Idlist[0];
+
             }
-            Send.DelLogic(logicId);
+            return exist;
         }
 
+        ///<summary>
+        ///鑾峰彇閫昏緫淇℃伅
+        /// 杩斿洖鍊硷細null涓嶅瓨鍦�;鍏跺畠鍊奸兘瀛樺湪;
+        /// </summary>
+        public static async System.Threading.Tasks.Task<Common.Logic> GetLogicIfon()
+        {
+            Common.Logic logic = null;
+            var Idlist = await Send.GetLogicId(3);
+            if (Idlist.Count != 0)
+            {
+                //榛樿鍙栫涓�涓�昏緫ID(鏃舵晥鎬у彧鏈変竴鏉¢�昏緫)
+                int exist = Idlist[0];
+                logic = await Send.GetLogic(exist, 3);
+            }
+            return logic;
+        }
     }
 }
 

--
Gitblit v1.8.0