From d7ad5a3953a8cd001659092ebde204b881f94b9d Mon Sep 17 00:00:00 2001
From: WJC <wjc@hdlchina.com.cn>
Date: 星期四, 31 十月 2019 10:47:13 +0800
Subject: [PATCH] 2019-10-31-1

---
 ZigbeeApp/Shared/Phone/Device/Logic/Send.cs                       |  275 ++++++++++++++-----------
 ZigbeeApp/Shared/Phone/Device/Logic/MemberList.cs                 |   13 
 ZigbeeApp/Shared/Phone/Device/Logic/DoorLockLogic/AddCondition.cs |  198 +++++++++++++++---
 ZigbeeApp/.vs/GateWay/xs/UserPrefs.xml                            |   22 +
 ZigbeeApp/Shared/Phone/Device/Logic/DeviceStateCondition.cs       |   33 +-
 ZigbeeApp/.vs/GateWay/xs/sqlite3/storage.ide                      |    0 
 ZigbeeApp/Shared/Phone/Device/Logic/DoorLockLogic/LockIfon.cs     |   48 ----
 ZigbeeApp/Shared/Phone/Device/Logic/TemplateDeviceCondition.cs    |   20 +
 8 files changed, 375 insertions(+), 234 deletions(-)

diff --git a/ZigbeeApp/.vs/GateWay/xs/UserPrefs.xml b/ZigbeeApp/.vs/GateWay/xs/UserPrefs.xml
index 5207081..d02ce45 100644
--- a/ZigbeeApp/.vs/GateWay/xs/UserPrefs.xml
+++ b/ZigbeeApp/.vs/GateWay/xs/UserPrefs.xml
@@ -2,14 +2,13 @@
   <MonoDevelop.Ide.ItemProperties.GateWay.Droid PreferredExecutionTarget="Android.SelectDevice" />
   <MonoDevelop.Ide.ItemProperties.GateWay.Ios automaticSigning="False" PreferredExecutionTarget="MonoDevelop.IPhone.IPhoneDeviceTarget.913cb77b0eef11c9119c61a02bc00fec01bf67d6" />
   <MonoDevelop.Ide.ItemProperties.ShardLib PreferredExecutionTarget="Android.M7BBB18B19152766" />
-  <MonoDevelop.Ide.Workbench ActiveDocument="Shared/Phone/UserCenter/CommonBase/Logic/UserCenterLogic.cs">
+  <MonoDevelop.Ide.Workbench ActiveDocument="Shared/Phone/Device/Logic/TemplateDeviceCondition.cs">
     <Files>
-      <File FileName="Shared/Phone/Device/Logic/DoorLockLogic/LockLogicList.cs" Line="1" Column="1" />
-      <File FileName="Shared/Phone/Device/Logic/MemberList.cs" Line="1" Column="1" />
-      <File FileName="Shared/Phone/Device/Logic/Send.cs" Line="920" Column="1" />
-      <File FileName="Shared/Phone/Device/Logic/DeviceStateCondition.cs" Line="1377" Column="90" />
-      <File FileName="Shared/Phone/UserCenter/CommonBase/Logic/UserCenterLogic.cs" Line="230" Column="32" />
-      <File FileName="Shared/Common/CommonPage.cs" Line="271" Column="59" />
+      <File FileName="Shared/Phone/Device/Logic/DeviceStateCondition.cs" Line="1381" Column="27" />
+      <File FileName="Shared/Phone/Device/Logic/MemberList.cs" Line="313" Column="107" />
+      <File FileName="Shared/Phone/Device/Logic/DoorLockLogic/AddCondition.cs" Line="215" Column="83" />
+      <File FileName="Shared/Phone/Device/Logic/DoorLockLogic/LockIfon.cs" Line="16" Column="73" />
+      <File FileName="Shared/Phone/Device/Logic/TemplateDeviceCondition.cs" Line="1379" Column="83" />
     </Files>
     <Pads>
       <Pad Id="ProjectPad">
@@ -22,18 +21,21 @@
               <Node name="Common" expanded="True" />
               <Node name="Phone" expanded="True">
                 <Node name="Device" expanded="True">
+                  <Node name="Category" expanded="True" />
                   <Node name="Logic" expanded="True">
                     <Node name="DoorLockLogic" expanded="True" />
+                    <Node name="TemplateDeviceCondition.cs" selected="True" />
                   </Node>
                 </Node>
                 <Node name="UserCenter" expanded="True">
                   <Node name="CommonBase" expanded="True">
-                    <Node name="Logic" expanded="True">
-                      <Node name="UserCenterLogic.cs" selected="True" />
-                    </Node>
+                    <Node name="Common" expanded="True" />
                   </Node>
                   <Node name="DoorLock" expanded="True" />
                 </Node>
+                <Node name="ZigBee" expanded="True">
+                  <Node name="Device" expanded="True" />
+                </Node>
               </Node>
             </Node>
           </Node>
