From 160785587667cc0d927f85e44c139ec9dde13a9e Mon Sep 17 00:00:00 2001
From: 黄学彪 <hxb@hdlchina.com.cn>
Date: 星期一, 25 十一月 2019 14:30:13 +0800
Subject: [PATCH] 原来的 IOS 工程舍弃(注:没有合并其他组员的代码)

---
 ZigbeeApp/Shared/Phone/Device/Logic/DoorLockLogic/AddCondition.cs |  103 ++++++++++++++++++++++++++++++---------------------
 1 files changed, 61 insertions(+), 42 deletions(-)

diff --git a/ZigbeeApp/Shared/Phone/Device/Logic/DoorLockLogic/AddCondition.cs b/ZigbeeApp/Shared/Phone/Device/Logic/DoorLockLogic/AddCondition.cs
index dae8177..8d531a1 100755
--- a/ZigbeeApp/Shared/Phone/Device/Logic/DoorLockLogic/AddCondition.cs
+++ b/ZigbeeApp/Shared/Phone/Device/Logic/DoorLockLogic/AddCondition.cs
@@ -12,8 +12,9 @@
             Tag = "LockLogic";
         }
         Button selectedIcon = new Button();
-       
+        VerticalScrolViewLayout middle;
         public int conditionsIndex = -1;
+
         public async void Show()
         {
             #region  鏈�涓婇潰鐨勫竷灞�浠g爜
@@ -68,7 +69,7 @@
 
             #endregion
 
-            var middle = new VerticalScrolViewLayout
+            middle = new VerticalScrolViewLayout
             {
                 Y = topRowLayout.Bottom,
                 Height = Application.GetRealHeight(1920 - 184),
@@ -86,23 +87,21 @@
                     d = true;
                     break;
                 }
-
             }
-
+            CommonPage.Loading.Start();
             if (!d)
             {
-               
                 var allMemberslist = await Send.AllMembers(Send.CurrentDoorLock.DeviceAddr);
                 Send.LockList.AddRange(allMemberslist);
             }
-            UserAllView(middle, macport);
+            UserAllView(macport);
+            CommonPage.Loading.Hide();
 
         }
         /// <summary>
         /// 鏄剧ず鎵�鏈夌敤鎴�
         /// </summary>
-        /// <param name="middle"></param>
-        void UserAllView(VerticalScrolViewLayout middle,string macport)
+        void UserAllView(string macport)
         {
 
             for (int i = 0; i < Send.LockList.Count; i++)
@@ -154,7 +153,7 @@
 
                 EventHandler<MouseEventArgs> userclick = (sender, e) =>
                 {
-                    SelectedUserID(user.UserIdMode, usernameBtn.Text);
+                    SelectedUserID(user);
                 };
                 usernameBtn.MouseUpEventHandler += userclick;
                 btntimeback.MouseUpEventHandler += userclick;
@@ -169,7 +168,7 @@
         /// </summary>
         /// <param name="membershipIfon">瑙﹀彂婧愬垪琛�</param>
         /// <param name="userName">鐢ㄦ埛鍚嶅瓧</param>
-        void SelectedUserID(List<Send.UnlockingMode> membershipIfon, string userName) {
+        void SelectedUserID(Send.MembershipIfon membershipIfon) {
 
            var flMain = new FrameLayout { BackgroundColor = ZigbeeColor.Current.LogicViewBackgroundColor };
             this.AddChidren(flMain);
@@ -233,7 +232,7 @@
                 TextAlignment = TextAlignment.Center,
                 X = Btncancel.Right + Application.GetRealWidth(100),
                 TextSize = 16,
-                Text =userName,
+                Text = membershipIfon.UserName,
             };
             lockRow.AddChidren(Btntitle);
             var Btncomplete = new Button
@@ -251,13 +250,15 @@
             #endregion
 
             string SelectedLockStatus = "";
-            lockcolorfra1.Y = Application.GetRealHeight(1920 - 140 - (160 * membershipIfon.Count) - 20 - 50);
-            lockcolorfra1.Height = Application.GetRealHeight(140 + (160 * membershipIfon.Count) + 20 + 50);
+            lockcolorfra1.Y = Application.GetRealHeight(1920 - 140 - (160 * membershipIfon.UserIdMode.Count) - 20 - 50);
+            lockcolorfra1.Height = Application.GetRealHeight(140 + (160 * membershipIfon.UserIdMode.Count) + 20 + 50);
             ///瀹氫箟涓や釜鍙橀噺璁板綍閫変腑鐘舵�侊紱
-            string attriButeId ="", attriButeData2 ="";
-            for (int j = 0; j < membershipIfon.Count; j++)
+            string attriButeId = "";
+            string attriButeData2 = "";
+            string modeName = "";
+            for (int j = 0; j < membershipIfon.UserIdMode.Count; j++)
             {
-                var userIdmode = membershipIfon[j];
+                var userIdmode = membershipIfon.UserIdMode[j];
                 var doorlockfra = new FrameLayout
                 {
                     Height = Application.GetRealHeight(160),
@@ -284,27 +285,7 @@
                     TextSize = 14,
                 };
                 doorlockRow.AddChidren(doorlockBtn);
-                //(0鎸夐敭/3鍗�/15鎸囩汗)
-                //switch (userIdmode.OpenMode.ToString())
-                //{
-                //    case "0":
-                //        {
-                //            doorlockBtn.Text = Language.StringByID(MyInternationalizationString.lockpassword);
-                //        }
-                //        break;
-                //    case "3":
-                //        {
-                //            doorlockBtn.Text = Language.StringByID(MyInternationalizationString.ic);
-                //        }
-                //        break;
-                //    case "15":
-                //        {
-                //            doorlockBtn.Text = Language.StringByID(MyInternationalizationString.fingerprint);
-                //        }
-                //        break;
-                //}
-
-
+               
                 var doorlockSelected = new Button
                 {
                     X = Application.GetRealWidth(860),
@@ -316,7 +297,7 @@
 
                 };
                 doorlockRow.AddChidren(doorlockSelected);
-                if ((membershipIfon.Count - 1) == j)
+                if ((membershipIfon.UserIdMode.Count - 1) == j)
                 {
                     doorlockRow.LineColor = ZigbeeColor.Current.LogicBackgroundColor;
                 }
@@ -329,6 +310,7 @@
                     //doorlockBtn.TextColor = ZigbeeColor.Current.LogicBtnSelectedColor;
                     attriButeId = userIdmode.OpenMode.ToString();
                     attriButeData2 = userIdmode.UserId;
+                    modeName = userIdmode.ModeName;
                 };
                 doorlockRow.MouseUpEventHandler += doorlockclick;
                 doorlockBtn.MouseUpEventHandler += doorlockclick;
@@ -344,6 +326,8 @@
                         selectedIcon = doorlockSelected;
                         doorlockSelected.Visible = true;
                     }
+                    
+
                 }
             }
            
