From 9f326f4000847e6167d8166fa2f6a66f53cb3734 Mon Sep 17 00:00:00 2001
From: 黄学彪 <hxb@hdlchina.com.cn>
Date: 星期四, 17 十二月 2020 09:07:13 +0800
Subject: [PATCH] 新云端Ver1.3

---
 ZigbeeApp/Shared/Phone/UserCenter/Device/DeviceMacInfoEditorForm.cs |  453 +++++++++++++++++++++++++++++++++++++++-----------------
 1 files changed, 315 insertions(+), 138 deletions(-)

diff --git a/ZigbeeApp/Shared/Phone/UserCenter/Device/DeviceMacInfoEditorForm.cs b/ZigbeeApp/Shared/Phone/UserCenter/Device/DeviceMacInfoEditorForm.cs
index 6b5741f..22b08b0 100755
--- a/ZigbeeApp/Shared/Phone/UserCenter/Device/DeviceMacInfoEditorForm.cs
+++ b/ZigbeeApp/Shared/Phone/UserCenter/Device/DeviceMacInfoEditorForm.cs
@@ -36,19 +36,19 @@
         /// </summary>
         private NormalViewControl btnAirConditionerVersion = null;
         /// <summary>
-        /// 绠�绾﹂潰鏉跨粦瀹氱殑娓╁害鐩爣鍚嶅瓧
+        /// 绠�绾﹀鍔熻兘闈㈡澘缁戝畾鐨勬俯搴︾洰鏍囧悕瀛�
         /// </summary>
         private string bindTemperatureName = string.Empty;
         /// <summary>
-        /// 绠�绾﹂潰鏉跨粦瀹氱殑婀垮害鐩爣鍚嶅瓧
+        /// 绠�绾﹀鍔熻兘闈㈡澘缁戝畾鐨勬箍搴︾洰鏍囧悕瀛�
         /// </summary>
         private string bindHumidityName = string.Empty;
         /// <summary>
-        /// 绠�绾﹂潰鏉跨粦瀹氳缁戠洰鏍囨槸娓╁害
+        /// 绠�绾﹀鍔熻兘闈㈡澘缁戝畾琚粦鐩爣鏄俯搴�
         /// </summary>
         private CommonDevice bindTemperatureDev;
         /// <summary>
-        /// 绠�绾﹂潰鏉跨粦瀹氳缁戠洰鏍囨槸婀垮害
+        /// 绠�绾﹀鍔熻兘闈㈡澘缁戝畾琚粦鐩爣鏄箍搴�
         /// </summary>
         private CommonDevice bindHumidityDev;
         /// <summary>
@@ -56,10 +56,13 @@
         /// </summary>
         private string deviceMacTemp = string.Empty;
         // <summary>
-        /// 绠�绾﹂潰鏉夸腑琚粦瀹氱殑娓╂箍搴︾洰鏍囧垪琛�
+        /// 绠�绾﹀鍔熻兘闈㈡澘涓缁戝畾鐨勬俯婀垮害鐩爣鍒楄〃
         /// </summary>
         private List<BindObj.BindListResponseObj> bindList = new List<BindObj.BindListResponseObj>();
-        #endregion
+        /// <summary>
+        /// 绠�绾﹀鍔熻兘闈㈡澘鐨勬帴杩戞劅搴旀暟鎹� 
+        private Panel.PanelProximitySensorInfo proximitySensorsInfo = new Panel.PanelProximitySensorInfo();
+         #endregion
 
         #region 鈻� 鍒濆鍖朹____________________________
 
@@ -69,11 +72,11 @@
         /// <param name="deviceMac">璁惧mac鍦板潃</param>
         public void ShowForm(string deviceMac)
         {
-            this.listNewDevice = Common.LocalDevice.Current.GetDevicesByMac(deviceMac);
+            this.listNewDevice = HdlDeviceCommonLogic.Current.GetDevicesByMac(deviceMac);
             if (listNewDevice.Count == 0)
             {
                 //閽堝鍗曠函鍙湁涓�涓�200绔偣鐨勮澶�
-                listNewDevice.Add(Common.LocalDevice.Current.GetOTADevice(deviceMac));
+                listNewDevice.Add(HdlDeviceCommonLogic.Current.GetOTADevice(deviceMac));
             }
             this.listDeviceType.Clear();
             deviceMacTemp = deviceMac;
@@ -83,33 +86,49 @@
                 this.listDeviceType.Add(device.Type);
             }
             //鑾峰彇杩欎竴鍫嗚澶囨椂灞炰簬浠�涔堢被鍨嬬殑
-            this.deviceEnumInfo = Common.LocalDevice.Current.GetMyDeviceEnumInfo(listNewDevice);
+            this.deviceEnumInfo = HdlDeviceCommonLogic.Current.GetMyDeviceEnumInfo(listNewDevice);
 
             //璁剧疆鏍囬淇℃伅
             base.SetTitleText(Language.StringByID(R.MyInternationalizationString.uDeviceSettion));
 
-            //鍒濆鍖栧彸涓婅鑿滃崟
-            this.InitTopRightMenu();
+            //閲嶆柊鑾峰彇纭欢淇℃伅(false:涓嶉渶瑕佽幏鍙�,true:闇�瑕佽幏鍙�)
+            var result = this.RefreshHardFirmwareInfo();
 