diff --git a/ZigbeeApp/.vs/GateWay/xs/sqlite3/storage.ide b/ZigbeeApp/.vs/GateWay/xs/sqlite3/storage.ide
index c21645f..1db2e15 100644
--- a/ZigbeeApp/.vs/GateWay/xs/sqlite3/storage.ide
+++ b/ZigbeeApp/.vs/GateWay/xs/sqlite3/storage.ide
Binary files differ
diff --git a/ZigbeeApp/Shared/Phone/Device/Logic/DeviceStateCondition.cs b/ZigbeeApp/Shared/Phone/Device/Logic/DeviceStateCondition.cs
index 2d9f8b6..24b3a70 100644
--- a/ZigbeeApp/Shared/Phone/Device/Logic/DeviceStateCondition.cs
+++ b/ZigbeeApp/Shared/Phone/Device/Logic/DeviceStateCondition.cs
@@ -1371,8 +1371,7 @@
                 case DeviceType.DoorLock:
                     {
                         #region  ------
-                        var doorlockifonlist = Send.ReadDoorLockIfon(common.DeviceAddr);
-                        //var list = Send.ReadDoorLockIfon(common.DeviceAddr);
+                        var doorlockifonlist = await Send.UserListIfon(common.DeviceAddr);
                         var pra = new UserCenter.MemberListInfoPra();
                         string result = await UserCenter.UserCenterLogic.GetResponseDataByRequestHttps("ZigbeeUsers/GetSubAccountByDistributedMark", false, pra);
                         var listInfo = Newtonsoft.Json.JsonConvert.DeserializeObject<List<UserCenter.MemberInfoRes>>(result);
@@ -1386,9 +1385,20 @@
                                 ///鏌ユ壘鎴愬憳浠ュ強鎴愬憳闂ㄩ攣瑙﹀彂婧�(1鎸夐敭/3鍗�/15鎸囩汗)
                                 if (doorlockifonlist[j].CloudAccountId == membershipifon.SubAccountDistributedMark)
                                 {
-                                    membership.UserIdMode.Add(doorlockifonlist[j].UserIdMode);
-                                    membership.MembershipName = membershipifon.UserName;
+                                    var lockMode = new Send.LockMode();
+                                    lockMode.UserId = doorlockifonlist[j].DoorLockLocalUserId;
+                                    lockMode.OpenMode = doorlockifonlist[j].OpenLockMode;
+                                    membership.UserIdMode.Add(lockMode);
                                     membership.MembershipId = membershipifon.SubAccountDistributedMark;
+                                    if (string.IsNullOrEmpty(membershipifon.UserName))
+                                    {
+                                        membership.MembershipName = membershipifon.Account;
+                                    }
+                                    else
+                                    {
+                                        membership.MembershipName = membershipifon.UserName;
+
+                                    }
 
                                 }
 
@@ -1396,7 +1406,7 @@
                             if (membership.UserIdMode.Count != 0)
                             {
                                 ///杩囨护鎺夐噸澶嶆暟鎹紱
-                                var str = Send.UserList.Find((c) => { return c.MembershipId == membership.MembershipId; });
+                                var str = Send.UserList.Find((c) => { return c.MembershipId == membershipifon.SubAccountDistributedMark; });
                                 if (str == null)
                                 {
                                     Send.UserList.Add(membership);
@@ -1413,7 +1423,6 @@
                         memberList.Show(common);
                     }
                     break;
-
                 case DeviceType.TemperatureSensor:
                     {
                         string current = Language.StringByID(MyInternationalizationString.current);
@@ -1451,12 +1460,12 @@
                             {
                                 dictionary(deviceConditionsInfo, "AttriButeData1", horizontalSeekBarVol.Progress.ToString());
 
-                                Btntemperaturevalue.Text = current+">" + horizontalSeekBarVol.Progress.ToString() + "鈩�";
+                                Btntemperaturevalue.Text = current + ">" + horizontalSeekBarVol.Progress.ToString() + "鈩�";
 
                             }
                             else
                             {
-                                Btntemperaturevalue.Text = current+"<" + horizontalSeekBarVol.Progress.ToString() + "%";
+                                Btntemperaturevalue.Text = current + "<" + horizontalSeekBarVol.Progress.ToString() + "%";
                                 dictionary(deviceConditionsInfo, "AttriButeData1", horizontalSeekBarVol.Progress.ToString());//娓╁害鍊�
                             }
                         };
@@ -1470,12 +1479,12 @@
                             dictionary(deviceConditionsInfo, "Range", "0");//0澶т簬AttriButeData1鏃惰Е鍙戝姩浣�
                             dictionary(deviceConditionsInfo, "AttriButeData1", "0");
                             dictionary(deviceConditionsInfo, "AttriButeData2", "0");
-                            Btntemperaturevalue.Text = current+">0鈩�";
+                            Btntemperaturevalue.Text = current + ">0鈩�";
 
                         }
                         else
                         {
-                            Btntemperaturevalue.Text = current+"<0%";
+                            Btntemperaturevalue.Text = current + "<0%";
                             dictionary(deviceConditionsInfo, "Cluster_ID", "1029");
                             dictionary(deviceConditionsInfo, "AttriButeId", "0");
                             dictionary(deviceConditionsInfo, "Range", "2");//2灏忎簬AttriButeData1鏃惰Е鍙戝姩浣�
@@ -1489,12 +1498,12 @@
                             if (temperatureSensor.SensorDiv == 1)
                             {
 
-                                Btntemperaturevalue.Text = current+">" + devices["AttriButeData1"] + "鈩�";
+                                Btntemperaturevalue.Text = current + ">" + devices["AttriButeData1"] + "鈩�";
 
                             }
                             else
                             {
-                                Btntemperaturevalue.Text = current+"<" + devices["AttriButeData1"] + "%";
+                                Btntemperaturevalue.Text = current + "<" + devices["AttriButeData1"] + "%";
                             }
                         }
 
diff --git a/ZigbeeApp/Shared/Phone/Device/Logic/DoorLockLogic/AddCondition.cs b/ZigbeeApp/Shared/Phone/Device/Logic/DoorLockLogic/AddCondition.cs
index 577d841..b80464b 100644
--- a/ZigbeeApp/Shared/Phone/Device/Logic/DoorLockLogic/AddCondition.cs
+++ b/ZigbeeApp/Shared/Phone/Device/Logic/DoorLockLogic/AddCondition.cs
@@ -14,7 +14,7 @@
         Button selectedIcon = new Button();
        
         public int conditionsIndex = -1;
-        public void Show()
+        public async  void  Show()
         {
             #region  鏈�涓婇潰鐨勫竷灞�浠g爜
             var topRowLayout = new RowLayout
@@ -34,8 +34,8 @@
                 Width = Application.GetRealWidth(400),
                 Height = Application.GetRealHeight(69),
                 Y = Application.GetRealHeight(92),
-                //TextID = MyInternationalizationString.selection,
-                Text = "閫夋嫨鐢ㄦ埛",
+                TextID = MyInternationalizationString.userlist,
+                //Text = "閫夋嫨鐢ㄦ埛",
             };
             topRowLayout.AddChidren(titleName);
 
@@ -76,26 +76,82 @@
             };
             this.AddChidren(middle);
 
-
-            var userlist = new List<ZigBee.Device.DoorLock.LocaDoorLockObj>();
-            userlist.Clear();
+            var userlist = new List<Send.MembershipIfon>();
             ///鍒ゆ柇APP鐧诲綍杩涙潵鐢ㄦ埛韬唤(涓讳汉锛岀鐞嗗憳锛屾垚鍛�)
