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/NewAndEditAddressController.cls | 108 +++++++++++++++++++++++++++++++++-------------------- 1 files changed, 67 insertions(+), 41 deletions(-) diff --git a/force-app/main/default/classes/NewAndEditAddressController.cls b/force-app/main/default/classes/NewAndEditAddressController.cls index f259e3d..7311d8f 100644 --- a/force-app/main/default/classes/NewAndEditAddressController.cls +++ b/force-app/main/default/classes/NewAndEditAddressController.cls @@ -1,13 +1,13 @@ /* - * Author: Bubba Li + * Author: Yanan Chen * Created Date: 02/08/2022 * Purpose: Utility class for describe layouts * Test Class: NewAndEditAddressController * History: - * 02/08/2022 - Bubba Li - Initial Code. + * 02/08/2022 - Yanan Chen - Initial Code. * * */ -public without sharing class NewAndEditAddressController { +global without sharing class NewAndEditAddressController { public List <LayoutDescriberHelper.LayoutSection > layoutSections{set;get;} public String awsToken{set;get;} public static Map<String, Schema.SObjectType> schemaMap = Schema.getGlobalDescribe(); @@ -15,50 +15,75 @@ 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 NewAndEditAddressController(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('Address__c').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 = '0121m000000kiMxAAI';//For testing - layoutSections = LayoutDescriberHelper.describeSectionWithFields(rtTypeId, 'Address__c','classic'); + SObject obj = controller.getRecord(); if(obj.Id != null){ + //鏇存柊 isNewMode = false; - Address__c addressData = [select Id, RecordTypeId, AWS_Data_Id__c from Address__c where id =: obj.Id]; + Address__c addressData = [select Id, RecordTypeId, AWS_Data_Id__c, Contacts__r.Id, Contacts__r.AWS_Data_Id__c from Address__c where id =: obj.Id]; rtTypeId = addressData.RecordTypeId; AWSDataId = addressData.AWS_Data_Id__c; + Map<String,String> sfIdToAWSIdMap = new Map<String,String>(); + // if(addressData.Contacts__r.Id != null){ + // sfIdToAWSIdMap.put(String.valueof(addressData.Contacts__r.Id).subString(0,15),addressData.Contacts__r.AWS_Data_Id__c); + // } + sfIdToAWSIdMap.put(String.valueof(addressData.Contacts__r.Id).subString(0,15),addressData.Contacts__r.AWS_Data_Id__c); + contactsInfo = JSON.serialize(sfIdToAWSIdMap); + }else{ + //鏂板缓 + rtTypeId = ApexPages.currentPage().getParameters().get('RecordType'); } - List<String> fieldApiList = new List<String>(); - for (LayoutDescriberHelper.LayoutSection ls : layoutSections) { - for (LayoutDescriberHelper.LayoutField lf : ls.layoutFields) { - if (lf.fieldAPI != '') { - fieldApiList.add(lf.fieldAPI); - } - } - } - fieldApiListStr = JSON.serialize(fieldApiList); - awsToken = AWSServiceTool.getAWSToken(); + LayoutDescriberHelper.LayoutWrapper LayoutWrapperValue = LayoutDescriberHelper.describeSectionWithFieldsWrapper(rtTypeId, 'Address__c','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('Address__c'); + 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 saveAddress(String addressJson,String transId,Boolean isNew) { + global static Response saveAddress(String addressJson,String transId,Boolean isNew) { System.debug('Address Info:' + JSON.serialize(addressJson)); //1. Prepare the payload for Address Schema.SObjectType addressSchema = schemaMap.get(sobjectTypeValue); Map<String, Schema.SObjectField> fieldAPIToTypeMap = addressSchema.getDescribe().fields.getMap(); Map<String,Object> fieldValueMap = (Map<String,Object>)JSON.deserializeUntyped(addressJson); Address__c addressInfo = new Address__c(); + //鑷畾涔夋牸寮忚浆鎹� 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)){ @@ -75,44 +100,45 @@ }else if(String.valueOf(fielddataType)=='Number'||String.valueOf(fielddataType)=='DOUBLE' ){ addressInfo.put(fieldAPI, Decimal.valueOf(String.valueOf(fieldValueMap.get(fieldAPI)))); } else if(String.valueof(fielddataType)=='BOOLEAN'){ - addressInfo.put(fieldAPI, Boolean.valueOf(fieldValueMap.get(fieldAPI))); + addressInfo.put(fieldAPI, fieldValueMap.get(fieldAPI)); }else { addressInfo.put(fieldAPI, String.valueOf(fieldValueMap.get(fieldAPI))); } } - + //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('addressInfoNancy = ' + addressInfo); insert addressInfo; }else{ - //Id addressIdValue = [select id from Address where AWS_Data_Id__c =:awsId]; - addressInfo.put('Id','a4R1m000000KGxSEAW');//For testing; + System.debug('into update'); + String awsDataId = (String)addressInfo.get('AWS_Data_Id__c'); + System.debug('awsDataId = ' + awsDataId); + Address__c[] addresses = [select id from Address__c where AWS_Data_Id__c =:awsDataId]; + System.debug('addresses[0].id = ' + addresses[0].id); + addressInfo.put('Id',addresses[0].id);//For testing; update addressInfo; } - // //saveTransLog(transId, addressInfo.AWS_Data_Id__c, status, ''); - // Transaction_Log__c traLog = new Transaction_Log__c(); - // // AWS_Data_Id__c=AWSDataId,TransId__c=transId,JsonContent__c=addressJson,Status__c=status - // traLog.AWS_Data_Id__c = AWSDataId; - // traLog.TransId__c = transId; - // traLog.JsonContent__c = addressJson; - // traLog.Status__c = status; - // insert traLog; + rid=addressInfo.Id; + PIHelper.saveTransLog(sobjectTypeValue,(String)addressInfo.get('AWS_Data_Id__c'),rid,transId,addressJson ,status,''); resp.recordId = addressInfo.Id; - // resp.message = 'success saveAddress'; + 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, addressInfo.AWS_Data_Id__c, status, ''); - // system.System.debug(e.getMessage() + '-' + e.getStackTraceString() + '-' + e.getLineNumber()); - // resp.message = e.getMessage(); - // resp.recordId = 'fail saveAddress'; + status = 'fail'; + PIHelper.saveTransLog(sobjectTypeValue,(String)addressInfo.get('AWS_Data_Id__c'),rid,transId,addressJson,status,e.getMessage()); + resp.message = e.getMessage(); resp.status = status; return resp; } -- Gitblit v1.9.1