From ea285ffe71284f5499e870f89c65b710d2d6a79c Mon Sep 17 00:00:00 2001
From: lss <lsc@hdlchina.com.cn>
Date: 星期一, 27 六月 2022 10:54:32 +0800
Subject: [PATCH] Merge branch 'wxr0114' of http://59.41.255.150:6688/r/~wxr/OnPro into wxr0114

---
 HDL_ON/UI/UI2/4-PersonalCenter/Visitor/VisitorQRCodePage.cs |  105 +++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 87 insertions(+), 18 deletions(-)

diff --git a/HDL_ON/UI/UI2/4-PersonalCenter/Visitor/VisitorQRCodePage.cs b/HDL_ON/UI/UI2/4-PersonalCenter/Visitor/VisitorQRCodePage.cs
index 26a6115..efd1ad3 100644
--- a/HDL_ON/UI/UI2/4-PersonalCenter/Visitor/VisitorQRCodePage.cs
+++ b/HDL_ON/UI/UI2/4-PersonalCenter/Visitor/VisitorQRCodePage.cs
@@ -1,10 +1,10 @@
 锘縰sing System;
 using HDL_ON.UI.CSS;
 using Shared;
-using Com.Hdl.Hdllinphonesdk.Dialog;
 using HDL_ON.DAL.Server;
 using System.Collections.Generic;
 using Com.Hdl.Hdllinphonesdk.Utils;