+            var doorlockifonlist = await Send.UserListIfon(LockIfon.DoorLock.DeviceAddr);
             if (UserCenter.UserCenterResourse.UserInfo.AuthorityNo == 3)
             {
-                var list = LockIfon.GetUserIfon(LockIfon.UserMemberInfoRes.SubAccountDistributedMark);
-                foreach (var o in list)
+                Send.MembershipIfon membershipIfon = new Send.MembershipIfon();
+                foreach (var o in doorlockifonlist)
                 {
-                    if (userlist.Count != 0)
+
+                    if (o.CloudAccountId == LockIfon.UserMemberInfoRes.SubAccountDistributedMark)
                     {
-                        continue;
+                        Send.LockMode lockMode = new Send.LockMode();
+                        lockMode.OpenMode = o.OpenLockMode;
+                        lockMode.UserId = o.DoorLockLocalUserId;
+                        membershipIfon.UserIdMode.Add(lockMode);
+                        membershipIfon.MembershipId = LockIfon.UserMemberInfoRes.SubAccountDistributedMark;
+                        if (string.IsNullOrEmpty(LockIfon.UserMemberInfoRes.UserName))
+                        {
+                            membershipIfon.MembershipName = LockIfon.UserMemberInfoRes.Account;
+                        }
+                        else
+                        {
+                            membershipIfon.MembershipName = LockIfon.UserMemberInfoRes.UserName;
+                        }
                     }
-                    userlist.Add(o);
+
                 }
+                userlist.Add(membershipIfon);
+
             }
             else
             {
-                userlist = LockIfon.GetUserList();
+                var pra = new UserCenter.MemberListInfoPra();
+                string result = await UserCenter.UserCenterLogic.GetResponseDataByRequestHttps("ZigbeeUsers/GetSubAccountByDistributedMark", false, pra);
+                var listInfo = Newtonsoft.Json.JsonConvert.DeserializeObject<List<UserCenter.MemberInfoRes>>(result);
+                for (int i = 0; i < listInfo.Count; i++)
+                {
+                    var membership = new Send.MembershipIfon();
+                    var membershipifon = listInfo[i];
+                    for (int j = 0; j < doorlockifonlist.Count; j++)
+                    {
+                        ///鏌ユ壘鎴愬憳浠ュ強鎴愬憳闂ㄩ攣瑙﹀彂婧�(1鎸夐敭/3鍗�/15鎸囩汗)
+                        if (doorlockifonlist[j].CloudAccountId == membershipifon.SubAccountDistributedMark)
+                        {
+                            Send.LockMode lockMode = new Send.LockMode();
+                            lockMode.OpenMode = doorlockifonlist[j].OpenLockMode;
+                            lockMode.UserId = doorlockifonlist[j].DoorLockLocalUserId;
+                            membership.UserIdMode.Add(lockMode);
+                            membership.MembershipId = membershipifon.SubAccountDistributedMark;
+                            if (string.IsNullOrEmpty(membershipifon.UserName))
+                            {
+                                membership.MembershipName = membershipifon.Account;
+                            }
+                            else
+                            {
+                                membership.MembershipName = membershipifon.UserName;
+
+                            }
+
+                        }
+
+                    }
+                    if (membership.UserIdMode.Count != 0)
+                    {
+                        ///杩囨护鎺夐噸澶嶆暟鎹紱
+                        var str = userlist.Find((c) => { return c.MembershipId == membershipifon.SubAccountDistributedMark; });
+                        if (str == null)
+                        {
+                            userlist.Add(membership);
+                        }
+                    }
+
+                }
+
             }
