From 0a3c181367008553cd34bc7c4deab70ba3c8bac7 Mon Sep 17 00:00:00 2001
From: 涂煌豪 <tuhuanghao@prec-tech.com>
Date: 星期四, 19 五月 2022 10:09:52 +0800
Subject: [PATCH] 客户人员重复校验修改为姓名+手机号形式

---
 force-app/main/default/classes/ContactTriggerHandler.cls |   42 ++++++++++++---------
 force-app/main/default/classes/NFM624Rest.cls            |   59 +++++++++++++++++++----------
 2 files changed, 63 insertions(+), 38 deletions(-)

diff --git a/force-app/main/default/classes/ContactTriggerHandler.cls b/force-app/main/default/classes/ContactTriggerHandler.cls
index 3c3c299..54e167f 100644
--- a/force-app/main/default/classes/ContactTriggerHandler.cls
+++ b/force-app/main/default/classes/ContactTriggerHandler.cls
@@ -172,7 +172,7 @@
         }else{
             //Add By Li Jun for sync agency contact to aws 20220424 start
             if(!Test.isRunningTest()){
-                SyncAccountContactToAWS.assignOnceOneMinuteLater();
+                SyncAccountContactToAWS.assignOnceOneMinuteLater(aclist);
             }
             //Add By Li Jun for sync agency contact to aws 20220424 end
         }
