From c36f49d724cf5e680091a45f590fbd03673c82c4 Mon Sep 17 00:00:00 2001 From: 涂煌豪 <tuhuanghao@prec-tech.com> Date: 星期五, 27 五月 2022 10:11:24 +0800 Subject: [PATCH] 只对医院客户人员进行姓名+手机重复校验 --- force-app/main/default/classes/ContactTriggerHandler.cls | 113 +++++++++++++++++++++++++++++++++++--------------------- 1 files changed, 71 insertions(+), 42 deletions(-) diff --git a/force-app/main/default/classes/ContactTriggerHandler.cls b/force-app/main/default/classes/ContactTriggerHandler.cls index 3c3c299..3e9f002 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; @@ -313,24 +315,39 @@ } } } - if (Trigger.isInsert) { + // if (Trigger.isInsert) { + if(DoctorRecordTypeId.equals(contactnew.RecordTypeId)){ accountIdSet.add(contactnew.AccountId); - } + } + // } } //鎵嬫満鍙峰敮涓�鏍¢獙-鍖婚櫌涓嬫柊寤哄鎴蜂汉鍛樻牎楠屼娇鐢ㄥ姞瀵嗘墜鏈哄彿,缁忛攢鍟嗕娇鐢ㄦ櫘閫氭墜鏈哄彿 thh 20220328 end - // 鏂板鑱旂郴浜烘椂锛� + // 鏂板鍖婚櫌鑱旂郴浜烘椂 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 - FROM Contact - WHERE IsFromSPO__c = false AND AccountId IN:accountIdSet]; - if ( contactList.size() > 0) { + List<Contact> contactList = new List<Contact>(); + if(Trigger.isInsert){ + 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(Trigger.isUpdate){ + 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 AND Id Not IN: oldMap.keyset()]; + } + System.debug('contactList:' + contactList); + 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; } @@ -346,29 +363,41 @@ } for (Contact contactnew: newList) { - - if (Trigger.isInsert) { - - String accountId = String.valueOf(contactnew.AccountId).substring(0, 15); - - 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 - 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)) { + if(AgencyRecordTypeId.equals(contactnew.RecordTypeId) || (Trigger.isUpdate && !oldMap.isEmpty() && oldMap.get(contactnew.Id) != null + && String.isBlank(oldMap.get(contactnew.Id).MobilePhone_Encrypted__c) + && String.isBlank(contactnew.MobilePhone_Encrypted__c))){ + continue; + } + String accountId = String.valueOf(contactnew.AccountId).substring(0, 15); + if (accountContactMap.containsKey(accountId)) { + Map<String,Contact> contactFullNameMap = accountContactMap.get(accountId); + // 閫氳繃濮撳悕+鎵嬫満鍙峰垽鏂汉鍛樻槸鍚﹂噸澶� 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)) { + // if(Trigger.isInsert) { contactnew.LastName.addError('瀹㈡埛 [ '+accountName+ ' ],宸插瓨鍦ㄧ浉鍚屽悕瀛楃殑鑱旂郴浜� 浜哄憳绠$悊缂栫爜 ['+cManageCode+' ] 锛屼笉鑳介噸澶嶅垱寤猴紝璇蜂簡瑙�'); - } - - } + // } + // 瀹㈡埛浜哄憳鍒犻櫎鎵嬫満鍙锋椂,杩涜鍒ゆ柇鏄惁瀛樺湪鍚屽悕涓旀墜鏈哄彿涓虹┖鐨勫鎴蜂汉鍛� thh 20220523 start + // if(Trigger.isUpdate && !UserInfo.getUserId().equals(System.Label.interfaceUserID)) { + // if (String.isNotBlank(oldMap.get(contactnew.Id).MobilePhone_Encrypted__c) && String.isBlank(contactnew.MobilePhone_Encrypted__c)){ + // contactnew.LastName.addError('鐩稿悓鍚嶅瓧鐨勮仈绯讳汉 浜哄憳绠$悊缂栫爜 ['+cManageCode+' ] 鎵嬫満鍙蜂负绌哄凡缁忓瓨鍦紝涓嶈兘閲嶅鍒涘缓锛岃浜嗚В'); + // } + // if (oldMap.get(contactnew.Id).CManageCode__c != contactnew.CManageCode__c){ + // contactnew.LastName.addError('瀹㈡埛 [ '+accountName+ ' ],宸插瓨鍦ㄧ浉鍚屽悕瀛楃殑鑱旂郴浜� 浜哄憳绠$悊缂栫爜 ['+cManageCode+' ] 锛屼笉鑳介噸澶嶅垱寤猴紝璇蜂簡瑙�'); + // } + // } + // 瀹㈡埛浜哄憳鍒犻櫎鎵嬫満鍙锋椂,杩涜鍒ゆ柇鏄惁瀛樺湪鍚屽悕涓旀墜鏈哄彿涓虹┖鐨勫鎴蜂汉鍛� thh 20220523 end + } } - - } + } } } public static Map<Id,Id> NFM606_IdMap = new Map<Id,Id>(); -- Gitblit v1.9.1