+
             for (int i = 0; i < userlist.Count; i++)
             {
                 var user = userlist[i];
@@ -118,12 +174,12 @@
 
                 var usernameBtn = new Button
                 {
-                    Text = user.UserName,
+                    Text = user.MembershipName,
                     TextAlignment = TextAlignment.CenterLeft,
                     TextColor = ZigbeeColor.Current.LogicTextBlackColor,
                     Width = Application.GetRealWidth(600),
                     Height = Application.GetRealHeight(130),
-                    Tag = userlist[i].ConnectedAccount
+                    Tag = userlist[i],
                 };
                 userRow.AddChidren(usernameBtn);
 
@@ -140,8 +196,7 @@
 
                 EventHandler<MouseEventArgs> userclick = (sender, e) =>
                 {
-                    var uesrifonlist = LockIfon.GetUserIfon(usernameBtn.Tag.ToString());
-                    SelectedUserID(uesrifonlist, usernameBtn.Text);
+                    SelectedUserID(user.UserIdMode, usernameBtn.Text);
                 };
                 usernameBtn.MouseUpEventHandler += userclick;
                 btntimeback.MouseUpEventHandler += userclick;
@@ -155,9 +210,9 @@
         /// <summary>
         /// 閫夋嫨鏌愪釜鐢ㄦ埛
         /// </summary>
-        /// <param name="uesrifonlist">瑙﹀彂婧愬垪琛�</param>
+        /// <param name="membershipIfon">瑙﹀彂婧愬垪琛�</param>
         /// <param name="userName">鐢ㄦ埛鍚嶅瓧</param>
-         void SelectedUserID(List<ZigBee.Device.DoorLock.LocaDoorLockObj> uesrifonlist,string userName) {
+         void SelectedUserID(List<Send.LockMode> membershipIfon, string userName) {
 
            var flMain = new FrameLayout { BackgroundColor = ZigbeeColor.Current.LogicViewBackgroundColor };
             this.AddChidren(flMain);
@@ -236,13 +291,13 @@
             #endregion
 
             string SelectedLockStatus = "";
-            lockcolorfra1.Y = Application.GetRealHeight(1920 - 140 - (160 * uesrifonlist.Count) - 20 - 50);
-            lockcolorfra1.Height = Application.GetRealHeight(140 + (160 * uesrifonlist.Count) + 20 + 50);
+            lockcolorfra1.Y = Application.GetRealHeight(1920 - 140 - (160 * membershipIfon.Count) - 20 - 50);
+            lockcolorfra1.Height = Application.GetRealHeight(140 + (160 * membershipIfon.Count) + 20 + 50);
             ///瀹氫箟涓や釜鍙橀噺璁板綍閫変腑鐘舵�侊紱
-            int attriButeId = 0, attriButeData2 = 0;
-            for (int j = 0; j < uesrifonlist.Count; j++)
+            string attriButeId ="", attriButeData2 ="";
+            for (int j = 0; j < membershipIfon.Count; j++)
             {
-                var userid = uesrifonlist[j];
+                var userIdmode = membershipIfon[j];
                 var doorlockfra = new FrameLayout
                 {
                     Height = Application.GetRealHeight(160),
@@ -268,19 +323,19 @@
                 };
                 doorlockRow.AddChidren(doorlockBtn);
                 //(0鎸夐敭/3鍗�/15鎸囩汗)
-                switch (userid.UnlockType)
+                switch (userIdmode.OpenMode.ToString())
                 {
-                    case 0:
+                    case "0":
                         {
                             doorlockBtn.Text = Language.StringByID(MyInternationalizationString.lockpassword);
                         }
                         break;
-                    case 3:
+                    case "3":
                         {
                             doorlockBtn.Text = Language.StringByID(MyInternationalizationString.ic);
                         }
                         break;
-                    case 15:
+                    case "15":
                         {
                             doorlockBtn.Text = Language.StringByID(MyInternationalizationString.fingerprint);
                         }
@@ -300,7 +355,7 @@
 
                 };
                 doorlockRow.AddChidren(doorlockSelected);
-                if ((uesrifonlist.Count - 1) == j)
+                if ((membershipIfon.Count - 1) == j)
                 {
                     doorlockRow.LineColor = ZigbeeColor.Current.LogicBackgroundColor;
                 }
@@ -311,8 +366,8 @@
                     selectedIcon = doorlockSelected;
                     doorlockSelected.Visible = true;
                     //doorlockBtn.TextColor = ZigbeeColor.Current.LogicBtnSelectedColor;
-                    attriButeId = userid.UnlockType;
-                    attriButeData2 = userid.UserID;
+                    attriButeId = userIdmode.OpenMode.ToString();
+                    attriButeData2 = userIdmode.UserId;
                 };
                 doorlockRow.MouseUpEventHandler += doorlockclick;
                 doorlockBtn.MouseUpEventHandler += doorlockclick;
@@ -322,7 +377,7 @@
                 if (conditionsIndex != -1)
                 {
                     var s = Common.Logic.CurrentLogic.Conditions[conditionsIndex];
-                    if (s["AttriButeId"] == userid.UnlockType.ToString() && s["AttriButeData2"] == userid.UserID.ToString())
+                    if (s["AttriButeId"] == userIdmode.OpenMode.ToString() && s["AttriButeData2"] == userIdmode.UserId)
                     {
                         selectedIcon.Visible = false;
                         selectedIcon = doorlockSelected;
@@ -339,8 +394,8 @@
                 lockConditionsInfo.Add("MacAddr", LockIfon.DoorLock.DeviceAddr);
                 lockConditionsInfo.Add("Epoint", LockIfon.DoorLock.DeviceEpoint.ToString());
                 lockConditionsInfo.Add("Cluster_ID", "64529");
-                lockConditionsInfo.Add("AttriButeId", attriButeId.ToString());
-                lockConditionsInfo.Add("AttriButeData2", attriButeData2.ToString());
+                lockConditionsInfo.Add("AttriButeId", attriButeId);
+                lockConditionsInfo.Add("AttriButeData2", attriButeData2);
                 lockConditionsInfo.Add("AttriButeData1", "2");
                 lockConditionsInfo.Add("Range", "0");
                 if (SelectedLockStatus != "")
@@ -373,5 +428,82 @@
                 lockLogicCommunalPage.Show(() => { });
             };
         }
+        /*
+        public async  List<Send.MembershipIfon> readuserlist(){
+            var userlist = new List<Send.MembershipIfon>();
+            ///鍒ゆ柇APP鐧诲綍杩涙潵鐢ㄦ埛韬唤(涓讳汉锛岀鐞嗗憳锛屾垚鍛�)
+            var doorlockifonlist = await Send.UserListIfon(LockIfon.DoorLock.DeviceAddr);
+            if (UserCenter.UserCenterResourse.UserInfo.AuthorityNo == 3)
+            {
+                Send.MembershipIfon membershipIfon = new Send.MembershipIfon();
+                //var list = LockIfon.GetUserIfon(LockIfon.UserMemberInfoRes.SubAccountDistributedMark);
+                foreach (var o in doorlockifonlist)
+                {
+
+                    if (o.CloudAccountId == LockIfon.UserMemberInfoRes.SubAccountDistributedMark)
+                    {
+                        membershipIfon.MembershipId = LockIfon.UserMemberInfoRes.SubAccountDistributedMark;
+                        membershipIfon.UserIdMode.Add(o.OpenLockMode.ToString());
+                        if (string.IsNullOrEmpty(LockIfon.UserMemberInfoRes.UserName))
+                        {
+                            membershipIfon.MembershipName = LockIfon.UserMemberInfoRes.Account;
+
+                        }
+                        else
+                        {
+                            membershipIfon.MembershipName = LockIfon.UserMemberInfoRes.UserName;
+
+                        }
+                    }
+
+                }
+                userlist.Add(membershipIfon);
+
+            }
+            else
+            {
+                var pra = new UserCenter.MemberListInfoPra();
+                string result = await UserCenter.UserCenterLogic.GetResponseDataByRequestHttps("ZigbeeUsers/GetSubAccountByDistributedMark", false, pra);
+                var listInfo = Newtonsoft.Json.JsonConvert.DeserializeObject<List<UserCenter.MemberInfoRes>>(result);
+                for (int i = 0; i < listInfo.Count; i++)
+                {
+                    var membership = new Send.MembershipIfon();
+                    var membershipifon = listInfo[i];
+                    for (int j = 0; j < doorlockifonlist.Count; j++)
+                    {
+                        ///鏌ユ壘鎴愬憳浠ュ強鎴愬憳闂ㄩ攣瑙﹀彂婧�(1鎸夐敭/3鍗�/15鎸囩汗)
+                        if (doorlockifonlist[j].CloudAccountId == membershipifon.SubAccountDistributedMark)
+                        {
+                            membership.UserIdMode.Add(doorlockifonlist[j].UserIdMode);
+                            membership.MembershipId = membershipifon.SubAccountDistributedMark;
+                            if (string.IsNullOrEmpty(membershipifon.UserName))
+                            {
+                                membership.MembershipName = membershipifon.Account;
+                            }
+                            else
+                            {
+                                membership.MembershipName = membershipifon.UserName;
+
+                            }
+
+                        }
+
+                    }
+                    if (membership.UserIdMode.Count != 0)
+                    {
+                        ///杩囨护鎺夐噸澶嶆暟鎹紱
+                        var str = userlist.Find((c) => { return c.MembershipId == membership.MembershipId; });
+                        if (str == null)
+                        {
+                            userlist.Add(membership);
+                        }
+                    }
+
+                }
+
+            }
+            return userlist;
+        }
+        */
     }
 }
diff --git a/ZigbeeApp/Shared/Phone/Device/Logic/DoorLockLogic/LockIfon.cs b/ZigbeeApp/Shared/Phone/Device/Logic/DoorLockLogic/LockIfon.cs
index 1d13ab0..6a1ce2a 100644
--- a/ZigbeeApp/Shared/Phone/Device/Logic/DoorLockLogic/LockIfon.cs
+++ b/ZigbeeApp/Shared/Phone/Device/Logic/DoorLockLogic/LockIfon.cs
@@ -9,55 +9,11 @@
         /// <summary>
         /// 褰撳墠闂ㄩ攣
         /// </summary>
-        public static ZigBee.Device.DoorLock DoorLock=null;
+        public static ZigBee.Device.DoorLock DoorLock = null;
         /// <summary>
-        /// 褰撳墠鎴愬憳鐨勪俊鎭�
+        /// 褰撳墠鐢ㄦ埛鐨勪俊鎭�
         /// </summary>
         public static UserCenter.MemberInfoRes UserMemberInfoRes = null;
-        /// <summary>
-        /// 鑾峰彇闂ㄩ攣鎵�鏈夌殑鎴愬憳
-        /// </summary>
-        /// <returns></returns>
-        public static List<ZigBee.Device.DoorLock.LocaDoorLockObj> GetUserList()
-        {
-            var locaDoorLockObjlist = new List<ZigBee.Device.DoorLock.LocaDoorLockObj>();
-            locaDoorLockObjlist.Clear();
-            foreach (var dictionary in DoorLock.localDoorLockUserList)
-            {
-                if (string.IsNullOrEmpty(dictionary.Value.ConnectedAccount)) {
-                    //涓嶇煡閬撲紶杩囨潵ConnectedAccount涓轰粈涔堜负绌猴紝闃叉鎶涘紓甯革紱
-                    continue;
-                }
-                var @null = locaDoorLockObjlist.Find((o) => { return o.ConnectedAccount == dictionary.Value.ConnectedAccount; });
-                if (@null == null)
-                {
-                    locaDoorLockObjlist.Add(dictionary.Value);
-                }
 
-            }
-            return locaDoorLockObjlist;
-        }
-        /// <summary>
-        /// 鑾峰彇闂ㄩ攣鏌愪釜鎴愬憳鐨勪俊鎭�
-        /// </summary>
-        /// <returns></returns>
-        public static List<ZigBee.Device.DoorLock.LocaDoorLockObj> GetUserIfon(string SubAccountDistributedMark)
-        {
-            var locaDoorLockObjlist = new List<ZigBee.Device.DoorLock.LocaDoorLockObj>();
-            locaDoorLockObjlist.Clear();
-            foreach (var dictionary in DoorLock.localDoorLockUserList)
-            {
-                if (string.IsNullOrEmpty(dictionary.Value.ConnectedAccount))
-                {
-                    //涓嶇煡閬撲紶杩囨潵ConnectedAccount涓轰粈涔堜负绌猴紝闃叉鎶涘紓甯革紱
-                    continue;
-                }
-                if (dictionary.Value.ConnectedAccount ==SubAccountDistributedMark)
-                {
-                    locaDoorLockObjlist.Add(dictionary.Value);
-                }
-            }
-            return locaDoorLockObjlist;
-        }
     }
 }
