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/Device/Category/Category.cs |  548 +++++++++++++++++++++++++++++-------------------------
 1 files changed, 298 insertions(+), 250 deletions(-)

diff --git a/ZigbeeApp/Shared/Phone/Device/Category/Category.cs b/ZigbeeApp/Shared/Phone/Device/Category/Category.cs
index 47604d0..867f080 100644
--- a/ZigbeeApp/Shared/Phone/Device/Category/Category.cs
+++ b/ZigbeeApp/Shared/Phone/Device/Category/Category.cs
@@ -8,6 +8,7 @@
 using Shared.Phone.Device.AC;
 using Shared.Phone.UserCenter.DoorLock;
 using Shared.Phone.Device.DeviceLogic;
+using Shared.Phone.UserCenter;
 
 namespace Shared.Phone.Device.Category
 {
@@ -282,14 +283,6 @@
                                                 case 28:
                                                     ac.currentSystemMode = attList.AttriButeData;
                                                     ac.LastDateTime = DateTime.Now;
-                                                    break;
-                                                case 4099:
-                                                    var value = Convert.ToString(attList.AttriButeData, 2).PadLeft(16, '0');
-                                                    var modeStr = value.Substring(value.Length - 5, 5);
-                                                    for (int j = 0; j < modeStr.Length; j++)
-                                                    {
-                                                        ac.listSupportMode[j] = Convert.ToInt32(modeStr[j]) == 49 ? 1 : 0;
-                                                    }
                                                     break;
                                                 case 4097:
                                                     //杩囪檻缃戞竻娲楁爣蹇�:42
@@ -808,6 +801,10 @@
             UserView.HomePage.Instance.AddChidren(scene);
             UserView.HomePage.Instance.PageIndex += 1;
             scene.Show();
+            scene.AddAction = () =>
+            {
+                ShowScene();
+            };
         }
 
         /// <summary>
@@ -880,7 +877,7 @@
             typeIdDic.Clear();
             foreach (var device in devList)
             {
-                var info = Common.LocalDevice.Current.GetNotHdlMyDeviceEnumInfo(new List<CommonDevice> { device.CommonDevice });
+                var info = Common.LocalDevice.Current.GetDeviceBelongEnumInfo(device.CommonDevice);
                 if (info.BeloneType == DeviceBeloneType.A骞叉帴鐐� || info.BeloneType == DeviceBeloneType.A涓户鍣�)
                 {
                     continue;
@@ -1053,43 +1050,14 @@
                     {
                         try
                         {
-                            //鍒犻櫎璁惧
-                            EventHandler<MouseEventArgs> delEvent = (delSender, delE) =>
+                            var deviceTypeRowLayout = new RowLayout()
                             {
-                                var alert = new CustomAlert();
-                                AddChidren(alert);
-                                alert.Show(Language.StringByID(R.MyInternationalizationString.DeleteFunction));
-                                alert.ResultEventHandler += (e2) =>
-                                {
-                                    if (e2)
-                                    {
-                                        if (Common.Room.CurrentRoom.IsLove)
-                                        {
-                                            Shared.Common.Room.CurrentRoom.DeleteDevice(deviceUI.FileName);
-                                            deviceListScrolView.RemoveViewByTag((delSender as Button).Tag);
-                                            sameTypeList.Remove(deviceUI);
-                                        }
-                                        else
-                                        {
-                                            Shared.Common.Room.CurrentRoom.DeleteDevice(deviceUI.CommonDevice);
-                                            deviceListScrolView.RemoveViewByTag((delSender as Button).Tag);
-                                            sameTypeList.Remove(deviceUI);
-                                        }
-                                        //if (sameTypeList.Count == 0)
-                                        //{
-                                        //    RefreshBodyView();
-                                        //}
-                                    }
-                                };
+                                Height = Application.GetRealHeight(127 + 35),
+                                LineColor = ZigbeeColor.Current.GXCClearColor,
+                                Tag = deviceUI,
+                                SubViewWidth=Application.GetRealWidth(184)
                             };
-                            EventHandler<MouseEventArgs> deviceDetailHandler = (send2, e2) =>
-                            {
-                                var detailInfo = new Device.CommonForm.DeviceDetailInfo { };
-                                UserView.HomePage.Instance.AddChidren(detailInfo);
-                                UserView.HomePage.Instance.PageIndex += 1;
-                                detailInfo.Show(deviceUI, Shared.Common.Room.CurrentRoom);
-                                detailInfo.action = RefreshBodyView;
-                            };
+                            deviceListScrolView.AddChidren(deviceTypeRowLayout);
 
                             if (deviceUI.CommonDevice.Type == DeviceType.OnOffOutput)
                             {
@@ -1118,18 +1086,9 @@
                                     })
                                     { IsBackground = true }.Start();
 
-                                    var deviceTypeRowLayout = new RowLayout()
-                                    {
-                                        Height = Application.GetRealHeight(129 + 35),
-                                        LineColor = ZigbeeColor.Current.GXCBackgroundColor,
-                                        Tag = deviceUI
-                                    };
-                                    deviceListScrolView.AddChidren(deviceTypeRowLayout);
-
                                     var deviceRow = new CategoryFunctionRow(0, 35);
                                     deviceRow.Init(deviceUI.IconPath, deviceUI.OnlineIconPath);
-                                    deviceRow.SetTitle(deviceUI.CommonDevice.DeviceEpointName);
-                                    //deviceRow.SetOnLineStatu(light.IsOnline == 1);
+                                    deviceRow.SetTitle(Common.LocalDevice.Current.GetDeviceEpointName(deviceUI.CommonDevice));
                                     deviceRow.SetStatuText(deviceUI.GetDeviceStatu());
                                     deviceRow.IsSelected = light.OnOffStatus == 1;
                                     deviceTypeRowLayout.AddChidren(deviceRow);
@@ -1165,51 +1124,37 @@
                                             }
                                         });
                                     };
