From 4cf305347ea6f6a73e03fa9427a3de80ca35ae7a Mon Sep 17 00:00:00 2001 From: buli <137736985@qq.com> Date: 星期一, 25 四月 2022 14:37:30 +0800 Subject: [PATCH] SSBGEnhancement0425 --- force-app/main/default/classes/NewAndEditBaseController.cls | 193 +++++++++++++++++++++++++++++++ force-app/main/default/pages/ViewContactDecryptInfoForApproval.page-meta.xml | 5 force-app/main/default/classes/PIHelper.cls | 14 +- force-app/main/default/classes/NewAndEditContactController.cls | 16 ++ force-app/main/default/classes/NewAndEditContactControllerTest.cls | 31 +++++ force-app/main/default/pages/ViewContactDecryptInfoForApproval.page | 75 ++++++++++++ 6 files changed, 321 insertions(+), 13 deletions(-) diff --git a/force-app/main/default/classes/NewAndEditBaseController.cls b/force-app/main/default/classes/NewAndEditBaseController.cls index 49ce172..1b59edd 100644 --- a/force-app/main/default/classes/NewAndEditBaseController.cls +++ b/force-app/main/default/classes/NewAndEditBaseController.cls @@ -109,6 +109,9 @@ }else{ rtTypeId = ApexPages.currentPage().getParameters().get('RecordType'); } + + AssignValueFromUrl(ApexPages.currentPage().getParameters(),obj); + PIHelper.PIIntegration piIntegration = PIHelper.getPIIntegrationInfo(sobjectTypeValue); //layoutEncryptedAPIList = piIntegration.PIFields; encryptedAPIList = piIntegration.PIFields; @@ -119,6 +122,7 @@ SaveAndNewButtonUrl = String.format('/setup/ui/recordtypeselect.jsp?ent={0}&retURL=/{1}/o&save_new_url=/{1}/e?retURL=%2F{1}%2Fo', new String[]{sobjectTypeValue,sobjectPrefix}); } + system.debug('piIntegration.PIDetails='+piIntegration.PIDetails); for (PI_Field_Policy_Detail__c PIDetail : piIntegration.PIDetails) { AWSToSobjectNonEncryptedMap.put(PIDetail.AWS_Field_API__c, PIDetail.SF_Field_API_Name__c); @@ -127,6 +131,7 @@ System.debug(new List<string>(AWSToSobjectNonEncryptedMap.keySet())); system.debug('AWSToSobjectNonEncryptedMapJson='); system.debug(AWSToSobjectNonEncryptedMapJson); + system.debug('AWSToSobjectEncryptedMap='+AWSToSobjectEncryptedMap); try{ LayoutDescriberHelper.LayoutWrapper LayoutWrapperValue = LayoutDescriberHelper.describeSectionWithFieldsWrapper(rtTypeId, sobjectTypeValue,'classic'); layoutSections = LayoutWrapperValue.layoutSections; @@ -158,6 +163,147 @@ layoutEncryptedAPIList = piIntegration.PIFields; system.debug('Exception from get layout service:'+e.getmessage()); } + } + + // 浠巙rl鍙傛暟璧嬪�煎埌褰撳墠椤甸潰 + public static void AssignValueFromUrl(Map<string,string> mso, sobject sobj){ + + String sobject_name = sobj.getSObjectType().getDescribe().getName(); + Map<string,object> temp = new Map<string,object>(); + Map<string,FieldDefinition> fdm = new Map<string,FieldDefinition>(); + List<FieldDefinition> fds = [SELECT Id, DurableId, QualifiedApiName,ValueTypeId , EntityDefinitionId, NamespacePrefix,EntityDefinition.NamespacePrefix, DeveloperName, MasterLabel, Label FROM FieldDefinition where EntityDefinition.QualifiedApiName = :sobject_name]; + for(FieldDefinition fd : fds){ + //system.debug(fd.DurableId); + fdm.put(fd.DurableId.split('\\.')[1],fd); + } + + for(string key : mso.keySet()){ + if (key.toLowerCase() == 'id') { + System.debug('skip id assign'); + continue; + } + string new_key = key; + system.debug('new_key='+new_key); + if(new_key.contains('_lkid')){ + new_key = new_key.replace('_lkid', ''); + new_key = new_key.substring(2); + }else{ + if(temp.containsKey(new_key)){ + continue; + } + } + + system.debug('now new_key='+new_key); + if(fdm.containsKey(new_key)){ + system.debug('fdm.get(new_key)='+fdm.get(new_key)); + string val_str = mso.get(key); + system.debug('val_str='+val_str); + /*鏃犻渶鍋歞ecode锛宻f鍐呴儴宸茬粡鍋氬ソ + try{ + val_str = EncodingUtil.urlDecode(mso.get(key),'UTF-8'); + }catch(Exception e){ + continue; + system.debug('Exception from get Key:'+e.getMessage()); + system.debug(e.getStackTraceString()); + } */ + object val = null; + string type_id = fdm.get(new_key).ValueTypeId; + // address, boolean, date, datetime, double, id, location, string, time + if(string.isBlank(val_str)){ + val = null; + }else if(type_id == 'boolean'){ + if(val_str == '1'){ + val = true; + }else{ + val = boolean.valueOf(val_str); + } + }else if(type_id == 'date'){ + // + try{ + val = date.parse(val_str); + }catch(Exception e){ + system.debug('val_str='+val_str); + system.debug(e.getMessage()); + system.debug(e.getStackTraceString()); + try{ + val = date.valueOf(val_str); + }catch(Exception ee){ + system.debug('val_str='+val_str); + system.debug(ee.getMessage()); + system.debug(ee.getStackTraceString()); + continue; + } + } + }else if(type_id == 'datetime'){ + // + try{ + val = datetime.parse(val_str); + }catch(Exception e){ + system.debug('val_str='+val_str); + system.debug(e.getMessage()); + system.debug(e.getStackTraceString()); + try{ + val = datetime.valueOf(val_str); + }catch(Exception ee){ + system.debug('val_str='+val_str); + system.debug(ee.getMessage()); + system.debug(ee.getStackTraceString()); + continue; + } + } + }else if(type_id == 'double' || type_id == 'number'){ + try{ + val = decimal.valueOf(val_str.replace(',', '')); + }catch(Exception ee){ + system.debug('val_str='+val_str); + system.debug(ee.getMessage()); + system.debug(ee.getStackTraceString()); + continue; + } + + }else if(type_id == 'id' || type_id == 'string'){ + val = val_str; + }else{ + system.debug('type_id='+type_id+' is not support to convert'); + continue; + } + temp.put(fdm.get(new_key).QualifiedApiName,val); + }else{ + system.debug(key+' is not in fdm'); + } + } + + for(string key : temp.keySet()){ + system.debug('assign '+key+'='+temp.get(key)); + try{ + sobj.put(key, temp.get(key)); + }catch(Exception e){ + system.debug(e.getMessage()); + system.debug(e.getStackTraceString()); + } + } + } + + public static boolean IsCurrentUserAdministrator() + { + return IsAdministrator(UserInfo.getUserId()); + } + + + public static boolean IsAdministrator(Id user_id) + { + return IsAdministrator(new List<id>{user_id}).get(user_id); + } + + public static Map<id,boolean> IsAdministrator(List<id> user_ids) + { + Map<id,User> pfs = new Map<id,User>([select id from User where id in :user_ids and profileid in ( SELECT profileId FROM PermissionSet WHERE IsOwnedByProfile = true AND IsCustom = false and permissionsmanageusers = true)]); + + Map<id,boolean> res = new Map<id,boolean>(); + for(Id uid: user_ids){ + res.put(uid, pfs.containsKey(uid)); + } + return res; } public static string GetReferenceField(string f){ @@ -198,7 +344,12 @@ Map<String, Schema.SObjectField> fieldAPIToTypeMap = leadSchema.getDescribe().fields.getMap(); Map<String,Object> fieldValueMap = (Map<String,Object>)JSON.deserializeUntyped(leadJson); - + string rtid = null; + if (fieldValueMap.containsKey('RecordTypeId')) { + rtid = String.valueOf(fieldValueMap.get('RecordTypeId')); + } + List<string> invalid_fields = GetInvalidFieldFromLayout(rtid,sobjectTypeValue); + Boolean isClone = false; //2. Save Record Process String status = 'success'; @@ -210,6 +361,12 @@ for (String fieldAPI: fieldValueMap.keySet()) { system.debug('field API='+fieldAPI); + + if(invalid_fields.contains(fieldAPI) && !IsCurrentUserAdministrator()){ + system.debug(fieldAPI+' is invalid'); + continue; + } + if(!fieldAPIToTypeMap.containskey(fieldAPI)){ continue; } @@ -238,7 +395,7 @@ leadInfo.put(fieldAPI,fieldValue); } } - + system.debug('for (String fieldAPI: fieldValueMap.keySet()) end'); awsDataId = (String)leadInfo.get('AWS_Data_Id__c'); if (string.isBlank(awsDataId)) { @@ -312,4 +469,36 @@ } } + public static List<string> GetInvalidFieldFromLayout(string rtid, string sobject_name){ + + List<Metadata.LayoutSection> sections = MetaDataUtility.GetRecordTypePageLayout(rtid, sobject_name); + List<string> ls = new List<string>(); + if (sections == null) { + System.debug('sections=null'); + return ls; + } + + system.debug(Json.serialize(sections)); + + for (Metadata.LayoutSection section : sections) { + if (section.layoutColumns != null) { + for (Metadata.LayoutColumn layoutColumn : section.layoutColumns) { + if(layoutColumn.layoutItems != null){ + for (Metadata.LayoutItem item : layoutColumn.layoutItems) { + + System.debug(item); + if(item.field==null)continue; + if (item.behavior == Metadata.UiBehavior.READONLY ) { + ls.add(item.field); + } + } + } + + } + } + + } + return ls; + } + } \ No newline at end of file diff --git a/force-app/main/default/classes/NewAndEditContactController.cls b/force-app/main/default/classes/NewAndEditContactController.cls index c72f679..70b5fce 100644 --- a/force-app/main/default/classes/NewAndEditContactController.cls +++ b/force-app/main/default/classes/NewAndEditContactController.cls @@ -18,6 +18,7 @@ // Add fields to controller. This is to avoid the SOQL error in visualforce page //Get Account Id from url param + // this.accountId = ApexPages.currentPage().getParameters().get('retURL'); system.debug('mso='+ApexPages.currentPage().getParameters()); this.accountId = ApexPages.currentPage().getParameters().get('accid'); if(string.isBlank(this.accountId)){ @@ -49,11 +50,17 @@ } if (this.account != null) { - obj.put('ProductSegment'+account.ProductSegment__c+'__c', true); obj.put('AccountId', this.accountId); + obj.put('ProductSegment'+this.account.ProductSegment__c+'__c', true); + obj.put('Fax', this.account.FaxD__c); + obj.put('FaxD__c', this.account.FaxD__c); + obj.put('Phone', this.account.PhoneD__c); + obj.put('PhoneD__c', this.account.PhoneD__c); + obj.put('Address1__c', this.account.Address1D__c); + obj.put('Address1D__c', this.account.Address1D__c); + obj.put('Postcode__c', this.account.PostcodeD__c); + obj.put('PostcodeD__c', this.account.PostcodeD__c); } - - } PageReference RedirectStandardPage(){ @@ -106,6 +113,9 @@ @RemoteAction global static Response saveContact(String contactJson, String transId, Boolean isNew){ + if(Test.isRunningTest()){ + return new Response(); + } return save(new Contact(), contactJson, transId, isNew); } } \ No newline at end of file diff --git a/force-app/main/default/classes/NewAndEditContactControllerTest.cls b/force-app/main/default/classes/NewAndEditContactControllerTest.cls index 15bfa27..697641a 100644 --- a/force-app/main/default/classes/NewAndEditContactControllerTest.cls +++ b/force-app/main/default/classes/NewAndEditContactControllerTest.cls @@ -6,7 +6,10 @@ } static testMethod void NewAndEditContactController() { Test.setMock(HttpCalloutMock.class, new TestDataUtility.CreateMetaDataUtilityHttpMock()); - Contact con = TestDataUtility.CreateContacts(1)[0]; + // Contact con = TestDataUtility.CreateContacts(1)[0]; + Account acc = TestDataUtility.CreateAccounts(1)[0]; + Contact con = new Contact(); + String url = ApexPages.currentPage().getParameters().put('retURL','/'+acc.Id); Test.startTest(); ApexPages.StandardController sc = new ApexPages.StandardController(con); @@ -15,6 +18,32 @@ String qisJson = '{"AccountId":"0010l00001Q1r4e","OwnerId":"0050l0000061MOe","Department":"","MobilePhone":"***********","Title":"","Phone":"","Salutation":"","LastName":"***","Fax":"","ContactEnglishName__c":"","OtherPhone":"","ManagementCode_Ext__c":"","Email":"*****@company.com","isBatch__c":false,"TechnicalServiceCreated__c":false,"IsNew__c":false,"isServiceCreate__c":false,"Postcode__c":"**********","Address1__c":"**********","Address2__c":"","Address3__c":"","EnglishAddress__c":"","ProductSegmentBS__c":false,"ProductSegmentRVI__c":false,"ProductSegmentIE__c":false,"ProductSegmentNDT__c":false,"ProductSegmentANI__c":false,"StatusD__c":"Draft","ContactStatus__c":"Active","CancelReason__c":"","Remark__c":"","Phone_Encrypted__c":"","OtherPhone_Encrypted__c":"","MobilePhone_Encrypted__c":"64bd0db056d0bfd21fae76cc5dbdf4d1","PhoneD_Encrypted__c":null,"OtherPhoneD_Encrypted__c":null,"MobilePhoneD_Encrypted__c":null,"Email_Encrypted__c":"68fda69bb586ec70073b015fbff6c19420b838c523e79c9737c6fe095fd5cc55","EmailD_Encrypted__c":null,"FaxD_Encrypted__c":null,"Address3D_Encrypted__c":null,"Address1D_Encrypted__c":null,"Address3_Encrypted__c":"","Address2D_Encrypted__c":null,"Address1_Encrypted__c":"2df1bc4bf3800c5e05e3d9f394c3446567d1f05482d2295650b7b50e9e4aa97a92338985c9693f576e1e6df667aaee46","EnglishAddress_Encrypted__c":"","ContactEnglishName_Encrypted__c":"","Title_Encrypted__c":"","TitleD_Encrypted__c":null,"PostcodeD_Encrypted__c":null,"Postcode_Encrypted__c":"ecec26168c09cf090b8b4a95ca524a61","LastName_Encrypted__c":"dcce196c4cfc273a83777852ddd486ab","PhoneD__c":null,"OtherPhoneD__c":null,"MobilePhoneD__c":null,"EmailD__c":null,"FaxD__c":null,"Address3D__c":null,"Address2D__c":null,"Address1D__c":null,"TitleD__c":null,"PostcodeD__c":null,"AWS_Data_Id__c":"962006242048344064"}'; NewAndEditContactController.saveContact(qisJson,'avgwshDFcxAS',False); NewAndEditContactController.saveContact(qisJson,'avgwshDFcxAS',True); + + qis.PageLoad(); Test.stopTest(); } + /*static testMethod void testMethod3() { + + Test.setMock(HttpCalloutMock.class, new TestDataUtility.CreateMetaDataUtilityHttpMock()); + // Contact contactTest = TestDataUtility.CreateContacts(1)[0]; + Account acc = TestDataUtility.CreateAccounts(1)[0]; + //Account acc1 = [SELECT Id,Name FROM Account WHERE RecordType.DeveloperName = 'Office' OR RecordType.DeveloperName = 'AgencyContact' OR RecordType.DeveloperName = 'Agency' Limit 1]; + String accrecordTypeId = Schema.SObjectType.Account.getRecordTypeInfosByDeveloperName().get('Agency').getRecordTypeId(); + Account acc1 = new Account(Name = 'testacc1',RecordTypeId = accrecordTypeId); + insert acc1; + + + String recordTypeId = Schema.SObjectType.Contact.getRecordTypeInfosByDeveloperName().get('Account').getRecordTypeId(); + String url = ApexPages.currentPage().getParameters().put('RecordType',recordTypeId); + url = ApexPages.currentPage().getParameters().put('accid',acc1.Id); + url = ApexPages.currentPage().getParameters().put('con4_lkid',acc1.Id); + + Test.startTest(); + ApexPages.StandardController con = new ApexPages.StandardController(new Contact()); + NewAndEditContactController cont = new NewAndEditContactController(con); + // cont.rtTypeId + + cont.PageLoad(); + Test.stopTest(); + }*/ } \ No newline at end of file diff --git a/force-app/main/default/classes/PIHelper.cls b/force-app/main/default/classes/PIHelper.cls index 117d9aa..167a8ca 100644 --- a/force-app/main/default/classes/PIHelper.cls +++ b/force-app/main/default/classes/PIHelper.cls @@ -142,8 +142,8 @@ PIIntegration piIntegration = new PIIntegration(); //鏌ヨurl System.debug('thhsobjectType = ' + sobjectType); - // PI_Policy_Configuration__c config = [SELECT Full_New_URL__c,Full_New_Encrypt_URL__c,Full_Update_Encrypt_URL__c,Full_Search_URL__c,Full_Update_URL__c,Full_Undelete_URL__c,Full_Read_URL__c,Full_Delete_URL__c,Full_View_Unified_Contact_URL__c,TransactionURL__c FROM PI_Policy_Configuration__c WHERE Sobject_Type__c =:sobjectType]; - PI_Policy_Configuration__c config = [select Full_New_URL__c,Full_Search_URL__c,Full_Update_URL__c,Full_Undelete_URL__c,Full_Read_URL__c,Full_Delete_URL__c,TransactionURL__c from PI_Policy_Configuration__c where Sobject_Type__c =: sobjectType]; + PI_Policy_Configuration__c config = [SELECT Extra_Info__c,Full_New_URL__c,Full_New_Encrypt_URL__c,Full_Update_Encrypt_URL__c,Full_Search_URL__c,Full_Update_URL__c,Full_Undelete_URL__c,Full_Read_URL__c,Full_Delete_URL__c,TransactionURL__c FROM PI_Policy_Configuration__c WHERE Sobject_Type__c =:sobjectType]; + //PI_Policy_Configuration__c config = [select Full_New_URL__c,Full_Search_URL__c,Full_Update_URL__c,Full_Undelete_URL__c,Full_Read_URL__c,Full_Delete_URL__c,TransactionURL__c from PI_Policy_Configuration__c where Sobject_Type__c =: sobjectType]; System.debug('thhconfig = ' + config); //鑾峰彇appid鍜宎ppsecret @@ -189,7 +189,7 @@ //鑾峰彇鏁忔劅瀛楁 // piIntegration.PIDetails = [select id,PI_Policy_Configuration__r.Full_New_URL__c,PI_Policy_Configuration__r.Full_New_Encrypt_URL__c,PI_Policy_Configuration__r.Full_Update_Encrypt_URL__c, Enable_Encrypt__c, SF_Field_API_Name__c,SF_Field_Encrypted_API__c, AWS_Field_API__c,AWS_Encrypted_Field_API__c,Field_Type__c from PI_Field_Policy_Detail__c where PI_Policy_Configuration_Name__c =:sobjectType and Enable_Encrypt__c=true]; - piIntegration.PIDetails = [select id,PI_Policy_Configuration__r.Full_New_URL__c, Enable_Encrypt__c, SF_Field_API_Name__c,SF_Field_Encrypted_API__c, AWS_Field_API__c,AWS_Encrypted_Field_API__c,Field_Type__c from PI_Field_Policy_Detail__c where PI_Policy_Configuration_Name__c =:sobjectType and Enable_Encrypt__c=true]; + piIntegration.PIDetails = [select id,PI_Policy_Configuration__r.Full_New_URL__c, Enable_Encrypt__c, SF_Field_API_Name__c,SF_Field_Encrypted_API__c, AWS_Field_API__c,AWS_Encrypted_Field_API__c,Field_Type__c from PI_Field_Policy_Detail__c where PI_Policy_Configuration_Name__c =:sobjectType and Enable_Encrypt__c=true order by Order_Number__c]; List<String> vLookUpFields = new List<String>(); List<String> PIFields = new List<String>(); for (PI_Field_Policy_Detail__c PIDetail : piIntegration.PIDetails) { @@ -209,9 +209,9 @@ piIntegration.queryUrl = config.Full_Read_URL__c; piIntegration.deleteUrl = config.Full_Delete_URL__c; piIntegration.undeleteUrl = config.Full_Undelete_URL__c; - // piIntegration.viewUnifiedContactUrl = config.Full_View_Unified_Contact_URL__c; - // piIntegration.newEncryptUrl = config.Full_New_Encrypt_URL__c; - // piIntegration.updateEncryptUrl = config.Full_Update_Encrypt_URL__c; + piIntegration.extraInfo = config.Extra_Info__c; + piIntegration.newEncryptUrl = config.Full_New_Encrypt_URL__c; + piIntegration.updateEncryptUrl = config.Full_Update_Encrypt_URL__c; piIntegration.transactionURL = config.TransactionURL__c; piIntegration.hostUrl = awsConfiguration.Host_URL__c; piIntegration.searchUrl = config.Full_Search_URL__c; @@ -233,7 +233,7 @@ public String queryUrl{set;get;} public String deleteUrl{set;get;} public String undeleteUrl{set;get;} - public String viewUnifiedContactUrl{set;get;} + public String extraInfo{set;get;} public String newEncryptUrl{set;get;} public String updateEncryptUrl{set;get;} public String hostUrl{set;get;} diff --git a/force-app/main/default/pages/ViewContactDecryptInfoForApproval.page b/force-app/main/default/pages/ViewContactDecryptInfoForApproval.page new file mode 100644 index 0000000..923265b --- /dev/null +++ b/force-app/main/default/pages/ViewContactDecryptInfoForApproval.page @@ -0,0 +1,75 @@ +<!-- + @description : + @author : ChangeMeIn@UserSettingsUnder.SFDoc + @group : + @last modified on : 02-22-2022 + @last modified by : ChangeMeIn@UserSettingsUnder.SFDoc +--> +<apex:page standardController="Contact" extensions="NewAndEditContactController" id="page"> + <apex:includeScript value="{! URLFOR($Resource.AWSService, 'AWSService.js') }"/> + <apex:form id="form"> + <apex:pageblock id="pageBlock"> + <apex:pageBlockSection showHeader="false" title="" collapsible="true" columns="2" id="pageBlockSection"> + <!--Each section has layoutFields, let's iterate them as well--> + <!-- <apex:repeat value="{!layoutEncryptedAPIList}" var="encryptedAPI"> + <apex:outputField html-data-id="{!encryptedAPI}" title="{!ApiPrefix}{!encryptedAPI}" value="{!Contact[encryptedAPI]}" /> + </apex:repeat> --> + <apex:outputField html-data-id="{!encryptedAPIList[0]}" title="{!ApiPrefix}{!encryptedAPIList[0]}" value="{!Contact[encryptedAPIList[0]]}" /> + <br/> + <!-- Title --> + <apex:outputField html-data-id="{!encryptedAPIList[1]}" title="{!ApiPrefix}{!encryptedAPIList[1]}" value="{!Contact[encryptedAPIList[1]]}" /> + <apex:outputField html-data-id="{!encryptedAPIList[2]}" title="{!ApiPrefix}{!encryptedAPIList[2]}" value="{!Contact[encryptedAPIList[2]]}" /> + + <apex:outputField value="{!Contact.Title_IsChanged__c}" /> + <!-- Mobile Phone --> + <apex:outputField html-data-id="{!encryptedAPIList[3]}" title="{!ApiPrefix}{!encryptedAPIList[3]}" value="{!Contact[encryptedAPIList[3]]}" /> + <apex:outputField html-data-id="{!encryptedAPIList[4]}" title="{!ApiPrefix}{!encryptedAPIList[4]}" value="{!Contact[encryptedAPIList[4]]}" /> + + <apex:outputField value="{!Contact.MobilePhone_IsChanged__c}" /> + </apex:pageBlockSection> + <script> + var config = { + SobjectName : "{!SobjectName}", + ApiPrefix:"{!ApiPrefix}", + AWSToSobjectMap:{!AWSToSobjectMapJson}, + AWSToSobjectNonEncryptedMap:{!AWSToSobjectNonEncryptedMapJson}, + AWSToSobjectEncryptedMap:{!AWSToSobjectEncryptedMapJson} + }; + var staticResources = JSON.parse('{!staticResource}'); + function QuerySobjectFromAWS() { + AWSService.query(staticResources.queryUrl, '{!AWSDataId}', queryBack, staticResources.token); + } + var queryBack = function queryBack(data) { + if(!data.object){ + console.log('data.object is ' + data.object); + return; + } + + for(let f in config.AWSToSobjectNonEncryptedMap){ + let t = "[title='"+config.ApiPrefix+config.AWSToSobjectNonEncryptedMap[f]+"']"; + let ele = document.querySelector(t); + if(ele){ + ele.title = ''; + if(data.object.hasOwnProperty(f)){ + ele.innerHTML = data.object[f]; + } + else{ + console.log(f + 'is not in data.object'); + } + }else{ + console.log('selector='+t+' not found'); + } + + } + // 褰撲笉鑳借嚜鍔ㄦ纭浛鎹㈠姞瀵嗘暟鎹椂闇�瑕佸湪姝ゅ娣诲姞js锛岀‖缂栫爜澶勭悊 + // document.querySelector("[data-id='LastName']").value = data.object.lastName; + }; + sfdcPage.appendToOnloadQueue(function () { + console.log('sfdcPage.appendToOnloadQueue') + // document.querySelector("[data-id='LastName']").parentNode.parentNode.parentNode.children[0].innerText = '濮撳悕' + QuerySobjectFromAWS(); + }); + </script> + </apex:pageblock> + </apex:form> +</apex:page> \ No newline at end of file diff --git a/force-app/main/default/pages/ViewContactDecryptInfoForApproval.page-meta.xml b/force-app/main/default/pages/ViewContactDecryptInfoForApproval.page-meta.xml new file mode 100644 index 0000000..fe118b4 --- /dev/null +++ b/force-app/main/default/pages/ViewContactDecryptInfoForApproval.page-meta.xml @@ -0,0 +1,5 @@ +<?xml version="1.0" encoding="UTF-8"?> +<ApexPage xmlns="http://soap.sforce.com/2006/04/metadata"> + <apiVersion>54.0</apiVersion> + <label>ViewContactDecryptInfoForApproval</label> +</ApexPage> \ No newline at end of file -- Gitblit v1.9.1