From 611786df5108dca0bdcff03834cc285cba4b8e61 Mon Sep 17 00:00:00 2001
From: 陈嘉乐 <cjl@hdlchina.com.cn>
Date: 星期二, 13 十月 2020 16:48:43 +0800
Subject: [PATCH] 2020-10-13-1

---
 HDL_ON/UI/UI2/4-PersonalCenter/PersonalCenterPageBLL.cs |  285 +++++++++++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 245 insertions(+), 40 deletions(-)

diff --git a/HDL_ON/UI/UI2/4-PersonalCenter/PersonalCenterPageBLL.cs b/HDL_ON/UI/UI2/4-PersonalCenter/PersonalCenterPageBLL.cs
index daabf42..2cd202e 100644
--- a/HDL_ON/UI/UI2/4-PersonalCenter/PersonalCenterPageBLL.cs
+++ b/HDL_ON/UI/UI2/4-PersonalCenter/PersonalCenterPageBLL.cs
@@ -1,10 +1,13 @@
 锘縰sing System;
+using HDL_ON.Entity;
 using Shared;
 
 namespace HDL_ON.UI
 {
     public partial class PersonalCenterPage
     {
+
+
         /// <summary>
         /// 鍔犺浇浜嬩欢鍒楄〃
         /// </summary>
@@ -12,11 +15,15 @@
         {
             LoadEvent_SwitchHome();
             LoadEvent_GoPersonalDataPage();
-            LoadEvent_SkipResdentialManagePage();
-
-
+            if (!DB_ResidenceData.residenceData.residecenInfo.IsOthreShare)
+            {
+                LoadEvent_SkipResdentialManagePage();
+            }
+            if (!DB_ResidenceData.residenceData.residecenInfo.IsOthreShare)
+            {
+                LoadEvent_GoMemberManagement();
+            }
         }
-
 
         #region 鍒囨崲浣忓畢
         /// <summary>
@@ -24,11 +31,80 @@
         /// </summary>
         void LoadEvent_SwitchHome()
         {
-            btnCurResidenceName.MouseUpEventHandler += (sender, e) => {
+#if DEBUG
+            btnUserTypeName.MouseUpEventHandler = (sender, e) =>
+            {
+                var pm = new DAL.Server.HttpServerRequest();
+                var iddd = pm.GetRegionLastBackupId();
+                Dialog dialog = new Dialog();
+
+                FrameLayout bodyView = new FrameLayout();
+                dialog.AddChidren(bodyView);
+                bodyView.MouseUpEventHandler = (sender3, e3) => {
+                    dialog.Close();
+                };
+                
+                FrameLayout frame = new FrameLayout()
+                {
+                    Gravity = Gravity.Center,
+                    Width = Application.GetRealWidth(280),
+                    Height =Application.GetRealHeight(300),
+                    BackgroundColor = CSS.CSS_Color.MainBackgroundColor,
+                    Radius = (uint)Application.GetRealWidth(16),
+                };
+                dialog.AddChidren(frame);
+
+                Button btnTitleDialog = new Button()
+                {
+                    Height = Application.GetRealHeight(60),
+                    TextAlignment = TextAlignment.Center,
+                    Text = "鏁版嵁鎭㈠",
+                    TextSize = CSS.CSS_FontSize.SubheadingFontSize,
+                    TextColor = CSS.CSS_Color.SecondLevelTitleColor,
+                    BackgroundColor = CSS.CSS_Color.PromptingColor2,
+                };
+                frame.AddChidren(btnTitleDialog);
+
+                VerticalScrolViewLayout view = new VerticalScrolViewLayout()
+                {
+                    Y = Application.GetRealHeight(60),
+                    Height = Application.GetRealHeight(240),
+                };
+                frame.AddChidren(view);
+
+                foreach(var dd in iddd)
+                {
+                    Button btn = new Button()
+                    {
+                        Height = Application.GetRealHeight(50),
+                        TextAlignment = TextAlignment.Center,
+                        TextSize = CSS.CSS_FontSize.TextFontSize,
+                        TextColor = CSS.CSS_Color.TextualColor,
+                        Text = dd.Value,
+                    };
+                    view.AddChidren(btn);
+
+                    btn.MouseUpEventHandler = (sender1, e1) =>
+                    {
+                        dialog.Close();
+                        pm.GetBackupFileList(dd.Key);
+                    };
+
+                    view.AddChidren(new Button()
+                    {
+                        Gravity = Gravity.CenterHorizontal,
+                        Height = Application.GetRealHeight(1),
+                        BackgroundColor = CSS.CSS_Color.BackgroundColor
+                    });
+                }
+                dialog.Show();
+            };
+#endif
+            EventHandler<MouseEventArgs> eventHandler = (sender, e) => {
                 var dialog = new Dialog();
                 var dialogBody = new FrameLayout();
                 dialog.AddChidren(dialogBody);
-                dialogBody.MouseUpEventHandler += (sender1, e1) => {
+                dialogBody.MouseUpEventHandler = (sender1, e1) => {
                     dialog.Close();
                 };
 
@@ -37,20 +113,20 @@
                     X = Application.GetRealWidth(22),
                     Y = Application.GetRealHeight(268),
                     Width = Application.GetRealWidth(160),
-                    Height = Application.GetRealHeight(190),
+                    Height = Application.GetRealHeight(198),
                     BackgroundImagePath = "PersonalCenter/HomeListbg.png",
                 };
                 dialogBody.AddChidren(dispalyView);
 
                 var contentView = new VerticalScrolViewLayout() {
                     X = Application.GetRealWidth(8),
-                    Y = Application.GetRealHeight(16),
-                    Width = Application.GetRealWidth(144),
+                    Y = Application.GetRealHeight(15),
+                    Width = Application.GetRealWidth(150),
                     Height = Application.GetRealHeight(45*4),
                 };
                 dispalyView.AddChidren(contentView);
 
-                foreach(var home in MainPage.LoginUser.HomeLists)
+                foreach(var home in MainPage.LoginUser.regionList)
                 {
                     var btnHomeName = new Button()
                     {
@@ -58,66 +134,195 @@
                         Width = Application.GetRealWidth(112),
                         Height = Application.GetRealHeight(44),
                         TextAlignment = TextAlignment.CenterLeft,
-                        TextColor = UI.CSS.CSS_Color.MainBackgroundColor,
-                        SelectedTextColor = UI.CSS.CSS_Color.MainColor,
+                        TextColor = CSS.CSS_Color.FirstLevelTitleColor,
+                        SelectedTextColor = CSS.CSS_Color.MainColor,
                         Text = home.Name,
-                        TextSize = UI.CSS.CSS_FontSize.SubheadingFontSize,
-                        IsSelected = UserConfig.Instance.CurrentRegion.RegionID == home.RegionID,
+                        TextSize = home.Name.Length > 14 ? CSS.CSS_FontSize.TextFontSize : CSS.CSS_FontSize.SubheadingFontSize,
+                        IsSelected = DB_ResidenceData.residenceData.residecenInfo.RegionID == home.RegionID,
                         IsMoreLines = true,
-                        Tag = home
+                        Tag = home.RegionID
                     };
                     contentView.AddChidren(btnHomeName);
-                    var btnContentLine = new Button()
+
+                    if (MainPage.LoginUser.regionList.IndexOf(home) < MainPage.LoginUser.regionList.Count - 1)
                     {
-                        Gravity = Gravity.CenterHorizontal,
-                        Width = Application.GetRealWidth(112),
-                        Height = Application.GetRealHeight(1),
-                        BackgroundColor = UI.CSS.CSS_Color.SecondLevelTitleColor
-                    };
-                    contentView.AddChidren(btnContentLine);
+                        contentView.AddChidren(new Button()
+                        {
+                            Gravity = Gravity.CenterHorizontal,
+                            Width = Application.GetRealWidth(112),
+                            Height = Application.GetRealHeight(1),
+                            BackgroundColor = CSS.CSS_Color.BackgroundColor
+                        });
+                    }
 
                     btnHomeName.MouseUpEventHandler += (senderH, en) =>
                     {
-                        var regionInfo = btnHomeName.Tag as RegionInfoRes;
+                        var regionId = (string)btnHomeName.Tag;
                         dialog.Close();
-
-                        UserConfig.Instance.CurrentRegion = regionInfo;
-                        btnCurResidenceName.Text = regionInfo.Name;
-                        UserConfig.Instance.SaveUserConfig();
+                        LoadEvent_ChangeCurHome(MainPage.LoginUser.regionList.Find((obj) => obj.RegionID == regionId));
+                
                     };
                 }
-
                 dialog.Show();
             };
-        }
 
+            btnResidenceDownIcon.MouseUpEventHandler = eventHandler;
+            btnCurResidenceName.MouseUpEventHandler = eventHandler;
+        }
+        /// <summary>
+        /// 鏇存崲褰撳墠閫変腑浣忓畢
+        /// </summary>
+        /// <param name="homeTemp"></param>
+        void LoadEvent_ChangeCurHome(RegionInfoRes homeTemp)
+        {
+            if (DB_ResidenceData.residenceData.CurReginID == homeTemp.RegionID)
+            {
+                return;
+            }
+            var waitPage = new Loading();
+            new System.Threading.Thread(() =>
+            {
+                try
+                {
+                    var backuplist = FileUtils.ReadFiles();
+                    int index = 0;
+                    string oldRegionRootPath = FileUtils.CreateRegionBackup(DB_ResidenceData.residenceData.CurReginID.ToString());
+                    FileUtils.DeleteRegionFiles(oldRegionRootPath);
+                    //绉诲姩鏂囦欢
+                    foreach (var fileName in backuplist)
+                    {
+                        System.IO.FileInfo fileInfo = new System.IO.FileInfo(FileUtils.RootPath + fileName);
+                        if(fileName == "headImage.png")
+                        {
+                            continue;
+                        }
+                        if (fileInfo.Exists)
+                        {
+                            fileInfo.MoveTo(oldRegionRootPath + fileName);
+                            MainPage.Log("move file : " + fileName);
+                        }
+                        index++;
+                        Application.RunOnMainThread(() =>
+                        {
+                            int pro = (int)(index * 1.0 / backuplist.Count * 50);
+                            waitPage.Text = pro.ToString() + "%";
+                        });
+                    }
+                    //鍒犻櫎鏈湴鏂囦欢
+                    foreach (var fileName in backuplist)
+                    {
+                        if (fileName == "headImage.png")
+                        {
+                            continue;
+                        }
+                        FileUtils.DeleteFile(fileName);
+                    }
+                    //鍊掑嚭鏂颁綇瀹呮暟鎹�
+                    string newRegionRootPath = FileUtils.CreateRegionBackup(homeTemp.RegionID.ToString());
+                    FileUtils.RestoreRegionFiles(newRegionRootPath);
+                    MainPage.LoginUser.SaveUserInfo();
+                    DB_ResidenceData.residenceData.EixtAccount();
+                    DB_ResidenceData.residenceData.CurReginID = homeTemp.RegionID;
+                    OnAppConfig.Instance.SaveUserConfig();
+                    DB_ResidenceData.InitRoomFunction();
+                    DB_ResidenceData.residenceData.SaveResidenceData();
+                    Application.RunOnMainThread(() =>
+                    {
+                        btnCurResidenceName.Text = DB_ResidenceData.residenceData.residecenInfo.Name;
+                    });
+                }
+                catch (Exception ex)
+                {
+                    Application.RunOnMainThread(() =>
+                    {
+                        new Alert(Language.StringByID(StringId.Tip), Language.StringByID(StringId.OperationFailed),
+                                   Language.StringByID(StringId.Close)).Show();
+                    });
+                    MainPage.Log(ex.Message);
+                }
+                finally
+                {
+                    Application.RunOnMainThread(() =>
+                    {
+                        waitPage.Hide();
+                        waitPage.RemoveFromParent();
+                    });
+                }
+            })
+            { IsBackground = true }.Start();
+        }
         #endregion
 
         #region 浣忓畢绠$悊
         void LoadEvent_SkipResdentialManagePage()
         {
-            EventHandler<MouseEventArgs> eventHandler = (sender, e) => {
-                var residentialManagePage = new ResidentialManagePage();
-                MainPage.BasePageView.AddChidren(residentialManagePage);
-                residentialManagePage.LoadPage();
-                MainPage.BasePageView.PageIndex = MainPage.BasePageView.ChildrenCount - 1;
-            };
-            btnResidenceManageIcon.MouseUpEventHandler = eventHandler;
-            btnResidenceManageText.MouseUpEventHandler = eventHandler;
+            if (!DB_ResidenceData.residenceData.residecenInfo.IsOthreShare)
+            {
+                EventHandler<MouseEventArgs> eventHandler = (sender, e) =>
+                {
+                    Action updateResidenceName = () => {
+                        btnCurResidenceName.Text = DB_ResidenceData.residenceData.residecenInfo.Name;
+                    };
+                    var residentialManagePage = new ResidentialManagePage(updateResidenceName);
+                    MainPage.BasePageView.AddChidren(residentialManagePage);
+                    residentialManagePage.LoadPage();
+                    MainPage.BasePageView.PageIndex = MainPage.BasePageView.ChildrenCount - 1;
+                };
+                btnResidenceManageIcon.MouseUpEventHandler = eventHandler;
+                btnResidenceManageText.MouseUpEventHandler = eventHandler;
+            }
         }
-
         #endregion
 
         #region 涓汉涓績
         void LoadEvent_GoPersonalDataPage()
         {
-            btnUserHeadPortrait.MouseUpEventHandler += (sender, e) => {
-                var personalDataView = new PersonalDataPage();
+            EventHandler<MouseEventArgs> eventHandler = (sender, e) =>
+            {
+                Action updataHeadImage = () =>
+                {
+                    userHeadImageView.ImagePath = MainPage.LoginUser.headImagePagePath;
+                };
+                Action updataUserName = () =>
+                {
+                    btnUserName.Text = MainPage.LoginUser.userName;
+                };
+
+                var personalDataView = new PersonalDataPage(updataHeadImage, updataUserName);
                 MainPage.BasePageView.AddChidren(personalDataView);
                 personalDataView.LoadView();
                 MainPage.BasePageView.PageIndex = MainPage.BasePageView.ChildrenCount - 1;
             };
+            userHeadImageView.MouseUpEventHandler = eventHandler;
+            btnUserName.MouseUpEventHandler = eventHandler;
+            btnEmail.MouseUpEventHandler = eventHandler;
+
         }
         #endregion
+
+        #region 鎴愬憳绠$悊
+        void LoadEvent_GoMemberManagement()
+        {
+
+            EventHandler<MouseEventArgs> eHandler = (sender, e) => {
+            //};
+            //residenceMemberView.MouseUpEventHandler = (sender, e) => {
+                //Action updataHeadImage = () => {
+                //    userHeadImageView.ImagePath = MainPage.LoginUser.headImagePagePath;
+                //};
+                //Action updataUserName = () => {
+                //    btnUserName.Text = MainPage.LoginUser.userName;
+                //};
+
+                var mmp = new MemberManagementPage();
+                MainPage.BasePageView.AddChidren(mmp);
+                mmp.LoadPage();
+                MainPage.BasePageView.PageIndex = MainPage.BasePageView.ChildrenCount - 1;
+            };
+            btnResidenceMemberIcon.MouseUpEventHandler = eHandler;
+            btnResidenceMemberText.MouseUpEventHandler = eHandler;
+        }
+
+        #endregion
     }
 }

--
Gitblit v1.8.0