From 02ddc35714cbd1688b7cb057f770f1410de79dab Mon Sep 17 00:00:00 2001 From: buli <137736985@qq.com> Date: 星期五, 11 三月 2022 12:19:33 +0800 Subject: [PATCH] PIPL Updated Code 20220311 --- force-app/main/default/classes/NewAndEditLeadController.cls | 123 ++++++++++++++++++++++++---------------- 1 files changed, 74 insertions(+), 49 deletions(-) diff --git a/force-app/main/default/classes/NewAndEditLeadController.cls b/force-app/main/default/classes/NewAndEditLeadController.cls index d7c8bf0..1ce6a1e 100644 --- a/force-app/main/default/classes/NewAndEditLeadController.cls +++ b/force-app/main/default/classes/NewAndEditLeadController.cls @@ -7,7 +7,7 @@ * 01/19/2022 - Bubba Li - Initial Code. * * */ -public without sharing class NewAndEditLeadController { +global without sharing class NewAndEditLeadController { public List <LayoutDescriberHelper.LayoutSection > layoutSections{set;get;} public String awsToken{set;get;} public static Map<String, Schema.SObjectType> schemaMap = Schema.getGlobalDescribe(); @@ -15,69 +15,93 @@ public Boolean isNewMode{set;get;} public String rtTypeId {get; set;} public String AWSDataId{set;get;} - //fieldLabel fieldAPI - public String fieldApiListStr {get; set;} + public String contactId{set;get;}//For Lookup field + public List<String> encryptedAPIList{set;get;} + public String staticResource {get; set;} + public String staticResourceContact {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 NewAndEditLeadController(ApexPages.StandardController controller) { 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<String> fieldList = new List<String>(Schema.getGlobalDescribe().get('Lead').getDescribe().fields.getMap().keyset()); // Add fields to controller. This is to avoid the SOQL error in visualforce page - controller.addFields(fieldList); - SObject obj = controller.getRecord(); - //rtTypeId = ApexPages.currentPage().getParameters().get('RecordType'); - rtTypeId = '01210000000QiRa';//For testing - layoutSections = LayoutDescriberHelper.describeSectionWithFields(rtTypeId, 'Lead','classic'); + controller.addFields(fieldList); + SObject obj = controller.getRecord(); if(obj.Id != null){ + //鏇存柊 isNewMode = false; - Lead leadData = [select Id,RecordTypeId,AWS_Data_Id__c from Lead where id =: obj.Id]; + 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; - } - List<String> fieldApiList = new List<String>(); - for (LayoutDescriberHelper.LayoutSection ls : layoutSections) { - for (LayoutDescriberHelper.LayoutField lf : ls.layoutFields) { - if (lf.fieldAPI != '') { - fieldApiList.add(lf.fieldAPI); - } + Map<String,String> sfIdToAWSIdMap = new Map<String,String>(); + 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{ + //鏂板缓 + rtTypeId = ApexPages.currentPage().getParameters().get('RecordType'); + obj.put('OwnerId',UserInfo.getUserId()); } - fieldApiListStr = JSON.serialize(fieldApiList); - //awsToken = AWSServiceTool.getAWSToken(); + LayoutDescriberHelper.LayoutWrapper LayoutWrapperValue = LayoutDescriberHelper.describeSectionWithFieldsWrapper(rtTypeId, 'Lead','classic'); + layoutSections = LayoutWrapperValue.layoutSections; + List<String> requiredFieldAPIList = LayoutWrapperValue.requiredFieldAPIList; + Map<String,String> 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')); + encryptedAPIList = piIntegration.PIFields; + sobjectPrefix = piIntegration.sobjectPrefix; } - public class Response{ + global class Response{ public String recordId{set;get;} public String message{set;get;} public String status{set;get;} } @RemoteAction - public static Response saveLead(String leadJson,String transId,Boolean isNew) { + 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<String, Schema.SObjectField> fieldAPIToTypeMap = leadSchema.getDescribe().fields.getMap(); Map<String,Object> fieldValueMap = (Map<String,Object>)JSON.deserializeUntyped(leadJson); Lead leadInfo = new Lead(); + //鑷畾涔夋牸寮忚浆鎹� for (String fieldAPI: fieldValueMap.keySet()) { + system.debug('field API='+fieldAPI); Schema.DisplayType fielddataType = fieldAPIToTypeMap.get(fieldAPI).getDescribe().getType(); String fieldValue = String.valueOf(fieldValueMap.get(fieldAPI)); - if(String.isBlank(fieldValue)){ - continue; - } + system.debug('Field Type:'+fielddataType+' field Value='+fieldValue); if(String.valueOf(fielddataType)=='DATE'){ - leadInfo.put(fieldAPI, Date.valueOf(String.valueOf(fieldValueMap.get(fieldAPI)).replace('/', '-'))); + leadInfo.put(fieldAPI,(String.isBlank(fieldValue)||String.isEmpty(fieldValue))? null:Date.valueOf(fieldValue.replace('/', '-'))); }else if(String.valueOf(fielddataType)=='DATETIME'){ - String dt = String.valueOf(fieldValueMap.get(fieldAPI)); - if(String.isNotBlank(dt)&&dt.contains('T')){ - dt = dt.replace('T',' '); - leadInfo.put(fieldAPI, Datetime.valueOfGmt(dt)); - } - }else if(String.valueOf(fielddataType)=='Number'||String.valueOf(fielddataType)=='DOUBLE' ){ - leadInfo.put(fieldAPI, Decimal.valueOf(String.valueOf(fieldValueMap.get(fieldAPI)))); + 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))?0:Decimal.valueOf(fieldValue)); } else if(String.valueof(fielddataType)=='BOOLEAN'){ - leadInfo.put(fieldAPI, Boolean.valueOf(fieldValueMap.get(fieldAPI))); + leadInfo.put(fieldAPI, fieldValueMap.get(fieldAPI)); }else { - leadInfo.put(fieldAPI, String.valueOf(fieldValueMap.get(fieldAPI))); + leadInfo.put(fieldAPI,fieldValue); } } @@ -85,34 +109,35 @@ 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{ - //Id leadIdValue = [select id from Lead where AWS_Data_Id__c =:awsId]; - leadInfo.put('Id','00Q1m000001lVY8');//For testing; + 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; } - // //saveTransLog(transId, leadInfo.AWS_Data_Id__c, status, ''); - // Transaction_Log__c traLog = new Transaction_Log__c(); - // // AWS_Data_Id__c=AWSDataId,TransId__c=transId,JsonContent__c=leadJson,Status__c=status - // traLog.AWS_Data_Id__c = AWSDataId; - // traLog.TransId__c = transId; - // traLog.JsonContent__c = leadJson; - // traLog.Status__c = status; - // insert traLog; + rid=leadInfo.Id; + PIHelper.saveTransLog(sobjectTypeValue,(String)leadInfo.get('AWS_Data_Id__c'),rid,transId,leadJson ,status,''); resp.recordId = leadInfo.Id; - // resp.message = 'success saveLead'; + 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'; - // //saveTransLog(transId, leadInfo.AWS_Data_Id__c, status, ''); - // system.System.debug(e.getMessage() + '-' + e.getStackTraceString() + '-' + e.getLineNumber()); - // resp.message = e.getMessage(); - // resp.recordId = 'fail saveLead'; + 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; } -- Gitblit v1.9.1