From 9ed0e7a2efb8dd44876970766431ed80da93db1f Mon Sep 17 00:00:00 2001
From: buli <137736985@qq.com>
Date: 星期五, 15 四月 2022 10:10:20 +0800
Subject: [PATCH] 20220415Backup

---
 force-app/main/default/classes/NewAndEditBaseController.cls |  160 +++++++++++++++++++++++++++++++++--------------------
 1 files changed, 99 insertions(+), 61 deletions(-)

diff --git a/force-app/main/default/classes/NewAndEditBaseController.cls b/force-app/main/default/classes/NewAndEditBaseController.cls
index 35317ff..49ce172 100644
--- a/force-app/main/default/classes/NewAndEditBaseController.cls
+++ b/force-app/main/default/classes/NewAndEditBaseController.cls
@@ -1,19 +1,16 @@
-/**
- * @description       : 
- * @author            : ChangeMeIn@UserSettingsUnder.SFDoc
- * @group             : 
- * @last modified on  : 03-16-2022
- * @last modified by  : ChangeMeIn@UserSettingsUnder.SFDoc
-**/
 global abstract class NewAndEditBaseController {
 
     public List <LayoutDescriberHelper.LayoutSection > layoutSections{set;get;}
+    public String layoutSectionsStr {get; set;}//for dynamic add readonly attribute 20220316 by Mingjie
     public String awsToken{set;get;}
     public static Map<String, Schema.SObjectType> schemaMap = Schema.getGlobalDescribe();
     public String sobjectTypeValue {private set; get;}
     public Boolean isNewMode{set;get;}
+    public Boolean isCloneMode{protected set;get;}
     public String rtTypeId {get; set;}
     public String AWSDataId{set;get;}
+    public String CurrentUserId{private set;get;}
+    public String CurrentUserName{private set;get;}
 
     // 褰撳墠瀵硅薄鎵�鏈夌殑鍔犲瘑瀛楁闆嗗悎
     public List<String> encryptedAPIList{private set;get;}
@@ -51,12 +48,13 @@
 
     public String sobjectPrefix{get;private set;}
     public String SaveAndNewButtonUrl{get;private set;}
+    @TestVisible
     public List<String> VLookUpFields{get;private set;}
     public String VLookUpFieldsJson{get{return Json.serialize(VLookUpFields);}}
     public List<String> LookUpOverrideFields{get;private set;}
-    public string LookUpOverrideFieldsMapJson{get;private set;}
-    
-
+    public string LookUpOverrideFieldsMapJson{get; set;}
+    public string recordId{get;private set;}
+	
     public NewAndEditBaseController(){
         ApiPrefix = 'PIBackApi';
         AWSToSobjectNonEncryptedMap = new Map<string,string>();
@@ -64,17 +62,24 @@
         VLookUpFields = new List<String>();
         layoutEncryptedAPIList = new List<String>();
         LookUpOverrideFields = new List<String>();
+        CurrentUserName = UserInfo.getName();
+        CurrentUserId = UserInfo.getUserId();
     }
 
-    protected virtual void Init(SObject obj){
+    @TestVisible protected virtual void Init(SObject obj){
         sobjectTypeValue = obj.getSObjectType().getDescribe().getName();
         SobjectLabel = obj.getSObjectType().getDescribe().getLabel();
         system.debug('obj='+sobjectTypeValue);
         
         isNewMode = true;
+        isCloneMode = false;
         List<Sobject> lso = Database.query('select id from RecordType where SobjectType = :sobjectTypeValue');
-        
+        Map<string,string> mso = ApexPages.currentPage().getParameters();
+        if(mso != null && mso.containsKey('newclone')){
+            isCloneMode = true;
+        }
         if(obj.Id != null){
+            recordId = obj.Id;
             isNewMode = false;
             string sql = 'select Id';
             if (lso.size()>0) {
@@ -97,7 +102,7 @@
                     sfIdToAWSIdMap.put(String.valueOf(o).subString(0,15), String.valueOf(leadData.getSobject(GetReferenceField(f)).get('AWS_Data_Id__c')));
                 }
             }
-           
+            
             LookUpOverrideFieldsMapJson = JSON.serialize(sfIdToAWSIdMap);
 
 
@@ -105,7 +110,7 @@
             rtTypeId = ApexPages.currentPage().getParameters().get('RecordType');
         }
         PIHelper.PIIntegration piIntegration = PIHelper.getPIIntegrationInfo(sobjectTypeValue);
-        layoutEncryptedAPIList = piIntegration.PIFields;
+        //layoutEncryptedAPIList = piIntegration.PIFields;
         encryptedAPIList = piIntegration.PIFields;
         staticResource = JSON.serialize(piIntegration);
         sobjectPrefix = piIntegration.sobjectPrefix;
@@ -124,7 +129,7 @@
         system.debug(AWSToSobjectNonEncryptedMapJson);
         try{
             LayoutDescriberHelper.LayoutWrapper LayoutWrapperValue = LayoutDescriberHelper.describeSectionWithFieldsWrapper(rtTypeId, sobjectTypeValue,'classic');
-            layoutSections = LayoutWrapperValue.layoutSections;
+            layoutSections = LayoutWrapperValue.layoutSections;         
             List<String> requiredFieldAPIList = LayoutWrapperValue.requiredFieldAPIList;
             Map<String,String> fieldAPIToLabelMap = LayoutWrapperValue.fieldAPIToLabelMap;
             List<String> fieldApiList = new List<String>(); 
@@ -138,17 +143,19 @@
                         }
 
                         //鍦╲iew瑙e瘑section涓彧闇�鏄剧ず褰撳墠layout涓殑鍔犲瘑瀛楁
-                        // if (encryptedAPIList.contains(lf.fieldAPI)) {
-                        //     layoutEncryptedAPIList.add(lf.fieldAPI);
-                        // }
+                        if (encryptedAPIList.contains(lf.fieldAPI)) {
+                            layoutEncryptedAPIList.add(lf.fieldAPI);
+                        }
                     }
                 }
             }
