From e87985ec1dcb69beedaf9f95e8e7aba14b7c08d6 Mon Sep 17 00:00:00 2001
From: JLChen <551775569@qq.com>
Date: 星期三, 09 十二月 2020 18:50:14 +0800
Subject: [PATCH] 2020-12-09 1.信息中心,增加下划线和点击Alter提醒详情。

---
 HDL-ON_iOS/AppDelegate.cs |  173 +++++++++++++++++++++++++++++++++++++++++++++++----------
 1 files changed, 141 insertions(+), 32 deletions(-)

diff --git a/HDL-ON_iOS/AppDelegate.cs b/HDL-ON_iOS/AppDelegate.cs
index 821c341..c10be06 100644
--- a/HDL-ON_iOS/AppDelegate.cs
+++ b/HDL-ON_iOS/AppDelegate.cs
@@ -8,6 +8,7 @@
 using Microsoft.AppCenter.Analytics;
 using Microsoft.AppCenter.Crashes;
 using HDL_ON.UI;
+using HDL_ON.DAL.Server;
 
 namespace SharedMethod
 {
@@ -23,7 +24,7 @@
         //    UserConfig.Instance.IsAppStoreVersionNewer = Harpy.Harpy.SharedInstance.TestIsAppStoreVersionNewer;
         //    UserConfig.Instance.StoreVersion = Harpy.Harpy.SharedInstance.CurrentAppStoreVersion;
         //    UserConfig.Instance.SaveUserConfig();
-        //    if (Shared.SimpleControl.MainPage.LoginUser.AccountString == @"464027401@qq.com")
+        //    if (Shared.SimpleControl. UserInfo.Current.AccountString == @"464027401@qq.com")
         //    {
         //        return $"TestIsAppStoreVersionNewer : {UserConfig.Instance.IsAppStoreVersionNewer};;  CurrentAppStoreVersion : {UserConfig.Instance.StoreVersion}";
         //    }
@@ -34,6 +35,7 @@
         //}
     }
 
+    
 }
 
 namespace HDL_ON_iOS
@@ -99,16 +101,16 @@
                 NSUserDefaults.StandardUserDefaults.SetString(DeviceToken, "PushDeviceToken");
                 string userPhoneName = UIDevice.CurrentDevice.Name;
 
-                OnAppConfig.Instance.PushDeviceToken = DeviceToken;
-                //UserConfig.Instance.phoneName = userPhoneName;
-                //UserConfig.Instance.SaveUserConfig();
+                UserInfo.Current.PushDeviceToken = DeviceToken;
+                UserInfo.Current.PhoneName = userPhoneName;
+                UserInfo.Current.SaveUserInfo();
             }
-            if (OnAppConfig.Instance.PushDeviceToken != DeviceToken)
+            if (UserInfo.Current.PushDeviceToken != DeviceToken)
             {
                 string userPhoneName = UIDevice.CurrentDevice.Name;
-                OnAppConfig.Instance.PushDeviceToken = DeviceToken;
-                //UserConfig.Instance.phoneName = userPhoneName;
-                //UserConfig.Instance.SaveUserConfig();
+                UserInfo.Current.PushDeviceToken = DeviceToken;
+                UserInfo.Current.PhoneName = userPhoneName;
+                UserInfo.Current.SaveUserInfo();
             }
         }
 
@@ -118,6 +120,26 @@
 
             //璇诲彇鎺ㄩ�佷俊鎭�
             UIApplication.SharedApplication.ApplicationIconBadgeNumber = 0;
+
+            if (userInfo == null)
+            {
+                return;
+            }
+
+            Console.WriteLine(userInfo);
+
+            if (application.ApplicationState == UIApplicationState.Active || application.ApplicationState == UIApplicationState.Background)
+            {
+
+                HandleNotificationMessageUserInfo(userInfo, false);
+            }
+            else
+            {
+                //Inactive
+                HandleNotificationMessageUserInfo(userInfo, false);
+
+            }
+            completionHandler(UIBackgroundFetchResult.NewData);
         }
 
         public override void ReceivedRemoteNotification(UIApplication application, NSDictionary userInfo)
