public with sharing class WeeklyReportCmp { @AuraEnabled public List reports { get; set; } @AuraEnabled public Map>> allselectlist { get; set; } @AuraEnabled public Map fieldsMap { get; set; } @AuraEnabled public Map>> docmap { get; set; } @AuraEnabled public List> doctorList { get; set; } // PIPL update Yin Mingjie 21/02/2022 start @AuraEnabled public Map awsurl { get; set; } @AuraEnabled public Map contactawsurl { get; set; } // PIPL update Yin Mingjie 21/02/2022 end public WeeklyReportCmp() { } // PIPL update Yin Mingjie 21/02/2022 start @RemoteAction @AuraEnabled public static Map getAwsurl(String sobj) { PIHelper.PIIntegration piIntegration = PIHelper.getPIIntegrationInfo(sobj); Map awsmap = new Map(); awsmap.put('token', piIntegration.token); awsmap.put('newUrl', piIntegration.newUrl); awsmap.put('searchUrl', piIntegration.searchUrl); awsmap.put('transactionURL', piIntegration.transactionURL); return awsmap; } // @RemoteAction // @AuraEnabled // public static Map saveAgencyContact(String name, String nameEncrypt, String type, String typeEncrypt, String doctorDivision1, // String doctorDivision1Encrypt, String agencyHospitalid, String awsid) { // Agency_Contact__c agency_contact = new Agency_Contact__c(); // agency_contact.Name = name; // agency_contact.Name_Encrypted__c = nameEncrypt; // agency_contact.Type__c = type; // agency_contact.Type_Encrypted__c = typeEncrypt; // agency_contact.Doctor_Division1__c = doctorDivision1; // agency_contact.Doctor_Division1_Encrypted__c = doctorDivision1Encrypt; // agency_contact.Agency_Hospital__c = agencyHospitalid; // agency_contact.AWS_Data_Id__c = awsid; // Map acMap = new Map(); // acMap = LightningUtil.insertAgencyContact(agency_contact); // return acMap; // } //zhj 新方案改造 2022-12-21 start @RemoteAction @AuraEnabled public static Map saveAgencyContact( String name, String type, String doctorDivision1, String agencyHospitalid, String awsid ) { Agency_Contact__c agency_contact = new Agency_Contact__c(); agency_contact.Name = name; agency_contact.Type__c = type; agency_contact.Doctor_Division1__c = doctorDivision1; agency_contact.Agency_Hospital__c = agencyHospitalid; agency_contact.AWS_Data_Id__c = awsid; Map acMap = new Map(); acMap = LightningUtil.insertAgencyContact(agency_contact); return acMap; } //zhj 新方案改造 2022-12-21 end // PIPL update Yin Mingjie 21/02/2022 end @RemoteAction @AuraEnabled public static List> getProductList( String dc, String opdsis ) { List ptList; if (opdsis != '') { ptList = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dc AND OPD_SIS_Type__c = :opdsis ]; } else { ptList = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dc ]; } List> pts = new List>(); Map blank = new Map(); blank.put('label', ''); blank.put('value', ''); pts.add(blank); for (ProductTypes__c pt : ptList) { Map ptMap = new Map(); ptMap.put('label', pt.Name); ptMap.put('value', pt.Id); pts.add(ptMap); } return pts; } public void setalldata() { /*** create allselectlist ***/ this.allselectlist = new Map>>(); Map>> alldata = new Map>>(); // プルダウン初期値の空白 List> tmp = new List>(); Map space = new Map(); space.put('label', ''); space.put('value', ''); // PIPL update Yin Mingjie 21/02/2022 start space.put('awsid', ''); // PIPL update Yin Mingjie 21/02/2022 end space.put('selected', 'true'); tmp.add(space); // 代理店担当者 AgencyPerson__c List agency_person_data = LightningUtil.selectAgencyPerson(); for (Contact var : agency_person_data) { Map om = new Map(); om.put('label', var.Name); om.put('value', var.Id); // PIPL update Yin Mingjie 21/02/2022 start om.put('awsid', var.AWS_Data_Id__c); // PIPL update Yin Mingjie 21/02/2022 end om.put('selected', 'false'); tmp.add(om); } this.allselectlist.put('AgencyPerson__c', tmp); /* List agency_person_data = [Select Id,Name,CurrencyIsoCode From AgencyPerson__c]; List> tmp = new List>(); Map space = new Map(); space.put('label', ''); space.put('value', ''); space.put('selected', 'true'); tmp.add(space); for(AgencyPerson__c var : agency_person_data){ Map om = new Map(); om.put('label', var.Name); om.put('value', var.Id); om.put('selected', 'false'); tmp.add(om); } this.allselectlist.put('AgencyPerson__c', tmp); */ // 科室分类 Department_Cateogy__c this.allselectlist.put( 'Department_Cateogy__c', WeeklyReportCmp.getPicklistValues( 'Agency_Report__c', 'Department_Cateogy__c' ) ); // 活动区分 Purpose_Type__c this.allselectlist.put( 'Purpose_Type__c', WeeklyReportCmp.getPicklistValues('Agency_Report__c', 'Purpose_Type__c') ); // 结果 Result__c this.allselectlist.put( 'Result__c', WeeklyReportCmp.getPicklistValues('Agency_Report__c', 'Result__c') ); //阶段 StageName__c this.allselectlist.put( 'StageName__c', WeeklyReportCmp.getPicklistValues('Agency_Opportunity__c', 'StageName__c') ); //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 start // 支援需求 SupportNeeds__c this.allselectlist.put( 'SupportNeeds__c', WeeklyReportCmp.getPicklistValues('Agency_Report__c', 'SupportNeeds__c') ); //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 end // 职位 // this.allselectlist.put('visitor_title__c', WeeklyReportCmp.getPicklistValues('Agency_Report__c','visitor_title__c')); // 製品区分 //List ProductTypes = [select id,Name from ProductTypes__c]; //List> tmp2 = new List>(); //tmp2.add(space); //for(ProductTypes__c var : ProductTypes){ // Map om = new Map(); // om.put('label', var.Name); // om.put('value', var.Id); // om.put('selected', 'false'); // tmp2.add(om); //} //this.allselectlist.put('Product_Category__c', tmp2); // 見出し設定 this.fieldsMap = new Map(); this.fieldsMap = this.getfiledsmap(); //System.debug('fieldsMap is ' + fieldsMap); //System.debug('allselectlist is ' + this.allselectlist); this.awsurl = getAwsurl('Agency_Contact__c'); // 20220222 PI改造 by Bright this.contactawsurl = getAwsurl('Contact'); // 20220222 PI改造 by Bright } public static List> getPicklistValues( String objstr, String fld ) { List> options = new List>(); Map space = new Map(); space.put('label', ''); space.put('value', ''); space.put('selected', 'true'); options.add(space); Schema.sObjectType objType = Schema.getGlobalDescribe().get(objstr); Schema.DescribeSObjectResult objDescribe = objType.getDescribe(); map fieldMap = objDescribe.fields.getMap(); list values = fieldMap.get(fld) .getDescribe() .getPickListValues(); system.debug(objstr + '=' + values); for (Schema.PicklistEntry a : values) { if (!a.isActive()) continue; Map ses = new Map(); ses.put('label', a.getLabel()); ses.put('value', a.getValue()); ses.put('selected', 'false'); options.add(ses); } return options; } public Map getfiledsmap() { Map schemaMap = Schema.getGlobalDescribe(); Map> typemap = new Map>(); Map fieldMap = schemaMap.get( 'Agency_Opportunity__c' ) .getDescribe() .fields.getMap(); Map mappingmap = new Map(); for (Schema.SObjectField sfield : fieldMap.Values()) { Schema.describefieldresult dfield = sfield.getDescribe(); String lab = ''; lab = dfield.getLabel(); system.debug(lab); mappingmap.put(dfield.name, lab); } fieldMap = schemaMap.get('Agency_Report__c').getDescribe().fields.getMap(); for (Schema.SObjectField sfield : fieldMap.Values()) { Schema.describefieldresult dfield = sfield.getDescribe(); String lab = ''; lab = dfield.getLabel(); system.debug(lab); mappingmap.put(dfield.name, lab); } return mappingmap; } @RemoteAction @AuraEnabled public static WeeklyReportCmp getalldata() { WeeklyReportCmp li = new WeeklyReportCmp(); li.setalldata(); return li; } @RemoteAction @AuraEnabled public static ProductTypes__c getProduct(String id) { return [ SELECT Department_Cateogy__c, OPD_Flg__c, Id, SIS_Flg__c FROM ProductTypes__c WHERE Id = :id ]; } @RemoteAction @AuraEnabled public static String createReportHeader( String name, String s_date, String s_agency, String head_key ) { Agency_Report_Header__c agency_report_header = makeReportHeader( name, s_date, s_agency, head_key ); agency_report_header = LightningUtil.upsertAgencyReportHeader( agency_report_header ); return agency_report_header.Id; } public static Agency_Report_Header__c makeReportHeader( String name, String s_date, String s_agency, String head_key ) { Date week = Date.valueOf(s_date); Agency_Report_Header__c agency_report_header = new Agency_Report_Header__c(); agency_report_header.Name = name + ' (' + s_date + ')'; agency_report_header.HeaderInputKey__c = head_key; agency_report_header.Week__c = week; agency_report_header.Agency_Person2__c = s_agency; // READ OlympusCalendar__c system.debug(week); OlympusCalendar__c olympus_calendar = [ SELECT Id, Date__c FROM OlympusCalendar__c WHERE Date__c = :week ]; system.debug(olympus_calendar); String olympus_calendar_id = olympus_calendar.Id; if (olympus_calendar_id != '') { agency_report_header.OlympusDate__c = olympus_calendar_id; } system.debug(agency_report_header); return agency_report_header; } @RemoteAction @AuraEnabled public static List getHospitalList( String hospital_name ) { hospital_name = '%' + hospital_name.trim() + '%'; system.debug('hospital_name+++' + hospital_name); List ahllist = [ SELECT Hospital_Name_readonly__c, Id, Hospital__c FROM Agency_Hospital_Link__c WHERE Hospital_Name_readonly__c LIKE :hospital_name AND Agency_Campaign_Obj__c = TRUE ]; system.debug('Agency_Campaign_Obj__c+++' + ahllist); return ahllist; } @RemoteAction @AuraEnabled // PIPL update Yin Mingjie 21/02/2022 start public static Map> getDoctorList( String hospital_id ) { /* public static List> getDoctorList(String hospital_id){ List> ret = new List>(); Map space = new Map(); space.put('label', ''); space.put('value', ''); space.put('selected', 'true'); ret.add(space); */ // PIPL update Yin Mingjie 21/02/2022 end // 戦略科室IDを取得して、それをもとに顧客をSELECT Agency_Hospital_Link__c ahl = [ SELECT Hospital__c FROM Agency_Hospital_Link__c WHERE id = :hospital_id ]; // PIPL update Yin Mingjie 21/02/2022 start /* List doctor_list = [select id,Name,Doctor_Division1__c,Type__c,Agency_Hospital__c FROM Agency_Contact__c WHERE Hospital_ID18__c=:ahl.Hospital__c order by Name]; for (Agency_Contact__c row : doctor_list) { Map tmp = new Map(); tmp.put('label', row.Name); tmp.put('value', row.Id); tmp.put('selected', 'false'); tmp.put('Doctor_Division1__c', row.Doctor_Division1__c); ret.add(tmp); } */ List doctor_list = [ SELECT id, Name, AWS_Data_Id__c, Doctor_Division1__c, Type__c, Agency_Hospital__c FROM Agency_Contact__c WHERE Hospital_ID18__c = :ahl.Hospital__c ORDER BY Name ]; Map> ret_test = new Map>(); for (Agency_Contact__c row : doctor_list) { if (row.AWS_Data_Id__c == '' || row.AWS_Data_Id__c == null) { continue; } Map tmp = new Map(); tmp.put('label', row.Name); tmp.put('value', row.Id); tmp.put('awsid', row.AWS_Data_Id__c); tmp.put('selected', 'false'); tmp.put('Doctor_Division1__c', row.Doctor_Division1__c); ret_test.put(row.AWS_Data_Id__c, tmp); } PIHelper.PIIntegration piIntegration = PIHelper.getPIIntegrationInfo( 'Agency_Contact__c' ); Map sre = new Map(); sre.put('token', piIntegration.token); sre.put('searchUrl', piIntegration.searchUrl); ret_test.put('sre', sre); return ret_test; // PIPL update Yin Mingjie 21/02/2022 end /* String record_type_id = LightningUtil.getRecordTypeId(department); List doctor_list = LightningUtil.selectContactList(hospital_id, record_type_id); for (Contact row : doctor_list) { Map tmp = new Map(); tmp.put('label', row.Name); tmp.put('value', row.Id); tmp.put('selected', 'false'); tmp.put('Doctor_Division1__c', row.Doctor_Division1__c); ret.add(tmp); } */ // PIPL update Yin Mingjie 21/02/2022 start /* return ret; */ // PIPL update Yin Mingjie 21/02/2022 end } /* @RemoteAction @AuraEnabled public static List> getOpportunityList(String record_type, String hospital_link_id){ List> ret = new List>(); Map space = new Map(); space.put('label', ''); space.put('value', ''); space.put('selected', 'true'); ret.add(space); List opportunity_list = [select id,Name from Agency_Opportunity__c where RecordType__c=:record_type AND Account__c=:hospital_link_id]; for (Agency_Opportunity__c row : opportunity_list) { Map tmp = new Map(); tmp.put('label', row.Name); tmp.put('value', row.Id); tmp.put('selected', 'false'); ret.add(tmp); } return ret; } */ @RemoteAction @AuraEnabled //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 start SupportNeedsc ,String SupportNeedsc public static String saveAgencyReport( String Department_Cateogy, String Purpose_Type, String SupportNeedsc, String Agency_Report_Header, String Agency_Hospital, String Person_In_Charge2, String doctor, String Submit_date, String Product_Category1, String Product_Category2, String Product_Category3, String Result, String Opportunity, String StageName, String oppAmount, String oppOCMPrice, String Close_Forecasted_Date, String Report_Date ) { Agency_Report__c agency_report = makeAgencyReport( Department_Cateogy, Purpose_Type, Agency_Report_Header, Agency_Hospital, Person_In_Charge2, doctor, Submit_date, Product_Category1, Product_Category2, Product_Category3, //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 start SupportNeedsc ,SupportNeedsc Result, Opportunity, StageName, oppAmount, oppOCMPrice, Close_Forecasted_Date, Report_Date, SupportNeedsc ); agency_report = LightningUtil.insertAgencyReport(agency_report); return agency_report.Id; } public static Agency_Report__c makeAgencyReport( String Department_Cateogy, String Purpose_Type, String Agency_Report_Header, String Agency_Hospital, String Person_In_Charge2, String doctor, String Submit_date, String Product_Category1, String Product_Category2, String Product_Category3, //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 start SupportNeeds__c ,String SupportNeedsc String Result, String Opportunity, String StageName, String oppAmount, String oppOCMPrice, String Close_Forecasted_Date, String Report_Date, String SupportNeedsc ) { Agency_Report__c agency_report = new Agency_Report__c(); Date week = Date.valueOf(Submit_date); agency_report.Submit_date__c = week; Date reportDate = Date.valueOf(Report_Date); agency_report.Report_Date__c = reportDate; // MaxActivityDate__c 更新 if (Person_In_Charge2 != '') { agency_report.Person_In_Charge2__c = Person_In_Charge2; //Contact contact = LightningUtil.selectContact(Person_In_Charge2)[0]; //LightningUtil.updateAccMaxActivityDate(contact.AccountId, reportDate); } else { agency_report.Person_In_Charge2__c = null; } if (Agency_Hospital != '') { LightningUtil.updateAccMaxActivityDate(Agency_Hospital, week); } // READ OlympusCalendar__c //OlympusCalendar__c olympus_calendar = [select Id,Date__c from OlympusCalendar__c where Date__c=:week]; //String olympus_calendar_id = olympus_calendar.Id; // WRITE Agency Report__c if (doctor != '') { agency_report.doctor2__c = doctor; } else { agency_report.doctor2__c = null; } if (Department_Cateogy != '') { agency_report.Department_Cateogy__c = Department_Cateogy; } if (Purpose_Type != '') { agency_report.Purpose_Type__c = Purpose_Type; } //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 start if (SupportNeedsc != '') { agency_report.SupportNeeds__c = SupportNeedsc; } //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 end if (Agency_Report_Header != '') { agency_report.Agency_Report_Header__c = Agency_Report_Header; } if (Agency_Hospital != '') { agency_report.Agency_Hospital__c = Agency_Hospital; } //if (olympus_calendar_id != '') { agency_report.Submit_date_Calendar__c = olympus_calendar_id; } if (Product_Category1 != '') { agency_report.Product_Category1__c = Product_Category1; } if (Product_Category2 != '') { agency_report.Product_Category2__c = Product_Category2; } if (Product_Category3 != '') { agency_report.Product_Category3__c = Product_Category3; } if (Result != '') { agency_report.Result__c = Result; } if (Opportunity != '') { agency_report.Opportunity__c = Opportunity; if ( StageName != '' || oppAmount != '' || Close_Forecasted_Date != '' || oppOCMPrice != '' ) { Agency_Opportunity__c aopp = [ SELECT Id, StageName__c, Amount__c, Close_Forecasted_Date__c FROM Agency_Opportunity__c WHERE Id = :Opportunity ]; if (StageName != '') { aopp.StageName__c = StageName; } if (String.isNotBlank(oppAmount)) { Decimal amt = Decimal.valueOf(oppAmount); aopp.Amount__c = amt; } if (String.isNotBlank(oppOCMPrice)) { Decimal amt = Decimal.valueOf(oppOCMPrice); aopp.OCMSale_Price__c = amt; } if (Close_Forecasted_Date != '') { Date closeForecastedDate = Date.valueOf(Close_Forecasted_Date); aopp.Close_Forecasted_Date__c = closeForecastedDate; } update aopp; } } system.debug(agency_report); return agency_report; } @RemoteAction @AuraEnabled public static String editAgencyReport( String Agency_Report_Id, String Department_Cateogy, String Purpose_Type, String SupportNeedsc, String Agency_Report_Header, String Agency_Hospital, String Person_In_Charge2, String doctor, String Submit_date, String Product_Category1, String Product_Category2, String Product_Category3, //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 start SupportNeeds__c ,String SupportNeedsc String Result, String Opportunity, String StageName, String oppAmount, String oppOCMPrice, String Close_Forecasted_Date, String Report_Date ) { if (String.isBlank(Agency_Report_Id)) { return null; } //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 start SupportNeeds__c ,SupportNeeds__c // Agency_Report__c agency_report = [select Id, Name, Department_Cateogy__c, Purpose_Type__c,SupportNeeds__c, Agency_Hospital__c, // Person_In_Charge2__c, doctor2__c, Submit_date__c, Product_Category__c, Result__c, visitor_title__c, Opportunity__c // from Agency_Report__c where id=:Agency_Report_Id]; Agency_Report__c agency_report = new Agency_Report__c(); if (Test.isRunningTest()) { List agency_report_tests = [ SELECT Id, Name, Department_Cateogy__c, Purpose_Type__c, SupportNeeds__c, Agency_Hospital__c, Person_In_Charge2__c, doctor2__c, Submit_date__c, Product_Category__c, Result__c, visitor_title__c, Opportunity__c FROM Agency_Report__c LIMIT 1 ]; agency_report = agency_report_tests[0]; } else { agency_report = [ SELECT Id, Name, Department_Cateogy__c, Purpose_Type__c, SupportNeeds__c, Agency_Hospital__c, Person_In_Charge2__c, doctor2__c, Submit_date__c, Product_Category__c, Result__c, visitor_title__c, Opportunity__c FROM Agency_Report__c WHERE id = :Agency_Report_Id ]; } Date week = Date.valueOf(Submit_date); agency_report.Submit_date__c = week; Date reportDate = Date.valueOf(Report_Date); agency_report.Report_Date__c = reportDate; // MaxActivityDate__c 更新 if (Person_In_Charge2 != '') { agency_report.Person_In_Charge2__c = Person_In_Charge2; //Contact contact = LightningUtil.selectContact(Person_In_Charge2)[0]; //LightningUtil.updateAccMaxActivityDate(contact.AccountId, reportDate); } else { agency_report.Person_In_Charge2__c = null; } if (Agency_Hospital != '') { LightningUtil.updateAccMaxActivityDate(Agency_Hospital, week); } system.debug('Purpose_Type+++==++===' + Purpose_Type); // WRITE Agency Report__c if (doctor != '') { agency_report.doctor2__c = doctor; } else { agency_report.doctor2__c = null; } if (Department_Cateogy != '') { agency_report.Department_Cateogy__c = Department_Cateogy; } else { agency_report.Department_Cateogy__c = null; } if (Purpose_Type != '') { agency_report.Purpose_Type__c = Purpose_Type; } else { agency_report.Purpose_Type__c = null; } //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 start SupportNeeds__c if (SupportNeedsc != '') { agency_report.SupportNeeds__c = SupportNeedsc; } else { agency_report.SupportNeeds__c = null; } if (Agency_Hospital != '') { agency_report.Agency_Hospital__c = Agency_Hospital; } else { agency_report.Agency_Hospital__c = null; } if (Product_Category1 != '') { agency_report.Product_Category1__c = Product_Category1; } else { agency_report.Product_Category1__c = null; } if (Product_Category2 != '') { agency_report.Product_Category2__c = Product_Category2; } else { agency_report.Product_Category2__c = null; } if (Product_Category3 != '') { agency_report.Product_Category3__c = Product_Category3; } else { agency_report.Product_Category3__c = null; } //if (Product_Category != '') { agency_report.Product_Category__c = Product_Category; } else { agency_report.Product_Category__c = null; } if (Result != '') { agency_report.Result__c = Result; } else { agency_report.Result__c = null; } //if (Opportunity != '') { agency_report.Opportunity__c = Opportunity; } else { agency_report.Opportunity__c = null; } if (Opportunity != '') { agency_report.Opportunity__c = Opportunity; if ( StageName != '' || oppAmount != '' || Close_Forecasted_Date != '' || oppOCMPrice != '' ) { Agency_Opportunity__c aopp = [ SELECT Id, StageName__c, Amount__c, Close_Forecasted_Date__c FROM Agency_Opportunity__c WHERE Id = :Opportunity ]; if (StageName != '') { aopp.StageName__c = StageName; } if (String.isNotBlank(oppAmount)) { Decimal amt = Decimal.valueOf(oppAmount); aopp.Amount__c = amt; } if (String.isNotBlank(oppOCMPrice)) { Decimal amt = Decimal.valueOf(oppOCMPrice); aopp.OCMSale_Price__c = amt; } if (Close_Forecasted_Date != '') { Date closeForecastedDate = Date.valueOf(Close_Forecasted_Date); aopp.Close_Forecasted_Date__c = closeForecastedDate; } update aopp; } } else { agency_report.Opportunity__c = null; } system.debug(agency_report); agency_report = LightningUtil.updateAgencyReport(agency_report); return agency_report.Id; } @RemoteAction @AuraEnabled public static List selectOpportunityByIdAndHospitalLinkId( String opportunity_id, String agency_hospital_link_id ) { List ret = new List(); ret = LightningUtil.selectOpportunityByIdAndHospitalLinkId( opportunity_id, agency_hospital_link_id ); return ret; } @RemoteAction @AuraEnabled public static WeeklyReportCmp getReports(String date_str, String person_str) { WeeklyReportCmp li = new WeeklyReportCmp(); li.get_reports(date_str, person_str); return li; } public void get_reports(String date_str, String person_str) { // 週報データを取得 Date week = Date.valueOf(date_str); this.reports = LightningUtil.selectAgencyReport(week, person_str); } @RemoteAction @AuraEnabled public static List getReportsById(String report_id) { List ret = new List(); ret = LightningUtil.selectAgencyReportById(report_id); return ret; } // 批量添加周报by vivek start @RemoteAction @AuraEnabled public static List getReportsByDate( String date1, String date2 ) { Date date1_date = Date.valueOf(date1); Date date2_date = Date.valueOf(date2); WeeklyReportCmp li = new WeeklyReportCmp(); // li.get_reports(date_str, person_str); // return li; List conMList = LightningUtil.selectAgencyPerson(); // LightningUtil.selectAgencyPerson(); System.debug('=====' + conMList); // List reportlist = [Select Id, Name, Report_Date__c, Product_Category1__r.Name, Product_Category2__r.Name, Product_Category3__r.Name, Product_Category1__c, Product_Category2__c, Product_Category3__c, Department_Cateogy__c, Purpose_Type__c, Agency_Report_Header__c, Agency_Hospital__r.Name, Agency_Hospital__r.Hospital__c, OppName__c, // Person_In_Charge2__c, Person_In_Charge2__r.Name, doctor2__c, doctor2__r.Name, Submit_date__c, // Product_Category__c, Product_Category__r.Name, Result__c, visitor_title__c, Opportunity__c, Opportunity__r.Name // From Agency_Report__c // where Person_In_Charge2__c in :conMList and Report_Date__c >= :date1_date and Report_Date__c <= :date2_date ]; // return reportlist; return LightningUtil.selectMAgencyReport(date1_date, date2_date, conMList); } public List selectMAgencyPerson() { String login_user_id = UserInfo.getUserId(); // return [select id, Name, Agency_User__c from contact where Agency_User__c = true and Isactive__c = '有效' and AccountId in (select AccountId from User where id=:login_user_id)]; // return [select id, Name, Agency_User__c from contact where Agency_User__c = true and AccountId in (select AccountId from User where id=:login_user_id)]; return [SELECT id, Name, Agency_User__c FROM contact]; } // fy 导入 20220424 start public class GeDatass { public String dataId; public String doctorDivision1; //public String doctorDivision1Encrypt; //zhj MEBG新方案改造 2022-11-29 public Integer isDelete; public String name; //public String nameEncrypt; //zhj MEBG新方案改造 2022-11-29 public String sfRecordId; public String type; //public String typeEncrypt; //zhj MEBG新方案改造 2022-11-29 } @AuraEnabled public static String processDataAWSId(String fileData) { System.debug('fileData:::' + filedata); String errorMag = ''; // 创建周报 try { if (fileData != null) { String[] fileLines = new List{}; fileLines = fileData.split('\n'); // 经销商医院名称list List ahlNameList = new List(); //for content system.debug('fileLines.size()==============>' + fileLines.size()); for (Integer i = 1, j = fileLines.size(); i < j; i++) { List inputvalues = new List(); inputvalues = fileLines[i].split(','); if (inputvalues != null) { if (inputvalues[2] == '' || inputvalues[2] == null) { errorMag += 'error1 第' + i + '行数据医院不能为空'; } ahlNameList.add(inputvalues[2]); } } // 经销商医院的ocsm医院id的list List ahlOcsmIdList = new List(); System.debug('ahlNameList = ' + ahlNameList); List ahlList = [ SELECT id, name, Hospital__c, MaxActivityDate__c FROM Agency_Hospital_Link__c WHERE name = :ahlNameList AND Agency_Campaign_Obj__c = TRUE ]; for (Agency_Hospital_Link__c ahl : ahlList) { ahlOcsmIdList.add(ahl.Hospital__c); } List doctor2list = new List(); System.debug('ahlOcsmIdList = ' + ahlOcsmIdList); if (!Test.isRunningTest()) doctor2list = [ SELECT id, Name, Doctor_Division1__c, Type__c, Agency_Hospital__c, AWS_Data_Id__c FROM Agency_Contact__c WHERE Hospital_ID18__c = :ahlOcsmIdList ORDER BY Name ]; //zhj 新方案改造 2022-12-21 去掉Name_Encrypted__c if (errorMag != '') { return errorMag; } String doctor2listStr = JSON.serialize(doctor2list); System.debug('doctor2listStr = ' + doctor2listStr); return doctor2listStr; } } catch (Exception e) { System.debug('exception' + e); return e.getLineNumber() + 'exception:' + e; } return 'success'; } // fy 导入 20220424 end @AuraEnabled // fy 导入 20220424 start String sobjectName,List fields, // public static String processData(String fileData,String Agency_ContactListjson) { public static String processData( String fileData, String sobjectName, List fields ) { DateTime now = System.now(); System.debug('当前时间:::' + now); System.debug('fileData:::' + filedata); System.debug('sobjectName:::' + sobjectName); System.debug('fields:::' + fields); // System.debug('Agency_ContactListjson::::'+Agency_ContactListjson); String errorMag = ''; // 创建周报 try { if (fileData != null) { // List Agency_ContactList = (List)JSON.deserialize(Agency_ContactListjson,List.class); // System.debug('Agency_ContactList::::'+Agency_ContactList); // Map Agency_ContactMap = new Map(); // for(GeDatass agconobj :Agency_ContactList){ // Agency_ContactMap.put(agconobj.name.replace(' ',''),agconobj.dataId); // } String[] fileLines = new List{}; fileLines = fileData.split('\n'); // 担当名称的list List nameList = new List(); // 报告日的list List dateList = new List(); // List s_dateList = new List(); // 导入的数据 List> inputList = new List>(); // 经销商医院名称list List ahlNameList = new List(); // 科室Set Set departmentSet = new Set(); // 经销商询价名称list // List ahlOppNameList = new List(); //for content system.debug('fileLines.size()==============>' + fileLines.size()); for (Integer i = 1, j = fileLines.size(); i < j; i++) { system.debug('for2022161329'); List inputvalues = new List(); inputvalues = fileLines[i].split(','); System.debug('inputvalues++' + inputvalues); if (inputvalues != null) { system.debug('if2022161333'); if (inputvalues[0] == '' || inputvalues[0] == null) { // return 'error1 第'+i+'行数据担当不能为空'; errorMag += 'error1 第' + i + '行数据担当不能为空'; errorMag += '='; } if (inputvalues[1] == '' || inputvalues[1] == null) { // return 'error1 第'+i+'行数据活动日不能为空'; errorMag += 'error1 第' + i + '行数据活动日不能为空'; errorMag += '='; } //SWAG-C7AASP 【委托】DAMS系统周报补录时间调整 2022-1-10 pk start List R = new List(); R = inputvalues[1].split('/'); system.debug('R202216' + R); Date rDate = Date.newInstance( Integer.Valueof(R[0]), Integer.Valueof(R[1]), Integer.Valueof(R[2]) ); system.debug('rDate202216' + rDate); Date start = Date.today().addMonths(-1); Date startDay = start.toStartOfWeek(); Date firstDayOfweek = System.today().toStartOfWeek(); Date endDay = firstDayOfweek.addDays(6); if (rDate > endDay || rDate < startDay) { system.debug('rDate >= ssDate'); // return 'error1 第'+i+'行数据活动日不能为空'; errorMag += 'error1 第' + i + '行数据,导入周报仅可补报最近一月周报'; errorMag += '='; } //SWAG-C7AASP 【委托】DAMS系统周报补录时间调整 2022-1-10 pk end if (inputvalues[2] == '' || inputvalues[2] == null) { // return 'error1 第'+i+'行数据医院不能为空'; errorMag += 'error1 第' + i + '行数据医院不能为空'; errorMag += '='; } if (inputvalues[3] == '' || inputvalues[3] == null) { // return 'error1 第'+i+'行数据科室不能为空'; errorMag += 'error1 第' + i + '行数据科室不能为空'; errorMag += '='; } String departmentstr = GetDepartment_Cateogy(inputvalues[3]); if ( departmentstr == 'no' && inputvalues[3] != '' && inputvalues[3] != null ) { // return 'error3 第'+i+'行数据科室选项列表的值'+inputvalues[3]+'不存在'; errorMag += 'error3 第' + i + '行数据科室选项列表的值' + inputvalues[3] + '不存在'; errorMag += '='; } if (inputvalues[4] == '' || inputvalues[4] == null) { // return 'error1 第'+i+'行数据拜访人不能为空'; errorMag += 'error1 第' + i + '行数据拜访人不能为空'; errorMag += '='; } if (inputvalues[5] == '' || inputvalues[5] == null) { // return 'error1 第'+i+'行数据产品区分1不能为空'; errorMag += 'error1 第' + i + '行数据产品区分1不能为空'; errorMag += '='; } if ( (inputvalues[6] != '' && inputvalues[6] != null) && inputvalues[5] == inputvalues[6] ) { // return 'error1 第'+i+'行数据产品区分1和产品区分2的值不能重复'; errorMag += 'error1 第' + i + '行数据产品区分1和产品区分2的值不能重复'; errorMag += '='; } if ( (inputvalues[7] != '' && inputvalues[7] != null) && inputvalues[5] == inputvalues[7] ) { // return 'error1 第'+i+'行数据产品区分1和产品区分3的值不能重复'; errorMag += 'error1 第' + i + '行数据产品区分1和产品区分3的值不能重复'; errorMag += '='; } if ( (inputvalues[6] != '' && inputvalues[6] != null) && (inputvalues[7] != '' && inputvalues[7] != null) && inputvalues[6] == inputvalues[7] ) { // return 'error1 第'+i+'行数据产品区分2和产品区分3的值不能重复'; errorMag += 'error1 第' + i + '行数据产品区分2和产品区分3的值不能重复'; errorMag += '='; } if (inputvalues[8] == '' || inputvalues[8] == null) { // return 'error1 第'+i+'行数据活动区分不能为空'; errorMag += 'error1 第' + i + '行数据活动区分不能为空'; errorMag += '='; } boolean purposeType = GetPurposeType(inputvalues[8]); if ( !purposeType && inputvalues[8] != '' && inputvalues[8] != null ) { // return 'error3 第'+i+'行数据活动区分选项列表的值'+inputvalues[8]+'不存在'; errorMag += 'error3 第' + i + '行数据活动区分选项列表的值' + inputvalues[8] + '不存在'; errorMag += '='; } // if(inputvalues[9] == '\r' || inputvalues[9] == null){ // return 'error1 结果不能为空'; // } if ( inputvalues[8] == '询价挖掘-OPD' || inputvalues[8] == '询价挖掘-SIS' || inputvalues[8] == '询价推进-OPD' || inputvalues[8] == '询价推进-SIS' ) { System.debug(']]]]]1' + inputvalues[9] + '====='); if (inputvalues[9] == '\r') { // return 'error5 第'+i+'行数据当活动区分为'+inputvalues[8]+'结果不能为空'; errorMag += 'error5 第' + i + '行数据当活动区分为' + inputvalues[8] + '结果不能为空'; errorMag += '='; } } // if(inputvalues[9] != '\r' && getResultlist(inputvalues[9])){ if (inputvalues[9] != '' && getResultlist(inputvalues[9])) { // return 'error3 第'+i+'行数据结果选项列表的值'+inputvalues[9]+'不存在'; errorMag += 'error3 第' + i + '行数据结果选项列表的值' + inputvalues[9] + '不存在'; errorMag += '='; } system.debug('inputvalues[0]=================>' + inputvalues[0]); system.debug('inputvalues[1]=================>' + inputvalues[1]); system.debug('inputvalues[2]=================>' + inputvalues[2]); system.debug('inputvalues[3]=================>' + inputvalues[3]); system.debug('inputvalues[4]=================>' + inputvalues[4]); system.debug('inputvalues[5]=================>' + inputvalues[5]); system.debug('inputvalues[6]=================>' + inputvalues[6]); system.debug('inputvalues[7]=================>' + inputvalues[7]); system.debug('inputvalues[8]=================>' + inputvalues[8]); system.debug('inputvalues[9]=================>' + inputvalues[9]); // system.debug('inputvalues[10]=================>'+inputvalues[10]); nameList.add(inputvalues[0]); dateList.add(Date.valueOf(inputvalues[1].replace('/', '-'))); ahlNameList.add(inputvalues[2]); departmentSet.add( '%' + GetDepartment_Cateogy(inputvalues[3]) + '%' + '-' + GetEPurposeType(inputvalues[8]) ); inputList.add(inputvalues); } } system.debug('snduksbdnjsvbdskjv'); // 担当名称匹配的map Map nameIdMap = new Map(); Map nameConMap = new Map(); // 经销商医院名称匹配的map Map ahlMap = new Map(); // 产品区分的map Map protypeMap = new Map(); // 经销商医院的ocsm医院id的list List ahlOcsmIdList = new List(); // 经销商医院id的List List ahlIdList = new List(); // 获取每周第一天的map Map dateMap = new Map(); // 根据日期获取olympus日历id的map Map dateIdMap = new Map(); // 根据经销商医院的ocsm医院获取的所有.客户人员的信息的名称和id的map Map doctor2Map = new Map(); // 经销商询价的map Map aoMap = new Map(); // 科室和产品区分关系map Map>> impProMap = new Map>>(); impProMap = getImplProductList(departmentSet); System.debug('---===---===---===' + impProMap); // return nameList[0]; // List conList = [select id,name from Contact where name = :nameList]; // List conList = [select id,name from Contact]; List conList = LightningUtil.selectAgencyPerson(); System.debug('---===---===---=====' + conList); List olympusDateList = [ SELECT Id, Date__c, FirstDayOfWeek__c, DayOfTheWeek__c FROM OlympusCalendar__c WHERE Date__c = :dateList ]; // test用 // String testuse = ''; // testuse += '====='+ahlNameList; List ahlList = [ SELECT id, name, Hospital__c, MaxActivityDate__c FROM Agency_Hospital_Link__c WHERE name = :ahlNameList AND Agency_Campaign_Obj__c = TRUE ]; // List ahlList = [select id,name,Hospital__c,MaxActivityDate__c from Agency_Hospital_Link__c ]; // List proTypeList = [select id,name from ProductTypes__c]; for (OlympusCalendar__c olym : olympusDateList) { if (olym.DayOfTheWeek__c == 'Sun') { dateMap.put(olym.Date__c, olym.Date__c.addDays(1)); } else { dateMap.put(olym.Date__c, olym.FirstDayOfWeek__c); } } System.debug('x' + dateMap); List olympusIdList = [ SELECT Id, Date__c, FirstDayOfWeek__c FROM OlympusCalendar__c WHERE Date__c = :dateMap.values() ]; for (OlympusCalendar__c olym : olympusIdList) { dateIdMap.put(olym.FirstDayOfWeek__c, olym.id); } System.debug('dateIdMap====' + dateIdMap); for (Contact con : conList) { nameIdMap.put(con.Name.replace(' ', ''), con.Id); nameConMap.put(con.Id, con.Name); } // testuse += '======'+ahlList; // return testuse; for (Agency_Hospital_Link__c ahl : ahlList) { ahlMap.put(ahl.Name, ahl); ahlOcsmIdList.add(ahl.Hospital__c); ahlIdList.add(ahl.Id); } // for(ProductTypes__c protype : proTypeList){ // protypeMap.put(protype.Name, protype.Id); // } //fy 20220424 start AWS_Data_Id__c if (!Test.isRunningTest()) { List doctor2list = [ SELECT id, Name, Doctor_Division1__c, Type__c, Agency_Hospital__c, AWS_Data_Id__c FROM Agency_Contact__c WHERE Hospital_ID18__c = :ahlOcsmIdList ORDER BY Name ]; //zhj 新方案改造 2022-12-21 去掉Name_Encrypted__c for (Agency_Contact__c ac : doctor2list) { //fy 20220424 start // doctor2Map.put(ac.AWS_Data_Id__c, ac.Id); // doctor2Map.put(ac.Name.replace(' ',''), ac.Id); //doctor2Map.put(ac.Name_Encrypted__c, ac.Id); doctor2Map.put(ac.AWS_Data_Id__c, ac.Id); //zhj 新方案改造 不再存的nameEncrpt而是awsdataid 2022-12-21 //fy 20220424 end } } // List aoList = [select id,name,StageName__c,Amount__c,OCMSale_Price__c,Close_Forecasted_Date__c,Agency_Hospital__c from Agency_Opportunity__c where Agency_Hospital__c = :ahlIdList and name = :ahlOppNameList]; // for(Agency_Opportunity__c ao : aoList){ // aoMap.put(ao.Name, ao); // } System.debug('nameIdMap====' + nameIdMap); // 创建周报 List agency_report_headerlist = new List(); Map agency_report_headerMap = new Map(); for (List lineList : inputList) { Date week = Date.today(); String s_agency = null; String s_agencyname = null; System.debug('dateMap====' + dateMap); // System.debug('lineList[0]====不等于空'+lineList[1]); if ( dateMap.get(Date.valueOf(lineList[1].replace('/', '-'))) != null ) { System.debug('dateMap====不等于空'); week = dateMap.get(Date.valueOf(lineList[1].replace('/', '-'))); System.debug('====' + week); } System.debug('lineList[0].replace()' + lineList[0].replace(' ', '')); if (nameIdMap.get(lineList[0].replace(' ', '')) != null) { System.debug('nameIdMap====不等于空'); s_agency = nameIdMap.get(lineList[0].replace(' ', '')); s_agencyname = nameConMap.get( nameIdMap.get(lineList[0].replace(' ', '')) ); System.debug('====' + s_agency); } // if(s_agency == null || s_agencyname == null){ // // return 'error0 担当 '+lineList[0]+'填写不正确'; // errorMag += 'error0 担当 '+lineList[0]+'不存在'; // errorMag += '='; // } Agency_Report_Header__c agency_report_header = new Agency_Report_Header__c(); // agency_report_header.Name = lineList[0] + ' (' + week.format() + ')'; agency_report_header.Name = s_agencyname + ' (' + week.format().replace('/', '-') + ')'; agency_report_header.HeaderInputKey__c = createHeader(week, s_agency); agency_report_header.Week__c = week; agency_report_header.Agency_Person2__c = s_agency; if (dateIdMap.containsKey(week)) { agency_report_header.OlympusDate__c = dateIdMap.get(week); } if ( s_agencyname != null && s_agencyname != '' && s_agencyname != 'null' ) { agency_report_headerMap.put( agency_report_header.HeaderInputKey__c, agency_report_header ); } } agency_report_headerlist = agency_report_headerMap.values(); System.debug('===========' + agency_report_headerlist + ''); // upsert agency_report_headerlist Agency_Report_Header__c.HeaderInputKey__c; if (agency_report_headerlist.size() > 0) { LightningUtil.upsertMAgencyReportHeader(agency_report_headerlist); } List arList = new List(); Integer hang = 1; for (List lineList : inputList) { // 创建周报明细 Date week = null; String s_agency = null; System.debug('dateMap====' + dateMap); System.debug('lineList[0]====不等于空' + lineList[1]); if ( dateMap.get(Date.valueOf(lineList[1].replace('/', '-'))) != null ) { System.debug('dateMap====不等于空'); week = dateMap.get(Date.valueOf(lineList[1].replace('/', '-'))); System.debug('====' + week); } if (nameIdMap.get(lineList[0].replace(' ', '')) != null) { System.debug('nameIdMap====不等于空'); s_agency = nameIdMap.get(lineList[0].replace(' ', '')); System.debug('====' + s_agency); } Agency_Report__c agencyReport = new Agency_Report__c(); if (week == null && lineList[1] != '' && lineList[1] != null) { // return 'error2 第'+hang+'行数据报告日'+lineList[1]+'填写有误'; errorMag += 'error2 第' + hang + '行数据报告日' + lineList[1] + '填写有误'; errorMag += '='; } agencyReport.Submit_date__c = week; // 提出周 if ( (s_agency == null || s_agency == '') && lineList[0] != '' && lineList[0] != null ) { // return 'error2 第'+hang+'行数据担当'+lineList[0]+'不存在'; errorMag += 'error2 第' + hang + '行数据担当' + lineList[0] + '不存在'; errorMag += '='; } agencyReport.Person_In_Charge2__c = s_agency; // 担当 if (lineList[1] != null && lineList[1] != '') { agencyReport.Report_Date__c = Date.valueOf( lineList[1].replace('/', '-') ); // 活动日 } if (ahlMap.containsKey(lineList[2])) { agencyReport.Agency_Hospital__c = ahlMap.get(lineList[2]).Id; //经销商医院 // 更新经销商医院的最新周 ahlMap.get(lineList[2]).MaxActivityDate__c = week; } else { if (lineList[2] != '' && lineList[2] != null) { // return 'error2 第'+hang+'行数据经销商医院'+lineList[2]+'不存在'; errorMag += 'error2 第' + hang + '行数据经销商医院' + lineList[2] + '不存在'; errorMag += '='; } } String departmentE = GetDepartment_Cateogy(lineList[3]); if (departmentE != 'no') { agencyReport.Department_Cateogy__c = departmentE; // 科室 } else { // return 'error2 第'+hang+'行数据科室'+lineList[3]+'不存在'; // errorMag += 'error2 第'+hang+'行数据科室'+lineList[3]+'不存在'; // errorMag += '='; } //fy 20220424 start // if(doctor2Map.containsKey(lineList[4].replace(' ',''))){ if (doctor2Map.containsKey(lineList[4])) { // if(Agency_ContactMap.containsKey(lineList[4].replace(' ',''))){ // if(doctor2Map.containsKey(Agency_ContactMap.get(lineList[4].replace(' ','')))){ // agencyReport.doctor2__c = doctor2Map.get(lineList[4].replace(' ','')); // 拜访人 agencyReport.doctor2__c = doctor2Map.get(lineList[4]); // 拜访人 // agencyReport.doctor2__c = doctor2Map.get(Agency_ContactMap.get(lineList[4].replace(' ',''))); // 拜访人 // } } else { if (lineList[4] != '' && lineList[4] != null) { // return 'error2 第'+hang+'行数据拜访人'+lineList[4]+'不存在'; errorMag += 'error2 第' + hang + '行数据拜访人' + lineList[4] + '不存在'; errorMag += '='; } } if (GetPurposeType(lineList[8])) { agencyReport.Purpose_Type__c = lineList[8]; // 活动区分 } else { // return 'error3 第'+hang+'行数据活动区分选项列表值'+lineList[8]+'不存在'; // errorMag += 'error3 第'+hang+'行数据活动区分选项列表值'+lineList[8]+'不存在'; // errorMag += '='; } // 科室产品区分关系判断 // 如果能找到,就是正确的 String departandprokey = '%' + GetDepartment_Cateogy(lineList[3]) + '%' + '-' + GetEPurposeType(lineList[8]); System.debug('---===---===---===' + departandprokey); if (impProMap.containsKey(departandprokey)) { System.debug( '---===---===---===' + ifTrueProduct(impProMap.get(departandprokey), lineList[5]) ); if ( ifTrueProduct(impProMap.get(departandprokey), lineList[5]) != '' ) { System.debug(']]]不等于空进入'); agencyReport.Product_Category1__c = ifTrueProduct( impProMap.get(departandprokey), lineList[5] ); } else { System.debug(']]]等于空进入'); // return 'error4 第'+hang+'行数据产品区分1的赋值不正确'+lineList[5]; errorMag += 'error4 第' + hang + '行数据产品区分1的赋值不正确' + lineList[5]; errorMag += '='; } if (lineList[6] != '' && lineList[6] != null) { if ( ifTrueProduct(impProMap.get(departandprokey), lineList[6]) != '' ) { agencyReport.Product_Category2__c = ifTrueProduct( impProMap.get(departandprokey), lineList[6] ); } else { // return 'error4 第'+hang+'行数据产品区分2的赋值不正确'+lineList[6]; errorMag += 'error4 第' + hang + '行数据产品区分2的赋值不正确' + lineList[6]; errorMag += '='; } } if (lineList[7] != '' && lineList[7] != null) { if ( ifTrueProduct(impProMap.get(departandprokey), lineList[7]) != '' ) { agencyReport.Product_Category3__c = ifTrueProduct( impProMap.get(departandprokey), lineList[7] ); } else { // return 'error4 第'+hang+'行数据产品区分3的赋值不正确'+lineList[7]; errorMag += 'error4 第' + hang + '行数据产品区分3的赋值不正确' + lineList[7]; errorMag += '='; } } } // 通过map 科室,产品区分名 判断取值是否符合要求 // if(protypeMap.containsKey(lineList[5])){ // agencyReport.Product_Category1__c = protypeMap.get(lineList[5]);// 产品区分1 // } // if(protypeMap.containsKey(lineList[6])){ // agencyReport.Product_Category2__c = protypeMap.get(lineList[6]);// 产品区分2 // } // if(protypeMap.containsKey(lineList[7])){ // agencyReport.Product_Category3__c = protypeMap.get(lineList[7]);// 产品区分3 // } agencyReport.Result__c = lineList[9]; if (lineList.size() == 11) { if (lineList[10] != null && lineList[10] != '') { agencyReport.SupportNeeds__c = lineList[10]; } } String headerStr = createHeader(week, s_agency); if (agency_report_headerMap.containsKey(headerStr)) { agencyReport.Agency_Report_Header__c = agency_report_headerMap.get( headerStr ) .Id; // 周报一览 } // if(aoMap.containsKey(lineList[6])){ // agencyReport.Opportunity__c = aoMap.get(lineList[6]).Id; // 经销商询价 // // 经销商询价更新字段 // aoMap.get(lineList[6]).StageName__c = lineList[5]; // 询价阶段 // aoMap.get(lineList[6]).Amount__c = Decimal.valueOf(lineList[6]); // 医院采购预算(含税,元) // aoMap.get(lineList[6]).OCMSale_Price__c = Decimal.valueOf(lineList[7]); // 订货金额(含税,元) // aoMap.get(lineList[6]).Close_Forecasted_Date__c = Date.valueOf(lineList[8].replace('/','-')); // 预测于OLY签约日 // } hang++; arList.add(agencyReport); } if (errorMag != '') { return errorMag; } // 更新经销商意愿的最新周 if (ahlMap.values().size() > 0) { update ahlMap.values(); } // 更新经销商询价 // if(aoMap.values().size() > 0 ){ // update aoMap.values(); // } // 新增周报明细 if (arList.size() > 0) { // insert arList; LightningUtil.insertMAgencyReport(arList); } } return 'success'; } catch (Exception e) { System.debug('exception' + e); return e.getLineNumber() + 'exception:' + e; } return 'success'; } // 创建唯一键 public static String createHeader(Date s_date, String nameid) { String str = s_date.format(); String str1 = str.replace('/', ''); return nameid + ':' + str1; } // 科室对应翻译 public static String GetDepartment_Cateogy(String department) { String departmentE = 'no'; if (department == '呼吸科') { departmentE = 'BF'; } if (department == '耳鼻喉科') { departmentE = 'ENT'; } if (department == 'ET耗材') { departmentE = 'ET'; } if (department == '消化科') { departmentE = 'GI'; } if (department == '普外科') { departmentE = 'GS'; } if (department == '妇科') { departmentE = 'GYN'; } if (department == '其他') { departmentE = 'OTH'; } if (department == '泌尿科') { departmentE = 'URO'; } return departmentE; } // 判断活动分区是否存在 public static boolean GetPurposeType(String purposeType) { Schema.DescribeFieldResult fieldResult = Agency_Report__c.Purpose_Type__c.getDescribe(); List ple = fieldResult.getPicklistValues(); for (Schema.PicklistEntry pickListVal : ple) { if (pickListVal.getValue() == purposeType) { return true; } } return false; } public static boolean getResultlist(String resultlist) { system.debug('resultlist===============>' + resultlist); Schema.DescribeFieldResult fieldResult = Agency_Report__c.Result__c.getDescribe(); List ple = fieldResult.getPicklistValues(); for (Schema.PicklistEntry pickListVal : ple) { System.debug( 'weixiao' + resultlist.trim() + '111111' + pickListVal.getValue() + '222222' ); string temp = string.ValueOf(pickListVal.getValue()); if (temp.equals(resultlist.trim())) { // if(pickListVal.getValue().equals(resultlist)){ System.debug( 'weixiaoweixiao' + resultlist + '' + pickListVal.getValue() ); return false; } } return true; } public static String GetEPurposeType(String purposeType) { // String purpose_Type=''; if (purposeType.substring(purposeType.length() - 3) == 'OPD') { purposeType = 'OPD'; } else if (purposeType.substring(purposeType.length() - 3) == 'SIS') { purposeType = 'SIS'; } else { purposeType = ''; } return purposeType; } // 判断产品区分是否满足要求 public static String ifTrueProduct( List> prolist, String str ) { system.debug('=ifTrueProduct==============ifTrueProduct=========' + str); system.debug('=prolist==============prolist=========' + prolist); for (Map strmap : prolist) { System.debug('---===---===---===' + str + '===' + strmap.get('label')); if (strmap.get('label') == str) { return strmap.get('value'); } } return ''; } // 获取导入数据的科室和产品区分的匹配 public static Map>> getImplProductList( Set ptdc ) { Map>> impProMap = new Map>>(); List dc = new List(ptdc); if (dc.size() > 0) { List ptList1 = new List(); List dcList = dc[0].split('-'); if (dcList.size() > 1) { ptList1 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] AND OPD_SIS_Type__c = :dcList[1] ]; } else { ptList1 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] ]; } List> impProList = new List>(); for (ProductTypes__c pt : ptList1) { Map productMap = new Map(); productMap.put('label', pt.Name); productMap.put('value', pt.Id); impProList.add(productMap); } impProMap.put(dc[0], impProList); } if (dc.size() > 1) { List ptList2 = new List(); List dcList = dc[1].split('-'); if (dcList.size() > 1) { ptList2 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] AND OPD_SIS_Type__c = :dcList[1] ]; } else { ptList2 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] ]; } List> impProList = new List>(); for (ProductTypes__c pt : ptList2) { Map productMap = new Map(); productMap.put('label', pt.Name); productMap.put('value', pt.Id); impProList.add(productMap); } impProMap.put(dc[1], impProList); } if (dc.size() > 2) { List ptList3 = new List(); List dcList = dc[2].split('-'); if (dcList.size() > 1) { ptList3 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] AND OPD_SIS_Type__c = :dcList[1] ]; } else { ptList3 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] ]; } List> impProList = new List>(); for (ProductTypes__c pt : ptList3) { Map productMap = new Map(); productMap.put('label', pt.Name); productMap.put('value', pt.Id); impProList.add(productMap); } impProMap.put(dc[2], impProList); } if (dc.size() > 3) { List ptList4 = new List(); List dcList = dc[3].split('-'); if (dcList.size() > 1) { ptList4 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] AND OPD_SIS_Type__c = :dcList[1] ]; } else { ptList4 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] ]; } List> impProList = new List>(); for (ProductTypes__c pt : ptList4) { Map productMap = new Map(); productMap.put('label', pt.Name); productMap.put('value', pt.Id); impProList.add(productMap); } impProMap.put(dc[3], impProList); } if (dc.size() > 4) { List ptList5 = new List(); List dcList = dc[4].split('-'); if (dcList.size() > 1) { ptList5 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] AND OPD_SIS_Type__c = :dcList[1] ]; } else { ptList5 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] ]; } List> impProList = new List>(); for (ProductTypes__c pt : ptList5) { Map productMap = new Map(); productMap.put('label', pt.Name); productMap.put('value', pt.Id); impProList.add(productMap); } impProMap.put(dc[4], impProList); } if (dc.size() > 5) { List ptList6 = new List(); List dcList = dc[5].split('-'); if (dcList.size() > 1) { ptList6 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] AND OPD_SIS_Type__c = :dcList[1] ]; } else { ptList6 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] ]; } List> impProList = new List>(); for (ProductTypes__c pt : ptList6) { Map productMap = new Map(); productMap.put('label', pt.Name); productMap.put('value', pt.Id); impProList.add(productMap); } impProMap.put(dc[5], impProList); } if (dc.size() > 6) { List ptList7 = new List(); List dcList = dc[6].split('-'); if (dcList.size() > 1) { ptList7 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] AND OPD_SIS_Type__c = :dcList[1] ]; } else { ptList7 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] ]; } List> impProList = new List>(); for (ProductTypes__c pt : ptList7) { Map productMap = new Map(); productMap.put('label', pt.Name); productMap.put('value', pt.Id); impProList.add(productMap); } impProMap.put(dc[6], impProList); } if (dc.size() > 7) { List ptList8 = new List(); List dcList = dc[7].split('-'); if (dcList.size() > 1) { ptList8 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] AND OPD_SIS_Type__c = :dcList[1] ]; } else { ptList8 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] ]; } List> impProList = new List>(); for (ProductTypes__c pt : ptList8) { Map productMap = new Map(); productMap.put('label', pt.Name); productMap.put('value', pt.Id); impProList.add(productMap); } impProMap.put(dc[7], impProList); } if (dc.size() > 8) { List ptList9 = new List(); List dcList = dc[8].split('-'); if (dcList.size() > 1) { ptList9 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] AND OPD_SIS_Type__c = :dcList[1] ]; } else { ptList9 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] ]; } List> impProList = new List>(); for (ProductTypes__c pt : ptList9) { Map productMap = new Map(); productMap.put('label', pt.Name); productMap.put('value', pt.Id); impProList.add(productMap); } impProMap.put(dc[8], impProList); } if (dc.size() > 9) { List ptList10 = new List(); List dcList = dc[9].split('-'); if (dcList.size() > 1) { ptList10 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] AND OPD_SIS_Type__c = :dcList[1] ]; } else { ptList10 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] ]; } List> impProList = new List>(); for (ProductTypes__c pt : ptList10) { Map productMap = new Map(); productMap.put('label', pt.Name); productMap.put('value', pt.Id); impProList.add(productMap); } impProMap.put(dc[9], impProList); } if (dc.size() > 10) { List ptList11 = new List(); List dcList = dc[10].split('-'); if (dcList.size() > 1) { ptList11 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] AND OPD_SIS_Type__c = :dcList[1] ]; } else { ptList11 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] ]; } List> impProList = new List>(); for (ProductTypes__c pt : ptList11) { Map productMap = new Map(); productMap.put('label', pt.Name); productMap.put('value', pt.Id); impProList.add(productMap); } impProMap.put(dc[10], impProList); } if (dc.size() > 11) { List ptList12 = new List(); List dcList = dc[11].split('-'); if (dcList.size() > 1) { ptList12 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] AND OPD_SIS_Type__c = :dcList[1] ]; } else { ptList12 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] ]; } List> impProList = new List>(); for (ProductTypes__c pt : ptList12) { Map productMap = new Map(); productMap.put('label', pt.Name); productMap.put('value', pt.Id); impProList.add(productMap); } impProMap.put(dc[11], impProList); } if (dc.size() > 12) { List ptList13 = new List(); List dcList = dc[12].split('-'); if (dcList.size() > 1) { ptList13 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] AND OPD_SIS_Type__c = :dcList[1] ]; } else { ptList13 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] ]; } List> impProList = new List>(); for (ProductTypes__c pt : ptList13) { Map productMap = new Map(); productMap.put('label', pt.Name); productMap.put('value', pt.Id); impProList.add(productMap); } impProMap.put(dc[12], impProList); } if (dc.size() > 13) { List ptList14 = new List(); List dcList = dc[13].split('-'); if (dcList.size() > 1) { ptList14 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] AND OPD_SIS_Type__c = :dcList[1] ]; } else { ptList14 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] ]; } List> impProList = new List>(); for (ProductTypes__c pt : ptList14) { Map productMap = new Map(); productMap.put('label', pt.Name); productMap.put('value', pt.Id); impProList.add(productMap); } impProMap.put(dc[13], impProList); } if (dc.size() > 14) { List ptList15 = new List(); List dcList = dc[14].split('-'); if (dcList.size() > 1) { ptList15 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] AND OPD_SIS_Type__c = :dcList[1] ]; } else { ptList15 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] ]; } List> impProList = new List>(); for (ProductTypes__c pt : ptList15) { Map productMap = new Map(); productMap.put('label', pt.Name); productMap.put('value', pt.Id); impProList.add(productMap); } impProMap.put(dc[14], impProList); } if (dc.size() > 15) { List ptList16 = new List(); List dcList = dc[15].split('-'); if (dcList.size() > 1) { ptList16 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] AND OPD_SIS_Type__c = :dcList[1] ]; } else { ptList16 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] ]; } List> impProList = new List>(); for (ProductTypes__c pt : ptList16) { Map productMap = new Map(); productMap.put('label', pt.Name); productMap.put('value', pt.Id); impProList.add(productMap); } impProMap.put(dc[15], impProList); } if (dc.size() > 16) { List ptList17 = new List(); List dcList = dc[16].split('-'); if (dcList.size() > 1) { ptList17 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] AND OPD_SIS_Type__c = :dcList[1] ]; } else { ptList17 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] ]; } List> impProList = new List>(); for (ProductTypes__c pt : ptList17) { Map productMap = new Map(); productMap.put('label', pt.Name); productMap.put('value', pt.Id); impProList.add(productMap); } impProMap.put(dc[16], impProList); } if (dc.size() > 17) { List ptList18 = new List(); List dcList = dc[17].split('-'); if (dcList.size() > 1) { ptList18 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] AND OPD_SIS_Type__c = :dcList[1] ]; } else { ptList18 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] ]; } List> impProList = new List>(); for (ProductTypes__c pt : ptList18) { Map productMap = new Map(); productMap.put('label', pt.Name); productMap.put('value', pt.Id); impProList.add(productMap); } impProMap.put(dc[17], impProList); } if (dc.size() > 18) { List ptList19 = new List(); List dcList = dc[18].split('-'); if (dcList.size() > 1) { ptList19 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] AND OPD_SIS_Type__c = :dcList[1] ]; } else { ptList19 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] ]; } List> impProList = new List>(); for (ProductTypes__c pt : ptList19) { Map productMap = new Map(); productMap.put('label', pt.Name); productMap.put('value', pt.Id); impProList.add(productMap); } impProMap.put(dc[18], impProList); } if (dc.size() > 19) { List ptList20 = new List(); List dcList = dc[19].split('-'); if (dcList.size() > 1) { ptList20 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] AND OPD_SIS_Type__c = :dcList[1] ]; } else { ptList20 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] ]; } List> impProList = new List>(); for (ProductTypes__c pt : ptList20) { Map productMap = new Map(); productMap.put('label', pt.Name); productMap.put('value', pt.Id); impProList.add(productMap); } impProMap.put(dc[19], impProList); } if (dc.size() > 20) { List ptList21 = new List(); List dcList = dc[20].split('-'); if (dcList.size() > 1) { ptList21 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] AND OPD_SIS_Type__c = :dcList[1] ]; } else { ptList21 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] ]; } List> impProList = new List>(); for (ProductTypes__c pt : ptList21) { Map productMap = new Map(); productMap.put('label', pt.Name); productMap.put('value', pt.Id); impProList.add(productMap); } impProMap.put(dc[20], impProList); } if (dc.size() > 21) { List ptList22 = new List(); List dcList = dc[21].split('-'); if (dcList.size() > 1) { ptList22 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] AND OPD_SIS_Type__c = :dcList[1] ]; } else { ptList22 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] ]; } List> impProList = new List>(); for (ProductTypes__c pt : ptList22) { Map productMap = new Map(); productMap.put('label', pt.Name); productMap.put('value', pt.Id); impProList.add(productMap); } impProMap.put(dc[21], impProList); } if (dc.size() > 22) { List ptList23 = new List(); List dcList = dc[22].split('-'); if (dcList.size() > 1) { ptList23 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] AND OPD_SIS_Type__c = :dcList[1] ]; } else { ptList23 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] ]; } List> impProList = new List>(); for (ProductTypes__c pt : ptList23) { Map productMap = new Map(); productMap.put('label', pt.Name); productMap.put('value', pt.Id); impProList.add(productMap); } impProMap.put(dc[22], impProList); } if (dc.size() > 23) { List ptList24 = new List(); List dcList = dc[23].split('-'); if (dcList.size() > 1) { ptList24 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] AND OPD_SIS_Type__c = :dcList[1] ]; } else { ptList24 = [ SELECT Id, Name, Department_Cateogy__c, OPD_Flg__c, SIS_Flg__c FROM ProductTypes__c WHERE DeleteFlg__c = FALSE AND Department_Cateogy_Text__c LIKE :dcList[0] ]; } List> impProList = new List>(); for (ProductTypes__c pt : ptList24) { Map productMap = new Map(); productMap.put('label', pt.Name); productMap.put('value', pt.Id); impProList.add(productMap); } impProMap.put(dc[23], impProList); } return impProMap; } // 批量添加周报by vivek end //zhj MEBG新方案改造 2022-11-29 start @AuraEnabled public static ControllerResponse searchAgencyDataId(String hospitalId) { ControllerResponse r = new ControllerResponse(); try { if (String.isBlank(hospitalId)) { r.IsSuccess = true; r.Message = 'noHospitalId'; return r; } List acList = [ SELECT id, AWS_Data_Id__c, Agency_Hospital__r.Name FROM Agency_Contact__c WHERE Agency_Hospital__c = :hospitalId ]; r.IsSuccess = true; r.Message = ''; r.Data = acList; return r; } catch (Exception e) { System.debug('into catch' + e.getMessage()); r.IsSuccess = false; r.message = e.getMessage() + e.getStackTraceString(); return r; } } //zhj MEBG新方案改造 2022-11-29 end }