@@ -359,11 +343,16 @@
                 lockConditionsInfo.Add("AttriButeData2", attriButeData2);
                 lockConditionsInfo.Add("AttriButeData1", "2");
                 lockConditionsInfo.Add("Range", "0");
+                var accounts = new Dictionary<string, string>();
+                accounts.Add("Type", "1");
+                accounts.Add("Account", membershipIfon.UserName+ modeName);
+                accounts.Add("UserId", attriButeData2);
                 if (SelectedLockStatus != "")
                 {
                     if (conditionsIndex == -1)
                     {
-                        bool add = false;
+                        bool addCondition = false;
+                        bool addAccount = false;
                         for (int i = 0; i < Common.Logic.CurrentLogic.Conditions.Count; i++)
                         {
                             if (Common.Logic.CurrentLogic.Conditions[i]["Type"] == "1")
@@ -372,23 +361,53 @@
                                 {
                                     if (Common.Logic.CurrentLogic.Conditions[i]["AttriButeId"] == lockConditionsInfo["AttriButeId"] && Common.Logic.CurrentLogic.Conditions[i]["AttriButeData2"] == lockConditionsInfo["AttriButeData2"])
                                     {
-                                        add = true;
+                                        addCondition = true;
                                         break;
                                     }
                                 }
                             }
                         }
-                        
-                        if (!add)
+                        if (!addCondition)
                         {
                             Common.Logic.CurrentLogic.Conditions.Add(lockConditionsInfo);
                         }
 
+                        for (int i = 0; i < Common.Logic.CurrentLogic.Accounts.Count; i++)
+                        {
+                            if (Common.Logic.CurrentLogic.Accounts[i]["Type"] == "1")
+                            {
+                                if (Common.Logic.CurrentLogic.Accounts[i]["UserId"] == attriButeData2)
+                                {
+                                    addAccount = true;
+                                    break;
+                                }
+                            }
+                        }
+                        if (!addAccount)
+                        {
+                            Common.Logic.CurrentLogic.Accounts.Add(accounts);
+                        }
                     }
                     else
                     {
+                        ///鎵惧嚭涔嬪墠鐨勬棫鏁版嵁绉婚櫎鎺夛紝鍐嶉噸鏂版坊鍔犳柊鏁版嵁锛�
+                        string accountuserId = Common.Logic.CurrentLogic.Conditions[conditionsIndex]["AttriButeData2"];
                         Common.Logic.CurrentLogic.Conditions.RemoveAt(conditionsIndex);
                         Common.Logic.CurrentLogic.Conditions.Insert(conditionsIndex, lockConditionsInfo);
+                        for (int i = 0; i < Common.Logic.CurrentLogic.Accounts.Count; i++)
+                        {
+                            if (Common.Logic.CurrentLogic.Accounts[i]["Type"] == "1")
+                            {
+                                ///鎵惧嚭涔嬪墠鐨勬棫鏁版嵁绉婚櫎鎺夛紝鍐嶉噸鏂版坊鍔犳柊鏁版嵁锛�
+                                if (Common.Logic.CurrentLogic.Accounts[i]["UserId"] == accountuserId)
+                                {
+                                    Common.Logic.CurrentLogic.Accounts.RemoveAt(i);
+                                    Common.Logic.CurrentLogic.Accounts.Insert(i, accounts);
+                                    break;
+                                }
+                            }
+                        }
+
                     }
 
                 }

--
Gitblit v1.8.0