diff --git a/ZigbeeApp/Shared/Phone/Device/Logic/MemberList.cs b/ZigbeeApp/Shared/Phone/Device/Logic/MemberList.cs
index 39fe971..763516c 100644
--- a/ZigbeeApp/Shared/Phone/Device/Logic/MemberList.cs
+++ b/ZigbeeApp/Shared/Phone/Device/Logic/MemberList.cs
@@ -211,7 +211,7 @@
                     lockcolorfra1.Height = Application.GetRealHeight(140 + (160 * user.UserIdMode.Count) + 20 + 50);
                     for (int i = 0; i < user.UserIdMode.Count; i++)
                     {
-                        var userid = user.UserIdMode[i];
+                        var userifon = user.UserIdMode[i];
                         var doorlockfra = new FrameLayout
                         {
                             Height = Application.GetRealHeight(160),
@@ -237,8 +237,7 @@
                         };
                         doorlockRow.AddChidren(doorlockBtn);
                         //(1鎸夐敭/3鍗�/15鎸囩汗)
-                        string[] s = userid.Split('_');
-                        switch (s[1])
+                        switch (userifon.OpenMode.ToString())
                         {
                             case "0":
                                 {
@@ -286,8 +285,8 @@
                             {
                                 deviceConditionsInfo.Remove("AttriButeData2");
                             }
-                            deviceConditionsInfo.Add("AttriButeId", s[1]);
-                            deviceConditionsInfo.Add("AttriButeData2", s[0]);
+                            deviceConditionsInfo.Add("AttriButeId", userifon.OpenMode.ToString());
+                            deviceConditionsInfo.Add("AttriButeData2", userifon.UserId);
 
                             if (userdictionary.ContainsKey("Account"))
                             {
@@ -303,7 +302,7 @@
                             }
                             userdictionary.Add("Account", Btntitle.Text+doorlockBtn.Text);
                             userdictionary.Add("Type", "1");
-                            userdictionary.Add("UserId", s[0]);
+                            userdictionary.Add("UserId", userifon.UserId);
                         };
                         doorlockRow.MouseUpEventHandler += doorlockclick;
                         doorlockBtn.MouseUpEventHandler += doorlockclick;
@@ -311,7 +310,7 @@
                         doorlockfra.MouseUpEventHandler += doorlockclick;
                         if (edit)
                         {
-                            if (editdeviceConditionsInfo["AttriButeData2"] == s[1])
+                            if (editdeviceConditionsInfo["AttriButeData2"] == userifon.OpenMode.ToString())
                             {
                                 selectedIcon.Visible = false;
                                 selectedIcon = doorlockSelected;
diff --git a/ZigbeeApp/Shared/Phone/Device/Logic/Send.cs b/ZigbeeApp/Shared/Phone/Device/Logic/Send.cs
index 061d345..54081cb 100644
--- a/ZigbeeApp/Shared/Phone/Device/Logic/Send.cs
+++ b/ZigbeeApp/Shared/Phone/Device/Logic/Send.cs
@@ -609,7 +609,7 @@
                         logic.IsEnable = int.Parse(Logicifon["IsEnable"].ToString());
                         logic.LogicName = Logicifon["LogicName"].ToString();
                         logic.LogicType = int.Parse(Logicifon["LogicType"].ToString());
-                        logic.Relationship = int.Parse(Logicifon["Relationship"].ToString()); 
+                        logic.Relationship = int.Parse(Logicifon["Relationship"].ToString());
                         logic.TimeAttribute = Newtonsoft.Json.JsonConvert.DeserializeObject<Common.TimeAttributeObj>(Logicifon["TimeAttribute"].ToString());
                         logic.Conditions = Newtonsoft.Json.JsonConvert.DeserializeObject<List<Dictionary<string, string>>>(Logicifon["Conditions"].ToString());
                         logic.Accounts = Newtonsoft.Json.JsonConvert.DeserializeObject<List<Dictionary<string, string>>>(Logicifon["Accounts"].ToString());
@@ -712,12 +712,12 @@
             return Common.Room.Lists.FindAll((obj) => obj.FloorId == floorId);
 
         }
-# endregion
+        #endregion
 
         #region  ----鑾峰彇闂ㄩ攣
-        public static List<DoorLock> ReadDoorLockIfon(string doorlockMac)
+        public static List<LogicLock> ReadDoorLockIfon(string doorlockMac)
         {
-            List<DoorLock> list = new List<DoorLock>();
+            List<LogicLock> list = new List<LogicLock>();
             string url = "https://global.hdlcontrol.com/HangZhouHdlCloudApi/App/GetHomePager";//瀛愯处鍙峰拰涓昏处鍙峰彲鑳介摼鎺ヤ笉鍚�
             System.Net.WebClient webClient = new System.Net.WebClient();
             System.Collections.Specialized.NameValueCollection postValues = new System.Collections.Specialized.NameValueCollection();
@@ -784,9 +784,9 @@
 
         }
 
-        public static List<DoorLock> ReadToken(Residential residential)
+        public static List<LogicLock> ReadToken(Residential residential)
         {
-            List<DoorLock> list = new List<DoorLock>();
+            List<LogicLock> list = new List<LogicLock>();
             string url = "https://global.hdlcontrol.com/HangZhouHdlCloudApi/App/GetSharedHomeApiControl";
             System.Net.WebClient webClient = new System.Net.WebClient();
             System.Collections.Specialized.NameValueCollection postValues = new System.Collections.Specialized.NameValueCollection();
@@ -829,9 +829,9 @@
             return list;
         }
 
-        public static List<DoorLock> ReadDoorLock(Residential lockifon)
+        public static List<LogicLock> ReadDoorLock(Residential lockifon)
         {
-            List<DoorLock> list = new List<DoorLock>();
+            List<LogicLock> list = new List<LogicLock>();
             System.Net.WebClient webClient = new System.Net.WebClient();
             System.Collections.Specialized.NameValueCollection postValues = new System.Collections.Specialized.NameValueCollection();
             postValues.Add("RequestVersion", CommonPage.RequestVersion);
@@ -856,7 +856,7 @@
                     for (int i = 0; i < datalist.Count; i++)
                     {
                         var data = JObject.Parse(datalist[i].ToString());
-                        DoorLock doorLock = new DoorLock();
+                        LogicLock doorLock = new LogicLock();
                         doorLock.DoorLockLocalUserId = data["DoorLockLocalUserId"].ToString();
                         doorLock.OpenLockMode = int.Parse(data["OpenLockMode"].ToString());
                         doorLock.CloudAccountId = data["CloudAccountId"].ToString();
@@ -864,13 +864,13 @@
                     }
 
                 }
-                catch(Exception e)
+                catch (Exception e)
                 {
                     var s = e.Message;
                 }
 
             });
-           var datetime = DateTime.Now;
+            var datetime = DateTime.Now;
             while ((DateTime.Now - datetime).TotalMilliseconds < 3 * 1000)
             {
                 if (list.Count != 0)
@@ -881,54 +881,17 @@
             return list;
         }
 
-        public class Residential
+
+
+
+
+        #region ---绗�2绉�
+
+        public static async System.Threading.Tasks.Task<List<LogicLock>> UserListIfon(string doorlockMac)
         {
-            public string Id = string.Empty;
-            public bool IsOthreShare;
-            public string MainUserDistributedMark = string.Empty;
-            public string Url = string.Empty;
-            public string Token = string.Empty;
-            public bool IsOtherAccountCtrl;
-            public string doorlockmac;
-        }
-
-        public class DoorLock
-        {
-            public string DoorLockLocalUserId = string.Empty;
-            public int OpenLockMode;
-            public string CloudAccountId = string.Empty;
-            /// <summary>
-            /// 韬唤+瑙﹀彂婧�(0鎸夐敭/3鍗�/15鎸囩汗)
-            /// </summary>
-            public string UserIdMode
-            {
-                get
-                {
-                    return DoorLockLocalUserId + "_" + OpenLockMode.ToString();
-                }
-            }
-        }
-
-        public class MembershipIfon
-        {
-            public string MembershipId = string.Empty;
-            public List<string> UserIdMode = new List<string>();
-            public string MembershipName = string.Empty;
-        }
-
-        public static List<MembershipIfon> UserList = new List<MembershipIfon>();
-
-
-        #endregion
-        /*
-        public async System.Threading.Tasks.Task<List<>> a()
-        {
-            string url = "https://global.hdlcontrol.com/HangZhouHdlCloudApi/App/GetHomePager";
-            System.Collections.Specialized.NameValueCollection postValues = new System.Collections.Specialized.NameValueCollection();
-            postValues.Add("RequestVersion", CommonPage.RequestVersion);
-            postValues.Add("ReqDto.LoginAccessToken", Config.Instance.Token);
-            var str = await WebClientAsync(postValues, url);
-            var jObject = JObject.Parse(str);
+            List<LogicLock> list = new List<LogicLock>();
+            var s = await ReadUserList(doorlockMac);
+            var jObject = JObject.Parse(s);
             if (jObject == null || jObject["StateCode"].ToString() != "Success")
             {
                 return null;
@@ -938,63 +901,19 @@
             for (int i = 0; i < datalist.Count; i++)
             {
                 var data = JObject.Parse(datalist[i].ToString());
-                if (Config.Instance.HomeId == data["Id"].ToString())
-                {
-                    Residential residential = new Residential();
-
-                    if (Convert.ToBoolean(data["IsOthreShare"].ToString()))
-                    {
-                        //鍒嗕韩鑰匢D
-                        residential.Id = data["Id"].ToString();
-                        //鏄惁鏄垎浜处鍙穂true(鏄垎浜�);false;(涓嶆槸鍒嗕韩)];
-                        residential.IsOthreShare = Convert.ToBoolean(data["IsOthreShare"].ToString());
-                        //鍒嗕韩鑰呬綇瀹匢D
-                        residential.MainUserDistributedMark = data["MainUserDistributedMark"].ToString();
-                        residential.IsOtherAccountCtrl = true;
-                        //residential.doorlockmac = doorlockMac;
-                        //list = ReadToken(residential);
-                    }
-                    else
-                    {
-                        residential.Url = "https://global.hdlcontrol.com/HangZhouHdlCloudApi/DoorLock/GetDoorLockPager";
-                        residential.Token = Config.Instance.Token;
-                        residential.Id = Config.Instance.HomeId;
-                        residential.IsOtherAccountCtrl = false;
-                        //residential.doorlockmac = doorlockMac;
-                        //list = ReadDoorLock(residential);
-
-                    }
-                }
-
+                LogicLock doorLock = new LogicLock();
+                doorLock.DoorLockLocalUserId = data["DoorLockLocalUserId"].ToString();
+                doorLock.OpenLockMode = int.Parse(data["OpenLockMode"].ToString());
+                doorLock.CloudAccountId = data["CloudAccountId"].ToString();
+                list.Add(doorLock);
             }
+            return list;
         }
 
-        public async System.Threading.Tasks.Task<string> aa(int value, string url, Residential residential = null)
+        public static async System.Threading.Tasks.Task<string> ReadUserList(string doorlockMac)
         {
-            NameValueCollection postValues = new NameValueCollection();
-            if (value == 1)
-            {
-
-            }
-            else if (value == 2)
-            {
-                postValues.Add("RequestVersion", CommonPage.RequestVersion);
-                postValues.Add("LoginAccessToken", Config.Instance.Token);
-                postValues.Add("MainAccountId", residential.MainUserDistributedMark);
-                postValues.Add("SharedHid", residential.Id);
-            }
-            else
-            {
-                postValues.Add("RequestVersion", CommonPage.RequestVersion);
-                postValues.Add("ReqDto.LoginAccessToken", Config.Instance.Token);
-
-            }
-            return await WebClientAsync(postValues, url);
-        }
-
-        public async System.Threading.Tasks.Task<string> aaa(NameValueCollection postValues, string url)
-        {
-            var str = await aa(0, "https://global.hdlcontrol.com/HangZhouHdlCloudApi/App/GetHomePager");
+            string s = null;
+            var str = await WebClientAsync(0, "https://global.hdlcontrol.com/HangZhouHdlCloudApi/App/GetHomePager");
             var jObject = JObject.Parse(str);
             if (jObject == null || jObject["StateCode"].ToString() != "Success")
             {
@@ -1017,10 +936,9 @@
                         //鍒嗕韩鑰呬綇瀹匢D
                         residential.MainUserDistributedMark = data["MainUserDistributedMark"].ToString();
                         residential.IsOtherAccountCtrl = true;
-                        //residential.doorlockmac = doorlockMac;
-                        //list = ReadToken(residential);
-                      
-                        var str = await WebClientAsync(residential, postValues, url);
+                        residential.doorlockmac = doorlockMac;
+                        residential.Url = "https://global.hdlcontrol.com/HangZhouHdlCloudApi/App/GetSharedHomeApiControl";
+                        s = await ReadUserDoorLock(residential);
                     }
                     else
                     {
@@ -1028,13 +946,34 @@
                         residential.Token = Config.Instance.Token;
                         residential.Id = Config.Instance.HomeId;
                         residential.IsOtherAccountCtrl = false;
-                        //residential.doorlockmac = doorlockMac;
-                        var str = await WebClientAsync(postValues, url);
-
+                        residential.doorlockmac = doorlockMac;
+                        s = await WebClientAsync(2, residential.Url, residential);
                     }
-                }
 
+                }
             }
+            return s;
+        }
+
+        public static async System.Threading.Tasks.Task<string> ReadUserDoorLock(Residential residential)
+        {
+
+            var s = await WebClientAsync(1, residential.Url, residential);
+
+            var jObject = JObject.Parse(s);
+            if (jObject == null || jObject["StateCode"].ToString() != "Success")
+            {
+                return null;
+            }
+            var RequestBaseUrl = jObject["ResponseData"]["RequestBaseUrl"].ToString();
+            var RequestToken = jObject["ResponseData"]["RequestToken"].ToString();
+            Residential lockifon = new Residential();
+            lockifon.Url = RequestBaseUrl + "/DoorLock/GetDoorLockPager";
+            lockifon.Token = RequestToken;
+            lockifon.Id = Config.Instance.HomeId;
+            lockifon.IsOtherAccountCtrl = true;
+            lockifon.doorlockmac = residential.doorlockmac;
+            return await WebClientAsync(2, lockifon.Url, lockifon);
         }
 
         /// <summary>
@@ -1043,13 +982,107 @@
         /// <param name="postValues">post鍙傛暟</param>
         /// <param name="url"></param>
         /// <returns></returns>
-        public async System.Threading.Tasks.Task<string> WebClientAsync(NameValueCollection postValues, string url)
+        public static async System.Threading.Tasks.Task<string> WebClientAsync(int value, string url, Residential residential = null)
         {
+            
+            NameValueCollection postValues = new NameValueCollection();
+            if (value == 0)
+            {
+                postValues.Add("RequestVersion", CommonPage.RequestVersion);
+                postValues.Add("ReqDto.LoginAccessToken", Config.Instance.Token);
 
+            }
+            else if (value == 1)
+            {
+                postValues.Add("RequestVersion", CommonPage.RequestVersion);
+                postValues.Add("LoginAccessToken", Config.Instance.Token);
+                postValues.Add("MainAccountId", residential.MainUserDistributedMark);
+                postValues.Add("SharedHid", residential.Id);
+            }
+            else if (value == 2)
+            {
+                postValues.Add("RequestVersion", CommonPage.RequestVersion);
+                postValues.Add("LoginAccessToken", residential.Token);
+                postValues.Add("HomeId", residential.Id);
+                postValues.Add("DoorLockId", residential.doorlockmac);//闂ㄩ攣Mac
+                postValues.Add("IsOtherAccountCtrl", residential.IsOtherAccountCtrl.ToString());
+            }
             System.Net.WebClient webClient = new System.Net.WebClient();
             byte[] responseArray = webClient.UploadValues(url, postValues);
             return System.Text.Encoding.UTF8.GetString(responseArray);
         }
-        */
+        #endregion
+
+        public class Residential
+        {
+            /// <summary>
+            /// 浣忓畢ID
+            /// </summary>
+            public string Id = string.Empty;
+            /// <summary>
+            /// 褰撳墠浣忓畢鏄笉鏄叾浠栦富甯愬彿鍒嗕韩杩囨潵鐨�
+            /// </summary>
+            public bool IsOthreShare;
+            /// <summary>
+            /// 褰撳墠浣忓畢鏄笉鏄叾浠栦富甯愬彿鍒嗕韩杩囨潵鐨勪富甯愬彿鐨勫垎甯冨紡Id
+            /// </summary>
+            public string MainUserDistributedMark = string.Empty;
+            public string Url = string.Empty;
+            public string Token = string.Empty;
+            public bool IsOtherAccountCtrl;
+            /// <summary>
+            /// 褰撳墠闂ㄩ攣mac
+            /// </summary>
+            public string doorlockmac;
+        }
+
+        public class LogicLock
+        {
+            /// <summary>
+            /// 瑙﹀彂婧怚D
+            /// </summary>
+            public string DoorLockLocalUserId = string.Empty;
+            /// <summary>
+            /// 瑙﹀彂婧愭ā寮�(0:瀵嗙爜;3:鍗�;15:鎸囩汗;)
+            /// </summary>
+            public int OpenLockMode;
+            /// <summary>
+            /// 璇嗗埆鐢ㄦ埛韬唤
+            /// </summary>
+            public string CloudAccountId = string.Empty;
+        }
+
+        public class MembershipIfon
+        {
+            /// <summary>
+            /// 璇嗗埆鐢ㄦ埛韬唤
+            /// </summary>
+            public string MembershipId = string.Empty;
+            /// <summary>
+            /// 瑙﹀彂婧怚D+妯″紡(0:瀵嗙爜;3:鍗�;15:鎸囩汗;)
+            /// </summary>
+            public List<LockMode> UserIdMode = new List<LockMode>();
+            /// <summary>
+            /// 鐢ㄦ埛鏄电О
+            /// </summary>
+            public string MembershipName = string.Empty;
+        }
+
+        public class LockMode
+        {
+            /// <summary>
+            /// 瑙﹀彂婧怚D
+            /// </summary>
+            public string UserId = string.Empty;
+            /// <summary>
+            /// 瑙﹀彂婧愭ā寮�(0:瀵嗙爜;3:鍗�;15:鎸囩汗;)
+            /// </summary>
+            public int OpenMode;
+
+        }
+
+        public static List<MembershipIfon> UserList = new List<MembershipIfon>();
+       
+        #endregion
     }
 }