-
                                     deviceRow.ClickBtn.MouseUpEventHandler += (send2, e2) =>
                                     {
-                                        if (deviceUI.CommonDevice.DfunctionType == DeviceFunctionType.A寮�鍏�)
+                                        var lightControl = new Phone.Device.Light.OnOffControl();
+                                        UserView.HomePage.Instance.AddChidren(lightControl);
+                                        UserView.HomePage.Instance.PageIndex += 1;
+                                        lightControl.Show(deviceUI, Common.Room.CurrentRoom);
+                                        lightControl.action += (curDev, curRoom) =>
                                         {
-                                            var lightControl = new Phone.Device.Light.OnOffControl();
-                                            UserView.HomePage.Instance.AddChidren(lightControl);
-                                            UserView.HomePage.Instance.PageIndex += 1;
-                                            //lightControl.action = RefreshBodyView;
-                                            lightControl.Show(deviceUI, Common.Room.CurrentRoom);
-                                        }
-                                        else if (deviceUI.CommonDevice.DfunctionType == DeviceFunctionType.A鎻掑骇)
-                                        {
-                                            var lightControl = new Phone.Device.Light.PlugControl();
-                                            UserView.HomePage.Instance.AddChidren(lightControl);
-                                            UserView.HomePage.Instance.PageIndex += 1;
-                                            //lightControl.action = RefreshBodyView;
-                                            lightControl.Show(deviceUI, Common.Room.CurrentRoom);
-                                        }
-                                        else
-                                        {
-                                            var lightControl = new Phone.Device.Light.LightControl();
-                                            UserView.HomePage.Instance.AddChidren(lightControl);
-                                            UserView.HomePage.Instance.PageIndex += 1;
-                                            //lightControl.action = RefreshBodyView;
-                                            lightControl.Show(deviceUI, Common.Room.CurrentRoom);
-                                        }
+                                            ReFreshDeviceAction(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+                                        };
                                     };
 
+                                    EventHandler<MouseEventArgs> deviceDetailHandler = (send2, e2) =>
+                                    {
+                                        var detailInfo = new Device.CommonForm.DeviceDetailInfo { };
+                                        UserView.HomePage.Instance.AddChidren(detailInfo);
+                                        UserView.HomePage.Instance.PageIndex += 1;
+                                        detailInfo.Show(deviceUI, Shared.Common.Room.CurrentRoom);
+                                        detailInfo.EditAction += (curDevice, curRoom) =>
+                                        {
+                                            ReFreshDeviceAction(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+                                        };
+                                    };
                                     var editBtn = new CommonForm.RowLayoutEditButton()
                                     {
-                                        Tag = deviceUI,
-                                        Radius = 0
-                                    };
-                                    var delBtn = new CommonForm.RowLayoutDeleteButton()
-                                    {
-                                        Tag = deviceUI,
-                                        Radius = 0
+                                        Tag = deviceUI
                                     };
                                     if (Common.Room.CurrentRoom.IsSharedRoom == false)
                                     {
                                         deviceTypeRowLayout.AddRightView(editBtn);
                                         editBtn.MouseUpEventHandler += deviceDetailHandler;
-                                        deviceTypeRowLayout.AddRightView(delBtn);
-                                        delBtn.MouseUpEventHandler += delEvent;
                                     }
                                 }
                             }
@@ -1239,22 +1184,12 @@
                                     })
                                     { IsBackground = true }.Start();
 
-                                    var deviceTypeRowLayout = new RowLayout()
-                                    {
-                                        Height = Application.GetRealHeight(129 + 35),
-                                        LineColor = ZigbeeColor.Current.GXCBackgroundColor,
-                                        Tag = deviceUI
-                                    };
-                                    deviceListScrolView.AddChidren(deviceTypeRowLayout);
-
                                     var deviceRow = new CategoryFunctionRow(0, 35);
                                     deviceRow.Init(deviceUI.IconPath, deviceUI.OnlineIconPath);
-                                    deviceRow.SetTitle(deviceUI.CommonDevice.DeviceEpointName);
-                                    //deviceRow.SetOnLineStatu(airSwitch.IsOnline == 1);
+                                    deviceRow.SetTitle(Common.LocalDevice.Current.GetDeviceEpointName(deviceUI.CommonDevice));
                                     deviceRow.IsSelected = airSwitch.OnOffStatus == 1;
                                     deviceRow.SetStatuText(deviceUI.GetDeviceStatu());
                                     deviceTypeRowLayout.AddChidren(deviceRow);
