From 66a9965c44ecc32a6696abca876ab9d1cd091584 Mon Sep 17 00:00:00 2001
From: gxc <guoxuecheng@guoxuechengdeMacBook-Pro.local>
Date: 星期五, 28 二月 2020 15:25:13 +0800
Subject: [PATCH] 2020.2.28

---
 ZigbeeApp/Shared/Phone/UserCenter/Device/Bind/AddDevicePage.cs |  217 +++++++++++++++++++++++++++++++++--------------------
 1 files changed, 134 insertions(+), 83 deletions(-)

diff --git a/ZigbeeApp/Shared/Phone/UserCenter/Device/Bind/AddDevicePage.cs b/ZigbeeApp/Shared/Phone/UserCenter/Device/Bind/AddDevicePage.cs
index b740b67..c57bf0f 100755
--- a/ZigbeeApp/Shared/Phone/UserCenter/Device/Bind/AddDevicePage.cs
+++ b/ZigbeeApp/Shared/Phone/UserCenter/Device/Bind/AddDevicePage.cs
@@ -16,14 +16,8 @@
         /// <param name="common">Common.</param>
         public void Changed(CommonDevice common)
         {
-            //if (common.Type != ZigBee.Device.DeviceType.OnOffSwitch)
-            //{
-            //    return;
-            //}
-
             Shared.Application.RunOnMainThread(() =>
             {
-                //var dev = common as Panel;
             });
         }
 
@@ -87,7 +81,6 @@
             var btnAddFrameLayout = new FrameLayout
             {
                 X = Application.GetRealWidth(830),
-                Width = Application.GetRealWidth(200),
             };
             this.titleFrameLayout.AddChidren(btnAddFrameLayout);
 
@@ -97,7 +90,8 @@
                 X = Application.GetRealWidth(15),
                 Text = Language.StringByID(R.MyInternationalizationString.FirstFloor),
                 TextColor = Shared.Common.ZigbeeColor.Current.XMBlack,
-                TextSize = 15,
+                TextSize = 14,
+                IsBold = true,
                 TextAlignment = TextAlignment.CenterRight,
             };
             btnAddFrameLayout.AddChidren(btnFloorText);
@@ -111,10 +105,24 @@
                 Gravity = Gravity.CenterVertical,
             };
             btnAddFrameLayout.AddChidren(btnBindDown);
+
+            if (Common.Config.Instance.Home.FloorDics.Count == 0)
+            {
+                btnBindDown.Visible = false;
+            }
+
             btnBindDown.MouseDownEventHandler += (sender, e) =>
             {
                 SideslipFramelayout();
             };
+            if (Common.Config.Instance.Home.FloorDics.Count == 0)
+            {
+                btnAddFrameLayout.Width = 0;
+            }
+            else
+            {
+                btnAddFrameLayout.Width = Application.GetRealWidth(200);
+            }
             MidFrameLayoutContent(btnFloorText);
         }
 
@@ -157,11 +165,12 @@
             {
                 Width = Application.GetRealWidth(907),
                 Gravity = Gravity.CenterHorizontal,
-                Radius = (uint)Application.GetRealHeight(120) / 2,
+                Radius = (uint)Application.GetRealHeight(127) / 2,
                 TextID = R.MyInternationalizationString.ChooseKeyMode,
                 BackgroundColor = Shared.Common.ZigbeeColor.Current.XMBlack,
                 TextColor = Shared.Common.ZigbeeColor.Current.XMWhite,
                 TextSize = 16,
+                IsBold = true,
             };
             bottomFrameLayout.AddChidren(btnChooseKeyMode);
             #endregion
@@ -171,23 +180,34 @@
             dicFloor = Common.Room.CurrentRoom.GetFloorSortList();
             currentKey.currentSelectFloorId = BindInfo.GetCurrentSelectFloorId();
             btnFloorText.Text = BindInfo.GetCurrentSelectFloorIdName();
-            // 鑾峰彇妤煎眰瀵瑰簲瀵规埧闂�
-            foreach (var room in Shared.Common.Room.Lists)
+
+            if (Common.Config.Instance.Home.FloorDics.Count == 0)
             {
-                if (room.FloorId == currentKey.currentSelectFloorId)
+                // 鑾峰彇娌℃湁妤煎眰鎴块棿
+                foreach (var room in Shared.Common.Room.Lists)
                 {
-                    roomList.Add(room);
+                    if (string.IsNullOrEmpty(room.FloorId))
+                    {
+                        roomList.Add(room);
+                    }
                 }
             }