@@ -255,7 +255,7 @@
     // 鎵嬫満鍙峰幓閲嶅強瑙勫垯楠岃瘉 鍙婃柊澧炲鎴蜂汉鍛橀噸鍚嶉獙璇�
     public void mobileNumberVerification(){
 
-        Pattern pattern = Pattern.compile('^(13[0-9]|14[01456879]|15[0-35-9]|16[2567]|17[0-8]|18[0-9]|19[0-35-9])\\d{8}$');
+        // Pattern pattern = Pattern.compile('^(13[0-9]|14[01456879]|15[0-35-9]|16[2567]|17[0-8]|18[0-9]|19[0-35-9])\\d{8}$');
         Map<String, Map<String,Contact>> accountContactMap = new Map<String, Map<String,Contact>>();
         Set<Id> accountIdSet = new Set<Id>();
         //鐢ㄦ埛瀵硅薄涓婃壘瀵瑰簲鐨勮仈绯讳汉
@@ -293,18 +293,20 @@
             // 鎵嬫満鍙锋湁鍊煎苟涓旇仈绯讳汉鏈夋晥锛岃仈绯讳汉鐨勫鎴锋湁鏁堬紝杩涜鎵嬫満鍙风爜楠岃瘉
             if (('鏈夋晥'.equals(contactnew.Isactive__c) || '鏈夊姽'.equals(contactnew.Isactive__c))
                 && ('鏈夊姽'.equals(accMap.get(contactnew.AccountId)) || '鏈夋晥'.equals(accMap.get(contactnew.AccountId)))) {
+                // 缁忛攢鍟嗗鎴蜂汉鍛樹笉杩涜鎵嬫満鍙锋牎楠� thh 20220517 start
                 if(AgencyRecordTypeId.equals(contactnew.RecordTypeId)){
                     if(String.isNotBlank(contactnew.MobilePhone)){
-                        Matcher isMobilePhone = pattern.matcher(contactnew.MobilePhone);
-                        if (isMobilePhone.matches()) {
-                            contactnew.UniqueNumber__c = contactnew.MobilePhone;
-                        } else {
+                        // Matcher isMobilePhone = pattern.matcher(contactnew.MobilePhone);
+                        // if (isMobilePhone.matches()) {
+                        contactnew.UniqueNumber__c = contactnew.MobilePhone;
+                        // } else {
                             // 鎵嬫満鍙峰敮涓�瀛楁娓呯┖
-                            contactnew.UniqueNumber__c = null;
-                        }
+                            // contactnew.UniqueNumber__c = null;
+                        // }
                     } else {
                         contactnew.UniqueNumber__c = null;
                     }
+                // 缁忛攢鍟嗗鎴蜂汉鍛樹笉杩涜鎵嬫満鍙锋牎楠� thh 20220517 end
                 } else if(DoctorRecordTypeId.equals(contactnew.RecordTypeId)){
                     if(String.isNotBlank(contactnew.MobilePhone_Encrypted__c)){
                         contactnew.UniqueNumber__c = contactnew.MobilePhone_Encrypted__c;
@@ -322,15 +324,17 @@
         if (accountIdSet.size() > 0) {
             List<Contact> contactList = [SELECT Id,AccountId,FullName__c,LastName,FirstName,Account.Name,CManageCode__c,IsFromSPO__c,
                                          LastName_Encrypted__c// 20220314 PI鏀归�� by Bright
+                                         , MobilePhone_Encrypted__c // 閫氳繃濮撳悕+鎵嬫満鍙峰垽鏂汉鍛樻槸鍚﹂噸澶� thh 20220518
                                         FROM Contact 
                                         WHERE IsFromSPO__c = false AND AccountId IN:accountIdSet];
             if ( contactList.size() > 0) {
                 for(Contact contact :contactList){
-
-                    String lastNameStr = String.isNotBlank(contact.LastName) ? contact.LastName:'';
-                    String firstNameStr = String.isNotBlank(contact.FirstName) ? contact.FirstName:'';
-                    String contactFullName = lastNameStr + firstNameStr;
-                    contactFullName = contact.LastName_Encrypted__c;// 20220314 PI鏀归�� by Bright
+                    // 閫氳繃濮撳悕+鎵嬫満鍙峰垽鏂汉鍛樻槸鍚﹂噸澶� thh 20220518 start
+                    // String lastNameStr = String.isNotBlank(contact.LastName) ? contact.LastName:'';
+                    // String firstNameStr = String.isNotBlank(contact.FirstName) ? contact.FirstName:'';
+                    // String contactFullName = lastNameStr + firstNameStr + MobilePhoneStr;
+                    String contactFullName = contact.LastName_Encrypted__c + contact.MobilePhone_Encrypted__c;// 20220314 PI鏀归�� by Bright
+                    // 閫氳繃濮撳悕+鎵嬫満鍙峰垽鏂汉鍛樻槸鍚﹂噸澶� thh 20220518 end
                     if(string.isBlank(contactFullName)){
                         continue;
                     }      
@@ -353,17 +357,19 @@
 
                 if (accountContactMap.containsKey(accountId)) {
                     Map<String,Contact> contactFullNameMap =  accountContactMap.get(accountId);
-                    String lastNameStr = String.isNotBlank(contactnew.LastName) ? contactnew.LastName:'';
-                    String firstNameStr = String.isNotBlank(contactnew.FirstName) ? contactnew.FirstName:'';
-                    String contactFullName = lastNameStr + firstNameStr;
-					contactFullName = contactnew.LastName_Encrypted__c;// 20220314 PI鏀归�� by Bright
+                    // 閫氳繃濮撳悕+鎵嬫満鍙峰垽鏂汉鍛樻槸鍚﹂噸澶� thh 20220518 start
+                    // String lastNameStr = String.isNotBlank(contactnew.LastName) ? contactnew.LastName:'';
+                    // String firstNameStr = String.isNotBlank(contactnew.FirstName) ? contactnew.FirstName:'';
+                    // String contactFullName = lastNameStr + firstNameStr + MobilePhoneStr;
+                    String contactFullName = contactnew.LastName_Encrypted__c + contactnew.MobilePhone_Encrypted__c;// 20220314 PI鏀归�� by Bright
+                    // 閫氳繃濮撳悕+鎵嬫満鍙峰垽鏂汉鍛樻槸鍚﹂噸澶� thh 20220518 end
                     if (contactFullNameMap.containsKey(contactFullName)) {
                         String accountName = contactFullNameMap.get(contactFullName).Account.Name;
                         String cManageCode = contactFullNameMap.get(contactFullName).CManageCode__c;
                         // 璺宠繃娴嬭瘯绋嬪簭 鍜� SPO閫氳繃203鎺ュ彛鍒涘缓鐨勮仈绯讳汉
                         if (!(Test.isRunningTest() || contactnew.IsFromSPO__c)) {
                             contactnew.LastName.addError('瀹㈡埛 [ '+accountName+ ' ],宸插瓨鍦ㄧ浉鍚屽悕瀛楃殑鑱旂郴浜� 浜哄憳绠$悊缂栫爜 ['+cManageCode+' ] 锛屼笉鑳介噸澶嶅垱寤猴紝璇蜂簡瑙�');     
-                        }
+                        }      
                            
                     }
                 }
diff --git a/force-app/main/default/classes/NFM624Rest.cls b/force-app/main/default/classes/NFM624Rest.cls
index f86d171..bbaf611 100644
--- a/force-app/main/default/classes/NFM624Rest.cls
+++ b/force-app/main/default/classes/NFM624Rest.cls
@@ -18,7 +18,7 @@
     // global class GeDatasRest {
     //     public GeDatas GeDatas;
     // }
- 
+
     global class GeDatas {
         public NFMUtil.Monitoring Monitoring;
         public GeData[] GeData;
@@ -101,7 +101,6 @@
     }
  
     global static void main(String rowData_Id) {
- 
         // Map<String,String> RecordTypeMap = new Map<String,String>();
         // RecordTypeMap.put('','')
 //List<RecordType> rectDpt = [select Id from RecordType where IsActive = true and SobjectType = 'Account' and DeveloperName IN ('Department_OTH','Department_GI', 'Department_BF','Department_GYN','Department_GS','Department_URO','Department_ENT','Department_Class_ET') order by DeveloperName desc];        
@@ -222,6 +221,7 @@
                 List < Contact > peopleList = [select Id, 
                                                       Account.Name,
                                                       Department__c, 
+                                                      UnifiedI_Contact_ID__c,
                                                       Account.parent.Name, 
                                                       Account.PlatformCode__c, 
                                                       Account.Management_Code__c, 
@@ -230,7 +230,10 @@
                                                       Account.Parent_Management_Code__c, 
                                                       Account.Parent_PlatformCode__c, 
                                                       CManageCode__c, 
-                                                      AccountId 
+                                                      AccountId,
+                                                      // 閫氳繃濮撳悕+鎵嬫満鍙峰垽鏂汉鍛樻槸鍚﹂噸澶� thh 20220518 start
+                                                      MobilePhone_Encrypted__c
+                                                      // 閫氳繃濮撳悕+鎵嬫満鍙峰垽鏂汉鍛樻槸鍚﹂噸澶� thh 20220518 end
                                                       from Contact 
                                                       where CManageCode__c IN: PersonManagementCodeList 
                                                       OR (Account.Parent_PlatformCode__c IN: ManagementList AND LastName_Encrypted__c IN:NameList)
@@ -249,7 +252,9 @@
                         }
                         snameMap.put(namekey, ct);
                         snameMap.put(nameKey2,ct);
-                        snameMap.put(ct.LastName_Encrypted__c.trim(), ct);
+                        // 閫氳繃濮撳悕+鎵嬫満鍙峰垽鏂汉鍛樻槸鍚﹂噸澶� thh 20220518 start
+                        snameMap.put(ct.LastName_Encrypted__c.trim() + ct.MobilePhone_Encrypted__c.trim(), ct);
+                        // 閫氳繃濮撳悕+鎵嬫満鍙峰垽鏂汉鍛樻槸鍚﹂噸澶� thh 20220518 end
                         nameMap.put(ct.Account.parent.Name, snameMap);
                         system.debug('snameMap'+snameMap);
                     }
@@ -396,11 +401,14 @@
                                             Map < String, Contact > sMap = nameMap.get(DepartmentClasskey);
                                             System.debug('sMap'+sMap);
                                             System.debug('sMap.containsKey(namekey)'+sMap.containsKey(namekey));
-                                            if (sMap.containsKey(namekey)) {
+                                            System.debug('sMap.containsKey(gedata.NameEncrypted)'+sMap.containsKey(gedata.NameEncrypted));
+                                            if (sMap.containsKey(namekey) && sMap.get(namekey).UnifiedI_Contact_ID__c == null) {
                                                 system.debug('Id璧嬪��'+sMap);
                                                 ct.id = sMap.get(namekey).id;
-                                            } else if(sMap.containsKey(gedata.NameEncrypted)){
-                                                ct.id = sMap.get(gedata.NameEncrypted).id;
+                                            // 閫氳繃濮撳悕+鎵嬫満鍙峰垽鏂汉鍛樻槸鍚﹂噸澶� thh 20220518 start
+                                            } else if(sMap.containsKey(gedata.NameEncrypted + gedata.MobileEncrypted) && sMap.get(gedata.NameEncrypted + gedata.MobileEncrypted).UnifiedI_Contact_ID__c == null){
+                                                ct.id = sMap.get(gedata.NameEncrypted + gedata.MobileEncrypted).id;
+                                            // 閫氳繃濮撳悕+鎵嬫満鍙峰垽鏂汉鍛樻槸鍚﹂噸澶� thh 20220518 end
                                             }else { // 7 瀹屾垚
                                                 system.debug('7閫昏緫 鏃犱汉鍛樼鐞嗙紪鐮� 鏈夊尰闄� 鏈夌瀹� 浜哄悕鏌ユ壘鏃� 鍔ㄤ綔锛氭柊寤鸿仈绯讳汉 ');
                                             }
@@ -442,8 +450,8 @@
                                             system.debug('鎴樼暐绉戝瀛樺湪' + nameMap.get(DepartmentClasskey));
                                             Map < String, Contact > sMap = nameMap.get(DepartmentClasskey);
                                             system.debug('namekey'+namekey);
-                                            system.debug('sMap.containsKey(namekey)'+sMap.containsKey(namekey));
-                                            if (sMap.containsKey(namekey)) { //鏌ユ壘瀛樺湪 8 瀹屾垚
+                                            system.debug('sMap.containsKey(namekey)'+sMap.containsKey(namekey) );
+                                            if (sMap.containsKey(namekey) && sMap.get(namekey).UnifiedI_Contact_ID__c == null) { //鏌ユ壘瀛樺湪 8 瀹屾垚
                                                 system.debug('8閫昏緫');
                                                 system.debug('璇ヨ仈绯讳汉瀛樺湪');
                                                 ct.id = sMap.get(namekey).id;
@@ -452,11 +460,14 @@
                                                 // if(sMap.containsKey(gedata.Name)){
                                                 //     ct.Id = sMap.get(gedata.Name).Id;
                                                 // }
-                                            }else if(sMap.containsKey(gedata.NameEncrypted)){
+                                            // 閫氳繃濮撳悕+鎵嬫満鍙峰垽鏂汉鍛樻槸鍚﹂噸澶� thh 20220518 start
+                                            }else if(sMap.containsKey(gedata.NameEncrypted + gedata.MobileEncrypted) && sMap.get(gedata.NameEncrypted + gedata.MobileEncrypted).UnifiedI_Contact_ID__c == null){
                                                 system.debug('1234567890');
-                                                ct.Id = sMap.get(gedata.NameEncrypted).Id;
+                                                ct.Id = sMap.get(gedata.NameEncrypted + gedata.MobileEncrypted).Id;
                                                 //upsertAccountList.add(dpt);
+                                                upsertContactList.add(ct);
                                             }
+                                            // 閫氳繃濮撳悕+鎵嬫満鍙峰垽鏂汉鍛樻槸鍚﹂噸澶� thh 20220518 end
                                             system.debug('contactMap        '  +  contactMap);
                                             System.debug('9閫昏緫');
                                             contactMap.put(Gedata.DepartmentManagementCode2, ct);
@@ -650,19 +661,27 @@
             //List<String> contactIdList = new List<String>();
             for (Inquiry_form__c inquiryInfo : inquiryList) {
                 //contactIdList.add(inquiryInfo.ContactId__c);
-                inquiryMap.put(inquiryInfo.ContactId__c, inquiryInfo.Id);
+                // map鐨刱-v鏀归�� thh 20220517 start
+                inquiryMap.put(inquiryInfo.Id, inquiryInfo.ContactId__c);
+                // map鐨刱-v鏀归�� thh 20220517 end
             }
-            if (contactList.size() >0 ) {
-                for (Contact contactInfo : contactList) {
+            // map鐨刱-v鏀归�� thh 20220517 start
+            if (contactList.size() >0 && inquiryMap.size() > 0) {
+                for(String Id : inquiryMap.keySet()){
                     Inquiry_form__c inquiry = new Inquiry_form__c();
-                    inquiry.Id = inquiryMap.get(contactInfo.UnifiedI_Contact_ID__c);      //ID
-                    inquiry.Hospital_Name__c = contactInfo.Account.Id;                    //绉戝鍚�   
-                    inquiry.Department_Class__c = contactInfo.Strategic_dept_Class__c;    //鎴樼暐绉戝鍒嗙被
-                    inquiry.Contact_Name__c = contactInfo.Id;                             //瀹㈡埛濮撳悕
-                    inquiry.OwnerId = contactInfo.Strategic_dept_Class__r.OwnerId;        //鎵�鏈変汉
-                    inquiryFormList.add(inquiry);
+                    for (Contact contactInfo : contactList) {
+                        if(inquiryMap.get(Id) == contactInfo.UnifiedI_Contact_ID__c){
+                            inquiry.Id = Id;      //ID
+                            inquiry.Hospital_Name__c = contactInfo.Account.Id;                    //绉戝鍚�   
+                            inquiry.Department_Class__c = contactInfo.Strategic_dept_Class__c;    //鎴樼暐绉戝鍒嗙被
+                            inquiry.Contact_Name__c = contactInfo.Id;                             //瀹㈡埛濮撳悕
+                            inquiry.OwnerId = contactInfo.Strategic_dept_Class__r.OwnerId;        //鎵�鏈変汉
+                            inquiryFormList.add(inquiry);
+                        }
+                    }
                 }
             }
+            // map鐨刱-v鏀归�� thh 20220517 end  
             system.debug('inquiryFormList=========>'+inquiryFormList);
             if(inquiryFormList.size()>0){
                 update inquiryFormList;

--
Gitblit v1.9.1