-
                                     deviceRow.SwitchBtn.MouseUpEventHandler += (send2, e2) =>
                                     {
                                         zbGateway = deviceUI.CommonDevice.Gateway;
@@ -1286,33 +1221,41 @@
                                             }
                                         });
                                     };
-
                                     deviceRow.ClickBtn.MouseUpEventHandler += (send2, e2) =>
                                     {
 
                                         var lightControl = new Phone.Device.Light.AirSwitchControl();
                                         UserView.HomePage.Instance.AddChidren(lightControl);
                                         UserView.HomePage.Instance.PageIndex += 1;
-                                        //lightControl.action = RefreshBodyView;
                                         lightControl.Show(deviceUI, Common.Room.CurrentRoom);
+                                        lightControl.action += (curDev, curRoom) =>
+                                        {
+
+                                            ReFreshDeviceAction(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+
+                                        };
                                     };
 
+                                    EventHandler<MouseEventArgs> deviceDetailHandler = (send2, e2) =>
+                                    {
+                                        var detailInfo = new Device.CommonForm.DeviceDetailInfo { };
+                                        UserView.HomePage.Instance.AddChidren(detailInfo);
+                                        UserView.HomePage.Instance.PageIndex += 1;
+                                        detailInfo.Show(deviceUI, Shared.Common.Room.CurrentRoom);
+                                        detailInfo.EditAction += (curDevice, curRoom) =>
+                                        {
+                                            ReFreshDeviceAction(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+
+                                        };
+                                    };
                                     var editBtn = new CommonForm.RowLayoutEditButton()
                                     {
-                                        Tag = deviceUI,
-                                        Radius = 0
-                                    };
-                                    var delBtn = new CommonForm.RowLayoutDeleteButton()
-                                    {
-                                        Tag = deviceUI,
-                                        Radius = 0
+                                        Tag = deviceUI
                                     };
                                     if (Common.Room.CurrentRoom.IsSharedRoom == false)
                                     {
                                         deviceTypeRowLayout.AddRightView(editBtn);
                                         editBtn.MouseUpEventHandler += deviceDetailHandler;
-                                        deviceTypeRowLayout.AddRightView(delBtn);
-                                        delBtn.MouseUpEventHandler += delEvent;
                                     }
                                 }
                             }
@@ -1342,18 +1285,9 @@
                                     })
                                     { IsBackground = true }.Start();
 
-                                    var deviceTypeRowLayout = new RowLayout()
-                                    {
-                                        Height = Application.GetRealHeight(129 + 35),
-                                        LineColor = ZigbeeColor.Current.GXCBackgroundColor,
-                                        Tag = deviceUI
-                                    };
-                                    deviceListScrolView.AddChidren(deviceTypeRowLayout);
-
                                     var deviceRow = new CategoryFunctionRow(0, 35);
                                     deviceRow.Init(deviceUI.IconPath, deviceUI.OnlineIconPath);
-                                    deviceRow.SetTitle(deviceUI.CommonDevice.DeviceEpointName);
-                                    //deviceRow.SetOnLineStatu(dimmableLight.IsOnline == 1);
+                                    deviceRow.SetTitle(Common.LocalDevice.Current.GetDeviceEpointName(deviceUI.CommonDevice));
                                     deviceRow.SetStatuText(deviceUI.GetDeviceStatu());
                                     deviceRow.IsSelected = dimmableLight.OnOffStatus == 1;
                                     deviceTypeRowLayout.AddChidren(deviceRow);
@@ -1396,26 +1330,33 @@
                                         UserView.HomePage.Instance.AddChidren(dimmableLightControl);
                                         UserView.HomePage.Instance.PageIndex += 1;
                                         UserView.HomePage.Instance.ScrollEnabled = false;
-                                        //dimmableLightControl.action = RefreshBodyView;
                                         dimmableLightControl.Show(deviceUI, Common.Room.CurrentRoom);
+                                        dimmableLightControl.action += (curDev, curRoom) =>
+                                        {
+                                            ReFreshDeviceAction(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+                                        };
+
                                     };
 
+                                    EventHandler<MouseEventArgs> deviceDetailHandler = (send2, e2) =>
+                                    {
+                                        var detailInfo = new Device.CommonForm.DeviceDetailInfo { };
+                                        UserView.HomePage.Instance.AddChidren(detailInfo);
+                                        UserView.HomePage.Instance.PageIndex += 1;
+                                        detailInfo.Show(deviceUI, Shared.Common.Room.CurrentRoom);
+                                        detailInfo.EditAction += (curDevice, curRoom) =>
+                                        {
+                                            ReFreshDeviceAction(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+                                        };
+                                    };
                                     var editBtn = new CommonForm.RowLayoutEditButton()
                                     {
-                                        Tag = deviceUI,
-                                        Radius = 0
-                                    };
-                                    var delBtn = new Device.CommonForm.RowLayoutDeleteButton()
-                                    {
-                                        Tag = deviceUI,
-                                        Radius = 0
+                                        Tag = deviceUI
                                     };
                                     if (Common.Room.CurrentRoom.IsSharedRoom == false)
                                     {
                                         deviceTypeRowLayout.AddRightView(editBtn);
                                         editBtn.MouseUpEventHandler += deviceDetailHandler;
-                                        deviceTypeRowLayout.AddRightView(delBtn);
-                                        delBtn.MouseUpEventHandler += delEvent;
                                     }
                                 }
                             }