-            //褰撳墠鎸夐敭鎵�鏈夋樉绀烘埧闂寸殑鎵�鏈夎澶囧鐞�
-            var aa = GetALlDispalyRoomDeviceList();
+            else
+            {
+                // 鑾峰彇妤煎眰瀵瑰簲瀵规埧闂�
+                foreach (var room in Shared.Common.Room.Lists)
+                {
+                    if (room.FloorId == currentKey.currentSelectFloorId)
+                    {
+                        roomList.Add(room);
+                    }
+                }
+            }
             //棣栨鎷垮埌鎵�鏈夋埧闂翠腑鎸夐敭鐨勭洰鏍囧苟瀛樺偍
-            //if (IsInitEntry)
-            //{
-            //棣栨鎷垮埌鎵�鏈夋埧闂翠腑鎸夐敭鐨勭洰鏍囧苟瀛樺偍
+            GetALlDispalyRoomDeviceList();
             if (currentKeyAllRoomDeviceList.Count != 0)
             {
-                if (currentKey.bindList != null && currentKey.bindList.Count != 0)
+                if (currentKey.bindList.Count != 0)
                 {
                     foreach (var devA in currentKeyAllRoomDeviceList)
                     {
@@ -203,7 +223,7 @@
                     }
                 }
             }
-            if (oldTargetList != null)
+            if (oldTargetList.Count != 0)
             {
                 foreach (var de in oldTargetList.Keys)
                 {
@@ -212,7 +232,10 @@
                 }
             }
 
-            //}
+            if (roomList.Count == 0)
+            {
+                return;
+            }
             Shared.Common.Room curRoom = roomList[0];
             int index = 0;
             RefreshRoomList(curRoom, btnChooseKeyMode, ref index);
@@ -227,9 +250,23 @@
                 btnChooseKeyMode.Enable = true;
                 btnChooseKeyMode.BackgroundColor = Shared.Common.ZigbeeColor.Current.XMBlack;
             }
