From 0ee75b88cfe03e46289de0de96e8ed4580c797d3 Mon Sep 17 00:00:00 2001
From: wxr <464027401@qq.com>
Date: 星期二, 27 九月 2022 14:04:21 +0800
Subject: [PATCH] Merge branch 'Dev-Branch' into dev--wxr

---
 HDL_ON/UI/UI2/2-Classification/ClassificationPage.cs |  199 +++++++++++++++++++++++++++++++++++++------------
 1 files changed, 151 insertions(+), 48 deletions(-)

diff --git a/HDL_ON/UI/UI2/2-Classification/ClassificationPage.cs b/HDL_ON/UI/UI2/2-Classification/ClassificationPage.cs
index a2ebe9b..511af3b 100644
--- a/HDL_ON/UI/UI2/2-Classification/ClassificationPage.cs
+++ b/HDL_ON/UI/UI2/2-Classification/ClassificationPage.cs
@@ -5,6 +5,7 @@
 using HDL_ON.Entity;
 using HDL_ON.UI;
 using HDL_ON.UI.CSS;
+using Newtonsoft.Json;
 using Newtonsoft.Json.Linq;
 using Shared;
 
@@ -1062,6 +1063,16 @@
                         break;
                     case ShowFunction.Acst:
                         btnName.TextID = StringId.Acst;
+
+                        Button btnJMLogo = new Button()
+                        {
+                            Y = specialList.Contains(index) ? Application.GetRealWidth(147) : Application.GetRealWidth(104),
+                            UnSelectedImagePath = "FunctionIcon/Acst/LvJianLogo.png",
+                            Width = Application.GetRealWidth(105),
+                            Height = Application.GetRealWidth(57),
+                        };
+                        functionView.AddChidren(btnJMLogo);
+
                         Button btnAcstPower = new Button()
                         {
                             X = Application.GetRealWidth(120),
@@ -1074,8 +1085,22 @@
                             Tag = item + "_AllControl",
                         };
                         functionView.AddChidren(btnAcstPower);