@@ -1447,18 +1388,9 @@
                                     })
                                     { IsBackground = true }.Start();
 
-                                    var deviceTypeRowLayout = new RowLayout()
-                                    {
-                                        Height = Application.GetRealHeight(129 + 35),
-                                        LineColor = ZigbeeColor.Current.GXCBackgroundColor,
-                                        Tag = deviceUI
-                                    };
-                                    deviceListScrolView.AddChidren(deviceTypeRowLayout);
-
                                     var deviceRow = new CategoryFunctionRow(0, 35);
                                     deviceRow.Init(deviceUI.IconPath, deviceUI.OnlineIconPath);
-                                    deviceRow.SetTitle(deviceUI.CommonDevice.DeviceEpointName);
-                                    //deviceRow.SetOnLineStatu(ac.IsOnline == 1);
+                                    deviceRow.SetTitle(Common.LocalDevice.Current.GetDeviceEpointName(deviceUI.CommonDevice));
                                     deviceRow.SetStatuText(deviceUI.GetDeviceStatu());
                                     deviceRow.IsSelected = ac.currentSystemMode != 1;
                                     deviceTypeRowLayout.AddChidren(deviceRow);
@@ -1495,34 +1427,41 @@
                                             }
                                         });
                                     };
-
-                                    var editBtn = new CommonForm.RowLayoutEditButton()
-                                    {
-                                        Tag = deviceUI,
-                                        Radius = 0
-                                    };
-                                    var delBtn = new CommonForm.RowLayoutDeleteButton()
-                                    {
-                                        Tag = deviceUI,
-                                        Radius = 0
-                                    };
-                                    if (Common.Room.CurrentRoom.IsSharedRoom == false)
-                                    {
-                                        deviceTypeRowLayout.AddRightView(editBtn);
-                                        editBtn.MouseUpEventHandler += deviceDetailHandler;
-                                        deviceTypeRowLayout.AddRightView(delBtn);
-                                        delBtn.MouseUpEventHandler += delEvent;
-                                    }
-
                                     deviceRow.ClickBtn.MouseUpEventHandler += (send2, e2) =>
                                     {
                                         var acControl = new Phone.Device.AC.ACControl();
                                         UserView.HomePage.Instance.AddChidren(acControl);
                                         UserView.HomePage.Instance.PageIndex += 1;
                                         UserView.HomePage.Instance.ScrollEnabled = false;
-                                        //rollerShadeControl.action = RefreshBodyView;
                                         acControl.Show(deviceUI, Common.Room.CurrentRoom);
+                                        acControl.action += (curDev, curRoom) =>
+                                        {
+                                            ReFreshDeviceAction(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+
+                                        };
                                     };
+
+                                    EventHandler<MouseEventArgs> deviceDetailHandler = (send2, e2) =>
+                                    {
+                                        var detailInfo = new Device.CommonForm.DeviceDetailInfo { };
+                                        UserView.HomePage.Instance.AddChidren(detailInfo);
+                                        UserView.HomePage.Instance.PageIndex += 1;
+                                        detailInfo.Show(deviceUI, Shared.Common.Room.CurrentRoom);
+                                        detailInfo.EditAction += (curDevice, curRoom) =>
+                                        {
+                                            ReFreshDeviceAction(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+
+                                        };
+                                    };
+                                    var editBtn = new CommonForm.RowLayoutEditButton()
+                                    {
+                                        Tag = deviceUI
+                                    };
+                                    if (Common.Room.CurrentRoom.IsSharedRoom == false)
+                                    {
+                                        deviceTypeRowLayout.AddRightView(editBtn);
+                                        editBtn.MouseUpEventHandler += deviceDetailHandler;
+                                    }
                                 }
                             }
                             else if (deviceUI.CommonDevice.Type == DeviceType.WindowCoveringDevice)
@@ -1552,18 +1491,9 @@
                                     })
                                     { IsBackground = true }.Start();
 
-                                    var deviceTypeRowLayout = new RowLayout()
-                                    {
-                                        Height = Application.GetRealHeight(129 + 35),
-                                        LineColor = ZigbeeColor.Current.GXCBackgroundColor,
-                                        Tag = deviceUI
-                                    };
-                                    deviceListScrolView.AddChidren(deviceTypeRowLayout);
-
                                     var deviceRow = new CategoryFunctionForWinRow(0, 35);
                                     deviceRow.Init(deviceUI);