-
+            if (targetList.Count == 0)
+            {
+                btnChooseKeyMode.Enable = false;
+                btnChooseKeyMode.BackgroundColor = Shared.Common.ZigbeeColor.Current.XMUnSelect;
+            }
+            else
+            {
+                btnChooseKeyMode.Enable = true;
+                btnChooseKeyMode.BackgroundColor = Shared.Common.ZigbeeColor.Current.XMBlack;
+            }
             btnChooseKeyMode.MouseUpEventHandler += (sender, e) =>
             {
+                if (targetList.Count == 0)
+                {
+                    new Tip() { MaxWidth = 150, Text = Language.StringByID(R.MyInternationalizationString.BindDeviceTargetIsEmpty), Direction = AMPopTipDirection.Up, CloseTime = 1 }.Show(btnChooseKeyMode);
+                    return;
+                }
                 this.RemoveFromParent();
 
                 var chooseKeyModePage = new Shared.Phone.UserCenter.DeviceBind.ChooseKeyModePage(currentKey, curDeviceBindType, targetList);
@@ -282,12 +319,11 @@
 
                 var btnRoomFrameLayout = new FrameLayout
                 {
-                    Height = Application.GetRealHeight(78),
-                    Width = Application.GetRealWidth(187),
-                    Y = Application.GetRealHeight(58),
-                    X = Application.GetRealWidth(58),
-                    Radius = (uint)Application.GetMinRealAverage(78 / 2),
-                    BorderColor = Shared.Common.ZigbeeColor.Current.XMOrange,
+                    Height = Application.GetRealHeight(159),
+                    Width = Application.GetRealWidth(255),
+                    Y = Application.GetRealHeight(23),
+                    X = Application.GetRealWidth(5),
+                    BackgroundImagePath = "Item/RoomIconBackground.png",
                     BorderWidth = 1,
                 };
                 btnHorizontalScrolViewLayout.AddChidren(btnRoomFrameLayout);
@@ -308,9 +344,7 @@
                 btnRoom.IsSelected = false;
                 if (index == 0)
                 {
-                    btnRoom.BackgroundColor = Shared.Common.ZigbeeColor.Current.XMOrange;
-                    btnRoomFrameLayout.BackgroundColor = Shared.Common.ZigbeeColor.Current.XMOrange;
-                    btnRoomFrameLayout.BorderWidth = 0;
+                    btnRoomFrameLayout.BackgroundImagePath = "Item/RoomIconBackgroundSelected.png";
                     btnRoom.TextColor = Shared.Common.ZigbeeColor.Current.XMWhite;
                     curentOldRoom = btnRoom;
                     curentOldRoomFrameLayout = btnRoomFrameLayout;
@@ -322,24 +356,9 @@
                         if (curentOldRoom != null)
                         {
                             curentOldRoom.TextColor = Shared.Common.ZigbeeColor.Current.XMGray3;
-                            curentOldRoom.BackgroundColor = Shared.Common.ZigbeeColor.Current.XMMidFrameLayout;
                         }
                         curentOldRoom = btnRoom;
                         curentOldRoom.TextColor = Shared.Common.ZigbeeColor.Current.XMWhite;
-                        curentOldRoom.BackgroundColor = Shared.Common.ZigbeeColor.Current.XMOrange;
-                        curRoom = room;
-                        currentKey.RoomId = room.Id;
-                        RefreshDeviceList(curRoom);
-                        if (curTypeDeviceList.Count == 0)
-                        {
-                            btnChooseKeyMode.Enable = false;
-                            btnChooseKeyMode.BackgroundColor = Shared.Common.ZigbeeColor.Current.XMUnSelect;
-                        }
-                        else
-                        {
-                            btnChooseKeyMode.Enable = true;
-                            btnChooseKeyMode.BackgroundColor = Shared.Common.ZigbeeColor.Current.XMBlack;
-                        }
                     }
 
                     if (btnRoomFrameLayout.BorderWidth == 1)
@@ -347,35 +366,39 @@
                         if (curentOldRoomFrameLayout != null)
                         {
                             curentOldRoomFrameLayout.BorderWidth = 1;
-                            curentOldRoomFrameLayout.BackgroundColor = Shared.Common.ZigbeeColor.Current.XMMidFrameLayout;
+                            curentOldRoomFrameLayout.BorderColor = Shared.Common.ZigbeeColor.Current.XMOrange;
+                            curentOldRoomFrameLayout.BackgroundImagePath = "Item/RoomIconBackground.png";
                         }
                         curentOldRoomFrameLayout = btnRoomFrameLayout;
                         curentOldRoomFrameLayout.BorderWidth = 0;
-                        curentOldRoomFrameLayout.BackgroundColor = Shared.Common.ZigbeeColor.Current.XMOrange;
-                        curRoom = room;
-                        currentKey.RoomId = room.Id;
-                        RefreshDeviceList(curRoom);
-                        if (curTypeDeviceList.Count == 0)
-                        {
-                            btnChooseKeyMode.Enable = false;
-                            btnChooseKeyMode.BackgroundColor = Shared.Common.ZigbeeColor.Current.XMUnSelect;
-                        }
-                        else
-                        {
-                            btnChooseKeyMode.Enable = true;
-                            btnChooseKeyMode.BackgroundColor = Shared.Common.ZigbeeColor.Current.XMBlack;
-                        }
+                        curentOldRoomFrameLayout.BackgroundImagePath = "Item/RoomIconBackgroundSelected.png";
+                    }
+                    curRoom = room;
+                    currentKey.RoomId = room.Id;
+                    RefreshDeviceList(curRoom);
+                    if (curTypeDeviceList.Count == 0)
+                    {
+                        btnChooseKeyMode.Enable = false;
+                        btnChooseKeyMode.BackgroundColor = Shared.Common.ZigbeeColor.Current.XMUnSelect;
+                    }
+                    else
+                    {
+                        btnChooseKeyMode.Enable = true;
+                        btnChooseKeyMode.BackgroundColor = Shared.Common.ZigbeeColor.Current.XMBlack;
+                    }
+                    if (targetList.Count == 0)
+                    {
+                        btnChooseKeyMode.Enable = false;
+                        btnChooseKeyMode.BackgroundColor = Shared.Common.ZigbeeColor.Current.XMUnSelect;
+                    }
+                    else
+                    {
+                        btnChooseKeyMode.Enable = true;
+                        btnChooseKeyMode.BackgroundColor = Shared.Common.ZigbeeColor.Current.XMBlack;
                     }
                 };
                 btnRoom.MouseUpEventHandler += eHandlerRoom;
                 btnRoomFrameLayout.MouseUpEventHandler += eHandlerRoom;
-
-                var btnEmpty = new Button
-                {
-                    Width = Application.GetRealWidth(58),
-                    X = btnRoom.Right,
-                };
-                btnHorizontalScrolViewLayout.AddChidren(btnEmpty);
                 index++;
             }
             BindInfo.FinishDisplay(roomTempList, btnChooseKeyMode);