-                        btnFunctionViewBg.MouseUpEventHandler = (sender, e) => {
-                            //缁垮缓绉戞妧绯荤粺todo
+                        btnAcstPower.MouseUpEventHandler = (sender, e) =>
+                        {
+                            btnAcstPower.IsSelected = !btnAcstPower.IsSelected;
+                            string onoff = btnAcstPower.IsSelected ? "on" : "off";
+                            Dictionary<string, string> d = new Dictionary<string, string>();
+                            d.Add(FunctionAttributeKey.OnOff, onoff);
+
+                            foreach (var temp in FunctionList.List.GetAcstParentList())
+                            {
+                                Control.Ins.SendWriteCommand(temp, d);
+                            }
+                        };
+
+
+                        btnFunctionViewBg.MouseUpEventHandler = (sender, e) =>
+                        {
                             var page = new AcstParentPage();
                             MainPage.BasePageView.AddChidren(page);
                             page.LoadPage();
@@ -1087,7 +1112,7 @@
                 }
                 //鐣岄潰璺宠浆--闊充箰璺宠浆鑷繁鐨勭晫闈�--鐜璺宠浆鑷繁鐨勭晫闈�
                 if (item != ShowFunction.Music && item != ShowFunction.Environmental && item != ShowFunction.SecurityMonitoring && item != ShowFunction.DoorLock
-                    && ShowFunction.EnergyMonitoring!= item && ShowFunction.VideoIntercom != item && ShowFunction.SecurityCenter != item
+                    && ShowFunction.EnergyMonitoring != item && ShowFunction.VideoIntercom != item && ShowFunction.SecurityCenter != item
                     && ShowFunction.Acst != item)
                 {
                     btnFunctionViewBg.MouseUpEventHandler = (sender, e) =>
@@ -1102,17 +1127,12 @@
             }
 
 
-            bool debugFlag = false;
-#if DEBUG
-            debugFlag = true;
-#endif
-
             //鍏変紡鏁版嵁
-            if (FunctionList.List.InverterList.Count > 0 || debugFlag)
+            if (FunctionList.List.InverterList().Count > 0)
             {
                 FrameLayout inverterListView = new FrameLayout()
                 {
-                    Height = Application.GetRealHeight(223),
+                    Height = Application.GetRealHeight(204),
                     Radius = (uint)Application.GetRealWidth(6),
                     BackgroundColor = CSS_Color.MainBackgroundColor,
                     Tag = "inverterList_View",
@@ -1141,7 +1161,7 @@
                 Button btnName = new Button()
                 {
                     X = Application.GetRealWidth(16),
-                    Y = Application.GetRealHeight(22),//14),//
+                    Y = Application.GetRealHeight(16),//14),//
                     Width = Application.GetRealWidth(140),
                     Height = Application.GetRealHeight(20),
                     TextColor = CSS_Color.FirstLevelTitleColor,
@@ -1153,22 +1173,50 @@
                 };
                 inverterListView.AddChidren(btnName);
 
-                Button btnWorkStatus = new Button()
+
+                Button btnFunctionCount = new Button()
                 {
-                    Y = Application.GetRealHeight(24),
-                    Width = Application.GetRealWidth(148),
-                    Height = Application.GetRealHeight(18),
-                    TextAlignment = TextAlignment.CenterRight,
-                    TextColor = 0xFF0BAF31,
-                    TextID = StringId.NormalOperation,
-                    TextSize = CSS_FontSize.TextFontSize
+                    X = Application.GetRealWidth(17) + Application.GetRealWidth(7 * FunctionList.List.InverterList().Count.ToString().Length),
+                    Y = btnName.Bottom,
+                    Width = Application.GetRealWidth(120),
+                    Height = Application.GetRealHeight(24),
+                    TextColor = CSS_Color.PromptingColor1,
+                    TextSize = CSS_FontSize.PromptFontSize_FirstLevel,
+                    TextAlignment = TextAlignment.CenterLeft,
+                    Text = "/" + FunctionList.List.InverterList().Count,
                 };
-                inverterListView.AddChidren(btnWorkStatus);
+                inverterListView.AddChidren(btnFunctionCount);
+                Button btnOpenCount = new Button()
+                {
+                    X = Application.GetRealWidth(16),
+                    Y = btnName.Bottom,
+                    Width = Application.GetRealWidth(14 * FunctionList.List.InverterList().Count.ToString().Length),
+                    Height = Application.GetRealHeight(24),
+                    TextColor = CSS_Color.MainColor,
+                    TextSize = CSS_FontSize.PromptFontSize_FirstLevel,
+                    TextAlignment = TextAlignment.CenterLeft,
+                    Text = FunctionList.List.InverterList().FindAll((temp)=>temp.trait_on_off.curValue.ToString() == "on").Count.ToString(),
+                    Tag = "inverter_onCount",
+                    BorderWidth = 0,
+                };
+                inverterListView.AddChidren(btnOpenCount);
+
+                //Button btnWorkStatus = new Button()
+                //{
+                //    Y = Application.GetRealHeight(24),
+                //    Width = Application.GetRealWidth(148),
+                //    Height = Application.GetRealHeight(18),
+                //    TextAlignment = TextAlignment.CenterRight,
+                //    TextColor = 0xFF0BAF31,
+                //    TextID = StringId.NormalOperation,
+                //    TextSize = CSS_FontSize.TextFontSize
+                //};
+                //inverterListView.AddChidren(btnWorkStatus);
 
                 Button btnWorkingMode = new Button()
                 {
                     X = Application.GetRealWidth(16),
-                    Y = btnWorkStatus.Bottom + Application.GetRealHeight(16),
+                    Y = btnOpenCount.Bottom + Application.GetRealHeight(5),// + Application.GetRealHeight(16),
                     Width = Application.GetRealWidth(148),
                     Height = Application.GetRealHeight(18),
                     TextColor = CSS_Color.FirstLevelTitleColor,
@@ -1181,9 +1229,9 @@
                 Button btnPowerTenerationToday = new Button()
                 {
                     X = Application.GetRealWidth(16),
-                    Y = btnWorkingMode.Bottom + Application.GetRealHeight(16),
+                    Y = btnWorkingMode.Bottom + Application.GetRealHeight(5),
                     Width = Application.GetRealWidth(148),
-                    Height = Application.GetRealHeight(18),
+                    Height = Application.GetRealHeight(21),
                     TextColor = CSS_Color.FirstLevelTitleColor,
                     TextSize = CSS_FontSize.PromptFontSize_FirstLevel,
                     TextID = StringId.PowerTenerationToday,
@@ -1195,9 +1243,9 @@
                 Button btnCurrentPowerGeneration = new Button()
                 {
                     X = Application.GetRealWidth(16),
-                    Y = btnPowerTenerationToday.Bottom + Application.GetRealHeight(16),
+                    Y = btnPowerTenerationToday.Bottom + Application.GetRealHeight(5),
                     Width = Application.GetRealWidth(148),
-                    Height = Application.GetRealHeight(18),
+                    Height = Application.GetRealHeight(21),
                     TextColor = CSS_Color.FirstLevelTitleColor,
                     TextSize = CSS_FontSize.PromptFontSize_FirstLevel,
                     TextID = StringId.CurrentPowerGeneration,
@@ -1208,7 +1256,7 @@
                 Button btnBatterySOC = new Button()
                 {
                     X = Application.GetRealWidth(16),
-                    Y = btnCurrentPowerGeneration.Bottom + Application.GetRealHeight(16),
+                    Y = btnCurrentPowerGeneration.Bottom,
                     Width = Application.GetRealWidth(148),
                     Height = Application.GetRealHeight(18),
                     TextColor = CSS_Color.FirstLevelTitleColor,
@@ -1216,38 +1264,45 @@
                     TextID = StringId.BatterySOC,
                     TextAlignment = TextAlignment.CenterLeft,
                 };
-                inverterListView.AddChidren(btnBatterySOC);
+                //inverterListView.AddChidren(btnBatterySOC);
 
-                Button btnOperationDataTotalData = new Button()
-                {
-                    X = Application.GetRealWidth(16),
-                    Y = btnBatterySOC.Bottom + Application.GetRealHeight(16),
-                    Width = Application.GetRealWidth(148),
-                    Height = Application.GetRealHeight(18),
-                    TextColor = CSS_Color.FirstLevelTitleColor,
-                    TextSize = CSS_FontSize.PromptFontSize_FirstLevel,
-                    TextID = StringId.OperationDataTotalData,
-                    TextAlignment = TextAlignment.CenterLeft,
-                };
-                inverterListView.AddChidren(btnOperationDataTotalData);
+                //Button btnOperationDataTotalData = new Button()
+                //{
+                //    X = Application.GetRealWidth(16),
+                //    Y = btnBatterySOC.Bottom + Application.GetRealHeight(16),
+                //    Width = Application.GetRealWidth(148),
+                //    Height = Application.GetRealHeight(18),
+                //    TextColor = CSS_Color.FirstLevelTitleColor,
+                //    TextSize = CSS_FontSize.PromptFontSize_FirstLevel,
+                //    TextID = StringId.OperationDataTotalData,
+                //    TextAlignment = TextAlignment.CenterLeft,
+                //};
+                //inverterListView.AddChidren(btnOperationDataTotalData);
 
                 var clickButton = new Button();
                 inverterListView.AddChidren(clickButton);
 
                 clickButton.MouseUpEventHandler = (sender2, e2) =>
                 {
-                    var h5BasePage = new FrameLayout();
+                    var h5BasePage = new FrameLayout() {
+                        BackgroundColor = CSS_Color.MainBackgroundColor,
+                    };
 
-#if __Android__
+//#if __Android__
                     //閫傞厤瀹夊崜娌夋蹈寮忓鑸爮
-                    h5BasePage.Y = Application.GetRealHeight(16);
-                    h5BasePage.Height = Application.GetRealHeight(651);
-#endif
+                    h5BasePage.Y = Application.GetRealHeight(20);
+                    h5BasePage.Height = Application.GetRealHeight(646);
+//#endif
                     MainPage.BasePageView.AddChidren(h5BasePage);
                     MainPage.BasePageView.PageIndex = MainPage.BasePageView.ChildrenCount - 1;
 
                     h5BasePage.AddChidren(Inverter.Ins.H5Page);//000
-                    string url = $"h5/index.html?homeId={DB_ResidenceData.Instance.CurrentRegion.id}&token={UserInfo.Current.AccessToken}&refresh_token={UserInfo.Current.RefreshToken}&url={HttpUtil.GlobalRequestHttpsHost}";
+                    string lz = "zh";
+                    if (Language.CurrentLanguage != "Chinese")
+                    {
+                        lz = "en";
+                    }
+                    string url = $"h5/index.html?homeId={DB_ResidenceData.Instance.CurrentRegion.id}&token={UserInfo.Current.AccessToken}&refresh_token={UserInfo.Current.RefreshToken}&url={HttpUtil.GlobalRequestHttpsHost}&lang={lz}";
                     Inverter.Ins.ShowWebviewFormUrl(url);
                     Inverter.Ins.H5Page.JSToNativeAction = (dictionary) =>
                     {
@@ -1267,7 +1322,7 @@
                             }
                             var function = new Function();
                             function.sid = data["sid"].ToString();
-                            var inObj = FunctionList.List.InverterList.Find((obj) => obj.sid == function.sid);
+                            var inObj = FunctionList.List.InverterList().Find((obj) => obj.sid == function.sid);
                             if (inObj == null)
                             {
                                 return;
@@ -1284,10 +1339,20 @@
                             {
                                 h5BasePage.RemoveFromParent();
                             });
+                            refreshInverterInfo(btnPowerTenerationToday, btnWorkingMode, btnCurrentPowerGeneration, btnBatterySOC);
+                        }
+                        else if(jObj["method"].ToString() == "setPageIndex")
+                        {
+                            var data = jObj["data"].ToString();
+                            Inverter.Ins.PageIndex = data.ToString();
                         }
                     };
+
+
+
                 };
 
+                refreshInverterInfo(btnPowerTenerationToday, btnWorkingMode, btnCurrentPowerGeneration, btnBatterySOC);
 
                 index++;
             }
@@ -1295,6 +1360,44 @@
             s1View.Height = s2View.Height = functionContentView.Height = functionContentViewHeight + Application.GetRealWidth(40);
 
             #endregion
+        }
+
+        void refreshInverterInfo(Button btnPowerTenerationToday, Button btnWorkingMode, Button btnCurrentPowerGeneration, Button btnBatterySOC)
+        {
+            new System.Threading.Thread(() =>
+            {
+                var http = new HttpServerRequest();
+                var pack = http.GetInverterStatisticsInfo();
+                if (pack != null)
+                {
+                    if(pack.Data == null)
+                    {
+                        return;
+                    }
+                    var info = JsonConvert.DeserializeObject<StatisticsInfo>(pack.Data?.ToString());
+                    if (info == null)
+                    {
+                        return;
+                    }
+                    try
+                    {
+                        Application.RunOnMainThread(() =>
+                        {
+                            btnPowerTenerationToday.Text = Language.StringByID(StringId.PowerTenerationToday).Replace("----", info.totalElectricityPvToday);
+                            btnWorkingMode.Text = Language.StringByID(StringId.WorkingMode).Replace("----", info.workMode);
+                            btnCurrentPowerGeneration.Text = Language.StringByID(StringId.CurrentPowerGeneration).Replace("----", info.powerPvNow);
+                            btnBatterySOC.Text = Language.StringByID(StringId.BatterySOC).Replace("--", info.batterySoc);
+                        });
+                    }
+                    catch (Exception ex)
+                    {
+                        MainPage.Log($"鑾峰彇瀹跺涵鍏変紡缁熻鏁版嵁寮傚父锛歿ex.Message}");
+                    }
+                }
+
+
+            })
+            { IsBackground = true }.Start();
         }
 
 #region 鍒囨崲妤煎眰
@@ -1393,7 +1496,7 @@
 
                 foreach (var floor in chooseList)
                 {
-                    if (!string.IsNullOrEmpty( floor.roomId))// != Language.StringByID(StringId.All))
+                    if (!string.IsNullOrEmpty( floor.roomId))
                     {
                         //---鍒嗗壊绾�
                         contentView.AddChidren(new Button()
@@ -1456,4 +1559,4 @@
         }
 #endregion
     }
-}
\ No newline at end of file
+}

--
Gitblit v1.8.0