From 43b0d5870d528f23ecd6aeceb6cfd4325188b46f Mon Sep 17 00:00:00 2001
From: wxr <464027401@qq.com>
Date: 星期四, 01 七月 2021 15:50:43 +0800
Subject: [PATCH] Revert "1"

---
 HDL_ON/Common/HDLCommon.cs |  131 ++++++++++++++++++++++++++++++++++++-------
 1 files changed, 108 insertions(+), 23 deletions(-)

diff --git a/HDL_ON/Common/HDLCommon.cs b/HDL_ON/Common/HDLCommon.cs
index 70b5864..ecced88 100644
--- a/HDL_ON/Common/HDLCommon.cs
+++ b/HDL_ON/Common/HDLCommon.cs
@@ -248,44 +248,106 @@
         #region 鈻� 鎺ㄩ�佸鐞哶______________________
         /// <summary>
         /// 鎺ㄩ�佹秷鎭鐞�
+        /// 娉ㄦ剰锛欰ndroid瑕佸湪涓荤嚎绋嬶紙UI绾跨▼锛夋墽琛�
         /// </summary>
         /// <param name="jpushMessageInfo"></param>
         public void AdjustPushMessage(JPushMessageInfo jpushMessageInfo)
         {
             try
             {
-                if (jpushMessageInfo.Extras != null && jpushMessageInfo.Extras.Contains("OffLine"))
-                {
-                    Shared.Application.RunOnMainThread(() =>
-                    {
-                        ////璐﹀彿鍦ㄥ埆澶勭櫥闄嗭紝琚涪涓嬬嚎 璺宠浆鍒扮櫥褰曢〉闈�
-                        //new Alert(Language.StringByID(StringId.Tip), Language.StringByID(StringId.LoggedOnOtherDevices), Language.StringByID(StringId.Close)).Show();
-                        //閫�鍑虹櫥褰曟搷浣�
-                        CheckLogout();
+                //Extras涓虹┖涓嶅鐞�
+                if (string.IsNullOrEmpty(jpushMessageInfo.Extras)) return;
 
-                    });
-                    return;
+                if (jpushMessageInfo.Extras.Contains(PushMessageType.OffLine.ToString()))
+                {
+                    CheckLogout();
                 }
                 else
                 {
-                    Shared.Application.RunOnMainThread(() =>
+                    GetPushMessageAction?.Invoke();
+
+                    //messageType涓虹┖涓嶅鐞�
+                    if (string.IsNullOrEmpty(jpushMessageInfo.messageType)) return;
+
+                    //鎶ヨ鎺ㄩ�佹墠寮圭獥鎻愮ず锛坢essageType鍖呭惈Alarm鍏抽敭瀛楃殑锛�
+                    if (jpushMessageInfo.messageType.Contains(PushMessageType.Alarm.ToString()))
                     {
-                        GetPushMessageAction?.Invoke();
-                        //鎶ヨ鎺ㄩ�佹墠寮圭獥鎻愮ず锛坢essageType鍖呭惈Alarm鍏抽敭瀛楃殑锛�
-                        if (jpushMessageInfo.messageType != null && jpushMessageInfo.messageType.Contains("Alarm"))
+                        //鎶ヨ鎺ㄩ�佸脊绐楁彁绀�
+                        ShowAlarmPushMessage(jpushMessageInfo,true);
+                    }
+                    else if (jpushMessageInfo.messageType.Contains(PushMessageType.FLCall.ToString()))
+                    {
+                        if (string.IsNullOrEmpty(jpushMessageInfo.expantContent)) return;
+
+                        ESVideoInfo eSVideoInfo = GetESOnVideoJson(jpushMessageInfo.expantContent);
+
+                        if (eSVideoInfo == null) return;
+
+                        if (string.IsNullOrEmpty(eSVideoInfo.uuid)) return;
+
+                        if (eSVideoInfo.uuid.Contains(","))
                         {
-                            //鎶ヨ鎺ㄩ�佸脊绐楁彁绀�
-                            ShowAlarmPushMessage(jpushMessageInfo);
-                            //new Alert(jpushMessageInfo.Title, jpushMessageInfo.Content, Language.StringByID(StringId.Close)).Show();
+                            var uuid = eSVideoInfo.uuid.Split(',');
+                            eSVideoInfo.ESVideoUUID = uuid[0];
+                        }
+                        else
+                        {
+                            eSVideoInfo.ESVideoUUID = eSVideoInfo.uuid;
                         }
 
-                    });
-                    return;
+                        ESOnVideo.Current.ShowESvideoVideoIntercom(eSVideoInfo, "FLVI");
+
+                    }
+                    else if (jpushMessageInfo.messageType.Contains(PushMessageType.HDL_INTERPHONE.ToString()))
+                    {
+                        if (string.IsNullOrEmpty(jpushMessageInfo.expantContent)) return;
+
+                        //瀛楁鍏煎闂锛屽彧鑳界洿鎺ュ彇鍊间簡
+                        var json= Newtonsoft.Json.Linq.JObject.Parse(jpushMessageInfo.expantContent);
+                        ESVideoInfo eSVideoInfo = new ESVideoInfo();// GetESOnVideoJson(jpushMessageInfo.expantContent);
+                        eSVideoInfo.callId = json["callId"].ToString();
+                        //eSVideoInfo.Lc_AccessToken = UI.UI2.PersonalCenter.PirDevice.PirSend.LcSubAccessToken;//json["subAccountToken"].ToString();//
+                        eSVideoInfo.Lc_AccessToken = json["subAccountToken"].ToString();//2021-05-13 鐩墠浜戠杩樻病鎷垮埌Lc_AccessToken锛岀洰鍓嶆病鍔炴硶姝e父浣跨敤
+                        eSVideoInfo.Lc_DeviceId = json["deviceId"].ToString();
+                        eSVideoInfo.Lc_Location = OnAppConfig.Instance.RequestHttpsHost.Contains("China") ? 0 : 1;
+                        eSVideoInfo.Lc_PlayToken = json["token"].ToString();
+                        eSVideoInfo.Lc_Psk = json["cname"].ToString();
+
+                        if (eSVideoInfo == null) return;
+
+                        ESOnVideo.Current.ShowESvideoVideoIntercom(eSVideoInfo, "IMOUVISIAL");
+
+                    }
+                    else if(jpushMessageInfo.messageType.Contains(PushMessageType.Prompt.ToString()))
+                    {
+                        ShowAlarmPushMessage(jpushMessageInfo, false);
+                    }
                 }
+            }
+            catch(Exception EX)
+            {
+                Utlis.WriteLine("catch: " + EX.ToString());
+            }
+        }
+
+        /// <summary>
+        /// 瑙f瀽涓版灄鍙瀵硅鎺ㄩ�佹暟鎹�
+        /// </summary>
+        /// <param name="jsonStr"></param>
+        /// <returns></returns>
+        ESVideoInfo GetESOnVideoJson(string jsonStr)
+        {
+            try
+            {
+                if (!string.IsNullOrEmpty(jsonStr))
+                {
+                    return Newtonsoft.Json.JsonConvert.DeserializeObject<ESVideoInfo>(jsonStr);
+                }
+                return null;
             }
             catch
             {
-
+                return null;
             }
         }
 