+            layoutSectionsStr = JSON.serialize(layoutSections); //for dynamic add readonly attribute 20220316 by Mingjie
             fieldApiListStr = JSON.serialize(fieldApiList);
             fieldAPIToLabelMapStr = JSON.serialize(fieldAPIToLabelMap);
             requiredFieldAPIListStr = JSON.serialize(requiredFieldAPIList);
             //awsToken = AWSServiceTool.getAWSToken();
         }catch(Exception e){
+            layoutEncryptedAPIList = piIntegration.PIFields;
             system.debug('Exception from get layout service:'+e.getmessage());
         }
     }
@@ -184,65 +191,77 @@
         string sobjectTypeValue = sobj.getSObjectType().getDescribe().getName();
         System.debug('sobjectTypeValue:'+sobjectTypeValue+' Info:' + JSON.serialize(leadJson));
         System.debug('json length='+leadJson.length());
-        System.debug('json ='+leadJson);
+        System.debug('leadJson---------'+leadJson);
+        System.debug('isNew---------'+isNew);
         //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);
-        Sobject leadInfo = sobj;
-        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)); 
-            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))?0:Decimal.valueOf(fieldValue)); 
-                if(String.isNotBlank(fieldValue)&&String.isNotEmpty(fieldValue)){
-                    if(fieldValue.contains(',')){
-                        fieldValue = fieldValue.replace(',', '');
-                    }
-                    leadInfo.put(fieldAPI, Decimal.valueOf(fieldValue));
-                }else{
-                    leadInfo.put(fieldAPI, 0);
-                } 
-            } else if(String.valueof(fielddataType)=='BOOLEAN'){
-                leadInfo.put(fieldAPI, fieldValueMap.get(fieldAPI));
-            }else {
-                leadInfo.put(fieldAPI,fieldValue);
-            }                  
-        }
-
-        system.debug('for (String fieldAPI: fieldValueMap.keySet()) end');
-
         
+
+        Boolean isClone = false;
         //2. Save Record Process
         String status = 'success';    
         Response resp = new Response();
         String awsDataId = '';
         Savepoint sp = Database.setSavepoint();
+        Sobject leadInfo = sobj;
         try{
-            System.debug('abcde');
-            if(isNew){
+            
+            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));
+                    //20220405 By ChenYanan Start
+                    }else if(String.isNotBlank(fieldValue))  {
+                        fieldValue = fieldValue.replace('/', '-') + ':00';
+                        leadInfo.put(fieldAPI, Datetime.valueOf(fieldValue));
+                    //20220405 By ChenYanan End
+                    }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);
+                }                  
+            }
+
+            system.debug('for (String fieldAPI: fieldValueMap.keySet()) end');
+            awsDataId = (String)leadInfo.get('AWS_Data_Id__c');
+            if (string.isBlank(awsDataId)) {
+                throw new DMLException('鏇存柊鏃禔WS_Data_Id__c涓嶈兘涓虹┖');
+            }
+            System.debug('awsDataId = ' + awsDataId);
+            Sobject[] sobjects = Database.query('select id from '+sobjectTypeValue+' where AWS_Data_Id__c =:awsDataId');
+            
+            
+            if(!isNew){
+                isClone = sobjects.size() == 0;
+            }
+            System.debug('isNew---------'+isNew);
+            
+            if(isNew || isClone){
                 System.debug('leadInfozhj = ' + leadInfo);
                 if(!Test.isRunningTest()){
                     insert leadInfo;
                 }
             }else{
                 System.debug('into update');
-                awsDataId = (String)leadInfo.get('AWS_Data_Id__c');
-                System.debug('awsDataId = ' + awsDataId);
-                Sobject[] leads = Database.query('select id from '+sobjectTypeValue+' where AWS_Data_Id__c =:awsDataId');
-                System.debug('leads[0].id = ' + leads[0].id);
-                leadInfo.put('Id',leads[0].id);//For testing;
+                System.debug('sobjects[0].id = ' + sobjects[0].id);
+                leadInfo.put('Id',sobjects[0].id);//For testing;
                 if(!Test.isRunningTest()){
                     update leadInfo;
                 }
@@ -263,7 +282,26 @@
             System.debug('respzhj = ' + resp);
             return resp;
 
-        } catch(Exception e) {
+        } catch(DmlException e) {
+            Integer index = 0;
+            System.debug(e.getNumDml());
+            System.debug(e.getDmlFields(index));
+            System.debug(e.getDmlId(index));
+            System.debug(e.getDmlIndex(index));
+            System.debug(e.getDmlMessage(index));
+            System.debug(e.getDmlStatusCode(index));
+            System.debug(e.getDmlType(index));
+            system.debug(e.getMessage());
+            system.debug(e.getStackTraceString());
+
+            System.debug('into catch'+e.getMessage());
+            Database.rollback(sp);
+            resp.status = 'Exception';
+            resp.message ='淇濆瓨澶辫触锛屽師鍥�:'+ e.getDmlMessage(index);
+            PIHelper.saveTransLog(sobjectTypeValue,awsDataId,leadInfo.Id,transId, leadJson ,status,e.getMessage()+e.getStackTraceString());
+            return resp;
+            
+        }catch(Exception e) {
             System.debug('into catch'+e.getMessage());
             Database.rollback(sp);
             resp.status = 'Exception';

--
Gitblit v1.9.1