-                                    deviceRow.SetTitle(deviceUI.CommonDevice.DeviceEpointName);
-                                    //deviceRow.SetOnLineStatu(rollerShade.IsOnline == 1);
+                                    deviceRow.SetTitle(Common.LocalDevice.Current.GetDeviceEpointName(deviceUI.CommonDevice));
                                     deviceRow.SetStatuText(deviceUI.GetDeviceStatu());
                                     deviceRow.IsSelected = rollerShade.WcdCurrentPositionLiftPercentage != 0;
                                     deviceRow.SetRollerShadeIcon(rollerShade.WcdType);
@@ -1586,47 +1516,46 @@
                                         { IsBackground = true }.Start();
                                     }
 
-                                    var editBtn = new CommonForm.RowLayoutEditButton()
-                                    {
-                                        Tag = deviceUI,
-                                    };
-                                    var delBtn = new Device.CommonForm.RowLayoutDeleteButton()
-                                    {
-                                        Tag = deviceUI,
-                                    };
-                                    if (Common.Room.CurrentRoom.IsSharedRoom == false)
-                                    {
-                                        deviceTypeRowLayout.AddRightView(editBtn);
-                                        editBtn.MouseUpEventHandler += deviceDetailHandler;
-                                        deviceTypeRowLayout.AddRightView(delBtn);
-                                        delBtn.MouseUpEventHandler += delEvent;
-                                    }
-
                                     deviceRow.ClickBtn.MouseUpEventHandler += (send2, e2) =>
                                     {
                                         var rollerShadeControl = new Phone.Device.Curtain.RollerShadeControl();
                                         UserView.HomePage.Instance.AddChidren(rollerShadeControl);
                                         UserView.HomePage.Instance.PageIndex += 1;
                                         UserView.HomePage.Instance.ScrollEnabled = false;
-                                        //rollerShadeControl.action = RefreshBodyView;
                                         rollerShadeControl.Show(deviceUI, Common.Room.CurrentRoom);
+                                        rollerShadeControl.action += (curDev, curRoom) =>
+                                        {
+                                            ReFreshDeviceActionForWin(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+                                        };
                                     };
+
+                                    EventHandler<MouseEventArgs> deviceDetailHandler = (send2, e2) =>
+                                    {
+                                        var detailInfo = new Device.CommonForm.DeviceDetailInfo { };
+                                        UserView.HomePage.Instance.AddChidren(detailInfo);
+                                        UserView.HomePage.Instance.PageIndex += 1;
+                                        detailInfo.Show(deviceUI, Shared.Common.Room.CurrentRoom);
+                                        detailInfo.EditAction += (curDevice, curRoom) =>
+                                        {
+                                            ReFreshDeviceActionForWin(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+                                        };
+                                    };
+                                    var editBtn = new CommonForm.RowLayoutEditButton()
+                                    {
+                                        Tag = deviceUI
+                                    };
+                                    if (Common.Room.CurrentRoom.IsSharedRoom == false)
+                                    {
+                                        deviceTypeRowLayout.AddRightView(editBtn);
+                                        editBtn.MouseUpEventHandler += deviceDetailHandler;
+                                    }
                                 }
                             }
                             else if (deviceUI.CommonDevice.Type == DeviceType.DoorLock)
                             {
-                                var deviceTypeRowLayout = new RowLayout()
-                                {
-                                    Height = Application.GetRealHeight(129 + 35),
-                                    LineColor = ZigbeeColor.Current.GXCBackgroundColor,
-                                    Tag = deviceUI
-                                };
-                                deviceListScrolView.AddChidren(deviceTypeRowLayout);
-
                                 var deviceRow = new CategoryFunctionRow(0, 35);
                                 deviceRow.Init(deviceUI.IconPath, deviceUI.OnlineIconPath);
-                                deviceRow.SetTitle(deviceUI.CommonDevice.DeviceEpointName);
-                                //deviceRow.SetOnLineStatu(deviceUI.CommonDevice.IsOnline == 1);
+                                deviceRow.SetTitle(Common.LocalDevice.Current.GetDeviceEpointName(deviceUI.CommonDevice));
                                 deviceRow.SetStatuText(deviceUI.GetDeviceStatu());
                                 deviceRow.HideSwitchBtn(true);
                                 deviceTypeRowLayout.AddChidren(deviceRow);
@@ -1638,12 +1567,18 @@
                                     HomePage.Instance.PageIndex += 1;
                                     userDoorLockPage.Show();
                                 };