-            //鍒濆鍖栦腑閮ㄦ帶浠�
-            this.InitMiddleFrame();
-
-            //閲嶆柊鑾峰彇纭欢淇℃伅
-            this.RefreshHardFirmwareInfo();
-
-            //绠�绾﹀鍔熻兘闈㈡澘鑾峰彇缁戝畾鐩爣鐨勬樉绀�
-            if (deviceEnumInfo.ConcreteType == DeviceConcreteType.ButtonPanel_SimpleMultifunction)
+            HdlThreadLogic.Current.RunThread(() =>
             {
-                //绠�绾﹂潰鏉块殢渚夸竴涓洖璺潵鑾峰彇璁惧淇℃伅
-                var dev = Common.LocalDevice.Current.GetDevice(deviceMac, 62);
-                if (dev != null)
+                if (result == true)
                 {
-                    var key = new ZigBee.Device.Panel();
-                    key.DeviceAddr = deviceMac;
-                    key.CurrentGateWayId = dev.CurrentGateWayId;
-                    InitBindInfo(key);
+                    //濡傛灉闇�瑕侀噸鏂板幓璇诲彇璁惧鐨勪俊鎭墠鑳芥樉绀虹晫闈㈢殑璇�,绛夊緟涓�娈垫椂闂�
+                    this.ShowProgressBar();
+                    System.Threading.Thread.Sleep(1500);
                 }
-            }
+                HdlThreadLogic.Current.RunMain(() =>
+                {
+                    //鍒濆鍖栧彸涓婅鑿滃崟
+                    this.InitTopRightMenu();
+
+                    //鍒濆鍖栦腑閮ㄦ帶浠�
+                    this.InitMiddleFrame();
+
+                    //绠�绾﹀鍔熻兘闈㈡澘鑾峰彇缁戝畾鐩爣鐨勬樉绀�
+                    if (deviceEnumInfo.ConcreteType == DeviceConcreteType.ButtonPanel_SimpleMultifunction)
+                    {
+                        //绠�绾﹂潰鏉块殢渚夸竴涓洖璺潵鑾峰彇璁惧淇℃伅
+                        var dev = HdlDeviceCommonLogic.Current.GetDevice(deviceMac, 62);
+                        if (dev != null)
+                        {
+                            var key = new ZigBee.Device.Panel();
+                            key.DeviceAddr = deviceMac;
+                            key.CurrentGateWayId = dev.CurrentGateWayId;
+                            InitBindInfo(key);
+                        }
+                    }
+                    if (result == true)
+                    {
+                        this.CloseProgressBar();
+                    }
+                });
+            });
         }
 
         /// <summary>
@@ -137,21 +156,27 @@
 
             //璁惧澶囨敞
             string caption = Language.StringByID(R.MyInternationalizationString.uDeviceNote);
-            string deviceName = Common.LocalDevice.Current.GetDeviceMacName(listNewDevice[0]);
+            string deviceName = HdlDeviceCommonLogic.Current.GetDeviceMacName(listNewDevice[0]);
             var btnNote = new FrameCaptionInputControl(caption, deviceName, listview.rowSpace / 2);
+            btnNote.txtInput.MaxByte = 48;//闄愬埗鍙兘杈撳叆48涓瓧鑺�
             listview.AddChidren(btnNote);
             btnNote.InitControl();
             //鍒掔嚎
             btnNote.AddBottomLine();
             btnNote.txtInput.FinishInputEvent += () =>
             {
-                string oldName = Common.LocalDevice.Current.GetDeviceMacName(listNewDevice[0]);
+                string oldName = HdlDeviceCommonLogic.Current.GetDeviceMacName(listNewDevice[0]);
                 if (btnNote.Text == string.Empty)
                 {
                     btnNote.Text = oldName;
                 }
                 if (oldName != btnNote.Text)
                 {
+                    //鏌ョ湅妯℃澘鏃�,涓嶅厑璁哥紪杈�
+                    if (Common.Config.Instance.Home.IsShowTemplate == true)
+                    {
+                        return;
+                    }
                     //淇敼鍚嶅瓧
                     this.DeviceReName(btnNote.Text, false);
                 }
@@ -159,7 +184,7 @@
 
             //璁惧绫诲瀷
             caption = Language.StringByID(R.MyInternationalizationString.uDeviceType);
-            deviceName = Common.LocalDevice.Current.GetDeviceObjectText(listNewDevice);
+            deviceName = HdlDeviceCommonLogic.Current.GetDeviceObjectText(listNewDevice);
             var btnType = new FrameCaptionViewControl(caption, deviceName, listview.rowSpace / 2);
             btnType.UseClickStatu = false;
             listview.AddChidren(btnType);
@@ -173,6 +198,11 @@
             rowBeloneArea.InitControl(Language.StringByID(R.MyInternationalizationString.uInstallationLocation), this.listNewDevice);
             //搴曠嚎
             rowBeloneArea.AddBottomLine();
+            //鏌ョ湅妯℃澘鏃�,涓嶅厑璁哥紪杈�
+            if (Common.Config.Instance.Home.IsShowTemplate == true)
+            {
+                rowBeloneArea.CanClick = false;
+            }
 
             var listCheck = new List<string>();
             rowBeloneArea.SelectRoomEvent += (roomKeys) =>
@@ -193,7 +223,7 @@
                         continue;
                     }
                     var room = HdlRoomLogic.Current.GetRoomByDevice(device);
-                    string mainKeys = LocalDevice.Current.GetDeviceMainKeys(device);
+                    string mainKeys = HdlDeviceCommonLogic.Current.GetDeviceMainKeys(device);
                     if (room == null)
                     {
                         //杩欓噷鏈夌偣鐗规畩,濡傛灉鍥炶矾娌℃湁璁剧疆鏈夊尯鍩熺殑鏃跺��,鎵嶈缃�
@@ -213,7 +243,7 @@
                     }
                 }
                 //淇濆瓨璁惧鎴块棿绱㈠紩
-                Common.LocalDevice.Current.SaveRealDeviceRoomId(this.listNewDevice, roomKeys);
+                HdlRoomLogic.Current.SaveRealDeviceRoomId(this.listNewDevice, roomKeys);
             };
 
             //娣诲姞鍏ㄩ儴鑿滃崟