+using Com.Hdl.Hdllinphonesdk.Dialog;
 
 namespace HDL_ON.UI.UI2.PersonalCenter.Visitor
 {
@@ -22,27 +22,41 @@
         private Button visitorVoucherBtn;
         private VisitorTempPassword tempPassword;
 
+        Action backAction;// 鍚庨��鎸夐敭锛屽埛鏂癠I
+
         public VisitorQRCodePage()
         {
             bodyView = this;
         }
 
-        public VisitorQRCodePage(VisitorTempPassword pwd)
+        public VisitorQRCodePage(Action action,VisitorTempPassword pwd)
         {
             bodyView = this;
             this.tempPassword = pwd;
+            backAction = action;
+        }
+
+        public override void RemoveFromParent()
+        {
+            this.tempPassword = null;
+            backAction?.Invoke();
+            base.RemoveFromParent();
         }
 
         public void LoadPage()
         {
             #region 椤堕儴瀵艰埅鏍�
-            if (tempPassword == null)
+            if (tempPassword == null || tempPassword.id == null)
             {
                 tempPassword = new VisitorTempPassword();
 
                 Action click = () =>
                 {
-                    VisitorHistoryPage page = new VisitorHistoryPage();
+                    Action action = () =>
+                    {
+                        LoadPage();
+                    };
+                    VisitorHistoryPage page = new VisitorHistoryPage(action);
                     MainPage.BasePageView.AddChidren(page);
                     page.LoadPage();
                     MainPage.BasePageView.PageIndex = MainPage.BasePageView.ChildrenCount - 1;
@@ -51,7 +65,6 @@
                 bodyView.BackgroundColor = CSS_Color.BackgroundColor;
                 new TopViewDiv(bodyView, Language.StringByID(StringId.VisitorInvitation))
                     .LoadTopView_SettingText(click, Language.StringByID(StringId.VisitorRecord));
-
             }
             else
             {
@@ -99,13 +112,15 @@
                 Width = Application.GetRealWidth(335),
                 TextSize = CSS_FontSize.TextFontSize,
                 TextColor = CSS_Color.FirstLevelTitleColor,
-                
+
                 PlaceholderText = Language.StringByID(StringId.InputPhoneNumberOfTheVisitor),
                 Text = tempPassword.phone,
                 IsNumberKeyboardType = true,
                 PlaceholderTextColor = CSS_Color.PromptingColor1,
             };
             bodyScrolView.AddChidren(phoneNumberEditText);
+            //phoneNumberEditText.Foucs = true;
+
             // 鍒嗗壊绾�
             bodyScrolView.AddChidren(new Button()
             {
@@ -141,7 +156,7 @@
                 TextColor = CSS_Color.FirstLevelTitleColor,
                 Width = Application.GetRealWidth(335),
                 PlaceholderText = Language.StringByID(StringId.Input6_DigitsTemporaryPassword),
-                Text = tempPassword.tempPwd,
+                IsNumberKeyboardType = true,
                 PlaceholderTextColor = CSS_Color.PromptingColor1,
             };
             pwdLayout.AddChidren(pwdEditText);
@@ -158,11 +173,6 @@
             };
             pwdLayout.AddChidren(randomBtn);
             bodyScrolView.AddChidren(pwdLayout);
-            randomBtn.MouseUpEventHandler += (sender, e) =>
-            {
-                string tPwd = getRandomPwd();
-                pwdEditText.Text = tPwd;
-            };
 
             // 鍒嗗壊绾�
             bodyScrolView.AddChidren(new Button()
@@ -367,7 +377,6 @@
             };
             bodyScrolView.AddChidren(visitorVoucherBtn);
 
-            //
             Action voucher_action = () =>
             {
                 if (codeIV.ImageBytes == null)
@@ -430,7 +439,7 @@
                 {
                     var tip_dialog = new Tip()
                     {
-                        Text = Language.StringByID(StringId.linshimima),
+                        Text = Language.StringByID(StringId.Input6_DigitsTemporaryPassword),
                         CloseTime = 2,
                         Direction = AMPopTipDirection.None
                     };
@@ -470,11 +479,67 @@
                 {
                     msg = Language.StringByID(StringId.saveFail);
                 }
-                EmptyTipView tipView = new EmptyTipView(msg, 160);
-                tipView.Gravity = Gravity.CenterHorizontal;
-                bodyView.AddChidren(tipView);
+
+                var tip_dialog = new Tip()
+                {
+                    Text = msg,
+                    CloseTime = 2,
+                    Direction = AMPopTipDirection.None
+                };
+                tip_dialog.Show(MainPage.BaseView);
 #endif
             };
+
+            if (tempPassword != null && tempPassword.id != null && tempPassword.id != "")
+            {
+                pwdEditText.Text = tempPassword.tempPwd;
+                pwdEditText.Enable = false;
+                phoneNumberEditText.Enable = false;
+                randomBtn.Enable = false;
+                startTimeBtn.Enable = false;
+                endTimeBtn.Enable = false;
+            }
+            else
+            {
+                pwdEditText.FoucsChanged = (sender, e) =>
+                {
+                    if (!pwdEditText.Foucs)
+                    {
+                        // 6浣嶅瘑鐮侀獙璇�
+                        var tip_dialog = new Tip()
+                        {
+                            Text = Language.StringByID(StringId.Input6_DigitsTemporaryPassword),
+                            CloseTime = 2,
+                            Direction = AMPopTipDirection.None
+                        };
+                        tip_dialog.Show(MainPage.BaseView);
+                    }
+                };
+
+                randomBtn.MouseUpEventHandler += (sender, e) =>
+                {
+                    string tPwd = getRandomPwd();
+                    pwdEditText.Text = tPwd;
+                };
+
+                phoneNumberEditText.FoucsChanged = (sender, e) =>
+                {
+                    if (!phoneNumberEditText.Foucs)
+                    {
+                        //鎵嬫満鍙风爜閿欒鎻愮ず
+                        if (!Utlis.CheckPhoneNumber(phoneNumberEditText.Text.Trim(), "86"))
+                        {
+                            var tip_dialog = new Tip()
+                            {
+                                Text = Language.StringByID(StringId.PhoneNumberErrorTip),
+                                CloseTime = 2,
+                                Direction = AMPopTipDirection.None
+                            };
+                            tip_dialog.Show(MainPage.BaseView);
+                        }
+                    }
+                };
+            }
 
             RefreshVisitorVoucherBtn();
         }
@@ -484,9 +549,11 @@
         /// </summary>
         private void RefreshVisitorVoucherBtn()
         {
+            if (tempPassword == null) return;
+
             if (tempPassword.tempPwd != null && tempPassword.tempPwd != "")
             {
-                codeIV.ImageBytes = Scan.BytesFromText(pwdEditText.Text, codeIV.Width, codeIV.Height);
+                codeIV.ImageBytes = Scan.BytesFromText(tempPassword.tempPwd, codeIV.Width, codeIV.Height);
                 //鍒ゆ柇浜岀淮鐮佹槸鍚﹀け鏁�
                 DateTime endTime = DateTime.Parse(tempPassword.validEndTime);
                 DateTime currentTime = DateTime.Now;
@@ -501,11 +568,13 @@
                         Text = Language.StringByID(StringId.QRcodeIsInvalid),
                     };
                     codeLayout.AddChidren(codeTip);
+                    visitorVoucherBtn.Visible = false;
                 }
                 visitorVoucherBtn.Text = Language.StringByID(StringId.CancleVisitorCredentials);
             }
             else
             {
+                visitorVoucherBtn.Visible = true;
                 visitorVoucherBtn.Text = Language.StringByID(StringId.GenerateVisitorCredentials);
             }
         }

--
Gitblit v1.8.0