-
-                                var editBtn = new CommonForm.RowLayoutEditButton()
+                                EventHandler<MouseEventArgs> deviceDetailHandler = (send2, e2) =>
                                 {
-                                    Tag = deviceUI
+                                    var detailInfo = new Device.CommonForm.DeviceDetailInfo { };
+                                    UserView.HomePage.Instance.AddChidren(detailInfo);
+                                    UserView.HomePage.Instance.PageIndex += 1;
+                                    detailInfo.Show(deviceUI, Shared.Common.Room.CurrentRoom);
+                                    detailInfo.EditAction += (curDevice, curRoom) =>
+                                    {
+                                        ReFreshDeviceAction(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+                                    };
                                 };
-                                var delBtn = new Device.CommonForm.RowLayoutDeleteButton()
+                                var editBtn = new CommonForm.RowLayoutEditButton()
                                 {
                                     Tag = deviceUI
                                 };
@@ -1651,33 +1586,30 @@
                                 {
                                     deviceTypeRowLayout.AddRightView(editBtn);
                                     editBtn.MouseUpEventHandler += deviceDetailHandler;
-                                    deviceTypeRowLayout.AddRightView(delBtn);
-                                    delBtn.MouseUpEventHandler += delEvent;
                                 }
                             }
                             else if (deviceUI.CommonDevice.Type == DeviceType.IASZone)
                             {
-                                var deviceTypeRowLayout = new RowLayout()
-                                {
-                                    Height = Application.GetRealHeight(129 + 35),
-                                    LineColor = ZigbeeColor.Current.GXCBackgroundColor,
-                                    Tag = deviceUI
-                                };
-                                deviceListScrolView.AddChidren(deviceTypeRowLayout);
-
                                 var deviceRow = new CategoryFunctionRow(0, 35);
                                 deviceRow.Init(deviceUI.IconPath, deviceUI.OnlineIconPath);
-                                deviceRow.SetTitle(deviceUI.CommonDevice.DeviceEpointName);
+                                deviceRow.SetTitle(Common.LocalDevice.Current.GetDeviceEpointName(deviceUI.CommonDevice));
                                 deviceRow.SetStatuText(deviceUI.GetDeviceStatu());
                                 deviceRow.IsSelected = (deviceUI.CommonDevice as IASZone).iASInfo?.Alarm1 == 1;
                                 deviceRow.HideSwitchBtn(true);
                                 deviceTypeRowLayout.AddChidren(deviceRow);
 
-                                var editBtn = new CommonForm.RowLayoutEditButton()
+                                EventHandler<MouseEventArgs> deviceDetailHandler = (send2, e2) =>
                                 {
-                                    Tag = deviceUI
+                                    var detailInfo = new Device.CommonForm.DeviceDetailInfo { };
+                                    UserView.HomePage.Instance.AddChidren(detailInfo);
+                                    UserView.HomePage.Instance.PageIndex += 1;
+                                    detailInfo.Show(deviceUI, Shared.Common.Room.CurrentRoom);
+                                    detailInfo.EditAction += (curDevice, curRoom) =>
+                                    {
+                                        ReFreshDeviceAction(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+                                    };
                                 };
-                                var delBtn = new Device.CommonForm.RowLayoutDeleteButton()
+                                var editBtn = new CommonForm.RowLayoutEditButton()
                                 {
                                     Tag = deviceUI
                                 };
@@ -1685,8 +1617,6 @@
                                 {
                                     deviceTypeRowLayout.AddRightView(editBtn);
                                     editBtn.MouseUpEventHandler += deviceDetailHandler;
-                                    deviceTypeRowLayout.AddRightView(delBtn);
-                                    delBtn.MouseUpEventHandler += delEvent;
                                 }
                             }
                             else if (deviceUI.CommonDevice.Type == DeviceType.TemperatureSensor)
@@ -1727,27 +1657,27 @@
                                         }
                                     })
                                     { IsBackground = true }.Start();
-                                    var deviceTypeRowLayout = new RowLayout()
-                                    {
-                                        Height = Application.GetRealHeight(129 + 35),
-                                        LineColor = ZigbeeColor.Current.GXCBackgroundColor,
-                                        Tag = deviceUI
-                                    };
-                                    deviceListScrolView.AddChidren(deviceTypeRowLayout);
 
                                     var deviceRow = new CategoryFunctionRow(0, 35);
                                     deviceRow.Init(deviceUI.IconPath, deviceUI.OnlineIconPath);
-                                    deviceRow.SetTitle(deviceUI.CommonDevice.DeviceEpointName);
+                                    deviceRow.SetTitle(Common.LocalDevice.Current.GetDeviceEpointName(deviceUI.CommonDevice));
                                     deviceRow.SetStatuText(deviceUI.GetDeviceStatu());
                                     deviceRow.IsSelected = false;
                                     deviceRow.HideSwitchBtn(true);
                                     deviceTypeRowLayout.AddChidren(deviceRow);
 
