From 87861ae5f1ed5456685f97f8a8e7625e47b9576d Mon Sep 17 00:00:00 2001
From: KKbes <1620284052@qq.com>
Date: 星期四, 13 四月 2023 11:12:26 +0800
Subject: [PATCH] Merge branch 'LEX_dev' of http://47.92.229.245:8089/r/lightningupdate into LEX_dev

---
 force-app/main/default/classes/ReportController.cls |  536 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 536 insertions(+), 0 deletions(-)

diff --git a/force-app/main/default/classes/ReportController.cls b/force-app/main/default/classes/ReportController.cls
new file mode 100644
index 0000000..aea48b6
--- /dev/null
+++ b/force-app/main/default/classes/ReportController.cls
@@ -0,0 +1,536 @@
+/* 
+鐢ㄤ簬缁檒wc鐨刯s鍒濆鍖栨暟鎹拰瀵硅褰曡繘琛宒ml鎿嶄綔锛屾controller灞炰簬鎶ュ憡涔�
+*/
+public with sharing class ReportController {
+    //缁橵OC瀹屾瘯鐩稿簲鐨刯s鎻愪緵鍒濆鍖栨暟鎹�
+    @AuraEnabled
+    public static InitData initForVOCFinishButton (String recordId) {
+        InitData res = new initData();
+        try {
+            Report__c report = [select Status__c from Report__c where Id = :recordId];
+            res.status = report.Status__c;
+            res.profileId = UserInfo.getProfileId();
+            System.debug(LoggingLevel.INFO, '*** res: ' + res);
+        } catch (Exception e) {
+            System.debug(LoggingLevel.INFO, '*** e: ' + e);
+        } 
+        return res;
+    }
+    //缁橵OC鍒ゅ畾鐩稿簲鐨刯s鎻愪緵鍒濆鍖栨暟鎹�
+    @AuraEnabled
+    public static InitData initForVOCCheckButton (String recordId) {
+        InitData res = new initData();
+        try {
+            Report__c report = [select Status__c,IsVOC__c,Responsible_Person__r.Id from Report__c where Id = :recordId];
+            res.status = report.Status__c;
+            res.isVOC = report.IsVOC__c;
+            res.personId = report.Responsible_Person__r.Id;
+            res.profileId = UserInfo.getProfileId();
+            System.debug(LoggingLevel.INFO, '*** res: ' + res);
+        } catch (Exception e) {
+            System.debug(LoggingLevel.INFO, '*** e: ' + e);
+        } 
+        return res;
+    }
+    //缁橵OC鎻愬嚭鐩稿簲鐨刯s鎻愪緵鍒濆鍖栨暟鎹�
+    @AuraEnabled
+    public static Initdata initForVOCSubmitButton(String recordId){
+        InitData res = new InitData();
+        try {
+            Report__c report = [select Status__c,Owner.Id,CreatedBy.Id from Report__c where Id = :recordId];
+            res.status = report.Status__c;
+            res.ownerId = report.Owner.Id;
+            res.createdById = report.CreatedBy.Id;
+            System.debug(LoggingLevel.INFO, '*** res: ' + res);
+        } catch (Exception e) {
+            System.debug(LoggingLevel.INFO, '*** e: ' + e);
+        }
+        return res;
+    }
+
+
+    //缁橵OC鍥炵瓟鐩稿簲鐨刯s鎻愪緵鍒濆鍖栨暟鎹�
+    @AuraEnabled
+    public static Initdata initForVOCAnswerButton(String recordId){
+        InitData res = new InitData();
+        try {
+            Report__c report = [select Status__c from Report__c where Id = :recordId];
+            res.status = report.Status__c;
+            System.debug(LoggingLevel.INFO, '*** res: ' + res);
+        } catch (Exception e) {
+            System.debug(LoggingLevel.INFO, '*** e: ' + e);
+        }
+        return res;
+    }
+    //缁橵OC缁撴灉纭鐩稿簲鐨刯s鎻愪緵鍒濆鍖栨暟鎹�
+    @AuraEnabled
+    public static InitData initForVOCConfirmButton (String recordId) {
+        InitData res = new initData();
+        try {
+            Report__c report = [select Status__c,VOC_Satisfy__c,VOC_Satisfy1__c from Report__c where Id = :recordId];
+            res.status = report.Status__c;
+            res.Satisfy = report.VOC_Satisfy__c;
+            res.Satisfy1 = report.VOC_Satisfy1__c;
+            System.debug(LoggingLevel.INFO, '*** res: ' + res);
+        } catch (Exception e) {
+            System.debug(LoggingLevel.INFO, '*** e: ' + e);
+        } 
+        return res;
+    }
+
+    //缁欏彇娑堢浉搴旂殑js鎻愪緵鍒濆鍖栨暟鎹�
+    @AuraEnabled
+    public static InitData initForCancelButton(String recordId){
+        InitData res = new InitData();
+        try {
+            Report__c report = [select Status__c from Report__c where Id = :recordId];
+            res.status = report.Status__c;
+        } catch (Exception e) {
+            System.debug(LoggingLevel.INFO, '*** e: ' + e);
+        }
+        return res;
+    }
+
+    //缁橭CSM涓嶈鎶ュ憡鐩稿簲鐨刯s鎻愪緵鍒濆鍖栨暟鎹�
+    @AuraEnabled
+    public static InitData initForOCSMNoToReportButton(String recordId){
+        InitData res = new InitData();
+        try {
+            Report__c report = [select OCSMAdministrativeReportNumber__c,OCSMAdministrativeReportDate__c,Aware_date__c from Report__c where Id = :recordId];
+            res.OCSMAdministrativeReportDate = report.OCSMAdministrativeReportDate__c;
+            res.OCSMAdministrativeReportNumber = report.OCSMAdministrativeReportNumber__c;
+            res.awareDate = report.Aware_date__c;
+        } catch (Exception e) {
+            System.debug(LoggingLevel.INFO, '*** e: ' + e);
+        }
+        return res;
+    }
+    //缁橲IStoOPD鐩稿簲鐨刯s鎻愪緵鍒濆鍖栨暟鎹�
+    @AuraEnabled
+    public static InitData initForSIStoOPDButton(String recordId){
+        InitData res = new InitData();
+        try {
+            Report__c report = [select Status__c,Owner.Id from Report__c where Id = :recordId];
+            res.status = report.Status__c;
+            res.ownerId = report.Owner.Id;
+            res.userId = UserInfo.getUserId();
+        } catch (Exception e) {
+            System.debug(LoggingLevel.INFO, '*** e: ' + e);
+        }
+        return res;
+    }
+
+    //缁橭CSM瑕佹姤鍛婄浉搴旂殑js鎻愪緵鍒濆鍖栨暟鎹�
+    @AuraEnabled
+    public static InitData initForOCSMToReportButton(String recordId){
+        InitData res = new InitData();
+        try {
+            Report__c report = [select OCSMAdministrativeReportStatus__c,AwareDate__C from Report__c where Id = :recordId];
+            res.OCSMAdministrativeReportStatus = report.OCSMAdministrativeReportStatus__c;
+            res.awareDate = report.AwareDate__C;
+        } catch (Exception e) {
+            System.debug(LoggingLevel.INFO, '*** e: ' + e);
+        }
+        return res;
+    }
+
+    //缁欏畬姣曠浉搴旂殑js鎻愪緵鍒濆鍖栨暟鎹�
+    @AuraEnabled
+    public static InitData initForCompleteButton(String recordId){
+        InitData res = new InitData();
+        try {
+            Report__c report = [select Status__c from Report__c where Id = :recordId];
+            res.status = report.Status__c;
+            res.profileId = UserInfo.getProfileId();
+        } catch (Exception e) {
+            System.debug(LoggingLevel.INFO, '*** e: ' + e);
+        }
+        return res;
+    }
+    //缁橧ntake universal code缂栬緫鐩稿簲鐨刯s鎻愪緵鍒濆鍖栨暟鎹�
+    @AuraEnabled
+    public static InitData initForASRCEditorButton(String recordId){
+        InitData res = new InitData();
+        String developerName = LightingButtonConstant.DEVELOPER_NAME_ASRC_DECISION;
+        try {
+            PAE_DecisionRecord__c[] report = [SELECT LastModifiedDate, Id, Name, LastModifiedById,RecordType.DeveloperName FROM PAE_DecisionRecord__c where PAE_Report__c =  :recordId  And RecordType.DeveloperName = :developerName Order by LastModifiedDate desc];
+            if (report != null && !report.isEmpty()) {
+                res.LastModifiedDate = report[0].LastModifiedDate;
+                res.Id = report[0].Id;
+                res.Name = report[0].Name;
+                res.LastModifiedById = report[0].LastModifiedById;
+                res.DeveloperName = report[0].RecordType.DeveloperName;
+            }
+        } catch (Exception e) {
+            System.debug(LoggingLevel.INFO, '*** e: ' + e);
+        }
+        return res;
+    }
+
+
+    //缁橣inal universal code缂栬緫鐩稿簲鐨刯s鎻愪緵鍒濆鍖栨暟鎹�
+    @AuraEnabled
+    public static InitData initForASACEditorButton(String recordId){
+        InitData res = new InitData();
+        String recordTypeId = LightingButtonConstant.DEVELOPER_NAME_ASAC_DECISION;
+        try {
+            PAE_DecisionRecord__c[] report = [SELECT LastModifiedDate, Id, Name, LastModifiedById,RecordType.DeveloperName FROM PAE_DecisionRecord__c where PAE_Report__c =  :recordId  And RecordType.DeveloperName = :recordTypeId Order by LastModifiedDate desc];
+            if (report != null && !report.isEmpty()) {
+                res.LastModifiedDate = report[0].LastModifiedDate;
+                res.Id = report[0].Id;
+                res.Name = report[0].Name;
+                res.LastModifiedById = report[0].LastModifiedById;
+                res.DeveloperName = report[0].RecordType.DeveloperName;
+            }
+        } catch (Exception e) {
+            System.debug(LoggingLevel.INFO, '*** e: ' + e);
+        }
+        return res;
+    }
+
+
+    //缁橭PDtoSIS鐩稿簲鐨刯s鎻愪緵鍒濆鍖栨暟鎹�
+    @AuraEnabled
+    public static InitData initForOPDtoSISButton(String recordId){
+        InitData res = new InitData();
+        try {
+            Report__c report = [select Status__c,Owner.Id from Report__C where Id = :recordId];
+            res.status = report.Status__c;
+            res.ownerId = report.Owner.Id;
+            res.userId = UserInfo.getUserId();
+        } catch (Exception e) {
+            System.debug(LoggingLevel.INFO, '*** e: ' + e);
+        }
+        return res;
+    }
+
+    //缁欐彁浜�(瀵规墜娲诲姩鎶ュ憡)鐩稿簲鐨刯s鎻愪緵鍒濆鍖栨暟鎹�
+    @AuraEnabled
+    public static InitData initForSubmitCompetitorReportButton(String recordId){
+        InitData res = null;
+        try {
+           res =  new InitData();
+        } catch (Exception e) {
+            throw new AuraHandledException(e.getMessage());
+        }
+        return res;
+    }
+
+    //缁欐彁浜ょ浉搴旂殑js鎻愪緵鍒濆鍖栨暟鎹�
+    @AuraEnabled
+    public static void updateForSubmitButton(String reocrdId){
+        try {
+            Report__c rac = new Report__c();
+            rac.Id = reocrdId;
+            rac.Status__c = LightingButtonConstant.RECORD_TYPE_NAME_BY_SUBMIT;
+            rac.Submit_time__c = Datetime.now();
+            rac.Submit_report_day__c = Date.today();
+            update rac;
+        } catch (Exception e) {
+            throw new AuraHandledException(e.getMessage());
+        }
+    }
+    //OPDtoSIS鎿嶄綔鏇存柊鐩稿簲鏁版嵁
+    @AuraEnabled
+    public static void updateForOPDtoSISButton(String recordId){
+        try {
+            Report__c rac = new Report__c();
+            rac.Id = recordId;
+            rac.RecordTypeId = Schema.SObjectType.Report__c.getRecordTypeInfosByName().get(LightingButtonConstant.RECORD_TYPE_NAME_BY_OPD).getRecordTypeId();
+            update rac;
+        } catch (Exception e) {
+            System.debug(LoggingLevel.INFO, '*** e: ' + e);
+        }
+    }
+
+    //鍙栨秷鎻愪氦鎿嶄綔鏇存柊鐩稿簲鏁版嵁
+    @AuraEnabled
+    public static void updateForCancelSubmitReportButton(String recordId){
+        try {
+            Report__c rac = new Report__c();
+            rac.Id = recordId;
+            rac.Status__c = LightingButtonConstant.STATUS_DRAFT;
+            rac.Submit_report_day__c = null;
+            rac.Submit_time__c = null;
+            update rac;
+        } catch (Exception e) {
+            throw new AuraHandledException(e.getMessage());
+        }
+    }
+    //瀹屾瘯鎿嶄綔鏇存柊鐩稿簲鏁版嵁
+    @AuraEnabled
+    public static void updateForCompleteButton(String recordId){
+        Report__c rac = new Report__c();
+        try {
+            rac.Id = recordId;
+            rac.Status__c = LightingButtonConstant.STATUS_COMPLETE;
+            rac.RecordTypeId = Schema.SObjectType.Report__c.getRecordTypeInfosByName().get(LightingButtonConstant.VOC_NAME).getRecordTypeId();
+            update rac;
+        } catch (Exception e) {
+            throw new AuraHandledException(e.getMessage());
+        }
+    }
+    //OCSM瑕佹姤鍛婃搷浣滄洿鏂扮浉搴旀暟鎹�
+    @AuraEnabled
+    public static void updateForOCSMToReportButton(String recordId){
+        try {
+            Report__c rac = new Report__c();
+            rac.Id = recordId;
+            rac.OCSMAdministrativeReportStatus__c = LightingButtonConstant.STATUS_TO_BE_REPORTED;
+            update rac;
+        } catch (Exception e) {
+            System.debug(LoggingLevel.INFO, '*** e: ' + e);
+        }
+    }
+
+    //SIStoOPD鎿嶄綔鏇存柊鐩稿簲鏁版嵁
+    @AuraEnabled
+    public static String updateForSIStoOPDButton(String recordId){
+        Report__c rac = new Report__c();
+        try {
+            rac.Id = recordId;
+            rac.RecordTypeId = Schema.SObjectType.Report__c.getRecordTypeInfosByName().get(LightingButtonConstant.RECORD_TYPE_NAME_BY_FOLLOW_THE_STAGE).getRecordTypeId();
+            update rac;
+            return null;
+        } catch (Exception e) {
+            return e.getMessage();
+        }
+    }
+    //DispatchOCSMQARA鎿嶄綔鏇存柊鐩稿簲鏁版嵁
+    @AuraEnabled
+    public static void updateForDispatchOCSMQARAButton(String recordId){
+        try {
+            Report__c rac = new Report__c();
+            rac.Id = recordId;
+            rac.Dispatch_OCSM_QARA__c = true;
+            update rac;
+        } catch (Exception e) {
+            System.debug(LoggingLevel.INFO, '*** e: ' + e);
+        }
+    }
+    //OCSM涓嶈鎶ュ憡鎿嶄綔鏇存柊鐩稿簲鏁版嵁
+    @AuraEnabled
+    public static void updateForOCSMNoToReportButton(String recordId){
+        try {
+            Report__c rac = new Report__c();
+            rac.Id = recordId;
+            rac.OCSMAdministrativeReportStatus__c  = LightingButtonConstant.STATUS_TO_NOT_REPORT;
+            update rac;
+        } catch (Exception e) {
+            System.debug(LoggingLevel.INFO, '*** e: ' + e);
+        }
+    }
+
+    //鍙栨秷鎿嶄綔鏇存柊鐩稿簲鏁版嵁
+    @AuraEnabled
+    public static void updateForCancelButton(String recordId){
+        try {
+            Report__c rac = new Report__c();
+            rac.Id = recordId;
+            rac.Status__c = LightingButtonConstant.STATUS_CANCEL;
+            update rac;
+        } catch (Exception e) {
+            System.debug(LoggingLevel.INFO, '*** e: ' + e);
+        }
+    }
+    
+    //VOC缁撴灉纭鏇存柊鐩稿簲鏁版嵁
+    @AuraEnabled
+    public static void updateForVOCConfirmButton(String recordId,String Satisfy,String Satisfy1){
+        try {
+            Report__c rac = new Report__c();
+            rac.Id = recordId;
+            if (Satisfy == LightingButtonConstant.CN_YES) {
+                rac.Status__c = LightingButtonConstant.STATUS_VOC_CONFIRMED;
+                } else if (Satisfy == LightingButtonConstant.CN_NO) {
+                // 瀵惧繙绲愭灉锛堜竴鍥炵洰锛夈伀鍊ゃ仾銇戙倢銇般�佷竴鍥炵洰銇�屽惁銆嶃仺瑕嬨仾銇�
+                if (Satisfy1 != LightingButtonConstant.CN_NO) {
+                Report__c[] records = [SELECT Id, VOC_Satisfy__c, VOC_Unsatisfy_Reason__c, VOC_follow_up_result__c, VOC_solution_category__c FROM Report__c WHERE Id = :recordId];
+                rac.VOC_Satisfy__c = null;
+                rac.VOC_Unsatisfy_Reason__c = null;
+                rac.VOC_follow_up_result__c = null;
+                rac.VOC_solution_category__c = null;
+                rac.VOC_Satisfy1__c= records[0].VOC_Satisfy__c;
+                rac.VOC_Unsatisfy_Reason1__c = records[0].VOC_Unsatisfy_Reason__c;
+                rac.VOC_follow_up_result1__c = records[0].VOC_follow_up_result__c;
+                rac.VOC_solution_category1__c = records[0].VOC_solution_category__c;
+                rac.Status__c = LightingButtonConstant.STATUS_DRAFT;
+                }
+                // 瀵惧繙绲愭灉锛堜竴鍥炵洰锛夈伀鍊ゃ亗銈屻伆銆佷簩鍥炵洰銇�屽惁銆嶃仺瑕嬨仾銇�
+                else {
+                rac.Status__c = LightingButtonConstant.STATUS_VOC_CONFIRMED;
+                }
+                }
+            update rac;
+        } catch (Exception e) {
+            System.debug(LoggingLevel.INFO, '*** e: ' + e);
+        }
+    }
+    //VOC鍥炵瓟鏇存柊鐩稿簲鏁版嵁
+    @AuraEnabled
+    public static String updateForVOCAnswerButton(String recordId){
+        try {
+            Report__c rac = [select Status__c from Report__c where Id = :recordId];
+            rac.Status__c = LightingButtonConstant.STATUS_VOC_END_OF_ANSWER;
+            update rac;
+            return null;
+        } catch (Exception e) {
+            System.debug(LoggingLevel.INFO, '*** e: ' + e);
+            String exc = '' + e.getMessage();
+            Integer left = exc.indexOf(':') + 1;
+            Integer right = exc.lastIndexOf(':');
+            String str = exc.substring(left,right);
+            left = str.indexOf(',') +  1;
+            String newStr = str.substring(left);
+            return newStr;
+        }
+    }
+
+    //鎻愪氦绔炰簤瀵规墜鎶ュ憡鏇存柊鐩稿簲鏁版嵁
+    @AuraEnabled
+    public static void updateForSubmitCompetitorReportButton(String recordId){
+        try {
+            Report__c rac = new Report__c();
+            rac.Id = recordId;
+            rac.Status__c = LightingButtonConstant.STATUS_VOC_APPLYING;
+            rac.Submit_time__c = Datetime.now();
+            rac.Submit_report_day__c = Date.today();
+            rac.Date__c = Date.today();
+            update rac;
+        } catch (Exception e) {
+            System.debug(LoggingLevel.INFO, '*** e: ' + e);
+        }
+    }
+    //VOC鍥炵瓟鏇存柊鐩稿簲鏁版嵁
+    @AuraEnabled
+    public static void updateForVOCSubmitButton(String recordId ,String createdById){
+        try {
+            Report__c rac = [select Status__c,JingliApprovalManager__r.Id,BuchangApprovalManager__r.Id,SalesManager__r.Id,BuchangApprovalManagerSales__r.Id,ZongjianApprovalManager__c,Submit_time__c,Submit_report_day__c,Owner.Id from Report__c where Id = :recordId];
+            // share
+            rac.Id = recordId;
+            User[] records = [SELECT  Job_Category__c FROM User WHERE Id = :createdById];
+            List<String> userAccess = new List<String>();
+            if (records[0].Job_Category__c == LightingButtonConstant.TYPE_OF_SALES_SERVICES) {
+            userAccess.add(rac.JingliApprovalManager__c + LightingButtonConstant.USER_ACCESS_READ);
+            userAccess.add(rac.BuchangApprovalManager__c + LightingButtonConstant.USER_ACCESS_READ);
+            rac.VOC_CreatedBy_jingli__c = rac.JingliApprovalManager__c;
+            rac.VOC_CreatedBy_buzhang__c = rac.BuchangApprovalManager__c;
+            } else {
+            userAccess.add(rac.SalesManager__c + LightingButtonConstant.USER_ACCESS_READ);
+            userAccess.add(rac.BuchangApprovalManagerSales__c + LightingButtonConstant.USER_ACCESS_READ);
+            rac.VOC_CreatedBy_jingli__c = rac.SalesManager__c;
+            rac.VOC_CreatedBy_buzhang__c = rac.BuchangApprovalManagerSales__c;
+            }
+            userAccess.add(rac.ZongjianApprovalManager__c + LightingButtonConstant.USER_ACCESS_READ);
+            String rtn = ControllerUtil.setSObjectShare(LightingButtonConstant.SOBJECT_NAME_OF_REPORT_SHARE,LightingButtonConstant.SOBJECT_NAME_OF_VOC_SHARE,recordId,userAccess,rac.Owner.Id);
+            if (rtn != LightingButtonConstant.OK) {
+            return;
+            }
+            rac.Status__c = LightingButtonConstant.STATUS_VOC_WRITE_OVER;
+            rac.Submit_time__c = Date.today();
+            rac.Submit_report_day__c = Date.today();
+            update rac;
+        } catch (Exception e) {
+            System.debug(LoggingLevel.INFO, '*** e: ' + e);
+            
+        }
+    }
+    //VOC鍒ゅ畾鏇存柊鐩稿簲鏁版嵁
+    @AuraEnabled
+    public static String updateForVOCCheckButton (String recordId,String isVOC,String personId) {          
+        try {
+            Report__c rac = [select Owner.Id,VOC_jingli__r.Id,VOC_buzhang__r.Id,VOC_zongjian__r.Id,VOC_Finish__c,VOC_share_date__c,Responsible_Person__r.Id from Report__c where Id = :recordId];
+            if (isVOC == LightingButtonConstant.VOC_NAME) {
+                // VOC瀵惧繙鑰呫伄绲岀悊閮ㄩ暦绶忕洠銈掕ō瀹�
+                User[] records = [SELECT Id, Job_Category__c, JingliApprovalManager__c, SalesManager__c, BuchangApprovalManager__c, BuchangApprovalManagerSales__c, ZongjianApprovalManager__c FROM User WHERE Id = :personId];
+                if (records[0].job_Category__c == LightingButtonConstant.TYPE_OF_SALES_SERVICES) {
+                    rac.VOC_jingli__c = records[0].JingliApprovalManager__c == null ? '' : records[0].JingliApprovalManager__c;
+                    rac.VOC_buzhang__c = records[0].BuchangApprovalManager__c == null ? '' : records[0].BuchangApprovalManager__c;
+                } else {
+                    rac.VOC_jingli__c = records[0].SalesManager__c == null ? '' : records[0].SalesManager__c;
+                    rac.VOC_buzhang__c = records[0].BuchangApprovalManagerSales__c == null ? '' : records[0].BuchangApprovalManagerSales__c;
+                }
+                rac.VOC_zongjian__c = records[0].ZongjianApprovalManager__c == null ? '' : records[0].ZongjianApprovalManager__c;
+                rac.Status__c = LightingButtonConstant.STATUS_VOC_CHECK_OVER;
+                rac.VOC_Finish__c = false;
+                Date serverTimestamp = Date.today();
+                rac.VOC_share_date__c = serverTimestamp;
+                // share
+                List<String> userAccess = new List<String>();
+                userAccess.add(rac.Responsible_Person__c + LightingButtonConstant.USER_ACCESS_EDIT);
+                userAccess.add(rac.VOC_jingli__c + LightingButtonConstant.USER_ACCESS_READ);
+                userAccess.add(rac.VOC_buzhang__c + LightingButtonConstant.USER_ACCESS_READ);
+                userAccess.add(rac.VOC_zongjian__c + LightingButtonConstant.USER_ACCESS_READ);
+                String rtn = ControllerUtil.setSObjectShare(LightingButtonConstant.SOBJECT_NAME_OF_REPORT_SHARE,LightingButtonConstant.SOBJECT_NAME_OF_VOC_SHARE,recordId,userAccess,rac.Owner.Id);
+                if (rtn != LightingButtonConstant.OK) {
+                    return null;
+                }
+                update rac;
+                } else {
+                    rac.Status__c = LightingButtonConstant.STATUS_VOC_FINISH;
+                    rac.VOC_Finish__c = true;
+                    update rac;
+                }
+                return null;
+        } catch (Exception e) {
+            System.debug(LoggingLevel.INFO, '*** e: ' + e);
+            String exc = e.getMessage();
+            return exc;
+        }
+    }
+    //VOC瀹屾瘯鎿嶄綔鏇存柊鐩稿簲鏁版嵁
+    @AuraEnabled
+    public static void updateForVOCFinishButton (String recordId) {
+        try {
+            Report__c report = [select Id,Status__C from Report__c where Id = :recordId];
+            report.Status__c = LightingButtonConstant.STATUS_VOC_FINISH;
+            update report;
+        } catch (Exception e) {
+            System.debug(LoggingLevel.INFO, '*** e: ' + e);
+        }
+    }
+    public class InitData{
+        @AuraEnabled
+        public String status;
+        @AuraEnabled
+        public String isVOC;
+        @AuraEnabled
+        public String personId;
+        @AuraEnabled
+        public String createdById;
+        @AuraEnabled
+        public String ownerId;
+        @AuraEnabled
+        public String Satisfy;
+        @AuraEnabled
+        public String Satisfy1;
+        @AuraEnabled
+        public String profileId;
+        @AuraEnabled
+        public String OCSMAdministrativeReportNumber;
+        @AuraEnabled
+        public Date OCSMAdministrativeReportDate;
+        @AuraEnabled
+        public Date awareDate;
+        @AuraEnabled
+        public String OCSMAdministrativeReportStatus;
+        @AuraEnabled
+        public Datetime LastModifiedDate;
+        @AuraEnabled
+        public String Id;
+        @AuraEnabled
+        public String Name;
+        @AuraEnabled
+        public String LastModifiedById;
+        @AuraEnabled
+        public String DeveloperName;
+        @AuraEnabled
+        public String userId;
+
+        
+
+
+
+
+    }
+}
\ No newline at end of file

--
Gitblit v1.9.1