@@ -391,10 +414,6 @@
                 case "AddSwitch":
                     foreach (var r in Shared.Common.Room.Lists)
                     {
-                        if (r.IsLove == true)
-                        {
-                            var aa = 0; ;
-                        }
                         if (r.DeviceUIList.Count == 0)
                         {
                             continue;
@@ -522,6 +541,11 @@
             int curIndex = 0;
             foreach (var device in curTypeDeviceList)
             {
+                curIndex++;
+                if (device.CommonDevice != null && device.CommonDevice.IsOnline == 0)
+                {
+                    continue;
+                }
                 #region 缁戝畾琛║I鏄撅紙鏃犳暟鎹鐞嗭級
                 var rowLayout = new FrameLayout()
                 {
@@ -544,11 +568,12 @@
 
                 var btnBindName = new Button()
                 {
-                    Width = Application.GetRealWidth(500 - 120),
+                    Width = Application.GetRealWidth(790),
                     X = devicePic.Right + Application.GetRealWidth(20),
                     TextColor = Shared.Common.ZigbeeColor.Current.TextBlack,
                     TextAlignment = TextAlignment.CenterLeft,
                     Tag = device.CommonDevice?.DeviceEpointName,
+                    TextSize = 15,
                 };
                 rowLayout.AddChidren(btnBindName);
 
@@ -559,7 +584,6 @@
                     X = Application.GetRealWidth(861 + 81),
                     Y = Application.GetRealHeight(35),
                     SelectedImagePath = "DoorLock/SelectedIcon.png",
-                    //Text = device.CommonDevice?.DeviceEpointName,
                     TextColor = Shared.Common.ZigbeeColor.Current.XMWhite,
                     Visible = false,
                     Tag = device.CommonDevice?.DeviceEpointName,
@@ -576,7 +600,7 @@
                 };
                 rowLayout.AddChidren(line2);
 
-                if (curIndex == curRoom.SceneUIList.Count - 1)
+                if (curIndex == curTypeDeviceList.Count)
                 {
                     line2.Visible = false;
                 }
@@ -594,9 +618,26 @@
                     }
                     else
                     {
-                        targetList.Add(device.CommonDevice);
-                        btnChoose.IsSelected = true;
-                        btnChoose.Visible = true;
+                        if (targetList.Count > 7)
+                        {
+                            new Tip() { MaxWidth = 150, Text = Language.StringByID(R.MyInternationalizationString.BindFull), Direction = AMPopTipDirection.None, CloseTime = 1 }.Show(Common.CommonPage.Instance);
+                        }
+                        else
+                        {
+                            targetList.Add(device.CommonDevice);
+                            btnChoose.IsSelected = true;
+                            btnChoose.Visible = true;
+                        }
+                    }
+                    if (targetList.Count == 0)
+                    {
+                        btnChooseKeyMode.Enable = false;
+                        btnChooseKeyMode.BackgroundColor = Shared.Common.ZigbeeColor.Current.XMUnSelect;
+                    }
+                    else
+                    {
+                        btnChooseKeyMode.Enable = true;
+                        btnChooseKeyMode.BackgroundColor = Shared.Common.ZigbeeColor.Current.XMBlack;
                     }
                 };
                 rowLayout.MouseUpEventHandler += hander;
@@ -604,7 +645,7 @@
                 btnBindName.MouseUpEventHandler += hander;
                 btnChoose.MouseUpEventHandler += hander;
 
-                if (device.CommonDevice?.DeviceEpointName == "")
+                if (string.IsNullOrEmpty(device.CommonDevice?.DeviceEpointName))
                 {
                     btnBindName.Text = device.CommonDevice?.DeviceAddr + "_" + device.CommonDevice?.DeviceEpoint;
                 }
@@ -621,10 +662,17 @@
                         btnChoose.Visible = true;
                     }
                 }
-
-                curIndex++;
             }
-            //IsInitEntry = false;
+            if (targetList.Count == 0)
+            {
+                btnChooseKeyMode.Enable = false;
+                btnChooseKeyMode.BackgroundColor = Shared.Common.ZigbeeColor.Current.XMUnSelect;
+            }
+            else
+            {
+                btnChooseKeyMode.Enable = true;
+                btnChooseKeyMode.BackgroundColor = Shared.Common.ZigbeeColor.Current.XMBlack;
+            }
         }
 
         // 渚ц竟瀵艰埅鏍�
@@ -658,10 +706,11 @@
                 Height = Application.GetRealHeight(58),
                 X = Application.GetRealWidth(81),
                 Y = Application.GetRealHeight(81),
-                TextColor = Shared.Common.ZigbeeColor.Current.XMGray3,
+                TextColor = Shared.Common.ZigbeeColor.Current.XMBlack,
                 TextSize = 14,
                 TextAlignment = TextAlignment.CenterLeft,
                 TextID = R.MyInternationalizationString.SelectFloor,
+                IsBold = true,
             };
             sidelipFrameLayout.AddChidren(btnSelectFloor);
 
@@ -710,6 +759,7 @@
                 if (currentKey.currentSelectFloorId == floorId)
                 {
                     btnAllMethod.IsSelected = true;
+                    btnAllMethod.IsBold = true;
                     btnMethodText.TextColor = Shared.Common.ZigbeeColor.Current.XMBlack;
                 }
 
@@ -738,6 +788,7 @@
                         oldbuttonText = btnMethodText;
                         btnMethodText.IsSelected = true;
                         oldbuttonText.TextColor = Shared.Common.ZigbeeColor.Current.XMBlack;
+                        oldbuttonText.IsBold = true;
                     }
 
                     //鑾峰彇妤煎眰瀵瑰簲鐨勬埧闂�

--
Gitblit v1.8.0