-                                    var editBtn = new CommonForm.RowLayoutEditButton()
+                                    EventHandler<MouseEventArgs> deviceDetailHandler = (send2, e2) =>
                                     {
-                                        Tag = deviceUI
+                                        var detailInfo = new Device.CommonForm.DeviceDetailInfo { };
+                                        UserView.HomePage.Instance.AddChidren(detailInfo);
+                                        UserView.HomePage.Instance.PageIndex += 1;
+                                        detailInfo.Show(deviceUI, Shared.Common.Room.CurrentRoom);
+                                        detailInfo.EditAction += (curDevice, curRoom) =>
+                                        {
+                                            ReFreshDeviceAction(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+                                        };
                                     };
-                                    var delBtn = new Device.CommonForm.RowLayoutDeleteButton()
+                                    var editBtn = new CommonForm.RowLayoutEditButton()
                                     {
                                         Tag = deviceUI
                                     };
@@ -1755,35 +1685,30 @@
                                     {
                                         deviceTypeRowLayout.AddRightView(editBtn);
                                         editBtn.MouseUpEventHandler += deviceDetailHandler;
-                                        deviceTypeRowLayout.AddRightView(delBtn);
-                                        delBtn.MouseUpEventHandler += delEvent;
                                     }
-
                                 }
                             }
                             else
                             {
-                                var deviceTypeRowLayout = new RowLayout()
-                                {
-                                    Height = Application.GetRealHeight(129 + 35),
-                                    LineColor = ZigbeeColor.Current.GXCBackgroundColor,
-                                    Tag = deviceUI
-                                };
-                                deviceListScrolView.AddChidren(deviceTypeRowLayout);
-
                                 var deviceRow = new CategoryFunctionRow(0, 35);
                                 deviceRow.Init(deviceUI.IconPath, deviceUI.OnlineIconPath);
-                                deviceRow.SetTitle(deviceUI.CommonDevice.DeviceEpointName);
-                                //deviceRow.SetOnLineStatu(deviceUI.CommonDevice.IsOnline == 1);
+                                deviceRow.SetTitle(Common.LocalDevice.Current.GetDeviceEpointName(deviceUI.CommonDevice));
                                 deviceRow.SetStatuText(deviceUI.GetDeviceStatu());
                                 deviceRow.HideSwitchBtn(true);
                                 deviceTypeRowLayout.AddChidren(deviceRow);
 
-                                var editBtn = new CommonForm.RowLayoutEditButton()
+                                EventHandler<MouseEventArgs> deviceDetailHandler = (send2, e2) =>
                                 {
-                                    Tag = deviceUI
+                                    var detailInfo = new Device.CommonForm.DeviceDetailInfo { };
+                                    UserView.HomePage.Instance.AddChidren(detailInfo);
+                                    UserView.HomePage.Instance.PageIndex += 1;
+                                    detailInfo.Show(deviceUI, Shared.Common.Room.CurrentRoom);
+                                    detailInfo.EditAction += (curDevice, curRoom) =>
+                                    {
+                                        ReFreshDeviceAction(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+                                    };
                                 };
-                                var delBtn = new Device.CommonForm.RowLayoutDeleteButton()
+                                var editBtn = new CommonForm.RowLayoutEditButton()
                                 {
                                     Tag = deviceUI
                                 };
@@ -1791,20 +1716,141 @@
                                 {
                                     deviceTypeRowLayout.AddRightView(editBtn);
                                     editBtn.MouseUpEventHandler += deviceDetailHandler;
-                                    deviceTypeRowLayout.AddRightView(delBtn);
-                                    delBtn.MouseUpEventHandler += delEvent;
                                 }
                             }
-                        }
-                        catch
-                        {
 
+                            //鍒犻櫎璁惧
+                            EventHandler<MouseEventArgs> delEvent = (delSender, delE) =>
+                            {
+                                var alert = new UserCenter.ShowMsgControl(ShowMsgType.Confirm, Language.StringByID(R.MyInternationalizationString.DeleteFunction));
+                                alert.Show();
+                                alert.ConfirmClickEvent += () =>
+                                {
+                                    if (Common.Room.CurrentRoom.IsLove)
+                                    {
+                                        Shared.Common.Room.CurrentRoom.DeleteDevice(deviceUI.FileName);
+                                        deviceListScrolView.RemoveViewByTag((delSender as Button).Tag);
+                                        sameTypeList.Remove(deviceUI);
+                                    }
+                                    else
+                                    {
+                                        Shared.Common.Room.CurrentRoom.DeleteDevice(deviceUI.CommonDevice);
+                                        deviceListScrolView.RemoveViewByTag((delSender as Button).Tag);
+                                        sameTypeList.Remove(deviceUI);
+                                        if (Common.Room.CurrentRoom.GetLoveRoom().DeviceUIList.Find((obj) => obj.FileName == deviceUI.FileName) != null)
+                                        {
+                                            Common.Room.CurrentRoom.GetLoveRoom().DeleteDevice(deviceUI.FileName);
+                                        }
+                                    }
+                                    if (sameTypeList.Count == 0)
+                                    {
+                                        RefreshBodyView();
+                                    }
+                                };
+                            };
+                            var delBtn = new CommonForm.RowLayoutDeleteButton()
+                            {
+                                Tag = deviceUI
+                            };
+                            if (Common.Room.CurrentRoom.IsSharedRoom == false)
+                            {
+                                deviceTypeRowLayout.AddRightView(delBtn);
+                                delBtn.MouseUpEventHandler += delEvent;
+                            }
                         }
+                        catch { }
                     });
                 })
                 { IsBackground = true }.Start();
             }
         }