diff --git a/ZigbeeApp/Shared/Phone/Device/Logic/TemplateDeviceCondition.cs b/ZigbeeApp/Shared/Phone/Device/Logic/TemplateDeviceCondition.cs
index 1489f2e..074389f 100644
--- a/ZigbeeApp/Shared/Phone/Device/Logic/TemplateDeviceCondition.cs
+++ b/ZigbeeApp/Shared/Phone/Device/Logic/TemplateDeviceCondition.cs
@@ -1361,8 +1361,7 @@
                 case DeviceType.DoorLock:
                     {
                         #region  ------
-                        var doorlockifonlist = Send.ReadDoorLockIfon("ccccccfffe300347");
-                        //var list = Send.ReadDoorLockIfon(common.DeviceAddr);
+                        var doorlockifonlist = await Send.UserListIfon(common.DeviceAddr);
                         var pra = new UserCenter.MemberListInfoPra();
                         string result = await UserCenter.UserCenterLogic.GetResponseDataByRequestHttps("ZigbeeUsers/GetSubAccountByDistributedMark", false, pra);
                         var listInfo = Newtonsoft.Json.JsonConvert.DeserializeObject<List<UserCenter.MemberInfoRes>>(result);
@@ -1376,9 +1375,20 @@
                                 ///鏌ユ壘鎴愬憳浠ュ強鎴愬憳闂ㄩ攣瑙﹀彂婧�(1鎸夐敭/3鍗�/15鎸囩汗)
                                 if (doorlockifonlist[j].CloudAccountId == membershipifon.SubAccountDistributedMark)
                                 {
-                                    membership.UserIdMode.Add(doorlockifonlist[j].UserIdMode);
-                                    membership.MembershipName = membershipifon.UserName;
+                                    var lockMode = new Send.LockMode();
+                                    lockMode.UserId = doorlockifonlist[j].DoorLockLocalUserId;
+                                    lockMode.OpenMode = doorlockifonlist[j].OpenLockMode;
+                                    membership.UserIdMode.Add(lockMode);
                                     membership.MembershipId = membershipifon.SubAccountDistributedMark;
+                                    if (string.IsNullOrEmpty(membershipifon.UserName))
+                                    {
+                                        membership.MembershipName = membershipifon.Account;
+                                    }
+                                    else
+                                    {
+                                        membership.MembershipName = membershipifon.UserName;
+
+                                    }
 
                                 }
 
@@ -1386,7 +1396,7 @@
                             if (membership.UserIdMode.Count != 0)
                             {
                                 ///杩囨护鎺夐噸澶嶆暟鎹紱
-                                var str = Send.UserList.Find((c) => { return c.MembershipId == membership.MembershipId; });
+                                var str = Send.UserList.Find((c) => { return c.MembershipId == membershipifon.SubAccountDistributedMark; });
                                 if (str == null)
                                 {
                                     Send.UserList.Add(membership);

--
Gitblit v1.8.0