@@ -229,7 +259,7 @@
             bodyFrameLayout.AddChidren(btnFinish);
             btnFinish.ButtonClickEvent += (sender, e) =>
             {
-                string oldName = Common.LocalDevice.Current.GetDeviceMacName(listNewDevice[0]);
+                string oldName = HdlDeviceCommonLogic.Current.GetDeviceMacName(listNewDevice[0]);
                 if (btnNote.Text.Trim() == string.Empty)
                 {
                     btnNote.Text = oldName;
@@ -245,8 +275,8 @@
                     this.CloseForm();
                 }
             };
-            //濡傛灉褰撳墠浣忓畢鏄櫄鎷熶綇瀹呯殑璇�,璁╂墍鏈夎彍鍗曢兘涓嶈兘鐐瑰嚮
-            if (Common.Config.Instance.Home.IsVirtually == true)
+            //鏌ョ湅妯℃澘鏃�,涓嶅厑璁哥紪杈�
+            if (Common.Config.Instance.Home.IsShowTemplate == true)
             {
                 for (int i = 0; i < listview.ChildrenCount; i++)
                 {
@@ -289,11 +319,13 @@
             }
             else if (deviceEnumInfo.ConcreteType == DeviceConcreteType.ButtonPanel_SimpleMultifunction)
             {
-                //绠�绾﹀鍔熻兘闈㈡澘
+                //绠�绾﹀鍔熻兘闈㈡澘                 
                 this.AddIBindRow(deviceMacTemp);
-                this.AddFunctionSettionRow();
+                this.AddProximitySensorsRow(deviceMacTemp);
+                this.AddFunctionSettionRow(); 
                 this.AddHumiditySourceRow(deviceMacTemp);
                 this.AddTemperatureSensorRow(deviceMacTemp);
+                this.DataCorrectionRow(deviceMacTemp);
             }
             else if (deviceEnumInfo.ConcreteType == DeviceConcreteType.ButtonPanel_SimpleEnvironment)
             {
@@ -374,7 +406,7 @@
                 var doorLock = this.listNewDevice[0] as ZigBee.Device.DoorLock;
                 btnRow.ButtonClickEvent += async (sender, e) =>
                  {
-                     if (UserCenterResourse.UserInfo.AuthorityNo == 1)
+                     if (HdlUserCenterResourse.ResidenceOption.AuthorityNo == 1)
                      {
                          Action action = null;
                          Action actionNone = null;
@@ -459,7 +491,7 @@
 
                 btnswitch.ButtonClickEvent += async (sender, e) =>
                  {
-                     if (UserCenterResourse.UserInfo.AuthorityNo == 1)
+                     if (HdlUserCenterResourse.ResidenceOption.AuthorityNo == 1)
                      {
                          if (btnswitch.IsSelected == true)
                          {
@@ -527,7 +559,7 @@
                 var doorLock = this.listNewDevice[0] as ZigBee.Device.DoorLock;
                 btnRow.ButtonClickEvent += async (sender, e) =>
                  {
-                     if (UserCenterResourse.UserInfo.AuthorityNo == 1)
+                     if (HdlUserCenterResourse.ResidenceOption.AuthorityNo == 1)
                      {
                          var tempPage = new Shared.Phone.UserCenter.DoorLock.TimeSettignPage(doorLock, "DoorLockTime");
                          Shared.Phone.UserView.HomePage.Instance.AddChidren(tempPage);
@@ -766,7 +798,7 @@
         private void AddFunctionSettionRow()
         {
             //鍙湁鍥炶矾鏁板ぇ浜�1鎵嶈兘鏈夎繖涓彍鍗�
-            if (Common.LocalDevice.Current.GetDevicesCountByMac(listNewDevice[0].DeviceAddr) == 1)
+            if (HdlDeviceCommonLogic.Current.GetDevicesCountByMac(listNewDevice[0].DeviceAddr) == 1)
             {
                 //鏂伴灏忔ā鍧楀彧鏈変竴涓洖璺紝浣嗚姹傛柊椋庡皬妯″潡鐨勬柊椋庢湁鍔熻兘璁剧疆
                 if (deviceEnumInfo.ConcreteType != DeviceConcreteType.Relay_FangyueFreshAirModul)
@@ -815,14 +847,19 @@
                     var form = new DevicePanel.PanelFangyueFunctionSettionForm();
                     form.AddForm(listNewDevice[0], deviceEnumInfo);
                 }
-                //绠�绾︾幆澧冮潰鏉跨殑鎸夐敭閰嶇疆
+                //绠�绾﹀鍔熻兘闈㈡澘鐨勬寜閿厤缃�
                 else if (deviceEnumInfo.ConcreteType == DeviceConcreteType.ButtonPanel_SimpleMultifunction)
                 {
-                    var form = new DeviceFunctionSettionForm();
-                    if (listNewDevice.Count > 62)
+                    foreach (var dev in listNewDevice)
                     {
-                        form.AddForm(listNewDevice[62], true);
+                        if (dev.Type == DeviceType.OnOffOutput && dev.DeviceEpoint == 62)
+                        {
+                            var form = new DeviceFunctionSettionForm();
+                            form.AddForm(dev, true);
+                            break;
+                        }
                     }
+
                 }
                 //娌充笢鐨勯潰鏉胯澶�
                 else if (deviceEnumInfo.BeloneType == DeviceBeloneType.A鎸夐敭闈㈡澘 && deviceEnumInfo.IsHdlDevice == true)
@@ -943,18 +980,25 @@
                     btnSwitch.IsSelected = statu;
                 }
             };
+            //鏌ョ湅妯℃澘鏃�,涓嶅厑璁哥紪杈�
+            if (Common.Config.Instance.Home.IsShowTemplate == true)
+            {
+                btnSwitch.CanClick = false;
+                btnSwitch.IsSelected = HdlTemplateDeviceDataLogic.Current.GetCurtainHandPullControl(deviceCurtain);
+                return;
+            }
             //濡傛灉鏄櫄鎷熶綇瀹�
             if (Common.Config.Instance.Home.IsVirtually == true)
             {
-                btnSwitch.IsSelected = ModelData.DeviceModelDataLogic.Current.GetCurtainHandPullControl(deviceCurtain);
+                btnSwitch.IsSelected = HdlTemplateDeviceDataLogic.Current.GetCurtainHandPullControl(deviceCurtain);
                 return;
             }
 
             //娣诲姞灞炴�т笂鎶ョ洃鍚�
-            string mainkeys = LocalDevice.Current.GetDeviceMainKeys(this.listNewDevice[0]);
+            string mainkeys = HdlDeviceCommonLogic.Current.GetDeviceMainKeys(this.listNewDevice[0]);
             HdlGatewayReceiveLogic.Current.AddAttributeEvent("HandPullControl", ReceiveComandDiv.A璁惧灞炴�т笂鎶�, (device) =>
             {
-                string checkKey = LocalDevice.Current.GetDeviceMainKeys(device);
+                string checkKey = HdlDeviceCommonLogic.Current.GetDeviceMainKeys(device);
                 if (mainkeys != checkKey || device.DeviceStatusReport.CluterID != 258)
                 {
                     return;
@@ -1010,7 +1054,7 @@
         }
         #endregion
 
-        #region 鈻�  绠�绾﹀鍔熻兘闈㈡澘鐢╛__________________
+        #region 鈻� 绠�绾﹀鍔熻兘闈㈡澘鐢╛__________________
         /// <summary>
         /// 娣诲姞銆愮粦瀹氱洰鏍囥�戣
         /// </summary>
@@ -1026,12 +1070,88 @@
             btnBindTargets.AddBottomLine();
             btnBindTargets.ButtonClickEvent += (sender, e) =>
             {
-                var simpleMutilfunctionTargetsPage = new Shared.Phone.UserCenter.DeviceBind.PanelSimpleMutilfunctionTargetsForm(deviceMac);
-                Shared.Phone.UserView.HomePage.Instance.AddChidren(simpleMutilfunctionTargetsPage);
-                Shared.Phone.UserView.HomePage.Instance.PageIndex += 1;
-                simpleMutilfunctionTargetsPage.Show();
+                var dev = HdlDeviceCommonLogic.Current.GetDevice(deviceMac, 32);//绠�绾﹂潰鏉块殢渚夸竴涓寜閿潵鑾峰彇璁惧
+                if (dev != null)
+                {
+                    var curControlDev = dev as Panel;
+                    var simpleMutilfunctionTargetsPage = new Shared.Phone.UserCenter.DeviceBind.PanelSimpleMutilfunctionTargetsForm(curControlDev);
+                    Shared.Phone.UserView.HomePage.Instance.AddChidren(simpleMutilfunctionTargetsPage);
+                    Shared.Phone.UserView.HomePage.Instance.PageIndex += 1;
+                    simpleMutilfunctionTargetsPage.Show();
+                }
             };
         }
+
+        #region 鈻� 鎺ヨ繎鎰熷簲___________________________
+
+        /// <summary>
+        /// 鎺ヨ繎鎰熷簲琛�
+        /// </summary>
+        private void AddProximitySensorsRow(string deviceMac)
+        {
+            string proximity = Language.StringByID(R.MyInternationalizationString.ProximitySensors);
+            var proximitySensors = new FrameRowControl(listview.rowSpace / 2);
+            listview.AddChidren(proximitySensors);
+            proximitySensors.AddLeftCaption(proximity, 400);
+
+            //鎺ヨ繎鎰熷簲
+            proximitySensors.AddLeftCaption(Language.StringByID(R.MyInternationalizationString.ProximitySensors), 400);
+            //寮�鍏虫帶浠�
+            var btnSwitch = proximitySensors.AddMostRightSwitchIcon();
+            //搴曠嚎
+            proximitySensors.AddBottomLine();
+
+            btnSwitch.ButtonClickEvent +=async (sender, e) =>
+            {
+                btnSwitch.IsSelected = !btnSwitch.IsSelected;
+                proximitySensorsInfo.enable = btnSwitch.IsSelected;
+
+                //绠�绾﹂潰鏉块殢渚夸竴涓洖璺潵鑾峰彇璁惧淇℃伅
+                var dev = HdlDeviceCommonLogic.Current.GetDevice(deviceMac, 62);
+                if (dev != null)
+                {
+                    var key = new ZigBee.Device.Panel();
+                    key.DeviceAddr = deviceMac;
+                    key.CurrentGateWayId = dev.CurrentGateWayId;
+                    SetProximitySensor(key); 
+                }
+            };
+            if (proximitySensorsInfo.enable == true)
+            {
+                btnSwitch.IsSelected = true;
+            }
+        }
+        #endregion
+
+        #region 鈻� 鏁版嵁鐭_________________________ 
+        /// <summary>
+        ///  鏁版嵁鐭琛�
+        /// </summary>
+        private void DataCorrectionRow(string deviceMac)
+        {
+            //鏁版嵁鐭
+            var rowLight = new FrameRowControl(listview.rowSpace / 2);
+            listview.AddChidren(rowLight);
+            rowLight.AddLeftCaption(Language.StringByID(R.MyInternationalizationString.DataCorrection), 600);
+            //搴曠嚎
+            rowLight.AddBottomLine();
+            //鍙崇澶�
+            rowLight.AddRightArrow();
+            rowLight.ButtonClickEvent += (sender, e) =>
+            {
+                var dev = HdlDeviceCommonLogic.Current.GetDevice(deviceMac, 62);//绠�绾﹂潰鏉块殢渚夸竴涓洖璺潵鑾峰彇璁惧
+                var device = new CommonDevice();
+                if (dev != null)
+                {
+                    device.CurrentGateWayId = dev.CurrentGateWayId;
+                }
+                device.DeviceAddr = deviceMac;
+                device.DeviceEpoint = 65;
+                var form = new Shared.Phone.UserCenter.DevicePanel.DataCorrectionForm();
+                form.AddForm(device);
+            };
+        }
+        #endregion
 
         /// <summary>
         ///  婀垮害鏉ユ簮琛�
@@ -1055,7 +1175,7 @@
             rowHumidity.ButtonClickEvent += (sender, e) =>
             {
 
-                var dev = Common.LocalDevice.Current.GetDevice(deviceMac, 62);//绠�绾﹂潰鏉块殢渚夸竴涓洖璺潵鑾峰彇璁惧
+                var dev = HdlDeviceCommonLogic.Current.GetDevice(deviceMac, 62);//绠�绾﹂潰鏉块殢渚夸竴涓洖璺潵鑾峰彇璁惧
                 var device = new CommonDevice();
                 if (dev != null)
                 {
@@ -1063,7 +1183,7 @@
                 }
                 device.Type = DeviceType.OnOffSwitch;
                 device.DeviceAddr = deviceMac;
-                device.DeviceEpoint = 65;//鑳界粦瀹氭箍搴︾殑鍥炶矾
+                device.DeviceEpoint = 1;//鑳界粦瀹氭箍搴︾殑鍥炶矾
                 var paneTargetsBaseFormp = new PaneTargetsBaseForm(device, bindHumidityDev, BindInfo.BindType.Humidity);
                 Shared.Phone.UserView.HomePage.Instance.AddChidren(paneTargetsBaseFormp);
                 Shared.Phone.UserView.HomePage.Instance.PageIndex += 1;
@@ -1106,7 +1226,7 @@
             var btnTemperatureStatu = rowTemPerature.AddMostRightView(msg, 700);
             rowTemPerature.ButtonClickEvent += (sender, e) =>
             {
-                var dev = Common.LocalDevice.Current.GetDevice(deviceMac, 62);//绠�绾﹂潰鏉块殢渚夸竴涓洖璺潵鑾峰彇璁惧
+                var dev = HdlDeviceCommonLogic.Current.GetDevice(deviceMac, 62);//绠�绾﹂潰鏉块殢渚夸竴涓洖璺潵鑾峰彇璁惧
                 var device = new CommonDevice();
                 if (dev != null)
                 {
@@ -1114,7 +1234,7 @@
                 }
                 device.Type = DeviceType.OnOffSwitch;
                 device.DeviceAddr = deviceMac;
-                device.DeviceEpoint = 64;//鑳界粦瀹氭俯搴︾殑鍥炶矾
+                device.DeviceEpoint = 1;//鑳界粦瀹氭俯搴︾殑鍥炶矾
                 var paneTargetsBaseFormp = new PaneTargetsBaseForm(device, bindTemperatureDev, BindInfo.BindType.Temperature);
                 Shared.Phone.UserView.HomePage.Instance.AddChidren(paneTargetsBaseFormp);
                 Shared.Phone.UserView.HomePage.Instance.PageIndex += 1;
@@ -1137,7 +1257,7 @@
         }
 
         /// <summary>
-        ///璇绘俯婀垮害鏁版嵁
+        ///鍒濆鍖栨暟鎹� 
         /// </summary>
         void InitBindInfo(CommonDevice curControlDev)
         {
@@ -1149,8 +1269,8 @@
                     {
                         CommonPage.Loading.Start("");
                     });
-                    //1銆佽幏鍘荤粦瀹氱殑娓╁害浼犳劅鍣�
-                    curControlDev.DeviceEpoint = 64;
+                    //璇绘俯婀垮害鏁版嵁 
+                    curControlDev.DeviceEpoint = 1;
                     var result = await GetBindName(curControlDev);
                     if (!result)
                     {
@@ -1160,17 +1280,16 @@
                         });
                         return;
                     }
-
-                    //2銆佽幏鍘荤粦瀹氱殑婀垮害搴︿紶鎰熷櫒
-                    curControlDev.DeviceEpoint = 65;
-                    var result2 = await GetBindName(curControlDev);
-                    if (!result2)
+                     
+                    //2銆佽幏璁惧鎺ヨ繎鎰熷簲鍒濆鏁版嵁
+                    //鎺ヨ繎鎰熷簲(浠栦滑璇撮殢渚挎嬁涓�璺洖璺氨琛屼簡)
+                    proximitySensorsInfo = await HdlDevicePanelLogic.Current.GetDeviceProximitySensorsSettion(curControlDev);
+                    if (proximitySensorsInfo == null)
                     {
-                        Application.RunOnMainThread(() =>
-                        {
-                            new Tip() { MaxWidth = 150, Text = Language.StringByID(R.MyInternationalizationString.GwResponseOvertime) + "(" + "5007_3" + ")", Direction = AMPopTipDirection.None, CloseTime = 1 }.Show(Common.CommonPage.Instance);
-                        });
-                        return;
+                        proximitySensorsInfo = new Panel.PanelProximitySensorInfo();
+                        //鍏抽棴杩涘害鏉�
+                        this.CloseProgressBar(ShowReLoadMode.YES);
+                        return ;
                     }
                 }
                 catch (Exception ex)
@@ -1181,6 +1300,8 @@
                 {
                     Application.RunOnMainThread(() =>
                     {
+                        //鍒濆鍖栧彸涓婅鑿滃崟
+                        this.InitTopRightMenu();
                         //鍒濆鍖栦腑閮ㄦ帶浠�
                         this.InitMiddleFrame();
                         CommonPage.Loading.Hide();
@@ -1203,7 +1324,7 @@
                 bindList = panelBindListRes.getAllBindResponseData.BindList;
                 foreach (var bDev in bindList)
                 {
-                    var device = Common.LocalDevice.Current.GetDevice(bDev.BindMacAddr, bDev.BindEpoint);
+                    var device = HdlDeviceCommonLogic.Current.GetDevice(bDev.BindMacAddr, bDev.BindEpoint);
                     if (device == null)
                     {
                         continue;
@@ -1213,41 +1334,18 @@
                         var bD = device as TemperatureSensor;
                         if (bD.SensorDiv == 1 && bDev.BindCluster == 1026)
                         {
-                            if (string.IsNullOrEmpty(bDev.ESName))
-                            {
-                                bindTemperatureName = Common.LocalDevice.Current.GetDeviceEpointName(device);
-                            }
-                            else
-                            {
-                                bindTemperatureName = bDev.ESName;
-                            }
+                            bindTemperatureName = HdlDeviceCommonLogic.Current.GetDeviceEpointName(device);
                             bindTemperatureDev = device;
                         }
                         if (bD.SensorDiv == 2 && bDev.BindCluster == 1029)
                         {
-                            if (string.IsNullOrEmpty(bDev.ESName))
-                            {
-                                bindHumidityName = Common.LocalDevice.Current.GetDeviceEpointName(device);
-                            }
-                            else
-                            {
-                                bindHumidityName = bDev.ESName;
-                            }
-
+                            bindHumidityName = HdlDeviceCommonLogic.Current.GetDeviceEpointName(device);
                             bindHumidityDev = device;
                         }
                     }
                     if (device.Type == DeviceType.FreshAirHumiditySensor)
                     {
-                        if (string.IsNullOrEmpty(bDev.ESName))
-                        {
-                            bindHumidityName = Common.LocalDevice.Current.GetDeviceEpointName(device);
-                        }
-                        else
-                        {
-                            bindHumidityName = bDev.ESName;
-                        }
-
+                        bindHumidityName = HdlDeviceCommonLogic.Current.GetDeviceEpointName(device);
                         bindHumidityDev = device;
                     }
                 }
@@ -1255,6 +1353,44 @@
             }
             return result;
         }
+         
+        #region 鈻� 璁剧疆鏁版嵁___________________________
+
+        /// <summary>
+        /// 璁剧疆闈㈡澘鎺ヨ繎鎰熷簲鏁版嵁
+        /// </summary>
+        private void SetProximitySensor(CommonDevice curControlDev)
+        {
+            System.Threading.Tasks.Task.Run(async () =>
+            {
+                try
+                {
+                    Application.RunOnMainThread(() =>
+                    {
+                        CommonPage.Loading.Start("");
+                    });
+                    //鎺ヨ繎鎰熷簲(鎻愪緵璁惧鐨勫悓浜嬭闅忎究涓�涓洖璺氨琛�)
+                    var result = await HdlDevicePanelLogic.Current.SetProximitySensorStatus(curControlDev, proximitySensorsInfo.enable);
+                    if (result == false)
+                    { 
+                        return;
+                    }
+                }
+                catch (Exception ex)
+                {
+                    var mess = ex.Message;
+                }
+                finally
+                {
+                    Application.RunOnMainThread(() =>
+                    {
+                        CommonPage.Loading.Hide();
+                    });
+                }
+            });
+        }
+ 
+        #endregion
         #endregion
 
         #region 鈻� 鍔熻兘绫诲瀷(绌烘皵寮�鍏充笓鐢�)_____________
@@ -1281,6 +1417,11 @@
             rowFunction.InitControl();
             //搴曠嚎
             rowFunction.AddBottomLine();
+            //鏌ョ湅妯℃澘鏃�,涓嶅厑璁哥紪杈�
+            if (Common.Config.Instance.Home.IsShowTemplate == true)
+            {
+                rowFunction.CanClick = false;
+            }
         }
 
         #endregion
@@ -1327,7 +1468,11 @@
             listview.AddChidren(rowVersion);
             rowVersion.AddLeftCaption(caption, 600);
             //鐗堟湰
-            this.btnAirConditionerVersion = rowVersion.AddMostRightView("", 800);
+            this.btnAirConditionerVersion = rowVersion.AddMostRightView(string.Empty, 900);
+            if (this.listNewDevice[0] is AC)
+            {
+                this.btnAirConditionerVersion.Text = ((AC)this.listNewDevice[0]).AcModelVersion;
+            }
             //搴曠嚎
             rowVersion.AddBottomLine();
 
@@ -1345,7 +1490,7 @@
         private void AddFirmwareUpdateRow()
         {
             //鎷ユ湁200绔彛杩欎釜涓滆タ鐨勬椂鍊欙紝鎵嶄細鏄剧ず杩欎竴琛�
-            var oTADevice = Common.LocalDevice.Current.GetOTADevice(listNewDevice[0].DeviceAddr);
+            var oTADevice = HdlDeviceCommonLogic.Current.GetOTADevice(listNewDevice[0].DeviceAddr);
             if (oTADevice == null)
             {
                 return;
@@ -1387,7 +1532,8 @@
             };
 
             //濡傛灉褰撳墠浣忓畢涓嶆槸铏氭嫙浣忓畢
-            if (Common.Config.Instance.Home.IsVirtually == false)
+            if (Config.Instance.Home.IsVirtually == false
+                && Config.Instance.Home.IsShowTemplate == false)
             {
                 //璁剧疆璁惧鐨勭増鏈俊鎭�
                 this.SetDeviceVersionInfo(btnNewVersion, oTADevice);
@@ -1405,10 +1551,22 @@
             {
                 bool receiveImageInfo = false;
                 //璁剧疆璁惧鍏ㄩ儴鐨勯暅鍍忎俊鎭�
-                HdlDeviceImageInfoLogic.Current.SetAllImageInfoToOtaDevice(oTADevice, (device, reportData) =>
+                string checkKey = HdlDeviceCommonLogic.Current.GetDeviceMainKeys(oTADevice.DeviceAddr, oTADevice.DeviceEpoint);
+                HdlGatewayReceiveLogic.Current.AddAttributeEvent("SetDeviceVersionInfo", ReceiveComandDiv.A璁惧灞炴�т笂鎶�, (report) =>
                 {
-                    receiveImageInfo = true;
+                    if (report.DeviceStatusReport.CluterID == (int)Cluster_ID.Ota)
+                    {
+                        string mainKey = HdlDeviceCommonLogic.Current.GetDeviceMainKeys(report.DeviceAddr, report.DeviceEpoint);
+                        if (checkKey == mainKey)
+                        {
+                            //宸茬粡鎺ユ敹寰楀埌
+                            receiveImageInfo = true;
+                        }
+                    }
                 });
+                //鍙戦�佸懡浠�
+                HdlDeviceAttributeLogic.Current.ReadDeviceFirmwareVersion(oTADevice);
+
                 int count = 5;
                 while (receiveImageInfo == false && count > 0)
                 {
@@ -1417,14 +1575,14 @@
                     count--;
                 }
                 //绉婚櫎浜嬩欢
-                HdlDeviceImageInfoLogic.Current.RemoveDeviceFirmwareVersionThread(oTADevice);
+                HdlGatewayReceiveLogic.Current.RemoveEvent("SetDeviceVersionInfo");
 
-                oTADevice = Common.LocalDevice.Current.GetOTADevice(listNewDevice[0].DeviceAddr);
+                oTADevice = HdlDeviceCommonLogic.Current.GetOTADevice(listNewDevice[0].DeviceAddr);
                 //娣诲姞鍗囩骇鍥轰欢淇℃伅(鎴愪笉鎴愬姛閮芥棤鎵�璋�)
-                var result = HdlFirmwareUpdateLogic.AddFirmwareVersionInfo(FirmwareLevelType.ZigbeeDevice, oTADevice.HwVersion.ToString(), oTADevice.ImgTypeId.ToString());
+                var result = HdlFirmwareUpdateLogic.Current.AddFirmwareVersionInfo(FirmwareLevelType.A璁惧, oTADevice.HwVersion.ToString(), oTADevice.ImgTypeId.ToString());
 
                 //鑾峰彇璁惧鏈�鏂扮増鏈�
-                var deviceFirmware = HdlFirmwareUpdateLogic.GetFirmwareMostVersionInfo(FirmwareLevelType.ZigbeeDevice,
+                var deviceFirmware = HdlFirmwareUpdateLogic.Current.GetFirmwareMostVersionInfo(FirmwareLevelType.A璁惧,
                     oTADevice.HwVersion.ToString(),
                     oTADevice.ImgTypeId.ToString(),
                     oTADevice.ImgVersion);
@@ -1454,7 +1612,7 @@
         {
             //淇敼MAC鍚�
             string deviceName = i_deviceName.Trim();
-            var result = Common.LocalDevice.Current.ReMacName(this.listNewDevice, deviceName);
+            var result = HdlDeviceCommonLogic.Current.ReMacName(this.listNewDevice, deviceName);
             if (result == false)
             {
                 return;
@@ -1481,6 +1639,11 @@
         /// </summary>
         private void InitTopRightMenu()
         {
+            //鏌ョ湅妯℃澘鏃�,涓嶅厑璁哥紪杈�
+            if (Common.Config.Instance.Home.IsShowTemplate == true)
+            {
+                return;
+            }
             var btnIcon = new MostRightIconControl(69, 69);
             btnIcon.UnSelectedImagePath = "Item/More.png";
             topFrameLayout.AddChidren(btnIcon);
@@ -1498,7 +1661,7 @@
         private void ShowTopRightMenu()
         {
             //妫�娴嬫鍥炶矾鏄惁鎷ユ湁瀹氫綅鍔熻兘(鎷跨鐐规渶灏忕殑閭d釜鍥炶矾鍘诲畾浣�)
-            bool canTest = Common.LocalDevice.Current.DeviceIsCanFixedPosition(listNewDevice[0]);
+            bool canTest = HdlDeviceCommonLogic.Current.DeviceIsCanFixedPosition(listNewDevice[0]);
 
             TopRightMenuControl frame = null;
 
@@ -1519,7 +1682,7 @@
                 frame.AddRowMenu(deviceMenu, "Item/FixedPosition.png", "Item/FixedPositionSelected.png", () =>
                 {
                     //鍙戦�佸畾浣嶅姛鑳�
-                    Common.LocalDevice.Current.SetFixedPositionCommand(listNewDevice[0]);
+                    HdlDeviceCommonLogic.Current.SetFixedPositionCommand(listNewDevice[0], true);
                 });
             }
 
@@ -1543,7 +1706,7 @@
 
             //鍚屾
             deviceMenu = Language.StringByID(R.MyInternationalizationString.Synchronization);
-            if (Common.LocalDevice.Current.DeviceIsCanFixedPosition(listNewDevice[0]))
+            if (HdlDeviceCommonLogic.Current.DeviceIsCanFixedPosition(listNewDevice[0]))
             {
                 frame.AddRowMenu(deviceMenu, "", "Item/SynchronizationSelected.png", () =>
                 {
@@ -1571,7 +1734,7 @@
                 this.ShowProgressBar();
 
                 //鍒犻櫎璁惧
-                bool result = await Common.LocalDevice.Current.DeleteDevice(listNewDevice);
+                bool result = await HdlDeviceCommonLogic.Current.DeleteDevice(listNewDevice);
                 //鍏抽棴杩涘害鏉�
                 this.CloseProgressBar();
                 if (result == false)
@@ -1597,7 +1760,7 @@
                 this.ShowProgressBar();
 
                 //鍚屾璁惧
-                bool result = await Common.LocalDevice.Current.SynchronizationDevice(listNewDevice);
+                bool result = await HdlDeviceCommonLogic.Current.SynchronizationDevice(listNewDevice);
                 //鍏抽棴杩涘害鏉�
                 this.CloseProgressBar();
                 if (result == false)
@@ -1616,11 +1779,10 @@
         public override void CloseFormBefore()
         {
             HdlGatewayReceiveLogic.Current.RemoveEvent("HandPullControl");
-            //绉婚櫎鑾峰彇璁惧纭欢淇℃伅鐨勭洃鍚嚎绋�
-            HdlDeviceHardInfoLogic.Current.RemoveDeviceHardInfoThread(listNewDevice[0]);
+            HdlGatewayReceiveLogic.Current.RemoveEvent("SetDeviceVersionInfo");
 
             //璁惧鏂板叆缃�
-            if (UserCenterResourse.DicActionForm.ContainsKey("AddDeviceTypeListForm") == true)
+            if (HdlFormLogic.Current.IsFormOpen("AddDeviceTypeListForm") == true)
             {
                 this.LoadFormMethodByName("DeviceListMainForm", "RefreshDeviceRow", new object[] { listNewDevice[0].DeviceAddr });
             }
@@ -1633,25 +1795,19 @@
         #region 鈻� 纭欢淇℃伅___________________________
 
         /// <summary>
-        /// 閲嶆柊鑾峰彇纭欢淇℃伅
+        /// 閲嶆柊鑾峰彇纭欢淇℃伅(false:涓嶉渶瑕佽幏鍙�,true:闇�瑕佽幏鍙�)
         /// </summary>
-        private void RefreshHardFirmwareInfo()
+        private bool RefreshHardFirmwareInfo()
         {
-            if (listNewDevice[0].DriveCode > 0)
+            if (listNewDevice[0].DriveCode > 0 || Common.Config.Instance.Home.IsShowTemplate == true)
             {
                 //铏氭嫙璁惧娌℃湁杩欑鎿嶄綔
-                return;
+                return false;
             }
             //閲嶆柊鑾峰彇纭欢淇℃伅
-            HdlDeviceHardInfoLogic.Current.SetAllHardFirmwareInfoToDevice(listNewDevice[0], (device, reportData) =>
-            {
-                for (int i = 1; i < listNewDevice.Count; i++)
-                {
-                    //鍏ㄩ儴鍥炶矾鐨勪俊鎭兘鏄竴鑷寸殑
-                    HdlDeviceHardInfoLogic.Current.SetHardFirmwareInfo(device.DeviceStatusReport, listNewDevice[i]);
-                    listNewDevice[i].ReSave();
-                }
-            });
+            HdlDeviceAttributeLogic.Current.ReadDeviceAllHardFirmwareInfo(listNewDevice[0]);
+            //鑾峰彇璁惧鐨勫浐瀹氬睘鎬�
+            return HdlDeviceAttributeLogic.Current.ReadDeviceAllFixedAttribute(listNewDevice[0]);
         }
 
         #endregion
@@ -1682,27 +1838,48 @@
             {
                 return;
             }
-            //鑾峰彇涓�....
-            this.btnAirConditionerVersion.TextID = R.MyInternationalizationString.uGetting;
+            //濡傛灉鏄櫄鎷熶綇瀹呮垨鑰呭睍绀烘ā鏉跨殑璇�
+            if (Config.Instance.Home.IsShowTemplate == true || Config.Instance.Home.IsVirtually == true)
+            {
+                return;
+            }
+
+            bool notVersion = true;
+            if (this.listNewDevice[0] is AC)
+            {
+                notVersion = ((AC)this.listNewDevice[0]).AcModelVersion == string.Empty;
+            }
+            if (notVersion == true)
+            {
+                //鑾峰彇涓�
+                btnAirConditionerVersion.Text = Language.StringByID(R.MyInternationalizationString.uGetting);
+            }
             HdlThreadLogic.Current.RunThread(async () =>
             {
                 //璇诲彇绌鸿皟妯″潡鐗堟湰
                 var result = await HdlDeviceAirConditionerLogic.Current.ReadACFirewareVersionAsync(listNewDevice[0]);
                 if (result == null || result.readACFirewareVersionResponData == null || result.readACFirewareVersionResponData.Status != 0)
                 {
-                    HdlThreadLogic.Current.RunMain(() =>
+                    if (notVersion == true)
                     {
                         //鑾峰彇澶辫触
-                        btnAirConditionerVersion.TextID = R.MyInternationalizationString.uGettingFail;
-                    });
+                        HdlThreadLogic.Current.RunMain(() =>
+                        {
+                            btnAirConditionerVersion.Text = Language.StringByID(R.MyInternationalizationString.uGettingFail);
+                        });
+                    }
+                    return;
                 }
-                else
+                HdlThreadLogic.Current.RunMain(() =>
                 {
-                    HdlThreadLogic.Current.RunMain(() =>
+                    string strVersion = result.readACFirewareVersionResponData.FirewareVersion.Replace("-", string.Empty);
+                    if (this.listNewDevice[0] is AC)
                     {
-                        btnAirConditionerVersion.Text = result.readACFirewareVersionResponData.FirewareVersion.Replace("-", string.Empty);
-                    });
-                }
+                        ((AC)this.listNewDevice[0]).AcModelVersion = strVersion;
+                        this.listNewDevice[0].ReSave();
+                    }
+                    btnAirConditionerVersion.Text = strVersion;
+                });
             });
         }
 

--
Gitblit v1.8.0