+
+        /// <summary>
+        /// ReFreshDeviceAction
+        /// </summary>
+        /// <param name="curRoom"></param>
+        /// <param name="sameTypeList"></param>
+        /// <param name="devListScrolView"></param>
+        /// <param name="deviceRow"></param>
+        private void ReFreshDeviceAction(DeviceUI deviceUI, Common.Room curRoom, List<DeviceUI> sameTypeList, VerticalScrolViewLayout devListScrolView, CategoryFunctionRow deviceRow)
+        {
+            if (Common.Room.CurrentRoom.IsLove)
+            {
+                deviceRow.SetDeviceIcon(deviceUI.IconPath, deviceUI.OnlineIconPath);
+                deviceRow.SetTitle(Common.LocalDevice.Current.GetDeviceEpointName(deviceUI.CommonDevice));
+                if (Common.Room.CurrentRoom.IsCollectInRoom(deviceUI.FileName) == false)
+                {
+                    devListScrolView.RemoveViewByTag(deviceUI);
+                    sameTypeList.Remove(deviceUI);
+                    if (sameTypeList.Count == 0)
+                    {
+                        RefreshFunction(Common.Room.CurrentRoom);
+                    }
+                }
+            }
+            else
+            {
+                if (curRoom.Id != Common.Room.CurrentRoom.Id)
+                {
+                    Shared.Common.Room.CurrentRoom.DeleteDevice(deviceUI.FileName);
+                    devListScrolView.RemoveViewByTag(deviceUI);
+                    sameTypeList.Remove(deviceUI);
+                    if (sameTypeList.Count == 0)
+                    {
+                        RefreshFunction(Common.Room.CurrentRoom);
+                    }
+                }
+                else
+                {
+                    deviceRow.SetDeviceIcon(deviceUI.IconPath, deviceUI.OnlineIconPath);
+                    deviceRow.SetTitle(Common.LocalDevice.Current.GetDeviceEpointName(deviceUI.CommonDevice));
+                }
+            }
+        }
+
+        /// <summary>
+        /// ReFreshDeviceAction
+        /// </summary>
+        /// <param name="curRoom"></param>
+        /// <param name="sameTypeList"></param>
+        /// <param name="devListScrolView"></param>
+        /// <param name="deviceRow"></param>
+        private void ReFreshDeviceActionForWin(DeviceUI deviceUI, Common.Room curRoom, List<DeviceUI> sameTypeList, VerticalScrolViewLayout devListScrolView, CategoryFunctionForWinRow deviceRow)
+        {
+            if (Common.Room.CurrentRoom.IsLove)
+            {
+                deviceRow.SetDeviceIcon(deviceUI.IconPath, deviceUI.OnlineIconPath);
+                deviceRow.SetTitle(Common.LocalDevice.Current.GetDeviceEpointName(deviceUI.CommonDevice));
+                if (Common.Room.CurrentRoom.IsCollectInRoom(deviceUI.FileName) == false)
+                {
+                    devListScrolView.RemoveViewByTag(deviceUI);
+                    sameTypeList.Remove(deviceUI);
+                    if (sameTypeList.Count == 0)
+                    {
+                        RefreshFunction(Common.Room.CurrentRoom);
+                    }
+                }
+            }
+            else
+            {
+                if (curRoom.Id != Common.Room.CurrentRoom.Id)
+                {
+                    Shared.Common.Room.CurrentRoom.DeleteDevice(deviceUI.FileName);
+                    devListScrolView.RemoveViewByTag(deviceUI);
+                    sameTypeList.Remove(deviceUI);
+                    if (sameTypeList.Count == 0)
+                    {
+                        RefreshFunction(Common.Room.CurrentRoom);
+                    }
+                }
+                else
+                {
+                    deviceRow.SetDeviceIcon(deviceUI.IconPath, deviceUI.OnlineIconPath);
+                    deviceRow.SetTitle(Common.LocalDevice.Current.GetDeviceEpointName(deviceUI.CommonDevice));
+                }
+            }
+        }
+
 
         /// <summary>
         /// AddRoomView
@@ -2152,7 +2198,8 @@
                             Common.Logic.CurrentLogic.IsEnable = 1;//榛樿涓哄紑
                             if (logiciocnBtn.Tag.ToString() == "3")
                             {
-                                Common.Logic.CurrentLogic.LogicName = logicnameBtn.Text;// Language.StringByID(MyInternationalizationString.automation1);
+                                Common.Logic.CurrentLogic.LogicName = logicnameBtn.Text;
+                                Common.Logic.CurrentLogic.LogicCustomPushText = Common.Logic.CurrentLogic.LogicName + Language.StringByID(MyInternationalizationString.defaulttext);
                                 var addLogicPage = new Logic.AddLogicPage();
                                 HomePage.Instance.AddChidren(addLogicPage);
                                 HomePage.Instance.PageIndex += 1;
@@ -2162,6 +2209,7 @@
                             {
 
                                 Common.Logic.CurrentLogic.LogicName = logicnameBtn.Text;
+                                Common.Logic.CurrentLogic.LogicCustomPushText = Common.Logic.CurrentLogic.LogicName + Language.StringByID(MyInternationalizationString.defaulttext);
                                 Logic.TemplatePage templatePage = new Logic.TemplatePage();
                                 Logic.TemplatePage.s = logiciocnBtn.Tag.ToString();
                                 HomePage.Instance.AddChidren(templatePage);
@@ -2816,4 +2864,4 @@
 
 
     }
-}
\ No newline at end of file
+}

--
Gitblit v1.8.0