/**
|
* Select Id From Contact Where RecordTypeId = '01210000000QfWdAAK' and Strategic_dept_Class__c != null
|
*/
|
public without sharing class ContactTriggerHandler extends Oly_TriggerHandler {
|
private Map < Id, Contact > newMap;
|
private Map < Id, Contact > oldMap;
|
private List < Contact > newList;
|
private List < Contact > oldList;
|
public ContactTriggerHandler() {
|
this.newMap = (Map < Id, Contact > ) Trigger.newMap;
|
this.oldMap = (Map < Id, Contact > ) Trigger.oldMap;
|
this.newList = (List < Contact > ) Trigger.new;
|
this.oldList = (List < Contact > ) Trigger.old;
|
}
|
protected override void beforeInsert() {
|
mobileNumberVerification();
|
}
|
|
protected override void afterInsert() {
|
syncToAgencyContact();
|
updateDealerNum();
|
sendToComPlat();
|
}
|
|
protected override void afterUpdate() {
|
syncToAgencyContact();
|
updateDealerNum();
|
sendToComPlat();
|
|
}
|
protected override void beforeUpdate() {
|
// 服务技师 2018/12/24 Start
|
UpdateProcessingWork();
|
// 服务技师 2018/12/24 end
|
mobileNumberVerification();
|
}
|
|
|
protected override void afterDelete() {
|
syncToAgencyContactDelete();
|
updateDealerNum();
|
}
|
|
//
|
/**
|
* @author 张玉山
|
* @DateTime 2019-03-11T13:49:10+0800
|
* 根据服务技师填写情况更新客户人员上的开展工作字段
|
*/
|
private void UpdateProcessingWork() {
|
for (Contact temContact: newList) {
|
if (System.label.UpdateServiceHistory.equals('true')) {
|
|
string ProcessingWork = '';
|
string ProcessingWorkWithoutNumber = '';
|
if (temContact.ServiceBookInput__c != 0) {
|
ProcessingWork += '维修委托书填写' + temContact.ServiceBookInput__c + '次';
|
ProcessingWorkWithoutNumber += '维修委托书填写';
|
|
}
|
if (temContact.InspectTime__c != 0) {
|
if (String.isBlank(ProcessingWork)) {
|
ProcessingWork += '点检' + temContact.InspectTime__c + '次';
|
ProcessingWorkWithoutNumber += '点检';
|
} else {
|
ProcessingWork += ',点检' + temContact.InspectTime__c + '次';
|
ProcessingWorkWithoutNumber += ',点检';
|
|
}
|
}
|
if (temContact.InspectEquipmentTime__c != 0) {
|
if (String.isBlank(ProcessingWork)) {
|
ProcessingWork += '点检设备' + temContact.InspectEquipmentTime__c + '个';
|
ProcessingWorkWithoutNumber += '点检设备';
|
} else {
|
ProcessingWork += ',点检设备' + temContact.InspectEquipmentTime__c + '个';
|
ProcessingWorkWithoutNumber += ',点检设备';
|
}
|
|
}
|
if (temContact.VisitTime__c != 0) {
|
if (String.isBlank(ProcessingWork)) {
|
ProcessingWork += '上门' + temContact.VisitTime__c + '次';
|
ProcessingWorkWithoutNumber += '上门';
|
} else {
|
ProcessingWork += ',上门' + temContact.VisitTime__c + '次';
|
ProcessingWorkWithoutNumber += ',上门';
|
}
|
|
}
|
if (temContact.pollingTime__c != 0) {
|
if (String.isBlank(ProcessingWork)) {
|
ProcessingWork += '巡检' + temContact.pollingTime__c + '次';
|
ProcessingWorkWithoutNumber += '巡检';
|
} else {
|
ProcessingWork += ',巡检' + temContact.pollingTime__c + '次';
|
ProcessingWorkWithoutNumber += ',巡检';
|
}
|
|
}
|
if (temContact.TeachingTime__c != 0) {
|
if (String.isBlank(ProcessingWork)) {
|
ProcessingWork += '培训次数' + temContact.TeachingTime__c + '次';
|
ProcessingWorkWithoutNumber += '培训次数';
|
} else {
|
ProcessingWork += ',培训次数' + temContact.TeachingTime__c + '次';
|
ProcessingWorkWithoutNumber += ',培训次数';
|
}
|
}
|
//if (!String.isBlank(ProcessingWork)) {
|
// ProcessingWork += '。';
|
// ProcessingWorkWithoutNumber += '。';
|
//}
|
temContact.ProcessingWork__c = ProcessingWork;
|
temContact.ProcessingWorkWithoutNumber__c = ProcessingWorkWithoutNumber;
|
|
|
}
|
}
|
|
}
|
// 服务技师 2018/12/24 end
|
private void syncToAgencyContact() {
|
Map < Id, Agency_Contact__c > targetContactMap = new Map < Id, Agency_Contact__c > ();
|
for (Contact nObj: newList) {
|
if (nObj.RecordTypeId == '01210000000QfWdAAK' // Doctor
|
&&
|
String.isBlank(nObj.Strategic_dept_Class__c) == false
|
) {
|
if (Trigger.isInsert ||
|
(Trigger.isUpdate
|
// && (
|
// oldMap.get(nObj.Id).LastName != nObj.LastName
|
// || oldMap.get(nObj.Id).FirstName != nObj.FirstName
|
// || oldMap.get(nObj.Id).Strategic_dept_Class__c != nObj.Strategic_dept_Class__c
|
// || oldMap.get(nObj.Id).Type__c != nObj.Type__c
|
// || oldMap.get(nObj.Id).Doctor_Division1__c != nObj.Doctor_Division1__c
|
// )
|
)
|
) {
|
Agency_Contact__c acObj = new Agency_Contact__c(Agency_ID__c = '000000000000000', Contact__c = nObj.Id, ContactId18__c = nObj.Id, Agency_Hospital__c = null, Name = nObj.LastName + ((String.isBlank(nObj.FirstName) == false) ? ' ' + nObj.FirstName : ''), Department_Class__c = nObj.Strategic_dept_Class__c, Type__c = nObj.Type__c, Doctor_Division1__c = nObj.Doctor_Division1__c);
|
targetContactMap.put(nObj.Id, acObj);
|
}
|
}
|
}
|
if (targetContactMap.size() > 0) {
|
upsert targetContactMap.values() ContactId18__c;
|
}
|
}
|
|
private void syncToAgencyContactDelete() {
|
List < Id > cIdList = new List < Id > ();
|
for (Contact oObj: oldList) {
|
cIdList.add(oObj.Id);
|
}
|
if (cIdList.size() > 0) {
|
List < Agency_Contact__c > acList = [Select Id From Agency_Contact__c
|
Where Contact__c =: null and Agency_ID__c = '000000000000000'
|
];
|
if (acList.size() > 0) {
|
delete acList;
|
}
|
}
|
}
|
|
//更新经销商用户人数字段 精琢技术 pk 2021-08-26 start
|
private void updateDealerNum() {
|
Set < Id > accountSet = new Set < Id > ();
|
Map < Id, Account > acMap = new Map < Id, Account > ();
|
if (Trigger.isUpdate) {
|
for (Contact contactnew: newList) {
|
if (contactnew.Agency_User__c != oldMap.get(contactnew.Id).Agency_User__c || (System.Label.onlyUpdate == '1' && UserInfo.getUserId() == '00510000005sEEMAA2')) {
|
accountSet.add(contactnew.AccountId);
|
}
|
}
|
}
|
|
if (Trigger.isInsert) {
|
for (Contact contactnew: newList) {
|
if (contactnew.Agency_User__c) {
|
accountSet.add(contactnew.AccountId);
|
}
|
}
|
}
|
|
|
if (Trigger.isDelete) {
|
for (Contact contactold: oldList) {
|
if (contactold.Agency_User__c) {
|
accountSet.add(contactold.AccountId);
|
}
|
}
|
}
|
|
if (accountSet.size() > 0) {
|
List < AggregateResult > contactList = [select count(id) ctn, AccountId accid from Contact where Agency_User__c = true and AccountId =: accountSet and RecordTypeId = '01210000000QfWi'
|
group by AccountId
|
];
|
for (AggregateResult ar: contactList) {
|
String accid = (String) ar.get('accid');
|
Account account = new Account();
|
account.id = accid;
|
account.Dealer_Num__c = (Integer) ar.get('ctn');
|
acMap.put(accid, account);
|
}
|
|
for (Id accountId: accountSet) {
|
if (!acMap.containsKey(accountId)) {
|
Account account = new Account();
|
account.id = accountId;
|
account.Dealer_Num__c = 0;
|
acMap.put(accountId, account);
|
}
|
}
|
|
if (acMap.size() > 0) {
|
update acMap.values();
|
}
|
}
|
|
|
}
|
//更新经销商用户人数字段 精琢技术 pk 2021-08-26 end
|
|
// 手机号去重及规则验证 及新增客户人员重名验证
|
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}$');
|
Map<String, Map<String,Contact>> accountContactMap = new Map<String, Map<String,Contact>>();
|
Set<Id> accountIdSet = new Set<Id>();
|
//用户对象上找对应的联系人
|
List<User> userList=[select ID,ContactID from User where ContactID != null];
|
Map<String,User> userMap= new Map<String,User>();
|
if (userList.size()>0){
|
for(User us1: userList){
|
userMap.put(us1.ContactId, us1);
|
}
|
}
|
//查找联系人对象上对应的有效客户;医院直接使用有效/无效字段、经销商使用有效/无效公式字段
|
List<String> accIdList = new List<String>();
|
Map<String,String> accMap= new Map<String,String>();
|
for (Contact contact1: newList) {
|
accIdList.add(contact1.AccountId);
|
}
|
if (accIdList.size()>0){
|
List<Account> accList=[select ID,Is_Active__c,Is_Active_Formula__c from Account where ID in:accIdList];
|
if(accList.size()>0){
|
for(Account acc:accList){
|
if (String.isNotBlank(acc.Is_Active__c)){
|
accMap.put(acc.Id, acc.Is_Active__c);
|
continue;
|
}
|
if (String.isNotBlank(acc.Is_Active_Formula__c)){
|
accMap.put(acc.Id, acc.Is_Active_Formula__c);
|
}
|
}
|
}
|
}
|
for (Contact contactnew: newList) {
|
// 手机号 有值 并且 联系人有效 联系人的客户有效 无外部关联用户 进行手机号码验证
|
if (String.isNotBlank(contactnew.MobilePhone) && ('有效'.equals(contactnew.Isactive__c) ||'有効'.equals(contactnew.Isactive__c))
|
&& '有効'.equals(accMap.get(contactnew.AccountId))
|
&& !userMap.containsKey(contactnew.Id)
|
) {
|
Matcher isMobilePhone = pattern.matcher(contactnew.MobilePhone);
|
if (isMobilePhone.matches()) {
|
// 将手机号 赋值给 手机号唯一字段
|
contactnew.UniqueNumber__c = contactnew.MobilePhone;
|
} else {
|
// 手机号唯一字段清空
|
contactnew.UniqueNumber__c = null;
|
}
|
} else {
|
// 手机号 无值 或者 联系人不是有效 手机号唯一字段清空
|
contactnew.UniqueNumber__c = null;
|
}
|
|
|
|
if (Trigger.isInsert) {
|
accountIdSet.add(contactnew.AccountId);
|
|
}
|
}
|
// 新增联系人时,
|
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) {
|
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
|
String accountId = String.valueOf(contact.AccountId).SubString(0,15);
|
Map<String,Contact> contactFullNameMap = new Map<String,Contact>();
|
if (accountContactMap.containsKey(accountId)) {
|
contactFullNameMap = accountContactMap.get(accountId);
|
}
|
contactFullNameMap.put(contactFullName, contact);
|
accountContactMap.put(accountId, contactFullNameMap);
|
}
|
}
|
}
|
|
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)) {
|
contactnew.LastName.addError('客户 [ '+accountName+ ' ],已存在相同名字的联系人 人员管理编码 ['+cManageCode+' ] ,不能重复创建,请了解');
|
}
|
|
}
|
}
|
|
}
|
}
|
|
|
}
|
|
|
public static Map<Id,Id> NFM606_IdMap = new Map<Id,Id>();
|
private void sendToComPlat() {
|
List<Id> contactIdList = new List<Id>();
|
List<String> interfaceUserUpsertContact = new List<String>();
|
for (Contact local: newList) {
|
|
Contact old = null;
|
if (Trigger.isUpdate) {
|
old = oldMap.get(local.Id);
|
}
|
if (Trigger.isInsert
|
|| old.LastName != local.LastName
|
|| old.FirstName != local.FirstName
|
|| old.Email != local.Email //メール Email
|
|| old.MobilePhone != local.MobilePhone //手机号码 Mobile_Phone__c
|
|| old.Employee_No_manual__c != local.Employee_No_manual__c //员工号码 Employee_No__c
|
|| old.Work_Location_manual__c != local.Work_Location_manual__c //工作地 Work_Location__c
|
|| old.Post_picklist__c != local.Post_picklist__c //职位 post__c
|
|| old.Job_Category_picklist__c != local.Job_Category_picklist__c //职种 Job_Category__c
|
|| old.Hire_date_text__c != local.Hire_date_text__c //入职日 Hire_date__c
|
|| old.Gender_text__c != local.Gender_text__c //性别 Gender__c
|
|| old.dept__c != local.dept__c //本部 dept__c
|
|| old.Pregnant_Rest__c != local.Pregnant_Rest__c // 是否产假 Pregnant_Rest__c
|
|| old.Stay_or_not__c != local.Stay_or_not__c // 在职/离职 Stay_or_not__c
|
//|| old.Salesdepartment_Text__c != local.Salesdepartment_Text__c // 销售本部 Salesdepartment__c
|
|| old.AccountId != local.AccountId//客户人员换客户
|
|| old.Isactive__c != local.Isactive__c//状态变更
|
|| old.ServicePlatformCode__c != local.ServicePlatformCode__c//服务平台编码
|
|| old.UnifiedI_Contact_ID__c != local.UnifiedI_Contact_ID__c//智慧医疗编码
|
|| old.ContactType__c != local.ContactType__c//人员类型
|
|
) {
|
if (!local.IsFromSPO__c && !'01210000000QtkyAAC'.equals(local.RecordTypeId)) {
|
|
// 医院 客户人员 统一平台编码有值 发送 PO
|
if ('01210000000QfWdAAK'.equals(local.RecordTypeId) && String.isNotBlank(local.UnifiedI_Contact_ID__c)) {
|
if (!NFM606_IdMap.containsKey(local.Id)) {
|
if(UserInfo.getUserId().equals(System.Label.interfaceUserID)){
|
interfaceUserUpsertContact.add(local.Id);
|
} else {
|
contactIdList.add(local.Id);
|
}
|
NFM606_IdMap.put(local.Id, local.Id);
|
}
|
}
|
// 经销商 客户人员 手机号码有值 发送 PO
|
if ('01210000000QfWiAAK'.equals(local.RecordTypeId) && String.isNotBlank(local.MobilePhone)) {
|
if (!NFM606_IdMap.containsKey(local.Id)) {
|
if(UserInfo.getUserId().equals(System.Label.interfaceUserID)){
|
interfaceUserUpsertContact.add(local.Id);
|
} else {
|
contactIdList.add(local.Id);
|
}
|
NFM606_IdMap.put(local.Id, local.Id);
|
}
|
}
|
}
|
|
}
|
}
|
|
if(!System.Test.isRunningTest()){
|
// NFM606Controller.executeNotFuture('', contactIdList);
|
if (contactIdList.size() > 0) {
|
NFM606Controller.callout('', contactIdList);
|
}
|
if (interfaceUserUpsertContact.size() > 0) {
|
NFM606Controller.executeNotFuture('', interfaceUserUpsertContact);
|
}
|
}
|
|
}
|
|
}
|