@@ -311,6 +373,8 @@
                 case "13602944661":
                 case "18778381374":
                 case "18316672920":
+                case "15626203746":
+                case "551775569@qq.com":
                     return;
             }
 
@@ -371,7 +435,8 @@
         /// 鎶ヨ鎺ㄩ�佸脊绐楁彁绀�,鐐瑰嚮鏌ョ湅璺宠浆淇℃伅涓績
         /// </summary>
         /// <param name="jpushMessageInfo"></param>
-        public void ShowAlarmPushMessage(JPushMessageInfo jpushMessageInfo)
+        /// <param name="isAlarm">鏄惁鏄姤璀︿俊鎭紝锛堝姞杞界殑寮圭獥棰滆壊涓嶄竴鏍凤級</param>
+        public void ShowAlarmPushMessage(JPushMessageInfo jpushMessageInfo,bool isAlarm)
         {
             //娌$櫥褰曚笉澶勭悊
             if (UserInfo.Current == null || !UserInfo.Current.IsLogin || MainPage.BasePageView == null)
@@ -382,6 +447,25 @@
             //璺宠浆淇℃伅涓績椤甸潰
             Action goAction = () =>
             {
+                //鏌ョ湅瀵瑰簲浣忓畢鐨勪俊鎭紝瑕佸垏鎹㈠埌瀵瑰簲浣忓畢
+                if (jpushMessageInfo.HomeId != DB_ResidenceData.Instance.CurrentRegion.id)
+                {
+                    var homeTemp = UserInfo.Current.regionList.Find((obj) => jpushMessageInfo.HomeId == obj.id);
+                    if (homeTemp != null)
+                    {
+                        DB_ResidenceData.Instance.CurrentRegion = homeTemp;
+                        DB_ResidenceData.Instance.SaveResidenceData();
+                        DB_ResidenceData.Instance.EixtAccount();
+                        //鍒锋柊浣忓畢鏁版嵁
+                        Common.ApiUtlis.Ins.DownloadData();
+                        while (MainPage.BasePageView.ChildrenCount > 1)
+                        {
+                            MainPage.BasePageView.PageIndex = MainPage.BasePageView.ChildrenCount - 2;
+                        }
+                        MainPage.CurPageIndex = 9999;
+                        MainPage.UserBasePage.ChooseCollection();
+                    }
+                }
                 //Dialog
                 alarmPushConfirmDialog = null;
                 Action backAction = () =>
@@ -403,7 +487,7 @@
             //闃叉澶氭寮圭獥澶勭悊
             if (alarmPushConfirmDialog == null)
             {
-                alarmPushConfirmDialog = new ConfirmDialog();
+                alarmPushConfirmDialog = new ConfirmDialog(isAlarm);
                 alarmPushConfirmDialog.ShowDialog(Language.StringByID(StringId.Tip), jpushMessageInfo.Content, goAction, cancelAction, StringId.Cancel, StringId.LookOver);
             }
             else
@@ -518,7 +602,8 @@
                             {
 #if __IOS__
                                 //iOS
-
+                                //鍒濆鍖栬悿鐭充簯SDK锛屼腑鏂囧浗鍐卥ey銆佽嫳鏂囨捣澶杒ey 寮�鍙戣�呰处鍙蜂娇鐢ㄥ簲鐢ㄥ寘鍚嶇敵璇风殑APPKEY锛屼笉鍚屽寘鍚嶅簲鐢ㄩ渶閰嶇疆涓嶅悓鐨凙PPKEY
+                                EZSDK.IOS.EZSDK.InitLibWithAppKey("1aa98a90489b4838b966b57018b4b04b", "1aa98a90489b4838b966b57018b4b04b");
                                 //1.璁剧疆鎵�闇�娌充笢鐨凙ccessToken鍜孯efreshToken銆佸煙鍚嶅湴鍧�
                                 EZSDK.IOS.EZSDK.SetHDlAccessToken(UserInfo.Current.LoginTokenString, UserInfo.Current.RefreshToken);
                                 EZSDK.IOS.EZSDK.SetRequestHttpsHost(OnAppConfig.Instance.RequestHttpsHost);

--
Gitblit v1.8.0