@@ -143,7 +165,8 @@
         public override void OnResignActivation(UIApplication application)
         {
             Console.WriteLine("OnResignActivation");
-            BusSocket.Stop();
+            OnAppConfig.Instance.unlockTime = DateTime.Now;
+            HDL_ON.DriverLayer.UdpSocket._BusSocket.Stop();
         }
 
         public override void DidEnterBackground(UIApplication application)
@@ -156,10 +179,11 @@
         public override void WillEnterForeground(UIApplication application)
         {
             SharedMethod.SharedMethod.IsBackground = false;
-            //BusSocket.Start(6000);
+            HDL_ON.DriverLayer.UdpSocket._BusSocket.Start();
             new AppUnlockPage().LoadPage();
             Console.WriteLine("WillEnterForeground");
             UIApplication.SharedApplication.ApplicationIconBadgeNumber = 0;
+            HDL_ON.DriverLayer.Control.Ins.SearchLoaclGateway();
         }
 
         public override void WillTerminate(UIApplication application)
@@ -172,19 +196,26 @@
             Console.WriteLine("OnActivated");
             base.OnActivated(application);
 
+            //if (haveToSignOut == true)
+            //{
+                ////寮哄埗涓嬬嚎
+                //UserInfo.Current.LastTime = DateTime.MinValue;
+                //UserInfo.Current.headImagePagePath = "LoginIcon/2.png";//閲嶇疆鐢ㄦ埛澶村儚
+                //UserInfo.Current.SaveUserInfo();
+                //HDLCommon.Current.ShowAlert(Language.StringByID(StringId.LoggedOnOtherDevices));
+            //}
+
         }
 
         public override bool FinishedLaunching(UIApplication application, NSDictionary launchOptions)
         {
 
             //Shared.Application.FontSize = 12;
-            //Shared.Application.IsUsePingFang = true;
+            Shared.Application.IsUsePingFang = true;
             Window = new UIWindow(UIScreen.MainScreen.Bounds);
             rootViewController = new UINavigationController(new ViewController()) { NavigationBarHidden = true };
             Window.RootViewController = rootViewController;
             Window.MakeKeyAndVisible();
-
-
 
             AppCenter.Start("e1add75a-82c6-4a5c-a902-4705b195748e",typeof(Analytics), typeof(Crashes));
             base.FinishedLaunching(application, launchOptions);
@@ -193,30 +224,23 @@
             //NSString* nsCount = [[NSLocale currentLocale] objectForKey: NSLocaleCountryCode];
             application.StatusBarStyle = UIStatusBarStyle.DarkContent;
 
-            string nsCount = NSLocale.CurrentLocale.CountryCode;
-            if (nsCount != OnAppConfig.Instance.CountryCode)
-            {
-                OnAppConfig.Instance.CountryCode = nsCount;
-                OnAppConfig.Instance.SaveUserConfig();
-            }
+            //string nsCount = NSLocale.CurrentLocale.CountryCode;
+
+            //if ( UserInfo.Current != null && nsCount !=  UserInfo.Current.areaCode.ToString())
+            //{
+            //    //int.TryParse(nsCount,out  UserInfo.Current.areaCode);
+            //    //2020-11-18
+            //     UserInfo.Current.areaCode = nsCount;
+            //    OnAppConfig.Instance.SaveUserConfig();
+            //}
+
             application.IdleTimerDisabled = true;
             application.RegisterForRemoteNotificationTypes(UIRemoteNotificationType.Alert | UIRemoteNotificationType.Badge | UIRemoteNotificationType.Sound);
 
             //window.AccessibilityNavigationStyle = UIAccessibilityNavigationStyle.Automatic;
             // check for a notification
-            if (launchOptions != null)
-            {
-                // check for a remote notification
-                if (launchOptions.ContainsKey(UIApplication.LaunchOptionsRemoteNotificationKey))
-                {
-
-                    NSDictionary remoteNotification = launchOptions[UIApplication.LaunchOptionsRemoteNotificationKey] as NSDictionary;
-                    if (remoteNotification != null)
-                    {
-                        //UIApplication.SharedApplication.ApplicationIconBadgeNumber = 0;
-                    }
-                }
-            }
+            DealWithPushMes(launchOptions);
+          
             if (UIDevice.CurrentDevice.CheckSystemVersion(8, 0))
             {
                 var notificationSettings = UIUserNotificationSettings.GetSettingsForTypes(UIUserNotificationType.Alert | UIUserNotificationType.Badge | UIUserNotificationType.Sound, null);
@@ -245,6 +269,91 @@
             Console.WriteLine("FinishedLaunching");
             return true;
         }
+
+        /// <summary>
+        /// 澶勭悊閫氱煡娑堟伅
+        /// </summary>
+        void HandleNotificationMessageUserInfo(NSDictionary userInfo, bool bFinishedLaunching)
+        {
+            try
+            {
+                if (userInfo.ContainsKey(new NSString("aps")))
+                {
+                    var aps = userInfo["aps"] as NSDictionary;
+                    var alert = aps["alert"] as NSDictionary;
+                    var body = alert["body"] as NSString;
+                    var title = alert["title"] as NSString;
+                    var expandData = "";
+                    if (userInfo.ContainsKey(new NSString("expandData")))
+                    {
+                        var expandDataNSD = userInfo["expandData"] as NSDictionary;
+                        expandData = expandDataNSD["messageType"] as NSString;
+                    }
+                    var pushMes = new JPushMessageInfo()
+                    {
+                        Title = title,
+                        Content = body,
+                        Extras = expandData,
+                    };
+                    System.Console.WriteLine("PushMes title : " + pushMes.Title);
+                    System.Console.WriteLine("PushMes message : " + pushMes.Content);
+                    System.Console.WriteLine("PushMes extras : " + pushMes.Extras);
+
+                    if (bFinishedLaunching)
+                    {
+                        if (pushMes.Extras != null && pushMes.Extras.Contains("OffLine"))
+                        {
+                            //haveToSignOut = true;
+                            //寮哄埗涓嬬嚎
+                            UserInfo.Current.LastTime = DateTime.MinValue;
+                            UserInfo.Current.headImagePagePath = "LoginIcon/2.png";//閲嶇疆鐢ㄦ埛澶村儚
+                            UserInfo.Current.SaveUserInfo();
+                            HDLCommon.Current.ShowAlert(Language.StringByID(StringId.LoggedOnOtherDevices));
+                        }
+                    }
+                    else
+                    {
+                        HDLCommon.Current.AdjustPushMessage(pushMes);
+                    }
+                   
+                }
+            }
+            catch
+            {
+
+            }
+        }
+
+        ///// <summary>
+        ///// 閫�鍑虹櫥褰曟爣璁�
+        ///// </summary>
+        //bool haveToSignOut;
+        /// <summary>
+        /// 鍚姩APP 澶勭悊閫氱煡
+        /// </summary>
+        /// <param name="launchOptions"></param>
+        void DealWithPushMes(NSDictionary launchOptions)
+        {
+            //haveToSignOut = false;
+            if (launchOptions != null)
+            {
+                // check for a remote notification
+                if (launchOptions.ContainsKey(UIApplication.LaunchOptionsRemoteNotificationKey))
+                {
+                    NSDictionary userInfo = launchOptions[UIApplication.LaunchOptionsRemoteNotificationKey] as NSDictionary;
+
+                    if (userInfo != null)
+                    {
+                        HandleNotificationMessageUserInfo(userInfo, true);
+
+                    }
+                }
+            }
+        }
+
+
+
     }
+
 }
 

--
Gitblit v1.8.0