public without sharing class LoanerReceiveGoodsController { // 基础Url public String baseUrl { get; private set; } // 样机借出申请ID public String laId { get; private set; } public loaner_application__c la { get; private set; } /* 画面步骤 * 下架:StockDown * */ public String step { get; private set; } // 明细Bean public List dataLines { get; set; } // 明细行数 public Integer getDatalineSize() { return dataLines == null ? 0 : dataLines.size(); } public LoanerReceiveGoodsController() { laId = System.currentPageReference().getParameters().get('id'); step = System.currentPageReference().getParameters().get('step'); } public PageReference init() { // 基础Url baseUrl = URL.getSalesforceBaseUrl().toExternalForm(); String path = URL.getCurrentRequestUrl().getPath(); if (path.indexOf('/apex') > 0) { baseUrl += path.substring(0,path.indexOf('/apex')); } else if (path.indexOf('production/') > 0) { baseUrl += '/production'; } // 明细Bean dataLines = new List(); if (String.isBlank(laId) == true) { return null; } if (String.isBlank(step) == true) { return null; } // 样机借出申请取得 List laList = [select Id,Status__c from loaner_application__c where Id = :laId]; if (laList.size() == 0) { return null; } la = laList[0]; // 样机借出申请明细取得 String sql_select = 'select Id,ReceiptRemark__c, SerialNumber__c, Internal_Asset_number__c, OTCODE__c, ECCode__c , Inspection_result__c,Receipt_Status__c,LOANER__r.Name,LOANER__r.Remarks2__c'; String sql_where = ' where loaner_application__c = :laId '; if (step == 'ApplicantReceive') { sql_where += ' and RAESD_Status__c = \'已出库\''; } else { return null; } String sql_full = sql_select + ' from loaner_application_detail__c ' + sql_where; List lads = Database.query(sql_full); if (lads.size() == 0) { return null; } // 明细Bean作成 Integer cnt = 0; for (loaner_application_detail__c lad : lads) { cnt += 1; DataLineBean dataLine = new DataLineBean(cnt, lad); dataLines.add(dataLine); } return null; } public PageReference saveBtn() { // 根据step更新样机借出申请明细状态 List updList = new List(); if(dataLines.size() > 0){ for (DataLineBean dataLine : dataLines) { if (dataLine.checkFlag == true) { loaner_application_detail__c lad = dataLine.lad; if (step == 'ApplicantReceive') { if('NG' == dataLine.lad.Receipt_Status__c){ if(lad.ReceiptRemark__c == null || lad.ReceiptRemark__c == ''){ ApexPages.addMessage(new ApexPages.Message(ApexPages.Severity.ERROR, '请填写收货NG备注')); return null; } lad.RAESD_Status__c = '申请者收货NG'; }else if('OK' == dataLine.lad.Receipt_Status__c){ lad.RAESD_Status__c = '申请者已收货'; }else{ ApexPages.addMessage(new ApexPages.Message(ApexPages.Severity.ERROR, '请选择收货状态')); return null; } lad.Receipt_Status__c = dataLine.lad.Receipt_Status__c; lad.Receipt_Date__c = Date.today(); } updList.add(lad); } } Savepoint sp = Database.setSavepoint(); try { if (updList.size() > 0) { update updList; if(la.Status__c != '完毕'){ la.Status__c = LoanerOrderState.getOrderStater(la.Id); update la; } }else{ ApexPages.addMessage(new ApexPages.Message(ApexPages.Severity.ERROR, '请选择需要收货的样机')); return null; } } catch (Exception ex) { Database.rollback(sp); ApexPages.addmessage(new ApexPages.message(ApexPages.severity.Error, ex.getMessage() + ' | Line:' + ex.getLineNumber())); return null; } } // 返回样机借出申请画面 String url = baseUrl; url += '\\' + laId; return new Pagereference(url); } public PageReference cancelBtn() { // 返回样机借出申请画面 String url = baseUrl; url += '\\' + laId; return new Pagereference(url); return null; } public class DataLineBean { // 是否选择 public boolean checkFlag { get; set; } // 行号 public Integer lineNo { get; private set; } public loaner_application_detail__c lad { get; set; } public DataLineBean(Integer in_no, loaner_application_detail__c in_lad) { checkFlag = false; lineNo = in_no; lad = in_lad; } } }