/* * Author: Bubba Li * Created Date: 01/19/2022 * Purpose: Utility class for describe layouts * Test Class: NewAndEditLeadController * History: * 01/19/2022 - Bubba Li - Initial Code. * * */ global without sharing class NewAndEditLeadController { public List layoutSections{set;get;} public String awsToken{set;get;} public static Map schemaMap = Schema.getGlobalDescribe(); public static String sobjectTypeValue = 'Lead'; public Boolean isNewMode{set;get;} public String rtTypeId {get; set;} public String AWSDataId{set;get;} public String AWSDataIdInquiryForm{set;get;} public String contactId{set;get;}//For Lookup field public List encryptedAPIList{set;get;} public String staticResource {get; set;} public String staticResourceContact {get; set;} public String staticResourceInquiryForm{get; set;} public String requiredFieldAPIListStr {get; set;} public String fieldAPIToLabelMapStr {get; set;} public String Input_Required_Field_Msg{set;get;} public String PIPL_Name_Label{set;get;} public String PIPL_Input_Account_Error_Msg{set;get;} public String sobjectPrefix{set;get;} public String sobjecttypeForFrontEnd{set;get;} public String contactsInfo {set;get;}//key sfid;value awsid public Inquiry_form__c ifc{get; private set;} public String contactDataId{get; set;} public String layoutSectionsStr {get; set;} public String isDecryptContact {get; set;} public NewAndEditLeadController(ApexPages.StandardController controller) { isDecryptContact = '0'; isNewMode = true; Input_Required_Field_Msg = Label.Input_Required_Field_Msg; PIPL_Name_Label = Label.PIPL_Name_Label; PIPL_Input_Account_Error_Msg = label.PIPL_Input_Account_Error_Msg; sobjecttypeForFrontEnd = sobjectTypeValue; //获取所有字段 List fieldList = new List(Schema.getGlobalDescribe().get('Lead').getDescribe().fields.getMap().keyset()); // Add fields to controller. This is to avoid the SOQL error in visualforce page if (!Test.isRunningTest()) { controller.addFields(fieldList); } SObject obj = controller.getRecord(); if(ApexPages.currentPage().getParameters().get('CF00N1000000962np_lkid') != null){ System.debug('CF00N1000000962np_lkid'); //产品咨询单过来的 String InquiryFormId = ApexPages.currentPage().getParameters().get('CF00N1000000962np_lkid'); ifc = [select Id,AWS_Data_Id__c,Contact_Name__c,Contact_Id__c,Hospital_Name__c,Hospital_ID__c,Department_Class__c, Department_ID__c,Opp_Name_Search__c,Opp_Name_Search_ID__c,Campaign__c, Campaign_ID__c,Name,Cancel_Reason__c,Phone__c,Email__c,Last_Name__c,LeadSource__c,Opportunity_Division__c,Request1__c, Urgent__c from Inquiry_form__c where id = :InquiryFormId]; System.debug('ifc = ' + ifc); if(ifc.Contact_Id__c !=null && ifc.Contact_Id__c != ''){ Contact c = [select AWS_Data_Id__c from Contact where id = :ifc.Contact_Id__c]; contactDataId = c.AWS_Data_Id__c; } AWSDataIdInquiryForm = ifc.AWS_Data_Id__c; System.debug('ifc = ' + ifc); rtTypeId = ApexPages.currentPage().getParameters().get('RecordType'); obj.put('OwnerId',UserInfo.getUserId()); }else if(obj.Id != null){ //更新 isNewMode = false; Lead leadData = [select Id,RecordTypeId,AWS_Data_Id__c,Contact_Name__r.Id,Contact_Name__r.AWS_Data_Id__c from Lead where id =: obj.Id]; rtTypeId = leadData.RecordTypeId; AWSDataId = leadData.AWS_Data_Id__c; Map sfIdToAWSIdMap = new Map(); if(leadData.Contact_Name__r.Id != null){ sfIdToAWSIdMap.put(String.valueof(leadData.Contact_Name__r.Id).subString(0,15),leadData.Contact_Name__r.AWS_Data_Id__c); } contactsInfo = JSON.serialize(sfIdToAWSIdMap); }else{ //看链接中有无带过来的参数(客户人员) Map mso = ApexPages.currentPage().getParameters(); for(String key : mso.keySet()){ System.debug('key=' + key + ',value=' + mso.get(key)); } //联系人 if(mso.containsKey('CF00N10000006ps6f_lkid')){ isDecryptContact = '1'; String contactId = mso.get('CF00N10000006ps6f_lkid'); //查询AWS_Data_Id__c Contact c = [select AWS_Data_Id__c from Contact where id=:contactId]; if (c != null) { contactDataId = c.AWS_Data_Id__c; } //查询战略科室分类 List cs = [select Account.Department_Class__c from Contact where id=:contactId]; if(cs.size()>0){ controller.getRecord().put('Department_Class__c',cs[0].Account.Department_Class__c); } controller.getRecord().put('Contact_Name__c',mso.get('CF00N10000006ps6f_lkid')); } //医院名 if(mso.containsKey('CF00N10000002CvC5_lkid')){ controller.getRecord().put('Hospital_Name__c',mso.get('CF00N10000002CvC5_lkid')); //通过医院id查询战略科室分类 String hospitalId = mso.get('CF00N10000002CvC5_lkid'); List hospitalAccount = [select Department_Class__c from Account where Id=:hospitalId]; if(hospitalAccount.size()>0){ List departmentAccount = [select Id from Account where Id=:hospitalAccount[0].Department_Class__c]; if (departmentAccount.size()>0) { System.debug('Department_Class__c = ' + departmentAccount[0].Id); controller.getRecord().put('Department_Class__c',departmentAccount[0].Id); } } } //公司(科室) if(mso.containsKey('CF00N10000002CvC5')){ controller.getRecord().put('Company',mso.get('CF00N10000002CvC5')); } //战略科室CF00N10000006qNtt_lkid // if(mso.containsKey('CF00N10000006qNtt_lkid ')){ // controller.getRecord().put('Department_Class__c',mso.get('CF00N10000006qNtt_lkid ')); // } rtTypeId = ApexPages.currentPage().getParameters().get('RecordType'); obj.put('OwnerId',UserInfo.getUserId()); } LayoutDescriberHelper.LayoutWrapper LayoutWrapperValue = LayoutDescriberHelper.describeSectionWithFieldsWrapper(rtTypeId, 'Lead','classic'); layoutSections = LayoutWrapperValue.layoutSections; List requiredFieldAPIList = LayoutWrapperValue.requiredFieldAPIList; Map fieldAPIToLabelMap = LayoutWrapperValue.fieldAPIToLabelMap; requiredFieldAPIListStr = JSON.serialize(requiredFieldAPIList); fieldAPIToLabelMapStr = JSON.serialize(fieldAPIToLabelMap); PIHelper.PIIntegration piIntegration = PIHelper.getPIIntegrationInfo('Lead'); staticResource = JSON.serialize(piIntegration); staticResourceContact = JSON.serialize(PIHelper.getPIIntegrationInfo('Contact')); staticResourceInquiryForm = JSON.serialize(PIHelper.getPIIntegrationInfo('Inquiry_form__c')); encryptedAPIList = piIntegration.PIFields; sobjectPrefix = piIntegration.sobjectPrefix; layoutSectionsStr = JSON.serialize(layoutSections); } global class Response{ public String recordId{set;get;} public String message{set;get;} public String status{set;get;} } @RemoteAction global static Response saveLead(String leadJson,String transId,Boolean isNew) { System.debug('Lead Info:' + JSON.serialize(leadJson)); //1. Prepare the payload for Lead Schema.SObjectType leadSchema = schemaMap.get(sobjectTypeValue); Map fieldAPIToTypeMap = leadSchema.getDescribe().fields.getMap(); Map fieldValueMap = (Map)JSON.deserializeUntyped(leadJson); Lead leadInfo = new Lead(); //自定义格式转换 for (String fieldAPI: fieldValueMap.keySet()) { system.debug('field API='+fieldAPI); if(!fieldAPIToTypeMap.containskey(fieldAPI)){ continue; } Schema.DisplayType fielddataType = fieldAPIToTypeMap.get(fieldAPI).getDescribe().getType(); String fieldValue = String.valueOf(fieldValueMap.get(fieldAPI)); system.debug('Field Type:'+fielddataType+' field Value='+fieldValue); if(String.valueOf(fielddataType)=='DATE'){ leadInfo.put(fieldAPI,(String.isBlank(fieldValue)||String.isEmpty(fieldValue))? null:Date.valueOf(fieldValue.replace('/', '-'))); }else if(String.valueOf(fielddataType)=='DATETIME'){ if(String.isNotBlank(fieldValue)&&fieldValue.contains('T')){ fieldValue = fieldValue.replace('T',' '); leadInfo.put(fieldAPI, Datetime.valueOfGmt(fieldValue)); }else{ leadInfo.put(fieldAPI, null); } }else if(String.valueof(fielddataType)=='CURRENCY'|| String.valueof(fielddataType)=='PERCENT'||String.valueOf(fielddataType)=='Number'||String.valueOf(fielddataType)=='DOUBLE' ){ leadInfo.put(fieldAPI, (String.isBlank(fieldValue)||String.isEmpty(fieldValue))?null:Decimal.valueOf(fieldValue.replace(',', ''))); } else if(String.valueof(fielddataType)=='BOOLEAN'){ leadInfo.put(fieldAPI, fieldValueMap.get(fieldAPI)); }else { leadInfo.put(fieldAPI,fieldValue); } } //2. Save Record Process String status = 'success'; Response resp = new Response(); Savepoint sp = Database.setSavepoint(); String rid = ''; try{ System.debug('abcde'); if(isNew){ System.debug('leadInfozhj = ' + leadInfo); insert leadInfo; }else{ System.debug('into update'); String awsDataId = (String)leadInfo.get('AWS_Data_Id__c'); System.debug('awsDataId = ' + awsDataId); Lead[] leads = [select id from Lead where AWS_Data_Id__c =:awsDataId]; System.debug('leads[0].id = ' + leads[0].id); leadInfo.put('Id',leads[0].id);//For testing; update leadInfo; } rid=leadInfo.Id; PIHelper.saveTransLog(sobjectTypeValue,(String)leadInfo.get('AWS_Data_Id__c'),rid,transId,leadJson ,status,''); resp.recordId = leadInfo.Id; resp.message = ''; resp.status = status; System.debug('resp from sfdx back-end' + resp); return resp; } catch(Exception e) { System.debug('into catch'+e.getMessage()); Database.rollback(sp); status = 'fail'; PIHelper.saveTransLog(sobjectTypeValue,(String)leadInfo.get('AWS_Data_Id__c'),rid,transId,leadJson,status,e.getMessage()); resp.message = e.getMessage(); resp.status = status; return resp; } } @RemoteAction global static String queryAccount(String accountTypes,String accountId) { System.debug('accountType='+accountTypes); System.debug('accountId='+accountId); List types = (List)JSON.deserializeUntyped(accountTypes); System.debug('types='+types); String soql = 'select Id,Name,'; for (Object t : types) { soql += (String)t+','; } soql = soql.substring(0,soql.length()-1); soql += ' from Account where id=\''+accountId+'\''; System.debug('soql='+soql); Sobject account = Database.query(soql); Map> m = new Map>(); System.debug('account='+account); for (Object ty : types) { String t = (String)ty; if (account.get(t) != null){ Sobject acc = Database.query('select Id,Name from Account where id=\''+account.get(t)+'\''); Map n = new Map(); n.put('Id', (String)acc.get('Id')); n.put('Name', (String)acc.get('Name')); m.put(t, n); } } // if (account.get('Hospital__c') != null){ // m.put('Hospital__c', (String)account.get('Hospital__c')); // m.put('Hospital__r.Name', (String)account.get('Hospital__r.Name')); // } // if (account.get('Department_Class__c') != null){ // m.put('Department_Class__c', (String)account.get('Department_Class__c')); // m.put('Department_Class__r.Name', (String)account.get('Department_Class__r.Name')); // } System.debug('m='+m); return JSON.serialize(m); // return (String)account.get('Hospital__c'); } }